@hkdigital/lib-core 0.3.11 → 0.3.12

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 (292) hide show
  1. package/README.md +173 -149
  2. package/dist/assets/autospuiten/car-paint-picker.js +41 -41
  3. package/dist/assets/autospuiten/labels.js +7 -7
  4. package/dist/classes/data/IterableTree.js +242 -242
  5. package/dist/classes/data/Selector.js +190 -190
  6. package/dist/classes/data/index.js +2 -2
  7. package/dist/classes/data/typedef.js +9 -9
  8. package/dist/classes/event-emitter/EventEmitter.js +273 -273
  9. package/dist/classes/event-emitter/index.js +2 -2
  10. package/dist/classes/index.js +4 -4
  11. package/dist/classes/promise/HkPromise.js +384 -384
  12. package/dist/classes/promise/index.js +1 -1
  13. package/dist/classes/stores/SubscribersCount.js +107 -107
  14. package/dist/classes/stores/index.js +1 -1
  15. package/dist/classes/streams/LogTransformStream.js +19 -19
  16. package/dist/classes/streams/ServerEventsStore.js +111 -111
  17. package/dist/classes/streams/TimeStampSource.js +26 -26
  18. package/dist/classes/streams/index.js +3 -3
  19. package/dist/classes/svelte/finite-state-machine/FiniteStateMachine.svelte.js +133 -133
  20. package/dist/classes/svelte/finite-state-machine/index.js +1 -1
  21. package/dist/classes/svelte/index.js +1 -11
  22. package/dist/classes/svelte/loading-state-machine/LoadingStateMachine.svelte.js +109 -109
  23. package/dist/classes/svelte/loading-state-machine/constants.js +16 -16
  24. package/dist/classes/svelte/loading-state-machine/index.js +3 -3
  25. package/dist/config/README.md +197 -196
  26. package/dist/config/generators/imagetools.js +189 -189
  27. package/dist/config/generators/vite.js +148 -142
  28. package/dist/config/imagetools.d.ts +72 -72
  29. package/dist/config/vite.js +4 -4
  30. package/dist/constants/bases/index.js +13 -13
  31. package/dist/constants/http/headers.js +6 -6
  32. package/dist/constants/http/index.js +2 -2
  33. package/dist/constants/http/methods.js +14 -14
  34. package/dist/constants/index.js +6 -6
  35. package/dist/constants/mime/application.js +5 -5
  36. package/dist/constants/mime/audio.js +13 -13
  37. package/dist/constants/mime/image.js +3 -3
  38. package/dist/constants/mime/index.js +4 -4
  39. package/dist/constants/mime/text.js +2 -2
  40. package/dist/constants/regexp/README.md +96 -95
  41. package/dist/constants/regexp/index.js +31 -31
  42. package/dist/constants/regexp/inspiratie.js__ +95 -95
  43. package/dist/constants/regexp/text.d.ts +4 -4
  44. package/dist/constants/regexp/text.js +49 -49
  45. package/dist/constants/regexp/url.js +3 -3
  46. package/dist/constants/regexp/user.js +29 -29
  47. package/dist/constants/states/drag.js +6 -6
  48. package/dist/constants/states/drop.js +6 -6
  49. package/dist/constants/states/index.js +4 -4
  50. package/dist/constants/states/input.js +11 -11
  51. package/dist/constants/states/submit.js +4 -4
  52. package/dist/constants/time/index.js +28 -28
  53. package/dist/css/utilities.css +43 -43
  54. package/dist/design/README.md +405 -405
  55. package/dist/design/config/design-config.js +73 -73
  56. package/dist/design/generators/index.js +288 -288
  57. package/dist/design/index.js +96 -96
  58. package/dist/design/plugins/skeleton.js +208 -208
  59. package/dist/design/tailwind-theme-extend.js +158 -158
  60. package/dist/design/themes/README.md +102 -102
  61. package/dist/design/themes/hkdev/components/blocks/text-block.css +34 -34
  62. package/dist/design/themes/hkdev/components/boxes/game-box.css +11 -11
  63. package/dist/design/themes/hkdev/components/buttons/button-icon-steeze.css +22 -22
  64. package/dist/design/themes/hkdev/components/buttons/button-text.css +32 -32
  65. package/dist/design/themes/hkdev/components/buttons/button.css +146 -146
  66. package/dist/design/themes/hkdev/components/buttons/skip-button.css +5 -5
  67. package/dist/design/themes/hkdev/components/drag-drop/draggable.css +73 -73
  68. package/dist/design/themes/hkdev/components/drag-drop/drop-zone.css +58 -58
  69. package/dist/design/themes/hkdev/components/icons/icon-steeze.css +15 -15
  70. package/dist/design/themes/hkdev/components/inputs/text-input.css +102 -102
  71. package/dist/design/themes/hkdev/components/panels/panel.css +25 -25
  72. package/dist/design/themes/hkdev/components/rows/panel-grid-row.css +4 -4
  73. package/dist/design/themes/hkdev/components/rows/panel-row-2.css +5 -5
  74. package/dist/design/themes/hkdev/components.css +29 -29
  75. package/dist/design/themes/hkdev/debug.css +1 -1
  76. package/dist/design/themes/hkdev/global/layout.css +32 -32
  77. package/dist/design/themes/hkdev/global/on-colors.css +32 -32
  78. package/dist/design/themes/hkdev/globals.css +3 -3
  79. package/dist/design/themes/hkdev/responsive.css +12 -12
  80. package/dist/design/themes/hkdev/theme-ext.js +12 -12
  81. package/dist/design/themes/hkdev/theme.css +218 -218
  82. package/dist/design/utils/clamp.js +66 -66
  83. package/dist/design/utils/root-vars.js +102 -102
  84. package/dist/design/utils/scaling.js +228 -228
  85. package/dist/design/utils/states.js +22 -22
  86. package/dist/errors/api.js +9 -9
  87. package/dist/errors/generic.js +20 -20
  88. package/dist/errors/http.js +16 -16
  89. package/dist/errors/index.js +5 -5
  90. package/dist/errors/jwt.js +5 -5
  91. package/dist/errors/promise.js +25 -25
  92. package/dist/logging/README.md +158 -0
  93. package/dist/logging/index.d.ts +3 -1
  94. package/dist/logging/index.js +11 -7
  95. package/dist/logging/internal/adapters/console.js +114 -114
  96. package/dist/logging/internal/adapters/index.js +2 -2
  97. package/dist/logging/internal/adapters/pino.js +160 -142
  98. package/dist/logging/internal/adapters/typedef.js +10 -10
  99. package/dist/logging/internal/{unified-logger/constants.js → constants.js} +22 -22
  100. package/dist/logging/internal/factories/client.d.ts +1 -1
  101. package/dist/logging/internal/factories/client.js +21 -21
  102. package/dist/logging/internal/factories/server.d.ts +1 -1
  103. package/dist/logging/internal/factories/server.js +22 -22
  104. package/dist/logging/internal/factories/universal.d.ts +2 -2
  105. package/dist/logging/internal/factories/universal.js +22 -22
  106. package/dist/logging/internal/{unified-logger → logger}/Logger.d.ts +2 -2
  107. package/dist/logging/internal/{unified-logger → logger}/Logger.js +217 -217
  108. package/dist/logging/internal/logger/index.d.ts +1 -0
  109. package/dist/logging/internal/logger/index.js +1 -0
  110. package/dist/logging/internal/{unified-logger/typedef.d.ts → typedef.d.ts} +2 -1
  111. package/dist/logging/internal/{unified-logger/typedef.js → typedef.js} +21 -17
  112. package/dist/network/README.md +172 -172
  113. package/dist/network/cache/IndexedDbCache.js +1407 -1407
  114. package/dist/network/cache/MemoryResponseCache.js +138 -138
  115. package/dist/network/cache/index.js +5 -5
  116. package/dist/network/cache/typedef.js +41 -41
  117. package/dist/network/cache.js +3 -3
  118. package/dist/network/http/caching.js +261 -261
  119. package/dist/network/http/errors.js +97 -97
  120. package/dist/network/http/headers.js +75 -75
  121. package/dist/network/http/http-request.js +578 -578
  122. package/dist/network/http/index.js +22 -22
  123. package/dist/network/http/json-request.js +224 -224
  124. package/dist/network/http/mocks.js +65 -65
  125. package/dist/network/http/response.js +318 -318
  126. package/dist/network/http/test-data__/content-length-test-hkdigital-small.V4HfZyBQ.avif +0 -0
  127. package/dist/network/http/typedef.js +93 -93
  128. package/dist/network/http/url.js +52 -52
  129. package/dist/network/http.js +5 -5
  130. package/dist/network/loaders/README.md +254 -254
  131. package/dist/network/loaders/audio/AudioLoader.svelte.js +58 -58
  132. package/dist/network/loaders/audio/AudioScene.svelte.js +324 -324
  133. package/dist/network/loaders/audio/mocks.js +35 -35
  134. package/dist/network/loaders/audio.js +1 -1
  135. package/dist/network/loaders/image/ImageLoader.svelte.js +44 -44
  136. package/dist/network/loaders/image/ImageScene.svelte.js +248 -248
  137. package/dist/network/loaders/image/ImageVariantsLoader.svelte.js +150 -150
  138. package/dist/network/loaders/image/index.js +4 -4
  139. package/dist/network/loaders/image/mocks.js +35 -35
  140. package/dist/network/loaders/image/typedef.js +8 -8
  141. package/dist/network/loaders/image/utils/index.js +86 -86
  142. package/dist/network/loaders/image.js +7 -7
  143. package/dist/network/loaders/typedef.js +38 -38
  144. package/dist/network/loaders.js +2 -2
  145. package/dist/network/states/NetworkLoader.svelte.js +338 -338
  146. package/dist/network/states/constants.js +3 -3
  147. package/dist/network/states/index.js +3 -3
  148. package/dist/network/states/mocks.js +30 -30
  149. package/dist/network/states/typedef.js +8 -8
  150. package/dist/network/typedef.js +9 -9
  151. package/dist/services/README.md +200 -0
  152. package/dist/services/index.d.ts +6 -1
  153. package/dist/services/index.js +8 -1
  154. package/dist/services/{internal/service-base → service-base}/ServiceBase.d.ts +2 -2
  155. package/dist/services/{internal/service-base → service-base}/ServiceBase.js +462 -462
  156. package/dist/services/{internal/service-base → service-base}/constants.d.ts +0 -12
  157. package/dist/services/{internal/service-base → service-base}/constants.js +98 -110
  158. package/dist/services/{internal/service-base → service-base}/index.js +3 -3
  159. package/dist/services/{internal/service-base → service-base}/typedef.d.ts +1 -1
  160. package/dist/services/{internal/service-base → service-base}/typedef.js +101 -101
  161. package/dist/services/{internal/service-manager → service-manager}/ServiceManager.d.ts +2 -2
  162. package/dist/services/{internal/service-manager → service-manager}/ServiceManager.js +608 -608
  163. package/dist/services/{internal/service-manager → service-manager}/constants.js +6 -6
  164. package/dist/services/{internal/service-manager → service-manager}/typedef.js +90 -90
  165. package/dist/states/index.js +1 -1
  166. package/dist/states/navigation.svelte.js +55 -55
  167. package/dist/stores/index.js +1 -1
  168. package/dist/stores/theme.js +80 -80
  169. package/dist/typedef/context.js +6 -6
  170. package/dist/typedef/drag.js +25 -25
  171. package/dist/typedef/drop.js +12 -12
  172. package/dist/typedef/index.js +4 -4
  173. package/dist/ui/components/button-group/ButtonGroup.svelte +82 -82
  174. package/dist/ui/components/button-group/typedef.js +10 -10
  175. package/dist/ui/components/compare-left-right/CompareLeftRight.svelte +179 -179
  176. package/dist/ui/components/compare-left-right/index.js +1 -1
  177. package/dist/ui/components/game-box/GameBox.svelte +577 -577
  178. package/dist/ui/components/game-box/gamebox.util.js +83 -83
  179. package/dist/ui/components/hk-app-layout/HkAppLayout.state.svelte.js +25 -25
  180. package/dist/ui/components/hk-app-layout/HkAppLayout.svelte +251 -251
  181. package/dist/ui/components/image-box/ImageBox.svelte +210 -210
  182. package/dist/ui/components/image-box/index.js +5 -5
  183. package/dist/ui/components/image-box/typedef.js +32 -32
  184. package/dist/ui/components/index.js +23 -23
  185. package/dist/ui/components/presenter/ImageSlide.svelte +64 -64
  186. package/dist/ui/components/presenter/Presenter.state.svelte.js +638 -638
  187. package/dist/ui/components/presenter/Presenter.svelte +142 -142
  188. package/dist/ui/components/presenter/constants.js +7 -7
  189. package/dist/ui/components/presenter/index.js +10 -10
  190. package/dist/ui/components/presenter/typedef.js +106 -106
  191. package/dist/ui/components/presenter/util.js +210 -210
  192. package/dist/ui/components/virtual-viewport/VirtualViewport.svelte +196 -196
  193. package/dist/ui/primitives/area/HkArea.svelte +49 -49
  194. package/dist/ui/primitives/area/HkGridArea.svelte +77 -77
  195. package/dist/ui/primitives/area/index.js +2 -2
  196. package/dist/ui/primitives/buttons/button/Button.svelte +82 -82
  197. package/dist/ui/primitives/buttons/button-icon-steeze/SteezeIconButton.svelte +30 -30
  198. package/dist/ui/primitives/buttons/button-text/TextButton.svelte +21 -21
  199. package/dist/ui/primitives/buttons/index.js +3 -3
  200. package/dist/ui/primitives/debug/debug-panel-design-scaling/DebugPanelDesignScaling.svelte +146 -146
  201. package/dist/ui/primitives/debug/index.js +1 -1
  202. package/dist/ui/primitives/drag-drop/DragController.js +44 -44
  203. package/dist/ui/primitives/drag-drop/DragDropContext.svelte +111 -111
  204. package/dist/ui/primitives/drag-drop/Draggable.svelte +519 -519
  205. package/dist/ui/primitives/drag-drop/DropZone.svelte +258 -258
  206. package/dist/ui/primitives/drag-drop/DropZoneArea.svelte +119 -119
  207. package/dist/ui/primitives/drag-drop/DropZoneList.svelte +125 -125
  208. package/dist/ui/primitives/drag-drop/actions.js +26 -26
  209. package/dist/ui/primitives/drag-drop/drag-state.svelte.js +322 -322
  210. package/dist/ui/primitives/drag-drop/index.js +7 -7
  211. package/dist/ui/primitives/drag-drop/util.js +85 -85
  212. package/dist/ui/primitives/hkdev/blocks/TextBlock.svelte +46 -46
  213. package/dist/ui/primitives/hkdev/buttons/CheckButton.svelte +62 -62
  214. package/dist/ui/primitives/icons/HkIcon.svelte +86 -86
  215. package/dist/ui/primitives/icons/HkTabIcon.svelte +116 -116
  216. package/dist/ui/primitives/icons/SteezeIcon.svelte +97 -97
  217. package/dist/ui/primitives/icons/index.js +6 -6
  218. package/dist/ui/primitives/icons/typedef.js +16 -16
  219. package/dist/ui/primitives/index.js +2 -2
  220. package/dist/ui/primitives/inputs/index.js +1 -1
  221. package/dist/ui/primitives/inputs/text-input/TestTextInput.svelte__ +102 -0
  222. package/dist/ui/primitives/inputs/text-input/TextInput.svelte +223 -223
  223. package/dist/ui/primitives/inputs/text-input/TextInput.svelte___ +83 -0
  224. package/dist/ui/primitives/inputs/text-input/assets/IconInvalid.svelte +14 -14
  225. package/dist/ui/primitives/inputs/text-input/assets/IconValid.svelte +12 -12
  226. package/dist/ui/primitives/layout/grid-layers/GridLayers.svelte +63 -63
  227. package/dist/ui/primitives/layout/grid-layers/GridLayers.svelte__heightFrom__ +372 -0
  228. package/dist/ui/primitives/layout/grid-layers/util.js +74 -74
  229. package/dist/ui/primitives/layout/index.js +1 -1
  230. package/dist/ui/primitives/panels/index.js +1 -1
  231. package/dist/ui/primitives/panels/panel/Panel.svelte +43 -43
  232. package/dist/ui/primitives/rows/index.js +3 -3
  233. package/dist/ui/primitives/rows/panel-grid-row/PanelGridRow.svelte +104 -104
  234. package/dist/ui/primitives/rows/panel-row-2/PanelRow2.svelte +40 -40
  235. package/dist/ui/primitives/tab-bar/HkTabBar.state.svelte.js +149 -149
  236. package/dist/ui/primitives/tab-bar/HkTabBar.svelte +74 -74
  237. package/dist/ui/primitives/tab-bar/HkTabBarSelector.state.svelte.js +93 -93
  238. package/dist/ui/primitives/tab-bar/HkTabBarSelector.svelte +49 -49
  239. package/dist/ui/primitives/tab-bar/index.js +17 -17
  240. package/dist/ui/primitives/tab-bar/typedef.js +11 -11
  241. package/dist/util/array/index.js +436 -436
  242. package/dist/util/bases/base58.js +262 -262
  243. package/dist/util/bases/index.js +1 -1
  244. package/dist/util/compare/index.js +247 -247
  245. package/dist/util/css/css-vars.js +83 -83
  246. package/dist/util/css/index.js +1 -1
  247. package/dist/util/env/index.js +9 -9
  248. package/dist/util/exceptions/index.d.ts +4 -3
  249. package/dist/util/exceptions/index.js +26 -23
  250. package/dist/util/expect/arrays.js +47 -47
  251. package/dist/util/expect/index.js +259 -259
  252. package/dist/util/expect/primitives.js +55 -55
  253. package/dist/util/expect/url.js +60 -60
  254. package/dist/util/function/index.js +218 -218
  255. package/dist/util/geo/index.js +26 -26
  256. package/dist/util/index.js +7 -7
  257. package/dist/util/is/index.js +147 -147
  258. package/dist/util/iterate/index.js +204 -204
  259. package/dist/util/object/index.js +1345 -1345
  260. package/dist/util/singleton/index.js +97 -97
  261. package/dist/util/string/array-path.js +75 -75
  262. package/dist/util/string/convert.js +54 -54
  263. package/dist/util/string/fs.js +226 -226
  264. package/dist/util/string/index.js +5 -5
  265. package/dist/util/string/interpolate.js +61 -61
  266. package/dist/util/string/pad.js +10 -10
  267. package/dist/util/svelte/index.js +4 -4
  268. package/dist/util/svelte/loading/loading-tracker.svelte.js +108 -108
  269. package/dist/util/svelte/observe/index.js +49 -49
  270. package/dist/util/svelte/state-context/index.js +117 -117
  271. package/dist/util/svelte/wait/index.js +38 -38
  272. package/dist/util/sveltekit/index.js +1 -1
  273. package/dist/util/sveltekit/route-folders/index.js +101 -101
  274. package/dist/util/time/index.js +328 -328
  275. package/dist/util/unique/index.js +231 -231
  276. package/dist/valibot/README.md +61 -50
  277. package/dist/valibot/index.js +8 -8
  278. package/dist/valibot/parsers/date.js__ +10 -0
  279. package/dist/valibot/parsers/email.d.ts +12 -0
  280. package/dist/valibot/parsers/email.js +34 -0
  281. package/dist/valibot/parsers/url.js +110 -110
  282. package/dist/valibot/parsers/user.js +23 -23
  283. package/dist/valibot/parsers.js +3 -3
  284. package/package.json +131 -131
  285. package/dist/logging/internal/unified-logger/index.d.ts +0 -3
  286. package/dist/logging/internal/unified-logger/index.js +0 -6
  287. package/dist/services/internal/index.d.ts +0 -6
  288. package/dist/services/internal/index.js +0 -8
  289. /package/dist/logging/internal/{unified-logger/constants.d.ts → constants.d.ts} +0 -0
  290. /package/dist/services/{internal/service-base → service-base}/index.d.ts +0 -0
  291. /package/dist/services/{internal/service-manager → service-manager}/constants.d.ts +0 -0
  292. /package/dist/services/{internal/service-manager → service-manager}/typedef.d.ts +0 -0
@@ -1,82 +1,82 @@
1
- <script>
2
- import { toStateClasses } from '../../../../design/index.js';
3
-
4
- /**
5
- * @type {{
6
- * base?: string,
7
- * bg?: string,
8
- * classes?: string,
9
- * type?: string,
10
- * role?: 'primary' | 'secondary' | 'tertiary' | 'custom',
11
- * size?: 'sm' | 'md' | 'lg',
12
- * variant?: string,
13
- * mode?: 'light'|'dark'
14
- * buttonType?: 'button' | 'submit' | 'reset',
15
- * active?: boolean,
16
- * selected?: boolean,
17
- * loading?: boolean,
18
- * error?: boolean,
19
- * disabled?: boolean,
20
- * snippetLoading?: import('svelte').Snippet,
21
- * snippetError?: import('svelte').Snippet,
22
- * children: import('svelte').Snippet,
23
- * [key: string]: any
24
- * }}
25
- */
26
- const {
27
- // Style
28
- base,
29
- bg,
30
- classes,
31
-
32
- type = '',
33
- role = 'primary',
34
- size = 'md',
35
- variant = '',
36
- mode = 'light',
37
-
38
- buttonType = 'button',
39
-
40
- // States
41
- active = $bindable(false),
42
- selected = $bindable(false),
43
- loading = $bindable(false),
44
- error = $bindable(false),
45
- disabled = $bindable(false),
46
-
47
- // Snippets
48
- snippetLoading,
49
- snippetError,
50
- children,
51
-
52
- // Attributes
53
- ...attrs
54
- } = $props();
55
-
56
- let stateClasses = $derived.by(() => {
57
- return toStateClasses({ active, selected, loading, error, disabled });
58
- });
59
- </script>
60
-
61
- <button
62
- data-component="button"
63
- data-type={type}
64
- data-role={role}
65
- data-size={size}
66
- data-variant={variant}
67
- data-mode={mode}
68
- type={buttonType}
69
- class="{base} {bg} {classes} {stateClasses}"
70
- disabled={disabled || loading}
71
- aria-busy={loading}
72
- aria-pressed={selected}
73
- {...attrs}
74
- >
75
- {#if loading && snippetLoading}
76
- {@render snippetLoading()}
77
- {:else if error && snippetError}
78
- {@render snippetError()}
79
- {:else}
80
- {@render children()}
81
- {/if}
82
- </button>
1
+ <script>
2
+ import { toStateClasses } from '../../../../design/index.js';
3
+
4
+ /**
5
+ * @type {{
6
+ * base?: string,
7
+ * bg?: string,
8
+ * classes?: string,
9
+ * type?: string,
10
+ * role?: 'primary' | 'secondary' | 'tertiary' | 'custom',
11
+ * size?: 'sm' | 'md' | 'lg',
12
+ * variant?: string,
13
+ * mode?: 'light'|'dark'
14
+ * buttonType?: 'button' | 'submit' | 'reset',
15
+ * active?: boolean,
16
+ * selected?: boolean,
17
+ * loading?: boolean,
18
+ * error?: boolean,
19
+ * disabled?: boolean,
20
+ * snippetLoading?: import('svelte').Snippet,
21
+ * snippetError?: import('svelte').Snippet,
22
+ * children: import('svelte').Snippet,
23
+ * [key: string]: any
24
+ * }}
25
+ */
26
+ const {
27
+ // Style
28
+ base,
29
+ bg,
30
+ classes,
31
+
32
+ type = '',
33
+ role = 'primary',
34
+ size = 'md',
35
+ variant = '',
36
+ mode = 'light',
37
+
38
+ buttonType = 'button',
39
+
40
+ // States
41
+ active = $bindable(false),
42
+ selected = $bindable(false),
43
+ loading = $bindable(false),
44
+ error = $bindable(false),
45
+ disabled = $bindable(false),
46
+
47
+ // Snippets
48
+ snippetLoading,
49
+ snippetError,
50
+ children,
51
+
52
+ // Attributes
53
+ ...attrs
54
+ } = $props();
55
+
56
+ let stateClasses = $derived.by(() => {
57
+ return toStateClasses({ active, selected, loading, error, disabled });
58
+ });
59
+ </script>
60
+
61
+ <button
62
+ data-component="button"
63
+ data-type={type}
64
+ data-role={role}
65
+ data-size={size}
66
+ data-variant={variant}
67
+ data-mode={mode}
68
+ type={buttonType}
69
+ class="{base} {bg} {classes} {stateClasses}"
70
+ disabled={disabled || loading}
71
+ aria-busy={loading}
72
+ aria-pressed={selected}
73
+ {...attrs}
74
+ >
75
+ {#if loading && snippetLoading}
76
+ {@render snippetLoading()}
77
+ {:else if error && snippetError}
78
+ {@render snippetError()}
79
+ {:else}
80
+ {@render children()}
81
+ {/if}
82
+ </button>
@@ -1,30 +1,30 @@
1
- <script>
2
- import Button from '../button/Button.svelte';
3
-
4
- import { SteezeIcon } from '../../icons/index.js';
5
-
6
- /**
7
- * @type {{
8
- * src: import('../../icons/typedef.js').IconSource,
9
- * iconSize?: string,
10
- * theme?: string,
11
- * [key: string]: any
12
- * }}
13
- */
14
- const {
15
- // Icon
16
- src,
17
- iconSize,
18
- theme,
19
-
20
- // Snippets
21
- children,
22
-
23
- // Attributes
24
- ...attrs
25
- } = $props();
26
- </script>
27
-
28
- <Button type="icon-steeze" {...attrs}>
29
- <SteezeIcon {src} size={iconSize} {theme} />
30
- </Button>
1
+ <script>
2
+ import Button from '../button/Button.svelte';
3
+
4
+ import { SteezeIcon } from '../../icons/index.js';
5
+
6
+ /**
7
+ * @type {{
8
+ * src: import('../../icons/typedef.js').IconSource,
9
+ * iconSize?: string,
10
+ * theme?: string,
11
+ * [key: string]: any
12
+ * }}
13
+ */
14
+ const {
15
+ // Icon
16
+ src,
17
+ iconSize,
18
+ theme,
19
+
20
+ // Snippets
21
+ children,
22
+
23
+ // Attributes
24
+ ...attrs
25
+ } = $props();
26
+ </script>
27
+
28
+ <Button type="icon-steeze" {...attrs}>
29
+ <SteezeIcon {src} size={iconSize} {theme} />
30
+ </Button>
@@ -1,21 +1,21 @@
1
- <script>
2
- import Button from '../button/Button.svelte';
3
-
4
- /**
5
- * @type {{
6
- * children: import('svelte').Snippet,
7
- * [key: string]: any
8
- * }}
9
- */
10
- const {
11
- // Snippets
12
- children,
13
-
14
- // Attributes
15
- ...attrs
16
- } = $props();
17
- </script>
18
-
19
- <Button type="text" {...attrs}>
20
- {@render children()}
21
- </Button>
1
+ <script>
2
+ import Button from '../button/Button.svelte';
3
+
4
+ /**
5
+ * @type {{
6
+ * children: import('svelte').Snippet,
7
+ * [key: string]: any
8
+ * }}
9
+ */
10
+ const {
11
+ // Snippets
12
+ children,
13
+
14
+ // Attributes
15
+ ...attrs
16
+ } = $props();
17
+ </script>
18
+
19
+ <Button type="text" {...attrs}>
20
+ {@render children()}
21
+ </Button>
@@ -1,3 +1,3 @@
1
- export { default as Button } from './button/Button.svelte';
2
- export { default as TextButton } from './button-text/TextButton.svelte';
3
- export { default as SteezeIconButton } from './button-icon-steeze/SteezeIconButton.svelte';
1
+ export { default as Button } from './button/Button.svelte';
2
+ export { default as TextButton } from './button-text/TextButton.svelte';
3
+ export { default as SteezeIconButton } from './button-icon-steeze/SteezeIconButton.svelte';
@@ -1,146 +1,146 @@
1
- <script>
2
- import { onMount } from 'svelte';
3
- import { DESIGN, CLAMPING } from '../../../../design/config/design-config.js';
4
- import {
5
- enableScalingUI,
6
- getAllRootScalingVars
7
- } from '../../../../design/index.js';
8
-
9
- /**
10
- * Holds the current scaling values for the debug panel
11
- * @type {Object}
12
- */
13
- let scalingValues = $state({
14
- scaleW: 0,
15
- scaleH: 0,
16
- scaleViewport: 0,
17
- scaleUI: 0,
18
- scaleTextBase: 0,
19
- scaleTextHeading: 0,
20
- scaleTextUI: 0
21
- });
22
-
23
- /**
24
- * Controls visibility of the debug panel
25
- */
26
- let showDebugPanel = $state(false);
27
-
28
- /**
29
- * Updates scaling values for the debug panel
30
- */
31
- function updateDebugValues() {
32
- // Get scaling values
33
- scalingValues = getAllRootScalingVars();
34
-
35
- // Update window size display if in browser context
36
- if (typeof window !== 'undefined') {
37
- const windowSizeElement = document.getElementById('window-size');
38
- if (windowSizeElement) {
39
- windowSizeElement.textContent = `${window.innerWidth}×${window.innerHeight}px`;
40
- }
41
- }
42
- }
43
-
44
- onMount(() => {
45
- // Initialize the design scaling system
46
- //const cleanup = () => {};
47
- const cleanup = enableScalingUI(DESIGN, CLAMPING);
48
-
49
- // Update debug values initially
50
- updateDebugValues();
51
-
52
- // Set up event listener for updating debug values on resize
53
- window.addEventListener('resize', updateDebugValues);
54
-
55
- // Return combined cleanup function
56
- return () => {
57
- cleanup();
58
- window.removeEventListener('resize', updateDebugValues);
59
- };
60
- });
61
-
62
- /**
63
- * Toggle debug panel visibility
64
- */
65
- function toggleDebugPanel() {
66
- showDebugPanel = !showDebugPanel;
67
- }
68
-
69
- /**
70
- * Format a number to 2 decimal places
71
- * @param {number} value - The number to format
72
- * @returns {string} Formatted number
73
- */
74
- function formatNumber(value) {
75
- return value.toFixed(2);
76
- }
77
- </script>
78
-
79
- <!-- Debug Panel -->
80
- {#if showDebugPanel}
81
- <div
82
- class="fixed bottom-0 right-0 bg-black bg-opacity-75 text-white p-2 text-ui-md z-50 font-mono"
83
- >
84
- <div class="flex justify-between items-center mb-1">
85
- <h3 class="font-bold">Design System Scaling</h3>
86
- <button
87
- onclick={toggleDebugPanel}
88
- class="ml-2 px-1.5 bg-gray-700 hover:bg-gray-600 rounded"
89
- >
90
- &times;
91
- </button>
92
- </div>
93
- <div class="grid grid-cols-2 gap-x-2 gap-y-0.5">
94
- <div class="text-gray-400">Design Width:</div>
95
- <div>{DESIGN.width}px</div>
96
-
97
- <div class="text-gray-400">Design Height:</div>
98
- <div>{DESIGN.height}px</div>
99
-
100
- <div class="text-gray-400">Window:</div>
101
- <div id="window-size">...</div>
102
-
103
- <div class="text-gray-400">Scale W:</div>
104
- <div>{formatNumber(scalingValues.scaleW)}</div>
105
-
106
- <div class="text-gray-400">Scale H:</div>
107
- <div>{formatNumber(scalingValues.scaleH)}</div>
108
-
109
- <div class="text-gray-400">Viewport:</div>
110
- <div>{formatNumber(scalingValues.scaleViewport)}</div>
111
-
112
- <div class="text-gray-400">UI:</div>
113
- <div>{formatNumber(scalingValues.scaleUI)}</div>
114
-
115
- <div class="text-gray-400">Text Content:</div>
116
- <div>{formatNumber(scalingValues.scaleTextBase)}</div>
117
-
118
- <div class="text-gray-400">Text Heading:</div>
119
- <div>{formatNumber(scalingValues.scaleTextHeading)}</div>
120
-
121
- <div class="text-gray-400">Text UI:</div>
122
- <div>{formatNumber(scalingValues.scaleTextUI)}</div>
123
- </div>
124
-
125
- <div class="mt-1 pt-1 border-t border-gray-600 text-gray-400">
126
- <div>Clamping:</div>
127
- <div class="grid grid-cols-3 text-2xs">
128
- <div>UI: {CLAMPING.ui.min} - {CLAMPING.ui.max}</div>
129
- <div>
130
- Content: {CLAMPING.textBase.min} - {CLAMPING.textBase.max}
131
- </div>
132
- <div>
133
- Heading: {CLAMPING.textHeading.min} - {CLAMPING.textHeading.max}
134
- </div>
135
- </div>
136
- </div>
137
- </div>
138
- {:else}
139
- <!-- Debug Panel Toggle Button -->
140
- <button
141
- onclick={toggleDebugPanel}
142
- class="fixed bottom-0 right-0 bg-black bg-opacity-75 text-white p-16ut py-8ut text-ui-md z-50 font-mono hover:bg-opacity-90"
143
- >
144
- Show Debug
145
- </button>
146
- {/if}
1
+ <script>
2
+ import { onMount } from 'svelte';
3
+ import { DESIGN, CLAMPING } from '../../../../design/config/design-config.js';
4
+ import {
5
+ enableScalingUI,
6
+ getAllRootScalingVars
7
+ } from '../../../../design/index.js';
8
+
9
+ /**
10
+ * Holds the current scaling values for the debug panel
11
+ * @type {Object}
12
+ */
13
+ let scalingValues = $state({
14
+ scaleW: 0,
15
+ scaleH: 0,
16
+ scaleViewport: 0,
17
+ scaleUI: 0,
18
+ scaleTextBase: 0,
19
+ scaleTextHeading: 0,
20
+ scaleTextUI: 0
21
+ });
22
+
23
+ /**
24
+ * Controls visibility of the debug panel
25
+ */
26
+ let showDebugPanel = $state(false);
27
+
28
+ /**
29
+ * Updates scaling values for the debug panel
30
+ */
31
+ function updateDebugValues() {
32
+ // Get scaling values
33
+ scalingValues = getAllRootScalingVars();
34
+
35
+ // Update window size display if in browser context
36
+ if (typeof window !== 'undefined') {
37
+ const windowSizeElement = document.getElementById('window-size');
38
+ if (windowSizeElement) {
39
+ windowSizeElement.textContent = `${window.innerWidth}×${window.innerHeight}px`;
40
+ }
41
+ }
42
+ }
43
+
44
+ onMount(() => {
45
+ // Initialize the design scaling system
46
+ //const cleanup = () => {};
47
+ const cleanup = enableScalingUI(DESIGN, CLAMPING);
48
+
49
+ // Update debug values initially
50
+ updateDebugValues();
51
+
52
+ // Set up event listener for updating debug values on resize
53
+ window.addEventListener('resize', updateDebugValues);
54
+
55
+ // Return combined cleanup function
56
+ return () => {
57
+ cleanup();
58
+ window.removeEventListener('resize', updateDebugValues);
59
+ };
60
+ });
61
+
62
+ /**
63
+ * Toggle debug panel visibility
64
+ */
65
+ function toggleDebugPanel() {
66
+ showDebugPanel = !showDebugPanel;
67
+ }
68
+
69
+ /**
70
+ * Format a number to 2 decimal places
71
+ * @param {number} value - The number to format
72
+ * @returns {string} Formatted number
73
+ */
74
+ function formatNumber(value) {
75
+ return value.toFixed(2);
76
+ }
77
+ </script>
78
+
79
+ <!-- Debug Panel -->
80
+ {#if showDebugPanel}
81
+ <div
82
+ class="fixed bottom-0 right-0 bg-black bg-opacity-75 text-white p-2 text-ui-md z-50 font-mono"
83
+ >
84
+ <div class="flex justify-between items-center mb-1">
85
+ <h3 class="font-bold">Design System Scaling</h3>
86
+ <button
87
+ onclick={toggleDebugPanel}
88
+ class="ml-2 px-1.5 bg-gray-700 hover:bg-gray-600 rounded"
89
+ >
90
+ &times;
91
+ </button>
92
+ </div>
93
+ <div class="grid grid-cols-2 gap-x-2 gap-y-0.5">
94
+ <div class="text-gray-400">Design Width:</div>
95
+ <div>{DESIGN.width}px</div>
96
+
97
+ <div class="text-gray-400">Design Height:</div>
98
+ <div>{DESIGN.height}px</div>
99
+
100
+ <div class="text-gray-400">Window:</div>
101
+ <div id="window-size">...</div>
102
+
103
+ <div class="text-gray-400">Scale W:</div>
104
+ <div>{formatNumber(scalingValues.scaleW)}</div>
105
+
106
+ <div class="text-gray-400">Scale H:</div>
107
+ <div>{formatNumber(scalingValues.scaleH)}</div>
108
+
109
+ <div class="text-gray-400">Viewport:</div>
110
+ <div>{formatNumber(scalingValues.scaleViewport)}</div>
111
+
112
+ <div class="text-gray-400">UI:</div>
113
+ <div>{formatNumber(scalingValues.scaleUI)}</div>
114
+
115
+ <div class="text-gray-400">Text Content:</div>
116
+ <div>{formatNumber(scalingValues.scaleTextBase)}</div>
117
+
118
+ <div class="text-gray-400">Text Heading:</div>
119
+ <div>{formatNumber(scalingValues.scaleTextHeading)}</div>
120
+
121
+ <div class="text-gray-400">Text UI:</div>
122
+ <div>{formatNumber(scalingValues.scaleTextUI)}</div>
123
+ </div>
124
+
125
+ <div class="mt-1 pt-1 border-t border-gray-600 text-gray-400">
126
+ <div>Clamping:</div>
127
+ <div class="grid grid-cols-3 text-2xs">
128
+ <div>UI: {CLAMPING.ui.min} - {CLAMPING.ui.max}</div>
129
+ <div>
130
+ Content: {CLAMPING.textBase.min} - {CLAMPING.textBase.max}
131
+ </div>
132
+ <div>
133
+ Heading: {CLAMPING.textHeading.min} - {CLAMPING.textHeading.max}
134
+ </div>
135
+ </div>
136
+ </div>
137
+ </div>
138
+ {:else}
139
+ <!-- Debug Panel Toggle Button -->
140
+ <button
141
+ onclick={toggleDebugPanel}
142
+ class="fixed bottom-0 right-0 bg-black bg-opacity-75 text-white p-16ut py-8ut text-ui-md z-50 font-mono hover:bg-opacity-90"
143
+ >
144
+ Show Debug
145
+ </button>
146
+ {/if}
@@ -1 +1 @@
1
- export { default as DebugPanelDesignScaling } from './debug-panel-design-scaling/DebugPanelDesignScaling.svelte';
1
+ export { default as DebugPanelDesignScaling } from './debug-panel-design-scaling/DebugPanelDesignScaling.svelte';
@@ -1,44 +1,44 @@
1
- /**
2
- * Controller for customizing drag
3
- * E.g. set a custom preview image
4
- */
5
- export class DragController {
6
- /**
7
- * @param {DragEvent} event - The drag event
8
- */
9
- constructor(event) {
10
- this.event = event;
11
- this.dataTransfer = event.dataTransfer;
12
- this.targetElement = /** @type {HTMLElement} */ (event.currentTarget);
13
-
14
- // Calculate natural offsets by default (to prevent "jumping")
15
- const rect = this.targetElement.getBoundingClientRect();
16
- this.offsetX = event.clientX - rect.left;
17
- this.offsetY = event.clientY - rect.top;
18
- }
19
-
20
- /**
21
- * Apply the default preview (uses the draggable element itself)
22
- * @returns {boolean}
23
- */
24
- applyDefaultPreview() {
25
- if (
26
- !this.dataTransfer ||
27
- !this.dataTransfer.setDragImage
28
- ) {
29
- return false;
30
- }
31
-
32
- try {
33
- this.dataTransfer.setDragImage(
34
- this.targetElement,
35
- this.offsetX,
36
- this.offsetY
37
- );
38
- return true;
39
- } catch (err) {
40
- console.error('Failed to set default drag preview:', err);
41
- return false;
42
- }
43
- }
44
- }
1
+ /**
2
+ * Controller for customizing drag
3
+ * E.g. set a custom preview image
4
+ */
5
+ export class DragController {
6
+ /**
7
+ * @param {DragEvent} event - The drag event
8
+ */
9
+ constructor(event) {
10
+ this.event = event;
11
+ this.dataTransfer = event.dataTransfer;
12
+ this.targetElement = /** @type {HTMLElement} */ (event.currentTarget);
13
+
14
+ // Calculate natural offsets by default (to prevent "jumping")
15
+ const rect = this.targetElement.getBoundingClientRect();
16
+ this.offsetX = event.clientX - rect.left;
17
+ this.offsetY = event.clientY - rect.top;
18
+ }
19
+
20
+ /**
21
+ * Apply the default preview (uses the draggable element itself)
22
+ * @returns {boolean}
23
+ */
24
+ applyDefaultPreview() {
25
+ if (
26
+ !this.dataTransfer ||
27
+ !this.dataTransfer.setDragImage
28
+ ) {
29
+ return false;
30
+ }
31
+
32
+ try {
33
+ this.dataTransfer.setDragImage(
34
+ this.targetElement,
35
+ this.offsetX,
36
+ this.offsetY
37
+ );
38
+ return true;
39
+ } catch (err) {
40
+ console.error('Failed to set default drag preview:', err);
41
+ return false;
42
+ }
43
+ }
44
+ }