@histoire/controls 0.17.17 → 1.0.0-alpha.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.
Files changed (96) hide show
  1. package/.histoire/dist/__sandbox.html +16 -0
  2. package/.histoire/dist/assets/BaseEmpty.d30f3079.js +11 -0
  3. package/.histoire/dist/assets/HomeView.8e044be6.js +24 -0
  4. package/.histoire/dist/assets/HstCheckbox.story.3d04d85b.js +144 -0
  5. package/.histoire/dist/assets/HstColorShades.story.68cf74d1.js +532 -0
  6. package/.histoire/dist/assets/HstCopyIcon.e40e725e.js +51 -0
  7. package/.histoire/dist/assets/HstNumber.story.1e1964ff.js +160 -0
  8. package/.histoire/dist/assets/HstSelect.story.04860383.js +277 -0
  9. package/.histoire/dist/assets/HstText.story.c915d831.js +137 -0
  10. package/.histoire/dist/assets/HstTextarea.story.802b9c26.js +105 -0
  11. package/.histoire/dist/assets/HstTokenGrid.story.025819d6.js +148 -0
  12. package/.histoire/dist/assets/HstTokenList.story.d3aa6575.js +176 -0
  13. package/.histoire/dist/assets/HstWrapper.246b6982.js +56 -0
  14. package/.histoire/dist/assets/SearchPane.daa2675c.js +426 -0
  15. package/.histoire/dist/assets/StoryView.2f64dad1.js +2260 -0
  16. package/.histoire/dist/assets/bundle-main.784e5bf7.js +1156 -0
  17. package/.histoire/dist/assets/bundle-sandbox.5e153933.js +84 -0
  18. package/.histoire/dist/assets/const.268165fd.js +658 -0
  19. package/.histoire/dist/assets/global-components.6736b2a9.js +5722 -0
  20. package/.histoire/dist/assets/search-docs-data.b9a75539.js +6 -0
  21. package/.histoire/dist/assets/style.04507241.css +2504 -0
  22. package/.histoire/dist/assets/vendor.2833ae3d.js +28970 -0
  23. package/.histoire/dist/index.html +16 -0
  24. package/dist/components/HstCopyIcon.vue.d.ts +3 -12
  25. package/dist/components/HstWrapper.vue.d.ts +4 -27
  26. package/dist/components/button/HstButton.story.vue.d.ts +1 -1
  27. package/dist/components/button/HstButton.vue.d.ts +5 -145
  28. package/dist/components/button/HstButtonGroup.story.vue.d.ts +1 -1
  29. package/dist/components/button/HstButtonGroup.vue.d.ts +6 -15
  30. package/dist/components/checkbox/HstCheckbox.story.vue.d.ts +1 -1
  31. package/dist/components/checkbox/HstCheckbox.vue.d.ts +5 -14
  32. package/dist/components/checkbox/HstCheckboxList.story.vue.d.ts +1 -1
  33. package/dist/components/checkbox/HstCheckboxList.vue.d.ts +6 -15
  34. package/dist/components/checkbox/HstSimpleCheckbox.story.vue.d.ts +1 -1
  35. package/dist/components/checkbox/HstSimpleCheckbox.vue.d.ts +5 -14
  36. package/dist/components/colorselect/HstColorSelect.story.vue.d.ts +1 -1
  37. package/dist/components/colorselect/HstColorSelect.vue.d.ts +5 -14
  38. package/dist/components/design-tokens/HstColorShades.story.vue.d.ts +1 -1
  39. package/dist/components/design-tokens/HstColorShades.vue.d.ts +3 -12
  40. package/dist/components/design-tokens/HstTokenGrid.story.vue.d.ts +1 -1
  41. package/dist/components/design-tokens/HstTokenGrid.vue.d.ts +4 -27
  42. package/dist/components/design-tokens/HstTokenList.story.vue.d.ts +1 -1
  43. package/dist/components/design-tokens/HstTokenList.vue.d.ts +3 -12
  44. package/dist/components/json/HstJson.story.vue.d.ts +1 -1
  45. package/dist/components/json/HstJson.vue.d.ts +5 -14
  46. package/dist/components/number/HstNumber.story.vue.d.ts +1 -1
  47. package/dist/components/number/HstNumber.vue.d.ts +5 -14
  48. package/dist/components/radio/HstRadio.story.vue.d.ts +1 -1
  49. package/dist/components/radio/HstRadio.vue.d.ts +6 -15
  50. package/dist/components/select/CustomSelect.vue.d.ts +6 -15
  51. package/dist/components/select/HstSelect.story.vue.d.ts +1 -1
  52. package/dist/components/select/HstSelect.vue.d.ts +6 -15
  53. package/dist/components/slider/HstSlider.story.vue.d.ts +1 -1
  54. package/dist/components/slider/HstSlider.vue.d.ts +5 -14
  55. package/dist/components/text/HstText.story.vue.d.ts +1 -1
  56. package/dist/components/text/HstText.vue.d.ts +5 -14
  57. package/dist/components/textarea/HstTextarea.story.vue.d.ts +1 -1
  58. package/dist/components/textarea/HstTextarea.vue.d.ts +5 -14
  59. package/dist/index.d.ts +732 -2488
  60. package/dist/index.es.css +1 -0
  61. package/dist/index.es.js +5279 -4823
  62. package/dist/style-standalone.css +74 -66
  63. package/dist/utils.d.ts +1 -1
  64. package/package.json +25 -25
  65. package/src/components/HstCopyIcon.vue +1 -1
  66. package/src/components/HstWrapper.vue +1 -1
  67. package/src/components/button/HstButtonGroup.vue +1 -1
  68. package/src/components/checkbox/HstCheckboxList.vue +1 -1
  69. package/src/components/design-tokens/HstColorShades.vue +2 -2
  70. package/src/components/design-tokens/HstTokenGrid.vue +1 -1
  71. package/src/components/json/HstJson.vue +12 -12
  72. package/src/components/radio/HstRadio.vue +1 -1
  73. package/src/components/select/CustomSelect.vue +3 -3
  74. package/src/components/select/HstSelect.vue +1 -1
  75. package/src/components/slider/HstSlider.vue +1 -1
  76. package/src/index.ts +8 -8
  77. package/tsconfig.json +1 -0
  78. package/vite.config.ts +1 -1
  79. package/dist/style.css +0 -1
  80. package/histoire-dist/__sandbox.html +0 -15
  81. package/histoire-dist/assets/BaseEmpty.a84c14c8.js +0 -1
  82. package/histoire-dist/assets/HomeView.f524bd4b.js +0 -1
  83. package/histoire-dist/assets/HstCheckbox.story.9f622545.js +0 -1
  84. package/histoire-dist/assets/HstInput.story.945401ce.js +0 -1
  85. package/histoire-dist/assets/SearchModal.76c035f2.js +0 -1
  86. package/histoire-dist/assets/StoryView.e4c41518.js +0 -15
  87. package/histoire-dist/assets/global-components.84d0ab22.js +0 -1
  88. package/histoire-dist/assets/histoire-text-dark.a529813a.svg +0 -89
  89. package/histoire-dist/assets/histoire-text.1d4474b5.svg +0 -89
  90. package/histoire-dist/assets/index.58f51dd0.js +0 -1
  91. package/histoire-dist/assets/preview-settings.a634d101.js +0 -1
  92. package/histoire-dist/assets/sandbox.2c60450a.js +0 -1
  93. package/histoire-dist/assets/style.7657d2ac.css +0 -1
  94. package/histoire-dist/assets/vendor.70a554f6.js +0 -9
  95. package/histoire-dist/index.html +0 -15
  96. /package/{histoire-dist/assets/histoire.8af7bd1f.svg → .histoire/dist/histoire.svg} +0 -0
@@ -0,0 +1,1156 @@
1
+ import { d as defineComponent, u as useMediaQuery, r as ref, w as watch, c as computed, o as onUnmounted, a as openBlock, b as createElementBlock, e as createBaseVNode, f as renderSlot, n as normalizeClass, g as withModifiers, h as normalizeStyle, i as unref, j as createBlock, k as withCtx, t as toDisplayString, l as createVNode, I as Icon, m as createCommentVNode, T as Transition, s as scrollIntoView, p as onMounted, q as resolveComponent, v as withKeys, x as mergeProps, y as createRouter, z as createWebHistory, A as defineStore, B as useTitle, C as resolveDynamicComponent, F as Fragment, D as createApp, E as createPinia, G as plugin, H as useStorage, J as renderList, K as useEventListener, L as resolveDirective, M as withDirectives, N as defineAsyncComponent, O as vShow, P as isRef, Q as useCssVars, R as createTextVNode, S as reactive, U as useRoute, V as pushScopeId, W as popScopeId } from "./vendor.2833ae3d.js";
2
+ import { _ as __vitePreload, f as files, m as mapFile, r as registerGlobalComponents, i as isDark, h as histoireConfig, t as toggleDark, a as tree, c as customLogos } from "./global-components.6736b2a9.js";
3
+ var style = "";
4
+ var $histoireThemeResolved = "";
5
+ var _export_sfc = (sfc, props) => {
6
+ const target = sfc.__vccOpts || sfc;
7
+ for (const [key, val] of props) {
8
+ target[key] = val;
9
+ }
10
+ return target;
11
+ };
12
+ const _sfc_main$2$1 = defineComponent({
13
+ inheritAttrs: false,
14
+ props: {
15
+ isActive: {
16
+ type: Boolean,
17
+ default: void 0
18
+ }
19
+ },
20
+ emits: {
21
+ navigate: () => true
22
+ },
23
+ setup(props, { emit }) {
24
+ function handleNavigate(event, navigate) {
25
+ emit("navigate");
26
+ navigate(event);
27
+ }
28
+ return {
29
+ handleNavigate
30
+ };
31
+ }
32
+ });
33
+ const _hoisted_1$2$1 = ["href", "onClick", "onKeyup"];
34
+ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
35
+ const _component_RouterLink = resolveComponent("RouterLink");
36
+ return openBlock(), createBlock(_component_RouterLink, mergeProps(_ctx.$attrs, { custom: "" }), {
37
+ default: withCtx(({ isActive: linkIsActive, href, navigate }) => [
38
+ createBaseVNode("a", {
39
+ href,
40
+ class: normalizeClass(["htw-flex htw-items-center htw-gap-2 htw-text-gray-900 dark:htw-text-gray-100", [
41
+ _ctx.$attrs.class,
42
+ (_ctx.isActive != null ? _ctx.isActive : linkIsActive) ? "active htw-bg-primary-500 hover:htw-bg-primary-600 htw-text-white dark:htw-text-black" : "hover:htw-bg-primary-100 dark:hover:htw-bg-primary-900"
43
+ ]]),
44
+ onClick: ($event) => _ctx.handleNavigate($event, navigate),
45
+ onKeyup: [
46
+ withKeys(($event) => _ctx.handleNavigate($event, navigate), ["enter"]),
47
+ withKeys(($event) => _ctx.handleNavigate($event, navigate), ["space"])
48
+ ]
49
+ }, [
50
+ renderSlot(_ctx.$slots, "default", {
51
+ active: _ctx.isActive != null ? _ctx.isActive : linkIsActive
52
+ })
53
+ ], 42, _hoisted_1$2$1)
54
+ ]),
55
+ _: 3
56
+ }, 16);
57
+ }
58
+ var BaseListItemLink = /* @__PURE__ */ _export_sfc(_sfc_main$2$1, [["render", _sfc_render]]);
59
+ function useScrollOnActive(active, el) {
60
+ watch(active, (value) => {
61
+ if (value) {
62
+ autoScroll();
63
+ }
64
+ });
65
+ function autoScroll() {
66
+ if (el.value) {
67
+ scrollIntoView(el.value, {
68
+ scrollMode: "if-needed",
69
+ block: "center",
70
+ inline: "nearest",
71
+ behavior: "smooth"
72
+ });
73
+ }
74
+ }
75
+ onMounted(() => {
76
+ if (active.value) {
77
+ autoScroll();
78
+ }
79
+ });
80
+ return {
81
+ autoScroll
82
+ };
83
+ }
84
+ const _hoisted_1$1$1 = ["onMousedown"];
85
+ const _sfc_main$1$1 = /* @__PURE__ */ defineComponent({
86
+ name: "BaseSplitPane",
87
+ props: {
88
+ orientation: {
89
+ type: String,
90
+ default: "landscape",
91
+ validator: (value) => ["landscape", "portrait"].includes(value)
92
+ },
93
+ defaultSplit: {
94
+ type: Number,
95
+ default: 50
96
+ },
97
+ split: {
98
+ type: Number,
99
+ default: void 0
100
+ },
101
+ min: {
102
+ type: Number,
103
+ default: 20
104
+ },
105
+ max: {
106
+ type: Number,
107
+ default: 80
108
+ },
109
+ draggerOffset: {
110
+ type: String,
111
+ default: "center",
112
+ validator: (value) => ["before", "center", "after"].includes(value)
113
+ },
114
+ saveId: {
115
+ type: String,
116
+ default: null
117
+ },
118
+ fixed: {
119
+ type: Boolean,
120
+ default: false
121
+ }
122
+ },
123
+ emits: {
124
+ "update:split": (value) => true
125
+ },
126
+ setup(__props, { emit }) {
127
+ const props = __props;
128
+ const SAVE_PREFIX = "__histoire";
129
+ const currentSplit = ref(props.defaultSplit);
130
+ watch(() => props.split, (value) => {
131
+ if (value !== void 0) {
132
+ currentSplit.value = value;
133
+ }
134
+ }, {
135
+ immediate: true
136
+ });
137
+ if (props.saveId) {
138
+ const storageKey = `${SAVE_PREFIX}-split-pane-${props.saveId}`;
139
+ const savedValue = localStorage.getItem(storageKey);
140
+ if (savedValue != null) {
141
+ let parsedValue;
142
+ try {
143
+ parsedValue = JSON.parse(savedValue);
144
+ } catch (e) {
145
+ console.error(e);
146
+ }
147
+ if (typeof parsedValue === "number") {
148
+ currentSplit.value = parsedValue;
149
+ }
150
+ }
151
+ watch(currentSplit, (value) => {
152
+ localStorage.setItem(storageKey, JSON.stringify(value));
153
+ });
154
+ watch(currentSplit, (value) => {
155
+ if (value !== props.split) {
156
+ emit("update:split", value);
157
+ }
158
+ }, {
159
+ immediate: true
160
+ });
161
+ }
162
+ const boundSplit = computed(() => {
163
+ if (currentSplit.value < props.min) {
164
+ return props.min;
165
+ } else if (currentSplit.value > props.max) {
166
+ return props.max;
167
+ } else {
168
+ return currentSplit.value;
169
+ }
170
+ });
171
+ const leftStyle = computed(() => ({
172
+ [props.orientation === "landscape" ? "width" : "height"]: props.fixed ? `${boundSplit.value}px` : `${boundSplit.value}%`
173
+ }));
174
+ const rightStyle = computed(() => ({
175
+ [props.orientation === "landscape" ? "width" : "height"]: props.fixed ? null : `${100 - boundSplit.value}%`
176
+ }));
177
+ const dragging = ref(false);
178
+ let startPosition = 0;
179
+ let startSplit = 0;
180
+ const el = ref(null);
181
+ function dragStart(e) {
182
+ dragging.value = true;
183
+ startPosition = props.orientation === "landscape" ? e.pageX : e.pageY;
184
+ startSplit = boundSplit.value;
185
+ window.addEventListener("mousemove", dragMove);
186
+ window.addEventListener("mouseup", dragEnd);
187
+ }
188
+ function dragMove(e) {
189
+ if (dragging.value) {
190
+ let position;
191
+ let totalSize;
192
+ if (props.orientation === "landscape") {
193
+ position = e.pageX;
194
+ totalSize = el.value.offsetWidth;
195
+ } else {
196
+ position = e.pageY;
197
+ totalSize = el.value.offsetHeight;
198
+ }
199
+ const dPosition = position - startPosition;
200
+ if (props.fixed) {
201
+ currentSplit.value = startSplit + dPosition;
202
+ } else {
203
+ currentSplit.value = startSplit + ~~(dPosition / totalSize * 200) / 2;
204
+ }
205
+ }
206
+ }
207
+ function dragEnd() {
208
+ dragging.value = false;
209
+ removeDragListeners();
210
+ }
211
+ function removeDragListeners() {
212
+ window.removeEventListener("mousemove", dragMove);
213
+ window.removeEventListener("mouseup", dragEnd);
214
+ }
215
+ onUnmounted(() => {
216
+ removeDragListeners();
217
+ });
218
+ return (_ctx, _cache) => {
219
+ return openBlock(), createElementBlock("div", {
220
+ ref_key: "el",
221
+ ref: el,
222
+ class: normalizeClass(["htw-flex htw-h-full htw-isolate htw-overflow-auto", {
223
+ "htw-flex-col": __props.orientation === "portrait",
224
+ "htw-cursor-ew-resize": dragging.value && __props.orientation === "landscape",
225
+ "htw-cursor-ns-resize": dragging.value && __props.orientation === "portrait",
226
+ [__props.orientation]: true
227
+ }])
228
+ }, [
229
+ createBaseVNode("div", {
230
+ class: normalizeClass(["htw-relative htw-top-0 htw-left-0 htw-z-20", {
231
+ "htw-pointer-events-none": dragging.value,
232
+ "htw-border-r htw-border-gray-200 dark:htw-border-gray-850": __props.orientation === "landscape",
233
+ "htw-flex-none": __props.fixed
234
+ }]),
235
+ style: normalizeStyle(unref(leftStyle))
236
+ }, [
237
+ renderSlot(_ctx.$slots, "first", {}, void 0, true),
238
+ createBaseVNode("div", {
239
+ class: normalizeClass(["dragger htw-absolute htw-z-100 hover:htw-bg-primary-500/50 htw-transition-colors htw-duration-150 htw-delay-150", {
240
+ "htw-top-0 htw-bottom-0 htw-cursor-ew-resize": __props.orientation === "landscape",
241
+ "htw-left-0 htw-right-0 htw-cursor-ns-resize": __props.orientation === "portrait",
242
+ [`dragger-offset-${__props.draggerOffset}`]: true,
243
+ "htw-bg-primary-500/25": dragging.value
244
+ }]),
245
+ onMousedown: withModifiers(dragStart, ["prevent"])
246
+ }, null, 42, _hoisted_1$1$1)
247
+ ], 6),
248
+ createBaseVNode("div", {
249
+ class: normalizeClass(["htw-relative htw-bottom-0 htw-right-0", {
250
+ "htw-pointer-events-none": dragging.value,
251
+ "htw-border-t htw-border-gray-200 dark:htw-border-gray-850": __props.orientation === "portrait",
252
+ "htw-flex-1": __props.fixed
253
+ }]),
254
+ style: normalizeStyle(unref(rightStyle))
255
+ }, [
256
+ renderSlot(_ctx.$slots, "last", {}, void 0, true)
257
+ ], 6)
258
+ ], 2);
259
+ };
260
+ }
261
+ });
262
+ var BaseSplitPane = /* @__PURE__ */ _export_sfc(_sfc_main$1$1, [["__scopeId", "data-v-4de97f66"]]);
263
+ const isMobile = useMediaQuery("(max-width: 640px)");
264
+ const _hoisted_1$b = {
265
+ key: 0,
266
+ class: "htw-absolute htw-z-10 htw-bg-white dark:htw-bg-gray-700 htw-w-screen htw-h-screen htw-inset-0 htw-overflow-hidden htw-flex htw-flex-col"
267
+ };
268
+ const _hoisted_2$8 = { class: "htw-p-4 htw-h-16 htw-flex htw-border-b htw-border-gray-100 dark:htw-border-gray-800 htw-items-center htw-place-content-between" };
269
+ const _hoisted_3$6 = { class: "htw-text-gray-500" };
270
+ const _sfc_main$b = /* @__PURE__ */ defineComponent({
271
+ name: "MobileOverlay",
272
+ props: {
273
+ title: null,
274
+ opened: { type: Boolean }
275
+ },
276
+ emits: ["close"],
277
+ setup(__props, { emit: emits }) {
278
+ return (_ctx, _cache) => {
279
+ return openBlock(), createBlock(Transition, { name: "__histoire-fade-bottom" }, {
280
+ default: withCtx(() => [
281
+ __props.opened ? (openBlock(), createElementBlock("div", _hoisted_1$b, [
282
+ createBaseVNode("div", _hoisted_2$8, [
283
+ createBaseVNode("span", _hoisted_3$6, toDisplayString(__props.title), 1),
284
+ createBaseVNode("a", {
285
+ class: "htw-p-1 hover:htw-text-primary-500 dark:hover:htw-text-primary-400 htw-cursor-pointer",
286
+ onClick: _cache[0] || (_cache[0] = ($event) => emits("close"))
287
+ }, [
288
+ createVNode(unref(Icon), {
289
+ icon: "carbon:close",
290
+ class: "htw-w-8 htw-h-8 htw-shrink-0"
291
+ })
292
+ ])
293
+ ]),
294
+ renderSlot(_ctx.$slots, "default")
295
+ ])) : createCommentVNode("", true)
296
+ ]),
297
+ _: 3
298
+ });
299
+ };
300
+ }
301
+ });
302
+ const base = "/";
303
+ const router = createRouter({
304
+ history: createWebHistory(base),
305
+ routes: [
306
+ {
307
+ path: "/",
308
+ name: "home",
309
+ component: () => __vitePreload(() => import("./HomeView.8e044be6.js"), true ? ["assets/HomeView.8e044be6.js","assets/vendor.2833ae3d.js","assets/global-components.6736b2a9.js"] : void 0)
310
+ },
311
+ {
312
+ path: "/story/:storyId",
313
+ name: "story",
314
+ component: () => __vitePreload(() => import("./StoryView.2f64dad1.js"), true ? ["assets/StoryView.2f64dad1.js","assets/vendor.2833ae3d.js","assets/BaseEmpty.d30f3079.js","assets/const.268165fd.js","assets/global-components.6736b2a9.js"] : void 0)
315
+ }
316
+ ]
317
+ });
318
+ const useStoryStore = defineStore("story", () => {
319
+ const stories = ref([]);
320
+ function setStories(value) {
321
+ stories.value = value;
322
+ }
323
+ const currentStory = computed(() => stories.value.find((s) => s.id === router.currentRoute.value.params.storyId));
324
+ const currentVariant = computed(() => {
325
+ var _a;
326
+ return (_a = currentStory.value) == null ? void 0 : _a.variants.find((v) => v.id === router.currentRoute.value.query.variantId);
327
+ });
328
+ const maps = computed(() => {
329
+ const storyMap = /* @__PURE__ */ new Map();
330
+ const variantMap = /* @__PURE__ */ new Map();
331
+ for (const story of stories.value) {
332
+ storyMap.set(story.id, story);
333
+ for (const variant of story.variants) {
334
+ variantMap.set(`${story.id}:${variant.id}`, variant);
335
+ }
336
+ }
337
+ return {
338
+ stories: storyMap,
339
+ variants: variantMap
340
+ };
341
+ });
342
+ function getStoryById(id) {
343
+ return maps.value.stories.get(id);
344
+ }
345
+ function getVariantById(idWithStoryId) {
346
+ return maps.value.variants.get(idWithStoryId);
347
+ }
348
+ return {
349
+ stories,
350
+ setStories,
351
+ currentStory,
352
+ currentVariant,
353
+ getStoryById,
354
+ getVariantById
355
+ };
356
+ });
357
+ var __defProp = Object.defineProperty;
358
+ var __defProps = Object.defineProperties;
359
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
360
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
361
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
362
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
363
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
364
+ var __spreadValues = (a, b) => {
365
+ for (var prop in b || (b = {}))
366
+ if (__hasOwnProp.call(b, prop))
367
+ __defNormalProp(a, prop, b[prop]);
368
+ if (__getOwnPropSymbols)
369
+ for (var prop of __getOwnPropSymbols(b)) {
370
+ if (__propIsEnum.call(b, prop))
371
+ __defNormalProp(a, prop, b[prop]);
372
+ }
373
+ return a;
374
+ };
375
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
376
+ const _hoisted_1$a = { class: "bind-tree-margin htw-flex htw-items-center htw-gap-2 htw-pl-4 htw-min-w-0" };
377
+ const _hoisted_2$7 = { class: "htw-truncate" };
378
+ const _hoisted_3$5 = {
379
+ key: 0,
380
+ class: "htw-opacity-40 htw-text-sm"
381
+ };
382
+ const _sfc_main$a = /* @__PURE__ */ defineComponent({
383
+ name: "StoryListItem",
384
+ props: {
385
+ story: null,
386
+ depth: { default: 0 }
387
+ },
388
+ setup(__props) {
389
+ const props = __props;
390
+ useCssVars((_ctx) => ({
391
+ "335c8a9c": unref(filePadding),
392
+ "10044424": __props.story.iconColor
393
+ }));
394
+ const filePadding = computed(() => {
395
+ return props.depth * 12 + "px";
396
+ });
397
+ const route = useRoute();
398
+ const active = computed(() => route.params.storyId === props.story.id);
399
+ const el = ref();
400
+ useScrollOnActive(active, el);
401
+ return (_ctx, _cache) => {
402
+ return openBlock(), createElementBlock("div", {
403
+ ref_key: "el",
404
+ ref: el,
405
+ "data-test-id": "story-list-item"
406
+ }, [
407
+ createVNode(BaseListItemLink, {
408
+ to: {
409
+ name: "story",
410
+ params: {
411
+ storyId: __props.story.id
412
+ }
413
+ },
414
+ class: "htw-pl-0.5 htw-pr-2 htw-py-2 md:htw-py-1.5 htw-mx-1 htw-rounded-sm"
415
+ }, {
416
+ default: withCtx(({ active: active2 }) => {
417
+ var _a;
418
+ return [
419
+ createBaseVNode("span", _hoisted_1$a, [
420
+ createVNode(unref(Icon), {
421
+ icon: (_a = __props.story.icon) != null ? _a : "carbon:cube",
422
+ class: normalizeClass(["base-list-item-link-icon htw-w-5 htw-h-5 sm:htw-w-4 sm:htw-h-4 htw-flex-none", {
423
+ "htw-text-primary-500": !active2 && !__props.story.iconColor,
424
+ "bind-icon-color": !active2 && __props.story.iconColor
425
+ }])
426
+ }, null, 8, ["icon", "class"]),
427
+ createBaseVNode("span", _hoisted_2$7, toDisplayString(__props.story.title), 1)
428
+ ]),
429
+ !__props.story.docsOnly ? (openBlock(), createElementBlock("span", _hoisted_3$5, toDisplayString(__props.story.variants.length), 1)) : createCommentVNode("", true)
430
+ ];
431
+ }),
432
+ _: 1
433
+ }, 8, ["to"])
434
+ ], 512);
435
+ };
436
+ }
437
+ });
438
+ var StoryListItem = /* @__PURE__ */ _export_sfc(_sfc_main$a, [["__scopeId", "data-v-3bb05a26"]]);
439
+ const useFolderStore = defineStore("folder", () => {
440
+ const openedFolders = useStorage("_histoire-tree-state", /* @__PURE__ */ new Map());
441
+ function getStringPath(path) {
442
+ return path.join("\u241C");
443
+ }
444
+ function toggleFolder(path, defaultToggleValue = true) {
445
+ const stringPath = getStringPath(path);
446
+ const currentValue = openedFolders.value.get(stringPath);
447
+ if (currentValue == null) {
448
+ setFolderOpen(stringPath, defaultToggleValue);
449
+ } else if (currentValue) {
450
+ setFolderOpen(stringPath, false);
451
+ } else {
452
+ setFolderOpen(stringPath, true);
453
+ }
454
+ }
455
+ function setFolderOpen(path, value) {
456
+ const stringPath = typeof path === "string" ? path : getStringPath(path);
457
+ openedFolders.value.set(stringPath, value);
458
+ }
459
+ function isFolderOpened(path, defaultValue = false) {
460
+ const value = openedFolders.value.get(getStringPath(path));
461
+ if (value == null) {
462
+ return defaultValue;
463
+ }
464
+ return value;
465
+ }
466
+ function openFileFolders(path) {
467
+ for (let pathLength = 1; pathLength < path.length; pathLength++) {
468
+ setFolderOpen(path.slice(0, pathLength), true);
469
+ }
470
+ }
471
+ const storyStore = useStoryStore();
472
+ watch(() => storyStore.currentStory, (story) => {
473
+ openFileFolders(story.file.path);
474
+ });
475
+ return {
476
+ isFolderOpened,
477
+ toggleFolder
478
+ };
479
+ });
480
+ const _hoisted_1$9 = { "data-test-id": "story-list-folder" };
481
+ const _hoisted_2$6 = ["onKeyup"];
482
+ const _hoisted_3$4 = { class: "bind-tree-padding htw-flex htw-items-center htw-gap-2 htw-min-w-0" };
483
+ const _hoisted_4$3 = { class: "htw-flex htw-flex-none htw-items-center" };
484
+ const _hoisted_5$1 = { class: "htw-truncate" };
485
+ const _hoisted_6 = { key: 0 };
486
+ const _sfc_main$9 = /* @__PURE__ */ defineComponent({
487
+ name: "StoryListFolder",
488
+ props: {
489
+ path: { default: () => [] },
490
+ folder: null,
491
+ stories: null,
492
+ depth: { default: 0 }
493
+ },
494
+ setup(__props) {
495
+ const props = __props;
496
+ useCssVars((_ctx) => ({
497
+ "27f98670": unref(folderPadding)
498
+ }));
499
+ const folderStore = useFolderStore();
500
+ const folderPath = computed(() => [...props.path, props.folder.title]);
501
+ const isFolderOpen = computed(() => folderStore.isFolderOpened(folderPath.value));
502
+ function toggleOpen() {
503
+ folderStore.toggleFolder(folderPath.value);
504
+ }
505
+ const folderPadding = computed(() => {
506
+ return props.depth * 12 + "px";
507
+ });
508
+ return (_ctx, _cache) => {
509
+ const _component_StoryListFolder = resolveComponent("StoryListFolder", true);
510
+ return openBlock(), createElementBlock("div", _hoisted_1$9, [
511
+ createBaseVNode("div", {
512
+ role: "button",
513
+ tabindex: "0",
514
+ class: "htw-px-0.5 htw-py-2 md:htw-py-1.5 htw-mx-1 htw-rounded-sm hover:htw-bg-primary-100 dark:hover:htw-bg-primary-900 htw-cursor-pointer htw-select-none htw-flex",
515
+ onClick: toggleOpen,
516
+ onKeyup: [
517
+ withKeys(toggleOpen, ["enter"]),
518
+ withKeys(toggleOpen, ["space"])
519
+ ]
520
+ }, [
521
+ createBaseVNode("span", _hoisted_3$4, [
522
+ createBaseVNode("span", _hoisted_4$3, [
523
+ createVNode(unref(Icon), {
524
+ icon: "carbon:caret-right",
525
+ class: normalizeClass(["htw-w-4 htw-h-4 htw-transition-transform htw-duration-150 htw-opacity-30", {
526
+ "htw-rotate-90": unref(isFolderOpen)
527
+ }])
528
+ }, null, 8, ["class"]),
529
+ createVNode(unref(Icon), {
530
+ icon: "carbon:folder",
531
+ class: "htw-w-5 htw-h-5 sm:htw-w-4 sm:htw-h-4"
532
+ })
533
+ ]),
534
+ createBaseVNode("span", _hoisted_5$1, toDisplayString(__props.folder.title), 1)
535
+ ])
536
+ ], 40, _hoisted_2$6),
537
+ unref(isFolderOpen) ? (openBlock(), createElementBlock("div", _hoisted_6, [
538
+ (openBlock(true), createElementBlock(Fragment, null, renderList(__props.folder.children, (element) => {
539
+ return openBlock(), createElementBlock(Fragment, {
540
+ key: element.title
541
+ }, [
542
+ element.children ? (openBlock(), createBlock(_component_StoryListFolder, {
543
+ key: 0,
544
+ path: unref(folderPath),
545
+ folder: element,
546
+ stories: __props.stories,
547
+ depth: __props.depth + 1
548
+ }, null, 8, ["path", "folder", "stories", "depth"])) : (openBlock(), createBlock(StoryListItem, {
549
+ key: 1,
550
+ story: __props.stories[element.index],
551
+ depth: __props.depth + 1
552
+ }, null, 8, ["story", "depth"]))
553
+ ], 64);
554
+ }), 128))
555
+ ])) : createCommentVNode("", true)
556
+ ]);
557
+ };
558
+ }
559
+ });
560
+ var StoryListFolder = /* @__PURE__ */ _export_sfc(_sfc_main$9, [["__scopeId", "data-v-1a78012e"]]);
561
+ const _hoisted_1$8 = {
562
+ "data-test-id": "story-group",
563
+ class: "htw-my-2 first:htw-mt-0 last:htw-mb-0"
564
+ };
565
+ const _hoisted_2$5 = ["onKeyup"];
566
+ const _hoisted_3$3 = { class: "htw-truncate htw-opacity-50" };
567
+ const _hoisted_4$2 = /* @__PURE__ */ createBaseVNode("span", { class: "htw-h-[1px] htw-flex-1 htw-bg-gray-500/10 htw-mx-2" }, null, -1);
568
+ const _hoisted_5 = { key: 1 };
569
+ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
570
+ name: "StoryGroup",
571
+ props: {
572
+ path: { default: () => [] },
573
+ group: null,
574
+ stories: null
575
+ },
576
+ setup(__props) {
577
+ const props = __props;
578
+ const folderStore = useFolderStore();
579
+ const folderPath = computed(() => [...props.path, props.group.title]);
580
+ const isFolderOpen = computed(() => folderStore.isFolderOpened(folderPath.value, true));
581
+ function toggleOpen() {
582
+ folderStore.toggleFolder(folderPath.value, false);
583
+ }
584
+ return (_ctx, _cache) => {
585
+ return openBlock(), createElementBlock("div", _hoisted_1$8, [
586
+ __props.group.title ? (openBlock(), createElementBlock("div", {
587
+ key: 0,
588
+ role: "button",
589
+ tabindex: "0",
590
+ class: "htw-px-0.5 htw-py-2 md:htw-py-1.5 htw-mx-1 htw-rounded-sm hover:htw-bg-primary-100 dark:hover:htw-bg-primary-900 htw-cursor-pointer htw-select-none htw-flex htw-items-center htw-gap-1 htw-min-w-0",
591
+ onClick: toggleOpen,
592
+ onKeyup: [
593
+ withKeys(toggleOpen, ["enter"]),
594
+ withKeys(toggleOpen, ["space"])
595
+ ]
596
+ }, [
597
+ createVNode(unref(Icon), {
598
+ icon: "carbon:caret-right",
599
+ class: normalizeClass(["htw-w-4 htw-h-4 htw-transition-transform htw-duration-150 htw-opacity-30 htw-flex-none", {
600
+ "htw-rotate-90": unref(isFolderOpen)
601
+ }])
602
+ }, null, 8, ["class"]),
603
+ createBaseVNode("span", _hoisted_3$3, toDisplayString(__props.group.title), 1),
604
+ _hoisted_4$2
605
+ ], 40, _hoisted_2$5)) : createCommentVNode("", true),
606
+ unref(isFolderOpen) ? (openBlock(), createElementBlock("div", _hoisted_5, [
607
+ (openBlock(true), createElementBlock(Fragment, null, renderList(__props.group.children, (element) => {
608
+ return openBlock(), createElementBlock(Fragment, {
609
+ key: element.title
610
+ }, [
611
+ element.children ? (openBlock(), createBlock(StoryListFolder, {
612
+ key: 0,
613
+ path: unref(folderPath),
614
+ folder: element,
615
+ stories: __props.stories,
616
+ depth: 0
617
+ }, null, 8, ["path", "folder", "stories"])) : (openBlock(), createBlock(StoryListItem, {
618
+ key: 1,
619
+ story: __props.stories[element.index],
620
+ depth: 0
621
+ }, null, 8, ["story"]))
622
+ ], 64);
623
+ }), 128))
624
+ ])) : createCommentVNode("", true)
625
+ ]);
626
+ };
627
+ }
628
+ });
629
+ const _hoisted_1$7 = { class: "htw-overflow-y-auto" };
630
+ const _sfc_main$7 = /* @__PURE__ */ defineComponent({
631
+ name: "StoryList",
632
+ props: {
633
+ tree: null,
634
+ stories: null
635
+ },
636
+ setup(__props) {
637
+ return (_ctx, _cache) => {
638
+ return openBlock(), createElementBlock("div", _hoisted_1$7, [
639
+ (openBlock(true), createElementBlock(Fragment, null, renderList(__props.tree, (element) => {
640
+ return openBlock(), createElementBlock(Fragment, {
641
+ key: element.title
642
+ }, [
643
+ element.group ? (openBlock(), createBlock(_sfc_main$8, {
644
+ key: 0,
645
+ group: element,
646
+ stories: __props.stories
647
+ }, null, 8, ["group", "stories"])) : element.children ? (openBlock(), createBlock(StoryListFolder, {
648
+ key: 1,
649
+ folder: element,
650
+ stories: __props.stories
651
+ }, null, 8, ["folder", "stories"])) : (openBlock(), createBlock(StoryListItem, {
652
+ key: 2,
653
+ story: __props.stories[element.index]
654
+ }, null, 8, ["story"]))
655
+ ], 64);
656
+ }), 128))
657
+ ]);
658
+ };
659
+ }
660
+ });
661
+ var HistoireLogoDark = "data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!-- Created with Inkscape (http://www.inkscape.org/) -->

<svg
   width="1536"
   height="512"
   viewBox="0 0 1536 512"
   version="1.1"
   id="svg5"
   xmlns="http://www.w3.org/2000/svg"
   xmlns:svg="http://www.w3.org/2000/svg">
  <defs
     id="defs2" />
  <g
     id="layer1">
    <rect
       style="opacity:0.5;fill:#34d399;fill-opacity:1;stroke-width:1.00375"
       id="rect1372"
       width="314.30923"
       height="406.60901"
       x="-26.565063"
       y="134.75079"
       transform="rotate(-23.821262)"
       ry="8" />
    <rect
       style="fill:#34d399;fill-opacity:1;stroke-width:1.00375"
       id="rect850"
       width="314.30923"
       height="406.60901"
       x="77.571838"
       y="72.808708"
       ry="8"
       transform="rotate(-4.5744534)" />
  </g>
  <g
     id="layer3">
    <path
       id="path1657-3"
       style="display:inline;fill:#adedd6;fill-opacity:1;stroke:#adedd6;stroke-width:8.34923;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
       d="M 359.38947,355.95134 320.72935,176.52942 238.34613,238.94118 Z M 273.64124,273.06608 152.59788,156.05591 191.25804,335.47786 Z" />
    <g
       aria-label="Histoire"
       id="text1821-4"
       style="font-size:231.926px;line-height:1.25;font-family:Sen;-inkscape-font-specification:Sen;fill:#adedd6;fill-opacity:1;stroke-width:5.79813"
       transform="matrix(1.1500556,0,0,1.1500556,-105.40156,-38.414233)">
      <path
         d="M 693.87591,344.24783 V 181.89964 h 25.04801 v 162.34819 z m -105.99018,0 V 181.89964 h 25.04801 v 162.34819 z m 10.90052,-68.88202 v -24.1203 h 106.22211 v 24.1203 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#adedd6;fill-opacity:1"
         id="path16857" />
      <path
         d="M 762.294,344.24783 V 222.48669 h 23.88838 v 121.76114 z m 11.5963,-148.66456 q -7.65356,0 -11.82822,-3.94274 -4.17467,-3.94274 -4.17467,-11.13245 0,-6.72585 4.17467,-10.90052 4.40659,-4.17467 11.82822,-4.17467 7.65356,0 11.82823,3.94274 4.17466,3.94275 4.17466,11.13245 0,6.72585 -4.40659,10.90052 -4.17467,4.17467 -11.5963,4.17467 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#adedd6;fill-opacity:1"
         id="path16859" />
      <path
         d="m 863.41371,346.56709 q -15.30711,0 -27.59919,-5.33429 -12.29208,-5.3343 -20.40949,-15.77097 l 16.23482,-13.91556 q 6.95778,8.11741 15.07519,11.82822 8.34934,3.47889 18.78601,3.47889 4.17466,0 7.65355,-0.9277 3.71082,-1.15963 6.26201,-3.24696 2.78311,-2.08734 4.17466,-4.87045 1.39156,-3.01504 1.39156,-6.49393 0,-6.03007 -4.40659,-9.74089 -2.31926,-1.62348 -7.42164,-3.47889 -4.87044,-2.08733 -12.75593,-4.17467 -13.4517,-3.47889 -22.03297,-7.88548 -8.58126,-4.4066 -13.21978,-9.97282 -3.47889,-4.40659 -5.10237,-9.50897 -1.62348,-5.33429 -1.62348,-11.59629 0,-7.65356 3.24696,-13.91556 3.47889,-6.49393 9.27704,-11.13245 6.03008,-4.87045 13.91556,-7.42163 8.11741,-2.55119 17.16253,-2.55119 8.58126,0 16.93059,2.31926 8.58126,2.31926 15.77097,6.72585 7.18971,4.4066 12.06015,10.43667 l -13.68363,15.07519 q -4.4066,-4.40659 -9.74089,-7.65355 -5.10237,-3.47889 -10.43667,-5.3343 -5.3343,-1.85541 -9.74089,-1.85541 -4.87045,0 -8.81319,0.9277 -3.94274,0.92771 -6.72586,2.78312 -2.55118,1.8554 -3.94274,4.63852 -1.39155,2.78311 -1.39155,6.262 0.23192,3.01504 1.39155,5.79815 1.39156,2.55118 3.71082,4.40659 2.55118,1.85541 7.65356,3.94274 5.10237,2.08734 12.98785,3.94274 11.5963,3.01504 19.01793,6.72586 7.65356,3.47889 12.06015,8.11741 4.63852,4.40659 6.49393,10.20474 1.85541,5.79815 1.85541,12.98786 0,10.43667 -6.03008,18.786 -5.79815,8.11741 -15.77096,12.75593 -9.97282,4.63852 -22.2649,4.63852 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#adedd6;fill-opacity:1"
         id="path16861" />
      <path
         d="M 948.99398,344.24783 V 191.4086 h 23.88838 v 152.83923 z m -25.27993,-98.56854 v -23.1926 h 77.46325 v 23.1926 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#adedd6;fill-opacity:1"
         id="path16863" />
      <path
         d="m 1076.5528,346.56709 q -17.8583,0 -32.0058,-8.11741 -13.9156,-8.34933 -22.033,-22.49682 -8.1174,-14.37941 -8.1174,-32.70156 0,-18.32216 8.1174,-32.46964 8.1174,-14.37941 22.033,-22.49682 14.1475,-8.34934 32.0058,-8.34934 17.6263,0 31.5419,8.34934 14.1475,8.11741 22.2649,22.49682 8.1174,14.14748 8.1174,32.46964 0,18.32215 -8.1174,32.70156 -8.1174,14.14749 -22.2649,22.49682 -13.9156,8.11741 -31.5419,8.11741 z m 0,-21.80104 q 10.9005,0 19.4818,-5.3343 8.5812,-5.56622 13.4517,-14.84326 4.8704,-9.50897 4.6385,-21.33719 0.2319,-12.06016 -4.6385,-21.33719 -4.8705,-9.50897 -13.4517,-14.84327 -8.5813,-5.3343 -19.4818,-5.3343 -10.9005,0 -19.7137,5.56623 -8.5813,5.3343 -13.4517,14.84326 -4.8705,9.27704 -4.6386,21.10527 -0.2319,11.82822 4.6386,21.33719 4.8704,9.27704 13.4517,14.84326 8.8132,5.3343 19.7137,5.3343 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#adedd6;fill-opacity:1"
         id="path16865" />
      <path
         d="M 1168.3954,344.24783 V 222.48669 h 23.8884 v 121.76114 z m 11.5963,-148.66456 q -7.6536,0 -11.8282,-3.94274 -4.1747,-3.94274 -4.1747,-11.13245 0,-6.72585 4.1747,-10.90052 4.4065,-4.17467 11.8282,-4.17467 7.6535,0 11.8282,3.94274 4.1747,3.94275 4.1747,11.13245 0,6.72585 -4.4066,10.90052 -4.1747,4.17467 -11.5963,4.17467 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#adedd6;fill-opacity:1"
         id="path16867" />
      <path
         d="M 1228.928,344.24783 V 222.48669 h 24.1203 v 38.26779 l -2.3192,-9.27704 q 2.5512,-8.81319 8.5812,-16.0029 6.262,-7.1897 14.1475,-11.36437 8.1174,-4.17467 16.6987,-4.17467 3.9427,0 7.4216,0.69578 3.7109,0.69578 5.7982,1.62348 l -6.262,25.97571 q -2.7831,-1.15963 -6.262,-1.85541 -3.247,-0.9277 -6.4939,-0.9277 -6.262,0 -12.0602,2.55119 -5.5662,2.31926 -9.9728,6.72585 -4.1747,4.17467 -6.7259,9.97282 -2.5512,5.56622 -2.5512,12.29207 v 67.25854 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#adedd6;fill-opacity:1"
         id="path16869" />
      <path
         d="m 1374.1134,346.56709 q -18.786,0 -33.3973,-7.88548 -14.3794,-8.11741 -22.7288,-22.03297 -8.1174,-13.91556 -8.1174,-32.00579 0,-14.37941 4.6386,-26.20763 4.6385,-11.82823 12.7559,-20.40949 8.3493,-8.81319 19.7137,-13.45171 11.5963,-4.87045 25.048,-4.87045 11.8282,0 22.033,4.63852 10.2047,4.4066 17.6263,12.29208 7.6536,7.88549 11.5963,18.78601 4.1747,10.66859 3.9428,23.42452 l -0.2319,10.20475 h -99.4963 l -5.3343,-19.01794 h 84.1891 l -3.4788,3.94275 v -5.56623 q -0.6958,-7.65355 -5.1024,-13.68363 -4.4066,-6.03008 -11.1325,-9.50897 -6.7258,-3.47889 -14.6113,-3.47889 -12.524,0 -21.1053,4.87045 -8.5812,4.63852 -12.9878,13.91556 -4.4066,9.04511 -4.4066,22.49682 0,12.75593 5.3343,22.2649 5.3343,9.27704 15.0752,14.37941 9.7409,5.10237 22.4968,5.10237 9.0451,0 16.6987,-3.01504 7.8855,-3.01504 16.9306,-10.90052 l 12.0601,16.9306 q -5.5662,5.56622 -13.6836,9.74089 -7.8855,4.17467 -16.9306,6.72585 -8.8132,2.31926 -17.3945,2.31926 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#adedd6;fill-opacity:1"
         id="path16871" />
    </g>
  </g>
  <g
     id="layer2"
     style="display:none">
    <path
       id="path1657"
       style="fill:#b4fae2;fill-opacity:1;stroke:#b4fae2;stroke-width:8;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
       d="m 296,103.98242 -135.53125,177.9668 h 88.70117 z M 262.83008,230.05078 216,408.01758 351.53125,230.05078 Z"
       transform="rotate(-4.156553,256,256.00691)" />
  </g>
</svg>
";
662
+ var HistoireLogoLight = "data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!-- Created with Inkscape (http://www.inkscape.org/) -->

<svg
   width="1536"
   height="512"
   viewBox="0 0 1536 512"
   version="1.1"
   id="svg5"
   xmlns="http://www.w3.org/2000/svg"
   xmlns:svg="http://www.w3.org/2000/svg">
  <defs
     id="defs2" />
  <g
     id="layer1">
    <rect
       style="opacity:0.5;fill:#34d399;fill-opacity:1;stroke-width:1.00375"
       id="rect1372"
       width="314.30923"
       height="406.60901"
       x="-26.565063"
       y="134.75079"
       transform="rotate(-23.821262)"
       ry="8" />
    <rect
       style="fill:#34d399;fill-opacity:1;stroke-width:1.00375"
       id="rect850"
       width="314.30923"
       height="406.60901"
       x="77.571838"
       y="72.808708"
       ry="8"
       transform="rotate(-4.5744534)" />
  </g>
  <g
     id="layer3">
    <path
       id="path1657-3"
       style="display:inline;fill:#adedd6;fill-opacity:1;stroke:#adedd6;stroke-width:8.34923;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
       d="M 359.38947,355.95134 320.72935,176.52942 238.34613,238.94118 Z M 273.64124,273.06608 152.59788,156.05591 191.25804,335.47786 Z" />
    <g
       aria-label="Histoire"
       id="text1821"
       style="font-size:231.926px;line-height:1.25;font-family:Sen;-inkscape-font-specification:Sen;fill:#2bc78e;stroke-width:5.79813;fill-opacity:1"
       transform="matrix(1.1500556,0,0,1.1500556,-105.40156,-38.414233)">
      <path
         d="M 693.87591,344.24783 V 181.89964 h 25.04801 v 162.34819 z m -105.99018,0 V 181.89964 h 25.04801 v 162.34819 z m 10.90052,-68.88202 v -24.1203 h 106.22211 v 24.1203 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#2bc78e;fill-opacity:1"
         id="path16857" />
      <path
         d="M 762.294,344.24783 V 222.48669 h 23.88838 v 121.76114 z m 11.5963,-148.66456 q -7.65356,0 -11.82822,-3.94274 -4.17467,-3.94274 -4.17467,-11.13245 0,-6.72585 4.17467,-10.90052 4.40659,-4.17467 11.82822,-4.17467 7.65356,0 11.82823,3.94274 4.17466,3.94275 4.17466,11.13245 0,6.72585 -4.40659,10.90052 -4.17467,4.17467 -11.5963,4.17467 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#2bc78e;fill-opacity:1"
         id="path16859" />
      <path
         d="m 863.41371,346.56709 q -15.30711,0 -27.59919,-5.33429 -12.29208,-5.3343 -20.40949,-15.77097 l 16.23482,-13.91556 q 6.95778,8.11741 15.07519,11.82822 8.34934,3.47889 18.78601,3.47889 4.17466,0 7.65355,-0.9277 3.71082,-1.15963 6.26201,-3.24696 2.78311,-2.08734 4.17466,-4.87045 1.39156,-3.01504 1.39156,-6.49393 0,-6.03007 -4.40659,-9.74089 -2.31926,-1.62348 -7.42164,-3.47889 -4.87044,-2.08733 -12.75593,-4.17467 -13.4517,-3.47889 -22.03297,-7.88548 -8.58126,-4.4066 -13.21978,-9.97282 -3.47889,-4.40659 -5.10237,-9.50897 -1.62348,-5.33429 -1.62348,-11.59629 0,-7.65356 3.24696,-13.91556 3.47889,-6.49393 9.27704,-11.13245 6.03008,-4.87045 13.91556,-7.42163 8.11741,-2.55119 17.16253,-2.55119 8.58126,0 16.93059,2.31926 8.58126,2.31926 15.77097,6.72585 7.18971,4.4066 12.06015,10.43667 l -13.68363,15.07519 q -4.4066,-4.40659 -9.74089,-7.65355 -5.10237,-3.47889 -10.43667,-5.3343 -5.3343,-1.85541 -9.74089,-1.85541 -4.87045,0 -8.81319,0.9277 -3.94274,0.92771 -6.72586,2.78312 -2.55118,1.8554 -3.94274,4.63852 -1.39155,2.78311 -1.39155,6.262 0.23192,3.01504 1.39155,5.79815 1.39156,2.55118 3.71082,4.40659 2.55118,1.85541 7.65356,3.94274 5.10237,2.08734 12.98785,3.94274 11.5963,3.01504 19.01793,6.72586 7.65356,3.47889 12.06015,8.11741 4.63852,4.40659 6.49393,10.20474 1.85541,5.79815 1.85541,12.98786 0,10.43667 -6.03008,18.786 -5.79815,8.11741 -15.77096,12.75593 -9.97282,4.63852 -22.2649,4.63852 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#2bc78e;fill-opacity:1"
         id="path16861" />
      <path
         d="M 948.99398,344.24783 V 191.4086 h 23.88838 v 152.83923 z m -25.27993,-98.56854 v -23.1926 h 77.46325 v 23.1926 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#2bc78e;fill-opacity:1"
         id="path16863" />
      <path
         d="m 1076.5528,346.56709 q -17.8583,0 -32.0058,-8.11741 -13.9156,-8.34933 -22.033,-22.49682 -8.1174,-14.37941 -8.1174,-32.70156 0,-18.32216 8.1174,-32.46964 8.1174,-14.37941 22.033,-22.49682 14.1475,-8.34934 32.0058,-8.34934 17.6263,0 31.5419,8.34934 14.1475,8.11741 22.2649,22.49682 8.1174,14.14748 8.1174,32.46964 0,18.32215 -8.1174,32.70156 -8.1174,14.14749 -22.2649,22.49682 -13.9156,8.11741 -31.5419,8.11741 z m 0,-21.80104 q 10.9005,0 19.4818,-5.3343 8.5812,-5.56622 13.4517,-14.84326 4.8704,-9.50897 4.6385,-21.33719 0.2319,-12.06016 -4.6385,-21.33719 -4.8705,-9.50897 -13.4517,-14.84327 -8.5813,-5.3343 -19.4818,-5.3343 -10.9005,0 -19.7137,5.56623 -8.5813,5.3343 -13.4517,14.84326 -4.8705,9.27704 -4.6386,21.10527 -0.2319,11.82822 4.6386,21.33719 4.8704,9.27704 13.4517,14.84326 8.8132,5.3343 19.7137,5.3343 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#2bc78e;fill-opacity:1"
         id="path16865" />
      <path
         d="M 1168.3954,344.24783 V 222.48669 h 23.8884 v 121.76114 z m 11.5963,-148.66456 q -7.6536,0 -11.8282,-3.94274 -4.1747,-3.94274 -4.1747,-11.13245 0,-6.72585 4.1747,-10.90052 4.4065,-4.17467 11.8282,-4.17467 7.6535,0 11.8282,3.94274 4.1747,3.94275 4.1747,11.13245 0,6.72585 -4.4066,10.90052 -4.1747,4.17467 -11.5963,4.17467 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#2bc78e;fill-opacity:1"
         id="path16867" />
      <path
         d="M 1228.928,344.24783 V 222.48669 h 24.1203 v 38.26779 l -2.3192,-9.27704 q 2.5512,-8.81319 8.5812,-16.0029 6.262,-7.1897 14.1475,-11.36437 8.1174,-4.17467 16.6987,-4.17467 3.9427,0 7.4216,0.69578 3.7109,0.69578 5.7982,1.62348 l -6.262,25.97571 q -2.7831,-1.15963 -6.262,-1.85541 -3.247,-0.9277 -6.4939,-0.9277 -6.262,0 -12.0602,2.55119 -5.5662,2.31926 -9.9728,6.72585 -4.1747,4.17467 -6.7259,9.97282 -2.5512,5.56622 -2.5512,12.29207 v 67.25854 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#2bc78e;fill-opacity:1"
         id="path16869" />
      <path
         d="m 1374.1134,346.56709 q -18.786,0 -33.3973,-7.88548 -14.3794,-8.11741 -22.7288,-22.03297 -8.1174,-13.91556 -8.1174,-32.00579 0,-14.37941 4.6386,-26.20763 4.6385,-11.82823 12.7559,-20.40949 8.3493,-8.81319 19.7137,-13.45171 11.5963,-4.87045 25.048,-4.87045 11.8282,0 22.033,4.63852 10.2047,4.4066 17.6263,12.29208 7.6536,7.88549 11.5963,18.78601 4.1747,10.66859 3.9428,23.42452 l -0.2319,10.20475 h -99.4963 l -5.3343,-19.01794 h 84.1891 l -3.4788,3.94275 v -5.56623 q -0.6958,-7.65355 -5.1024,-13.68363 -4.4066,-6.03008 -11.1325,-9.50897 -6.7258,-3.47889 -14.6113,-3.47889 -12.524,0 -21.1053,4.87045 -8.5812,4.63852 -12.9878,13.91556 -4.4066,9.04511 -4.4066,22.49682 0,12.75593 5.3343,22.2649 5.3343,9.27704 15.0752,14.37941 9.7409,5.10237 22.4968,5.10237 9.0451,0 16.6987,-3.01504 7.8855,-3.01504 16.9306,-10.90052 l 12.0601,16.9306 q -5.5662,5.56622 -13.6836,9.74089 -7.8855,4.17467 -16.9306,6.72585 -8.8132,2.31926 -17.3945,2.31926 z"
         style="font-family:'Lexend Deca';-inkscape-font-specification:'Lexend Deca';fill:#2bc78e;fill-opacity:1"
         id="path16871" />
    </g>
  </g>
  <g
     id="layer2"
     style="display:none">
    <path
       id="path1657"
       style="fill:#b4fae2;fill-opacity:1;stroke:#b4fae2;stroke-width:8;stroke-linecap:butt;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
       d="m 296,103.98242 -135.53125,177.9668 h 88.70117 z M 262.83008,230.05078 216,408.01758 351.53125,230.05078 Z"
       transform="rotate(-4.156553,256,256.00691)" />
  </g>
</svg>
";
663
+ const _hoisted_1$6 = ["src", "alt"];
664
+ const _sfc_main$6 = /* @__PURE__ */ defineComponent({
665
+ name: "AppLogo",
666
+ setup(__props) {
667
+ const logoUrl = computed(() => {
668
+ var _a, _b;
669
+ if (isDark.value) {
670
+ return ((_a = histoireConfig.theme.logo) == null ? void 0 : _a.dark) ? customLogos.dark : HistoireLogoDark;
671
+ }
672
+ return ((_b = histoireConfig.theme.logo) == null ? void 0 : _b.light) ? customLogos.light : HistoireLogoLight;
673
+ });
674
+ const altText = computed(() => histoireConfig.theme.title + " logo");
675
+ return (_ctx, _cache) => {
676
+ return openBlock(), createElementBlock("img", {
677
+ src: unref(logoUrl),
678
+ alt: unref(altText)
679
+ }, null, 8, _hoisted_1$6);
680
+ };
681
+ }
682
+ });
683
+ const isMac = navigator.platform.toLowerCase().includes("mac");
684
+ function onKeyboardShortcut(shortcut, handler, options = {}) {
685
+ var _a;
686
+ useEventListener((_a = options.event) != null ? _a : "keydown", (event) => {
687
+ if (isMatchingShortcut(isRef(shortcut) ? shortcut.value : shortcut)) {
688
+ handler(event);
689
+ }
690
+ });
691
+ }
692
+ const modifiers = {
693
+ ctrl: { key: "Control", pressed: false },
694
+ alt: { key: "Alt", pressed: false },
695
+ shift: { key: "Shift", pressed: false },
696
+ meta: { key: "Meta", pressed: false }
697
+ };
698
+ const pressedKeys = /* @__PURE__ */ new Set();
699
+ window.addEventListener("keydown", (event) => {
700
+ for (const i in modifiers) {
701
+ const mod = modifiers[i];
702
+ if (mod.key === event.key) {
703
+ mod.pressed = true;
704
+ return;
705
+ }
706
+ }
707
+ pressedKeys.add(event.key.toLocaleLowerCase());
708
+ });
709
+ window.addEventListener("keyup", (event) => {
710
+ requestAnimationFrame(() => {
711
+ pressedKeys.clear();
712
+ for (const i in modifiers) {
713
+ const mod = modifiers[i];
714
+ if (mod.key === event.key) {
715
+ mod.pressed = false;
716
+ break;
717
+ }
718
+ }
719
+ });
720
+ });
721
+ window.addEventListener("blur", () => {
722
+ pressedKeys.clear();
723
+ for (const i in modifiers) {
724
+ const mod = modifiers[i];
725
+ mod.pressed = false;
726
+ }
727
+ });
728
+ function isMatchingShortcut(shortcut) {
729
+ for (const combination of shortcut) {
730
+ if (isMatchingCombination(combination.toLowerCase())) {
731
+ return true;
732
+ }
733
+ }
734
+ return false;
735
+ }
736
+ function isMatchingCombination(combination) {
737
+ const splitted = combination.split("+").map((key) => key.trim());
738
+ const targetKey = splitted.pop();
739
+ for (const mod in modifiers) {
740
+ const containsMod = splitted.includes(mod);
741
+ const isPressed = modifiers[mod].pressed;
742
+ if (containsMod !== isPressed) {
743
+ return false;
744
+ }
745
+ }
746
+ return pressedKeys.has(targetKey);
747
+ }
748
+ function formatKey(key) {
749
+ key = key.toLowerCase();
750
+ if (key === "ctrl") {
751
+ return isMac ? "^" : "Ctrl";
752
+ }
753
+ if (key === "alt") {
754
+ return isMac ? "\u2387" : "Alt";
755
+ }
756
+ if (key === "shift") {
757
+ return "\u21E7";
758
+ }
759
+ if (key === "meta") {
760
+ return "\u2318";
761
+ }
762
+ return key.charAt(0).toUpperCase() + key.substring(1).toLowerCase();
763
+ }
764
+ function makeTooltip(descriptionHtml, keyboardShortcut) {
765
+ return {
766
+ content: `<div>${descriptionHtml}</div><div class="htw-flex htw-items-center htw-gap-1 htw-mt-2 htw-text-sm">${genKeyboardShortcutHtml(keyboardShortcut({ isMac }))}</div>`,
767
+ html: true
768
+ };
769
+ }
770
+ function genKeyboardShortcutHtml(shortcut) {
771
+ return shortcut.split("+").map((k) => k.trim()).map((key) => `<span class="htw-bg-gray-500 htw-border-b-2 htw-border-gray-600 htw-px-1 htw-rounded-sm">${formatKey(key)}</span>`).join("");
772
+ }
773
+ const _hoisted_1$5 = { class: "htw-px-4 htw-h-16 htw-flex htw-items-center htw-gap-2" };
774
+ const _hoisted_2$4 = { class: "htw-py-3 sm:htw-py-4 htw-flex-1 htw-h-full htw-flex htw-items-center htw-pr-2" };
775
+ const _hoisted_3$2 = ["href"];
776
+ const _hoisted_4$1 = { class: "htw-ml-auto htw-flex-none htw-flex" };
777
+ const _sfc_main$5 = /* @__PURE__ */ defineComponent({
778
+ name: "AppHeader",
779
+ emits: {
780
+ search: () => true
781
+ },
782
+ setup(__props) {
783
+ const themeIcon = computed(() => {
784
+ return isDark.value ? "carbon:moon" : "carbon:sun";
785
+ });
786
+ onKeyboardShortcut(["ctrl+shift+d", "meta+shift+d"], (event) => {
787
+ event.preventDefault();
788
+ toggleDark();
789
+ });
790
+ return (_ctx, _cache) => {
791
+ var _a;
792
+ const _directive_tooltip = resolveDirective("tooltip");
793
+ return openBlock(), createElementBlock("div", _hoisted_1$5, [
794
+ createBaseVNode("div", _hoisted_2$4, [
795
+ createBaseVNode("a", {
796
+ href: (_a = unref(histoireConfig).theme) == null ? void 0 : _a.logoHref,
797
+ target: "_blank",
798
+ class: "htw-w-full htw-h-full htw-flex htw-items-center"
799
+ }, [
800
+ createVNode(_sfc_main$6, { class: "htw-max-w-full htw-max-h-full" })
801
+ ], 8, _hoisted_3$2)
802
+ ]),
803
+ createBaseVNode("div", _hoisted_4$1, [
804
+ withDirectives((openBlock(), createElementBlock("a", {
805
+ class: "htw-p-2 sm:htw-p-1 hover:htw-text-primary-500 dark:hover:htw-text-primary-400 htw-cursor-pointer htw-text-gray-900 dark:htw-text-gray-100",
806
+ "data-test-id": "search-btn",
807
+ onClick: _cache[0] || (_cache[0] = ($event) => _ctx.$emit("search"))
808
+ }, [
809
+ createVNode(unref(Icon), {
810
+ icon: "carbon:search",
811
+ class: "htw-w-6 htw-h-6 sm:htw-w-4 sm:htw-h-4"
812
+ })
813
+ ])), [
814
+ [_directive_tooltip, unref(makeTooltip)("Search", ({ isMac: isMac2 }) => isMac2 ? "meta+k" : "ctrl+k")]
815
+ ]),
816
+ withDirectives((openBlock(), createElementBlock("a", {
817
+ class: "htw-p-2 sm:htw-p-1 hover:htw-text-primary-500 dark:hover:htw-text-primary-400 htw-cursor-pointer htw-text-gray-900 dark:htw-text-gray-100",
818
+ onClick: _cache[1] || (_cache[1] = ($event) => unref(toggleDark)())
819
+ }, [
820
+ createVNode(unref(Icon), {
821
+ icon: unref(themeIcon),
822
+ class: "htw-w-6 htw-h-6 sm:htw-w-4 sm:htw-h-4"
823
+ }, null, 8, ["icon"])
824
+ ])), [
825
+ [_directive_tooltip, unref(makeTooltip)("Toggle dark mode", ({ isMac: isMac2 }) => isMac2 ? "meta+shift+d" : "ctrl+shift+d")]
826
+ ])
827
+ ])
828
+ ]);
829
+ };
830
+ }
831
+ });
832
+ const _withScopeId = (n) => (pushScopeId("data-v-5fe505b0"), n = n(), popScopeId(), n);
833
+ const _hoisted_1$4 = /* @__PURE__ */ _withScopeId(() => /* @__PURE__ */ createBaseVNode("span", { class: "htw-opacity-40" }, " / ", -1));
834
+ const _hoisted_2$3 = { class: "htw-flex htw-items-center htw-gap-2" };
835
+ const _hoisted_3$1 = { class: "htw-opacity-40 htw-text-sm" };
836
+ const _hoisted_4 = /* @__PURE__ */ createTextVNode(" Select a story... ");
837
+ const _sfc_main$4 = /* @__PURE__ */ defineComponent({
838
+ name: "Breadcrumb",
839
+ props: {
840
+ tree: null,
841
+ stories: null
842
+ },
843
+ setup(__props) {
844
+ useCssVars((_ctx) => {
845
+ var _a;
846
+ return {
847
+ "7fa476a0": (_a = unref(story)) == null ? void 0 : _a.iconColor
848
+ };
849
+ });
850
+ const storyStore = useStoryStore();
851
+ const story = computed(() => storyStore.currentStory);
852
+ const folders = computed(() => {
853
+ return story.value.file.path.slice(0, -1);
854
+ });
855
+ const isMenuOpened = ref(false);
856
+ function openMenu() {
857
+ isMenuOpened.value = true;
858
+ }
859
+ function closeMenu() {
860
+ isMenuOpened.value = false;
861
+ }
862
+ watch(story, () => {
863
+ isMenuOpened.value = false;
864
+ });
865
+ return (_ctx, _cache) => {
866
+ var _a;
867
+ return openBlock(), createElementBlock(Fragment, null, [
868
+ createBaseVNode("div", null, [
869
+ createBaseVNode("a", {
870
+ class: "htw-px-6 htw-h-12 hover:htw-text-primary-500 dark:hover:htw-text-primary-400 htw-cursor-pointer htw-flex htw-gap-2 htw-flex-wrap htw-w-full htw-items-center",
871
+ onClick: openMenu
872
+ }, [
873
+ unref(story) ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
874
+ (openBlock(true), createElementBlock(Fragment, null, renderList(unref(folders), (file, key) => {
875
+ return openBlock(), createElementBlock(Fragment, { key }, [
876
+ createBaseVNode("span", null, toDisplayString(file), 1),
877
+ _hoisted_1$4
878
+ ], 64);
879
+ }), 128)),
880
+ createBaseVNode("span", _hoisted_2$3, [
881
+ createVNode(unref(Icon), {
882
+ icon: (_a = unref(story).icon) != null ? _a : "carbon:cube",
883
+ class: normalizeClass(["base-list-item-link-icon htw-w-5 htw-h-5 htw-flex-none", {
884
+ "htw-text-primary-500": !unref(story).iconColor,
885
+ "bind-icon-color": unref(story).iconColor
886
+ }])
887
+ }, null, 8, ["icon", "class"]),
888
+ createTextVNode(" " + toDisplayString(unref(story).title) + " ", 1),
889
+ createBaseVNode("span", _hoisted_3$1, toDisplayString(unref(story).variants.length), 1)
890
+ ])
891
+ ], 64)) : (openBlock(), createElementBlock(Fragment, { key: 1 }, [
892
+ _hoisted_4
893
+ ], 64)),
894
+ createVNode(unref(Icon), {
895
+ icon: "carbon:chevron-sort",
896
+ class: "htw-w-5 htw-h-5 htw-shrink-0 htw-ml-auto"
897
+ })
898
+ ])
899
+ ]),
900
+ createVNode(_sfc_main$b, {
901
+ title: "Select a story",
902
+ opened: isMenuOpened.value,
903
+ onClose: closeMenu
904
+ }, {
905
+ default: withCtx(() => [
906
+ createVNode(_sfc_main$7, {
907
+ tree: __props.tree,
908
+ stories: __props.stories,
909
+ class: "htw-flex-1 htw-overflow-y-scroll"
910
+ }, null, 8, ["tree", "stories"])
911
+ ]),
912
+ _: 1
913
+ }, 8, ["opened"])
914
+ ], 64);
915
+ };
916
+ }
917
+ });
918
+ var Breadcrumb = /* @__PURE__ */ _export_sfc(_sfc_main$4, [["__scopeId", "data-v-5fe505b0"]]);
919
+ const _hoisted_1$3 = { class: "htw-flex htw-items-center htw-gap-4 htw-pl-6 htw-border htw-border-transparent focus-visible:htw-border-primary-500 htw-h-[51px] htw-opacity-30" };
920
+ const _hoisted_2$2 = /* @__PURE__ */ createTextVNode(" Loading... ");
921
+ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
922
+ name: "SearchLoading",
923
+ setup(__props) {
924
+ return (_ctx, _cache) => {
925
+ return openBlock(), createElementBlock("div", _hoisted_1$3, [
926
+ createVNode(unref(Icon), {
927
+ icon: "carbon:search",
928
+ class: "flex-none htw-w-4 htw-h-4"
929
+ }),
930
+ _hoisted_2$2
931
+ ]);
932
+ };
933
+ }
934
+ });
935
+ const _hoisted_1$2 = {
936
+ class: "htw-fixed htw-inset-0 htw-bg-white/80 dark:htw-bg-gray-700/80 htw-z-20",
937
+ "data-test-id": "search-modal"
938
+ };
939
+ const _hoisted_2$1 = { class: "htw-bg-white dark:htw-bg-gray-700 md:htw-mt-16 md:htw-mx-auto htw-w-screen htw-max-w-[512px] htw-shadow-xl htw-border htw-border-gray-200 dark:htw-border-gray-850 htw-rounded-lg htw-relative htw-divide-y htw-divide-gray-200 dark:htw-divide-gray-850" };
940
+ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
941
+ name: "SearchModal",
942
+ props: {
943
+ shown: {
944
+ type: Boolean,
945
+ default: false
946
+ }
947
+ },
948
+ emits: {
949
+ close: () => true
950
+ },
951
+ setup(__props, { emit }) {
952
+ const SearchPane = defineAsyncComponent({
953
+ loader: () => __vitePreload(() => import("./SearchPane.daa2675c.js"), true ? ["assets/SearchPane.daa2675c.js","assets/global-components.6736b2a9.js","assets/vendor.2833ae3d.js","assets/BaseEmpty.d30f3079.js"] : void 0),
954
+ loadingComponent: _sfc_main$3,
955
+ delay: 0
956
+ });
957
+ function close() {
958
+ emit("close");
959
+ }
960
+ return (_ctx, _cache) => {
961
+ return withDirectives((openBlock(), createElementBlock("div", _hoisted_1$2, [
962
+ createBaseVNode("div", {
963
+ class: "htw-absolute htw-inset-0",
964
+ onClick: _cache[0] || (_cache[0] = ($event) => close())
965
+ }),
966
+ createBaseVNode("div", _hoisted_2$1, [
967
+ createVNode(unref(SearchPane), {
968
+ shown: __props.shown,
969
+ onClose: _cache[1] || (_cache[1] = ($event) => close())
970
+ }, null, 8, ["shown"])
971
+ ])
972
+ ], 512)), [
973
+ [vShow, __props.shown]
974
+ ]);
975
+ };
976
+ }
977
+ });
978
+ const _hoisted_1$1 = { class: "htw-fixed htw-inset-0 htw-bg-white dark:htw-bg-gray-700 htw-flex htw-flex-col htw-gap-6 htw-items-center htw-justify-center" };
979
+ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
980
+ name: "InitialLoading",
981
+ setup(__props) {
982
+ const progress = reactive({
983
+ loaded: 0,
984
+ total: 0
985
+ });
986
+ const maxCols = window.innerWidth / 20;
987
+ return (_ctx, _cache) => {
988
+ return openBlock(), createElementBlock("div", _hoisted_1$1, [
989
+ createVNode(Transition, { name: "__histoire-fade" }, {
990
+ default: withCtx(() => [
991
+ progress.total > 0 ? (openBlock(), createElementBlock("div", {
992
+ key: 0,
993
+ class: "htw-grid htw-gap-2",
994
+ style: normalizeStyle({
995
+ gridTemplateColumns: `repeat(${Math.min(Math.ceil(Math.sqrt(progress.total)), maxCols)}, minmax(0, 1fr))`
996
+ })
997
+ }, [
998
+ (openBlock(true), createElementBlock(Fragment, null, renderList(progress.total, (n) => {
999
+ return openBlock(), createElementBlock("div", {
1000
+ key: n,
1001
+ class: "htw-bg-primary-500/10 htw-rounded-full"
1002
+ }, [
1003
+ createBaseVNode("div", {
1004
+ class: normalizeClass(["htw-w-3 htw-h-3 htw-bg-primary-500 htw-rounded-full htw-duration-150 htw-ease-out", {
1005
+ "htw-transition-transform htw-scale-0": n >= progress.loaded
1006
+ }])
1007
+ }, null, 2)
1008
+ ]);
1009
+ }), 128))
1010
+ ], 4)) : createCommentVNode("", true)
1011
+ ]),
1012
+ _: 1
1013
+ })
1014
+ ]);
1015
+ };
1016
+ }
1017
+ });
1018
+ const _hoisted_1 = {
1019
+ key: 0,
1020
+ class: "htw-hidden"
1021
+ };
1022
+ const _hoisted_2 = {
1023
+ key: 0,
1024
+ class: "htw-h-full htw-flex htw-flex-col htw-divide-y htw-divide-gray-100 dark:htw-divide-gray-800"
1025
+ };
1026
+ const _hoisted_3 = { class: "htw-flex htw-flex-col htw-h-full" };
1027
+ const __default__ = {
1028
+ name: "HistoireApp"
1029
+ };
1030
+ const _sfc_main = /* @__PURE__ */ defineComponent(__spreadProps(__spreadValues({}, __default__), {
1031
+ setup(__props) {
1032
+ const files$1 = ref(files.map((file) => mapFile(file)));
1033
+ const tree$1 = ref(tree);
1034
+ const stories = computed(() => files$1.value.reduce((acc, file) => {
1035
+ acc.push(file.story);
1036
+ return acc;
1037
+ }, []));
1038
+ const storyStore = useStoryStore();
1039
+ watch(stories, (value) => {
1040
+ storyStore.setStories(value);
1041
+ }, {
1042
+ immediate: true
1043
+ });
1044
+ useTitle(computed(() => {
1045
+ if (storyStore.currentStory) {
1046
+ let title = storyStore.currentStory.title;
1047
+ if (storyStore.currentVariant) {
1048
+ title += ` \u203A ${storyStore.currentVariant.title}`;
1049
+ }
1050
+ return `${title} | ${histoireConfig.theme.title}`;
1051
+ }
1052
+ return histoireConfig.theme.title;
1053
+ }));
1054
+ const loadSearch = ref(false);
1055
+ const isSearchOpen = ref(false);
1056
+ watch(isSearchOpen, (value) => {
1057
+ if (value) {
1058
+ loadSearch.value = true;
1059
+ }
1060
+ });
1061
+ onKeyboardShortcut(["ctrl+k", "meta+k"], (event) => {
1062
+ isSearchOpen.value = true;
1063
+ event.preventDefault();
1064
+ });
1065
+ const loading = ref(false);
1066
+ const mounted = ref(false);
1067
+ onMounted(() => {
1068
+ mounted.value = true;
1069
+ });
1070
+ return (_ctx, _cache) => {
1071
+ const _component_RouterView = resolveComponent("RouterView");
1072
+ return openBlock(), createElementBlock(Fragment, null, [
1073
+ unref(storyStore).currentStory ? (openBlock(), createElementBlock("div", _hoisted_1, [
1074
+ (openBlock(), createBlock(resolveDynamicComponent(unref(storyStore).currentStory.file.component), {
1075
+ story: unref(storyStore).currentStory
1076
+ }, null, 8, ["story"]))
1077
+ ])) : createCommentVNode("", true),
1078
+ createBaseVNode("div", {
1079
+ class: "htw-h-screen htw-bg-white dark:htw-bg-gray-700 dark:htw-text-gray-100",
1080
+ style: normalizeStyle({
1081
+ opacity: mounted.value && !loading.value ? 1 : 0
1082
+ })
1083
+ }, [
1084
+ unref(isMobile) ? (openBlock(), createElementBlock("div", _hoisted_2, [
1085
+ createVNode(_sfc_main$5, {
1086
+ onSearch: _cache[0] || (_cache[0] = ($event) => isSearchOpen.value = true)
1087
+ }),
1088
+ createVNode(Breadcrumb, {
1089
+ tree: tree$1.value,
1090
+ stories: unref(stories)
1091
+ }, null, 8, ["tree", "stories"]),
1092
+ createVNode(_component_RouterView, { class: "htw-grow" })
1093
+ ])) : (openBlock(), createBlock(BaseSplitPane, {
1094
+ key: 1,
1095
+ "save-id": "main-horiz",
1096
+ min: 5,
1097
+ max: 50,
1098
+ "default-split": 15,
1099
+ class: "htw-h-full"
1100
+ }, {
1101
+ first: withCtx(() => [
1102
+ createBaseVNode("div", _hoisted_3, [
1103
+ createVNode(_sfc_main$5, {
1104
+ class: "htw-flex-none",
1105
+ onSearch: _cache[1] || (_cache[1] = ($event) => isSearchOpen.value = true)
1106
+ }),
1107
+ createVNode(_sfc_main$7, {
1108
+ tree: tree$1.value,
1109
+ stories: unref(stories),
1110
+ class: "htw-flex-1"
1111
+ }, null, 8, ["tree", "stories"])
1112
+ ])
1113
+ ]),
1114
+ last: withCtx(() => [
1115
+ createVNode(_component_RouterView)
1116
+ ]),
1117
+ _: 1
1118
+ })),
1119
+ loadSearch.value ? (openBlock(), createBlock(_sfc_main$2, {
1120
+ key: 2,
1121
+ shown: isSearchOpen.value,
1122
+ onClose: _cache[2] || (_cache[2] = ($event) => isSearchOpen.value = false)
1123
+ }, null, 8, ["shown"])) : createCommentVNode("", true)
1124
+ ], 4),
1125
+ createVNode(Transition, { name: "__histoire-fade" }, {
1126
+ default: withCtx(() => [
1127
+ loading.value ? (openBlock(), createBlock(_sfc_main$1, { key: 0 })) : createCommentVNode("", true)
1128
+ ]),
1129
+ _: 1
1130
+ })
1131
+ ], 64);
1132
+ };
1133
+ }
1134
+ }));
1135
+ function mountMainApp() {
1136
+ const app = createApp(_sfc_main);
1137
+ app.use(createPinia());
1138
+ app.use(plugin, {
1139
+ overflowPadding: 4,
1140
+ arrowPadding: 8,
1141
+ themes: {
1142
+ tooltip: {
1143
+ distance: 8
1144
+ },
1145
+ dropdown: {
1146
+ computeTransformOrigin: true,
1147
+ distance: 8
1148
+ }
1149
+ }
1150
+ });
1151
+ app.use(router);
1152
+ registerGlobalComponents(app);
1153
+ app.mount("#app");
1154
+ }
1155
+ mountMainApp();
1156
+ export { BaseListItemLink as B, _export_sfc as _, useScrollOnActive as a, BaseSplitPane as b, _sfc_main$b as c, base as d, isMobile as i, onKeyboardShortcut as o, useStoryStore as u };