<script lang="ts" setup name="fBS_CusExtend">
|
import { ref, reactive, onMounted } from "vue";
|
import { auth } from '/@/utils/authFunction';
|
import { ElMessageBox, ElMessage } from "element-plus";
|
import { downloadStreamFile } from "/@/utils/download";
|
import { useFBS_CusExtendApi } from '/@/api/Customer/fBS_CusExtend';
|
import editDialog from '/@/views/Customer/fBS_CusExtend/component/editDialog.vue'
|
import printDialog from '/@/views/system/print/component/hiprint/preview.vue'
|
import ModifyRecord from '/@/components/table/modifyRecord.vue';
|
import ImportData from "/@/components/table/importData.vue";
|
|
const fBS_CusExtendApi = useFBS_CusExtendApi();
|
const printDialogRef = ref();
|
const editDialogRef = ref();
|
const importDataRef = ref();
|
const state = reactive({
|
exportLoading: false,
|
tableLoading: false,
|
stores: {},
|
showAdvanceQueryUI: false,
|
dropdownData: {} as any,
|
selectData: [] as any[],
|
tableQueryParams: {} as any,
|
tableParams: {
|
page: 1,
|
pageSize: 20,
|
total: 0,
|
field: 'createTime', // 默认的排序字段
|
order: 'descending', // 排序方向
|
descStr: 'descending', // 降序排序的关键字符
|
},
|
tableData: [],
|
});
|
|
// 页面加载时
|
onMounted(async () => {
|
});
|
|
// 查询操作
|
const handleQuery = async (params: any = {}) => {
|
state.tableLoading = true;
|
state.tableParams = Object.assign(state.tableParams, params);
|
const result = await fBS_CusExtendApi.page(Object.assign(state.tableQueryParams, state.tableParams)).then(res => res.data.result);
|
state.tableParams.total = result?.total;
|
state.tableData = result?.items ?? [];
|
state.tableLoading = false;
|
};
|
|
// 列排序
|
const sortChange = async (column: any) => {
|
state.tableParams.field = column.prop;
|
state.tableParams.order = column.order;
|
await handleQuery();
|
};
|
|
// 删除
|
const delFBS_CusExtend = (row: any) => {
|
ElMessageBox.confirm(`确定要删除吗?`, "提示", {
|
confirmButtonText: "确定",
|
cancelButtonText: "取消",
|
type: "warning",
|
}).then(async () => {
|
await fBS_CusExtendApi.delete({ id: row.id });
|
handleQuery();
|
ElMessage.success("删除成功");
|
}).catch(() => {});
|
};
|
|
// 批量删除
|
const batchDelFBS_CusExtend = () => {
|
ElMessageBox.confirm(`确定要删除${state.selectData.length}条记录吗?`, "提示", {
|
confirmButtonText: "确定",
|
cancelButtonText: "取消",
|
type: "warning",
|
}).then(async () => {
|
await fBS_CusExtendApi.batchDelete(state.selectData.map(u => ({ id: u.id }) )).then(res => {
|
ElMessage.success(`成功批量删除${res.data.result}条记录`);
|
handleQuery();
|
});
|
}).catch(() => {});
|
};
|
|
// 导出数据
|
const exportFBS_CusExtendCommand = async (command: string) => {
|
try {
|
state.exportLoading = true;
|
if (command === 'select') {
|
const params = Object.assign({}, state.tableQueryParams, state.tableParams, { selectKeyList: state.selectData.map(u => u.id) });
|
await fBS_CusExtendApi.exportData(params).then(res => downloadStreamFile(res));
|
} else if (command === 'current') {
|
const params = Object.assign({}, state.tableQueryParams, state.tableParams);
|
await fBS_CusExtendApi.exportData(params).then(res => downloadStreamFile(res));
|
} else if (command === 'all') {
|
const params = Object.assign({}, state.tableQueryParams, state.tableParams, { page: 1, pageSize: 99999999 });
|
await fBS_CusExtendApi.exportData(params).then(res => downloadStreamFile(res));
|
}
|
} finally {
|
state.exportLoading = false;
|
}
|
}
|
|
handleQuery();
|
</script>
|
<template>
|
<div class="fBS_CusExtend-container" v-loading="state.exportLoading">
|
<el-card shadow="hover" :body-style="{ paddingBottom: '0' }">
|
<el-form :model="state.tableQueryParams" ref="queryForm" labelWidth="90">
|
<el-row>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10">
|
<el-form-item label="关键字">
|
<el-input v-model="state.tableQueryParams.keyword" clearable placeholder="请输入模糊查询关键字"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="用户ID">
|
<el-input v-model="state.tableQueryParams.customerId" clearable placeholder="请输入用户ID"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="企业类型 ">
|
<el-input v-model="state.tableQueryParams.enterpriseType" clearable placeholder="请输入企业类型 "/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="交易主体code">
|
<el-input v-model="state.tableQueryParams.transactionCode" clearable placeholder="请输入交易主体code"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="营业执照文件路径">
|
<el-input v-model="state.tableQueryParams.businessLicense" clearable placeholder="请输入营业执照文件路径"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="企业名称">
|
<el-input v-model="state.tableQueryParams.enterpriseName" clearable placeholder="请输入企业名称"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="统一社会信用代码">
|
<el-input v-model="state.tableQueryParams.unifiedSocialCreditCode" clearable placeholder="请输入统一社会信用代码"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="注册资金">
|
<el-input v-model="state.tableQueryParams.registeredCapital" clearable placeholder="请输入注册资金"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="法定代表人姓名">
|
<el-input v-model="state.tableQueryParams.legalRepresentativeName" clearable placeholder="请输入法定代表人姓名"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="法定代表人身份证文件路径">
|
<el-input v-model="state.tableQueryParams.legalRepresentativeIdCard" clearable placeholder="请输入法定代表人身份证文件路径"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="法定代表人姓名">
|
<el-input v-model="state.tableQueryParams.legalRepresentativeIdNumber" clearable placeholder="请输入法定代表人姓名"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="法定代表人姓名">
|
<el-input v-model="state.tableQueryParams.legalRepresentativePhone" clearable placeholder="请输入法定代表人姓名"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="企业住所">
|
<el-input v-model="state.tableQueryParams.residence" clearable placeholder="请输入企业住所"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="企业联系电话">
|
<el-input v-model="state.tableQueryParams.enterprisePhone" clearable placeholder="请输入企业联系电话"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="企业成立时间">
|
<el-date-picker type="daterange" v-model="state.tableQueryParams.establishmentTimeRange" value-format="YYYY-MM-DD HH:mm:ss" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="[new Date('1 00:00:00'), new Date('1 23:59:59')]" />
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="企业主营业务">
|
<el-input v-model="state.tableQueryParams.mainBusiness" clearable placeholder="请输入企业主营业务"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="企业邮箱">
|
<el-input v-model="state.tableQueryParams.enterpriseEmail" clearable placeholder="请输入企业邮箱"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="业务经办人姓名">
|
<el-input v-model="state.tableQueryParams.operatorName" clearable placeholder="请输入业务经办人姓名"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="业务经办人身份证文件路径或标识">
|
<el-input v-model="state.tableQueryParams.operatorIdCard" clearable placeholder="请输入业务经办人身份证文件路径或标识"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="法定代表人姓名">
|
<el-input v-model="state.tableQueryParams.operatorIdNumber" clearable placeholder="请输入法定代表人姓名"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="法定代表人姓名">
|
<el-input v-model="state.tableQueryParams.operatorPhone" clearable placeholder="请输入法定代表人姓名"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="法定代表人姓名">
|
<el-input v-model="state.tableQueryParams.bankName" clearable placeholder="请输入法定代表人姓名"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="法定代表人姓名">
|
<el-input v-model="state.tableQueryParams.bankAccount" clearable placeholder="请输入法定代表人姓名"/>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="state.showAdvanceQueryUI">
|
<el-form-item label="审核步骤">
|
<g-sys-dict v-model="state.tableQueryParams.steps" code="CusExtendStep" render-as="select" placeholder="请选择审核步骤" clearable filterable />
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10">
|
<el-form-item >
|
<el-button-group style="display: flex; align-items: center;">
|
<el-button type="primary" icon="ele-Search" @click="handleQuery" v-auth="'fBS_CusExtend:page'" v-reclick="1000"> 查询 </el-button>
|
<el-button icon="ele-Refresh" @click="() => state.tableQueryParams = {}"> 重置 </el-button>
|
<el-button icon="ele-ZoomIn" @click="() => state.showAdvanceQueryUI = true" v-if="!state.showAdvanceQueryUI" style="margin-left:5px;"> 高级查询 </el-button>
|
<el-button icon="ele-ZoomOut" @click="() => state.showAdvanceQueryUI = false" v-if="state.showAdvanceQueryUI" style="margin-left:5px;"> 隐藏 </el-button>
|
<el-button type="danger" style="margin-left:5px;" icon="ele-Delete" @click="batchDelFBS_CusExtend" :disabled="state.selectData.length == 0" v-auth="'fBS_CusExtend:batchDelete'"> 删除 </el-button>
|
<el-button type="primary" style="margin-left:5px;" icon="ele-Plus" @click="editDialogRef.openDialog(null, '新增企业资料')" v-auth="'fBS_CusExtend:add'"> 新增 </el-button>
|
<el-dropdown :show-timeout="70" :hide-timeout="50" @command="exportFBS_CusExtendCommand">
|
<el-button type="primary" style="margin-left:5px;" icon="ele-FolderOpened" v-reclick="20000" v-auth="'fBS_CusExtend:export'"> 导出 </el-button>
|
<template #dropdown>
|
<el-dropdown-menu>
|
<el-dropdown-item command="select" :disabled="state.selectData.length == 0">导出选中</el-dropdown-item>
|
<el-dropdown-item command="current">导出本页</el-dropdown-item>
|
<el-dropdown-item command="all">导出全部</el-dropdown-item>
|
</el-dropdown-menu>
|
</template>
|
</el-dropdown>
|
<el-button type="warning" style="margin-left:5px;" icon="ele-MostlyCloudy" @click="importDataRef.openDialog()" v-auth="'fBS_CusExtend:import'"> 导入 </el-button>
|
</el-button-group>
|
</el-form-item>
|
</el-col>
|
</el-row>
|
</el-form>
|
</el-card>
|
<el-card class="full-table" shadow="hover" style="margin-top: 5px">
|
<el-table :data="state.tableData" @selection-change="(val: any[]) => { state.selectData = val; }" style="width: 100%" v-loading="state.tableLoading" tooltip-effect="light" row-key="id" @sort-change="sortChange" border>
|
<el-table-column type="selection" width="40" align="center" v-if="auth('fBS_CusExtend:batchDelete') || auth('fBS_CusExtend:export')" />
|
<el-table-column type="index" label="序号" width="55" align="center"/>
|
<el-table-column prop='customerId' label='用户ID' show-overflow-tooltip />
|
<el-table-column prop='enterpriseType' label='企业类型 ' show-overflow-tooltip />
|
<el-table-column prop='transactionCode' label='交易主体code' show-overflow-tooltip />
|
<el-table-column prop='businessLicense' label='营业执照文件路径' show-overflow-tooltip />
|
<el-table-column prop='enterpriseName' label='企业名称' show-overflow-tooltip />
|
<el-table-column prop='unifiedSocialCreditCode' label='统一社会信用代码' show-overflow-tooltip />
|
<el-table-column prop='registeredCapital' label='注册资金' show-overflow-tooltip />
|
<el-table-column prop='legalRepresentativeName' label='法定代表人姓名' show-overflow-tooltip />
|
<el-table-column prop='legalRepresentativeIdCard' label='法定代表人身份证文件路径' show-overflow-tooltip />
|
<el-table-column prop='legalRepresentativeIdNumber' label='法定代表人姓名' show-overflow-tooltip />
|
<el-table-column prop='legalRepresentativePhone' label='法定代表人姓名' show-overflow-tooltip />
|
<el-table-column prop='residence' label='企业住所' show-overflow-tooltip />
|
<el-table-column prop='enterprisePhone' label='企业联系电话' show-overflow-tooltip />
|
<el-table-column prop='establishmentTime' label='企业成立时间' show-overflow-tooltip />
|
<el-table-column prop='mainBusiness' label='企业主营业务' show-overflow-tooltip />
|
<el-table-column prop='enterpriseEmail' label='企业邮箱' show-overflow-tooltip />
|
<el-table-column prop='operatorName' label='业务经办人姓名' show-overflow-tooltip />
|
<el-table-column prop='operatorIdCard' label='业务经办人身份证文件路径或标识' show-overflow-tooltip />
|
<el-table-column prop='operatorIdNumber' label='业务经办人姓名' show-overflow-tooltip />
|
<el-table-column prop='operatorPhone' label='业务经办人电话' show-overflow-tooltip />
|
<el-table-column prop='bankName' label='开户行名称' show-overflow-tooltip />
|
<el-table-column prop='bankAccount' label='开户行账号' show-overflow-tooltip />
|
<el-table-column prop='steps' label='审核步骤' show-overflow-tooltip>
|
<template #default="scope">
|
<g-sys-dict v-model="scope.row.steps" code="CusExtendStep" />
|
</template>
|
</el-table-column>
|
<el-table-column label="修改记录" width="100" align="center" show-overflow-tooltip>
|
<template #default="scope">
|
<ModifyRecord :data="scope.row" />
|
</template>
|
</el-table-column>
|
<el-table-column label="操作" width="140" align="center" fixed="right" show-overflow-tooltip v-if="auth('fBS_CusExtend:update') || auth('fBS_CusExtend:delete')">
|
<template #default="scope">
|
<el-button icon="ele-Edit" size="small" text type="primary" @click="editDialogRef.openDialog(scope.row, '编辑企业资料')" v-auth="'fBS_CusExtend:update'"> 编辑 </el-button>
|
<el-button icon="ele-Delete" size="small" text type="primary" @click="delFBS_CusExtend(scope.row)" v-auth="'fBS_CusExtend:delete'"> 删除 </el-button>
|
</template>
|
</el-table-column>
|
</el-table>
|
<el-pagination
|
v-model:currentPage="state.tableParams.page"
|
v-model:page-size="state.tableParams.pageSize"
|
@size-change="(val: any) => handleQuery({ pageSize: val })"
|
@current-change="(val: any) => handleQuery({ page: val })"
|
layout="total, sizes, prev, pager, next, jumper"
|
:page-sizes="[10, 20, 50, 100, 200, 500]"
|
:total="state.tableParams.total"
|
size="small"
|
background />
|
<ImportData ref="importDataRef" :import="fBS_CusExtendApi.importData" :download="fBS_CusExtendApi.downloadTemplate" v-auth="'fBS_CusExtend:import'" @refresh="handleQuery"/>
|
<printDialog ref="printDialogRef" :title="'打印企业资料'" @reloadTable="handleQuery" />
|
<editDialog ref="editDialogRef" @reloadTable="handleQuery" />
|
</el-card>
|
</div>
|
</template>
|
<style scoped>
|
:deep(.el-input), :deep(.el-select), :deep(.el-input-number) {
|
width: 100%;
|
}
|
</style>
|