Files
admin-vben5/apps/web-antd/src/views/property/personalCenter/processInstance/data.tsx
2025-08-06 16:47:42 +08:00

92 lines
1.8 KiB
TypeScript

import type { FormSchemaGetter } from '#/adapter/form';
import type { VxeGridProps } from '#/adapter/vxe-table';
import { DictEnum } from '@vben/constants';
import { OptionsTag } from '#/components/table';
import { renderDict } from '#/utils/render';
import { activityStatusOptions } from '../processDefinition/constant';
export const querySchema: FormSchemaGetter = () => [
{
component: 'Input',
label: '任务名称',
fieldName: 'nodeName',
},
{
component: 'Input',
label: '流程名称',
fieldName: 'flowName',
},
{
component: 'Input',
label: '流程编码',
fieldName: 'flowCode',
},
];
export const columns: VxeGridProps['columns'] = [
{ type: 'checkbox', width: 60 },
{
field: 'flowName',
title: '流程名称',
minWidth: 150,
},
{
field: 'nodeName',
title: '任务名称',
minWidth: 150,
},
{
field: 'flowCode',
title: '流程编码',
minWidth: 150,
},
{
field: 'createByName',
title: '申请人',
minWidth: 150,
},
{
field: 'version',
title: '版本号',
minWidth: 150,
formatter: ({ cellValue }) => `V${cellValue}.0`,
},
{
field: 'activityStatus',
title: '状态',
minWidth: 100,
slots: {
default: ({ row }) => {
const cellValue = row.activityStatus;
return (
<OptionsTag
options={activityStatusOptions as any}
value={cellValue}
/>
);
},
},
},
{
field: 'flowStatus',
title: '流程状态',
minWidth: 100,
slots: {
default: ({ row }) => {
return renderDict(row.flowStatus, DictEnum.WF_BUSINESS_STATUS);
},
},
},
{
field: 'action',
fixed: 'right',
slots: { default: 'action' },
title: '操作',
resizable: false,
width: 200,
},
];