| | |
| | | <template #action="{ record }"> |
| | | <TableAction :actions="createActions(record)" /> |
| | | </template> |
| | | <template #form-add="{ field }"> |
| | | <a-button |
| | | v-if="field" |
| | | class="mt-1 ml-1" |
| | | size="small" |
| | | @click="handleSelectItem" |
| | | preIcon="search|svg" |
| | | /> |
| | | <NormalModal @register="registerItemAdd" @success="handleItemSuccess" /> |
| | | </template> |
| | | </BasicTable> |
| | | <normalDrawer @register="registerDrawer" @success="handleSuccess" /> |
| | | </div> |
| | | </template> |
| | | <script lang="ts" setup> |
| | | import { h, onMounted, ref } from 'vue'; |
| | | import { h, onMounted, ref, unref } from 'vue'; |
| | | import { BasicTable, useTable, TableAction, BasicColumn, FormSchema } from '/@/components/Table'; |
| | | import { useDrawer } from '/@/components/Drawer'; |
| | | import normalDrawer from './normalDrawer.vue'; |
| | | import { getEntity, getListByPage } from '/@/api/tigerapi/system'; |
| | | import NormalModal from '/@/views/components/NormalModal.vue'; |
| | | import { GetEnum, getEntity, getListByPage } from '/@/api/tigerapi/system'; |
| | | import { useGlobSetting } from '/@/hooks/setting'; |
| | | import { useRoute } from 'vue-router'; |
| | | import { Tag, Tooltip } from 'ant-design-vue'; |
| | | import { isNullOrEmpty } from '/@/utils/is'; |
| | | import { GetActionColumn, GetActionsData } from './data'; |
| | | import { GetActionColumn, GetActionsData, OpenSelectItem, GetSelectSuccess } from './data'; |
| | | import { useModal } from '/@/components/Modal'; |
| | | import { useLocale } from '/@/locales/useLocale'; |
| | | |
| | | const { getLocale } = useLocale(); |
| | | const route = useRoute(); |
| | | const objParams = ref(JSON.parse(decodeURI(route.params?.id as string))); |
| | | const entityName = ref(objParams.value.ID); |
| | | const globSetting = useGlobSetting(); |
| | | const _columns = ref([]); |
| | | const _searchFormSchema = ref([]); |
| | | const _crudFormSchema = ref([]); |
| | | const [registerItemAdd, { openModal: openItemModal }] = useModal(); |
| | | const [registerDrawer, { openDrawer }] = useDrawer(); |
| | | const [registerTable, { reload }] = useTable({ |
| | | const [registerTable, { getForm, reload }] = useTable({ |
| | | title: '列表信息', |
| | | api: getListByPage, |
| | | searchInfo: { TABLE_NAME: objParams.value.ID }, |
| | |
| | | sqlcmd: "ASSEMBLY_NAME ='" + objParams.value.ID + "'", |
| | | entityName: 'SYS_LOW_CODE', |
| | | }); |
| | | _searchFormSchema.value = JSON.parse(data.Data.Items[0].SEARCH_FORM_JSON); |
| | | _crudFormSchema.value = JSON.parse(data.Data.Items[0].FORM_JSON); |
| | | var searchForms = JSON.parse(data.Data.Items[0].SEARCH_FORM_JSON); |
| | | for (const i in searchForms) { |
| | | if ( |
| | | !isNullOrEmpty(searchForms[i].componentProps) && |
| | | !isNullOrEmpty(searchForms[i].componentProps.api) && |
| | | searchForms[i].componentProps.api == 'GetEnum' |
| | | ) { |
| | | searchForms[i].componentProps.api = GetEnum; |
| | | searchForms[i].componentProps.params.name = `${objParams.value.ID}+${searchForms[i].field}s`; |
| | | searchForms[i].componentProps.labelField = unref(getLocale) == 'zh_CN' ? 'Desc' : 'Name'; |
| | | } |
| | | if ( |
| | | !isNullOrEmpty(searchForms[i].componentProps) && |
| | | !isNullOrEmpty(searchForms[i].componentProps.api) && |
| | | searchForms[i].componentProps.api == 'getEntity' |
| | | ) { |
| | | searchForms[i].componentProps.api = getEntity; |
| | | searchForms[i].componentProps.resultField = 'Data.Items'; |
| | | } |
| | | } |
| | | _searchFormSchema.value = searchForms; |
| | | var _cruds = JSON.parse(data.Data.Items[0].FORM_JSON); |
| | | for (const i in _cruds) { |
| | | if ( |
| | | !isNullOrEmpty(_cruds[i].componentProps) && |
| | | !isNullOrEmpty(_cruds[i].componentProps.api) && |
| | | _cruds[i].componentProps.api == 'GetEnum' |
| | | ) { |
| | | _cruds[i].componentProps.api = GetEnum; |
| | | _cruds[i].componentProps.params.name = `${objParams.value.ID}+${_cruds[i].field}s`; |
| | | _cruds[i].componentProps.labelField = unref(getLocale) == 'zh_CN' ? 'Desc' : 'Name'; |
| | | } |
| | | if ( |
| | | !isNullOrEmpty(_cruds[i].componentProps) && |
| | | !isNullOrEmpty(_cruds[i].componentProps.api) && |
| | | _cruds[i].componentProps.api == 'getEntity' |
| | | ) { |
| | | _cruds[i].componentProps.api = getEntity; |
| | | _cruds[i].componentProps.resultField = 'Data.Items'; |
| | | } |
| | | } |
| | | _crudFormSchema.value = _cruds; |
| | | |
| | | var objs = JSON.parse(data.Data.Items[0].BASE_FORM_JSON); |
| | | for (const i in objs) { |
| | | if (!isNullOrEmpty(objs[i].customRender)) { |
| | |
| | | } |
| | | _columns.value = objs; |
| | | }); |
| | | |
| | | /* 弹出选择框选择成功后事件 */ |
| | | function handleItemSuccess(d, u) { |
| | | getForm().setFieldsValue(GetSelectSuccess(d, u, getForm().getFieldsValue()['0'])); |
| | | } |
| | | |
| | | /* 弹出选择框 */ |
| | | function handleSelectItem() { |
| | | OpenSelectItem(openItemModal, getForm().getFieldsValue()['0']); |
| | | } |
| | | </script> |