This file provides guidance to Claude Code (claude.ai/code) when working with code in this repository.
使用 vue-tsc 进行类型检查。
# 其他检查
pnpm check:circular # 循环依赖扫描
pnpm check:dep # depcheck 依赖检查
pnpm check:cspell # 拼写检查
# 清理
pnpm clean # 删除 dist、node_modules 等产物
pnpm reinstall # clean + 重新安装
# 交互式规范提交
pnpm commit # czg 提交向导
Turbo 任务通过 dependsOn: ["^build"] 级联,构建某个应用时会自动先构建其所有依赖包。
apps/
backend-mock/ # 基于 Nitro 的 mock API 服务(h3 路由 + faker.js 数据)
web-antd/ # Ant Design Vue 应用
web-ele/ # Element Plus 应用
web-naive/ # Naive UI 应用
web-tdesign/ # TDesign Vue 应用
packages/
@core/ # 框架核心(不依赖具体 UI 库)
base/ # 共享工具、缓存、颜色处理、类型定义
composables/ # 核心 Vue composable
preferences/ # PreferenceManager 类(响应式、持久化配置)
ui-kit/ # UI 组件片段:form-ui、layout-ui、menu-ui、popup-ui、shadcn-ui、tabs-ui
effects/ # 高层模块,可依赖 @core 和 UI 库
access/ # 路由/菜单生成与权限指令
common-ui/ # 通用 UI 组件(ApiComponent、IconPicker、VCropper、Tippy 等)
hooks/ # useAppConfig 等
layouts/ # BasicLayout、登录页、各类 widgets
plugins/ # Motion 等插件
request/ # RequestClient(axios 封装 + 拦截器体系)
constants/ # 全局常量(LOGIN_PATH 等)
icons/ # Iconify 图标封装
locales/ # vue-i18n 初始化、loadLocalesMap 工具
preferences/ # 对外暴露 @core/preferences 的公共 API
stores/ # Pinia 全局 store:useAccessStore、useUserStore、useTabbarStore
styles/ # 全局 CSS / TailwindCSS 基础样式
types/ # 共享 TypeScript 类型
utils/ # 共享工具函数(mergeRouteModules、mapTree 等)
internal/
lint-configs/ # ESLint、Prettier、Stylelint、commitlint 配置包
node-utils/ # 构建时 Node 工具
tailwind-config/ # 共享 Tailwind 配置
tsconfig/ # 基础 tsconfig
vite-config/ # 共享 Vite 配置工厂 + 插件集合
scripts/
vsh/ # CLI 工具(lint、check-dep、check-circular、publint)
turbo-run/ # 交互式 turbo 运行器
playground/ # 组件演示场
docs/ # VitePress 文档
每个应用的 src/main.ts 调用 bootstrap(namespace)(位于 src/bootstrap.ts),依次执行:
src/adapter/component/index.ts)——将通用表单组件名映射到具体 UI 库的组件。initSetupVbenForm()(src/adapter/form.ts)配置通用表单系统。#app。@vben/preferences 导出单例 preferences(PreferenceManager)。它是响应式的,自动持久化到 localStorage(以应用 namespace 为前缀),并驱动主题 CSS 变量的更新。各应用在 src/preferences.ts 中调用 defineOverridesPreferences() 覆盖默认值,无需修改核心代码。
@vben/access(packages/effects/access)支持三种访问模式:
getAllMenusApi)获取菜单并动态注册路由。路由守卫(src/router/guard.ts)在登录后首次导航时调用 generateAccess(),将结果存入 useAccessStore,再重定向到目标页。v-access 指令和 <AccessControl> 组件用于按权限码或角色控制 UI 元素显示。
@vben/request 将 Axios 封装为 RequestClient。每个应用在 src/api/request.ts 中创建自己的实例,挂载以下拦截器:
defaultResponseInterceptor:解包 { code, data, message } 响应格式。authenticateResponseInterceptor:处理 401,自动刷新 token 或跳转登录。errorMessageResponseInterceptor:调用 message.error() 显示错误。在 API 文件中从 #/api/request 引入 requestClient(自动解包响应)或 baseRequestClient(原始响应)。
src/router/routes/modules/*.ts:需要权限验证的动态路由。src/router/routes/core/:始终可访问的路由(登录页、404 等)。mergeRouteModules(import.meta.glob(...)) 用于聚合路由模块文件。每个 UI 库应用在 src/adapter/ 下提供适配器,将 @vben/common-ui 的通用 form/modal/drawer 组件桥接到具体组件库。这是 web-antd、web-ele 等应用之间的主要差异所在。
useAccessStore:token、路由、菜单、锁屏、登录过期状态。useUserStore:用户信息、角色、homePath。useTabbarStore:已打开标签页管理。所有 store 通过 @vben/stores 的 initStores(app, { namespace }) 统一初始化。
apps/backend-mock 是一个 Nitro 服务器,可单独启动:pnpm -F @vben/backend-mock start。Vite 开发服务器通过 vite.config.ts(位于 internal/vite-config)将 API 请求代理到该服务。
#/* 指向各应用的 ./src/*(在 package.json#imports 中定义)。workspace:*,第三方包使用 catalog:(版本集中在 pnpm-workspace.yaml#catalog 中管理)。feat、fix、chore、docs、refactor、perf、test、ci、style、types、revert),由 lefthook + commitlint 强制执行。pnpm commit(czg)提交。src/views/ 下创建 .vue 文件,在 src/router/routes/modules/ 下添加路由模块;若使用 backend 模式,还需确保后端接口返回对应菜单数据。$t('key'),locale 文件位于 packages/locales/,项目级国际化文件位于 src/locales/langs。