@hkdigital/lib-sveltekit 0.2.21 → 0.2.22

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 +149 -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/{Dropzone.svelte → DropZone.svelte} +258 -258
  64. package/dist/components/drag-drop/DropZoneArea.svelte +119 -119
  65. package/dist/components/drag-drop/DropZoneList.svelte +125 -125
  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/GridLayers.svelte__heightFrom__ +372 -0
  86. package/dist/components/layout/grid-layers/util.js +74 -74
  87. package/dist/components/layout/index.js +1 -1
  88. package/dist/components/panels/index.js +1 -1
  89. package/dist/components/panels/panel/Panel.svelte +43 -43
  90. package/dist/components/rows/index.js +3 -3
  91. package/dist/components/rows/panel-grid-row/PanelGridRow.svelte +104 -104
  92. package/dist/components/rows/panel-row-2/PanelRow2.svelte +40 -40
  93. package/dist/components/tab-bar/HkTabBar.state.svelte.js +149 -149
  94. package/dist/components/tab-bar/HkTabBar.svelte +74 -74
  95. package/dist/components/tab-bar/HkTabBarSelector.state.svelte.js +93 -93
  96. package/dist/components/tab-bar/HkTabBarSelector.svelte +49 -49
  97. package/dist/components/tab-bar/index.js +17 -17
  98. package/dist/components/tab-bar/typedef.js +11 -11
  99. package/dist/config/imagetools-config.js +189 -189
  100. package/dist/config/imagetools.d.ts +72 -72
  101. package/dist/constants/bases.js +13 -13
  102. package/dist/constants/errors/api.js +9 -9
  103. package/dist/constants/errors/generic.js +5 -5
  104. package/dist/constants/errors/index.js +3 -3
  105. package/dist/constants/errors/jwt.js +5 -5
  106. package/dist/constants/http/headers.js +6 -6
  107. package/dist/constants/http/index.js +2 -2
  108. package/dist/constants/http/methods.js +14 -14
  109. package/dist/constants/index.js +3 -3
  110. package/dist/constants/mime/application.js +5 -5
  111. package/dist/constants/mime/audio.js +13 -13
  112. package/dist/constants/mime/image.js +3 -3
  113. package/dist/constants/mime/index.js +4 -4
  114. package/dist/constants/mime/text.js +2 -2
  115. package/dist/constants/regexp/index.js +31 -31
  116. package/dist/constants/regexp/inspiratie.js__ +95 -95
  117. package/dist/constants/regexp/text.js +49 -49
  118. package/dist/constants/regexp/user.js +32 -32
  119. package/dist/constants/regexp/web.js +3 -3
  120. package/dist/constants/state-labels/drag-states.js +6 -6
  121. package/dist/constants/state-labels/drop-states.js +6 -6
  122. package/dist/constants/state-labels/input-states.js +11 -11
  123. package/dist/constants/state-labels/submit-states.js +4 -4
  124. package/dist/constants/time.js +28 -28
  125. package/dist/css/utilities.css +43 -43
  126. package/dist/design/design-config.js +73 -73
  127. package/dist/design/tailwind-theme-extend.js +158 -158
  128. package/dist/features/button-group/ButtonGroup.svelte +82 -82
  129. package/dist/features/button-group/typedef.js +10 -10
  130. package/dist/features/compare-left-right/CompareLeftRight.svelte +179 -179
  131. package/dist/features/compare-left-right/index.js +1 -1
  132. package/dist/features/game-box/GameBox.svelte +577 -577
  133. package/dist/features/game-box/gamebox.util.js +83 -83
  134. package/dist/features/hk-app-layout/HkAppLayout.state.svelte.js +25 -25
  135. package/dist/features/hk-app-layout/HkAppLayout.svelte +251 -251
  136. package/dist/features/image-box/ImageBox.svelte +210 -210
  137. package/dist/features/image-box/index.js +5 -5
  138. package/dist/features/image-box/typedef.js +32 -32
  139. package/dist/features/index.js +23 -23
  140. package/dist/features/presenter/ImageSlide.svelte +64 -64
  141. package/dist/features/presenter/Presenter.state.svelte.js +638 -638
  142. package/dist/features/presenter/Presenter.svelte +142 -142
  143. package/dist/features/presenter/constants.js +7 -7
  144. package/dist/features/presenter/index.js +10 -10
  145. package/dist/features/presenter/typedef.js +106 -106
  146. package/dist/features/presenter/util.js +210 -210
  147. package/dist/features/virtual-viewport/VirtualViewport.svelte +196 -196
  148. package/dist/logging/adapters/console.js +114 -114
  149. package/dist/logging/adapters/pino.js +60 -60
  150. package/dist/logging/constants.js +1 -1
  151. package/dist/logging/factories/client.js +21 -21
  152. package/dist/logging/factories/server.js +22 -22
  153. package/dist/logging/factories/universal.js +23 -23
  154. package/dist/logging/index.js +8 -8
  155. package/dist/schemas/index.js +1 -1
  156. package/dist/schemas/validate-url.js +180 -180
  157. package/dist/server/index.js +1 -1
  158. package/dist/server/logger.js +94 -94
  159. package/dist/states/index.js +1 -1
  160. package/dist/states/navigation.svelte.js +55 -55
  161. package/dist/stores/index.js +1 -1
  162. package/dist/stores/theme.js +80 -80
  163. package/dist/themes/hkdev/components/blocks/text-block.css +34 -34
  164. package/dist/themes/hkdev/components/boxes/game-box.css +11 -11
  165. package/dist/themes/hkdev/components/buttons/button-icon-steeze.css +22 -22
  166. package/dist/themes/hkdev/components/buttons/button-text.css +32 -32
  167. package/dist/themes/hkdev/components/buttons/button.css +146 -146
  168. package/dist/themes/hkdev/components/buttons/skip-button.css +5 -5
  169. package/dist/themes/hkdev/components/drag-drop/draggable.css +73 -73
  170. package/dist/themes/hkdev/components/drag-drop/drop-zone.css +58 -58
  171. package/dist/themes/hkdev/components/icons/icon-steeze.css +15 -15
  172. package/dist/themes/hkdev/components/inputs/text-input.css +102 -102
  173. package/dist/themes/hkdev/components/panels/panel.css +25 -25
  174. package/dist/themes/hkdev/components/rows/panel-grid-row.css +4 -4
  175. package/dist/themes/hkdev/components/rows/panel-row-2.css +5 -5
  176. package/dist/themes/hkdev/components.css +29 -29
  177. package/dist/themes/hkdev/debug.css +1 -1
  178. package/dist/themes/hkdev/global/layout.css +32 -32
  179. package/dist/themes/hkdev/global/on-colors.css +32 -32
  180. package/dist/themes/hkdev/globals.css +3 -3
  181. package/dist/themes/hkdev/responsive.css +12 -12
  182. package/dist/themes/hkdev/theme-ext.js +12 -12
  183. package/dist/themes/hkdev/theme.css +218 -218
  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/exceptions/index.d.ts +11 -0
  205. package/dist/util/exceptions/index.js +17 -0
  206. package/dist/util/expect/arrays.js +47 -47
  207. package/dist/util/expect/index.js +259 -259
  208. package/dist/util/expect/primitives.js +55 -55
  209. package/dist/util/expect/url.js +60 -60
  210. package/dist/util/function/index.js +218 -218
  211. package/dist/util/geo/index.js +26 -26
  212. package/dist/util/http/caching.js +263 -263
  213. package/dist/util/http/errors.js +97 -97
  214. package/dist/util/http/headers.js +75 -75
  215. package/dist/util/http/http-request.js +578 -578
  216. package/dist/util/http/index.js +22 -22
  217. package/dist/util/http/json-request.js +224 -224
  218. package/dist/util/http/mocks.js +65 -65
  219. package/dist/util/http/response.js +294 -294
  220. package/dist/util/http/test-data__/content-length-test-hkdigital-small.V4HfZyBQ.avif +0 -0
  221. package/dist/util/http/typedef.js +93 -93
  222. package/dist/util/http/url.js +52 -52
  223. package/dist/util/image/index.js +86 -86
  224. package/dist/util/index.d.ts +1 -0
  225. package/dist/util/index.js +3 -2
  226. package/dist/util/is/index.js +140 -140
  227. package/dist/util/iterate/index.js +234 -234
  228. package/dist/util/object/index.js +1361 -1361
  229. package/dist/util/singleton/index.js +97 -97
  230. package/dist/util/string/array-path.js +75 -75
  231. package/dist/util/string/convert.js +54 -54
  232. package/dist/util/string/fs.js +226 -226
  233. package/dist/util/string/index.js +5 -5
  234. package/dist/util/string/interpolate.js +61 -61
  235. package/dist/util/string/pad.js +10 -10
  236. package/dist/util/svelte/index.js +4 -4
  237. package/dist/util/svelte/loading/loading-tracker.svelte.js +108 -108
  238. package/dist/util/svelte/observe/index.js +49 -49
  239. package/dist/util/svelte/state-context/index.js +117 -117
  240. package/dist/util/svelte/wait/index.js +38 -38
  241. package/dist/util/sveltekit/index.js +1 -1
  242. package/dist/util/sveltekit/route-folders/index.js +101 -101
  243. package/dist/util/time/index.js +323 -323
  244. package/dist/util/unique/index.js +249 -249
  245. package/dist/valibot/date.js__ +10 -10
  246. package/dist/valibot/index.js +9 -9
  247. package/dist/valibot/url.js +95 -95
  248. package/dist/valibot/user.js +23 -23
  249. package/dist/zod/all.js +33 -33
  250. package/dist/zod/generic.js +11 -11
  251. package/dist/zod/javascript.js +32 -32
  252. package/dist/zod/user.js +16 -16
  253. package/dist/zod/web.js +52 -52
  254. package/package.json +133 -132
@@ -1,102 +1,102 @@
1
- <script>
2
- /**
3
- * @type {{
4
- * base?: string,
5
- * error?: string,
6
- * classes?: string,
7
- * fieldClasses?: string,
8
- * fieldError?: string,
9
- * legendBase?: string,
10
- * legendClasses?: string,
11
- * legendError?: string,
12
- * value?: string,
13
- * type?: 'text' | 'url' | 'email' | 'number',
14
- * pattern?: string,
15
- * required?: boolean,
16
- * title?: string,
17
- * valid?: boolean,
18
- * pristine?: boolean,
19
- * validate?: (value: string) => string | undefined,
20
- * } & { [attr: string]: any }}
21
- */
22
- let {
23
- base = '',
24
- error = '',
25
- classes = '',
26
-
27
- fieldClasses,
28
- fieldError,
29
-
30
- legendBase = 'ml-16tp px-8tp',
31
- legendClasses,
32
- legendError,
33
-
34
- value = $bindable(''),
35
- type = 'text',
36
- pattern,
37
- required = false,
38
-
39
- title = '',
40
-
41
- valid = $bindable(true),
42
- pristine = $bindable(true),
43
-
44
- validate,
45
-
46
- ...attrs
47
- } = $props();
48
-
49
- let inputRef = $state();
50
- let validationMessage = $state('');
51
- let initialValue = $state('');
52
-
53
- $effect(() => {
54
- if (!inputRef) return;
55
- initialValue = value;
56
- validateInput(inputRef, value);
57
- });
58
-
59
- function validateInput(input, currentValue) {
60
- input.setCustomValidity('');
61
- const isBuiltInValid = input.checkValidity();
62
-
63
- if (isBuiltInValid && validate) {
64
- const customError = validate(currentValue);
65
- input.setCustomValidity(customError || '');
66
- }
67
-
68
- pristine = currentValue === initialValue;
69
- valid = input.validity.valid;
70
- validationMessage = input.validationMessage;
71
- }
72
-
73
- function handleInput(event) {
74
- validateInput(event.target, event.target.value);
75
- }
76
- </script>
77
-
78
- <fieldset
79
- data-inputs="text-input"
80
- class="flex w-full items-center rounded {fieldClasses}"
81
- >
82
- <legend class="{legendBase} {legendClasses}">{title}</legend>
83
-
84
- <input
85
- bind:this={inputRef}
86
- {type}
87
- {pattern}
88
- {required}
89
- {value}
90
- class="w-full border-none bg-transparent {base} {classes}"
91
- aria-invalid={!valid}
92
- aria-errormessage={!valid ? 'validation-message' : undefined}
93
- oninput={handleInput}
94
- {...attrs}
95
- />
96
-
97
- {#if !valid}
98
- <small id="validation-message" class="text-error" role="alert">
99
- {validationMessage}
100
- </small>
101
- {/if}
102
- </fieldset>
1
+ <script>
2
+ /**
3
+ * @type {{
4
+ * base?: string,
5
+ * error?: string,
6
+ * classes?: string,
7
+ * fieldClasses?: string,
8
+ * fieldError?: string,
9
+ * legendBase?: string,
10
+ * legendClasses?: string,
11
+ * legendError?: string,
12
+ * value?: string,
13
+ * type?: 'text' | 'url' | 'email' | 'number',
14
+ * pattern?: string,
15
+ * required?: boolean,
16
+ * title?: string,
17
+ * valid?: boolean,
18
+ * pristine?: boolean,
19
+ * validate?: (value: string) => string | undefined,
20
+ * } & { [attr: string]: any }}
21
+ */
22
+ let {
23
+ base = '',
24
+ error = '',
25
+ classes = '',
26
+
27
+ fieldClasses,
28
+ fieldError,
29
+
30
+ legendBase = 'ml-16tp px-8tp',
31
+ legendClasses,
32
+ legendError,
33
+
34
+ value = $bindable(''),
35
+ type = 'text',
36
+ pattern,
37
+ required = false,
38
+
39
+ title = '',
40
+
41
+ valid = $bindable(true),
42
+ pristine = $bindable(true),
43
+
44
+ validate,
45
+
46
+ ...attrs
47
+ } = $props();
48
+
49
+ let inputRef = $state();
50
+ let validationMessage = $state('');
51
+ let initialValue = $state('');
52
+
53
+ $effect(() => {
54
+ if (!inputRef) return;
55
+ initialValue = value;
56
+ validateInput(inputRef, value);
57
+ });
58
+
59
+ function validateInput(input, currentValue) {
60
+ input.setCustomValidity('');
61
+ const isBuiltInValid = input.checkValidity();
62
+
63
+ if (isBuiltInValid && validate) {
64
+ const customError = validate(currentValue);
65
+ input.setCustomValidity(customError || '');
66
+ }
67
+
68
+ pristine = currentValue === initialValue;
69
+ valid = input.validity.valid;
70
+ validationMessage = input.validationMessage;
71
+ }
72
+
73
+ function handleInput(event) {
74
+ validateInput(event.target, event.target.value);
75
+ }
76
+ </script>
77
+
78
+ <fieldset
79
+ data-inputs="text-input"
80
+ class="flex w-full items-center rounded {fieldClasses}"
81
+ >
82
+ <legend class="{legendBase} {legendClasses}">{title}</legend>
83
+
84
+ <input
85
+ bind:this={inputRef}
86
+ {type}
87
+ {pattern}
88
+ {required}
89
+ {value}
90
+ class="w-full border-none bg-transparent {base} {classes}"
91
+ aria-invalid={!valid}
92
+ aria-errormessage={!valid ? 'validation-message' : undefined}
93
+ oninput={handleInput}
94
+ {...attrs}
95
+ />
96
+
97
+ {#if !valid}
98
+ <small id="validation-message" class="text-error" role="alert">
99
+ {validationMessage}
100
+ </small>
101
+ {/if}
102
+ </fieldset>
@@ -1,223 +1,223 @@
1
- <script>
2
- import IconValid from './assets/IconValid.svelte';
3
- import IconInvalid from './assets/IconInvalid.svelte';
4
-
5
- import { Star, ExclamationTriangle, CheckCircle } from '@steeze-ui/heroicons';
6
-
7
- import { HkIcon } from '../../icons/index.js';
8
-
9
- import {
10
- PRISTINE,
11
- DIRTY,
12
- FOCUSED,
13
- UNFOCUSED,
14
- VALID,
15
- INVALID,
16
- REQUIRED,
17
- DISABLED
18
- } from '../../../constants/state-labels/input-states.js';
19
-
20
- /**
21
- * @type {{
22
- * base?: string,
23
- * borderShape?: string,
24
- * classes?: string,
25
- * inputBase?: string,
26
- * inputClasses?: string,
27
- * legendBase?: string,
28
- * legendClasses?: string,
29
- * iconClasses?: string,
30
- * initialValue?: string,
31
- * value?: string,
32
- * type?: 'text' | 'url' | 'email' | 'number',
33
- * pattern?: string,
34
- * required?: boolean,
35
- * title?: string,
36
- * placeholder?: string,
37
- * isValid?: boolean,
38
- * isPristine?: boolean,
39
- * hasFocus?: boolean,
40
- * validate?: (value: string) => string | undefined,
41
- * iconRequired?: import('svelte').Snippet,
42
- * iconValid?: import('svelte').Snippet,
43
- * iconInvalid?: import('svelte').Snippet
44
- * } & { [attr: string]: any }}
45
- */
46
- let {
47
- initialValue = '',
48
- value = $bindable(''),
49
-
50
- isValid = $bindable(true),
51
- isPristine = $bindable(true),
52
- hasFocus = $bindable(false),
53
-
54
- // Fieldset
55
- base = 'px-10p pb-10p',
56
- borderShape = 'border-1p rounded-xs',
57
-
58
- classes = '',
59
-
60
- // Input
61
- inputBase = 'w-full outline-none border-none bg-transparent',
62
- inputClasses,
63
-
64
- // Legend
65
- legendBase,
66
- legendClasses,
67
-
68
- // Icon
69
- iconBase = 'w-[24px] h-[24px]',
70
- iconClasses = '',
71
-
72
- // Input type and built-in validation
73
-
74
- type = 'text',
75
- required = false,
76
- disabled = false,
77
-
78
- title = '',
79
- placeholder = '',
80
-
81
- // legend = 'Invalid',
82
- // legendInvalid?
83
-
84
- iconRequired,
85
- iconValid,
86
- iconInvalid,
87
-
88
- validate,
89
-
90
- ...attrs
91
- } = $props();
92
-
93
- let inputRef = $state();
94
- let validationMessage = $state('');
95
-
96
- $effect(() => {
97
- if (!inputRef) return;
98
- validateInput(inputRef, initialValue);
99
- value = initialValue;
100
- });
101
-
102
- function validateInput(input, currentValue) {
103
- input.setCustomValidity('');
104
- const isBuiltInValid = input.checkValidity();
105
-
106
- if (isBuiltInValid && validate) {
107
- const customError = validate(currentValue);
108
- input.setCustomValidity(customError || '');
109
- }
110
-
111
- isPristine = currentValue === initialValue;
112
- isValid = input.validity.valid;
113
- validationMessage = input.validationMessage;
114
- }
115
-
116
- function handleInput(event) {
117
- validateInput(event.target, event.target.value);
118
- }
119
-
120
- // let legendHeight = $state(0);
121
-
122
- // let paddingBottomStyle = $derived.by(() => {
123
- // return `padding-bottom: ${legendHeight / 2}px;`;
124
- // });
125
-
126
- let hideLegendStyle = $derived.by(() => {
127
- if (isValid && !title) {
128
- return 'width: 0;';
129
- }
130
- });
131
-
132
- let stateClasses = $derived.by(() => {
133
- //
134
- // Return CSS classes that indicate the component's state
135
- //
136
- // @see $lib/constants/state-labels
137
- //
138
- const outArr = [];
139
-
140
- outArr.push(isPristine ? PRISTINE : DIRTY);
141
- outArr.push(hasFocus ? FOCUSED : UNFOCUSED);
142
- outArr.push(isValid ? VALID : INVALID);
143
-
144
- if (required) {
145
- outArr.push(REQUIRED);
146
- }
147
-
148
- if (disabled) {
149
- outArr.push(DISABLED);
150
- }
151
-
152
- return outArr.join(' ');
153
- });
154
- </script>
155
-
156
- <!-- {#snippet defaultWarning()}
157
- <WarningIcon />
158
- {/snippet} -->
159
-
160
- <fieldset
161
- data-input="text-input"
162
- class="{base} {borderShape} {classes} {stateClasses}"
163
- >
164
- <legend
165
- data-child="legend"
166
- class="{legendBase} {legendClasses}"
167
- style={hideLegendStyle}
168
- >
169
- {#if title}
170
- {title}
171
- <!-- {:else if !isValid}
172
- {invalidTitle} -->
173
- {:else}
174
- &nbsp;
175
- {/if}
176
- </legend>
177
-
178
- <div class="grid grid-cols-[1fr_auto] items-center">
179
- <input
180
- data-child="input"
181
- bind:this={inputRef}
182
- {type}
183
- {required}
184
- {disabled}
185
- bind:value
186
- {placeholder}
187
- class="{inputBase} {inputClasses}"
188
- aria-invalid={!isValid}
189
- aria-errormessage={!isValid ? 'validation-message' : undefined}
190
- oninput={handleInput}
191
- onfocus={() => {
192
- hasFocus = true;
193
- }}
194
- onblur={() => {
195
- hasFocus = false;
196
- }}
197
- {...attrs}
198
- />
199
-
200
- <div data-child="icon-box" class="{iconBase} {iconClasses}">
201
- {#if isPristine && required}
202
- {#if iconRequired}
203
- {@render iconRequired()}
204
- {:else}
205
- <HkIcon src={Star} theme="solid" />
206
- {/if}
207
- {:else if isValid}
208
- {#if iconValid}
209
- {@render iconValid()}
210
- {:else}
211
- <HkIcon src={CheckCircle} theme="solid" />
212
- {/if}
213
- {:else if iconInvalid}
214
- {@render iconInvalid()}
215
- {:else}
216
- <HkIcon src={ExclamationTriangle} theme="solid" />
217
- {/if}
218
- </div>
219
- </div>
220
- </fieldset>
221
-
222
- <style>
223
- </style>
1
+ <script>
2
+ import IconValid from './assets/IconValid.svelte';
3
+ import IconInvalid from './assets/IconInvalid.svelte';
4
+
5
+ import { Star, ExclamationTriangle, CheckCircle } from '@steeze-ui/heroicons';
6
+
7
+ import { HkIcon } from '../../icons/index.js';
8
+
9
+ import {
10
+ PRISTINE,
11
+ DIRTY,
12
+ FOCUSED,
13
+ UNFOCUSED,
14
+ VALID,
15
+ INVALID,
16
+ REQUIRED,
17
+ DISABLED
18
+ } from '../../../constants/state-labels/input-states.js';
19
+
20
+ /**
21
+ * @type {{
22
+ * base?: string,
23
+ * borderShape?: string,
24
+ * classes?: string,
25
+ * inputBase?: string,
26
+ * inputClasses?: string,
27
+ * legendBase?: string,
28
+ * legendClasses?: string,
29
+ * iconClasses?: string,
30
+ * initialValue?: string,
31
+ * value?: string,
32
+ * type?: 'text' | 'url' | 'email' | 'number',
33
+ * pattern?: string,
34
+ * required?: boolean,
35
+ * title?: string,
36
+ * placeholder?: string,
37
+ * isValid?: boolean,
38
+ * isPristine?: boolean,
39
+ * hasFocus?: boolean,
40
+ * validate?: (value: string) => string | undefined,
41
+ * iconRequired?: import('svelte').Snippet,
42
+ * iconValid?: import('svelte').Snippet,
43
+ * iconInvalid?: import('svelte').Snippet
44
+ * } & { [attr: string]: any }}
45
+ */
46
+ let {
47
+ initialValue = '',
48
+ value = $bindable(''),
49
+
50
+ isValid = $bindable(true),
51
+ isPristine = $bindable(true),
52
+ hasFocus = $bindable(false),
53
+
54
+ // Fieldset
55
+ base = 'px-10p pb-10p',
56
+ borderShape = 'border-1p rounded-xs',
57
+
58
+ classes = '',
59
+
60
+ // Input
61
+ inputBase = 'w-full outline-none border-none bg-transparent',
62
+ inputClasses,
63
+
64
+ // Legend
65
+ legendBase,
66
+ legendClasses,
67
+
68
+ // Icon
69
+ iconBase = 'w-[24px] h-[24px]',
70
+ iconClasses = '',
71
+
72
+ // Input type and built-in validation
73
+
74
+ type = 'text',
75
+ required = false,
76
+ disabled = false,
77
+
78
+ title = '',
79
+ placeholder = '',
80
+
81
+ // legend = 'Invalid',
82
+ // legendInvalid?
83
+
84
+ iconRequired,
85
+ iconValid,
86
+ iconInvalid,
87
+
88
+ validate,
89
+
90
+ ...attrs
91
+ } = $props();
92
+
93
+ let inputRef = $state();
94
+ let validationMessage = $state('');
95
+
96
+ $effect(() => {
97
+ if (!inputRef) return;
98
+ validateInput(inputRef, initialValue);
99
+ value = initialValue;
100
+ });
101
+
102
+ function validateInput(input, currentValue) {
103
+ input.setCustomValidity('');
104
+ const isBuiltInValid = input.checkValidity();
105
+
106
+ if (isBuiltInValid && validate) {
107
+ const customError = validate(currentValue);
108
+ input.setCustomValidity(customError || '');
109
+ }
110
+
111
+ isPristine = currentValue === initialValue;
112
+ isValid = input.validity.valid;
113
+ validationMessage = input.validationMessage;
114
+ }
115
+
116
+ function handleInput(event) {
117
+ validateInput(event.target, event.target.value);
118
+ }
119
+
120
+ // let legendHeight = $state(0);
121
+
122
+ // let paddingBottomStyle = $derived.by(() => {
123
+ // return `padding-bottom: ${legendHeight / 2}px;`;
124
+ // });
125
+
126
+ let hideLegendStyle = $derived.by(() => {
127
+ if (isValid && !title) {
128
+ return 'width: 0;';
129
+ }
130
+ });
131
+
132
+ let stateClasses = $derived.by(() => {
133
+ //
134
+ // Return CSS classes that indicate the component's state
135
+ //
136
+ // @see $lib/constants/state-labels
137
+ //
138
+ const outArr = [];
139
+
140
+ outArr.push(isPristine ? PRISTINE : DIRTY);
141
+ outArr.push(hasFocus ? FOCUSED : UNFOCUSED);
142
+ outArr.push(isValid ? VALID : INVALID);
143
+
144
+ if (required) {
145
+ outArr.push(REQUIRED);
146
+ }
147
+
148
+ if (disabled) {
149
+ outArr.push(DISABLED);
150
+ }
151
+
152
+ return outArr.join(' ');
153
+ });
154
+ </script>
155
+
156
+ <!-- {#snippet defaultWarning()}
157
+ <WarningIcon />
158
+ {/snippet} -->
159
+
160
+ <fieldset
161
+ data-input="text-input"
162
+ class="{base} {borderShape} {classes} {stateClasses}"
163
+ >
164
+ <legend
165
+ data-child="legend"
166
+ class="{legendBase} {legendClasses}"
167
+ style={hideLegendStyle}
168
+ >
169
+ {#if title}
170
+ {title}
171
+ <!-- {:else if !isValid}
172
+ {invalidTitle} -->
173
+ {:else}
174
+ &nbsp;
175
+ {/if}
176
+ </legend>
177
+
178
+ <div class="grid grid-cols-[1fr_auto] items-center">
179
+ <input
180
+ data-child="input"
181
+ bind:this={inputRef}
182
+ {type}
183
+ {required}
184
+ {disabled}
185
+ bind:value
186
+ {placeholder}
187
+ class="{inputBase} {inputClasses}"
188
+ aria-invalid={!isValid}
189
+ aria-errormessage={!isValid ? 'validation-message' : undefined}
190
+ oninput={handleInput}
191
+ onfocus={() => {
192
+ hasFocus = true;
193
+ }}
194
+ onblur={() => {
195
+ hasFocus = false;
196
+ }}
197
+ {...attrs}
198
+ />
199
+
200
+ <div data-child="icon-box" class="{iconBase} {iconClasses}">
201
+ {#if isPristine && required}
202
+ {#if iconRequired}
203
+ {@render iconRequired()}
204
+ {:else}
205
+ <HkIcon src={Star} theme="solid" />
206
+ {/if}
207
+ {:else if isValid}
208
+ {#if iconValid}
209
+ {@render iconValid()}
210
+ {:else}
211
+ <HkIcon src={CheckCircle} theme="solid" />
212
+ {/if}
213
+ {:else if iconInvalid}
214
+ {@render iconInvalid()}
215
+ {:else}
216
+ <HkIcon src={ExclamationTriangle} theme="solid" />
217
+ {/if}
218
+ </div>
219
+ </div>
220
+ </fieldset>
221
+
222
+ <style>
223
+ </style>