lapikit 0.1.6 → 0.1.8

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 (39) hide show
  1. package/dist/components/alert/alert.css +2 -2
  2. package/dist/components/appbar/appbar.css +49 -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 +4 -4
  11. package/dist/components/card/card.css +109 -0
  12. package/dist/components/card/card.svelte +50 -0
  13. package/dist/components/card/card.svelte.d.ts +4 -0
  14. package/dist/components/card/types.d.ts +18 -0
  15. package/dist/components/card/types.js +1 -0
  16. package/dist/components/chip/chip.css +199 -0
  17. package/dist/components/chip/chip.svelte +118 -0
  18. package/dist/components/chip/chip.svelte.d.ts +4 -0
  19. package/dist/components/chip/types.d.ts +30 -0
  20. package/dist/components/chip/types.js +1 -0
  21. package/dist/components/index.d.ts +5 -0
  22. package/dist/components/index.js +5 -0
  23. package/dist/components/list/list.css +5 -5
  24. package/dist/components/modal/modal.css +1 -1
  25. package/dist/components/spacer/spacer.css +3 -0
  26. package/dist/components/spacer/spacer.svelte +7 -0
  27. package/dist/components/spacer/spacer.svelte.d.ts +4 -0
  28. package/dist/components/spacer/types.d.ts +4 -0
  29. package/dist/components/spacer/types.js +1 -0
  30. package/dist/components/toolbar/toolbar.css +129 -0
  31. package/dist/components/toolbar/toolbar.svelte +47 -0
  32. package/dist/components/toolbar/toolbar.svelte.d.ts +4 -0
  33. package/dist/components/toolbar/types.d.ts +27 -0
  34. package/dist/components/toolbar/types.js +1 -0
  35. package/dist/internal/unit.d.ts +1 -0
  36. package/dist/internal/unit.js +11 -0
  37. package/dist/stores/index.js +6 -2
  38. package/dist/style/parser/device.js +31 -19
  39. package/package.json +1 -1
@@ -53,7 +53,7 @@
53
53
  padding-top: 0.75rem;
54
54
  }
55
55
 
56
- .kit-alert .kit-alert--prepend {
56
+ .kit-alert .kit-alert-prepend {
57
57
  align-self: flex-start;
58
58
  display: flex;
59
59
  align-items: center;
@@ -61,7 +61,7 @@
61
61
  margin-inline-end: 1rem;
62
62
  }
63
63
 
64
- .kit-alert .kit-alert--content {
64
+ .kit-alert .kit-alert-content {
65
65
  align-self: center;
66
66
  grid-area: content;
67
67
  overflow: hidden;
@@ -0,0 +1,49 @@
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
+ min-width: max-content;
13
+ border-style: solid;
14
+ border-width: 1px;
15
+ border-radius: var(--appbar-radius);
16
+ color: var(--appbar-color);
17
+ background-color: var(--appbar-background);
18
+ border-color: var(--appbar-background);
19
+ transition:
20
+ color 0.5s,
21
+ border-color 0.5s,
22
+ background-color 0.5s;
23
+ }
24
+
25
+ /* wrapper */
26
+ .kit-appbar .kit-appbar--wrapper {
27
+ display: flex;
28
+ align-items: center;
29
+ flex-direction: row;
30
+ height: calc(100% - (var(--appbar-padding-wrapper) * 2));
31
+ width: calc(100% - (var(--appbar-padding-wrapper) * 2));
32
+ margin: 0 auto;
33
+ }
34
+
35
+ /* density */
36
+ .kit-appbar[breakpoint]kit-appbar--density-default {
37
+ height: 4rem;
38
+ padding-inline: calc(var(--kit-spacing) * 1.5);
39
+ }
40
+
41
+ .kit-appbar[breakpoint]kit-appbar--density-compact {
42
+ height: 3.5rem;
43
+ padding-inline: calc(var(--kit-spacing) * 0.75);
44
+ }
45
+
46
+ .kit-appbar[breakpoint]kit-appbar--density-comfortable {
47
+ height: 4.5rem;
48
+ padding-inline: calc(var(--kit-spacing) * 2.25);
49
+ }
@@ -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
  };
@@ -12,7 +12,7 @@
12
12
  padding-right: var(--btn-spacing-y);
13
13
  padding-left: var(--btn-spacing-y);
14
14
  cursor: pointer;
15
-
15
+ width: fit-content;
16
16
  border-width: 1px;
17
17
  border-style: solid;
18
18
  border-radius: var(--btn-radius);
@@ -82,7 +82,7 @@
82
82
  /* density */
83
83
  .kit-btn:not(.kit-btn--icon)[breakpoint]kit-btn--density-default {
84
84
  height: calc(var(--btn-height));
85
- min-width: calc(var(--btn-height));
85
+ /* min-width: calc(var(--btn-height)); */
86
86
  --btn-spacing-x: 0;
87
87
  --btn-spacing-y: calc(var(--kit-spacing) * var(--btn-multiplier-y));
88
88
  }
@@ -95,7 +95,7 @@
95
95
 
96
96
  .kit-btn:not(.kit-btn--icon)[breakpoint]kit-btn--density-compact {
97
97
  height: calc(var(--btn-height) - 0.25rem);
98
- min-width: calc(var(--btn-height - 0.25rem));
98
+ /* min-width: calc(var(--btn-height) - 0.25rem); */
99
99
  --btn-spacing-x: 0;
100
100
  --btn-spacing-y: calc(var(--kit-spacing) * var(--btn-multiplier-y) - 0.25rem);
101
101
  }
@@ -108,7 +108,7 @@
108
108
 
109
109
  .kit-btn:not(.kit-btn--icon)[breakpoint]kit-btn--density-comfortable {
110
110
  height: calc(var(--btn-height) + 0.25rem);
111
- min-width: calc(var(--btn-height) + 0.25rem);
111
+ /* min-width: calc(var(--btn-height) + 0.25rem); */
112
112
  --btn-spacing-x: 0;
113
113
  --btn-spacing-y: calc(var(--kit-spacing) * var(--btn-multiplier-y) + 0.25rem);
114
114
  }
@@ -0,0 +1,109 @@
1
+ .kit-card {
2
+ --card-color: var(--on, var(--kit-on-neutral));
3
+ --card-background: var(--base, var(--kit-neutral));
4
+ --card-radius: var(--shape, var(--kit-radius-md));
5
+
6
+ position: relative;
7
+ display: flex;
8
+ flex-direction: column;
9
+ text-align: start;
10
+ overflow: hidden;
11
+ transition:
12
+ color 0.5s,
13
+ background-color 0.5s;
14
+
15
+ padding-top: var(--card-spacing-x);
16
+ padding-bottom: var(--card-spacing-x);
17
+ padding-right: var(--card-spacing-y);
18
+ padding-left: var(--card-spacing-y);
19
+
20
+ border-width: 1px;
21
+ border-style: solid;
22
+ border-radius: var(--card-radius);
23
+
24
+ /* theme */
25
+ color: var(--card-color);
26
+ background-color: var(--card-background);
27
+ border-color: var(--card-background);
28
+ }
29
+
30
+ /* density */
31
+ .kit-card[breakpoint]kit-card--density-default {
32
+ --card-spacing-x: 0.25rem;
33
+ --card-spacing-y: 0.25rem;
34
+ }
35
+
36
+ .kit-card[breakpoint]kit-card--density-compact {
37
+ --card-spacing-x: 0;
38
+ --card-spacing-y: 0;
39
+ }
40
+
41
+ .kit-card[breakpoint]kit-card--density-comfortable {
42
+ --card-spacing-x: 0.5rem;
43
+ --card-spacing-y: 0.5rem;
44
+ }
45
+
46
+ a.kit-card {
47
+ text-decoration: none;
48
+ }
49
+
50
+ .kit-card:hover:not(div) {
51
+ background-color: color-mix(in oklab, var(--card-background) 90%, black);
52
+ }
53
+
54
+ .kit-card:focus:not(div) {
55
+ background-color: color-mix(in oklab, var(--card-background) 95%, black);
56
+ }
57
+
58
+ .kit-card:active:not(div),
59
+ .kit-card.kit-card--active {
60
+ background-color: color-mix(in oklab, var(--card-background) 95%, black);
61
+ }
62
+
63
+ .kit-card:not(div) {
64
+ cursor: pointer;
65
+ }
66
+
67
+ .kit-card.kit-card--variant-outline {
68
+ border-color: currentColor;
69
+ }
70
+
71
+ .kit-card.kit-card--variant-text {
72
+ border-color: transparent;
73
+ }
74
+
75
+ .kit-card.kit-card--variant-outline,
76
+ .kit-card.kit-card--variant-text {
77
+ --card-color: var(--base, var(--kit-neutral));
78
+ background-color: transparent;
79
+ }
80
+
81
+ .kit-card.kit-card--variant-outline:hover:not(div),
82
+ .kit-card.kit-card--variant-text:hover:not(div) {
83
+ background-color: color-mix(in oklab, currentColor 7%, transparent);
84
+ }
85
+
86
+ .kit-card.kit-card--variant-outline:focus:not(div),
87
+ .kit-card.kit-card--variant-text:focus:not(div) {
88
+ background-color: color-mix(in oklab, currentColor 15%, transparent);
89
+ }
90
+
91
+ .kit-card.kit-card--variant-outline:active:not(div),
92
+ .kit-card.kit-card--variant-text:active:not(div),
93
+ .kit-card.kit-card--variant-outline.kit-card--active,
94
+ .kit-card.kit-card--variant-text.kit-card--active {
95
+ background-color: color-mix(in oklab, currentColor 10%, transparent);
96
+ }
97
+
98
+ .kit-card.kit-card--disabled,
99
+ .kit-card[disabled],
100
+ .kit-card:disabled {
101
+ pointer-events: none;
102
+ user-select: none;
103
+ opacity: 0.6;
104
+ }
105
+ .kit-card.kit-card--disabled > *,
106
+ .kit-card[disabled] > *,
107
+ .kit-card:disabled > * {
108
+ opacity: 0.6;
109
+ }
@@ -0,0 +1,50 @@
1
+ <script lang="ts">
2
+ import { getAssets } from '../../internal/index.js';
3
+ import type { CardProps } from './types.js';
4
+
5
+ let {
6
+ children,
7
+ ref = $bindable(),
8
+ is = 'div',
9
+ href,
10
+ dark,
11
+ light,
12
+ active,
13
+ density = 'default',
14
+ variant,
15
+ disabled,
16
+ rounded,
17
+ color,
18
+ background,
19
+ ...rest
20
+ }: CardProps = $props();
21
+
22
+ const assets = getAssets();
23
+
24
+ $effect(() => {
25
+ if (href) is = 'a';
26
+ });
27
+ </script>
28
+
29
+ <svelte:element
30
+ this={is}
31
+ bind:this={ref}
32
+ {...rest}
33
+ href={href && !disabled ? href : undefined}
34
+ class={[
35
+ 'kit-card',
36
+ light && 'light',
37
+ dark && 'dark',
38
+ variant && assets.className('card', 'variant', variant),
39
+ density && assets.className('card', 'density', density),
40
+ active && 'kit-card--active',
41
+ disabled && 'kit-card--disabled',
42
+ rest.class
43
+ ]}
44
+ disabled={href ? undefined : disabled}
45
+ style:--base={assets.color(background)}
46
+ style:--on={assets.color(color)}
47
+ style:--shape={assets.shape(rounded)}
48
+ >
49
+ {@render children?.()}
50
+ </svelte:element>
@@ -0,0 +1,4 @@
1
+ import type { CardProps } from './types.js';
2
+ declare const Card: import("svelte").Component<CardProps, {}, "ref">;
3
+ type Card = ReturnType<typeof Card>;
4
+ export default Card;
@@ -0,0 +1,18 @@
1
+ import type { Component } from '../../internal/types.js';
2
+ type Density = 'compact' | 'comfortable' | 'default';
3
+ export interface CardProps extends Component {
4
+ is?: 'a' | 'button' | 'div';
5
+ dark?: boolean;
6
+ light?: boolean;
7
+ href?: string;
8
+ variant?: 'outline' | 'text';
9
+ density?: Density | {
10
+ [key: string]: Density;
11
+ };
12
+ active?: boolean;
13
+ disabled?: boolean;
14
+ rounded?: string;
15
+ color?: string;
16
+ background?: string;
17
+ }
18
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,199 @@
1
+ .kit-chip {
2
+ --chip-color: var(--on, var(--kit-on-neutral));
3
+ --chip-background: var(--base, var(--kit-neutral));
4
+ --chip-radius: var(--shape, var(--kit-radius-full));
5
+
6
+ display: inline-flex;
7
+ align-items: center;
8
+ justify-content: center;
9
+ white-space: nowrap;
10
+ padding-top: var(--chip-spacing-x);
11
+ padding-bottom: var(--chip-spacing-x);
12
+ padding-right: var(--chip-spacing-y);
13
+ padding-left: var(--chip-spacing-y);
14
+
15
+ border-width: 1px;
16
+ border-style: solid;
17
+ border-radius: var(--chip-radius);
18
+
19
+ /* theme */
20
+ color: var(--chip-color);
21
+ background-color: var(--chip-background);
22
+ border-color: var(--chip-background);
23
+ }
24
+
25
+ a.kit-chip,
26
+ button.kit-chip {
27
+ cursor: pointer;
28
+ }
29
+
30
+ .kit-chip .kit-chip-content,
31
+ .kit-chip .kit-chip-append,
32
+ .kit-chip .kit-chip-prepend,
33
+ .kit-chip .kit-chip--close,
34
+ .kit-chip .kit-chip-loading {
35
+ display: inline-flex;
36
+ align-items: center;
37
+ justify-content: center;
38
+ white-space: nowrap;
39
+ gap: var(--chip-gap);
40
+ }
41
+
42
+ /* size */
43
+ .kit-chip[breakpoint]kit-chip--size-xs {
44
+ --chip-height: 1.25rem;
45
+ --chip-multiplier-y: 2;
46
+ --chip-gap: 0.25rem;
47
+ font-size: 0.625rem;
48
+ gap: var(--chip-gap);
49
+ }
50
+
51
+ .kit-chip[breakpoint]kit-chip--size-sm {
52
+ --chip-height: 1.625rem;
53
+ --chip-multiplier-y: 3;
54
+ --chip-gap: 0.5rem;
55
+ font-size: 0.75rem;
56
+ gap: var(--chip-gap);
57
+ }
58
+
59
+ .kit-chip[breakpoint]kit-chip--size-md {
60
+ --chip-height: 2rem;
61
+ --chip-multiplier-y: 4;
62
+ --chip-gap: 0.5rem;
63
+ font-size: 0.875rem;
64
+ gap: var(--chip-gap);
65
+ }
66
+
67
+ .kit-chip[breakpoint]kit-chip--size-lg {
68
+ --chip-height: 2.375rem;
69
+ --chip-multiplier-y: 5;
70
+ --chip-gap: 0.5rem;
71
+ font-size: 1rem;
72
+ gap: var(--chip-gap);
73
+ }
74
+
75
+ .kit-chip[breakpoint]kit-chip--size-xl {
76
+ --chip-height: 2.75rem;
77
+ --chip-multiplier-y: 6;
78
+ --chip-gap: 0.675rem;
79
+ font-size: 1.125rem;
80
+ gap: var(--chip-gap);
81
+ }
82
+
83
+ /* variant */
84
+ .kit-chip[breakpoint]kit-chip--variant-outline {
85
+ --chip-color: var(--base, var(--kit-neutral));
86
+ background-color: transparent;
87
+ border: 1px solid currentColor;
88
+ }
89
+
90
+ /* density */
91
+ .kit-chip[breakpoint]kit-chip--density-default {
92
+ height: calc(var(--chip-height));
93
+ min-width: calc(var(--chip-height));
94
+ --chip-spacing-x: 0;
95
+ --chip-spacing-y: calc(var(--kit-spacing) * var(--chip-multiplier-y));
96
+ }
97
+
98
+ .kit-chip[breakpoint]kit-chip--density-compact {
99
+ height: calc(var(--chip-height) - 0.25rem);
100
+ min-width: calc(var(--chip-height - 0.25rem));
101
+ --chip-spacing-x: 0;
102
+ --chip-spacing-y: calc(var(--kit-spacing) * var(--chip-multiplier-y) - 0.25rem);
103
+ }
104
+
105
+ .kit-chip[breakpoint]kit-chip--density-comfortable {
106
+ height: calc(var(--chip-height) + 0.25rem);
107
+ min-width: calc(var(--chip-height) + 0.25rem);
108
+ --chip-spacing-x: 0;
109
+ --chip-spacing-y: calc(var(--kit-spacing) * var(--chip-multiplier-y) + 0.25rem);
110
+ }
111
+
112
+ /* state */
113
+ .kit-chip.kit-chip--info:not([class*='chip--variant-']) {
114
+ --on: var(--kit-on-info);
115
+ --base: var(--kit-info);
116
+ }
117
+ .kit-chip.kit-chip--info[class*='chip--variant-'] {
118
+ --base: var(--kit-info);
119
+ }
120
+
121
+ .kit-chip.kit-chip--success:not([class*='chip--variant-']) {
122
+ --on: var(--kit-on-success);
123
+ --base: var(--kit-success);
124
+ }
125
+ .kit-chip.kit-chip--success[class*='chip--variant-'] {
126
+ --base: var(--kit-success);
127
+ }
128
+
129
+ .kit-chip.kit-chip--warning:not([class*='chip--variant-']) {
130
+ --on: var(--kit-on-warning);
131
+ --base: var(--kit-warning);
132
+ }
133
+ .kit-chip.kit-chip--warning[class*='chip--variant-'] {
134
+ --base: var(--kit-warning);
135
+ }
136
+
137
+ .kit-chip.kit-chip--error:not([class*='chip--variant-']) {
138
+ --on: var(--kit-on-error);
139
+ --base: var(--kit-error);
140
+ }
141
+ .kit-chip.kit-chip--error[class*='chip--variant-'] {
142
+ --base: var(--kit-error);
143
+ }
144
+
145
+ /* events */
146
+ .kit-chip.kit-chip--active:not([class*='chip--variant-']) {
147
+ background-color: color-mix(in oklab, var(--chip-background) 90%, var(--kit-scrim));
148
+ border-color: color-mix(in oklab, var(--chip-background) 90%, var(--kit-scrim));
149
+ }
150
+ .kit-chip.kit-chip--active[class*='chip--variant-'] {
151
+ background-color: color-mix(in oklab, currentColor 15%, transparent);
152
+ border-color: color-mix(in oklab, currentColor 15%, transparent);
153
+ }
154
+
155
+ .kit-chip:hover:not([class*='chip--variant-']) {
156
+ background-color: color-mix(in oklab, var(--chip-background) 85%, var(--kit-scrim));
157
+ border-color: color-mix(in oklab, var(--chip-background) 85%, var(--kit-scrim));
158
+ }
159
+ .kit-chip:hover[class*='chip--variant-'] {
160
+ background-color: color-mix(in oklab, currentColor 25%, transparent);
161
+ }
162
+
163
+ /* disabled */
164
+ .kit-chip.kit-chip--disabled,
165
+ .kit-chip[disabled] {
166
+ pointer-events: none;
167
+ user-select: none;
168
+ cursor: default;
169
+ }
170
+ .kit-chip:not([class*='chip--variant-']).kit-chip--disabled {
171
+ color: color-mix(in oklab, var(--chip-color) 40%, transparent) !important;
172
+ background-color: color-mix(in oklab, var(--chip-background) 70%, transparent) !important;
173
+ border-color: color-mix(in oklab, var(--chip-background) 70%, transparent) !important;
174
+ }
175
+ .kit-chip:not([class*='chip--variant-']).kit-chip--disabled i:before {
176
+ color: color-mix(in oklab, var(--chip-color) 40%, transparent) !important;
177
+ }
178
+ .kit-chip[class*='chip--variant-'].kit-chip--disabled,
179
+ .kit-chip[class*='chip--variant-'].kit-chip--disabled i:before {
180
+ color: color-mix(in oklab, var(--chip-background) 40%, transparent) !important;
181
+ }
182
+
183
+ /* loading */
184
+ .kit-chip.kit-chip--loading {
185
+ pointer-events: none;
186
+ user-select: none;
187
+ cursor: default;
188
+ }
189
+ .kit-chip.kit-chip--loading > .kit-chip-content {
190
+ color: transparent;
191
+ opacity: 0;
192
+ }
193
+ .kit-chip.kit-chip--loading > .kit-chip-loading {
194
+ position: absolute;
195
+ min-width: fit-content;
196
+ }
197
+ .kit-chip.kit-chip--loading > .kit-chip-loading .kit-icon-load {
198
+ animation: icon-rotate 1s ease-out infinite;
199
+ }
@@ -0,0 +1,118 @@
1
+ <script lang="ts">
2
+ import { getAssets } from '../../internal/index.js';
3
+ import { Icon } from '../index.js';
4
+ import type { ChipProps } from './types.js';
5
+
6
+ // external
7
+ import LoadingFill from '../../assets/icons/loading-fill.svelte';
8
+ import Close from '../../assets/icons/close-fill.svelte';
9
+
10
+ let {
11
+ children,
12
+ load,
13
+ close,
14
+ append,
15
+ prepend,
16
+ ref = $bindable(),
17
+ open = $bindable(true),
18
+ is = 'div',
19
+ href,
20
+ dark,
21
+ light,
22
+ active,
23
+ variant,
24
+ error,
25
+ info,
26
+ success,
27
+ warning,
28
+ density = 'default',
29
+ disabled,
30
+ size = 'md',
31
+ type,
32
+ background,
33
+ color,
34
+ label,
35
+ loading,
36
+ rounded,
37
+ closable,
38
+ ...rest
39
+ }: ChipProps = $props();
40
+
41
+ const assets = getAssets();
42
+ </script>
43
+
44
+ {#if !closable || (open && closable)}
45
+ <svelte:element
46
+ this={href ? 'a' : is}
47
+ bind:this={ref}
48
+ {...rest}
49
+ href={href && !disabled ? href : undefined}
50
+ class={[
51
+ 'kit-chip',
52
+ light && 'light',
53
+ dark && 'dark',
54
+ size && assets.className('chip', 'size', size),
55
+ variant && assets.className('chip', 'variant', variant),
56
+ density && assets.className('chip', 'density', density),
57
+ error && 'kit-chip--error',
58
+ info && 'kit-chip--info',
59
+ success && 'kit-chip--success',
60
+ warning && 'kit-chip--warning',
61
+ disabled && 'kit-chip--disabled',
62
+ active && 'kit-chip--active',
63
+ loading && 'kit-chip--loading',
64
+ rest.class
65
+ ]}
66
+ tabindex={href && disabled ? -1 : 0}
67
+ aria-disabled={href ? disabled : undefined}
68
+ aria-label={type !== 'button' ? label : undefined}
69
+ disabled={href ? undefined : disabled}
70
+ type={href ? undefined : type}
71
+ style:--base={assets.color(background)}
72
+ style:--on={assets.color(color)}
73
+ style:--shape={assets.shape(rounded)}
74
+ >
75
+ {#if loading}
76
+ <div class="kit-chip-loading">
77
+ {#if load}
78
+ {@render load?.()}
79
+ {:else}
80
+ <Icon class="kit-icon-load">
81
+ <LoadingFill />
82
+ </Icon>
83
+ {/if}
84
+ </div>
85
+ {/if}
86
+
87
+ {#if prepend}
88
+ <span class="kit-chip-prepend">
89
+ {@render prepend?.()}
90
+ </span>
91
+ {/if}
92
+ <span class="kit-chip-content">
93
+ {@render children?.()}
94
+ </span>
95
+ {#if append}
96
+ <span class="kit-chip-append">
97
+ {@render append?.()}
98
+ </span>
99
+ {/if}
100
+
101
+ {#if closable}
102
+ <button
103
+ class="kit-chip--close"
104
+ type="button"
105
+ aria-label="close"
106
+ onclick={() => (open = false)}
107
+ >
108
+ {#if close}
109
+ {@render close?.()}
110
+ {:else}
111
+ <Icon>
112
+ <Close />
113
+ </Icon>
114
+ {/if}
115
+ </button>
116
+ {/if}
117
+ </svelte:element>
118
+ {/if}
@@ -0,0 +1,4 @@
1
+ import type { ChipProps } from './types.js';
2
+ declare const Chip: import("svelte").Component<ChipProps, {}, "ref" | "open">;
3
+ type Chip = ReturnType<typeof Chip>;
4
+ export default Chip;
@@ -0,0 +1,30 @@
1
+ import type { Component } from '../../internal/types.js';
2
+ import type { Snippet } from 'svelte';
3
+ export interface ChipProps extends Component {
4
+ load?: Snippet;
5
+ close?: Snippet;
6
+ append?: Snippet;
7
+ prepend?: Snippet;
8
+ ref?: HTMLElement | null;
9
+ is?: 'button' | 'a' | 'span' | 'div';
10
+ dark?: boolean;
11
+ light?: boolean;
12
+ href?: string;
13
+ variant?: 'outline';
14
+ density?: 'compact' | 'comfortable' | 'default';
15
+ active?: boolean;
16
+ loading?: boolean;
17
+ error?: boolean;
18
+ info?: boolean;
19
+ warning?: boolean;
20
+ success?: boolean;
21
+ disabled?: boolean;
22
+ color?: string;
23
+ background?: string;
24
+ size?: string | {
25
+ [key: string]: string;
26
+ };
27
+ type?: 'button';
28
+ label?: string;
29
+ closable?: boolean;
30
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -14,3 +14,8 @@ export { default as Accordion } from './accordion/accordion.svelte';
14
14
  export { default as AccordionItem } from './accordion/modules/accordion-item.svelte';
15
15
  export { default as AspectRatio } from './aspect-ratio/aspect-ratio.svelte';
16
16
  export { default as Alert } from './alert/alert.svelte';
17
+ export { default as Chip } from './chip/chip.svelte';
18
+ export { default as Card } from './card/card.svelte';
19
+ export { default as Toolbar } from './toolbar/toolbar.svelte';
20
+ export { default as Appbar } from './appbar/appbar.svelte';
21
+ export { default as Spacer } from './spacer/spacer.svelte';
@@ -15,3 +15,8 @@ export { default as Accordion } from './accordion/accordion.svelte';
15
15
  export { default as AccordionItem } from './accordion/modules/accordion-item.svelte';
16
16
  export { default as AspectRatio } from './aspect-ratio/aspect-ratio.svelte';
17
17
  export { default as Alert } from './alert/alert.svelte';
18
+ export { default as Chip } from './chip/chip.svelte';
19
+ export { default as Card } from './card/card.svelte';
20
+ export { default as Toolbar } from './toolbar/toolbar.svelte';
21
+ export { default as Appbar } from './appbar/appbar.svelte';
22
+ export { default as Spacer } from './spacer/spacer.svelte';
@@ -2,9 +2,7 @@
2
2
  --list-color: var(--on, var(--kit-on-neutral));
3
3
  --list-background: var(--base, var(--kit-neutral));
4
4
  --list-radius: var(--shape, var(--kit-radius-md));
5
-
6
5
  display: flex;
7
- width: 100%;
8
6
  }
9
7
 
10
8
  .kit-list.kit-list--nav {
@@ -16,9 +14,11 @@
16
14
  /* orientation */
17
15
  .kit-list[breakpoint]kit-list--orientation-vertical {
18
16
  flex-direction: column;
17
+ width: 100%;
19
18
  }
20
19
  .kit-list[breakpoint]kit-list--orientation-horizontal {
21
20
  flex-direction: row;
21
+ width: fit-content;
22
22
  }
23
23
  .kit-list[breakpoint]kit-list--orientation-horizontal .kit-list-item {
24
24
  justify-content: center;
@@ -70,14 +70,14 @@
70
70
 
71
71
  .kit-list[breakpoint]kit-list--density-compact .kit-list-item {
72
72
  height: calc(var(--list-height) - 0.25rem);
73
- min-width: calc(var(--list-height - 0.25rem));
73
+ min-width: calc(var(--list-height) - 0.25rem);
74
74
  --list-spacing-x: 0;
75
- --list-spacing-y: calc(var(--list-spacing) * var(--list-multiplier-y) - 0.25rem);
75
+ --list-spacing-y: calc(var(--kit-spacing) * var(--list-multiplier-y) - 0.25rem);
76
76
  }
77
77
 
78
78
  .kit-list[breakpoint]kit-list--density-comfortable .kit-list-item {
79
79
  height: calc(var(--list-height) + 0.25rem);
80
- min-width: calc(var(--list-height + 0.25rem));
80
+ min-width: calc(var(--list-height) + 0.25rem);
81
81
  --list-spacing-x: 0;
82
82
  --list-spacing-y: calc(var(--kit-spacing) * var(--list-multiplier-y) + 0.25rem);
83
83
  }
@@ -11,7 +11,7 @@
11
11
  --modal-translate-y: -50%;
12
12
 
13
13
  position: fixed;
14
-
14
+ overflow-y: auto;
15
15
  z-index: 9100;
16
16
  width: 100%;
17
17
  height: 100%;
@@ -0,0 +1,3 @@
1
+ .kit-spacer {
2
+ flex-grow: 1;
3
+ }
@@ -0,0 +1,7 @@
1
+ <script lang="ts">
2
+ import type { SpacerProps } from './types.js';
3
+
4
+ let { is = 'div', ...rest }: SpacerProps = $props();
5
+ </script>
6
+
7
+ <svelte:element this={is} {...rest} class={['kit-spacer', rest.class]}> </svelte:element>
@@ -0,0 +1,4 @@
1
+ import type { SpacerProps } from './types.js';
2
+ declare const Spacer: import("svelte").Component<SpacerProps, {}, "">;
3
+ type Spacer = ReturnType<typeof Spacer>;
4
+ export default Spacer;
@@ -0,0 +1,4 @@
1
+ import type { Base } from '../../internal/types.js';
2
+ export interface SpacerProps extends Base {
3
+ is?: 'div';
4
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,129 @@
1
+ .kit-toolbar {
2
+ --toolbar-color: var(--on, var(--kit-on-neutral));
3
+ --toolbar-background: var(--base, var(--kit-neutral));
4
+ --toolbar-radius: var(--shape, var(--kit-radius-md));
5
+
6
+ display: flex;
7
+ align-items: center;
8
+ min-width: max-content;
9
+ border-style: solid;
10
+ transition:
11
+ color 0.5s,
12
+ border-color 0.5s,
13
+ background-color 0.5s;
14
+
15
+ border-width: 1px;
16
+ border-style: solid;
17
+ border-radius: var(--toolbar-radius);
18
+
19
+ /* theme */
20
+ color: var(--toolbar-color);
21
+ background-color: var(--toolbar-background);
22
+ border-color: var(--toolbar-background);
23
+ }
24
+
25
+ /* density */
26
+ .kit-toolbar[breakpoint]kit-toolbar--density-default {
27
+ border-radius: calc(var(--kit-spacing) * 2.25);
28
+ }
29
+ .kit-toolbar[breakpoint]kit-toolbar--density-default:not([class*='toolbar--orientation-vertical']) {
30
+ height: 3rem;
31
+ padding-inline: calc(var(--kit-spacing) * 1.5);
32
+ }
33
+
34
+ .kit-toolbar[breakpoint]kit-toolbar--density-default[class*='toolbar--orientation-vertical'] {
35
+ width: 3rem;
36
+ padding: calc(var(--kit-spacing) * 1.5) 0;
37
+ }
38
+
39
+ .kit-toolbar[breakpoint]kit-toolbar--density-compact {
40
+ border-radius: calc(var(--kit-spacing) * 1.75);
41
+ }
42
+
43
+ .kit-toolbar[breakpoint]kit-toolbar--density-compact:not([class*='toolbar--orientation-vertical']) {
44
+ height: 2.625rem;
45
+ padding-inline: calc(var(--kit-spacing) * 0.75);
46
+ }
47
+
48
+ .kit-toolbar[breakpoint]kit-toolbar--density-compact[class*='toolbar--orientation-vertical'] {
49
+ width: 2.625rem;
50
+ padding: calc(var(--kit-spacing) * 0.75) 0;
51
+ }
52
+
53
+ .kit-toolbar[breakpoint]kit-toolbar--density-comfortable {
54
+ border-radius: calc(var(--kit-spacing) * 3.5);
55
+ }
56
+
57
+ .kit-toolbar[breakpoint]kit-toolbar--density-comfortable:not(
58
+ [class*='toolbar--orientation-vertical']
59
+ ) {
60
+ height: 3.5rem;
61
+ padding-inline: calc(var(--kit-spacing) * 2.25);
62
+ }
63
+
64
+ .kit-toolbar[breakpoint]kit-toolbar--density-comfortable[class*='toolbar--orientation-vertical'] {
65
+ width: 3.5rem;
66
+ padding: calc(var(--kit-spacing) * 2.25) 0;
67
+ }
68
+
69
+ .kit-toolbar[breakpoint]kit-toolbar--variant-text,
70
+ .kit-toolbar[breakpoint]kit-toolbar--variant-outline,
71
+ .kit-toolbar[breakpoint]kit-toolbar--variant-dash {
72
+ --toolbar-color: var(--base, var(--kit-neutral));
73
+ background-color: transparent;
74
+ }
75
+
76
+ .kit-toolbar[breakpoint]kit-toolbar--variant-outline {
77
+ border-color: currentColor;
78
+ }
79
+
80
+ .kit-toolbar[breakpoint]kit-toolbar--variant-dash {
81
+ border-style: dashed;
82
+ border-color: currentColor;
83
+ }
84
+
85
+ .kit-toolbar[breakpoint]kit-toolbar--orientation-horizontal {
86
+ flex-direction: row;
87
+ width: 100%;
88
+ }
89
+
90
+ .kit-toolbar[breakpoint]kit-toolbar--orientation-vertical {
91
+ flex-direction: column;
92
+ min-height: fit-content;
93
+ width: fit-content;
94
+ }
95
+
96
+ /* wrapper */
97
+ .kit-toolbar .kit-toolbar--wrapper {
98
+ display: flex;
99
+ align-items: center;
100
+ /* margin-left: auto;
101
+ margin-right: auto; */
102
+ flex-direction: row;
103
+ height: auto;
104
+ width: 100%;
105
+ }
106
+
107
+ .kit-toolbar[breakpoint]kit-toolbar--orientation-vertical .kit-toolbar--wrapper {
108
+ flex-direction: column;
109
+ height: 100%;
110
+ }
111
+
112
+ /* location */
113
+ .kit-toolbar[breakpoint]kit-toolbar--location-top {
114
+ top: 0px;
115
+ z-index: 1004;
116
+ transform: translateY(0px);
117
+ position: fixed;
118
+ left: 0px;
119
+ width: calc(100% + 0px);
120
+ }
121
+
122
+ .kit-toolbar[breakpoint]kit-toolbar--location-bottom {
123
+ z-index: 1004;
124
+ transform: translateY(0px);
125
+ position: fixed;
126
+ left: 0px;
127
+ width: calc(100% + 0px);
128
+ bottom: 0px;
129
+ }
@@ -0,0 +1,47 @@
1
+ <script lang="ts">
2
+ import { getAssets } from '../../internal/index.js';
3
+ import type { ToolbarProps } from './types.js';
4
+
5
+ let {
6
+ children,
7
+ ref = $bindable(),
8
+ is = 'div',
9
+ classContent,
10
+ light,
11
+ dark,
12
+ variant,
13
+ rounded,
14
+ background,
15
+ color,
16
+ density = 'default',
17
+ orientation = 'horizontal',
18
+ location,
19
+ ...rest
20
+ }: ToolbarProps = $props();
21
+
22
+ const assets = getAssets();
23
+ </script>
24
+
25
+ <svelte:element
26
+ this={is}
27
+ bind:this={ref}
28
+ {...rest}
29
+ role="toolbar"
30
+ class={[
31
+ 'kit-toolbar',
32
+ light && 'light',
33
+ dark && 'dark',
34
+ variant && assets.className('toolbar', 'variant', variant),
35
+ density && assets.className('toolbar', 'density', density),
36
+ orientation && assets.className('toolbar', 'orientation', orientation),
37
+ location && assets.className('toolbar', 'location', location),
38
+ rest.class
39
+ ]}
40
+ style:--base={assets.color(background)}
41
+ style:--on={assets.color(color)}
42
+ style:--shape={assets.shape(rounded)}
43
+ >
44
+ <div class={['kit-toolbar--wrapper', classContent]}>
45
+ {@render children?.()}
46
+ </div>
47
+ </svelte:element>
@@ -0,0 +1,4 @@
1
+ import type { ToolbarProps } from './types.js';
2
+ declare const Toolbar: import("svelte").Component<ToolbarProps, {}, "ref">;
3
+ type Toolbar = ReturnType<typeof Toolbar>;
4
+ export default Toolbar;
@@ -0,0 +1,27 @@
1
+ import type { Component } from '../../internal/types.js';
2
+ type Variant = 'outline' | 'text' | 'dash';
3
+ type Density = 'compact' | 'comfortable' | 'default';
4
+ type Orientation = 'horizontal' | 'vertical';
5
+ type Location = 'top' | 'bottom';
6
+ export interface ToolbarProps extends Component {
7
+ is?: 'div' | 'header' | 'nav';
8
+ variant?: Variant | {
9
+ [key: string]: Variant;
10
+ };
11
+ rounded?: string;
12
+ density?: Density | {
13
+ [key: string]: Density;
14
+ };
15
+ dark?: boolean;
16
+ light?: boolean;
17
+ color?: string;
18
+ orientation?: Orientation | {
19
+ [key: string]: Orientation;
20
+ };
21
+ background?: string;
22
+ location?: Location | {
23
+ [key: string]: Location;
24
+ };
25
+ classContent?: string | string[] | undefined;
26
+ }
27
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1 @@
1
+ export declare const setUnit: (value: string | number) => string;
@@ -0,0 +1,11 @@
1
+ export const setUnit = (value) => {
2
+ if (typeof value === 'number')
3
+ return `${value}px`;
4
+ if (typeof value === 'string') {
5
+ const cleaned = value.trim();
6
+ const isOnlyNumericLike = /^[\d.,]+$/.test(cleaned);
7
+ if (isOnlyNumericLike)
8
+ return `${value}px`;
9
+ }
10
+ return value;
11
+ };
@@ -1,3 +1,4 @@
1
+ import { disabledScroll } from '../internal/scroll.js';
1
2
  import { writable } from 'svelte/store';
2
3
  // states
3
4
  const colorScheme_default = 'light';
@@ -29,14 +30,17 @@ export function setOpenModal(state) {
29
30
  }
30
31
  export const pushModal = (id) => {
31
32
  modalStack.update((stack) => {
33
+ let values = stack;
32
34
  if (!stack.includes(id))
33
- return [...stack, id];
34
- return stack;
35
+ values = [...stack, id];
36
+ disabledScroll(values.length !== 0 ? true : false);
37
+ return values;
35
38
  });
36
39
  };
37
40
  export const popModal = (id) => {
38
41
  modalStack.update((stack) => {
39
42
  const newStack = stack.filter((m) => m !== id);
43
+ disabledScroll(newStack.length !== 0 ? true : false);
40
44
  return newStack.length === 0 ? [] : newStack;
41
45
  });
42
46
  };
@@ -1,3 +1,4 @@
1
+ import { setUnit } from '../../internal/unit.js';
1
2
  export const devices = (config) => {
2
3
  let css = ``;
3
4
  const list = {
@@ -5,24 +6,35 @@ export const devices = (config) => {
5
6
  tablet: config.breakpoints.tabletBreakpoint,
6
7
  laptop: config.breakpoints.laptopBreakpoint
7
8
  };
8
- for (const [key, value] of Object.entries(list)) {
9
- const breakpointValue = config.breakpoints.thresholds[value];
10
- const breakpointValueMax = key !== 'laptop'
11
- ? config.breakpoints.thresholds[key === 'mobile' ? list.tablet : key == 'tablet' ? list.laptop : '']
12
- : undefined;
13
- css += `.device-${key}, .only-on-${key} {\n`;
14
- css += `display: none;\n`;
15
- css += `}\n`;
16
- css += `@media screen and (min-width: ${typeof breakpointValue === 'number' ? breakpointValue + 'px' : breakpointValue}) {\n`;
17
- css += `.device-${key} {\n`;
18
- css += `display: inherit !important;\n`;
19
- css += `}\n`;
20
- css += `}\n`;
21
- css += `@media screen and (min-width: ${typeof breakpointValue === 'number' ? breakpointValue + 'px' : breakpointValue}) ${breakpointValueMax ? `and (max-width: ${typeof breakpointValueMax === 'number' ? breakpointValueMax + 'px' : breakpointValueMax})` : ''}{\n`;
22
- css += `.only-on-${key} {\n`;
23
- css += `display: inherit !important;\n`;
24
- css += `}\n`;
25
- css += `}\n`;
26
- }
9
+ css += `@media screen and (max-width: ${setUnit(config.breakpoints.thresholds[list.tablet])}) {\n`;
10
+ css += `.hidden-mobile {\n`;
11
+ css += `display: none !important;\n`;
12
+ css += `}\n`;
13
+ css += `}\n`;
14
+ css += `@media screen and (min-width: ${setUnit(config.breakpoints.thresholds[list.tablet])}) {\n`;
15
+ css += `.display-mobile {\n`;
16
+ css += `display: none !important;\n`;
17
+ css += `}\n`;
18
+ css += `}\n`;
19
+ css += `@media screen and (min-width: ${setUnit(config.breakpoints.thresholds[list.tablet])}) and (max-width: ${setUnit(config.breakpoints.thresholds[list.laptop])}) {\n`;
20
+ css += `.hidden-tablet {\n`;
21
+ css += `display: none !important;\n`;
22
+ css += `}\n`;
23
+ css += `}\n`;
24
+ css += `@media screen and (max-width: ${setUnit(config.breakpoints.thresholds[list.tablet])}) and (min-width: ${setUnit(config.breakpoints.thresholds[list.laptop])}){\n`;
25
+ css += `.display-tablet {\n`;
26
+ css += `display: none !important;\n`;
27
+ css += `}\n`;
28
+ css += `}\n`;
29
+ css += `@media screen and (min-width: ${setUnit(config.breakpoints.thresholds[list.laptop])}) {\n`;
30
+ css += `.hidden-laptop {\n`;
31
+ css += `display: none !important;\n`;
32
+ css += `}\n`;
33
+ css += `}\n`;
34
+ css += `@media screen and (max-width: ${setUnit(config.breakpoints.thresholds[list.laptop])}) {\n`;
35
+ css += `.display-laptop {\n`;
36
+ css += `display: none !important;\n`;
37
+ css += `}\n`;
38
+ css += `}\n`;
27
39
  return css;
28
40
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lapikit",
3
- "version": "0.1.6",
3
+ "version": "0.1.8",
4
4
  "license": "MIT",
5
5
  "publishConfig": {
6
6
  "access": "public"