* fix(@vben/web-antd): erp 解决冲突 * fix(@vben/web-antd): erp 更新采购和销售退货表单,修复关联订单选择功能不统一详细可编辑的问题,统一文件名称格式 * feat(@vben/web-antd): erp-finance-account 新增结算账户管理功能,包括表单、列表及相关操作 * feat(@vben/web-antd): erp-sale-return 新增销售退货管理功能,包括退货列表、表单及相关操作 * feat(@vben/web-antd): erp-sale-out 新增销售出库管理功能,包括出库列表、表单及相关操作 * feat(@vben/web-antd): erp-sale-order 新增销售订单管理功能,包括订单列表、表单及相关操作 * feat(@vben/web-antd): erp-sale-customer 新增客户管理功能,包括客户表单、列表及相关操作 * feat(@vben/web-antd): erp-purchase-return 新增采购退货管理功能,包括表单、列表及相关操作 * feat(@vben/web-antd): erp-purchase-in 新增采购入库管理功能,包括表单、列表及相关操作 * feat(@vben/web-antd): erp-stock-check 新增库存盘点单管理功能,包括表单、列表及相关操作 * feat(@vben/web-antd): erp-stock-move 新增库存调拨单管理功能,包括表单、列表及相关操作 * feat(@vben/web-antd): erp-stock-out 新增其它出库单管理功能,包括表单、列表及相关操作 * fix(@vben/web-antd): erp-stock-in 修复提交表单时清空产品项 ID,确保请求成功不报row_xxx报错
168 lines
3.3 KiB
TypeScript
168 lines
3.3 KiB
TypeScript
import type { VbenFormSchema } from '#/adapter/form';
|
|
import type { VxeTableGridOptions } from '#/adapter/vxe-table';
|
|
|
|
import { h } from 'vue';
|
|
|
|
import { Tag } from 'ant-design-vue';
|
|
|
|
import { z } from '#/adapter/form';
|
|
import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils';
|
|
|
|
/** 新增/修改的表单 */
|
|
export function useFormSchema(): VbenFormSchema[] {
|
|
return [
|
|
{
|
|
component: 'Input',
|
|
fieldName: 'id',
|
|
dependencies: {
|
|
triggerFields: [''],
|
|
show: () => false,
|
|
},
|
|
},
|
|
{
|
|
component: 'Input',
|
|
fieldName: 'name',
|
|
label: '名称',
|
|
rules: 'required',
|
|
componentProps: {
|
|
placeholder: '请输入名称',
|
|
},
|
|
},
|
|
{
|
|
fieldName: 'status',
|
|
label: '状态',
|
|
component: 'RadioGroup',
|
|
componentProps: {
|
|
options: getDictOptions(DICT_TYPE.COMMON_STATUS, 'number'),
|
|
buttonStyle: 'solid',
|
|
optionType: 'button',
|
|
},
|
|
rules: z.number().default(CommonStatusEnum.ENABLE),
|
|
},
|
|
|
|
{
|
|
fieldName: 'sort',
|
|
label: '排序',
|
|
component: 'InputNumber',
|
|
componentProps: {
|
|
placeholder: '请输入排序',
|
|
precision: 0,
|
|
class: 'w-full',
|
|
},
|
|
rules: 'required',
|
|
defaultValue: 0,
|
|
},
|
|
{
|
|
fieldName: 'defaultStatus',
|
|
label: '是否默认',
|
|
component: 'RadioGroup',
|
|
componentProps: {
|
|
options: [
|
|
{
|
|
label: '是',
|
|
value: true,
|
|
},
|
|
{
|
|
label: '否',
|
|
value: false,
|
|
},
|
|
],
|
|
buttonStyle: 'solid',
|
|
optionType: 'button',
|
|
},
|
|
rules: z.boolean().default(false).optional(),
|
|
},
|
|
{
|
|
fieldName: 'no',
|
|
label: '编码',
|
|
component: 'Input',
|
|
componentProps: {
|
|
placeholder: '请输入编码',
|
|
},
|
|
},
|
|
{
|
|
fieldName: 'remark',
|
|
label: '备注',
|
|
component: 'Textarea',
|
|
},
|
|
];
|
|
}
|
|
|
|
/** 列表的搜索表单 */
|
|
export function useGridFormSchema(): VbenFormSchema[] {
|
|
return [
|
|
{
|
|
fieldName: 'name',
|
|
label: '名称',
|
|
component: 'Input',
|
|
},
|
|
{
|
|
fieldName: 'no',
|
|
label: '编码',
|
|
component: 'Input',
|
|
},
|
|
{
|
|
fieldName: 'remark',
|
|
label: '备注',
|
|
component: 'Input',
|
|
},
|
|
];
|
|
}
|
|
|
|
/** 列表的字段 */
|
|
export function useGridColumns(): VxeTableGridOptions['columns'] {
|
|
return [
|
|
{
|
|
field: 'name',
|
|
title: '名称',
|
|
},
|
|
{
|
|
field: 'no',
|
|
title: '编码',
|
|
},
|
|
{
|
|
field: 'remark',
|
|
title: '备注',
|
|
},
|
|
{
|
|
field: 'sort',
|
|
title: '排序',
|
|
},
|
|
{
|
|
field: 'status',
|
|
title: '状态',
|
|
cellRender: {
|
|
name: 'CellDict',
|
|
props: { type: DICT_TYPE.COMMON_STATUS },
|
|
},
|
|
},
|
|
{
|
|
field: 'defaultStatus',
|
|
title: '是否默认',
|
|
slots: {
|
|
default: ({ row }) => {
|
|
return h(
|
|
Tag,
|
|
{
|
|
class: 'mr-1',
|
|
color: row.defaultStatus ? 'blue' : 'red',
|
|
},
|
|
() => (row.defaultStatus ? '是' : '否'),
|
|
);
|
|
},
|
|
},
|
|
},
|
|
{
|
|
field: 'createTime',
|
|
title: '创建时间',
|
|
formatter: 'formatDateTime',
|
|
},
|
|
{
|
|
title: '操作',
|
|
width: 130,
|
|
fixed: 'right',
|
|
slots: { default: 'actions' },
|
|
},
|
|
];
|
|
}
|