mdk-skills 2.2.17 → 2.2.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "mdk-skills",
3
- "version": "2.2.17",
3
+ "version": "2.2.18",
4
4
  "description": "mdk-engineer - 沉稳靠谱的前端开发助手 Claude Skills 配置包,一键注入 .claude/ 技能目录和 CLAUDE.md 人设配置",
5
5
  "author": "XiaoMa",
6
6
  "license": "MIT",
@@ -149,6 +149,39 @@ body {
149
149
  transition: opacity 0.2s;
150
150
  }
151
151
 
152
+ /* ---------- 手搓折叠 ---------- */
153
+ .readme-fold {
154
+ margin-bottom: 20px;
155
+ border: 1px solid #e5e7eb;
156
+ border-radius: 6px;
157
+ overflow: hidden;
158
+ }
159
+ .fold-header {
160
+ display: flex;
161
+ align-items: center;
162
+ gap: 6px;
163
+ padding: 10px 16px;
164
+ font-size: 14px;
165
+ font-weight: 600;
166
+ background: #fafafa;
167
+ cursor: pointer;
168
+ user-select: none;
169
+ }
170
+ .fold-header:hover {
171
+ background: #f0f0f0;
172
+ }
173
+ .fold-arrow {
174
+ font-size: 11px;
175
+ transition: transform 0.2s;
176
+ color: #999;
177
+ }
178
+ .fold-arrow.open {
179
+ transform: rotate(90deg);
180
+ }
181
+ .fold-body {
182
+ padding: 0 16px 16px;
183
+ }
184
+
152
185
  .markdown-content pre:hover .copy-btn {
153
186
  opacity: 1;
154
187
  }
@@ -1,16 +1,15 @@
1
1
  <template>
2
2
  <div class="dashboard">
3
3
  <!-- 仓库 README -->
4
- <n-collapse
5
- v-if="readmeContent"
6
- :default-expanded-names="['readme']"
7
- class="readme-collapse"
8
- :animated="false"
9
- >
10
- <n-collapse-item title="仓库说明" name="readme">
4
+ <div class="readme-fold" v-if="readmeContent">
5
+ <div class="fold-header" @click="readmeOpen = !readmeOpen">
6
+ <span class="fold-arrow" :class="{ open: readmeOpen }">▶</span>
7
+ 仓库说明
8
+ </div>
9
+ <div class="fold-body" v-show="readmeOpen">
11
10
  <div class="markdown-content" v-html="renderedReadme" />
12
- </n-collapse-item>
13
- </n-collapse>
11
+ </div>
12
+ </div>
14
13
 
15
14
  <div class="page-header">
16
15
  <h2>技能列表</h2>
@@ -102,6 +101,7 @@ const loading = ref(false);
102
101
  // README
103
102
  const readmeContent = ref(null);
104
103
  const renderedReadme = ref("");
104
+ const readmeOpen = ref(true);
105
105
 
106
106
  // 详情弹窗
107
107
  const detailVisible = ref(false);
@@ -203,10 +203,6 @@ onUnmounted(() => document.removeEventListener("visibilitychange", onFocus));
203
203
  font-weight: 600;
204
204
  }
205
205
 
206
- .readme-collapse {
207
- margin-bottom: 20px;
208
- }
209
-
210
206
  .detail-status {
211
207
  display: flex;
212
208
  justify-content: center;
@@ -1,16 +1,15 @@
1
1
  <template>
2
2
  <div class="scene-switch">
3
3
  <!-- 技能说明文档 -->
4
- <n-collapse
5
- v-if="skillsReadmeContent"
6
- :default-expanded-names="['skills-readme']"
7
- class="readme-collapse"
8
- :animated="false"
9
- >
10
- <n-collapse-item title="技能说明" name="skills-readme">
4
+ <div class="readme-fold" v-if="skillsReadmeContent">
5
+ <div class="fold-header" @click="skillsReadmeOpen = !skillsReadmeOpen">
6
+ <span class="fold-arrow" :class="{ open: skillsReadmeOpen }">▶</span>
7
+ 技能说明
8
+ </div>
9
+ <div class="fold-body" v-show="skillsReadmeOpen">
11
10
  <div class="markdown-content" v-html="renderedSkillsReadme" />
12
- </n-collapse-item>
13
- </n-collapse>
11
+ </div>
12
+ </div>
14
13
 
15
14
  <div class="page-header">
16
15
  <h2>场景切换</h2>
@@ -242,6 +241,7 @@ const message = useMessage();
242
241
 
243
242
  // 技能说明 README
244
243
  const skillsReadmeContent = ref(null);
244
+ const skillsReadmeOpen = ref(true);
245
245
  const renderedSkillsReadme = ref("");
246
246
 
247
247
  const profiles = ref([]);
@@ -437,10 +437,6 @@ onMounted(() => {
437
437
  font-weight: 600;
438
438
  }
439
439
 
440
- .readme-collapse {
441
- margin-bottom: 20px;
442
- }
443
-
444
440
  .scene-grid {
445
441
  display: grid;
446
442
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));