@hkdigital/lib-sveltekit 0.1.6 → 0.1.7

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 (215) hide show
  1. package/README.md +127 -127
  2. package/dist/classes/data/IterableTree.js +243 -243
  3. package/dist/classes/data/Selector.js +190 -190
  4. package/dist/classes/data/index.js +2 -2
  5. package/dist/classes/index.js +3 -3
  6. package/dist/classes/promise/HkPromise.js +377 -377
  7. package/dist/classes/promise/index.js +1 -1
  8. package/dist/classes/stores/SubscribersCount.js +107 -107
  9. package/dist/classes/stores/index.js +1 -1
  10. package/dist/classes/streams/LogTransformStream.js +19 -19
  11. package/dist/classes/streams/ServerEventsStore.js +110 -110
  12. package/dist/classes/streams/TimeStampSource.js +26 -26
  13. package/dist/classes/streams/index.js +3 -3
  14. package/dist/classes/svelte/audio/AudioLoader.svelte.js +58 -58
  15. package/dist/classes/svelte/audio/AudioScene.svelte.js +282 -282
  16. package/dist/classes/svelte/audio/mocks.js +35 -35
  17. package/dist/classes/svelte/final-state-machine/FiniteStateMachine.svelte.js +133 -133
  18. package/dist/classes/svelte/final-state-machine/index.js +1 -1
  19. package/dist/classes/svelte/image/ImageLoader.svelte.js +47 -47
  20. package/dist/classes/svelte/image/ImageScene.svelte.js +253 -253
  21. package/dist/classes/svelte/image/ImageVariantsLoader.svelte.js +152 -152
  22. package/dist/classes/svelte/image/index.js +4 -4
  23. package/dist/classes/svelte/image/mocks.js +35 -35
  24. package/dist/classes/svelte/image/typedef.js +8 -8
  25. package/dist/classes/svelte/loading-state-machine/LoadingStateMachine.svelte.js +109 -109
  26. package/dist/classes/svelte/loading-state-machine/constants.js +16 -16
  27. package/dist/classes/svelte/loading-state-machine/index.js +3 -3
  28. package/dist/classes/svelte/network-loader/NetworkLoader.svelte.js +331 -331
  29. package/dist/classes/svelte/network-loader/constants.js +3 -3
  30. package/dist/classes/svelte/network-loader/index.js +3 -3
  31. package/dist/classes/svelte/network-loader/mocks.js +30 -30
  32. package/dist/classes/svelte/network-loader/typedef.js +8 -8
  33. package/dist/components/area/HkArea.svelte +49 -49
  34. package/dist/components/area/HkArea.svelte.d.ts +14 -0
  35. package/dist/components/area/HkGridArea.svelte +77 -77
  36. package/dist/components/area/HkGridArea.svelte.d.ts +22 -0
  37. package/dist/components/area/index.js +2 -2
  38. package/dist/components/boxes/game-box/GameBox.svelte +112 -112
  39. package/dist/components/boxes/game-box/GameBox.svelte.d.ts +15 -0
  40. package/dist/components/boxes/game-box/gamebox.util.js +83 -83
  41. package/dist/components/boxes/index.js +2 -2
  42. package/dist/components/boxes/virtual-viewport/VirtualViewport.svelte +199 -199
  43. package/dist/components/boxes/virtual-viewport/VirtualViewport.svelte.d.ts +22 -0
  44. package/dist/components/buttons/button/Button.svelte +76 -75
  45. package/dist/components/buttons/button/Button.svelte.d.ts +21 -0
  46. package/dist/components/buttons/button-icon-steeze/SteezeIconButton.svelte +30 -0
  47. package/dist/components/buttons/button-icon-steeze/SteezeIconButton.svelte.d.ts +16 -0
  48. package/dist/components/buttons/button-text/TextButton.svelte +21 -21
  49. package/dist/components/buttons/button-text/TextButton.svelte.d.ts +7 -0
  50. package/dist/components/buttons/index.d.ts +1 -0
  51. package/dist/components/buttons/index.js +3 -2
  52. package/dist/components/hkdev/blocks/TextBlock.svelte +46 -46
  53. package/dist/components/hkdev/blocks/TextBlock.svelte.d.ts +13 -0
  54. package/dist/components/hkdev/buttons/CheckButton.svelte +62 -62
  55. package/dist/components/hkdev/buttons/CheckButton.svelte.d.ts +18 -0
  56. package/dist/components/{icon → icons}/HkIcon.svelte +86 -86
  57. package/dist/components/icons/HkIcon.svelte.d.ts +22 -0
  58. package/dist/components/{icon → icons}/HkTabIcon.svelte +116 -116
  59. package/dist/components/icons/HkTabIcon.svelte.d.ts +40 -0
  60. package/dist/components/icons/SteezeIcon.svelte +96 -0
  61. package/dist/components/icons/SteezeIcon.svelte.d.ts +22 -0
  62. package/dist/components/{icon → icons}/index.d.ts +1 -0
  63. package/dist/components/{icon → icons}/index.js +6 -4
  64. package/dist/components/{icon → icons}/typedef.js +16 -16
  65. package/dist/components/image/ImageBox.svelte +208 -208
  66. package/dist/components/image/ImageBox.svelte.d.ts +19 -0
  67. package/dist/components/image/index.js +5 -5
  68. package/dist/components/image/typedef.js +32 -32
  69. package/dist/components/index.js +2 -2
  70. package/dist/components/inputs/index.js +1 -1
  71. package/dist/components/inputs/text-input/TestTextInput.svelte__ +102 -102
  72. package/dist/components/inputs/text-input/TextInput.svelte +226 -226
  73. package/dist/components/inputs/text-input/TextInput.svelte.d.ts +28 -0
  74. package/dist/components/inputs/text-input/TextInput.svelte___ +83 -83
  75. package/dist/components/inputs/text-input/assets/IconInvalid.svelte +14 -14
  76. package/dist/components/inputs/text-input/assets/IconValid.svelte +12 -12
  77. package/dist/components/layout/HkAppLayout.state.svelte.js +25 -25
  78. package/dist/components/layout/HkAppLayout.svelte +251 -251
  79. package/dist/components/layout/HkAppLayout.svelte.d.ts +11 -0
  80. package/dist/components/layout/HkGridLayers.svelte +82 -82
  81. package/dist/components/layout/HkGridLayers.svelte.d.ts +23 -0
  82. package/dist/components/layout/index.js +9 -9
  83. package/dist/components/panels/index.js +1 -1
  84. package/dist/components/panels/plain-panel/PlainPanel.svelte +33 -33
  85. package/dist/components/panels/plain-panel/PlainPanel.svelte.d.ts +12 -0
  86. package/dist/components/rows/index.js +3 -3
  87. package/dist/components/rows/panel-grid-row/PanelGridRow.svelte +104 -104
  88. package/dist/components/rows/panel-grid-row/PanelGridRow.svelte.d.ts +14 -0
  89. package/dist/components/rows/panel-row-2/PanelRow2.svelte +40 -40
  90. package/dist/components/rows/panel-row-2/PanelRow2.svelte.d.ts +14 -0
  91. package/dist/components/tab-bar/HkTabBar.state.svelte.js +149 -149
  92. package/dist/components/tab-bar/HkTabBar.svelte +74 -74
  93. package/dist/components/tab-bar/HkTabBar.svelte.d.ts +18 -0
  94. package/dist/components/tab-bar/HkTabBarSelector.state.svelte.js +93 -93
  95. package/dist/components/tab-bar/HkTabBarSelector.svelte +49 -49
  96. package/dist/components/tab-bar/HkTabBarSelector.svelte.d.ts +19 -0
  97. package/dist/components/tab-bar/index.js +17 -17
  98. package/dist/components/tab-bar/typedef.d.ts +1 -1
  99. package/dist/components/tab-bar/typedef.js +8 -8
  100. package/dist/components/widgets/compare-left-right/CompareLeftRight.svelte +179 -179
  101. package/dist/components/widgets/compare-left-right/CompareLeftRight.svelte.d.ts +10 -0
  102. package/dist/components/widgets/compare-left-right/index.js +1 -1
  103. package/dist/components/widgets/scale-control/index.js +1 -1
  104. package/dist/config/imagetools-config.js +189 -189
  105. package/dist/config/imagetools.d.ts +71 -71
  106. package/dist/config/typedef.js +8 -8
  107. package/dist/constants/errors/api.js +9 -9
  108. package/dist/constants/errors/generic.js +5 -5
  109. package/dist/constants/errors/index.js +3 -3
  110. package/dist/constants/errors/jwt.js +5 -5
  111. package/dist/constants/http/headers.js +6 -6
  112. package/dist/constants/http/index.js +2 -2
  113. package/dist/constants/http/methods.js +2 -2
  114. package/dist/constants/index.js +3 -3
  115. package/dist/constants/mime/application.js +5 -5
  116. package/dist/constants/mime/audio.js +13 -13
  117. package/dist/constants/mime/image.js +3 -3
  118. package/dist/constants/mime/index.js +4 -4
  119. package/dist/constants/mime/text.js +2 -2
  120. package/dist/constants/regexp/index.js +31 -31
  121. package/dist/constants/regexp/inspiratie.js__ +95 -95
  122. package/dist/constants/regexp/text.js +49 -49
  123. package/dist/constants/regexp/user.js +32 -32
  124. package/dist/constants/regexp/web.js +3 -3
  125. package/dist/constants/state-labels/input-states.js +11 -11
  126. package/dist/constants/state-labels/submit-states.js +4 -4
  127. package/dist/constants/time.js +28 -28
  128. package/dist/css/tw-prose.postcss__ +259 -259
  129. package/dist/css/utilities.postcss +43 -43
  130. package/dist/design/design-config.js +73 -73
  131. package/dist/design/tailwind-theme-extend.d.ts +4 -4
  132. package/dist/design/tailwind-theme-extend.js +160 -151
  133. package/dist/schemas/index.js +1 -1
  134. package/dist/schemas/validate-url.js +180 -180
  135. package/dist/server/index.js +1 -1
  136. package/dist/server/logger.js +94 -94
  137. package/dist/states/index.js +1 -1
  138. package/dist/states/navigation.svelte.js +55 -55
  139. package/dist/stores/index.js +1 -1
  140. package/dist/stores/theme.js +80 -80
  141. package/dist/themes/hkdev/components/blocks/text-block.postcss +40 -40
  142. package/dist/themes/hkdev/components/boxes/game-box.postcss +13 -13
  143. package/dist/themes/hkdev/components/buttons/button-icon-steeze.postcss +22 -0
  144. package/dist/themes/hkdev/components/buttons/button-text.postcss +34 -34
  145. package/dist/themes/hkdev/components/buttons/button.postcss +138 -138
  146. package/dist/themes/hkdev/components/buttons/button.postcss__ +40 -0
  147. package/dist/themes/hkdev/components/buttons/button.postcss___ +91 -0
  148. package/dist/themes/hkdev/components/buttons/skip-button.postcss +8 -8
  149. package/dist/themes/hkdev/components/icons/icon-steeze.postcss +22 -0
  150. package/dist/themes/hkdev/components/inputs/text-input.postcss +108 -108
  151. package/dist/themes/hkdev/components/panels/plain-panel.postcss +46 -46
  152. package/dist/themes/hkdev/components/panels/speech-bubble.postcss +52 -52
  153. package/dist/themes/hkdev/components/rows/panel-grid-row.postcss +7 -7
  154. package/dist/themes/hkdev/components/rows/panel-row-2.postcss +9 -9
  155. package/dist/themes/hkdev/components.postcss +61 -55
  156. package/dist/themes/hkdev/debug.postcss +1 -1
  157. package/dist/themes/hkdev/global/layout.postcss +39 -39
  158. package/dist/themes/hkdev/global/on-colors.postcss +53 -53
  159. package/dist/themes/hkdev/global/text.postcss__ +34 -34
  160. package/dist/themes/hkdev/global/vars.postcss__ +7 -7
  161. package/dist/themes/hkdev/globals.postcss +11 -11
  162. package/dist/themes/hkdev/responsive.postcss +12 -12
  163. package/dist/themes/hkdev/theme-ext.js +15 -15
  164. package/dist/themes/hkdev/theme.js +227 -227
  165. package/dist/themes/index.js +1 -1
  166. package/dist/util/array/index.js +455 -455
  167. package/dist/util/compare/index.js +247 -247
  168. package/dist/util/css/css-vars.js +83 -83
  169. package/dist/util/css/index.js +1 -1
  170. package/dist/util/design-system/components/states.js +22 -22
  171. package/dist/util/design-system/css/clamp.js +66 -66
  172. package/dist/util/design-system/css/root-design-vars.js +100 -100
  173. package/dist/util/design-system/index.js +5 -5
  174. package/dist/util/design-system/layout/scaling.js +97 -97
  175. package/dist/util/design-system/tailwind.js +289 -289
  176. package/dist/util/expect/arrays.js +47 -47
  177. package/dist/util/expect/index.js +259 -259
  178. package/dist/util/expect/primitives.js +55 -55
  179. package/dist/util/expect/url.js +60 -60
  180. package/dist/util/function/index.js +218 -218
  181. package/dist/util/http/errors.js +97 -97
  182. package/dist/util/http/headers.js +45 -45
  183. package/dist/util/http/http-request.js +273 -273
  184. package/dist/util/http/index.js +22 -22
  185. package/dist/util/http/json-request.js +143 -143
  186. package/dist/util/http/mocks.js +65 -65
  187. package/dist/util/http/response.js +228 -228
  188. package/dist/util/http/url.js +52 -52
  189. package/dist/util/image/index.js +86 -86
  190. package/dist/util/index.js +2 -2
  191. package/dist/util/is/index.js +140 -140
  192. package/dist/util/iterate/index.js +234 -234
  193. package/dist/util/object/index.js +1361 -1361
  194. package/dist/util/singleton/index.js +97 -97
  195. package/dist/util/string/index.js +184 -184
  196. package/dist/util/svelte/index.js +2 -2
  197. package/dist/util/svelte/observe/index.js +49 -49
  198. package/dist/util/svelte/state-context/index.js +83 -83
  199. package/dist/util/svelte/wait/index.js +38 -38
  200. package/dist/util/sveltekit/index.js +1 -1
  201. package/dist/util/sveltekit/route-folders/index.js +82 -82
  202. package/dist/util/time/index.js +339 -339
  203. package/dist/valibot/date.js__ +10 -10
  204. package/dist/valibot/index.js +9 -9
  205. package/dist/valibot/url.js +95 -95
  206. package/dist/valibot/user.js +23 -23
  207. package/dist/zod/all.js +33 -33
  208. package/dist/zod/generic.js +11 -11
  209. package/dist/zod/javascript.js +32 -32
  210. package/dist/zod/user.js +16 -16
  211. package/dist/zod/web.js +52 -52
  212. package/package.json +99 -99
  213. package/dist/components/icon/HkIcon.svelte.d.ts +0 -10
  214. package/dist/components/icon/HkTabIcon.svelte.d.ts +0 -19
  215. /package/dist/components/{icon → icons}/typedef.d.ts +0 -0
@@ -1,149 +1,149 @@
1
- import { defineStateContext } from '../../util/svelte/state-context/index.js';
2
- import { nav } from '../../states/navigation.svelte.js';
3
-
4
- import { goto } from '$app/navigation';
5
-
6
- /**
7
- * @typedef {import('./typedef.js').Tab} Tab
8
- */
9
-
10
- /* ------------------------------------------------------- Define state class */
11
-
12
- export class HkTabBarState {
13
- /** @type {Tab[]} */
14
- tabs = $state.raw([]);
15
-
16
- /** @type {any} */
17
- tabBarElement = $state();
18
-
19
- /** @type {HTMLElement[]} */
20
- tabElements = [];
21
-
22
- currentTabIndex = $state(-1);
23
-
24
- /** @type {Tab|null} */
25
- currentTab = $state(null);
26
-
27
- // /** @type {boolean} */
28
- // ready = $derived(this.currentTab !== null);
29
-
30
- constructor() {
31
- $effect.pre(() => {
32
- // > Update this.currentTab
33
-
34
- const tabs = this.tabs;
35
-
36
- if (!this.tabs?.length || this.currentTabIndex === -1) {
37
- this.currentTab = null;
38
- } else {
39
- const index = this.currentTabIndex;
40
- const tabValue = tabs[index] ?? null;
41
-
42
- // console.log('Selected active tab', index, tabValue);
43
-
44
- this.currentTab = tabValue;
45
- }
46
- });
47
- } // end constructor
48
-
49
- /**
50
- * Set tab contents
51
- *
52
- * @param {Tab[]} tabs
53
- */
54
- setTabs(tabs) {
55
- // console.log('setTabs', tabs);
56
- this.tabs = tabs;
57
-
58
- if (this.currentTabIndex >= tabs.length) {
59
- this.currentTabIndex = 0;
60
- }
61
- }
62
-
63
- /**
64
- * Navigate to the route that is specified on the current tab (if any)
65
- */
66
- navigate() {
67
- if (!this.currentTab || !this.currentTab.route) {
68
- return;
69
- }
70
-
71
- goto(this.currentTab.route);
72
- }
73
-
74
- /**
75
- * Select the tab that has a route property that matches the current
76
- * browser location pathname
77
- *
78
- * @note the pathname starts with a '/'
79
- *
80
- * @param {string} [pathname]
81
- * If not specified, pathname from the browser's location will be used
82
- */
83
- selectTabByPathName(pathname) {
84
- if (!this.tabs.length) {
85
- return;
86
- }
87
-
88
- if (!pathname) {
89
- pathname = nav.pathname;
90
- }
91
-
92
- // console.log(`selectTabByPathName [${pathname}]`);
93
-
94
- const tabs = this.tabs;
95
-
96
- // > Try to find an exact match
97
-
98
- for (let j = 0, n = tabs.length; j < n; j = j + 1) {
99
- const tab = tabs[j];
100
-
101
- if (tab.route && tab.route === pathname) {
102
- //console.log('Found tab by route', tab);
103
- this.selectTabByIndex(j);
104
-
105
- return;
106
- }
107
- } // end for
108
-
109
- // > Try to find a match using a route prefix
110
-
111
- for (let j = 0, n = tabs.length; j < n; j = j + 1) {
112
- const tab = tabs[j];
113
-
114
- if (tab.routePrefix && pathname.startsWith(tab.routePrefix)) {
115
- //console.log('Found tab by route prefix', tab);
116
- this.selectTabByIndex(j);
117
-
118
- return;
119
- }
120
- } // end for
121
- }
122
-
123
- /**
124
- * Select a tab by its index in the array this.tabs
125
- *
126
- * @param {number} index
127
- */
128
- selectTabByIndex(index) {
129
- // console.log(`Select tab by index [${index}]`);
130
- this.currentTabIndex = index;
131
- }
132
-
133
- /**
134
- * Link a tab to a DOM element
135
- * - An reference is stored as property
136
- * - This reference can be used by extensions of this tab bar,
137
- * e.g. to manipulate the visual appearance of the tabs
138
- *
139
- * @param {number} index
140
- * @param {HTMLElement} tabElement
141
- */
142
- linkTab(index, tabElement) {
143
- this.tabElements[index] = tabElement;
144
- }
145
- } // end class
146
-
147
- /* -------------------------------------- Export create & get state functions */
148
-
149
- export const [createOrGetState, createState, getState] = defineStateContext(HkTabBarState);
1
+ import { defineStateContext } from '../../util/svelte/state-context/index.js';
2
+ import { nav } from '../../states/navigation.svelte.js';
3
+
4
+ import { goto } from '$app/navigation';
5
+
6
+ /**
7
+ * @typedef {import('./typedef.js').Tab} Tab
8
+ */
9
+
10
+ /* ------------------------------------------------------- Define state class */
11
+
12
+ export class HkTabBarState {
13
+ /** @type {Tab[]} */
14
+ tabs = $state.raw([]);
15
+
16
+ /** @type {any} */
17
+ tabBarElement = $state();
18
+
19
+ /** @type {HTMLElement[]} */
20
+ tabElements = [];
21
+
22
+ currentTabIndex = $state(-1);
23
+
24
+ /** @type {Tab|null} */
25
+ currentTab = $state(null);
26
+
27
+ // /** @type {boolean} */
28
+ // ready = $derived(this.currentTab !== null);
29
+
30
+ constructor() {
31
+ $effect.pre(() => {
32
+ // > Update this.currentTab
33
+
34
+ const tabs = this.tabs;
35
+
36
+ if (!this.tabs?.length || this.currentTabIndex === -1) {
37
+ this.currentTab = null;
38
+ } else {
39
+ const index = this.currentTabIndex;
40
+ const tabValue = tabs[index] ?? null;
41
+
42
+ // console.log('Selected active tab', index, tabValue);
43
+
44
+ this.currentTab = tabValue;
45
+ }
46
+ });
47
+ } // end constructor
48
+
49
+ /**
50
+ * Set tab contents
51
+ *
52
+ * @param {Tab[]} tabs
53
+ */
54
+ setTabs(tabs) {
55
+ // console.log('setTabs', tabs);
56
+ this.tabs = tabs;
57
+
58
+ if (this.currentTabIndex >= tabs.length) {
59
+ this.currentTabIndex = 0;
60
+ }
61
+ }
62
+
63
+ /**
64
+ * Navigate to the route that is specified on the current tab (if any)
65
+ */
66
+ navigate() {
67
+ if (!this.currentTab || !this.currentTab.route) {
68
+ return;
69
+ }
70
+
71
+ goto(this.currentTab.route);
72
+ }
73
+
74
+ /**
75
+ * Select the tab that has a route property that matches the current
76
+ * browser location pathname
77
+ *
78
+ * @note the pathname starts with a '/'
79
+ *
80
+ * @param {string} [pathname]
81
+ * If not specified, pathname from the browser's location will be used
82
+ */
83
+ selectTabByPathName(pathname) {
84
+ if (!this.tabs.length) {
85
+ return;
86
+ }
87
+
88
+ if (!pathname) {
89
+ pathname = nav.pathname;
90
+ }
91
+
92
+ // console.log(`selectTabByPathName [${pathname}]`);
93
+
94
+ const tabs = this.tabs;
95
+
96
+ // > Try to find an exact match
97
+
98
+ for (let j = 0, n = tabs.length; j < n; j = j + 1) {
99
+ const tab = tabs[j];
100
+
101
+ if (tab.route && tab.route === pathname) {
102
+ //console.log('Found tab by route', tab);
103
+ this.selectTabByIndex(j);
104
+
105
+ return;
106
+ }
107
+ } // end for
108
+
109
+ // > Try to find a match using a route prefix
110
+
111
+ for (let j = 0, n = tabs.length; j < n; j = j + 1) {
112
+ const tab = tabs[j];
113
+
114
+ if (tab.routePrefix && pathname.startsWith(tab.routePrefix)) {
115
+ //console.log('Found tab by route prefix', tab);
116
+ this.selectTabByIndex(j);
117
+
118
+ return;
119
+ }
120
+ } // end for
121
+ }
122
+
123
+ /**
124
+ * Select a tab by its index in the array this.tabs
125
+ *
126
+ * @param {number} index
127
+ */
128
+ selectTabByIndex(index) {
129
+ // console.log(`Select tab by index [${index}]`);
130
+ this.currentTabIndex = index;
131
+ }
132
+
133
+ /**
134
+ * Link a tab to a DOM element
135
+ * - An reference is stored as property
136
+ * - This reference can be used by extensions of this tab bar,
137
+ * e.g. to manipulate the visual appearance of the tabs
138
+ *
139
+ * @param {number} index
140
+ * @param {HTMLElement} tabElement
141
+ */
142
+ linkTab(index, tabElement) {
143
+ this.tabElements[index] = tabElement;
144
+ }
145
+ } // end class
146
+
147
+ /* -------------------------------------- Export create & get state functions */
148
+
149
+ export const [createOrGetState, createState, getState] = defineStateContext(HkTabBarState);
@@ -1,74 +1,74 @@
1
- <script>
2
- /**
3
- * TabBar component
4
- *
5
- * Following component guidelines from Skeleton
6
- * @see https://next.skeleton.dev/docs/resources/contribute/components
7
- */
8
-
9
- import { createOrGetState } from './HkTabBar.state.svelte';
10
-
11
- import { HkGridArea } from '../area/index.js';
12
-
13
- /**
14
- * @type {{
15
- * cols?: number,
16
- * base?: string,
17
- * bg?: string,
18
- * padding?: string,
19
- * margin?: string,
20
- * classes?: string,
21
- * style?: string,
22
- * instanceKey?: Symbol | string,
23
- * children: import('svelte').Snippet,
24
- * onmount?: function,
25
- * domElem?: HTMLElement
26
- * } & { [attr: string]: any }}
27
- */
28
- let {
29
- // Functional
30
- cols = 3,
31
-
32
- // Style
33
- base,
34
- bg,
35
- padding,
36
- margin,
37
- classes,
38
-
39
- style,
40
-
41
- // State
42
- instanceKey,
43
-
44
- // Snippets
45
- children,
46
-
47
- // Event handlers
48
- onmount,
49
-
50
- // DOM Elements
51
- domElem = $bindable(),
52
-
53
- // Rest attributes
54
- ...attrs
55
- } = $props();
56
-
57
- createOrGetState(instanceKey);
58
-
59
- //grid-cols-[repeat({cols},minmax(0,auto))]
60
- </script>
61
-
62
- <HkGridArea
63
- data-hk-tab-bar
64
- base="justify-center content-stretch items-center {base}"
65
- style="grid-template-columns: repeat({cols}, minmax(0,auto)); {style}"
66
- boxBg={bg}
67
- boxPadding={padding}
68
- boxMargin={margin}
69
- bind:boxDomElem={domElem}
70
- {classes}
71
- {...attrs}
72
- >
73
- {@render children()}
74
- </HkGridArea>
1
+ <script>
2
+ /**
3
+ * TabBar component
4
+ *
5
+ * Following component guidelines from Skeleton
6
+ * @see https://next.skeleton.dev/docs/resources/contribute/components
7
+ */
8
+
9
+ import { createOrGetState } from './HkTabBar.state.svelte';
10
+
11
+ import { HkGridArea } from '../area/index.js';
12
+
13
+ /**
14
+ * @type {{
15
+ * cols?: number,
16
+ * base?: string,
17
+ * bg?: string,
18
+ * padding?: string,
19
+ * margin?: string,
20
+ * classes?: string,
21
+ * style?: string,
22
+ * instanceKey?: Symbol | string,
23
+ * children: import('svelte').Snippet,
24
+ * onmount?: function,
25
+ * domElem?: HTMLElement
26
+ * } & { [attr: string]: any }}
27
+ */
28
+ let {
29
+ // Functional
30
+ cols = 3,
31
+
32
+ // Style
33
+ base,
34
+ bg,
35
+ padding,
36
+ margin,
37
+ classes,
38
+
39
+ style,
40
+
41
+ // State
42
+ instanceKey,
43
+
44
+ // Snippets
45
+ children,
46
+
47
+ // Event handlers
48
+ onmount,
49
+
50
+ // DOM Elements
51
+ domElem = $bindable(),
52
+
53
+ // Rest attributes
54
+ ...attrs
55
+ } = $props();
56
+
57
+ createOrGetState(instanceKey);
58
+
59
+ //grid-cols-[repeat({cols},minmax(0,auto))]
60
+ </script>
61
+
62
+ <HkGridArea
63
+ data-hk-tab-bar
64
+ base="justify-center content-stretch items-center {base}"
65
+ style="grid-template-columns: repeat({cols}, minmax(0,auto)); {style}"
66
+ boxBg={bg}
67
+ boxPadding={padding}
68
+ boxMargin={margin}
69
+ bind:boxDomElem={domElem}
70
+ {classes}
71
+ {...attrs}
72
+ >
73
+ {@render children()}
74
+ </HkGridArea>
@@ -1,4 +1,22 @@
1
1
  export default HkTabBar;
2
+ type HkTabBar = {
3
+ $on?(type: string, callback: (e: any) => void): () => void;
4
+ $set?(props: Partial<{
5
+ cols?: number;
6
+ base?: string;
7
+ bg?: string;
8
+ padding?: string;
9
+ margin?: string;
10
+ classes?: string;
11
+ style?: string;
12
+ instanceKey?: string | Symbol;
13
+ children: Snippet<[]>;
14
+ onmount?: Function;
15
+ domElem?: HTMLElement;
16
+ } & {
17
+ [attr: string]: any;
18
+ }>): void;
19
+ };
2
20
  declare const HkTabBar: import("svelte").Component<{
3
21
  cols?: number;
4
22
  base?: string;
@@ -1,93 +1,93 @@
1
- import { defineStateContext } from '../../util/svelte/state-context/index.js';
2
-
3
- import { useResizeObserver } from '../../util/svelte/observe/index.js';
4
-
5
- /* ------------------------------------------------------- Define state class */
6
-
7
- export class HkTabBarSelectorState {
8
- /** @type {HTMLElement|undefined} */
9
- // outer = $state.raw();
10
- // outerBox = $state.raw();
11
-
12
- /** @type {number} */
13
- // tabBarWidth = $state(0);
14
-
15
- selectorWidth = $state(0);
16
- selectorStyle = $state('');
17
-
18
- //currentTabIndex;
19
-
20
- /** @type {DOMRect[]} */
21
- iconSizes = [];
22
-
23
- constructor() {
24
- // $effect(() => {
25
- // if (this.outer) {
26
- // this.outerBox = this.outer.getBoundingClientRect();
27
- // }
28
- // });
29
- }
30
-
31
- /**
32
- * Link the tab bar selector to a tab bar state
33
- *
34
- * @param {import('./HkTabBar.svelte').TabBarState} tabBarState
35
- */
36
- linkToTabBarState(tabBarState) {
37
- // console.log('setBottomBar', bottomBarState);
38
-
39
- // if this.bottomBarState > error
40
-
41
- this.tabBarState = tabBarState;
42
-
43
- $effect(() => {
44
- tabBarState.currentTabIndex;
45
-
46
- // console.log('currentTabIndex $effect');
47
-
48
- this.#updateSelector();
49
- });
50
-
51
- useResizeObserver(
52
- () => tabBarState.tabBarElement,
53
- (entries) => {
54
- this.#updateSelector();
55
- }
56
- );
57
- }
58
-
59
- /**
60
- * Update the size and position of the selector
61
- */
62
- #updateSelector() {
63
- if (!this.tabBarState) {
64
- return;
65
- }
66
-
67
- const { currentTabIndex, tabBarElement, tabElements } = this.tabBarState;
68
-
69
- const tabElem = tabElements[currentTabIndex];
70
-
71
- if (!tabElem || !tabBarElement) {
72
- return;
73
- }
74
-
75
- const tabElemRect = tabElem.getBoundingClientRect();
76
-
77
- const tabBarRect = tabBarElement.getBoundingClientRect();
78
-
79
- // const offsetX = (iconWidth - selectorWidth) / 2 - outerBox.x;
80
- const offsetX = (tabElemRect.width - this.selectorWidth) / 2 - tabBarRect.x;
81
-
82
- const x = tabElemRect.x + offsetX;
83
- const w = tabBarRect.width;
84
-
85
- this.selectorStyle = `left: ${(100 * x) / w}%; opacity: 1;`;
86
-
87
- // console.log('selectorStyle', this.selectorStyle);
88
- }
89
- }
90
-
91
- /* -------------------------------------- Export create & get state functions */
92
-
93
- export const [createOrGetState, createState, getState] = defineStateContext(HkTabBarSelectorState);
1
+ import { defineStateContext } from '../../util/svelte/state-context/index.js';
2
+
3
+ import { useResizeObserver } from '../../util/svelte/observe/index.js';
4
+
5
+ /* ------------------------------------------------------- Define state class */
6
+
7
+ export class HkTabBarSelectorState {
8
+ /** @type {HTMLElement|undefined} */
9
+ // outer = $state.raw();
10
+ // outerBox = $state.raw();
11
+
12
+ /** @type {number} */
13
+ // tabBarWidth = $state(0);
14
+
15
+ selectorWidth = $state(0);
16
+ selectorStyle = $state('');
17
+
18
+ //currentTabIndex;
19
+
20
+ /** @type {DOMRect[]} */
21
+ iconSizes = [];
22
+
23
+ constructor() {
24
+ // $effect(() => {
25
+ // if (this.outer) {
26
+ // this.outerBox = this.outer.getBoundingClientRect();
27
+ // }
28
+ // });
29
+ }
30
+
31
+ /**
32
+ * Link the tab bar selector to a tab bar state
33
+ *
34
+ * @param {import('./HkTabBar.svelte').TabBarState} tabBarState
35
+ */
36
+ linkToTabBarState(tabBarState) {
37
+ // console.log('setBottomBar', bottomBarState);
38
+
39
+ // if this.bottomBarState > error
40
+
41
+ this.tabBarState = tabBarState;
42
+
43
+ $effect(() => {
44
+ tabBarState.currentTabIndex;
45
+
46
+ // console.log('currentTabIndex $effect');
47
+
48
+ this.#updateSelector();
49
+ });
50
+
51
+ useResizeObserver(
52
+ () => tabBarState.tabBarElement,
53
+ (entries) => {
54
+ this.#updateSelector();
55
+ }
56
+ );
57
+ }
58
+
59
+ /**
60
+ * Update the size and position of the selector
61
+ */
62
+ #updateSelector() {
63
+ if (!this.tabBarState) {
64
+ return;
65
+ }
66
+
67
+ const { currentTabIndex, tabBarElement, tabElements } = this.tabBarState;
68
+
69
+ const tabElem = tabElements[currentTabIndex];
70
+
71
+ if (!tabElem || !tabBarElement) {
72
+ return;
73
+ }
74
+
75
+ const tabElemRect = tabElem.getBoundingClientRect();
76
+
77
+ const tabBarRect = tabBarElement.getBoundingClientRect();
78
+
79
+ // const offsetX = (iconWidth - selectorWidth) / 2 - outerBox.x;
80
+ const offsetX = (tabElemRect.width - this.selectorWidth) / 2 - tabBarRect.x;
81
+
82
+ const x = tabElemRect.x + offsetX;
83
+ const w = tabBarRect.width;
84
+
85
+ this.selectorStyle = `left: ${(100 * x) / w}%; opacity: 1;`;
86
+
87
+ // console.log('selectorStyle', this.selectorStyle);
88
+ }
89
+ }
90
+
91
+ /* -------------------------------------- Export create & get state functions */
92
+
93
+ export const [createOrGetState, createState, getState] = defineStateContext(HkTabBarSelectorState);