diff --git a/packages/@core/ui-kit/form-ui/src/form-api.ts b/packages/@core/ui-kit/form-ui/src/form-api.ts
index 459ba0805a9..1bb052f16a7 100644
--- a/packages/@core/ui-kit/form-ui/src/form-api.ts
+++ b/packages/@core/ui-kit/form-ui/src/form-api.ts
@@ -121,6 +121,47 @@ export class FormApi {
return form.values;
}
+ merge(formApi: FormApi) {
+ const chain = [this, formApi];
+ const proxy = new Proxy(formApi, {
+ get(target: any, prop: any) {
+ if (prop === 'merge') {
+ return (nextFormApi: FormApi) => {
+ chain.push(nextFormApi);
+ return proxy;
+ };
+ }
+ if (prop === 'submitAllForm') {
+ return async (needMerge: boolean = true) => {
+ try {
+ const results = await Promise.all(
+ chain.map(async (api) => {
+ const form = await api.getForm();
+ const validateResult = await api.validate();
+ if (!validateResult.valid) {
+ return;
+ }
+ const rawValues = toRaw(form.values || {});
+ return rawValues;
+ }),
+ );
+ if (needMerge) {
+ const mergedResults = Object.assign({}, ...results);
+ return mergedResults;
+ }
+ return results;
+ } catch (error) {
+ console.error('Validation error:', error);
+ }
+ };
+ }
+ return target[prop];
+ },
+ });
+
+ return proxy;
+ }
+
mount(formActions: FormActions) {
if (!this.isMounted) {
Object.assign(this.form, formActions);
diff --git a/playground/src/locales/langs/en-US.json b/playground/src/locales/langs/en-US.json
index 9e926ca89b7..92ce74fca2b 100644
--- a/playground/src/locales/langs/en-US.json
+++ b/playground/src/locales/langs/en-US.json
@@ -79,7 +79,8 @@
"rules": "Form Rules",
"dynamic": "Dynamic Form",
"custom": "Custom Component",
- "api": "Api"
+ "api": "Api",
+ "merge": "Merge Form"
},
"captcha": {
"title": "Captcha",
diff --git a/playground/src/locales/langs/zh-CN.json b/playground/src/locales/langs/zh-CN.json
index 08a2c38f4a3..ca28d818de5 100644
--- a/playground/src/locales/langs/zh-CN.json
+++ b/playground/src/locales/langs/zh-CN.json
@@ -79,7 +79,8 @@
"rules": "表单校验",
"dynamic": "动态表单",
"custom": "自定义组件",
- "api": "Api"
+ "api": "Api",
+ "merge": "合并表单"
},
"captcha": {
"title": "验证码",
diff --git a/playground/src/router/routes/modules/examples.ts b/playground/src/router/routes/modules/examples.ts
index 954c1154c34..697d47892d7 100644
--- a/playground/src/router/routes/modules/examples.ts
+++ b/playground/src/router/routes/modules/examples.ts
@@ -99,6 +99,14 @@ const routes: RouteRecordRaw[] = [
title: $t('page.examples.form.api'),
},
},
+ {
+ name: 'FormMergeExample',
+ path: '/examples/form/merge',
+ component: () => import('#/views/examples/form/merge.vue'),
+ meta: {
+ title: $t('page.examples.form.merge'),
+ },
+ },
],
},
{
diff --git a/playground/src/views/examples/form/merge.vue b/playground/src/views/examples/form/merge.vue
new file mode 100644
index 00000000000..95f0804bf1a
--- /dev/null
+++ b/playground/src/views/examples/form/merge.vue
@@ -0,0 +1,117 @@
+
+
+
+
+
+
+
+
+
+
+
+
+