| | |
| | | @change="getScheduledTableData" |
| | | /> |
| | | </el-form-item> |
| | | <el-form-item label="任务状态"> |
| | | <el-select v-model="scheduledFilters.status" placeholder="请选择任务状态" clearable style="width: 200px"> |
| | | <el-option label="启用" value="1" /> |
| | | <el-option label="停用" value="0" /> |
| | | <el-form-item label="是否启用"> |
| | | <el-select v-model="scheduledFilters.isEnabled" placeholder="请选择是否启用" clearable style="width: 200px"> |
| | | <el-option label="启用" :value="1" /> |
| | | <el-option label="禁用" :value="0" /> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item> |
| | |
| | | @selection-change="handleScheduledSelectionChange" |
| | | @pagination="changeScheduledPage" |
| | | > |
| | | <template #statusRef="{ row }"> |
| | | <el-tag v-if="row.status === 1" type="success">启用</el-tag> |
| | | <el-tag v-if="row.status === 0" type="danger">停用</el-tag> |
| | | <template #isEnabledRef="{ row }"> |
| | | <el-switch |
| | | v-model="row.isEnabled" |
| | | :active-value="1" |
| | | :inactive-value="0" |
| | | :loading="row.enableSwitchLoading" |
| | | :before-change="() => handleScheduledEnableBeforeChange(row)" |
| | | /> |
| | | </template> |
| | | <template #operation="{ row }"> |
| | | <el-button |
| | |
| | | delUpkeep, |
| | | deviceMaintenanceTaskList, |
| | | deviceMaintenanceTaskDel, |
| | | deviceMaintenanceTaskChangeEnable, |
| | | } from '@/api/equipmentManagement/upkeep' |
| | | import { |
| | | listMaintenanceTaskFiles, |
| | |
| | | // 定时任务管理tab相关变量 |
| | | const scheduledFilters = reactive({ |
| | | taskName: '', |
| | | status: '', |
| | | isEnabled: undefined, |
| | | }) |
| | | |
| | | const scheduledDataList = ref([]) |
| | |
| | | }, |
| | | { prop: "registrant", label: "登记人", minWidth: 100 }, |
| | | { prop: "registrationDate", label: "登记日期", minWidth: 100 }, |
| | | { |
| | | label: "是否启用", |
| | | prop: "isEnabled", |
| | | dataType: "slot", |
| | | slot: "isEnabledRef", |
| | | align: "center", |
| | | width: "120px", |
| | | }, |
| | | { |
| | | fixed: "right", |
| | | label: "操作", |
| | |
| | | current: scheduledPagination.currentPage, |
| | | size: scheduledPagination.pageSize, |
| | | taskName: scheduledFilters.taskName || undefined, |
| | | status: scheduledFilters.status || undefined, |
| | | isEnabled: scheduledFilters.isEnabled, |
| | | } |
| | | const { code, data } = await deviceMaintenanceTaskList(params) |
| | | if (code === 200) { |
| | | scheduledDataList.value = data?.records || [] |
| | | const records = data?.records || [] |
| | | scheduledDataList.value = records.map((item) => ({ |
| | | ...item, |
| | | isEnabled: Number(item.isEnabled ?? item.status ?? 1), |
| | | enableSwitchLoading: false, |
| | | })) |
| | | scheduledPagination.total = data?.total || 0 |
| | | } |
| | | } catch (error) { |
| | |
| | | |
| | | const resetScheduledFilters = () => { |
| | | scheduledFilters.taskName = '' |
| | | scheduledFilters.status = '' |
| | | scheduledFilters.isEnabled = undefined |
| | | getScheduledTableData() |
| | | } |
| | | |
| | |
| | | } |
| | | } |
| | | |
| | | const handleScheduledEnableBeforeChange = async (row) => { |
| | | if (row.enableSwitchLoading) { |
| | | return false |
| | | } |
| | | const nextValue = Number(row.isEnabled) === 1 ? 0 : 1 |
| | | row.enableSwitchLoading = true |
| | | try { |
| | | const res = await deviceMaintenanceTaskChangeEnable({ |
| | | id: row.id, |
| | | isEnabled: nextValue, |
| | | }) |
| | | if (res?.code !== 200) { |
| | | throw new Error(res?.msg || '更新失败') |
| | | } |
| | | ElMessage.success('启用状态已更新') |
| | | return true |
| | | } catch (error) { |
| | | ElMessage.error(error?.message || '启用状态更新失败') |
| | | return false |
| | | } finally { |
| | | row.enableSwitchLoading = false |
| | | } |
| | | } |
| | | |
| | | const handleScheduledOut = () => { |
| | | ElMessage.info('导出定时任务功能待实现') |
| | | } |