| <template> | 
|   <LoadingLayout :loading="isInitialLoading"> | 
|     <AppContainer> | 
|       <ProTableQueryFilterBar @on-reset="reset"> | 
|         <template #query> | 
|           <QueryFilterItem tip-content="配置状态"> | 
|             <FieldRadio | 
|               v-model="extraParamState.isConfigured" | 
|               :value-enum="IsConfiguredText" | 
|               buttonStyle | 
|               showAllBtn | 
|             /> | 
|           </QueryFilterItem> | 
|           <QueryFilterItem> | 
|             <SearchInput | 
|               v-model="extraParamState.keywords" | 
|               style="width: 300px" | 
|               placeholder="企业名称/法人/联系人" | 
|               @on-click-search="getList" | 
|             > | 
|             </SearchInput> | 
|           </QueryFilterItem> | 
|         </template> | 
|         <template #btn> | 
|           <el-button | 
|             v-if="checkSubModuleItemShow('pageButton', 'addBtn')" | 
|             @click="addOrEditEnterprise()" | 
|             icon="Plus" | 
|             type="primary" | 
|             >新增</el-button | 
|           > | 
|         </template> | 
|       </ProTableQueryFilterBar> | 
|       <ProTableV2 v-bind="proTableProps" :columns="column" :operationBtns="operationBtns"> | 
|       </ProTableV2> | 
|     </AppContainer> | 
|     <ConfigureDialog v-bind="dialogProps" /> | 
|     <WechatWalletOpen v-bind="dialogWechatProps"></WechatWalletOpen> | 
|   </LoadingLayout> | 
| </template> | 
|   | 
| <script setup lang="ts"> | 
| import { | 
|   ProTableQueryFilterBar, | 
|   OperationBtnType, | 
|   ProTableV2, | 
|   SearchInput, | 
|   LoadingLayout, | 
|   AppContainer, | 
|   QueryFilterItem, | 
|   useFormDialog, | 
|   FieldRadio, | 
|   useTableV2, | 
| } from '@bole-core/components'; | 
| import { useAccess, useGlobalEventContext } from '@/hooks'; | 
| import { EnterpriseConfigureType, IsConfiguredText } from '@/constants'; | 
| import ConfigureDialog from './components/ConfigureDialog.vue'; | 
| import { Message } from '@bole-core/core'; | 
| import * as enterpriseServices from '@/services/api/enterprise'; | 
| import WechatWalletOpen from './components/WechatWalletOpen.vue'; | 
|   | 
| defineOptions({ | 
|   name: 'EnterpriseManageList', | 
| }); | 
|   | 
| const operationBtnMap: Record<string, OperationBtnType> = { | 
|   editBtn: { emits: { onClick: (role) => addOrEditEnterprise(role) } }, | 
|   detailBtn: { emits: { onClick: (role) => handleDetail(role) } }, | 
|   configBtn: { emits: { onClick: (role) => openDialog(role) } }, | 
| }; | 
|   | 
| const { checkSubModuleItemShow, column, operationBtns } = useAccess({ | 
|   operationBtnMap, | 
| }); | 
|   | 
| const eventContext = useGlobalEventContext(); | 
|   | 
| eventContext.addEvent('enterprise:add', () => { | 
|   getList(); | 
| }); | 
|   | 
| eventContext.addEvent('enterprise:edit', () => { | 
|   getList(paginationState.pageIndex); | 
| }); | 
|   | 
| const router = useRouter(); | 
|   | 
| const { | 
|   getDataSource: getList, | 
|   proTableProps, | 
|   paginationState, | 
|   extraParamState, | 
|   reset, | 
|   isInitialLoading, | 
| } = useTableV2( | 
|   async ({ pageIndex, pageSize, isInitialLoading }, extraParamState) => { | 
|     try { | 
|       let params: API.GetEnterprisesQuery = { | 
|         pageModel: { | 
|           rows: pageSize, | 
|           page: pageIndex, | 
|           orderInput: extraParamState.orderInput, | 
|         }, | 
|         isConfigured: extraParamState.isConfigured, | 
|         keywords: extraParamState.keywords, | 
|       }; | 
|   | 
|       let res = await enterpriseServices.getEnterprises(params, { | 
|         showLoading: !isInitialLoading, | 
|       }); | 
|       return res; | 
|     } catch (error) { | 
|       console.log('error: ', error); | 
|     } | 
|   }, | 
|   { | 
|     defaultExtraParams: { | 
|       keywords: '', | 
|       orderInput: [{ property: 'id', order: EnumPagedListOrder.Desc }], | 
|       isConfigured: '' as any as boolean, | 
|     }, | 
|     queryKey: ['enterpriseServices/getEnterprises'], | 
|     columnsRenderProps: { | 
|       isReal: { type: 'enum', valueEnum: IsRealText }, | 
|       isConfigured: { type: 'enum', valueEnum: IsConfiguredText }, | 
|     }, | 
|   } | 
| ); | 
|   | 
| function openDialog(row?: API.GetEnterprisesQueryResultItem) { | 
|   handleEdit({ | 
|     id: row.id, | 
|     enterpriseConfigureType: EnterpriseConfigureType.Bank, | 
|   }); | 
| } | 
|   | 
| const { dialogProps, handleEdit, dialogState, editForm } = useFormDialog({ | 
|   onConfirm: handleAddOrEdit, | 
|   defaultFormParams: { | 
|     id: '', | 
|     enterpriseConfigureType: EnterpriseConfigureType.Bank, | 
|   }, | 
| }); | 
|   | 
| const { dialogProps: dialogWechatProps, handleAdd } = useFormDialog({ | 
|   defaultFormParams: { | 
|     url: '', | 
|   }, | 
| }); | 
|   | 
| async function handleAddOrEdit(data?: any) { | 
|   try { | 
|     if (editForm.enterpriseConfigureType === EnterpriseConfigureType.Wechat) { | 
|       handleAdd({ | 
|         url: data?.sign_url, | 
|       }); | 
|     } | 
|     Message.successMessage( | 
|       editForm.enterpriseConfigureType === EnterpriseConfigureType.Wechat | 
|         ? '提交成功,请超级管理员扫码进行签约操作' | 
|         : '操作成功' | 
|     ); | 
|     getList(paginationState.pageIndex); | 
|     dialogState.dialogVisible = false; | 
|   } catch (error) {} | 
| } | 
|   | 
| function addOrEditEnterprise(row?: API.GetEnterprisesQueryResultItem) { | 
|   router.push({ name: 'AddOrEditEnterprise', params: { id: row?.id ?? '' } }); | 
| } | 
| function handleDetail(row: API.GetEnterprisesQueryResultItem) { | 
|   router.push({ name: 'EnterpriseDetail', params: { id: row?.id ?? '' } }); | 
| } | 
| </script> |