lapikit 0.0.0-insiders.efb49b7 → 0.0.0-insiders.fb2e87e

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/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 +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 +182 -0
  17. package/dist/components/chip/chip.svelte +5 -5
  18. package/dist/components/chip/types.d.ts +1 -1
  19. package/dist/components/index.d.ts +5 -0
  20. package/dist/components/index.js +5 -0
  21. package/dist/components/list/list.css +5 -5
  22. package/dist/components/modal/modal.css +1 -1
  23. package/dist/components/spacer/spacer.css +3 -0
  24. package/dist/components/spacer/spacer.svelte +7 -0
  25. package/dist/components/spacer/spacer.svelte.d.ts +4 -0
  26. package/dist/components/spacer/types.d.ts +4 -0
  27. package/dist/components/spacer/types.js +1 -0
  28. package/dist/components/toolbar/toolbar.css +129 -0
  29. package/dist/components/toolbar/toolbar.svelte +47 -0
  30. package/dist/components/toolbar/toolbar.svelte.d.ts +4 -0
  31. package/dist/components/toolbar/types.d.ts +27 -0
  32. package/dist/components/toolbar/types.js +1 -0
  33. package/dist/internal/unit.d.ts +1 -0
  34. package/dist/internal/unit.js +11 -0
  35. package/dist/preset.js +1 -1
  36. package/dist/stores/index.d.ts +4 -3
  37. package/dist/stores/index.js +9 -4
  38. package/dist/style/parser/device.js +31 -19
  39. 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
  };
@@ -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 {};
@@ -1,3 +1,185 @@
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
+
1
183
  /* loading */
2
184
  .kit-chip.kit-chip--loading {
3
185
  pointer-events: none;
@@ -15,7 +15,7 @@
15
15
  prepend,
16
16
  ref = $bindable(),
17
17
  open = $bindable(true),
18
- is = 'span',
18
+ is = 'div',
19
19
  href,
20
20
  dark,
21
21
  light,
@@ -85,17 +85,17 @@
85
85
  {/if}
86
86
 
87
87
  {#if prepend}
88
- <div class="kit-chip-prepend">
88
+ <span class="kit-chip-prepend">
89
89
  {@render prepend?.()}
90
- </div>
90
+ </span>
91
91
  {/if}
92
92
  <span class="kit-chip-content">
93
93
  {@render children?.()}
94
94
  </span>
95
95
  {#if append}
96
- <div class="kit-chip-append">
96
+ <span class="kit-chip-append">
97
97
  {@render append?.()}
98
- </div>
98
+ </span>
99
99
  {/if}
100
100
 
101
101
  {#if closable}
@@ -10,7 +10,7 @@ export interface ChipProps extends Component {
10
10
  dark?: boolean;
11
11
  light?: boolean;
12
12
  href?: string;
13
- variant?: 'outline' | 'label';
13
+ variant?: 'outline';
14
14
  density?: 'compact' | 'comfortable' | 'default';
15
15
  active?: boolean;
16
16
  loading?: boolean;
@@ -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
+ };
package/dist/preset.js CHANGED
@@ -35,7 +35,7 @@ export const config = {
35
35
  breakpoints: {
36
36
  mobileBreakpoint: 'sm',
37
37
  tabletBreakpoint: 'md',
38
- laptopBreakpoint: 'xl',
38
+ laptopBreakpoint: 'lg',
39
39
  thresholds: {
40
40
  _default: 0, // 0px
41
41
  xs: '28rem', //448px
@@ -1,9 +1,10 @@
1
1
  import { type Writable } from 'svelte/store';
2
- export declare const colorScheme: Writable<'auto' | 'dark' | 'light'>;
2
+ export declare const colorScheme: Writable<'system' | 'dark' | 'light'>;
3
+ export declare const colorSchemeSystem: Writable<'dark' | 'light'>;
3
4
  export declare const modalOpen: Writable<boolean | 'persistent'>;
4
5
  export declare const modalStack: Writable<string[]>;
5
- export declare function updateThemeStore(update: 'auto' | 'dark' | 'light'): void;
6
- export declare function setColorScheme(scheme: 'auto' | 'dark' | 'light'): void;
6
+ export declare function updateThemeStore(update: 'system' | 'dark' | 'light'): void;
7
+ export declare function setColorScheme(scheme: 'system' | 'dark' | 'light'): void;
7
8
  export declare function setOpenModal(state: boolean | 'persistent'): void;
8
9
  export declare const pushModal: (id: string) => void;
9
10
  export declare const popModal: (id: string) => void;
@@ -1,16 +1,18 @@
1
+ import { disabledScroll } from '../internal/scroll.js';
1
2
  import { writable } from 'svelte/store';
2
3
  // states
3
- const colorScheme_default = 'light';
4
+ const colorScheme_default = 'system';
4
5
  const modalOpen_default = false;
5
6
  const isBrowser = typeof window !== 'undefined';
6
7
  export const colorScheme = writable(colorScheme_default);
8
+ export const colorSchemeSystem = writable('light');
7
9
  export const modalOpen = writable(modalOpen_default);
8
10
  export const modalStack = writable([]);
9
11
  export function updateThemeStore(update) {
10
12
  colorScheme.update(() => {
11
13
  if (isBrowser) {
12
14
  const ref = document.documentElement.classList;
13
- if (update === 'auto')
15
+ if (update === 'system')
14
16
  ref.remove('light', 'dark');
15
17
  else {
16
18
  ref.remove(update === 'dark' ? 'light' : 'dark');
@@ -29,14 +31,17 @@ export function setOpenModal(state) {
29
31
  }
30
32
  export const pushModal = (id) => {
31
33
  modalStack.update((stack) => {
34
+ let values = stack;
32
35
  if (!stack.includes(id))
33
- return [...stack, id];
34
- return stack;
36
+ values = [...stack, id];
37
+ disabledScroll(values.length !== 0 ? true : false);
38
+ return values;
35
39
  });
36
40
  };
37
41
  export const popModal = (id) => {
38
42
  modalStack.update((stack) => {
39
43
  const newStack = stack.filter((m) => m !== id);
44
+ disabledScroll(newStack.length !== 0 ? true : false);
40
45
  return newStack.length === 0 ? [] : newStack;
41
46
  });
42
47
  };
@@ -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.mobile])}) {\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.mobile])}) {\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.0.0-insiders.efb49b7",
3
+ "version": "0.0.0-insiders.fb2e87e",
4
4
  "license": "MIT",
5
5
  "publishConfig": {
6
6
  "access": "public"