feat: 代码生成 支持选择表单生成类型(需要模板支持)

This commit is contained in:
dap 2025-03-08 16:00:32 +08:00
parent 6e0c79411b
commit 55f5e6bd0c
6 changed files with 24 additions and 3 deletions

View File

@ -3,6 +3,7 @@
**FEATURES**
- 代码生成支持路径方式生成
- 代码生成 支持选择表单生成类型(需要模板支持)
# 1.2.1

View File

@ -1,6 +1,6 @@
{
"name": "@vben/web-antd",
"version": "1.2.1",
"version": "1.2.2",
"homepage": "https://vben.pro",
"bugs": "https://github.com/vbenjs/vue-vben-admin/issues",
"repository": {

View File

@ -177,6 +177,7 @@ export interface Info {
// 树表需要添加此属性
params?: any;
popupComponent?: string;
formComponent?: string;
}
export interface GenInfo {

View File

@ -82,6 +82,7 @@ async function handleSave() {
...requestData.params,
parentMenuId: requestData.parentMenuId,
popupComponent: requestData.popupComponent,
formComponent: requestData.formComponent,
};
}
//

View File

@ -109,9 +109,12 @@ onMounted(async () => {
await formApi.setValues(info);
//
if (info.options) {
const popupComponent = JSON.parse(info.options)?.popupComponent;
const { popupComponent, formComponent } = JSON.parse(info.options);
if (popupComponent) {
await formApi.setFieldValue('popupComponent', popupComponent);
formApi.setFieldValue('popupComponent', popupComponent);
}
if (formComponent) {
formApi.setFieldValue('formComponent', formComponent);
}
}
await Promise.all([initTreeSelect(info.columns), initMenuSelect()]);

View File

@ -157,6 +157,21 @@ export const formSchema: FormSchemaGetter = () => [
fieldName: 'popupComponent',
label: '弹窗组件类型',
},
{
component: 'RadioGroup',
componentProps: {
buttonStyle: 'solid',
options: [
{ label: 'useVbenForm', value: 'useForm' },
{ label: 'antd原生表单', value: 'native' },
],
optionType: 'button',
},
help: '自定义功能, 需要后端支持\n复杂(布局, 联动等)表单建议用antd原生表单',
defaultValue: 'useForm',
fieldName: 'formComponent',
label: '生成表单类型',
},
{
component: 'RadioGroup',
componentProps: {