lapikit 0.0.0-insiders.dcdfb82 → 0.0.0-insiders.df15d32

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 (175) hide show
  1. package/LICENSE +21 -0
  2. package/bin/configuration.js +304 -0
  3. package/bin/helper.js +64 -32
  4. package/bin/index.js +41 -0
  5. package/bin/lapikit.js +42 -10
  6. package/bin/legacy.js +34 -0
  7. package/bin/modules/adapter.js +5 -5
  8. package/bin/modules/plugin.js +223 -0
  9. package/bin/presets.js +26 -0
  10. package/bin/prompts.js +100 -0
  11. package/dist/actions/index.d.ts +1 -0
  12. package/dist/actions/index.js +1 -0
  13. package/dist/assets/icons/arrow-down.svelte +12 -0
  14. package/dist/assets/icons/arrow-down.svelte.d.ts +18 -0
  15. package/dist/assets/icons/arrow-up.svelte +12 -0
  16. package/dist/assets/icons/arrow-up.svelte.d.ts +18 -0
  17. package/dist/assets/icons/close-fill.svelte +12 -0
  18. package/dist/assets/icons/close-fill.svelte.d.ts +18 -0
  19. package/dist/assets/icons/loading-fill.svelte +31 -0
  20. package/dist/assets/icons/loading-fill.svelte.d.ts +18 -0
  21. package/dist/colors.css +0 -0
  22. package/dist/components/accordion/accordion.css +113 -0
  23. package/dist/components/accordion/accordion.svelte +37 -0
  24. package/dist/components/accordion/accordion.svelte.d.ts +4 -0
  25. package/dist/components/accordion/accordion.svelte.js +24 -0
  26. package/dist/components/accordion/modules/accordion-item.svelte +94 -0
  27. package/dist/components/accordion/modules/accordion-item.svelte.d.ts +4 -0
  28. package/dist/components/accordion/types.d.ts +33 -0
  29. package/dist/components/accordion/types.js +1 -0
  30. package/dist/components/alert/alert.css +137 -0
  31. package/dist/components/alert/alert.svelte +89 -0
  32. package/dist/components/alert/alert.svelte.d.ts +4 -0
  33. package/dist/components/alert/types.d.ts +28 -0
  34. package/dist/components/alert/types.js +1 -0
  35. package/dist/components/app/app.css +16 -0
  36. package/dist/components/app/app.svelte +48 -0
  37. package/dist/components/app/app.svelte.d.ts +7 -0
  38. package/dist/components/app/types.d.ts +4 -0
  39. package/dist/components/app/types.js +1 -0
  40. package/dist/components/appbar/appbar.css +48 -0
  41. package/dist/components/appbar/appbar.svelte +40 -0
  42. package/dist/components/appbar/appbar.svelte.d.ts +4 -0
  43. package/dist/components/appbar/types.d.ts +15 -0
  44. package/dist/components/appbar/types.js +1 -0
  45. package/dist/components/aspect-ratio/aspect-ratio.css +19 -0
  46. package/dist/components/aspect-ratio/aspect-ratio.svelte +47 -0
  47. package/dist/components/aspect-ratio/aspect-ratio.svelte.d.ts +4 -0
  48. package/dist/components/aspect-ratio/types.d.ts +5 -0
  49. package/dist/components/aspect-ratio/types.js +1 -0
  50. package/dist/components/avatar/avatar.css +109 -0
  51. package/dist/components/avatar/avatar.svelte +46 -0
  52. package/dist/components/avatar/avatar.svelte.d.ts +4 -0
  53. package/dist/components/avatar/types.d.ts +22 -0
  54. package/dist/components/avatar/types.js +1 -0
  55. package/dist/components/button/button.css +247 -0
  56. package/dist/components/button/button.svelte +102 -0
  57. package/dist/components/button/button.svelte.d.ts +4 -0
  58. package/dist/components/button/types.d.ts +29 -0
  59. package/dist/components/button/types.js +1 -0
  60. package/dist/components/card/card.css +115 -0
  61. package/dist/components/card/card.svelte +63 -0
  62. package/dist/components/card/card.svelte.d.ts +4 -0
  63. package/dist/components/card/types.d.ts +18 -0
  64. package/dist/components/card/types.js +1 -0
  65. package/dist/components/chip/chip.css +231 -0
  66. package/dist/components/chip/chip.svelte +131 -0
  67. package/dist/components/chip/chip.svelte.d.ts +4 -0
  68. package/dist/components/chip/types.d.ts +32 -0
  69. package/dist/components/chip/types.js +1 -0
  70. package/dist/components/dialog/dialog.css +136 -0
  71. package/dist/components/dialog/dialog.svelte +67 -0
  72. package/dist/components/dialog/dialog.svelte.d.ts +4 -0
  73. package/dist/components/dialog/types.d.ts +24 -0
  74. package/dist/components/dialog/types.js +1 -0
  75. package/dist/components/dropdown/dropdown.css +22 -0
  76. package/dist/components/dropdown/dropdown.svelte +116 -0
  77. package/dist/components/dropdown/dropdown.svelte.d.ts +4 -0
  78. package/dist/components/dropdown/dropdown.svelte.js +148 -0
  79. package/dist/components/dropdown/types.d.ts +26 -0
  80. package/dist/components/dropdown/types.js +1 -0
  81. package/dist/components/icon/icon.css +79 -0
  82. package/dist/components/icon/icon.svelte +49 -0
  83. package/dist/components/icon/icon.svelte.d.ts +4 -0
  84. package/dist/components/icon/types.d.ts +16 -0
  85. package/dist/components/icon/types.js +1 -0
  86. package/dist/components/index.d.ts +22 -0
  87. package/dist/components/index.js +23 -0
  88. package/dist/components/list/list.css +221 -0
  89. package/dist/components/list/list.svelte +44 -0
  90. package/dist/components/list/list.svelte.d.ts +4 -0
  91. package/dist/components/list/modules/list-item.svelte +76 -0
  92. package/dist/components/list/modules/list-item.svelte.d.ts +4 -0
  93. package/dist/components/list/types.d.ts +33 -0
  94. package/dist/components/list/types.js +1 -0
  95. package/dist/components/modal/modal.css +145 -0
  96. package/dist/components/modal/modal.svelte +113 -0
  97. package/dist/components/modal/modal.svelte.d.ts +4 -0
  98. package/dist/components/modal/types.d.ts +26 -0
  99. package/dist/components/modal/types.js +1 -0
  100. package/dist/components/popover/popover.css +22 -0
  101. package/dist/components/popover/popover.svelte +73 -0
  102. package/dist/components/popover/popover.svelte.d.ts +4 -0
  103. package/dist/components/popover/popover.svelte.js +134 -0
  104. package/dist/components/popover/types.d.ts +20 -0
  105. package/dist/components/popover/types.js +1 -0
  106. package/dist/components/separator/separator.css +46 -0
  107. package/dist/components/separator/separator.svelte +37 -0
  108. package/dist/components/separator/separator.svelte.d.ts +4 -0
  109. package/dist/components/separator/types.d.ts +11 -0
  110. package/dist/components/separator/types.js +1 -0
  111. package/dist/components/spacer/spacer.css +3 -0
  112. package/dist/components/spacer/spacer.svelte +7 -0
  113. package/dist/components/spacer/spacer.svelte.d.ts +4 -0
  114. package/dist/components/spacer/types.d.ts +4 -0
  115. package/dist/components/spacer/types.js +1 -0
  116. package/dist/components/textfield/textfield.css +305 -0
  117. package/dist/components/textfield/textfield.svelte +193 -0
  118. package/dist/components/textfield/textfield.svelte.d.ts +4 -0
  119. package/dist/components/textfield/types.d.ts +37 -0
  120. package/dist/components/textfield/types.js +1 -0
  121. package/dist/components/toolbar/toolbar.css +129 -0
  122. package/dist/components/toolbar/toolbar.svelte +47 -0
  123. package/dist/components/toolbar/toolbar.svelte.d.ts +4 -0
  124. package/dist/components/toolbar/types.d.ts +27 -0
  125. package/dist/components/toolbar/types.js +1 -0
  126. package/dist/components/tooltip/tooltip.css +124 -0
  127. package/dist/components/tooltip/tooltip.svelte +113 -0
  128. package/dist/components/tooltip/tooltip.svelte.d.ts +4 -0
  129. package/dist/components/tooltip/tooltip.svelte.js +131 -0
  130. package/dist/components/tooltip/types.d.ts +23 -0
  131. package/dist/components/tooltip/types.js +1 -0
  132. package/dist/index.d.ts +27 -1
  133. package/dist/index.js +27 -3
  134. package/dist/internal/assets.svelte.d.ts +8 -0
  135. package/dist/internal/assets.svelte.js +54 -0
  136. package/dist/internal/clickOutside.d.ts +9 -0
  137. package/dist/internal/clickOutside.js +34 -0
  138. package/dist/internal/deepMerge.d.ts +44 -0
  139. package/dist/internal/deepMerge.js +80 -0
  140. package/dist/internal/index.d.ts +2 -0
  141. package/dist/internal/index.js +2 -0
  142. package/dist/internal/ripple.d.ts +12 -0
  143. package/dist/internal/ripple.js +93 -0
  144. package/dist/internal/scroll.d.ts +1 -0
  145. package/dist/internal/scroll.js +6 -0
  146. package/dist/internal/types.d.ts +13 -0
  147. package/dist/internal/unit.d.ts +1 -0
  148. package/dist/internal/unit.js +11 -0
  149. package/dist/plugin/css.d.ts +1 -0
  150. package/dist/plugin/css.js +56 -0
  151. package/dist/plugin/preset-v2.d.ts +96 -0
  152. package/dist/plugin/preset-v2.js +114 -0
  153. package/dist/plugin/vitejs.d.ts +5 -1
  154. package/dist/plugin/vitejs.js +32 -3
  155. package/dist/preset.js +16 -4
  156. package/dist/stores/breakpoints.d.ts +6 -0
  157. package/dist/stores/breakpoints.js +14 -0
  158. package/dist/stores/components.d.ts +8 -0
  159. package/dist/stores/components.js +26 -0
  160. package/dist/stores/devices.d.ts +6 -0
  161. package/dist/stores/devices.js +9 -0
  162. package/dist/stores/index.d.ts +4 -0
  163. package/dist/stores/index.js +4 -0
  164. package/dist/stores/themes.d.ts +8 -0
  165. package/dist/stores/themes.js +34 -0
  166. package/dist/style/animation.css +62 -0
  167. package/dist/style/css.js +6 -3
  168. package/dist/style/normalize.css +2 -0
  169. package/dist/style/parser/color.js +15 -4
  170. package/dist/style/parser/device.js +31 -19
  171. package/dist/style/variable.css +12 -0
  172. package/dist/utils/convert.d.ts +1 -0
  173. package/dist/utils/convert.js +17 -0
  174. package/dist/utils/x11.d.ts +1 -1
  175. package/package.json +22 -4
@@ -0,0 +1,56 @@
1
+ import { deepMerge } from '../internal/deepMerge.js';
2
+ import { preset } from './preset-v2.js';
3
+ import { fileURLToPath } from 'url';
4
+ import { dirname } from 'path';
5
+ import fsPromises from 'fs/promises';
6
+ import path from 'path';
7
+ const __filename = fileURLToPath(import.meta.url);
8
+ const __dirname = dirname(__filename);
9
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
10
+ export function css(configuration) {
11
+ // states
12
+ const defaultTheme = configuration?.theme?.defaultTheme || preset.theme.defaultTheme;
13
+ const themesMerged = deepMerge(configuration?.theme?.themes || {}, preset.theme.themes);
14
+ let response = '';
15
+ for (const [name, values] of Object.entries(themesMerged)) {
16
+ let css = defaultTheme === name ? `:root,\n.${name} {\n` : `.${name} {\n`;
17
+ // ref
18
+ const ref = values?.dark ? preset.theme.themes.dark : preset.theme.themes.light;
19
+ // colors
20
+ css += ` color-scheme: ${values?.dark ? 'dark' : 'light'};\n`;
21
+ for (const [varName, varValue] of Object.entries(deepMerge(values?.colors, ref.colors) || {})) {
22
+ css += ` --system-${varName}: ${varValue};\n`;
23
+ }
24
+ console.log('VALUE', values, deepMerge(values?.variables, ref.variables));
25
+ // variables
26
+ for (const [name, varValue] of Object.entries(deepMerge(values?.variables, ref.variables) || {})) {
27
+ css += ` --kit-${name}: ${varValue};\n`;
28
+ }
29
+ css += '}\n';
30
+ console.log(`Themes colors (${name}):`, css);
31
+ response += css;
32
+ }
33
+ console.log('All themes CSS:', response);
34
+ // typography
35
+ // states
36
+ const defaultTypography = configuration?.typography?.defaultTypography || preset.typography.defaultTypography;
37
+ const fontsMerged = deepMerge(configuration?.typography?.fonts || {}, preset.typography.fonts);
38
+ for (const [name, values] of Object.entries(fontsMerged)) {
39
+ let css = '';
40
+ css += defaultTypography === name ? `:root,\n.${name} {\n` : `.${name} {\n`;
41
+ // fonts
42
+ for (const [fontName, fontValue] of Object.entries(values?.font || {})) {
43
+ css += ` --kit-font-${fontName}: ${parser(fontValue)};\n`;
44
+ }
45
+ css += '}\n';
46
+ response += css;
47
+ }
48
+ fsPromises.writeFile(path.resolve(__dirname, '../colors.css'), response);
49
+ }
50
+ const parser = (value) => {
51
+ if (typeof value === 'number')
52
+ return `${value}px`;
53
+ if (Array.isArray(value))
54
+ return value.join(', ');
55
+ return value;
56
+ };
@@ -0,0 +1,96 @@
1
+ export declare const preset: {
2
+ breakpoints: {
3
+ devices: {
4
+ desktop: number;
5
+ tablet: number;
6
+ mobile: number;
7
+ };
8
+ thresholds: {
9
+ base: number;
10
+ xs: number;
11
+ sm: number;
12
+ md: number;
13
+ lg: number;
14
+ xl: number;
15
+ '2xl': number;
16
+ '3xl': number;
17
+ };
18
+ };
19
+ theme: {
20
+ defaultTheme: string;
21
+ themes: {
22
+ light: {
23
+ dark: boolean;
24
+ colors: {
25
+ blue: string;
26
+ green: string;
27
+ red: string;
28
+ yellow: string;
29
+ orange: string;
30
+ purple: string;
31
+ pink: string;
32
+ indigo: string;
33
+ cyan: string;
34
+ gray: string;
35
+ 'gray-2': string;
36
+ 'gray-3': string;
37
+ 'gray-4': string;
38
+ 'gray-5': string;
39
+ 'gray-6': string;
40
+ background: string;
41
+ 'secondary-background': string;
42
+ 'tertiary-background': string;
43
+ label: string;
44
+ 'secondary-label': string;
45
+ };
46
+ variables: {
47
+ info: string;
48
+ success: string;
49
+ error: string;
50
+ warning: string;
51
+ };
52
+ };
53
+ dark: {
54
+ dark: boolean;
55
+ colors: {
56
+ blue: string;
57
+ green: string;
58
+ red: string;
59
+ yellow: string;
60
+ orange: string;
61
+ purple: string;
62
+ pink: string;
63
+ indigo: string;
64
+ cyan: string;
65
+ gray: string;
66
+ 'gray-2': string;
67
+ 'gray-3': string;
68
+ 'gray-4': string;
69
+ 'gray-5': string;
70
+ 'gray-6': string;
71
+ background: string;
72
+ 'secondary-background': string;
73
+ 'tertiary-background': string;
74
+ label: string;
75
+ 'secondary-label': string;
76
+ };
77
+ variables: {
78
+ info: string;
79
+ success: string;
80
+ error: string;
81
+ warning: string;
82
+ };
83
+ };
84
+ };
85
+ };
86
+ typography: {
87
+ defaultTypography: string;
88
+ fonts: {
89
+ default: {
90
+ sans: string[];
91
+ mono: string[];
92
+ serif: string[];
93
+ };
94
+ };
95
+ };
96
+ };
@@ -0,0 +1,114 @@
1
+ const variables = {
2
+ info: 'var(--system-blue)',
3
+ success: 'var(--system-green)',
4
+ error: 'var(--system-red)',
5
+ warning: 'var(--system-yellow)'
6
+ };
7
+ export const preset = {
8
+ breakpoints: {
9
+ devices: {
10
+ desktop: 1024, //64rem (lg)
11
+ tablet: 768, //48rem (md)
12
+ mobile: 375 //28rem (sm)
13
+ },
14
+ thresholds: {
15
+ base: 0, // 0px
16
+ xs: 448, //28rem
17
+ sm: 640, //40rem
18
+ md: 768, //48rem
19
+ lg: 1024, //64rem
20
+ xl: 1280, //80rem
21
+ '2xl': 1536, //96rem
22
+ '3xl': 1792 //112rem
23
+ }
24
+ },
25
+ theme: {
26
+ defaultTheme: 'light',
27
+ themes: {
28
+ light: {
29
+ dark: false,
30
+ colors: {
31
+ blue: '#007AFF',
32
+ green: '#34C759',
33
+ red: '#FF3B30',
34
+ yellow: '#FFCC00',
35
+ orange: '#FF9500',
36
+ purple: '#AF52DE',
37
+ pink: '#FF2D55',
38
+ indigo: '#5856D6',
39
+ cyan: '#5AC8FA',
40
+ gray: '#8E8E93',
41
+ 'gray-2': '#AEAEB2',
42
+ 'gray-3': '#C7C7CC',
43
+ 'gray-4': '#D1D1D6',
44
+ 'gray-5': '#E5E5EA',
45
+ 'gray-6': '#F2F2F7',
46
+ background: '#FFFFFF',
47
+ 'secondary-background': '#F2F2F7',
48
+ 'tertiary-background': '#EFEFF4',
49
+ label: '#000000',
50
+ 'secondary-label': 'rgba(60,60,67,0.6)'
51
+ },
52
+ variables: variables
53
+ },
54
+ dark: {
55
+ dark: true,
56
+ colors: {
57
+ blue: '#0A84FF',
58
+ green: '#30D158',
59
+ red: '#FF453A',
60
+ yellow: '#FFD60A',
61
+ orange: '#FF9F0A',
62
+ purple: '#BF5AF2',
63
+ pink: '#FF375F',
64
+ indigo: '#5E5CE6',
65
+ cyan: '#64D2FF',
66
+ gray: '#8E8E93',
67
+ 'gray-2': '#636366',
68
+ 'gray-3': '#48484A',
69
+ 'gray-4': '#3A3A3C',
70
+ 'gray-5': '#2C2C2E',
71
+ 'gray-6': '#1C1C1E',
72
+ background: '#000000',
73
+ 'secondary-background': '#1C1C1E',
74
+ 'tertiary-background': '#2C2C2E',
75
+ label: '#FFFFFF',
76
+ 'secondary-label': 'rgba(235,235,245,0.6)'
77
+ },
78
+ variables: variables
79
+ }
80
+ }
81
+ },
82
+ typography: {
83
+ defaultTypography: 'default',
84
+ fonts: {
85
+ default: {
86
+ sans: [
87
+ 'system-ui',
88
+ '-apple-system',
89
+ 'BlinkMacSystemFont',
90
+ 'Segoe UI',
91
+ 'Roboto',
92
+ 'Helvetica Neue',
93
+ 'Arial',
94
+ 'sans-serif',
95
+ 'Apple Color Emoji',
96
+ 'Segoe UI Emoji',
97
+ 'Segoe UI Symbol'
98
+ ],
99
+ mono: [
100
+ 'SFMono-Regular',
101
+ 'ui-monospace',
102
+ 'SF Mono',
103
+ 'Menlo',
104
+ 'Monaco',
105
+ 'Consolas',
106
+ 'Liberation Mono',
107
+ 'Courier New',
108
+ 'monospace'
109
+ ],
110
+ serif: ['Merriweather', 'Georgia', 'Cambria', 'Times New Roman', 'Times', 'serif']
111
+ }
112
+ }
113
+ }
114
+ };
@@ -1,6 +1,10 @@
1
1
  import type { ViteDevServer } from 'vite';
2
- export declare function lapikit(): Promise<{
2
+ type Lapikit = {
3
+ config?: string;
4
+ };
5
+ export declare function lapikit({ config }?: Lapikit): Promise<{
3
6
  name: string;
4
7
  configResolved(): Promise<void>;
5
8
  configureServer(server: ViteDevServer): Promise<void>;
6
9
  }>;
10
+ export {};
@@ -2,12 +2,41 @@ import { importer } from './modules/importer.js';
2
2
  import { processCSS } from '../style/css.js';
3
3
  import { parseConfig } from './modules/config.js';
4
4
  import { terminal } from '../internal/terminal.js';
5
- export async function lapikit() {
5
+ import path from 'path';
6
+ import fs from 'fs';
7
+ import { css } from './css.js';
8
+ const app = process.cwd();
9
+ async function getLapikitConfig(filePath) {
10
+ const pathConfig = path.resolve(app, filePath);
11
+ if (!fs.existsSync(pathConfig))
12
+ process.exit(1);
13
+ const code = fs.readFileSync(pathConfig, 'utf-8');
14
+ const match = code.match(/createLapikit\s*\(\s*({[\s\S]*?})\s*\)/);
15
+ let options = {};
16
+ if (match && match[1]) {
17
+ try {
18
+ options = new Function('return ' + match[1])();
19
+ }
20
+ catch (e) {
21
+ console.error('Error parsing lapikit config:', e);
22
+ }
23
+ }
24
+ else {
25
+ console.error('Lapikit not found');
26
+ }
27
+ return options;
28
+ }
29
+ export async function lapikit({ config } = {}) {
30
+ if (config) {
31
+ const value = getLapikitConfig(config);
32
+ console.log(value);
33
+ css(value);
34
+ }
6
35
  return {
7
36
  name: 'lapikit/vite.js',
8
37
  async configResolved() {
9
- const config = await importer();
10
- const result = await parseConfig(config);
38
+ const importedConfig = await importer();
39
+ const result = await parseConfig(importedConfig);
11
40
  await processCSS(result);
12
41
  terminal('info', 'lapikit is up!');
13
42
  },
package/dist/preset.js CHANGED
@@ -4,28 +4,40 @@ export const config = {
4
4
  minify: false // true | false
5
5
  },
6
6
  theme: {
7
- colorScheme: 'dark', // 'light' | 'dark' | 'auto'
7
+ colorScheme: 'system', // 'light' | 'dark' | 'system'
8
8
  colors: {
9
9
  primary: { light: 'oklch(45% 0.24 277.023)', dark: 'oklch(45% 0.24 277.023)' },
10
+ 'on-primary': { light: 'oklch(14% 0.005 285.823)', dark: 'oklch(14% 0.005 285.823)' },
10
11
  secondary: { light: 'oklch(65% 0.241 354.308)', dark: 'oklch(65% 0.241 354.308)' },
12
+ 'on-secondary': { light: 'oklch(14% 0.005 285.823)', dark: 'oklch(14% 0.005 285.823)' },
11
13
  tertiary: { light: 'oklch(77% 0.152 181.912)', dark: 'oklch(77% 0.152 181.912)' },
14
+ 'on-tertiary': { light: 'oklch(14% 0.005 285.823)', dark: 'oklch(14% 0.005 285.823)' },
12
15
  neutral: { light: 'oklch(14% 0.005 285.823)', dark: 'oklch(14% 0.005 285.823)' },
16
+ 'on-neutral': { light: 'oklch(100% 0 0)', dark: 'oklch(100% 0 0)' },
13
17
  info: { light: 'oklch(74% 0.16 232.661)', dark: 'oklch(74% 0.16 232.661)' },
18
+ 'on-info': { light: 'oklch(14% 0.005 285.823)', dark: 'oklch(14% 0.005 285.823)' },
14
19
  success: { light: 'oklch(76% 0.177 163.223)', dark: 'oklch(76% 0.177 163.223)' },
20
+ 'on-success': { light: 'oklch(14% 0.005 285.823)', dark: 'oklch(14% 0.005 285.823)' },
15
21
  warning: { light: 'oklch(82% 0.189 84.429)', dark: 'oklch(82% 0.189 84.429)' },
22
+ 'on-warning': { light: 'oklch(14% 0.005 285.823)', dark: 'oklch(14% 0.005 285.823)' },
16
23
  error: { light: 'oklch(71% 0.194 13.428)', dark: 'oklch(71% 0.194 13.428)' },
24
+ 'on-error': { light: 'oklch(14% 0.005 285.823)', dark: 'oklch(14% 0.005 285.823)' },
17
25
  base: { light: 'oklch(100% 0 0)', dark: 'oklch(25.33% 0.016 252.42)' },
26
+ 'on-base': { light: 'oklch(14% 0.005 285.823)', dark: 'oklch(100% 0 0)' },
18
27
  surface: { light: 'oklch(98% 0 0)', dark: 'oklch(23.26% 0.014 253.1)' },
28
+ 'on-surface': { light: 'oklch(14% 0.005 285.823)', dark: 'oklch(100% 0 0)' },
19
29
  container: { light: 'oklch(95% 0 0)', dark: 'oklch(21.15% 0.012 254.09)' },
20
- shadow: 'black'
30
+ 'on-container': { light: 'oklch(14% 0.005 285.823)', dark: 'oklch(100% 0 0)' },
31
+ shadow: 'black',
32
+ scrim: 'oklch(0.00% 0.000 0)'
21
33
  }
22
34
  },
23
35
  breakpoints: {
24
36
  mobileBreakpoint: 'sm',
25
37
  tabletBreakpoint: 'md',
26
- laptopBreakpoint: 'xl',
38
+ laptopBreakpoint: 'lg',
27
39
  thresholds: {
28
- none: 0, // 0px
40
+ _default: 0, // 0px
29
41
  xs: '28rem', //448px
30
42
  sm: '40rem', //640px
31
43
  md: '48rem', //768px
@@ -0,0 +1,6 @@
1
+ import { type Writable } from 'svelte/store';
2
+ type Breakpoints = {
3
+ [key: string]: number;
4
+ };
5
+ export declare const breakpoints: Writable<Breakpoints>;
6
+ export {};
@@ -0,0 +1,14 @@
1
+ // store breakpoints and thresholds
2
+ import { writable } from 'svelte/store';
3
+ // presets
4
+ const ref = {
5
+ base: 0, // 0px
6
+ xs: 448, //28rem
7
+ sm: 640, //40rem
8
+ md: 768, //48rem
9
+ lg: 1024, //64rem
10
+ xl: 1280, //80rem
11
+ '2xl': 1536, //96rem
12
+ '3xl': 1792 //112rem
13
+ };
14
+ export const breakpoints = writable(ref);
@@ -0,0 +1,8 @@
1
+ import { type Writable } from 'svelte/store';
2
+ type ModalState = boolean | 'persistent';
3
+ export declare const modalOpen: Writable<ModalState>;
4
+ export declare const modalStack: Writable<string[]>;
5
+ export declare function setOpenModal(state: boolean | 'persistent'): void;
6
+ export declare const pushModal: (id: string) => void;
7
+ export declare const popModal: (id: string) => void;
8
+ export {};
@@ -0,0 +1,26 @@
1
+ import { disabledScroll } from '../internal/scroll.js';
2
+ import { writable } from 'svelte/store';
3
+ // presets
4
+ const refModal = false;
5
+ // states
6
+ export const modalOpen = writable(refModal);
7
+ export const modalStack = writable([]);
8
+ export function setOpenModal(state) {
9
+ modalOpen.set(state);
10
+ }
11
+ export const pushModal = (id) => {
12
+ modalStack.update((stack) => {
13
+ let values = stack;
14
+ if (!stack.includes(id))
15
+ values = [...stack, id];
16
+ disabledScroll(values.length !== 0 ? true : false);
17
+ return values;
18
+ });
19
+ };
20
+ export const popModal = (id) => {
21
+ modalStack.update((stack) => {
22
+ const newStack = stack.filter((m) => m !== id);
23
+ disabledScroll(newStack.length !== 0 ? true : false);
24
+ return newStack.length === 0 ? [] : newStack;
25
+ });
26
+ };
@@ -0,0 +1,6 @@
1
+ import { type Writable } from 'svelte/store';
2
+ type Devices = {
3
+ [key: string]: number;
4
+ };
5
+ export declare const devices: Writable<Devices>;
6
+ export {};
@@ -0,0 +1,9 @@
1
+ // store devices
2
+ import { writable } from 'svelte/store';
3
+ // presets
4
+ const ref = {
5
+ desktop: 1024, //64rem (lg)
6
+ tablet: 768, //48rem (md)
7
+ mobile: 375 //28rem (sm)
8
+ };
9
+ export const devices = writable(ref);
@@ -0,0 +1,4 @@
1
+ export * from './breakpoints.js';
2
+ export * from './devices.js';
3
+ export * from './themes.js';
4
+ export * from './components.js';
@@ -0,0 +1,4 @@
1
+ export * from './breakpoints.js';
2
+ export * from './devices.js';
3
+ export * from './themes.js';
4
+ export * from './components.js';
@@ -0,0 +1,8 @@
1
+ import { type Writable } from 'svelte/store';
2
+ type PreferColorScheme = 'system' | 'dark' | 'light';
3
+ export declare const colorScheme: Writable<PreferColorScheme>;
4
+ export declare const colorSchemeSystem: Writable<'dark' | 'light'>;
5
+ export declare const theme: Writable<string>;
6
+ export declare function useColorScheme(scheme: PreferColorScheme, key?: string): void;
7
+ export declare function useTheme(name: string, key?: string): void;
8
+ export {};
@@ -0,0 +1,34 @@
1
+ import { writable } from 'svelte/store';
2
+ // presets
3
+ const colorSchemeRef = 'system';
4
+ const themeRef = 'lapikit';
5
+ // states
6
+ const isBrowser = typeof window !== 'undefined';
7
+ export const colorScheme = writable(colorSchemeRef);
8
+ export const colorSchemeSystem = writable('light');
9
+ export const theme = writable(themeRef);
10
+ export function useColorScheme(scheme, key = '@lapikit/color-scheme') {
11
+ colorScheme.update(() => {
12
+ if (isBrowser) {
13
+ const ref = document.documentElement.classList;
14
+ if (scheme === 'system')
15
+ ref.remove('light', 'dark');
16
+ else {
17
+ ref.remove(scheme === 'dark' ? 'light' : 'dark');
18
+ ref.add(scheme === 'dark' ? 'dark' : 'light');
19
+ }
20
+ localStorage.setItem(key, scheme);
21
+ }
22
+ return scheme;
23
+ });
24
+ }
25
+ export function useTheme(name, key = '@lapikit/theme') {
26
+ theme.update(() => {
27
+ if (isBrowser) {
28
+ const html = document.documentElement;
29
+ html.setAttribute('data-theme', name);
30
+ localStorage.setItem(key, name);
31
+ }
32
+ return name;
33
+ });
34
+ }
@@ -0,0 +1,62 @@
1
+ @keyframes button-click {
2
+ 0% {
3
+ transform: scale(0.98);
4
+ }
5
+ 40% {
6
+ transform: scale(1.02);
7
+ }
8
+ 100% {
9
+ transform: scale(1);
10
+ }
11
+ }
12
+
13
+ @keyframes icon-rotate {
14
+ 0% {
15
+ transform: rotate(10deg);
16
+ }
17
+ 100% {
18
+ transform: rotate(380deg);
19
+ }
20
+ }
21
+
22
+ .kit-ripple {
23
+ background-color: currentColor;
24
+ opacity: 0.1;
25
+ position: absolute;
26
+ border-radius: 50%;
27
+ pointer-events: none;
28
+ -webkit-transition: 0.6s;
29
+ transition: 0.6s;
30
+ -webkit-animation: lapikit-ripple var(--ripple-duration, 0.4s) cubic-bezier(0.4, 0, 0.2, 1);
31
+ animation: lapikit-ripple var(--ripple-duration, 0.4s) cubic-bezier(0.4, 0, 0.2, 1);
32
+ border-radius: var(--ripple-radius);
33
+ }
34
+
35
+ .kit-ripple--center {
36
+ top: 50% !important;
37
+ left: 50% !important;
38
+ translate: -50% -50% !important;
39
+ }
40
+
41
+ .kit-ripple--effect {
42
+ position: absolute;
43
+ left: 0;
44
+ right: 0;
45
+ top: 0;
46
+ bottom: 0;
47
+ overflow: hidden;
48
+ background: none;
49
+ pointer-events: none;
50
+ z-index: 999;
51
+ border-radius: var(--ripple-radius);
52
+ }
53
+
54
+ @keyframes lapikit-ripple {
55
+ from {
56
+ scale: 0;
57
+ }
58
+
59
+ to {
60
+ scale: 1;
61
+ }
62
+ }
package/dist/style/css.js CHANGED
@@ -8,9 +8,10 @@ import { colors, component, devices, variables } from './parser/index.js';
8
8
  import { terminal } from '../internal/terminal.js';
9
9
  const __filename = fileURLToPath(import.meta.url);
10
10
  const __dirname = dirname(__filename);
11
- const __components = path.resolve('src/components');
12
11
  export const processCSS = async (config) => {
13
12
  const _normalize = fs.readFileSync(path.resolve(__dirname, './normalize.css'), 'utf-8');
13
+ const _animation = fs.readFileSync(path.resolve(__dirname, './animation.css'), 'utf-8');
14
+ const _variables = fs.readFileSync(path.resolve(__dirname, './variable.css'), 'utf-8');
14
15
  let styles = ``;
15
16
  if (config.options.normalize)
16
17
  styles += `${_normalize}\n`;
@@ -19,10 +20,12 @@ export const processCSS = async (config) => {
19
20
  const variablesStyles = variables(config);
20
21
  styles += `${colorScheme.root}\n`;
21
22
  styles += `${variablesStyles}\n`;
23
+ styles += `${variablesStyles}\n`;
24
+ styles += `${_variables}\n`;
22
25
  styles += `${colorScheme.className}\n`;
23
26
  styles += `${deviceDisplay}\n`;
24
- if (fs.existsSync(__components) && fs.statSync(__components).isDirectory())
25
- styles += component(config);
27
+ styles += component(config);
28
+ styles += `${_animation}\n`;
26
29
  if (config.options.minify) {
27
30
  styles = minify(styles);
28
31
  terminal('success', 'css minified');
@@ -4,6 +4,8 @@ html {
4
4
  line-height: 1.5;
5
5
  box-sizing: border-box;
6
6
  font-family: var(--kit-font-family-sans);
7
+ background-color: var(--kit-base);
8
+ color: var(--kit-on-base);
7
9
  }
8
10
 
9
11
  pre,
@@ -38,7 +38,7 @@ export const colors = (config) => {
38
38
  }
39
39
  cssVariables += `}\n`;
40
40
  cssVariables += `.${inversed} {\n`;
41
- cssVariables += `color-scheme: ${used};\n`;
41
+ cssVariables += `color-scheme: ${inversed};\n`;
42
42
  for (const [colorName, colorValue] of Object.entries(schemes[inversed])) {
43
43
  cssVariables += `--kit-${colorName}: ${colorValue};\n`;
44
44
  }
@@ -56,7 +56,7 @@ export const colors = (config) => {
56
56
  }
57
57
  cssVariables += `}\n`;
58
58
  cssVariables += `.${inversed} {\n`;
59
- cssVariables += `color-scheme: ${used};\n`;
59
+ cssVariables += `color-scheme: ${inversed};\n`;
60
60
  for (const [colorName, colorValue] of Object.entries(schemes[inversed])) {
61
61
  cssVariables += `--kit-${colorName}: ${colorValue};\n`;
62
62
  }
@@ -65,10 +65,21 @@ export const colors = (config) => {
65
65
  // class
66
66
  let classStyles = '';
67
67
  for (const [property] of Object.entries(schemes.light)) {
68
+ // classStyles += `.${property}:not([class*='--variant-']) {\n`;
69
+ // classStyles += `--background-color: var(--kit-${property});\n`;
70
+ // classStyles += `--color: var(--kit-on-${property}, var(--kit-${property}));\n`;
71
+ // classStyles += `}\n`;
72
+ // classStyles += `.${property}[class*='--variant-'] {\n`;
73
+ // classStyles += `--color: var(--kit-${property});\n`;
74
+ // classStyles += `}\n`;
68
75
  classStyles += `.${property} {\n`;
69
- classStyles += `--background-color: var(--kit-${property});\n`;
70
- classStyles += `--color: var(--kit-${property});\n`;
76
+ classStyles += `--base: var(--kit-${property});\n`;
77
+ classStyles += `--on: var(--kit-on-${property}, var(--kit-${property}));\n`;
71
78
  classStyles += `}\n`;
79
+ // classStyles += `.${property}:not([class*='kit-']) {\n`;
80
+ // classStyles += `background-color: var(--kit-${property});\n`;
81
+ // classStyles += `color: var(--kit-on-${property}, var(--kit-${property}));\n`;
82
+ // classStyles += `}\n`;
72
83
  }
73
84
  return {
74
85
  root: cssVariables,