优化
This commit is contained in:
		| @ -6,7 +6,7 @@ VITE_APP_ENV = 'development' | ||||
|  | ||||
| # 开发环境 | ||||
|  | ||||
| VITE_APP_BASE_API = 'http://192.168.110.209:8899' | ||||
| VITE_APP_BASE_API = 'http://192.168.110.149:8899' | ||||
| # 李陈杰 209 | ||||
| # VITE_APP_BASE_API = 'http://192.168.110.209:8899' | ||||
| # 曾涛 | ||||
|  | ||||
| @ -1,54 +1,19 @@ | ||||
| <template> | ||||
|   <div class="p-2"> | ||||
|     <el-tabs type="border-card" v-model="activeName" @tab-click="handleClick"> | ||||
|       <el-tab-pane label="变更单" name="1" | ||||
|         ><el-card shadow="never"> | ||||
|           <template #header> | ||||
|             <el-row :gutter="10" class="mb8"> | ||||
|               <el-col :span="1.5"> | ||||
|                 <el-button type="primary" plain icon="Plus" :disabled="addSingle" @click="handleAddApp" v-hasPermi="['quality:qualityInspection:add']" | ||||
|                   >上传变更单模版</el-button | ||||
|                 > | ||||
|               </el-col> | ||||
|               <right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar> | ||||
|             </el-row> | ||||
|           </template> | ||||
|           <EngineeringChangeApplicationForm | ||||
|             @selection-change="handleSelectionChange" | ||||
|             :data="tableData" | ||||
|             :thumbnail="projectTypeOptions[1].thumbnail" | ||||
|             @delete="handleDelete" | ||||
|           ></EngineeringChangeApplicationForm> | ||||
|           <pagination | ||||
|             v-show="total > 0" | ||||
|             :total="total" | ||||
|             v-model:page="queryParams.pageNum" | ||||
|             v-model:limit="queryParams.pageSize" | ||||
|             @pagination="getList" | ||||
|           /> </el-card | ||||
|       ></el-tab-pane> | ||||
|       <el-tab-pane label="外部联系单" name="0" | ||||
|         ><el-card shadow="never"> | ||||
|           <template #header> | ||||
|             <el-row :gutter="10" class="mb8"> | ||||
|               <el-col :span="1.5"> | ||||
|                 <el-button type="primary" plain icon="Plus" :disabled="addSingle" @click="handleAdd" v-hasPermi="['quality:qualityInspection:add']" | ||||
|                   >上传外部联系单模版</el-button | ||||
|                 > | ||||
|               </el-col> | ||||
|               <right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar> | ||||
|             </el-row> | ||||
|           </template> | ||||
|           <Contactform @selection-change="handleSelectionChange" :data="tableData" @delete="handleDelete"></Contactform> | ||||
|           <pagination | ||||
|             v-show="total > 0" | ||||
|             :total="total" | ||||
|             v-model:page="queryParams.pageNum" | ||||
|             v-model:limit="queryParams.pageSize" | ||||
|             @pagination="getList" | ||||
|           /> </el-card | ||||
|       ></el-tab-pane> | ||||
|     </el-tabs> | ||||
|     <el-card shadow="never"> | ||||
|       <template #header> | ||||
|         <el-row :gutter="10" class="mb8"> | ||||
|           <el-col :span="1.5"> | ||||
|             <el-button type="primary" plain icon="Plus" :disabled="addSingle" @click="handleAdd" v-hasPermi="['quality:qualityInspection:add']" | ||||
|               >上传外部联系单模版</el-button | ||||
|             > | ||||
|           </el-col> | ||||
|           <right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar> | ||||
|         </el-row> | ||||
|       </template> | ||||
|       <Contactform @selection-change="handleSelectionChange" :data="tableData" @delete="handleDelete"></Contactform> | ||||
|       <pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" @pagination="getList" /> | ||||
|     </el-card> | ||||
|     <el-dialog title="新增模板" v-model="dialogVisible" width="800"> | ||||
|       <el-form :model="form" :rules="rules" ref="formRef" label-width="110px"> | ||||
|         <div class="flex"> | ||||
| @ -109,14 +74,11 @@ | ||||
|  | ||||
| <script setup lang="ts"> | ||||
| import { useUserStoreHook } from '@/store/modules/user'; | ||||
| import type { FormInstance, FormRules } from 'element-plus'; | ||||
| import type { FormInstance } from 'element-plus'; | ||||
| import Contactform from './components/contactform.vue'; | ||||
| import EngineeringChangeApplicationForm from './components/engineeringChangeApplicationForm.vue'; | ||||
| import { listContactTypeformtemplate } from '@/api/cory/contactformtemplate'; | ||||
| import { addContactnotice, delContactnotice, listContactnotice } from '@/api/cory/contactnotice'; | ||||
|  | ||||
| const { proxy } = getCurrentInstance() as ComponentInternalInstance; | ||||
| const { wf_business_status } = toRefs(proxy?.useDict('wf_business_status')); | ||||
| // 获取用户 store | ||||
| const userStore = useUserStoreHook(); | ||||
| // 从 store 中获取项目列表和当前选中的项目 | ||||
|  | ||||
| @ -0,0 +1,396 @@ | ||||
| <template> | ||||
|   <div class="content-box"> | ||||
|     <el-table :data="data" style="width: 100%" @selection-change="handleSelectionChange"> | ||||
|       <el-table-column type="index" width="55" label="序号" align="center" /> | ||||
|       <el-table-column align="center" prop="projectName" label="工程名称" /> | ||||
|       <el-table-column align="center" prop="submitUnit" label="提出单位" /> | ||||
|       <el-table-column align="center" prop="specialty" label="专业"> | ||||
|         <template #default="{ row }"> | ||||
|           <dict-tag :options="des_user_major" :value="row.specialty" /> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" prop="submitDate" label="提出日期"> | ||||
|         <template #default="{ row }"> | ||||
|           {{ formatDate(row.submitDate) }} | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" prop="volumeName" label="卷册名称" /> | ||||
|       <el-table-column align="center" prop="volumeNumber" label="卷册号" /> | ||||
|       <el-table-column align="center" prop="content" label="变更内容" /> | ||||
|       <el-table-column align="center" prop="costEstimation" label="变更费用估算" /> | ||||
|       <el-table-column label="流程状态" align="center" prop="status"> | ||||
|         <template #default="scope"> | ||||
|           <dict-tag :options="wf_business_status" :value="scope.row.status" /> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column align="center" prop="content" label="操作" width="240"> | ||||
|         <template #default="scope"> | ||||
|           <el-button link type="warning" v-if="scope.row.status === 'draft'" icon="Edit" @click="handleUpdate(scope.row)" class="ml-3" | ||||
|             >审批 | ||||
|           </el-button> | ||||
|           <el-button link type="primary" icon="View" @click="handleViewInfo(scope.row)" class="ml-3"> 查看流程 </el-button> | ||||
|           <el-button link type="success" icon="View" @click="handleDetail(scope.row)" class="ml-3"> 详情 </el-button> | ||||
|           <!-- <el-button link type="danger" icon="Delete" @click="handleDelete(scope.row)"> 删除 </el-button> --> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|     <!-- 详情 --> | ||||
|     <el-dialog title="变更单详情" v-model="detailVisible" width="1000"> | ||||
|       <div class="w[850px] ma word-export-wrapper" ref="exportRef"> | ||||
|         <div class="w80% ma"> | ||||
|           <h2 style="text-align: center; margin-top: 5px; font-weight: bold">变更单</h2> | ||||
|           <el-row> | ||||
|             <el-col :span="12">编号:{{ tableDetail.id }}</el-col> | ||||
|           </el-row> | ||||
|           <el-descriptions :column="2" border style="margin-top: 8px" label-width="160px" size="large"> | ||||
|             <el-descriptions-item label-align="center" label="工程名称" class-name="zebra"> {{ tableDetail.projectName }} </el-descriptions-item> | ||||
|             <el-descriptions-item label-align="center" label="提出单位" class-name="zebra"> {{ tableDetail.submitUnit }} </el-descriptions-item> | ||||
|             <el-descriptions-item label-align="center" label="专业" label-class-name="white" | ||||
|               ><dict-tag :options="des_user_major" :value="tableDetail.specialty" /> | ||||
|             </el-descriptions-item> | ||||
|             <el-descriptions-item label-align="center" label="提出日期" label-class-name="white"> | ||||
|               {{ dayjs(tableDetail.submitDate).format('YYYY-MM-DD') }} | ||||
|             </el-descriptions-item> | ||||
|             <el-descriptions-item label-align="center" label="卷册名称" class-name="zebra"> {{ tableDetail.volumeName }} </el-descriptions-item> | ||||
|             <el-descriptions-item label-align="center" label="卷册号" class-name="zebra"> {{ tableDetail.volumeNumber }} </el-descriptions-item> | ||||
|             <el-descriptions-item label-align="center" label="附图" :span="2" label-class-name="white"> | ||||
|               <img :src="item.url" v-for="item in tableDetail.attachmentsImgList" alt="" style="width: 200px; height: auto" /> | ||||
|             </el-descriptions-item> | ||||
|             <el-descriptions-item label-align="center" label="变更原因" :span="2" class-name="zebra"> | ||||
|               <el-checkbox-group v-model="tableDetail.changeReasons"> | ||||
|                 <el-checkbox | ||||
|                   v-for="(item, index) in radioList" | ||||
|                   :class="index % 2 == 0 ? 'w45%' : ''" | ||||
|                   :label="item.label" | ||||
|                   :value="item.label" | ||||
|                   disabled | ||||
|                 /> | ||||
|               </el-checkbox-group> | ||||
|             </el-descriptions-item> | ||||
|             <el-descriptions-item label-align="center" label="内容" :span="2" label-class-name="white"> | ||||
|               {{ tableDetail.content }} | ||||
|             </el-descriptions-item> | ||||
|             <el-descriptions-item label-align="center" label="附件" :span="2" label-class-name="white"> | ||||
|               <el-link type="primary" :underline="false" :href="tableDetail.attachmentsList?.url" target="_blank">{{ | ||||
|                 tableDetail.attachmentsList?.originalName | ||||
|               }}</el-link> | ||||
|             </el-descriptions-item> | ||||
|             <el-descriptions-item label-align="center" label="变更费用估算" :span="2" class-name="zebra"> | ||||
|               {{ tableDetail.costEstimation }} | ||||
|             </el-descriptions-item> | ||||
|           </el-descriptions> | ||||
|           <el-descriptions border direction="vertical" size="large"> | ||||
|             <el-descriptions-item label-align="center" label="施工承包单位" class-name="none"></el-descriptions-item> | ||||
|           </el-descriptions> | ||||
|           <el-descriptions :column="2" border label-width="160px" size="large"> | ||||
|             <el-descriptions-item label-align="center" label="项目经理 " label-class-name="white"> | ||||
|               {{ tableDetail.contractorLeader }} | ||||
|             </el-descriptions-item> | ||||
|             <el-descriptions-item label-align="center" label="日期" label-class-name="white"> | ||||
|               {{ dayjs(tableDetail.contractorDate).format('YYYY-MM-DD') }} | ||||
|             </el-descriptions-item> | ||||
|           </el-descriptions> | ||||
|           <!-- <el-descriptions border direction="vertical" size="large"> | ||||
|             <el-descriptions-item label-align="center" label="总承包单位" class-name="none"></el-descriptions-item> | ||||
|           </el-descriptions> | ||||
|           <el-descriptions :column="2" border label-width="160px" size="large"> | ||||
|             <el-descriptions-item label-align="center" label="项目技术负责人" label-class-name="white">{{ | ||||
|               tableDetail.bsupervisorLeader | ||||
|             }}</el-descriptions-item> | ||||
|             <el-descriptions-item label-align="center" label="日期" label-class-name="white"> | ||||
|               {{ dayjs(tableDetail.bsupervisorDate).format('YYYY-MM-DD') }} | ||||
|             </el-descriptions-item> | ||||
|           </el-descriptions> | ||||
|           <el-descriptions border direction="vertical" size="large"> | ||||
|             <el-descriptions-item label-align="center" label="设计单位" class-name="none"></el-descriptions-item> | ||||
|           </el-descriptions> | ||||
|           <el-descriptions :column="2" border label-width="160px" size="large"> | ||||
|             <el-descriptions-item label-align="center" label="设计代表" label-class-name="white">{{ | ||||
|               tableDetail.csupervisorLeader | ||||
|             }}</el-descriptions-item> | ||||
|             <el-descriptions-item label-align="center" label="日期" label-class-name="white"> | ||||
|               {{ dayjs(tableDetail.csupervisorDate).format('YYYY-MM-DD') }} | ||||
|             </el-descriptions-item> | ||||
|           </el-descriptions> --> | ||||
|           <el-descriptions border direction="vertical" size="large"> | ||||
|             <el-descriptions-item label-align="center" label="项目监理单位" class-name="none"></el-descriptions-item> | ||||
|           </el-descriptions> | ||||
|  | ||||
|           <!-- 单独插入整行占用的内容 --> | ||||
|           <el-descriptions :column="2" border label-width="160px" size="large"> | ||||
|             <el-descriptions-item label="总监理工程师" label-align="center" label-class-name="white"> | ||||
|               {{ tableDetail.supervisorLeader }} | ||||
|             </el-descriptions-item> | ||||
|             <el-descriptions-item label="日期" label-align="center" label-class-name="white"> | ||||
|               {{ dayjs(tableDetail.supervisorDate).format('YYYY-MM-DD') }} | ||||
|             </el-descriptions-item> | ||||
|           </el-descriptions> | ||||
|           <!-- 一组完整两列 --> | ||||
|           <!-- <el-descriptions :column="2" border label-width="160px" size="large"> | ||||
|              <el-descriptions-item label="监理工程师" label-align="center" label-class-name="white"> | ||||
|               {{ tableDetail.dsupervisorLeader }} | ||||
|             </el-descriptions-item>  | ||||
|             <el-descriptions-item label="日期" label-align="center" label-class-name="white"> | ||||
|               {{ dayjs(tableDetail.supervisorDate).format('YYYY-MM-DD') }} | ||||
|             </el-descriptions-item> | ||||
|           </el-descriptions> --> | ||||
|           <el-descriptions border direction="vertical" size="large"> | ||||
|             <el-descriptions-item label-align="center" label="建设单位" class-name="none"></el-descriptions-item> | ||||
|           </el-descriptions> | ||||
|           <el-descriptions :column="2" border label-width="160px" size="large"> | ||||
|             <!-- <el-descriptions-item label-align="center" label="会签" :span="2" label-class-name="white"> {{ tableDetail.esupervisorLeader }} </el-descriptions-item> --> | ||||
|             <el-descriptions-item label-align="center" label="负责人" label-class-name="white"> | ||||
|               {{ tableDetail.ownerRep }} | ||||
|             </el-descriptions-item> | ||||
|             <el-descriptions-item label-align="center" label="日期" label-class-name="white"> | ||||
|               {{ dayjs(tableDetail.ownerDate).format('YYYY-MM-DD') }} | ||||
|             </el-descriptions-item> | ||||
|           </el-descriptions> | ||||
|         </div> | ||||
|         <div class="dialog-footer"> | ||||
|           <div class="btn-item" @click="handleDownload"> | ||||
|             <img src="@/assets/icons/svg/derived.png" /> | ||||
|             <span>下载</span> | ||||
|           </div> | ||||
|         </div> | ||||
|       </div> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script lang="ts" setup> | ||||
| import { listByIds } from '@/api/system/oss'; | ||||
| import { dayjs } from 'element-plus'; | ||||
| import { saveAs } from 'file-saver'; | ||||
| const { proxy } = getCurrentInstance() as ComponentInternalInstance; | ||||
| const { wf_business_status } = toRefs<any>(proxy?.useDict('wf_business_status')); | ||||
| const props = defineProps({ | ||||
|   data: { | ||||
|     type: Array, | ||||
|     default: () => [] | ||||
|   }, | ||||
|   thumbnail: { | ||||
|     type: String, | ||||
|     default: '' | ||||
|   } | ||||
| }); | ||||
|  | ||||
| const tableDetail = ref<any>({ attachmentsImgList: [], attachmentsList: [] }); | ||||
|  | ||||
| const exportRef = ref<HTMLElement>(); | ||||
| const radioList = ref([ | ||||
|   { value: 0, label: '设计漏项' }, | ||||
|   { value: 1, label: '设计改进' }, | ||||
|   { value: 2, label: '设计差错' }, | ||||
|   { value: 3, label: '接口差错' }, | ||||
|   { value: 4, label: '业主要求' }, | ||||
|   { value: 5, label: '施工承包商要求' }, | ||||
|   { value: 6, label: '外部资料与最终情况不符' }, | ||||
|   { value: 7, label: '材料代用及其他' } | ||||
| ]); | ||||
| const detailVisible = ref(false); | ||||
| const formatDate = (val: string | Date) => (val ? dayjs(val).format('YYYY-MM-DD') : ''); | ||||
| const { des_user_major } = toRefs<any>(proxy?.useDict('des_user_major')); | ||||
|  | ||||
| const handleDetail = async (row) => { | ||||
|   tableDetail.value = { ...row }; | ||||
|  | ||||
|   if (row.attachmentsImg) { | ||||
|     const res = await listByIds(row.attachmentsImg); | ||||
|     tableDetail.value.attachmentsImgList = res.data; | ||||
|   } | ||||
|   if (row.attachments) { | ||||
|     const res = await listByIds(row.attachments); | ||||
|     tableDetail.value.attachmentsList = res.data[0]; | ||||
|   } | ||||
|  | ||||
|   // tableDetail.value = { | ||||
|   //   ...row, | ||||
|   //   hasAttachmentList: res.data | ||||
|   // }; | ||||
|   detailVisible.value = true; | ||||
| }; | ||||
| /** 多选框选中数据 */ | ||||
| const emit = defineEmits(['selection-change', 'delete']); | ||||
| const handleSelectionChange = (selection: any) => { | ||||
|   emit('selection-change', selection); | ||||
| }; | ||||
| const handleDelete = (row) => { | ||||
|   emit('delete', row.id); | ||||
| }; | ||||
| const handleUpdate = (row) => { | ||||
|   // 添加审批 | ||||
|   proxy.$tab.closePage(proxy.$route); | ||||
|   proxy.$router.push({ | ||||
|     path: `/approval/changeContact/indexEdit`, | ||||
|     query: { | ||||
|       thumbnailUrl: props.thumbnail, | ||||
|       row: JSON.stringify(row), | ||||
|       id: row.id, | ||||
|       type: 'update' | ||||
|     } | ||||
|   }); | ||||
| }; | ||||
| const handleViewInfo = (row) => { | ||||
|   // 添加审批 | ||||
|   proxy.$tab.closePage(proxy.$route); | ||||
|   proxy.$router.push({ | ||||
|     path: `/approval/changeContact/indexEdit`, | ||||
|     query: { | ||||
|       thumbnailUrl: props.thumbnail, | ||||
|       row: JSON.stringify(row), | ||||
|       id: row.id, | ||||
|       type: 'view' | ||||
|     } | ||||
|   }); | ||||
| }; | ||||
| const handleDownload = async () => { | ||||
|   const style = ` | ||||
|     <style> | ||||
|       .white { background: #fff !important; } | ||||
|       .none { display: none !important; } | ||||
|       .zebra { background: #f5f7fa !important; } | ||||
|       .el-descriptions__table { table-layout: fixed !important; } | ||||
|       table { border-collapse: collapse; width: 100%; } | ||||
|       th, td { border: 1px solid #333; padding: 6px; font-size: 14px; } | ||||
|     </style> | ||||
|   `; | ||||
|  | ||||
|   const el = exportRef.value; | ||||
|   if (!el) return; | ||||
|  | ||||
|   // 拷贝 DOM,避免影响原内容 | ||||
|   const clone = el.cloneNode(true) as HTMLElement; | ||||
|  | ||||
|   // 删除 .dialog-footer | ||||
|   const footer = clone.querySelector('.dialog-footer'); | ||||
|   if (footer) { | ||||
|     footer.remove(); | ||||
|   } | ||||
|  | ||||
|   // 工具函数:图片转成指定宽度的 base64 | ||||
|   const resizeImageToBase64 = (img: HTMLImageElement, maxWidth = 500) => { | ||||
|     return new Promise<string>((resolve) => { | ||||
|       const image = new Image(); | ||||
|       image.crossOrigin = 'anonymous'; | ||||
|       image.src = img.src; | ||||
|       image.onload = () => { | ||||
|         const scale = Math.min(1, maxWidth / image.naturalWidth); | ||||
|         const canvas = document.createElement('canvas'); | ||||
|         canvas.width = image.naturalWidth * scale; | ||||
|         canvas.height = image.naturalHeight * scale; | ||||
|         const ctx = canvas.getContext('2d'); | ||||
|         ctx!.drawImage(image, 0, 0, canvas.width, canvas.height); | ||||
|         resolve(canvas.toDataURL('image/png')); | ||||
|       }; | ||||
|       image.onerror = () => { | ||||
|         resolve(img.src); // 如果加载失败就用原地址 | ||||
|       }; | ||||
|     }); | ||||
|   }; | ||||
|  | ||||
|   // 找到所有图片并替换成 base64(顺序执行以避免并发问题) | ||||
|   const imgs = Array.from(clone.querySelectorAll('img')); | ||||
|   for (let img of imgs) { | ||||
|     const base64 = await resizeImageToBase64(img, 200); | ||||
|     img.src = base64; | ||||
|   } | ||||
|  | ||||
|   // 应用表格的内联样式 | ||||
|   applyInlineTableStyles(clone); | ||||
|  | ||||
|   // 拼接 HTML | ||||
|   const html = ` | ||||
|     <html> | ||||
|       <head> | ||||
|         <meta charset="utf-8"> | ||||
|         ${style} | ||||
|       </head> | ||||
|       <body> | ||||
|         ${clone.innerHTML} | ||||
|       </body> | ||||
|     </html> | ||||
|   `; | ||||
|  | ||||
|   const blob = (window as any).htmlDocx.asBlob(html); | ||||
|   saveAs(blob, '变更单.docx'); | ||||
| }; | ||||
|  | ||||
| const applyInlineTableStyles = (rootEl: HTMLElement) => { | ||||
|   rootEl.querySelectorAll('table').forEach((table) => { | ||||
|     table.setAttribute('style', 'width:100%; border-collapse:collapse; table-layout:fixed; border:1px solid #333;'); | ||||
|   }); | ||||
|  | ||||
|   rootEl.querySelectorAll('th, td').forEach((cell) => { | ||||
|     cell.setAttribute('style', 'border:1px solid #333; padding:6px; font-size:14px; word-break:break-all;'); | ||||
|   }); | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style lang="scss" scoped> | ||||
| :deep(.white) { | ||||
|   background: #fff !important; | ||||
| } | ||||
|  | ||||
| :deep(.none) { | ||||
|   display: none !important; | ||||
| } | ||||
|  | ||||
| :deep(.zebra) { | ||||
|   background: #f5f7fa; | ||||
| } | ||||
| :deep(.el-descriptions__table) { | ||||
|   table-layout: fixed !important; | ||||
| } | ||||
| .word-export-wrapper { | ||||
|   table { | ||||
|     width: 100% !important; | ||||
|     border-collapse: collapse; | ||||
|     table-layout: fixed; | ||||
|     word-break: break-all; | ||||
|   } | ||||
|  | ||||
|   th, | ||||
|   td { | ||||
|     border: 1px solid #333; | ||||
|     padding: 8px; | ||||
|     font-size: 14px; | ||||
|     text-align: left; | ||||
|     vertical-align: middle; | ||||
|   } | ||||
|  | ||||
|   /* 确保不超出 Word 页边距 */ | ||||
|   margin: 0 auto; | ||||
|   max-width: 100%; | ||||
|   overflow: hidden; | ||||
| } | ||||
|  | ||||
| .el-descriptions__label { | ||||
|   font-weight: bold; | ||||
|   background-color: #f2f2f2; | ||||
| } | ||||
| .dialog-footer { | ||||
|   height: 100px; | ||||
|   display: flex; | ||||
|  | ||||
|   flex-direction: column; | ||||
|   justify-content: space-between; | ||||
|   position: absolute; | ||||
|   top: 14%; | ||||
|   right: 6%; | ||||
|   background: #fff; | ||||
|   box-shadow: 0 0 10px #ddd; | ||||
|   text-align: center; | ||||
|   padding: 20px 10px; | ||||
|  | ||||
|   .btn-item { | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     justify-content: center; | ||||
|     cursor: pointer; | ||||
|     img { | ||||
|       transform: rotateZ(180deg); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| </style> | ||||
							
								
								
									
										279
									
								
								src/views/design/shijibiangeng/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										279
									
								
								src/views/design/shijibiangeng/index.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,279 @@ | ||||
| <template> | ||||
|   <div class="p-2"> | ||||
|     <el-card shadow="never"> | ||||
|       <template #header> | ||||
|         <el-row :gutter="10" class="mb8"> | ||||
|           <el-col :span="1.5"> | ||||
|             <el-button type="primary" plain icon="Plus" :disabled="addSingle" @click="handleAddApp" v-hasPermi="['quality:qualityInspection:add']" | ||||
|               >上传设计变更单</el-button | ||||
|             > | ||||
|           </el-col> | ||||
|           <right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar> | ||||
|         </el-row> | ||||
|       </template> | ||||
|       <EngineeringChangeApplicationForm | ||||
|         @selection-change="handleSelectionChange" | ||||
|         :data="tableData" | ||||
|         :thumbnail="projectTypeOptions[1].thumbnail" | ||||
|         @delete="handleDelete" | ||||
|       ></EngineeringChangeApplicationForm> | ||||
|       <pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" @pagination="getList" /> | ||||
|     </el-card> | ||||
|     <el-dialog title="新增模板" v-model="dialogVisible" width="800"> | ||||
|       <el-form :model="form" :rules="rules" ref="formRef" label-width="110px"> | ||||
|         <div class="flex"> | ||||
|           <div><image-preview :src="thumbnailUrl" width="150px"></image-preview></div> | ||||
|           <div> | ||||
|             <el-form-item label="工程名称" prop="projectName"> | ||||
|               <el-input v-model="form.projectName" placeholder="请输入工程名称" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="编号" prop="serialNumber"> | ||||
|               <el-input v-model="form.serialNumber" placeholder="请输入编号" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="致" prop="to"> | ||||
|               <el-input v-model="form.to" placeholder="致:" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="主题" prop="subject"> | ||||
|               <el-input v-model="form.subject" placeholder="请输入主题" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="内容" prop="content"> | ||||
|               <el-input v-model="form.content" type="textarea" :rows="6" placeholder="请输入内容" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="附件" prop="attachments"> | ||||
|               <file-upload v-model="form.attachments" :limit="1" :file-type="['pdf', 'png', 'jpg', 'jpeg', 'gif', 'bmp']"></file-upload> | ||||
|             </el-form-item> | ||||
|             <el-divider class="mb-10! mt-10!">施工项目部</el-divider> | ||||
|             <el-form-item label="项目负责人" prop="contractorLeader"> | ||||
|               <el-input v-model="form.contractorLeader" placeholder="请输入负责人姓名" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="日期" prop="contractorDate"> | ||||
|               <el-date-picker v-model="form.contractorDate" type="date" placeholder="选择日期" style="width: 100%" /> | ||||
|             </el-form-item> | ||||
|             <el-divider class="mb-10! mt-10!">项目监理机构</el-divider> | ||||
|  | ||||
|             <el-form-item label="总监理工程师" prop="supervisorLeader"> | ||||
|               <el-input v-model="form.supervisorLeader" placeholder="请输入总监理工程师姓名" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="日期" prop="supervisorDate"> | ||||
|               <el-date-picker v-model="form.supervisorDate" type="date" placeholder="选择日期" style="width: 100%" /> | ||||
|             </el-form-item> | ||||
|             <el-divider class="mb-10! mt-10!">建设单位</el-divider> | ||||
|             <el-form-item label="业主代表" prop="ownerRep"> | ||||
|               <el-input v-model="form.ownerRep" placeholder="请输入业主代表" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="日期" prop="ownerDate"> | ||||
|               <el-date-picker v-model="form.ownerDate" type="date" placeholder="选择日期" style="width: 100%" /> | ||||
|             </el-form-item> | ||||
|           </div> | ||||
|         </div> | ||||
|       </el-form> | ||||
|       <template #footer> | ||||
|         <span> | ||||
|           <el-button @click="dialogVisible = false">取消</el-button> | ||||
|           <el-button type="primary" @click="submitForm">确定</el-button> | ||||
|         </span> | ||||
|       </template> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script setup lang="ts"> | ||||
| import { useUserStoreHook } from '@/store/modules/user'; | ||||
| import type { FormInstance, FormRules } from 'element-plus'; | ||||
| import EngineeringChangeApplicationForm from './components/engineeringChangeApplicationForm.vue'; | ||||
| import { listContactTypeformtemplate } from '@/api/cory/contactformtemplate'; | ||||
| import { addContactnotice, delContactnotice, listContactnotice } from '@/api/cory/contactnotice'; | ||||
|  | ||||
| const { proxy } = getCurrentInstance() as ComponentInternalInstance; | ||||
| const { wf_business_status } = toRefs(proxy?.useDict('wf_business_status')); | ||||
| // 获取用户 store | ||||
| const userStore = useUserStoreHook(); | ||||
| // 从 store 中获取项目列表和当前选中的项目 | ||||
| const currentProject = computed(() => userStore.selectedProject); | ||||
| const thumbnailUrl = ref(''); | ||||
| const tableData = ref([]); | ||||
| const total = ref(0); | ||||
| const activeName = ref('1'); | ||||
| const formRef = ref<FormInstance>(); | ||||
| const dialogVisible = ref<boolean>(false); | ||||
| const showSearch = ref(true); | ||||
| const multiple = ref<boolean>(true); | ||||
| const addSingle = ref<boolean>(false); | ||||
| const single = ref<boolean>(true); | ||||
| const ids = ref<Array<string | number>>([]); | ||||
|  | ||||
| const projectTypeOptions = ref<any>([ | ||||
|   { | ||||
|     value: '0', | ||||
|     label: '外部联系单' | ||||
|   }, | ||||
|   { | ||||
|     value: '1', | ||||
|     label: '变更单' | ||||
|   }, | ||||
|   { | ||||
|     value: '2', | ||||
|     label: '通知单' | ||||
|   }, | ||||
|   { | ||||
|     value: '3', | ||||
|     label: '回复单' | ||||
|   }, | ||||
|   { | ||||
|     value: '4', | ||||
|     label: '签证单' | ||||
|   } | ||||
| ]); | ||||
|  | ||||
| const initFormData = { | ||||
|   projectType: '', | ||||
|   projectName: '', | ||||
|   serialNumber: '', | ||||
|   to: '', | ||||
|   subject: '', | ||||
|   content: '', | ||||
|   attachments: '', | ||||
|   contractorLeader: '', | ||||
|   contractorDate: '', | ||||
|   supervisorLeader: '', | ||||
|   supervisorDate: '', | ||||
|   ownerRep: '', | ||||
|   ownerDate: '', | ||||
|   unitName: '', | ||||
|   profession: '', | ||||
|   applyDate: '', | ||||
|   bookName: '', | ||||
|   bookNo: '', | ||||
|   hasAttachment: '', | ||||
|   changeReasons: [], | ||||
|   changeContent: '', | ||||
|   costEstimate: '' | ||||
| }; | ||||
| const data = reactive<PageData<any, any>>({ | ||||
|   form: { ...initFormData }, | ||||
|   queryParams: { | ||||
|     pageNum: 1, | ||||
|     pageSize: 10, | ||||
|     projectId: currentProject.value?.id, | ||||
|     inspectionType: undefined, | ||||
|     inspectionStatus: undefined, | ||||
|     teamId: undefined, | ||||
|     type: undefined, | ||||
|     params: {}, | ||||
|     // ids: ['1942107830848872449', '1942107931415699457'], | ||||
|     projectType: undefined | ||||
|   }, | ||||
|   rules: { | ||||
|     projectName: [{ required: true, message: '请输入工程名称', trigger: 'blur' }], | ||||
|     projectType: [{ required: true, message: '请选择模板类型', trigger: 'blur' }], | ||||
|     serialNumber: [{ required: true, message: '请输入编号', trigger: 'blur' }], | ||||
|     to: [{ required: true, message: '请输入接收方', trigger: 'blur' }], | ||||
|     subject: [{ required: true, message: '请输入主题', trigger: 'blur' }], | ||||
|     content: [{ required: true, message: '请输入内容', trigger: 'blur' }] | ||||
|   } | ||||
| }); | ||||
|  | ||||
| const { queryParams, form, rules } = toRefs(data); | ||||
|  | ||||
| const submitForm = () => { | ||||
|   formRef.value?.validate(async (valid) => { | ||||
|     if (valid) { | ||||
|       let data = { | ||||
|         type: queryParams.value.type, | ||||
|         projectId: currentProject.value?.id, | ||||
|         detail: JSON.stringify(form.value) | ||||
|       }; | ||||
|       console.log('提交表单:', form); | ||||
|       const res = await addContactnotice(data); | ||||
|       if (res.code == 200) { | ||||
|         proxy.$modal.msgSuccess('添加成功'); | ||||
|         dialogVisible.value = false; | ||||
|         formRef.value.resetFields(); | ||||
|         getList(); | ||||
|       } | ||||
|     } | ||||
|   }); | ||||
| }; | ||||
|  | ||||
| const handleAdd = () => { | ||||
|   dialogVisible.value = true; | ||||
| }; | ||||
|  | ||||
| const getList = async () => { | ||||
|   if (!queryParams.value.projectType) { | ||||
|     const res = await listContactTypeformtemplate(queryParams.value); | ||||
|     projectTypeOptions.value = res.data; | ||||
|     queryParams.value.projectType = res.data[1].name; | ||||
|     thumbnailUrl.value = res.data[1].thumbnail; | ||||
|     queryParams.value.type = res.data[1].id as string; | ||||
|   } | ||||
|   const res = await listContactnotice(queryParams.value); | ||||
|   res.rows = res.rows.map((item) => { | ||||
|     return { | ||||
|       ...item, | ||||
|       ...JSON.parse(item.detail), | ||||
|       status: item.status | ||||
|     }; | ||||
|   }); | ||||
|   tableData.value = res.rows; | ||||
|   console.log('🚀 ~ getList ~ tableData.value:', tableData.value); | ||||
|   total.value = res.total || 0; | ||||
| }; | ||||
| const handleDelete = async (id?: string) => { | ||||
|   const _ids = id || ids.value; | ||||
|   await proxy?.$modal.confirm('是否确认删除识别记录编号为"' + _ids + '"的数据项?').finally(); | ||||
|   const res = await delContactnotice(_ids); | ||||
|   if (res.code == 200) { | ||||
|     proxy.$modal.msgSuccess('删除成功'); | ||||
|     getList(); | ||||
|   } | ||||
| }; | ||||
| /** 多选框选中数据 */ | ||||
| const handleSelectionChange = (selection: any) => { | ||||
|   ids.value = selection.map((item) => item.id); | ||||
|   single.value = selection.length != 1; | ||||
|   multiple.value = !selection.length; | ||||
| }; | ||||
|  | ||||
| const selectType = (value: string) => { | ||||
|   queryParams.value.projectType = value; | ||||
|   thumbnailUrl.value = projectTypeOptions.value.filter((item) => item.name == value)[0].thumbnail; | ||||
|   queryParams.value.type = projectTypeOptions.value.filter((item) => item.name == value)[0].id; | ||||
|   getList(); | ||||
| }; | ||||
|  | ||||
| const handleClick = (val) => { | ||||
|   console.log(val); | ||||
|   queryParams.value.projectType = val.props.name; | ||||
|   getList(); | ||||
| }; | ||||
| const handleAddApp = (row) => { | ||||
|   // 添加审批 | ||||
|   proxy.$tab.closePage(proxy.$route); | ||||
|   proxy.$router.push({ | ||||
|     path: `/approval/changeContact/indexEdit`, | ||||
|     query: { | ||||
|       thumbnailUrl: projectTypeOptions.value[1].thumbnail, | ||||
|       id: projectTypeOptions.value[1].id, | ||||
|       row, | ||||
|       type: 'add' | ||||
|     } | ||||
|   }); | ||||
| }; | ||||
| onMounted(() => { | ||||
|   getList(); | ||||
| }); | ||||
|  | ||||
| //监听项目id刷新数据 | ||||
| const listeningProject = watch( | ||||
|   () => currentProject.value?.id, | ||||
|   (nid, oid) => { | ||||
|     queryParams.value.projectId = nid; | ||||
|     getList(); | ||||
|   } | ||||
| ); | ||||
|  | ||||
| onUnmounted(() => { | ||||
|   listeningProject(); | ||||
| }); | ||||
| </script> | ||||
| @ -10,6 +10,13 @@ | ||||
|             <el-form-item label="资料名称" prop="documentName"> | ||||
|               <el-input v-model="queryParams.documentName" placeholder="请输入资料名称" clearable @keyup.enter="handleQuery" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="是否文件上传" prop="isUpload" label-width="110px"> | ||||
|               <el-select v-model="queryParams.isUpload" placeholder="请选择" clearable @keyup.enter="handleQuery"> | ||||
|                 <el-option value="1" label="是" /> | ||||
|                 <el-option value="0" label="否" /> | ||||
|                 <el-option value="2" label="全部" /> | ||||
|               </el-select> | ||||
|             </el-form-item> | ||||
|             <el-form-item> | ||||
|               <el-button type="primary" icon="Search" @click="handleQuery" v-hasPermi="['design:volumeCatalog:query']">搜索</el-button> | ||||
|               <el-button icon="Refresh" @click="resetQuery" v-hasPermi="['design:volumeCatalog:query']">重置</el-button> | ||||
| @ -154,14 +161,14 @@ | ||||
|         <el-form-item v-if="uploadForm.type == '3'" label="蓝图" prop="fileIds"> | ||||
|           <file-upload :fileType="['pdf']" :isShowTip="false" :fileSize="100" v-model="uploadForm.fileIds"></file-upload> | ||||
|         </el-form-item> | ||||
|         <el-form-item v-if="uploadForm.type == '3'" label="通知人"> | ||||
|         <el-form-item v-if="uploadForm.type == '1'" label="过程图纸" prop="cancellationIds"> | ||||
|           <file-upload :fileType="['pdf']" :isShowTip="false" :fileSize="100" v-model="uploadForm.cancellationIds"></file-upload> | ||||
|         </el-form-item> | ||||
|         <el-form-item label="通知人"> | ||||
|           <el-select multiple filterable clearable v-model="form.userIds" placeholder="请选择通知人"> | ||||
|             <el-option :value="item.userId" v-for="item in userCoryList" :key="item.userId" :label="item.nickName + '-' + item.phonenumber" /> | ||||
|           </el-select> | ||||
|         </el-form-item> | ||||
|         <el-form-item v-if="uploadForm.type == '1'" label="过程图纸" prop="cancellationIds"> | ||||
|           <file-upload :fileType="['pdf']" :isShowTip="false" :fileSize="100" v-model="uploadForm.cancellationIds"></file-upload> | ||||
|         </el-form-item> | ||||
|       </el-form> | ||||
|       <span style="font-size: 12px; color: #999999">注意:请上传pdf格式文件</span> | ||||
|       <div style="display: flex; justify-content: flex-end"> | ||||
| @ -360,7 +367,8 @@ const data = reactive({ | ||||
|     designSubitemId: undefined, | ||||
|     volumeNumber: undefined, | ||||
|     documentName: undefined, | ||||
|     params: {} | ||||
|     params: {}, | ||||
|     isUpload: '2' | ||||
|   }, | ||||
|   rules: { | ||||
|     design: [{ required: true, message: '主键ID不能为空', trigger: 'blur' }], | ||||
| @ -585,7 +593,6 @@ const handleUploadSuccess = async (flieList: any, res: any) => { | ||||
| }; | ||||
| /** 审核蓝图按钮操作 */ | ||||
| const handleAuditLantu = async (row) => { | ||||
|   proxy.$tab.closePage(proxy.$route); | ||||
|   proxy.$router.push({ | ||||
|     path: `/approval/volumeCatalog/blueprintEdit`, | ||||
|     query: { | ||||
| @ -596,7 +603,6 @@ const handleAuditLantu = async (row) => { | ||||
| }; | ||||
| /** 查看蓝图按钮操作 */ | ||||
| const handleAuditViewLantu = async (row) => { | ||||
|   proxy.$tab.closePage(proxy.$route); | ||||
|   proxy.$router.push({ | ||||
|     path: `/approval/volumeCatalog/blueprintEdit`, | ||||
|     query: { | ||||
|  | ||||
| @ -82,11 +82,18 @@ | ||||
|         </el-row> | ||||
|       </template> | ||||
|  | ||||
|       <el-table v-loading="loading" :data="formalitiesAreConsolidatedList" @selection-change="handleSelectionChange" row-key="id" default-expand-all> | ||||
|       <el-table | ||||
|         v-loading="loading" | ||||
|         :table-layout="'auto'" | ||||
|         :data="formalitiesAreConsolidatedList" | ||||
|         @selection-change="handleSelectionChange" | ||||
|         row-key="id" | ||||
|         default-expand-all | ||||
|       > | ||||
|         <el-table-column type="selection" width="55" align="center" /> | ||||
|         <el-table-column label="手续办理清单" align="left" prop="formalitiesName"> | ||||
|           <template #default="scope"> | ||||
|             <span style="white-space: nowrap">{{ scope.row.formalitiesName }}</span> | ||||
|            {{ scope.row.formalitiesName }} | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|         <el-table-column label="计划开始时间" align="center" prop="planTheStartTime" width="180"> | ||||
|  | ||||
| @ -13,7 +13,7 @@ | ||||
|               <el-input v-model="queryParams.nodeName" placeholder="请输入任务名称" @keyup.enter="handleQuery" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="流程定义名称" label-width="100" prop="flowName"> | ||||
|               <el-input v-model="queryParams.flowName" placeholder="请输入流程定义名称" @keyup.enter="handleQuery" /> | ||||
|               <el-input v-model="queryParams.flowName" placeholder="请输入流程名称" @keyup.enter="handleQuery" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item> | ||||
|               <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button> | ||||
| @ -38,8 +38,7 @@ | ||||
|         <el-table v-loading="loading" border :data="taskList" @selection-change="handleSelectionChange"> | ||||
|           <el-table-column type="selection" width="55" align="center" /> | ||||
|           <el-table-column align="center" type="index" label="序号" width="60"></el-table-column> | ||||
|           <el-table-column :show-overflow-tooltip="true" prop="flowName" align="center" label="流程定义名称"></el-table-column> | ||||
|           <el-table-column align="center" prop="flowCode" label="流程定义编码"></el-table-column> | ||||
|           <el-table-column :show-overflow-tooltip="true" prop="flowName" align="center" label="流程名称"></el-table-column> | ||||
|           <el-table-column align="center" prop="categoryName" label="流程分类"></el-table-column> | ||||
|           <el-table-column align="center" prop="version" label="版本号" width="90"> | ||||
|             <template #default="scope"> v{{ scope.row.version }}.0</template> | ||||
|  | ||||
| @ -24,8 +24,13 @@ | ||||
|           <div v-show="showSearch" class="mb-[10px]"> | ||||
|             <el-card shadow="hover"> | ||||
|               <el-form v-show="showSearch" ref="queryFormRef" :model="queryParams" :inline="true" label-width="120px"> | ||||
|                 <el-form-item label="流程定义编码" prop="flowCode"> | ||||
|                   <el-input v-model="queryParams.flowCode" placeholder="请输入流程定义编码" @keyup.enter="handleQuery" /> | ||||
|                 <el-form-item label="流程名称" prop="flowName"> | ||||
|                   <el-input v-model="queryParams.flowName" placeholder="请输入流程名称" @keyup.enter="handleQuery" /> | ||||
|                 </el-form-item> | ||||
|                 <el-form-item label="项目" prop="projectId"> | ||||
|                   <el-select v-model="queryParams.projectId" placeholder="全部" clearable filterable style="width: 150px; margin-right: 20px"> | ||||
|                     <el-option v-for="project in projects" :key="project.id" :label="project.name" :value="project.id" /> | ||||
|                   </el-select> | ||||
|                 </el-form-item> | ||||
|                 <el-form-item> | ||||
|                   <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button> | ||||
| @ -43,11 +48,10 @@ | ||||
|           </template> | ||||
|  | ||||
|           <el-table v-loading="loading" border :data="processInstanceList" @selection-change="handleSelectionChange"> | ||||
|             <el-table-column type="selection" width="55" align="center" /> | ||||
|             <el-table-column align="center" type="index" label="序号" width="60"></el-table-column> | ||||
|             <el-table-column v-if="false" align="center" prop="id" label="id"></el-table-column> | ||||
|             <el-table-column :show-overflow-tooltip="true" prop="flowName" align="center" label="流程定义名称"> </el-table-column> | ||||
|             <el-table-column align="center" prop="flowCode" label="流程定义编码"></el-table-column> | ||||
|             <el-table-column :show-overflow-tooltip="true" prop="flowName" align="center" label="流程名称"> </el-table-column> | ||||
|             <!-- <el-table-column align="center" prop="flowCode" label="流程定义编码"></el-table-column> --> | ||||
|             <el-table-column align="center" prop="categoryName" label="流程分类"></el-table-column> | ||||
|             <el-table-column align="center" prop="version" label="版本号" width="90"> | ||||
|               <template #default="scope"> v{{ scope.row.version }}.0</template> | ||||
| @ -68,20 +72,18 @@ | ||||
|               <template #default="scope"> | ||||
|                 <el-row :gutter="10" class="mb8"> | ||||
|                   <el-col :span="1.5" v-if="scope.row.flowStatus === 'draft' || scope.row.flowStatus === 'cancel' || scope.row.flowStatus === 'back'"> | ||||
|                     <el-button type="primary" size="small" icon="Edit" @click="handleOpen(scope.row, 'update')">编辑</el-button> | ||||
|                     <el-button type="primary" link icon="Edit" @click="handleOpen(scope.row, 'update')">编辑</el-button> | ||||
|                   </el-col> | ||||
|                   <el-col :span="1.5" v-if="scope.row.flowStatus === 'draft' || scope.row.flowStatus === 'cancel' || scope.row.flowStatus === 'back'"> | ||||
|                     <el-button type="primary" size="small" icon="Delete" @click="handleDelete(scope.row)">删除</el-button> | ||||
|                     <el-button type="primary" link icon="Delete" @click="handleDelete(scope.row)">删除</el-button> | ||||
|                   </el-col> | ||||
|                 </el-row> | ||||
|                 <el-row :gutter="10" class="mb8"> | ||||
|                   <el-col :span="1.5"> | ||||
|                     <el-button type="primary" size="small" icon="View" @click="handleOpen(scope.row, 'view')">查看</el-button> | ||||
|                     <el-button type="primary" link icon="View" @click="handleOpen(scope.row, 'view')">查看</el-button> | ||||
|                   </el-col> | ||||
|                   <el-col :span="1.5" v-if="scope.row.flowStatus === 'waiting'"> | ||||
|                     <el-button type="primary" size="small" icon="Notification" @click="handleCancelProcessApply(scope.row.businessId)" | ||||
|                       >撤销</el-button | ||||
|                     > | ||||
|                     <el-button type="primary" link icon="Notification" @click="handleCancelProcessApply(scope.row.businessId)">撤销</el-button> | ||||
|                   </el-col> | ||||
|                 </el-row> | ||||
|               </template> | ||||
| @ -113,7 +115,12 @@ const { proxy } = getCurrentInstance() as ComponentInternalInstance; | ||||
| const { wf_business_status } = toRefs<any>(proxy?.useDict('wf_business_status')); | ||||
| const queryFormRef = ref<ElFormInstance>(); | ||||
| const categoryTreeRef = ref<ElTreeInstance>(); | ||||
|  | ||||
| import { useUserStore } from '@/store/modules/user'; | ||||
| const userStore = useUserStore(); | ||||
| const projects = computed(() => [ | ||||
|   { id: '0', name: '全部项目' }, // 添加空选项 | ||||
|   ...userStore.projects | ||||
| ]); | ||||
| // 遮罩层 | ||||
| const loading = ref(true); | ||||
| // 选中数组 | ||||
| @ -135,11 +142,13 @@ const categoryName = ref(''); | ||||
|  | ||||
| const tab = ref('running'); | ||||
| // 查询参数 | ||||
| const queryParams = ref<FlowInstanceQuery>({ | ||||
| const queryParams = ref({ | ||||
|   pageNum: 1, | ||||
|   pageSize: 10, | ||||
|   flowCode: undefined, | ||||
|   category: undefined | ||||
|   category: undefined, | ||||
|   projectId: '0', | ||||
|   flowName: undefined | ||||
| }); | ||||
|  | ||||
| onMounted(() => { | ||||
|  | ||||
| @ -7,11 +7,13 @@ | ||||
|             <el-form-item label="任务名称" prop="nodeName"> | ||||
|               <el-input v-model="queryParams.nodeName" placeholder="请输入任务名称" @keyup.enter="handleQuery" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="流程定义名称" label-width="100" prop="flowName"> | ||||
|               <el-input v-model="queryParams.flowName" placeholder="请输入流程定义名称" @keyup.enter="handleQuery" /> | ||||
|             <el-form-item label="流程名称" label-width="100" prop="flowName"> | ||||
|               <el-input v-model="queryParams.flowName" placeholder="请输入流程名称" @keyup.enter="handleQuery" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="流程定义编码" label-width="100" prop="flowCode"> | ||||
|               <el-input v-model="queryParams.flowCode" placeholder="请输入流程定义编码" @keyup.enter="handleQuery" /> | ||||
|             <el-form-item label="项目" prop="projectId"> | ||||
|               <el-select v-model="queryParams.projectId" placeholder="全部" clearable filterable style="width: 150px; margin-right: 20px"> | ||||
|                 <el-option v-for="project in projects" :key="project.id" :label="project.name" :value="project.id" /> | ||||
|               </el-select> | ||||
|             </el-form-item> | ||||
|             <el-form-item> | ||||
|               <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button> | ||||
| @ -31,8 +33,7 @@ | ||||
|       <el-table v-loading="loading" border :data="taskList" @selection-change="handleSelectionChange"> | ||||
|         <el-table-column type="selection" width="55" align="center" /> | ||||
|         <el-table-column align="center" type="index" label="序号" width="60"></el-table-column> | ||||
|         <el-table-column :show-overflow-tooltip="true" prop="flowName" align="center" label="流程定义名称"></el-table-column> | ||||
|         <el-table-column align="center" prop="flowCode" label="流程定义编码"></el-table-column> | ||||
|         <el-table-column :show-overflow-tooltip="true" prop="flowName" align="center" label="流程名称"></el-table-column> | ||||
|         <el-table-column align="center" prop="categoryName" label="流程分类"></el-table-column> | ||||
|         <el-table-column align="center" prop="nodeName" label="任务名称"></el-table-column> | ||||
|         <el-table-column align="center" label="流程状态" min-width="70"> | ||||
| @ -43,7 +44,7 @@ | ||||
|         <el-table-column align="center" prop="updateTime" label="更新时间" width="150"></el-table-column> | ||||
|         <el-table-column label="操作" align="center" width="200"> | ||||
|           <template #default="scope"> | ||||
|             <el-button type="primary" size="small" icon="View" @click="handleView(scope.row)">查看</el-button> | ||||
|             <el-button type="primary"  icon="View" @click="handleView(scope.row)">查看</el-button> | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|       </el-table> | ||||
| @ -64,6 +65,12 @@ import { TaskQuery } from '@/api/workflow/task/types'; | ||||
| import workflowCommon from '@/api/workflow/workflowCommon'; | ||||
| import { RouterJumpVo } from '@/api/workflow/workflowCommon/types'; | ||||
| //审批记录组件 | ||||
| import { useUserStore } from '@/store/modules/user'; | ||||
| const userStore = useUserStore(); | ||||
| const projects = computed(() => [ | ||||
|   { id: '0', name: '全部项目' }, // 添加空选项 | ||||
|   ...userStore.projects | ||||
| ]); | ||||
| const queryFormRef = ref<ElFormInstance>(); | ||||
| const { proxy } = getCurrentInstance() as ComponentInternalInstance; | ||||
| const { wf_business_status } = toRefs<any>(proxy?.useDict('wf_business_status')); | ||||
| @ -82,8 +89,9 @@ const total = ref(0); | ||||
| // 模型定义表格数据 | ||||
| const taskList = ref([]); | ||||
| // 查询参数 | ||||
| const queryParams = ref<TaskQuery>({ | ||||
| const queryParams = ref({ | ||||
|   pageNum: 1, | ||||
|   projectId: '0', | ||||
|   pageSize: 10, | ||||
|   nodeName: undefined, | ||||
|   flowName: undefined, | ||||
|  | ||||
| @ -4,19 +4,21 @@ | ||||
|       <div v-show="showSearch" class="mb-[10px]"> | ||||
|         <el-card shadow="hover"> | ||||
|           <el-form v-show="showSearch" ref="queryFormRef" :model="queryParams" :inline="true"> | ||||
|             <el-form-item> | ||||
|             <!-- <el-form-item> | ||||
|               <el-badge :value="userSelectCount" :max="10" class="item"> | ||||
|                 <el-button type="primary" @click="openUserSelect">选择申请人</el-button> | ||||
|               </el-badge> | ||||
|             </el-form-item> | ||||
|             </el-form-item> --> | ||||
|             <el-form-item label="任务名称" prop="nodeName"> | ||||
|               <el-input v-model="queryParams.nodeName" placeholder="请输入任务名称" @keyup.enter="handleQuery" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="流程定义名称" label-width="100" prop="flowName"> | ||||
|               <el-input v-model="queryParams.flowName" placeholder="请输入流程定义名称" @keyup.enter="handleQuery" /> | ||||
|             <el-form-item label="流程名称" label-width="100" prop="flowName"> | ||||
|               <el-input v-model="queryParams.flowName" placeholder="请输入流程名称" @keyup.enter="handleQuery" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="流程定义编码" label-width="100" prop="flowCode"> | ||||
|               <el-input v-model="queryParams.flowCode" placeholder="请输入流程定义编码" @keyup.enter="handleQuery" /> | ||||
|             <el-form-item label="项目" prop="projectId"> | ||||
|               <el-select v-model="queryParams.projectId" placeholder="全部" clearable filterable style="width: 150px; margin-right: 20px"> | ||||
|                 <el-option v-for="project in projects" :key="project.id" :label="project.name" :value="project.id" /> | ||||
|               </el-select> | ||||
|             </el-form-item> | ||||
|             <el-form-item> | ||||
|               <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button> | ||||
| @ -34,10 +36,8 @@ | ||||
|       </template> | ||||
|  | ||||
|       <el-table v-loading="loading" border :data="taskList" @selection-change="handleSelectionChange"> | ||||
|         <el-table-column type="selection" width="55" align="center" /> | ||||
|         <el-table-column align="center" type="index" label="序号" width="60"></el-table-column> | ||||
|         <el-table-column align="center" prop="flowName" label="流程定义名称"></el-table-column> | ||||
|         <el-table-column align="center" prop="flowCode" label="流程定义编码"></el-table-column> | ||||
|         <el-table-column align="center" prop="flowName" label="流程名称"></el-table-column> | ||||
|         <el-table-column align="center" prop="categoryName" label="流程分类"></el-table-column> | ||||
|         <el-table-column align="center" prop="version" label="版本号" width="90"> | ||||
|           <template #default="scope"> v{{ scope.row.version }}.0</template> | ||||
| @ -64,7 +64,7 @@ | ||||
|         <el-table-column align="center" prop="createTime" label="创建时间" width="160"></el-table-column> | ||||
|         <el-table-column label="操作" align="center" width="200"> | ||||
|           <template #default="scope"> | ||||
|             <el-button type="primary" size="small" icon="View" @click="handleView(scope.row)">查看</el-button> | ||||
|             <el-button type="primary" link  icon="View" @click="handleView(scope.row)">查看</el-button> | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|       </el-table> | ||||
| @ -94,7 +94,12 @@ const { wf_task_status } = toRefs<any>(proxy?.useDict('wf_task_status')); | ||||
| import UserSelect from '@/components/UserSelect'; | ||||
| import { ref } from 'vue'; | ||||
| import { UserVO } from '@/api/system/user/types'; | ||||
|  | ||||
| import { useUserStore } from '@/store/modules/user'; | ||||
| const userStore = useUserStore(); | ||||
| const projects = computed(() => [ | ||||
|   { id: '0', name: '全部项目' }, // 添加空选项 | ||||
|   ...userStore.projects | ||||
| ]); | ||||
| const userSelectRef = ref<InstanceType<typeof UserSelect>>(); | ||||
| // 遮罩层 | ||||
| const loading = ref(true); | ||||
| @ -111,11 +116,12 @@ const total = ref(0); | ||||
| // 模型定义表格数据 | ||||
| const taskList = ref([]); | ||||
| // 查询参数 | ||||
| const queryParams = ref<TaskQuery>({ | ||||
| const queryParams = ref({ | ||||
|   pageNum: 1, | ||||
|   pageSize: 10, | ||||
|   nodeName: undefined, | ||||
|   flowName: undefined, | ||||
|   projectId: '0', | ||||
|   flowCode: undefined, | ||||
|   createByIds: [] | ||||
| }); | ||||
|  | ||||
| @ -12,11 +12,13 @@ | ||||
|             <el-form-item label="任务名称" prop="nodeName"> | ||||
|               <el-input v-model="queryParams.nodeName" placeholder="请输入任务名称" @keyup.enter="handleQuery" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="流程定义名称" label-width="100" prop="flowName"> | ||||
|               <el-input v-model="queryParams.flowName" placeholder="请输入流程定义名称" @keyup.enter="handleQuery" /> | ||||
|             <el-form-item label="流程名称" label-width="100" prop="flowName"> | ||||
|               <el-input v-model="queryParams.flowName" placeholder="请输入流程名称" @keyup.enter="handleQuery" /> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="流程定义编码" label-width="100" prop="flowCode"> | ||||
|               <el-input v-model="queryParams.flowCode" placeholder="请输入流程定义编码" @keyup.enter="handleQuery" /> | ||||
|             <el-form-item label="项目" prop="projectId"> | ||||
|               <el-select v-model="queryParams.projectId" placeholder="全部" clearable filterable style="width: 150px; margin-right: 20px"> | ||||
|                 <el-option v-for="project in projects" :key="project.id" :label="project.name" :value="project.id" /> | ||||
|               </el-select> | ||||
|             </el-form-item> | ||||
|             <el-form-item> | ||||
|               <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button> | ||||
| @ -33,10 +35,8 @@ | ||||
|         </el-row> | ||||
|       </template> | ||||
|       <el-table v-loading="loading" border :data="taskList" @selection-change="handleSelectionChange"> | ||||
|         <el-table-column type="selection" width="55" align="center" /> | ||||
|         <el-table-column align="center" type="index" label="序号" width="60"></el-table-column> | ||||
|         <el-table-column :show-overflow-tooltip="true" prop="flowName" align="center" label="流程定义名称"></el-table-column> | ||||
|         <el-table-column align="center" prop="flowCode" label="流程定义编码"></el-table-column> | ||||
|         <el-table-column :show-overflow-tooltip="true" prop="flowName" align="center" label="流程名称"></el-table-column> | ||||
|         <el-table-column align="center" prop="categoryName" label="流程分类"></el-table-column> | ||||
|         <el-table-column align="center" prop="nodeName" label="任务名称"></el-table-column> | ||||
|         <el-table-column align="center" prop="createByName" label="申请人"></el-table-column> | ||||
| @ -60,7 +60,7 @@ | ||||
|         <el-table-column align="center" prop="createTime" label="创建时间" width="160"></el-table-column> | ||||
|         <el-table-column label="操作" align="center" width="200"> | ||||
|           <template #default="scope"> | ||||
|             <el-button type="primary" size="small" icon="Edit" @click="handleOpen(scope.row)">办理</el-button> | ||||
|             <el-button type="primary" link icon="Edit" @click="handleOpen(scope.row)">办理</el-button> | ||||
|           </template> | ||||
|         </el-table-column> | ||||
|       </el-table> | ||||
| @ -88,7 +88,12 @@ const { wf_business_status } = toRefs<any>(proxy?.useDict('wf_business_status')) | ||||
| import UserSelect from '@/components/UserSelect'; | ||||
| import { ref } from 'vue'; | ||||
| import { UserVO } from '@/api/system/user/types'; | ||||
|  | ||||
| import { useUserStore } from '@/store/modules/user'; | ||||
| const userStore = useUserStore(); | ||||
| const projects = computed(() => [ | ||||
|   { id: '0', name: '全部项目' }, // 添加空选项 | ||||
|   ...userStore.projects | ||||
| ]); | ||||
| const userSelectRef = ref<InstanceType<typeof UserSelect>>(); | ||||
| //提交组件 | ||||
| const queryFormRef = ref<ElFormInstance>(); | ||||
| @ -112,13 +117,14 @@ const selectUserIds = ref<Array<number | string>>([]); | ||||
| //申请人选择数量 | ||||
| const userSelectCount = ref(0); | ||||
| // 查询参数 | ||||
| const queryParams = ref<TaskQuery>({ | ||||
| const queryParams = ref({ | ||||
|   pageNum: 1, | ||||
|   pageSize: 10, | ||||
|   nodeName: undefined, | ||||
|   flowName: undefined, | ||||
|   flowCode: undefined, | ||||
|   createByIds: [] | ||||
|   createByIds: [], | ||||
|   projectId: '0' | ||||
| }); | ||||
| onMounted(() => { | ||||
|   getWaitingList(); | ||||
|  | ||||
		Reference in New Issue
	
	Block a user