tansci/.claude/skills/fa-slot-creator/SKILL.md
xuewuerduo f468d532b1 feat: 初始化tansci资产管理项目
包含以下模块:
- antdv-next-admin: Vue 3 + TypeScript + Ant Design Vue 管理后台
  - 设备/许可证/配件/耗材 CRUD 管理页面
  - 基础数据管理 (分类/位置/制造商/型号/供应商)
  - 业务管理 (故障报修/盘点/资产分配/资产申请/交易记录)
  - 下拉选项改造 (ID输入框 → 搜索下拉选择)
  - 资产状态字典化 (接入sys_dict系统)
  - 界面文案优化 (设备→资产, 在库/在用/维修中/已报废)
  - 修复 console 警告 (popupClassName, 重复组件注册)
- our-itam: Java Spring Boot + magic-api 后端服务
- fantastic-admin: 前端底层框架 (pnpm monorepo)
- ciyo-itasset: CIYO 资产模块
- magic-script-skill: Claude Code skill 定义
- .claude: 对话历史记录

Co-Authored-By: Claude Code <noreply@anthropic.com>
2026-05-17 21:41:22 +08:00

3.8 KiB
Raw Blame History

name description
fa-slot-creator 在 Fantastic-admin 框架中创建插槽,向布局的任意位置注入自定义内容。当用户提到以下任何需求时必须使用此技能:在头部/侧边栏/工具栏/标签栏加东西、logo 旁边加内容、侧边栏底部加用户信息、加个悬浮按钮、在导航菜单右侧加自定义组件、想在框架布局某个区域插入内容、在页面顶部或底部插入全局横幅/公告/版权栏。即使用户只是说"在顶部加个 XX"或"侧边栏加点东西",也应触发此技能。支持 19 个插槽位置。

Fantastic-admin 插槽创建器

框架通过约定自动发现插槽:目录名必须与插槽名完全匹配(区分大小写),文件名固定为 index.vue。不符合约定的文件不会被加载,这是框架的自动发现机制决定的。

第一步:确认工作区(必须阻塞等待用户回复)

本项目是 monorepo 架构,apps/ 目录下存放各应用。在执行任何文件读写操作之前,必须先确认目标应用:

  1. 执行 ls apps/ 列出所有可用应用
  2. 立即向用户提问,明确询问要在哪个应用中创建插槽,并停止等待回复
  3. 收到用户明确回复后,才能继续后续步骤

严格规则:如果用户没有在请求中明确说明目标应用(例如"在 example 应用中"、"apps/core"),则必须提问,不得自行猜测或默认选择任何应用。

确认后,后续所有文件路径均以该应用目录为根,例如 apps/<app>/src/slots/

创建插槽(手动步骤)

  1. 创建目录:apps/<app>/src/slots/{插槽名称}/
  2. 在该目录下创建 index.vue 文件,内容参考下方模板

普通插槽模板

<script setup lang="ts">
// 在此添加插槽逻辑
</script>

<template>
  <div>
    <!-- 在此添加插槽内容 -->
  </div>
</template>

<style scoped>
/* 在此添加插槽样式 */
</style>

FreePosition 插槽模板

<script setup lang="ts">
// 在此添加插槽逻辑
</script>

<template>
  <div class="free-position-slot">
    <!-- 在此添加插槽内容 -->
    <!-- 注意此插槽需要绝对定位 -->
  </div>
</template>

<style scoped>
.free-position-slot {
  position: absolute;
  /* 在此设置定位坐标,例如: */
  /* bottom: 20px; */
  /* right: 20px; */
  /* z-index: 1000; */
}
</style>

可用插槽位置

区域 插槽名称
布局 LayoutTopLayoutBottom
头部 HeaderStartHeaderAfterLogoHeaderAfterMenuHeaderEnd
主侧边栏 MainSidebarTopMainSidebarAfterLogoMainSidebarAfterMenuMainSidebarBottom
子侧边栏 SubSidebarTopSubSidebarAfterLogoSubSidebarAfterMenuSubSidebarBottom
标签栏 TabbarStartTabbarEnd
工具栏 ToolbarStartToolbarEnd
自由定位 FreePosition

选择指南

  • 全局顶部横幅/公告(覆盖整个布局最上方) → LayoutTop
  • 全局底部栏/版权声明(覆盖整个布局最下方) → LayoutBottom
  • 全局导航元素 → HeaderStart / HeaderEnd
  • 侧边栏用户信息/品牌内容 → MainSidebarTop / MainSidebarAfterLogo
  • 工具栏自定义操作 → ToolbarStart / ToolbarEnd
  • 悬浮元素(需要绝对定位) → FreePosition

LayoutTop / LayoutBottom 位于整个布局的最外层,内容会横跨全宽,适合全局公告横幅、版权栏等需要独占一行的场景。

FreePosition 特殊说明

FreePosition 插槽需要在样式中手动设置定位,否则内容不可见(模板见上方"FreePosition 插槽模板")。

故障排除

插槽未显示?检查:

  • 目录名是否与插槽名完全匹配(区分大小写)
  • 文件名是否为 index.vue
  • apps/<app>/src/slots/ 目录是否存在