| <template> | 
|   <div class="wmsContainerPackaging-container"> | 
|     <el-card shadow="hover" :body-style="{ paddingBottom: '0' }">  | 
|       <el-form :model="queryParams" ref="queryForm" labelWidth="90"> | 
|         <el-row> | 
|           <el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="showAdvanceQueryUI"> | 
|             <el-form-item label="容器类型ID"> | 
|               <el-select clearable="" v-model="queryParams.containerTypeId" placeholder="请选择容器类型ID"> | 
|                 <el-option v-for="(item,index) in dl('')" :key="index" :value="item.code" :label="`[${item.code}] ${item.value}`" /> | 
|                  | 
|               </el-select> | 
|                | 
|             </el-form-item> | 
|           </el-col> | 
|           <el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="showAdvanceQueryUI"> | 
|             <el-form-item label="物料类型ID"> | 
|               <el-select clearable="" v-model="queryParams.materialTypeId" placeholder="请选择物料类型ID"> | 
|                 <el-option v-for="(item,index) in dl('')" :key="index" :value="item.code" :label="`[${item.code}] ${item.value}`" /> | 
|                  | 
|               </el-select> | 
|                | 
|             </el-form-item> | 
|           </el-col> | 
|           <el-col :xs="24" :sm="12" :md="12" :lg="6" :xl="6" class="mb10"> | 
|             <el-form-item> | 
|               <el-button-group style="display: flex; align-items: center;"> | 
|                 <el-button type="primary"  icon="ele-Search" @click="handleQuery" v-auth="'wmsContainerPackaging:page'"> 查询 </el-button> | 
|                       <el-button icon="ele-Refresh" @click="() => queryParams = {}"> 重置 </el-button> | 
|                 <el-button type="primary" style="margin-left:5px;" icon="ele-Plus" @click="openAddWmsContainerPackaging" v-auth="'wmsContainerPackaging:add'"> 新增 </el-button> | 
|                  | 
|               </el-button-group> | 
|             </el-form-item> | 
|              | 
|           </el-col> | 
|         </el-row> | 
|       </el-form> | 
|     </el-card> | 
|     <el-card class="full-table" shadow="hover" style="margin-top: 5px"> | 
|       <el-table | 
|                 :data="tableData" | 
|                 style="width: 100%" | 
|                 v-loading="loading" | 
|                 tooltip-effect="light" | 
|                                 row-key="id" | 
|                 @sort-change="sortChange" | 
|                 border=""> | 
|         <el-table-column type="index" label="序号" width="55" align="center"/> | 
|           <el-table-column prop="containerTypeId" label="容器类型ID"  show-overflow-tooltip="" > | 
|             <template #default="scope"> | 
|               <el-tag :type="di('', scope.row.containerTypeId)?.tagType"> {{di("", scope.row.containerTypeId)?.value}} </el-tag> | 
|             </template> | 
|           </el-table-column> | 
|         <el-table-column prop="containerTypeName" label="容器类型名称"  show-overflow-tooltip="" /> | 
|           <el-table-column prop="materialTypeId" label="物料类型ID"  show-overflow-tooltip="" > | 
|             <template #default="scope"> | 
|               <el-tag :type="di('', scope.row.materialTypeId)?.tagType"> {{di("", scope.row.materialTypeId)?.value}} </el-tag> | 
|             </template> | 
|           </el-table-column> | 
|         <el-table-column prop="materialTypeCode" label="物料类型编号"  show-overflow-tooltip="" /> | 
|         <el-table-column prop="materialTypeName" label="物料类型名称"  show-overflow-tooltip="" /> | 
|         <el-table-column prop="boxQty" label="物料容器容量"  show-overflow-tooltip="" /> | 
|         <el-table-column prop="createTime" label="创建时间"  show-overflow-tooltip=""  width="130px" /> | 
|         <el-table-column prop="updateTime" label="修改时间"  show-overflow-tooltip=""  width="130px" /> | 
|         <el-table-column prop="createUserName" label="创建人"  show-overflow-tooltip=""/> | 
|         <el-table-column prop="updateUserName" label="修改人"  show-overflow-tooltip="" /> | 
|         <el-table-column label="操作" width="140" align="center" fixed="right" show-overflow-tooltip="" v-if="auth('wmsContainerPackaging:update') || auth('wmsContainerPackaging:delete')"> | 
|           <template #default="scope"> | 
|             <el-button icon="ele-Edit" size="small" text="" type="primary" @click="openEditWmsContainerPackaging(scope.row)" v-auth="'wmsContainerPackaging:update'"> 编辑 </el-button> | 
|             <el-button icon="ele-Delete" size="small" text="" type="primary" @click="delWmsContainerPackaging(scope.row)" v-auth="'wmsContainerPackaging:delete'"> 删除 </el-button> | 
|           </template> | 
|         </el-table-column> | 
|       </el-table> | 
|       <el-pagination | 
|                 v-model:currentPage="tableParams.page" | 
|                 v-model:page-size="tableParams.pageSize" | 
|                 :total="tableParams.total" | 
|                 :page-sizes="[10, 20, 50, 100, 200, 500]" | 
|                 small="" | 
|                 background="" | 
|                 @size-change="handleSizeChange" | 
|                 @current-change="handleCurrentChange" | 
|                 layout="total, sizes, prev, pager, next, jumper" | 
|     /> | 
|       <printDialog | 
|         ref="printDialogRef" | 
|         :title="printWmsContainerPackagingTitle" | 
|         @reloadTable="handleQuery" /> | 
|       <editDialog | 
|         ref="editDialogRef" | 
|         :title="editWmsContainerPackagingTitle" | 
|         @reloadTable="handleQuery" | 
|       /> | 
|     </el-card> | 
|   </div> | 
| </template> | 
|   | 
| <script lang="ts" setup="" name="wmsContainerPackaging"> | 
|   import { ref } from "vue"; | 
|   import { ElMessageBox, ElMessage } from "element-plus"; | 
|   import { auth } from '/@/utils/authFunction'; | 
|   import { getDictDataItem as di, getDictDataList as dl } from '/@/utils/dict-utils'; | 
|   import { formatDate } from '/@/utils/formatTime'; | 
|   | 
|   | 
|   import printDialog from '/@/views/system/print/component/hiprint/preview.vue' | 
|   import editDialog from '/@/views/main/WmsBase/wmsContainerPackaging/component/editDialog.vue' | 
|   import { pageWmsContainerPackaging, deleteWmsContainerPackaging } from '/@/api/main/WmsBase/wmsContainerPackaging'; | 
|   | 
|   | 
|   const showAdvanceQueryUI = ref(true); | 
|   const printDialogRef = ref(); | 
|   const editDialogRef = ref(); | 
|   const loading = ref(false); | 
|   const tableData = ref<any>([]); | 
|   const queryParams = ref<any>({}); | 
|   const tableParams = ref({ | 
|     page: 1, | 
|     pageSize: 10, | 
|     total: 0, | 
|   }); | 
|   | 
|   const printWmsContainerPackagingTitle = ref(""); | 
|   const editWmsContainerPackagingTitle = ref(""); | 
|   | 
|   // 改变高级查询的控件显示状态 | 
|   const changeAdvanceQueryUI = () => { | 
|     showAdvanceQueryUI.value = !showAdvanceQueryUI.value; | 
|   } | 
|    | 
|   | 
|   // 查询操作 | 
|   const handleQuery = async () => { | 
|     loading.value = true; | 
|     var res = await pageWmsContainerPackaging(Object.assign(queryParams.value, tableParams.value)); | 
|     tableData.value = res.data.result?.items ?? []; | 
|     tableParams.value.total = res.data.result?.total; | 
|     loading.value = false; | 
|   }; | 
|   | 
|   // 列排序 | 
|   const sortChange = async (column: any) => { | 
|     queryParams.value.field = column.prop; | 
|     queryParams.value.order = column.order; | 
|     await handleQuery(); | 
|   }; | 
|   | 
|   // 打开新增页面 | 
|   const openAddWmsContainerPackaging = () => { | 
|     editWmsContainerPackagingTitle.value = '添加容器关系基础'; | 
|     editDialogRef.value.openDialog({}); | 
|   }; | 
|   | 
|   // 打开打印页面 | 
|   const openPrintWmsContainerPackaging = async (row: any) => { | 
|     printWmsContainerPackagingTitle.value = '打印容器关系基础'; | 
|   } | 
|    | 
|   // 打开编辑页面 | 
|   const openEditWmsContainerPackaging = (row: any) => { | 
|     editWmsContainerPackagingTitle.value = '编辑容器关系基础'; | 
|     editDialogRef.value.openDialog(row); | 
|   }; | 
|   | 
|   // 删除 | 
|   const delWmsContainerPackaging = (row: any) => { | 
|     ElMessageBox.confirm(`确定要删除吗?`, "提示", { | 
|     confirmButtonText: "确定", | 
|     cancelButtonText: "取消", | 
|     type: "warning", | 
|   }) | 
|   .then(async () => { | 
|     var  ret = await deleteWmsContainerPackaging(row); | 
|     if(ret.data.type=="success"){ | 
|       ElMessage.success("删除成功"); | 
|       handleQuery(); | 
|     } | 
|   }) | 
|   .catch(() => {}); | 
|   }; | 
|   | 
|   // 改变页面容量 | 
|   const handleSizeChange = (val: number) => { | 
|     tableParams.value.pageSize = val; | 
|     handleQuery(); | 
|   }; | 
|   | 
|   // 改变页码序号 | 
|   const handleCurrentChange = (val: number) => { | 
|     tableParams.value.page = val; | 
|     handleQuery(); | 
|   }; | 
|   | 
|   handleQuery(); | 
| </script> | 
| <style scoped> | 
| :deep(.el-input), | 
| :deep(.el-select), | 
| :deep(.el-input-number) { | 
|     width: 100%; | 
| } | 
| </style> |