signcontract.vue 9.77 KB
<template>
	<view class="sign_content">
		<TopBar title="金融分期"/>
		<view :style="{'margin-top':'28rpx'}">
			<view class="apply_title">签署合同</view>
			<view class="apply_desc">请填写合同内详细信息</view>
			<view v-for="(item,index) in list" :key="index">
				{{item.index}}
			</view>
		</view>
		<uni-collapse>
			<uni-collapse-item 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
			}
		},
		components: {
			uniCollapse,
			uniCollapseItem,
			TopBar
		},
		onLoad() {
			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(){
				if(!this.is_agree){
					uni.showToast({
					    title: '请阅读并同意采购分期合同',
					    duration: 2000,
							icon: 'none'
					});
					return;
				}
				const data = this.getData();
				// 临时存储合同信息
				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){
							this.$jump(data.data.viewUrl);
						}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;
			}
		}
	}
</script>

<style lang="less" scoped>
	.sign_content {
		background: #fff;
		padding:  80rpx 36rpx 0;
		.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>