@hkdigital/lib-core 0.3.9 → 0.3.11

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 (428) hide show
  1. package/README.md +149 -149
  2. package/dist/assets/autospuiten/car-paint-picker.d.ts +7 -7
  3. package/dist/assets/autospuiten/car-paint-picker.js +41 -41
  4. package/dist/assets/autospuiten/labels.js +7 -7
  5. package/dist/classes/data/IterableTree.d.ts +15 -24
  6. package/dist/classes/data/IterableTree.js +242 -243
  7. package/dist/classes/data/Selector.js +190 -190
  8. package/dist/classes/data/index.js +2 -2
  9. package/dist/classes/data/typedef.d.ts +8 -0
  10. package/dist/classes/data/typedef.js +9 -0
  11. package/dist/classes/event-emitter/EventEmitter.js +273 -275
  12. package/dist/classes/event-emitter/index.js +2 -2
  13. package/dist/classes/index.js +4 -4
  14. package/dist/classes/promise/HkPromise.d.ts +18 -17
  15. package/dist/classes/promise/HkPromise.js +384 -377
  16. package/dist/classes/promise/index.js +1 -1
  17. package/dist/classes/stores/SubscribersCount.js +107 -107
  18. package/dist/classes/stores/index.js +1 -1
  19. package/dist/classes/streams/LogTransformStream.js +19 -19
  20. package/dist/classes/streams/ServerEventsStore.d.ts +2 -3
  21. package/dist/classes/streams/ServerEventsStore.js +111 -110
  22. package/dist/classes/streams/TimeStampSource.js +26 -26
  23. package/dist/classes/streams/index.js +3 -3
  24. package/dist/classes/svelte/finite-state-machine/FiniteStateMachine.svelte.js +133 -133
  25. package/dist/classes/svelte/finite-state-machine/index.js +1 -1
  26. package/dist/classes/svelte/index.d.ts +0 -8
  27. package/dist/classes/svelte/index.js +11 -14
  28. package/dist/classes/svelte/loading-state-machine/LoadingStateMachine.svelte.js +109 -109
  29. package/dist/classes/svelte/loading-state-machine/constants.js +16 -16
  30. package/dist/classes/svelte/loading-state-machine/index.js +3 -3
  31. package/dist/config/README.md +196 -0
  32. package/dist/config/{imagetools-config.js → generators/imagetools.js} +189 -189
  33. package/dist/config/generators/vite.d.ts +47 -0
  34. package/dist/config/generators/vite.js +142 -0
  35. package/dist/config/imagetools.d.ts +72 -72
  36. package/dist/config/vite.d.ts +1 -0
  37. package/dist/config/vite.js +5 -0
  38. package/dist/constants/bases/index.js +13 -13
  39. package/dist/constants/http/headers.js +6 -6
  40. package/dist/constants/http/index.js +2 -2
  41. package/dist/constants/http/methods.js +14 -14
  42. package/dist/constants/index.js +6 -6
  43. package/dist/constants/mime/application.js +5 -5
  44. package/dist/constants/mime/audio.js +13 -13
  45. package/dist/constants/mime/image.js +3 -3
  46. package/dist/constants/mime/index.js +4 -4
  47. package/dist/constants/mime/text.js +2 -2
  48. package/dist/constants/regexp/README.md +95 -0
  49. package/dist/constants/regexp/index.d.ts +1 -1
  50. package/dist/constants/regexp/index.js +31 -31
  51. package/dist/constants/regexp/inspiratie.js__ +95 -95
  52. package/dist/constants/regexp/text.d.ts +3 -3
  53. package/dist/constants/regexp/text.js +49 -49
  54. package/dist/constants/regexp/url.d.ts +1 -0
  55. package/dist/constants/regexp/url.js +3 -0
  56. package/dist/constants/regexp/user.d.ts +0 -1
  57. package/dist/constants/regexp/user.js +29 -33
  58. package/dist/constants/states/drag.js +6 -6
  59. package/dist/constants/states/drop.js +6 -6
  60. package/dist/constants/states/index.js +4 -4
  61. package/dist/constants/states/input.js +11 -11
  62. package/dist/constants/states/submit.js +4 -4
  63. package/dist/constants/time/index.js +28 -28
  64. package/dist/css/utilities.css +43 -43
  65. package/dist/design/README.md +405 -0
  66. package/dist/design/{design-config.js → config/design-config.js} +73 -73
  67. package/dist/{util/design-system/tailwind.js → design/generators/index.js} +288 -288
  68. package/dist/design/index.d.ts +8 -0
  69. package/dist/design/index.js +97 -0
  70. package/dist/{util/design-system → design/plugins}/skeleton.js +208 -208
  71. package/dist/design/tailwind-theme-extend.js +158 -158
  72. package/dist/design/themes/README.md +103 -0
  73. package/dist/{themes → design/themes}/hkdev/components/blocks/text-block.css +34 -34
  74. package/dist/{themes → design/themes}/hkdev/components/boxes/game-box.css +11 -11
  75. package/dist/{themes → design/themes}/hkdev/components/buttons/button-icon-steeze.css +22 -22
  76. package/dist/{themes → design/themes}/hkdev/components/buttons/button-text.css +32 -32
  77. package/dist/{themes → design/themes}/hkdev/components/buttons/button.css +146 -146
  78. package/dist/{themes → design/themes}/hkdev/components/buttons/skip-button.css +5 -5
  79. package/dist/{themes → design/themes}/hkdev/components/drag-drop/draggable.css +73 -73
  80. package/dist/{themes → design/themes}/hkdev/components/drag-drop/drop-zone.css +58 -58
  81. package/dist/{themes → design/themes}/hkdev/components/icons/icon-steeze.css +15 -15
  82. package/dist/{themes → design/themes}/hkdev/components/inputs/text-input.css +102 -102
  83. package/dist/{themes → design/themes}/hkdev/components/panels/panel.css +25 -25
  84. package/dist/{themes → design/themes}/hkdev/components/rows/panel-grid-row.css +4 -4
  85. package/dist/{themes → design/themes}/hkdev/components/rows/panel-row-2.css +5 -5
  86. package/dist/{themes → design/themes}/hkdev/components.css +29 -29
  87. package/dist/design/themes/hkdev/debug.css +2 -0
  88. package/dist/{themes → design/themes}/hkdev/global/layout.css +32 -32
  89. package/dist/{themes → design/themes}/hkdev/global/on-colors.css +32 -32
  90. package/dist/{themes → design/themes}/hkdev/globals.css +3 -3
  91. package/dist/{themes → design/themes}/hkdev/responsive.css +12 -12
  92. package/dist/{themes → design/themes}/hkdev/theme-ext.js +12 -12
  93. package/dist/{themes → design/themes}/hkdev/theme.css +218 -218
  94. package/dist/{util/design-system/css → design/utils}/clamp.js +66 -66
  95. package/dist/{util/design-system/css/root-design-vars.d.ts → design/utils/root-vars.d.ts} +2 -2
  96. package/dist/{util/design-system/css/root-design-vars.js → design/utils/root-vars.js} +102 -102
  97. package/dist/{util/design-system/layout → design/utils}/scaling.js +228 -228
  98. package/dist/{util/design-system/components → design/utils}/states.js +22 -22
  99. package/dist/errors/api.js +9 -9
  100. package/dist/errors/generic.js +20 -20
  101. package/dist/errors/http.js +16 -16
  102. package/dist/errors/index.d.ts +1 -0
  103. package/dist/errors/index.js +5 -4
  104. package/dist/errors/jwt.js +5 -5
  105. package/dist/errors/promise.d.ts +27 -0
  106. package/dist/errors/promise.js +26 -0
  107. package/dist/logging/index.js +7 -7
  108. package/dist/logging/internal/adapters/console.js +114 -114
  109. package/dist/logging/internal/adapters/index.js +2 -2
  110. package/dist/logging/internal/adapters/pino.d.ts +1 -0
  111. package/dist/logging/internal/adapters/pino.js +142 -115
  112. package/dist/logging/internal/adapters/typedef.d.ts +24 -0
  113. package/dist/logging/internal/adapters/typedef.js +10 -0
  114. package/dist/logging/internal/factories/client.js +21 -21
  115. package/dist/logging/internal/factories/server.js +22 -22
  116. package/dist/logging/internal/factories/universal.js +22 -22
  117. package/dist/logging/internal/unified-logger/Logger.js +217 -217
  118. package/dist/logging/internal/unified-logger/constants.js +22 -22
  119. package/dist/logging/internal/unified-logger/index.js +6 -6
  120. package/dist/logging/internal/unified-logger/typedef.js +17 -17
  121. package/dist/network/README.md +173 -0
  122. package/dist/{classes → network}/cache/IndexedDbCache.js +1407 -1407
  123. package/dist/{classes → network}/cache/MemoryResponseCache.js +138 -138
  124. package/dist/{classes → network}/cache/index.js +5 -5
  125. package/dist/{classes → network}/cache/typedef.js +41 -41
  126. package/dist/network/cache.d.ts +3 -0
  127. package/dist/network/cache.js +4 -0
  128. package/dist/{util → network}/http/caching.js +261 -263
  129. package/dist/{util → network}/http/errors.js +97 -97
  130. package/dist/{util → network}/http/headers.js +75 -75
  131. package/dist/{util → network}/http/http-request.js +578 -578
  132. package/dist/{util → network}/http/index.js +22 -22
  133. package/dist/{util → network}/http/json-request.js +224 -224
  134. package/dist/{util → network}/http/mocks.js +65 -65
  135. package/dist/{util → network}/http/response.js +318 -318
  136. package/dist/{util → network}/http/typedef.js +93 -93
  137. package/dist/{util → network}/http/url.js +52 -52
  138. package/dist/network/http.d.ts +6 -0
  139. package/dist/network/http.js +6 -0
  140. package/dist/network/loaders/README.md +255 -0
  141. package/dist/{classes/svelte → network/loaders}/audio/AudioLoader.svelte.d.ts +1 -1
  142. package/dist/{classes/svelte → network/loaders}/audio/AudioLoader.svelte.js +58 -58
  143. package/dist/{classes/svelte → network/loaders}/audio/AudioScene.svelte.js +324 -324
  144. package/dist/{classes/svelte → network/loaders}/audio/mocks.js +35 -35
  145. package/dist/network/loaders/audio.d.ts +2 -0
  146. package/dist/network/loaders/audio.js +2 -0
  147. package/dist/{classes/svelte → network/loaders}/image/ImageLoader.svelte.d.ts +3 -6
  148. package/dist/{classes/svelte → network/loaders}/image/ImageLoader.svelte.js +44 -45
  149. package/dist/{classes/svelte → network/loaders}/image/ImageScene.svelte.d.ts +5 -7
  150. package/dist/{classes/svelte → network/loaders}/image/ImageScene.svelte.js +248 -249
  151. package/dist/{classes/svelte → network/loaders}/image/ImageVariantsLoader.svelte.d.ts +4 -4
  152. package/dist/{classes/svelte → network/loaders}/image/ImageVariantsLoader.svelte.js +150 -152
  153. package/dist/{classes/svelte → network/loaders}/image/index.js +4 -4
  154. package/dist/{classes/svelte → network/loaders}/image/mocks.js +35 -35
  155. package/dist/{classes/svelte → network/loaders}/image/typedef.js +8 -8
  156. package/dist/{util/image → network/loaders/image/utils}/index.d.ts +2 -2
  157. package/dist/{util/image → network/loaders/image/utils}/index.js +86 -86
  158. package/dist/network/loaders/image.d.ts +5 -0
  159. package/dist/network/loaders/image.js +8 -0
  160. package/dist/{typedef/image.js → network/loaders/typedef.js} +38 -38
  161. package/dist/network/loaders.d.ts +2 -0
  162. package/dist/network/loaders.js +2 -0
  163. package/dist/{classes/svelte/network-loader → network/states}/NetworkLoader.svelte.d.ts +1 -1
  164. package/dist/{classes/svelte/network-loader → network/states}/NetworkLoader.svelte.js +338 -338
  165. package/dist/{classes/svelte/network-loader → network/states}/constants.js +3 -3
  166. package/dist/{classes/svelte/network-loader → network/states}/index.js +3 -3
  167. package/dist/{classes/svelte/network-loader → network/states}/mocks.js +30 -30
  168. package/dist/{classes/svelte/network-loader → network/states}/typedef.js +8 -8
  169. package/dist/network/typedef.d.ts +4 -0
  170. package/dist/network/typedef.js +10 -0
  171. package/dist/services/index.js +1 -1
  172. package/dist/services/internal/index.js +8 -8
  173. package/dist/services/internal/service-base/ServiceBase.js +462 -462
  174. package/dist/services/internal/service-base/constants.js +110 -110
  175. package/dist/services/internal/service-base/index.js +3 -3
  176. package/dist/services/internal/service-base/typedef.js +101 -101
  177. package/dist/services/internal/service-manager/ServiceManager.d.ts +2 -35
  178. package/dist/services/internal/service-manager/ServiceManager.js +608 -614
  179. package/dist/services/internal/service-manager/constants.js +6 -6
  180. package/dist/services/internal/service-manager/typedef.js +90 -90
  181. package/dist/states/index.js +1 -1
  182. package/dist/states/navigation.svelte.js +55 -55
  183. package/dist/stores/index.js +1 -1
  184. package/dist/stores/theme.js +80 -80
  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/index.d.ts +0 -1
  189. package/dist/typedef/index.js +4 -4
  190. package/dist/{components → ui/components}/button-group/ButtonGroup.svelte +82 -82
  191. package/dist/{components → ui/components}/button-group/typedef.js +10 -10
  192. package/dist/{components → ui/components}/compare-left-right/CompareLeftRight.svelte +179 -179
  193. package/dist/{components → ui/components}/compare-left-right/index.js +1 -1
  194. package/dist/{components → ui/components}/game-box/GameBox.svelte +577 -577
  195. package/dist/{components → ui/components}/game-box/gamebox.util.js +83 -83
  196. package/dist/ui/components/hk-app-layout/HkAppLayout.state.svelte.d.ts +6 -0
  197. package/dist/{components → ui/components}/hk-app-layout/HkAppLayout.state.svelte.js +25 -25
  198. package/dist/{components → ui/components}/hk-app-layout/HkAppLayout.svelte +251 -251
  199. package/dist/{components → ui/components}/image-box/ImageBox.svelte +210 -210
  200. package/dist/{components → ui/components}/image-box/ImageBox.svelte.d.ts +6 -6
  201. package/dist/ui/components/image-box/index.js +5 -0
  202. package/dist/{components → ui/components}/image-box/typedef.js +32 -32
  203. package/dist/{components → ui/components}/index.js +23 -23
  204. package/dist/{components → ui/components}/presenter/ImageSlide.svelte +64 -64
  205. package/dist/{components → ui/components}/presenter/ImageSlide.svelte.d.ts +2 -2
  206. package/dist/{components → ui/components}/presenter/Presenter.state.svelte.d.ts +1 -1
  207. package/dist/{components → ui/components}/presenter/Presenter.state.svelte.js +638 -638
  208. package/dist/{components → ui/components}/presenter/Presenter.svelte +142 -142
  209. package/dist/{components → ui/components}/presenter/constants.js +7 -7
  210. package/dist/{components → ui/components}/presenter/index.js +10 -10
  211. package/dist/{components → ui/components}/presenter/typedef.js +106 -106
  212. package/dist/{components → ui/components}/presenter/util.js +210 -210
  213. package/dist/{components → ui/components}/virtual-viewport/VirtualViewport.svelte +196 -196
  214. package/dist/{primitives → ui/primitives}/area/HkArea.svelte +49 -49
  215. package/dist/{primitives → ui/primitives}/area/HkGridArea.svelte +77 -77
  216. package/dist/{primitives → ui/primitives}/area/index.js +2 -2
  217. package/dist/{primitives → ui/primitives}/buttons/button/Button.svelte +82 -82
  218. package/dist/{primitives → ui/primitives}/buttons/button/Button.svelte.d.ts +1 -1
  219. package/dist/{primitives → ui/primitives}/buttons/button-icon-steeze/SteezeIconButton.svelte +30 -30
  220. package/dist/{primitives → ui/primitives}/buttons/button-text/TextButton.svelte +21 -21
  221. package/dist/{primitives → ui/primitives}/buttons/index.js +3 -3
  222. package/dist/{primitives → ui/primitives}/debug/debug-panel-design-scaling/DebugPanelDesignScaling.svelte +146 -146
  223. package/dist/{primitives → ui/primitives}/debug/index.js +1 -1
  224. package/dist/{primitives → ui/primitives}/drag-drop/DragController.js +44 -44
  225. package/dist/{primitives → ui/primitives}/drag-drop/DragDropContext.svelte +111 -111
  226. package/dist/{primitives → ui/primitives}/drag-drop/DragDropContext.svelte.d.ts +1 -1
  227. package/dist/{primitives → ui/primitives}/drag-drop/Draggable.svelte +519 -519
  228. package/dist/{primitives → ui/primitives}/drag-drop/Draggable.svelte.d.ts +1 -1
  229. package/dist/{primitives → ui/primitives}/drag-drop/DropZone.svelte +258 -258
  230. package/dist/{primitives → ui/primitives}/drag-drop/DropZone.svelte.d.ts +3 -3
  231. package/dist/{primitives → ui/primitives}/drag-drop/DropZoneArea.svelte +119 -119
  232. package/dist/{primitives → ui/primitives}/drag-drop/DropZoneArea.svelte.d.ts +3 -3
  233. package/dist/{primitives → ui/primitives}/drag-drop/DropZoneList.svelte +125 -125
  234. package/dist/{primitives → ui/primitives}/drag-drop/DropZoneList.svelte.d.ts +3 -3
  235. package/dist/{primitives → ui/primitives}/drag-drop/actions.js +26 -26
  236. package/dist/{primitives → ui/primitives}/drag-drop/drag-state.svelte.d.ts +11 -11
  237. package/dist/{primitives → ui/primitives}/drag-drop/drag-state.svelte.js +322 -322
  238. package/dist/{primitives → ui/primitives}/drag-drop/index.js +7 -7
  239. package/dist/{primitives → ui/primitives}/drag-drop/util.js +85 -85
  240. package/dist/{primitives → ui/primitives}/hkdev/blocks/TextBlock.svelte +46 -46
  241. package/dist/{primitives → ui/primitives}/hkdev/buttons/CheckButton.svelte +62 -62
  242. package/dist/{primitives → ui/primitives}/icons/HkIcon.svelte +86 -86
  243. package/dist/{primitives → ui/primitives}/icons/HkTabIcon.svelte +116 -116
  244. package/dist/{primitives → ui/primitives}/icons/SteezeIcon.svelte +97 -97
  245. package/dist/{primitives → ui/primitives}/icons/index.js +6 -6
  246. package/dist/{primitives → ui/primitives}/icons/typedef.js +16 -16
  247. package/dist/{primitives → ui/primitives}/index.js +2 -2
  248. package/dist/{primitives → ui/primitives}/inputs/index.js +1 -1
  249. package/dist/{primitives → ui/primitives}/inputs/text-input/TextInput.svelte +223 -223
  250. package/dist/{primitives → ui/primitives}/inputs/text-input/assets/IconInvalid.svelte +14 -14
  251. package/dist/{primitives → ui/primitives}/inputs/text-input/assets/IconValid.svelte +12 -12
  252. package/dist/{primitives → ui/primitives}/layout/grid-layers/GridLayers.svelte +63 -63
  253. package/dist/{primitives → ui/primitives}/layout/grid-layers/util.js +74 -74
  254. package/dist/{primitives → ui/primitives}/layout/index.js +1 -1
  255. package/dist/{primitives → ui/primitives}/panels/index.js +1 -1
  256. package/dist/{primitives → ui/primitives}/panels/panel/Panel.svelte +43 -43
  257. package/dist/{primitives → ui/primitives}/rows/index.js +3 -3
  258. package/dist/{primitives → ui/primitives}/rows/panel-grid-row/PanelGridRow.svelte +104 -104
  259. package/dist/{primitives → ui/primitives}/rows/panel-row-2/PanelRow2.svelte +40 -40
  260. package/dist/{primitives → ui/primitives}/tab-bar/HkTabBar.state.svelte.d.ts +3 -3
  261. package/dist/{primitives → ui/primitives}/tab-bar/HkTabBar.state.svelte.js +149 -149
  262. package/dist/{primitives → ui/primitives}/tab-bar/HkTabBar.svelte +74 -74
  263. package/dist/{primitives → ui/primitives}/tab-bar/HkTabBarSelector.state.svelte.d.ts +3 -3
  264. package/dist/{primitives → ui/primitives}/tab-bar/HkTabBarSelector.state.svelte.js +93 -93
  265. package/dist/{primitives → ui/primitives}/tab-bar/HkTabBarSelector.svelte +49 -49
  266. package/dist/{primitives → ui/primitives}/tab-bar/index.js +17 -17
  267. package/dist/{primitives → ui/primitives}/tab-bar/typedef.js +11 -11
  268. package/dist/util/array/index.js +436 -436
  269. package/dist/util/bases/base58.js +262 -262
  270. package/dist/util/bases/index.js +1 -1
  271. package/dist/util/compare/index.js +247 -247
  272. package/dist/util/css/css-vars.js +83 -83
  273. package/dist/util/css/index.js +1 -1
  274. package/dist/util/env/index.js +9 -9
  275. package/dist/util/exceptions/index.js +23 -23
  276. package/dist/util/expect/arrays.js +47 -47
  277. package/dist/util/expect/index.js +259 -259
  278. package/dist/util/expect/primitives.js +55 -55
  279. package/dist/util/expect/url.d.ts +6 -6
  280. package/dist/util/expect/url.js +60 -60
  281. package/dist/util/function/index.js +218 -218
  282. package/dist/util/geo/index.js +26 -26
  283. package/dist/util/index.d.ts +3 -1
  284. package/dist/util/index.js +7 -3
  285. package/dist/util/is/index.d.ts +15 -14
  286. package/dist/util/is/index.js +147 -140
  287. package/dist/util/iterate/index.d.ts +37 -69
  288. package/dist/util/iterate/index.js +204 -234
  289. package/dist/util/object/index.d.ts +38 -57
  290. package/dist/util/object/index.js +1345 -1361
  291. package/dist/util/singleton/index.js +97 -97
  292. package/dist/util/string/array-path.js +75 -75
  293. package/dist/util/string/convert.js +54 -54
  294. package/dist/util/string/fs.js +226 -226
  295. package/dist/util/string/index.js +5 -5
  296. package/dist/util/string/interpolate.js +61 -61
  297. package/dist/util/string/pad.js +10 -10
  298. package/dist/util/svelte/index.js +4 -4
  299. package/dist/util/svelte/loading/loading-tracker.svelte.js +108 -108
  300. package/dist/util/svelte/observe/index.js +49 -49
  301. package/dist/util/svelte/state-context/index.js +117 -117
  302. package/dist/util/svelte/wait/index.js +38 -38
  303. package/dist/util/sveltekit/index.js +1 -1
  304. package/dist/util/sveltekit/route-folders/index.js +101 -101
  305. package/dist/util/time/index.js +328 -323
  306. package/dist/util/unique/index.js +231 -249
  307. package/dist/valibot/README.md +50 -0
  308. package/dist/valibot/index.d.ts +4 -4
  309. package/dist/valibot/index.js +8 -9
  310. package/dist/valibot/{url.d.ts → parsers/url.d.ts} +13 -5
  311. package/dist/valibot/{url.js → parsers/url.js} +111 -95
  312. package/dist/valibot/{user.js → parsers/user.js} +23 -23
  313. package/dist/valibot/parsers.d.ts +2 -0
  314. package/dist/valibot/parsers.js +4 -0
  315. package/package.json +131 -133
  316. package/dist/components/hk-app-layout/HkAppLayout.state.svelte.d.ts +0 -6
  317. package/dist/components/image-box/index.js +0 -5
  318. package/dist/constants/regexp/web.d.ts +0 -1
  319. package/dist/constants/regexp/web.js +0 -3
  320. package/dist/primitives/inputs/text-input/TestTextInput.svelte__ +0 -102
  321. package/dist/primitives/inputs/text-input/TextInput.svelte___ +0 -83
  322. package/dist/primitives/layout/grid-layers/GridLayers.svelte__heightFrom__ +0 -372
  323. package/dist/schemas/index.d.ts +0 -1
  324. package/dist/schemas/index.js +0 -1
  325. package/dist/schemas/validate-url.d.ts +0 -30
  326. package/dist/schemas/validate-url.js +0 -180
  327. package/dist/themes/hkdev/debug.css +0 -2
  328. package/dist/themes/index.d.ts +0 -1
  329. package/dist/themes/index.js +0 -1
  330. package/dist/util/design-system/index.d.ts +0 -5
  331. package/dist/util/design-system/index.js +0 -5
  332. package/dist/util/http/test-data__/content-length-test-hkdigital-small.V4HfZyBQ.avif +0 -0
  333. package/dist/valibot/date.js__ +0 -10
  334. package/dist/zod/all.d.ts +0 -6
  335. package/dist/zod/all.js +0 -33
  336. package/dist/zod/generic.d.ts +0 -6
  337. package/dist/zod/generic.js +0 -11
  338. package/dist/zod/javascript.d.ts +0 -8
  339. package/dist/zod/javascript.js +0 -32
  340. package/dist/zod/user.d.ts +0 -9
  341. package/dist/zod/user.js +0 -16
  342. package/dist/zod/web.d.ts +0 -21
  343. package/dist/zod/web.js +0 -52
  344. /package/dist/config/{imagetools-config.d.ts → generators/imagetools.d.ts} +0 -0
  345. /package/dist/design/{design-config.d.ts → config/design-config.d.ts} +0 -0
  346. /package/dist/{util/design-system/tailwind.d.ts → design/generators/index.d.ts} +0 -0
  347. /package/dist/{util/design-system → design/plugins}/skeleton.d.ts +0 -0
  348. /package/dist/{themes → design/themes}/hkdev/theme-ext.d.ts +0 -0
  349. /package/dist/{util/design-system/css → design/utils}/clamp.d.ts +0 -0
  350. /package/dist/{util/design-system/layout → design/utils}/scaling.d.ts +0 -0
  351. /package/dist/{util/design-system/components → design/utils}/states.d.ts +0 -0
  352. /package/dist/{classes → network}/cache/IndexedDbCache.d.ts +0 -0
  353. /package/dist/{classes → network}/cache/MemoryResponseCache.d.ts +0 -0
  354. /package/dist/{classes → network}/cache/index.d.ts +0 -0
  355. /package/dist/{classes → network}/cache/typedef.d.ts +0 -0
  356. /package/dist/{util → network}/http/caching.d.ts +0 -0
  357. /package/dist/{util → network}/http/errors.d.ts +0 -0
  358. /package/dist/{util → network}/http/headers.d.ts +0 -0
  359. /package/dist/{util → network}/http/http-request.d.ts +0 -0
  360. /package/dist/{util → network}/http/index.d.ts +0 -0
  361. /package/dist/{util → network}/http/json-request.d.ts +0 -0
  362. /package/dist/{util → network}/http/mocks.d.ts +0 -0
  363. /package/dist/{util → network}/http/response.d.ts +0 -0
  364. /package/dist/{util → network}/http/typedef.d.ts +0 -0
  365. /package/dist/{util → network}/http/url.d.ts +0 -0
  366. /package/dist/{classes/svelte → network/loaders}/audio/AudioScene.svelte.d.ts +0 -0
  367. /package/dist/{classes/svelte → network/loaders}/audio/mocks.d.ts +0 -0
  368. /package/dist/{classes/svelte → network/loaders}/image/index.d.ts +0 -0
  369. /package/dist/{classes/svelte → network/loaders}/image/mocks.d.ts +0 -0
  370. /package/dist/{classes/svelte → network/loaders}/image/typedef.d.ts +0 -0
  371. /package/dist/{typedef/image.d.ts → network/loaders/typedef.d.ts} +0 -0
  372. /package/dist/{classes/svelte/network-loader → network/states}/constants.d.ts +0 -0
  373. /package/dist/{classes/svelte/network-loader → network/states}/index.d.ts +0 -0
  374. /package/dist/{classes/svelte/network-loader → network/states}/mocks.d.ts +0 -0
  375. /package/dist/{classes/svelte/network-loader → network/states}/typedef.d.ts +0 -0
  376. /package/dist/{components → ui/components}/button-group/ButtonGroup.svelte.d.ts +0 -0
  377. /package/dist/{components → ui/components}/button-group/typedef.d.ts +0 -0
  378. /package/dist/{components → ui/components}/compare-left-right/CompareLeftRight.svelte.d.ts +0 -0
  379. /package/dist/{components → ui/components}/compare-left-right/index.d.ts +0 -0
  380. /package/dist/{components → ui/components}/game-box/GameBox.svelte.d.ts +0 -0
  381. /package/dist/{components → ui/components}/game-box/gamebox.util.d.ts +0 -0
  382. /package/dist/{components → ui/components}/hk-app-layout/HkAppLayout.svelte.d.ts +0 -0
  383. /package/dist/{components → ui/components}/image-box/index.d.ts +0 -0
  384. /package/dist/{components → ui/components}/image-box/typedef.d.ts +0 -0
  385. /package/dist/{components → ui/components}/index.d.ts +0 -0
  386. /package/dist/{components → ui/components}/presenter/Presenter.svelte.d.ts +0 -0
  387. /package/dist/{components → ui/components}/presenter/constants.d.ts +0 -0
  388. /package/dist/{components → ui/components}/presenter/index.d.ts +0 -0
  389. /package/dist/{components → ui/components}/presenter/typedef.d.ts +0 -0
  390. /package/dist/{components → ui/components}/presenter/util.d.ts +0 -0
  391. /package/dist/{components → ui/components}/virtual-viewport/VirtualViewport.svelte.d.ts +0 -0
  392. /package/dist/{primitives → ui/primitives}/area/HkArea.svelte.d.ts +0 -0
  393. /package/dist/{primitives → ui/primitives}/area/HkGridArea.svelte.d.ts +0 -0
  394. /package/dist/{primitives → ui/primitives}/area/index.d.ts +0 -0
  395. /package/dist/{primitives → ui/primitives}/buttons/button-icon-steeze/SteezeIconButton.svelte.d.ts +0 -0
  396. /package/dist/{primitives → ui/primitives}/buttons/button-text/TextButton.svelte.d.ts +0 -0
  397. /package/dist/{primitives → ui/primitives}/buttons/index.d.ts +0 -0
  398. /package/dist/{primitives → ui/primitives}/debug/debug-panel-design-scaling/DebugPanelDesignScaling.svelte.d.ts +0 -0
  399. /package/dist/{primitives → ui/primitives}/debug/index.d.ts +0 -0
  400. /package/dist/{primitives → ui/primitives}/drag-drop/DragController.d.ts +0 -0
  401. /package/dist/{primitives → ui/primitives}/drag-drop/actions.d.ts +0 -0
  402. /package/dist/{primitives → ui/primitives}/drag-drop/index.d.ts +0 -0
  403. /package/dist/{primitives → ui/primitives}/drag-drop/util.d.ts +0 -0
  404. /package/dist/{primitives → ui/primitives}/hkdev/blocks/TextBlock.svelte.d.ts +0 -0
  405. /package/dist/{primitives → ui/primitives}/hkdev/buttons/CheckButton.svelte.d.ts +0 -0
  406. /package/dist/{primitives → ui/primitives}/icons/HkIcon.svelte.d.ts +0 -0
  407. /package/dist/{primitives → ui/primitives}/icons/HkTabIcon.svelte.d.ts +0 -0
  408. /package/dist/{primitives → ui/primitives}/icons/SteezeIcon.svelte.d.ts +0 -0
  409. /package/dist/{primitives → ui/primitives}/icons/index.d.ts +0 -0
  410. /package/dist/{primitives → ui/primitives}/icons/typedef.d.ts +0 -0
  411. /package/dist/{primitives → ui/primitives}/index.d.ts +0 -0
  412. /package/dist/{primitives → ui/primitives}/inputs/index.d.ts +0 -0
  413. /package/dist/{primitives → ui/primitives}/inputs/text-input/TextInput.svelte.d.ts +0 -0
  414. /package/dist/{primitives → ui/primitives}/inputs/text-input/assets/IconInvalid.svelte.d.ts +0 -0
  415. /package/dist/{primitives → ui/primitives}/inputs/text-input/assets/IconValid.svelte.d.ts +0 -0
  416. /package/dist/{primitives → ui/primitives}/layout/grid-layers/GridLayers.svelte.d.ts +0 -0
  417. /package/dist/{primitives → ui/primitives}/layout/grid-layers/util.d.ts +0 -0
  418. /package/dist/{primitives → ui/primitives}/layout/index.d.ts +0 -0
  419. /package/dist/{primitives → ui/primitives}/panels/index.d.ts +0 -0
  420. /package/dist/{primitives → ui/primitives}/panels/panel/Panel.svelte.d.ts +0 -0
  421. /package/dist/{primitives → ui/primitives}/rows/index.d.ts +0 -0
  422. /package/dist/{primitives → ui/primitives}/rows/panel-grid-row/PanelGridRow.svelte.d.ts +0 -0
  423. /package/dist/{primitives → ui/primitives}/rows/panel-row-2/PanelRow2.svelte.d.ts +0 -0
  424. /package/dist/{primitives → ui/primitives}/tab-bar/HkTabBar.svelte.d.ts +0 -0
  425. /package/dist/{primitives → ui/primitives}/tab-bar/HkTabBarSelector.svelte.d.ts +0 -0
  426. /package/dist/{primitives → ui/primitives}/tab-bar/index.d.ts +0 -0
  427. /package/dist/{primitives → ui/primitives}/tab-bar/typedef.d.ts +0 -0
  428. /package/dist/valibot/{user.d.ts → parsers/user.d.ts} +0 -0
@@ -1,93 +1,93 @@
1
- /**
2
- * @typedef {Object} HttpRequestOptions
3
- * @property {string|URL} url URL string or URL object for the request
4
- * @property {string} [method] HTTP method to use (GET, POST, etc.)
5
- *
6
- * @property {Object|URLSearchParams} [urlSearchParams]
7
- * Parameters to add to the URL
8
- *
9
- * @property {*} [body] Request body (for POST, PUT, etc.)
10
- * @property {Object} [headers] HTTP headers as name-value pairs
11
- * @property {boolean} [withCredentials] Whether to include credentials
12
- * @property {number} [timeoutMs] Request timeout in milliseconds
13
- * @property {Function} [requestHandler] Handler for abort/timeout control
14
- * @property {string} [mode] CORS mode ('cors', 'no-cors', 'same-origin')
15
- * @property {string} [cache] Cache mode ('default', 'no-cache', etc.)
16
- * @property {string} [redirect] Redirect mode ('follow', 'error', 'manual')
17
- * @property {string} [referrerPolicy] Referrer policy
18
- * @property {boolean} [cacheEnabled] Enable or disabled automatic caching
19
- */
20
-
21
- /**
22
- * @typedef {Object} RequestHandlerParams
23
- *
24
- * @property {AbortController} controller
25
- * The AbortController instance for this request
26
- *
27
- * @property {(reason?: Error) => void} abort Function to abort the request
28
- * @property {(delayMs: number) => void} timeout Function to set a timeout
29
- */
30
-
31
- /**
32
- * @callback RequestHandler
33
- * @param {RequestHandlerParams} params Parameters for controlling the request
34
- * @returns {void}
35
- */
36
-
37
- /**
38
- * @typedef {Object} JsonGetOptions
39
- * @property {string|URL} url URL string or URL object for the request
40
- *
41
- * @property {Object|URLSearchParams} [urlSearchParams]
42
- * Parameters to add to the URL
43
- *
44
- * @property {Object} [headers] HTTP headers as name-value pairs
45
- * @property {boolean} [withCredentials] Whether to include credentials
46
- * @property {number} [timeoutMs] Request timeout in milliseconds
47
- * @property {RequestHandler} [requestHandler] Handler for abort/timeout control
48
- * @property {string} [mode] CORS mode ('cors', 'no-cors', 'same-origin')
49
- * @property {string} [cache] Cache mode ('default', 'no-cache', etc.)
50
- * @property {string} [redirect] Redirect mode ('follow', 'error', 'manual')
51
- * @property {string} [referrerPolicy] Referrer policy
52
- * @property {boolean} [cacheEnabled] Enable or disabled automatic caching
53
- */
54
-
55
- /**
56
- * @typedef {Object} JsonPostOptions
57
- * @property {string|URL} url URL string or URL object for the request
58
- * @property {*} body Request body (will be sent as JSON)
59
- *
60
- * @property {Object|URLSearchParams} [urlSearchParams]
61
- * Parameters to add to the URL
62
- *
63
- * @property {Object} [headers] HTTP headers as name-value pairs
64
- * @property {boolean} [withCredentials] Whether to include credentials
65
- * @property {number} [timeoutMs] Request timeout in milliseconds
66
- * @property {RequestHandler} [requestHandler] Handler for abort/timeout control
67
- * @property {string} [mode] CORS mode ('cors', 'no-cors', 'same-origin')
68
- * @property {string} [cache] Cache mode ('default', 'no-cache', etc.)
69
- * @property {string} [redirect] Redirect mode ('follow', 'error', 'manual')
70
- * @property {string} [referrerPolicy] Referrer policy
71
- * @property {boolean} [cacheEnabled] Enable or disabled automatic caching
72
- */
73
-
74
- /**
75
- * @typedef {Object} StaleInfo
76
- * @property {boolean} isStale Whether the response contains stale data
77
- *
78
- * @property {Promise<Response>|null} fresh
79
- * Promise that resolves to fresh data (if available)
80
- *
81
- * @property {number} timestamp When the response was originally cached
82
- * @property {number|null} expires When the response expires
83
- */
84
-
85
- /**
86
- * @typedef {Response} ResponseWithStale
87
- * @property {boolean} isStale Whether this response contains stale data
88
- *
89
- * @property {Promise<Response>|null} fresh
90
- * Promise for fresh data if this is stale
91
- */
92
-
93
- export {};
1
+ /**
2
+ * @typedef {Object} HttpRequestOptions
3
+ * @property {string|URL} url URL string or URL object for the request
4
+ * @property {string} [method] HTTP method to use (GET, POST, etc.)
5
+ *
6
+ * @property {Object|URLSearchParams} [urlSearchParams]
7
+ * Parameters to add to the URL
8
+ *
9
+ * @property {*} [body] Request body (for POST, PUT, etc.)
10
+ * @property {Object} [headers] HTTP headers as name-value pairs
11
+ * @property {boolean} [withCredentials] Whether to include credentials
12
+ * @property {number} [timeoutMs] Request timeout in milliseconds
13
+ * @property {Function} [requestHandler] Handler for abort/timeout control
14
+ * @property {string} [mode] CORS mode ('cors', 'no-cors', 'same-origin')
15
+ * @property {string} [cache] Cache mode ('default', 'no-cache', etc.)
16
+ * @property {string} [redirect] Redirect mode ('follow', 'error', 'manual')
17
+ * @property {string} [referrerPolicy] Referrer policy
18
+ * @property {boolean} [cacheEnabled] Enable or disabled automatic caching
19
+ */
20
+
21
+ /**
22
+ * @typedef {Object} RequestHandlerParams
23
+ *
24
+ * @property {AbortController} controller
25
+ * The AbortController instance for this request
26
+ *
27
+ * @property {(reason?: Error) => void} abort Function to abort the request
28
+ * @property {(delayMs: number) => void} timeout Function to set a timeout
29
+ */
30
+
31
+ /**
32
+ * @callback RequestHandler
33
+ * @param {RequestHandlerParams} params Parameters for controlling the request
34
+ * @returns {void}
35
+ */
36
+
37
+ /**
38
+ * @typedef {Object} JsonGetOptions
39
+ * @property {string|URL} url URL string or URL object for the request
40
+ *
41
+ * @property {Object|URLSearchParams} [urlSearchParams]
42
+ * Parameters to add to the URL
43
+ *
44
+ * @property {Object} [headers] HTTP headers as name-value pairs
45
+ * @property {boolean} [withCredentials] Whether to include credentials
46
+ * @property {number} [timeoutMs] Request timeout in milliseconds
47
+ * @property {RequestHandler} [requestHandler] Handler for abort/timeout control
48
+ * @property {string} [mode] CORS mode ('cors', 'no-cors', 'same-origin')
49
+ * @property {string} [cache] Cache mode ('default', 'no-cache', etc.)
50
+ * @property {string} [redirect] Redirect mode ('follow', 'error', 'manual')
51
+ * @property {string} [referrerPolicy] Referrer policy
52
+ * @property {boolean} [cacheEnabled] Enable or disabled automatic caching
53
+ */
54
+
55
+ /**
56
+ * @typedef {Object} JsonPostOptions
57
+ * @property {string|URL} url URL string or URL object for the request
58
+ * @property {*} body Request body (will be sent as JSON)
59
+ *
60
+ * @property {Object|URLSearchParams} [urlSearchParams]
61
+ * Parameters to add to the URL
62
+ *
63
+ * @property {Object} [headers] HTTP headers as name-value pairs
64
+ * @property {boolean} [withCredentials] Whether to include credentials
65
+ * @property {number} [timeoutMs] Request timeout in milliseconds
66
+ * @property {RequestHandler} [requestHandler] Handler for abort/timeout control
67
+ * @property {string} [mode] CORS mode ('cors', 'no-cors', 'same-origin')
68
+ * @property {string} [cache] Cache mode ('default', 'no-cache', etc.)
69
+ * @property {string} [redirect] Redirect mode ('follow', 'error', 'manual')
70
+ * @property {string} [referrerPolicy] Referrer policy
71
+ * @property {boolean} [cacheEnabled] Enable or disabled automatic caching
72
+ */
73
+
74
+ /**
75
+ * @typedef {Object} StaleInfo
76
+ * @property {boolean} isStale Whether the response contains stale data
77
+ *
78
+ * @property {Promise<Response>|null} fresh
79
+ * Promise that resolves to fresh data (if available)
80
+ *
81
+ * @property {number} timestamp When the response was originally cached
82
+ * @property {number|null} expires When the response expires
83
+ */
84
+
85
+ /**
86
+ * @typedef {Response} ResponseWithStale
87
+ * @property {boolean} isStale Whether this response contains stale data
88
+ *
89
+ * @property {Promise<Response>|null} fresh
90
+ * Promise for fresh data if this is stale
91
+ */
92
+
93
+ export {};
@@ -1,52 +1,52 @@
1
- import { TypeOrValueError } from '../../errors/index.js';
2
-
3
- /**
4
- * Returns an URL instance
5
- * - Prefixes the URL with the current orign if the url is relative
6
- *
7
- * @param {string|URL} url
8
- *
9
- * @returns {URL} url instance
10
- */
11
- export function toURL(url) {
12
- if (typeof url === 'string') {
13
- if (hasProtocol(url)) {
14
- return new URL(url);
15
- } else {
16
- // Use location.origin aas baseUrl
17
- return new URL(url, location.origin);
18
- }
19
- } else if (!(url instanceof URL)) {
20
- throw new TypeOrValueError('Missing or invalid parameter [url]');
21
- }
22
-
23
- // already an URL instance
24
- return url;
25
- }
26
-
27
- /**
28
- * Checks if the url starts with a protocol specification such
29
- * as https://
30
- *
31
- * @param {string} url
32
- *
33
- * @return {boolean} true if the value looks like an array
34
- */
35
- export function hasProtocol(url) {
36
- if (/^([a-zA-Z]{2,})s?:\/\//.test(url)) {
37
- return true;
38
- }
39
-
40
- return false;
41
- }
42
-
43
- /**
44
- * Convert an url to an absolute url and apply decodeURI to
45
- * convert URI encoded characters to normal characters
46
- *
47
- * @param {string|URL} url
48
- */
49
- export function href(url) {
50
- const urlObj = toURL(url);
51
- return decodeURI(urlObj.href);
52
- }
1
+ import { TypeOrValueError } from '../../errors/index.js';
2
+
3
+ /**
4
+ * Returns an URL instance
5
+ * - Prefixes the URL with the current orign if the url is relative
6
+ *
7
+ * @param {string|URL} url
8
+ *
9
+ * @returns {URL} url instance
10
+ */
11
+ export function toURL(url) {
12
+ if (typeof url === 'string') {
13
+ if (hasProtocol(url)) {
14
+ return new URL(url);
15
+ } else {
16
+ // Use location.origin aas baseUrl
17
+ return new URL(url, location.origin);
18
+ }
19
+ } else if (!(url instanceof URL)) {
20
+ throw new TypeOrValueError('Missing or invalid parameter [url]');
21
+ }
22
+
23
+ // already an URL instance
24
+ return url;
25
+ }
26
+
27
+ /**
28
+ * Checks if the url starts with a protocol specification such
29
+ * as https://
30
+ *
31
+ * @param {string} url
32
+ *
33
+ * @return {boolean} true if the value looks like an array
34
+ */
35
+ export function hasProtocol(url) {
36
+ if (/^([a-zA-Z]{2,})s?:\/\//.test(url)) {
37
+ return true;
38
+ }
39
+
40
+ return false;
41
+ }
42
+
43
+ /**
44
+ * Convert an url to an absolute url and apply decodeURI to
45
+ * convert URI encoded characters to normal characters
46
+ *
47
+ * @param {string|URL} url
48
+ */
49
+ export function href(url) {
50
+ const urlObj = toURL(url);
51
+ return decodeURI(urlObj.href);
52
+ }
@@ -0,0 +1,6 @@
1
+ export * from "./http/headers.js";
2
+ export * from "./http/errors.js";
3
+ export * from "./http/url.js";
4
+ export * from "./http/response.js";
5
+ export * from "./http/http-request.js";
6
+ export * from "./http/json-request.js";
@@ -0,0 +1,6 @@
1
+ export * from './http/headers.js';
2
+ export * from './http/errors.js';
3
+ export * from './http/url.js';
4
+ export * from './http/response.js';
5
+ export * from './http/http-request.js';
6
+ export * from './http/json-request.js';
@@ -0,0 +1,255 @@
1
+ # Media Loaders
2
+
3
+ Advanced media loading and processing classes for audio and images with loading state management, streaming support, and responsive image handling.
4
+
5
+ ## Quick Start
6
+
7
+ ```javascript
8
+ import * as image from '$lib/network/loaders.js';
9
+ import * as audio from '$lib/network/loaders.js';
10
+ ```
11
+
12
+ ## Image Loaders
13
+
14
+ ### ImageLoader
15
+
16
+ Loads single images with chunked streaming and loading states.
17
+
18
+ ```javascript
19
+ import { ImageLoader } from '$lib/network/loaders.js';
20
+
21
+ // Create image loader with single image or responsive variants
22
+ const imageSource = { src: '/path/to/image.jpg', width: 800, height: 600 };
23
+ const imageLoader = new ImageLoader({ imageSource });
24
+
25
+ // Start loading
26
+ imageLoader.load();
27
+
28
+ // Access loading states
29
+ console.log(imageLoader.loading); // true while loading
30
+ console.log(imageLoader.loaded); // true when complete
31
+ console.log(imageLoader.error); // error object if failed
32
+
33
+ // Get object URL when loaded
34
+ if (imageLoader.loaded) {
35
+ const objectURL = imageLoader.getObjectURL();
36
+ // Use objectURL in img src
37
+ }
38
+ ```
39
+
40
+ ### ImageVariantsLoader
41
+
42
+ Loads responsive image variants, automatically selecting the best size for container dimensions.
43
+
44
+ ```javascript
45
+ import { ImageVariantsLoader } from '$lib/network/loaders.js';
46
+
47
+ const loader = new ImageVariantsLoader();
48
+
49
+ // Load responsive variants
50
+ const imageSource = [
51
+ { src: '/image-400.jpg', width: 400, height: 300 },
52
+ { src: '/image-800.jpg', width: 800, height: 600 },
53
+ { src: '/image-1200.jpg', width: 1200, height: 900 }
54
+ ];
55
+
56
+ await loader.load({
57
+ imageSource,
58
+ containerWidth: 600,
59
+ containerHeight: 400,
60
+ fit: 'cover', // or 'contain', 'fill'
61
+ devicePixelRatio: window.devicePixelRatio
62
+ });
63
+ ```
64
+
65
+ ### ImageScene
66
+
67
+ High-level loader that manages multiple image sources with loading states.
68
+
69
+ ```javascript
70
+ import { ImageScene } from '$lib/network/loaders.js';
71
+
72
+ const imageScene = new ImageScene();
73
+
74
+ // Configure multiple image sources
75
+ imageScene.updateSources({
76
+ 'thumbnail': { src: '/thumb.jpg', width: 200, height: 150 },
77
+ 'full': { src: '/full.jpg', width: 1920, height: 1080 }
78
+ });
79
+
80
+ // Load specific source
81
+ imageScene.load('full');
82
+
83
+ // Monitor state changes
84
+ imageScene.state; // 'initial', 'loading', 'loaded', 'error'
85
+ ```
86
+
87
+ ## Audio Components
88
+
89
+ ### AudioLoader
90
+
91
+ Loads audio files with streaming support and loading state management.
92
+
93
+ ```javascript
94
+ import { AudioLoader } from '$lib/network/loaders.js';
95
+
96
+ const audioLoader = new AudioLoader({
97
+ url: '/path/to/audio.mp3'
98
+ });
99
+
100
+ // Start loading
101
+ audioLoader.load();
102
+
103
+ // Access audio data when loaded
104
+ if (audioLoader.loaded) {
105
+ const audioBuffer = audioLoader.getAudioBuffer();
106
+ const objectURL = audioLoader.getObjectURL();
107
+ }
108
+ ```
109
+
110
+ ### AudioScene
111
+
112
+ Manages multiple audio sources with scene-based loading.
113
+
114
+ ```javascript
115
+ import { AudioScene } from '$lib/network/loaders.js';
116
+
117
+ const audioScene = new AudioScene();
118
+
119
+ // Configure audio sources
120
+ audioScene.updateSources({
121
+ 'background': { url: '/bg-music.mp3' },
122
+ 'sfx': { url: '/sound-effect.wav' }
123
+ });
124
+
125
+ // Load and play audio
126
+ audioScene.load('background');
127
+ ```
128
+
129
+ ## Image Utilities
130
+
131
+ ### Responsive Image Helpers
132
+
133
+ ```javascript
134
+ import {
135
+ toSingleImageMeta,
136
+ calculateEffectiveWidth
137
+ } from '$lib/network/loaders/image/utils/index.js';
138
+
139
+ // Extract single image from array of variants
140
+ const imageMeta = toSingleImageMeta([
141
+ { src: '/small.jpg', width: 400, height: 300 },
142
+ { src: '/large.jpg', width: 800, height: 600 }
143
+ ]); // Returns the largest (last) image
144
+
145
+ // Calculate optimal width for container
146
+ const effectiveWidth = calculateEffectiveWidth({
147
+ containerWidth: 600,
148
+ containerHeight: 400,
149
+ imageAspectRatio: 16/9,
150
+ fit: 'contain' // or 'cover', 'fill'
151
+ });
152
+ ```
153
+
154
+ ## Loading States
155
+
156
+ All loaders implement consistent loading state management:
157
+
158
+ - **`initial`** - Not started loading
159
+ - **`loading`** - Currently loading
160
+ - **`loaded`** - Successfully loaded
161
+ - **`error`** - Failed to load
162
+ - **`cancelled`** - Loading was cancelled
163
+
164
+ ## Integration with SvelteKit
165
+
166
+ ### Using in Components
167
+
168
+ ```svelte
169
+ <script>
170
+ import { ImageLoader } from '$lib/network/loaders.js';
171
+ import { onMount } from 'svelte';
172
+
173
+ let imageLoader = $state();
174
+ let objectURL = $state();
175
+
176
+ const imageMeta = { src: '/image.jpg', width: 800, height: 600 };
177
+
178
+ onMount(() => {
179
+ imageLoader = new ImageLoader({ imageMeta });
180
+ imageLoader.load();
181
+ });
182
+
183
+ $effect(() => {
184
+ if (imageLoader?.loaded) {
185
+ objectURL = imageLoader.getObjectURL();
186
+ }
187
+
188
+ return () => {
189
+ if (objectURL) {
190
+ URL.revokeObjectURL(objectURL);
191
+ }
192
+ };
193
+ });
194
+ </script>
195
+
196
+ {#if objectURL}
197
+ <img src={objectURL} alt="Loaded image" />
198
+ {:else if imageLoader?.loading}
199
+ <p>Loading...</p>
200
+ {:else if imageLoader?.error}
201
+ <p>Error: {imageLoader.error.message}</p>
202
+ {/if}
203
+ ```
204
+
205
+ ### Responsive Images
206
+
207
+ ```svelte
208
+ <script>
209
+ import { ImageBox } from '$lib/ui/components/index.js';
210
+
211
+ // ImageBox uses ImageVariantsLoader internally
212
+ const imageSource = [
213
+ { src: '/image-400.jpg', width: 400, height: 300 },
214
+ { src: '/image-800.jpg', width: 800, height: 600 }
215
+ ];
216
+ </script>
217
+
218
+ <ImageBox
219
+ imageSource={imageSource}
220
+ width="600px"
221
+ height="400px"
222
+ fit="cover"
223
+ />
224
+ ```
225
+
226
+ ## Error Handling
227
+
228
+ ```javascript
229
+ try {
230
+ const imageLoader = new ImageLoader({ imageMeta });
231
+ await imageLoader.load();
232
+
233
+ if (imageLoader.error) {
234
+ console.error('Loading failed:', imageLoader.error);
235
+ }
236
+ } catch (error) {
237
+ console.error('Setup failed:', error);
238
+ }
239
+ ```
240
+
241
+ ## Available Exports
242
+
243
+ ### Image (`$lib/network/loaders.js`)
244
+ - `ImageLoader` - Single image loading with streaming
245
+ - `ImageVariantsLoader` - Responsive image variant selection
246
+
247
+ ### Audio (`$lib/network/loaders.js`)
248
+ - `AudioLoader` - Audio file loading with streaming
249
+ - `AudioScene` - Multi-source audio management
250
+
251
+ ### Utilities (`$lib/network/loaders/image/utils/`)
252
+ - `toSingleImageMeta()` - Extract single image from variants
253
+ - `calculateEffectiveWidth()` - Calculate optimal image dimensions
254
+
255
+ All loaders provide built-in loading states, error handling, and memory management with automatic cleanup of object URLs.
@@ -27,4 +27,4 @@ export default class AudioLoader extends NetworkLoader {
27
27
  getAudioBuffer(audioContext: AudioContext): Promise<AudioBuffer>;
28
28
  #private;
29
29
  }
30
- import { NetworkLoader } from '../network-loader/index.js';
30
+ import { NetworkLoader } from '../../states/index.js';
@@ -1,58 +1,58 @@
1
- import {
2
- NetworkLoader,
3
- ERROR_NOT_LOADED,
4
- ERROR_TRANSFERRED
5
- } from '../network-loader/index.js';
6
-
7
- /**
8
- * AudioLoader instance
9
- * - Loads audio data from network into an ArrayBuffer
10
- * - Loaded data can be transferred to an AudioBufferSourceNode
11
- */
12
- export default class AudioLoader extends NetworkLoader {
13
- /** @type {AudioBuffer|null} */
14
- #audioBuffer = null;
15
-
16
- /**
17
- * Get an AudioBufferSourceNode instance
18
- *
19
- * @note AudioBufferSourceNodes can play only once, a new source node
20
- * must be created otherwise
21
- *
22
- * @param {AudioContext} audioContext
23
- *
24
- * @returns {Promise<AudioBufferSourceNode>}
25
- */
26
- async getAudioBufferSourceNode(audioContext) {
27
- if (!this.#audioBuffer) {
28
- this.#audioBuffer = await this.getAudioBuffer(audioContext);
29
- }
30
-
31
- return new AudioBufferSourceNode(audioContext, {
32
- buffer: this.#audioBuffer
33
- });
34
- }
35
-
36
- /**
37
- * Gets data as AudioBuffer
38
- * - Stores created AudioBuffer instance internally
39
- * - Transfers data from internal ArrayBuffer, which will be detached
40
- *
41
- * @param {AudioContext} audioContext
42
- *
43
- * @returns {Promise<AudioBuffer>}
44
- */
45
- async getAudioBuffer(audioContext) {
46
- if (!this._buffer) {
47
- throw new Error(ERROR_NOT_LOADED);
48
- }
49
-
50
- if (this._buffer.detached) {
51
- throw new Error(ERROR_TRANSFERRED);
52
- }
53
-
54
- this.#audioBuffer = await audioContext.decodeAudioData(this._buffer);
55
-
56
- return this.#audioBuffer;
57
- }
58
- } // end class
1
+ import {
2
+ NetworkLoader,
3
+ ERROR_NOT_LOADED,
4
+ ERROR_TRANSFERRED
5
+ } from '../../states/index.js';
6
+
7
+ /**
8
+ * AudioLoader instance
9
+ * - Loads audio data from network into an ArrayBuffer
10
+ * - Loaded data can be transferred to an AudioBufferSourceNode
11
+ */
12
+ export default class AudioLoader extends NetworkLoader {
13
+ /** @type {AudioBuffer|null} */
14
+ #audioBuffer = null;
15
+
16
+ /**
17
+ * Get an AudioBufferSourceNode instance
18
+ *
19
+ * @note AudioBufferSourceNodes can play only once, a new source node
20
+ * must be created otherwise
21
+ *
22
+ * @param {AudioContext} audioContext
23
+ *
24
+ * @returns {Promise<AudioBufferSourceNode>}
25
+ */
26
+ async getAudioBufferSourceNode(audioContext) {
27
+ if (!this.#audioBuffer) {
28
+ this.#audioBuffer = await this.getAudioBuffer(audioContext);
29
+ }
30
+
31
+ return new AudioBufferSourceNode(audioContext, {
32
+ buffer: this.#audioBuffer
33
+ });
34
+ }
35
+
36
+ /**
37
+ * Gets data as AudioBuffer
38
+ * - Stores created AudioBuffer instance internally
39
+ * - Transfers data from internal ArrayBuffer, which will be detached
40
+ *
41
+ * @param {AudioContext} audioContext
42
+ *
43
+ * @returns {Promise<AudioBuffer>}
44
+ */
45
+ async getAudioBuffer(audioContext) {
46
+ if (!this._buffer) {
47
+ throw new Error(ERROR_NOT_LOADED);
48
+ }
49
+
50
+ if (this._buffer.detached) {
51
+ throw new Error(ERROR_TRANSFERRED);
52
+ }
53
+
54
+ this.#audioBuffer = await audioContext.decodeAudioData(this._buffer);
55
+
56
+ return this.#audioBuffer;
57
+ }
58
+ } // end class