祖安之光
2025-11-18 00bae2110315cf9c9a533afea2c617d950f6768e
修改新增
已修改2个文件
41 ■■■■■ 文件已修改
src/views/build/conpanyFunctionConsult/standardSysTemp/techStandardModule/components/editDialog.vue 23 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/standardSysTemp/techStandardModule/index.vue 18 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/standardSysTemp/techStandardModule/components/editDialog.vue
@@ -33,6 +33,17 @@
        <el-form-item label="模板名称:" prop="templateName">
          <el-input v-model.trim="state.form.templateName" :disabled="state.title =='查看'" placeholder="模板名称"></el-input>
        </el-form-item>
        <el-form-item label="行业类别:" prop="industryTypeId">
          <el-select v-model="state.form.industryTypeId" filterable placeholder="请选择" clearable>
            <el-option
                v-for="item in state.typeList"
                :key="item.id"
                style="width: 100%"
                :label="item.name"
                :value="item.id">
            </el-option>
          </el-select>
        </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>
@@ -81,6 +92,8 @@
    filePath: '',
    format: '',
    companyId: null,
    industryTypeId: null,
    industryTypeName: '',
    deptId:null,
    templateType: 2
  },
@@ -89,6 +102,7 @@
    templateName: [{ required: true, message: '请输入模板名称', trigger: 'blur' }],
    filePath: [{ required: true, validator: checkFiles, trigger: 'blur' }],
    deptId: [{ required: true, message: '请选择部门', trigger: 'blur' }],
    industryTypeId: [{ required: true, message: '请选择行业类别', trigger: 'blur' }]
  },
  isAdmin: false,
  companyList: [],
@@ -98,17 +112,19 @@
  },
  fileLimit: 1,
  fileList: [],
  deptList: []
  deptList: [],
  typeList: []
})
onMounted(() => {
});
const openDialog = async (type, value,companyId, isAdmin, companyList) => {
const openDialog = async (type, value,companyId, isAdmin, companyList,typeList) => {
  state.isAdmin = isAdmin
  if(isAdmin){
    state.companyList = companyList
  }
  state.typeList = typeList
  state.title = type === 'add' ? '新增' : type ==='edit' ? '编辑' : '查看'
  state.form.companyId = companyId
  if(state.title == '编辑'||state.title == '查看'){
@@ -146,6 +162,7 @@
const onSubmit = async () => {
  const valid = await superRef.value.validate();
  if(valid){
    state.form.industryTypeName = state.typeList.find(i=>i.id == state.form.industryTypeId)?.name || ''
    if(state.title == '新增'){
      const {id,...data} = state.form
      const res = await saveStandardTemp(data)
@@ -227,6 +244,8 @@
    filePath: '',
    format: '',
    companyId: null,
    industryTypeId: null,
    industryTypeName: '',
    deptId:null,
    templateType: 2
  }
src/views/build/conpanyFunctionConsult/standardSysTemp/techStandardModule/index.vue
@@ -31,6 +31,7 @@
      <el-table-column label="序号" type="index" align="center" width="80"/>
      <el-table-column label="模板名称" prop="templateName" header-align="center" align="left"/>
      <el-table-column label="所属部门" prop="deptName" header-align="center" align="left"/>
      <el-table-column label="行业类别" prop="industryTypeName" header-align="center" align="left"/>
      <el-table-column label="模板文件" header-align="center" align="left">
        <template #default="scope">
          <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
@@ -66,6 +67,7 @@
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
import { renderAsync } from "docx-preview";
import {getIndustryPage} from "@/api/system/industry";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -80,6 +82,7 @@
  total: 0,
  dataList: [],
  companyList: [],
  typeList: [],
  isAdmin: false
});
@@ -94,6 +97,7 @@
    data.queryParams.companyId = userStore.companyId
  }
  await getList()
  await getTypeList()
})
onUnmounted(()=>{
@@ -142,7 +146,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{
@@ -165,12 +168,23 @@
  }
}
const getTypeList = async () => {
  const res = await getIndustryPage({pageNum: 1,
    pageSize: 999,
    companyId: data.queryParams.companyId})
  if(res.code == 200){
    data.typeList = res.data.list
  }else{
    ElMessage.warning(res.message)
  }
}
const downloadFile = (path)=>{
  window.open(import.meta.env.VITE_APP_BASE_API + '/' + path)
}
const openDialog = (type, value) => {
  dialogRef.value.openDialog(type, value, data.queryParams.companyId, data.isAdmin, data.companyList);
  dialogRef.value.openDialog(type, value, data.queryParams.companyId, data.isAdmin, data.companyList, data.typeList);
}
/** 重置新增的表单以及其他数据  */