@hkdigital/lib-sveltekit 0.1.62 → 0.1.65

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 (209) hide show
  1. package/README.md +135 -135
  2. package/dist/assets/autospuiten/car-paint-picker.js +41 -41
  3. package/dist/assets/autospuiten/labels.js +7 -7
  4. package/dist/classes/data/IterableTree.js +243 -243
  5. package/dist/classes/data/Selector.js +190 -190
  6. package/dist/classes/data/index.js +2 -2
  7. package/dist/classes/index.js +4 -4
  8. package/dist/classes/promise/HkPromise.js +377 -377
  9. package/dist/classes/promise/index.js +1 -1
  10. package/dist/classes/stores/SubscribersCount.js +107 -107
  11. package/dist/classes/stores/index.js +1 -1
  12. package/dist/classes/streams/LogTransformStream.js +19 -19
  13. package/dist/classes/streams/ServerEventsStore.js +110 -110
  14. package/dist/classes/streams/TimeStampSource.js +26 -26
  15. package/dist/classes/streams/index.js +3 -3
  16. package/dist/classes/svelte/audio/AudioLoader.svelte.js +58 -58
  17. package/dist/classes/svelte/audio/AudioScene.svelte.js +295 -295
  18. package/dist/classes/svelte/audio/mocks.js +35 -35
  19. package/dist/classes/svelte/finite-state-machine/FiniteStateMachine.svelte.js +133 -133
  20. package/dist/classes/svelte/finite-state-machine/index.js +1 -1
  21. package/dist/classes/svelte/image/ImageLoader.svelte.js +47 -47
  22. package/dist/classes/svelte/image/ImageScene.svelte.js +253 -253
  23. package/dist/classes/svelte/image/ImageVariantsLoader.svelte.js +152 -152
  24. package/dist/classes/svelte/image/index.js +4 -4
  25. package/dist/classes/svelte/image/mocks.js +35 -35
  26. package/dist/classes/svelte/image/typedef.js +8 -8
  27. package/dist/classes/svelte/index.js +14 -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/classes/svelte/network-loader/NetworkLoader.svelte.js +331 -331
  32. package/dist/classes/svelte/network-loader/constants.js +3 -3
  33. package/dist/classes/svelte/network-loader/index.js +3 -3
  34. package/dist/classes/svelte/network-loader/mocks.js +30 -30
  35. package/dist/classes/svelte/network-loader/typedef.js +8 -8
  36. package/dist/components/area/HkArea.svelte +49 -49
  37. package/dist/components/area/HkGridArea.svelte +77 -77
  38. package/dist/components/area/index.js +2 -2
  39. package/dist/components/buttons/button/Button.svelte +82 -82
  40. package/dist/components/buttons/button-icon-steeze/SteezeIconButton.svelte +30 -30
  41. package/dist/components/buttons/button-text/TextButton.svelte +21 -21
  42. package/dist/components/buttons/index.js +3 -3
  43. package/dist/components/debug/debug-panel-design-scaling/DebugPanelDesignScaling.svelte +146 -146
  44. package/dist/components/debug/index.js +1 -1
  45. package/dist/components/hkdev/blocks/TextBlock.svelte +46 -46
  46. package/dist/components/hkdev/buttons/CheckButton.svelte +62 -62
  47. package/dist/components/icons/HkIcon.svelte +86 -86
  48. package/dist/components/icons/HkTabIcon.svelte +116 -116
  49. package/dist/components/icons/SteezeIcon.svelte +97 -97
  50. package/dist/components/icons/index.js +6 -6
  51. package/dist/components/icons/typedef.js +16 -16
  52. package/dist/components/index.js +2 -2
  53. package/dist/components/inputs/index.js +1 -1
  54. package/dist/components/inputs/text-input/TestTextInput.svelte__ +102 -102
  55. package/dist/components/inputs/text-input/TextInput.svelte +223 -223
  56. package/dist/components/inputs/text-input/TextInput.svelte___ +83 -83
  57. package/dist/components/inputs/text-input/assets/IconInvalid.svelte +14 -14
  58. package/dist/components/inputs/text-input/assets/IconValid.svelte +12 -12
  59. package/dist/components/layout/grid-layers/GridLayers.svelte +167 -167
  60. package/dist/components/layout/index.js +1 -1
  61. package/dist/components/panels/index.js +1 -1
  62. package/dist/components/panels/panel/Panel.svelte +43 -43
  63. package/dist/components/rows/index.js +3 -3
  64. package/dist/components/rows/panel-grid-row/PanelGridRow.svelte +104 -104
  65. package/dist/components/rows/panel-row-2/PanelRow2.svelte +40 -40
  66. package/dist/components/tab-bar/HkTabBar.state.svelte.js +149 -149
  67. package/dist/components/tab-bar/HkTabBar.svelte +74 -74
  68. package/dist/components/tab-bar/HkTabBarSelector.state.svelte.js +93 -93
  69. package/dist/components/tab-bar/HkTabBarSelector.svelte +49 -49
  70. package/dist/components/tab-bar/index.js +17 -17
  71. package/dist/components/tab-bar/typedef.js +8 -8
  72. package/dist/config/imagetools-config.js +189 -189
  73. package/dist/config/imagetools.d.ts +71 -71
  74. package/dist/config/typedef.js +8 -8
  75. package/dist/constants/bases.js +13 -13
  76. package/dist/constants/errors/api.js +9 -9
  77. package/dist/constants/errors/generic.js +5 -5
  78. package/dist/constants/errors/index.js +3 -3
  79. package/dist/constants/errors/jwt.js +5 -5
  80. package/dist/constants/http/headers.js +6 -6
  81. package/dist/constants/http/index.js +2 -2
  82. package/dist/constants/http/methods.js +2 -2
  83. package/dist/constants/index.js +3 -3
  84. package/dist/constants/mime/application.js +5 -5
  85. package/dist/constants/mime/audio.js +13 -13
  86. package/dist/constants/mime/image.js +3 -3
  87. package/dist/constants/mime/index.js +4 -4
  88. package/dist/constants/mime/text.js +2 -2
  89. package/dist/constants/regexp/index.js +31 -31
  90. package/dist/constants/regexp/inspiratie.js__ +95 -95
  91. package/dist/constants/regexp/text.js +49 -49
  92. package/dist/constants/regexp/user.js +32 -32
  93. package/dist/constants/regexp/web.js +3 -3
  94. package/dist/constants/state-labels/input-states.js +11 -11
  95. package/dist/constants/state-labels/submit-states.js +4 -4
  96. package/dist/constants/time.js +28 -28
  97. package/dist/css/utilities.css +43 -43
  98. package/dist/design/design-config.js +73 -73
  99. package/dist/design/tailwind-theme-extend.js +158 -158
  100. package/dist/schemas/index.js +1 -1
  101. package/dist/schemas/validate-url.js +180 -180
  102. package/dist/server/index.js +1 -1
  103. package/dist/server/logger.js +94 -94
  104. package/dist/states/index.js +1 -1
  105. package/dist/states/navigation.svelte.js +55 -55
  106. package/dist/stores/index.js +1 -1
  107. package/dist/stores/theme.js +80 -80
  108. package/dist/themes/hkdev/components/blocks/text-block.css +41 -41
  109. package/dist/themes/hkdev/components/boxes/game-box.css +12 -12
  110. package/dist/themes/hkdev/components/buttons/button-icon-steeze.css +22 -22
  111. package/dist/themes/hkdev/components/buttons/button-text.css +32 -32
  112. package/dist/themes/hkdev/components/buttons/button.css +142 -142
  113. package/dist/themes/hkdev/components/buttons/skip-button.css +6 -6
  114. package/dist/themes/hkdev/components/icons/icon-steeze.css +22 -22
  115. package/dist/themes/hkdev/components/inputs/text-input.css +104 -104
  116. package/dist/themes/hkdev/components/panels/panel.css +27 -27
  117. package/dist/themes/hkdev/components/rows/panel-grid-row.css +6 -6
  118. package/dist/themes/hkdev/components/rows/panel-row-2.css +7 -7
  119. package/dist/themes/hkdev/components.css +47 -47
  120. package/dist/themes/hkdev/debug.css +1 -1
  121. package/dist/themes/hkdev/global/layout.css +39 -39
  122. package/dist/themes/hkdev/global/on-colors.css +53 -53
  123. package/dist/themes/hkdev/globals.css +11 -11
  124. package/dist/themes/hkdev/responsive.css +12 -12
  125. package/dist/themes/hkdev/theme-ext.js +15 -15
  126. package/dist/themes/hkdev/theme.js +235 -235
  127. package/dist/themes/index.js +1 -1
  128. package/dist/util/array/index.js +455 -455
  129. package/dist/util/bases/base58.js +262 -262
  130. package/dist/util/bases/index.js +1 -1
  131. package/dist/util/compare/index.js +247 -247
  132. package/dist/util/css/css-vars.js +83 -83
  133. package/dist/util/css/index.js +1 -1
  134. package/dist/util/design-system/components/states.js +22 -22
  135. package/dist/util/design-system/css/clamp.js +66 -66
  136. package/dist/util/design-system/css/root-design-vars.js +100 -100
  137. package/dist/util/design-system/index.js +5 -5
  138. package/dist/util/design-system/layout/scaling.js +228 -228
  139. package/dist/util/design-system/skeleton.js +208 -208
  140. package/dist/util/design-system/tailwind.js +288 -288
  141. package/dist/util/expect/arrays.js +47 -47
  142. package/dist/util/expect/index.js +259 -259
  143. package/dist/util/expect/primitives.js +55 -55
  144. package/dist/util/expect/url.js +60 -60
  145. package/dist/util/function/index.js +218 -218
  146. package/dist/util/http/errors.js +97 -97
  147. package/dist/util/http/headers.js +45 -45
  148. package/dist/util/http/http-request.js +294 -294
  149. package/dist/util/http/index.js +22 -22
  150. package/dist/util/http/json-request.js +143 -143
  151. package/dist/util/http/mocks.js +65 -65
  152. package/dist/util/http/response.js +241 -241
  153. package/dist/util/http/test-data__/content-length-test-hkdigital-small.V4HfZyBQ.avif +0 -0
  154. package/dist/util/http/url.js +52 -52
  155. package/dist/util/image/index.js +86 -86
  156. package/dist/util/index.js +2 -2
  157. package/dist/util/is/index.js +140 -140
  158. package/dist/util/iterate/index.js +234 -234
  159. package/dist/util/object/index.js +1361 -1361
  160. package/dist/util/singleton/index.js +97 -97
  161. package/dist/util/string/array-path.js +75 -75
  162. package/dist/util/string/convert.js +54 -54
  163. package/dist/util/string/fs.js +226 -226
  164. package/dist/util/string/index.js +5 -5
  165. package/dist/util/string/interpolate.js +61 -61
  166. package/dist/util/string/pad.js +10 -10
  167. package/dist/util/svelte/index.js +4 -4
  168. package/dist/util/svelte/loading/loading-tracker.svelte.js +108 -108
  169. package/dist/util/svelte/observe/index.js +49 -49
  170. package/dist/util/svelte/state-context/index.js +83 -83
  171. package/dist/util/svelte/wait/index.js +38 -38
  172. package/dist/util/sveltekit/index.js +1 -1
  173. package/dist/util/sveltekit/route-folders/index.js +101 -101
  174. package/dist/util/time/index.js +323 -323
  175. package/dist/util/unique/index.js +249 -249
  176. package/dist/valibot/date.js__ +10 -10
  177. package/dist/valibot/index.js +9 -9
  178. package/dist/valibot/url.js +95 -95
  179. package/dist/valibot/user.js +23 -23
  180. package/dist/widgets/button-group/ButtonGroup.svelte +82 -94
  181. package/dist/widgets/button-group/ButtonGroup.svelte.d.ts +0 -2
  182. package/dist/widgets/button-group/typedef.js +10 -10
  183. package/dist/widgets/compare-left-right/CompareLeftRight.svelte +179 -179
  184. package/dist/widgets/compare-left-right/index.js +1 -1
  185. package/dist/widgets/game-box/GameBox.svelte +579 -186
  186. package/dist/widgets/game-box/GameBox.svelte.d.ts +64 -4
  187. package/dist/widgets/game-box/gamebox.util.js +83 -83
  188. package/dist/widgets/hk-app-layout/HkAppLayout.state.svelte.js +25 -25
  189. package/dist/widgets/hk-app-layout/HkAppLayout.svelte +251 -251
  190. package/dist/widgets/image-box/ImageBox.svelte +212 -212
  191. package/dist/widgets/image-box/index.js +5 -5
  192. package/dist/widgets/image-box/typedef.js +32 -32
  193. package/dist/widgets/index.js +23 -23
  194. package/dist/widgets/presenter/(broken) Presenter.state.svelte.js__ +613 -0
  195. package/dist/widgets/presenter/ImageSlide.svelte +64 -64
  196. package/dist/widgets/presenter/Presenter.state.svelte.js +636 -636
  197. package/dist/widgets/presenter/Presenter.svelte +140 -140
  198. package/dist/widgets/presenter/Presenter.svelte__ +125 -0
  199. package/dist/widgets/presenter/constants.js +7 -7
  200. package/dist/widgets/presenter/index.js +10 -10
  201. package/dist/widgets/presenter/typedef.js +106 -106
  202. package/dist/widgets/presenter/util.js +210 -210
  203. package/dist/widgets/virtual-viewport/VirtualViewport.svelte +196 -196
  204. package/dist/zod/all.js +33 -33
  205. package/dist/zod/generic.js +11 -11
  206. package/dist/zod/javascript.js +32 -32
  207. package/dist/zod/user.js +16 -16
  208. package/dist/zod/web.js +52 -52
  209. package/package.json +102 -102
@@ -1,80 +1,80 @@
1
- /**
2
- * @example Set theme color in a layout file
3
- *
4
- * // +layout.svelte
5
- * <script>
6
- * import { theme as themeStore } from './theme.js';
7
- *
8
- * const { metaThemeColorBase, metaThemeColorDark } = themeStore;
9
- * </script>
10
- *
11
- * <svelte:head>
12
- * <meta
13
- * name="theme-color"
14
- * media="(prefers-color-scheme: light)"
15
- * content={$metaThemeColorBase}
16
- * />
17
- * <meta
18
- * name="theme-color"
19
- * media="(prefers-color-scheme: dark)"
20
- * content={$metaThemeColorDark}
21
- * />
22
- * </svelte:head>
23
- */
24
-
25
- import { writable, get } from 'svelte/store';
26
-
27
- // > Internals
28
-
29
- const DEFAULT_THEME_COLOR_BASE = '#fffffe';
30
- const DEFAULT_THEME_COLOR_DARK = '#000001';
31
-
32
- /** @type {import('svelte/store').Writable<string>} */
33
- const themeColorBase = writable(DEFAULT_THEME_COLOR_BASE);
34
-
35
- /** @type {import('svelte/store').Writable<string|null>} */
36
- const themeColorDark = writable(DEFAULT_THEME_COLOR_DARK);
37
-
38
- // > Exports
39
-
40
- /**
41
- * Set meta theme color for both light and dark mode
42
- *
43
- * @param {string} value - HTML Color
44
- */
45
- export function setMetaThemeColor(value) {
46
- themeColorBase.set(value);
47
- themeColorDark.set(value);
48
- }
49
-
50
- /**
51
- * Set meta theme color for light mode
52
- *
53
- * @param {string} value - HTML Color
54
- */
55
- export function setMetaThemeColorBase(value) {
56
- themeColorBase.set(value);
57
- }
58
-
59
- /**
60
- * Set meta theme color for dark mode only
61
- *
62
- * @param {string} value - HTML Color
63
- */
64
- export function setMetaThemeColorDark(value) {
65
- themeColorDark.set(value);
66
- }
67
-
68
- export const metaThemeColorBase = {
69
- subscribe: themeColorBase.subscribe,
70
- get: () => {
71
- get(themeColorBase);
72
- }
73
- };
74
-
75
- export const metaThemeColorDark = {
76
- subscribe: themeColorDark.subscribe,
77
- get: () => {
78
- get(themeColorDark);
79
- }
80
- };
1
+ /**
2
+ * @example Set theme color in a layout file
3
+ *
4
+ * // +layout.svelte
5
+ * <script>
6
+ * import { theme as themeStore } from './theme.js';
7
+ *
8
+ * const { metaThemeColorBase, metaThemeColorDark } = themeStore;
9
+ * </script>
10
+ *
11
+ * <svelte:head>
12
+ * <meta
13
+ * name="theme-color"
14
+ * media="(prefers-color-scheme: light)"
15
+ * content={$metaThemeColorBase}
16
+ * />
17
+ * <meta
18
+ * name="theme-color"
19
+ * media="(prefers-color-scheme: dark)"
20
+ * content={$metaThemeColorDark}
21
+ * />
22
+ * </svelte:head>
23
+ */
24
+
25
+ import { writable, get } from 'svelte/store';
26
+
27
+ // > Internals
28
+
29
+ const DEFAULT_THEME_COLOR_BASE = '#fffffe';
30
+ const DEFAULT_THEME_COLOR_DARK = '#000001';
31
+
32
+ /** @type {import('svelte/store').Writable<string>} */
33
+ const themeColorBase = writable(DEFAULT_THEME_COLOR_BASE);
34
+
35
+ /** @type {import('svelte/store').Writable<string|null>} */
36
+ const themeColorDark = writable(DEFAULT_THEME_COLOR_DARK);
37
+
38
+ // > Exports
39
+
40
+ /**
41
+ * Set meta theme color for both light and dark mode
42
+ *
43
+ * @param {string} value - HTML Color
44
+ */
45
+ export function setMetaThemeColor(value) {
46
+ themeColorBase.set(value);
47
+ themeColorDark.set(value);
48
+ }
49
+
50
+ /**
51
+ * Set meta theme color for light mode
52
+ *
53
+ * @param {string} value - HTML Color
54
+ */
55
+ export function setMetaThemeColorBase(value) {
56
+ themeColorBase.set(value);
57
+ }
58
+
59
+ /**
60
+ * Set meta theme color for dark mode only
61
+ *
62
+ * @param {string} value - HTML Color
63
+ */
64
+ export function setMetaThemeColorDark(value) {
65
+ themeColorDark.set(value);
66
+ }
67
+
68
+ export const metaThemeColorBase = {
69
+ subscribe: themeColorBase.subscribe,
70
+ get: () => {
71
+ get(themeColorBase);
72
+ }
73
+ };
74
+
75
+ export const metaThemeColorDark = {
76
+ subscribe: themeColorDark.subscribe,
77
+ get: () => {
78
+ get(themeColorDark);
79
+ }
80
+ };
@@ -1,41 +1,41 @@
1
- @define-mixin text_block {
2
-
3
- /* .on-primary-dark
4
- {
5
- & [data-title-text-button-block] {
6
- & > .title-box {
7
- @apply text-white;
8
- }
9
-
10
- & > .text-box {
11
- ...text color
12
- }
13
- }
14
- } */
15
-
16
- [data-title-text-button-block] {
17
-
18
- &.block-width {
19
- @apply w-1/2;
20
- }
21
-
22
- & > .title-box {
23
- @apply text-heading-h3;
24
- @apply uppercase;
25
- }
26
-
27
- & > .content-box .p {
28
- @apply text-base-md;
29
- }
30
-
31
- & > .content-box:has( + .footer-box )
32
- {
33
- @apply mb-30p; /* 10p + 20p */
34
- }
35
-
36
- & > .footer-box {
37
- }
38
- }
39
-
40
-
41
- }
1
+ @define-mixin text_block {
2
+
3
+ /* .on-primary-dark
4
+ {
5
+ & [data-title-text-button-block] {
6
+ & > .title-box {
7
+ @apply text-white;
8
+ }
9
+
10
+ & > .text-box {
11
+ ...text color
12
+ }
13
+ }
14
+ } */
15
+
16
+ [data-title-text-button-block] {
17
+
18
+ &.block-width {
19
+ @apply w-1/2;
20
+ }
21
+
22
+ & > .title-box {
23
+ @apply text-heading-h3;
24
+ @apply uppercase;
25
+ }
26
+
27
+ & > .content-box .p {
28
+ @apply text-base-md;
29
+ }
30
+
31
+ & > .content-box:has( + .footer-box )
32
+ {
33
+ @apply mb-30p; /* 10p + 20p */
34
+ }
35
+
36
+ & > .footer-box {
37
+ }
38
+ }
39
+
40
+
41
+ }
@@ -1,12 +1,12 @@
1
- @import '../../global/on-colors.css';
2
-
3
- @define-mixin boxes-game-box {
4
- [data-boxes='game-box'] {
5
- /*& .game-box-padding-20p {
6
- @apply mt-20p;
7
- @apply mr-20p;
8
- @apply mb-20p;
9
- @apply ml-20p;
10
- }*/
11
- }
12
- }
1
+ @import '../../global/on-colors.css';
2
+
3
+ @define-mixin boxes-game-box {
4
+ [data-boxes='game-box'] {
5
+ /*& .game-box-padding-20p {
6
+ @apply mt-20p;
7
+ @apply mr-20p;
8
+ @apply mb-20p;
9
+ @apply ml-20p;
10
+ }*/
11
+ }
12
+ }
@@ -1,22 +1,22 @@
1
- @define-mixin component-button-icon-steeze {
2
-
3
- /* @note using CSS vars defined in the parent button postcss */
4
-
5
- /* Type-based styling for text buttons */
6
- [data-component="button"][data-type="icon-steeze"] {
7
-
8
- /*&[data-size="sm"] {
9
- @apply px-8ut py-8ut;
10
- }
11
-
12
- &[data-size="md"] {
13
- @apply px-16ut py-12ut;
14
- }
15
-
16
- &[data-size="lg"] {
17
- @apply px-32ut py-16ut;
18
- }*/
19
-
20
- }
21
-
22
- }
1
+ @define-mixin component-button-icon-steeze {
2
+
3
+ /* @note using CSS vars defined in the parent button postcss */
4
+
5
+ /* Type-based styling for text buttons */
6
+ [data-component="button"][data-type="icon-steeze"] {
7
+
8
+ /*&[data-size="sm"] {
9
+ @apply px-8ut py-8ut;
10
+ }
11
+
12
+ &[data-size="md"] {
13
+ @apply px-16ut py-12ut;
14
+ }
15
+
16
+ &[data-size="lg"] {
17
+ @apply px-32ut py-16ut;
18
+ }*/
19
+
20
+ }
21
+
22
+ }
@@ -1,32 +1,32 @@
1
- @define-mixin component-button-text {
2
-
3
- /* @note using CSS vars defined in the parent button postcss */
4
-
5
- /* Type-based styling for text buttons */
6
- [data-component="button"][data-type="text"] {
7
-
8
- /* Typography settings */
9
- @apply font-ui text-ui-md;
10
- @apply uppercase;
11
- @apply whitespace-nowrap;
12
-
13
- /* Size settings */
14
-
15
- &[data-size="md"] {
16
- @apply rounded-sm;
17
- @apply py-8ut px-16ut;
18
- min-width: var(--btn-min-width);
19
- min-height: var(--btn-min-height);
20
- }
21
-
22
- /* Role-specific text adjustments */
23
- &[data-role="primary"] {
24
- @apply font-extrabold;
25
- }
26
-
27
- &[data-role="secondary"] {
28
- @apply font-bold;
29
- }
30
- }
31
-
32
- }
1
+ @define-mixin component-button-text {
2
+
3
+ /* @note using CSS vars defined in the parent button postcss */
4
+
5
+ /* Type-based styling for text buttons */
6
+ [data-component="button"][data-type="text"] {
7
+
8
+ /* Typography settings */
9
+ @apply font-ui text-ui-md;
10
+ @apply uppercase;
11
+ @apply whitespace-nowrap;
12
+
13
+ /* Size settings */
14
+
15
+ &[data-size="md"] {
16
+ @apply rounded-sm;
17
+ @apply py-8ut px-16ut;
18
+ min-width: var(--btn-min-width);
19
+ min-height: var(--btn-min-height);
20
+ }
21
+
22
+ /* Role-specific text adjustments */
23
+ &[data-role="primary"] {
24
+ @apply font-extrabold;
25
+ }
26
+
27
+ &[data-role="secondary"] {
28
+ @apply font-bold;
29
+ }
30
+ }
31
+
32
+ }
@@ -1,142 +1,142 @@
1
- @define-mixin component-button {
2
- [data-component='button'] {
3
- /* ---- Core Button Variables ---- */
4
-
5
- /* Size variables */
6
- --btn-min-width: calc(150px * var(--scale-ui));
7
- --btn-min-height: calc(40px * var(--scale-ui));
8
-
9
- /* ---- Primary Button Variables ---- */
10
- --btn-primary-bg: var(--color-primary-500);
11
- --btn-primary-text: var(--color-primary-50);
12
- --btn-primary-border: var(--color-primary-500);
13
- --btn-primary-selected-bg: var(--color-primary-700);
14
- --btn-primary-selected-border: var(--color-primary-800);
15
- --btn-primary-selected-text: var(--color-primary-50);
16
- --btn-primary-hover-bg: var(--color-primary-600);
17
- --btn-primary-hover-border: var(--color-primary-600);
18
- --btn-primary-focus-outline: var(--color-primary-800);
19
-
20
- /* ---- Secondary Button Variables ---- */
21
- --btn-secondary-bg: transparent;
22
- --btn-secondary-text: var(--color-secondary-500);
23
- --btn-secondary-border: var(--color-secondary-500);
24
- --btn-secondary-selected-bg: var(--color-secondary-100);
25
- --btn-secondary-selected-border: var(--color-secondary-600);
26
- --btn-secondary-selected-text: var(--color-secondary-800);
27
- --btn-secondary-hover-bg: var(--color-secondary-50);
28
- --btn-secondary-hover-border: var(--color-secondary-500);
29
- --btn-secondary-focus-outline: var(--color-secondary-800);
30
-
31
- /* ---- State Variables ---- */
32
- --btn-active-transform: scale(0.98);
33
- --btn-active-shadow: inset 0 2px 4px 0 rgba(0, 0, 0, 0.1);
34
-
35
- --btn-error-border: var(--color-error-500);
36
- --btn-loading-opacity: 0.8;
37
-
38
- /* Appearance variations */
39
- --btn-border-width: 2px;
40
- --btn-transition-duration: 150ms;
41
- --btn-disabled-opacity: 0.6;
42
- --btn-focus-ring-width: 3px;
43
- --btn-focus-ring-opacity: 0.4;
44
-
45
- /* Base styles */
46
- display: inline-flex;
47
- justify-content: center;
48
- align-items: center;
49
- cursor: pointer;
50
- position: relative;
51
- transition-property:
52
- background-color, color, border-color, transform, box-shadow;
53
- transition-duration: var(--btn-transition-duration);
54
- }
55
-
56
- /* Size variants */
57
- /*[data-component="button"][data-size="sm"] {
58
- @apply rounded-xs;
59
- @apply py-8ut px-8ut;
60
- @apply min-w-24ut min-h-24ut;
61
- }*/
62
-
63
- /*[data-component="button"][data-size="lg"] {
64
- @apply rounded-sm;
65
- @apply py-16ut px-36ut;
66
- @apply min-w-36ut min-h-36ut;
67
- }*/
68
-
69
- /* Role-based styling for primary buttons */
70
- [data-component='button'][data-role='primary'] {
71
- @apply border-width-normal;
72
- border-color: rgb(var(--btn-primary-border));
73
- background-color: rgb(var(--btn-primary-bg));
74
- color: rgb(var(--btn-primary-text));
75
-
76
- &:hover:not(:disabled):not(.state-selected) {
77
- border-color: rgb(var(--btn-primary-hover-border));
78
- background-color: rgb(var(--btn-primary-hover-bg));
79
- }
80
-
81
- &:focus-visible {
82
- @apply outline outline-normal outline-offset-normal;
83
- outline-color: rgb(var(--btn-primary-focus-outline));
84
- }
85
-
86
- &.state-selected {
87
- background-color: rgb(var(--btn-primary-selected-bg));
88
- border-color: rgb(var(--btn-primary-selected-border));
89
- color: rgb(var(--btn-primary-selected-text));
90
- }
91
- }
92
-
93
- /* Role-based styling for secondary buttons */
94
- [data-component='button'][data-role='secondary'] {
95
- @apply border-width-normal;
96
- border-color: rgb(var(--btn-secondary-border));
97
- color: rgb(var(--btn-secondary-text));
98
- background-color: var(--btn-secondary-bg);
99
-
100
- &:hover:not(:disabled):not(.state-selected) {
101
- background-color: rgb(var(--btn-secondary-hover-bg));
102
- border-color: rgb(var(--btn-secondary-hover-border));
103
- }
104
-
105
- &:focus-visible {
106
- @apply outline outline-normal outline-offset-normal;
107
- outline-color: rgb(var(--btn-secondary-focus-outline));
108
- }
109
-
110
- &.state-selected {
111
- background-color: rgb(var(--btn-secondary-selected-bg));
112
- border-color: rgb(var(--btn-secondary-selected-border));
113
- color: rgb(var(--btn-secondary-selected-text));
114
- }
115
- }
116
-
117
- /* State-based styling for primary and secondary buttons */
118
-
119
- [data-component='button'][data-role='primary'],
120
- [data-component='button'][data-role='secondary'] {
121
- &.state-active {
122
- transform: var(--btn-active-transform);
123
- box-shadow: var(--btn-active-shadow);
124
- }
125
-
126
- &.state-error {
127
- border-color: rgb(var(--btn-error-border));
128
- }
129
-
130
- &.state-loading {
131
- opacity: var(--btn-loading-opacity);
132
- cursor: wait;
133
- }
134
- }
135
-
136
- /* Disabled state */
137
- [data-component='button']:disabled {
138
- cursor: not-allowed;
139
- opacity: var(--btn-disabled-opacity);
140
- pointer-events: none;
141
- }
142
- }
1
+ @define-mixin component-button {
2
+ [data-component='button'] {
3
+ /* ---- Core Button Variables ---- */
4
+
5
+ /* Size variables */
6
+ --btn-min-width: calc(150px * var(--scale-ui));
7
+ --btn-min-height: calc(40px * var(--scale-ui));
8
+
9
+ /* ---- Primary Button Variables ---- */
10
+ --btn-primary-bg: var(--color-primary-500);
11
+ --btn-primary-text: var(--color-primary-50);
12
+ --btn-primary-border: var(--color-primary-500);
13
+ --btn-primary-selected-bg: var(--color-primary-700);
14
+ --btn-primary-selected-border: var(--color-primary-800);
15
+ --btn-primary-selected-text: var(--color-primary-50);
16
+ --btn-primary-hover-bg: var(--color-primary-600);
17
+ --btn-primary-hover-border: var(--color-primary-600);
18
+ --btn-primary-focus-outline: var(--color-primary-800);
19
+
20
+ /* ---- Secondary Button Variables ---- */
21
+ --btn-secondary-bg: transparent;
22
+ --btn-secondary-text: var(--color-secondary-500);
23
+ --btn-secondary-border: var(--color-secondary-500);
24
+ --btn-secondary-selected-bg: var(--color-secondary-100);
25
+ --btn-secondary-selected-border: var(--color-secondary-600);
26
+ --btn-secondary-selected-text: var(--color-secondary-800);
27
+ --btn-secondary-hover-bg: var(--color-secondary-50);
28
+ --btn-secondary-hover-border: var(--color-secondary-500);
29
+ --btn-secondary-focus-outline: var(--color-secondary-800);
30
+
31
+ /* ---- State Variables ---- */
32
+ --btn-active-transform: scale(0.98);
33
+ --btn-active-shadow: inset 0 2px 4px 0 rgba(0, 0, 0, 0.1);
34
+
35
+ --btn-error-border: var(--color-error-500);
36
+ --btn-loading-opacity: 0.8;
37
+
38
+ /* Appearance variations */
39
+ --btn-border-width: 2px;
40
+ --btn-transition-duration: 150ms;
41
+ --btn-disabled-opacity: 0.6;
42
+ --btn-focus-ring-width: 3px;
43
+ --btn-focus-ring-opacity: 0.4;
44
+
45
+ /* Base styles */
46
+ display: inline-flex;
47
+ justify-content: center;
48
+ align-items: center;
49
+ cursor: pointer;
50
+ position: relative;
51
+ transition-property:
52
+ background-color, color, border-color, transform, box-shadow;
53
+ transition-duration: var(--btn-transition-duration);
54
+ }
55
+
56
+ /* Size variants */
57
+ /*[data-component="button"][data-size="sm"] {
58
+ @apply rounded-xs;
59
+ @apply py-8ut px-8ut;
60
+ @apply min-w-24ut min-h-24ut;
61
+ }*/
62
+
63
+ /*[data-component="button"][data-size="lg"] {
64
+ @apply rounded-sm;
65
+ @apply py-16ut px-36ut;
66
+ @apply min-w-36ut min-h-36ut;
67
+ }*/
68
+
69
+ /* Role-based styling for primary buttons */
70
+ [data-component='button'][data-role='primary'] {
71
+ @apply border-width-normal;
72
+ border-color: rgb(var(--btn-primary-border));
73
+ background-color: rgb(var(--btn-primary-bg));
74
+ color: rgb(var(--btn-primary-text));
75
+
76
+ &:hover:not(:disabled):not(.state-selected) {
77
+ border-color: rgb(var(--btn-primary-hover-border));
78
+ background-color: rgb(var(--btn-primary-hover-bg));
79
+ }
80
+
81
+ &:focus-visible {
82
+ @apply outline outline-normal outline-offset-normal;
83
+ outline-color: rgb(var(--btn-primary-focus-outline));
84
+ }
85
+
86
+ &.state-selected {
87
+ background-color: rgb(var(--btn-primary-selected-bg));
88
+ border-color: rgb(var(--btn-primary-selected-border));
89
+ color: rgb(var(--btn-primary-selected-text));
90
+ }
91
+ }
92
+
93
+ /* Role-based styling for secondary buttons */
94
+ [data-component='button'][data-role='secondary'] {
95
+ @apply border-width-normal;
96
+ border-color: rgb(var(--btn-secondary-border));
97
+ color: rgb(var(--btn-secondary-text));
98
+ background-color: var(--btn-secondary-bg);
99
+
100
+ &:hover:not(:disabled):not(.state-selected) {
101
+ background-color: rgb(var(--btn-secondary-hover-bg));
102
+ border-color: rgb(var(--btn-secondary-hover-border));
103
+ }
104
+
105
+ &:focus-visible {
106
+ @apply outline outline-normal outline-offset-normal;
107
+ outline-color: rgb(var(--btn-secondary-focus-outline));
108
+ }
109
+
110
+ &.state-selected {
111
+ background-color: rgb(var(--btn-secondary-selected-bg));
112
+ border-color: rgb(var(--btn-secondary-selected-border));
113
+ color: rgb(var(--btn-secondary-selected-text));
114
+ }
115
+ }
116
+
117
+ /* State-based styling for primary and secondary buttons */
118
+
119
+ [data-component='button'][data-role='primary'],
120
+ [data-component='button'][data-role='secondary'] {
121
+ &.state-active {
122
+ transform: var(--btn-active-transform);
123
+ box-shadow: var(--btn-active-shadow);
124
+ }
125
+
126
+ &.state-error {
127
+ border-color: rgb(var(--btn-error-border));
128
+ }
129
+
130
+ &.state-loading {
131
+ opacity: var(--btn-loading-opacity);
132
+ cursor: wait;
133
+ }
134
+ }
135
+
136
+ /* Disabled state */
137
+ [data-component='button']:disabled {
138
+ cursor: not-allowed;
139
+ opacity: var(--btn-disabled-opacity);
140
+ pointer-events: none;
141
+ }
142
+ }
@@ -1,6 +1,6 @@
1
- @import '../../global/on-colors.css';
2
-
3
- @define-mixin buttons-skip-button {
4
- [data-button='skip-button'] {
5
- }
6
- }
1
+ @import '../../global/on-colors.css';
2
+
3
+ @define-mixin buttons-skip-button {
4
+ [data-button='skip-button'] {
5
+ }
6
+ }