lapikit 0.0.0-insiders.f325e60 → 0.0.0-insiders.f352010

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 (185) hide show
  1. package/bin/configuration.js +0 -1
  2. package/bin/helper.js +0 -38
  3. package/bin/index.js +1 -9
  4. package/bin/presets.js +1 -1
  5. package/bin/prompts.js +46 -79
  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 -121
  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 -126
  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 -44
  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 -49
  24. package/dist/components/appbar/types.d.ts +1 -1
  25. package/dist/components/aspect-ratio/aspect-ratio.svelte +0 -41
  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 -118
  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 -235
  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 +5 -113
  35. package/dist/components/card/types.d.ts +1 -1
  36. package/dist/components/chip/chip.css +26 -33
  37. package/dist/components/chip/chip.svelte +5 -216
  38. package/dist/components/chip/types.d.ts +1 -1
  39. package/dist/components/dialog/dialog.css +13 -20
  40. package/dist/components/dialog/dialog.svelte +5 -149
  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 -31
  44. package/dist/components/dropdown/types.d.ts +1 -1
  45. package/dist/components/icon/icon.css +9 -12
  46. package/dist/components/icon/icon.svelte +2 -91
  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 -203
  50. package/dist/components/list/modules/list-item.css +67 -0
  51. package/dist/components/list/modules/list-item.svelte +5 -204
  52. package/dist/components/list/types.d.ts +1 -1
  53. package/dist/components/modal/modal.css +15 -23
  54. package/dist/components/modal/modal.svelte +4 -140
  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 -30
  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 -53
  61. package/dist/components/separator/types.d.ts +1 -1
  62. package/dist/components/spacer/spacer.svelte +0 -5
  63. package/dist/components/spacer/types.d.ts +1 -1
  64. package/dist/components/textfield/textfield.css +16 -23
  65. package/dist/components/textfield/textfield.svelte +4 -274
  66. package/dist/components/textfield/types.d.ts +1 -1
  67. package/dist/components/toolbar/toolbar.css +11 -34
  68. package/dist/components/toolbar/toolbar.svelte +4 -139
  69. package/dist/components/toolbar/types.d.ts +1 -1
  70. package/dist/components/tooltip/tooltip.css +5 -13
  71. package/dist/components/tooltip/tooltip.svelte +5 -132
  72. package/dist/components/tooltip/types.d.ts +1 -1
  73. package/dist/index.d.ts +2 -26
  74. package/dist/index.js +2 -6
  75. package/dist/internal/config/presets.d.ts +71 -47
  76. package/dist/internal/config/presets.js +72 -41
  77. package/dist/internal/config/variables.d.ts +1 -4
  78. package/dist/internal/config/variables.js +1 -4
  79. package/dist/internal/{assets.svelte.js → core/actions/assets.svelte.js} +4 -4
  80. package/dist/internal/core/actions/dropdown.svelte.d.ts +7 -0
  81. package/dist/internal/core/actions/popover.svelte.d.ts +7 -0
  82. package/dist/internal/core/actions/tooltip.svelte.d.ts +7 -0
  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.js +37 -40
  86. package/dist/internal/core/formatter/device.js +37 -36
  87. package/dist/internal/core/formatter/index.d.ts +1 -1
  88. package/dist/internal/core/formatter/index.js +2 -2
  89. package/dist/internal/core/formatter/theme.js +22 -6
  90. package/dist/internal/core/formatter/typography.js +1 -1
  91. package/dist/internal/core/standard-colors.d.ts +75 -0
  92. package/dist/internal/core/standard-colors.js +75 -0
  93. package/dist/internal/helpers/colors.d.ts +1 -0
  94. package/dist/internal/{colors.js → helpers/colors.js} +2 -2
  95. package/dist/internal/helpers/parser.js +2 -1
  96. package/dist/internal/plugins/vite.js +8 -6
  97. package/dist/internal/types/components.d.ts +14 -0
  98. package/dist/internal/types/configuration.d.ts +24 -1
  99. package/dist/internal/types/index.d.ts +1 -0
  100. package/dist/internal/types/index.js +1 -0
  101. package/dist/stores/components.js +1 -1
  102. package/dist/stores/index.d.ts +1 -0
  103. package/dist/stores/index.js +1 -0
  104. package/dist/stores/themes.d.ts +0 -6
  105. package/dist/stores/themes.js +1 -31
  106. package/dist/stores/viewport.d.ts +7 -0
  107. package/dist/stores/viewport.js +7 -0
  108. package/dist/styles/reset.css +6 -4
  109. package/package.json +7 -11
  110. package/bin/lapikit.js +0 -86
  111. package/bin/legacy.js +0 -34
  112. package/bin/modules/adapter.js +0 -52
  113. package/bin/modules/plugin.js +0 -223
  114. package/bin/modules/preset.js +0 -11
  115. package/dist/internal/colors.d.ts +0 -1
  116. package/dist/internal/index.d.ts +0 -4
  117. package/dist/internal/index.js +0 -4
  118. package/dist/internal/types.d.ts +0 -57
  119. package/dist/internal/unit.d.ts +0 -1
  120. package/dist/internal/unit.js +0 -11
  121. package/dist/labs/index.d.ts +0 -4
  122. package/dist/labs/index.js +0 -5
  123. package/dist/labs/my-component-style-global.svelte +0 -6
  124. package/dist/labs/my-component-style-global.svelte.d.ts +0 -18
  125. package/dist/labs/my-component-style-import.svelte +0 -15
  126. package/dist/labs/my-component-style-import.svelte.d.ts +0 -18
  127. package/dist/labs/my-component-style-mixed.svelte +0 -23
  128. package/dist/labs/my-component-style-mixed.svelte.d.ts +0 -18
  129. package/dist/labs/my-component.svelte +0 -16
  130. package/dist/labs/my-component.svelte.d.ts +0 -18
  131. package/dist/labs/style-mixed.css +0 -7
  132. package/dist/labs/style.css +0 -7
  133. package/dist/labs.css +0 -1
  134. package/dist/plugin/css.d.ts +0 -1
  135. package/dist/plugin/css.js +0 -73
  136. package/dist/plugin/modules/config.d.ts +0 -2
  137. package/dist/plugin/modules/config.js +0 -54
  138. package/dist/plugin/modules/importer.d.ts +0 -1
  139. package/dist/plugin/modules/importer.js +0 -15
  140. package/dist/plugin/preset-v2.d.ts +0 -108
  141. package/dist/plugin/preset-v2.js +0 -126
  142. package/dist/plugin/vitejs.d.ts +0 -10
  143. package/dist/plugin/vitejs.js +0 -55
  144. package/dist/preset.d.ts +0 -2
  145. package/dist/preset.js +0 -92
  146. package/dist/style/animation.css +0 -62
  147. package/dist/style/css.d.ts +0 -2
  148. package/dist/style/css.js +0 -34
  149. package/dist/style/normalize.css +0 -125
  150. package/dist/style/parser/color.d.ts +0 -5
  151. package/dist/style/parser/color.js +0 -88
  152. package/dist/style/parser/component.d.ts +0 -2
  153. package/dist/style/parser/component.js +0 -115
  154. package/dist/style/parser/device.d.ts +0 -2
  155. package/dist/style/parser/device.js +0 -40
  156. package/dist/style/parser/index.d.ts +0 -4
  157. package/dist/style/parser/index.js +0 -4
  158. package/dist/style/parser/variable.d.ts +0 -2
  159. package/dist/style/parser/variable.js +0 -25
  160. package/dist/style/variable.css +0 -12
  161. /package/dist/{components/accordion → actions}/accordion.svelte.js +0 -0
  162. /package/dist/internal/{assets.svelte.d.ts → core/actions/assets.svelte.d.ts} +0 -0
  163. /package/dist/{components/dropdown → internal/core/actions}/dropdown.svelte.js +0 -0
  164. /package/dist/{components/popover → internal/core/actions}/popover.svelte.js +0 -0
  165. /package/dist/{components/tooltip → internal/core/actions}/tooltip.svelte.js +0 -0
  166. /package/dist/internal/{ripple.d.ts → core/animations/ripple.d.ts} +0 -0
  167. /package/dist/internal/{ripple.js → core/animations/ripple.js} +0 -0
  168. /package/dist/internal/{ansi.d.ts → core/bin/ansi.d.ts} +0 -0
  169. /package/dist/internal/{ansi.js → core/bin/ansi.js} +0 -0
  170. /package/dist/internal/{terminal.d.ts → core/bin/terminal.d.ts} +0 -0
  171. /package/dist/internal/{terminal.js → core/bin/terminal.js} +0 -0
  172. /package/dist/internal/{minify.d.ts → core/minify.d.ts} +0 -0
  173. /package/dist/internal/{minify.js → core/minify.js} +0 -0
  174. /package/dist/{utils/x11.d.ts → internal/core/x11-colors.d.ts} +0 -0
  175. /package/dist/{utils/x11.js → internal/core/x11-colors.js} +0 -0
  176. /package/dist/{utils → internal/helpers}/convert.d.ts +0 -0
  177. /package/dist/{utils → internal/helpers}/convert.js +0 -0
  178. /package/dist/internal/{deepMerge.d.ts → helpers/deep-merge.d.ts} +0 -0
  179. /package/dist/internal/{deepMerge.js → helpers/deep-merge.js} +0 -0
  180. /package/dist/internal/{clickOutside.d.ts → helpers/outside.d.ts} +0 -0
  181. /package/dist/internal/{clickOutside.js → helpers/outside.js} +0 -0
  182. /package/dist/internal/{scroll.d.ts → helpers/scroll.d.ts} +0 -0
  183. /package/dist/internal/{scroll.js → helpers/scroll.js} +0 -0
  184. /package/dist/internal/{types.js → types/components.js} +0 -0
  185. /package/dist/{colors.css → themes.css} +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 { 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">
@@ -87,125 +87,3 @@
87
87
  {/if}
88
88
  </svelte:element>
89
89
  {/if}
90
-
91
- <style>/* root */
92
- .kit-alert {
93
- --alert-color: var(--on, var(--kit-on-container));
94
- --alert-background: var(--base, var(--kit-container));
95
- --alert-radius: var(--shape, var(--kit-radius-md));
96
- }
97
- .kit-alert {
98
- display: grid;
99
- flex: 1 1;
100
- grid-template-areas:
101
- 'prepend content append close'
102
- '. content . .';
103
- grid-template-columns: max-content minmax(0, 1fr) max-content max-content;
104
- position: relative;
105
- padding: 1rem;
106
- overflow: hidden;
107
- color: var(--alert-color);
108
- background-color: var(--alert-background);
109
- border-radius: var(--alert-radius);
110
- line-height: 0;
111
- }
112
- .kit-alert .kit-alert--underlay {
113
- grid-area: none;
114
- position: absolute;
115
- background-color: var(--alert-background);
116
- border-radius: inherit;
117
- top: 0;
118
- right: 0;
119
- bottom: 0;
120
- left: 0;
121
- z-index: -1;
122
- }
123
- .kit-alert.kit-alert--outline {
124
- border: thin solid currentColor;
125
- background-color: transparent;
126
- }
127
- /* density */
128
- .kit-alert[breakpoint]kit-alert--density-default {
129
- padding-bottom: 1rem;
130
- padding-top: 1rem;
131
- }
132
- .kit-alert[breakpoint]kit-alert--density-compact {
133
- padding-bottom: 0.5rem;
134
- padding-top: 0.5rem;
135
- }
136
- .kit-alert[breakpoint]kit-alert--density-comfortable {
137
- padding-bottom: 0.75rem;
138
- padding-top: 0.75rem;
139
- }
140
- .kit-alert .kit-alert--prepend {
141
- align-self: flex-start;
142
- display: flex;
143
- align-items: center;
144
- grid-area: prepend;
145
- margin-inline-end: 1rem;
146
- }
147
- .kit-alert .kit-alert--content {
148
- align-self: flex-start;
149
- grid-area: content;
150
- overflow: hidden;
151
- line-height: normal;
152
- }
153
- .kit-alert .kit-alert--close {
154
- align-self: flex-start;
155
- margin-inline-start: 1rem;
156
- flex: 0 1 auto;
157
- grid-area: close;
158
- }
159
- .kit-alert .kit-alert--append {
160
- align-self: flex-start;
161
- display: flex;
162
- align-items: center;
163
- grid-area: append;
164
- margin-inline-start: 1rem;
165
- }
166
- /* state */
167
- .kit-alert.kit-alert--info:not([class*='alert--variant-']) {
168
- --on: var(--kit-on-info);
169
- --base: var(--kit-info);
170
- }
171
- .kit-alert.kit-alert--info[class*='alert--variant-'] {
172
- --base: var(--kit-info);
173
- }
174
- .kit-alert.kit-alert--success:not([class*='alert--variant-']) {
175
- --on: var(--kit-on-success);
176
- --base: var(--kit-success);
177
- }
178
- .kit-alert.kit-alert--success[class*='alert--variant-'] {
179
- --base: var(--kit-success);
180
- }
181
- .kit-alert.kit-alert--warning:not([class*='alert--variant-']) {
182
- --on: var(--kit-on-warning);
183
- --base: var(--kit-warning);
184
- }
185
- .kit-alert.kit-alert--warning[class*='alert--variant-'] {
186
- --base: var(--kit-warning);
187
- }
188
- .kit-alert.kit-alert--error:not([class*='alert--variant-']) {
189
- --on: var(--kit-on-error);
190
- --base: var(--kit-error);
191
- }
192
- .kit-alert.kit-alert--error[class*='alert--variant-'] {
193
- --base: var(--kit-error);
194
- }
195
- /* variant */
196
- .kit-alert[breakpoint]kit-alert--variant-outline {
197
- --alert-color: var(--base, var(--kit-neutral));
198
- background-color: transparent;
199
- border: 1px solid currentColor;
200
- }
201
- .kit-alert[breakpoint]kit-alert--variant-text {
202
- --alert-color: var(--base, var(--kit-neutral));
203
- background-color: transparent;
204
- border-color: transparent;
205
- }
206
- .kit-alert[breakpoint]kit-alert--variant-dash {
207
- --alert-color: var(--base, var(--kit-neutral));
208
- background-color: transparent;
209
- border: 1px dashed currentColor;
210
- }
211
- </style>
@@ -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,38 +1,51 @@
1
1
  <script lang="ts">
2
2
  import { BROWSER } from 'esm-env';
3
- import {
4
- colorSchemeSystem,
5
- modalOpen,
6
- setOpenModal,
7
- useColorScheme,
8
- useTheme
9
- } from '../../stores/index.js';
10
3
  import type { Snippet } from 'svelte';
11
- 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();
12
14
 
13
15
  $effect.pre(() => {
14
16
  if (!BROWSER) return;
15
- // system
16
- if (window.matchMedia) {
17
- colorSchemeSystem.set(
18
- window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light'
19
- );
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
+ }
20
33
  }
21
34
 
22
- // listener
23
- window
24
- .matchMedia('(prefers-color-scheme: dark)')
25
- .addEventListener('change', (event: MediaQueryListEvent) => {
26
- 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
27
42
  });
28
-
29
- // local
30
- const localColorScheme = localStorage.getItem('@lapikit/color-scheme');
31
- const localTheme = localStorage.getItem('@lapikit/theme');
32
-
33
- // apply local settings
34
- if (localColorScheme !== null) useColorScheme(localColorScheme as 'dark' | 'light' | 'system');
35
- if (localTheme !== null) useTheme(localTheme as string);
43
+ }
44
+ updateViewport();
45
+ window.addEventListener('resize', updateViewport);
46
+ return () => {
47
+ window.removeEventListener('resize', updateViewport);
48
+ };
36
49
  });
37
50
  </script>
38
51
 
@@ -46,21 +59,3 @@
46
59
  onclick={() => $modalOpen !== 'persistent' && setOpenModal(false)}
47
60
  ></div>
48
61
  {/if}
49
-
50
- <style>.kit-overlay {
51
- position: fixed;
52
- top: 0;
53
- left: 0;
54
- height: 100%;
55
- width: 100%;
56
- background-color: color-mix(in oklab, var(--kit-shadow) 70%, transparent);
57
- z-index: 9000;
58
- cursor: default;
59
- }
60
-
61
- .kit-overlay.kit-overlay--persistent {
62
- /* pointer-events: none; */
63
- user-select: none;
64
- cursor: default;
65
- }
66
- </style>
@@ -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(--prism-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(--prism-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(--prism-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(--prism-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,56 +30,11 @@
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?.()}
39
39
  </div>
40
40
  </svelte:element>
41
-
42
- <style>/* root default*/
43
- .kit-appbar {
44
- --appbar-color: var(--on, var(--kit-on-surface));
45
- --appbar-background: var(--base, var(--kit-surface));
46
- --appbar-radius: var(--shape, 0);
47
- --appbar-padding-wrapper: var(--prism-spacing) * 4;
48
- }
49
- .kit-appbar {
50
- display: flex;
51
- align-items: center;
52
- border-style: solid;
53
- border-width: 1px;
54
- border-radius: var(--appbar-radius);
55
- color: var(--appbar-color);
56
- background-color: var(--appbar-background);
57
- border-color: var(--appbar-background);
58
- /* transition:
59
- color 0.5s,
60
- border-color 0.5s,
61
- background-color 0.5s; */
62
- }
63
- /* wrapper */
64
- .kit-appbar .kit-appbar--wrapper {
65
- display: flex;
66
- align-items: center;
67
- flex-direction: row;
68
- height: calc(100% - (var(--appbar-padding-wrapper) * 2));
69
- width: calc(100% - (var(--appbar-padding-wrapper) * 2));
70
- margin: 0 auto;
71
- }
72
- /* density */
73
- .kit-appbar[breakpoint]kit-appbar--density-default {
74
- height: 4rem;
75
- padding-inline: calc(var(--prism-spacing) * 1.5);
76
- }
77
- .kit-appbar[breakpoint]kit-appbar--density-compact {
78
- height: 3.5rem;
79
- padding-inline: calc(var(--prism-spacing) * 0.75);
80
- }
81
- .kit-appbar[breakpoint]kit-appbar--density-comfortable {
82
- height: 4.5rem;
83
- padding-inline: calc(var(--prism-spacing) * 2.25);
84
- }
85
- </style>
@@ -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,44 +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>.kit-aspect-ratio {
28
- display: flex;
29
- flex: 1 0 auto;
30
- max-height: 100%;
31
- max-width: 100%;
32
- overflow: hidden;
33
- position: relative;
34
- }
35
-
36
- .kit-aspect-ratio--inline {
37
- display: inline-flex;
38
- flex: 0 0 auto;
39
- }
40
-
41
- .kit-aspect-ratio--sizer {
42
- flex: 1 0 0px;
43
- transition: padding-bottom 0.2s cubic-bezier(0.4, 0, 0.2, 1);
44
- pointer-events: none;
45
- }
46
-
47
- .kit-aspect-ratio {
48
- display: flex;
49
- flex: 1 0 auto;
50
- max-height: 100%;
51
- max-width: 100%;
52
- overflow: hidden;
53
- position: relative;
54
- }
55
-
56
- .kit-aspect-ratio--inline {
57
- display: inline-flex;
58
- flex: 0 0 auto;
59
- }
60
-
61
- .kit-aspect-ratio--sizer {
62
- flex: 1 0 0px;
63
- transition: padding-bottom 0.2s cubic-bezier(0.4, 0, 0.2, 1);
64
- pointer-events: none;
65
- }
66
- </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} />
@@ -44,117 +44,3 @@
44
44
  {@render children?.()}
45
45
  {/if}
46
46
  </svelte:element>
47
-
48
- <style>.kit-avatar {
49
- --avatar-color: var(--on, var(--kit-on-container));
50
- --avatar-background: var(--base, var(--kit-container));
51
- --avatar-radius: var(--shape, var(--kit-radius-full));
52
-
53
- display: flex;
54
- align-items: center;
55
- justify-content: center;
56
- white-space: nowrap;
57
- padding-top: var(--avatar-spacing-x);
58
- padding-bottom: var(--avatar-spacing-x);
59
- padding-right: var(--avatar-spacing-y);
60
- padding-left: var(--avatar-spacing-y);
61
-
62
- border-width: 1px;
63
- border-style: solid;
64
- border-radius: var(--avatar-radius);
65
-
66
- /* theme */
67
- color: var(--avatar-color);
68
- background-color: var(--avatar-background);
69
- border-color: var(--avatar-background);
70
- }
71
-
72
- .kit-avatar.kit-avatar--image {
73
- position: relative;
74
- overflow: hidden;
75
- }
76
-
77
- .kit-avatar.kit-avatar--image img {
78
- position: relative;
79
- top: 0;
80
- left: 0;
81
- width: 100%;
82
- height: 100%;
83
- object-fit: cover;
84
- }
85
-
86
- /* size */
87
-
88
- .kit-avatar[breakpoint]kit-avatar--size-xs {
89
- --avatar-height: 1.75rem;
90
- --avatar-multiplier-y: 2;
91
- font-size: 0.75rem;
92
- }
93
-
94
- .kit-avatar[breakpoint]kit-avatar--size-sm {
95
- --avatar-height: 2rem;
96
- --avatar-multiplier-y: 3;
97
- font-size: 0.875rem;
98
- }
99
-
100
- .kit-avatar[breakpoint]kit-avatar--size-md {
101
- --avatar-height: 2.25rem;
102
- --avatar-multiplier-y: 4;
103
- font-size: 0.875rem;
104
- }
105
-
106
- .kit-avatar[breakpoint]kit-avatar--size-lg {
107
- --avatar-height: 2.5rem;
108
- --avatar-multiplier-y: 5;
109
- font-size: 1rem;
110
- }
111
-
112
- .kit-avatar[breakpoint]kit-avatar--size-xl {
113
- --avatar-height: 2.75rem;
114
- --avatar-multiplier-y: 6;
115
- font-size: 1.125rem;
116
- }
117
-
118
- /* density */
119
-
120
- .kit-avatar[breakpoint]kit-avatar--density-default {
121
- height: calc(var(--avatar-height));
122
- width: calc(var(--avatar-height));
123
- --avatar-spacing-x: 0;
124
- --avatar-spacing-y: 0;
125
- }
126
-
127
- .kit-avatar[breakpoint]kit-avatar--density-compact {
128
- height: calc(var(--avatar-height) - 0.25rem);
129
- width: calc(var(--avatar-height) - 0.25rem);
130
- --avatar-spacing-x: 0;
131
- --avatar-spacing-y: 0;
132
- }
133
-
134
- .kit-avatar[breakpoint]kit-avatar--density-comfortable {
135
- height: calc(var(--avatar-height) + 0.25rem);
136
- width: calc(var(--avatar-height) + 0.25rem);
137
- --avatar-spacing-x: 0;
138
- --avatar-spacing-y: 0;
139
- }
140
-
141
- /* variant */
142
-
143
- .kit-avatar[breakpoint]kit-avatar--variant-outline {
144
- --avatar-color: var(--base, var(--kit-container));
145
- background-color: transparent;
146
- border: 1px solid currentColor;
147
- }
148
-
149
- .kit-avatar[breakpoint]kit-avatar--variant-text {
150
- --avatar-color: var(--base, var(--kit-container));
151
- background-color: transparent;
152
- border-color: transparent;
153
- }
154
-
155
- .kit-avatar[breakpoint]kit-avatar--variant-dash {
156
- --avatar-color: var(--base, var(--kit-container));
157
- background-color: transparent;
158
- border: 1px dashed currentColor;
159
- }
160
- </style>
@@ -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';