From dc63cd71100864be7486b2a4e947017e0880880e Mon Sep 17 00:00:00 2001 From: Ben Lin <maobin001@msn.com> Date: 星期二, 17 十二月 2024 22:39:37 +0800 Subject: [PATCH] 一些更新 --- src/views/tigerprojects/system/lowcode/high/dtl.vue | 111 +++++++++++++++++++++++++++++++++++-------------------- 1 files changed, 71 insertions(+), 40 deletions(-) diff --git a/src/views/tigerprojects/system/lowcode/high/dtl.vue b/src/views/tigerprojects/system/lowcode/high/dtl.vue index 39fe51c..c8767a7 100644 --- a/src/views/tigerprojects/system/lowcode/high/dtl.vue +++ b/src/views/tigerprojects/system/lowcode/high/dtl.vue @@ -8,12 +8,12 @@ > <BasicTable @register="useTables[item.name]"> <template #toolbar> - <a-button type="primary" @click="handleCreate(index, item.name)" preIcon="add_02|svg"> + <a-button type="primary" @click="handleCreate(index, item)" preIcon="add_02|svg"> 鏂板 </a-button> </template> <template #action="{ record }"> - <TableAction :actions="createActions(record, index, item.name)" /> + <TableAction :actions="createActions(record, index, item)" /> </template> <template #[item]="{ field }" v-for="item in colSlots" :key="item"> <a-button @@ -42,13 +42,14 @@ import { useForm } from '/@/components/Form/index'; import GeneralModal from '/@/views/components/GeneralModal.vue'; import normalDrawer from '../normalDrawer.vue'; - import { isNullOrEmpty, isNullOrUnDef } from '/@/utils/is'; + import { isFunction, isNullOrEmpty, isNullOrUnDef } from '/@/utils/is'; import { useModal } from '/@/components/Modal'; import { useGo } from '/@/hooks/web/usePage'; import { DeleteEntity, getEntity } from '/@/api/tigerapi/system'; import { useI18n } from '/@/hooks/web/useI18n'; import { Card } from 'ant-design-vue'; import { EntityCustFunctionType } from '/@/api/tigerapi/model/basModel'; + import { useMessage } from '/@/hooks/web/useMessage'; const { t } = useI18n(); const ACard = Card; @@ -67,6 +68,7 @@ const keyFieldValues = inject('keyFieldValues') as Ref<Recordable[]>; const go = useGo(); + const { createErrorModal } = useMessage(); const [registerItemAdd, { openModal: openItemModal }] = useModal(); const cType = ref(''); const dtlSlots = ref([] as any[]); @@ -81,6 +83,7 @@ GetTitle(type: string | undefined) {}, GetUseTables(data: Ref<Recordable[]>, ...args) {}, GetUseDrawers() {}, + CustInitData(data: Ref<any[]>, keyFieldValues: Ref<{}>, type: string) {}, } as EntityCustFunctionType, ]); /* 鍔ㄦ�乮mport瀹炰綋鍚�.ts鐨勮嚜瀹氫箟鏂规硶 */ @@ -96,6 +99,7 @@ GetTitle, GetUseTables, GetUseDrawers, + CustInitData, }, ] = isNullOrUnDef(custImport.value['default']) ? EntityCustFunction.value @@ -133,15 +137,25 @@ } /* type: all-琛ㄧず闇�瑕乧ode鐨勬墍鏈夌殑鍊� */ if (drawers.value[i]['type'] == 'all') { - sqlcmd += ` And ${drawers.value[i]['code']} in (${data.value[drawers.value[i]['keyName']].map((value) => `'${value[drawers.value[i]['code']]}'`).join(',')})`; + if (data.value[drawers.value[i]['keyName']].length > 0) { + sqlcmd += ` And ${drawers.value[i]['code']} in (${data.value[drawers.value[i]['keyName']].map((value) => `'${value[drawers.value[i]['code']]}'`).join(',')})`; + } else { + sqlcmd = ' 1!=1 '; //鏂板鐨勬椂鍊欎笉鏌ユ暟鎹紝鏌ヤ篃娌℃湁 + } } const list = await getEntity({ sqlcmd: sqlcmd, - entityName: drawers.value[i].name, + entityName: isNullOrEmpty(drawers.value[i].dataType) + ? drawers.value[i].name + : drawers.value[i].dataType, order: drawers.value[i].order, }); if (!isNullOrEmpty(list.Data) && !isNullOrEmpty(list.Data.Items)) { data.value[drawers.value[i].name] = list.Data.Items; + // 鑷畾涔夊垵濮嬪寲鏁版嵁 + if (CustInitData && isFunction(CustInitData)) { + CustInitData(data, keyFieldValues, drawers.value[i].name); + } useTables[drawers.value[i].name][1].setProps({ dataSource: [], }); @@ -161,22 +175,25 @@ function createActions(record, index, item) { const params = { record, - isUpdate: true, - ifSave: true, - entityName: props.entityName, - formJson: [], //getFormSchema(`${entityName.value}_Crud`), - cType, + isUpdate: true, //鏄洿鏂拌繕鏄柊澧� + ifSave: objParams.value['ifSave'], //鏄惁鐩存帴淇濆瓨琛ㄥ崟鍒版暟鎹簱锛宖alse鐨勮瘽瑕佹渶鍚庝竴璧锋彁浜� + entityName: props.entityName, //瀹炰綋鍚嶇О + formJson: [], //getFormSchema(`${entityName.value}_Crud`), //琛ㄥ崟缁撴瀯 + cType, //绫诲瀷锛屼互姝ゆ潵纭畾鏄摢绉嶆柟娉曟垨鑰呯粨鏋勶紝鏍规嵁瀹為檯鎯呭喌鑰屽畾 dtlSlots, useModalData, useFormData, - crudColSlots: props.crudColSlots, + crudColSlots: isNullOrUnDef(objParams.value['crudColSlots']) + ? [] + : objParams.value['crudColSlots'][item['name']], //鎻掓Ы鍒楄〃 data, - name: item, //drawers鍒楄〃閲岄潰鐨刵ame锛岃〃绀烘槸鍝竴涓疄浣擄紝涔熷氨鏄珮绾ц〃鍗曚腑琛ㄦ牸鐨勫悕瀛� + name: item.name, //drawers鍒楄〃閲岄潰鐨刵ame锛岃〃绀烘槸鍝竴涓疄浣擄紝涔熷氨鏄珮绾ц〃鍗曚腑琛ㄦ牸鐨勫悕瀛� + keyName: item.keyName, //瀹為檯鐢ㄦ潵纭畾鍔ㄦ�佸紩鍏ュ疄浣�.ts鐨勫疄浣撳悕绉� }; const actionItem = [ { icon: 'clarity:note-edit-line', - onClick: editRecord.bind(null, useDrawers[index][item][1].openDrawer, params), + onClick: editRecord.bind(null, useDrawers[index][item.name][1].openDrawer, params), }, { icon: 'ant-design:delete-outlined', @@ -184,7 +201,7 @@ popConfirm: { title: '鏄惁纭鍒犻櫎?', placement: 'left', - confirm: deleteRecord.bind(null, useTables[item][1].reload, params), + confirm: deleteRecord.bind(null, useTables[item.name][1].reload, params), }, }, ]; @@ -194,13 +211,12 @@ return nActionItem( params, actionItem, - useDrawers[index][item][1].openDrawer, - useTables[item][1].reload, + useDrawers[index][item.name][1].openDrawer, + useTables, null, useForm, useModal, go, - useTables[item][1].setProps, ); } @@ -253,23 +269,31 @@ function handleCreate(index, item) { validate().then((res) => { const Keys = Object.getOwnPropertyNames(useFormData.value); - for (const t in drawers.value) { - for (const i in Keys) { - keyFieldValues.value[drawers.value[t]['code']] = objParams.value['IsID'] - ? res[Keys[i]]['ID'] - : res[Keys[i]][drawers.value[t]['code']]; + for (const i in Keys) { + const _Keys = Object.getOwnPropertyNames(res[Keys[i]]); + for (const j in _Keys) { + if (_Keys[j] == item['code']) { + keyFieldValues.value[item['code']] = objParams.value['IsID'] + ? res[Keys[i]]['ID'] + : res[Keys[i]][item['code']]; + } else if (_Keys[j] != 'ID') { + keyFieldValues.value[_Keys[j]] = res[Keys[i]][_Keys[j]]; + } } - useDrawers[index][item][1].openDrawer(true, { - isUpdate: false, - ifSave: true, - entityName: drawers.value[t]['name'], //props.entityName, - // formJson: GetCrudForm(item, data), //鑾峰彇澧炲垹鏀硅〃鍗曞瓧娈� - crudColSlots: props.crudColSlots, - keyFieldValues: keyFieldValues.value, - data, - name: item, //drawers鍒楄〃閲岄潰鐨刵ame锛岃〃绀烘槸鍝竴涓疄浣擄紝涔熷氨鏄珮绾ц〃鍗曚腑琛ㄦ牸鐨勫悕瀛� - }); } + useDrawers[index][item['name']][1].openDrawer(true, { + isUpdate: false, + ifSave: objParams.value['ifSave'], + entityName: item['name'], //props.entityName, + // formJson: GetCrudForm(item, data), //鑾峰彇澧炲垹鏀硅〃鍗曞瓧娈� + crudColSlots: isNullOrUnDef(objParams.value['crudColSlots']) + ? [] + : objParams.value['crudColSlots'][item['name']], + keyFieldValues: keyFieldValues.value, + data, + name: item['name'], //drawers鍒楄〃閲岄潰鐨刵ame锛岃〃绀烘槸鍝竴涓疄浣擄紝涔熷氨鏄珮绾ц〃鍗曚腑琛ㄦ牸鐨勫悕瀛� + keyName: item['keyName'], + }); }); } @@ -283,14 +307,21 @@ function handleSuccess(d, u, item) { if (!isNullOrUnDef(custImport.value)) { /* 鑷畾涔夌紪杈戞柟娉曪紝鏍规嵁瀹炰綋鍚嶅幓璋冪敤 */ - EditOperation(data, d, u, item); - useTables[item][1].setProps({ - dataSource: [], - }); - useTables[item][1].setProps({ - dataSource: data.value[item], - }); - useTables[item][1].reload(); + if (item == 'BAS_PKG_PROD' && data.value[item].some((q) => q.ITEM_CODE == d.ITEM_CODE) && !u) { + createErrorModal({ + title: t('sys.api.errorTip'), + content: t(`鏂欏彿[${d.ITEM_CODE}]宸茬粡瀛樺湪`), + }); + } else { + EditOperation(data, d, u, item); + useTables[item][1].setProps({ + dataSource: [], + }); + useTables[item][1].setProps({ + dataSource: data.value[item], + }); + useTables[item][1].reload(); + } } } -- Gitblit v1.9.3