@hkdigital/lib-core 0.3.1

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 (485) hide show
  1. package/README.md +149 -0
  2. package/dist/assets/autospuiten/car-paint-picker/army-green.jpg +0 -0
  3. package/dist/assets/autospuiten/car-paint-picker/electric-blue.jpg +0 -0
  4. package/dist/assets/autospuiten/car-paint-picker/lemon-yellow.jpg +0 -0
  5. package/dist/assets/autospuiten/car-paint-picker/opaque-purple.jpg +0 -0
  6. package/dist/assets/autospuiten/car-paint-picker/rusty.jpg +0 -0
  7. package/dist/assets/autospuiten/car-paint-picker/sunset-orange.jpg +0 -0
  8. package/dist/assets/autospuiten/car-paint-picker/tomato-red.jpg +0 -0
  9. package/dist/assets/autospuiten/car-paint-picker.d.ts +17 -0
  10. package/dist/assets/autospuiten/car-paint-picker.js +41 -0
  11. package/dist/assets/autospuiten/labels.d.ts +7 -0
  12. package/dist/assets/autospuiten/labels.js +7 -0
  13. package/dist/classes/cache/IndexedDbCache.d.ts +216 -0
  14. package/dist/classes/cache/IndexedDbCache.js +1407 -0
  15. package/dist/classes/cache/MemoryResponseCache.d.ts +106 -0
  16. package/dist/classes/cache/MemoryResponseCache.js +138 -0
  17. package/dist/classes/cache/index.d.ts +3 -0
  18. package/dist/classes/cache/index.js +5 -0
  19. package/dist/classes/cache/typedef.d.ts +67 -0
  20. package/dist/classes/cache/typedef.js +41 -0
  21. package/dist/classes/data/IterableTree.d.ts +51 -0
  22. package/dist/classes/data/IterableTree.js +243 -0
  23. package/dist/classes/data/Selector.d.ts +30 -0
  24. package/dist/classes/data/Selector.js +190 -0
  25. package/dist/classes/data/index.d.ts +2 -0
  26. package/dist/classes/data/index.js +2 -0
  27. package/dist/classes/events/EventEmitter.d.ts +142 -0
  28. package/dist/classes/events/EventEmitter.js +275 -0
  29. package/dist/classes/events/index.d.ts +1 -0
  30. package/dist/classes/events/index.js +2 -0
  31. package/dist/classes/index.d.ts +4 -0
  32. package/dist/classes/index.js +4 -0
  33. package/dist/classes/logging/Logger.d.ts +78 -0
  34. package/dist/classes/logging/Logger.js +210 -0
  35. package/dist/classes/logging/constants.d.ts +12 -0
  36. package/dist/classes/logging/constants.js +16 -0
  37. package/dist/classes/logging/index.d.ts +2 -0
  38. package/dist/classes/logging/index.js +4 -0
  39. package/dist/classes/logging/typedef.d.ts +34 -0
  40. package/dist/classes/logging/typedef.js +17 -0
  41. package/dist/classes/promise/HkPromise.d.ts +121 -0
  42. package/dist/classes/promise/HkPromise.js +377 -0
  43. package/dist/classes/promise/index.d.ts +1 -0
  44. package/dist/classes/promise/index.js +1 -0
  45. package/dist/classes/services/ServiceBase.d.ts +163 -0
  46. package/dist/classes/services/ServiceBase.js +463 -0
  47. package/dist/classes/services/ServiceManager.d.ts +179 -0
  48. package/dist/classes/services/ServiceManager.js +614 -0
  49. package/dist/classes/services/index.d.ts +4 -0
  50. package/dist/classes/services/index.js +5 -0
  51. package/dist/classes/services/service-states.d.ts +159 -0
  52. package/dist/classes/services/service-states.js +205 -0
  53. package/dist/classes/services/typedef.d.ts +247 -0
  54. package/dist/classes/services/typedef.js +179 -0
  55. package/dist/classes/stores/SubscribersCount.d.ts +39 -0
  56. package/dist/classes/stores/SubscribersCount.js +107 -0
  57. package/dist/classes/stores/index.d.ts +1 -0
  58. package/dist/classes/stores/index.js +1 -0
  59. package/dist/classes/streams/LogTransformStream.d.ts +4 -0
  60. package/dist/classes/streams/LogTransformStream.js +19 -0
  61. package/dist/classes/streams/ServerEventsStore.d.ts +22 -0
  62. package/dist/classes/streams/ServerEventsStore.js +110 -0
  63. package/dist/classes/streams/TimeStampSource.d.ts +13 -0
  64. package/dist/classes/streams/TimeStampSource.js +26 -0
  65. package/dist/classes/streams/index.d.ts +3 -0
  66. package/dist/classes/streams/index.js +3 -0
  67. package/dist/classes/svelte/audio/AudioLoader.svelte.d.ts +30 -0
  68. package/dist/classes/svelte/audio/AudioLoader.svelte.js +58 -0
  69. package/dist/classes/svelte/audio/AudioScene.svelte.d.ts +74 -0
  70. package/dist/classes/svelte/audio/AudioScene.svelte.js +324 -0
  71. package/dist/classes/svelte/audio/mocks.d.ts +7 -0
  72. package/dist/classes/svelte/audio/mocks.js +35 -0
  73. package/dist/classes/svelte/finite-state-machine/FiniteStateMachine.svelte.d.ts +50 -0
  74. package/dist/classes/svelte/finite-state-machine/FiniteStateMachine.svelte.js +133 -0
  75. package/dist/classes/svelte/finite-state-machine/index.d.ts +1 -0
  76. package/dist/classes/svelte/finite-state-machine/index.js +1 -0
  77. package/dist/classes/svelte/image/ImageLoader.svelte.d.ts +19 -0
  78. package/dist/classes/svelte/image/ImageLoader.svelte.js +45 -0
  79. package/dist/classes/svelte/image/ImageScene.svelte.d.ts +78 -0
  80. package/dist/classes/svelte/image/ImageScene.svelte.js +249 -0
  81. package/dist/classes/svelte/image/ImageVariantsLoader.svelte.d.ts +43 -0
  82. package/dist/classes/svelte/image/ImageVariantsLoader.svelte.js +152 -0
  83. package/dist/classes/svelte/image/index.d.ts +2 -0
  84. package/dist/classes/svelte/image/index.js +4 -0
  85. package/dist/classes/svelte/image/mocks.d.ts +7 -0
  86. package/dist/classes/svelte/image/mocks.js +35 -0
  87. package/dist/classes/svelte/image/typedef.d.ts +16 -0
  88. package/dist/classes/svelte/image/typedef.js +8 -0
  89. package/dist/classes/svelte/index.d.ts +9 -0
  90. package/dist/classes/svelte/index.js +14 -0
  91. package/dist/classes/svelte/loading-state-machine/LoadingStateMachine.svelte.d.ts +12 -0
  92. package/dist/classes/svelte/loading-state-machine/LoadingStateMachine.svelte.js +109 -0
  93. package/dist/classes/svelte/loading-state-machine/constants.d.ts +12 -0
  94. package/dist/classes/svelte/loading-state-machine/constants.js +16 -0
  95. package/dist/classes/svelte/loading-state-machine/index.d.ts +2 -0
  96. package/dist/classes/svelte/loading-state-machine/index.js +3 -0
  97. package/dist/classes/svelte/network-loader/NetworkLoader.svelte.d.ts +91 -0
  98. package/dist/classes/svelte/network-loader/NetworkLoader.svelte.js +338 -0
  99. package/dist/classes/svelte/network-loader/constants.d.ts +2 -0
  100. package/dist/classes/svelte/network-loader/constants.js +3 -0
  101. package/dist/classes/svelte/network-loader/index.d.ts +2 -0
  102. package/dist/classes/svelte/network-loader/index.js +3 -0
  103. package/dist/classes/svelte/network-loader/mocks.d.ts +7 -0
  104. package/dist/classes/svelte/network-loader/mocks.js +30 -0
  105. package/dist/classes/svelte/network-loader/typedef.d.ts +7 -0
  106. package/dist/classes/svelte/network-loader/typedef.js +8 -0
  107. package/dist/components/area/HkArea.svelte +49 -0
  108. package/dist/components/area/HkArea.svelte.d.ts +26 -0
  109. package/dist/components/area/HkGridArea.svelte +77 -0
  110. package/dist/components/area/HkGridArea.svelte.d.ts +42 -0
  111. package/dist/components/area/index.d.ts +2 -0
  112. package/dist/components/area/index.js +2 -0
  113. package/dist/components/buttons/button/Button.svelte +82 -0
  114. package/dist/components/buttons/button/Button.svelte.d.ts +44 -0
  115. package/dist/components/buttons/button-icon-steeze/SteezeIconButton.svelte +30 -0
  116. package/dist/components/buttons/button-icon-steeze/SteezeIconButton.svelte.d.ts +16 -0
  117. package/dist/components/buttons/button-text/TextButton.svelte +21 -0
  118. package/dist/components/buttons/button-text/TextButton.svelte.d.ts +12 -0
  119. package/dist/components/buttons/index.d.ts +3 -0
  120. package/dist/components/buttons/index.js +3 -0
  121. package/dist/components/debug/debug-panel-design-scaling/DebugPanelDesignScaling.svelte +146 -0
  122. package/dist/components/debug/debug-panel-design-scaling/DebugPanelDesignScaling.svelte.d.ts +6 -0
  123. package/dist/components/debug/index.d.ts +1 -0
  124. package/dist/components/debug/index.js +1 -0
  125. package/dist/components/drag-drop/DragController.d.ts +20 -0
  126. package/dist/components/drag-drop/DragController.js +44 -0
  127. package/dist/components/drag-drop/DragDropContext.svelte +111 -0
  128. package/dist/components/drag-drop/DragDropContext.svelte.d.ts +18 -0
  129. package/dist/components/drag-drop/Draggable.svelte +519 -0
  130. package/dist/components/drag-drop/Draggable.svelte.d.ts +95 -0
  131. package/dist/components/drag-drop/DropZone.svelte +258 -0
  132. package/dist/components/drag-drop/DropZone.svelte.d.ts +96 -0
  133. package/dist/components/drag-drop/DropZoneArea.svelte +119 -0
  134. package/dist/components/drag-drop/DropZoneArea.svelte.d.ts +90 -0
  135. package/dist/components/drag-drop/DropZoneList.svelte +125 -0
  136. package/dist/components/drag-drop/DropZoneList.svelte.d.ts +92 -0
  137. package/dist/components/drag-drop/actions.d.ts +9 -0
  138. package/dist/components/drag-drop/actions.js +26 -0
  139. package/dist/components/drag-drop/drag-state.svelte.d.ts +97 -0
  140. package/dist/components/drag-drop/drag-state.svelte.js +322 -0
  141. package/dist/components/drag-drop/index.d.ts +6 -0
  142. package/dist/components/drag-drop/index.js +7 -0
  143. package/dist/components/drag-drop/util.d.ts +0 -0
  144. package/dist/components/drag-drop/util.js +85 -0
  145. package/dist/components/hkdev/blocks/TextBlock.svelte +47 -0
  146. package/dist/components/hkdev/blocks/TextBlock.svelte.d.ts +24 -0
  147. package/dist/components/hkdev/buttons/CheckButton.svelte +63 -0
  148. package/dist/components/hkdev/buttons/CheckButton.svelte.d.ts +34 -0
  149. package/dist/components/icons/HkIcon.svelte +86 -0
  150. package/dist/components/icons/HkIcon.svelte.d.ts +22 -0
  151. package/dist/components/icons/HkTabIcon.svelte +116 -0
  152. package/dist/components/icons/HkTabIcon.svelte.d.ts +40 -0
  153. package/dist/components/icons/SteezeIcon.svelte +97 -0
  154. package/dist/components/icons/SteezeIcon.svelte.d.ts +22 -0
  155. package/dist/components/icons/index.d.ts +4 -0
  156. package/dist/components/icons/index.js +6 -0
  157. package/dist/components/icons/typedef.d.ts +13 -0
  158. package/dist/components/icons/typedef.js +16 -0
  159. package/dist/components/index.d.ts +0 -0
  160. package/dist/components/index.js +2 -0
  161. package/dist/components/inputs/index.d.ts +1 -0
  162. package/dist/components/inputs/index.js +1 -0
  163. package/dist/components/inputs/text-input/TestTextInput.svelte__ +102 -0
  164. package/dist/components/inputs/text-input/TextInput.svelte +223 -0
  165. package/dist/components/inputs/text-input/TextInput.svelte.d.ts +56 -0
  166. package/dist/components/inputs/text-input/TextInput.svelte___ +83 -0
  167. package/dist/components/inputs/text-input/assets/IconInvalid.svelte +14 -0
  168. package/dist/components/inputs/text-input/assets/IconInvalid.svelte.d.ts +26 -0
  169. package/dist/components/inputs/text-input/assets/IconValid.svelte +12 -0
  170. package/dist/components/inputs/text-input/assets/IconValid.svelte.d.ts +26 -0
  171. package/dist/components/layout/grid-layers/GridLayers.svelte +63 -0
  172. package/dist/components/layout/grid-layers/GridLayers.svelte.d.ts +26 -0
  173. package/dist/components/layout/grid-layers/GridLayers.svelte__heightFrom__ +372 -0
  174. package/dist/components/layout/grid-layers/util.d.ts +19 -0
  175. package/dist/components/layout/grid-layers/util.js +74 -0
  176. package/dist/components/layout/index.d.ts +1 -0
  177. package/dist/components/layout/index.js +1 -0
  178. package/dist/components/panels/index.d.ts +1 -0
  179. package/dist/components/panels/index.js +1 -0
  180. package/dist/components/panels/panel/Panel.svelte +43 -0
  181. package/dist/components/panels/panel/Panel.svelte.d.ts +24 -0
  182. package/dist/components/rows/index.d.ts +2 -0
  183. package/dist/components/rows/index.js +3 -0
  184. package/dist/components/rows/panel-grid-row/PanelGridRow.svelte +104 -0
  185. package/dist/components/rows/panel-grid-row/PanelGridRow.svelte.d.ts +26 -0
  186. package/dist/components/rows/panel-row-2/PanelRow2.svelte +40 -0
  187. package/dist/components/rows/panel-row-2/PanelRow2.svelte.d.ts +26 -0
  188. package/dist/components/tab-bar/HkTabBar.state.svelte.d.ts +54 -0
  189. package/dist/components/tab-bar/HkTabBar.state.svelte.js +149 -0
  190. package/dist/components/tab-bar/HkTabBar.svelte +74 -0
  191. package/dist/components/tab-bar/HkTabBar.svelte.d.ts +34 -0
  192. package/dist/components/tab-bar/HkTabBarSelector.state.svelte.d.ts +19 -0
  193. package/dist/components/tab-bar/HkTabBarSelector.state.svelte.js +93 -0
  194. package/dist/components/tab-bar/HkTabBarSelector.svelte +49 -0
  195. package/dist/components/tab-bar/HkTabBarSelector.svelte.d.ts +36 -0
  196. package/dist/components/tab-bar/index.d.ts +5 -0
  197. package/dist/components/tab-bar/index.js +17 -0
  198. package/dist/components/tab-bar/typedef.d.ts +8 -0
  199. package/dist/components/tab-bar/typedef.js +11 -0
  200. package/dist/config/imagetools-config.d.ts +26 -0
  201. package/dist/config/imagetools-config.js +189 -0
  202. package/dist/config/imagetools.d.ts +72 -0
  203. package/dist/constants/bases.d.ts +10 -0
  204. package/dist/constants/bases.js +13 -0
  205. package/dist/constants/errors/api.d.ts +10 -0
  206. package/dist/constants/errors/api.js +9 -0
  207. package/dist/constants/errors/generic.d.ts +20 -0
  208. package/dist/constants/errors/generic.js +20 -0
  209. package/dist/constants/errors/http.d.ts +16 -0
  210. package/dist/constants/errors/http.js +16 -0
  211. package/dist/constants/errors/index.d.ts +4 -0
  212. package/dist/constants/errors/index.js +4 -0
  213. package/dist/constants/errors/jwt.d.ts +8 -0
  214. package/dist/constants/errors/jwt.js +5 -0
  215. package/dist/constants/http/headers.d.ts +5 -0
  216. package/dist/constants/http/headers.js +6 -0
  217. package/dist/constants/http/index.d.ts +2 -0
  218. package/dist/constants/http/index.js +2 -0
  219. package/dist/constants/http/methods.d.ts +7 -0
  220. package/dist/constants/http/methods.js +14 -0
  221. package/dist/constants/index.d.ts +2 -0
  222. package/dist/constants/index.js +3 -0
  223. package/dist/constants/mime/application.d.ts +3 -0
  224. package/dist/constants/mime/application.js +5 -0
  225. package/dist/constants/mime/audio.d.ts +10 -0
  226. package/dist/constants/mime/audio.js +13 -0
  227. package/dist/constants/mime/image.d.ts +3 -0
  228. package/dist/constants/mime/image.js +3 -0
  229. package/dist/constants/mime/index.d.ts +4 -0
  230. package/dist/constants/mime/index.js +4 -0
  231. package/dist/constants/mime/text.d.ts +2 -0
  232. package/dist/constants/mime/text.js +2 -0
  233. package/dist/constants/regexp/index.d.ts +3 -0
  234. package/dist/constants/regexp/index.js +31 -0
  235. package/dist/constants/regexp/inspiratie.js__ +95 -0
  236. package/dist/constants/regexp/text.d.ts +47 -0
  237. package/dist/constants/regexp/text.js +49 -0
  238. package/dist/constants/regexp/user.d.ts +6 -0
  239. package/dist/constants/regexp/user.js +33 -0
  240. package/dist/constants/regexp/web.d.ts +1 -0
  241. package/dist/constants/regexp/web.js +3 -0
  242. package/dist/constants/state-labels/drag-states.d.ts +5 -0
  243. package/dist/constants/state-labels/drag-states.js +6 -0
  244. package/dist/constants/state-labels/drop-states.d.ts +4 -0
  245. package/dist/constants/state-labels/drop-states.js +6 -0
  246. package/dist/constants/state-labels/input-states.d.ts +8 -0
  247. package/dist/constants/state-labels/input-states.js +11 -0
  248. package/dist/constants/state-labels/submit-states.d.ts +4 -0
  249. package/dist/constants/state-labels/submit-states.js +4 -0
  250. package/dist/constants/time.d.ts +18 -0
  251. package/dist/constants/time.js +28 -0
  252. package/dist/css/utilities.css +43 -0
  253. package/dist/design/design-config.d.ts +157 -0
  254. package/dist/design/design-config.js +73 -0
  255. package/dist/design/tailwind-theme-extend.d.ts +23 -0
  256. package/dist/design/tailwind-theme-extend.js +158 -0
  257. package/dist/features/button-group/ButtonGroup.svelte +82 -0
  258. package/dist/features/button-group/ButtonGroup.svelte.d.ts +34 -0
  259. package/dist/features/button-group/typedef.d.ts +7 -0
  260. package/dist/features/button-group/typedef.js +10 -0
  261. package/dist/features/compare-left-right/CompareLeftRight.svelte +179 -0
  262. package/dist/features/compare-left-right/CompareLeftRight.svelte.d.ts +18 -0
  263. package/dist/features/compare-left-right/index.d.ts +1 -0
  264. package/dist/features/compare-left-right/index.js +1 -0
  265. package/dist/features/game-box/GameBox.svelte +577 -0
  266. package/dist/features/game-box/GameBox.svelte.d.ts +140 -0
  267. package/dist/features/game-box/gamebox.util.d.ts +32 -0
  268. package/dist/features/game-box/gamebox.util.js +83 -0
  269. package/dist/features/hk-app-layout/HkAppLayout.state.svelte.d.ts +6 -0
  270. package/dist/features/hk-app-layout/HkAppLayout.state.svelte.js +25 -0
  271. package/dist/features/hk-app-layout/HkAppLayout.svelte +251 -0
  272. package/dist/features/hk-app-layout/HkAppLayout.svelte.d.ts +19 -0
  273. package/dist/features/image-box/ImageBox.svelte +210 -0
  274. package/dist/features/image-box/ImageBox.svelte.d.ts +38 -0
  275. package/dist/features/image-box/index.d.ts +4 -0
  276. package/dist/features/image-box/index.js +5 -0
  277. package/dist/features/image-box/typedef.d.ts +4 -0
  278. package/dist/features/image-box/typedef.js +32 -0
  279. package/dist/features/index.d.ts +11 -0
  280. package/dist/features/index.js +23 -0
  281. package/dist/features/presenter/ImageSlide.svelte +64 -0
  282. package/dist/features/presenter/ImageSlide.svelte.d.ts +36 -0
  283. package/dist/features/presenter/Presenter.state.svelte.d.ts +74 -0
  284. package/dist/features/presenter/Presenter.state.svelte.js +638 -0
  285. package/dist/features/presenter/Presenter.svelte +142 -0
  286. package/dist/features/presenter/Presenter.svelte.d.ts +18 -0
  287. package/dist/features/presenter/constants.d.ts +5 -0
  288. package/dist/features/presenter/constants.js +7 -0
  289. package/dist/features/presenter/index.d.ts +6 -0
  290. package/dist/features/presenter/index.js +10 -0
  291. package/dist/features/presenter/typedef.d.ts +92 -0
  292. package/dist/features/presenter/typedef.js +106 -0
  293. package/dist/features/presenter/util.d.ts +63 -0
  294. package/dist/features/presenter/util.js +210 -0
  295. package/dist/features/virtual-viewport/VirtualViewport.svelte +196 -0
  296. package/dist/features/virtual-viewport/VirtualViewport.svelte.d.ts +42 -0
  297. package/dist/index.d.ts +0 -0
  298. package/dist/index.js +0 -0
  299. package/dist/logging/adapters/console.d.ts +48 -0
  300. package/dist/logging/adapters/console.js +114 -0
  301. package/dist/logging/adapters/pino.d.ts +25 -0
  302. package/dist/logging/adapters/pino.js +60 -0
  303. package/dist/logging/constants.d.ts +1 -0
  304. package/dist/logging/constants.js +1 -0
  305. package/dist/logging/factories/client.d.ts +10 -0
  306. package/dist/logging/factories/client.js +21 -0
  307. package/dist/logging/factories/server.d.ts +10 -0
  308. package/dist/logging/factories/server.js +22 -0
  309. package/dist/logging/factories/universal.d.ts +9 -0
  310. package/dist/logging/factories/universal.js +23 -0
  311. package/dist/logging/index.d.ts +5 -0
  312. package/dist/logging/index.js +8 -0
  313. package/dist/schemas/index.d.ts +1 -0
  314. package/dist/schemas/index.js +1 -0
  315. package/dist/schemas/validate-url.d.ts +30 -0
  316. package/dist/schemas/validate-url.js +180 -0
  317. package/dist/server/index.d.ts +1 -0
  318. package/dist/server/index.js +1 -0
  319. package/dist/server/logger.d.ts +25 -0
  320. package/dist/server/logger.js +94 -0
  321. package/dist/states/index.d.ts +1 -0
  322. package/dist/states/index.js +1 -0
  323. package/dist/states/navigation.svelte.d.ts +23 -0
  324. package/dist/states/navigation.svelte.js +55 -0
  325. package/dist/stores/index.d.ts +1 -0
  326. package/dist/stores/index.js +1 -0
  327. package/dist/stores/theme.d.ts +28 -0
  328. package/dist/stores/theme.js +80 -0
  329. package/dist/themes/hkdev/components/blocks/text-block.css +34 -0
  330. package/dist/themes/hkdev/components/boxes/game-box.css +11 -0
  331. package/dist/themes/hkdev/components/buttons/button-icon-steeze.css +22 -0
  332. package/dist/themes/hkdev/components/buttons/button-text.css +32 -0
  333. package/dist/themes/hkdev/components/buttons/button.css +146 -0
  334. package/dist/themes/hkdev/components/buttons/skip-button.css +5 -0
  335. package/dist/themes/hkdev/components/drag-drop/draggable.css +73 -0
  336. package/dist/themes/hkdev/components/drag-drop/drop-zone.css +58 -0
  337. package/dist/themes/hkdev/components/icons/icon-steeze.css +16 -0
  338. package/dist/themes/hkdev/components/inputs/text-input.css +102 -0
  339. package/dist/themes/hkdev/components/panels/panel.css +25 -0
  340. package/dist/themes/hkdev/components/rows/panel-grid-row.css +4 -0
  341. package/dist/themes/hkdev/components/rows/panel-row-2.css +5 -0
  342. package/dist/themes/hkdev/components.css +29 -0
  343. package/dist/themes/hkdev/debug.css +2 -0
  344. package/dist/themes/hkdev/global/layout.css +32 -0
  345. package/dist/themes/hkdev/global/on-colors.css +32 -0
  346. package/dist/themes/hkdev/globals.css +4 -0
  347. package/dist/themes/hkdev/responsive.css +12 -0
  348. package/dist/themes/hkdev/theme-ext.d.ts +4 -0
  349. package/dist/themes/hkdev/theme-ext.js +12 -0
  350. package/dist/themes/hkdev/theme.css +219 -0
  351. package/dist/themes/index.d.ts +1 -0
  352. package/dist/themes/index.js +1 -0
  353. package/dist/typedef/context.d.ts +3 -0
  354. package/dist/typedef/context.js +6 -0
  355. package/dist/typedef/drag.d.ts +29 -0
  356. package/dist/typedef/drag.js +25 -0
  357. package/dist/typedef/drop.d.ts +15 -0
  358. package/dist/typedef/drop.js +12 -0
  359. package/dist/typedef/image.d.ts +12 -0
  360. package/dist/typedef/image.js +38 -0
  361. package/dist/typedef/index.d.ts +4 -0
  362. package/dist/typedef/index.js +4 -0
  363. package/dist/util/array/index.d.ts +183 -0
  364. package/dist/util/array/index.js +436 -0
  365. package/dist/util/bases/base58.d.ts +58 -0
  366. package/dist/util/bases/base58.js +262 -0
  367. package/dist/util/bases/index.d.ts +1 -0
  368. package/dist/util/bases/index.js +1 -0
  369. package/dist/util/compare/index.d.ts +68 -0
  370. package/dist/util/compare/index.js +247 -0
  371. package/dist/util/css/css-vars.d.ts +24 -0
  372. package/dist/util/css/css-vars.js +83 -0
  373. package/dist/util/css/index.d.ts +1 -0
  374. package/dist/util/css/index.js +1 -0
  375. package/dist/util/design-system/components/states.d.ts +15 -0
  376. package/dist/util/design-system/components/states.js +22 -0
  377. package/dist/util/design-system/css/clamp.d.ts +17 -0
  378. package/dist/util/design-system/css/clamp.js +66 -0
  379. package/dist/util/design-system/css/root-design-vars.d.ts +77 -0
  380. package/dist/util/design-system/css/root-design-vars.js +102 -0
  381. package/dist/util/design-system/index.d.ts +5 -0
  382. package/dist/util/design-system/index.js +5 -0
  383. package/dist/util/design-system/layout/scaling.d.ts +98 -0
  384. package/dist/util/design-system/layout/scaling.js +228 -0
  385. package/dist/util/design-system/skeleton.d.ts +41 -0
  386. package/dist/util/design-system/skeleton.js +208 -0
  387. package/dist/util/design-system/tailwind.d.ts +183 -0
  388. package/dist/util/design-system/tailwind.js +288 -0
  389. package/dist/util/env/index.d.ts +1 -0
  390. package/dist/util/env/index.js +9 -0
  391. package/dist/util/exceptions/index.d.ts +15 -0
  392. package/dist/util/exceptions/index.js +23 -0
  393. package/dist/util/expect/arrays.d.ts +30 -0
  394. package/dist/util/expect/arrays.js +47 -0
  395. package/dist/util/expect/index.d.ts +103 -0
  396. package/dist/util/expect/index.js +259 -0
  397. package/dist/util/expect/primitives.d.ts +30 -0
  398. package/dist/util/expect/primitives.js +55 -0
  399. package/dist/util/expect/url.d.ts +32 -0
  400. package/dist/util/expect/url.js +60 -0
  401. package/dist/util/function/index.d.ts +34 -0
  402. package/dist/util/function/index.js +218 -0
  403. package/dist/util/geo/index.d.ts +10 -0
  404. package/dist/util/geo/index.js +26 -0
  405. package/dist/util/http/caching.d.ts +28 -0
  406. package/dist/util/http/caching.js +263 -0
  407. package/dist/util/http/errors.d.ts +18 -0
  408. package/dist/util/http/errors.js +97 -0
  409. package/dist/util/http/headers.d.ts +40 -0
  410. package/dist/util/http/headers.js +75 -0
  411. package/dist/util/http/http-request.d.ts +267 -0
  412. package/dist/util/http/http-request.js +578 -0
  413. package/dist/util/http/index.d.ts +6 -0
  414. package/dist/util/http/index.js +22 -0
  415. package/dist/util/http/json-request.d.ts +84 -0
  416. package/dist/util/http/json-request.js +224 -0
  417. package/dist/util/http/mocks.d.ts +20 -0
  418. package/dist/util/http/mocks.js +65 -0
  419. package/dist/util/http/response.d.ts +125 -0
  420. package/dist/util/http/response.js +294 -0
  421. package/dist/util/http/test-data__/content-length-test-hkdigital-small.V4HfZyBQ.avif +0 -0
  422. package/dist/util/http/typedef.d.ts +184 -0
  423. package/dist/util/http/typedef.js +93 -0
  424. package/dist/util/http/url.d.ts +25 -0
  425. package/dist/util/http/url.js +52 -0
  426. package/dist/util/image/index.d.ts +25 -0
  427. package/dist/util/image/index.js +86 -0
  428. package/dist/util/index.d.ts +3 -0
  429. package/dist/util/index.js +3 -0
  430. package/dist/util/is/index.d.ts +68 -0
  431. package/dist/util/is/index.js +140 -0
  432. package/dist/util/iterate/index.d.ts +131 -0
  433. package/dist/util/iterate/index.js +234 -0
  434. package/dist/util/object/index.d.ts +326 -0
  435. package/dist/util/object/index.js +1361 -0
  436. package/dist/util/singleton/index.d.ts +34 -0
  437. package/dist/util/singleton/index.js +97 -0
  438. package/dist/util/string/array-path.d.ts +15 -0
  439. package/dist/util/string/array-path.js +75 -0
  440. package/dist/util/string/convert.d.ts +22 -0
  441. package/dist/util/string/convert.js +54 -0
  442. package/dist/util/string/fs.d.ts +55 -0
  443. package/dist/util/string/fs.js +226 -0
  444. package/dist/util/string/index.d.ts +5 -0
  445. package/dist/util/string/index.js +5 -0
  446. package/dist/util/string/interpolate.d.ts +22 -0
  447. package/dist/util/string/interpolate.js +61 -0
  448. package/dist/util/string/pad.d.ts +8 -0
  449. package/dist/util/string/pad.js +10 -0
  450. package/dist/util/svelte/index.d.ts +3 -0
  451. package/dist/util/svelte/index.js +4 -0
  452. package/dist/util/svelte/loading/loading-tracker.svelte.d.ts +31 -0
  453. package/dist/util/svelte/loading/loading-tracker.svelte.js +108 -0
  454. package/dist/util/svelte/observe/index.d.ts +10 -0
  455. package/dist/util/svelte/observe/index.js +49 -0
  456. package/dist/util/svelte/state-context/index.d.ts +18 -0
  457. package/dist/util/svelte/state-context/index.js +117 -0
  458. package/dist/util/svelte/wait/index.d.ts +15 -0
  459. package/dist/util/svelte/wait/index.js +38 -0
  460. package/dist/util/sveltekit/index.d.ts +1 -0
  461. package/dist/util/sveltekit/index.js +1 -0
  462. package/dist/util/sveltekit/route-folders/index.d.ts +28 -0
  463. package/dist/util/sveltekit/route-folders/index.js +101 -0
  464. package/dist/util/time/index.d.ts +108 -0
  465. package/dist/util/time/index.js +323 -0
  466. package/dist/util/unique/index.d.ts +81 -0
  467. package/dist/util/unique/index.js +249 -0
  468. package/dist/valibot/date.js__ +10 -0
  469. package/dist/valibot/index.d.ts +4 -0
  470. package/dist/valibot/index.js +9 -0
  471. package/dist/valibot/url.d.ts +26 -0
  472. package/dist/valibot/url.js +95 -0
  473. package/dist/valibot/user.d.ts +6 -0
  474. package/dist/valibot/user.js +23 -0
  475. package/dist/zod/all.d.ts +6 -0
  476. package/dist/zod/all.js +33 -0
  477. package/dist/zod/generic.d.ts +6 -0
  478. package/dist/zod/generic.js +11 -0
  479. package/dist/zod/javascript.d.ts +8 -0
  480. package/dist/zod/javascript.js +32 -0
  481. package/dist/zod/user.d.ts +9 -0
  482. package/dist/zod/user.js +16 -0
  483. package/dist/zod/web.d.ts +21 -0
  484. package/dist/zod/web.js +52 -0
  485. package/package.json +133 -0
@@ -0,0 +1,85 @@
1
+ // import { createOrGetDragState } from './drag-state.svelte.js';
2
+
3
+ // /**
4
+ // * Find the source draggable element from an event
5
+ // *
6
+ // * @param {DragEvent} event
7
+ // * @returns {HTMLElement|null}
8
+ // */
9
+ // export function findDraggableSource(event) {
10
+ // const target = /** @type {Element|EventTarget|null} */ (event.target);
11
+
12
+ // if (!(target instanceof Element)) {
13
+ // return null;
14
+ // }
15
+
16
+ // let element = /** @type {Element|null} */ (target);
17
+
18
+ // // Walk up the DOM tree
19
+ // while (element !== null && element !== document.body) {
20
+ // if (element.hasAttribute('data-id')) {
21
+ // // Return as HTMLElement if needed
22
+ // return /** @type {HTMLElement} */ (element);
23
+ // }
24
+
25
+ // element = element.parentElement;
26
+ // }
27
+
28
+ // return null;
29
+ // }
30
+
31
+ // /**
32
+ // * Get draggable ID from an event, if available
33
+ // * @param {DragEvent} event
34
+ // * @returns {string|null}
35
+ // */
36
+ // export function getDraggableIdFromEvent(event) {
37
+ // const element = findDraggableSource(event);
38
+ // return element ? element.getAttribute('data-id') : null;
39
+ // }
40
+
41
+ // /**
42
+ // * Process a drop event with the provided data and handlers
43
+ // * @param {DragEvent} event
44
+ // * @param {any} data The drag data
45
+ // * @param {Object} options
46
+ // * @param {Function} options.onDropStart Optional drop start handler
47
+ // * @param {Function} options.onDrop Main drop handler
48
+ // * @param {Function} options.onDropEnd Optional drop end handler
49
+ // * @param {string} options.zone The drop zone identifier
50
+ // * @param {Function} options.setState Function to update component state
51
+ // * @returns {Promise<boolean>} Success status
52
+ // */
53
+ // export async function processDropWithData(
54
+ // event,
55
+ // data,
56
+ // { onDropStart, onDrop, onDropEnd, zone, setState }
57
+ // ) {
58
+ // try {
59
+ // // Update state and notify listeners
60
+ // setState('ACTIVE_DROP');
61
+ // onDropStart?.({ event, zone, data });
62
+
63
+ // // Call the onDrop handler
64
+ // const dropResult = onDrop?.({
65
+ // event,
66
+ // zone,
67
+ // item: data.item,
68
+ // source: data.source,
69
+ // metadata: data.metadata
70
+ // });
71
+
72
+ // // Handle async or sync results
73
+ // await Promise.resolve(dropResult);
74
+
75
+ // // Success path
76
+ // setState('READY');
77
+ // onDropEnd?.({ event, zone, data, success: true });
78
+ // return true;
79
+ // } catch (error) {
80
+ // // Error path
81
+ // setState('READY');
82
+ // onDropEnd?.({ event, zone, data, success: false, error });
83
+ // return false;
84
+ // }
85
+ // }
@@ -0,0 +1,47 @@
1
+ <script>
2
+ /**
3
+ * @type {{
4
+ * base?: string,
5
+ * bg?: string,
6
+ * classes?: string,
7
+ * title?: import('svelte').Snippet,
8
+ * content?: import('svelte').Snippet,
9
+ * footer?: import('svelte').Snippet
10
+ * } & { [attr: string]: * }}
11
+ */
12
+ let {
13
+ // Style
14
+ base,
15
+ bg,
16
+ classes,
17
+
18
+ // Content
19
+ title,
20
+ content,
21
+ footer,
22
+
23
+ // Attributes
24
+ ...attrs
25
+ } = $props();
26
+ </script>
27
+
28
+ <div data-title-text-button-block class="{base} {bg} {classes}" {...attrs}>
29
+ {#if title}
30
+ <h1 class="title-box h1">
31
+ {@render title()}
32
+ </h1>
33
+ {/if}
34
+
35
+ {#if content}
36
+ <div class="content-box">
37
+ {@render content()}
38
+ </div>
39
+ {/if}
40
+
41
+ {#if footer}
42
+ <div class="footer-box">
43
+ {@render footer()}
44
+ </div>
45
+ {/if}
46
+ </div>
47
+
@@ -0,0 +1,24 @@
1
+ export default TextBlock;
2
+ type TextBlock = {
3
+ $on?(type: string, callback: (e: any) => void): () => void;
4
+ $set?(props: Partial<{
5
+ base?: string;
6
+ bg?: string;
7
+ classes?: string;
8
+ title?: Snippet<[]>;
9
+ content?: Snippet<[]>;
10
+ footer?: Snippet<[]>;
11
+ } & {
12
+ [attr: string]: any;
13
+ }>): void;
14
+ };
15
+ declare const TextBlock: import("svelte").Component<{
16
+ base?: string;
17
+ bg?: string;
18
+ classes?: string;
19
+ title?: import("svelte").Snippet;
20
+ content?: import("svelte").Snippet;
21
+ footer?: import("svelte").Snippet;
22
+ } & {
23
+ [attr: string]: any;
24
+ }, {}, "">;
@@ -0,0 +1,63 @@
1
+ <script>
2
+ /**
3
+ *
4
+ * @type {{
5
+ * checked?: boolean,
6
+ * activeChild?: boolean,
7
+ * inactiveChild?: boolean,
8
+ * iconActiveBase?: string,
9
+ * classes?: string
10
+ * disabled?: boolean,
11
+ * title: string,
12
+ * iconInactiveBase?: string,
13
+ * inactiveClasses?: string,
14
+ * activeClasses: string,
15
+ * onclick?: () => void,
16
+ * onchange?: () => void,
17
+ * topic?: string,
18
+ * }}
19
+ */
20
+ let {
21
+ classes,
22
+ checked = $bindable(false),
23
+ iconInactiveBase = 'pointer-events-none',
24
+ iconActiveBase = 'pointer-events-none',
25
+ disabled = false,
26
+ topic,
27
+ title,
28
+ onchange = () => {},
29
+ inactiveChild,
30
+ activeChild,
31
+ activeClasses,
32
+ inactiveClasses,
33
+ onclick = () => {}
34
+ } = $props();
35
+
36
+
37
+ </script>
38
+
39
+ <button
40
+ class="variant-filled btn {classes} {checked
41
+ ? activeClasses
42
+ : inactiveClasses}"
43
+ >
44
+ {title}
45
+ {#if checked && activeChild}
46
+ <svg
47
+ width="10"
48
+ height="10"
49
+ viewBox="0 0 10 10"
50
+ fill="none"
51
+ xmlns="http://www.w3.org/2000/svg"
52
+ >
53
+ <path
54
+ d="M1 9L9 1M1 1L9 9"
55
+ stroke="white"
56
+ stroke-width="1.5"
57
+ stroke-linecap="round"
58
+ stroke-linejoin="round"
59
+ />
60
+ </svg>
61
+ {/if}
62
+ </button>
63
+
@@ -0,0 +1,34 @@
1
+ export default CheckButton;
2
+ type CheckButton = {
3
+ $on?(type: string, callback: (e: any) => void): () => void;
4
+ $set?(props: Partial<{
5
+ checked?: boolean;
6
+ activeChild?: boolean;
7
+ inactiveChild?: boolean;
8
+ iconActiveBase?: string;
9
+ classes?: string;
10
+ disabled?: boolean;
11
+ title: string;
12
+ iconInactiveBase?: string;
13
+ inactiveClasses?: string;
14
+ activeClasses: string;
15
+ onclick?: () => void;
16
+ onchange?: () => void;
17
+ topic?: string;
18
+ }>): void;
19
+ };
20
+ declare const CheckButton: import("svelte").Component<{
21
+ checked?: boolean;
22
+ activeChild?: boolean;
23
+ inactiveChild?: boolean;
24
+ iconActiveBase?: string;
25
+ classes?: string;
26
+ disabled?: boolean;
27
+ title: string;
28
+ iconInactiveBase?: string;
29
+ inactiveClasses?: string;
30
+ activeClasses: string;
31
+ onclick?: () => void;
32
+ onchange?: () => void;
33
+ topic?: string;
34
+ }, {}, "checked">;
@@ -0,0 +1,86 @@
1
+ <script>
2
+ /**
3
+ * Icon component
4
+ *
5
+ * Source code adapted from
6
+ * @see https://github.com/steeze-ui/icons
7
+ *
8
+ *
9
+ * Install icons
10
+ * For icon packs @see https://github.com/steeze-ui/icons
11
+ *
12
+ * @eg install Hero Icons
13
+ *
14
+ * pnpm add -D @steeze-ui/heroicons
15
+ */
16
+
17
+ /**
18
+ * Properties
19
+ * ----------
20
+ * src - icon component
21
+ * size - width and height of the icon as percentage (..%) or in pixels
22
+ * theme - name of the icon set theme (e.g. 'solid' or 'outline')
23
+ *
24
+ * @type {{
25
+ * src: import('./typedef.js').IconSource,
26
+ * size?: string,
27
+ * theme?: string,
28
+ * base?: string,
29
+ * classes?: string
30
+ * } & { [attr: string]: any }}
31
+ */
32
+ let {
33
+ src,
34
+ size = '100%',
35
+ theme = 'default',
36
+ base,
37
+ classes,
38
+ ...attrs
39
+ } = $props();
40
+
41
+ /** @type {any} */
42
+ let icon = $state();
43
+
44
+ $effect(() => {
45
+ icon = src?.[theme] ?? src?.['default'] ?? Object.values(src)?.[0];
46
+ });
47
+
48
+ if (size !== '100%') {
49
+ if (size.slice(-1) !== '%') {
50
+ try {
51
+ size = parseInt(size, 10) + 'px';
52
+ } catch (error) {
53
+ size = '100%';
54
+ }
55
+ }
56
+ }
57
+ </script>
58
+
59
+ <svg
60
+ data-hk-icon
61
+ {...icon?.a}
62
+ xmlns="http://www.w3.org/2000/svg"
63
+ width={size}
64
+ height={size}
65
+ class="{base} {classes}"
66
+ {...attrs}
67
+ >
68
+ {#each icon?.path ?? [] as a}
69
+ <path {...a} />
70
+ {/each}
71
+ {#each icon?.rect ?? [] as a}
72
+ <rect {...a} />
73
+ {/each}
74
+ {#each icon?.circle ?? [] as a}
75
+ <circle {...a} />
76
+ {/each}
77
+ {#each icon?.polygon ?? [] as a}
78
+ <polygon {...a} />
79
+ {/each}
80
+ {#each icon?.polyline ?? [] as a}
81
+ <polyline {...a} />
82
+ {/each}
83
+ {#each icon?.line ?? [] as a}
84
+ <line {...a} />
85
+ {/each}
86
+ </svg>
@@ -0,0 +1,22 @@
1
+ export default HkIcon;
2
+ type HkIcon = {
3
+ $on?(type: string, callback: (e: any) => void): () => void;
4
+ $set?(props: Partial<{
5
+ src: IconSource;
6
+ size?: string;
7
+ theme?: string;
8
+ base?: string;
9
+ classes?: string;
10
+ } & {
11
+ [attr: string]: any;
12
+ }>): void;
13
+ };
14
+ declare const HkIcon: import("svelte").Component<{
15
+ src: import("./typedef.js").IconSource;
16
+ size?: string;
17
+ theme?: string;
18
+ base?: string;
19
+ classes?: string;
20
+ } & {
21
+ [attr: string]: any;
22
+ }, {}, "">;
@@ -0,0 +1,116 @@
1
+ <script>
2
+ /**
3
+ * TabBarIcon component
4
+ *
5
+ * Following component guidelines from Skeleton
6
+ * @see https://next.skeleton.dev/docs/resources/contribute/components
7
+ */
8
+
9
+ // import { ElementRect } from 'runed';
10
+
11
+ import { onMount } from 'svelte';
12
+
13
+ import { HkGridArea } from '../area';
14
+
15
+ import HkIcon from './HkIcon.svelte';
16
+
17
+ /**
18
+ * Properties
19
+ * ----------
20
+ * src - icon component
21
+ * theme - name of the icon set theme (e.g. 'solid' or 'outline')
22
+ * label - text of the label to place below the icon
23
+ *
24
+ * @type {{
25
+ * src: import('./typedef.js').IconSource,
26
+ * iconTheme?: string,
27
+ * label?: string,
28
+ * route?: string,
29
+ * active?: boolean,
30
+ * base?: string,
31
+ * bg?: string,
32
+ * padding?: string,
33
+ * margin?: string,
34
+ * classes?: string,
35
+ * iconClasses? : string,
36
+ * iconHeight?: string,
37
+ * labelClasses? : string,
38
+ * rect?: DOMRect,
39
+ * } & { [attr: string]: any }}
40
+ *
41
+ *
42
+ */
43
+ let {
44
+ // Functional
45
+ src,
46
+ iconTheme,
47
+ label,
48
+ route,
49
+
50
+ active,
51
+
52
+ // Style
53
+ base,
54
+ bg,
55
+ padding,
56
+ margin,
57
+ classes,
58
+ iconClasses,
59
+ labelClasses,
60
+
61
+ // Event handlers
62
+ onmount,
63
+
64
+ // Rest attributes
65
+ ...attrs
66
+ } = $props();
67
+
68
+ /** @type {HTMLElement} */
69
+ let iconBoxElem;
70
+
71
+ onMount(() => {
72
+ onmount(iconBoxElem);
73
+ });
74
+ </script>
75
+
76
+ {#snippet contents()}
77
+ <div
78
+ data-hk--icon-box
79
+ class="flex aspect-square w-full justify-center"
80
+ bind:this={iconBoxElem}
81
+ >
82
+ <HkIcon {src} size="100%" theme={iconTheme} classes={iconClasses} />
83
+ </div>
84
+
85
+ {#if label}
86
+ <div data-hk--label class="flex w-full justify-center {labelClasses}">
87
+ {label}
88
+ </div>
89
+ {/if}
90
+ {/snippet}
91
+
92
+ <HkGridArea
93
+ data-hk-tab-icon
94
+ boxMargin={margin}
95
+ boxPadding={padding}
96
+ base="grid-cols-1 justify-items-center cursor-pointer break-all overflow-clip h-full
97
+ {active ? 'active' : ''}
98
+ {label ? 'hasLabel' : ''} {base}"
99
+ {bg}
100
+ {...attrs}
101
+ >
102
+ {#if !route}
103
+ {@render contents()}
104
+ {:else}
105
+ <a href={route}>
106
+ {@render contents()}
107
+ </a>
108
+ {/if}
109
+ </HkGridArea>
110
+
111
+ <style>
112
+ a {
113
+ display: block;
114
+ text-decoration: none;
115
+ }
116
+ </style>
@@ -0,0 +1,40 @@
1
+ export default HkTabIcon;
2
+ type HkTabIcon = {
3
+ $on?(type: string, callback: (e: any) => void): () => void;
4
+ $set?(props: Partial<{
5
+ src: IconSource;
6
+ iconTheme?: string;
7
+ label?: string;
8
+ route?: string;
9
+ active?: boolean;
10
+ base?: string;
11
+ bg?: string;
12
+ padding?: string;
13
+ margin?: string;
14
+ classes?: string;
15
+ iconClasses?: string;
16
+ iconHeight?: string;
17
+ labelClasses?: string;
18
+ rect?: DOMRect;
19
+ } & {
20
+ [attr: string]: any;
21
+ }>): void;
22
+ };
23
+ declare const HkTabIcon: import("svelte").Component<{
24
+ src: import("./typedef.js").IconSource;
25
+ iconTheme?: string;
26
+ label?: string;
27
+ route?: string;
28
+ active?: boolean;
29
+ base?: string;
30
+ bg?: string;
31
+ padding?: string;
32
+ margin?: string;
33
+ classes?: string;
34
+ iconClasses?: string;
35
+ iconHeight?: string;
36
+ labelClasses?: string;
37
+ rect?: DOMRect;
38
+ } & {
39
+ [attr: string]: any;
40
+ }, {}, "">;
@@ -0,0 +1,97 @@
1
+ <script>
2
+ /**
3
+ * Steeze like icon component
4
+ * The main difference with the original Steeze svelte component is that
5
+ * the component follows the conventions used for components in
6
+ * this library
7
+ *
8
+ * @see https://github.com/steeze-ui/icons
9
+ *
10
+ * Install icons
11
+ * For icon packs @see https://github.com/steeze-ui/icons
12
+ *
13
+ * @eg install Hero Icons
14
+ *
15
+ * pnpm add -D @steeze-ui/heroicons
16
+ */
17
+
18
+ /**
19
+ * Properties
20
+ * ----------
21
+ * src - icon component
22
+ * size - width and height of the icon as percentage (..%) or in pixels
23
+ * theme - name of the icon theme (e.g. 'solid' or 'outline')
24
+ *
25
+ * @type {{
26
+ * src: import('./typedef.js').IconSource,
27
+ * size?: string,
28
+ * theme?: string,
29
+ * base?: string,
30
+ * classes?: string
31
+ * } & { [attr: string]: any }}
32
+ */
33
+ let {
34
+ // Style
35
+ base,
36
+ classes,
37
+
38
+ size = 'md',
39
+ variant = '',
40
+
41
+ // Functional
42
+ src,
43
+ theme = 'default', // icon theme 'default'|'solid'|'outline'...
44
+
45
+ // States
46
+ // ...
47
+
48
+ // Attributes
49
+ ...attrs
50
+ } = $props();
51
+
52
+ /** @type {any} */
53
+ let icon = $state();
54
+
55
+ $effect(() => {
56
+ icon = src?.[theme] ?? src?.['default'] ?? Object.values(src)?.[0];
57
+ });
58
+
59
+ // if (size !== '100%') {
60
+ // if (size.slice(-1) !== '%') {
61
+ // try {
62
+ // size = parseInt(size, 10) + 'px';
63
+ // } catch (error) {
64
+ // size = '100%';
65
+ // }
66
+ // }
67
+ // }
68
+ </script>
69
+
70
+ <svg
71
+ data-component="icon"
72
+ data-type="steeze"
73
+ data-size={size}
74
+ {...icon?.a}
75
+ xmlns="http://www.w3.org/2000/svg"
76
+ class="{base} {classes}"
77
+ {...attrs}
78
+ >
79
+ {#each icon?.path ?? [] as a}
80
+ <path {...a} />
81
+ {/each}
82
+ {#each icon?.rect ?? [] as a}
83
+ <rect {...a} />
84
+ {/each}
85
+ {#each icon?.circle ?? [] as a}
86
+ <circle {...a} />
87
+ {/each}
88
+ {#each icon?.polygon ?? [] as a}
89
+ <polygon {...a} />
90
+ {/each}
91
+ {#each icon?.polyline ?? [] as a}
92
+ <polyline {...a} />
93
+ {/each}
94
+ {#each icon?.line ?? [] as a}
95
+ <line {...a} />
96
+ {/each}
97
+ </svg>
@@ -0,0 +1,22 @@
1
+ export default SteezeIcon;
2
+ type SteezeIcon = {
3
+ $on?(type: string, callback: (e: any) => void): () => void;
4
+ $set?(props: Partial<{
5
+ src: IconSource;
6
+ size?: string;
7
+ theme?: string;
8
+ base?: string;
9
+ classes?: string;
10
+ } & {
11
+ [attr: string]: any;
12
+ }>): void;
13
+ };
14
+ declare const SteezeIcon: import("svelte").Component<{
15
+ src: import("./typedef.js").IconSource;
16
+ size?: string;
17
+ theme?: string;
18
+ base?: string;
19
+ classes?: string;
20
+ } & {
21
+ [attr: string]: any;
22
+ }, {}, "">;
@@ -0,0 +1,4 @@
1
+ export { default as HkIcon } from "./HkIcon.svelte";
2
+ export { default as HkTabIcon } from "./HkTabIcon.svelte";
3
+ export { default as SteezeIcon } from "./SteezeIcon.svelte";
4
+ export * from "./typedef.js";
@@ -0,0 +1,6 @@
1
+ export { default as HkIcon } from './HkIcon.svelte';
2
+ export { default as HkTabIcon } from './HkTabIcon.svelte';
3
+
4
+ export { default as SteezeIcon } from './SteezeIcon.svelte';
5
+
6
+ export * from './typedef.js';
@@ -0,0 +1,13 @@
1
+ declare const _default: {};
2
+ export default _default;
3
+ export type AllowedTags = "path" | "circle" | "rect" | "polygon" | "polyline" | "line";
4
+ export type IconThemeSource = {
5
+ a: {
6
+ [attribute: string]: string;
7
+ };
8
+ } & { [tag in AllowedTags]?: {
9
+ [attribute: string]: string;
10
+ }[]; };
11
+ export type IconSource = {
12
+ [theme: string]: IconThemeSource;
13
+ };
@@ -0,0 +1,16 @@
1
+ /**
2
+ * @typedef {'path' | 'circle' | 'rect' | 'polygon' | 'polyline' | 'line'} AllowedTags
3
+ */
4
+
5
+ /**
6
+ * @typedef { { a: { [attribute: string]: string }} &
7
+ * { [tag in AllowedTags]?: { [attribute: string]: string }[] }
8
+ * } IconThemeSource
9
+ */
10
+
11
+ /**
12
+ * @typedef {{[theme: string]: IconThemeSource}} IconSource
13
+ */
14
+
15
+ // Export default is required for exporting typedefs
16
+ export default {};
File without changes
@@ -0,0 +1,2 @@
1
+ // export * as area from "./area/index.js";
2
+ // export * as icon from "./icon/index.js";
@@ -0,0 +1 @@
1
+ export { default as TextInput } from "./text-input/TextInput.svelte";