1312eeb57ff234386b53d07869e844fe68afa482..b7ebccdbc4f29cc7663582213886579091c84dd5
昨天 祖安之光
修改新增
b7ebcc 对比 | 目录
昨天 zhouwx
修改
68c36c 对比 | 目录
昨天 zhouwx
修改
dfc1da 对比 | 目录
昨天 zhouwx
修改
29a021 对比 | 目录
昨天 zhouwx
修改
708c8c 对比 | 目录
昨天 zhouwx
修改
dcddf9 对比 | 目录
已修改37个文件
1865 ■■■■ 文件已修改
package.json 1 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/Tinymce/Tinymce.vue 6 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main.js 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/companyInfo/basicInfo/components/basicInfoDialog.vue 59 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/companyInfo/basicInfo/index.vue 58 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/companyInfo/overview/components/overviewDialog.vue 50 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/companyInfo/overview/index.vue 107 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/companyInfo/policy/components/policyDialog.vue 56 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/companyInfo/policy/index.vue 66 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/companyInfo/qualifications/components/qualificationsDialog.vue 27 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/companyInfo/qualifications/index.vue 68 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/appFile/index.vue 33 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/qualityManual/index.vue 43 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/recordSheets/index.vue 35 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/workInstruct/index.vue 33 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/digitalFileDep/otherIntellFile/index.vue 33 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/digitalFileDep/productType/index.vue 33 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/digitalFileDep/techType/index.vue 33 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/industryTemplate/index.vue 33 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/orgStructure/departManage/components/departDialog.vue 26 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/orgStructure/departManage/components/dutyDialog.vue 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/orgStructure/departManage/index.vue 16 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/orgStructure/dutyDistributeChart/index.vue 72 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/qualityManage/rangeManage/range/components/dataDialog.vue 16 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/qualityManage/rangeManage/range/index.vue 80 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/qualityObjectives/objective/components/objectiveDialog.vue 187 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/qualityObjectives/objective/index.vue 58 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/qualityObjectives/reportsituation/components/stationCompanyDialog.vue 93 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/qualityObjectives/reportsituation/index.vue 58 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/qualityObjectives/table/components/tableCompanyDialog.vue 130 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/qualityObjectives/table/components/tableDeptDialog.vue 153 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/qualityObjectives/table/index.vue 80 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/staffManage/staffRegister/components/staffDialog.vue 6 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/staffManage/staffRegister/index.vue 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/standardSysTemp/appStandardModule/index.vue 38 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/standardSysTemp/sysStandardModule/index.vue 39 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/standardSysTemp/techStandardModule/index.vue 33 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
package.json
@@ -23,6 +23,7 @@
    "@wangeditor/editor-for-vue": "^5.1.12",
    "@wangeditor/plugin-upload-attachment": "^1.1.0",
    "axios": "0.27.2",
    "docx-preview": "^0.3.5",
    "docxtemplater": "^3.63.2",
    "echarts": "5.4.0",
    "element-plus": "2.2.27",
src/components/Tinymce/Tinymce.vue
@@ -36,6 +36,10 @@
            type: String,
            default: ""
        },
      height: {
        type: Number,
        default: 500
      },
        disabled: {
            type: Boolean,
            default: false
@@ -58,7 +62,7 @@
                language: "zh_CN",
                skin_url: "/tinymce/skins/ui/oxide", // skin路径
                content_css: '/tinymce/skins/content/default/content.css',
                height: 500, // 编辑器高度
                height: this.height? this.height : 500, // 编辑器高度
                branding: false, // 是否禁用“Powered by TinyMCE”
                menubar: true, // 顶部菜单栏显示
                plugins: this.plugins,
src/main.js
@@ -45,7 +45,7 @@
import preReClick from "@/utils/preReClick";
import vue3JsonExcel   from 'vue3-json-excel';
import vue3JsonExcel from 'vue3-json-excel';
import { Boot } from '@wangeditor/editor'
src/views/build/conpanyFunctionConsult/companyInfo/basicInfo/components/basicInfoDialog.vue
@@ -9,25 +9,14 @@
        :close-on-click-modal="false"
    >
      <el-form :model="state.form" size="default" ref="busRef" :rules="state.formRules" label-position="top" label-width="150px" >
        <el-form-item label="企业名称:" prop="companyName" v-if="state.isAdmin">
          <el-select
              v-model="state.form.companyName"
              filterable
              remote
              :disabled="title == '查看' || title == '编辑' || !state.isAdmin"
              @change="selectValue"
              reserve-keyword
              placeholder="请输入企业名称"
              remote-show-suffix
              :remote-method="getCompanyList"
              style="width: 100%"
          >
        <el-form-item label="企业名称:" prop="companyId" v-if="state.isAdmin">
          <el-select v-model="state.form.companyId" filterable placeholder="请选择" clearable style="width: 100%" :disabled="title == '查看' || title == '编辑' || !state.isAdmin">
            <el-option
                v-for="item in state.companyList"
                :key="item.id"
                :label="item.name"
                :value="item.name"
            />
                :value="item.id">
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="1.企业的基本情况,主要包括:法人证书编号,所属部门、法人代表姓名、身份证号、职务、人员总数、技术人员数、不良情况记录、保密等资质。" prop="basic" >
@@ -95,7 +84,7 @@
    resource: '',
  },
  formRules:{
    companyName: [{ required: true, message: '请选择企业', trigger: 'blur' }],
    companyId: [{ required: true, message: '请选择企业', trigger: 'blur' }],
    basic: [{ required: true, message: '请输入', trigger: 'blur' }],
    introduce:[{ required: true, message: '请输入', trigger: 'blur' }],
    target: [{ required: true, message: '请输入', trigger: 'blur' }],
@@ -112,13 +101,13 @@
onMounted(() => {
})
const openDialog = async (type, value) => {
const openDialog = async (type, value,companyList) => {
  const userInfo = JSON.parse(Cookies.get('userInfo'))
  state.isAdmin = userInfo.userType === 0;
  if(state.isAdmin){
    await   getCompanyList()
   state.companyList = companyList
  }
  title.value = type === 'add' ? '新增' : type ==='edit' ? '编辑' : '查看' ;
  if(type === 'edit' || type === 'review') {
@@ -195,40 +184,6 @@
  }
  state.companyList = []
}
const selectValue = (val) => {
  state.companyList.forEach(item => {
    if(item.name === val){
      state.form.companyId = item.id
    }
  })
}
const getCompanyList = async (val)=>{
  if(val){
    const queryParams = {
      name: val
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      state.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }else {
    const queryParams = {
      pageSize: 10,
      pageNum: 1,
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      state.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }
}
defineExpose({
  openDialog
src/views/build/conpanyFunctionConsult/companyInfo/basicInfo/index.vue
@@ -11,24 +11,13 @@
            >新增</el-button>
          </el-form-item>
          <el-form-item label="企业名称:" v-if="data.isAdmin" style="margin-left: 20px">
            <el-select
                v-model="data.queryParams.companyName"
                filterable
                remote
                @change="selectValue"
                reserve-keyword
                placeholder="请输入企业名称"
                remote-show-suffix
                :remote-method="getCompanyList"
                :loading="loadingCompany"
                style="width: 240px"
            >
            <el-select v-model="data.queryParams.companyId" filterable placeholder="请选择" clearable>
              <el-option
                  v-for="item in data.companyList"
                  :key="item.id"
                  :label="item.name"
                  :value="item.name"
              />
                  :value="item.id">
              </el-option>
            </el-select>
          </el-form-item>
          <el-form-item v-if="data.isAdmin">
@@ -134,7 +123,7 @@
  getList();
}
const openDialog = (type, value) => {
  noticeRef.value.openDialog(type, value);
  noticeRef.value.openDialog(type, value,data.companyList);
}
const selectValue = (val) => {
  data.companyList.forEach(item => {
@@ -144,34 +133,17 @@
  })
}
const getCompanyList = async (val)=>{
  if(val){
    loadingCompany.value = true;
    const queryParams = {
      name: val
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      loadingCompany.value = false;
      data.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }else {
    loadingCompany.value = true;
    const queryParams = {
      pageSize: 10,
      pageNum: 1,
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      loadingCompany.value = false;
      data.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
const getCompanyList = async ()=>{
  const queryParams = {
    pageNum: 1,
    pageSize: 999
  }
  const res = await getCompany(queryParams)
  if (res.code == 200) {
    data.companyList = res.data.list?res.data.list:[]
    // data.queryParams.companyId = data.companyList[0].id
  } else {
    ElMessage.warning(res.message)
  }
}
src/views/build/conpanyFunctionConsult/companyInfo/overview/components/overviewDialog.vue
@@ -7,25 +7,15 @@
            :before-close="handleClose"
        >
            <el-form :model="state.noticeForm" size="default" ref="noticeRef" :rules="title === '新增' || title === '编辑' ? state.formRules : {}" label-width="110px" >
              <el-form-item label="企业名称:" prop="companyName" v-if="state.isAdmin">
                <el-select
                    v-model="state.noticeForm.companyName"
                    filterable
                    remote
                    :disabled="title == '查看' || title == '编辑' || !state.isAdmin"
                    @change="selectValue"
                    reserve-keyword
                    placeholder="请输入企业名称"
                    remote-show-suffix
                    :remote-method="getCompanyList"
                    style="width: 100%"
                >
              <el-form-item v-if="state.isAdmin" label="企业:" prop="companyId">
                <el-select v-model="state.noticeForm.companyId" placeholder="请选择" clearable filterable style="width: 100%" :disabled="title == '查看' || title == '编辑' || !state.isAdmin">
                  <el-option
                      v-for="item in state.companyList"
                      :key="item.id"
                      :label="item.name"
                      :value="item.name"
                  />
                      :value="item.id">
                  </el-option>
                </el-select>
              </el-form-item>
                <el-form-item label="企业概括:" v-if="showEditor"  required>
@@ -80,7 +70,7 @@
        companyName: ''
    },
    formRules:{
      companyName: [{ required: true, message: '请选择企业', trigger: 'blur' }],
      companyId: [{ required: true, message: '请选择企业', trigger: 'blur' }],
      companySummary: [{ required: true, message: '企业概况', trigger: 'blur' }],
    },
  isAdmin: false,
@@ -90,12 +80,12 @@
onMounted(() => {
});
const openDialog = async (type, value) => {
const openDialog = async (type, value,companyList) => {
    const userInfo = JSON.parse(Cookies.get('userInfo'))
    state.isAdmin = userInfo.userType === 0;
  if(state.isAdmin){
    await   getCompanyList()
    state.companyList = companyList
  }
    isReview.value = false;
    showEditor.value = false
@@ -158,31 +148,7 @@
        })
    }
}
const getCompanyList = async (val)=>{
  if(val){
    const queryParams = {
      name: val
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      state.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }else {
    const queryParams = {
      pageSize: 10,
      pageNum: 1,
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      state.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }
}
const onSubmit = async () => {
    state.noticeForm.companySummary = tinyMCE.activeEditor.getContent();
src/views/build/conpanyFunctionConsult/companyInfo/overview/index.vue
@@ -11,25 +11,33 @@
          >新增</el-button>
        </el-form-item>
        <el-form-item label="企业名称:" v-if="data.isAdmin" style="margin-left: 20px">
          <el-select
              v-model="data.companyName"
              filterable
              remote
              @change="selectValue"
              reserve-keyword
              placeholder="请输入企业名称"
              remote-show-suffix
              :remote-method="getCompanyList"
              :loading="loadingCompany"
              style="width: 240px"
          >
          <el-select v-model="data.queryParams.companyId" filterable placeholder="请选择" clearable>
            <el-option
                v-for="item in data.companyList"
                :key="item.id"
                :label="item.name"
                :value="item.name"
            />
                :value="item.id">
            </el-option>
          </el-select>
<!--          <el-select-->
<!--              v-model="data.companyName"-->
<!--              filterable-->
<!--              remote-->
<!--              @change="selectValue"-->
<!--              reserve-keyword-->
<!--              placeholder="请输入企业名称"-->
<!--              remote-show-suffix-->
<!--              :remote-method="getCompanyList"-->
<!--              :loading="loadingCompany"-->
<!--              style="width: 240px"-->
<!--          >-->
<!--            <el-option-->
<!--                v-for="item in data.companyList"-->
<!--                :key="item.id"-->
<!--                :label="item.name"-->
<!--                :value="item.name"-->
<!--            />-->
<!--          </el-select>-->
        </el-form-item>
        <el-form-item v-if="data.isAdmin">
          <el-button type="primary" style="margin-left: 30px" @click="searchClick">查询</el-button>
@@ -124,7 +132,7 @@
  getList();
}
const openDialog = (type, value) => {
  noticeRef.value.openDialog(type, value);
  noticeRef.value.openDialog(type, value,data.companyList);
}
const selectValue = (val) => {
  data.companyList.forEach(item => {
@@ -134,36 +142,49 @@
  })
}
const getCompanyList = async (val)=>{
  if(val){
    loadingCompany.value = true;
    const queryParams = {
      name: val
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      loadingCompany.value = false;
      data.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }else{
    loadingCompany.value = true;
    const queryParams = {
      pageSize: 10,
      pageNum: 1,
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      loadingCompany.value = false;
      data.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
const getCompanyList = async ()=>{
  const queryParams = {
    pageNum: 1,
    pageSize: 999
  }
  const res = await getCompany(queryParams)
  if (res.code == 200) {
    data.companyList = res.data.list?res.data.list:[]
    // data.queryParams.companyId = data.companyList[0].id
  } else {
    ElMessage.warning(res.message)
  }
}
// const getCompanyList = async (val)=>{
//   if(val){
//     loadingCompany.value = true;
//     const queryParams = {
//       name: val
//     }
//     const res = await getCompany(queryParams)
//     if (res.code == 200) {
//       loadingCompany.value = false;
//       data.companyList = res.data.list
//
//     } else {
//       ElMessage.warning(res.message)
//     }
//   }else{
//     loadingCompany.value = true;
//     const queryParams = {
//       pageSize: 999,
//       pageNum: 1,
//     }
//     const res = await getCompany(queryParams)
//     if (res.code == 200) {
//       loadingCompany.value = false;
//       data.companyList = res.data.list
//
//     } else {
//       ElMessage.warning(res.message)
//     }
//   }
// }
const handleSizeChange = (val) => {
  data.queryParams.pageSize = val
src/views/build/conpanyFunctionConsult/companyInfo/policy/components/policyDialog.vue
@@ -7,25 +7,14 @@
        :before-close="handleClose"
    >
      <el-form :model="state.noticeForm" size="default" ref="noticeRef" :rules="title === '新增' || title === '编辑' ? state.formRules : {}" label-width="110px" >
        <el-form-item label="企业名称:" prop="companyName" v-if="state.isAdmin">
          <el-select
              v-model="state.noticeForm.companyName"
              filterable
              remote
              :disabled="title == '查看' || title == '编辑' ||!state.isAdmin"
              @change="selectValue"
              reserve-keyword
              placeholder="请输入企业名称"
              remote-show-suffix
              :remote-method="getCompanyList"
              style="width: 100%"
          >
        <el-form-item label="企业名称:" prop="companyId" v-if="state.isAdmin">
          <el-select v-model="state.noticeForm.companyId" placeholder="请选择" filterable clearable style="width: 100%" :disabled="title == '查看' || title == '编辑' || !state.isAdmin">
            <el-option
                v-for="item in state.companyList"
                :key="item.id"
                :label="item.name"
                :value="item.name"
            />
                :value="item.id">
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="质量方针:" v-if="showEditor"  required>
@@ -81,7 +70,7 @@
    companyName: ''
  },
  formRules:{
    companyName: [{ required: true, message: '请选择企业', trigger: 'blur' }],
    companyId: [{ required: true, message: '请选择企业', trigger: 'blur' }],
    policy: [{ required: true, message: '质量方针', trigger: 'blur' }],
  },
  isAdmin: false,
@@ -92,11 +81,11 @@
onMounted(() => {
});
const openDialog = async (type, value) => {
const openDialog = async (type, value,companyList) => {
  const userInfo = JSON.parse(Cookies.get('userInfo'))
  state.isAdmin = userInfo.userType === 0;
  if(state.isAdmin){
    await   getCompanyList()
   state.companyList = companyList
  }
  isReview.value = false;
  showEditor.value = false
@@ -233,38 +222,7 @@
    companyName: ''
  }
}
const selectValue = (val) => {
  state.companyList.forEach(item => {
    if(item.name === val){
      state.noticeForm.companyId = item.id
    }
  })
}
const getCompanyList = async (val)=>{
  if(val){
    const queryParams = {
      name: val
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      state.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }else {
    const queryParams = {
      pageSize: 10,
      pageNum: 1,
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      state.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }
}
defineExpose({
  openDialog
src/views/build/conpanyFunctionConsult/companyInfo/policy/index.vue
@@ -11,24 +11,13 @@
          >新增</el-button>
        </el-form-item>
        <el-form-item label="企业名称:" v-if="data.isAdmin" style="margin-left: 20px">
          <el-select
              v-model="data.companyName"
              filterable
              remote
              @change="selectValue"
              reserve-keyword
              placeholder="请输入企业名称"
              remote-show-suffix
              :remote-method="getCompanyList"
              :loading="loadingCompany"
              style="width: 240px"
          >
          <el-select v-model="data.queryParams.companyId" placeholder="请选择" filterable clearable>
            <el-option
                v-for="item in data.companyList"
                :key="item.id"
                :label="item.name"
                :value="item.name"
            />
                :value="item.id">
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item v-if="data.isAdmin">
@@ -125,44 +114,19 @@
  getList();
}
const openDialog = (type, value) => {
  noticeRef.value.openDialog(type, value);
  noticeRef.value.openDialog(type, value,data.companyList);
}
const selectValue = (val) => {
  data.companyList.forEach(item => {
    if(item.name === val){
      data.queryParams.companyId = item.id
    }
  })
}
const getCompanyList = async (val)=>{
  if(val){
    loadingCompany.value = true;
    const queryParams = {
      name: val
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      loadingCompany.value = false;
      data.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }else{
    loadingCompany.value = true;
    const queryParams = {
      pageSize: 10,
      pageNum: 1,
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      loadingCompany.value = false;
      data.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
const getCompanyList = async ()=>{
  const queryParams = {
    pageNum: 1,
    pageSize: 999
  }
  const res = await getCompany(queryParams)
  if (res.code == 200) {
    data.companyList = res.data.list?res.data.list:[]
    // data.queryParams.companyId = data.companyList[0].id
  } else {
    ElMessage.warning(res.message)
  }
}
src/views/build/conpanyFunctionConsult/companyInfo/qualifications/components/qualificationsDialog.vue
@@ -9,25 +9,14 @@
        :close-on-click-modal="false"
    >
      <el-form :model="state.form" size="default" ref="busRef" :rules="state.formRules" label-width="150px" >
        <el-form-item label="企业名称:" prop="companyName" v-if="state.isAdmin">
          <el-select
              v-model="state.form.companyName"
              filterable
              remote
              :disabled="title == '查看' || title == '编辑' || !state.isAdmin"
              @change="selectValue"
              reserve-keyword
              placeholder="请输入企业名称"
              remote-show-suffix
              :remote-method="getCompanyList"
              style="width: 100%"
          >
        <el-form-item label="企业名称:" prop="companyId" v-if="state.isAdmin">
          <el-select v-model="state.form.companyId" placeholder="请选择" filterable clearable style="width: 100%" :disabled="title == '查看' || title == '编辑' || !state.isAdmin">
            <el-option
                v-for="item in state.companyList"
                :key="item.id"
                :label="item.name"
                :value="item.name"
            />
                :value="item.id">
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="取得资质证书名称:" prop="certificateName" >
@@ -106,7 +95,7 @@
    fileName: ''
  },
  formRules:{
    companyName: [{ required: true, message: '请选择企业', trigger: 'blur' }],
    companyId: [{ required: true, message: '请选择企业', trigger: 'blur' }],
    certificateName:[{ required: true, message: '请输入取得资质证书名称', trigger: 'blur' }],
    certificateNum:[{ required: true, message: '请输入证书编号', trigger: 'blur' }],
    effectiveTime:[{ required: true, message: '请选择截止日期', trigger: 'blur' }],
@@ -122,11 +111,11 @@
})
const openDialog = async (type, value) => {
const openDialog = async (type, value,companyList) => {
  const userInfo = JSON.parse(Cookies.get('userInfo'))
  state.isAdmin = userInfo.userType === 0;
  if(state.isAdmin){
    await   getCompanyList()
    state.companyList = companyList
  }
  title.value = type === 'add' ? '新增' : type ==='edit' ? '编辑' : '查看' ;
  if(type === 'edit' || type === 'review') {
@@ -269,7 +258,7 @@
    }
  }else{
    const queryParams = {
      pageSize: 10,
      pageSize: 999,
      pageNum: 1,
    }
    const res = await getCompany(queryParams)
src/views/build/conpanyFunctionConsult/companyInfo/qualifications/index.vue
@@ -11,24 +11,13 @@
            >新增</el-button>
          </el-form-item>
          <el-form-item label="企业名称:" v-if="data.isAdmin" style="margin-left: 20px">
            <el-select
                v-model="data.queryParams.companyName"
                filterable
                remote
                @change="selectValue"
                reserve-keyword
                placeholder="请输入企业名称"
                remote-show-suffix
                :remote-method="getCompanyList"
                :loading="loadingCompany"
                style="width: 240px"
            >
            <el-select v-model="data.queryParams.companyId" placeholder="请选择" filterable clearable>
              <el-option
                  v-for="item in data.companyList"
                  :key="item.id"
                  :label="item.name"
                  :value="item.name"
              />
                  :value="item.id">
              </el-option>
            </el-select>
          </el-form-item>
          <el-form-item v-if="data.isAdmin">
@@ -147,47 +136,21 @@
  getList();
}
const openDialog = (type, value) => {
  noticeRef.value.openDialog(type, value);
  noticeRef.value.openDialog(type, value,data.companyList);
}
const selectValue = (val) => {
  data.companyList.forEach(item => {
    if(item.name === val){
      data.queryParams.companyId = item.id
    }
  })
}
const getCompanyList = async (val)=>{
  if(val){
    loadingCompany.value = true;
    const queryParams = {
      name: val
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      loadingCompany.value = false;
      data.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }else{
    loadingCompany.value = true;
    const queryParams = {
      pageSize: 10,
      pageNum: 1,
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      loadingCompany.value = false;
      data.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
const getCompanyList = async ()=>{
  const queryParams = {
    pageNum: 1,
    pageSize: 999
  }
  const res = await getCompany(queryParams)
  if (res.code == 200) {
    data.companyList = res.data.list?res.data.list:[]
    // data.queryParams.companyId = data.companyList[0].id
  } else {
    ElMessage.warning(res.message)
  }
}
const handleSizeChange = (val) => {
  data.queryParams.pageSize = val
  getList()
@@ -207,6 +170,7 @@
  choosedData.value = []
  data.companyList = [];
  getList();
  getCompanyList()
}
const exportData = () => {
src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/appFile/index.vue
@@ -32,11 +32,12 @@
      <el-table-column label="名称" prop="templateName" align="center"/>
      <el-table-column label="文件" align="center">
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName}}</el-button>
          <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
          <el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
          <el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
        </template>
@@ -63,6 +64,7 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
import {renderAsync} from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -96,7 +98,36 @@
onUnmounted(()=>{
})
const openFile = async(path)=>{
  try {
    // 1. 获取文件
    const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
    const arrayBuffer = await response.arrayBuffer();
    // 2. 创建新窗口
    const win = window.open('', '_blank');
    win.document.write(`
      <!DOCTYPE html>
      <html>
        <head>
          <title>预览</title>
          <style>
            body { margin: 20px; font-family: Arial; }
            .docx-container { width: 100%; height: 100%; }
          </style>
        </head>
        <body>
          <div id="container" class="docx-container"></div>
        </body>
      </html>
    `);
    // 3. 渲染 DOCX
    await renderAsync(arrayBuffer, win.document.getElementById('container'));
  } catch (error) {
    console.error('预览失败:', error);
    alert(`预览失败: ${error.message}`);
  }
}
const getList = async () => {
  loading.value = true
  const res = await getStandardTemp(data.queryParams)
src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/qualityManual/index.vue
@@ -42,7 +42,8 @@
        </template>
      </el-table-column>
    </el-table>
<!--    <org-tree :data="companyInfo.deptList" />-->
    <button @click="exportOrgChart">导出组织架构图</button>
    <pagination
        v-show="total > 0"
        :total="total"
@@ -50,8 +51,6 @@
        v-model:limit="queryParams.pageSize"
        @pagination="getList"
    />
    <edit-dialog ref="dialogRef" @getList=getList></edit-dialog>
  </div>
</template>
@@ -59,17 +58,10 @@
import {getCurrentInstance, onMounted, onUnmounted, reactive, ref, toRefs} from "vue";
import {ElMessage, ElMessageBox} from "element-plus";
import {delCompany, getCompany} from "@/api/onlineEducation/company";
import {delUser, getUser} from "@/api/onlineEducation/user";
import Cookies from "js-cookie";
import editDialog from './components/editDialog.vue'
import {generateWordDocument} from './components/exportDoc.js'
import {
  addIndustryTemp,
  delIndustryTemp,
  getIndustryTemp,
} from "@/api/staffManage/staff";
// import OrgTree from 'vue-org-tree'
import html2canvas from 'html2canvas'
import { saveAs } from 'file-saver'
import useUserStore from "@/store/modules/user";
import {
  addStandardQuality,
@@ -77,8 +69,6 @@
  getStandardDetail,
  getStandardQuality
} from "@/api/standardSys/standardSys";
import {getBasic} from "@/api/companyInfo/basicInfo";
import {getCom} from "@/api/companyInfo/overview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
@@ -126,7 +116,7 @@
  ]
});
const { queryParams, total, dataList,companyList, isAdmin } = toRefs(data);
const { queryParams, total, dataList,companyList, isAdmin, companyInfo } = toRefs(data);
const userInfo = ref()
onMounted(async ()=>{
  if(userStore.roles.includes('admin')){
@@ -143,6 +133,27 @@
})
const exportOrgChart=()=> {
  const element = document.querySelector('.org-tree'); // 获取组织架构图的容器元素
  html2canvas(element).then(canvas => {
    // 创建一个图片元素
    let img = new Image();
    img.src = canvas.toDataURL('image/png');
    // 创建并触发下载
    img.onload = () => {
      let w = img.width;
      let h = img.height;
      let canvas2 = document.createElement('canvas');
      let ctx = canvas2.getContext('2d');
      canvas2.width = w;
      canvas2.height = h;
      ctx.drawImage(img, 0, 0, w, h);
      saveAs(canvas2.toDataURL('image/png'), '组织架构图.png');
    };
  });
}
const getList = async () => {
  loading.value = true
  const res = await getStandardQuality(data.queryParams)
src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/recordSheets/index.vue
@@ -32,11 +32,12 @@
      <el-table-column label="名称" prop="templateName" align="center"/>
      <el-table-column label="文件" align="center">
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName}}</el-button>
          <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
          <el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
          <el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
        </template>
@@ -63,6 +64,7 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
import {renderAsync} from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -97,6 +99,37 @@
})
const openFile = async(path)=>{
  try {
    // 1. 获取文件
    const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
    const arrayBuffer = await response.arrayBuffer();
    // 2. 创建新窗口
    const win = window.open('', '_blank');
    win.document.write(`
      <!DOCTYPE html>
      <html>
        <head>
          <title>预览</title>
          <style>
            body { margin: 20px; font-family: Arial; }
            .docx-container { width: 100%; height: 100%; }
          </style>
        </head>
        <body>
          <div id="container" class="docx-container"></div>
        </body>
      </html>
    `);
    // 3. 渲染 DOCX
    await renderAsync(arrayBuffer, win.document.getElementById('container'));
  } catch (error) {
    console.error('预览失败:', error);
    alert(`预览失败: ${error.message}`);
  }
}
const getList = async () => {
  loading.value = true
  const res = await getStandardTemp(data.queryParams)
src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/workInstruct/index.vue
@@ -32,11 +32,12 @@
      <el-table-column label="名称" prop="templateName" align="center"/>
      <el-table-column label="文件" align="center">
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName}}</el-button>
          <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
          <el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
          <el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
        </template>
@@ -63,6 +64,7 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
import {renderAsync} from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -96,7 +98,36 @@
onUnmounted(()=>{
})
const openFile = async(path)=>{
  try {
    // 1. 获取文件
    const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
    const arrayBuffer = await response.arrayBuffer();
    // 2. 创建新窗口
    const win = window.open('', '_blank');
    win.document.write(`
      <!DOCTYPE html>
      <html>
        <head>
          <title>预览</title>
          <style>
            body { margin: 20px; font-family: Arial; }
            .docx-container { width: 100%; height: 100%; }
          </style>
        </head>
        <body>
          <div id="container" class="docx-container"></div>
        </body>
      </html>
    `);
    // 3. 渲染 DOCX
    await renderAsync(arrayBuffer, win.document.getElementById('container'));
  } catch (error) {
    console.error('预览失败:', error);
    alert(`预览失败: ${error.message}`);
  }
}
const getList = async () => {
  loading.value = true
  const res = await getStandardTemp(data.queryParams)
src/views/build/conpanyFunctionConsult/digitalFileDep/otherIntellFile/index.vue
@@ -32,11 +32,12 @@
      <el-table-column label="名称" prop="templateName" align="center"/>
      <el-table-column label="文件" align="center">
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName}}</el-button>
          <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
          <el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
          <el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
        </template>
@@ -63,6 +64,7 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
import {renderAsync} from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -96,7 +98,36 @@
onUnmounted(()=>{
})
const openFile = async(path)=>{
  try {
    // 1. 获取文件
    const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
    const arrayBuffer = await response.arrayBuffer();
    // 2. 创建新窗口
    const win = window.open('', '_blank');
    win.document.write(`
      <!DOCTYPE html>
      <html>
        <head>
          <title>预览</title>
          <style>
            body { margin: 20px; font-family: Arial; }
            .docx-container { width: 100%; height: 100%; }
          </style>
        </head>
        <body>
          <div id="container" class="docx-container"></div>
        </body>
      </html>
    `);
    // 3. 渲染 DOCX
    await renderAsync(arrayBuffer, win.document.getElementById('container'));
  } catch (error) {
    console.error('预览失败:', error);
    alert(`预览失败: ${error.message}`);
  }
}
const getList = async () => {
  loading.value = true
  const res = await getStandardTemp(data.queryParams)
src/views/build/conpanyFunctionConsult/digitalFileDep/productType/index.vue
@@ -32,11 +32,12 @@
      <el-table-column label="名称" prop="templateName" align="center"/>
      <el-table-column label="文件" align="center">
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName}}</el-button>
          <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
          <el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
          <el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
        </template>
@@ -63,6 +64,7 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
import {renderAsync} from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -96,7 +98,36 @@
onUnmounted(()=>{
})
const openFile = async(path)=>{
  try {
    // 1. 获取文件
    const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
    const arrayBuffer = await response.arrayBuffer();
    // 2. 创建新窗口
    const win = window.open('', '_blank');
    win.document.write(`
      <!DOCTYPE html>
      <html>
        <head>
          <title>预览</title>
          <style>
            body { margin: 20px; font-family: Arial; }
            .docx-container { width: 100%; height: 100%; }
          </style>
        </head>
        <body>
          <div id="container" class="docx-container"></div>
        </body>
      </html>
    `);
    // 3. 渲染 DOCX
    await renderAsync(arrayBuffer, win.document.getElementById('container'));
  } catch (error) {
    console.error('预览失败:', error);
    alert(`预览失败: ${error.message}`);
  }
}
const getList = async () => {
  loading.value = true
  const res = await getStandardTemp(data.queryParams)
src/views/build/conpanyFunctionConsult/digitalFileDep/techType/index.vue
@@ -32,11 +32,12 @@
      <el-table-column label="名称" prop="templateName" align="center"/>
      <el-table-column label="文件" align="center">
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName}}</el-button>
          <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
          <el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
          <el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
        </template>
@@ -63,6 +64,7 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
import {renderAsync} from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -96,7 +98,36 @@
onUnmounted(()=>{
})
const openFile = async(path)=>{
  try {
    // 1. 获取文件
    const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
    const arrayBuffer = await response.arrayBuffer();
    // 2. 创建新窗口
    const win = window.open('', '_blank');
    win.document.write(`
      <!DOCTYPE html>
      <html>
        <head>
          <title>预览</title>
          <style>
            body { margin: 20px; font-family: Arial; }
            .docx-container { width: 100%; height: 100%; }
          </style>
        </head>
        <body>
          <div id="container" class="docx-container"></div>
        </body>
      </html>
    `);
    // 3. 渲染 DOCX
    await renderAsync(arrayBuffer, win.document.getElementById('container'));
  } catch (error) {
    console.error('预览失败:', error);
    alert(`预览失败: ${error.message}`);
  }
}
const getList = async () => {
  loading.value = true
  const res = await getStandardTemp(data.queryParams)
src/views/build/conpanyFunctionConsult/industryTemplate/index.vue
@@ -48,13 +48,14 @@
      <el-table-column label="行业" prop="industryName" align="center" />
      <el-table-column label="模板" prop="fileName" align="center">
        <template #default="scope">
          <el-link  style="" type="primary" @click="downloadFile(scope.row)">{{scope.row.fileName}}</el-link>
          <el-link  style="" type="primary" @click="openFile(scope.row.filePath)">{{scope.row.fileName}}</el-link>
        </template>
      </el-table-column>
      <el-table-column label="分类" prop="type" align="center" />
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row)">下载</el-button>
          <el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
          <el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
        </template>
@@ -122,6 +123,7 @@
import axios from "axios";
import {getToken} from "@/utils/auth";
import {getIndustry} from "@/api/system/industry";
import {renderAsync} from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -181,7 +183,36 @@
onUnmounted(()=>{
})
const openFile = async(path)=>{
  try {
    // 1. 获取文件
    const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
    const arrayBuffer = await response.arrayBuffer();
    // 2. 创建新窗口
    const win = window.open('', '_blank')
    win.document.write(`
      <!DOCTYPE html>
      <html>
        <head>
          <title>预览</title>
          <style>
            body { margin: 20px; font-family: Arial; }
            .docx-container { width: 100%; height: 100%; }
          </style>
        </head>
        <body>
          <div id="container" class="docx-container"></div>
        </body>
      </html>
    `);
    // 3. 渲染 DOCX
    await renderAsync(arrayBuffer, win.document.getElementById('container'));
  } catch (error) {
    console.error('预览失败:', error);
    alert(`预览失败: ${error.message}`);
  }
}
const getList = async () => {
  loading.value = true
  const res = await getIndustryTemp(data.queryParams)
src/views/build/conpanyFunctionConsult/orgStructure/departManage/components/departDialog.vue
@@ -32,12 +32,13 @@
            />
          </el-select>
        </el-form-item>
        <el-form-item label="主要负责部门:" prop="parentId">
        <el-form-item label="主要负责部门:" prop="childDeptIds">
          <el-select
              clearable
              v-model="state.form.parentId"
              v-model="state.form.childDeptIds"
              :disabled="state.title =='查看'"
              filterable
              multiple
              placeholder="主要负责部门"
              style="width: 100%"
          >
@@ -68,6 +69,12 @@
            />
          </el-select>
        </el-form-item>
        <el-form-item label="是否加入职能分配表" prop="responsType">
          <el-radio-group v-model="state.form.responsType"  :disabled="disabled">
            <el-radio :label="1">是</el-radio>
            <el-radio :label="2">否</el-radio>
          </el-radio-group>
        </el-form-item>
      </el-form>
      <template #footer v-if="state.title !='查看'">
        <span class="dialog-footer">
@@ -96,7 +103,9 @@
    parentId: null,
    caluseVO1List: [],
    delCaluseIds: [],
    companyId: null
    companyId: null,
    responsType: 1,
    childDeptIds: []
  },
  isAdmin: false,
  companyList: [],
@@ -109,7 +118,7 @@
    deptName: [{ required: true, message: '请输入部门名称', trigger: 'blur' }],
    // leaderUserId: [{ required: true, message: '请选择负责人', trigger: 'blur' }],
    // parentId: [{ required: true, message: '请选择负责部门', trigger: 'blur' }],
    caluseVO1List: [{ required: true, message: '请选择涉及条款', trigger: 'blur' }],
    // caluseVO1List: [{ required: true, message: '请选择涉及条款', trigger: 'blur' }],
  }
})
@@ -135,7 +144,8 @@
      }
    });
    state.oldClauseList = value.caluseVO1List
    console.log(state.oldClauseList,'old')
    state.form.childDeptIds = value.sysDeptManageVoList?.map(i=>i.subDeptId)
    state.form.responsType = Number(value.responsType)
  }else{
    state.form.companyId = companyId
  }
@@ -143,7 +153,7 @@
}
const getUserList = async ()=> {
  const res = await listUser()
  const res = await listUser({pageIndex: 1,pageSize: 999})
  if(res.code == 200){
    state.userList = res.data.list?res.data.list:[]
  }else{
@@ -215,7 +225,9 @@
    parentId: null,
    caluseVO1List: [],
    delCaluseIds: [],
    companyId: null
    companyId: null,
    responsType: 1,
    childDeptIds: []
  }
  superRef.value.clearValidate();
src/views/build/conpanyFunctionConsult/orgStructure/departManage/components/dutyDialog.vue
@@ -203,7 +203,7 @@
  oldResponsibilityList: [],
  formRules:{
    personNum: [{ required: true, message: '请输入部门人数', trigger: 'blur' }],
    internalAuditors: [{ required: true, message: '请选择内审员', trigger: 'blur' }],
    // internalAuditors: [{ required: true, message: '请选择内审员', trigger: 'blur' }],
    responsibilities: [{ required: true, message: '请输入部门职责', trigger: 'blur' }]
  },
  firstFive: [
src/views/build/conpanyFunctionConsult/orgStructure/departManage/index.vue
@@ -27,14 +27,18 @@
      <el-table-column label="序号" type="index" align="center" width="80" />
      <el-table-column label="部门名称" prop="deptName" align="center"  />
      <el-table-column label="负责人" prop="leaderName" align="center" />
      <el-table-column label="主要负责部门" prop="parentName" align="center"/>
      <el-table-column label="主要负责部门" prop="parentName" align="center">
        <template #default="scope">
            <span>
              {{scope.row.sysDeptManageVoList?.map(i=>i.subDeptName).join('、')}}
            </span>
        </template>
      </el-table-column>
      <el-table-column label="部门涉及条款" prop="userTypeName" align="center" width="150">
        <template #default="scope">
          <div v-if="scope.row.caluseVO1List">
            <div v-for="(item,index) in scope.row.caluseVO1List" :key="index">
              {{ item.clauseNum + ' ' + item.content}}
            </div>
          </div>
            <span>
              {{scope.row.caluseVO1List?.map(i=>i.clauseNum).join('、')}}
            </span>
        </template>
      </el-table-column>
      <el-table-column label="部门职责表" prop="userTypeName" align="center" width="150">
src/views/build/conpanyFunctionConsult/orgStructure/dutyDistributeChart/index.vue
@@ -38,16 +38,16 @@
    <el-table v-loading="loading" :data="caluseList" class="caluseTable" :border="true" :span-method="arraySpanMethod">
      <el-table-column label="条款号" prop="clauseNum" align="center"/>
      <el-table-column label="条款内容/要素" prop="content" align="left"/>
      <el-table-column label="总经理" prop="manage" align="center">
        <template #default="scope">
          <el-checkbox v-model="scope.row.manage" disabled size="large" />
        </template>
      </el-table-column>
      <el-table-column label="管理者代表" prop="represent" align="center">
        <template #default="scope">
          <el-checkbox v-model="scope.row.represent" disabled size="large" />
        </template>
      </el-table-column>
<!--      <el-table-column label="总经理" prop="manage" align="center">-->
<!--        <template #default="scope">-->
<!--          <el-checkbox v-model="scope.row.manage" disabled size="large" />-->
<!--        </template>-->
<!--      </el-table-column>-->
<!--      <el-table-column label="管理者代表" prop="represent" align="center">-->
<!--        <template #default="scope">-->
<!--          <el-checkbox v-model="scope.row.represent" disabled size="large" />-->
<!--        </template>-->
<!--      </el-table-column>-->
      <el-table-column v-for="column in deptList" :key="column.deptId" :prop="column.deptId" :label="column.deptName" align="center">
        <template #default="scope">
          <el-checkbox v-model="scope.row[column.deptId]" :disabled="!isEdit" size="large" @change="changeStatus(scope.row)"/>
@@ -97,7 +97,50 @@
    {clauseNum: '7.1.3', content: '基础设施',manage: false,represent: true},
    {clauseNum: '7.1.4', content: '过程运行环境',manage: false,represent: true},
    {clauseNum: '7.1.5', content: '监视和测量资源',manage: false,represent: true},
    {clauseNum: '7.1.6', content: '组织的知识',manage: false,represent: true}
    {clauseNum: '7.1.6', content: '组织的知识',manage: false,represent: true},
    {clauseNum: '7.2', content: '能力'},
    {clauseNum: '7.3', content: '意识'},
    {clauseNum: '7.4', content: '沟通'},
    {clauseNum: '7.5', content: '成文信息'},
    {clauseNum: '7.6', content: '质量信息'},
    {clauseNum: '8', content: '运行'},
    {clauseNum: '8.1', content: '运行策划和控制'},
    {clauseNum: '8.2', content: '产品和服务的要求'},
    {clauseNum: '8.2.1', content: '顾客沟通'},
    {clauseNum: '8.2.2', content: '与产品和服务有关的要求的确定'},
    {clauseNum: '8.2.3', content: '与产品和服务有关的要求的评审'},
    {clauseNum: '8.2.4', content: '产品和服务要求的更改'},
    {clauseNum: '8.3', content: '产品和服务的设计和开发'},
    {clauseNum: '8.3.1', content: '总则'},
    {clauseNum: '8.3.2', content: '设计和开发策划'},
    {clauseNum: '8.3.3', content: '设计和开发输入'},
    {clauseNum: '8.3.4', content: '设计和开发控制'},
    {clauseNum: '8.3.5', content: '设计和开发输出'},
    {clauseNum: '8.3.6', content: '设计和开发更改'},
    {clauseNum: '8.3.7', content: '新产品试制'},
    {clauseNum: '8.3.8', content: '设计和开发的试验控制'},
    {clauseNum: '8.4', content: '外部提供过程、产品和服务的控制'},
    {clauseNum: '8.4.1', content: '总则'},
    {clauseNum: '8.4.2', content: '控制类型和程度'},
    {clauseNum: '8.4.3', content: '提供给外部供方的信息'},
    {clauseNum: '8.5', content: '生产和服务提供'},
    {clauseNum: '8.5.1', content: '生产和服务提供的控制'},
    {clauseNum: '8.5.2', content: '标识和可追溯性'},
    {clauseNum: '8.5.3', content: '顾客或外部供方的财产'},
    {clauseNum: '8.5.4', content: '防护'},
    {clauseNum: '8.5.5', content: '交付后的活动'},
    {clauseNum: '8.5.6', content: '更改控制'},
    {clauseNum: '8.5.7', content: '关键过程'},
    {clauseNum: '8.6', content: '产品和服务的放行'},
    {clauseNum: '8.7', content: '不合格输出的控制'},
    {clauseNum: '9', content: '绩效评价'},
    {clauseNum: '9.1', content: '监视、测量、分析和评价'},
    {clauseNum: '9.1.1', content: '总则'},
    {clauseNum: '9.1.2', content: '顾客满意'},
    {clauseNum: '9.1.3', content: '分析和评价'},
    {clauseNum: '9.2', content: '内部审核'},
    {clauseNum: '9.3', content: '管理评审'},
    {clauseNum: '10', content: '持续改进'}
  ],
  form: {
    companyId: null,
@@ -170,7 +213,8 @@
     rowIndex,
     columnIndex,
   }) => {
  if (rowIndex === 0 || rowIndex === 5 ||rowIndex === 9 ||rowIndex === 13) {
  const mergeValues = ['4','5','6','7','7.1','8','8.2','8.3','8.4','8.5','9','9.1','10']
  if (mergeValues.includes(row.clauseNum)) {
    if (columnIndex === 0) {
      return [1, 1]
    } else if(columnIndex === 1){
@@ -287,7 +331,7 @@
<style lang="scss">
.caluseTable{
  .el-table__cell{
    padding: 4px 0 !important;
    padding: 0 !important;
    .is-disabled{
      .el-checkbox__label{
        color: #606266 !important
@@ -313,7 +357,7 @@
    }
  }
  .cell{
    padding: 0 6px !important;
    padding: 0 4px !important;
  }
}
</style>
src/views/build/conpanyFunctionConsult/qualityManage/rangeManage/range/components/dataDialog.vue
@@ -12,14 +12,14 @@
        <el-form-item label="材料名称:" prop="name">
          <el-input v-model.trim="state.form.name" :disabled="state.title =='查看'" placeholder="材料名称"></el-input>
        </el-form-item>
        <el-form-item label="材料模板:" prop="filePath">
          <el-upload accept=".doc,.docx" :action="state.uploadUrl" :headers="state.header" method="post" :on-success="(res, uploadFile)=>handleAvatarSuccess(res, uploadFile)" :on-exceed="showTip" :limit='state.fileLimit' v-model:file-list="state.fileList" :before-upload="picSize" :on-remove="(file, uploadFiles)=>handleRemove(file, uploadFiles)" >
            <el-button type="primary">点击上传</el-button>
            <template #tip>
              <div class="el-upload__tip">支持上传.doc、.docx格式文档,尺寸小于5M,最多可上传1张</div>
            </template>
          </el-upload>
        </el-form-item>
<!--        <el-form-item label="材料模板:" prop="filePath">-->
<!--          <el-upload accept=".doc,.docx" :action="state.uploadUrl" :headers="state.header" method="post" :on-success="(res, uploadFile)=>handleAvatarSuccess(res, uploadFile)" :on-exceed="showTip" :limit='state.fileLimit' v-model:file-list="state.fileList" :before-upload="picSize" :on-remove="(file, uploadFiles)=>handleRemove(file, uploadFiles)" >-->
<!--            <el-button type="primary">点击上传</el-button>-->
<!--            <template #tip>-->
<!--              <div class="el-upload__tip">支持上传.doc、.docx格式文档,尺寸小于5M,最多可上传1张</div>-->
<!--            </template>-->
<!--          </el-upload>-->
<!--        </el-form-item>-->
      </el-form>
      <template #footer v-if="state.title !='查看'">
        <span class="dialog-footer">
src/views/build/conpanyFunctionConsult/qualityManage/rangeManage/range/index.vue
@@ -46,10 +46,13 @@
      <div class="right">
        <el-form :model="state.form" size="default" ref="noticeRef" :rules="data.formRules" label-position="left" label-width="125px" >
          <el-form-item label="具体内容" prop="content" >
            <el-input v-model="state.form.content" :rows="4" type="textarea" />
            <t-editor style="width: 100%;" :height="300" ref="myEditor1" :value="state.form.content" ></t-editor>
<!--            <el-input v-model="state.form.content" :rows="4" type="textarea" />-->
          </el-form-item>
          <el-form-item label="标准分析" prop="analysis" >
            <el-input v-model="state.form.analysis" :rows="4" type="textarea" />
            <t-editor style="width: 100%;" :height="300" ref="myEditor2" :value="state.form.analysis" ></t-editor>
<!--            <el-input v-model="state.form.analysis" :rows="4" type="textarea" />-->
          </el-form-item>
          <el-form-item label="应准备材料" prop="dataList">
            <el-button type="primary" @click="openDataDialog('add',{})">新增</el-button>
@@ -57,11 +60,11 @@
          <el-table style="margin:15px 0;width: 100%" :data="state.form.dataList" :border="true" >
            <el-table-column type="index" label="序号" width="80" align="center"></el-table-column>
            <el-table-column label="材料名称" prop="name" align="center"  />
            <el-table-column label="材料模板" prop="fileName" align="center" >
              <template #default="scope">
                <el-link v-if="scope.row.fileName" style="" type="primary" @click="downloadFile(scope.row)">{{scope.row.fileName}}</el-link>
              </template>
            </el-table-column>
<!--            <el-table-column label="材料模板" prop="fileName" align="center" >-->
<!--              <template #default="scope">-->
<!--                <el-link v-if="scope.row.fileName" style="" type="primary" @click="downloadFile(scope.row)">{{scope.row.fileName}}</el-link>-->
<!--              </template>-->
<!--            </el-table-column>-->
            <el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
              <template #default="scope">
                <el-button link type="primary"  @click="openDataDialog('edit',scope.row)" >编辑</el-button>
@@ -69,24 +72,24 @@
              </template>
            </el-table-column>
          </el-table>
          <el-form-item label="记录上传" prop="recordList">
            <el-button type="primary" @click="openRecordDialog('add',{})">新增</el-button>
          </el-form-item>
          <el-table style="margin-top: 15px;width: 100%" :data="state.form.recordList" :border="true" >
            <el-table-column type="index" label="序号" width="80" align="center"></el-table-column>
            <el-table-column label="记录名称" prop="name" align="center"  />
            <el-table-column label="材料模板" prop="fileName" align="center">
              <template #default="scope">
                <el-link v-if="scope.row.fileName" style="" type="primary" @click="downloadFile(scope.row)">{{scope.row.fileName}}</el-link>
              </template>
            </el-table-column>
            <el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
              <template #default="scope">
                <el-button link type="primary"  @click="openRecordDialog('edit',scope.row)" >编辑</el-button>
                <el-button link type="danger"  @click="handleRecordDelete(scope.row)" >删除</el-button>
              </template>
            </el-table-column>
          </el-table>
<!--          <el-form-item label="记录上传" prop="recordList">-->
<!--            <el-button type="primary" @click="openRecordDialog('add',{})">新增</el-button>-->
<!--          </el-form-item>-->
<!--          <el-table style="margin-top: 15px;width: 100%" :data="state.form.recordList" :border="true" >-->
<!--            <el-table-column type="index" label="序号" width="80" align="center"></el-table-column>-->
<!--            <el-table-column label="记录名称" prop="name" align="center"  />-->
<!--            <el-table-column label="材料模板" prop="fileName" align="center">-->
<!--              <template #default="scope">-->
<!--                <el-link v-if="scope.row.fileName" style="" type="primary" @click="downloadFile(scope.row)">{{scope.row.fileName}}</el-link>-->
<!--              </template>-->
<!--            </el-table-column>-->
<!--            <el-table-column label="操作" align="center" class-name="small-padding fixed-width" >-->
<!--              <template #default="scope">-->
<!--                <el-button link type="primary"  @click="openRecordDialog('edit',scope.row)" >编辑</el-button>-->
<!--                <el-button link type="danger"  @click="handleRecordDelete(scope.row)" >删除</el-button>-->
<!--              </template>-->
<!--            </el-table-column>-->
<!--          </el-table>-->
        </el-form>
        <div style="display: flex;align-items: center;justify-content: right;margin-top: 10px">
          <el-button v-if="state.form.id" type="danger"  @click="deleteData">删除</el-button>
@@ -96,7 +99,7 @@
      </div>
    </div>
    <dataDialog ref="dialogRef" @getList="getFileList"></dataDialog>
    <record-dialog ref="dialogRecordRef" @getList="getFileList"></record-dialog>
<!--    <record-dialog ref="dialogRecordRef" @getList="getFileList"></record-dialog>-->
  </div>
</template>
<script setup>
@@ -119,11 +122,14 @@
  getFile
} from "@/api/qualityManage/range";
import axios from "axios";
import TEditor from "@/components/Tinymce/Tinymce.vue";
const { proxy } = getCurrentInstance();
const loading = ref(false);
const noticeRef = ref();
const dialogRef = ref();
const myEditor1 = ref();
const myEditor2 = ref();
const dialogRecordRef = ref();
const loadingCompany = ref(false)
const data = reactive({
@@ -135,8 +141,8 @@
  formRules: {
    content: [{ required: true, message: '请输入具体内容', trigger: 'blur' }],
    analysis: [{ required: true, message: '请输入标准分析', trigger: 'blur' }],
    dataList: [{ required: true, message: '', trigger: 'blur' }],
    recordList: [{ required: true, message: '', trigger: 'blur' }]
    // dataList: [{ required: true, message: '', trigger: 'blur' }],
    // recordList: [{ required: true, message: '', trigger: 'blur' }]
  },
  companyList: [],
  isAdmin: false,
@@ -293,18 +299,20 @@
}
const addData = async () => {
  state.form.content = myEditor1.value.myValue
  state.form.analysis = myEditor2.value.myValue
  if(!state.form.catalogueId){
    ElMessage.warning('请先选择左侧目录!')
    return
  }
  if(state.form.dataList && state.form.dataList.length==0){
    ElMessage.warning('请上传应准备材料!')
    return
  }
  if(state.form.recordList && state.form.recordList.length==0){
    ElMessage.warning('请上传记录!')
    return
  }
  // if(state.form.dataList && state.form.dataList.length==0){
  //   ElMessage.warning('请上传应准备材料!')
  //   return
  // }
  // if(state.form.recordList && state.form.recordList.length==0){
  //   ElMessage.warning('请上传记录!')
  //   return
  // }
  const valid = await noticeRef.value.validate();
  if(valid){
src/views/build/conpanyFunctionConsult/qualityObjectives/objective/components/objectiveDialog.vue
@@ -11,25 +11,14 @@
      <el-form :model="state.form" size="default" ref="busRef" :rules="state.rules"  label-width="120px" >
        <el-row :gutter="24">
          <el-col :span="24">
            <el-form-item label="企业名称:" prop="companyName" v-if="state.isAdmin">
              <el-select
                  v-model="state.form.companyName"
                  filterable
                  remote
                  :disabled="title == '查看' || title == '编辑' || !state.isAdmin"
                  @change="selectValueCom"
                  reserve-keyword
                  placeholder="请输入企业名称"
                  remote-show-suffix
                  :remote-method="getCompanyList"
                  style="width: 100%"
              >
            <el-form-item label="企业名称:" prop="companyId" v-if="state.isAdmin">
              <el-select v-model="state.form.companyId" placeholder="请选择" filterable clearable style="width: 100%" :disabled="title == '查看' || title == '编辑' || !state.isAdmin" @change="selectValueCom">
                <el-option
                    v-for="item in state.companyList"
                    :key="item.id"
                    :label="item.name"
                    :value="item.name"
                />
                    :value="item.id">
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
@@ -143,24 +132,13 @@
        </el-row>
        <el-row :gutter="24" v-if="state.form.type == 2">
          <el-col :span="12">
            <el-form-item label="编制:" prop="compilationName" >
              <el-select
                  :disabled="title === '查看'"
                  v-model="state.form.compilationName"
                  filterable
                  remote
                  @change="selectValue"
                  reserve-keyword
                  placeholder="请输入人员名称"
                  remote-show-suffix
                  :remote-method="getPeopleList"
                  style="width: 240px"
              >
            <el-form-item label="编制:" prop="compilationId" >
              <el-select clearable v-model="state.form.compilationId" :disabled="title =='查看'" filterable  style="width: 100%">
                <el-option
                    v-for="item in state.peopleList"
                    v-for="item in state.userList"
                    :key="item.id"
                    :label="item.name"
                    :value="item.name"
                    :value="item.id"
                />
              </el-select>
            </el-form-item>
@@ -178,24 +156,13 @@
        </el-row>
        <el-row :gutter="24" >
          <el-col :span="12">
            <el-form-item label="质量管理部:" prop="qualityName" >
              <el-select
                  :disabled="title === '查看'"
                  v-model="state.form.qualityName"
                  filterable
                  remote
                  @change="selectValue1"
                  reserve-keyword
                  placeholder="请输入人员名称"
                  remote-show-suffix
                  :remote-method="getPeopleList"
                  style="width: 240px"
              >
            <el-form-item label="质量管理部:" prop="qualityId" >
              <el-select clearable v-model="state.form.qualityId" :disabled="title =='查看'" filterable  style="width: 100%">
                <el-option
                    v-for="item in state.peopleList"
                    v-for="item in state.userList"
                    :key="item.id"
                    :label="item.name"
                    :value="item.name"
                    :value="item.id"
                />
              </el-select>
            </el-form-item>
@@ -213,24 +180,13 @@
        </el-row>
        <el-row :gutter="24">
          <el-col :span="12">
            <el-form-item label="公司分管领导:" prop="leadName" >
              <el-select
                  :disabled="title === '查看'"
                  v-model="state.form.leadName"
                  filterable
                  remote
                  @change="selectValue2"
                  reserve-keyword
                  placeholder="请输入人员名称"
                  remote-show-suffix
                  :remote-method="getPeopleList"
                  style="width: 240px"
              >
            <el-form-item label="公司分管领导:" prop="leadId" >
              <el-select clearable v-model="state.form.leadId" :disabled="title =='查看'" filterable  style="width: 100%">
                <el-option
                    v-for="item in state.peopleList"
                    v-for="item in state.userList"
                    :key="item.id"
                    :label="item.name"
                    :value="item.name"
                    :value="item.id"
                />
              </el-select>
            </el-form-item>
@@ -263,6 +219,7 @@
import {ElMessage} from "element-plus";
import {getUser} from "@/api/onlineEducation/user";
import {addObjective, editObject, getDept} from "@/api/qualityObjectives/object";
import {listUser} from "@/api/system/user";
const dialogVisible = ref(false);
const title = ref("");
@@ -278,26 +235,26 @@
    type: '',
    departId: '',
    method: '',
    compilationBy:'',
    compilationId:'',
    compilationTime:'',
    qualityBy: '',
    qualityId: '',
    qualityTime:'',
    leadBy:'',
    leadId:'',
    leadTime: '',
    qualityTargets:[],
  },
  rules: {
    companyName: [{ required: true, message: '请选择企业', trigger: 'blur' }],
    companyId: [{ required: true, message: '请选择企业', trigger: 'blur' }],
    year: [{ required: true, message: '请输入年份', trigger: 'blur' }],
    num: [{ required: true, message: '请输入序号', trigger: 'blur' }],
    type: [{ required: true, message: '请选择级别', trigger: 'blur' }],
    method: [{ required: true, message: '请输入目标测量方法', trigger: 'blur' }],
    compilationName: [{ required: true, message: '请选择编制人员', trigger: 'blur' }],
    compilationId: [{ required: true, message: '请选择编制人员', trigger: 'blur' }],
    compilationTime: [{ required: true, message: '请选择日期', trigger: 'blur' }],
    qualityName: [{ required: true, message: '请选择质量管理部人员', trigger: 'blur' }],
    qualityId: [{ required: true, message: '请选择质量管理部人员', trigger: 'blur' }],
    qualityTime: [{ required: true, message: '请选择日期', trigger: 'blur' }],
    leadName: [{ required: true, message: '请选择公司分管领导', trigger: 'blur' }],
    leadId: [{ required: true, message: '请选择公司分管领导', trigger: 'blur' }],
    leadTime: [{ required: true, message: '请选择日期', trigger: 'blur' }],
    departId: [{ required: true, message: '请选择部门', trigger: 'blur' }],
    objName: [{required: true, message: "质量目标不能为空", trigger: "blur"}],
@@ -340,23 +297,28 @@
  ]
})
const openDialog = async (type, value) => {
const openDialog = async (type, value,companyList) => {
  const userInfo = JSON.parse(Cookies.get('userInfo'))
  state.isAdmin = userInfo.userType === 0;
  state.form.companyName = userInfo.companyName
  state.form.companyId = userInfo.companyId
  if(state.isAdmin){
    state.companyList = companyList
    state.form.companyId = null
  }
  title.value = type === 'add' ? '新增' : type ==='edit' ? '编辑' : '查看' ;
  if(type === 'edit' || type === 'review') {
    state.form = JSON.parse(JSON.stringify(value));
    state.form.compilationBy = state.form.compilationId
    state.form.leadBy = state.form.leadId
    state.form.qualityBy = state.form.qualityId
    if(state.isAdmin){
      state.form.companyId = value.companyId
      state.form.companyName = value.companyName
    }
  }
  await getDeptList()
  if(state.isAdmin){
    await   getCompanyList()
  }
  await   getPeopleList()
  dialogVisible.value = true;
}
@@ -450,35 +412,52 @@
const handleDelete = (val) => {
  state.form.qualityTargets = state.form.qualityTargets.filter(item=> item != val)
}
const getPeopleList = async (val)=>{
  if(val){
    const queryParams = {
      name: val,
      companyId: state.form.companyId == 0 ? null : state.form.companyId
    }
    const res = await getUser(queryParams)
    if (res.code == 200) {
      state.peopleList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }else {
    const queryParams = {
      pageNum: 1,
      pageSize: 10,
      companyId: state.form.companyId == 0 ? null : state.form.companyId
    }
    const res = await getUser(queryParams)
    if (res.code == 200) {
      state.peopleList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
const getPeopleList = async ()=> {
  if(state.isAdmin && (state.form.companyId == 0 || state.form.companyId == null)){
    return
  }
}
     const queryParams = {
       pageNum: 1,
       pageSize: 9999,
      companyId: state.form.companyId
    }
  const res = await getUser(queryParams)
  if(res.code == 200){
    state.userList = res.data.list?res.data.list:[]
  }else{
    ElMessage.warning(res.message)
  }
};
// const getPeopleList = async (val)=>{
//   if(val){
//     const queryParams = {
//       name: val,
//       companyId: state.form.companyId == 0 ? null : state.form.companyId
//     }
//     const res = await getUser(queryParams)
//     if (res.code == 200) {
//       state.peopleList = res.data.list
//
//     } else {
//       ElMessage.warning(res.message)
//     }
//   }else {
//     const queryParams = {
//       pageNum: 1,
//       pageSize: 10,
//       companyId: state.form.companyId == 0 ? null : state.form.companyId
//     }
//     const res = await getUser(queryParams)
//     if (res.code == 200) {
//       state.peopleList = res.data.list
//
//     } else {
//       ElMessage.warning(res.message)
//     }
//
//   }
// }
const selectValue = (val) => {
  state.peopleList.forEach(item => {
    if(item.name === val){
@@ -509,16 +488,16 @@
  }
}
const selectValueCom = (val) => {
  state.form.leadBy = null
  state.form.qualityBy = null
  state.form.compilationBy = null
  state.form.leadId = null
  state.form.qualityId = null
  state.form.compilationId = null
  state.form.leadName = null
  state.form.qualityName = null
  state.form.compilationName = null
  state.form.departId = null
  state.companyList.forEach(item => {
    if(item.name === val){
      state.form.companyId = item.id
    if(item.id === val){
      state.form.companyName = item.name
    }
  })
  getDeptList()
@@ -542,7 +521,7 @@
    }
  }else {
    const queryParams = {
      pageSize: 10,
      pageSize: 999,
      pageNum: 1,
    }
    const res = await getCompany(queryParams)
src/views/build/conpanyFunctionConsult/qualityObjectives/objective/index.vue
@@ -11,24 +11,13 @@
            >新增</el-button>
          </el-form-item>
          <el-form-item label="企业名称:" v-if="data.isAdmin" style="margin-left: 20px">
            <el-select
                v-model="data.queryParams.companyName"
                filterable
                remote
                @change="selectValue"
                reserve-keyword
                placeholder="请输入企业名称"
                remote-show-suffix
                :remote-method="getCompanyList"
                :loading="loadingCompany"
                style="width: 240px"
            >
            <el-select v-model="data.queryParams.companyId" placeholder="请选择" filterable clearable>
              <el-option
                  v-for="item in data.companyList"
                  :key="item.id"
                  :label="item.name"
                  :value="item.name"
              />
                  :value="item.id">
              </el-option>
            </el-select>
          </el-form-item>
          <el-form-item label="年份:" style="margin-left: 20px">
@@ -219,7 +208,7 @@
  getList();
}
const openDialog = (type, value) => {
  noticeRef.value.openDialog(type, value);
  noticeRef.value.openDialog(type, value,data.companyList);
}
const selectValue = (val) => {
  data.companyList.forEach(item => {
@@ -229,34 +218,17 @@
  })
}
const getCompanyList = async (val)=>{
  if(val){
    loadingCompany.value = true;
    const queryParams = {
      name: val
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      loadingCompany.value = false;
      data.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }else{
    loadingCompany.value = true;
    const queryParams = {
      pageSize: 10,
      pageNum: 1,
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      loadingCompany.value = false;
      data.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
const getCompanyList = async ()=>{
  const queryParams = {
    pageNum: 1,
    pageSize: 999
  }
  const res = await getCompany(queryParams)
  if (res.code == 200) {
    data.companyList = res.data.list?res.data.list:[]
    // data.queryParams.companyId = data.companyList[0].id
  } else {
    ElMessage.warning(res.message)
  }
}
src/views/build/conpanyFunctionConsult/qualityObjectives/reportsituation/components/stationCompanyDialog.vue
@@ -11,26 +11,14 @@
      <el-form :model="state.form" size="default" ref="busRef" :rules="state.rules"   label-width="120" >
        <el-row :gutter="24">
          <el-col :span="24">
            <el-form-item label="企业名称:" prop="companyName" v-if="state.isAdmin">
              <el-select
                  v-model="state.form.companyName"
                  filterable
                  remote
                  :disabled="title == '查看' || title == '编辑' || !state.isAdmin"
                  @change="selectValueCom"
                  reserve-keyword
                  placeholder="请输入企业名称"
                  remote-show-suffix
                  :remote-method="getCompanyList"
                  style="width: 100%"
              >
            <el-form-item label="企业名称:" prop="companyId" v-if="state.isAdmin">
              <el-select v-model="state.form.companyId" placeholder="请选择" filterable clearable style="width: 100%" :disabled="title == '查看' || title == '编辑' || !state.isAdmin" @change="selectValueCom">
                <el-option
                    v-for="item in state.companyList"
                    :key="item.id"
                    :label="item.name"
                    :value="item.name"
                />
                    :value="item.id">
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
@@ -109,24 +97,13 @@
        </el-row>
        <el-row :gutter="24">
          <el-col :span="12">
            <el-form-item :label="state.type == 1 ? '公司负责人:' : '部门负责人:'" prop="chargeName" >
              <el-select
                  :disabled="title === '查看'"
                  v-model="state.form.chargeName"
                  filterable
                  remote
                  @change="selectValue"
                  reserve-keyword
                  placeholder="请输入人员名称"
                  remote-show-suffix
                  :remote-method="getPeopleList"
                  style="width: 240px"
              >
            <el-form-item :label="state.type == 1 ? '公司负责人:' : '部门负责人:'" prop="chargeId" >
              <el-select clearable v-model="state.form.chargeId" :disabled="title =='查看'" filterable  style="width: 100%">
                <el-option
                    v-for="item in state.peopleList"
                    :key="item.id"
                    :label="item.name"
                    :value="item.name"
                    :value="item.id"
                />
              </el-select>
            </el-form-item>
@@ -183,10 +160,10 @@
    qualityTargets:[],
  },
  rules: {
    companyName: [{ required: true, message: '请选择企业', trigger: 'blur' }],
    companyId: [{ required: true, message: '请选择企业', trigger: 'blur' }],
    qualityId: [{ required: true, message: '请选择质量目标', trigger: 'blur' }],
    serial: [{ required: true, message: '请输入序号', trigger: 'blur' }],
    chargeName: [{ required: true, message: '请选择负责人', trigger: 'blur' }],
    chargeId: [{ required: true, message: '请选择负责人', trigger: 'blur' }],
    chargeTime: [{ required: true, message: '请选择日期', trigger: 'blur' }],
    accomplish:[{ required: true, message: '请输入质量目标完成情况', trigger: 'blur' }],
    frequency:[{ required: true, message: '请选择考核时机', trigger: 'blur' }],
@@ -222,7 +199,7 @@
});
const openDialog = async (type, isCom, value) => {
const openDialog = async (type, isCom, value,companyList) => {
  const userInfo = JSON.parse(Cookies.get('userInfo'))
  state.isAdmin = userInfo.userType === 0;
@@ -232,6 +209,7 @@
  if(state.isAdmin){
    state.form.companyId = value.companyId
    state.form.companyName = value.companyName
    state.companyList = companyList
  }
  await getQualityList()
  title.value = type === 'add' ? '新增' : type ==='edit' ? '编辑' : '查看' ;
@@ -239,9 +217,7 @@
    state.form = JSON.parse(JSON.stringify(value));
    chooseQuality(state.form.qualityId)
  }
  if(state.isAdmin){
    await   getCompanyList()
  }
  await   getPeopleList()
  dialogVisible.value = true;
}
@@ -332,35 +308,22 @@
  state.companyList = []
  state.qualityList = []
}
const getPeopleList = async (val)=>{
  if(val){
    const queryParams = {
      companyId: state.form.companyId == 0 ? null : state.form.companyId,
      name: val
    }
    const res = await getUser(queryParams)
    if (res.code == 200) {
      state.peopleList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }else {
    const queryParams = {
      pageNum: 1,
      pageSize: 10,
      companyId: state.form.companyId == 0 ? null : state.form.companyId
    }
    const res = await getUser(queryParams)
    if (res.code == 200) {
      state.peopleList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
const getPeopleList = async ()=> {
  if(state.isAdmin && (state.form.companyId == 0 || state.form.companyId == null)){
    return
  }
}
  const queryParams = {
    pageNum: 1,
    pageSize: 9999,
    companyId: state.form.companyId
  }
  const res = await getUser(queryParams)
  if(res.code == 200){
    state.peopleList = res.data.list?res.data.list:[]
  }else{
    ElMessage.warning(res.message)
  }
};
const selectValue = (val) => {
  state.peopleList.forEach(item => {
    if(item.name === val){
@@ -413,7 +376,7 @@
    }
  }else {
    const queryParams = {
      pageSize: 10,
      pageSize: 999,
      pageNum: 1,
    }
    const res = await getCompany(queryParams)
src/views/build/conpanyFunctionConsult/qualityObjectives/reportsituation/index.vue
@@ -11,24 +11,13 @@
          >新增</el-button>
        </el-form-item>
        <el-form-item label="企业名称:" v-if="data.isAdmin" style="margin-left: 20px">
          <el-select
              v-model="data.queryParams.companyName"
              filterable
              remote
              @change="selectValue"
              reserve-keyword
              placeholder="请输入企业名称"
              remote-show-suffix
              :remote-method="getCompanyList"
              :loading="loadingCompany"
              style="width: 240px"
          >
          <el-select v-model="data.queryParams.companyId" placeholder="请选择" filterable clearable>
            <el-option
                v-for="item in data.companyList"
                :key="item.id"
                :label="item.name"
                :value="item.name"
            />
                :value="item.id">
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="年份:" style="margin-left: 20px">
@@ -270,7 +259,7 @@
  data.dialogVisible = true
}
const openDialog = (type,isCom, value) => {
  noticeRef.value.openDialog(type, isCom,value);
  noticeRef.value.openDialog(type, isCom,value,data.companyList);
}
const openDeptDialog = (type, value) => {
  deptRef.value.openDialog(type, value);
@@ -284,37 +273,22 @@
  })
}
const getCompanyList = async (val)=>{
  if(val){
    loadingCompany.value = true;
    const queryParams = {
      name: val
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      loadingCompany.value = false;
      data.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }else{
    loadingCompany.value = true;
    const queryParams = {
      pageSize: 10,
      pageNum: 1,
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      loadingCompany.value = false;
      data.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
const getCompanyList = async ()=>{
  const queryParams = {
    pageNum: 1,
    pageSize: 999
  }
  const res = await getCompany(queryParams)
  if (res.code == 200) {
    data.companyList = res.data.list?res.data.list:[]
    // data.queryParams.companyId = data.companyList[0].id
  } else {
    ElMessage.warning(res.message)
  }
}
const handleSizeChange = (val) => {
  data.queryParams.pageSize = val
  getList()
src/views/build/conpanyFunctionConsult/qualityObjectives/table/components/tableCompanyDialog.vue
@@ -11,26 +11,14 @@
      <el-form :model="state.form" size="default" ref="busRef" :rules="state.rules"    >
        <el-row :gutter="24">
          <el-col :span="24">
            <el-form-item label="企业名称:" prop="companyName" v-if="state.isAdmin">
              <el-select
                  v-model="state.form.companyName"
                  filterable
                  remote
                  :disabled="title == '查看' || title == '编辑' || !state.isAdmin"
                  @change="selectValueCom"
                  reserve-keyword
                  placeholder="请输入企业名称"
                  remote-show-suffix
                  :remote-method="getCompanyList"
                  style="width: 100%"
              >
            <el-form-item label="企业名称:" prop="companyId" v-if="state.isAdmin">
              <el-select v-model="state.form.companyId" placeholder="请选择" filterable clearable style="width: 100%" :disabled="title == '查看' || title == '编辑' || !state.isAdmin" @change="selectValueCom">
                <el-option
                    v-for="item in state.companyList"
                    :key="item.id"
                    :label="item.name"
                    :value="item.name"
                />
                    :value="item.id">
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
@@ -120,24 +108,13 @@
        </el-row>
        <el-row :gutter="24">
          <el-col :span="12">
            <el-form-item label="拟制:" prop="fictionName" >
              <el-select
                  :disabled="title === '查看'"
                  v-model="state.form.fictionName"
                  filterable
                  remote
                  @change="selectValue"
                  reserve-keyword
                  placeholder="请输入人员名称"
                  remote-show-suffix
                  :remote-method="getPeopleList"
                  style="width: 240px"
              >
            <el-form-item label="拟制:" prop="fictionId" >
              <el-select clearable v-model="state.form.fictionId" :disabled="title =='查看'" filterable  style="width: 100%">
                <el-option
                    v-for="item in state.peopleList"
                    :key="item.id"
                    :label="item.name"
                    :value="item.name"
                    :value="item.id"
                />
              </el-select>
            </el-form-item>
@@ -155,24 +132,13 @@
        </el-row>
        <el-row :gutter="24" >
          <el-col :span="12">
            <el-form-item label="审核:" prop="checkName" >
              <el-select
                  :disabled="title === '查看'"
                  v-model="state.form.checkName"
                  filterable
                  remote
                  @change="selectValue1"
                  reserve-keyword
                  placeholder="请输入人员名称"
                  remote-show-suffix
                  :remote-method="getPeopleList"
                  style="width: 240px"
              >
            <el-form-item label="审核:" prop="checkId" >
              <el-select clearable v-model="state.form.checkId" :disabled="title =='查看'" filterable  style="width: 100%">
                <el-option
                    v-for="item in state.peopleList"
                    :key="item.id"
                    :label="item.name"
                    :value="item.name"
                    :value="item.id"
                />
              </el-select>
            </el-form-item>
@@ -190,24 +156,13 @@
        </el-row>
        <el-row :gutter="24">
          <el-col :span="12">
            <el-form-item label="批准:" prop="ratifyName" >
              <el-select
                  :disabled="title === '查看'"
                  v-model="state.form.ratifyName"
                  filterable
                  remote
                  @change="selectValue2"
                  reserve-keyword
                  placeholder="请输入人员名称"
                  remote-show-suffix
                  :remote-method="getPeopleList"
                  style="width: 240px"
              >
            <el-form-item label="批准:" prop="ratifyId" >
              <el-select clearable v-model="state.form.ratifyId" :disabled="title =='查看'" filterable  style="width: 100%">
                <el-option
                    v-for="item in state.peopleList"
                    :key="item.id"
                    :label="item.name"
                    :value="item.name"
                    :value="item.id"
                />
              </el-select>
            </el-form-item>
@@ -266,13 +221,13 @@
    qualityTargets:[],
  },
  rules: {
    companyName: [{ required: true, message: '请选择企业', trigger: 'blur' }],
    companyId: [{ required: true, message: '请选择企业', trigger: 'blur' }],
    qualityId: [{ required: true, message: '请选择质量目标', trigger: 'blur' }],
    number: [{ required: true, message: '请输入编号', trigger: 'blur' }],
    serial: [{ required: true, message: '请输入序号', trigger: 'blur' }],
    fictionName: [{ required: true, message: '请选择拟制', trigger: 'blur' }],
    ratifyName: [{ required: true, message: '请选择批准人', trigger: 'blur' }],
    checkName: [{ required: true, message: '请选择审核人', trigger: 'blur' }],
    fictionId: [{ required: true, message: '请选择拟制', trigger: 'blur' }],
    ratifyId: [{ required: true, message: '请选择批准人', trigger: 'blur' }],
    checkId: [{ required: true, message: '请选择审核人', trigger: 'blur' }],
    checkTime: [{ required: true, message: '请选择日期', trigger: 'blur' }],
    ratifyTime: [{ required: true, message: '请选择日期', trigger: 'blur' }],
    fictionTime: [{ required: true, message: '请选择日期', trigger: 'blur' }],
@@ -294,7 +249,7 @@
});
const openDialog = async (type, value) => {
const openDialog = async (type, value,companyList) => {
  const userInfo = JSON.parse(Cookies.get('userInfo'))
  state.isAdmin = userInfo.userType === 0;
  state.form.companyName = userInfo.companyName
@@ -302,6 +257,7 @@
  if(state.isAdmin){
    state.form.companyId = value.companyId
    state.form.companyName = value.companyName
    state.companyList = companyList
  }
    await getQualityList()
  title.value = type === 'add' ? '新增' : type ==='edit' ? '编辑' : '查看' ;
@@ -311,9 +267,6 @@
      state.form.companyId = value.companyId
      state.form.companyName = value.companyName
    }
  }
  if(state.isAdmin){
    await   getCompanyList()
  }
  await   getPeopleList()
  dialogVisible.value = true;
@@ -406,35 +359,22 @@
  state.companyList = []
  state.qualityList = []
}
const getPeopleList = async (val)=>{
  if(val){
    const queryParams = {
      companyId: state.form.companyId == 0 ? null : state.form.companyId,
      name: val
    }
    const res = await getUser(queryParams)
    if (res.code == 200) {
      state.peopleList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }else {
    const queryParams = {
      pageNum: 1,
      pageSize: 10,
      companyId: state.form.companyId == 0 ? null : state.form.companyId
    }
    const res = await getUser(queryParams)
    if (res.code == 200) {
      state.peopleList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
const getPeopleList = async ()=> {
  if(state.isAdmin && (state.form.companyId == 0 || state.form.companyId == null)){
    return
  }
}
  const queryParams = {
    pageNum: 1,
    pageSize: 9999,
    companyId: state.form.companyId
  }
  const res = await getUser(queryParams)
  if(res.code == 200){
    state.peopleList = res.data.list?res.data.list:[]
  }else{
    ElMessage.warning(res.message)
  }
};
const selectValue = (val) => {
  state.peopleList.forEach(item => {
    if(item.name === val){
@@ -505,7 +445,7 @@
    }
  }else {
    const queryParams = {
      pageSize: 10,
      pageSize: 999,
      pageNum: 1,
    }
    const res = await getCompany(queryParams)
src/views/build/conpanyFunctionConsult/qualityObjectives/table/components/tableDeptDialog.vue
@@ -11,26 +11,14 @@
      <el-form :model="state.form" size="default" ref="busRef" :rules="state.rules"    >
        <el-row :gutter="24">
          <el-col :span="24">
            <el-form-item label="企业名称:" prop="companyName" v-if="state.isAdmin">
              <el-select
                  v-model="state.form.companyName"
                  filterable
                  remote
                  :disabled="title == '查看' || title == '编辑' || !state.isAdmin"
                  @change="selectValueCom"
                  reserve-keyword
                  placeholder="请输入企业名称"
                  remote-show-suffix
                  :remote-method="getCompanyList"
                  style="width: 100%"
              >
            <el-form-item label="企业名称:" prop="companyId" v-if="state.isAdmin">
              <el-select v-model="state.form.companyId" placeholder="请选择" filterable clearable style="width: 100%" :disabled="title == '查看' || title == '编辑' || !state.isAdmin" @change="selectValueCom">
                <el-option
                    v-for="item in state.companyList"
                    :key="item.id"
                    :label="item.name"
                    :value="item.name"
                />
                    :value="item.id">
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
@@ -108,24 +96,13 @@
        </el-row>
        <el-row :gutter="24">
          <el-col :span="12">
            <el-form-item label="编制:" prop="fictionName" >
              <el-select
                  :disabled="title === '查看'"
                  v-model="state.form.fictionName"
                  filterable
                  remote
                  @change="selectValue"
                  reserve-keyword
                  placeholder="请输入人员名称"
                  remote-show-suffix
                  :remote-method="getPeopleList"
                  style="width: 240px"
              >
            <el-form-item label="编制:" prop="fictionId" >
              <el-select clearable v-model="state.form.fictionId" :disabled="title =='查看'" filterable  style="width: 100%">
                <el-option
                    v-for="item in state.peopleList"
                    :key="item.id"
                    :label="item.name"
                    :value="item.name"
                    :value="item.id"
                />
              </el-select>
            </el-form-item>
@@ -143,24 +120,13 @@
        </el-row>
        <el-row :gutter="24" >
          <el-col :span="12">
            <el-form-item label="审核:" prop="checkName" >
              <el-select
                  :disabled="title === '查看'"
                  v-model="state.form.checkName"
                  filterable
                  remote
                  @change="selectValue1"
                  reserve-keyword
                  placeholder="请输入人员名称"
                  remote-show-suffix
                  :remote-method="getPeopleList"
                  style="width: 240px"
              >
            <el-form-item label="审核:" prop="checkId" >
              <el-select clearable v-model="state.form.checkId" :disabled="title =='查看'" filterable  style="width: 100%">
                <el-option
                    v-for="item in state.peopleList"
                    :key="item.id"
                    :label="item.name"
                    :value="item.name"
                    :value="item.id"
                />
              </el-select>
            </el-form-item>
@@ -178,24 +144,13 @@
        </el-row>
        <el-row :gutter="24">
          <el-col :span="12">
            <el-form-item label="批准(公司分管领导):" prop="ratifyName" >
              <el-select
                  :disabled="title === '查看'"
                  v-model="state.form.ratifyName"
                  filterable
                  remote
                  @change="selectValue2"
                  reserve-keyword
                  placeholder="请输入人员名称"
                  remote-show-suffix
                  :remote-method="getPeopleList"
                  style="width: 240px"
              >
            <el-form-item label="批准(公司分管领导):" prop="ratifyId" >
              <el-select clearable v-model="state.form.ratifyId" :disabled="title =='查看'" filterable  style="width: 100%">
                <el-option
                    v-for="item in state.peopleList"
                    :key="item.id"
                    :label="item.name"
                    :value="item.name"
                    :value="item.id"
                />
              </el-select>
            </el-form-item>
@@ -254,13 +209,13 @@
    qualityTargets:[],
  },
  rules: {
    companyName: [{ required: true, message: '请选择企业', trigger: 'blur' }],
    companyId: [{ required: true, message: '请选择企业', trigger: 'blur' }],
    qualityId: [{ required: true, message: '请选择质量目标', trigger: 'blur' }],
    number: [{ required: true, message: '请输入编号', trigger: 'blur' }],
    serial: [{ required: true, message: '请输入序号', trigger: 'blur' }],
    fictionName: [{ required: true, message: '请选择拟制', trigger: 'blur' }],
    ratifyName: [{ required: true, message: '请选择批准人', trigger: 'blur' }],
    checkName: [{ required: true, message: '请选择审核人', trigger: 'blur' }],
    fictionId: [{ required: true, message: '请选择拟制', trigger: 'blur' }],
    ratifyId: [{ required: true, message: '请选择批准人', trigger: 'blur' }],
    checkId: [{ required: true, message: '请选择审核人', trigger: 'blur' }],
    checkTime: [{ required: true, message: '请选择日期', trigger: 'blur' }],
    ratifyTime: [{ required: true, message: '请选择日期', trigger: 'blur' }],
    fictionTime: [{ required: true, message: '请选择日期', trigger: 'blur' }],
@@ -282,7 +237,7 @@
});
const openDialog = async (type, value) => {
const openDialog = async (type, value,companyList) => {
  const userInfo = JSON.parse(Cookies.get('userInfo'))
  state.isAdmin = userInfo.userType === 0;
  state.form.companyName = userInfo.companyName
@@ -290,6 +245,7 @@
  if(state.isAdmin){
    state.form.companyId = value.companyId
    state.form.companyName = value.companyName
    state.companyList = companyList
  }
    await getQualityList()
@@ -298,9 +254,7 @@
  if(type === 'edit' || type === 'review') {
    state.form = JSON.parse(JSON.stringify(value));
  }
  if(state.isAdmin){
    await   getCompanyList()
  }
  await   getPeopleList()
  dialogVisible.value = true;
}
@@ -391,35 +345,22 @@
  state.peopleList = []
  state.companyList = []
}
const getPeopleList = async (val)=>{
  if(val){
    const queryParams = {
      companyId: state.form.companyId == 0 ? null : state.form.companyId,
      name: val
    }
    const res = await getUser(queryParams)
    if (res.code == 200) {
      state.peopleList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }else {
    const queryParams = {
      pageNum: 1,
      pageSize: 10,
      companyId: state.form.companyId == 0 ? null : state.form.companyId
    }
    const res = await getUser(queryParams)
    if (res.code == 200) {
      state.peopleList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
const getPeopleList = async ()=> {
  if(state.isAdmin && (state.form.companyId == 0 || state.form.companyId == null)){
    return
  }
}
  const queryParams = {
    pageNum: 1,
    pageSize: 9999,
    companyId: state.form.companyId
  }
  const res = await getUser(queryParams)
  if(res.code == 200){
    state.peopleList = res.data.list?res.data.list:[]
  }else{
    ElMessage.warning(res.message)
  }
};
const selectValue = (val) => {
  state.peopleList.forEach(item => {
    if(item.name === val){
@@ -476,31 +417,7 @@
  getQualityList()
  getPeopleList()
}
const getCompanyList = async (val)=>{
  if(val){
    const queryParams = {
      name: val
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      state.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }else {
    const queryParams = {
      pageSize: 10,
      pageNum: 1,
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      state.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }
}
defineExpose({
  openDialog
});
src/views/build/conpanyFunctionConsult/qualityObjectives/table/index.vue
@@ -11,25 +11,33 @@
          >新增</el-button>
        </el-form-item>
        <el-form-item label="企业名称:" v-if="data.isAdmin" style="margin-left: 20px">
          <el-select
              v-model="data.queryParams.companyName"
              filterable
              remote
              @change="selectValue"
              reserve-keyword
              placeholder="请输入企业名称"
              remote-show-suffix
              :remote-method="getCompanyList"
              :loading="loadingCompany"
              style="width: 240px"
          >
          <el-select v-model="data.queryParams.companyId" placeholder="请选择" filterable clearable>
            <el-option
                v-for="item in data.companyList"
                :key="item.id"
                :label="item.name"
                :value="item.name"
            />
                :value="item.id">
            </el-option>
          </el-select>
<!--          <el-select-->
<!--              v-model="data.queryParams.companyName"-->
<!--              filterable-->
<!--              remote-->
<!--              @change="selectValue"-->
<!--              reserve-keyword-->
<!--              placeholder="请输入企业名称"-->
<!--              remote-show-suffix-->
<!--              :remote-method="getCompanyList"-->
<!--              :loading="loadingCompany"-->
<!--              style="width: 240px"-->
<!--          >-->
<!--            <el-option-->
<!--                v-for="item in data.companyList"-->
<!--                :key="item.id"-->
<!--                :label="item.name"-->
<!--                :value="item.name"-->
<!--            />-->
<!--          </el-select>-->
        </el-form-item>
        <el-form-item label="年份:" style="margin-left: 20px">
          <el-select
@@ -241,10 +249,10 @@
  data.dialogVisible = true
}
const openDialog = (type, value) => {
  noticeRef.value.openDialog(type, value);
  noticeRef.value.openDialog(type, value,data.companyList);
}
const openDeptDialog = (type, value) => {
  deptRef.value.openDialog(type, value);
  deptRef.value.openDialog(type, value,data.companyList);
}
const selectValue = (val) => {
@@ -255,37 +263,21 @@
  })
}
const getCompanyList = async (val)=>{
  if(val){
    loadingCompany.value = true;
    const queryParams = {
      name: val
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      loadingCompany.value = false;
      data.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
  }else{
    loadingCompany.value = true;
    const queryParams = {
      pageSize: 10,
      pageNum: 1,
    }
    const res = await getCompany(queryParams)
    if (res.code == 200) {
      loadingCompany.value = false;
      data.companyList = res.data.list
    } else {
      ElMessage.warning(res.message)
    }
const getCompanyList = async ()=>{
  const queryParams = {
    pageNum: 1,
    pageSize: 999
  }
  const res = await getCompany(queryParams)
  if (res.code == 200) {
    data.companyList = res.data.list?res.data.list:[]
    // data.queryParams.companyId = data.companyList[0].id
  } else {
    ElMessage.warning(res.message)
  }
}
const handleSizeChange = (val) => {
  data.queryParams.pageSize = val
  getList()
src/views/build/conpanyFunctionConsult/staffManage/staffRegister/components/staffDialog.vue
@@ -43,9 +43,9 @@
        </el-form-item>
        <el-form-item label="用户类型:" v-if="state.title !== '修改密码'" prop="userType">
          <el-radio-group v-model="state.form.userType"  :disabled="disabled" @change="changeType" v-if="state.title == '新增'">
            <el-radio :label="0" v-if="state.currentUserType == 0">管理员</el-radio>
            <el-radio :label="1" v-if="state.currentUserType == 0 ">企业级</el-radio>
            <el-radio :label="2" v-if="state.currentUserType == 1 ">部门级</el-radio>
            <el-radio :label="0" v-if="state.currentUserType == 0">系统管理员</el-radio>
            <el-radio :label="1" v-if="state.currentUserType == 0 ">企业管理员</el-radio>
            <el-radio :label="2" v-if="state.currentUserType == 1 ">企业用户</el-radio>
            <el-radio :label="3" v-if="!state.isAdmin">车间(岗位)级</el-radio>
            <el-radio :label="4" v-if="state.currentUserType == 0">其他</el-radio>
          </el-radio-group>
src/views/build/conpanyFunctionConsult/staffManage/staffRegister/index.vue
@@ -214,7 +214,7 @@
    companyId: null
  })
  if(res.code == 200){
    data.expertData = res.data.list.map((item,index) => {
    data.expertData = res.data.list?.map((item,index) => {
      return {
        ...item,
        index: index + 1,
src/views/build/conpanyFunctionConsult/standardSysTemp/appStandardModule/index.vue
@@ -32,11 +32,12 @@
      <el-table-column label="模板名称" prop="templateName" align="center"/>
      <el-table-column label="模板文件" align="center">
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName + '模板'}}</el-button>
          <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
          <el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
          <el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
        </template>
@@ -63,6 +64,9 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
import { renderAsync } from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -101,7 +105,6 @@
  loading.value = true
  const res = await getStandardTemp(data.queryParams)
  if(res.code == 200){
    console.log(res.data,'data')
    data.dataList = res.data.list || []
    data.total = res.data.total
  }else{
@@ -128,6 +131,37 @@
  window.open(import.meta.env.VITE_APP_BASE_API + '/' + path)
}
const openFile = async(path)=>{
  try {
    // 1. 获取文件
    const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
    const arrayBuffer = await response.arrayBuffer();
    // 2. 创建新窗口
    const win = window.open('', '_blank');
    win.document.write(`
      <!DOCTYPE html>
      <html>
        <head>
          <title>预览</title>
          <style>
            body { margin: 20px; font-family: Arial; }
            .docx-container { width: 100%; height: 100%; }
          </style>
        </head>
        <body>
          <div id="container" class="docx-container"></div>
        </body>
      </html>
    `);
    // 3. 渲染 DOCX
    await renderAsync(arrayBuffer, win.document.getElementById('container'));
  } catch (error) {
    console.error('预览失败:', error);
    alert(`预览失败: ${error.message}`);
  }
}
const openDialog = (type, value) => {
  dialogRef.value.openDialog(type, value, data.queryParams.companyId, data.isAdmin, data.companyList);
}
src/views/build/conpanyFunctionConsult/standardSysTemp/sysStandardModule/index.vue
@@ -32,11 +32,12 @@
      <el-table-column label="模板名称" prop="templateName" align="center"/>
      <el-table-column label="模板文件" align="center">
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName + '模板'}}</el-button>
          <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
          <el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
          <el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
        </template>
@@ -50,7 +51,7 @@
        v-model:limit="queryParams.pageSize"
        @pagination="getList"
    />
    <div id="docx-preview-container" style="width: 100%; height: auto; border: 1px solid #ccc;"></div>
    <edit-dialog ref="dialogRef" @getList=getList></edit-dialog>
  </div>
</template>
@@ -63,6 +64,8 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
import { renderAsync } from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -97,6 +100,38 @@
})
const openFile = async(path)=>{
  try {
    // 1. 获取文件
    const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
    const arrayBuffer = await response.arrayBuffer();
    // 2. 创建新窗口
    const win = window.open('', '_blank');
    win.document.write(`
      <!DOCTYPE html>
      <html>
        <head>
          <title>预览</title>
          <style>
            body { margin: 20px; font-family: Arial; }
            .docx-container { width: 100%; height: 100%; }
          </style>
        </head>
        <body>
          <div id="container" class="docx-container"></div>
        </body>
      </html>
    `);
    // 3. 渲染 DOCX
    await renderAsync(arrayBuffer, win.document.getElementById('container'));
  } catch (error) {
    console.error('预览失败:', error);
    alert(`预览失败: ${error.message}`);
  }
}
const getList = async () => {
  loading.value = true
  const res = await getStandardTemp(data.queryParams)
src/views/build/conpanyFunctionConsult/standardSysTemp/techStandardModule/index.vue
@@ -32,11 +32,12 @@
      <el-table-column label="模板名称" prop="templateName" align="center"/>
      <el-table-column label="模板文件" align="center">
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName + '模板'}}</el-button>
          <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
        <template #default="scope">
          <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
          <el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
          <el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
        </template>
@@ -63,6 +64,7 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
import { renderAsync } from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -96,7 +98,36 @@
onUnmounted(()=>{
})
const openFile = async(path)=>{
  try {
    // 1. 获取文件
    const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
    const arrayBuffer = await response.arrayBuffer();
    // 2. 创建新窗口
    const win = window.open('', '_blank')
    win.document.write(`
      <!DOCTYPE html>
      <html>
        <head>
          <title>预览</title>
          <style>
            body { margin: 20px; font-family: Arial; }
            .docx-container { width: 100%; height: 100%; }
          </style>
        </head>
        <body>
          <div id="container" class="docx-container"></div>
        </body>
      </html>
    `);
    // 3. 渲染 DOCX
    await renderAsync(arrayBuffer, win.document.getElementById('container'));
  } catch (error) {
    console.error('预览失败:', error);
    alert(`预览失败: ${error.message}`);
  }
}
const getList = async () => {
  loading.value = true
  const res = await getStandardTemp(data.queryParams)