| <template> | 
|   <div class="app-container"> | 
|     <el-form | 
|       class="responsive-form" | 
|       :model="queryParams" | 
|       ref="queryRef" | 
|       :inline="true" | 
|       v-show="showSearch" | 
|       :label-width="locale === 'zh' ? '90px' : '200px'" | 
|     > | 
|       <el-row type="flex" justify="left"> | 
|         <el-col :span="locale === 'zh' ? 5 : 10"> | 
|           <el-form-item | 
|             :label="$t('plan.query.requireTraceID')" | 
|             prop="description" | 
|           > | 
|             <el-input | 
|               :style="{ width: locale === 'zh' ? '140px' : '300px' }" | 
|               v-model="queryParams.description" | 
|               :placeholder="`${$t('plan.placeholder.requireTraceID')}`" | 
|               clearable | 
|               @keyup.enter="handleQuery" | 
|             /> | 
|           </el-form-item> | 
|         </el-col> | 
|         <el-col :span="locale === 'zh' ? 8 : 9"> | 
|           <el-form-item :label="$t('plan.query.itemNumber')" prop="description"> | 
|             <el-input | 
|               :style="{ width: locale === 'zh' ? '140px' : '210px' }" | 
|               v-model="queryParams.description" | 
|               :placeholder="`${$t('common.common.placeholder')}${$t( | 
|                 'plan.query.itemNumber' | 
|               )}`" | 
|               clearable | 
|               @keyup.enter="handleQuery" | 
|             /> | 
|           </el-form-item> | 
|         </el-col> | 
|         <el-col :span="locale === 'zh' ? 11 : 5" style="text-align: right"> | 
|           <el-form-item class="column-with-margin"> | 
|             <el-button type="primary" icon="Search" @click="handleQuery">{{ | 
|               $t("common.common.query") | 
|             }}</el-button> | 
|             <el-button icon="Refresh" @click="resetQuery">{{ | 
|               $t("common.common.reset") | 
|             }}</el-button> | 
|           </el-form-item> | 
|         </el-col> | 
|       </el-row> | 
|     </el-form> | 
|   | 
|     <el-row :gutter="10" class="mb8"> | 
|       <el-col :span="1.5"> | 
|         <el-button | 
|           type="warning" | 
|           plain | 
|           icon="Download" | 
|           @click="handleExport" | 
|           v-hasPermi="['core:calendar:export']" | 
|           >{{ $t("common.common.export") }}</el-button | 
|         > | 
|       </el-col> | 
|       <right-toolbar | 
|         v-model:showSearch="showSearch" | 
|         @queryTable="getList" | 
|       ></right-toolbar> | 
|     </el-row> | 
|     <HxlhTable | 
|       style="width: 100%" | 
|       :columns="columns" | 
|       :data="calendarList" | 
|       :loading="loading" | 
|       :height="height" | 
|       ref="tableRef" | 
|       :page="page" | 
|       @changePageNo="changePageNo" | 
|       @changePageSize="changePageSize" | 
|       @on-checkbox="handleCheckboxChange" | 
|       class="auto-height-grid" | 
|     > | 
|     </HxlhTable> | 
|   </div> | 
| </template> | 
|   | 
| <script setup name="Calendar"> | 
| import HxlhTable from "@/components/HxlhTable"; | 
| import { | 
|   listCalendar, | 
|   getCalendar, | 
|   delCalendar, | 
|   addCalendar, | 
|   updateCalendar, | 
| } from "@/api/basicData/calendar"; | 
| import axios from "axios"; | 
| import { listAll_plant } from "@/api/basicData/plant"; | 
| import { listAll_shop, listAps_shop } from "@/api/basicData/shop"; | 
| import { selectProcessNameList } from "@/api/basicData/processRoute.js"; | 
| import { useI18n } from "vue-i18n"; //要在js中使用国际化 | 
| const { t, locale } = useI18n(); | 
| const { proxy } = getCurrentInstance(); | 
| const tableRef = ref(); | 
| const calendarList = ref([]); | 
| const loading = ref(true); | 
| const showSearch = ref(true); | 
| const ids = ref([]); | 
| const single = ref(true); | 
| const multiple = ref(true); | 
| const total = ref(0); | 
| const title = ref(""); | 
| const data = reactive({ | 
|   form: { | 
|     type: "1", | 
|   }, | 
|   queryParams: { | 
|     pageNum: 1, | 
|     pageSize: 10, | 
|     description: null, | 
|     type: null, | 
|     effectiveDate: null, | 
|     expiringDate: null, | 
|     content: null, | 
|     applicableFactory: null, | 
|     applicableWorkshop: null, | 
|     applicableProcess: null, | 
|   }, | 
| }); | 
| const { queryParams, form, rules } = toRefs(data); | 
| const typeRadioNumber = ref(1); | 
| const plantList = ref([]); | 
| const shopList = ref([]); | 
| const allShopList = ref([]); | 
| const processList = ref([]); | 
| const height = ref(document.documentElement.clientHeight - 220 + "px;"); | 
| // 表格配置-列表 | 
| const columns = ref([]); | 
| // 分页属性 | 
| const page = ref({ | 
|   total: 0, | 
|   current: 1, | 
|   size: 10, | 
| }); | 
| watch( | 
|   locale, | 
|   (newLocale) => { | 
|     columns.value = [ | 
|       { | 
|         title: t("plan.table.workOrderNo"), | 
|         field: "description", | 
|         width: 150, | 
|         align: "center", | 
|       }, | 
|       { | 
|         title: t("plan.table.subItemPartNumber"), | 
|         field: "type", | 
|         width: 200, | 
|         align: "center", | 
|       }, | 
|       { | 
|         title: t("plan.table.productionQuantity"), | 
|         field: "effectiveDate", | 
|         width: 200, | 
|         align: "center", | 
|       }, | 
|       { | 
|         title: t("plan.table.mismatchedProductionQuantity"), | 
|         field: "expiringDate", | 
|         width: 200, | 
|         align: "center", | 
|       }, | 
|       { | 
|         title: t("plan.table.applicableFactories"), | 
|         field: "applicableFactory", | 
|         width: 200, | 
|         align: "center", | 
|         formatter: ({ cellValue, row, column }) => { | 
|           if (cellValue) { | 
|             for (let i = 0; i < plantList.value.length; i++) { | 
|               if (cellValue === plantList.value[i].plantCode) { | 
|                 return plantList.value[i].plantName; | 
|               } | 
|             } | 
|           } | 
|         }, | 
|       }, | 
|       { | 
|         title: t("plan.table.productionBase"), | 
|         field: "expiringDate", | 
|         width: 200, | 
|         align: "center", | 
|       }, | 
|       { | 
|         title: t("plan.table.planStartDay"), | 
|         field: "createTime", | 
|         width: 200, | 
|         align: "center", | 
|       }, | 
|       { | 
|         title: t("plan.table.planEndDayDate"), | 
|         field: "updateTime", | 
|         width: 100, | 
|         align: "center", | 
|       }, | 
|       { | 
|         title: t("plan.table.workorderCreationTime"), | 
|         field: "updateTime", | 
|         width: 100, | 
|         align: "center", | 
|       }, | 
|     ]; | 
|   }, | 
|   { immediate: true, deep: true } | 
| ); | 
| /** 查询日历管理列表 */ | 
| function getList() { | 
|   loading.value = true; | 
|   listCalendar(queryParams.value).then((response) => { | 
|     calendarList.value = response.rows; | 
|     page.value.total = response.total; | 
|     loading.value = false; | 
|   }); | 
|   axios | 
|     .all([ | 
|       /** 查询工厂列表 */ | 
|       listAll_plant({}), | 
|       /** 查询车间列表 */ | 
|       listAll_shop({}), | 
|     ]) | 
|     .then( | 
|       axios.spread((response1, response2) => { | 
|         plantList.value = response1.data; | 
|         shopList.value = response2.data; | 
|         loading.value = false; | 
|       }) | 
|     ) | 
|     .catch((error) => { | 
|       console.error("请求出错:", error); | 
|     }); | 
| } | 
|   | 
| // 取消按钮 | 
| function cancel() { | 
|   open.value = false; | 
|   reset(); | 
| } | 
|   | 
| // 表单重置 | 
| function reset() { | 
|   form.value = { | 
|     id: null, | 
|     description: null, | 
|     type: "1", | 
|     effectiveDate: null, | 
|     expiringDate: null, | 
|     content: null, | 
|     applicableFactory: null, | 
|     applicableWorkshop: null, | 
|     applicableProcess: null, | 
|     createBy: null, | 
|     createTime: null, | 
|     updateBy: null, | 
|     updateTime: null, | 
|   }; | 
|   proxy.resetForm("calendarRef"); | 
| } | 
|   | 
| /** 搜索按钮操作 */ | 
| function handleQuery() { | 
|   queryParams.value.pageNum = 1; | 
|   getList(); | 
| } | 
|   | 
| /** 重置按钮操作 */ | 
| function resetQuery() { | 
|   proxy.resetForm("queryRef"); | 
|   handleQuery(); | 
| } | 
|   | 
| // 多选框选中数据 | 
| function handleSelectionChange(selection) { | 
|   ids.value = selection.map((item) => item.id); | 
|   single.value = selection.length != 1; | 
|   multiple.value = !selection.length; | 
| } | 
|   | 
| /** 新增按钮操作 */ | 
| async function handleAdd() { | 
|   reset(); | 
|   open.value = true; | 
|   title.value = "添加日历管理"; | 
| } | 
| /** 选择工厂后事件 加载车间 和 工序 **/ | 
| function changePlant(plant) { | 
|   listAps_shop({ plantCode: plant }).then((response) => { | 
|     shopList.value = response.rows; | 
|   }); | 
|   selectProcessNameList({ orgCode: plant }).then((response) => { | 
|     processList.value = response.rows; | 
|   }); | 
| } | 
| /** 修改按钮操作 */ | 
| function handleUpdate(row) { | 
|   reset(); | 
|   const _id = row.id || ids.value; | 
|   getCalendar(_id).then((response) => { | 
|     form.value = response.data; | 
|     // form.value.content = JSON.parse(response.data.content.value); | 
|     if (form.value.type === "1") { | 
|       weekDaysSettingList.value = JSON.parse( | 
|         response.data.content.value | 
|       ).weekdays; | 
|     } else if (form.value.type === "2") { | 
|       holidays.value = JSON.parse(response.data.content.value).holidays; | 
|     } | 
|   | 
|     open.value = true; | 
|     title.value = "修改日历管理"; | 
|   }); | 
| } | 
|   | 
| /** 提交按钮 */ | 
| function submitForm() { | 
|   proxy.$refs["calendarRef"].validate((valid) => { | 
|     if (valid) { | 
|       if (form.value.id != null) { | 
|         if (form.value.type === "1") { | 
|           updateCalendar({ | 
|             ...form.value, | 
|             content: { | 
|               weekdays: weekDaysSettingList.value, | 
|             }, | 
|             applicableWorkshop: form.value.applicableWorkshop, | 
|             applicableProcess: form.value.applicableProcess, | 
|           }).then((response) => { | 
|             proxy.$modal.msgSuccess("修改成功"); | 
|             open.value = false; | 
|             getList(); | 
|           }); | 
|         } else if (form.value.type === "2") { | 
|           updateCalendar({ | 
|             ...form.value, | 
|             content: { | 
|               holidays: holidays.value, | 
|             }, | 
|             applicableWorkshop: form.value.applicableWorkshop, | 
|             applicableProcess: form.value.applicableProcess, | 
|           }).then((response) => { | 
|             proxy.$modal.msgSuccess("修改成功"); | 
|             open.value = false; | 
|             getList(); | 
|           }); | 
|         } | 
|       } else { | 
|         if (form.value.type === "1") { | 
|           addCalendar({ | 
|             ...form.value, | 
|             content: { | 
|               weekdays: weekDaysSettingList.value, | 
|             }, | 
|           }).then((response) => { | 
|             proxy.$modal.msgSuccess("新增成功"); | 
|             open.value = false; | 
|             getList(); | 
|           }); | 
|         } else if (form.value.type === "2") { | 
|           addCalendar({ | 
|             ...form.value, | 
|             content: { | 
|               holidays: holidays.value, | 
|             }, | 
|           }).then((response) => { | 
|             proxy.$modal.msgSuccess("新增成功"); | 
|             open.value = false; | 
|             getList(); | 
|           }); | 
|         } | 
|       } | 
|     } | 
|   }); | 
| } | 
|   | 
| /** 删除按钮操作 */ | 
| function handleDelete(row) { | 
|   const _ids = row.id || ids.value; | 
|   proxy.$modal | 
|     .confirm('是否确认删除日历管理编号为"' + _ids + '"的数据项?') | 
|     .then(function () { | 
|       return delCalendar(_ids); | 
|     }) | 
|     .then(() => { | 
|       getList(); | 
|       proxy.$modal.msgSuccess("删除成功"); | 
|     }) | 
|     .catch(() => {}); | 
| } | 
|   | 
| /** 导出按钮操作 */ | 
| function handleExport() { | 
|   proxy.download( | 
|     "core/calendar/export", | 
|     { | 
|       ...queryParams.value, | 
|     }, | 
|     `calendar_${new Date().getTime()}.xlsx` | 
|   ); | 
| } | 
| function handleSwitchType(e) { | 
|   typeRadioNumber.value = e; | 
|   form.value.type = e; | 
|   form.value.effectiveDate = null; | 
|   form.value.expiringDate = null; | 
|   form.value.content = null; | 
|   form.value.applicableFactory = null; | 
|   form.value.applicableWorkshop = null; | 
|   form.value.applicableProcess = null; | 
| } | 
| function changePageNo(currentPage) { | 
|   queryParams.value.pageNum = currentPage; | 
|   page.value.current = currentPage; | 
|   getList(); | 
| } | 
| function changePageSize(pageSize) { | 
|   page.value.current = 1; | 
|   queryParams.value.pageNum = 1; | 
|   queryParams.value.pageSize = pageSize; | 
|   getList(); | 
| } | 
| // 多选框选中数据 | 
| const handleCheckboxChange = (data) => { | 
|   ids.value = data.records.map((item) => item.id); | 
|   single.value = data.records.length !== 1; | 
|   multiple.value = !data.records.length; | 
| }; | 
| onMounted(() => { | 
|   getList(); | 
| }); | 
| </script> | 
| <style lang="scss" scoped> | 
| .column-with-margin { | 
|   margin-right: 0px; | 
| } | 
| .title_bar_line { | 
|   display: flex; | 
|   justify-content: flex-start; | 
|   align-items: center; | 
|   color: #333; | 
|   margin-bottom: 10px; | 
|   .line_short { | 
|     width: 5%; | 
|     height: 1px; | 
|     margin-right: 20px; | 
|     border-top: 1px solid #ddd; | 
|   } | 
|   .line_long { | 
|     width: 60%; | 
|     height: 1px; | 
|     margin-left: 20px; | 
|     border-top: 1px solid #ddd; | 
|   } | 
| } | 
| .week_flex { | 
|   display: flex; | 
|   justify-content: flex-start; | 
|   align-content: center; | 
|   color: #606266; | 
|   font-weight: 700; | 
|   margin-left: 20px; | 
|   &.mt20 { | 
|     margin-top: 20px; | 
|     margin-left: 0 !important; | 
|   } | 
|   .week_flex_item { | 
|     &:nth-child(1) { | 
|       margin-top: 5px; | 
|     } | 
|     &:nth-child(2) { | 
|       margin-left: 20px; | 
|     } | 
|   } | 
| } | 
| .factory_use_item { | 
|   margin-top: 10px; | 
| } | 
| .mart5 { | 
|   margin-top: 5px; | 
| } | 
| .custom-height { | 
|   height: 200px; /* 或者使用 min-height */ | 
| } | 
| .auto-height-grid .xe-body .xe-body--row { | 
|   height: auto; /* 或者使用 min-height */ | 
| } | 
| </style> |