lapikit 0.0.0-insiders.efb49b7 → 0.0.0-insiders.f502b02

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 (46) hide show
  1. package/dist/components/app/app.svelte +22 -4
  2. package/dist/components/appbar/appbar.css +48 -0
  3. package/dist/components/appbar/appbar.svelte +41 -0
  4. package/dist/components/appbar/appbar.svelte.d.ts +4 -0
  5. package/dist/components/appbar/types.d.ts +15 -0
  6. package/dist/components/appbar/types.js +1 -0
  7. package/dist/components/aspect-ratio/aspect-ratio.svelte +23 -0
  8. package/dist/components/avatar/avatar.svelte +4 -4
  9. package/dist/components/avatar/types.d.ts +1 -1
  10. package/dist/components/button/button.css +162 -194
  11. package/dist/components/button/button.svelte +36 -24
  12. package/dist/components/button/button.svelte.d.ts +2 -2
  13. package/dist/components/button/types.d.ts +6 -4
  14. package/dist/components/card/card.css +109 -0
  15. package/dist/components/card/card.svelte +50 -0
  16. package/dist/components/card/card.svelte.d.ts +4 -0
  17. package/dist/components/card/types.d.ts +18 -0
  18. package/dist/components/card/types.js +1 -0
  19. package/dist/components/chip/chip.css +182 -0
  20. package/dist/components/chip/chip.svelte +5 -5
  21. package/dist/components/chip/types.d.ts +1 -1
  22. package/dist/components/icon/icon.css +13 -10
  23. package/dist/components/index.d.ts +6 -1
  24. package/dist/components/index.js +6 -1
  25. package/dist/components/list/list.css +5 -5
  26. package/dist/components/modal/modal.css +1 -1
  27. package/dist/components/spacer/spacer.css +3 -0
  28. package/dist/components/spacer/spacer.svelte +7 -0
  29. package/dist/components/spacer/spacer.svelte.d.ts +4 -0
  30. package/dist/components/spacer/types.d.ts +4 -0
  31. package/dist/components/spacer/types.js +1 -0
  32. package/dist/components/toolbar/toolbar.css +129 -0
  33. package/dist/components/toolbar/toolbar.svelte +47 -0
  34. package/dist/components/toolbar/toolbar.svelte.d.ts +4 -0
  35. package/dist/components/toolbar/types.d.ts +27 -0
  36. package/dist/components/toolbar/types.js +1 -0
  37. package/dist/internal/ripple.d.ts +11 -0
  38. package/dist/internal/ripple.js +90 -0
  39. package/dist/internal/unit.d.ts +1 -0
  40. package/dist/internal/unit.js +11 -0
  41. package/dist/preset.js +2 -2
  42. package/dist/stores/index.d.ts +4 -3
  43. package/dist/stores/index.js +9 -4
  44. package/dist/style/animation.css +40 -0
  45. package/dist/style/parser/device.js +31 -19
  46. package/package.json +1 -1
@@ -1,18 +1,36 @@
1
1
  <script lang="ts">
2
2
  import { BROWSER } from 'esm-env';
3
- import { modalOpen, setOpenModal, updateThemeStore } from '../../stores/index.js';
3
+ import {
4
+ colorSchemeSystem,
5
+ modalOpen,
6
+ setOpenModal,
7
+ updateThemeStore
8
+ } from '../../stores/index.js';
4
9
  import type { Snippet } from 'svelte';
5
10
  let { children }: { children: Snippet } = $props();
6
11
 
7
12
  $effect.pre(() => {
8
13
  if (!BROWSER) return;
14
+ // system
15
+ if (window.matchMedia) {
16
+ colorSchemeSystem.set(
17
+ window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light'
18
+ );
19
+ }
20
+
21
+ // listener
22
+ window
23
+ .matchMedia('(prefers-color-scheme: dark)')
24
+ .addEventListener('change', (event: MediaQueryListEvent) => {
25
+ colorSchemeSystem.set(event.matches ? 'dark' : 'light');
26
+ });
27
+
28
+ // local
9
29
  const local = localStorage.getItem('@lapikit/theme');
10
- if (local !== null) updateThemeStore(local as 'dark' | 'light' | 'auto');
30
+ if (local !== null) updateThemeStore(local as 'dark' | 'light' | 'system');
11
31
  });
12
32
  </script>
13
33
 
14
- {$modalOpen ? ($modalOpen === 'persistent' ? 'persistent' : 'true') : 'false'}
15
-
16
34
  {@render children?.()}
17
35
 
18
36
  <!-- svelte-ignore a11y_no_static_element_interactions -->
@@ -0,0 +1,48 @@
1
+ /* root default*/
2
+ .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
+ }
8
+
9
+ .kit-appbar {
10
+ display: flex;
11
+ align-items: center;
12
+ border-style: solid;
13
+ 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;
22
+ }
23
+
24
+ /* wrapper */
25
+ .kit-appbar .kit-appbar--wrapper {
26
+ display: flex;
27
+ align-items: center;
28
+ flex-direction: row;
29
+ height: calc(100% - (var(--appbar-padding-wrapper) * 2));
30
+ width: calc(100% - (var(--appbar-padding-wrapper) * 2));
31
+ margin: 0 auto;
32
+ }
33
+
34
+ /* density */
35
+ .kit-appbar[breakpoint]kit-appbar--density-default {
36
+ height: 4rem;
37
+ padding-inline: calc(var(--kit-spacing) * 1.5);
38
+ }
39
+
40
+ .kit-appbar[breakpoint]kit-appbar--density-compact {
41
+ height: 3.5rem;
42
+ padding-inline: calc(var(--kit-spacing) * 0.75);
43
+ }
44
+
45
+ .kit-appbar[breakpoint]kit-appbar--density-comfortable {
46
+ height: 4.5rem;
47
+ padding-inline: calc(var(--kit-spacing) * 2.25);
48
+ }
@@ -0,0 +1,41 @@
1
+ <script lang="ts">
2
+ import { getAssets } from '../../internal/index.js';
3
+ import type { AppbarProps } from './types.js';
4
+
5
+ let {
6
+ children,
7
+ ref = $bindable(),
8
+ is = 'header',
9
+ classContent,
10
+ light,
11
+ dark,
12
+ rounded,
13
+ background,
14
+ color,
15
+ density = 'default',
16
+ ...rest
17
+ }: AppbarProps = $props();
18
+
19
+ const assets = getAssets();
20
+ </script>
21
+
22
+ <svelte:element
23
+ this={is}
24
+ bind:this={ref}
25
+ {...rest}
26
+ role="heading"
27
+ class={[
28
+ 'kit-appbar',
29
+ light && 'light',
30
+ dark && 'dark',
31
+ density && assets.className('appbar', 'density', density),
32
+ rest.class
33
+ ]}
34
+ style:--base={assets.color(background)}
35
+ style:--on={assets.color(color)}
36
+ style:--shape={assets.shape(rounded)}
37
+ >
38
+ <div class={['kit-appbar--wrapper', classContent]}>
39
+ {@render children?.()}
40
+ </div>
41
+ </svelte:element>
@@ -0,0 +1,4 @@
1
+ import type { AppbarProps } from './types.js';
2
+ declare const Appbar: import("svelte").Component<AppbarProps, {}, "ref">;
3
+ type Appbar = ReturnType<typeof Appbar>;
4
+ export default Appbar;
@@ -0,0 +1,15 @@
1
+ import type { Component } from '../../internal/types.js';
2
+ type Density = 'compact' | 'comfortable' | 'default';
3
+ export interface AppbarProps extends Component {
4
+ is?: 'div' | 'header' | 'nav';
5
+ rounded?: string;
6
+ density?: Density | {
7
+ [key: string]: Density;
8
+ };
9
+ dark?: boolean;
10
+ light?: boolean;
11
+ color?: string;
12
+ background?: string;
13
+ classContent?: string | string[] | undefined;
14
+ }
15
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -23,3 +23,26 @@
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
+ background-color: aqua;
30
+ display: flex;
31
+ flex: 1 0 auto;
32
+ max-height: 100%;
33
+ max-width: 100%;
34
+ overflow: hidden;
35
+ position: relative;
36
+ }
37
+
38
+ .kit-aspect-ratio--inline {
39
+ display: inline-flex;
40
+ flex: 0 0 auto;
41
+ }
42
+
43
+ .kit-aspect-ratio--sizer {
44
+ flex: 1 0 0px;
45
+ transition: padding-bottom 0.2s cubic-bezier(0.4, 0, 0.2, 1);
46
+ pointer-events: none;
47
+ }
48
+ </style>
@@ -11,7 +11,7 @@
11
11
  alt,
12
12
  background,
13
13
  color,
14
- image,
14
+ src,
15
15
  variant,
16
16
  density = 'default',
17
17
  ...rest
@@ -28,7 +28,7 @@
28
28
  'kit-avatar',
29
29
  light && 'light',
30
30
  dark && 'dark',
31
- image && 'kit-avatar--image',
31
+ src && 'kit-avatar--image',
32
32
  size && assets.className('avatar', 'size', size),
33
33
  variant && assets.className('avatar', 'variant', variant),
34
34
  density && assets.className('avatar', 'density', density),
@@ -38,8 +38,8 @@
38
38
  style:--on={assets.color(color)}
39
39
  style:--shape={assets.shape(rounded)}
40
40
  >
41
- {#if image}
42
- <img src={image} {alt} />
41
+ {#if src}
42
+ <img {src} {alt} />
43
43
  {:else}
44
44
  {@render children?.()}
45
45
  {/if}
@@ -8,7 +8,7 @@ export interface AvatarProps extends Component {
8
8
  light?: boolean;
9
9
  color?: string;
10
10
  background?: string;
11
- image?: string;
11
+ src?: string;
12
12
  size?: AvatarSize | {
13
13
  [key: string]: AvatarSize;
14
14
  };
@@ -1,276 +1,244 @@
1
- .kit-btn {
2
- --btn-color: var(--on, var(--kit-on-neutral));
3
- --btn-background: var(--base, var(--kit-neutral));
4
- --btn-radius: var(--shape, var(--kit-radius-md));
5
-
6
- display: inline-flex;
7
- align-items: center;
8
- justify-content: center;
9
- white-space: nowrap;
10
- padding-top: var(--btn-spacing-x);
11
- padding-bottom: var(--btn-spacing-x);
12
- padding-right: var(--btn-spacing-y);
13
- padding-left: var(--btn-spacing-y);
14
- cursor: pointer;
15
-
16
- border-width: 1px;
17
- border-style: solid;
18
- border-radius: var(--btn-radius);
19
-
20
- /* theme */
21
- color: var(--btn-color);
22
- background-color: var(--btn-background);
23
- border-color: var(--btn-background);
1
+ /* root */
2
+ .kit-button {
3
+ --button-color: var(--on, var(--kit-on-neutral));
4
+ --button-background: var(--base, var(--kit-neutral));
5
+ --button-radius: var(--shape, var(--kit-radius-md));
24
6
  }
25
7
 
26
- .kit-btn .kit-btn-content,
27
- .kit-btn .kit-btn-loading {
8
+ .kit-button {
9
+ position: relative;
10
+ cursor: pointer;
11
+ border: none;
12
+ outline: none;
13
+ padding-top: var(--button-spacing-x);
14
+ padding-bottom: var(--button-spacing-x);
15
+ padding-right: var(--button-spacing-y);
16
+ padding-left: var(--button-spacing-y);
17
+ border-radius: var(--button-radius);
18
+ color: var(--button-color);
19
+ background-color: var(--button-background);
20
+ }
21
+
22
+ .kit-button,
23
+ .kit-button .kit-button-content,
24
+ .kit-button .kit-button-append,
25
+ .kit-button .kit-button-prepend,
26
+ .kit-button .kit-button-loading {
28
27
  display: inline-flex;
29
28
  align-items: center;
30
29
  justify-content: center;
31
30
  white-space: nowrap;
32
- gap: var(--btn-gap);
31
+ gap: calc(var(--kit-spacing) * var(--button-multiplier-gap));
32
+ font-size: calc(var(--kit-spacing) * var(--button-multiplier-font-size));
33
33
  }
34
34
 
35
- .kit-btn:active:hover,
36
- .kit-btn:active:focus {
37
- animation: button-click 0s ease-out;
38
- transform: scale(0.97);
35
+ .kit-button::after {
36
+ content: '';
37
+ position: absolute;
38
+ inset: 0;
39
+ background-color: currentColor;
40
+ opacity: 0;
41
+ transition: opacity 150ms ease;
42
+ pointer-events: none;
43
+ border-radius: inherit;
44
+ }
45
+ .kit-button:hover::after {
46
+ opacity: 0.08;
47
+ }
48
+ .kit-button:active::after {
49
+ opacity: 0.12;
50
+ }
51
+ .kit-button:focus-visible::after {
52
+ opacity: 0.12;
39
53
  }
40
54
 
41
55
  /* size */
42
- .kit-btn[breakpoint]kit-btn--size-xs {
43
- --btn-height: 1.75rem;
44
- --btn-multiplier-y: 2;
45
- --btn-gap: 0.25rem;
46
- font-size: 0.75rem;
47
- gap: var(--btn-gap);
56
+ .kit-button[breakpoint]kit-button--size-xs {
57
+ --button-multiplier-x: 12;
58
+ --button-multiplier-y: 2;
59
+ --button-multiplier-gap: 2;
60
+ --button-multiplier-font-size: 6;
61
+ }
62
+ .kit-button[breakpoint]kit-button--size-xs .kit-icon[class*='kit-icon--size-md'] {
63
+ --icon-multiplier-parent-size: 7;
48
64
  }
49
65
 
50
- .kit-btn[breakpoint]kit-btn--size-sm {
51
- --btn-height: 2rem;
52
- --btn-multiplier-y: 3;
53
- --btn-gap: 0.5rem;
54
- font-size: 0.875rem;
55
- gap: var(--btn-gap);
66
+ .kit-button[breakpoint]kit-button--size-sm {
67
+ --button-multiplier-x: 16;
68
+ --button-multiplier-y: 3;
69
+ --button-multiplier-gap: 4;
70
+ --button-multiplier-font-size: 7;
71
+ }
72
+ .kit-button[breakpoint]kit-button--size-sm .kit-icon[class*='kit-icon--size-md'] {
73
+ --icon-multiplier-parent-size: 8;
56
74
  }
57
75
 
58
- .kit-btn[breakpoint]kit-btn--size-md {
59
- --btn-height: 2.25rem;
60
- --btn-multiplier-y: 4;
61
- --btn-gap: 0.5rem;
62
- font-size: 0.875rem;
63
- gap: var(--btn-gap);
76
+ .kit-button[breakpoint]kit-button--size-md {
77
+ --button-multiplier-x: 20;
78
+ --button-multiplier-y: 4;
79
+ --button-multiplier-gap: 4;
80
+ --button-multiplier-font-size: 8;
81
+ }
82
+ .kit-button[breakpoint]kit-button--size-md .kit-icon[class*='kit-icon--size-md'] {
83
+ --icon-multiplier-parent-size: 9;
64
84
  }
65
85
 
66
- .kit-btn[breakpoint]kit-btn--size-lg {
67
- --btn-height: 2.5rem;
68
- --btn-multiplier-y: 5;
69
- --btn-gap: 0.5rem;
70
- font-size: 1rem;
71
- gap: var(--btn-gap);
86
+ .kit-button[breakpoint]kit-button--size-lg {
87
+ --button-multiplier-x: 24;
88
+ --button-multiplier-y: 5;
89
+ --button-multiplier-gap: 4;
90
+ --button-multiplier-font-size: 9;
91
+ }
92
+ .kit-button[breakpoint]kit-button--size-lg .kit-icon[class*='kit-icon--size-md'] {
93
+ --icon-multiplier-parent-size: 10;
72
94
  }
73
95
 
74
- .kit-btn[breakpoint]kit-btn--size-xl {
75
- --btn-height: 2.75rem;
76
- --btn-multiplier-y: 6;
77
- --btn-gap: 0.675rem;
78
- font-size: 1.125rem;
79
- gap: var(--btn-gap);
96
+ .kit-button[breakpoint]kit-button--size-xl {
97
+ --button-multiplier-x: 28;
98
+ --button-multiplier-y: 6;
99
+ --button-multiplier-gap: 5;
100
+ --button-multiplier-font-size: 10;
101
+ }
102
+ .kit-button[breakpoint]kit-button--size-xl .kit-icon[class*='kit-icon--size-md'] {
103
+ --icon-multiplier-parent-size: 11;
80
104
  }
81
105
 
82
106
  /* density */
83
- .kit-btn:not(.kit-btn--icon)[breakpoint]kit-btn--density-default {
84
- height: calc(var(--btn-height));
85
- min-width: calc(var(--btn-height));
86
- --btn-spacing-x: 0;
87
- --btn-spacing-y: calc(var(--kit-spacing) * var(--btn-multiplier-y));
88
- }
89
- .kit-btn.kit-btn--icon[breakpoint]kit-btn--density-default {
90
- height: calc(var(--btn-height));
91
- width: calc(var(--btn-height));
92
- --btn-spacing-x: 0;
93
- --btn-spacing-y: 0;
107
+ .kit-button:not(.kit-button--icon)[breakpoint]kit-button--density-default {
108
+ height: calc(var(--kit-spacing) * var(--button-multiplier-x));
109
+ --button-spacing-x: 0;
110
+ --button-spacing-y: calc(var(--kit-spacing) * var(--button-multiplier-y));
94
111
  }
95
-
96
- .kit-btn:not(.kit-btn--icon)[breakpoint]kit-btn--density-compact {
97
- height: calc(var(--btn-height) - 0.25rem);
98
- min-width: calc(var(--btn-height - 0.25rem));
99
- --btn-spacing-x: 0;
100
- --btn-spacing-y: calc(var(--kit-spacing) * var(--btn-multiplier-y) - 0.25rem);
101
- }
102
- .kit-btn.kit-btn--icon[breakpoint]kit-btn--density-compact {
103
- height: calc(var(--btn-height) - 0.25rem);
104
- width: calc(var(--btn-height) - 0.25rem);
105
- --btn-spacing-x: 0;
106
- --btn-spacing-y: 0;
112
+ .kit-button.kit-button--icon[breakpoint]kit-button--density-default {
113
+ height: calc(var(--kit-spacing) * var(--button-multiplier-x));
114
+ width: calc(var(--kit-spacing) * var(--button-multiplier-x));
115
+ --button-spacing-x: 0;
116
+ --button-spacing-y: 0;
107
117
  }
108
118
 
109
- .kit-btn:not(.kit-btn--icon)[breakpoint]kit-btn--density-comfortable {
110
- height: calc(var(--btn-height) + 0.25rem);
111
- min-width: calc(var(--btn-height) + 0.25rem);
112
- --btn-spacing-x: 0;
113
- --btn-spacing-y: calc(var(--kit-spacing) * var(--btn-multiplier-y) + 0.25rem);
114
- }
115
- .kit-btn.kit-btn--icon[breakpoint]kit-btn--density-comfortable {
116
- height: calc(var(--btn-height) + 0.25rem);
117
- width: calc(var(--btn-height) + 0.25rem);
118
- --btn-spacing-x: 0;
119
- --btn-spacing-y: 0;
119
+ .kit-button:not(.kit-button--icon)[breakpoint]kit-button--density-compact {
120
+ height: calc(var(--kit-spacing) * var(--button-multiplier-x) - 0.25rem);
121
+ --button-spacing-x: 0;
122
+ --button-spacing-y: calc(var(--kit-spacing) * var(--button-multiplier-y) - 0.25rem);
120
123
  }
121
-
122
- /* variant */
123
- .kit-btn[breakpoint]kit-btn--variant-outline {
124
- --btn-color: var(--base, var(--kit-neutral));
125
- background-color: transparent;
126
- border: 1px solid currentColor;
124
+ .kit-button.kit-button--icon[breakpoint]kit-button--density-compact {
125
+ height: calc(var(--kit-spacing) * var(--button-multiplier-x) - 0.25rem);
126
+ width: calc(var(--kit-spacing) * var(--button-multiplier-x) - 0.25rem);
127
+ --button-spacing-x: 0;
128
+ --button-spacing-y: 0;
127
129
  }
128
130
 
129
- .kit-btn[breakpoint]kit-btn--variant-text {
130
- --btn-color: var(--base, var(--kit-neutral));
131
- background-color: transparent;
132
- border-color: transparent;
131
+ .kit-button:not(.kit-button--icon)[breakpoint]kit-button--density-comfortable {
132
+ height: calc(var(--kit-spacing) * var(--button-multiplier-x) + 0.25rem);
133
+ --button-spacing-x: 0;
134
+ --button-spacing-y: calc(var(--kit-spacing) * var(--button-multiplier-y) + 0.25rem);
135
+ }
136
+ .kit-button.kit-button--icon[breakpoint]kit-button--density-comfortable {
137
+ height: calc(var(--kit-spacing) * var(--button-multiplier-x) + 0.25rem);
138
+ width: calc(var(--kit-spacing) * var(--button-multiplier-x) + 0.25rem);
139
+ --button-spacing-x: 0;
140
+ --button-spacing-y: 0;
133
141
  }
134
142
 
135
- .kit-btn[breakpoint]kit-btn--variant-dash {
136
- --btn-color: var(--base, var(--kit-neutral));
143
+ /* variant */
144
+ .kit-button[breakpoint]kit-button--variant-outline {
145
+ --button-color: var(--base, var(--kit-neutral));
137
146
  background-color: transparent;
138
- border: 1px dashed currentColor;
147
+ }
148
+ .kit-button[breakpoint]kit-button--variant-outline::before {
149
+ content: '';
150
+ position: absolute;
151
+ inset: 0;
152
+ border: 1px solid currentColor;
153
+ pointer-events: none;
154
+ border-radius: inherit;
139
155
  }
140
156
 
141
- .kit-btn[breakpoint]kit-btn--variant-link {
142
- --btn-color: var(--base, var(--kit-neutral));
157
+ .kit-button[breakpoint]kit-button--variant-text {
158
+ --button-color: var(--base, var(--kit-neutral));
143
159
  background-color: transparent;
144
- border-color: transparent;
160
+ border: none;
145
161
  }
146
162
 
147
163
  /* state */
148
- .kit-btn.kit-btn--info:not([class*='btn--variant-']) {
164
+ .kit-button.kit-button--info:not([class*='button--variant-']) {
149
165
  --on: var(--kit-on-info);
150
166
  --base: var(--kit-info);
151
167
  }
152
- .kit-btn.kit-btn--info[class*='btn--variant-'] {
168
+ .kit-button.kit-button--info[class*='button--variant-'] {
153
169
  --base: var(--kit-info);
154
170
  }
155
-
156
- .kit-btn.kit-btn--success:not([class*='btn--variant-']) {
171
+ .kit-button.kit-button--success:not([class*='button--variant-']) {
157
172
  --on: var(--kit-on-success);
158
173
  --base: var(--kit-success);
159
174
  }
160
- .kit-btn.kit-btn--success[class*='btn--variant-'] {
175
+ .kit-button.kit-button--success[class*='button--variant-'] {
161
176
  --base: var(--kit-success);
162
177
  }
163
-
164
- .kit-btn.kit-btn--warning:not([class*='btn--variant-']) {
178
+ .kit-button.kit-button--warning:not([class*='button--variant-']) {
165
179
  --on: var(--kit-on-warning);
166
180
  --base: var(--kit-warning);
167
181
  }
168
- .kit-btn.kit-btn--warning[class*='btn--variant-'] {
182
+ .kit-button.kit-button--warning[class*='button--variant-'] {
169
183
  --base: var(--kit-warning);
170
184
  }
171
-
172
- .kit-btn.kit-btn--error:not([class*='btn--variant-']) {
185
+ .kit-button.kit-button--error:not([class*='button--variant-']) {
173
186
  --on: var(--kit-on-error);
174
187
  --base: var(--kit-error);
175
188
  }
176
- .kit-btn.kit-btn--error[class*='btn--variant-'] {
189
+ .kit-button.kit-button--error[class*='button--variant-'] {
177
190
  --base: var(--kit-error);
178
191
  }
179
192
 
180
- /* types */
181
- .kit-btn:where(.kit-btn:is(input[type='checkbox'])),
182
- .kit-btn:where(.kit-btn:is(input[type='radio'])) {
183
- width: auto;
184
- -webkit-appearance: none;
185
- -moz-appearance: none;
186
- appearance: none;
187
- vertical-align: inherit;
188
- }
189
- .kit-btn:is(input[type='checkbox']):after,
190
- .kit-btn:is(input[type='radio']):after {
191
- --btn-content: attr(aria-label);
192
- content: var(--btn-content);
193
- }
194
-
195
- .kit-btn:is(input[type='checkbox']):focus,
196
- .kit-btn:is(input[type='radio']):focus {
197
- outline: none;
198
- outline-offset: inherit;
199
- box-shadow: none;
200
- }
201
-
202
- .kit-btn:is(input[type='checkbox']):checked,
203
- .kit-btn:is(input[type='radio']):checked {
204
- background-image: initial;
205
- }
206
-
207
193
  /* events */
208
- .kit-btn.kit-btn--active:not([class*='btn--variant-']),
209
- .kit-btn:not([class*='btn--variant-']):is(input[type='radio']):checked,
210
- .kit-btn:not([class*='btn--variant-']):is(input[type='checkbox']):checked {
211
- background-color: color-mix(in oklab, var(--btn-background) 90%, var(--kit-scrim));
212
- border-color: color-mix(in oklab, var(--btn-background) 90%, var(--kit-scrim));
213
- }
214
- .kit-btn.kit-btn--active[class*='btn--variant-'],
215
- .kit-btn[class*='btn--variant-']:is(input[type='radio']):checked,
216
- .kit-btn[class*='btn--variant-']:is(input[type='checkbox']):checked {
194
+ .kit-button:not([class*='button--variant-']):active,
195
+ .kit-button.kit-button--active:not([class*='button--variant-']) {
196
+ background-color: color-mix(in oklab, var(--button-background) 90%, var(--kit-scrim));
197
+ border-color: color-mix(in oklab, var(--button-background) 90%, var(--kit-scrim));
198
+ }
199
+ .kit-button.kit-button--active[class*='button--variant-']:active,
200
+ .kit-button.kit-button--active[class*='button--variant-'] {
217
201
  background-color: color-mix(in oklab, currentColor 15%, transparent);
218
202
  border-color: color-mix(in oklab, currentColor 15%, transparent);
219
203
  }
220
204
 
221
- .kit-btn:hover:not([class*='btn--variant-']),
222
- .kit-btn:not([class*='btn--variant-']):is(input[type='radio']):hover,
223
- .kit-btn:not([class*='btn--variant-']):is(input[type='checkbox']):hover {
224
- background-color: color-mix(in oklab, var(--btn-background) 85%, var(--kit-scrim));
225
- border-color: color-mix(in oklab, var(--btn-background) 85%, var(--kit-scrim));
226
- }
227
- .kit-btn:hover[class*='btn--variant-'],
228
- .kit-btn[class*='btn--variant-']:is(input[type='radio']):hover,
229
- .kit-btn[class*='btn--variant-']:is(input[type='checkbox']):hover {
230
- background-color: color-mix(in oklab, currentColor 25%, transparent);
231
- }
232
-
233
205
  /* icon */
234
- .kit-btn i:before {
235
- color: var(--btn-color);
206
+ .kit-button i::before,
207
+ .kit-button .kit-icon {
208
+ --base-parent: var(--button-color);
236
209
  }
237
210
 
238
211
  /* disabled */
239
- .kit-btn.kit-btn--disabled,
240
- .kit-btn[disabled],
241
- input.kit-btn.kit-btn--disabled,
242
- input.kit-btn[disabled] {
212
+ .kit-button.kit-button--disabled,
213
+ .kit-button[disabled],
214
+ .kit-button.kit-button--loading {
243
215
  pointer-events: none;
244
216
  user-select: none;
245
217
  cursor: default;
246
218
  }
247
- .kit-btn:not([class*='btn--variant-']).kit-btn--disabled {
248
- color: color-mix(in oklab, var(--btn-color) 40%, transparent) !important;
249
- background-color: color-mix(in oklab, var(--btn-background) 70%, transparent) !important;
250
- border-color: color-mix(in oklab, var(--btn-background) 70%, transparent) !important;
219
+ .kit-button:not([class*='button--variant-']).kit-button--disabled {
220
+ color: color-mix(in oklab, var(--button-color) 40%, transparent) !important;
221
+ background-color: color-mix(in oklab, var(--button-background) 70%, transparent) !important;
222
+ border-color: color-mix(in oklab, var(--button-background) 70%, transparent) !important;
251
223
  }
252
- .kit-btn:not([class*='btn--variant-']).kit-btn--disabled i:before {
253
- color: color-mix(in oklab, var(--btn-color) 40%, transparent) !important;
224
+ .kit-button:not([class*='button--variant-']).kit-button--disabled i:before {
225
+ color: color-mix(in oklab, var(--button-color) 40%, transparent) !important;
254
226
  }
255
- .kit-btn[class*='btn--variant-'].kit-btn--disabled,
256
- .kit-btn[class*='btn--variant-'].kit-btn--disabled i:before {
257
- color: color-mix(in oklab, var(--btn-background) 40%, transparent) !important;
227
+ .kit-button[class*='button--variant-'].kit-button--disabled,
228
+ .kit-button[class*='button--variant-'].kit-button--disabled i::before {
229
+ color: color-mix(in oklab, var(--button-background) 40%, transparent) !important;
258
230
  }
259
231
 
260
232
  /* loading */
261
- .kit-btn.kit-btn--loading {
262
- pointer-events: none;
263
- user-select: none;
264
- cursor: default;
265
- }
266
- .kit-btn.kit-btn--loading > .kit-btn-content {
267
- color: transparent;
268
- opacity: 0;
233
+ .kit-button.kit-button--loading > .kit-button-content,
234
+ .kit-button.kit-button--loading > .kit-button-append,
235
+ .kit-button.kit-button--loading > .kit-button-prepend {
236
+ visibility: hidden;
269
237
  }
270
- .kit-btn.kit-btn--loading > .kit-btn-loading {
238
+ .kit-button.kit-button--loading > .kit-button-loading {
271
239
  position: absolute;
272
240
  min-width: fit-content;
273
241
  }
274
- .kit-btn.kit-btn--loading > .kit-btn-loading .kit-icon-load {
242
+ .kit-button.kit-button--loading > .kit-button-loading .kit-icon-load {
275
243
  animation: icon-rotate 1s ease-out infinite;
276
244
  }