dd2006d2d24ffffbdf1d30867fe2bfc19adb4a84..a390dbc5239ac26f093c6670c12cfd6a49ca6037
2025-11-20 zhouwx
修改
a390db 对比 | 目录
2025-11-20 祖安之光
修改新增
a286e0 对比 | 目录
2025-11-20 祖安之光
修改新增
8c2a70 对比 | 目录
已修改5个文件
79 ■■■■■ 文件已修改
src/views/build/conpanyFunctionConsult/standardSysTemp/appStandardModule/components/editDialog.vue 34 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/standardSysTemp/appStandardModule/index.vue 2 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/standardSysTemp/programStanderdModule/components/editDialog.vue 24 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/standardSysTemp/programStanderdModule/index.vue 17 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/work/empResource/deptEmpAnalysis/index.vue 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/build/conpanyFunctionConsult/standardSysTemp/appStandardModule/components/editDialog.vue
@@ -19,6 +19,19 @@
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="阶段:" prop="stage">
          <el-input v-model.trim="state.form.stage" :disabled="state.title =='查看'" placeholder="阶段"></el-input>
        </el-form-item>
        <el-form-item label="行业:" prop="industryTypeId">
          <el-select v-model="state.form.industryTypeId" placeholder="请选择" clearable style="width: 100%">
            <el-option
                v-for="item in state.industryList"
                :key="item.id"
                :label="item.name"
                :value="item.id">
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="模板名称:" prop="templateName">
          <el-input v-model.trim="state.form.templateName" :disabled="state.title =='查看'" placeholder="模板名称"></el-input>
        </el-form-item>
@@ -50,6 +63,7 @@
import {getToken} from "@/utils/auth";
import {delPic} from "@/api/onlineEducation/banner";
import {saveStandardTemp, updateStandardTemp} from "@/api/standardSys/standardSys";
import {getIndustry} from "@/api/system/industry";
const emit = defineEmits(["getList"]);
const dialogVisible = ref(false)
@@ -68,16 +82,21 @@
    templateName: '',
    filePath: '',
    format: '',
    stage:'',
    industryTypeId:'',
    companyId: null,
    templateType: 3
  },
  formRules:{
    companyId: [{ required: true, message: '请选择企业', trigger: 'blur' }],
    templateName: [{ required: true, message: '请输入模板名称', trigger: 'blur' }],
    filePath: [{ required: true, validator: checkFiles, trigger: 'blur' }]
    filePath: [{ required: true, validator: checkFiles, trigger: 'blur' }],
    stage: [{ required: true, message: '请输入阶段', trigger: 'blur' }],
    industryTypeId: [{ required: true, message: '请选择行业', trigger: 'blur' }],
  },
  isAdmin: false,
  companyList: [],
  industryList: [],
  uploadUrl: import.meta.env.VITE_APP_BASE_API + '/system/common/uploadFile',
  header: {
    Authorization: getToken()
@@ -96,12 +115,14 @@
  }
  state.title = type === 'add' ? '新增' : type ==='edit' ? '编辑' : '查看'
  state.form.companyId = companyId
  await getIndustryList()
  if(state.title == '编辑'||state.title == '查看'){
    Object.keys(state.form).forEach(key => {
      if (key in value) {
        state.form[key] = value[key]
      }
    })
    state.form.industryTypeId = value.industryTypeId ? value.industryTypeId : null
    if(value.filePath) {
      const obj = {
        url: value.filePath,
@@ -112,7 +133,14 @@
  }
  dialogVisible.value = true
}
const getIndustryList = async () => {
  const res = await getIndustry()
  if(res.code == 200){
    state.industryList = res.data.data
  }else{
    ElMessage.warning(res.message)
  }
}
const onSubmit = async () => {
  const valid = await superRef.value.validate();
@@ -197,6 +225,8 @@
    templateName: '',
    filePath: '',
    format: '',
    industryTypeId:'',
    stage:'',
    companyId: null,
    templateType: 3
  }
src/views/build/conpanyFunctionConsult/standardSysTemp/appStandardModule/index.vue
@@ -29,12 +29,14 @@
    <!-- 表格数据 -->
    <el-table v-loading="loading" :data="dataList" :border="true">
      <el-table-column label="序号" type="index" align="center" width="80"/>
      <el-table-column label="阶段" prop="stage" header-align="center" align="left"/>
      <el-table-column label="模板名称" prop="templateName" 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>
        </template>
      </el-table-column>
      <el-table-column label="行业" prop="industryTypeName" header-align="center" align="left"/>
      <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>
src/views/build/conpanyFunctionConsult/standardSysTemp/programStanderdModule/components/editDialog.vue
@@ -29,9 +29,19 @@
            </el-option>
          </el-select>
        </el-form-item>
        <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)" >
@@ -81,6 +91,8 @@
    filePath: '',
    format: '',
    companyId: null,
    industryTypeId: null,
    industryTypeName: '',
    deptId:null,
    templateType: 10
  },
@@ -89,6 +101,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 +111,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 +161,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 +243,8 @@
    filePath: '',
    format: '',
    companyId: null,
    industryTypeId: null,
    industryTypeName: '',
    deptId:null,
    templateType: 10
  }
src/views/build/conpanyFunctionConsult/standardSysTemp/programStanderdModule/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);
@@ -79,6 +81,7 @@
  },
  total: 0,
  dataList: [],
  typeList: [],
  companyList: [],
  isAdmin: false
});
@@ -94,6 +97,7 @@
    data.queryParams.companyId = userStore.companyId
  }
  await getList()
  await getTypeList()
})
onUnmounted(()=>{
@@ -165,12 +169,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);
}
/** 重置新增的表单以及其他数据  */
src/views/work/empResource/deptEmpAnalysis/index.vue
@@ -38,7 +38,7 @@
        其中
        <span v-if="dataList.positional3>0">高级人称{{dataList.positional3}}人,</span>
        <span v-if="dataList.positional2>0">中级人称{{dataList.positional2}}人,</span>
        <span v-if="dataList.positional1>0">初级人称{{dataList.positional1}}人,</span>。
        <span v-if="dataList.positional1>0">初级人称{{dataList.positional1}}人</span>。
      </span>
      <br>
      本科及以上学历{{dataList.qualification3 + dataList.qualification4 + dataList.qualification5}}人,占总人数的{{dataList.qualificationBKRatio}}%,