为 Fantastic-admin 框架生成 Pinia Store 模块。当用户提到以下任何需求时必须使用此技能:多个页面需要共享数据、全局状态管理、数据需要持久化(刷新后还在)、登录状态/用户信息需要缓存、购物车/通知/权限等全局数据、需要在组件外访问状态。即使用户只是说"这个数据要全局共享"或"刷新后数据不能丢",也应触发此技能。触发关键词:创建 store、全局状态、状态管理、pinia、持久化、共享数据。
本项目是 monorepo 架构,apps/ 目录下存放各应用。在执行任何文件读写操作之前,必须先确认目标应用:
ls apps/ 列出所有可用应用严格规则:如果用户没有在请求中明确说明目标应用(例如"在 example 应用中"、"apps/core"),则必须提问,不得自行猜测或默认选择任何应用。
确认后,后续所有文件路径均以该应用目录为根,例如 apps/<app>/src/store/modules/。
apps/<app>/src/store/modules/ (业务 store)defineStore + setup 函数)unplugin-auto-import 自动导入,组件中无需手动 importpinia-plugin-persistedstate v4,配置 persist: { pick: [...] }详细模板和示例见 references/store-patterns.md
先收集信息再生成代码,因为 store 的字段结构、持久化需求、异步 action 直接决定代码骨架——跳过这步会生成空壳,用户还要大量修改。
向用户提问(可合并为一次):
apps/<app>/src/store/modules/ — 业务 store(推荐)apps/<app>/src/store/modules/app/ — 框架级 store(仅框架内部使用)根据 Step 1 的回答,继续询问:
汇总用户的回答,展示将要生成的内容摘要,确认后再写入文件。
| 类型 | Store ID | 函数名 | 文件名 |
|---|---|---|---|
| 业务 store | camelCase | use<Name>Store | <name>.ts |
| 框架 store | app<Name> | useApp<Name>Store | <name>.ts |
示例:
cart,函数: useCartStore,文件: apps/<app>/src/store/modules/cart.tsnotification,函数: useNotificationStore,文件: apps/<app>/src/store/modules/notification.tsStore 文件创建完成后,告知用户:
unplugin-auto-import 已自动处理const xxxStore = useXxxStore()useXxxStore(pinia)