feat: 更新codegen页面

-将按钮工具栏替换为ActionButtons组件,以提高UI一致性。
-实现导入表功能。
pull/52/head
chenminjie 2024-11-27 20:41:00 +08:00
parent 14a15347e1
commit 05262754b1
3 changed files with 120 additions and 63 deletions

View File

@ -4,6 +4,7 @@ import type { VxeGridProps } from '#/adapter/vxe-table';
import type { CodegenApi } from '#/api/infra/codegen';
import { getDataSourceConfigList } from '#/api/infra/data-source-config';
import { $t } from '#/locales';
export namespace CodegenDefaultData {
/**
@ -26,10 +27,11 @@ export namespace CodegenDefaultData {
{ field: 'createTime', title: '创建时间', formatter: 'formatDateTime' },
{ field: 'updateTime', title: '更新时间', formatter: 'formatDateTime' },
{
title: '操作',
width: 'auto',
field: 'action',
fixed: 'right',
width: 'auto',
slots: { default: 'action' },
title: $t('page.action.action'),
},
];
/**

View File

@ -8,13 +8,19 @@ import {
type VxeGridProps,
} from '@vben/plugins/vxe-table';
import { getSchemaTableList } from '#/api/infra/codegen';
import {
type CodegenApi,
createCodegenList,
getSchemaTableList,
} from '#/api/infra/codegen';
import { CodegenImportTableModalData } from '../codegen.data';
const confirmLoading = ref<boolean>(false);
// checked
const checkedStatus = ref<boolean>(false);
const checkedRecords = ref<any[]>([]);
/**
* 表格查询表单配置
*/
@ -55,8 +61,9 @@ const gridOptions = reactive<any>({
const gridEvents = reactive<any>({
checkboxChange: (params) => {
const { checked } = params;
const { checked, $grid } = params;
checkedStatus.value = checked;
checkedRecords.value = $grid.getCheckboxRecords();
},
checkboxAll: (params) => {
const { checked } = params;
@ -73,11 +80,30 @@ const [Grid, gridApi] = useVbenVxeGrid(
}),
);
const [Modal] = useVbenModal({
const [Modal, modalApi] = useVbenModal({
class: 'w-[800px] h-[800px]',
confirmLoading: confirmLoading.value,
closeOnClickModal: false,
closeOnPressEscape: false,
onOpened: async () => {
gridApi.reload(await gridApi.formApi.getValues());
},
onConfirm: async () => {
modalApi.setState({ confirmLoading: true });
const formValues = await gridApi.formApi.getValues();
//
const checkedRecords =
gridApi.grid.getCheckboxRecords() as CodegenApi.DatabaseTableRespVO[];
try {
await createCodegenList({
dataSourceConfigId: formValues.dataSourceConfigId,
tableNames: checkedRecords.map((item) => item.name),
});
} finally {
modalApi.setState({ confirmLoading: false });
}
modalApi.close();
},
});
</script>

View File

@ -3,24 +3,16 @@ import { defineAsyncComponent, reactive, ref } from 'vue';
import { Page, useVbenModal, type VbenFormProps } from '@vben/common-ui';
import { Button } from 'ant-design-vue';
import {
useVbenVxeGrid,
type VxeGridListeners,
type VxeGridProps,
} from '#/adapter/vxe-table';
import { type CodegenApi, getCodegenTablePage } from '#/api/infra/codegen';
import { ActionButtons, IconEnum } from '#/components/action-buttons';
import { CodegenDefaultData } from './codegen.data';
// 使
const [ImportTableModal, importTableModalApi] = useVbenModal({
connectedComponent: defineAsyncComponent(
() => import('./components/import-table-modal.vue'),
),
});
// checked
const checkedStatus = ref<boolean>(false);
@ -52,14 +44,6 @@ const handleBatchDelete = (_rows: CodegenApi.CodegenTableRespVO[]) => {
// console.log('', rows);
};
/**
* 导入表
*/
const handleImportTable = () => {
// console.log('', importTableModalApi);
importTableModalApi.open();
};
/**
* 同步
*/
@ -109,10 +93,9 @@ const formOptions = reactive<any>({
*/
const gridOptions = reactive<any>({
columns: CodegenDefaultData.tableColumns,
toolbarConfig: {
slots: {
buttons: 'toolbar_buttons',
},
height: 'auto',
checkboxConfig: {
reserve: true,
},
proxyConfig: {
ajax: {
@ -140,53 +123,99 @@ const gridEvents = reactive<any>({
} as VxeGridListeners);
// 使
const [Grid] = useVbenVxeGrid({
const [Grid, gridApi] = useVbenVxeGrid({
formOptions,
gridOptions,
gridEvents,
});
// 使
const [ImportTableModal, importTableModalApi] = useVbenModal({
connectedComponent: defineAsyncComponent(
() => import('./components/import-table-modal.vue'),
),
onClosed: () => {
gridApi.reload(formOptions.values);
},
});
</script>
<template>
<Page auto-content-height>
<Grid>
<template #toolbar_buttons="{ $grid }">
<div class="flex items-center gap-2">
<Button type="primary" @click="handleImportTable"></Button>
<Button
:disabled="!checkedStatus"
type="primary"
@click="handleBatchSync($grid.getCheckboxRecords())"
>
批量同步
</Button>
<Button
:disabled="!checkedStatus"
type="primary"
@click="handleBatchGenerateCode($grid.getCheckboxRecords())"
>
批量生成
</Button>
<Button
:disabled="!checkedStatus"
danger
type="primary"
@click="handleBatchDelete($grid.getCheckboxRecords())"
>
批量删除
</Button>
</div>
<template #toolbar-actions>
<ActionButtons
:actions="[
{
type: 'primary',
label: '导入表',
icon: IconEnum.ADD,
onClick: () => importTableModalApi.open(),
},
{
label: '批量同步',
disabled: !checkedStatus,
class: checkedStatus
? 'bg-emerald-500 text-white border-emerald-400 hover:bg-emerald-400 hover:!text-white hover:!border-emerald-400 active:!bg-emerald-600 active:!text-white active:!border-emerald-600'
: '',
icon: 'ant-design:sync-outlined',
onClick: handleBatchSync,
},
{
label: '批量生成',
disabled: !checkedStatus,
class: checkedStatus
? 'bg-emerald-500 text-white border-emerald-400 hover:bg-emerald-400 hover:!text-white hover:!border-emerald-400 active:!bg-emerald-600 active:!text-white active:!border-emerald-600'
: '',
icon: 'ant-design:code-outlined',
onClick: handleBatchGenerateCode,
},
{
label: '批量删除',
disabled: !checkedStatus,
danger: true,
icon: 'ant-design:delete-outlined',
onClick: handleBatchDelete,
},
]"
/>
</template>
<template #action="{ row }">
<div class="flex w-fit items-center justify-around">
<Button type="link" @click="handleView(row)"></Button>
<Button type="link" @click="handleEdit(row)"></Button>
<Button type="link" @click="handleSync(row)"></Button>
<Button type="link" @click="handleGenerateCode(row)">
生成代码
</Button>
<Button danger type="link" @click="handleDelete(row)"></Button>
</div>
<ActionButtons
:actions="[
{
type: 'link',
label: '查看',
icon: 'ant-design:eye-outlined',
onClick: handleView.bind(null, row),
},
{
type: 'link',
label: '编辑',
icon: 'ant-design:edit-outlined',
onClick: handleEdit.bind(null, row),
},
{
type: 'link',
label: '删除',
danger: true,
icon: 'ant-design:delete-outlined',
onClick: handleDelete.bind(null, row),
},
]"
:drop-down-actions="[
{
label: '同步',
icon: 'ant-design:sync-outlined',
onClick: handleSync.bind(null, row),
},
{
label: '生成代码',
icon: 'ant-design:code-outlined',
onClick: handleGenerateCode.bind(null, row),
},
]"
/>
</template>
</Grid>
<ImportTableModal />