| <template> | 
|   <div class="list"> | 
|     <TableCustom :queryForm="form" :tableData="tableData" :total="total"> | 
|       <template #search> | 
|         <el-form :model="form" labelWidth="auto" inline> | 
|           <el-form-item label="所属项目课题方案:"> | 
|             <el-input v-model="form.planName" placeholder="请输入"></el-input> | 
|           </el-form-item> | 
|           <el-form-item label="实验编号"> | 
|             <el-input | 
|               v-model="form.experimentCode" | 
|               placeholder="请输入" | 
|             ></el-input> | 
|           </el-form-item> | 
|           <el-form-item label="通知时间"> | 
|             <el-date-picker | 
|               v-model="form.createTime" | 
|               type="daterange" | 
|               range-separator="至" | 
|               start-placeholder="开始日期" | 
|               end-placeholder="结束日期" | 
|               value-format="yyyy-MM-dd" | 
|             ></el-date-picker> | 
|           </el-form-item> | 
|           <el-form-item label="状态"> | 
|             <el-select v-model="form.status" placeholder="请选择"> | 
|               <el-option label="全部" value=""></el-option> | 
|               <el-option label="待确认" value="pending"></el-option> | 
|               <el-option label="已确认" value="confirmed"></el-option> | 
|               <el-option label="已取消" value="cancelled"></el-option> | 
|             </el-select> | 
|           </el-form-item> | 
|           <el-form-item label=""> | 
|             <el-button type="default" @click="resetForm">重置</el-button> | 
|             <el-button type="primary" @click="handleSearch">查询</el-button> | 
|           </el-form-item> | 
|         </el-form> | 
|       </template> | 
|       <template #setting> | 
|         <div class="tableTitle"> | 
|           <div class="flex a-center"> | 
|             <div | 
|               class="title" | 
|               :class="{ active: currentType === 'list' }" | 
|               @click="handleTypeChange('list')" | 
|             > | 
|               实验调度列表 | 
|             </div> | 
|             <div | 
|               class="drafts" | 
|               :class="{ active: currentType === 'draft' }" | 
|               @click="handleTypeChange('draft')" | 
|             > | 
|               草稿箱 | 
|             </div> | 
|           </div> | 
|           <el-button @click="handleAddPlan" class="el-icon-plus" type="primary"> | 
|             新增实验调度</el-button | 
|           > | 
|         </div> | 
|       </template> | 
|       <template #table> | 
|         <el-table-column | 
|           prop="experimentCode" | 
|           label="所属项目课题方案" | 
|         ></el-table-column> | 
|         <el-table-column | 
|           prop="experimentName" | 
|           label="实验编号" | 
|         ></el-table-column> | 
|         <el-table-column prop="startTime" label="实验名称"></el-table-column> | 
|         <el-table-column prop="endTime" label="通知时间"></el-table-column> | 
|         <el-table-column | 
|           prop="participants" | 
|           label="实验开始时间" | 
|         ></el-table-column> | 
|         <el-table-column | 
|           prop="createTime" | 
|           label="实验结束时间" | 
|         ></el-table-column> | 
|         <el-table-column prop="people" label="参加人员"></el-table-column> | 
|         <el-table-column prop="status" label="状态"> | 
|           <template slot-scope="scope"> | 
|             <el-tag :type="getStatusType(scope.row.status)"> | 
|               {{ getStatusText(scope.row.status) }} | 
|             </el-tag> | 
|           </template> | 
|         </el-table-column> | 
|         <el-table-column label="操作" width="200"> | 
|           <template slot-scope="scope"> | 
|             <el-button | 
|               v-if="scope.row.status === 'pending'" | 
|               type="text" | 
|               @click="handleConfirm(scope.row)" | 
|               >确认</el-button | 
|             > | 
|             <el-button type="text" @click="handleDelete(scope.row)" | 
|               >删除</el-button | 
|             > | 
|             <el-button type="text" @click="handleDetail(scope.row)" | 
|               >详情</el-button | 
|             > | 
|           </template> | 
|         </el-table-column> | 
|       </template> | 
|     </TableCustom> | 
|     <SignatureCanvas | 
|       :visible="signatureDialogVisible" | 
|       @confirm="handleSignatureConfirm" | 
|     /> | 
|     <edit-dispatch | 
|       :visible.sync="approvalDialogVisible" | 
|       :type="approvalDialogType" | 
|       :data="currentApprovalData" | 
|     /> | 
|   </div> | 
| </template> | 
|   | 
| <script> | 
| import SignatureCanvas from "@/components/SignatureCanvas.vue"; | 
| import EditDispatch from "./editDispatch.vue"; | 
|   | 
| export default { | 
|   name: "dispatchingList", | 
|   components: { | 
|     SignatureCanvas, | 
|     EditDispatch, | 
|   }, | 
|   data() { | 
|     return { | 
|       currentType: "list", // 当前显示类型:list-列表,draft-草稿箱 | 
|       form: { | 
|         experimentName: "", | 
|         experimentCode: "", | 
|         createTime: [], | 
|         status: "", | 
|       }, | 
|       tableData: [], | 
|       total: 0, | 
|       // 模拟数据 | 
|       mockListData: [ | 
|         { | 
|           experimentCode: "EXP-2024-001", | 
|           experimentName: "材料力学性能测试实验", | 
|           startTime: "2024-03-20 09:00", | 
|           endTime: "2024-03-20 17:00", | 
|           participants: "张三、李四、王五", | 
|           createTime: "2024-03-15", | 
|           status: "pending", | 
|           planName: "新材料研发项目", | 
|           planCode: "PLAN-2024-001", | 
|           stage: "实验阶段", | 
|           testDate: "2024-03-20", | 
|           testName: "材料力学性能测试", | 
|           testCode: "TEST-2024-001", | 
|           testTime: "2024-03-20 09:00", | 
|           groupTableData: [ | 
|             { | 
|               groupName: "对照组", | 
|               remark: "标准材料组" | 
|             }, | 
|             { | 
|               groupName: "实验组", | 
|               remark: "新材料组" | 
|             } | 
|           ], | 
|           taskTableData: [ | 
|             { | 
|               taskName: "材料准备", | 
|               leader: "张三", | 
|               startTime: "2024-03-20 09:00" | 
|             }, | 
|             { | 
|               taskName: "性能测试", | 
|               leader: "李四", | 
|               startTime: "2024-03-20 10:00" | 
|             } | 
|           ] | 
|         }, | 
|         { | 
|           experimentCode: "EXP-2024-002", | 
|           experimentName: "化学合成实验", | 
|           startTime: "2024-03-21 10:00", | 
|           endTime: "2024-03-21 16:00", | 
|           participants: "赵六、钱七、孙八", | 
|           createTime: "2024-03-16", | 
|           status: "confirmed", | 
|         }, | 
|         { | 
|           experimentCode: "EXP-2024-003", | 
|           experimentName: "生物培养实验", | 
|           startTime: "2024-03-22 08:00", | 
|           endTime: "2024-03-22 18:00", | 
|           participants: "周九、吴十、郑十一", | 
|           createTime: "2024-03-17", | 
|           status: "cancelled", | 
|         }, | 
|       ], | 
|       mockDraftData: [ | 
|         { | 
|           experimentCode: "EXP-2024-004", | 
|           experimentName: "物理光学实验(草稿)", | 
|           startTime: "2024-03-23 09:00", | 
|           endTime: "2024-03-23 17:00", | 
|           participants: "王十二、李十三", | 
|           createTime: "2024-03-18", | 
|           status: "draft", | 
|         }, | 
|       ], | 
|       signatureDialogVisible: false, | 
|       currentRow: null, | 
|       approvalDialogVisible: false, | 
|       approvalDialogType: "view", | 
|       currentApprovalData: null, | 
|     }; | 
|   }, | 
|   created() { | 
|     this.getTableData(); | 
|   }, | 
|   methods: { | 
|     resetForm() { | 
|       this.form = { | 
|         experimentName: "", | 
|         experimentCode: "", | 
|         createTime: [], | 
|         status: "", | 
|       }; | 
|     }, | 
|     handleSearch() { | 
|       // 实现查询逻辑 | 
|       console.log("查询条件:", this.form); | 
|     }, | 
|     getStatusType(status) { | 
|       const statusMap = { | 
|         pending: "warning", | 
|         confirmed: "success", | 
|         cancelled: "danger", | 
|         draft: "info", | 
|       }; | 
|       return statusMap[status] || "info"; | 
|     }, | 
|     getStatusText(status) { | 
|       const statusMap = { | 
|         pending: "待确认", | 
|         confirmed: "已确认", | 
|         cancelled: "已取消", | 
|         draft: "草稿", | 
|       }; | 
|       return statusMap[status] || "未知"; | 
|     }, | 
|     handleAddPlan() { | 
|       this.$router.push({ | 
|         path: "/dataManagement/addDispatch", | 
|       }); | 
|     }, | 
|     handleConfirm(row) { | 
|       // this.currentRow = row; | 
|       // this.signatureDialogVisible = true; | 
|   | 
|       this.currentApprovalData = row; | 
|       this.approvalDialogType = "approve"; | 
|       this.approvalDialogVisible = true; | 
|     }, | 
|     handleSignatureConfirm(imageData) { | 
|       console.log("imageData imageData", imageData); | 
|       this.signatureDialogVisible = false; | 
|   | 
|       // 这里处理签名确认后的逻辑 | 
|       // this.$confirm('确认该实验调度吗?', '提示', { | 
|       //   confirmButtonText: '确定', | 
|       //   cancelButtonText: '取消', | 
|       //   type: 'warning' | 
|       // }).then(() => { | 
|       //   // 这里可以将签名图片数据(imageData)连同其他数据一起提交到后端 | 
|       //   this.$message.success('确认成功'); | 
|       //   this.signatureDialogVisible = false; | 
|       //   this.getTableData(); | 
|       // }).catch(() => { | 
|       //   this.signatureDialogVisible = false; | 
|       // }); | 
|     }, | 
|     handleDelete(row) { | 
|       this.$confirm("确定要删除该实验调度吗?", "提示", { | 
|         confirmButtonText: "确定", | 
|         cancelButtonText: "取消", | 
|         type: "warning", | 
|       }) | 
|         .then(() => { | 
|           this.$message.success("删除成功"); | 
|           this.getTableData(); | 
|         }) | 
|         .catch(() => {}); | 
|     }, | 
|     handleDetail(row) { | 
|       this.currentApprovalData = row; | 
|       this.approvalDialogType = "view"; | 
|       this.approvalDialogVisible = true; | 
|     }, | 
|     handleTypeChange(type) { | 
|       this.currentType = type; | 
|       this.getTableData(); | 
|     }, | 
|     getTableData() { | 
|       // 根据currentType请求不同的数据 | 
|       if (this.currentType === "list") { | 
|         this.tableData = this.mockListData; | 
|         this.total = this.mockListData.length; | 
|       } else { | 
|         this.tableData = this.mockDraftData; | 
|         this.total = this.mockDraftData.length; | 
|       } | 
|     }, | 
|   }, | 
| }; | 
| </script> | 
|   | 
| <style scoped lang="less"> | 
| .list { | 
|   height: 100%; | 
| } | 
| .flex { | 
|   display: flex; | 
|   align-items: center; | 
| } | 
| .tableTitle { | 
|   display: flex; | 
|   padding-bottom: 20px; | 
|   justify-content: space-between; | 
|   align-items: center; | 
|   .title { | 
|     background: #fafafc; | 
|     border-radius: 8px 8px 0px 0px; | 
|     border: 1px solid #dcdfe6; | 
|     padding: 16px 29px; | 
|     font-weight: bold; | 
|     font-size: 18px; | 
|     color: #606266; | 
|     width: unset; | 
|     cursor: pointer; | 
|   } | 
|   .drafts { | 
|     padding: 16px 65px; | 
|     background: #fafafc; | 
|     border-radius: 8px 8px 0px 0px; | 
|     border: 1px solid #dcdfe6; | 
|     font-weight: 400; | 
|     font-size: 18px; | 
|     color: #606266; | 
|     margin-left: 16px; | 
|     cursor: pointer; | 
|   } | 
|   .active { | 
|     color: #049c9a; | 
|     background: #ffffff; | 
|     border-radius: 8px 8px 0px 0px; | 
|     border: 1px solid #049c9a; | 
|   } | 
| } | 
| </style> |