|
|
@@ -1,233 +0,0 @@
|
|
|
-<template>
|
|
|
- <el-dialog v-model="visible" :title="titleMap[mode]" :width="680" @closed="$emit('closed', fileIsDel)">
|
|
|
- <el-form ref="formRef" :model="form" :rules="rules" label-width="110px">
|
|
|
- <el-row>
|
|
|
- <el-col v-if="form.id" :span="12">
|
|
|
- <el-form-item label="政策编号" prop="businessNo">
|
|
|
- <el-input v-model="form.businessNo" disabled></el-input>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="填报人">
|
|
|
- <el-input v-model="form.createName" disabled></el-input>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="填报部门">
|
|
|
- <el-input v-model="form.deptName" disabled></el-input>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="填报单位">
|
|
|
- <el-input v-model="form.companyName" disabled></el-input>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col v-if="form.id" :span="12">
|
|
|
- <el-form-item label="填报时间">
|
|
|
- <el-date-picker v-model="form.createTime" disabled format="YYYY-MM-DD HH:mm:ss"></el-date-picker>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="政策名称" prop="name">
|
|
|
- <el-input v-model="form.name" placeholder="请输入政策名称"></el-input>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="政策等级" prop="zcLevel">
|
|
|
- <el-select v-model="form.zcLevel" placeholder="请选择政策等级">
|
|
|
- <el-option v-for="item in levelDic" :key="item" :label="item" :value="item"></el-option>
|
|
|
- </el-select>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="政策类别" prop="zcType">
|
|
|
- <el-select v-model="form.zcType" placeholder="请选择政策类别">
|
|
|
- <el-option v-for="item in typeDic" :key="item" :label="item" :value="item"></el-option>
|
|
|
- </el-select>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="政策文号" prop="docNo">
|
|
|
- <el-input v-model="form.docNo" placeholder="请输入政策文号"></el-input>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="联系方式" prop="contactPhone">
|
|
|
- <el-input v-model="form.contactPhone" placeholder="请输入联系方式"></el-input>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="24">
|
|
|
- <el-form-item label="政策概要" prop="abstractContent">
|
|
|
- <el-input v-model="form.abstractContent" type="textarea" :rows="4" placeholder="请输入政策概要"></el-input>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="是否入库">
|
|
|
- <el-radio-group v-model="form.isInWh" @change="form.inWhType = null">
|
|
|
- <el-radio v-for="(label, key) in whetherDic" :key="key" :label="label" :value="parseInt(key)"></el-radio>
|
|
|
- </el-radio-group>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="分值(0-10)">
|
|
|
- <el-input-number v-model="form.score" :min="0" :max="10" :step="0.1" :precision="2" controls-position="right" placeholder="请输入分值"></el-input-number>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col v-if="form.isInWh == 1" :span="12">
|
|
|
- <el-form-item label="入库类型" prop="inWhType">
|
|
|
- <el-select v-model="form.inWhType" placeholder="请选择入库类型">
|
|
|
- <el-option v-for="item in storageTypeDic" :key="item" :label="item" :value="item"></el-option>
|
|
|
- </el-select>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col v-if="mode == 'decode'" :span="24">
|
|
|
- <el-form-item label="政策解读" prop="decodeContent">
|
|
|
- <el-input v-model="form.decodeContent" type="textarea" :rows="4" placeholder="请输入政策解读"></el-input>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="24">
|
|
|
- <el-form-item label="附件">
|
|
|
- <yhUpload v-model="form.fileList" :limit="10" @updateTable="fileIsDel = true">
|
|
|
- <el-button type="primary" icon="upload" size="small"></el-button>
|
|
|
- </yhUpload>
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- </el-row>
|
|
|
- </el-form>
|
|
|
-
|
|
|
- <template #footer>
|
|
|
- <el-button type="primary" @click="submit">确 定</el-button>
|
|
|
- </template>
|
|
|
- </el-dialog>
|
|
|
-</template>
|
|
|
-
|
|
|
-<script>
|
|
|
-import Common from "@/api/common";
|
|
|
-import API from "@/api/policy/share";
|
|
|
-import { useUserStore } from "@/store/user";
|
|
|
-import { levelDic, typeDic, whetherDic, storageTypeDic } from "@/views/policyShare/main";
|
|
|
-import yhUpload from "@/components/Upload/index.vue";
|
|
|
-
|
|
|
-const { userInfo } = useUserStore(); // store 用户
|
|
|
-
|
|
|
-export default {
|
|
|
- emits: ["success", "closed"],
|
|
|
- components: {
|
|
|
- yhUpload
|
|
|
- },
|
|
|
-
|
|
|
- data() {
|
|
|
- return {
|
|
|
- levelDic, typeDic, whetherDic, storageTypeDic,
|
|
|
- visible: false,
|
|
|
- mode: "add",
|
|
|
- titleMap: {
|
|
|
- add: "新增",
|
|
|
- edit: "修改",
|
|
|
- decode: "添加解读"
|
|
|
- },
|
|
|
- form: {
|
|
|
- id: null,
|
|
|
- businessNo: null,
|
|
|
- status: null,
|
|
|
- createId: userInfo.id,
|
|
|
- createName: userInfo.name,
|
|
|
- createTime: null,
|
|
|
- name: null,
|
|
|
- companyName: null,
|
|
|
- deptName: null,
|
|
|
- zcLevel: null,
|
|
|
- zcType: null,
|
|
|
- docNo: null,
|
|
|
- contactPhone: null,
|
|
|
- abstractContent: null,
|
|
|
- decodeContent: null,
|
|
|
- score: null,
|
|
|
- isInWh: 1,
|
|
|
- inWhType: null,
|
|
|
- fileList: []
|
|
|
- },
|
|
|
-
|
|
|
- rules: {
|
|
|
- businessNo: [{ required: true }],
|
|
|
- name: [{ required: true, message: "请输入政策名称" }],
|
|
|
- zcLevel: [{ required: true, message: "请选择政策等级" }],
|
|
|
- zcType: [{ required: true, message: "请选择政策类别" }],
|
|
|
- docNo: [{ required: true, message: "请输入政策文号" }],
|
|
|
- contactPhone: [{ required: true, message: "请输入联系方式" }],
|
|
|
- abstractContent: [{ required: true, message: "请输入政策概要" }],
|
|
|
- inWhType: [{ required: true, message: "请选择入库类型" }],
|
|
|
- decodeContent: [{ required: true, message: "请输入政策解读" }]
|
|
|
- },
|
|
|
-
|
|
|
- fileIsDel: false,
|
|
|
- dialog: false
|
|
|
- }
|
|
|
- },
|
|
|
-
|
|
|
- mounted() {
|
|
|
- this.getUserDept();
|
|
|
- },
|
|
|
-
|
|
|
- methods: {
|
|
|
- init(mode = "add") {
|
|
|
- this.mode = mode;
|
|
|
- this.visible = true;
|
|
|
- return this;
|
|
|
- },
|
|
|
-
|
|
|
- setData(id) {
|
|
|
- API.detail(id).then(res => {
|
|
|
- if (res.code === 200) {
|
|
|
- for (const key in this.form) {
|
|
|
- if (key == "fileList") {
|
|
|
- this.form[key] = res.data[key].map(file => ({ ...file, name: file.originalName, path: file.fileDomain + "/" + file.fileName }));
|
|
|
- } else if (key == "isInWh") this.form.isInWh = !!res.data[key] && res.data[key] || 0;
|
|
|
- else this.form[key] = res.data[key] || null;
|
|
|
- }
|
|
|
- } else ElMessage.error(res.msg);
|
|
|
- });
|
|
|
- },
|
|
|
-
|
|
|
- getUserDept() {
|
|
|
- Common.getUserDept(userInfo.deptId).then(res => {
|
|
|
- if (res.code === 200) {
|
|
|
- this.form.companyName = res.data.companyName;
|
|
|
- this.form.deptName = res.data.deptName;
|
|
|
- }
|
|
|
- });
|
|
|
- },
|
|
|
-
|
|
|
- // 表单提交方法
|
|
|
- submit() {
|
|
|
- this.$refs.formRef.validate(valid => {
|
|
|
- if (valid) {
|
|
|
- const apiKey = this.mode == "add" && "saveDone" || "edit";
|
|
|
- API[apiKey](this.form).then(() => {
|
|
|
- ElMessage.success("操作成功");
|
|
|
- this.visible = false;
|
|
|
- this.fileIsDel = false;
|
|
|
- this.$emit("success", apiKey);
|
|
|
- });
|
|
|
- } else {
|
|
|
- return false;
|
|
|
- }
|
|
|
- });
|
|
|
- }
|
|
|
- }
|
|
|
-}
|
|
|
-</script>
|
|
|
-
|
|
|
-<style lang="scss" scoped>
|
|
|
-.el-input-number {
|
|
|
- width: 100%;
|
|
|
-
|
|
|
- :deep(.el-input) .el-input__wrapper {
|
|
|
- padding: 1px 11px;
|
|
|
-
|
|
|
- .el-input__inner {
|
|
|
- text-align: unset;
|
|
|
- }
|
|
|
- }
|
|
|
-}
|
|
|
-</style>
|