|
@@ -12,18 +12,21 @@
|
|
|
|
|
|
|
|
<el-table v-loading="loading" border :data="bankList" @selection-change="handleSelectionChange">
|
|
<el-table v-loading="loading" border :data="bankList" @selection-change="handleSelectionChange">
|
|
|
<el-table-column type="selection" width="55" align="center" />
|
|
<el-table-column type="selection" width="55" align="center" />
|
|
|
- <el-table-column label="银行编号" align="center" prop="bnId" />
|
|
|
|
|
|
|
+ <el-table-column label="编号" align="center" prop="bnId" />
|
|
|
<el-table-column label="银行名称" align="center" prop="bnName" />
|
|
<el-table-column label="银行名称" align="center" prop="bnName" />
|
|
|
- <el-table-column label="银行地址" align="center" prop="bnAddr" />
|
|
|
|
|
- <el-table-column label="银行分类" align="center" prop="bnCatgId" />
|
|
|
|
|
|
|
+ <el-table-column label="行号" align="center" prop="faxNo" />
|
|
|
|
|
+ <!-- <el-table-column label="省" align="center" prop="" />
|
|
|
|
|
+ <el-table-column label="市" align="center" prop="" /> -->
|
|
|
|
|
+ <el-table-column label="城市" align="center" prop="provincialCityCountry" />
|
|
|
|
|
+ <el-table-column label="地址" align="center" prop="bnAddr" />
|
|
|
|
|
+ <!-- <el-table-column label="银行分类" align="center" prop="bnCatgId" />
|
|
|
<el-table-column label="传真" align="center" prop="faxNo" />
|
|
<el-table-column label="传真" align="center" prop="faxNo" />
|
|
|
- <el-table-column label="联系电话" align="center" prop="telNo" />
|
|
|
|
|
- <el-table-column label="是否显示" align="center" prop="isShow">
|
|
|
|
|
|
|
+ <el-table-column label="联系电话" align="center" prop="telNo" /> -->
|
|
|
|
|
+ <el-table-column label="状态" align="center" prop="isShow">
|
|
|
<template #default="scope">
|
|
<template #default="scope">
|
|
|
<el-switch v-model="scope.row.isShow" active-value="0" inactive-value="1" @change="handleStatusChange(scope.row)"></el-switch>
|
|
<el-switch v-model="scope.row.isShow" active-value="0" inactive-value="1" @change="handleStatusChange(scope.row)"></el-switch>
|
|
|
</template>
|
|
</template>
|
|
|
</el-table-column>
|
|
</el-table-column>
|
|
|
- <el-table-column label="备注" align="center" prop="remark" />
|
|
|
|
|
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
|
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
|
|
<template #default="scope">
|
|
<template #default="scope">
|
|
|
<el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['system:bank:edit']">编辑</el-button>
|
|
<el-button link type="primary" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['system:bank:edit']">编辑</el-button>
|
|
@@ -34,28 +37,37 @@
|
|
|
<pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" @pagination="getList" />
|
|
<pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" @pagination="getList" />
|
|
|
</el-card>
|
|
</el-card>
|
|
|
<!-- 添加或修改银行信息对话框 -->
|
|
<!-- 添加或修改银行信息对话框 -->
|
|
|
- <el-dialog :title="dialog.title" v-model="dialog.visible" width="650px" append-to-body>
|
|
|
|
|
|
|
+ <el-dialog :title="dialog.title" v-model="dialog.visible" width="750px" append-to-body>
|
|
|
<el-form ref="bankFormRef" :model="form" :rules="rules" label-width="80px">
|
|
<el-form ref="bankFormRef" :model="form" :rules="rules" label-width="80px">
|
|
|
<el-form-item label="银行名称" prop="bnName">
|
|
<el-form-item label="银行名称" prop="bnName">
|
|
|
<el-input v-model="form.bnName" placeholder="请输入银行名称" />
|
|
<el-input v-model="form.bnName" placeholder="请输入银行名称" />
|
|
|
</el-form-item>
|
|
</el-form-item>
|
|
|
|
|
+ <el-form-item label="行号" prop="faxNo">
|
|
|
|
|
+ <el-input v-model="form.faxNo" placeholder="请输入银行地址" />
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ <!-- <el-form-item label="省" prop="">
|
|
|
|
|
+ <el-input />
|
|
|
|
|
+ </el-form-item>
|
|
|
|
|
+ <el-form-item label="市" prop="">
|
|
|
|
|
+ <el-input />
|
|
|
|
|
+ </el-form-item> -->
|
|
|
|
|
+ <el-form-item label="城市" prop="provincialCityCountry">
|
|
|
|
|
+ <el-cascader v-model="codeArr" :options="regionData as any" placeholder="请选择" @change="handleChange" style="width: 100%"></el-cascader>
|
|
|
|
|
+ </el-form-item>
|
|
|
<el-form-item label="银行地址" prop="bnAddr">
|
|
<el-form-item label="银行地址" prop="bnAddr">
|
|
|
<el-input v-model="form.bnAddr" placeholder="请输入银行地址" />
|
|
<el-input v-model="form.bnAddr" placeholder="请输入银行地址" />
|
|
|
</el-form-item>
|
|
</el-form-item>
|
|
|
- <el-form-item label="传真号码" prop="faxNo">
|
|
|
|
|
|
|
+ <!-- <el-form-item label="传真号码" prop="faxNo">
|
|
|
<el-input v-model="form.faxNo" placeholder="请输入传真号码" />
|
|
<el-input v-model="form.faxNo" placeholder="请输入传真号码" />
|
|
|
</el-form-item>
|
|
</el-form-item>
|
|
|
<el-form-item label="联系电话" prop="telNo">
|
|
<el-form-item label="联系电话" prop="telNo">
|
|
|
<el-input v-model="form.telNo" placeholder="请输入联系电话" />
|
|
<el-input v-model="form.telNo" placeholder="请输入联系电话" />
|
|
|
- </el-form-item>
|
|
|
|
|
- <el-form-item label="是否显示" prop="isShow">
|
|
|
|
|
|
|
+ </el-form-item> -->
|
|
|
|
|
+ <el-form-item label="状态" prop="isShow">
|
|
|
<el-radio-group v-model="form.isShow">
|
|
<el-radio-group v-model="form.isShow">
|
|
|
<el-radio v-for="dict in sys_platform_yes_no" :key="dict.value" :value="dict.value">{{ dict.label }}</el-radio>
|
|
<el-radio v-for="dict in sys_platform_yes_no" :key="dict.value" :value="dict.value">{{ dict.label }}</el-radio>
|
|
|
</el-radio-group>
|
|
</el-radio-group>
|
|
|
</el-form-item>
|
|
</el-form-item>
|
|
|
- <el-form-item label="备注" prop="remark">
|
|
|
|
|
- <el-input v-model="form.remark" type="textarea" placeholder="请输入内容" />
|
|
|
|
|
- </el-form-item>
|
|
|
|
|
</el-form>
|
|
</el-form>
|
|
|
<template #footer>
|
|
<template #footer>
|
|
|
<div class="dialog-footer">
|
|
<div class="dialog-footer">
|
|
@@ -70,7 +82,7 @@
|
|
|
<script setup name="Bank" lang="ts">
|
|
<script setup name="Bank" lang="ts">
|
|
|
import { listBank, getBank, delBank, addBank, updateBank, changeShowStatus } from '@/api/company/bank';
|
|
import { listBank, getBank, delBank, addBank, updateBank, changeShowStatus } from '@/api/company/bank';
|
|
|
import { BankVO, BankQuery, BankForm } from '@/api/company/bank/types';
|
|
import { BankVO, BankQuery, BankForm } from '@/api/company/bank/types';
|
|
|
-
|
|
|
|
|
|
|
+import { regionData } from 'element-china-area-data';
|
|
|
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
|
|
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
|
|
|
const { sys_platform_yes_no } = toRefs<any>(proxy?.useDict('sys_platform_yes_no'));
|
|
const { sys_platform_yes_no } = toRefs<any>(proxy?.useDict('sys_platform_yes_no'));
|
|
|
|
|
|
|
@@ -83,6 +95,7 @@ const single = ref(true);
|
|
|
const multiple = ref(true);
|
|
const multiple = ref(true);
|
|
|
const total = ref(0);
|
|
const total = ref(0);
|
|
|
|
|
|
|
|
|
|
+const codeArr = ref([]);
|
|
|
const queryFormRef = ref<ElFormInstance>();
|
|
const queryFormRef = ref<ElFormInstance>();
|
|
|
const bankFormRef = ref<ElFormInstance>();
|
|
const bankFormRef = ref<ElFormInstance>();
|
|
|
|
|
|
|
@@ -100,7 +113,7 @@ const initFormData: BankForm = {
|
|
|
bnCatgId: undefined,
|
|
bnCatgId: undefined,
|
|
|
faxNo: undefined,
|
|
faxNo: undefined,
|
|
|
telNo: undefined,
|
|
telNo: undefined,
|
|
|
- isShow: undefined,
|
|
|
|
|
|
|
+ isShow: '0',
|
|
|
remark: undefined
|
|
remark: undefined
|
|
|
};
|
|
};
|
|
|
const data = reactive<PageData<BankForm, BankQuery>>({
|
|
const data = reactive<PageData<BankForm, BankQuery>>({
|
|
@@ -144,6 +157,7 @@ const cancel = () => {
|
|
|
/** 表单重置 */
|
|
/** 表单重置 */
|
|
|
const reset = () => {
|
|
const reset = () => {
|
|
|
form.value = { ...initFormData };
|
|
form.value = { ...initFormData };
|
|
|
|
|
+ codeArr.value = [];
|
|
|
bankFormRef.value?.resetFields();
|
|
bankFormRef.value?.resetFields();
|
|
|
};
|
|
};
|
|
|
|
|
|
|
@@ -159,6 +173,40 @@ const resetQuery = () => {
|
|
|
handleQuery();
|
|
handleQuery();
|
|
|
};
|
|
};
|
|
|
|
|
|
|
|
|
|
+/** 处理区域选择变化 */
|
|
|
|
|
+const handleChange = (val: string[]) => {
|
|
|
|
|
+ // 保存编码
|
|
|
|
|
+ form.value.provincialNo = val[0];
|
|
|
|
|
+ form.value.cityNo = val[1];
|
|
|
|
|
+ form.value.countryNo = val[2];
|
|
|
|
|
+
|
|
|
|
|
+ // 根据编码获取名称
|
|
|
|
|
+ const names: string[] = [];
|
|
|
|
|
+ if (val[0]) {
|
|
|
|
|
+ const province = regionData.find((item: any) => item.value === val[0]);
|
|
|
|
|
+ if (province) {
|
|
|
|
|
+ names.push(province.label);
|
|
|
|
|
+
|
|
|
|
|
+ if (val[1] && province.children) {
|
|
|
|
|
+ const city = province.children.find((item: any) => item.value === val[1]);
|
|
|
|
|
+ if (city) {
|
|
|
|
|
+ names.push(city.label);
|
|
|
|
|
+
|
|
|
|
|
+ if (val[2] && city.children) {
|
|
|
|
|
+ const county = city.children.find((item: any) => item.value === val[2]);
|
|
|
|
|
+ if (county) {
|
|
|
|
|
+ names.push(county.label);
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // 将省市区名称用斜杠连接
|
|
|
|
|
+ form.value.provincialCityCountry = names.join('/');
|
|
|
|
|
+};
|
|
|
|
|
+
|
|
|
/** 多选框选中数据 */
|
|
/** 多选框选中数据 */
|
|
|
const handleSelectionChange = (selection: BankVO[]) => {
|
|
const handleSelectionChange = (selection: BankVO[]) => {
|
|
|
ids.value = selection.map((item) => item.id);
|
|
ids.value = selection.map((item) => item.id);
|
|
@@ -190,6 +238,7 @@ const handleUpdate = async (row?: BankVO) => {
|
|
|
reset();
|
|
reset();
|
|
|
const _id = row?.id || ids.value[0];
|
|
const _id = row?.id || ids.value[0];
|
|
|
const res = await getBank(_id);
|
|
const res = await getBank(_id);
|
|
|
|
|
+ codeArr.value = [res.data.provincialNo, res.data.cityNo, res.data.countryNo];
|
|
|
Object.assign(form.value, res.data);
|
|
Object.assign(form.value, res.data);
|
|
|
dialog.visible = true;
|
|
dialog.visible = true;
|
|
|
dialog.title = '修改银行信息';
|
|
dialog.title = '修改银行信息';
|