Form.vue 8.46 KB
<template>
	<el-dialog :title="!dataForm.id ? '新建' :  isDetail ? '详情':'编辑'" :close-on-click-modal="false" :visible.sync="visible" class="NCC-dialog NCC-dialog_center" lock-scroll width="600px">
		<el-row :gutter="15" class="" >
				<el-form ref="elForm" :model="dataForm" size="small" label-width="100px" label-position="right" :disabled="!!isDetail" :rules="rules">
					<el-col :span="24">
						<el-form-item label="合同编号" prop="id">
							<el-input v-model="dataForm.id" placeholder="请输入" clearable readonly :style='{"width":"100%"}' >
							</el-input>
						</el-form-item>
					</el-col>
					<el-col :span="24">
						<el-form-item label="门店编码" prop="mdbm">
							<el-select v-model="dataForm.mdbm" placeholder="请选择" clearable :style='{"width":"100%"}' filterable >
								<el-option v-for="(item, index) in mdbmOptions" :key="index" :label="item.fullName" :value="item.id" ></el-option>
							</el-select>
						</el-form-item>
					</el-col>
					<el-col :span="24">
						<el-form-item label="单据门店" prop="djmd">
							<el-input v-model="dataForm.djmd" placeholder="请输入" clearable :style='{"width":"100%"}' >
							</el-input>
						</el-form-item>
					</el-col>
					<el-col :span="24">
						<el-form-item label="房租" prop="fz">
							<el-input v-model="dataForm.fz" placeholder="请输入" clearable :style='{"width":"100%"}' >
							</el-input>
						</el-form-item>
					</el-col>
					<el-col :span="24">
						<el-form-item label="支付时间" prop="zfsj">
							<el-date-picker v-model="dataForm.zfsj" placeholder="请选择" clearable :style='{"width":"100%"}' type='date' format="yyyy-MM-dd" value-format="timestamp" >
							</el-date-picker>
						</el-form-item>
					</el-col>
					<el-col :span="24">
						<el-form-item label="借方" prop="jfz">
							<el-select v-model="dataForm.jfz" placeholder="请选择" clearable :style='{"width":"100%"}' >
								<el-option v-for="(item, index) in jfzOptions" :key="index" :label="item.fullName" :value="item.id" ></el-option>
							</el-select>
						</el-form-item>
					</el-col>
					<el-col :span="24">
						<el-form-item label="贷方" prop="dfz">
							<el-select v-model="dataForm.dfz" placeholder="请选择" clearable :style='{"width":"100%"}' >
								<el-option v-for="(item, index) in dfzOptions" :key="index" :label="item.fullName" :value="item.id" ></el-option>
							</el-select>
						</el-form-item>
					</el-col>
					<el-col :span="24">
						<el-form-item label="应收账款押金" prop="yszkyj">
							<el-input v-model="dataForm.yszkyj" placeholder="请输入" clearable :style='{"width":"100%"}' >
							</el-input>
						</el-form-item>
					</el-col>
					<el-col :span="24">
						<el-form-item label="支付方式" prop="zffs">
							<el-select v-model="dataForm.zffs" placeholder="请选择" clearable :style='{"width":"100%"}' filterable >
								<el-option v-for="(item, index) in zffsOptions" :key="index" :label="item.fullName" :value="item.id" ></el-option>
							</el-select>
						</el-form-item>
					</el-col>
					<el-col :span="24">
						<el-form-item label="合同签订时间" prop="htqdsj">
							<el-date-picker v-model="dataForm.htqdsj" placeholder="请选择" clearable :style='{"width":"100%"}' type='date' format="yyyy-MM-dd" value-format="timestamp" >
							</el-date-picker>
						</el-form-item>
					</el-col>
					<el-col :span="24">
						<el-form-item label="合同结束时间" prop="htjssj">
							<el-date-picker v-model="dataForm.htjssj" placeholder="请选择" clearable :style='{"width":"100%"}' type='date' format="yyyy-MM-dd" value-format="timestamp" >
							</el-date-picker>
						</el-form-item>
					</el-col>
					<el-col :span="24">
						<el-form-item label="物业" prop="wy">
							<el-input v-model="dataForm.wy" placeholder="请输入" clearable :style='{"width":"100%"}' >
							</el-input>
						</el-form-item>
					</el-col>
					<el-col :span="24">
						<el-form-item label="借方" prop="jwy">
							<el-select v-model="dataForm.jwy" placeholder="请选择" clearable :style='{"width":"100%"}' >
								<el-option v-for="(item, index) in jwyOptions" :key="index" :label="item.fullName" :value="item.id" ></el-option>
							</el-select>
						</el-form-item>
					</el-col>
					<el-col :span="24">
						<el-form-item label="贷方" prop="dwy">
							<el-select v-model="dataForm.dwy" placeholder="请选择" clearable :style='{"width":"100%"}' >
								<el-option v-for="(item, index) in dwyOptions" :key="index" :label="item.fullName" :value="item.id" ></el-option>
							</el-select>
						</el-form-item>
					</el-col>
				</el-form>
		</el-row>
		<span slot="footer" class="dialog-footer">
			<el-button @click="visible = false">取 消</el-button>
			<el-button type="primary" @click="dataFormSubmit()" v-if="!isDetail">确 定</el-button>
		</span>
	</el-dialog>
</template>
<script>
	import request from '@/utils/request'
	import { getDictionaryDataSelector } from '@/api/systemData/dictionary'
	import { previewDataInterface } from '@/api/systemData/dataInterface'
	export default {
		components: {},
		props: [],
		data() {
			return {
				loading: false,
				visible: false,
				isDetail: false,
				dataForm: {
					id:'',
					id:undefined,
					mdbm:undefined,
					djmd:undefined,
					fz:undefined,
					zfsj:undefined,
					jfz:undefined,
					dfz:undefined,
					yszkyj:undefined,
					zffs:undefined,
					htqdsj:undefined,
					htjssj:undefined,
					wy:undefined,
					jwy:undefined,
					dwy:undefined,
				},
				rules: {
				},
				mdbmOptions : [],
				jfzOptions:[{"fullName":"选项一","id":"1"},{"fullName":"选项二","id":"2"}],
				dfzOptions:[{"fullName":"选项一","id":"1"},{"fullName":"选项二","id":"2"}],
				zffsOptions:[{"fullName":"1个月","id":"1个月"},{"fullName":"3个月","id":"3个月"},{"fullName":"6个月","id":"6个月"},{"fullName":"12个月","id":"12个月"}],
				jwyOptions:[{"fullName":"选项一","id":"1"},{"fullName":"选项二","id":"2"}],
				dwyOptions:[{"fullName":"选项一","id":"1"},{"fullName":"选项二","id":"2"}],
			}
		},
		computed: {},
        watch: {},
        created() {
			this.getmdbmOptions();
		},
		mounted() {
        },
		methods: {
			getmdbmOptions(){
				previewDataInterface('730960205902251269').then(res => {
					this.mdbmOptions = res.data
				});
			},
			goBack() {
                this.$emit('refresh')
            },
			init(id, isDetail) {
				this.dataForm.id = id || 0;
                this.visible = true;
                this.isDetail = isDetail || false;
				this.$nextTick(() => {
					this.$refs['elForm'].resetFields();
					if (this.dataForm.id) {
						request({
							url: '/api/Extend/LqMdFzht/' + this.dataForm.id,
							method: 'get'
						}).then(res =>{
							this.dataForm = res.data;
						})
					}
				})
			},
			dataFormSubmit() {
				this.$refs['elForm'].validate((valid) => {
                    if (valid) {
                        if (!this.dataForm.id) {
                            request({
                                url: `/api/Extend/LqMdFzht`,
                                method: 'post',
                                data: this.dataForm,
                            }).then((res) => {
                                this.$message({
                                    message: res.msg,
                                    type: 'success',
                                    duration: 1000,
                                    onClose: () => {
                                        this.visible = false,
                                            this.$emit('refresh', true)
                                    }
                                })
                            })
                        } else {
                            request({
                                url: '/api/Extend/LqMdFzht/' + this.dataForm.id,
                                method: 'PUT',
                                data: this.dataForm
                            }).then((res) => {
                                this.$message({
                                    message: res.msg,
                                    type: 'success',
                                    duration: 1000,
                                    onClose: () => {
                                        this.visible = false
                                        this.$emit('refresh', true)
                                    }
                                })
                            })
                        }
                    }
                })
			},
		}
	}
</script>