|  | @@ -16,85 +16,86 @@
 | 
	
		
			
				|  |  |            label-width="130px"
 | 
	
		
			
				|  |  |            label-prefix=":"
 | 
	
		
			
				|  |  |          >
 | 
	
		
			
				|  |  | -          <el-form-item prop="orgId" label="签署责任人所在机构:">
 | 
	
		
			
				|  |  | +          <el-form-item prop="orgId" label="选择机构:">
 | 
	
		
			
				|  |  |              <tree-select
 | 
	
		
			
				|  |  | -              v-model="formData.orgId"
 | 
	
		
			
				|  |  | -              :options="deptOptions"
 | 
	
		
			
				|  |  | -              :show-count="true"
 | 
	
		
			
				|  |  | -              :normalizer="tenantIdnormalizer"
 | 
	
		
			
				|  |  | -              :props="{ checkStrictly: true, label: 'name' }"
 | 
	
		
			
				|  |  | -              placeholder="请选择签署责任人所在机构"
 | 
	
		
			
				|  |  | -            />
 | 
	
		
			
				|  |  | +                v-model="formData.orgId"
 | 
	
		
			
				|  |  | +                :options="deptOptions"
 | 
	
		
			
				|  |  | +                :show-count="true"
 | 
	
		
			
				|  |  | +                :normalizer="tenantIdnormalizer"
 | 
	
		
			
				|  |  | +                :props="{ checkStrictly: true, label: 'name' }"
 | 
	
		
			
				|  |  | +                placeholder="请选择机构"
 | 
	
		
			
				|  |  | +                :noChildrenText="''"
 | 
	
		
			
				|  |  | +                noOptionsText="没有数据"
 | 
	
		
			
				|  |  | +                noResultsText="没有搜索结果"
 | 
	
		
			
				|  |  | +              />
 | 
	
		
			
				|  |  |            </el-form-item>
 | 
	
		
			
				|  |  | -          <el-form-item prop="type" label="签署责任书类型:">
 | 
	
		
			
				|  |  | -            <el-select
 | 
	
		
			
				|  |  | -              v-model="formData.type"
 | 
	
		
			
				|  |  | -              style="width: 100%"
 | 
	
		
			
				|  |  | -              placeholder="请选择签署责任书类型"
 | 
	
		
			
				|  |  | -            >
 | 
	
		
			
				|  |  | -              <el-option
 | 
	
		
			
				|  |  | -                v-for="dict in dict.type.safety_book_type"
 | 
	
		
			
				|  |  | -                :key="dict.value"
 | 
	
		
			
				|  |  | -                :label="dict.label"
 | 
	
		
			
				|  |  | -                :value="`${dict.value}`"
 | 
	
		
			
				|  |  | -              ></el-option>
 | 
	
		
			
				|  |  | -            </el-select>
 | 
	
		
			
				|  |  | +          <el-form-item prop="userIds" label="参与人员:">
 | 
	
		
			
				|  |  | +            <div>
 | 
	
		
			
				|  |  | +              <el-input
 | 
	
		
			
				|  |  | +                :readonly="true"
 | 
	
		
			
				|  |  | +                v-model="joinedStringArray"
 | 
	
		
			
				|  |  | +                placeholder="点击选择"
 | 
	
		
			
				|  |  | +              ></el-input>
 | 
	
		
			
				|  |  | +              <el-button @click="selectUser">选择</el-button>
 | 
	
		
			
				|  |  | +            </div>
 | 
	
		
			
				|  |  | +          </el-form-item>
 | 
	
		
			
				|  |  | +          <el-form-item prop="date" label="开会日期:">
 | 
	
		
			
				|  |  | +            <el-date-picker
 | 
	
		
			
				|  |  | +              v-model="formData.date"
 | 
	
		
			
				|  |  | +              style="width: 240px"
 | 
	
		
			
				|  |  | +              value-format="yyyy-MM-dd hh:mm:ss"
 | 
	
		
			
				|  |  | +              placeholder="请选择记录日期"
 | 
	
		
			
				|  |  | +              type="datetime"
 | 
	
		
			
				|  |  | +              :clearable="false"
 | 
	
		
			
				|  |  | +            ></el-date-picker>
 | 
	
		
			
				|  |  |            </el-form-item>
 | 
	
		
			
				|  |  | -        </el-form>
 | 
	
		
			
				|  |  | -        <el-button @click="openSelect">新增签署</el-button>
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        <el-table :data="tableData" style="width: 100%" height="400px">
 | 
	
		
			
				|  |  | -          <el-table-column prop="names" label="姓名">
 | 
	
		
			
				|  |  | -            <template slot-scope="scope">
 | 
	
		
			
				|  |  | -              <template v-for="item in scope.row.names">
 | 
	
		
			
				|  |  | -                {{ item }}
 | 
	
		
			
				|  |  | -                <br />
 | 
	
		
			
				|  |  | -              </template>
 | 
	
		
			
				|  |  | -            </template>
 | 
	
		
			
				|  |  | -          </el-table-column>
 | 
	
		
			
				|  |  | -          <el-table-column prop="time" label="签署时间"> </el-table-column>
 | 
	
		
			
				|  |  | -          <el-table-column prop="files" label="签署文件"> </el-table-column>
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -          <el-table-column prop="names" label="操作">
 | 
	
		
			
				|  |  | -            <template v-slot="{ row }">
 | 
	
		
			
				|  |  | -              <el-button type="text" @click="removeRow(row)">删除</el-button>
 | 
	
		
			
				|  |  | -            </template>
 | 
	
		
			
				|  |  | -          </el-table-column>
 | 
	
		
			
				|  |  | -        </el-table>
 | 
	
		
			
				|  |  | +          <el-form-item label="照片" prop="images">
 | 
	
		
			
				|  |  | +            <imgs-upload
 | 
	
		
			
				|  |  | +              :limit="5"
 | 
	
		
			
				|  |  | +              v-model="formData.images"
 | 
	
		
			
				|  |  | +              :fileSize="2"
 | 
	
		
			
				|  |  | +            ></imgs-upload>
 | 
	
		
			
				|  |  | +          </el-form-item>
 | 
	
		
			
				|  |  | +          <div>
 | 
	
		
			
				|  |  | +            <el-form-item label="内容" prop="content">
 | 
	
		
			
				|  |  | +              <Editor style="height: 150px" v-model="formData.content"></Editor>
 | 
	
		
			
				|  |  | +            </el-form-item>
 | 
	
		
			
				|  |  | +          </div>
 | 
	
		
			
				|  |  | +        </el-form>
 | 
	
		
			
				|  |  |        </div>
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -      <div slot="footer" class="dialog-footer">
 | 
	
		
			
				|  |  | +      <div style="margin-top: 100px" slot="footer" class="dialog-footer">
 | 
	
		
			
				|  |  |          <el-button @click="isShow = false">取消</el-button>
 | 
	
		
			
				|  |  |          <el-button type="primary" @click="onSubmit">确定</el-button>
 | 
	
		
			
				|  |  |        </div>
 | 
	
		
			
				|  |  | -   </DialogCom>
 | 
	
		
			
				|  |  | -    <DialogSelect ref="DialogSelect" @success="getSign"></DialogSelect>
 | 
	
		
			
				|  |  | +    </DialogCom>
 | 
	
		
			
				|  |  | +    <UserSelector ref="UserSelector" @select="onUserSelect"></UserSelector>
 | 
	
		
			
				|  |  |    </div>
 | 
	
		
			
				|  |  |  </template>
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  <script>
 | 
	
		
			
				|  |  |  import { mapState, mapMutations } from "vuex";
 | 
	
		
			
				|  |  | -import {
 | 
	
		
			
				|  |  | -  listSafetyBook,
 | 
	
		
			
				|  |  | -  getSafetyBook,
 | 
	
		
			
				|  |  | -  editOrAdd,
 | 
	
		
			
				|  |  | -  delSafetyBook,
 | 
	
		
			
				|  |  | -} from "@/api/safetyBook/index";
 | 
	
		
			
				|  |  | +import { Add, edit, getaqbwbndjh } from "@/api/safetyBook/aqbwbndjh";
 | 
	
		
			
				|  |  |  import { deptTreeSelect } from "@/api/system/public";
 | 
	
		
			
				|  |  | -import DialogSelect from "./dialog.sign";
 | 
	
		
			
				|  |  | +import UserSelector from "@/components/userSelector/index.vue";
 | 
	
		
			
				|  |  | +import ImgsUpload from "@/components/ImgsUpload";
 | 
	
		
			
				|  |  | +import Editor from "@/components/Editor";
 | 
	
		
			
				|  |  |  export default {
 | 
	
		
			
				|  |  | -  dicts: ["safety_book_type"],
 | 
	
		
			
				|  |  | +  components: { UserSelector, ImgsUpload, Editor },
 | 
	
		
			
				|  |  |    data() {
 | 
	
		
			
				|  |  |      return {
 | 
	
		
			
				|  |  |        id: null,
 | 
	
		
			
				|  |  |        isShow: false,
 | 
	
		
			
				|  |  |        formData: this.reset(),
 | 
	
		
			
				|  |  | -      tableData: [],
 | 
	
		
			
				|  |  |        //修改新增中的机构树
 | 
	
		
			
				|  |  |        deptOptions: [],
 | 
	
		
			
				|  |  |        formDataRules: {
 | 
	
		
			
				|  |  | -        orgId: [{ required: true, message: "请选择签署责任人所在机构" }],
 | 
	
		
			
				|  |  | -        type: [{ required: true, message: "请选择签署责任书类型" }],
 | 
	
		
			
				|  |  | +        userIds: [{ required: true, message: "请选择参与人员" }],
 | 
	
		
			
				|  |  | +        date: [{ required: true, message: "请选择记录日期" }],
 | 
	
		
			
				|  |  | +        images: [{ required: true, message: "请选择照片" }],
 | 
	
		
			
				|  |  | +        content: [{ required: true, message: "请输入内容" }],
 | 
	
		
			
				|  |  | +        orgId: [{ required: true, message: "请选择机构" }],
 | 
	
		
			
				|  |  |        },
 | 
	
		
			
				|  |  |      };
 | 
	
		
			
				|  |  |    },
 | 
	
	
		
			
				|  | @@ -102,18 +103,21 @@ export default {
 | 
	
		
			
				|  |  |    watch: {},
 | 
	
		
			
				|  |  |    computed: {
 | 
	
		
			
				|  |  |      ...mapState([]),
 | 
	
		
			
				|  |  | +    joinedStringArray: {
 | 
	
		
			
				|  |  | +      get() {
 | 
	
		
			
				|  |  | +        if (this.formData.names == null || this.formData.names == undefined) {
 | 
	
		
			
				|  |  | +          this.formData.names = this.formData.userNames.split(", ");
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +        return this.formData.names.join(", ");
 | 
	
		
			
				|  |  | +      },
 | 
	
		
			
				|  |  | +      set(value) {
 | 
	
		
			
				|  |  | +        this.formData.names = value.split(", ");
 | 
	
		
			
				|  |  | +      },
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  |    },
 | 
	
		
			
				|  |  |    methods: {
 | 
	
		
			
				|  |  |      ...mapMutations([]),
 | 
	
		
			
				|  |  | -    //添加签署后回调
 | 
	
		
			
				|  |  | -    getSign(data) {
 | 
	
		
			
				|  |  | -      this.tableData.push(data);
 | 
	
		
			
				|  |  | -      // console.log(data, "ddd");
 | 
	
		
			
				|  |  | -    },
 | 
	
		
			
				|  |  | -    //新增签署
 | 
	
		
			
				|  |  | -    openSelect() {
 | 
	
		
			
				|  |  | -      this.$refs.DialogSelect.show();
 | 
	
		
			
				|  |  | -    },
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |      /** 查询机构树数据 */
 | 
	
		
			
				|  |  |      getDeptTree() {
 | 
	
		
			
				|  |  |        deptTreeSelect().then((response) => {
 | 
	
	
		
			
				|  | @@ -131,29 +135,31 @@ export default {
 | 
	
		
			
				|  |  |          children: node.children,
 | 
	
		
			
				|  |  |        };
 | 
	
		
			
				|  |  |      },
 | 
	
		
			
				|  |  | -    removeRow(row) {
 | 
	
		
			
				|  |  | -      this.tableData = this.tableData.filter((item) => item !== row);
 | 
	
		
			
				|  |  | -    },
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |      reset() {
 | 
	
		
			
				|  |  |        return {
 | 
	
		
			
				|  |  |          id: null,
 | 
	
		
			
				|  |  | -        type: null,
 | 
	
		
			
				|  |  | +        names: [],
 | 
	
		
			
				|  |  | +        userIds: [],
 | 
	
		
			
				|  |  | +        date: null,
 | 
	
		
			
				|  |  | +        images: [],
 | 
	
		
			
				|  |  | +        content: null,
 | 
	
		
			
				|  |  | +        title: null,
 | 
	
		
			
				|  |  | +        orgId:null,
 | 
	
		
			
				|  |  |        };
 | 
	
		
			
				|  |  |      },
 | 
	
		
			
				|  |  |      async refresh(id) {
 | 
	
		
			
				|  |  | -      if(id!=null&&id!=undefined){
 | 
	
		
			
				|  |  | -        await getSafetyBook(id).then((res) => {
 | 
	
		
			
				|  |  | -          // console.log(res.data,"res")
 | 
	
		
			
				|  |  | -          this.formData=res.data;
 | 
	
		
			
				|  |  | -          this.tableData=res.data.bookUsers;
 | 
	
		
			
				|  |  | +      if (id != null && id != undefined) {
 | 
	
		
			
				|  |  | +        await getaqbwbndjh(id).then((res) => {
 | 
	
		
			
				|  |  | +          this.formData.names = res.data.userNames.split(",");
 | 
	
		
			
				|  |  | +          this.formData = res.data;
 | 
	
		
			
				|  |  |          });
 | 
	
		
			
				|  |  |        }
 | 
	
		
			
				|  |  |      },
 | 
	
		
			
				|  |  |      async show(id) {
 | 
	
		
			
				|  |  |        // console.log(id, "id");
 | 
	
		
			
				|  |  |        this.getDeptTree();
 | 
	
		
			
				|  |  | -      this.formData=this.reset();
 | 
	
		
			
				|  |  | -      this.tableData=[];
 | 
	
		
			
				|  |  | +      this.formData = this.reset();
 | 
	
		
			
				|  |  |        this.id = id;
 | 
	
		
			
				|  |  |        await this.refresh(id);
 | 
	
		
			
				|  |  |        this.isShow = true;
 | 
	
	
		
			
				|  | @@ -165,21 +171,41 @@ export default {
 | 
	
		
			
				|  |  |        this.$refs.form.resetFields();
 | 
	
		
			
				|  |  |      },
 | 
	
		
			
				|  |  |      onSubmit() {
 | 
	
		
			
				|  |  | -      console.log(this.formData,"this.formData")
 | 
	
		
			
				|  |  | +      console.log(this.formData, "this.formData");
 | 
	
		
			
				|  |  |        this.$refs.form.validate(async (isValidate) => {
 | 
	
		
			
				|  |  |          if (!isValidate) return;
 | 
	
		
			
				|  |  | -        this.formData.bookUsers=this.tableData;
 | 
	
		
			
				|  |  | -        await editOrAdd(this.formData);
 | 
	
		
			
				|  |  | -        this.$emit("success");
 | 
	
		
			
				|  |  | -        this.isShow = false;
 | 
	
		
			
				|  |  | +        if (this.id == null || this.id == undefined) {
 | 
	
		
			
				|  |  | +          await Add(this.formData).then((res) => {
 | 
	
		
			
				|  |  | +            this.$emit("success");
 | 
	
		
			
				|  |  | +            this.isShow = false;
 | 
	
		
			
				|  |  | +          });
 | 
	
		
			
				|  |  | +        } else {
 | 
	
		
			
				|  |  | +          await edit(this.formData).then((res) => {
 | 
	
		
			
				|  |  | +            this.$emit("success");
 | 
	
		
			
				|  |  | +            this.isShow = false;
 | 
	
		
			
				|  |  | +          });
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  |        });
 | 
	
		
			
				|  |  |      },
 | 
	
		
			
				|  |  | +    //选择用户回调
 | 
	
		
			
				|  |  | +    onUserSelect(data) {
 | 
	
		
			
				|  |  | +      var ids = data.map((obj) => obj.id);
 | 
	
		
			
				|  |  | +      var names = data.map((obj) => obj.name);
 | 
	
		
			
				|  |  | +      this.formData.userIds = ids;
 | 
	
		
			
				|  |  | +      this.formData.names = names;
 | 
	
		
			
				|  |  | +      this.formData.userNames = names.join(",");
 | 
	
		
			
				|  |  | +      //   console.log(this.formData.userIds, "this.formData.userIds");
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    //用户选择
 | 
	
		
			
				|  |  | +    selectUser(event) {
 | 
	
		
			
				|  |  | +      //   event.preventDefault();
 | 
	
		
			
				|  |  | +      this.$refs.UserSelector.show();
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      // 事件
 | 
	
		
			
				|  |  |      //apimark//
 | 
	
		
			
				|  |  |    },
 | 
	
		
			
				|  |  |    mounted() {},
 | 
	
		
			
				|  |  | -  components: { DialogSelect },
 | 
	
		
			
				|  |  |  };
 | 
	
		
			
				|  |  |  </script>
 | 
	
		
			
				|  |  |  
 |