@hkdigital/lib-sveltekit 0.2.20 → 0.2.21

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 (254) 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 +210 -210
  15. package/dist/classes/logging/constants.js +16 -16
  16. package/dist/classes/logging/index.js +4 -4
  17. package/dist/classes/logging/typedef.js +17 -17
  18. package/dist/classes/promise/HkPromise.js +377 -377
  19. package/dist/classes/promise/index.js +1 -1
  20. package/dist/classes/services/ServiceBase.js +463 -463
  21. package/dist/classes/services/ServiceManager.js +614 -614
  22. package/dist/classes/services/index.js +5 -5
  23. package/dist/classes/services/service-states.js +205 -205
  24. package/dist/classes/services/typedef.js +179 -179
  25. package/dist/classes/stores/SubscribersCount.js +107 -107
  26. package/dist/classes/stores/index.js +1 -1
  27. package/dist/classes/streams/LogTransformStream.js +19 -19
  28. package/dist/classes/streams/ServerEventsStore.js +110 -110
  29. package/dist/classes/streams/TimeStampSource.js +26 -26
  30. package/dist/classes/streams/index.js +3 -3
  31. package/dist/classes/svelte/audio/AudioLoader.svelte.js +58 -58
  32. package/dist/classes/svelte/audio/AudioScene.svelte.js +324 -324
  33. package/dist/classes/svelte/audio/mocks.js +35 -35
  34. package/dist/classes/svelte/finite-state-machine/FiniteStateMachine.svelte.js +133 -133
  35. package/dist/classes/svelte/finite-state-machine/index.js +1 -1
  36. package/dist/classes/svelte/image/ImageLoader.svelte.js +45 -45
  37. package/dist/classes/svelte/image/ImageScene.svelte.js +249 -249
  38. package/dist/classes/svelte/image/ImageVariantsLoader.svelte.js +152 -152
  39. package/dist/classes/svelte/image/index.js +4 -4
  40. package/dist/classes/svelte/image/mocks.js +35 -35
  41. package/dist/classes/svelte/image/typedef.js +8 -8
  42. package/dist/classes/svelte/index.js +14 -14
  43. package/dist/classes/svelte/loading-state-machine/LoadingStateMachine.svelte.js +109 -109
  44. package/dist/classes/svelte/loading-state-machine/constants.js +16 -16
  45. package/dist/classes/svelte/loading-state-machine/index.js +3 -3
  46. package/dist/classes/svelte/network-loader/NetworkLoader.svelte.js +338 -338
  47. package/dist/classes/svelte/network-loader/constants.js +3 -3
  48. package/dist/classes/svelte/network-loader/index.js +3 -3
  49. package/dist/classes/svelte/network-loader/mocks.js +30 -30
  50. package/dist/classes/svelte/network-loader/typedef.js +8 -8
  51. package/dist/components/area/HkArea.svelte +49 -49
  52. package/dist/components/area/HkGridArea.svelte +77 -77
  53. package/dist/components/area/index.js +2 -2
  54. package/dist/components/buttons/button/Button.svelte +82 -82
  55. package/dist/components/buttons/button-icon-steeze/SteezeIconButton.svelte +30 -30
  56. package/dist/components/buttons/button-text/TextButton.svelte +21 -21
  57. package/dist/components/buttons/index.js +3 -3
  58. package/dist/components/debug/debug-panel-design-scaling/DebugPanelDesignScaling.svelte +146 -146
  59. package/dist/components/debug/index.js +1 -1
  60. package/dist/components/drag-drop/DragController.js +44 -44
  61. package/dist/components/drag-drop/DragDropContext.svelte +111 -111
  62. package/dist/components/drag-drop/Draggable.svelte +519 -519
  63. package/dist/components/drag-drop/DropZoneArea.svelte +119 -119
  64. package/dist/components/drag-drop/DropZoneList.svelte +125 -125
  65. package/dist/components/drag-drop/{DropZone.svelte → Dropzone.svelte} +258 -258
  66. package/dist/components/drag-drop/actions.js +26 -26
  67. package/dist/components/drag-drop/drag-state.svelte.js +322 -322
  68. package/dist/components/drag-drop/index.js +7 -7
  69. package/dist/components/drag-drop/util.js +85 -85
  70. package/dist/components/hkdev/blocks/TextBlock.svelte +46 -46
  71. package/dist/components/hkdev/buttons/CheckButton.svelte +62 -62
  72. package/dist/components/icons/HkIcon.svelte +86 -86
  73. package/dist/components/icons/HkTabIcon.svelte +116 -116
  74. package/dist/components/icons/SteezeIcon.svelte +97 -97
  75. package/dist/components/icons/index.js +6 -6
  76. package/dist/components/icons/typedef.js +16 -16
  77. package/dist/components/index.js +2 -2
  78. package/dist/components/inputs/index.js +1 -1
  79. package/dist/components/inputs/text-input/TestTextInput.svelte__ +102 -102
  80. package/dist/components/inputs/text-input/TextInput.svelte +223 -223
  81. package/dist/components/inputs/text-input/TextInput.svelte___ +83 -83
  82. package/dist/components/inputs/text-input/assets/IconInvalid.svelte +14 -14
  83. package/dist/components/inputs/text-input/assets/IconValid.svelte +12 -12
  84. package/dist/components/layout/grid-layers/GridLayers.svelte +63 -63
  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 +14 -14
  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/logging/adapters/console.js +114 -114
  148. package/dist/logging/adapters/pino.js +60 -60
  149. package/dist/logging/constants.js +1 -1
  150. package/dist/logging/factories/client.js +21 -21
  151. package/dist/logging/factories/server.js +22 -22
  152. package/dist/logging/factories/universal.js +23 -23
  153. package/dist/logging/index.js +8 -8
  154. package/dist/schemas/index.js +1 -1
  155. package/dist/schemas/validate-url.js +180 -180
  156. package/dist/server/index.js +1 -1
  157. package/dist/server/logger.js +94 -94
  158. package/dist/states/index.js +1 -1
  159. package/dist/states/navigation.svelte.js +55 -55
  160. package/dist/stores/index.js +1 -1
  161. package/dist/stores/theme.js +80 -80
  162. package/dist/themes/hkdev/components/blocks/text-block.css +34 -41
  163. package/dist/themes/hkdev/components/boxes/game-box.css +11 -12
  164. package/dist/themes/hkdev/components/buttons/button-icon-steeze.css +22 -22
  165. package/dist/themes/hkdev/components/buttons/button-text.css +32 -32
  166. package/dist/themes/hkdev/components/buttons/button.css +146 -146
  167. package/dist/themes/hkdev/components/buttons/skip-button.css +5 -6
  168. package/dist/themes/hkdev/components/drag-drop/draggable.css +73 -73
  169. package/dist/themes/hkdev/components/drag-drop/drop-zone.css +58 -48
  170. package/dist/themes/hkdev/components/icons/icon-steeze.css +16 -22
  171. package/dist/themes/hkdev/components/inputs/text-input.css +102 -104
  172. package/dist/themes/hkdev/components/panels/panel.css +25 -27
  173. package/dist/themes/hkdev/components/rows/panel-grid-row.css +4 -6
  174. package/dist/themes/hkdev/components/rows/panel-row-2.css +5 -7
  175. package/dist/themes/hkdev/components.css +29 -53
  176. package/dist/themes/hkdev/debug.css +1 -1
  177. package/dist/themes/hkdev/global/layout.css +32 -39
  178. package/dist/themes/hkdev/global/on-colors.css +32 -53
  179. package/dist/themes/hkdev/globals.css +4 -11
  180. package/dist/themes/hkdev/responsive.css +12 -12
  181. package/dist/themes/hkdev/theme-ext.js +12 -15
  182. package/dist/themes/hkdev/theme.css +219 -0
  183. package/dist/themes/index.d.ts +1 -1
  184. package/dist/themes/index.js +1 -1
  185. package/dist/typedef/context.js +6 -6
  186. package/dist/typedef/drag.js +25 -25
  187. package/dist/typedef/drop.js +12 -12
  188. package/dist/typedef/image.js +38 -38
  189. package/dist/typedef/index.js +4 -4
  190. package/dist/util/array/index.js +436 -436
  191. package/dist/util/bases/base58.js +262 -262
  192. package/dist/util/bases/index.js +1 -1
  193. package/dist/util/compare/index.js +247 -247
  194. package/dist/util/css/css-vars.js +83 -83
  195. package/dist/util/css/index.js +1 -1
  196. package/dist/util/design-system/components/states.js +22 -22
  197. package/dist/util/design-system/css/clamp.js +66 -66
  198. package/dist/util/design-system/css/root-design-vars.js +102 -102
  199. package/dist/util/design-system/index.js +5 -5
  200. package/dist/util/design-system/layout/scaling.js +228 -228
  201. package/dist/util/design-system/skeleton.js +208 -208
  202. package/dist/util/design-system/tailwind.js +288 -288
  203. package/dist/util/env/index.js +9 -9
  204. package/dist/util/expect/arrays.js +47 -47
  205. package/dist/util/expect/index.js +259 -259
  206. package/dist/util/expect/primitives.js +55 -55
  207. package/dist/util/expect/url.js +60 -60
  208. package/dist/util/function/index.js +218 -218
  209. package/dist/util/geo/index.js +26 -26
  210. package/dist/util/http/caching.js +263 -263
  211. package/dist/util/http/errors.js +97 -97
  212. package/dist/util/http/headers.js +75 -75
  213. package/dist/util/http/http-request.js +578 -578
  214. package/dist/util/http/index.js +22 -22
  215. package/dist/util/http/json-request.js +224 -224
  216. package/dist/util/http/mocks.js +65 -65
  217. package/dist/util/http/response.js +294 -294
  218. package/dist/util/http/typedef.js +93 -93
  219. package/dist/util/http/url.js +52 -52
  220. package/dist/util/image/index.js +86 -86
  221. package/dist/util/index.js +2 -2
  222. package/dist/util/is/index.js +140 -140
  223. package/dist/util/iterate/index.js +234 -234
  224. package/dist/util/object/index.js +1361 -1361
  225. package/dist/util/singleton/index.js +97 -97
  226. package/dist/util/string/array-path.js +75 -75
  227. package/dist/util/string/convert.js +54 -54
  228. package/dist/util/string/fs.js +226 -226
  229. package/dist/util/string/index.js +5 -5
  230. package/dist/util/string/interpolate.js +61 -61
  231. package/dist/util/string/pad.js +10 -10
  232. package/dist/util/svelte/index.js +4 -4
  233. package/dist/util/svelte/loading/loading-tracker.svelte.js +108 -108
  234. package/dist/util/svelte/observe/index.js +49 -49
  235. package/dist/util/svelte/state-context/index.js +117 -117
  236. package/dist/util/svelte/wait/index.js +38 -38
  237. package/dist/util/sveltekit/index.js +1 -1
  238. package/dist/util/sveltekit/route-folders/index.js +101 -101
  239. package/dist/util/time/index.js +323 -323
  240. package/dist/util/unique/index.js +249 -249
  241. package/dist/valibot/date.js__ +10 -10
  242. package/dist/valibot/index.js +9 -9
  243. package/dist/valibot/url.js +95 -95
  244. package/dist/valibot/user.js +23 -23
  245. package/dist/zod/all.js +33 -33
  246. package/dist/zod/generic.js +11 -11
  247. package/dist/zod/javascript.js +32 -32
  248. package/dist/zod/user.js +16 -16
  249. package/dist/zod/web.js +52 -52
  250. package/package.json +132 -129
  251. package/dist/components/layout/grid-layers/GridLayers.svelte__heightFrom__ +0 -372
  252. package/dist/themes/hkdev/theme.d.ts +0 -234
  253. package/dist/themes/hkdev/theme.js +0 -235
  254. 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,111 +1,111 @@
1
- <script>
2
- import { createDragState } from './drag-state.svelte.js';
3
-
4
- import { activeTouchMove, activeDragOver, activeDrop } 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
- use:activeDrop={onDrop}
101
- ondragend={onDragEnd}
102
- use:activeTouchMove={(e) => {
103
- if (dragState.isDragging()) {
104
- e.preventDefault();
105
- }
106
- }}
107
- class="{base} {classes}"
108
- {...attrs}
109
- >
110
- {@render children()}
111
- </div>
1
+ <script>
2
+ import { createDragState } from './drag-state.svelte.js';
3
+
4
+ import { activeTouchMove, activeDragOver, activeDrop } 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
+ use:activeDrop={onDrop}
101
+ ondragend={onDragEnd}
102
+ use:activeTouchMove={(e) => {
103
+ if (dragState.isDragging()) {
104
+ e.preventDefault();
105
+ }
106
+ }}
107
+ class="{base} {classes}"
108
+ {...attrs}
109
+ >
110
+ {@render children()}
111
+ </div>