<template> <view class="sign_content"> <TopBar title="金融分期"/> <view :style="{'margin-top':'28rpx'}"> <view class="apply_title">{{title}}</view> <view class="apply_desc">{{sub_title}}</view> <view v-for="(item,index) in list" :key="index"> {{item.index}} </view> </view> <uni-collapse> <uni-collapse-item :title="third_title" :open="true"> <view v-for="(item, index) in list" :key="index"> <view class="sign_title">{{item.name}}</view> <view> <input type="text" v-model="list[index].value" value="" :name="item.key" class="sign_input"> </view> </view> </uni-collapse-item> </uni-collapse> <view @click="checkAgree" class="checkAgree"> <text class="sign_checkbox" :class="{act: is_agree}"></text> <text class="agree_title">我已阅读并同意</text> <text @click="previewContract" class="agreement">《产品分期采购合同》</text> </view> <!-- <text>《谛宝多多金融分期协议》</text> --> <!-- <view class="agreement"> 关于 <text @click="previewContract">《产品分期采购合同》</text> </view> --> <view class="sign_btn_box"> <text class="prev_step" @click="goBack">上一步</text> <text class="confirm_pay" @click="handleSubmit">缴纳定金 <i class="arrow_icon"></i> </text> </view> </view> </template> <script> import uniCollapse from '@/components/uni-collapse/uni-collapse.vue'; import uniCollapseItem from '@/components/uni-collapse-item/uni-collapse-item.vue'; import TopBar from '@/components/TopBar/TopBar.vue'; export default { data() { return { list: [], data: {}, is_eidt: false, is_agree: false, title: '签署合同', sub_title: '请填写合同内详细信息', third_title: '企业信息' } }, components: { uniCollapse, uniCollapseItem, TopBar }, onLoad(option) { const {type} = option; if(type){ this.title = '收货信息'; this.sub_title = '请填写收货地址信息'; this.third_title = '收货信息'; } this.loadData(); }, methods:{ // 默认获取合同签署字段 loadData(){ const install = uni.getStorageSync('installment'); const {contract_no, equipment_id, property_id} = install; // 获取合同已填的信息 uni.request({ url: `/uni/api/signcontract/GetContract?contract_no=${contract_no}`, method: 'GET', dataType: 'json', success: (res) => { const {data} = res; if(data.code == 0){ if(data.data){ const { contract_content } = data.data; if(contract_content){ this.data = JSON.parse(contract_content); this.is_eidt = true; } }else{ // const temporary = uni.getStorageSync('temporary'); // if (temporary) { // this.data = JSON.parse(temporary); // } } uni.request({ url: `/uni/api/signcontract/GetContractField?equipment_id=${equipment_id}`, method: 'GET', dataType: 'json', success: (res) => { const {data} = res; if(data.code == 0){ this.list = data.data || []; for(var i=0; i< this.list.length; i++){ let key = this.list[i].key; this.list[i].value = this.data[key] || ''; } } } }) } } }) }, // 缴纳定金提交 handleSubmit(){ const data = this.getData(); const checkData = this.checkData(data); console.log(checkData,'checkData'); if(checkData > 0){ uni.showToast({ title: '请填写签署合同信息', duration: 2000, icon: 'none' }); return; } if(!this.is_agree){ uni.showToast({ title: '请阅读并同意采购分期合同', duration: 2000, icon: 'none' }); return; } // 临时存储合同信息 // uni.setStorageSync('temporary', JSON.stringify(data)); const install = uni.getStorageSync('installment'); const {contract_no, equipment_id, property_id} = install; const url = this.is_eidt ? '/uni/api/signcontract/EditContract' : '/uni/api/signcontract/AddContract'; uni.showLoading({ title: '提交中...' }) uni.request({ url: url, method: this.is_eidt ? 'PUT' : 'POST', data: { contract_no: contract_no, equipment_id: equipment_id, property_id: property_id, contract_content: data }, dataType: 'json', success: (res) => { const {data} = res; uni.hideLoading(); if(data.code == 0){ this.is_eidt = true; uni.navigateTo({ url: '/pages/checkstand/checkstand' }); }else{ uni.showToast({ icon: 'none', title: '提交失败,请重试' }) } } }); }, // 预览合同 previewContract(){ const data = this.getData(); const install = uni.getStorageSync('installment'); // 临时存储合同信息 // uni.setStorageSync('temporary', JSON.stringify(data)); const {contract_no, equipment_id, property_id} = install; uni.showLoading({ title: '获取合同中...', }); uni.request({ url: '/uni/api/signcontract/PreviewContract', method: 'POST', data: { contract_no: contract_no, equipment_id: equipment_id, property_id: property_id, contract_content: data }, dataType: 'json', success: (res) => { const {data} = res; uni.hideLoading(); if(data.code == 0){ const url = data.data.viewUrl; // this.$jump(data.data.viewUrl); uni.navigateTo({ url: `/pages/web/web?contract_url=${url}` }); }else{ uni.showToast({ icon: 'none', title: '获取失败' }) } } }); }, checkAgree(){ this.is_agree = !this.is_agree; }, // 返回上一页 goBack(){ this.$backup(); }, // 获取签署合同提交信息 getData(){ const length = this.list.length; let data = {}; for(var i = 0; i < length; i++){ let key = this.list[i].key; data[key] = this.list[i].value; } return data; }, // 判断合同字段是否都已填写 checkData(data){ if(data){ let num = 0; for(let d in data){ if(!data[d]){ num++; } } return num; } } } } </script> <style lang="less" scoped> .sign_content { background: #fff; padding: 80rpx 36rpx 0; padding-bottom: 100rpx; .apply_title { font-size:32rpx; font-family:PingFangSC-Medium,PingFang SC; font-weight:500; line-height: 44rpx; color: #212121; } .apply_desc { font-size:24rpx; line-height: 34rpx; color: #979797; margin-top: 8rpx; } .sign_title { color: #464646; height:40rpx; font-size:28rpx; margin-top: 32rpx; } .sign_input { width:100%; height:72rpx; background:rgba(248,248,248,1); border-radius:16rpx; margin-top: 20rpx; line-height: 72rpx; padding: 0 20rpx; box-sizing: border-box; font-size: 28rpx; color: #212121; } .sign_flex { display: flex; justify-content: space-between; align-items: center; margin-top: 32rpx; } .sign_btn_box { margin: 126rpx 0 40rpx; display: flex; justify-content: space-between; color: #212121; font-size: 28rpx; line-height: 80rpx; text-align: center; .prev_step { width: 244rpx; background: #F5F5F5; border-radius: 16rpx; height: 80rpx; } .confirm_pay { width: 416rpx; height: 80rpx; background: #FFCD00; border-radius: 16rpx; } .arrow_icon { display: inline-block; background-image:url(''); background-size: 100% 100%; background-repeat: no-repeat; width: 24rpx; height: 24rpx; position: relative; top: 1px; } } .agreement { font-size: 26rpx; // color: #979797; color: #718BCA; margin-top: 34rpx; text { color: #718BCA; } } .agree_title { font-size: 26rpx; color: #7C7C7C; } .checkAgree{ margin-top: 26rpx; } .sign_checkbox { display: inline-block; width: 36rpx; height: 36rpx; background-image:url(''); background-size: 100% 100%; background-repeat: no-repeat; vertical-align: middle; margin-right: 4rpx; } .sign_checkbox.act { background-image:url(''); } } </style>