From 98a91e1cb21ecda83c18fa6b7127d1edc9e16d8b Mon Sep 17 00:00:00 2001 From: xingyu Date: Sun, 17 Nov 2024 20:58:43 +0800 Subject: [PATCH] feat: system post finish 2/3 --- apps/web-antd/src/api/system/post/index.ts | 2 +- .../src/views/system/post/PostModal.vue | 54 ++++++++ apps/web-antd/src/views/system/post/index.vue | 126 ++++++++++-------- .../src/views/system/post/post.data.ts | 103 ++++++++++++++ 4 files changed, 225 insertions(+), 60 deletions(-) create mode 100644 apps/web-antd/src/views/system/post/PostModal.vue create mode 100644 apps/web-antd/src/views/system/post/post.data.ts diff --git a/apps/web-antd/src/api/system/post/index.ts b/apps/web-antd/src/api/system/post/index.ts index a4b7e814..516261e4 100644 --- a/apps/web-antd/src/api/system/post/index.ts +++ b/apps/web-antd/src/api/system/post/index.ts @@ -12,7 +12,7 @@ export interface PostVO { // 查询岗位列表 export function getPostPage(params: any) { - return requestClient.get('/system/post/page', params); + return requestClient.get('/system/post/page', { params }); } // 获取岗位精简信息列表 diff --git a/apps/web-antd/src/views/system/post/PostModal.vue b/apps/web-antd/src/views/system/post/PostModal.vue new file mode 100644 index 00000000..64ce6a2d --- /dev/null +++ b/apps/web-antd/src/views/system/post/PostModal.vue @@ -0,0 +1,54 @@ + + diff --git a/apps/web-antd/src/views/system/post/index.vue b/apps/web-antd/src/views/system/post/index.vue index d469d3fc..d742c3f5 100644 --- a/apps/web-antd/src/views/system/post/index.vue +++ b/apps/web-antd/src/views/system/post/index.vue @@ -2,48 +2,21 @@ import type { VbenFormProps } from '#/adapter/form'; import type { VxeGridProps } from '#/adapter/vxe-table'; -import { Page } from '@vben/common-ui'; +import { Page, useVbenModal } from '@vben/common-ui'; +import { $t } from '@vben/locales'; -import { message } from 'ant-design-vue'; +import { Button, message } from 'ant-design-vue'; import { useVbenVxeGrid } from '#/adapter/vxe-table'; -import { getPostPage, type PostVO } from '#/api/system/post'; +import { exportPost, getPostPage, type PostVO } from '#/api/system/post'; + +import { columns, formSchema } from './post.data'; +import PostModal from './PostModal.vue'; const formOptions: VbenFormProps = { // 默认展开 collapsed: false, - schema: [ - { - component: 'Input', - fieldName: 'name', - label: '岗位名称', - }, - { - component: 'Input', - fieldName: 'code', - label: '岗位编码', - }, - // TODO: dict - { - component: 'Select', - componentProps: { - allowClear: true, - options: [ - { - label: 'Color1', - value: '1', - }, - { - label: 'Color2', - value: '2', - }, - ], - placeholder: '请选择', - }, - fieldName: 'status', - label: '状态', - }, - ], + schema: formSchema, // 控制表单是否显示折叠按钮 showCollapseButton: true, // 按下回车时是否提交表单 @@ -53,32 +26,15 @@ const formOptions: VbenFormProps = { const gridOptions: VxeGridProps = { checkboxConfig: { highlight: true, - labelField: 'name', + labelField: 'id', }, - columns: [ - { title: '序号', type: 'seq', width: 50 }, - { field: 'id', title: '岗位编号' }, - { field: 'name', title: '岗位名称' }, - { field: 'code', title: '岗位编码' }, - { field: 'sort', title: '岗位顺序' }, - { field: 'remark', title: '岗位备注' }, - { field: 'status', title: '状态' }, - { field: 'createTime', formatter: 'formatDateTime', title: '创建时间' }, - { - cellRender: { name: 'CellLink', props: { text: '编辑' } }, - field: 'action', - fixed: 'right', - title: '操作', - width: 120, - }, - ], + columns, height: 'auto', keepSource: true, pagerConfig: {}, proxyConfig: { ajax: { query: async ({ page }, formValues) => { - message.success(`Query params: ${JSON.stringify(formValues)}`); return await getPostPage({ page: page.currentPage, pageSize: page.pageSize, @@ -89,17 +45,69 @@ const gridOptions: VxeGridProps = { }, }; -const [Grid] = useVbenVxeGrid({ formOptions, gridOptions }); +const [Grid, tableApi] = useVbenVxeGrid({ formOptions, gridOptions }); + +const [FormModal, formModalApi] = useVbenModal({ + connectedComponent: PostModal, +}); + +function handleCreate() { + formModalApi.setData({ + valuse: {}, + }); + formModalApi.open(); +} +async function handleEdit(id: number) { + formModalApi.setData({ id }); + formModalApi.open(); +} +// TODO +function handleDelete(id: number) { + message.success(id); +} +// TODO +async function handleExport() { + await exportPost(tableApi.formApi.form.values); +}