lapikit 0.0.0-insiders.f8b6426 → 0.0.0-insiders.fb12c48

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 (181) hide show
  1. package/bin/configuration.js +303 -0
  2. package/bin/helper.js +0 -38
  3. package/bin/index.js +33 -0
  4. package/bin/presets.js +26 -0
  5. package/bin/prompts.js +67 -0
  6. package/dist/actions/accordion.svelte.d.ts +9 -0
  7. package/dist/actions/index.d.ts +2 -1
  8. package/dist/actions/index.js +2 -1
  9. package/dist/actions/use-theme.d.ts +1 -0
  10. package/dist/actions/use-theme.js +18 -0
  11. package/dist/components/accordion/accordion.css +0 -77
  12. package/dist/components/accordion/accordion.svelte +5 -3
  13. package/dist/components/accordion/modules/accordion-item.css +68 -0
  14. package/dist/components/accordion/modules/accordion-item.svelte +4 -4
  15. package/dist/components/accordion/types.d.ts +1 -1
  16. package/dist/components/alert/alert.css +11 -18
  17. package/dist/components/alert/alert.svelte +4 -4
  18. package/dist/components/alert/types.d.ts +1 -1
  19. package/dist/components/app/app.css +1 -2
  20. package/dist/components/app/app.svelte +39 -21
  21. package/dist/components/app/app.svelte.d.ts +2 -0
  22. package/dist/components/appbar/appbar.css +8 -18
  23. package/dist/components/appbar/appbar.svelte +4 -4
  24. package/dist/components/appbar/types.d.ts +1 -1
  25. package/dist/components/aspect-ratio/aspect-ratio.svelte +0 -22
  26. package/dist/components/aspect-ratio/types.d.ts +1 -1
  27. package/dist/components/avatar/avatar.css +7 -14
  28. package/dist/components/avatar/avatar.svelte +4 -4
  29. package/dist/components/avatar/types.d.ts +1 -1
  30. package/dist/components/button/button.css +29 -36
  31. package/dist/components/button/button.svelte +5 -5
  32. package/dist/components/button/types.d.ts +1 -1
  33. package/dist/components/card/card.css +10 -20
  34. package/dist/components/card/card.svelte +9 -5
  35. package/dist/components/card/types.d.ts +3 -1
  36. package/dist/components/chip/chip.css +30 -37
  37. package/dist/components/chip/chip.svelte +10 -8
  38. package/dist/components/chip/types.d.ts +2 -1
  39. package/dist/components/dialog/dialog.css +15 -20
  40. package/dist/components/dialog/dialog.svelte +5 -5
  41. package/dist/components/dialog/types.d.ts +1 -1
  42. package/dist/components/dropdown/dropdown.css +3 -12
  43. package/dist/components/dropdown/dropdown.svelte +6 -7
  44. package/dist/components/dropdown/types.d.ts +1 -1
  45. package/dist/components/icon/icon.css +11 -12
  46. package/dist/components/icon/icon.svelte +2 -2
  47. package/dist/components/icon/types.d.ts +1 -1
  48. package/dist/components/list/list.css +19 -91
  49. package/dist/components/list/list.svelte +4 -4
  50. package/dist/components/list/modules/list-item.css +67 -0
  51. package/dist/components/list/modules/list-item.svelte +5 -5
  52. package/dist/components/list/types.d.ts +1 -1
  53. package/dist/components/modal/modal.css +22 -29
  54. package/dist/components/modal/modal.svelte +4 -5
  55. package/dist/components/modal/types.d.ts +1 -1
  56. package/dist/components/popover/popover.css +3 -12
  57. package/dist/components/popover/popover.svelte +6 -6
  58. package/dist/components/popover/types.d.ts +1 -1
  59. package/dist/components/separator/separator.css +4 -8
  60. package/dist/components/separator/separator.svelte +5 -5
  61. package/dist/components/separator/types.d.ts +1 -1
  62. package/dist/components/spacer/types.d.ts +1 -1
  63. package/dist/components/textfield/textfield.css +16 -23
  64. package/dist/components/textfield/textfield.svelte +4 -4
  65. package/dist/components/textfield/types.d.ts +1 -1
  66. package/dist/components/toolbar/toolbar.css +11 -34
  67. package/dist/components/toolbar/toolbar.svelte +4 -4
  68. package/dist/components/toolbar/types.d.ts +1 -1
  69. package/dist/components/tooltip/tooltip.css +5 -13
  70. package/dist/components/tooltip/tooltip.svelte +5 -5
  71. package/dist/components/tooltip/types.d.ts +1 -1
  72. package/dist/index.d.ts +3 -1
  73. package/dist/index.js +23 -3
  74. package/dist/internal/config/presets.d.ts +149 -0
  75. package/dist/internal/config/presets.js +169 -0
  76. package/dist/internal/config/variables.d.ts +3 -0
  77. package/dist/internal/config/variables.js +3 -0
  78. package/dist/internal/{assets.svelte.js → core/actions/assets.svelte.js} +4 -4
  79. package/dist/internal/core/actions/dropdown.svelte.d.ts +7 -0
  80. package/dist/internal/core/actions/popover.svelte.d.ts +7 -0
  81. package/dist/internal/core/actions/tooltip.svelte.d.ts +7 -0
  82. package/dist/internal/{ripple.js → core/animations/ripple.js} +3 -3
  83. package/dist/internal/core/css.d.ts +1 -0
  84. package/dist/internal/core/css.js +16 -0
  85. package/dist/internal/core/formatter/component.d.ts +5 -0
  86. package/dist/internal/core/formatter/component.js +60 -0
  87. package/dist/internal/core/formatter/device.d.ts +5 -0
  88. package/dist/internal/core/formatter/device.js +66 -0
  89. package/dist/internal/core/formatter/index.d.ts +7 -0
  90. package/dist/internal/core/formatter/index.js +35 -0
  91. package/dist/internal/core/formatter/style.d.ts +4 -0
  92. package/dist/internal/core/formatter/style.js +15 -0
  93. package/dist/internal/core/formatter/theme.d.ts +5 -0
  94. package/dist/internal/core/formatter/theme.js +44 -0
  95. package/dist/internal/core/formatter/typography.d.ts +5 -0
  96. package/dist/internal/core/formatter/typography.js +12 -0
  97. package/dist/internal/core/standard-colors.d.ts +75 -0
  98. package/dist/internal/core/standard-colors.js +75 -0
  99. package/dist/internal/helpers/colors.d.ts +1 -0
  100. package/dist/internal/{colors.js → helpers/colors.js} +2 -2
  101. package/dist/internal/helpers/convert.d.ts +1 -0
  102. package/dist/internal/helpers/convert.js +17 -0
  103. package/dist/internal/helpers/deep-merge.d.ts +44 -0
  104. package/dist/internal/helpers/deep-merge.js +80 -0
  105. package/dist/internal/helpers/parser.d.ts +10 -0
  106. package/dist/internal/helpers/parser.js +93 -0
  107. package/dist/internal/plugins/vite.d.ts +8 -0
  108. package/dist/internal/plugins/vite.js +33 -0
  109. package/dist/internal/types/components.d.ts +14 -0
  110. package/dist/internal/types/configuration.d.ts +63 -0
  111. package/dist/internal/types/configuration.js +1 -0
  112. package/dist/internal/types/index.d.ts +2 -0
  113. package/dist/internal/types/index.js +2 -0
  114. package/dist/stores/breakpoints.d.ts +6 -0
  115. package/dist/stores/breakpoints.js +14 -0
  116. package/dist/stores/components.d.ts +8 -0
  117. package/dist/stores/components.js +26 -0
  118. package/dist/stores/devices.d.ts +6 -0
  119. package/dist/stores/devices.js +9 -0
  120. package/dist/stores/index.d.ts +5 -10
  121. package/dist/stores/index.js +5 -47
  122. package/dist/stores/themes.d.ts +2 -0
  123. package/dist/stores/themes.js +4 -0
  124. package/dist/stores/viewport.d.ts +7 -0
  125. package/dist/stores/viewport.js +7 -0
  126. package/dist/styles/animation.css +33 -0
  127. package/dist/styles/keyframes.css +30 -0
  128. package/dist/{style/normalize.css → styles/reset.css} +15 -7
  129. package/dist/themes.css +0 -0
  130. package/package.json +12 -5
  131. package/bin/lapikit.js +0 -79
  132. package/bin/modules/adapter.js +0 -52
  133. package/bin/modules/plugin.js +0 -66
  134. package/bin/modules/preset.js +0 -11
  135. package/dist/internal/colors.d.ts +0 -1
  136. package/dist/internal/index.d.ts +0 -4
  137. package/dist/internal/index.js +0 -4
  138. package/dist/internal/types.d.ts +0 -57
  139. package/dist/internal/unit.d.ts +0 -1
  140. package/dist/internal/unit.js +0 -11
  141. package/dist/plugin/modules/config.d.ts +0 -2
  142. package/dist/plugin/modules/config.js +0 -54
  143. package/dist/plugin/modules/importer.d.ts +0 -1
  144. package/dist/plugin/modules/importer.js +0 -15
  145. package/dist/plugin/vitejs.d.ts +0 -6
  146. package/dist/plugin/vitejs.js +0 -26
  147. package/dist/preset.d.ts +0 -2
  148. package/dist/preset.js +0 -92
  149. package/dist/style/animation.css +0 -62
  150. package/dist/style/css.d.ts +0 -2
  151. package/dist/style/css.js +0 -34
  152. package/dist/style/parser/color.d.ts +0 -5
  153. package/dist/style/parser/color.js +0 -88
  154. package/dist/style/parser/component.d.ts +0 -2
  155. package/dist/style/parser/component.js +0 -115
  156. package/dist/style/parser/device.d.ts +0 -2
  157. package/dist/style/parser/device.js +0 -40
  158. package/dist/style/parser/index.d.ts +0 -4
  159. package/dist/style/parser/index.js +0 -4
  160. package/dist/style/parser/variable.d.ts +0 -2
  161. package/dist/style/parser/variable.js +0 -25
  162. package/dist/style/variable.css +0 -12
  163. /package/dist/{components/accordion → actions}/accordion.svelte.js +0 -0
  164. /package/dist/internal/{assets.svelte.d.ts → core/actions/assets.svelte.d.ts} +0 -0
  165. /package/dist/{components/dropdown → internal/core/actions}/dropdown.svelte.js +0 -0
  166. /package/dist/{components/popover → internal/core/actions}/popover.svelte.js +0 -0
  167. /package/dist/{components/tooltip → internal/core/actions}/tooltip.svelte.js +0 -0
  168. /package/dist/internal/{ripple.d.ts → core/animations/ripple.d.ts} +0 -0
  169. /package/dist/internal/{ansi.d.ts → core/bin/ansi.d.ts} +0 -0
  170. /package/dist/internal/{ansi.js → core/bin/ansi.js} +0 -0
  171. /package/dist/internal/{terminal.d.ts → core/bin/terminal.d.ts} +0 -0
  172. /package/dist/internal/{terminal.js → core/bin/terminal.js} +0 -0
  173. /package/dist/internal/{minify.d.ts → core/minify.d.ts} +0 -0
  174. /package/dist/internal/{minify.js → core/minify.js} +0 -0
  175. /package/dist/{utils/x11.d.ts → internal/core/x11-colors.d.ts} +0 -0
  176. /package/dist/{utils/x11.js → internal/core/x11-colors.js} +0 -0
  177. /package/dist/internal/{clickOutside.d.ts → helpers/outside.d.ts} +0 -0
  178. /package/dist/internal/{clickOutside.js → helpers/outside.js} +0 -0
  179. /package/dist/internal/{scroll.d.ts → helpers/scroll.d.ts} +0 -0
  180. /package/dist/internal/{scroll.js → helpers/scroll.js} +0 -0
  181. /package/dist/internal/{types.js → types/components.js} +0 -0
@@ -1,5 +1,5 @@
1
1
  <script lang="ts">
2
- import { getAssets } from '../../../internal/assets.svelte.js';
2
+ import { getAssets } from '../../../internal/core/actions/assets.svelte.js';
3
3
  import type { AccordionItemProps, ModelAccordionItemProps } from '../types.js';
4
4
 
5
5
  // components
@@ -49,9 +49,9 @@
49
49
  open && 'kit-accordion-item--active',
50
50
  rest.class
51
51
  ]}
52
- style:--base={assets.color(background)}
53
- style:--on={assets.color(color)}
54
- style:--shape={assets.shape(rounded)}
52
+ style:--accordion--item-shape={assets.shape(rounded)}
53
+ style:--accordion--item-background={assets.color(background)}
54
+ style:--accordion--item-color={assets.color(color)}
55
55
  >
56
56
  <button
57
57
  class={[
@@ -1,4 +1,4 @@
1
- import type { Component } from '../../internal/types.js';
1
+ import type { Component } from '../../internal/types/index.js';
2
2
  import type { Snippet } from 'svelte';
3
3
  export interface AccordionProps extends Component {
4
4
  ref?: HTMLElement | null;
@@ -1,10 +1,3 @@
1
- /* root */
2
- .kit-alert {
3
- --alert-color: var(--on, var(--kit-on-container));
4
- --alert-background: var(--base, var(--kit-container));
5
- --alert-radius: var(--shape, var(--kit-radius-md));
6
- }
7
-
8
1
  .kit-alert {
9
2
  display: grid;
10
3
  flex: 1 1;
@@ -15,9 +8,9 @@
15
8
  position: relative;
16
9
  padding: 1rem;
17
10
  overflow: hidden;
18
- color: var(--alert-color);
19
- background-color: var(--alert-background);
20
- border-radius: var(--alert-radius);
11
+ color: var(--alert-color, var(--kit-label-primary));
12
+ background-color: var(--alert-background, var(--kit-background-grouped-tertiary));
13
+ border-radius: var(--alert-shape, var(--system-shape-md));
21
14
  line-height: 0;
22
15
  }
23
16
 
@@ -87,34 +80,34 @@
87
80
  /* state */
88
81
  .kit-alert.kit-alert--info:not([class*='alert--variant-']) {
89
82
  --on: var(--kit-on-info);
90
- --base: var(--kit-info);
83
+ --base: var(--kit-accent-info);
91
84
  }
92
85
  .kit-alert.kit-alert--info[class*='alert--variant-'] {
93
- --base: var(--kit-info);
86
+ --base: var(--kit-accent-info);
94
87
  }
95
88
 
96
89
  .kit-alert.kit-alert--success:not([class*='alert--variant-']) {
97
90
  --on: var(--kit-on-success);
98
- --base: var(--kit-success);
91
+ --base: var(--kit-accent-successs);
99
92
  }
100
93
  .kit-alert.kit-alert--success[class*='alert--variant-'] {
101
- --base: var(--kit-success);
94
+ --base: var(--kit-accent-successs);
102
95
  }
103
96
 
104
97
  .kit-alert.kit-alert--warning:not([class*='alert--variant-']) {
105
98
  --on: var(--kit-on-warning);
106
- --base: var(--kit-warning);
99
+ --base: var(--kit-accent-warning);
107
100
  }
108
101
  .kit-alert.kit-alert--warning[class*='alert--variant-'] {
109
- --base: var(--kit-warning);
102
+ --base: var(--kit-accent-warning);
110
103
  }
111
104
 
112
105
  .kit-alert.kit-alert--error:not([class*='alert--variant-']) {
113
106
  --on: var(--kit-on-error);
114
- --base: var(--kit-error);
107
+ --base: var(--kit-accent-destructive);
115
108
  }
116
109
  .kit-alert.kit-alert--error[class*='alert--variant-'] {
117
- --base: var(--kit-error);
110
+ --base: var(--kit-accent-destructive);
118
111
  }
119
112
 
120
113
  /* variant */
@@ -1,5 +1,5 @@
1
1
  <script lang="ts">
2
- import { getAssets } from '../../internal/assets.svelte.js';
2
+ import { getAssets } from '../../internal/core/actions/assets.svelte.js';
3
3
  import type { AlertProps } from './types.js';
4
4
 
5
5
  // components
@@ -51,9 +51,9 @@
51
51
  rest.class
52
52
  ]}
53
53
  role="alert"
54
- style:--base={assets.color(background)}
55
- style:--on={assets.color(color)}
56
- style:--shape={assets.shape(rounded)}
54
+ style:--alert-background={assets.color(background)}
55
+ style:--alert-color={assets.color(color)}
56
+ style:--alert-shape={assets.shape(rounded)}
57
57
  >
58
58
  {#if prepend}
59
59
  <div class="kit-alert--prepend">
@@ -1,4 +1,4 @@
1
- import type { Component } from '../../internal/types.js';
1
+ import type { Component } from '../../internal/types/index.js';
2
2
  import type { Snippet } from 'svelte';
3
3
  type AlertDensity = 'compact' | 'comfortable' | 'default';
4
4
  type AlertVariant = 'outline' | 'dash' | 'text';
@@ -4,13 +4,12 @@
4
4
  left: 0;
5
5
  height: 100%;
6
6
  width: 100%;
7
- background-color: color-mix(in oklab, var(--kit-shadow) 70%, transparent);
7
+ background-color: color-mix(in oklab, var(--kit-state-shadow) 70%, transparent);
8
8
  z-index: 9000;
9
9
  cursor: default;
10
10
  }
11
11
 
12
12
  .kit-overlay.kit-overlay--persistent {
13
- /* pointer-events: none; */
14
13
  user-select: none;
15
14
  cursor: default;
16
15
  }
@@ -1,33 +1,51 @@
1
1
  <script lang="ts">
2
2
  import { BROWSER } from 'esm-env';
3
- import {
4
- colorSchemeSystem,
5
- modalOpen,
6
- setOpenModal,
7
- updateThemeStore
8
- } from '../../stores/index.js';
9
3
  import type { Snippet } from 'svelte';
10
- let { children }: { children: Snippet } = $props();
4
+ import { useTheme } from '../../actions/use-theme.js';
5
+ import { modalOpen, setOpenModal } from '../../stores/components.js';
6
+
7
+ import { viewport } from '../../stores/viewport.js';
8
+
9
+ let {
10
+ children,
11
+ themes,
12
+ storageKey = '@lapikit/theme'
13
+ }: { children: Snippet; themes?: string | string[]; storageKey?: string } = $props();
11
14
 
12
15
  $effect.pre(() => {
13
16
  if (!BROWSER) return;
14
- // system
15
- if (window.matchMedia) {
16
- colorSchemeSystem.set(
17
- window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light'
18
- );
17
+ const colorScheme = window.matchMedia('(prefers-color-scheme: dark)').matches
18
+ ? 'dark'
19
+ : 'light';
20
+ const localTheme = localStorage.getItem(storageKey);
21
+
22
+ if (localTheme) {
23
+ useTheme(localTheme);
24
+ } else if (colorScheme) {
25
+ if (typeof themes === 'string') {
26
+ useTheme(themes);
27
+ } else if (typeof themes === 'object' && Array.isArray(themes)) {
28
+ if (colorScheme === 'dark') useTheme(themes[1] ?? themes[0]);
29
+ else useTheme(themes[0]);
30
+ } else {
31
+ useTheme(colorScheme);
32
+ }
19
33
  }
20
34
 
21
- // listener
22
- window
23
- .matchMedia('(prefers-color-scheme: dark)')
24
- .addEventListener('change', (event: MediaQueryListEvent) => {
25
- colorSchemeSystem.set(event.matches ? 'dark' : 'light');
35
+ // Met à jour le store viewport à l'init et sur resize
36
+ function updateViewport() {
37
+ viewport.set({
38
+ innerWidth: window.innerWidth,
39
+ outerWidth: window.outerWidth,
40
+ innerHeight: window.innerHeight,
41
+ outerHeight: window.outerHeight
26
42
  });
27
-
28
- // local
29
- const local = localStorage.getItem('@lapikit/theme');
30
- if (local !== null) updateThemeStore(local as 'dark' | 'light' | 'system');
43
+ }
44
+ updateViewport();
45
+ window.addEventListener('resize', updateViewport);
46
+ return () => {
47
+ window.removeEventListener('resize', updateViewport);
48
+ };
31
49
  });
32
50
  </script>
33
51
 
@@ -1,6 +1,8 @@
1
1
  import type { Snippet } from 'svelte';
2
2
  type $$ComponentProps = {
3
3
  children: Snippet;
4
+ themes?: string | string[];
5
+ storageKey?: string;
4
6
  };
5
7
  declare const App: import("svelte").Component<$$ComponentProps, {}, "">;
6
8
  type App = ReturnType<typeof App>;
@@ -1,24 +1,14 @@
1
- /* root default*/
2
1
  .kit-appbar {
3
- --appbar-color: var(--on, var(--kit-on-surface));
4
- --appbar-background: var(--base, var(--kit-surface));
5
- --appbar-radius: var(--shape, 0);
6
- --appbar-padding-wrapper: var(--kit-spacing) * 4;
7
- }
2
+ --appbar-padding-wrapper: var(--system-spacing) * 4;
8
3
 
9
- .kit-appbar {
10
4
  display: flex;
11
5
  align-items: center;
12
6
  border-style: solid;
13
7
  border-width: 1px;
14
- border-radius: var(--appbar-radius);
15
- color: var(--appbar-color);
16
- background-color: var(--appbar-background);
17
- border-color: var(--appbar-background);
18
- /* transition:
19
- color 0.5s,
20
- border-color 0.5s,
21
- background-color 0.5s; */
8
+ border-radius: var(--appbar-shape);
9
+ color: var(--appbar-color, var(--kit-label-primary));
10
+ background-color: var(--appbar-background, var(--kit-background-grouped-tertiary));
11
+ border-color: var(--appbar-background, var(--kit-background-grouped-tertiary));
22
12
  }
23
13
 
24
14
  /* wrapper */
@@ -34,15 +24,15 @@
34
24
  /* density */
35
25
  .kit-appbar[breakpoint]kit-appbar--density-default {
36
26
  height: 4rem;
37
- padding-inline: calc(var(--kit-spacing) * 1.5);
27
+ padding-inline: calc(var(--system-spacing) * 1.5);
38
28
  }
39
29
 
40
30
  .kit-appbar[breakpoint]kit-appbar--density-compact {
41
31
  height: 3.5rem;
42
- padding-inline: calc(var(--kit-spacing) * 0.75);
32
+ padding-inline: calc(var(--system-spacing) * 0.75);
43
33
  }
44
34
 
45
35
  .kit-appbar[breakpoint]kit-appbar--density-comfortable {
46
36
  height: 4.5rem;
47
- padding-inline: calc(var(--kit-spacing) * 2.25);
37
+ padding-inline: calc(var(--system-spacing) * 2.25);
48
38
  }
@@ -1,5 +1,5 @@
1
1
  <script lang="ts">
2
- import { getAssets } from '../../internal/index.js';
2
+ import { getAssets } from '../../internal/core/actions/assets.svelte.js';
3
3
  import type { AppbarProps } from './types.js';
4
4
 
5
5
  let {
@@ -30,9 +30,9 @@
30
30
  density && assets.className('appbar', 'density', density),
31
31
  rest.class
32
32
  ]}
33
- style:--base={assets.color(background)}
34
- style:--on={assets.color(color)}
35
- style:--shape={assets.shape(rounded)}
33
+ style:--appbar-background={assets.color(background)}
34
+ style:--appbar-color={assets.color(color)}
35
+ style:--appbar-shape={assets.shape(rounded)}
36
36
  >
37
37
  <div class={['kit-appbar--wrapper', classContent]}>
38
38
  {@render children?.()}
@@ -1,4 +1,4 @@
1
- import type { Component } from '../../internal/types.js';
1
+ import type { Component } from '../../internal/types/index.js';
2
2
  type Density = 'compact' | 'comfortable' | 'default';
3
3
  export interface AppbarProps extends Component {
4
4
  is?: 'div' | 'header' | 'nav';
@@ -23,25 +23,3 @@
23
23
  <div class="kit-aspect-ratio--sizer" style={`padding-bottom: ${paddingBottom}%;`}></div>
24
24
  {@render children?.()}
25
25
  </div>
26
-
27
- <style>
28
- .kit-aspect-ratio {
29
- display: flex;
30
- flex: 1 0 auto;
31
- max-height: 100%;
32
- max-width: 100%;
33
- overflow: hidden;
34
- position: relative;
35
- }
36
-
37
- .kit-aspect-ratio--inline {
38
- display: inline-flex;
39
- flex: 0 0 auto;
40
- }
41
-
42
- .kit-aspect-ratio--sizer {
43
- flex: 1 0 0px;
44
- transition: padding-bottom 0.2s cubic-bezier(0.4, 0, 0.2, 1);
45
- pointer-events: none;
46
- }
47
- </style>
@@ -1,4 +1,4 @@
1
- import type { Component } from '../../internal/types.js';
1
+ import type { Component } from '../../internal/types/index.js';
2
2
  export interface AspectRationProps extends Component {
3
3
  aspectRatio?: string;
4
4
  inline?: boolean;
@@ -1,8 +1,4 @@
1
1
  .kit-avatar {
2
- --avatar-color: var(--on, var(--kit-on-container));
3
- --avatar-background: var(--base, var(--kit-container));
4
- --avatar-radius: var(--shape, var(--kit-radius-full));
5
-
6
2
  display: flex;
7
3
  align-items: center;
8
4
  justify-content: center;
@@ -11,15 +7,12 @@
11
7
  padding-bottom: var(--avatar-spacing-x);
12
8
  padding-right: var(--avatar-spacing-y);
13
9
  padding-left: var(--avatar-spacing-y);
14
-
15
10
  border-width: 1px;
16
11
  border-style: solid;
17
- border-radius: var(--avatar-radius);
18
-
19
- /* theme */
20
- color: var(--avatar-color);
21
- background-color: var(--avatar-background);
22
- border-color: var(--avatar-background);
12
+ border-radius: var(--avatar-shape, var(--system-shape-full));
13
+ color: var(--avatar-color, var(--kit-label-primary));
14
+ background-color: var(--avatar-background, var(--kit-background-secondary));
15
+ border-color: var(--avatar-background, var(--kit-background-secondary));
23
16
  }
24
17
 
25
18
  .kit-avatar.kit-avatar--image {
@@ -91,19 +84,19 @@
91
84
 
92
85
  /* variant */
93
86
  .kit-avatar[breakpoint]kit-avatar--variant-outline {
94
- --avatar-color: var(--base, var(--kit-container));
87
+ --avatar-color: var(--base, var(--kit-background-grouped-tertiary));
95
88
  background-color: transparent;
96
89
  border: 1px solid currentColor;
97
90
  }
98
91
 
99
92
  .kit-avatar[breakpoint]kit-avatar--variant-text {
100
- --avatar-color: var(--base, var(--kit-container));
93
+ --avatar-color: var(--base, var(--kit-background-grouped-tertiary));
101
94
  background-color: transparent;
102
95
  border-color: transparent;
103
96
  }
104
97
 
105
98
  .kit-avatar[breakpoint]kit-avatar--variant-dash {
106
- --avatar-color: var(--base, var(--kit-container));
99
+ --avatar-color: var(--base, var(--kit-background-grouped-tertiary));
107
100
  background-color: transparent;
108
101
  border: 1px dashed currentColor;
109
102
  }
@@ -1,5 +1,5 @@
1
1
  <script lang="ts">
2
- import { getAssets } from '../../internal/assets.svelte.js';
2
+ import { getAssets } from '../../internal/core/actions/assets.svelte.js';
3
3
  import type { AvatarProps } from './types.js';
4
4
  let {
5
5
  children,
@@ -34,9 +34,9 @@
34
34
  density && assets.className('avatar', 'density', density),
35
35
  rest.class
36
36
  ]}
37
- style:--base={assets.color(background)}
38
- style:--on={assets.color(color)}
39
- style:--shape={assets.shape(rounded)}
37
+ style:--avatar-background={assets.color(background)}
38
+ style:--avatar-color={assets.color(color)}
39
+ style:--avatar-shape={assets.shape(rounded)}
40
40
  >
41
41
  {#if src}
42
42
  <img {src} {alt} />
@@ -1,4 +1,4 @@
1
- import type { Component } from '../../internal/types.js';
1
+ import type { Component } from '../../internal/types/index.js';
2
2
  type AvatarSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl' | 'full';
3
3
  type AvatarDensity = 'compact' | 'comfortable' | 'default';
4
4
  type AvatarVariant = 'outline' | 'text' | 'dash';
@@ -1,10 +1,3 @@
1
- /* root */
2
- .kit-button {
3
- --button-color: var(--on, var(--kit-on-container));
4
- --button-background: var(--base, var(--kit-container));
5
- --button-radius: var(--shape, var(--kit-radius-md));
6
- }
7
-
8
1
  .kit-button {
9
2
  position: relative;
10
3
  cursor: pointer;
@@ -14,8 +7,8 @@
14
7
  padding-bottom: var(--button-spacing-x);
15
8
  padding-right: var(--button-spacing-y);
16
9
  padding-left: var(--button-spacing-y);
17
- border-radius: var(--button-radius);
18
- color: var(--button-color);
10
+ border-radius: var(--button-shape, var(--system-shape-md));
11
+ color: var(--button-color, var(--kit-label-primary));
19
12
  font-weight: 500;
20
13
  text-decoration: none;
21
14
  }
@@ -29,8 +22,8 @@
29
22
  align-items: center;
30
23
  justify-content: center;
31
24
  white-space: nowrap;
32
- gap: calc(var(--kit-spacing) * var(--button-multiplier-gap));
33
- font-size: calc(var(--kit-spacing) * var(--button-multiplier-font-size));
25
+ gap: calc(var(--system-spacing) * var(--button-multiplier-gap));
26
+ font-size: calc(var(--system-spacing) * var(--button-multiplier-font-size));
34
27
  }
35
28
 
36
29
  .kit-button::after {
@@ -106,49 +99,49 @@
106
99
 
107
100
  /* density */
108
101
  .kit-button:not(.kit-button--icon)[breakpoint]kit-button--density-default {
109
- height: calc(var(--kit-spacing) * var(--button-multiplier-x));
102
+ height: calc(var(--system-spacing) * var(--button-multiplier-x));
110
103
  --button-spacing-x: 0;
111
- --button-spacing-y: calc(var(--kit-spacing) * var(--button-multiplier-y));
104
+ --button-spacing-y: calc(var(--system-spacing) * var(--button-multiplier-y));
112
105
  }
113
106
  .kit-button.kit-button--icon[breakpoint]kit-button--density-default {
114
- height: calc(var(--kit-spacing) * var(--button-multiplier-x));
115
- width: calc(var(--kit-spacing) * var(--button-multiplier-x));
107
+ height: calc(var(--system-spacing) * var(--button-multiplier-x));
108
+ width: calc(var(--system-spacing) * var(--button-multiplier-x));
116
109
  --button-spacing-x: 0;
117
110
  --button-spacing-y: 0;
118
111
  }
119
112
 
120
113
  .kit-button:not(.kit-button--icon)[breakpoint]kit-button--density-compact {
121
- height: calc(var(--kit-spacing) * var(--button-multiplier-x) - 0.25rem);
114
+ height: calc(var(--system-spacing) * var(--button-multiplier-x) - 0.25rem);
122
115
  --button-spacing-x: 0;
123
- --button-spacing-y: calc(var(--kit-spacing) * var(--button-multiplier-y) - 0.25rem);
116
+ --button-spacing-y: calc(var(--system-spacing) * var(--button-multiplier-y) - 0.25rem);
124
117
  }
125
118
  .kit-button.kit-button--icon[breakpoint]kit-button--density-compact {
126
- height: calc(var(--kit-spacing) * var(--button-multiplier-x) - 0.25rem);
127
- width: calc(var(--kit-spacing) * var(--button-multiplier-x) - 0.25rem);
119
+ height: calc(var(--system-spacing) * var(--button-multiplier-x) - 0.25rem);
120
+ width: calc(var(--system-spacing) * var(--button-multiplier-x) - 0.25rem);
128
121
  --button-spacing-x: 0;
129
122
  --button-spacing-y: 0;
130
123
  }
131
124
 
132
125
  .kit-button:not(.kit-button--icon)[breakpoint]kit-button--density-comfortable {
133
- height: calc(var(--kit-spacing) * var(--button-multiplier-x) + 0.25rem);
126
+ height: calc(var(--system-spacing) * var(--button-multiplier-x) + 0.25rem);
134
127
  --button-spacing-x: 0;
135
- --button-spacing-y: calc(var(--kit-spacing) * var(--button-multiplier-y) + 0.25rem);
128
+ --button-spacing-y: calc(var(--system-spacing) * var(--button-multiplier-y) + 0.25rem);
136
129
  }
137
130
  .kit-button.kit-button--icon[breakpoint]kit-button--density-comfortable {
138
- height: calc(var(--kit-spacing) * var(--button-multiplier-x) + 0.25rem);
139
- width: calc(var(--kit-spacing) * var(--button-multiplier-x) + 0.25rem);
131
+ height: calc(var(--system-spacing) * var(--button-multiplier-x) + 0.25rem);
132
+ width: calc(var(--system-spacing) * var(--button-multiplier-x) + 0.25rem);
140
133
  --button-spacing-x: 0;
141
134
  --button-spacing-y: 0;
142
135
  }
143
136
 
144
137
  /* variant */
145
138
  .kit-button[breakpoint]kit-button--variant-filled {
146
- background-color: var(--button-background);
139
+ background-color: var(--button-background, var(--kit-background-grouped-primary));
147
140
  }
148
141
 
149
142
  .kit-button[breakpoint]kit-button--variant-outline {
150
- --button-color: var(--on, var(--kit-on-container));
151
- background-color: var(--button-background);
143
+ --button-color: var(--on, var(--kit-label-primary));
144
+ background-color: var(--button-background, var(--kit-background-grouped-primary));
152
145
  }
153
146
  .kit-button[breakpoint]kit-button--variant-outline::before {
154
147
  content: '';
@@ -160,7 +153,7 @@
160
153
  }
161
154
 
162
155
  .kit-button[breakpoint]kit-button--variant-text {
163
- --button-color: var(--base, var(--kit-on-container));
156
+ --button-color: var(--base, var(--kit-label-primary));
164
157
  background-color: transparent;
165
158
  border: none;
166
159
  }
@@ -168,37 +161,37 @@
168
161
  /* state */
169
162
  .kit-button.kit-button--info[class*='button--variant-filled'] {
170
163
  --on: var(--kit-on-info);
171
- --base: var(--kit-info);
164
+ --base: var(--kit-accent-info);
172
165
  }
173
166
  .kit-button.kit-button--info[class*='button--variant-']:not([class*='variant-filled']) {
174
- --base: var(--kit-info);
167
+ --base: var(--kit-accent-info);
175
168
  }
176
169
  .kit-button.kit-button--success[class*='button--variant-filled'] {
177
170
  --on: var(--kit-on-success);
178
- --base: var(--kit-success);
171
+ --base: var(--kit-accent-successs);
179
172
  }
180
173
  .kit-button.kit-button--success[class*='button--variant-']:not([class*='variant-filled']) {
181
- --base: var(--kit-success);
174
+ --base: var(--kit-accent-successs);
182
175
  }
183
176
  .kit-button.kit-button--warning[class*='button--variant-filled'] {
184
177
  --on: var(--kit-on-warning);
185
- --base: var(--kit-warning);
178
+ --base: var(--kit-accent-warning);
186
179
  }
187
180
  .kit-button.kit-button--warning[class*='button--variant-']:not([class*='variant-filled']) {
188
- --base: var(--kit-warning);
181
+ --base: var(--kit-accent-warning);
189
182
  }
190
183
  .kit-button.kit-button--error[class*='button--variant-filled'] {
191
184
  --on: var(--kit-on-error);
192
- --base: var(--kit-error);
185
+ --base: var(--kit-accent-destructive);
193
186
  }
194
187
  .kit-button.kit-button--error[class*='button--variant-']:not([class*='variant-filled']) {
195
- --base: var(--kit-error);
188
+ --base: var(--kit-accent-destructive);
196
189
  }
197
190
 
198
191
  /* events */
199
192
  .kit-button[class*='button--variant-filled']:active,
200
193
  .kit-button.kit-button--active[class*='button--variant-filled'] {
201
- background-color: color-mix(in oklab, var(--button-background) 90%, var(--kit-scrim));
194
+ background-color: color-mix(in oklab, var(--button-background) 90%, var(--kit-state-shadow));
202
195
  }
203
196
  .kit-button.kit-button--active[class*='button--variant-']:not([class*='variant-filled']):active,
204
197
  .kit-button.kit-button--active[class*='button--variant-']:not([class*='variant-filled']) {
@@ -1,11 +1,11 @@
1
1
  <script lang="ts">
2
- import { getAssets } from '../../internal/index.js';
2
+ import { getAssets } from '../../internal/core/actions/assets.svelte.js';
3
3
  import type { ButtonProps } from './types.js';
4
4
 
5
5
  // external
6
6
  import { Icon } from '../index.js';
7
7
  import LoadingFill from '../../assets/icons/loading-fill.svelte';
8
- import { ripple } from '../../internal/ripple.js';
8
+ import { ripple } from '../../internal/core/animations/ripple.js';
9
9
 
10
10
  let {
11
11
  children,
@@ -68,9 +68,9 @@
68
68
  component: 'button',
69
69
  disabled: noRipple || disabled
70
70
  }}
71
- style:--base={assets.color(background)}
72
- style:--on={assets.color(color)}
73
- style:--shape={assets.shape(rounded)}
71
+ style:--button-background={assets.color(background)}
72
+ style:--button-color={assets.color(color)}
73
+ style:--button-shape={assets.shape(rounded)}
74
74
  >
75
75
  {#if loading}
76
76
  <div class="kit-button-loading">
@@ -1,4 +1,4 @@
1
- import type { Component } from '../../internal/types.js';
1
+ import type { Component } from '../../internal/types/index.js';
2
2
  import type { Snippet } from 'svelte';
3
3
  export interface ButtonProps extends Component {
4
4
  ref?: HTMLElement | null;