|  |  |  | 
|---|
|  |  |  | import { ref, onMounted, reactive, Ref, nextTick, computed } from 'vue' | 
|---|
|  |  |  | import { injectModel } from '@/libs/Provider/Provider' | 
|---|
|  |  |  | import { WmsMaterial } from '../Models/WmsMaterial' | 
|---|
|  |  |  | import { ElMessage } from 'element-plus' | 
|---|
|  |  |  | import { ConfirmBox } from '@/components/ConfirmBox/ConfirmBox' | 
|---|
|  |  |  | import { useFile } from './File' | 
|---|
|  |  |  |  | 
|---|
|  |  |  | interface CurrentType { | 
|---|
|  |  |  | row: any | 
|---|
|  |  |  | index: number | 
|---|
|  |  |  | } | 
|---|
|  |  |  | export const useWmsMaterial = (props: any, ctx?: any) => { | 
|---|
|  |  |  | const wmsMaterial = injectModel<WmsMaterial>('wmsMaterial') | 
|---|
|  |  |  | const { exportFile } = useFile() | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * å¤´é¨é
ç½® | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const headers = ref({}) | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * å¨æåé
ç½® | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const wmsMaterialColumns = ref<Record<string, any>>([]) | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * æç´¢å¼ | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const search = ref('') | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * æåº | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const sort = ref(0) | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * éæ©é¡¹ | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const selection = ref([]) | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * å½åéä¸çè¡ | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const current = ref<any>(null) | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * æ°æ®æº | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const dataSource: Ref<any[]> = ref([]) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * è¡¨æ ¼ | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const tableRef = ref() | 
|---|
|  |  |  | const dialogConfig = reactive({ | 
|---|
|  |  |  | visible: false, | 
|---|
|  |  |  | title: '', | 
|---|
|  |  |  | isAdd: false, | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | const dialogConfigForQuery = reactive({ | 
|---|
|  |  |  | visible: false, | 
|---|
|  |  |  | title: '', | 
|---|
|  |  |  | isAdd: false, | 
|---|
|  |  |  | }) | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const dialogSettingConfig = reactive({ | 
|---|
|  |  |  | visible: false, | 
|---|
|  |  |  | title: '', | 
|---|
|  |  |  | }) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * åé¡µæ°æ® | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const paginationParams = ref({}) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * æå¼è¯¦æ | 
|---|
|  |  |  | * @param row | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const openDetail = (row: any) => { | 
|---|
|  |  |  | current.value = row | 
|---|
|  |  |  | dialogConfig.visible = true | 
|---|
|  |  |  | dialogConfig.title = row.name | 
|---|
|  |  |  | dialogConfig.isAdd = false | 
|---|
|  |  |  | sort.value = row.sort | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const contextMenu = [ | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: 'å±å¼è¯¦æ
', | 
|---|
|  |  |  | fn: (c: CurrentType) => { | 
|---|
|  |  |  | current.value = null | 
|---|
|  |  |  | sort.value = c.row.sort | 
|---|
|  |  |  | nextTick(() => openDetail(c.row)) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | divided: true, | 
|---|
|  |  |  | icon: 'o', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // { | 
|---|
|  |  |  | //   label: 'å䏿·»å ', | 
|---|
|  |  |  | //   fn: (c: CurrentType, pageNum: number) => { | 
|---|
|  |  |  | //     current.value = null | 
|---|
|  |  |  | //     sort.value = c.index + 1 + (pageNum - 1) * 50 | 
|---|
|  |  |  | //     dialogConfig.visible = true | 
|---|
|  |  |  | //     dialogConfig.title = 'æ·»å ' | 
|---|
|  |  |  | //     dialogConfig.isAdd = false | 
|---|
|  |  |  | //   }, | 
|---|
|  |  |  | //   divided: true, | 
|---|
|  |  |  | //   icon: 'up', | 
|---|
|  |  |  | // }, | 
|---|
|  |  |  | // { | 
|---|
|  |  |  | //   label: 'å䏿·»å ', | 
|---|
|  |  |  | //   fn: (c: CurrentType, pageNum: number) => { | 
|---|
|  |  |  | //     current.value = null | 
|---|
|  |  |  | //     sort.value = c.index + 2 + (pageNum - 1) * 50 | 
|---|
|  |  |  | //     dialogConfig.visible = true | 
|---|
|  |  |  | //     dialogConfig.title = 'æ·»å ' | 
|---|
|  |  |  | //     dialogConfig.isAdd = false | 
|---|
|  |  |  | //   }, | 
|---|
|  |  |  | //   divided: true, | 
|---|
|  |  |  | //   icon: 'down', | 
|---|
|  |  |  | // }, | 
|---|
|  |  |  | // { | 
|---|
|  |  |  | //   label: 'åå»ºå¯æ¬', | 
|---|
|  |  |  | //   fn: async ({ row }: CurrentType) => { | 
|---|
|  |  |  | //     await wmsMaterial.cloneData([row.id]) | 
|---|
|  |  |  | //     ElMessage.success('åå»ºå¯æ¬æå') | 
|---|
|  |  |  | //     tableRef.value?.getList() | 
|---|
|  |  |  | //   }, | 
|---|
|  |  |  | //   divided: true, | 
|---|
|  |  |  | //   icon: 'copy', | 
|---|
|  |  |  | // }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: 'å é¤', | 
|---|
|  |  |  | fn: async (c: CurrentType) => { | 
|---|
|  |  |  | const names = selection.value.map((item: { name: string }) => item.name) | 
|---|
|  |  |  | ConfirmBox( | 
|---|
|  |  |  | `æ¯å¦å é¤${names.length ? names.join(',') : c.row.name}` | 
|---|
|  |  |  | ).then(async () => { | 
|---|
|  |  |  | const ids = selection.value.map((item: { id: string }) => item.id) | 
|---|
|  |  |  | await wmsMaterial.deleteWmsMaterials(ids.length ? ids : [c.row.id]) | 
|---|
|  |  |  | ElMessage.success('å é¤æå') | 
|---|
|  |  |  | tableRef.value.getList() | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | icon: 'close', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | ] | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const onCheck = (records: any) => { | 
|---|
|  |  |  | selection.value = records | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const onAddWmsMaterial = () => { | 
|---|
|  |  |  | const params = tableRef.value?.getPaginationParams() | 
|---|
|  |  |  | current.value = null | 
|---|
|  |  |  | dialogConfig.visible = true | 
|---|
|  |  |  | dialogConfig.isAdd = true | 
|---|
|  |  |  | dialogConfig.title = 'æ·»å ' | 
|---|
|  |  |  | sort.value = params.totalCount + 1 | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //ç¹å»æé®ãé«çº§æ¥è¯¢ã | 
|---|
|  |  |  | const onAdvancedQuery = () => { | 
|---|
|  |  |  | const params = tableRef.value?.getPaginationParams() | 
|---|
|  |  |  | current.value = null | 
|---|
|  |  |  | dialogConfigForQuery.visible = true | 
|---|
|  |  |  | dialogConfigForQuery.isAdd = true | 
|---|
|  |  |  | dialogConfigForQuery.title = 'é«çº§æ¥è¯¢' | 
|---|
|  |  |  | } | 
|---|
|  |  |  | import { ref, onMounted, reactive, Ref, nextTick, computed } from 'vue' | 
|---|
|  |  |  | import { injectModel } from '@/libs/Provider/Provider' | 
|---|
|  |  |  | import { WmsMaterial } from '../Models/WmsMaterial' | 
|---|
|  |  |  | import { ElMessage } from 'element-plus' | 
|---|
|  |  |  | import { ConfirmBox } from '@/components/ConfirmBox/ConfirmBox' | 
|---|
|  |  |  | import { useFile } from './File' | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const onConfirmWmsMaterial = async () => { | 
|---|
|  |  |  | dialogConfig.visible = false | 
|---|
|  |  |  | if (dialogConfig.isAdd) { | 
|---|
|  |  |  | tableRef.value?.scrollToRow({ | 
|---|
|  |  |  | skip: true, | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | await tableRef.value?.getList() | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * è¡ç¹å»æ¶æ´æ°current | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const onRowClick = ({ row }: any) => { | 
|---|
|  |  |  | if (dialogConfig.visible && current.value) { | 
|---|
|  |  |  | current.value = row | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * å¯¼åº | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const onExport = () => { | 
|---|
|  |  |  | const params = tableRef.value?.getParams() | 
|---|
|  |  |  | exportFile('/api/v1/hIAWms/wmsMaterial/export', params, 'hIAWms') | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * å
³é®åæç´¢ | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const onSearch = () => { | 
|---|
|  |  |  | tableRef.value?.getList({ | 
|---|
|  |  |  | Filter: search.value, | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * éç½®è¡¨æ ¼æ°æ® | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const reloadList = () => { | 
|---|
|  |  |  | tableRef.value?.getList() | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * ä¸ä¼ æå | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const onSuccess = () => { | 
|---|
|  |  |  | tableRef.value?.getList() | 
|---|
|  |  |  | ElMessage.success('导å
¥æå') | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * å¤±è´¥ | 
|---|
|  |  |  | * @param err | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const onError = (err: any) => { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | const message = JSON.parse(err.message) | 
|---|
|  |  |  | ElMessage.error(message.msg) | 
|---|
|  |  |  | } catch (error) { | 
|---|
|  |  |  | ElMessage.error('导å
¥å¤±è´¥') | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * ä¸ä¼ é©å | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const onBeforeUpload = (file: File) => { | 
|---|
|  |  |  | const format = ['xlsx', 'xls', 'csv'] | 
|---|
|  |  |  | if (!format.includes(file.name.split('.')[1])) { | 
|---|
|  |  |  | ElMessage.error('导å
¥æä»¶æ ¼å¼ä¸æ£ç¡®ï¼è¯·å¯¼å
¥.xlsx/.xlsä¸.csvæ ¼å¼çæä»¶') | 
|---|
|  |  |  | return false | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return true | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | onMounted(() => { | 
|---|
|  |  |  | headers.value = { | 
|---|
|  |  |  | Authorization: `Bearer ${sessionStorage.getItem('Token')}`, | 
|---|
|  |  |  | 'X-Project': sessionStorage.getItem('X-Project'), | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ctx.expose({ | 
|---|
|  |  |  | reloadList, | 
|---|
|  |  |  | }) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | dataSource, | 
|---|
|  |  |  | contextMenu, | 
|---|
|  |  |  | dialogConfig, | 
|---|
|  |  |  | dialogConfigForQuery, | 
|---|
|  |  |  | dialogSettingConfig, | 
|---|
|  |  |  | tableRef, | 
|---|
|  |  |  | current, | 
|---|
|  |  |  | search, | 
|---|
|  |  |  | sort, | 
|---|
|  |  |  | wmsMaterialColumns, | 
|---|
|  |  |  | paginationParams, | 
|---|
|  |  |  | headers, | 
|---|
|  |  |  | onBeforeUpload, | 
|---|
|  |  |  | onError, | 
|---|
|  |  |  | onSuccess, | 
|---|
|  |  |  | openDetail, | 
|---|
|  |  |  | onSearch, | 
|---|
|  |  |  | onExport, | 
|---|
|  |  |  | onRowClick, | 
|---|
|  |  |  | onConfirmWmsMaterial, | 
|---|
|  |  |  | onCheck, | 
|---|
|  |  |  | onAddWmsMaterial, | 
|---|
|  |  |  | onAdvancedQuery | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | interface CurrentType { | 
|---|
|  |  |  | row: any | 
|---|
|  |  |  | index: number | 
|---|
|  |  |  | } | 
|---|
|  |  |  | export const useWmsMaterial = (props: any, ctx?: any) => { | 
|---|
|  |  |  | const wmsMaterial = injectModel<WmsMaterial>('wmsMaterial') | 
|---|
|  |  |  | const { exportFile } = useFile() | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * å¤´é¨é
ç½® | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const headers = ref({}) | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * å¨æåé
ç½® | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const wmsMaterialColumns = ref<Record<string, any>>([]) | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * æç´¢å¼ | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const search = ref('') | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * æåº | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const sort = ref(0) | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * éæ©é¡¹ | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const selection = ref([]) | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * å½åéä¸çè¡ | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const current = ref<any>(null) | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * æ°æ®æº | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const dataSource: Ref<any[]> = ref([]) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * è¡¨æ ¼ | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const tableRef = ref() | 
|---|
|  |  |  | const dialogConfig = reactive({ | 
|---|
|  |  |  | visible: false, | 
|---|
|  |  |  | title: '', | 
|---|
|  |  |  | isAdd: false, | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | const dialogConfigForQuery = reactive({ | 
|---|
|  |  |  | visible: false, | 
|---|
|  |  |  | title: '', | 
|---|
|  |  |  | isAdd: false, | 
|---|
|  |  |  | }) | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const dialogSettingConfig = reactive({ | 
|---|
|  |  |  | visible: false, | 
|---|
|  |  |  | title: '', | 
|---|
|  |  |  | }) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * åé¡µæ°æ® | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const paginationParams = ref({}) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * æå¼è¯¦æ | 
|---|
|  |  |  | * @param row | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const openDetail = (row: any) => { | 
|---|
|  |  |  | current.value = row | 
|---|
|  |  |  | dialogConfig.visible = true | 
|---|
|  |  |  | dialogConfig.title = row.name | 
|---|
|  |  |  | dialogConfig.isAdd = false | 
|---|
|  |  |  | sort.value = row.sort | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const contextMenu = [ | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: 'å±å¼è¯¦æ
', | 
|---|
|  |  |  | fn: (c: CurrentType) => { | 
|---|
|  |  |  | current.value = null | 
|---|
|  |  |  | sort.value = c.row.sort | 
|---|
|  |  |  | nextTick(() => openDetail(c.row)) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | divided: true, | 
|---|
|  |  |  | icon: 'o', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // { | 
|---|
|  |  |  | //   label: 'å䏿·»å ', | 
|---|
|  |  |  | //   fn: (c: CurrentType, pageNum: number) => { | 
|---|
|  |  |  | //     current.value = null | 
|---|
|  |  |  | //     sort.value = c.index + 1 + (pageNum - 1) * 50 | 
|---|
|  |  |  | //     dialogConfig.visible = true | 
|---|
|  |  |  | //     dialogConfig.title = 'æ·»å ' | 
|---|
|  |  |  | //     dialogConfig.isAdd = false | 
|---|
|  |  |  | //   }, | 
|---|
|  |  |  | //   divided: true, | 
|---|
|  |  |  | //   icon: 'up', | 
|---|
|  |  |  | // }, | 
|---|
|  |  |  | // { | 
|---|
|  |  |  | //   label: 'å䏿·»å ', | 
|---|
|  |  |  | //   fn: (c: CurrentType, pageNum: number) => { | 
|---|
|  |  |  | //     current.value = null | 
|---|
|  |  |  | //     sort.value = c.index + 2 + (pageNum - 1) * 50 | 
|---|
|  |  |  | //     dialogConfig.visible = true | 
|---|
|  |  |  | //     dialogConfig.title = 'æ·»å ' | 
|---|
|  |  |  | //     dialogConfig.isAdd = false | 
|---|
|  |  |  | //   }, | 
|---|
|  |  |  | //   divided: true, | 
|---|
|  |  |  | //   icon: 'down', | 
|---|
|  |  |  | // }, | 
|---|
|  |  |  | // { | 
|---|
|  |  |  | //   label: 'åå»ºå¯æ¬', | 
|---|
|  |  |  | //   fn: async ({ row }: CurrentType) => { | 
|---|
|  |  |  | //     await wmsMaterial.cloneData([row.id]) | 
|---|
|  |  |  | //     ElMessage.success('åå»ºå¯æ¬æå') | 
|---|
|  |  |  | //     tableRef.value?.getList() | 
|---|
|  |  |  | //   }, | 
|---|
|  |  |  | //   divided: true, | 
|---|
|  |  |  | //   icon: 'copy', | 
|---|
|  |  |  | // }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: 'å é¤', | 
|---|
|  |  |  | fn: async (c: CurrentType) => { | 
|---|
|  |  |  | const names = selection.value.map((item: { name: string }) => item.name) | 
|---|
|  |  |  | ConfirmBox( | 
|---|
|  |  |  | `æ¯å¦å é¤${names.length ? names.join(',') : c.row.name}` | 
|---|
|  |  |  | ).then(async () => { | 
|---|
|  |  |  | const ids = selection.value.map((item: { id: string }) => item.id) | 
|---|
|  |  |  | await wmsMaterial.deleteWmsMaterials(ids.length ? ids : [c.row.id]) | 
|---|
|  |  |  | ElMessage.success('å é¤æå') | 
|---|
|  |  |  | tableRef.value.getList() | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | icon: 'close', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | ] | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const onCheck = (records: any) => { | 
|---|
|  |  |  | selection.value = records | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const onAddWmsMaterial = () => { | 
|---|
|  |  |  | const params = tableRef.value?.getPaginationParams() | 
|---|
|  |  |  | current.value = null | 
|---|
|  |  |  | dialogConfig.visible = true | 
|---|
|  |  |  | dialogConfig.isAdd = true | 
|---|
|  |  |  | dialogConfig.title = 'æ·»å ' | 
|---|
|  |  |  | sort.value = params.totalCount + 1 | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //ç¹å»æé®ãé«çº§æ¥è¯¢ã | 
|---|
|  |  |  | const onAdvancedQuery = () => { | 
|---|
|  |  |  | const params = tableRef.value?.getPaginationParams() | 
|---|
|  |  |  | current.value = null | 
|---|
|  |  |  | dialogConfigForQuery.visible = true | 
|---|
|  |  |  | dialogConfigForQuery.isAdd = true | 
|---|
|  |  |  | dialogConfigForQuery.title = 'é«çº§æ¥è¯¢' | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const onConfirmWmsMaterial = async () => { | 
|---|
|  |  |  | dialogConfig.visible = false | 
|---|
|  |  |  | if (dialogConfig.isAdd) { | 
|---|
|  |  |  | tableRef.value?.scrollToRow({ | 
|---|
|  |  |  | skip: true, | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | await tableRef.value?.getList() | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * è¡ç¹å»æ¶æ´æ°current | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const onRowClick = ({ row }: any) => { | 
|---|
|  |  |  | if (dialogConfig.visible && current.value) { | 
|---|
|  |  |  | current.value = row | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * å¯¼åº | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const onExport = (data={}) => { | 
|---|
|  |  |  | //const params = tableRef.value?.getParams() | 
|---|
|  |  |  | exportFile('/api/v1/hIAWms/wmsMaterial/export', data, 'hIAWms') | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * å
³é®åæç´¢ | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const onSearch = () => { | 
|---|
|  |  |  | tableRef.value?.getList({ | 
|---|
|  |  |  | Filter: search.value, | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * éç½®è¡¨æ ¼æ°æ® | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const reloadList = () => { | 
|---|
|  |  |  | tableRef.value?.getList() | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * ä¸ä¼ æå | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const onSuccess = () => { | 
|---|
|  |  |  | tableRef.value?.getList() | 
|---|
|  |  |  | ElMessage.success('导å
¥æå') | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * å¤±è´¥ | 
|---|
|  |  |  | * @param err | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const onError = (err: any) => { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | const message = JSON.parse(err.message) | 
|---|
|  |  |  | ElMessage.error(message.msg) | 
|---|
|  |  |  | } catch (error) { | 
|---|
|  |  |  | ElMessage.error('导å
¥å¤±è´¥') | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * ä¸ä¼ é©å | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | const onBeforeUpload = (file: File) => { | 
|---|
|  |  |  | const format = ['xlsx', 'xls', 'csv'] | 
|---|
|  |  |  | if (!format.includes(file.name.split('.')[1])) { | 
|---|
|  |  |  | ElMessage.error('导å
¥æä»¶æ ¼å¼ä¸æ£ç¡®ï¼è¯·å¯¼å
¥.xlsx/.xlsä¸.csvæ ¼å¼çæä»¶') | 
|---|
|  |  |  | return false | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return true | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | onMounted(() => { | 
|---|
|  |  |  | headers.value = { | 
|---|
|  |  |  | Authorization: `Bearer ${sessionStorage.getItem('Token')}`, | 
|---|
|  |  |  | 'X-Project': sessionStorage.getItem('X-Project'), | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ctx.expose({ | 
|---|
|  |  |  | reloadList, | 
|---|
|  |  |  | }) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | dataSource, | 
|---|
|  |  |  | contextMenu, | 
|---|
|  |  |  | dialogConfig, | 
|---|
|  |  |  | dialogConfigForQuery, | 
|---|
|  |  |  | dialogSettingConfig, | 
|---|
|  |  |  | tableRef, | 
|---|
|  |  |  | current, | 
|---|
|  |  |  | search, | 
|---|
|  |  |  | sort, | 
|---|
|  |  |  | wmsMaterialColumns, | 
|---|
|  |  |  | paginationParams, | 
|---|
|  |  |  | headers, | 
|---|
|  |  |  | onBeforeUpload, | 
|---|
|  |  |  | onError, | 
|---|
|  |  |  | onSuccess, | 
|---|
|  |  |  | openDetail, | 
|---|
|  |  |  | onSearch, | 
|---|
|  |  |  | onExport, | 
|---|
|  |  |  | onRowClick, | 
|---|
|  |  |  | onConfirmWmsMaterial, | 
|---|
|  |  |  | onCheck, | 
|---|
|  |  |  | onAddWmsMaterial, | 
|---|
|  |  |  | onAdvancedQuery | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|