ruoyi-plus-vben5/apps/web-antd/src/views/workflow/processDefinition/data.tsx

174 lines
3.9 KiB
TypeScript
Raw Normal View History

2024-12-11 21:33:59 +08:00
import type { VxeGridProps } from '#/adapter/vxe-table';
import { DictEnum } from '@vben/constants';
import { getPopupContainer } from '@vben/utils';
import { type FormSchemaGetter, z } from '#/adapter/form';
import { getDictOptions } from '#/utils/dict';
export const querySchema: FormSchemaGetter = () => [
{
component: 'Input',
fieldName: 'flowName',
label: '流程名称',
},
{
component: 'Input',
fieldName: 'flowCode',
label: '流程code',
},
];
export const columns: VxeGridProps['columns'] = [
{ type: 'checkbox', width: 60 },
{
field: 'flowName',
title: '流程名称',
minWidth: 150,
},
{
field: 'flowCode',
title: '流程code',
minWidth: 150,
},
{
field: 'version',
title: '版本号',
minWidth: 80,
formatter: ({ cellValue }) => `V${cellValue}.0`,
},
{
field: 'activityStatus',
title: '状态',
minWidth: 100,
},
{
field: 'isPublish',
title: '发布状态',
minWidth: 100,
},
{
field: 'action',
fixed: 'right',
slots: { default: 'action' },
title: '操作',
resizable: false,
width: 180,
},
];
export const drawerSchema: FormSchemaGetter = () => [
{
component: 'Input',
dependencies: {
show: () => false,
triggerFields: [''],
},
fieldName: 'userId',
},
{
component: 'Input',
fieldName: 'userName',
label: '用户账号',
rules: 'required',
},
{
component: 'InputPassword',
fieldName: 'password',
label: '用户密码',
rules: 'required',
},
{
component: 'Input',
fieldName: 'nickName',
label: '用户昵称',
rules: 'required',
},
{
component: 'TreeSelect',
// 在drawer里更新 这里不需要默认的componentProps
defaultValue: undefined,
fieldName: 'deptId',
label: '所属部门',
rules: 'selectRequired',
},
{
component: 'Input',
fieldName: 'phonenumber',
label: '手机号码',
defaultValue: undefined,
rules: z
.string()
.regex(/^1[3-9]\d{9}$/, '请输入正确的手机号码')
.optional()
.or(z.literal('')),
},
{
component: 'Input',
fieldName: 'email',
defaultValue: undefined,
label: '邮箱',
/**
* z.literal Zod
*
* 使 z.literal
*
*/
rules: z.string().email('请输入正确的邮箱').optional().or(z.literal('')),
},
{
component: 'RadioGroup',
componentProps: {
buttonStyle: 'solid',
options: getDictOptions(DictEnum.SYS_USER_SEX),
optionType: 'button',
},
defaultValue: '0',
fieldName: 'sex',
formItemClass: 'col-span-2 lg:col-span-1',
label: '性别',
},
{
component: 'RadioGroup',
componentProps: {
buttonStyle: 'solid',
options: getDictOptions(DictEnum.SYS_NORMAL_DISABLE),
optionType: 'button',
},
defaultValue: '0',
fieldName: 'status',
formItemClass: 'col-span-2 lg:col-span-1',
label: '状态',
},
{
component: 'Select',
componentProps: {
getPopupContainer,
mode: 'multiple',
optionFilterProp: 'label',
optionLabelProp: 'label',
placeholder: '请先选择部门',
},
fieldName: 'postIds',
help: '选择部门后, 将自动加载该部门下所有的岗位',
label: '岗位',
},
{
component: 'Select',
componentProps: {
getPopupContainer,
mode: 'multiple',
optionFilterProp: 'title',
optionLabelProp: 'title',
},
fieldName: 'roleIds',
label: '角色',
},
{
component: 'Textarea',
fieldName: 'remark',
formItemClass: 'items-baseline',
label: '备注',
},
];