slidev-theme-gtlabo 2.1.0 → 2.1.1

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.
@@ -147,12 +147,23 @@
147
147
  </template>
148
148
 
149
149
  <script setup>
150
- import { computed } from 'vue'
150
+ import { computed, inject } from 'vue'
151
151
  import { useSlideContext } from '@slidev/client'
152
152
 
153
153
  // Slidevコンテキストからconfigsにアクセス
154
154
  const { $slidev } = useSlideContext()
155
- const citations = $slidev.configs.citations || {}
155
+
156
+ // 方法1: frontmatterから取得(従来通り)
157
+ const frontmatterCitations = $slidev.configs.citations || {}
158
+
159
+ // 方法2: injectから取得(外部ファイル対応)
160
+ const injectedCitations = inject('citations', {})
161
+
162
+ // 両方をマージ(frontmatter優先)
163
+ const citations = computed(() => ({
164
+ ...injectedCitations,
165
+ ...frontmatterCitations
166
+ }))
156
167
 
157
168
  // プロパティ定義
158
169
  const props = defineProps({
@@ -177,16 +188,17 @@ const props = defineProps({
177
188
 
178
189
  // 参考文献リストを生成(frontmatterの順番を維持)
179
190
  const citationsList = computed(() => {
180
- if (!citations || typeof citations !== 'object') {
191
+ const citationsData = citations.value
192
+ if (!citationsData || typeof citationsData !== 'object') {
181
193
  return []
182
194
  }
183
195
 
184
196
  // frontmatterの記述順でキーを取得
185
- const originalKeys = Object.keys(citations)
197
+ const originalKeys = Object.keys(citationsData)
186
198
 
187
199
  const list = originalKeys.map((key, index) => ({
188
200
  key,
189
- data: citations[key],
201
+ data: citationsData[key],
190
202
  number: index + 1 // frontmatterの順番に基づく番号
191
203
  }))
192
204
 
@@ -1,4 +1,4 @@
1
- <!-- components/TableOfContents.vue -->
1
+ <!-- components/SectionDivider.vue -->
2
2
  <template>
3
3
  <div class="table-of-contents-container flex flex-col justify-start bg-white overflow-hidden relative">
4
4
  <!-- 厳密な背景グリッド - Swiss Styleの基礎 -->
@@ -160,12 +160,23 @@
160
160
  </template>
161
161
 
162
162
  <script setup>
163
- import { computed } from 'vue'
163
+ import { computed, inject } from 'vue'
164
164
  import { useSlideContext } from '@slidev/client'
165
165
 
166
166
  // Slidevコンテキストからconfigsにアクセス
167
167
  const { $slidev } = useSlideContext()
168
- const chapters = $slidev.configs.chapters || {}
168
+
169
+ // 方法1: frontmatterから取得(従来通り)
170
+ const frontmatterChapters = $slidev.configs.chapters || {}
171
+
172
+ // 方法2: injectから取得(外部ファイル対応)
173
+ const injectedChapters = inject('chapters', {})
174
+
175
+ // 両方をマージ(frontmatter優先)
176
+ const chapters = computed(() => ({
177
+ ...injectedChapters,
178
+ ...frontmatterChapters
179
+ }))
169
180
 
170
181
  const props = defineProps({
171
182
  nextChapter: {
@@ -188,7 +199,8 @@ const props = defineProps({
188
199
 
189
200
  // セクションの重複を除去する関数
190
201
  const getUniqueSections = (chapterKey) => {
191
- const chapter = chapters[chapterKey]
202
+ const chaptersData = chapters.value
203
+ const chapter = chaptersData[chapterKey]
192
204
  if (!chapter?.sections) return []
193
205
 
194
206
  const sections = chapter.sections
@@ -221,14 +233,15 @@ const isAppendixSection = computed(() => {
221
233
 
222
234
  // 通常の章リスト(refと付録を除外)
223
235
  const regularChapters = computed(() => {
224
- if (!chapters || typeof chapters !== 'object') {
236
+ const chaptersData = chapters.value
237
+ if (!chaptersData || typeof chaptersData !== 'object') {
225
238
  return []
226
239
  }
227
240
 
228
- return Object.keys(chapters)
241
+ return Object.keys(chaptersData)
229
242
  .filter(chapterKey => chapterKey !== 'ref' && !chapterKey.startsWith('ap'))
230
243
  .map(chapterKey => {
231
- const chapter = chapters[chapterKey]
244
+ const chapter = chaptersData[chapterKey]
232
245
  const sections = chapter?.sections || {}
233
246
  const sectionKeys = Object.keys(sections)
234
247
 
@@ -244,14 +257,15 @@ const regularChapters = computed(() => {
244
257
 
245
258
  // 付録の章リスト
246
259
  const appendixChapters = computed(() => {
247
- if (!chapters || typeof chapters !== 'object') {
260
+ const chaptersData = chapters.value
261
+ if (!chaptersData || typeof chaptersData !== 'object') {
248
262
  return []
249
263
  }
250
264
 
251
- return Object.keys(chapters)
265
+ return Object.keys(chaptersData)
252
266
  .filter(chapterKey => chapterKey.startsWith('ap'))
253
267
  .map(chapterKey => {
254
- const chapter = chapters[chapterKey]
268
+ const chapter = chaptersData[chapterKey]
255
269
  const sections = chapter?.sections || {}
256
270
  const sectionKeys = Object.keys(sections)
257
271
 
@@ -267,7 +281,8 @@ const appendixChapters = computed(() => {
267
281
 
268
282
  // セクションタイトルを取得
269
283
  const getSectionTitle = (chapterKey, sectionKey) => {
270
- const chapter = chapters[chapterKey]
284
+ const chaptersData = chapters.value
285
+ const chapter = chaptersData[chapterKey]
271
286
  const sectionData = chapter?.sections?.[sectionKey]
272
287
  return sectionData?.title || `セクション ${sectionKey}`
273
288
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "slidev-theme-gtlabo",
3
- "version": "2.1.0",
3
+ "version": "2.1.1",
4
4
  "description": "A Slidev theme for laboratory presentations with customizable components",
5
5
  "author": "mksmkss",
6
6
  "license": "MIT",
@@ -1,93 +0,0 @@
1
- <!-- components/ChapterItem.vue -->
2
- <template>
3
- <div
4
- class="flex flex-col"
5
- :class="isNext ? 'border-sky-500 border-l-8 pl-6' : 'border-slate-200 border-l-4 pl-7'"
6
- >
7
- <!-- 次の章インジケーター - sky-500アクセント -->
8
- <div
9
- v-if="isNext"
10
- :class="nextBadgeClasses"
11
- class="bg-sky-500 text-white font-bold uppercase tracking-widest leading-none"
12
- >
13
- NEXT
14
- </div>
15
-
16
- <!-- 章番号とタイトル - 左揃え、明確なヒエラルキー -->
17
- <div :class="chapterHeaderClasses">
18
- <div class="flex items-end space-x-3 w-full">
19
- <div :class="chapterNumberClasses" class="flex text-slate-900 font-bold tabular-nums leading-none">
20
- {{ chapterNumber }}
21
- </div>
22
- <div class="flex-1">
23
- <div class="border-b border-slate-900 mb-2">
24
- <span :class="chapterTitleClasses" class="text-slate-900 font-bold leading-tight">
25
- {{ chapter.title }}
26
- </span>
27
- </div>
28
- </div>
29
- </div>
30
- </div>
31
-
32
- <!-- セクション一覧 - 機能的な情報構造 -->
33
- <div :class="sectionListClasses">
34
- <div
35
- v-for="(sectionData, sectionIndex) in chapter.uniqueSections"
36
- :key="`${chapter.key}-${sectionIndex}`"
37
- class="flex items-start"
38
- >
39
- <span class="w-1 h-1 bg-slate-400 mr-2 mt-1.5 flex-shrink-0 rounded-full"></span>
40
- <span :class="sectionTextClasses" class="text-slate-600 leading-snug">
41
- {{ sectionData.title }}
42
- </span>
43
- </div>
44
- </div>
45
- </div>
46
- </template>
47
-
48
- <script setup>
49
- import { computed } from 'vue'
50
-
51
- const props = defineProps({
52
- chapter: {
53
- type: Object,
54
- required: true
55
- },
56
- index: {
57
- type: Number,
58
- required: true
59
- },
60
- isNext: {
61
- type: Boolean,
62
- default: false
63
- },
64
- isAppendix: {
65
- type: Boolean,
66
- default: false
67
- },
68
- size: {
69
- type: String,
70
- default: 'md'
71
- },
72
- config: {
73
- type: Object,
74
- required: true
75
- }
76
- })
77
-
78
- // 章番号の生成(通常章は "01", "02"、付録は "A1", "A2")
79
- const chapterNumber = computed(() => {
80
- if (props.isAppendix) {
81
- return `A${props.index + 1}`
82
- }
83
- return String(props.index + 1).padStart(2, '0')
84
- })
85
-
86
- // 動的クラス
87
- const chapterHeaderClasses = computed(() => props.config.chapterHeader)
88
- const chapterNumberClasses = computed(() => props.config.chapterNumber)
89
- const chapterTitleClasses = computed(() => props.config.chapterTitle)
90
- const sectionListClasses = computed(() => props.config.sectionList)
91
- const sectionTextClasses = computed(() => props.config.sectionText)
92
- const nextBadgeClasses = computed(() => props.config.nextBadge)
93
- </script>