| | |
| | | </template> |
| | | </el-dialog> |
| | | <el-dialog v-model="scheduleDialogVisible" |
| | | :title="`生产排产(工单编号:${currentReportRowData?.workOrderNo || '-'})`" |
| | | :title="scheduleDialogTitle" |
| | | width="1000px" |
| | | :close-on-click-modal="false"> |
| | | <div class="schedule-panel"> |
| | | <el-row style="margin-bottom: 12px;"> |
| | | <el-row v-if="!isScheduleHistoryMode" style="margin-bottom: 12px;"> |
| | | <el-col> |
| | | <el-button type="primary" plain :disabled="scheduleLoading || scheduleSaving" @click="addScheduleRow"> |
| | | 新增一行 |
| | |
| | | filterable |
| | | clearable |
| | | style="width: 100%" |
| | | :disabled="scheduleSaving" |
| | | :disabled="scheduleSaving || isScheduleHistoryMode" |
| | | @change="val => handleScheduleDeviceChange(val, row)" |
| | | > |
| | | <el-option |
| | |
| | | |
| | | <el-table-column label="本次上机人" min-width="220"> |
| | | <template #default="{ row }"> |
| | | <div v-if="isScheduleHistoryMode" class="schedule-user-tags"> |
| | | <el-tag |
| | | v-for="(userId, index) in row.userIds" |
| | | :key="`${userId}-${index}`" |
| | | type="primary" |
| | | > |
| | | {{ resolveScheduleUserName(userId) }} |
| | | </el-tag> |
| | | <span v-if="!row.userIds?.length">-</span> |
| | | </div> |
| | | <el-select |
| | | v-else |
| | | v-model="row.userIds" |
| | | placeholder="请选择上机人" |
| | | filterable |
| | |
| | | format="YYYY-MM-DD HH:mm:ss" |
| | | placeholder="请选择上机时间" |
| | | style="width: 100%" |
| | | :disabled="scheduleSaving" |
| | | :disabled="scheduleSaving || isScheduleHistoryMode" |
| | | /> |
| | | </template> |
| | | </el-table-column> |
| | | |
| | | <el-table-column label="操作" width="110" align="center"> |
| | | <el-table-column v-if="!isScheduleHistoryMode" label="操作" width="110" align="center"> |
| | | <template #default="{ row }"> |
| | | <el-button |
| | | link |
| | |
| | | </el-table> |
| | | |
| | | <Pagination |
| | | v-show="schedulePage.total > 0" |
| | | v-show="isScheduleHistoryMode && schedulePage.total > 0" |
| | | style="margin-top: 12px" |
| | | :total="schedulePage.total" |
| | | :page="schedulePage.current" |
| | |
| | | |
| | | <template #footer> |
| | | <span class="dialog-footer"> |
| | | <el-button type="primary" :loading="scheduleSaving" @click="handleSaveSchedule">保存排产</el-button> |
| | | <el-button :disabled="scheduleSaving" @click="scheduleDialogVisible = false">取消</el-button> |
| | | <template v-if="isScheduleHistoryMode"> |
| | | <el-button @click="scheduleDialogVisible = false">关闭</el-button> |
| | | </template> |
| | | <template v-else> |
| | | <el-button type="primary" :loading="scheduleSaving" @click="handleSaveSchedule">保存排产</el-button> |
| | | <el-button :disabled="scheduleSaving" @click="scheduleDialogVisible = false">取消</el-button> |
| | | </template> |
| | | </span> |
| | | </template> |
| | | </el-dialog> |
| | |
| | | return; |
| | | } |
| | | |
| | | const first = scheduleRows.value[0] || {}; |
| | | const deviceId = first.deviceId || currentReportRowData.value?.deviceId || ""; |
| | | const userOptions = deviceId ? buildScheduleUserOptionsByDeviceId(deviceId) : [...baseScheduleUsers.value]; |
| | | const defaultUserId = userOptions[0]?.userId ? String(userOptions[0].userId) : ""; |
| | | |
| | | scheduleRows.value.push( |
| | | createScheduleRow({ |
| | | id: "", |
| | | deviceId, |
| | | deviceName: first.deviceName || currentReportRowData.value?.deviceName || "", |
| | | userIds: defaultUserId ? [defaultUserId] : [], |
| | | deviceId:"", |
| | | deviceName:"", |
| | | userIds: [], |
| | | startTime: dayjs().format("YYYY-MM-DD HH:mm:ss"), |
| | | }) |
| | | ); |
| | |
| | | if (!workOrderRow?.id) { |
| | | schedulePage.current = 1; |
| | | schedulePage.total = 0; |
| | | scheduleRows.value = [createScheduleRow({})]; |
| | | scheduleRows.value = []; |
| | | return; |
| | | } |
| | | |
| | |
| | | } |
| | | |
| | | const rows = records.map(record => mapMachineRecordToScheduleRow(record)); |
| | | scheduleRows.value = rows.length > 0 ? rows : [createScheduleRow({})]; |
| | | scheduleRows.value = rows; |
| | | } catch (error) { |
| | | console.error("获取排产记录失败", error); |
| | | schedulePage.total = 0; |
| | | scheduleRows.value = [createScheduleRow({})]; |
| | | scheduleRows.value = []; |
| | | ElMessage.error("获取排产记录失败"); |
| | | } finally { |
| | | scheduleLoading.value = false; |
| | |
| | | }; |
| | | |
| | | const removeScheduleRow = async (row) => { |
| | | if (!row) return; |
| | | if (!row || isScheduleHistoryMode.value) return; |
| | | |
| | | if (!row.id) { |
| | | scheduleRows.value = scheduleRows.value.filter((item) => item !== row); |
| | | if (!scheduleRows.value.length) { |
| | | scheduleRows.value = [createScheduleRow({})]; |
| | | addScheduleRow(); |
| | | } |
| | | return; |
| | | } |
| | |
| | | }; |
| | | |
| | | const handleSchedulePagination = ({page, limit}) => { |
| | | if (!isScheduleHistoryMode.value) return; |
| | | schedulePage.current = page; |
| | | schedulePage.size = limit; |
| | | refreshScheduleRows(); |
| | |
| | | return (schedulePage.current - 1) * schedulePage.size + index + 1; |
| | | }; |
| | | |
| | | const scheduleDialogMode = ref("create"); |
| | | const isScheduleHistoryMode = computed(() => scheduleDialogMode.value === "history"); |
| | | const scheduleDialogTitle = computed(() => |
| | | `${isScheduleHistoryMode.value ? "排产记录" : "生产排产"}(工单编号:${currentReportRowData.value?.workOrderNo || "-"})` |
| | | ); |
| | | |
| | | const mapMachineRecordToScheduleRow = (record) => { |
| | | const id = record?.id ?? ""; |
| | | const deviceId = record?.machineId ?? record?.deviceId ?? ""; |
| | |
| | | ); |
| | | }; |
| | | |
| | | const resetCreateScheduleRows = () => { |
| | | schedulePage.current = 1; |
| | | schedulePage.total = 0; |
| | | scheduleRows.value = []; |
| | | addScheduleRow(); |
| | | }; |
| | | |
| | | const openScheduleDialog = async (row) => { |
| | | scheduleDialogMode.value = "create"; |
| | | currentReportRowData.value = row; |
| | | baseScheduleUsers.value = buildBaseScheduleUsersByRow(row); |
| | | userTemp.value = [...baseScheduleUsers.value]; |
| | | scheduleDialogVisible.value = true; |
| | | resetCreateScheduleRows(); |
| | | }; |
| | | |
| | | const openHistoryTimelineDialog = async (row) => { |
| | | scheduleDialogMode.value = "history"; |
| | | currentReportRowData.value = row; |
| | | baseScheduleUsers.value = buildBaseScheduleUsersByRow(row); |
| | | userTemp.value = [...baseScheduleUsers.value]; |
| | | schedulePage.current = 1; |
| | | schedulePage.total = 0; |
| | | scheduleRows.value = []; |
| | | scheduleDialogVisible.value = true; |
| | | |
| | |
| | | }; |
| | | |
| | | const handleSaveSchedule = async () => { |
| | | if (isScheduleHistoryMode.value) return; |
| | | if (scheduleSaving.value) return; |
| | | if (!validateScheduleRows()) return; |
| | | |
| | |
| | | } |
| | | |
| | | proxy.$modal.msgSuccess("排产已保存"); |
| | | await refreshScheduleRows(); |
| | | resetCreateScheduleRows(); |
| | | getList(); |
| | | } catch (error) { |
| | | console.error("保存排产失败", error); |
| | |
| | | }, |
| | | { |
| | | label: "操作", |
| | | width: "200", |
| | | width: "220", |
| | | align: "center", |
| | | dataType: "action", |
| | | fixed: "right", |
| | |
| | | showReportDialog(row); |
| | | }, |
| | | // 用户当前id |
| | | disabled: row => row.completeQuantity !==0 || |
| | | disabled: row => row.completeQuantity >= row.planQuantity || |
| | | !isCurrentUserInUserIds(row) |
| | | }, |
| | | { |
| | |
| | | openScheduleDialog(row); |
| | | }, |
| | | disabled: row => !row.canSchedule || row.completeQuantity >= row.planQuantity |
| | | }, |
| | | { |
| | | name: "排产记录", |
| | | clickFun: row => { |
| | | if (!row.canSchedule) { |
| | | ElMessage.warning("当前用户不在该工序人员中,不能查看排产记录"); |
| | | return; |
| | | } |
| | | openHistoryTimelineDialog(row); |
| | | }, |
| | | disabled: row => !row.canSchedule |
| | | } |
| | | // { |
| | | // name:"审核", |
| | |
| | | justify-content: flex-start; |
| | | } |
| | | } |
| | | |
| | | .schedule-user-tags { |
| | | display: flex; |
| | | flex-wrap: wrap; |
| | | gap: 8px; |
| | | min-height: 32px; |
| | | align-items: center; |
| | | } |
| | | </style> |
| | | |
| | | <style lang="scss"> |