From 6f18718c879a56a619719ee3ed81885500935994 Mon Sep 17 00:00:00 2001 From: allen <495141992@qq.com> Date: Mon, 13 Apr 2026 19:20:01 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20add=20collapsible=20=E7=BB=84=E4=BB=B6?= =?UTF-8?q?=EF=BC=8Cform=E8=A1=A8=E5=8D=95=E5=A2=9E=E5=8A=A0=E5=8D=95?= =?UTF-8?q?=E9=A1=B9=E5=8F=AF=E6=8A=98=E5=8F=A0=EF=BC=8C=E6=94=AF=E6=8C=81?= =?UTF-8?q?schema=E9=85=8D=E7=BD=AE=E9=BB=98=E8=AE=A4=E5=85=B3=E9=97=AD/?= =?UTF-8?q?=E5=BC=80=E5=90=AF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit feat: add collapsible 组件,form表单增加单项可折叠,支持schema配置默认关闭/开启 - shadcn-ui 增加 collapsible组件,collapsible-params组件 - form新增支持单项折叠 - collapsible-params组件在Form表单应用 --- apps/web-naive/package.json | 1 + apps/web-naive/src/views/demos/form/basic.vue | 169 ++++++++++++- packages/@core/base/icons/src/lucide.ts | 1 + .../form-ui/src/components/form-actions.vue | 4 - .../form-ui/src/form-render/form-field.vue | 160 +++++++----- .../form-ui/src/form-render/form-label.vue | 1 + packages/@core/ui-kit/form-ui/src/types.ts | 9 + .../collapsible/collapsible-params-item.vue | 98 ++++++++ .../collapsible/collapsible-params.vue | 230 ++++++++++++++++++ .../components/collapsible/collapsible.vue | 77 ++++++ .../src/components/collapsible/index.ts | 4 + .../src/components/collapsible/type.ts | 15 ++ .../ui-kit/shadcn-ui/src/components/index.ts | 1 + .../src/locales/langs/en-US/examples.json | 3 +- .../src/locales/langs/zh-CN/examples.json | 3 +- .../src/router/routes/modules/examples.ts | 8 + .../src/views/examples/form/collapsible.vue | 210 ++++++++++++++++ pnpm-lock.yaml | 3 + 18 files changed, 929 insertions(+), 68 deletions(-) create mode 100644 packages/@core/ui-kit/shadcn-ui/src/components/collapsible/collapsible-params-item.vue create mode 100644 packages/@core/ui-kit/shadcn-ui/src/components/collapsible/collapsible-params.vue create mode 100755 packages/@core/ui-kit/shadcn-ui/src/components/collapsible/collapsible.vue create mode 100755 packages/@core/ui-kit/shadcn-ui/src/components/collapsible/index.ts create mode 100644 packages/@core/ui-kit/shadcn-ui/src/components/collapsible/type.ts create mode 100644 playground/src/views/examples/form/collapsible.vue diff --git a/apps/web-naive/package.json b/apps/web-naive/package.json index e7ab20bab..d8940c0d1 100644 --- a/apps/web-naive/package.json +++ b/apps/web-naive/package.json @@ -26,6 +26,7 @@ "#/*": "./src/*" }, "dependencies": { + "@vben-core/shadcn-ui": "workspace:*", "@vben/access": "workspace:*", "@vben/common-ui": "workspace:*", "@vben/constants": "workspace:*", diff --git a/apps/web-naive/src/views/demos/form/basic.vue b/apps/web-naive/src/views/demos/form/basic.vue index 60702a11e..0dcf9bc30 100644 --- a/apps/web-naive/src/views/demos/form/basic.vue +++ b/apps/web-naive/src/views/demos/form/basic.vue @@ -1,7 +1,19 @@