|  |  |  | 
|---|
|  |  |  | <template> | 
|---|
|  |  |  | <ProDialog title="出账审批" v-model="visible" @close="onDialogClose" destroy-on-close draggable> | 
|---|
|  |  |  | <PortraitTableWithAttachment v-bind="portraitTableWithAttachmentProps" /> | 
|---|
|  |  |  | <ProDialog | 
|---|
|  |  |  | :title="form.title" | 
|---|
|  |  |  | v-model="visible" | 
|---|
|  |  |  | @close="onDialogClose" | 
|---|
|  |  |  | destroy-on-close | 
|---|
|  |  |  | draggable | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <PortraitTableWithAttachment v-bind="portraitTableWithAttachmentProps" labelWidth="100px"> | 
|---|
|  |  |  | <template #title> | 
|---|
|  |  |  | <el-row class="portrait-table-with-attachment-title"> | 
|---|
|  |  |  | <el-text style="color: #333333">打款信息</el-text> | 
|---|
|  |  |  | <el-button type="primary" link @click="handleApply">复制</el-button> | 
|---|
|  |  |  | </el-row> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </PortraitTableWithAttachment> | 
|---|
|  |  |  | <ProForm | 
|---|
|  |  |  | :model="form" | 
|---|
|  |  |  | ref="dialogForm" | 
|---|
|  |  |  | 
|---|
|  |  |  | </ProFormCol> | 
|---|
|  |  |  | <ProFormCol v-if="form.isCheck"> | 
|---|
|  |  |  | <ProFormColItem :span="12"> | 
|---|
|  |  |  | <ProFormItemV2 label="审核日期:" prop="auditTime"> | 
|---|
|  |  |  | <ProFormItemV2 label="审核日期:" prop="auditTime" v-if="isApplyTrade"> | 
|---|
|  |  |  | <ProFormDatePicker v-model="form.auditTime" type="date" format="YYYY-MM-DD HH:mm" /> | 
|---|
|  |  |  | </ProFormItemV2> | 
|---|
|  |  |  | <ProFormItemV2 label="审核日期:" prop="financeAuditTime" v-else> | 
|---|
|  |  |  | <ProFormDatePicker | 
|---|
|  |  |  | v-model="form.financeAuditTime" | 
|---|
|  |  |  | type="date" | 
|---|
|  |  |  | format="YYYY-MM-DD HH:mm" | 
|---|
|  |  |  | /> | 
|---|
|  |  |  | </ProFormItemV2> | 
|---|
|  |  |  | </ProFormColItem> | 
|---|
|  |  |  | </ProFormCol> | 
|---|
|  |  |  | 
|---|
|  |  |  | <ProFormItemV2 | 
|---|
|  |  |  | label="上传凭证:" | 
|---|
|  |  |  | prop="payAuditFileUrl" | 
|---|
|  |  |  | :check-rules="[ | 
|---|
|  |  |  | { | 
|---|
|  |  |  | message: '请上传凭证', | 
|---|
|  |  |  | type: 'upload', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | ]" | 
|---|
|  |  |  | :required="!isApplyTrade" | 
|---|
|  |  |  | :check-rules=" | 
|---|
|  |  |  | !isApplyTrade | 
|---|
|  |  |  | ? [ | 
|---|
|  |  |  | { | 
|---|
|  |  |  | message: '请上传凭证', | 
|---|
|  |  |  | type: 'upload', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | ] | 
|---|
|  |  |  | : undefined | 
|---|
|  |  |  | " | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <ProFormUpload | 
|---|
|  |  |  | v-model:file-url="form.payAuditFileUrl" | 
|---|
|  |  |  | 
|---|
|  |  |  | ProFormDatePicker, | 
|---|
|  |  |  | UploadUserFile, | 
|---|
|  |  |  | } from '@bole-core/components'; | 
|---|
|  |  |  | import * as parkBountyApplyServices from '@/services/api/ParkBountyApply'; | 
|---|
|  |  |  | import { usePortraitTableWithAttachment } from '@/hooks'; | 
|---|
|  |  |  | import { convertApi2FormUrl, convertApi2FormUrlOnlyOne } from '@/utils'; | 
|---|
|  |  |  | import { useQuery } from '@tanstack/vue-query'; | 
|---|
|  |  |  | import { copyTextToClipboard, StringUtils } from '@/utils'; | 
|---|
|  |  |  | import { | 
|---|
|  |  |  | EnumParkBountyTradeDetailAuditStatus, | 
|---|
|  |  |  | EnumParkBountyTradeDetailAuditStatusTextForAdudit, | 
|---|
|  |  |  | EnterpriseType, | 
|---|
|  |  |  | EnterpriseTypeText, | 
|---|
|  |  |  | } from '@/constants'; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | defineOptions({ | 
|---|
|  |  |  | name: 'WithdrawalApprovalAuditDialog', | 
|---|
|  |  |  | name: 'RewardApplyTradeCheckDialog', | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // type Props = {}; | 
|---|
|  |  |  | type Props = { | 
|---|
|  |  |  | //true 出账审批 false 财务审批 | 
|---|
|  |  |  | isApplyTrade?: boolean; | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // const props = withDefaults(defineProps<Props>(), {}); | 
|---|
|  |  |  | const props = withDefaults(defineProps<Props>(), {}); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const visible = defineModel({ type: Boolean }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | parkName: string; | 
|---|
|  |  |  | parkTypeName: string; | 
|---|
|  |  |  | tradeAmount: number; | 
|---|
|  |  |  | remianAmount: number; | 
|---|
|  |  |  | bountyAmount: number; | 
|---|
|  |  |  | tradeTime: string; | 
|---|
|  |  |  | auditTime: string; | 
|---|
|  |  |  | financeAuditTime: string; | 
|---|
|  |  |  | payRemark: string; | 
|---|
|  |  |  | payFileUrl: UploadUserFile[]; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | incomeCompanyName: string; | 
|---|
|  |  |  | insureBillNo: string; | 
|---|
|  |  |  | incomeBankAccount: string; | 
|---|
|  |  |  | incomeBankCardNumber: string; | 
|---|
|  |  |  | incomeBankName: string; | 
|---|
|  |  |  | creationTime: string; | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const form = defineModel<Form>('form'); | 
|---|
|  |  |  | 
|---|
|  |  |  | annexList: computed(() => form.value?.payFileUrl), | 
|---|
|  |  |  | columns: [ | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: '开户账号', | 
|---|
|  |  |  | key: 'userName', | 
|---|
|  |  |  | formatter: () => '1511 2001 2920 0156 069', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: '进账单位', | 
|---|
|  |  |  | key: 'enterpriseName', | 
|---|
|  |  |  | formatter: () => '太平财产保险有限公司抚州中心支公司', | 
|---|
|  |  |  | key: 'incomeCompanyName', | 
|---|
|  |  |  | formatter: (row) => | 
|---|
|  |  |  | row.id === '52febfa5-1df6-23d6-21fd-3a1cfdef4222' | 
|---|
|  |  |  | ? '中国大地财产保险股份有限公司深圳分公司' | 
|---|
|  |  |  | : row.incomeCompanyName ?? '太平财产保险有限公司抚州中心支公司', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: '开户名称', | 
|---|
|  |  |  | key: 'societyCreditCode', | 
|---|
|  |  |  | formatter: () => '太平财产保险有限公司抚州中心支公司', | 
|---|
|  |  |  | key: 'incomeBankAccount', | 
|---|
|  |  |  | formatter: (row) => | 
|---|
|  |  |  | row.id === '52febfa5-1df6-23d6-21fd-3a1cfdef4222' | 
|---|
|  |  |  | ? '中国大地财产保险股份有限公司深圳分公司' | 
|---|
|  |  |  | : row.incomeBankAccount ?? '太平财产保险有限公司抚州中心支公司', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: '开户银行', | 
|---|
|  |  |  | key: 'contactPhone', | 
|---|
|  |  |  | formatter: () => '中国工商银行股份有限公司抚州赣东支行', | 
|---|
|  |  |  | key: 'incomeBankName', | 
|---|
|  |  |  | formatter: (row) => | 
|---|
|  |  |  | row.id === '52febfa5-1df6-23d6-21fd-3a1cfdef4222' | 
|---|
|  |  |  | ? '中国工商银行股份有限公司深圳喜年支行' | 
|---|
|  |  |  | : row.incomeBankName ?? '中国工商银行股份有限公司抚州赣东支行', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: '开户账号', | 
|---|
|  |  |  | key: 'incomeBankCardNumber', | 
|---|
|  |  |  | formatter: (row) => | 
|---|
|  |  |  | row.id === '52febfa5-1df6-23d6-21fd-3a1cfdef4222' | 
|---|
|  |  |  | ? StringUtils.insertSpaces('4000032419200171762') | 
|---|
|  |  |  | : StringUtils.insertSpaces(row.incomeBankCardNumber ?? '1511200129200156069'), | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // { | 
|---|
|  |  |  | //   label: '企业类型', | 
|---|
|  |  |  | 
|---|
|  |  |  | //   label: '园区类型', | 
|---|
|  |  |  | //   key: 'parkTypeName', | 
|---|
|  |  |  | // }, | 
|---|
|  |  |  | // { | 
|---|
|  |  |  | //   label: '消费类型', | 
|---|
|  |  |  | //   key: 'payRemark', | 
|---|
|  |  |  | // }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: '申请出账金额', | 
|---|
|  |  |  | label: '消费类型', | 
|---|
|  |  |  | key: 'payRemark', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: '保单号', | 
|---|
|  |  |  | key: 'insureBillNo', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: '出账申请日期', | 
|---|
|  |  |  | key: 'tradeTime', | 
|---|
|  |  |  | type: 'date', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | props.isApplyTrade | 
|---|
|  |  |  | ? { | 
|---|
|  |  |  | label: '', | 
|---|
|  |  |  | } | 
|---|
|  |  |  | : { | 
|---|
|  |  |  | label: '出账审核日期', | 
|---|
|  |  |  | key: 'auditTime', | 
|---|
|  |  |  | type: 'date', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: '出账金额', | 
|---|
|  |  |  | key: 'tradeAmount', | 
|---|
|  |  |  | type: 'money', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: '申请出账时间', | 
|---|
|  |  |  | key: 'tradeTime', | 
|---|
|  |  |  | type: 'date', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: '资金余额', | 
|---|
|  |  |  | key: 'remianAmount', | 
|---|
|  |  |  | key: 'bountyAmount', | 
|---|
|  |  |  | type: 'money', | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | ], | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | function handleApply() { | 
|---|
|  |  |  | copyTextToClipboard( | 
|---|
|  |  |  | `开户名称:${'太平财产保险有限公司抚州中心支公司'}\n开户银行:${'中国工商银行股份有限公司抚州赣东支行'}\n开户账号:${'1511 2001 2920 0156 069'}` | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | </script> | 
|---|
|  |  |  | <style lang="scss" scoped> | 
|---|
|  |  |  | @use '@/style/common.scss' as *; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .portrait-table-with-attachment-title { | 
|---|
|  |  |  | justify-content: space-between; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | </style> | 
|---|