diff --git a/app.json b/app.json index d99c439..a335f10 100644 --- a/app.json +++ b/app.json @@ -21,6 +21,7 @@ "navigationBarBackgroundColor": "#ffffff" }, "tabBar": { + "custom": true, "color": "#515151", "selectedColor": "#FE9944", "list": [{ diff --git a/app.wxss b/app.wxss index 483aee3..aee1f19 100644 --- a/app.wxss +++ b/app.wxss @@ -8,7 +8,7 @@ page { .page-container { display: flex; flex-direction: column; - padding: 20rpx; + padding: 15px; } ::-webkit-scrollbar { @@ -21,8 +21,6 @@ page { .custom-navbar { display: flex; align-items: center; - padding-left: 20rpx; - padding-right: 20rpx; background-color: transparent; /* box-shadow: 0 2rpx 4rpx rgba(0, 0, 0, 0.05); */ } diff --git a/components/tabbar/custom-tabbar.js b/components/tabbar/custom-tabbar.js new file mode 100644 index 0000000..f116dff --- /dev/null +++ b/components/tabbar/custom-tabbar.js @@ -0,0 +1,40 @@ +Component({ + properties: { + tabList: { + type: Array, + value: [] + }, + color: { + type: String, + value: '#515151' + }, + selectedColor: { + type: String, + value: '#FE9944' + } + }, + data: {}, + attached() { + // 获取当前页面路径 + const pages = getCurrentPages(); + const currentPage = pages[pages.length - 1]; + const currentPath = `/${currentPage.route}`; + const index = this.data.tabList.findIndex(item => item.pagePath === currentPath); + if (index !== -1) { + this.setData({ + selected: index + }); + } + }, + methods: { + switchTab(e) { + console.log('点击了') + const index = e.currentTarget.dataset.index; + const pagePath = this.data.tabList[index].pagePath; + console.log(index, pagePath) + wx.switchTab({ + url: '/' + pagePath + }); + } + } +}); \ No newline at end of file diff --git a/components/tabbar/custom-tabbar.json b/components/tabbar/custom-tabbar.json new file mode 100644 index 0000000..e8cfaaf --- /dev/null +++ b/components/tabbar/custom-tabbar.json @@ -0,0 +1,4 @@ +{ + "component": true, + "usingComponents": {} +} \ No newline at end of file diff --git a/components/tabbar/custom-tabbar.wxml b/components/tabbar/custom-tabbar.wxml new file mode 100644 index 0000000..480edb9 --- /dev/null +++ b/components/tabbar/custom-tabbar.wxml @@ -0,0 +1,6 @@ + + + + {{item.text}} + + \ No newline at end of file diff --git a/components/tabbar/custom-tabbar.wxss b/components/tabbar/custom-tabbar.wxss new file mode 100644 index 0000000..0f46d84 --- /dev/null +++ b/components/tabbar/custom-tabbar.wxss @@ -0,0 +1,29 @@ +.tabbar { + position: fixed; + bottom: 0; + left: 0; + width: 100%; + height: 160rpx; + background-color: #FFFFFF; + display: flex; + justify-content: space-around; + align-items: center; + border-top: 1px solid #EEEEEE; +} + +.tabbar-item { + display: flex; + flex-direction: column; + align-items: center; + justify-content: center; +} + +.tabbar-icon { + width: 24px; + height: 24px; + margin-bottom: 2px; +} + +.tabbar-text { + font-size: 12px; +} \ No newline at end of file diff --git a/net/api/projectApi.js b/net/api/projectApi.js index db0a9c2..08719b2 100644 --- a/net/api/projectApi.js +++ b/net/api/projectApi.js @@ -12,6 +12,7 @@ const apiPath = { getPackageList: '/api/proj/servicepkg/packageorder/listpage/self', //获取套餐包 getCommendProjectName: '/api/proj/recommend/list-proj-name/ai', //推荐项目名称 createProject: '/api/proj/create-quick', //快速创建项目 + buildProject: '/api/proj/create-quick/proj-id/{projId}', //生成项目 reCreate: '/api/proj/generate/proj-id/${projId}', //重新生成 proLangList: '/api/env/custom/list-active-lang', //项目语言 ruleData: '/app/agreementportal/getrelease/{id}', //使用规则 project="operator" @@ -53,6 +54,11 @@ class ProjectService { static doCreateProject(data) { return request(apiPath.createProject, "POST", data) } + //生成项目 + static doBuildProject(id) { + const path = apiPath.buildProject.replace('{projId}', id) + return request(path, "GET") + } //重新生成 static doReCreate(url) { const path = apiPath.reCreate.replace('${projId}', url) diff --git a/net/http.js b/net/http.js index febaee2..0f1d7ed 100644 --- a/net/http.js +++ b/net/http.js @@ -31,7 +31,7 @@ function request(url, method = "GET", data = {}, params = {}, project = "copyrig baseUrl = operatorUrl } else if (project == 'copyright') { baseUrl = copyrightUrl - } else if(project=='online') { + } else if (project == 'online') { baseUrl = 'https://www.aimzhu.com/operator' } return new Promise(function (resolve, reject) { diff --git a/pages/copyright/createProjectInfo/createProjectInfo.js b/pages/copyright/createProjectInfo/createProjectInfo.js index 0943a3f..168fc00 100644 --- a/pages/copyright/createProjectInfo/createProjectInfo.js +++ b/pages/copyright/createProjectInfo/createProjectInfo.js @@ -9,7 +9,7 @@ const { Page({ data: { date: utils.formatDate(new Date()), - completeDate: utils.formatDate(new Date()), //开发完成时间 + completeDate: '', //开发完成时间 version: "v1.0", //系统版本 type: 'ALL', //默认全托管 上级页面传递type参数 all全托管 material写材料 languageList: ['JAVA'], @@ -50,6 +50,7 @@ Page({ urgent: 0, //加急费用 isUrgentDisable: false, //是否禁用加急 proPrice: 0, //价格 + transmitPId: '', //传递过来的套餐包ID }, onLoad(options) { wx.setNavigationBarTitle({ @@ -65,21 +66,25 @@ Page({ }) const typeParams = options.type //类型 const priceParams = options.price //价格 - const isUrgentParams = options.isUrgent + const isUrgentParams = options.isUrgent //是否加急 + const pId = options.pId //套餐包ID console.log(priceParams) if (priceParams && priceParams > 0) { this.setData({ price: priceParams, proPrice: priceParams, type: typeParams, - isUrgent: isUrgentParams + isUrgent: isUrgentParams, + transmitPId: pId }) } else { - wx.showToast({ - title: '数据有误,请重试', - icon: 'error' + this.setData({ + errorHint: '数据有误,请稍后重试', + showError: true }) - wx.navigateBack() + setTimeout(() => { + wx.navigateBack() + }, 1000); } if (this.data.type == 'ALL') { this.setData({ @@ -297,6 +302,23 @@ Page({ _self.setData({ packageList: res.rows }) + if (_self.data.transmitPId != '' && _self.data.transmitPId != 'undefined') { + res.rows.map(item => { + if (item.packageInfoId == _self.data.transmitPId) { + _self.setData({ + selectPackage: item, + showPackage: false, + tempPackage: {}, + canSelCoupons: false, + selectCoupons: {}, + tempCoupons: {}, + isUrgent: false, //取消加急 + isUrgentDisable: true, //加急不能选择 + price: 0 + }) + } + }) + } }, err => { console.log(err) _self.setData({ @@ -472,6 +494,11 @@ Page({ }) } }, + clearTime() { + this.setData({ + completeDate: '' + }) + }, //保存联系人 doSaveContact() { //校验参数 @@ -486,7 +513,7 @@ Page({ if (_self.data.contactPhone == '' || !isValidPhone(_self.data.contactPhone)) { _self.setData({ showError: true, - errorHint: '请输入合法的联系电话' + errorHint: '请输入正确的联系电话' }) return } @@ -494,7 +521,7 @@ Page({ if (!isValidEmail(_self.data.contactEmail)) { _self.setData({ showError: true, - errorHint: '请输入合法的邮箱' + errorHint: '请输入正确的邮箱' }) return } diff --git a/pages/copyright/createProjectInfo/createProjectInfo.wxml b/pages/copyright/createProjectInfo/createProjectInfo.wxml index d3a858f..90dc0a4 100644 --- a/pages/copyright/createProjectInfo/createProjectInfo.wxml +++ b/pages/copyright/createProjectInfo/createProjectInfo.wxml @@ -10,7 +10,7 @@ 项目信息 - + 推荐 @@ -20,7 +20,7 @@ 产权联系人 - {{selectContact.name}} + {{selectContact.name}} @@ -29,13 +29,13 @@ 系统版本 - + 系统语言 - {{selectLang}} + {{selectLang}} @@ -43,12 +43,13 @@ 开发完成时间 - - - {{completeDate}} - - + + {{completeDate != ''? completeDate:'请选择开发完成时间'}} + + + + @@ -56,12 +57,12 @@ 套餐包 - {{selectPackage.packageName?selectPackage.packageName:'请选择套餐包'}} + {{selectPackage.packageName?selectPackage.packageName:'请选择套餐包'}} 取消 优惠券 - {{selectCoupons.couponId? selectCoupons.coupon.title : '请选择优惠券'}} + {{selectCoupons.couponId? selectCoupons.coupon.title : '请选择优惠券'}} 取消 选择 @@ -87,24 +88,24 @@ 姓名 - + 联系电话 - 联系邮箱 - + 联系邮箱 + - 公司 + 公司 - + @@ -113,7 +114,7 @@ - + {{item}} @@ -121,37 +122,39 @@ - - + + 优惠卷 - - - - - - - - + + + + + + + + + + + 优惠卷 - 优惠卷 + 减{{item.coupon.amount/100}}元 - 减{{item.coupon.amount/100}}元 + {{item.coupon.title}} + 有效期:{{item.coupon.useGmtStart}}至{{item.coupon.useGmtEnd}} + + + - {{item.coupon.title}} - 有效期:{{item.coupon.useGmtStart}}至{{item.coupon.useGmtEnd}} - - - - - - - + + + + @@ -161,25 +164,27 @@ 套餐包 - - - - - - - 套餐包 - 剩余{{item.packageTotalSurplusCount}}件 + + + + + + + + 套餐包 + 剩余{{item.packageTotalSurplusCount}}件 + + {{item.packageInfoAppDTO.packageName}} + {{item.packageInfoAppDTO.packageDescription}} + + + - {{item.packageInfoAppDTO.packageName}} - {{item.packageInfoAppDTO.packageDescription}} - - - - - - - + + + + diff --git a/pages/copyright/createProjectInfo/createProjectInfo.wxss b/pages/copyright/createProjectInfo/createProjectInfo.wxss index adeb8bd..b52e0f1 100644 --- a/pages/copyright/createProjectInfo/createProjectInfo.wxss +++ b/pages/copyright/createProjectInfo/createProjectInfo.wxss @@ -62,15 +62,18 @@ page { .info-title { font-size: 36rpx; - font-weight: 500; + font-weight: bold; } .info-value { margin-top: 20rpx; border: 1rpx solid #f2f2f2; - padding: 24rpx; - font-size: 28rpx; + font-size: 14px; + line-height: 16px; background-color: white; + height: 65rpx; + width: auto; + padding: 15px; } .info-btn { @@ -104,6 +107,7 @@ page { .label { color: black; + font-weight: bold; } .desc { @@ -118,18 +122,46 @@ page { align-items: center; } +.select-time { + color: #000000; + flex: 1; + font-size: 14px; + text-align: left; + padding-left: 30rpx; +} + +.clear-icon { + width: 20px; + height: 20px; + margin-right: 20rpx; +} + .desc .icon { width: 32rpx; height: 32rpx; } .value { - color: #666; + color: #9A9A9A; padding-right: 10px; + flex: 1; + text-align: right; + padding-right: 10px; + font-size: 14px; } + +.value-hint { + color: #9A9A9A; +} + +.v-select { + color: #000000; +} + + .language-sel { - font-size: 30rpx; + font-size: 14px; flex: 1; text-align: center; } @@ -171,6 +203,8 @@ page { background-color: #f0f0f0; } +.weui-half-screen-dialog__ft {} + .bottom-box { position: fixed; left: 0; @@ -234,7 +268,7 @@ page { text-align: left; } -.form-item-title:not(.no-after)::after { +.form-item-title:not(.no-after)::before { content: "*"; color: red; font-size: 14px; @@ -244,19 +278,24 @@ page { .form-item-content { flex: 1; + text-align: right; } .project-box { display: flex; - flex-direction: column; + flex-direction: row; + flex-wrap: wrap; + margin-top: 10rpx; } .project-item { - font-size: 18px; - background-color: #f5f5f5; - margin: 10px; - padding: 10px; + font-size: 24rpx; + background-color: #ffaa0034; text-align: center; + color: #FFA900; + text-align: center; + margin: 20rpx; + padding: 5rpx 20rpx; } .confirm-btn { @@ -264,15 +303,21 @@ page { color: white; font-size: 16px; height: 40px; - border-radius: 10px; + border-radius: 5px; text-align: center; + width: 85vw !important; +} + + +.weui-half-screen-dialog__bd { + padding-bottom: 40rpx; } .coupons-list-box { display: flex; flex-direction: column; justify-content: center; - align-items: flex-start; + align-items: center; } .tickets { @@ -286,7 +331,7 @@ page { width: 60vw; position: relative; padding: 10px; - background: radial-gradient(circle at right top, transparent 16rpx, #ffaa0017 0) right top / 100% 51% no-repeat, + background: radial-gradient(circle at right top, transparent 16rpx, #ffaa0017 0) right top / 100% 50% no-repeat, radial-gradient(circle at right bottom, transparent 16rpx, #ffaa0017 0) right bottom / 100% 50% no-repeat; } diff --git a/pages/copyright/payment/payment.wxss b/pages/copyright/payment/payment.wxss index c8ec7d1..f70ced8 100644 --- a/pages/copyright/payment/payment.wxss +++ b/pages/copyright/payment/payment.wxss @@ -6,7 +6,7 @@ page { } .input-money { - font-size: 24px; + font-size: 48rpx; font-weight: bold; height: 24px; line-height: 24px; diff --git a/pages/copyright/publicPay/publicPay.js b/pages/copyright/publicPay/publicPay.js index d054a35..04af02f 100644 --- a/pages/copyright/publicPay/publicPay.js +++ b/pages/copyright/publicPay/publicPay.js @@ -23,7 +23,7 @@ Page({ companyName: '', //公司名称 companyBank: '', //开户行 companyBankNum: '', //账户号码 - packageId: null, //套餐ID + packageId: '', //套餐ID payMoney: 0, //金额 packageName: '', //套餐名称 accountRechargeId: '', //订单ID @@ -50,8 +50,9 @@ Page({ // 获取完整的年月日时分秒,以及默认显示的数组 const obj = dateTimePicker.dateTimePicker(this.data.startYear, this.data.endYear); console.log(obj.dateTime) + console.log(typeof options.packageId) this.setData({ - packageId: options.packageId, //套餐包 + packageId: options.packageId && options.packageId != 'undefined' ? options.packageId : '', //套餐包 packageName: options.name, payMoney: options.money, //金额 dateTimeArray: obj.dateTimeArray, @@ -62,6 +63,7 @@ Page({ this.buildCurrentTime() this.getEnterpriseAccountInfo() //获取订单 + console.log(this.data.packageId) this.doGetOrder() }, //公司名称 @@ -114,6 +116,7 @@ Page({ title: '加载中...', }) const _self = this + console.log(_self.data.packageId) const data = { packageInfoId: _self.data.packageId ? _self.data.packageId : '', rechargeMoney: _self.data.payMoney, diff --git a/pages/copyright/publicPay/publicPay.wxss b/pages/copyright/publicPay/publicPay.wxss index 9fd6290..f1b5d89 100644 --- a/pages/copyright/publicPay/publicPay.wxss +++ b/pages/copyright/publicPay/publicPay.wxss @@ -1,7 +1,7 @@ /* pages/copyright/publicPay/publicPay.wxss */ page { background: linear-gradient(to bottom, #F0F0F0, #FFFFFF); - background-size: 100% 100vh; + background-size: 100vw 100vh; background-repeat: no-repeat; } @@ -30,9 +30,9 @@ page { display: flex; flex-direction: row; justify-content: center; - align-items: center; - width: 90vw; + align-items: flex-start; padding: 6px 20px; + width: 85vw; } .red { @@ -43,13 +43,13 @@ page { } */ .title { - flex: .3; + flex: 0.3; font-size: 14px; color: black; } .content { - flex: 1; + flex: 0.7; font-size: 14px; } @@ -132,9 +132,9 @@ page { } .input-box { - width: 60vw; + flex: 1; background-color: #FAFAFA; - border-radius: 20px; + border-radius: 2rpx; padding: 3px 8px; text-align: left; font-size: 12px; diff --git a/pages/index/index.js b/pages/index/index.js index 406ed48..548bb03 100644 --- a/pages/index/index.js +++ b/pages/index/index.js @@ -12,14 +12,19 @@ const deviceInfo = wx.getDeviceInfo() const screenInfo = wx.getWindowInfo(); const statusBarHeight = screenInfo.statusBarHeight; // 状态栏高度 const navBarHeight = deviceInfo.platform == 'IOS' ? 48 : 50; // 导航栏高度(iOS 为 44px,Android 为 48px) +const tabBarHeight = screenInfo.screenHeight - (screenInfo.safeArea ? screenInfo.safeArea.bottom : 50); +const screenHeight = screenInfo.screenHeight +const screenWidth = screenInfo.screenWidth const windowHeight = screenInfo.windowHeight - navBarHeight - statusBarHeight; //可用内容高度 - Page({ data: { statusBarHeight: statusBarHeight, navBarHeight: navBarHeight, totalHeight: navBarHeight, // 导航栏总高度 contentHeight: windowHeight, + screenHeight: screenHeight, //屏幕高度 + screenWidth: screenWidth, //屏幕宽度 + tabBarHeight: tabBarHeight, //tabbar高度 tagList: [], currentTag: '', imgUrl: previewUrl, @@ -75,10 +80,26 @@ Page({ showAd: false, //显示优惠卷广告 tempCoupons: null, //优惠卷 isNoShowToday: false, //今日不再显示 + tabList: [{ + "pagePath": "pages/index/index", + "text": "首页", + "iconPath": "/static/images/ic_home_normal.png", + "selectedIconPath": "/static/images/ic_home_select.png", + "selected": true + }, + { + "pagePath": "pages/mine/mineIndex/mine", + "text": "我的", + "iconPath": "/static/images/ic_mine_normal.png", + "selectedIconPath": "/static/images/ic_mine_select.png", + "selected": false + } + ], + color: "#515151", + selectedColor: "#FE9944", }, onLoad(e) { const _self = this - console.log(screenInfo.windowHeight) //获取通知 _self.doGetNotice() //获取标签选项 @@ -86,10 +107,6 @@ Page({ //获取列表 const params = _self.buildParams(1, true) _self.doGetSelfList(params, true) - const h = Utils.pxToRpx(_self.data.contentHeight) - _self.setData({ - contentHeight: h - }) const noShowToday = Cache.get('noShowToday') const currentDate = new Date().toLocaleDateString(); if (noShowToday && noShowToday === currentDate) { @@ -99,6 +116,41 @@ Page({ } else { _self.doGetClaimsCoupons() } + this.countViewHeight() + }, + onShow() { + const pages = getCurrentPages(); + const currentPage = pages[pages.length - 1]; + const tabList = this.data.tabList; + tabList.forEach(item => { + item.selected = item.pagePath === currentPage.route; + }); + this.setData({ + tabList + }); + }, + //计算剩余高度 + countViewHeight() { + const query = wx.createSelectorQuery(); + const _self = this + // 指定要查询的 view 元素 + query.select('#title-box').boundingClientRect(); + query.exec((res) => { + if (res[0]) { + const height = res[0].height; + //屏幕高度-内容高度-tabbar高度 + const contentHeight = _self.data.screenHeight - height - 50 + console.log('tabbarHeight:', _self.data.tabBarHeight) + const h = Utils.pxToRpx(contentHeight, _self.data.screenWidth) + const tempH = h - 130 + console.log('转后', h, '内容高度:', tempH) + _self.setData({ + contentHeight: tempH + }) + } else { + console.log('未找到指定的 view 元素'); + } + }) }, //获取可以申领的优惠卷 doGetClaimsCoupons() { @@ -381,6 +433,33 @@ Page({ downloadProgress: 0 }) }, + //去生成项目 + doCreatePro(e) { + wx.showLoading({ + title: '生成中...', + }) + const _self = this + const item = e.currentTarget.dataset.value + ProjectService.doBuildProject(item.projId) + .then(res => { + // 刷新列表 + wx.hideLoading() + console.log(res) + _self.setData({ + successHint: '正在生成中,请耐心等待', + showSuccess: true + }) + _self.doRefreshList() + }) + .catch(err => { + console.log(err) + wx.hideLoading() + _self.setData({ + errorHint: err.msg ? err.msg : '生成失败,请稍后重试', + showError: true + }) + }) + }, //重新生成 doReCreate(e) { console.log(e) diff --git a/pages/index/index.json b/pages/index/index.json index b893f35..4e7eda4 100644 --- a/pages/index/index.json +++ b/pages/index/index.json @@ -5,7 +5,8 @@ "mp-toptips": "weui-miniprogram/toptips/toptips", "down-progress": "/components/down-progress/down-progress", "mp-loading": "weui-miniprogram/loading/loading", - "ad-popup": "/components/ad-popup/ad-popup" + "ad-popup": "/components/ad-popup/ad-popup", + "custom-tabbar": "/components/tabbar/custom-tabbar" }, "navigationStyle": "custom" } \ No newline at end of file diff --git a/pages/index/index.wxml b/pages/index/index.wxml index 8dab55a..ba6a5c0 100644 --- a/pages/index/index.wxml +++ b/pages/index/index.wxml @@ -1,95 +1,105 @@ - - - AI喵著 - - - - - - 创建软著 + + + + + + AI喵著 - 充值 - - - - - {{noticeContent}} - - - - - - - - - 软著列表 - - 进行中的 - 已完成的 + + + + + 创建软著 + + 充值 + + + + + {{noticeContent}} + - - - - - {{item.label}} + + + + + + 软著列表 - - - - - {{item.label}} - - - - - - {{item.value}} - - - - - - - - - - - - - - - - - - - - - {{tools.status(item.generate.generateStatus)}} - - - - - {{item.projName}} - {{item.pay.servicePackageId != '' ? '套餐包':item.pay.charge}} - - - - {{item.apply.applyContactName}} - - - {{item.gmtCreate}} - 下载 - 重新生成 - + + 进行中的 + 已完成的 - - + + + + + {{item.label}} + + + + + + {{item.label}} + + + + + + {{item.value}} + + + + + - - + + + + + + + + + + + + + + + + + {{tools.status(item.generate.generateStatus,item.aiSetting.settingStatus)}} + + + + + {{item.projName}} + {{item.pay.servicePackageId != '' ? '套餐包':item.pay.charge}} + + + + {{item.apply.applyContactName}} + + + {{item.gmtCreate}} + 下载 + 重新生成 + 生成 + + + + + + + + + + + 资料下载 diff --git a/pages/index/index.wxss b/pages/index/index.wxss index 136e7a6..c7372c0 100644 --- a/pages/index/index.wxss +++ b/pages/index/index.wxss @@ -9,18 +9,24 @@ display: flex; flex-direction: column; padding: 20rpx; - margin-top: -50rpx; - margin-left: 20rpx; - margin-right: 20rpx; - border-radius: 10rpx; + margin-left: 30rpx; + margin-right: 30rpx; + border-bottom-left-radius: 10rpx; + border-bottom-right-radius: 10rpx; background-color: rgba(255, 255, 255, 1); - box-shadow: 0rpx 2rpx 6rpx 0rpx rgba(206, 206, 206, 0.4); + box-shadow: 0rpx 2rpx 6rpx 0rpx rgba(206, 206, 206, 0.6); } .container-title { display: flex; flex-direction: column; - height: 80px; +} + +.title-box { + display: flex; + flex-direction: column; + justify-content: flex-start; + padding: 0rpx 30rpx; } .title-func { @@ -91,13 +97,27 @@ .container-box { display: flex; flex-direction: column; + background-color: white; + padding: 20rpx; + border-top-left-radius: 10rpx; + border-top-right-radius: 10rpx; margin-top: 20rpx; + background-color: rgba(255, 255, 255, 1); + box-shadow: 0rpx -6rpx 6rpx 0rpx rgba(206, 206, 206, 0.1); } .list-title-box { display: flex; flex-direction: row; justify-content: space-between; + align-items: center; +} + +.title-line { + width: 10rpx; + height: 32rpx; + border-radius: 17rpx; + background-color: rgba(255, 169, 0, 1); } .list-title-txt { @@ -106,6 +126,10 @@ font-size: 16px; font-family: TaipeiHei-bold; font-weight: bold; + display: flex; + flex-direction: row; + justify-content: center; + align-items: center; } .list-title-btns { @@ -189,6 +213,7 @@ background-color: #F7F7F7; border-radius: 2px; padding: 5px; + align-items: center; } .list-item:nth-of-type(n+2) { @@ -203,31 +228,50 @@ } .item-img .cover { - width: 95px; - height: 68px; + width: 210rpx; + height: 136rpx; border-radius: 2px; } .item-img-status { - background-color: #AFE5C7; text-align: center; position: absolute; bottom: 0; left: 0; - width: 95px; + width: 210rpx; font-size: 24rpx; border-bottom-left-radius: 2px; border-bottom-right-radius: 2px; } +.status-gray { + background-color: #adadadc0; + color: black; +} + +.status-green { + background-color: #AFE5C7; + color: black; +} + +.status-yellow { + background-color: #fe9844c0; + color: black; +} + +.status-red { + background-color: #FF0000C0; + color: white; +} + .item-content { display: flex; flex-direction: column; justify-content: space-between; flex: 1; height: 72px; - padding-left: 16px; - width: 90vw; + padding-left: 16rpx; + min-width: 0; } .item-content-title { @@ -235,7 +279,6 @@ flex-direction: row; justify-content: space-between; align-items: center; - width: 59vw; } @@ -245,6 +288,10 @@ text-align: left; font-weight: bold; flex: 1; + display: block; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; } .project-status { @@ -254,12 +301,14 @@ flex: .3; padding-left: 5px; text-align: center; + white-space: nowrap; } .item-content-title { display: flex; flex-direction: row; justify-content: space-between; + min-width: 0; } .project-aff { @@ -287,7 +336,6 @@ flex-direction: row; justify-content: space-between; align-items: flex-end; - width: 57vw; } .project-create-time { @@ -296,7 +344,7 @@ } .project-btn { - font-size: 28rpx; + font-size: 24rpx; background-color: #FE9944; color: white; padding: 2px 10px; @@ -505,5 +553,5 @@ .weui-half-screen-dialog__ft { height: 0; - padding: 0; + /* padding: 0; */ } \ No newline at end of file diff --git a/pages/login/login.js b/pages/login/login.js index 83ac14c..89c8e43 100644 --- a/pages/login/login.js +++ b/pages/login/login.js @@ -128,11 +128,11 @@ Page({ Cache.set("token", res.accessToken); //创建所属人 if (res.phone && res.phone != '') { + //判断是否存在所属人 _self.setData({ phone: res.phone }) - _self.doUpdateUserInfo('') - _self.doGetCsaNo() + _self.doGetMineContact() } else { //获取客服编号 wx.switchTab({ @@ -153,6 +153,34 @@ Page({ _self.doShowExit() } }, + //判断是否需要创建联系人 + doGetMineContact() { + wx.showLoading({ + title: '加载中...', + }) + const data = { + page: 1, + rows: 2 + } + UserApi.doGetMineContactList(data) + .then(res => { + wx.hideLoading() + if (res.rows && res.rows.length <= 0) { + //需要创建 + _self.doUpdateUserInfo('') + _self.doGetCsaNo() + } else { + //无需创建 + wx.switchTab({ + url: '/pages/index/index', + }) + } + }) + .catch(err => { + wx.hideLoading() + _self.doShowExit() + }) + }, //创建用户 doUpdateUserInfo(name) { const _self = this diff --git a/pages/login/login.wxss b/pages/login/login.wxss index c627065..5229d50 100644 --- a/pages/login/login.wxss +++ b/pages/login/login.wxss @@ -38,6 +38,8 @@ wx-checkbox .wx-checkbox-input.wx-checkbox-input-checked:before { background-image: url(''); width: 100vw; height: 100vh; + background-size: cover; + background-repeat: no-repeat; } .btn-content { @@ -69,14 +71,17 @@ wx-checkbox .wx-checkbox-input.wx-checkbox-input-checked:before { } .btn { - background-color: green; - color: white; animation: clickScale 1.2s; animation-iteration-count: infinite; animation-timing-function: ease-in-out; - border-radius: 50rpx; - margin-top: 30rpx; + margin-top: 40rpx; font-size: 24rpx; + line-height: 20px; + border-radius: 45px; + background-color: rgba(255, 169, 0, 1); + color: rgba(255, 255, 255, 1); + text-align: center; + font-family: PingFangSC-regular; } @keyframes clickScale { @@ -139,7 +144,7 @@ wx-checkbox .wx-checkbox-input.wx-checkbox-input-checked:before { } .weui-half-screen-dialog__ft { - padding: 15px; + /* padding: 15px; */ text-align: center; } diff --git a/pages/mine/mineAccount/mineContact/mineContact.js b/pages/mine/mineAccount/mineContact/mineContact.js index 5e933b0..3e4fea3 100644 --- a/pages/mine/mineAccount/mineContact/mineContact.js +++ b/pages/mine/mineAccount/mineContact/mineContact.js @@ -179,7 +179,7 @@ Page({ if (_self.data.contactPhone == '' || !isValidPhone(_self.data.contactPhone)) { _self.setData({ showError: true, - errorHint: '请输入合法的联系电话' + errorHint: '请输入正确的联系电话' }) return } @@ -187,7 +187,7 @@ Page({ if (!isValidEmail(_self.data.contactEmail)) { _self.setData({ showError: true, - errorHint: '请输入合法的邮箱' + errorHint: '请输入正确的邮箱' }) return } @@ -240,7 +240,7 @@ Page({ if (_self.data.contactPhone == '' || !isValidPhone(_self.data.contactPhone)) { _self.setData({ showError: true, - errorHint: '请输入合法的联系电话' + errorHint: '请输入正确的联系电话' }) return } @@ -248,7 +248,7 @@ Page({ if (!isValidEmail(_self.data.contactEmail)) { _self.setData({ showError: true, - errorHint: '请输入合法的邮箱' + errorHint: '请输入正确的邮箱' }) return } diff --git a/pages/mine/mineAccount/mineContact/mineContact.wxml b/pages/mine/mineAccount/mineContact/mineContact.wxml index 717ce0b..68c9120 100644 --- a/pages/mine/mineAccount/mineContact/mineContact.wxml +++ b/pages/mine/mineAccount/mineContact/mineContact.wxml @@ -15,7 +15,7 @@ - {{item.name}} + {{item.name}} {{item.phone}} @@ -41,25 +41,25 @@ 姓名 - + 联系电话 - 联系邮箱 - + 联系邮箱 + - 公司 + 公司 - - + + diff --git a/pages/mine/mineAccount/mineContact/mineContact.wxss b/pages/mine/mineAccount/mineContact/mineContact.wxss index af13e17..b3a5abf 100644 --- a/pages/mine/mineAccount/mineContact/mineContact.wxss +++ b/pages/mine/mineAccount/mineContact/mineContact.wxss @@ -17,10 +17,12 @@ page { position: fixed; top: 0; left: 0; - width: 97vw; display: flex; flex-direction: row; align-items: center; + justify-content: center; + align-self: center; + width: 96vw; } .search-container { @@ -29,7 +31,7 @@ page { border-radius: 5px; background-color: rgba(255, 255, 255, 1); font-family: -regular; - margin: 10px; + margin: 10px 15px; padding: 5px; display: flex; flex-direction: row; @@ -114,6 +116,15 @@ page { align-items: center; } +.name { + line-height: 23rpx; + color: rgba(0, 0, 0, 1); + font-size: 32rpx; + text-align: left; + font-weight: bold; + font-family: SourceHanSansSC-black; +} + .service-desc { padding: 0px 15px 15px 15px; line-height: 20px; @@ -128,10 +139,10 @@ page { border-radius: 4px; background-color: rgba(122, 196, 131, 0.42); color: rgba(255, 255, 255, 1); - font-size: 14px; + font-size: 28rpx; text-align: center; font-family: PingFangSC-regular; - padding: 5px 15px; + padding: 5rpx 10rpx; } .del { @@ -139,10 +150,10 @@ page { border-radius: 4px; background-color: rgba(247, 49, 42, 0.42); color: rgba(255, 255, 255, 1); - font-size: 14px; + font-size: 28rpx; text-align: center; font-family: PingFangSC-regular; - padding: 5px 15px; + padding: 5rpx 10rpx; margin-left: 5px; } @@ -188,7 +199,7 @@ page { text-align: left; } -.form-item-title:not(.no-after)::after { +.form-item-title:not(.no-after)::before { content: "*"; color: red; font-size: 14px; @@ -198,4 +209,23 @@ page { .form-item-content { flex: 1; + text-align: right; +} + +.confirm-btn { + background-color: green; + color: white; + font-size: 16px; + height: 40px; + border-radius: 5px; + text-align: center; + width: 85vw !important; +} + +.weui-half-screen-dialog__ft { + /* padding: 0rpx; */ +} + +.weui-half-screen-dialog__bd { + padding-bottom: 40rpx; } \ No newline at end of file diff --git a/pages/mine/mineAccount/mineOrder/mineOrder.wxml b/pages/mine/mineAccount/mineOrder/mineOrder.wxml index c6960bb..13ab7c2 100644 --- a/pages/mine/mineAccount/mineOrder/mineOrder.wxml +++ b/pages/mine/mineAccount/mineOrder/mineOrder.wxml @@ -5,41 +5,39 @@ - - - - - - - - 订单号:{{item.orderNo}} - {{tools.orderStatus(item.orderStatus)}} - - - - {{detail.productName}} - - {{tools.proType(detail.productType)}} - 数量{{detail.quantity}} - 单价{{detail.unitPrice/100}} - 总金额{{item.totalAmount/100}} - - - 订单备注 - {{detail.notes}} - - - 商品描述 - {{detail.productDescription}} - - - + + + + + + + 订单号:{{item.orderNo}} + {{tools.orderStatus(item.orderStatus)}} - - - - - - + + + {{detail.productName}} + + {{tools.proType(detail.productType)}} + 数量{{detail.quantity}} + 单价{{detail.unitPrice/100}} + 总金额{{item.totalAmount/100}} + + + 订单备注 + {{detail.notes}} + + + 商品描述 + {{detail.productDescription}} + + + + + + + + + \ No newline at end of file diff --git a/pages/mine/mineAccount/mineOrder/mineOrder.wxss b/pages/mine/mineAccount/mineOrder/mineOrder.wxss index be92dfa..25ba17d 100644 --- a/pages/mine/mineAccount/mineOrder/mineOrder.wxss +++ b/pages/mine/mineAccount/mineOrder/mineOrder.wxss @@ -1,6 +1,6 @@ page { background: linear-gradient(to bottom, #F0F0F0, #FFFFFF); - background-size: 100% 100vh; + background-size: 100vw 100vh; background-repeat: no-repeat; } @@ -15,10 +15,10 @@ page { .search-container { position: relative; align-self: center; - border-radius: 5px; + border-radius: 5rpx; background-color: rgba(255, 255, 255, 1); font-family: -regular; - margin: 10px; + margin: 20rpx 30rpx; padding: 5px; display: flex; flex-direction: row; @@ -51,6 +51,7 @@ page { .content-container { height: 86vh; margin-top: 50px; + width: 100vw; } @@ -58,14 +59,13 @@ page { display: flex; flex-direction: column; justify-content: center; - align-items: center; - width: 100vw; + padding-bottom: 30px; } .order-item { display: flex; flex-direction: column; - width: 100vw; + flex-grow: 1; } .order-item:nth-of-type(n+2) { @@ -77,9 +77,10 @@ page { flex-direction: row; justify-content: space-between; align-items: center; - width: 87vw; padding: 8px 17px; background-color: #7AC483; + border-top-left-radius: 5rpx; + border-top-right-radius: 5rpx; } .order-no { @@ -98,9 +99,10 @@ page { display: flex; flex-direction: column; justify-content: center; - align-items: flex-start; background-color: white; padding: 17px; + border-bottom-left-radius: 5rpx; + border-bottom-right-radius: 5rpx; } .order-caption { @@ -116,7 +118,6 @@ page { flex-direction: row; justify-content: space-between; align-items: center; - width: 87vw; margin-top: 15px; } @@ -151,10 +152,8 @@ page { .order-remark-box { display: flex; flex-direction: row; - justify-content: center; align-items: center; margin-top: 10px; - width: 87vw; } .order-remark-title { @@ -166,7 +165,7 @@ page { .order-remark-content { color: rgba(16, 16, 16, 1); - font-size: 10px; + font-size: 20rpx; text-align: left; font-family: PingFangSC-light; border-radius: 5px; diff --git a/pages/mine/mineIndex/mine.js b/pages/mine/mineIndex/mine.js index eb70622..9d7315f 100644 --- a/pages/mine/mineIndex/mine.js +++ b/pages/mine/mineIndex/mine.js @@ -1,5 +1,6 @@ // pages/mine/mine.js import UserApi from '../../../net/api/userApi' +import ProApi from '../../../net/api/projectApi' import { copyrightUrl } from '../../../net/http' @@ -9,6 +10,9 @@ const deviceInfo = wx.getDeviceInfo() const screenInfo = wx.getWindowInfo(); const statusBarHeight = screenInfo.statusBarHeight; // 状态栏高度 const navBarHeight = deviceInfo.platform == 'IOS' ? 48 : 50; // 导航栏高度(iOS 为 44px,Android 为 48px) +const tabBarHeight = screenInfo.screenHeight - (screenInfo.safeArea ? screenInfo.safeArea.bottom : 50); +const screenHeight = screenInfo.screenHeight +const screenWidth = screenInfo.screenWidth const windowHeight = screenInfo.windowHeight - navBarHeight - statusBarHeight; //可用内容高度 Page({ @@ -20,6 +24,9 @@ Page({ navBarHeight: navBarHeight, totalHeight: navBarHeight, // 导航栏总高度 contentHeight: windowHeight, + screenHeight: screenHeight, //屏幕高度 + screenWidth: screenWidth, //屏幕宽度 + tabBarHeight: tabBarHeight, //tabbar高度 allCount: 0, materialCount: 0, accountInfo: {}, @@ -49,6 +56,26 @@ Page({ errorHint: '', animationData: {}, //刷新动画 animation: null, + tabList: [{ + "pagePath": "pages/index/index", + "text": "首页", + "iconPath": "/static/images/ic_home_normal.png", + "selectedIconPath": "/static/images/ic_home_select.png", + "selected": true + }, + { + "pagePath": "pages/mine/mineIndex/mine", + "text": "我的", + "iconPath": "/static/images/ic_mine_normal.png", + "selectedIconPath": "/static/images/ic_mine_select.png", + "selected": false + } + ], + color: "#515151", + selectedColor: "#FE9944", + allPrice: 0, //全托管价格 + materialPrice: 0, //写材料价格 + urgent: 0, //加急价格 }, /** @@ -58,10 +85,6 @@ Page({ const _self = this _self.getMineAccount() _self.getMinePackageCount() - const h = Utils.pxToRpx(_self.data.contentHeight) - _self.setData({ - contentHeight: h - }) // 创建一个动画实例 const animation = wx.createAnimation({ duration: 1000, @@ -70,6 +93,125 @@ Page({ this.setData({ animation: animation }) + this.countViewHeight() + this.doGetPrice() + }, + //计算高度 + countViewHeight() { + // + const query = wx.createSelectorQuery(); + const _self = this + // 指定要查询的 view 元素 + query.select('#func-box').boundingClientRect(); + query.exec((res) => { + if (res[0]) { + const height = res[0].height; + //屏幕高度-内容高度-tabbar高度 + const contentHeight = _self.data.screenHeight - height - 50 + const h = Utils.pxToRpx(contentHeight, _self.data.screenWidth) + const tempH = h - 140 + console.log('转后', h, '内容高度:', tempH) + _self.setData({ + contentHeight: tempH + }) + } else { + console.log('未找到指定的 view 元素'); + } + }) + }, + //跳转创建项目页面 + openCreate(e) { + //计算价格 + const _self = this + const type = e.currentTarget.dataset.type + if (type == 'ALL') { + if (_self.data.allCount > 0) { + _self.doGetPackage(type) + } else { + //提示充值 + _self.setData({ + errorHint: '您的账户当前无套餐包,为正常使用请及时充值。', + showError: true + }) + } + } else { + if (_self.data.materialCount > 0) { + _self.doGetPackage(type) + } else { + //提示充值 + _self.setData({ + errorHint: '您的账户当前无套餐包,为正常使用请及时充值。', + showError: true + }) + } + } + }, + //获取套餐包详情 + doGetPackage(type) { + const _self = this + const data = { + page: 1, + rows: 10, + packageType: type, + keyong: 1, + } + ProApi.doGetPackageList(data) + .then(res => { + console.log(res.rows) + if (res.rows && res.rows.length > 0) { + const packageId = res.rows[0].packageInfoId + const price = type == 'ALL' ? _self.data.allPrice : _self.data.materialPrice + wx.navigateTo({ + url: '../../copyright/createProjectInfo/createProjectInfo?type=' + type + '&price=' + price + '&isUrgent=false&pId=' + packageId, + }) + } else { + _self.setData({ + errorHint: '您的账户当前无套餐包,为正常使用请及时充值。', + showError: true + }) + } + }) + .catch(err => { + _self.setData({ + errorHint: '获取套餐包失败,请稍后重试', + showError: true + }) + }) + }, + //获取单价 + doGetPrice() { + wx.showLoading({ + title: '加载中...', + }) + const _self = this + ProApi.doGetPrice() + .then(res => { + wx.hideLoading() + console.log(res) + res.projTypes.forEach(el => { + if (el.type == 'ALL') { + _self.setData({ + allPrice: el.price + }) + } else if (el.type == 'MATERIAL') { + _self.setData({ + materialPrice: el.price + }) + } + }); + _self.setData({ + urgent: res.additional.urgent, //加急办理 + }) + }, err => { + wx.hideLoading() + wx.showToast({ + title: '数据有误,请稍后重试', + icon: 'error', + success: () => { + wx.navigateBack() + } + }) + }) }, //刷新账户 doRefresh() { @@ -77,6 +219,7 @@ Page({ _self.playAnimation() _self.getMineAccount() //获取账户信息 _self.getMinePackageCount() //获取套餐包信息 + _self.doGetPrice() //获取单价 }, //播放刷新动画 playAnimation() { @@ -101,6 +244,15 @@ Page({ }, 1100); }, onShow(options) { + const pages = getCurrentPages(); + const currentPage = pages[pages.length - 1]; + const tabList = this.data.tabList; + tabList.forEach(item => { + item.selected = item.pagePath === currentPage.route; + }); + this.setData({ + tabList + }); this.getMineAccount() //获取账户信息 this.getMinePackageCount() //获取套餐包信息 }, diff --git a/pages/mine/mineIndex/mine.json b/pages/mine/mineIndex/mine.json index bb15e8b..85625a2 100644 --- a/pages/mine/mineIndex/mine.json +++ b/pages/mine/mineIndex/mine.json @@ -1,7 +1,8 @@ { "usingComponents": { "mp-dialog": "weui-miniprogram/dialog/dialog", - "mp-toptips": "weui-miniprogram/toptips/toptips" + "mp-toptips": "weui-miniprogram/toptips/toptips", + "custom-tabbar": "/components/tabbar/custom-tabbar" }, "navigationStyle": "custom", "enablePullDownRefresh": true diff --git a/pages/mine/mineIndex/mine.wxml b/pages/mine/mineIndex/mine.wxml index 53d0897..d9e510e 100644 --- a/pages/mine/mineIndex/mine.wxml +++ b/pages/mine/mineIndex/mine.wxml @@ -1,10 +1,10 @@ - - AI喵著 - - + + + AI喵著 + @@ -19,11 +19,11 @@ 套餐包余额 - + 全托管 {{allCount}} - + 写材料 {{materialCount}} @@ -34,22 +34,23 @@ - - - - - - - {{item.title}} - - - - - - + + + + + + + + {{item.title}} + + + + + + {{hintTxt}} diff --git a/pages/mine/mineIndex/mine.wxss b/pages/mine/mineIndex/mine.wxss index 47710c4..866033b 100644 --- a/pages/mine/mineIndex/mine.wxss +++ b/pages/mine/mineIndex/mine.wxss @@ -17,7 +17,6 @@ .content-container { position: relative; - padding: 0rpx 10rpx 10rpx 10rpx; z-index: 1; color: white; } @@ -131,6 +130,8 @@ background: white; border-radius: 20rpx; padding-top: 20rpx; + margin-left: 30rpx; + margin-right: 30rpx; } .menu-item { diff --git a/utils/comm.wxs b/utils/comm.wxs index 889c106..816f8d6 100644 --- a/utils/comm.wxs +++ b/utils/comm.wxs @@ -3,21 +3,39 @@ var isEmpty = function (obj) { if (typeof obj !== 'object') return false; return JSON.stringify(obj) === '{}'; }; -var status = function (value) { - var status = '排队中...' - switch (value) { - case 'NONE': - status = '排队中...' - break - case 'GENERATING': - status = '生成中...' - break - case 'SUCCESS': - status = '生成成功' - break - case 'FAILED': - status = '生成失败' - break +//state=AiSetting, value=generate +var status = function (value, state) { + var status = '未生成' + if (state == 'SUCCESS') { + switch (value) { + case 'NONE': + status = '未生成' + break + case 'PENDING': + status = '等待' + break + case 'GENERATING': + status = '生成中...' + break + case 'SUCCESS': + status = '生成成功' + break + case 'FAILED': + status = '生成失败' + break + } + } else { + switch (state) { + case 'FAILED': + status = '生成失败' + break + case 'GENERATING': + status = '生成中...' + break + case 'NONE': + status = '未生成' + break + } } return status }; @@ -42,6 +60,37 @@ var orderStatus = function (value) { } return statusStr }; +var statusColor = function (value, state) { + var color = 'status-gray' + if (state == 'SUCCESS') { + switch (value) { + case 'NONE': + case 'PENDING': + color = 'status-gray' + break + case 'GENERATING': + case 'SUCCESS': + color = 'status-green' + break + case 'FAILED': + color = 'status-red' + break + } + } else { + switch (state) { + case 'GENERATING': + color = 'status-green' + break + case 'FAILED': + color = 'status-red' + break + case 'NONE': + color = 'status-gray' + break + } + } + return color +} var proType = function (value) { // PROJ:项目、AGENT:代理、FULL_REFUND:全额退款、CORRECTION1_REFUND:补正1次退款、CORRECTION2_REFUND:补正2次退款 var str = '项目创建' @@ -109,5 +158,6 @@ module.exports = { proType: proType, boderStyle: boderStyle, fontColor: fontColor, - timeSplit: timeSplit + timeSplit: timeSplit, + statusColor: statusColor }; \ No newline at end of file diff --git a/utils/util.js b/utils/util.js index e79f229..4bb7933 100644 --- a/utils/util.js +++ b/utils/util.js @@ -62,8 +62,11 @@ const dateTimePicker = (startYear, endYear) => { }; } -const pxToRpx = (pxValue) => { - return (pxValue / 750) * 750; +const pxToRpx = (pxValue, screenWidth) => { + console.log('转换Px', pxValue, '屏幕宽度', screenWidth) + // return pxValue * (750 / screenWidth); + const rpx = (750 / screenWidth) * Number(pxValue) + return Math.floor(rpx); }