feat(project): 添加vben5前端

This commit is contained in:
wcg
2026-01-04 13:45:07 +08:00
parent 2c0689fe02
commit 51ee3fb460
839 changed files with 74231 additions and 0 deletions

View File

@@ -0,0 +1,131 @@
import type { FormSchemaGetter } from '#/adapter/form';
import type { VxeGridProps } from '#/adapter/vxe-table';
import { DictEnum } from '@vben/constants';
import { getPopupContainer } from '@vben/utils';
import { getDictOptions } from '#/utils/dict';
import { renderDict } from '#/utils/render';
export const querySchema: FormSchemaGetter = () => [
{
component: 'Input',
fieldName: 'postCode',
label: '岗位编码',
},
{
component: 'Input',
fieldName: 'postName',
label: '岗位名称',
},
{
component: 'Select',
componentProps: {
getPopupContainer,
options: [
{ label: '启用', value: true },
{ label: '禁用', value: false },
],
},
fieldName: 'state',
label: '状态',
},
];
export const columns: VxeGridProps['columns'] = [
{ type: 'checkbox', width: 60 },
{
title: '岗位编码',
field: 'postCode',
},
{
title: '岗位名称',
field: 'postName',
},
{
title: '排序',
field: 'orderNum',
},
{
title: '状态',
field: 'state',
slots: {
default: ({ row }) => {
return renderDict(String(row.state), DictEnum.SYS_NORMAL_DISABLE);
},
},
},
{
title: '创建时间',
field: 'creationTime',
},
{
field: 'action',
fixed: 'right',
slots: { default: 'action' },
title: '操作',
resizable: false,
width: 'auto',
},
];
export const drawerSchema: FormSchemaGetter = () => [
{
component: 'Input',
dependencies: {
show: () => false,
triggerFields: [''],
},
fieldName: 'id',
label: 'id',
},
{
component: 'TreeSelect',
componentProps: {
getPopupContainer,
},
fieldName: 'deptId',
label: '所属部门',
rules: 'selectRequired',
},
{
component: 'Input',
fieldName: 'postName',
label: '岗位名称',
rules: 'required',
},
{
component: 'Input',
fieldName: 'postCode',
label: '岗位编码',
rules: 'required',
},
{
component: 'InputNumber',
fieldName: 'orderNum',
label: '岗位排序',
rules: 'required',
defaultValue: 0,
},
{
component: 'RadioGroup',
componentProps: {
buttonStyle: 'solid',
options: [
{ label: '启用', value: true },
{ label: '禁用', value: false },
],
optionType: 'button',
},
defaultValue: true,
fieldName: 'state',
label: '岗位状态',
rules: 'required',
},
{
component: 'Textarea',
fieldName: 'remark',
formItemClass: 'items-start',
label: '备注',
},
];