|  |  |  | 
|---|
|  |  |  | <template> | 
|---|
|  |  |  | <LoadingLayout :loading="state.loading"> | 
|---|
|  |  |  | <LoadingLayout :loading="isInitialLoading"> | 
|---|
|  |  |  | <AppContainer> | 
|---|
|  |  |  | <ProTableQueryFilterBar @on-reset="reset"> | 
|---|
|  |  |  | <template #query> | 
|---|
|  |  |  | 
|---|
|  |  |  | :value-enum="IsConfiguredText" | 
|---|
|  |  |  | buttonStyle | 
|---|
|  |  |  | showAllBtn | 
|---|
|  |  |  | @change="getList()" | 
|---|
|  |  |  | /> | 
|---|
|  |  |  | </QueryFilterItem> | 
|---|
|  |  |  | <QueryFilterItem> | 
|---|
|  |  |  | 
|---|
|  |  |  | style="width: 300px" | 
|---|
|  |  |  | placeholder="企业名称/法人/联系人" | 
|---|
|  |  |  | @on-click-search="getList" | 
|---|
|  |  |  | @keyup.enter="getList()" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </SearchInput> | 
|---|
|  |  |  | </QueryFilterItem> | 
|---|
|  |  |  | 
|---|
|  |  |  | </ProTableV2> | 
|---|
|  |  |  | </AppContainer> | 
|---|
|  |  |  | <ConfigureDialog v-bind="dialogProps" /> | 
|---|
|  |  |  | <WechatWalletOpen v-bind="dialogWechatProps"></WechatWalletOpen> | 
|---|
|  |  |  | </LoadingLayout> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | LoadingLayout, | 
|---|
|  |  |  | AppContainer, | 
|---|
|  |  |  | QueryFilterItem, | 
|---|
|  |  |  | useTable, | 
|---|
|  |  |  | 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 * as enterpriseWalletServices from '@/services/api/enterpriseWallet'; | 
|---|
|  |  |  | import WechatWalletOpen from './components/WechatWalletOpen.vue'; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | defineOptions({ | 
|---|
|  |  |  | name: 'EnterpriseManageList', | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const router = useRouter(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const BaseState = { | 
|---|
|  |  |  | loading: true, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const state = reactive({ ...BaseState }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const { invalidateQueries } = useEnabledElectronSignSettings(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | onMounted(async () => { | 
|---|
|  |  |  | await getList(); | 
|---|
|  |  |  | state.loading = false; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const { | 
|---|
|  |  |  | getDataSource: getList, | 
|---|
|  |  |  | proTableProps, | 
|---|
|  |  |  | paginationState, | 
|---|
|  |  |  | extraParamState, | 
|---|
|  |  |  | reset, | 
|---|
|  |  |  | } = useTable( | 
|---|
|  |  |  | async ({ pageIndex, pageSize }, extraParamState) => { | 
|---|
|  |  |  | isInitialLoading, | 
|---|
|  |  |  | } = useTableV2( | 
|---|
|  |  |  | async ({ pageIndex, pageSize, isInitialLoading }, extraParamState) => { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | let params: API.GetEnterprisesQuery = { | 
|---|
|  |  |  | pageModel: { | 
|---|
|  |  |  | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | let res = await enterpriseServices.getEnterprises(params, { | 
|---|
|  |  |  | showLoading: !state.loading, | 
|---|
|  |  |  | showLoading: !isInitialLoading, | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | return res; | 
|---|
|  |  |  | } catch (error) { | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | async function getEnterpriseElectronSignSetting(id: string) { | 
|---|
|  |  |  | return await enterpriseServices.getEnterpriseElectronSignSetting({ id: id }); | 
|---|
|  |  |  | function openDialog(row?: API.GetEnterprisesQueryResultItem) { | 
|---|
|  |  |  | handleEdit({ | 
|---|
|  |  |  | id: row.id, | 
|---|
|  |  |  | enterpriseConfigureType: EnterpriseConfigureType.Bank, | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | async function getEnterpriseSmsSetting(id: string) { | 
|---|
|  |  |  | return await enterpriseServices.getEnterpriseSmsSetting({ id: id }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const EnumElectronSignAccessList = computed(() => | 
|---|
|  |  |  | Object.values(EnumElectronSignAccess) | 
|---|
|  |  |  | .filter(Number) | 
|---|
|  |  |  | .map((x) => Number(x)) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | async function openDialog(row?: API.GetEnterprisesQueryResultItem) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | if (row) { | 
|---|
|  |  |  | let electronSignSetting = await getEnterpriseElectronSignSetting(row.id); | 
|---|
|  |  |  | let smsSetting = await getEnterpriseSmsSetting(row.id); | 
|---|
|  |  |  | // let alipayWallet = await enterpriseWalletServices.getEnterpriseWallet({ | 
|---|
|  |  |  | //   enterpriseId: row.id, | 
|---|
|  |  |  | //   access: EnumEnterpriseWalletAccess.Alipay, | 
|---|
|  |  |  | // }); | 
|---|
|  |  |  | handleEdit({ | 
|---|
|  |  |  | id: row.id, | 
|---|
|  |  |  | enterpriseConfigureType: EnterpriseConfigureType.AliPay, | 
|---|
|  |  |  | electronSignAccesses: EnumElectronSignAccessList.value.map((value) => | 
|---|
|  |  |  | electronSignSetting.electronSignAccesses.includes(value) ? value : null | 
|---|
|  |  |  | ), | 
|---|
|  |  |  | smsAccess: smsSetting.smsAccess, | 
|---|
|  |  |  | smsCost: smsSetting.smsCost, | 
|---|
|  |  |  | alipayAccount: '', | 
|---|
|  |  |  | alipayMerchantId: '', | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | handleAdd({ | 
|---|
|  |  |  | enterpriseConfigureType: EnterpriseConfigureType.AliPay, | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (error) {} | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const { dialogProps, handleAdd, handleEdit, editForm, dialogState } = useFormDialog({ | 
|---|
|  |  |  | const { dialogProps, handleEdit, dialogState, editForm } = useFormDialog({ | 
|---|
|  |  |  | onConfirm: handleAddOrEdit, | 
|---|
|  |  |  | defaultFormParams: { | 
|---|
|  |  |  | id: '', | 
|---|
|  |  |  | enterpriseConfigureType: EnterpriseConfigureType.AliPay, | 
|---|
|  |  |  | electronSignAccesses: [] as EnumElectronSignAccess[], | 
|---|
|  |  |  | smsAccess: '' as any as EnumSmsAccess, | 
|---|
|  |  |  | smsCost: 0, | 
|---|
|  |  |  | alipayAccount: '', | 
|---|
|  |  |  | alipayMerchantId: '', | 
|---|
|  |  |  | enterpriseConfigureType: EnterpriseConfigureType.Bank, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | async function handleAddOrEdit() { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | let res; | 
|---|
|  |  |  | // if (type === EnterpriseConfigureType.Bank) { | 
|---|
|  |  |  | //   res = await createOrEditFlexEnterpriseBankSetting(); | 
|---|
|  |  |  | // } | 
|---|
|  |  |  | if (editForm.enterpriseConfigureType === EnterpriseConfigureType.Electronic) { | 
|---|
|  |  |  | res = await createOrEditFlexEnterpriseSignSetting(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (editForm.enterpriseConfigureType === EnterpriseConfigureType.ShortMessage) { | 
|---|
|  |  |  | res = await createOrEditFlexEnterpriseMessageSetting(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (res) { | 
|---|
|  |  |  | Message.successMessage('操作成功'); | 
|---|
|  |  |  | getList(paginationState.pageIndex); | 
|---|
|  |  |  | dialogState.dialogVisible = false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (error) {} | 
|---|
|  |  |  | } | 
|---|
|  |  |  | const { dialogProps: dialogWechatProps, handleAdd } = useFormDialog({ | 
|---|
|  |  |  | defaultFormParams: { | 
|---|
|  |  |  | url: '', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // async function createOrEditFlexEnterpriseBankSetting() { | 
|---|
|  |  |  | //   try { | 
|---|
|  |  |  | //     let params: API.CreateOrEditFlexEnterpriseBankInput = { | 
|---|
|  |  |  | //       id: editForm.id, | 
|---|
|  |  |  | //       openBank: editForm.openBank, | 
|---|
|  |  |  | //       openBranchBank: editForm.openBranchBank, | 
|---|
|  |  |  | //       bankAccount: editForm.bankAccount, | 
|---|
|  |  |  | //       verifyStatus: editForm.verifyStatus, | 
|---|
|  |  |  | //       flexEnterpirseId: editForm.flexEnterpirseId, | 
|---|
|  |  |  | //     }; | 
|---|
|  |  |  | //     return await flexEnterpriseServices.createOrEditFlexEnterpriseBankSetting(params); | 
|---|
|  |  |  | //   } catch (error) {} | 
|---|
|  |  |  | // } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | async function createOrEditFlexEnterpriseSignSetting() { | 
|---|
|  |  |  | async function handleAddOrEdit(data?: any) { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | let params: API.SetEnterpriseElectronSignSettingCommand = { | 
|---|
|  |  |  | id: editForm.id, | 
|---|
|  |  |  | electronSignAccesses: editForm.electronSignAccesses.filter(Boolean), | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | let res = await enterpriseServices.setEnterpriseElectronSignSetting(params); | 
|---|
|  |  |  | invalidateQueries(); | 
|---|
|  |  |  | return res; | 
|---|
|  |  |  | } catch (error) {} | 
|---|
|  |  |  | } | 
|---|
|  |  |  | async function createOrEditFlexEnterpriseMessageSetting() { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | let params: API.SetEnterpriseSmsSettingCommand = { | 
|---|
|  |  |  | id: editForm.id, | 
|---|
|  |  |  | smsAccess: editForm.smsAccess, | 
|---|
|  |  |  | smsCost: editForm.smsCost, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | return await enterpriseServices.setEnterpriseSmsSetting(params); | 
|---|
|  |  |  | if (editForm.enterpriseConfigureType === EnterpriseConfigureType.Wechat) { | 
|---|
|  |  |  | handleAdd({ | 
|---|
|  |  |  | url: data?.sign_url, | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Message.successMessage( | 
|---|
|  |  |  | editForm.enterpriseConfigureType === EnterpriseConfigureType.Wechat | 
|---|
|  |  |  | ? '提交成功,请超级管理员扫码进行签约操作' | 
|---|
|  |  |  | : '操作成功' | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | getList(paginationState.pageIndex); | 
|---|
|  |  |  | dialogState.dialogVisible = false; | 
|---|
|  |  |  | } catch (error) {} | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|