528 lines
		
	
	
		
			20 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			528 lines
		
	
	
		
			20 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <div class="p-2">
 | |
|     <transition :enter-active-class="proxy?.animate.searchAnimate.enter"
 | |
|       :leave-active-class="proxy?.animate.searchAnimate.leave">
 | |
|       <div v-show="showSearch" class="mb-[10px]">
 | |
|         <el-card shadow="hover">
 | |
|           <el-form ref="queryFormRef" :model="queryParams" :inline="true">
 | |
|             <el-form-item label="检查类型" prop="checkType">
 | |
|               <el-select v-model="queryParams.checkType" placeholder="全部" clearable>
 | |
|                 <el-option v-for="dict in safety_inspection_check_type" :key="dict.value" :label="dict.label"
 | |
|                   :value="dict.value" />
 | |
|               </el-select>
 | |
|             </el-form-item>
 | |
|             <el-form-item label="违章类型" prop="violationType">
 | |
|               <el-select v-model="queryParams.violationType" placeholder="全部" clearable>
 | |
|                 <el-option v-for="dict in safety_inspection_violation_type" :key="dict.value" :label="dict.label"
 | |
|                   :value="dict.value" />
 | |
|               </el-select>
 | |
|             </el-form-item>
 | |
|             <el-form-item label="处理状态" prop="status">
 | |
|               <el-select v-model="queryParams.status" placeholder="全部" clearable>
 | |
|                 <el-option v-for="dict in safety_inspection_type" :key="dict.value" :label="dict.label"
 | |
|                   :value="dict.value" />
 | |
|               </el-select>
 | |
|             </el-form-item>
 | |
|             <el-form-item>
 | |
|               <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
 | |
|               <el-button icon="Refresh" @click="resetQuery">重置</el-button>
 | |
|             </el-form-item>
 | |
|           </el-form>
 | |
|         </el-card>
 | |
|       </div>
 | |
|     </transition>
 | |
| 
 | |
|     <el-card shadow="never">
 | |
|       <template #header>
 | |
|         <el-row :gutter="10" class="mb8">
 | |
|           <el-col :span="1.5">
 | |
|             <el-button type="primary" plain icon="Plus" @click="handleAdd" v-hasPermi="['safety:safetyInspection:add']">
 | |
|               新增 </el-button>
 | |
|           </el-col>
 | |
|           <el-col :span="1.5">
 | |
|             <el-button type="danger" plain icon="Delete" :disabled="multiple" @click="handleDelete()"
 | |
|               v-hasPermi="['safety:safetyInspection:remove']">
 | |
|               删除
 | |
|             </el-button>
 | |
|           </el-col>
 | |
|           <el-col :span="1.5">
 | |
|             <el-button type="warning" plain icon="Download" @click="handleExport"
 | |
|               v-hasPermi="['safety:safetyInspection:export']">导出 </el-button>
 | |
|           </el-col>
 | |
|           <right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar>
 | |
|         </el-row>
 | |
|       </template>
 | |
| 
 | |
|       <el-table v-loading="loading" :data="safetyInspectionList" @selection-change="handleSelectionChange">
 | |
|         <el-table-column type="selection" width="55" align="center" />
 | |
|         <el-table-column label="序号" type="index" width="60" align="center" />
 | |
|         <el-table-column label="检查项目" align="center" prop="checkProject" />
 | |
|         <el-table-column label="处理状态" align="center" prop="status">
 | |
|           <template #default="scope">
 | |
|             <dict-tag :options="safety_inspection_type" :value="scope.row.status" />
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|         <el-table-column label="检查人" align="center" prop="correctorName" />
 | |
|         <el-table-column label="检查时间" align="center" prop="rectificationDeadline" width="180">
 | |
|           <template #default="scope">
 | |
|             <span>{{ parseTime(scope.row.rectificationDeadline, '{y}-{m}-{d}') }}</span>
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|         <el-table-column label="检查类型" align="center" prop="checkType">
 | |
|           <template #default="scope">
 | |
|             <dict-tag :options="safety_inspection_check_type" :value="scope.row.checkType" />
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|         <el-table-column label="违章类型" align="center" prop="violationType">
 | |
|           <template #default="scope">
 | |
|             <dict-tag :options="safety_inspection_violation_type" :value="scope.row.violationType" />
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|         <el-table-column label="巡检结果" align="center" prop="inspectionResult">
 | |
|           <template #default="scope">
 | |
|             <el-tooltip placement="top" effect="dark">
 | |
|               <template #content>
 | |
|                 <div class="max-w-670px">{{ scope.row.inspectionResult }}</div>
 | |
|               </template>
 | |
|               <el-text truncated>
 | |
|                 {{ scope.row.inspectionResult }}
 | |
|               </el-text>
 | |
|             </el-tooltip>
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|         <el-table-column label="整改人" align="center" prop="correctorName" />
 | |
|         <el-table-column label="复查状态" align="center" prop="reviewType">
 | |
|           <template #default="scope">
 | |
|             <dict-tag :options="review_type" :value="scope.row.reviewType" />
 | |
|           </template>
 | |
|         </el-table-column>
 | |
|         <el-table-column label="备注" align="center" prop="remark" />
 | |
|         <el-table-column label="操作" align="center" class-name="small-padding fixed-width" width="220">
 | |
|           <template #default="scope">
 | |
|             <el-space>
 | |
|               <el-button link type="primary" icon="View" @click="handleShowDialog(scope.row)"
 | |
|                 v-hasPermi="['safety:safetyInspection:query']">
 | |
|                 详情
 | |
|               </el-button>
 | |
|               <el-button link type="success" v-if="scope.row.status === '1'" icon="Pointer"
 | |
|                 @click="handleDialog(scope.row)" v-hasPermi="['safety:safetyInspection:rectification']">
 | |
|                 整改
 | |
|               </el-button>
 | |
|               <el-button link type="warning" icon="SuccessFilled" v-if="scope.row.status === '2'"
 | |
|                 @click="handleDialog(scope.row)" v-hasPermi="['safety:safetyInspection:review']">
 | |
|                 复查
 | |
|               </el-button>
 | |
|               <!-- <el-button link type="success" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['safety:safetyInspection:edit']">修改 </el-button> -->
 | |
|               <el-button link type="danger" icon="Delete" @click="handleDelete(scope.row)"
 | |
|                 v-hasPermi="['safety:safetyInspection:remove']">
 | |
|                 删除
 | |
|               </el-button>
 | |
|             </el-space>
 | |
|           </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" />
 | |
|     </el-card>
 | |
|     <!-- 添加或修改安全巡检工单对话框 -->
 | |
| 
 | |
|     <el-dialog :title="dialog.title" v-model="dialog.visible" append-to-body>
 | |
|       <el-form ref="safetyInspectionFormRef" :model="form" :rules="rules" label-width="120px">
 | |
|         <el-form-item label="检查项目" prop="checkProject">
 | |
|           <el-input v-model="form.checkProject" placeholder="请输入检查项目" />
 | |
|         </el-form-item>
 | |
|         <el-form-item label="检查类型" prop="checkType">
 | |
|           <el-select v-model="form.checkType" placeholder="请选择检查类型">
 | |
|             <el-option v-for="dict in safety_inspection_check_type" :key="dict.value" :label="dict.label"
 | |
|               :value="dict.value"></el-option>
 | |
|           </el-select>
 | |
|         </el-form-item>
 | |
|         <el-form-item label="违章类型" prop="violationType">
 | |
|           <el-select v-model="form.violationType" placeholder="请选择违章类型">
 | |
|             <el-option v-for="dict in safety_inspection_violation_type" :key="dict.value" :label="dict.label"
 | |
|               :value="dict.value"></el-option>
 | |
|           </el-select>
 | |
|         </el-form-item>
 | |
|         <el-form-item label="巡检结果" prop="inspectionResult">
 | |
|           <el-input v-model="form.inspectionResult" placeholder="请输入巡检结果" />
 | |
|         </el-form-item>
 | |
|         <el-form-item label="工单整改单位" prop="rectificationUnit">
 | |
|           <el-select v-model="form.rectificationUnit" placeholder="请选择整改单位类型">
 | |
|             <el-option v-for="dict in rectification_unit_type" :key="dict.value" :label="dict.label"
 | |
|               :value="dict.value"></el-option>
 | |
|           </el-select>
 | |
|         </el-form-item>
 | |
|         <el-form-item label="整改班组" prop="teamId">
 | |
|           <el-select v-model="form.teamId" placeholder="请选择整改班组">
 | |
|             <el-option v-for="item in teamOpt" :key="item.value" :label="item.label" :value="item.value"
 | |
|               @click="changeForeman(item.value)" />
 | |
|           </el-select>
 | |
|         </el-form-item>
 | |
|         <el-form-item label="整改人" prop="correctorId">
 | |
|           <el-select v-model="form.correctorId" placeholder="请选择整改人" :disabled="!form.teamId">
 | |
|             <el-option v-for="item in foremanOpt" :key="item.value" :label="item.label" :value="item.value" />
 | |
|           </el-select>
 | |
|         </el-form-item>
 | |
| 
 | |
|         <el-form-item label="是否回复" prop="isReply">
 | |
|           <el-radio-group v-model="form.isReply">
 | |
|             <el-radio label="1">是</el-radio>
 | |
|             <el-radio label="2">否</el-radio>
 | |
|           </el-radio-group>
 | |
|         </el-form-item>
 | |
|         <el-form-item label="问题隐患" prop="hiddenDanger">
 | |
|           <el-input v-model="form.hiddenDanger" type="textarea" placeholder="请输入内容" />
 | |
|         </el-form-item>
 | |
|         <!-- <el-form-item label="整改措施" prop="measure">
 | |
|           <el-input v-model="form.measure" type="textarea" placeholder="请输入内容" />
 | |
|         </el-form-item> -->
 | |
|         <el-form-item label="要求整改期限" prop="checkTime">
 | |
|           <el-date-picker clearable v-model="form.rectificationDeadline" type="date" value-format="YYYY-MM-DD"
 | |
|             placeholder="选择要求整改期限" />
 | |
|         </el-form-item>
 | |
|         <el-form-item label="检查附件" prop="checkFile">
 | |
|           <file-upload v-model="form.checkFile" :file-size="20"
 | |
|             :file-type="['doc', 'docx', 'pdf', 'png', 'jpg', 'jpeg']" />
 | |
|         </el-form-item>
 | |
|         <el-form-item label="整改附件" prop="rectificationFile">
 | |
|           <file-upload v-model="form.rectificationFile" :file-size="20"
 | |
|             :file-type="['doc', 'docx', 'pdf', 'png', 'jpg', 'jpeg']" />
 | |
|         </el-form-item>
 | |
|         <el-form-item label="备注" prop="remark">
 | |
|           <el-input v-model="form.remark" type="textarea" placeholder="请输入内容" />
 | |
|         </el-form-item>
 | |
|       </el-form>
 | |
|       <template #footer>
 | |
|         <div class="dialog-footer">
 | |
|           <el-button :loading="buttonLoading" type="primary" @click="submitForm">确 定</el-button>
 | |
|           <el-button @click="cancel">取 消</el-button>
 | |
|         </div>
 | |
|       </template>
 | |
|     </el-dialog>
 | |
|     <el-dialog title="巡检工单详情" v-model="showDetailDialog" width="60vw">
 | |
|       <safety-inspection-detail-dialog :safety-inspection-id="currentSafetyInspectionId" />
 | |
|     </el-dialog>
 | |
|     <el-dialog :title="handleType === 'rectification' ? '处理整改工单' : '处理复查工单'" v-model="handleDialogVisible"
 | |
|       width="500px">
 | |
|       <el-form ref="handleFormRef" :model="handleForm" :rules="rules" label-width="120px">
 | |
|         <el-form-item label="整改措施" prop="measure" v-if="handleType === 'rectification'">
 | |
|           <el-input v-model="handleForm.measure" type="textarea" placeholder="请输入内容" />
 | |
|         </el-form-item>
 | |
|         <el-form-item label="整改附件" prop="rectificationFile" v-if="handleType === 'rectification'">
 | |
|           <image-upload v-model="handleForm.rectificationFile" />
 | |
|         </el-form-item>
 | |
|         <el-form-item label="复查情况" prop="review" v-if="handleType === 'review'">
 | |
|           <el-input v-model="handleForm.review" type="textarea" placeholder="请输入内容" />
 | |
|         </el-form-item>
 | |
|         <el-form-item label="复查类型" prop="reviewType" v-if="handleType === 'review'">
 | |
|           <el-select v-model="handleForm.reviewType" placeholder="请选择复查类型">
 | |
|             <el-option v-for="dict in review_type" :key="dict.value" :label="dict.label"
 | |
|               :value="dict.value"></el-option>
 | |
|           </el-select>
 | |
|         </el-form-item>
 | |
|         <el-form-item>
 | |
|           <el-button type="primary" @click="handleSubmit">确 定</el-button>
 | |
|         </el-form-item>
 | |
|       </el-form>
 | |
|     </el-dialog>
 | |
|   </div>
 | |
| </template>
 | |
| 
 | |
| <script setup name="SafetyInspection" lang="ts">
 | |
| import {
 | |
|   addSafetyInspection,
 | |
|   delSafetyInspection,
 | |
|   getSafetyInspection,
 | |
|   listSafetyInspection,
 | |
|   updateSafetyInspection,
 | |
|   addSafetyInspectionReview,
 | |
|   addSafetyInspectionRectification,
 | |
| } from '@/api/safety/safetyInspection';
 | |
| import { SafetyInspectionForm, SafetyInspectionQuery, SafetyInspectionVO } from '@/api/safety/safetyInspection/types';
 | |
| import { useUserStoreHook } from '@/store/modules/user';
 | |
| import SafetyInspectionDetailDialog from '@/views/safety/safetyInspection/component/SafetyInspectionDetailDialog.vue';
 | |
| import { listProjectTeamForeman } from '@/api/project/projectTeam';
 | |
| import { foremanQuery, ProjectTeamForemanResp } from '@/api/project/projectTeam/types';
 | |
| 
 | |
| const { proxy } = getCurrentInstance() as ComponentInternalInstance;
 | |
| const { rectification_unit_type, safety_inspection_violation_type, review_type, safety_inspection_type, safety_inspection_check_type } = toRefs<any>(
 | |
|   proxy?.useDict(
 | |
|     'rectification_unit_type',
 | |
|     'safety_inspection_violation_type',
 | |
|     'review_type',
 | |
|     'safety_inspection_type',
 | |
|     'safety_inspection_check_type'
 | |
|   )
 | |
| );
 | |
| // 获取用户 store
 | |
| const userStore = useUserStoreHook();
 | |
| // 从 store 中获取项目列表和当前选中的项目
 | |
| const currentProject = computed(() => userStore.selectedProject);
 | |
| const safetyInspectionList = ref<SafetyInspectionVO[]>([]);
 | |
| const buttonLoading = ref(false);
 | |
| const loading = ref(true);
 | |
| const showSearch = ref(true);
 | |
| const ids = ref<Array<string | number>>([]);
 | |
| const single = ref(true);
 | |
| const multiple = ref(true);
 | |
| const total = ref(0);
 | |
| 
 | |
| const queryFormRef = ref<ElFormInstance>();
 | |
| const safetyInspectionFormRef = ref<ElFormInstance>();
 | |
| 
 | |
| const dialog = reactive<DialogOption>({
 | |
|   visible: false,
 | |
|   title: ''
 | |
| });
 | |
| const handleForm = ref({
 | |
|   id: undefined,
 | |
|   measure: undefined,
 | |
|   rectificationFile: undefined,
 | |
|   review: undefined,
 | |
|   reviewType: undefined,
 | |
|   remark: undefined,
 | |
| })
 | |
| const initFormData: SafetyInspectionForm = {
 | |
|   id: undefined,
 | |
|   pid: undefined,
 | |
|   projectId: currentProject.value?.id,
 | |
|   checkType: undefined,
 | |
|   violationType: undefined,
 | |
|   inspectionResult: undefined,
 | |
|   teamId: undefined,
 | |
|   correctorId: undefined,
 | |
|   rectificationDeadline: undefined,
 | |
|   isReply: undefined,
 | |
|   replyDate: undefined,
 | |
|   status: undefined,
 | |
|   hiddenDanger: undefined,
 | |
|   measure: undefined,
 | |
|   review: undefined,
 | |
|   reviewType: undefined,
 | |
|   checkTime: undefined,
 | |
|   rectificationTime: undefined,
 | |
|   rectificationUnit: undefined,
 | |
|   checkProject: undefined,
 | |
|   reviewTime: undefined,
 | |
|   checkFile: undefined,
 | |
|   rectificationFile: undefined,
 | |
|   remark: undefined
 | |
| };
 | |
| const data = reactive<PageData<SafetyInspectionForm, SafetyInspectionQuery>>({
 | |
|   form: { ...initFormData },
 | |
|   queryParams: {
 | |
|     pageNum: 1,
 | |
|     pageSize: 10,
 | |
|     id: undefined,
 | |
|     pid: undefined,
 | |
|     projectId: currentProject.value?.id,
 | |
|     checkType: undefined,
 | |
|     violationType: undefined,
 | |
|     inspectionResult: undefined,
 | |
|     teamId: undefined,
 | |
|     correctorId: undefined,
 | |
|     isReply: undefined,
 | |
|     replyDate: undefined,
 | |
|     status: undefined,
 | |
|     hiddenDanger: undefined,
 | |
|     measure: undefined,
 | |
|     review: undefined,
 | |
|     reviewType: undefined,
 | |
|     checkTime: undefined,
 | |
|     rectificationTime: undefined,
 | |
|     reviewTime: undefined,
 | |
|     remark: undefined,
 | |
|     params: {}
 | |
|   },
 | |
|   rules: {
 | |
|     id: [{ required: true, message: '主键ID不能为空', trigger: 'blur' }],
 | |
|     projectId: [{ required: true, message: '项目ID不能为空', trigger: 'blur' }],
 | |
|     checkType: [{ required: true, message: '检查类型不能为空', trigger: 'blur' }],
 | |
|     violationType: [{ required: true, message: '违章类型不能为空', trigger: 'blur' }],
 | |
|     checkProject: [{ required: true, message: '检查项目不能为空', trigger: 'blur' }],
 | |
|     isReply: [{ required: true, message: '是否回复不能为空', trigger: 'blur' }]
 | |
|   }
 | |
| });
 | |
| 
 | |
| const { queryParams, form, rules } = toRefs(data);
 | |
| 
 | |
| const teamOpt = ref([]);
 | |
| const foremanOpt = ref([]);
 | |
| const teamList = ref<ProjectTeamForemanResp[]>();
 | |
| const handleType = ref("")
 | |
| 
 | |
| 
 | |
| 
 | |
| /** 查询安全巡检工单列表 */
 | |
| const getList = async () => {
 | |
|   loading.value = true;
 | |
|   const res = await listSafetyInspection(queryParams.value);
 | |
|   safetyInspectionList.value = res.rows;
 | |
|   total.value = res.total;
 | |
|   // 获取项目班组信息
 | |
|   const teamRes = await listProjectTeamForeman(currentProject.value?.id);
 | |
|   teamList.value = teamRes.data;
 | |
|   teamOpt.value = teamList.value.map((team: ProjectTeamForemanResp) => ({
 | |
|     label: team.teamName,
 | |
|     value: team.id
 | |
|   }));
 | |
| 
 | |
|   loading.value = false;
 | |
| };
 | |
| 
 | |
| const changeForeman = (value: string | number) => {
 | |
|   const team = teamList.value.filter((team) => team.id === value)[0];
 | |
|   foremanOpt.value = team.foremanList?.map((foreman: foremanQuery) => ({
 | |
|     label: foreman.foremanName,
 | |
|     value: foreman.foremanId
 | |
|   }));
 | |
|   form.value.correctorId = '';
 | |
| };
 | |
| /** 处理安全巡查工单 */
 | |
| const handleSubmit = async () => {
 | |
|   let flag = false;
 | |
|   if (handleType.value == "rectification") {
 | |
|     const { code } = await addSafetyInspectionRectification(handleForm.value)
 | |
|     if (code == 200) flag = true
 | |
|   } else {
 | |
|     const { code } = await addSafetyInspectionReview(handleForm.value)
 | |
|     if (code == 200) flag = true
 | |
|   }
 | |
|   if (flag) {
 | |
|     ElMessage.success("处理成功")
 | |
|     handleDialogVisible.value = false;
 | |
|     getList()
 | |
|     reset()
 | |
|   } else {
 | |
|     ElMessage.error("处理失败")
 | |
|   }
 | |
| 
 | |
| }
 | |
| 
 | |
| 
 | |
| /** 展开安全巡检工单详情对话框操作 */
 | |
| const currentSafetyInspectionId = ref<string | number>();
 | |
| const showDetailDialog = ref<boolean>(false);
 | |
| const handleDialogVisible = ref<boolean>(false);
 | |
| const handleShowDialog = (row?: SafetyInspectionVO) => {
 | |
|   currentSafetyInspectionId.value = row.id;
 | |
| 
 | |
|   showDetailDialog.value = true;
 | |
| };
 | |
| /**打开整改/复查对话框操作*/
 | |
| const handleDialog = (row?: SafetyInspectionVO) => {
 | |
| 
 | |
|   if (row.status == '1') {
 | |
|     handleType.value = "rectification"
 | |
|   } else {
 | |
|     handleType.value = "review"
 | |
|   }
 | |
|   handleForm.value.id = row.id;
 | |
|   handleDialogVisible.value = true;
 | |
| };
 | |
| /** 取消按钮 */
 | |
| const cancel = () => {
 | |
|   reset();
 | |
|   dialog.visible = false;
 | |
| };
 | |
| 
 | |
| /** 表单重置 */
 | |
| const reset = () => {
 | |
|   form.value = { ...initFormData };
 | |
|   safetyInspectionFormRef.value?.resetFields();
 | |
| };
 | |
| 
 | |
| /** 搜索按钮操作 */
 | |
| const handleQuery = () => {
 | |
|   queryParams.value.pageNum = 1;
 | |
|   getList();
 | |
| };
 | |
| 
 | |
| /** 重置按钮操作 */
 | |
| const resetQuery = () => {
 | |
|   queryFormRef.value?.resetFields();
 | |
|   handleQuery();
 | |
| };
 | |
| 
 | |
| /** 多选框选中数据 */
 | |
| const handleSelectionChange = (selection: SafetyInspectionVO[]) => {
 | |
|   ids.value = selection.map((item) => item.id);
 | |
|   single.value = selection.length != 1;
 | |
|   multiple.value = !selection.length;
 | |
| };
 | |
| 
 | |
| /** 新增按钮操作 */
 | |
| const handleAdd = () => {
 | |
|   reset();
 | |
|   dialog.visible = true;
 | |
|   dialog.title = '添加安全巡检工单';
 | |
| };
 | |
| 
 | |
| /** 修改按钮操作 */
 | |
| const handleUpdate = async (row?: SafetyInspectionVO) => {
 | |
|   reset();
 | |
|   const _id = row?.id || ids.value[0];
 | |
|   const res = await getSafetyInspection(_id);
 | |
|   Object.assign(form.value, res.data);
 | |
|   dialog.visible = true;
 | |
|   dialog.title = '修改安全巡检工单';
 | |
| };
 | |
| 
 | |
| /** 提交按钮 */
 | |
| const submitForm = () => {
 | |
|   safetyInspectionFormRef.value?.validate(async (valid: boolean) => {
 | |
|     if (valid) {
 | |
|       buttonLoading.value = true;
 | |
|       form.value.projectId = currentProject.value?.id;
 | |
|       if (form.value.id) {
 | |
|         await updateSafetyInspection(form.value).finally(() => (buttonLoading.value = false));
 | |
|       } else {
 | |
|         await addSafetyInspection(form.value).finally(() => (buttonLoading.value = false));
 | |
|       }
 | |
|       proxy?.$modal.msgSuccess('操作成功');
 | |
|       dialog.visible = false;
 | |
|       await getList();
 | |
|     }
 | |
|   });
 | |
| };
 | |
| 
 | |
| /** 删除按钮操作 */
 | |
| const handleDelete = async (row?: SafetyInspectionVO) => {
 | |
|   const _ids = row?.id || ids.value;
 | |
|   await proxy?.$modal.confirm('是否确认删除安全巡检工单编号为"' + _ids + '"的数据项?').finally(() => (loading.value = false));
 | |
|   await delSafetyInspection(_ids);
 | |
|   proxy?.$modal.msgSuccess('删除成功');
 | |
|   await getList();
 | |
| };
 | |
| 
 | |
| /** 导出按钮操作 */
 | |
| const handleExport = () => {
 | |
|   proxy?.download(
 | |
|     'safety/safetyInspection/export',
 | |
|     {
 | |
|       ...queryParams.value
 | |
|     },
 | |
|     `safetyInspection_${new Date().getTime()}.xlsx`
 | |
|   );
 | |
| };
 | |
| 
 | |
| //监听项目id刷新数据
 | |
| const listeningProject = watch(
 | |
|   () => currentProject.value?.id,
 | |
|   (nid, oid) => {
 | |
|     queryParams.value.projectId = nid;
 | |
|     form.value.projectId = nid;
 | |
|     getList();
 | |
|   }
 | |
| );
 | |
| 
 | |
| onUnmounted(() => {
 | |
|   listeningProject();
 | |
| });
 | |
| 
 | |
| onMounted(() => {
 | |
|   getList();
 | |
| });
 | |
| </script>
 |