From 1225fbcf6dd197c39853e2cb0f70c7318836abcb Mon Sep 17 00:00:00 2001 From: zs <zhousong@weben-smart.com> Date: 周一, 19 5月 2025 16:53:12 +0800 Subject: [PATCH] 仓库信息高级查询 --- HIAWms/hiawms_web/src/widgets/WmsStoreInfo/Views/Pages/WmsArea/WmsArea.tsx | 282 ++++++++++++++++++++++++++++++-------------------------- 1 files changed, 151 insertions(+), 131 deletions(-) diff --git a/HIAWms/hiawms_web/src/widgets/WmsStoreInfo/Views/Pages/WmsArea/WmsArea.tsx b/HIAWms/hiawms_web/src/widgets/WmsStoreInfo/Views/Pages/WmsArea/WmsArea.tsx index 0ff3d54..3765110 100644 --- a/HIAWms/hiawms_web/src/widgets/WmsStoreInfo/Views/Pages/WmsArea/WmsArea.tsx +++ b/HIAWms/hiawms_web/src/widgets/WmsStoreInfo/Views/Pages/WmsArea/WmsArea.tsx @@ -14,6 +14,9 @@ getWmsEnumData, getStoreDataList, } from '@/widgets/HIAWms/Models/Service/WmsMaterialDrawer' +// 寮曞叆鍏叡閫夐」閰嶇疆 +import { FILTER_MODE_OPTIONS_STRING } from '@/components/DyFormForHighQuery/DyFormForHighQueryOptions' +import WmsAreaQueryDrawer from '../Dialog/WmsAreaQueryDrawer/WmsAreaQueryDrawer' interface RenderTableType { url?: string @@ -35,6 +38,7 @@ dataSource, contextMenu, dialogConfig, + dialogConfigForQuery, tableRef, current, search, @@ -45,6 +49,7 @@ onRowClick, onConfirmWmsArea, onCheck, + onAdvancedQuery, onAddWmsArea, onExport, openDetail, @@ -52,44 +57,38 @@ onBeforeUpload, } = useWmsArea(props, ctx) + //瀹氫箟楂樼骇鏌ヨ寮曠敤 + const wmsAreaQueryDrawerRef = ref(null) // 鏂板鐨勬煡璇㈡潯浠� const queryForm = ref({ - areaNo: '', - areaName: '', - areaType: '', - areaStatus: '', - filter: '', + searchVal: '', + str_searchFormInputAttrs: [], + searchVal_FilterMode: '', }) - - const queryParams = computed(() => ({ - ...queryForm.value, - areaType: queryForm.value.areaType || '', // 澶勭悊涓嬫媺 - areaStatus: queryForm.value.areaStatus || '', - })) + //瀹氫箟鏁翠綋妯$硦鏌ヨ鐨勫垪鏁扮粍(娉ㄦ剰锛氬繀椤诲ぇ灏忓啓璺熷悗绔殑瀹炰綋绫诲睘鎬у悕涓�鑷达紝鍚﹀垯浼氬鑷村尮閰嶄笉瀵圭殑闂) + const _searchFormInputAttrs = ref(['AreaNo', 'AreaName']) + const searchFormInputAttrs_Placeholder = ref('璇疯緭鍏ュ簱鍖虹紪鍙�/搴撳尯鍚嶇О') // 鍔ㄦ�佹灇涓鹃�夐」 const enumOptions = reactive({ - areaType: [] as Array<{ label: string; value: any }>, areaStatus: [] as Array<{ label: string; value: any }>, + areaType: [] as Array<{ label: string; value: any }>, }) // 鑾峰彇鏋氫妇鏁版嵁 const fetchEnumData = async () => { try { - // 鑾峰彇鐗╂枡绫诲瀷鏋氫妇 - const areaTypeData = await getWmsEnumData({ - EnumName: 'AreaTypeEnum', + const areaStatusEnumData = await getWmsEnumData({ + EnumName: 'AreaStatusEnum', }) - enumOptions.areaType = areaTypeData.map((item) => ({ + enumOptions.areaStatus = areaStatusEnumData.map((item) => ({ label: item.description, value: item.value, })) - - // 鑾峰彇閲囪喘绫诲瀷鏋氫妇 - const areaStatusData = await getWmsEnumData({ - EnumName: 'AreaStatusEnum', + const areaTypeEnumData = await getWmsEnumData({ + EnumName: 'AreaTypeEnum', }) - enumOptions.areaStatus = areaStatusData.map((item) => ({ + enumOptions.areaType = areaTypeEnumData.map((item) => ({ label: item.description, value: item.value, })) @@ -98,28 +97,80 @@ } } + // 瀹氫箟鍝嶅簲寮忔煡璇㈡暟鎹� + 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 handleQuery = async () => { - // tableRef.value.getTableList() - tableRef.value.getList(queryParams.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 = { - areaNo: '', - areaName: '', - areaType: '', - areaStatus: '', - filter: '', - } + 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 琛ㄦ牸 */ @@ -187,94 +238,17 @@ sort={sort.value} onConfirm={onConfirmWmsArea} /> - {/* 鏂板鐨勬煡璇㈣〃鍗� */} - <ElForm - inline - model={queryForm.value} - class={styles.queryForm} - label-width="80px" - > - <ElFormItem label="鍏抽敭瀛�"> - <ElInput - v-model={queryForm.value.filter} - placeholder="璇疯緭鍏ュ叧閿瓧鎼滅储" - clearable - class={styles.formItem} - /> - </ElFormItem> - <ElFormItem label="搴撳尯缂栫爜"> - <ElInput - v-model={queryForm.value.areaNo} - placeholder="璇疯緭鍏ュ簱鍖虹紪鐮�" - clearable - class={styles.formItem} - /> - </ElFormItem> - <ElFormItem label="搴撳尯鍚嶇О"> - <ElInput - v-model={queryForm.value.areaName} - placeholder="璇疯緭鍏ュ簱鍖哄悕绉�" - clearable - class={styles.formItem} - /> - </ElFormItem> - <ElFormItem label="搴撲綅绫诲瀷"> - <ElSelect - v-model={queryForm.value.areaType} - placeholder="璇烽�夋嫨鎵樼洏绫诲瀷" - clearable - loading={enumOptions.areaType.length === 0} - class={styles.formItem} - > - {enumOptions.areaType.map((option) => ( - <ElOption - key={option.value} - label={option.label} - value={option.value} - /> - ))} - </ElSelect> - </ElFormItem> - <ElFormItem label="搴撳尯鐘舵��"> - <ElSelect - v-model={queryForm.value.areaStatus} - placeholder="璇烽�夋嫨鎵樼洏鐘舵��" - clearable - loading={enumOptions.areaStatus.length === 0} - class={styles.formItem} - > - {enumOptions.areaStatus.map((option) => ( - <ElOption - key={option.value} - label={option.label} - value={option.value} - /> - ))} - </ElSelect> - </ElFormItem> - {/* <ElFormItem label="鏃ユ湡鑼冨洿"> - <ElDatePicker - v-model={queryForm.value.dateRange} - type="daterange" - range-separator="鑷�" - start-placeholder="寮�濮嬫棩鏈�" - end-placeholder="缁撴潫鏃ユ湡" - value-format="YYYY-MM-DD" - /> - </ElFormItem> */} - <ElFormItem> - <IconButton type="primary" icon="search" onClick={handleQuery}> - 鏌ヨ - </IconButton> - <IconButton - style="margin-left: 10px;" - icon="refresh" - onClick={resetQuery} - > - 閲嶇疆 - </IconButton> - </ElFormItem> - </ElForm> + {/* 楂樼骇鏌ヨ */} + <WmsAreaQueryDrawer + ref="wmsAreaQueryDrawerRef" + 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}> @@ -287,6 +261,7 @@ 娣诲姞 </IconButton> <el-divider direction="vertical" /> + <el-upload v-permission="wmsArea-import" name="file" @@ -304,20 +279,65 @@ <IconButton v-permission="wmsArea-output" icon="out" - onClick={onExport} + onClick={handleExport} > 瀵煎嚭 </IconButton> </div> - {/* <Search - placeholder="璇疯緭鍏ュ叧閿瓧" - v-model={search.value} - onConfirm={onSearch} - style={{ marginTop: '-1px' }} - /> */} + <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="wmsArea-add" + icon="search" + onClick={onAdvancedQuery} + type="primary" + > + 楂樼骇鏌ヨ + </IconButton> + </ElFormItem> </div> + <RenderBaseTable - url="/api/v1/HIAWms/wmsArea" + url="/api/v1/HIAWms/wmsArea/page" dataSource={dataSource} isChecked={true} isDrag={true} -- Gitblit v1.9.3