@hkdigital/lib-sveltekit 0.2.8 → 0.2.9

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