Form.vue 7.2 KB
<template>
	<el-dialog title="判研建议" :close-on-click-modal="false" :visible.sync="visible" class="NCC-dialog NCC-dialog_center" lock-scroll width="70%">
		<el-row :gutter="15" class="" >
			<el-col :span="24" class="form_title">
				巡查上报详情
			</el-col>
			<el-form ref="elForm" :model="dataForm" size="small" label-width="100px" label-position="right" :disabled="!!isDetail" :rules="rules" v-loading="loading">
					<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="12">
						<el-form-item label="平台名称" prop="platformName">
							<el-input v-model="dataForm.platformName" placeholder="--" clearable :style='{"width":"100%"}' >
							</el-input>
						</el-form-item>
					</el-col>
					<el-col :span="12">
						<el-form-item label="平台类型" prop="platformType">
							<el-select v-model="dataForm.platformType" placeholder="--" clearable :style='{"width":"100%"}' >
								<el-option v-for="(item, index) in platformTypeOptions" :key="index" :label="item.fullName" :value="item.id" ></el-option>
							</el-select>
						</el-form-item>
					</el-col>
					<el-col :span="12">
						<el-form-item label="问题类型" prop="questionType">
							<el-radio-group v-model="dataForm.questionType" :style='{}' >
								<el-radio v-for="(item, index) in questionTypeOptions" :key="index" :label="item.id"  >{{item.fullName || '--'}}</el-radio>
							</el-radio-group>
						</el-form-item>
					</el-col>
					<el-col :span="12">
						<el-form-item label="问题分类" prop="questionClass">
							<el-select v-model="dataForm.questionClass" placeholder="--" clearable :style='{"width":"100%"}' >
								<el-option v-for="(item, index) in questionClassOptions" :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="questionContent">
							<el-input v-model="dataForm.questionContent" 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">
						<el-form-item label="有害链接" prop="link">
							<el-input v-model="dataForm.link" placeholder="--" clearable :style='{"width":"100%"}' >
							</el-input>
						</el-form-item>
					</el-col>
					<el-col :span="24">
						<el-form-item label="取证内容" prop="obtainEvidence">
							<NCC-UploadFz v-model="dataForm.obtainEvidence" :fileSize="5" sizeUnit="MB" :limit="9" buttonText="点击上传" >
							</NCC-UploadFz>
						</el-form-item>
					</el-col>
					<el-col :span="24">
						<el-form-item label="附件上传" prop="annex">
							<NCC-UploadFz v-model="dataForm.annex" :fileSize="5" sizeUnit="MB" :limit="9" buttonText="点击上传" >
							</NCC-UploadFz>
						</el-form-item>
					</el-col>
			</el-form>
			<el-col :span="24" class="form_title">
				判研建议
			</el-col>
			<el-form ref="suggestionForm" :model="suggestionForm" size="small" label-width="100px" label-position="right">
				<el-col :span="24">
					<el-form-item :label="isSHILevel ? '处置要求' : '处置建议'" prop="disposalSuggestions">
						<el-input v-model="suggestionForm.disposalSuggestions" 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">
					<el-form-item label="截止时间" prop="endTime">
						<el-date-picker v-model="suggestionForm.endTime" type="date" placeholder="选择日期"></el-date-picker>
					</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()">确 定</el-button>
			<el-button type="primary" @click="dataFormSubmit()">存 档</el-button>
		</span>
	</el-dialog>
</template>
<script>
	import request from '@/utils/request'
	import { getDictionaryDataSelector } from '@/api/systemData/dictionary'
	import { getDetail, disposalSuggestions } from '@/api/systemData/dataInterface'
	export default {
		components: {},
		props: [],
		data() {
			return {
				loading: true,
				visible: false,
				isDetail: true,
				dataForm: {
					id:undefined,
					platformName:undefined,
					platformType:undefined,
					questionType:undefined,
					questionClass:undefined,
					questionContent:undefined,
					link:undefined,
					obtainEvidence:[],
					annex:[],
				},
				rules: {
				},
				sourceOptions:[{"fullName":"市网信办线索","id":"市网信办线索"},{"fullName":"自主巡查发现","id":"自主巡查发现"}],
				platformTypeOptions : [],
				questionTypeOptions : [],
				questionClassOptions:[{"fullName":"选项一","id":"1"},{"fullName":"选项二","id":"2"}],
				stageOptions:[{"fullName":"选项一","id":"1"},{"fullName":"选项二","id":"2"}],

				suggestionForm: {
					disposalSuggestions: "", //处置建议
					judgmentOpinions: "", //判断意见
					judgmentClass: "", //判断分类
					endTime: '',
				}
			}
		},
		computed: {
			isSHILevel() {
    		  // 判断角色是否为‘市级办公室’
    		  return this.$store.state.user.userInfo.organizeId == '580547494862128389';
    		},
		},
        watch: {},
        created() {
			this.getplatformTypeOptions();
			this.getquestionTypeOptions();
		},
		mounted() {
        },
		methods: {
			getplatformTypeOptions(){
				getDictionaryDataSelector('576279943168656645').then(res => {
					this.platformTypeOptions = res.data.list
				});
			},
			getquestionTypeOptions(){
				getDictionaryDataSelector('577006814432855301').then(res => {
					this.questionTypeOptions = res.data.list
				});
			},
			goBack() {
                this.$emit('refresh')
            },
			init(id, isDetail) {
				this.dataForm.id = id || 0;
                this.visible = true;
				this.$nextTick(async () => {
					this.$refs['elForm'].resetFields();
					this.$refs['suggestionForm'].resetFields();
					if (this.dataForm.id) {
						let res = await getDetail(this.dataForm.id)
						this.dataForm = res.data;
						this.loading = false;
						if(!this.dataForm.obtainEvidence)this.dataForm.obtainEvidence=[];
						if(!this.dataForm.annex)this.dataForm.annex=[];
					}
				})
			},
			dataFormSubmit() {
				if(!this.suggestionForm.disposalSuggestions && !this.suggestionForm.judgmentOpinions && !this.suggestionForm.judgmentClass) {
					this.$message({
						message: '判研建议不能为空!',
						type: 'danger',
					})
				}
				this.$refs['suggestionForm'].validate(async (valid) => {
                    if (valid) {
						let res = await disposalSuggestions(this.dataForm);
						this.$message({
							message: res.msg,
							type: 'success',
							duration: 1000,
							onClose: () => {
								this.visible = false, this.$emit('refresh', true)
							}
						})
                    }
                })
			},
		}
	}
</script>
<style lang="scss" scoped>
	.form_title {
		line-height: 30px;
		padding-left: 40px;
		color: #409eff;
	}
</style>