@hkdigital/lib-sveltekit 0.2.7 → 0.2.8

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 (242) hide show
  1. package/README.md +135 -135
  2. package/dist/assets/autospuiten/car-paint-picker.js +41 -41
  3. package/dist/assets/autospuiten/labels.js +7 -7
  4. package/dist/classes/cache/IndexedDbCache.js +1407 -1407
  5. package/dist/classes/cache/MemoryResponseCache.js +138 -138
  6. package/dist/classes/cache/index.js +5 -5
  7. package/dist/classes/cache/typedef.js +41 -41
  8. package/dist/classes/data/IterableTree.js +243 -243
  9. package/dist/classes/data/Selector.js +190 -190
  10. package/dist/classes/data/index.js +2 -2
  11. package/dist/classes/events/EventEmitter.js +275 -275
  12. package/dist/classes/events/index.js +2 -2
  13. package/dist/classes/index.js +4 -4
  14. package/dist/classes/logging/Logger.js +158 -158
  15. package/dist/classes/logging/constants.js +18 -18
  16. package/dist/classes/logging/index.js +4 -4
  17. package/dist/classes/promise/HkPromise.js +377 -377
  18. package/dist/classes/promise/index.js +1 -1
  19. package/dist/classes/services/ServiceBase.js +409 -409
  20. package/dist/classes/services/ServiceManager.js +1114 -1114
  21. package/dist/classes/services/constants.js +12 -12
  22. package/dist/classes/services/index.js +5 -5
  23. package/dist/classes/stores/SubscribersCount.js +107 -107
  24. package/dist/classes/stores/index.js +1 -1
  25. package/dist/classes/streams/LogTransformStream.js +19 -19
  26. package/dist/classes/streams/ServerEventsStore.js +110 -110
  27. package/dist/classes/streams/TimeStampSource.js +26 -26
  28. package/dist/classes/streams/index.js +3 -3
  29. package/dist/classes/svelte/audio/AudioLoader.svelte.js +58 -58
  30. package/dist/classes/svelte/audio/AudioScene.svelte.js +324 -324
  31. package/dist/classes/svelte/audio/mocks.js +35 -35
  32. package/dist/classes/svelte/finite-state-machine/FiniteStateMachine.svelte.js +133 -133
  33. package/dist/classes/svelte/finite-state-machine/index.js +1 -1
  34. package/dist/classes/svelte/image/ImageLoader.svelte.js +45 -45
  35. package/dist/classes/svelte/image/ImageScene.svelte.js +249 -249
  36. package/dist/classes/svelte/image/ImageVariantsLoader.svelte.js +152 -152
  37. package/dist/classes/svelte/image/index.js +4 -4
  38. package/dist/classes/svelte/image/mocks.js +35 -35
  39. package/dist/classes/svelte/image/typedef.js +8 -8
  40. package/dist/classes/svelte/index.js +14 -14
  41. package/dist/classes/svelte/loading-state-machine/LoadingStateMachine.svelte.js +109 -109
  42. package/dist/classes/svelte/loading-state-machine/constants.js +16 -16
  43. package/dist/classes/svelte/loading-state-machine/index.js +3 -3
  44. package/dist/classes/svelte/network-loader/NetworkLoader.svelte.js +338 -338
  45. package/dist/classes/svelte/network-loader/constants.js +3 -3
  46. package/dist/classes/svelte/network-loader/index.js +3 -3
  47. package/dist/classes/svelte/network-loader/mocks.js +30 -30
  48. package/dist/classes/svelte/network-loader/typedef.js +8 -8
  49. package/dist/components/area/HkArea.svelte +49 -49
  50. package/dist/components/area/HkGridArea.svelte +77 -77
  51. package/dist/components/area/index.js +2 -2
  52. package/dist/components/buttons/button/Button.svelte +82 -82
  53. package/dist/components/buttons/button-icon-steeze/SteezeIconButton.svelte +30 -30
  54. package/dist/components/buttons/button-text/TextButton.svelte +21 -21
  55. package/dist/components/buttons/index.js +3 -3
  56. package/dist/components/debug/debug-panel-design-scaling/DebugPanelDesignScaling.svelte +146 -146
  57. package/dist/components/debug/index.js +1 -1
  58. package/dist/components/drag-drop/DragController.js +44 -44
  59. package/dist/components/drag-drop/DragDropContext.svelte +110 -110
  60. package/dist/components/drag-drop/Draggable.svelte +512 -512
  61. package/dist/components/drag-drop/DropZoneArea.svelte +119 -119
  62. package/dist/components/drag-drop/DropZoneList.svelte +125 -125
  63. package/dist/components/drag-drop/{DropZone.svelte → Dropzone.svelte} +258 -258
  64. package/dist/components/drag-drop/drag-state.svelte.js +319 -319
  65. package/dist/components/drag-drop/index.js +7 -7
  66. package/dist/components/drag-drop/util.js +85 -85
  67. package/dist/components/hkdev/blocks/TextBlock.svelte +46 -46
  68. package/dist/components/hkdev/buttons/CheckButton.svelte +62 -62
  69. package/dist/components/icons/HkIcon.svelte +86 -86
  70. package/dist/components/icons/HkTabIcon.svelte +116 -116
  71. package/dist/components/icons/SteezeIcon.svelte +97 -97
  72. package/dist/components/icons/index.js +6 -6
  73. package/dist/components/icons/typedef.js +16 -16
  74. package/dist/components/index.js +2 -2
  75. package/dist/components/inputs/index.js +1 -1
  76. package/dist/components/inputs/text-input/TestTextInput.svelte__ +102 -102
  77. package/dist/components/inputs/text-input/TextInput.svelte +223 -223
  78. package/dist/components/inputs/text-input/TextInput.svelte___ +83 -83
  79. package/dist/components/inputs/text-input/assets/IconInvalid.svelte +14 -14
  80. package/dist/components/inputs/text-input/assets/IconValid.svelte +12 -12
  81. package/dist/components/layout/grid-layers/GridLayers.svelte +63 -63
  82. package/dist/components/layout/grid-layers/util.js +74 -74
  83. package/dist/components/layout/index.js +1 -1
  84. package/dist/components/panels/index.js +1 -1
  85. package/dist/components/panels/panel/Panel.svelte +43 -43
  86. package/dist/components/rows/index.js +3 -3
  87. package/dist/components/rows/panel-grid-row/PanelGridRow.svelte +104 -104
  88. package/dist/components/rows/panel-row-2/PanelRow2.svelte +40 -40
  89. package/dist/components/tab-bar/HkTabBar.state.svelte.js +149 -149
  90. package/dist/components/tab-bar/HkTabBar.svelte +74 -74
  91. package/dist/components/tab-bar/HkTabBarSelector.state.svelte.js +93 -93
  92. package/dist/components/tab-bar/HkTabBarSelector.svelte +49 -49
  93. package/dist/components/tab-bar/index.js +17 -17
  94. package/dist/components/tab-bar/typedef.js +11 -11
  95. package/dist/config/imagetools-config.js +189 -189
  96. package/dist/config/imagetools.d.ts +72 -72
  97. package/dist/constants/bases.js +13 -13
  98. package/dist/constants/errors/api.js +9 -9
  99. package/dist/constants/errors/generic.js +5 -5
  100. package/dist/constants/errors/index.js +3 -3
  101. package/dist/constants/errors/jwt.js +5 -5
  102. package/dist/constants/http/headers.js +6 -6
  103. package/dist/constants/http/index.js +2 -2
  104. package/dist/constants/http/methods.js +2 -2
  105. package/dist/constants/index.js +3 -3
  106. package/dist/constants/mime/application.js +5 -5
  107. package/dist/constants/mime/audio.js +13 -13
  108. package/dist/constants/mime/image.js +3 -3
  109. package/dist/constants/mime/index.js +4 -4
  110. package/dist/constants/mime/text.js +2 -2
  111. package/dist/constants/regexp/index.js +31 -31
  112. package/dist/constants/regexp/inspiratie.js__ +95 -95
  113. package/dist/constants/regexp/text.js +49 -49
  114. package/dist/constants/regexp/user.js +32 -32
  115. package/dist/constants/regexp/web.js +3 -3
  116. package/dist/constants/state-labels/drag-states.js +6 -6
  117. package/dist/constants/state-labels/drop-states.js +6 -6
  118. package/dist/constants/state-labels/input-states.js +11 -11
  119. package/dist/constants/state-labels/submit-states.js +4 -4
  120. package/dist/constants/time.js +28 -28
  121. package/dist/css/utilities.css +43 -43
  122. package/dist/design/design-config.js +73 -73
  123. package/dist/design/tailwind-theme-extend.js +158 -158
  124. package/dist/features/button-group/ButtonGroup.svelte +82 -82
  125. package/dist/features/button-group/typedef.js +10 -10
  126. package/dist/features/compare-left-right/CompareLeftRight.svelte +179 -179
  127. package/dist/features/compare-left-right/index.js +1 -1
  128. package/dist/features/game-box/GameBox.svelte +577 -577
  129. package/dist/features/game-box/gamebox.util.js +83 -83
  130. package/dist/features/hk-app-layout/HkAppLayout.state.svelte.js +25 -25
  131. package/dist/features/hk-app-layout/HkAppLayout.svelte +251 -251
  132. package/dist/features/image-box/ImageBox.svelte +210 -210
  133. package/dist/features/image-box/index.js +5 -5
  134. package/dist/features/image-box/typedef.js +32 -32
  135. package/dist/features/index.js +23 -23
  136. package/dist/features/presenter/ImageSlide.svelte +64 -64
  137. package/dist/features/presenter/Presenter.state.svelte.js +638 -638
  138. package/dist/features/presenter/Presenter.svelte +142 -142
  139. package/dist/features/presenter/constants.js +7 -7
  140. package/dist/features/presenter/index.js +10 -10
  141. package/dist/features/presenter/typedef.js +106 -106
  142. package/dist/features/presenter/util.js +210 -210
  143. package/dist/features/virtual-viewport/VirtualViewport.svelte +196 -196
  144. package/dist/schemas/index.js +1 -1
  145. package/dist/schemas/validate-url.js +180 -180
  146. package/dist/server/index.js +1 -1
  147. package/dist/server/logger.js +94 -94
  148. package/dist/states/index.js +1 -1
  149. package/dist/states/navigation.svelte.js +55 -55
  150. package/dist/stores/index.js +1 -1
  151. package/dist/stores/theme.js +80 -80
  152. package/dist/themes/hkdev/components/blocks/text-block.css +41 -41
  153. package/dist/themes/hkdev/components/boxes/game-box.css +12 -12
  154. package/dist/themes/hkdev/components/buttons/button-icon-steeze.css +22 -22
  155. package/dist/themes/hkdev/components/buttons/button-text.css +32 -32
  156. package/dist/themes/hkdev/components/buttons/button.css +146 -146
  157. package/dist/themes/hkdev/components/buttons/skip-button.css +6 -6
  158. package/dist/themes/hkdev/components/drag-drop/draggable.css +73 -73
  159. package/dist/themes/hkdev/components/drag-drop/drop-zone.css +48 -48
  160. package/dist/themes/hkdev/components/icons/icon-steeze.css +22 -22
  161. package/dist/themes/hkdev/components/inputs/text-input.css +104 -104
  162. package/dist/themes/hkdev/components/panels/panel.css +27 -27
  163. package/dist/themes/hkdev/components/rows/panel-grid-row.css +6 -6
  164. package/dist/themes/hkdev/components/rows/panel-row-2.css +7 -7
  165. package/dist/themes/hkdev/components.css +53 -53
  166. package/dist/themes/hkdev/debug.css +1 -1
  167. package/dist/themes/hkdev/global/layout.css +39 -39
  168. package/dist/themes/hkdev/global/on-colors.css +53 -53
  169. package/dist/themes/hkdev/globals.css +11 -11
  170. package/dist/themes/hkdev/responsive.css +12 -12
  171. package/dist/themes/hkdev/theme-ext.js +15 -15
  172. package/dist/themes/hkdev/theme.js +235 -235
  173. package/dist/themes/index.js +1 -1
  174. package/dist/typedef/context.js +6 -6
  175. package/dist/typedef/drag.js +25 -25
  176. package/dist/typedef/drop.js +12 -12
  177. package/dist/typedef/image.js +38 -38
  178. package/dist/typedef/index.js +4 -4
  179. package/dist/util/array/index.js +436 -436
  180. package/dist/util/bases/base58.js +262 -262
  181. package/dist/util/bases/index.js +1 -1
  182. package/dist/util/compare/index.js +247 -247
  183. package/dist/util/css/css-vars.js +83 -83
  184. package/dist/util/css/index.js +1 -1
  185. package/dist/util/design-system/components/states.js +22 -22
  186. package/dist/util/design-system/css/clamp.js +66 -66
  187. package/dist/util/design-system/css/root-design-vars.js +102 -102
  188. package/dist/util/design-system/index.js +5 -5
  189. package/dist/util/design-system/layout/scaling.js +228 -228
  190. package/dist/util/design-system/skeleton.js +208 -208
  191. package/dist/util/design-system/tailwind.js +288 -288
  192. package/dist/util/env/index.js +9 -9
  193. package/dist/util/expect/arrays.js +47 -47
  194. package/dist/util/expect/index.js +259 -259
  195. package/dist/util/expect/primitives.js +55 -55
  196. package/dist/util/expect/url.js +60 -60
  197. package/dist/util/function/index.js +218 -218
  198. package/dist/util/geo/index.js +26 -26
  199. package/dist/util/http/caching.js +263 -263
  200. package/dist/util/http/errors.js +97 -97
  201. package/dist/util/http/headers.js +75 -75
  202. package/dist/util/http/http-request.js +379 -379
  203. package/dist/util/http/index.js +22 -22
  204. package/dist/util/http/json-request.js +224 -224
  205. package/dist/util/http/mocks.js +65 -65
  206. package/dist/util/http/response.js +294 -294
  207. package/dist/util/http/typedef.js +93 -93
  208. package/dist/util/http/url.js +52 -52
  209. package/dist/util/image/index.js +86 -86
  210. package/dist/util/index.js +2 -2
  211. package/dist/util/is/index.js +140 -140
  212. package/dist/util/iterate/index.js +234 -234
  213. package/dist/util/object/index.js +1361 -1361
  214. package/dist/util/singleton/index.js +97 -97
  215. package/dist/util/string/array-path.js +75 -75
  216. package/dist/util/string/convert.js +54 -54
  217. package/dist/util/string/fs.js +226 -226
  218. package/dist/util/string/index.js +5 -5
  219. package/dist/util/string/interpolate.js +61 -61
  220. package/dist/util/string/pad.js +10 -10
  221. package/dist/util/svelte/index.js +4 -4
  222. package/dist/util/svelte/loading/loading-tracker.svelte.js +108 -108
  223. package/dist/util/svelte/observe/index.js +49 -49
  224. package/dist/util/svelte/state-context/index.js +117 -117
  225. package/dist/util/svelte/wait/index.js +38 -38
  226. package/dist/util/sveltekit/index.js +1 -1
  227. package/dist/util/sveltekit/route-folders/index.js +101 -101
  228. package/dist/util/time/index.js +323 -323
  229. package/dist/util/unique/index.js +249 -249
  230. package/dist/valibot/date.js__ +10 -10
  231. package/dist/valibot/index.js +9 -9
  232. package/dist/valibot/url.js +95 -95
  233. package/dist/valibot/user.js +23 -23
  234. package/dist/zod/all.js +33 -33
  235. package/dist/zod/generic.js +11 -11
  236. package/dist/zod/javascript.js +32 -32
  237. package/dist/zod/user.js +16 -16
  238. package/dist/zod/web.js +52 -52
  239. package/package.json +112 -112
  240. package/dist/components/drag-drop/drag-state.svelte.js__ +0 -323
  241. package/dist/components/layout/grid-layers/GridLayers.svelte__heightFrom__ +0 -372
  242. package/dist/util/http/test-data__/content-length-test-hkdigital-small.V4HfZyBQ.avif +0 -0
@@ -1,146 +1,146 @@
1
- <script>
2
- import { onMount } from 'svelte';
3
- import { DESIGN, CLAMPING } from '../../../design/design-config.js';
4
- import {
5
- enableScalingUI,
6
- getAllRootScalingVars
7
- } from '../../../util/design-system/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/design-config.js';
4
+ import {
5
+ enableScalingUI,
6
+ getAllRootScalingVars
7
+ } from '../../../util/design-system/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
+ }
@@ -1,110 +1,110 @@
1
- <script>
2
- import { createDragState } from './drag-state.svelte.js';
3
-
4
- /**
5
- * @type {{
6
- * contextKey?: import('../../typedef').ContextKey,
7
- * base?: string,
8
- * classes?: string,
9
- * children: import('svelte').Snippet,
10
- * [key: string]: any
11
- * }}
12
- */
13
- let { contextKey, base = '', classes = '', children, ...attrs } = $props();
14
-
15
- // Create the state context at this level to ensure all children
16
- // have access to the same state instance
17
- const dragState = createDragState(contextKey);
18
-
19
- /**
20
- * Handle drag enter at context level
21
- * @param {DragEvent} event
22
- */
23
- function onDragEnter(event) {
24
- event.preventDefault();
25
- dragState.updateActiveDropZone(event.clientX, event.clientY, event);
26
- }
27
-
28
- /**
29
- * Handle drag over at context level
30
- * @param {DragEvent} event
31
- */
32
- function onDragOver(event) {
33
- event.preventDefault();
34
- dragState.updateActiveDropZone(event.clientX, event.clientY, event);
35
-
36
- // Set appropriate drop effect based on current drag operation
37
- if (dragState.isDragging()) {
38
- const activeZone = dragState.activeDropZone;
39
- if (activeZone) {
40
- const config = dragState.dropZones.get(activeZone);
41
- if (config?.canDrop) {
42
- event.dataTransfer.dropEffect = 'move';
43
- } else {
44
- event.dataTransfer.dropEffect = 'none';
45
- }
46
- } else {
47
- event.dataTransfer.dropEffect = 'none';
48
- }
49
- } else {
50
- // No internal drag operation, might be file drag
51
- event.dataTransfer.dropEffect = 'copy';
52
- }
53
- }
54
-
55
- /**
56
- * Handle drag leave at context level
57
- * @param {DragEvent} event
58
- */
59
- function onDragLeave(event) {
60
- // Only handle if we're leaving the entire context
61
- const rect =
62
- /** @type {Element} */ (event.currentTarget).getBoundingClientRect();
63
-
64
-
65
- const x = event.clientX;
66
- const y = event.clientY;
67
-
68
- // Check if we're truly leaving the context bounds
69
- if (x < rect.left || x > rect.right || y < rect.top || y > rect.bottom) {
70
- dragState.updateActiveDropZone(-1, -1, event);
71
- }
72
- }
73
-
74
- /**
75
- * Handle drop at context level
76
- * @param {DragEvent} event
77
- */
78
- function onDrop(event) {
79
- event.preventDefault();
80
- dragState.handleDropAtPoint(event.clientX, event.clientY, event);
81
- }
82
-
83
- /**
84
- * Handle drag end to clean up
85
- * @param {DragEvent} event
86
- */
87
- function onDragEnd(event) {
88
- // This will trigger cleanup in drag state
89
- dragState.updateActiveDropZone(-1, -1, event);
90
- }
91
- </script>
92
-
93
- <div
94
- data-component="drag-drop-context"
95
- ondragenter={onDragEnter}
96
- ondragover={onDragOver}
97
- ondragleave={onDragLeave}
98
- ondrop={onDrop}
99
- ondragend={onDragEnd}
100
- ontouchmove={(e) => {
101
- // Prevent scrolling if we're dragging
102
- if (dragState.isDragging()) {
103
- e.preventDefault();
104
- }
105
- }}
106
- class="{base} {classes}"
107
- {...attrs}
108
- >
109
- {@render children()}
110
- </div>
1
+ <script>
2
+ import { createDragState } from './drag-state.svelte.js';
3
+
4
+ /**
5
+ * @type {{
6
+ * contextKey?: import('../../typedef').ContextKey,
7
+ * base?: string,
8
+ * classes?: string,
9
+ * children: import('svelte').Snippet,
10
+ * [key: string]: any
11
+ * }}
12
+ */
13
+ let { contextKey, base = '', classes = '', children, ...attrs } = $props();
14
+
15
+ // Create the state context at this level to ensure all children
16
+ // have access to the same state instance
17
+ const dragState = createDragState(contextKey);
18
+
19
+ /**
20
+ * Handle drag enter at context level
21
+ * @param {DragEvent} event
22
+ */
23
+ function onDragEnter(event) {
24
+ event.preventDefault();
25
+ dragState.updateActiveDropZone(event.clientX, event.clientY, event);
26
+ }
27
+
28
+ /**
29
+ * Handle drag over at context level
30
+ * @param {DragEvent} event
31
+ */
32
+ function onDragOver(event) {
33
+ event.preventDefault();
34
+ dragState.updateActiveDropZone(event.clientX, event.clientY, event);
35
+
36
+ // Set appropriate drop effect based on current drag operation
37
+ if (dragState.isDragging()) {
38
+ const activeZone = dragState.activeDropZone;
39
+ if (activeZone) {
40
+ const config = dragState.dropZones.get(activeZone);
41
+ if (config?.canDrop) {
42
+ event.dataTransfer.dropEffect = 'move';
43
+ } else {
44
+ event.dataTransfer.dropEffect = 'none';
45
+ }
46
+ } else {
47
+ event.dataTransfer.dropEffect = 'none';
48
+ }
49
+ } else {
50
+ // No internal drag operation, might be file drag
51
+ event.dataTransfer.dropEffect = 'copy';
52
+ }
53
+ }
54
+
55
+ /**
56
+ * Handle drag leave at context level
57
+ * @param {DragEvent} event
58
+ */
59
+ function onDragLeave(event) {
60
+ // Only handle if we're leaving the entire context
61
+ const rect =
62
+ /** @type {Element} */ (event.currentTarget).getBoundingClientRect();
63
+
64
+
65
+ const x = event.clientX;
66
+ const y = event.clientY;
67
+
68
+ // Check if we're truly leaving the context bounds
69
+ if (x < rect.left || x > rect.right || y < rect.top || y > rect.bottom) {
70
+ dragState.updateActiveDropZone(-1, -1, event);
71
+ }
72
+ }
73
+
74
+ /**
75
+ * Handle drop at context level
76
+ * @param {DragEvent} event
77
+ */
78
+ function onDrop(event) {
79
+ event.preventDefault();
80
+ dragState.handleDropAtPoint(event.clientX, event.clientY, event);
81
+ }
82
+
83
+ /**
84
+ * Handle drag end to clean up
85
+ * @param {DragEvent} event
86
+ */
87
+ function onDragEnd(event) {
88
+ // This will trigger cleanup in drag state
89
+ dragState.updateActiveDropZone(-1, -1, event);
90
+ }
91
+ </script>
92
+
93
+ <div
94
+ data-component="drag-drop-context"
95
+ ondragenter={onDragEnter}
96
+ ondragover={onDragOver}
97
+ ondragleave={onDragLeave}
98
+ ondrop={onDrop}
99
+ ondragend={onDragEnd}
100
+ ontouchmove={(e) => {
101
+ // Prevent scrolling if we're dragging
102
+ if (dragState.isDragging()) {
103
+ e.preventDefault();
104
+ }
105
+ }}
106
+ class="{base} {classes}"
107
+ {...attrs}
108
+ >
109
+ {@render children()}
110
+ </div>