| import { computed, defineComponent, onMounted, reactive, ref } from 'vue' | 
| import type { Ref } from 'vue' | 
| import BaseTable from '@/components/Table/Table' | 
| import styles from './WmsContainer.module.scss' | 
| import { useWmsContainer } from '../../../Controllers/WmsContainer' | 
| import IconButton from '@/components/IconButton/IconButton' | 
| import WmsContainerDrawer from '../Dialog/WmsContainerDrawer/WmsContainerDrawer' | 
| import WmsContainerQueryDrawer from '../Dialog/WmsContainerQueryDrawer/WmsContainerQueryDrawer' | 
| import Search from '@/components/Search/Search' | 
| import { columns } from './Config' | 
| import TdButton from '@/components/TdButton/TdButton' | 
| import { vPermission } from '@/libs/Permission/Permission' | 
| import dayjs from 'dayjs' | 
| import { getWmsEnumData } from '@/widgets/WmsContainer/Models/Service/WmsContainerDrawer' | 
| import { | 
|   ElInput, | 
|   ElSelect, | 
|   ElOption, | 
|   ElDatePicker, | 
|   ElForm, | 
|   ElFormItem, | 
| } from 'element-plus' | 
| import { injectModel } from '@/libs/Provider/Provider' | 
| // 引入公共选项配置 | 
| import { FILTER_MODE_OPTIONS_STRING } from '@/components/DyFormForHighQuery/DyFormForHighQueryOptions' | 
|   | 
| interface RenderTableType { | 
|   url?: string | 
|   dataSource: Ref<any[]> | 
|   isDrag?: boolean | 
|   isChecked?: boolean | 
|   isHidePagination?: boolean | 
|   params?: Record<string, any> | 
|   autoHeight?: boolean | 
| } | 
|   | 
| export default defineComponent({ | 
|   name: 'WmsContainer', | 
|   directives: { | 
|     permission: vPermission, | 
|   }, | 
|   setup(props, ctx) { | 
|     const { | 
|       dataSource, | 
|       contextMenu, | 
|       dialogConfig, | 
|       dialogConfigForQuery, | 
|       tableRef, | 
|       current, | 
|       search, | 
|       sort, | 
|       headers, | 
|       onError, | 
|       onSearch, | 
|       onRowClick, | 
|       onConfirmWmsContainer, | 
|       onCheck, | 
|       onAddWmsContainer, | 
|       onAdvancedQuery, | 
|       onExport, | 
|       openDetail, | 
|       onSuccess, | 
|       onBeforeUpload, | 
|     } = useWmsContainer(props, ctx) | 
|   | 
|     //定义高级查询引用 | 
|     const wmsContainerQueryDrawerRef = ref(null) | 
|     // 新增的查询条件 | 
|     const queryForm = ref({ | 
|       searchVal: '', | 
|       str_searchFormInputAttrs: [], | 
|       searchVal_FilterMode: '', | 
|     }) | 
|     //定义整体模糊查询的列数组(注意:必须大小写跟后端的实体类属性名一致,否则会导致匹配不对的问题) | 
|     const _searchFormInputAttrs = ref(['ContainerNo']) | 
|     const searchFormInputAttrs_Placeholder = ref('请输入托盘编号') | 
|   | 
|     // 动态枚举选项 | 
|     const enumOptions = reactive({ | 
|       containerType: [] as Array<{ label: string; value: any }>, | 
|       containerStatus: [] as Array<{ label: string; value: any }>, | 
|     }) | 
|   | 
|     // 获取枚举数据 | 
|     const fetchEnumData = async () => { | 
|       try { | 
|         const containerTypeEnumData = await getWmsEnumData({ | 
|           EnumName: 'ContainerTypeEnum', | 
|         }) | 
|         enumOptions.containerType = containerTypeEnumData.map((item) => ({ | 
|           label: item.description, | 
|           value: item.value, | 
|         })) | 
|         const containerStatusEnumData = await getWmsEnumData({ | 
|           EnumName: 'ContainerStatusEnum', | 
|         }) | 
|         enumOptions.containerStatus = containerStatusEnumData.map((item) => ({ | 
|           label: item.description, | 
|           value: item.value, | 
|         })) | 
|       } catch (error) { | 
|         console.error('获取枚举数据失败:', error) | 
|       } | 
|     } | 
|   | 
|     // 定义响应式查询数据 | 
|     const _curHighQueryData = ref({ | 
|       searchVal: '', | 
|       str_searchFormInputAttrs: [], | 
|       searchVal_FilterMode: '', | 
|     }) | 
|     // 组件挂载时获取枚举数据 | 
|     onMounted(() => { | 
|       fetchEnumData() | 
|       queryForm.value.searchVal_FilterMode = | 
|         FILTER_MODE_OPTIONS_STRING[0]?.value || '' | 
|       _curHighQueryData.value.searchVal_FilterMode = | 
|         queryForm.value.searchVal_FilterMode | 
|       _curHighQueryData.value.str_searchFormInputAttrs = | 
|         _searchFormInputAttrs.value | 
|     }) | 
|   | 
|     // 新版的查询方法(主页面中的按钮【查询】) | 
|     const handleQueryForMain = async () => { | 
|       _curHighQueryData.value.searchVal = queryForm.value.searchVal | 
|       _curHighQueryData.value.searchVal_FilterMode = | 
|         queryForm.value.searchVal_FilterMode | 
|       _curHighQueryData.value.str_searchFormInputAttrs = | 
|         _searchFormInputAttrs.value | 
|       tableRef.value.getList(_curHighQueryData.value) | 
|     } | 
|     // 新版的查询方法(高级查询中的按钮【查询】) | 
|     const handleQuery = async (extraParams = {}) => { | 
|       let filteredData = commonGetHighQueryForm(extraParams) | 
|       commonSaveCurHighQueryData(filteredData) | 
|       tableRef.value.getList(filteredData) | 
|     } | 
|     // 新版的查询重置 | 
|     const resetQuery = () => { | 
|       queryForm.value.searchVal = '' | 
|       queryForm.value.searchVal_FilterMode = | 
|         FILTER_MODE_OPTIONS_STRING[0]?.value || '' | 
|       queryForm.value.str_searchFormInputAttrs = _searchFormInputAttrs.value | 
|     } | 
|     //新版的导出方法 | 
|     const handleExport = () => { | 
|       onExport(_curHighQueryData.value) | 
|     } | 
|     // 新版的查询弹出框关闭方法 | 
|     const closeQuery = (extraParams = {}) => { | 
|       let filteredData = commonGetHighQueryForm(extraParams) | 
|       console.log('closeQuery方法') | 
|       console.log(filteredData) | 
|       commonSaveCurHighQueryData(filteredData) | 
|     } | 
|     //保存查询值 | 
|     const commonSaveCurHighQueryData = (filteredData = {}) => { | 
|       _curHighQueryData.value = { ..._curHighQueryData.value, ...filteredData } | 
|       _curHighQueryData.value.searchVal = queryForm.value.searchVal | 
|       _curHighQueryData.value.searchVal_FilterMode = | 
|         queryForm.value.searchVal_FilterMode | 
|       _curHighQueryData.value.str_searchFormInputAttrs = | 
|         _searchFormInputAttrs.value | 
|     } | 
|     //获取高级查询弹出框的查询值 | 
|     const commonGetHighQueryForm = (extraParams = {}) => { | 
|       // 过滤掉 undefined 的值 | 
|       let filteredData = Object.assign( | 
|         {}, | 
|         ...Object.entries(extraParams).map(([key, value]) => | 
|           value !== undefined ? { [key]: value } : {} | 
|         ) | 
|       ) | 
|       //组合模糊查询 | 
|       filteredData.searchVal = queryForm.value.searchVal | 
|       filteredData.searchVal_FilterMode = queryForm.value.searchVal_FilterMode | 
|       filteredData.str_searchFormInputAttrs = _searchFormInputAttrs.value | 
|       return filteredData | 
|     } | 
|   | 
|     /** | 
|      * @returns 表格 | 
|      */ | 
|     const RenderBaseTable = (props: RenderTableType) => { | 
|       const { | 
|         url, | 
|         dataSource, | 
|         isDrag, | 
|         isChecked, | 
|         isHidePagination, | 
|         params, | 
|         autoHeight, | 
|       } = props | 
|   | 
|       return ( | 
|         <div | 
|           class={{ | 
|             [styles.wmsContainerList]: true, | 
|           }} | 
|         > | 
|           <BaseTable | 
|             ref={tableRef} | 
|             url={url} | 
|             sortUrlTpl="/api/v1/HIAWms/wmsContainer/{id}/adjustsort/{sort}" | 
|             v-model:dataSource={dataSource.value} | 
|             columns={columns} | 
|             contextMenu={contextMenu} | 
|             params={params} | 
|             isDrag={isDrag} | 
|             isChecked={isChecked} | 
|             autoHeight={autoHeight} | 
|             onCheck={onCheck} | 
|             onRowClick={onRowClick} | 
|             isHidePagination={isHidePagination} | 
|             pageSize={20} | 
|             v-slots={{ | 
|               isDisabled: ({ row }: any) => { | 
|                 return ( | 
|                   <div> | 
|                     {row.isDisabled != null | 
|                       ? row.isDisabled | 
|                         ? '是' | 
|                         : '否' | 
|                       : '-'} | 
|                   </div> | 
|                 ) | 
|               }, | 
|               creationTime: ({ row }: any) => { | 
|                 return ( | 
|                   <div> | 
|                     {row.creationTime != null | 
|                       ? dayjs(row.creationTime).format('YYYY-MM-DD HH:mm:ss') | 
|                       : '-'} | 
|                   </div> | 
|                 ) | 
|               }, | 
|               lastModificationTime: ({ row }: any) => { | 
|                 return ( | 
|                   <div> | 
|                     {row.lastModificationTime != null | 
|                       ? dayjs(row.lastModificationTime).format( | 
|                           'YYYY-MM-DD HH:mm:ss' | 
|                         ) | 
|                       : '-'} | 
|                   </div> | 
|                 ) | 
|               }, | 
|               isDeleted: ({ row }: any) => { | 
|                 return ( | 
|                   <div> | 
|                     {row.isDeleted != null | 
|                       ? row.isDeleted | 
|                         ? '是' | 
|                         : '否' | 
|                       : '-'} | 
|                   </div> | 
|                 ) | 
|               }, | 
|               deletionTime: ({ row }: any) => { | 
|                 return ( | 
|                   <div> | 
|                     {row.deletionTime != null | 
|                       ? dayjs(row.deletionTime).format('YYYY-MM-DD HH:mm:ss') | 
|                       : '-'} | 
|                   </div> | 
|                 ) | 
|               }, | 
|               name: ({ row }: any) => { | 
|                 return row?.name ? ( | 
|                   <TdButton | 
|                     onClick={() => openDetail(row)} | 
|                     text={<span style="color:#5a84ff">详情</span>} | 
|                     icon="scale" | 
|                     tip={row?.name} | 
|                     hover | 
|                   > | 
|                     {row?.name} | 
|                   </TdButton> | 
|                 ) : ( | 
|                   '-' | 
|                 ) | 
|               }, | 
|             }} | 
|           ></BaseTable> | 
|         </div> | 
|       ) | 
|     } | 
|   | 
|     return () => { | 
|       return ( | 
|         <div class={styles.wmsContainerContent}> | 
|           {/* 添加/编辑 */} | 
|           <WmsContainerDrawer | 
|             v-model={dialogConfig.visible} | 
|             title={dialogConfig.title} | 
|             row={current.value} | 
|             sort={sort.value} | 
|             onConfirm={onConfirmWmsContainer} | 
|           /> | 
|           {/* 高级查询 */} | 
|           <WmsContainerQueryDrawer | 
|             ref="wmsContainerQueryDrawerRef" | 
|             v-model={dialogConfigForQuery.visible} | 
|             title={dialogConfigForQuery.title} | 
|             row={current.value} | 
|             sort={sort.value} | 
|             onConfirmQuery={handleQuery} | 
|             onRestQuery={resetQuery} | 
|             onClose={closeQuery} | 
|           /> | 
|   | 
|           <div class={styles.headerContent}> | 
|             <div class={styles.header}> | 
|               <IconButton | 
|                 v-permission="wmsContainer-add" | 
|                 icon="add-p" | 
|                 onClick={onAddWmsContainer} | 
|                 type="primary" | 
|               > | 
|                 添加 | 
|               </IconButton> | 
|               <el-divider direction="vertical" /> | 
|   | 
|               <el-upload | 
|                 v-permission="wmsContainer-import" | 
|                 name="file" | 
|                 accept=".xlsx,.xls,.csv" | 
|                 show-file-list={false} | 
|                 onError={onError} | 
|                 onSuccess={onSuccess} | 
|                 before-upload={onBeforeUpload} | 
|                 headers={headers.value} | 
|                 action="/api/v1/HIAWms/wmsContainer/import" | 
|               > | 
|                 <IconButton icon="in">导入</IconButton> | 
|               </el-upload> | 
|   | 
|               <IconButton | 
|                 v-permission="wmsContainer-output" | 
|                 icon="out" | 
|                 onClick={handleExport} | 
|               > | 
|                 导出 | 
|               </IconButton> | 
|             </div> | 
|             <ElFormItem style={{ marginTop: '15px' }}> | 
|               <ElFormItem label="关键字"> | 
|                 <el-tooltip | 
|                   class="box-item" | 
|                   effect="dark" | 
|                   content={searchFormInputAttrs_Placeholder.value} | 
|                   placement="top-start" | 
|                 > | 
|                   <ElInput | 
|                     v-model={queryForm.value.searchVal} | 
|                     placeholder={searchFormInputAttrs_Placeholder.value} | 
|                     clearable | 
|                     class={styles.formItem} | 
|                   /> | 
|                 </el-tooltip> | 
|               </ElFormItem> | 
|               <ElFormItem label="" style="width:100px;"> | 
|                 <ElSelect | 
|                   v-model={queryForm.value.searchVal_FilterMode} | 
|                   placeholder="请选择" | 
|                   class={styles.formItem} | 
|                 > | 
|                   {FILTER_MODE_OPTIONS_STRING.map((option) => ( | 
|                     <ElOption | 
|                       key={option.value} | 
|                       label={option.label} | 
|                       value={option.value} | 
|                     /> | 
|                   ))} | 
|                 </ElSelect> | 
|               </ElFormItem> | 
|               <IconButton | 
|                 type="primary" | 
|                 icon="search" | 
|                 onClick={handleQueryForMain} | 
|               > | 
|                 查询 | 
|               </IconButton> | 
|               {/* <IconButton style="" icon="refresh" onClick={resetQuery}>  | 
|                 重置  | 
|               </IconButton> */} | 
|               <IconButton | 
|                 v-permission="wmsContainer-add" | 
|                 icon="search" | 
|                 onClick={onAdvancedQuery} | 
|                 type="primary" | 
|               > | 
|                 高级查询 | 
|               </IconButton> | 
|             </ElFormItem> | 
|           </div> | 
|   | 
|           <RenderBaseTable | 
|             url="/api/v1/HIAWms/wmsContainer/page" | 
|             dataSource={dataSource} | 
|             isChecked={true} | 
|             isDrag={true} | 
|           /> | 
|         </div> | 
|       ) | 
|     } | 
|   }, | 
| }) |