From 9b998490450d23422bd9769522c42c4952db0263 Mon Sep 17 00:00:00 2001
From: 祖安之光 <11848914+light-of-zuan@user.noreply.gitee.com>
Date: 星期一, 18 八月 2025 16:51:01 +0800
Subject: [PATCH] 修改新增

---
 src/views/work/qualityInfo/outsourcingCooperate/outsourcedProcessReview/index.vue |  299 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 299 insertions(+), 0 deletions(-)

diff --git a/src/views/work/qualityInfo/outsourcingCooperate/outsourcedProcessReview/index.vue b/src/views/work/qualityInfo/outsourcingCooperate/outsourcedProcessReview/index.vue
new file mode 100644
index 0000000..e59ab28
--- /dev/null
+++ b/src/views/work/qualityInfo/outsourcingCooperate/outsourcedProcessReview/index.vue
@@ -0,0 +1,299 @@
+<template>
+  <div class="app-container">
+    <div style="display: flex;justify-content: space-between">
+      <el-form :inline="true" style="display: flex;align-items: center;flex-wrap: wrap;" >
+        <el-form-item>
+          <el-button
+              type="primary"
+              plain
+              icon="Plus"
+              @click="openDialog('add',{})"
+          >新增</el-button>
+        </el-form-item>
+        <el-form-item v-if="isAdmin" label="企业:" >
+          <el-select v-model="data.queryParams.companyId" placeholder="请选择" clearable>
+            <el-option
+                v-for="item in companyList"
+                :key="item.id"
+                :label="item.name"
+                :value="item.id">
+            </el-option>
+          </el-select>
+        </el-form-item>
+        <el-form-item >
+          <el-button v-if="isAdmin" type="primary" @click="getList">查询</el-button>
+          <el-button v-if="isAdmin" type="primary" plain @click="reset">重置</el-button>
+<!--          <el-button type="primary">导出</el-button>-->
+        </el-form-item>
+      </el-form>
+    </div>
+    <!-- 表格数据 -->
+    <el-table v-loading="loading" :data="dataList" :border="true">
+      <el-table-column type="index" label="序号"></el-table-column>
+      <el-table-column prop="reviewName" align="center" label="评审表名称">
+        <template #default="scope">
+          {{scope.row.reviewName}}
+        </template>
+      </el-table-column>
+      <el-table-column label="操作" align="center">
+        <template #default="scope">
+          <el-button link type="primary" @click="openDialog('view',scope.row)">查看</el-button>
+          <el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
+          <el-button link type="primary" @click="downloadFile(scope.row)">导出</el-button>
+          <el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
+        </template>
+      </el-table-column>
+    </el-table>
+
+    <pagination
+        v-show="total > 0"
+        :total="total"
+        v-model:page="queryParams.pageNum"
+        v-model:limit="queryParams.pageSize"
+        @pagination="getList"
+    />
+
+    <edit-dialog ref="dialogRef" @getList=getList></edit-dialog>
+  </div>
+</template>
+
+<script setup>
+import {getCurrentInstance, onMounted, onUnmounted, reactive, ref, toRefs} from "vue";
+import {ElMessage, ElMessageBox} from "element-plus";
+import {delCompany, getCompany} from "@/api/onlineEducation/company";
+import Cookies from "js-cookie";
+import editDialog from './components/editDialog.vue'
+import useUserStore from "@/store/modules/user";
+import {generateWordDocument} from "@/utils/exportWord";
+import {
+  delMaintenanceEvaluate,
+  getMaintenanceEvaluateDetail,
+  getMaintenanceEvaluateList
+} from "@/api/infrastructureMng/ledger";
+import {
+  delOutsourcedReview,
+  getOutsourcedReviewDetail,
+  getOutsourcedReviewList
+} from "@/api/outsourcingCooperate/outsourcingCooperate";
+
+
+const userStore = useUserStore()
+const { proxy } = getCurrentInstance();
+const loading = ref(false);
+const dialogRef = ref();
+const data = reactive({
+  queryParams: {
+    pageNum: 1,
+    pageSize: 10,
+    companyId: null
+  },
+  total: 0,
+  dataList: [],
+  companyList: [],
+  isAdmin: false,
+  keyList: [
+    {id: 1, label: '关键件'},
+    {id: 2, label: '重要件'},
+    {id: 3, label: '普通件'}
+  ],
+  vitalList: [
+    {id: 1, label: '关键'},
+    {id: 2, label: '一般'}
+  ],
+  necessaryList: [
+    {id: '1', label: '本单位没有能力满足产品实现需求'},
+    {id: '2', label: '生产急需,利用外部资源实现产品'},
+    {id: '3', label: '其他'}
+  ],
+  workList: [
+    {id: '1', label: '本单位可提供现成的图纸、技术资料'},
+    {id: '2', label: '本单位可提供合格的原材料'},
+    {id: '3', label: '本单位有能力对供方产品实现过程实施控制'},
+    {id: '4', label: '其他'}
+  ],
+  riskList: [
+    {id: '1', label: '外包过程对我所产品质量有很大影响'},
+    {id: '2', label: '外包产品供货影响我所生产进度'},
+    {id: '3', label: '实施外包对我所经济效益有影响'},
+    {id: '4', label: '其他'}
+  ],
+  qualityList: [
+    {id: '1', label: '进货检验'},
+    {id: '2', label: '我司到供方现场验证'},
+    {id: '3', label: '顾客到供方现场验证'}
+  ],
+  processList: [
+    {id: '1', label: '与供方及时沟通'},
+    {id: '2', label: '要求供方列出进度计划'},
+    {id: '3', label: '纳入协同合作采取经济制约'}
+  ],
+  economyList: [
+    {id: '1', label: '我司财务预算'},
+    {id: '2', label: '在预算范围内外包'},
+    {id: '3', label: '与供方协商解决'}
+  ],
+  signList: [
+    {id: 1, label: '可以外包'},
+    {id: 2, label: '不可以外包,由部门采取措施解决。措施内容:'},
+  ]
+});
+
+const { queryParams, total, dataList,companyList, isAdmin } = toRefs(data);
+const userInfo = ref()
+onMounted(async ()=>{
+  if(userStore.roles.includes('admin')){
+    data.isAdmin = true
+    await getCompanyList()
+  }else{
+    data.isAdmin = false
+    data.queryParams.companyId = userStore.companyId
+  }
+  await getList()
+})
+
+onUnmounted(()=>{
+
+})
+
+const getList = async () => {
+  loading.value = true
+  const res = await getOutsourcedReviewList(data.queryParams)
+  if(res.code == 200){
+    data.dataList = res.data.list || []
+    data.total = res.data.total
+  }else{
+    ElMessage.warning(res.message)
+  }
+  loading.value = false
+}
+
+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 downloadFile = async (val)=>{
+  const res = await getOutsourcedReviewDetail({id: val.id})
+  if(res.code == 200){
+    if(res.data){
+      let tableData = res.data
+      tableData.reviewList = res.data.outsourcedReviewSubsidiaryList
+      tableData.keyList = data.keyList.map(item=>{
+        return {
+          ...item,
+          checked: tableData.pieceType == item.id ? false: true
+        }
+      })
+      tableData.vitalList = data.vitalList.map(item=>{
+        return {
+          ...item,
+          checked: tableData.processType == item.id ? false: true
+        }
+      })
+      tableData.necessaryList = data.necessaryList.map(item=>{
+        return {
+          ...item,
+          checked: tableData.necessity.split(',').includes(item.id) ? false: true
+        }
+      })
+      tableData.workList = data.workList.map(item=>{
+        return {
+          ...item,
+          checked: tableData.feasibility.split(',').includes(item.id) ? false: true
+        }
+      })
+      tableData.riskList = data.riskList.map(item=>{
+        return {
+          ...item,
+          checked: tableData.riskRecognition.split(',').includes(item.id) ? false: true
+        }
+      })
+      tableData.qualityList = data.qualityList.map(item=>{
+        return {
+          ...item,
+          checked: tableData.qualityMeasures.split(',').includes(item.id) ? false: true
+        }
+      })
+      tableData.processList = data.processList.map(item=>{
+        return {
+          ...item,
+          checked: tableData.progressMeasures.split(',').includes(item.id) ? false: true
+        }
+      })
+      tableData.economyList = data.economyList.map(item=>{
+        return {
+          ...item,
+          checked: tableData.economicMeasure.split(',').includes(item.id) ? false: true
+        }
+      })
+      tableData.signList = data.signList.map(item=>{
+        return {
+          ...item,
+          checked: tableData.outsourceType == item.id ? false: true
+        }
+      })
+      tableData.applyDeptDate = tableData.applyDeptDate.replace(/^(\d{4})-(\d{1,2})-(\d{1,2}).*$/, (match, year, month, day) => `${year}年${parseInt(month)}月${parseInt(day)}日`)
+      tableData.qualityInspectionDate = tableData.qualityInspectionDate.replace(/^(\d{4})-(\d{1,2})-(\d{1,2}).*$/, (match, year, month, day) => `${year}年${parseInt(month)}月${parseInt(day)}日`)
+      tableData.managementRepresentativeDate = tableData.managementRepresentativeDate.replace(/^(\d{4})-(\d{1,2})-(\d{1,2}).*$/, (match, year, month, day) => `${year}年${parseInt(month)}月${parseInt(day)}日`)
+      tableData.executiveDate = tableData.executiveDate.replace(/^(\d{4})-(\d{1,2})-(\d{1,2}).*$/, (match, year, month, day) => `${year}年${parseInt(month)}月${parseInt(day)}日`)
+      tableData.reviewList = res.data.outsourcedReviewSubsidiaryList
+      try {
+        generateWordDocument('/outsourceProcessReview.docx', tableData, tableData.reviewName +'.docx');
+      } catch (error){
+        ElMessage({
+          type: 'warning',
+          message: '导出失败'
+        });
+      }
+    }else{
+      ElMessage.warning('暂无数据')
+    }
+  }else{
+    ElMessage.warning(res.message)
+  }
+}
+
+const openDialog = (type, value) => {
+  dialogRef.value.openDialog(type, value, data.queryParams.companyId, data.isAdmin, data.companyList);
+}
+
+/** 重置新增的表单以及其他数据  */
+const reset= async()=> {
+  data.queryParams = {
+    pageNum: 1,
+    pageSize: 10,
+    companyId: null
+  }
+  await getCompanyList()
+  await getList()
+}
+const handleDelete = (val) => {
+  ElMessageBox.confirm(
+      '确定删除此条数据?',
+      '提示',
+      {
+        confirmButtonText: '确定',
+        cancelButtonText: '取消',
+        type: 'warning',
+      })
+      .then( async() => {
+        const res = await delOutsourcedReview({id: val.id})
+        if(res.code == 200){
+          ElMessage.success('数据删除成功')
+          await getList()
+        }else{
+          ElMessage.warning(res.message)
+        }
+      })
+}
+
+</script>

--
Gitblit v1.9.2