Form.vue 8.73 KB
<template>
	<el-dialog :title="!dataForm.id ? '新增' :  isDetail ? '详情':'编辑'" :close-on-click-modal="false" :visible.sync="visible" class="NCC-dialog NCC-dialog_center basePrincipalResponsibilityForm" lock-scroll width="40%">
		<el-row :gutter="15" class="NCC-dialog-content" v-loading="dialogLoading">
				<el-form ref="elForm" :model="dataForm" size="small" label-width="110px" label-position="right" :disabled="!!isDetail" :rules="rules">
					<el-col :span="24" v-if="false" >
						<el-form-item label="主键" prop="id">
							<el-input v-model="dataForm.id" placeholder="请输入" clearable :style='{"width":"100%"}' >
							</el-input>
						</el-form-item>
					</el-col>
					<el-col :span="24" v-if="ncc.hasFormP('fileName')">
						<el-form-item label="文件名" prop="fileName">
							<el-input v-model="dataForm.fileName" placeholder="请输入文件名" clearable :style='{"width":"100%"}' />
						</el-form-item>
					</el-col>
					<el-col :span="24" v-if="ncc.hasFormP('fileType')">
						<el-form-item label="文件类型" prop="fileType">
							<el-radio-group v-model="dataForm.fileType">
								<el-radio v-for="(item, index) in fileTypeOptions" :key="index" :label="item.id"  >{{item.fullName}}</el-radio>
							</el-radio-group>
						</el-form-item>
					</el-col>
					<el-col :span="24" v-if="ncc.hasFormP('otherFileType')" v-show="dataForm.fileType == '0'">
						<el-form-item label="其他文件类型" prop="otherFileType">
							<el-input v-model="dataForm.otherFileType" placeholder="请输入其他文件类型" clearable :style='{"width":"100%"}' />
						</el-form-item>
					</el-col>
					<el-col :span="24" v-if="ncc.hasFormP('timeTakingEffect')">
						<el-form-item label="生效时间" prop="timeTakingEffect">
							<el-date-picker v-model="dataForm.timeTakingEffect" 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" v-if="ncc.hasFormP('content')">
						<el-form-item label="具体内容" prop="content">
							<el-input v-model="dataForm.content" placeholder="请输入具体内容" show-word-limit :style='{"width":"100%"}' type='textarea' :autosize='{"minRows":4,"maxRows":4}' >
							</el-input>
						</el-form-item>
					</el-col>
					<el-col :span="24" v-if="ncc.hasFormP('fileUrl')">
						<el-form-item label="文件地址" prop="fileUrl">
							<NCC-UploadFz v-model="dataForm.fileUrl" :fileSize="5" sizeUnit="MB" :limit="9" buttonText="点击上传" >
							</NCC-UploadFz>
						</el-form-item>
					</el-col>
					<el-col :span="24" v-if="false" >
						<el-form-item label="创建用户" prop="creatorUserId">
							<el-input v-model="dataForm.creatorUserId" placeholder="系统自动生成" readonly >
							</el-input>
						</el-form-item>
					</el-col>
					<el-col :span="24" v-if="false" >
						<el-form-item label="创建时间" prop="creatorTime">
							<el-input v-model="dataForm.creatorTime" placeholder="系统自动生成" readonly >
							</el-input>
						</el-form-item>
					</el-col>
					<el-col :span="24" v-if="false" >
						<el-form-item label="修改用户" prop="lastModifyUserId">
							<el-input v-model="dataForm.lastModifyUserId" placeholder="系统自动生成" readonly >
							</el-input>
						</el-form-item>
					</el-col>
					<el-col :span="24" v-if="false" >
						<el-form-item label="修改时间" prop="lastModifyTime">
							<el-input v-model="dataForm.lastModifyTime" placeholder="系统自动生成" readonly >
							</el-input>
						</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" :loading="btnLoading">确 定</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() {
			var validateOtherFileType = (rule, value, callback) => {
				if (this.dataForm.fileType == '0' &&  !value) {
        		  callback(new Error('请输入其他文件类型'));
        		} else {
				  callback();
				}
			}
			return {
				loading: false,
				visible: false,
				isDetail: false,
                dialogLoading: true,
				dataForm: {
					id:'',
					id:undefined,
					fileName:undefined,
					fileType:undefined,
					timeTakingEffect:undefined,
					content:undefined,
					fileUrl:[],
					creatorUserId:undefined,
					creatorTime:undefined,
					lastModifyUserId:undefined,
					lastModifyTime:undefined,
					otherFileType: undefined,
				},
				rules: {
					fileName: [{ required: true, message: '请输入文件名称', trigger: 'blur' }],
					fileType: [{ required: true, message: '请选择文件类型', trigger: 'blur' }],
					otherFileType: [{ validator: validateOtherFileType, trigger: 'blur' }],
				},
				fileTypeOptions : [],
				btnLoading: false,
			}
		},
		computed: {},
        watch: {},
        created() {
		},
		mounted() {
        },
		methods: {
			async getfileTypeOptions(){
				let res = await getDictionaryDataSelector('577087166203561221');
				this.fileTypeOptions = [...res.data.list, { fullName: '其他', id: '0' }];
			},
			goBack() {
                this.$emit('refresh')
            },
			async init(id, isDetail) {
				this.dataForm.id = id || 0;
                this.visible = true;
                this.isDetail = isDetail || false;
				this.dialogLoading = true;
				await this.getfileTypeOptions();
				this.$nextTick(() => {
					this.$refs['elForm'].resetFields();
					if (this.dataForm.id) {
						request({
							url: '/Extend/BasePrincipalResponsibility/' + this.dataForm.id,
							method: 'get'
						}).then(res =>{
							if(res.code != 200) return this.dialogLoading = false;
							this.dataForm = res.data;
							this.dataForm.fileUrl = res.data.fileUrlModel;
                            this.setTileType(res.data.fileType);
                            this.dialogLoading = false;
						}).catch(() => this.dialogLoading = false)
					} else {
						this.dialogLoading = false;
					}
				})
			},
            setTileType(val) {
                let index = this.fileTypeOptions.findIndex(v => v.id == val);
                if(index == -1 || index == (this.fileTypeOptions.length - 1)) {
                    this.dataForm.fileType = '0';
                    this.dataForm.otherFileType = val;
                } else {
                    this.dataForm.fileType = val;
                    this.dataForm.otherFileType = '';
                }
            },
			dataFormSubmit() {
				this.$refs['elForm'].validate((valid) => {
                    if (valid) {
						this.dataForm.fileType = this.dataForm.fileType == '0' ? this.dataForm.otherFileType : this.dataForm.fileType;
						delete this.dataForm.fileUrlModel;
						this.btnLoading = true;
                        if (!this.dataForm.id) {
                            request({
                                url: `/Extend/BasePrincipalResponsibility`,
                                method: 'post',
                                data: this.dataForm,
                            }).then((res) => {
								if(res.code != 200) return this.btnLoading = false;
                                this.$message({
                                    message: res.msg,
                                    type: 'success',
                                    duration: 1000,
                                })
                                this.visible = false;
                                this.$emit('refresh', true);
                            }).catch(() => this.btnLoading = false);
                        } else {
                            request({
                                url: '/Extend/BasePrincipalResponsibility/' + this.dataForm.id,
                                method: 'PUT',
                                data: this.dataForm
                            }).then((res) => {
								if(res.code != 200) return this.btnLoading = false;
                                this.$message({
                                    message: res.msg,
                                    type: 'success',
                                    duration: 1000,
                                })
                                this.visible = false;
                                this.$emit('refresh', true);
                            }).catch(() => this.btnLoading = false);
                        }
                    }
                })
			},
		}
	}
</script>
<style lang="scss" scoped>
.basePrincipalResponsibilityForm {
	:deep(.el-radio) {
		margin: 0 30px 8px 0;
	}
}
</style>