lapikit 0.0.0-insiders.e94247e → 0.0.0-insiders.eb9b51b

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (185) hide show
  1. package/bin/configuration.js +0 -1
  2. package/bin/helper.js +0 -38
  3. package/bin/index.js +1 -9
  4. package/bin/presets.js +1 -1
  5. package/bin/prompts.js +46 -79
  6. package/dist/actions/accordion.svelte.d.ts +9 -0
  7. package/dist/actions/index.d.ts +2 -1
  8. package/dist/actions/index.js +2 -1
  9. package/dist/actions/use-theme.d.ts +1 -0
  10. package/dist/actions/use-theme.js +18 -0
  11. package/dist/components/accordion/accordion.css +0 -77
  12. package/dist/components/accordion/accordion.svelte +5 -121
  13. package/dist/components/accordion/modules/accordion-item.css +68 -0
  14. package/dist/components/accordion/modules/accordion-item.svelte +4 -4
  15. package/dist/components/accordion/types.d.ts +1 -1
  16. package/dist/components/alert/alert.css +11 -18
  17. package/dist/components/alert/alert.svelte +4 -126
  18. package/dist/components/alert/types.d.ts +1 -1
  19. package/dist/components/app/app.css +1 -2
  20. package/dist/components/app/app.svelte +24 -46
  21. package/dist/components/app/app.svelte.d.ts +2 -0
  22. package/dist/components/appbar/appbar.css +8 -18
  23. package/dist/components/appbar/appbar.svelte +4 -49
  24. package/dist/components/appbar/types.d.ts +1 -1
  25. package/dist/components/aspect-ratio/aspect-ratio.svelte +0 -41
  26. package/dist/components/aspect-ratio/types.d.ts +1 -1
  27. package/dist/components/avatar/avatar.css +7 -14
  28. package/dist/components/avatar/avatar.svelte +4 -118
  29. package/dist/components/avatar/types.d.ts +1 -1
  30. package/dist/components/button/button.css +29 -36
  31. package/dist/components/button/button.svelte +5 -235
  32. package/dist/components/button/types.d.ts +1 -1
  33. package/dist/components/card/card.css +10 -20
  34. package/dist/components/card/card.svelte +5 -113
  35. package/dist/components/card/types.d.ts +1 -1
  36. package/dist/components/chip/chip.css +26 -33
  37. package/dist/components/chip/chip.svelte +5 -216
  38. package/dist/components/chip/types.d.ts +1 -1
  39. package/dist/components/dialog/dialog.css +13 -20
  40. package/dist/components/dialog/dialog.svelte +5 -149
  41. package/dist/components/dialog/types.d.ts +1 -1
  42. package/dist/components/dropdown/dropdown.css +3 -12
  43. package/dist/components/dropdown/dropdown.svelte +6 -31
  44. package/dist/components/dropdown/types.d.ts +1 -1
  45. package/dist/components/icon/icon.css +9 -12
  46. package/dist/components/icon/icon.svelte +2 -91
  47. package/dist/components/icon/types.d.ts +1 -1
  48. package/dist/components/list/list.css +19 -91
  49. package/dist/components/list/list.svelte +4 -203
  50. package/dist/components/list/modules/list-item.css +67 -0
  51. package/dist/components/list/modules/list-item.svelte +5 -204
  52. package/dist/components/list/types.d.ts +1 -1
  53. package/dist/components/modal/modal.css +15 -23
  54. package/dist/components/modal/modal.svelte +4 -140
  55. package/dist/components/modal/types.d.ts +1 -1
  56. package/dist/components/popover/popover.css +3 -12
  57. package/dist/components/popover/popover.svelte +6 -30
  58. package/dist/components/popover/types.d.ts +1 -1
  59. package/dist/components/separator/separator.css +4 -8
  60. package/dist/components/separator/separator.svelte +5 -53
  61. package/dist/components/separator/types.d.ts +1 -1
  62. package/dist/components/spacer/spacer.svelte +0 -5
  63. package/dist/components/spacer/types.d.ts +1 -1
  64. package/dist/components/textfield/textfield.css +16 -23
  65. package/dist/components/textfield/textfield.svelte +4 -274
  66. package/dist/components/textfield/types.d.ts +1 -1
  67. package/dist/components/toolbar/toolbar.css +14 -26
  68. package/dist/components/toolbar/toolbar.svelte +4 -139
  69. package/dist/components/toolbar/types.d.ts +1 -1
  70. package/dist/components/tooltip/tooltip.css +5 -13
  71. package/dist/components/tooltip/tooltip.svelte +5 -132
  72. package/dist/components/tooltip/types.d.ts +1 -1
  73. package/dist/index.d.ts +2 -26
  74. package/dist/index.js +2 -6
  75. package/dist/internal/config/presets.d.ts +88 -75
  76. package/dist/internal/config/presets.js +89 -41
  77. package/dist/internal/config/variables.d.ts +1 -18
  78. package/dist/internal/config/variables.js +1 -18
  79. package/dist/internal/{assets.svelte.js → core/actions/assets.svelte.js} +4 -4
  80. package/dist/internal/core/actions/dropdown.svelte.d.ts +7 -0
  81. package/dist/internal/core/actions/popover.svelte.d.ts +7 -0
  82. package/dist/internal/core/actions/tooltip.svelte.d.ts +7 -0
  83. package/dist/internal/{ripple.js → core/animations/ripple.js} +3 -3
  84. package/dist/internal/core/css.d.ts +1 -0
  85. package/dist/internal/core/css.js +16 -0
  86. package/dist/internal/core/formatter/component.js +37 -40
  87. package/dist/internal/core/formatter/device.d.ts +5 -0
  88. package/dist/internal/core/formatter/device.js +66 -0
  89. package/dist/internal/core/formatter/index.d.ts +2 -1
  90. package/dist/internal/core/formatter/index.js +9 -4
  91. package/dist/internal/core/formatter/theme.js +22 -6
  92. package/dist/internal/core/formatter/typography.js +1 -1
  93. package/dist/internal/core/standard-colors.d.ts +75 -0
  94. package/dist/internal/core/standard-colors.js +75 -0
  95. package/dist/internal/helpers/colors.d.ts +1 -0
  96. package/dist/internal/{colors.js → helpers/colors.js} +2 -2
  97. package/dist/internal/helpers/parser.js +2 -1
  98. package/dist/internal/plugins/vite.js +13 -5
  99. package/dist/internal/types/components.d.ts +14 -0
  100. package/dist/internal/types/configuration.d.ts +24 -1
  101. package/dist/internal/types/index.d.ts +1 -0
  102. package/dist/internal/types/index.js +1 -0
  103. package/dist/stores/components.js +1 -1
  104. package/dist/stores/themes.d.ts +0 -6
  105. package/dist/stores/themes.js +1 -31
  106. package/dist/styles/animation.css +33 -0
  107. package/dist/styles/keyframes.css +30 -0
  108. package/dist/{style/normalize.css → styles/reset.css} +15 -7
  109. package/package.json +7 -11
  110. package/bin/lapikit.js +0 -86
  111. package/bin/legacy.js +0 -34
  112. package/bin/modules/adapter.js +0 -52
  113. package/bin/modules/plugin.js +0 -223
  114. package/bin/modules/preset.js +0 -11
  115. package/dist/internal/colors.d.ts +0 -1
  116. package/dist/internal/index.d.ts +0 -4
  117. package/dist/internal/index.js +0 -4
  118. package/dist/internal/types.d.ts +0 -57
  119. package/dist/internal/unit.d.ts +0 -1
  120. package/dist/internal/unit.js +0 -11
  121. package/dist/labs/index.d.ts +0 -4
  122. package/dist/labs/index.js +0 -5
  123. package/dist/labs/my-component-style-global.svelte +0 -6
  124. package/dist/labs/my-component-style-global.svelte.d.ts +0 -18
  125. package/dist/labs/my-component-style-import.svelte +0 -15
  126. package/dist/labs/my-component-style-import.svelte.d.ts +0 -18
  127. package/dist/labs/my-component-style-mixed.svelte +0 -23
  128. package/dist/labs/my-component-style-mixed.svelte.d.ts +0 -18
  129. package/dist/labs/my-component.svelte +0 -16
  130. package/dist/labs/my-component.svelte.d.ts +0 -18
  131. package/dist/labs/style-mixed.css +0 -7
  132. package/dist/labs/style.css +0 -7
  133. package/dist/labs.css +0 -25
  134. package/dist/plugin/css.d.ts +0 -1
  135. package/dist/plugin/css.js +0 -73
  136. package/dist/plugin/modules/config.d.ts +0 -2
  137. package/dist/plugin/modules/config.js +0 -54
  138. package/dist/plugin/modules/importer.d.ts +0 -1
  139. package/dist/plugin/modules/importer.js +0 -15
  140. package/dist/plugin/preset-v2.d.ts +0 -108
  141. package/dist/plugin/preset-v2.js +0 -126
  142. package/dist/plugin/vitejs.d.ts +0 -10
  143. package/dist/plugin/vitejs.js +0 -55
  144. package/dist/preset.d.ts +0 -2
  145. package/dist/preset.js +0 -92
  146. package/dist/style/animation.css +0 -62
  147. package/dist/style/css.d.ts +0 -2
  148. package/dist/style/css.js +0 -34
  149. package/dist/style/parser/color.d.ts +0 -5
  150. package/dist/style/parser/color.js +0 -88
  151. package/dist/style/parser/component.d.ts +0 -2
  152. package/dist/style/parser/component.js +0 -115
  153. package/dist/style/parser/device.d.ts +0 -2
  154. package/dist/style/parser/device.js +0 -40
  155. package/dist/style/parser/index.d.ts +0 -4
  156. package/dist/style/parser/index.js +0 -4
  157. package/dist/style/parser/variable.d.ts +0 -2
  158. package/dist/style/parser/variable.js +0 -25
  159. package/dist/style/variable.css +0 -12
  160. /package/dist/{components/accordion → actions}/accordion.svelte.js +0 -0
  161. /package/dist/internal/{assets.svelte.d.ts → core/actions/assets.svelte.d.ts} +0 -0
  162. /package/dist/{components/dropdown → internal/core/actions}/dropdown.svelte.js +0 -0
  163. /package/dist/{components/popover → internal/core/actions}/popover.svelte.js +0 -0
  164. /package/dist/{components/tooltip → internal/core/actions}/tooltip.svelte.js +0 -0
  165. /package/dist/internal/{ripple.d.ts → core/animations/ripple.d.ts} +0 -0
  166. /package/dist/internal/{ansi.d.ts → core/bin/ansi.d.ts} +0 -0
  167. /package/dist/internal/{ansi.js → core/bin/ansi.js} +0 -0
  168. /package/dist/internal/{terminal.d.ts → core/bin/terminal.d.ts} +0 -0
  169. /package/dist/internal/{terminal.js → core/bin/terminal.js} +0 -0
  170. /package/dist/internal/core/formatter/{styles.d.ts → style.d.ts} +0 -0
  171. /package/dist/internal/core/formatter/{styles.js → style.js} +0 -0
  172. /package/dist/internal/{minify.d.ts → core/minify.d.ts} +0 -0
  173. /package/dist/internal/{minify.js → core/minify.js} +0 -0
  174. /package/dist/{utils/x11.d.ts → internal/core/x11-colors.d.ts} +0 -0
  175. /package/dist/{utils/x11.js → internal/core/x11-colors.js} +0 -0
  176. /package/dist/{utils → internal/helpers}/convert.d.ts +0 -0
  177. /package/dist/{utils → internal/helpers}/convert.js +0 -0
  178. /package/dist/internal/{deepMerge.d.ts → helpers/deep-merge.d.ts} +0 -0
  179. /package/dist/internal/{deepMerge.js → helpers/deep-merge.js} +0 -0
  180. /package/dist/internal/{clickOutside.d.ts → helpers/outside.d.ts} +0 -0
  181. /package/dist/internal/{clickOutside.js → helpers/outside.js} +0 -0
  182. /package/dist/internal/{scroll.d.ts → helpers/scroll.d.ts} +0 -0
  183. /package/dist/internal/{scroll.js → helpers/scroll.js} +0 -0
  184. /package/dist/internal/{types.js → types/components.js} +0 -0
  185. /package/dist/{colors.css → themes.css} +0 -0
@@ -0,0 +1,7 @@
1
+ import type { PositionElement } from '../../../components/dropdown/types.js';
2
+ type Location = 'top' | 'bottom' | 'left' | 'right';
3
+ export declare function getPositions(): {
4
+ readonly values: PositionElement;
5
+ update(activator: HTMLElement | PointerEvent, element: HTMLElement, location?: Location, centered?: boolean, avoidCollisions?: boolean): void;
6
+ };
7
+ export {};
@@ -0,0 +1,7 @@
1
+ import type { PositionElement } from '../../../components/popover/types.js';
2
+ type Location = 'top' | 'bottom' | 'left' | 'right';
3
+ export declare function getPositions(): {
4
+ readonly values: PositionElement;
5
+ update(activator: HTMLElement, element: HTMLElement, location?: Location, centered?: boolean, avoidCollisions?: boolean): void;
6
+ };
7
+ export {};
@@ -0,0 +1,7 @@
1
+ import type { PositionElement } from '../../../components/tooltip/types.js';
2
+ type Location = 'top' | 'bottom' | 'left' | 'right';
3
+ export declare function getPositionsTooltip(): {
4
+ readonly values: PositionElement;
5
+ update(activator: HTMLElement, element: HTMLElement, location?: Location, centered?: boolean, avoidCollisions?: boolean): void;
6
+ };
7
+ export {};
@@ -27,13 +27,13 @@ export function ripple(el, options = {}) {
27
27
  options.duration = undefined;
28
28
  }
29
29
  if (options.component) {
30
- rippleContainer.style.setProperty('--ripple-radius', `var(--${options.component}-radius)`);
30
+ rippleContainer.style.setProperty('--system-ripple-radius', `var(--${options.component}-radius)`);
31
31
  }
32
32
  if (options.color) {
33
- rippleContainer.style.setProperty('--ripple-color', options.color);
33
+ rippleContainer.style.setProperty('--system-ripple-color', options.color);
34
34
  }
35
35
  if (options.duration) {
36
- rippleContainer.style.setProperty('--ripple-duration', `${options.duration}ms`);
36
+ rippleContainer.style.setProperty('--system-animation-ripple-duration', `${options.duration}ms`);
37
37
  }
38
38
  }
39
39
  function createRipple(e, center) {
@@ -0,0 +1 @@
1
+ export declare const processImportStyles: () => Promise<string>;
@@ -0,0 +1,16 @@
1
+ import { fileURLToPath } from 'url';
2
+ import { dirname } from 'path';
3
+ import fs from 'fs';
4
+ import path from 'path';
5
+ const __filename = fileURLToPath(import.meta.url);
6
+ const __dirname = dirname(__filename);
7
+ export const processImportStyles = async () => {
8
+ const _reset = fs.readFileSync(path.resolve(__dirname, './../../styles/reset.css'), 'utf-8');
9
+ const _animation = fs.readFileSync(path.resolve(__dirname, './../../styles/animation.css'), 'utf-8');
10
+ const _keyframes = fs.readFileSync(path.resolve(__dirname, './../../styles/keyframes.css'), 'utf-8');
11
+ let styles = ``;
12
+ styles += `${_reset}\n`;
13
+ styles += `${_animation}\n`;
14
+ styles += `${_keyframes}\n`;
15
+ return styles;
16
+ };
@@ -12,49 +12,46 @@ export async function componentFormatter({ breakpoints }) {
12
12
  const absolutePath = path.join(directory, File);
13
13
  if (fs.statSync(absolutePath).isDirectory())
14
14
  return loadSvelteFiles(absolutePath);
15
- else if (absolutePath.endsWith('.svelte') && !absolutePath.includes('/_')) {
16
- console.log(absolutePath);
17
- const fileContent = fs.readFileSync(absolutePath, 'utf8');
18
- const styleRegex = /<style[^>]*>([\s\S]*?)<\/style>/gi;
19
- const styleMatch = styleRegex.exec(fileContent);
20
- if (styleMatch) {
21
- const originalStyleContent = styleMatch[1];
22
- const content = parserCSSBreakpoints(originalStyleContent);
23
- let css = '';
24
- for (const property in breakpoints) {
25
- if (property !== 'base') {
26
- const name = `.${/^\d/.test(property) ? `\\3${property}` : property}\\:`;
27
- const value = typeof breakpoints[property] === 'number'
28
- ? `${breakpoints[property]}px`
29
- : breakpoints[property];
30
- if (content.base !== '' || content.minmax !== '' || content.min !== '') {
31
- css += `@media screen and (min-width: ${value}) {\n`;
32
- if (content.base !== '')
33
- css += content.base.replaceAll('[breakpoint]', name);
34
- if (content.minmax !== '')
35
- css += content.minmax.replaceAll('[breakpoint]', name);
36
- if (content.min !== '')
37
- css += content.min.replaceAll('[breakpoint]', name);
38
- css += `}\n`;
39
- }
40
- if (content.max !== '' || content.all !== '') {
41
- css += `@media screen and (max-width: ${value}) {\n`;
42
- if (content.max !== '')
43
- css += content.max.replaceAll('[breakpoint]', name);
44
- if (content.all !== '')
45
- css += content.all.replaceAll('[breakpoint]', name);
46
- css += `}\n`;
47
- }
15
+ else if (absolutePath.endsWith('.css') && !absolutePath.includes('/_')) {
16
+ const fileCSS = fs.readFileSync(absolutePath, 'utf8');
17
+ const content = parserCSSBreakpoints(fileCSS);
18
+ let css = `${content.cleaned}\n`;
19
+ for (const property in breakpoints) {
20
+ if (property !== 'base') {
21
+ const name = `.${/^\d/.test(property) ? `\\3${property}` : property}\\:`;
22
+ const value = typeof breakpoints[property] === 'number'
23
+ ? `${breakpoints[property]}px`
24
+ : breakpoints[property];
25
+ if (content.base !== '' || content.minmax !== '' || content.min !== '') {
26
+ css += `\n@media screen and (min-width: ${value}) {\n`;
27
+ if (content.base !== '')
28
+ css += content.base.replaceAll('[breakpoint]', name);
29
+ if (content.minmax !== '')
30
+ css += content.minmax.replaceAll('[breakpoint]', name);
31
+ if (content.min !== '')
32
+ css += content.min.replaceAll('[breakpoint]', name);
33
+ css += `\n}\n`;
48
34
  }
49
- else {
50
- css += content.all.replaceAll('[breakpoint]', '.');
35
+ if (content.max !== '' || content.minmax !== '') {
36
+ css += `\n@media screen and (max-width: ${value}) {\n`;
37
+ if (content.max !== '')
38
+ css += content.max.replaceAll('[breakpoint]', `max\\:${name}`);
39
+ if (content.minmax !== '')
40
+ css += content.all.replaceAll('[breakpoint]', `max\\:${name}`);
41
+ css += `\n}\n`;
51
42
  }
52
43
  }
53
- let formattedCSS = css;
54
- formattedCSS = formattedCSS.trim().replace(/\n{3,}/g, '\n\n');
55
- console.log(formattedCSS);
56
- const updatedFileContent = fileContent.replace(styleRegex, `<style>${formattedCSS}</style>`);
57
- fs.writeFileSync(absolutePath, updatedFileContent, 'utf8');
44
+ else {
45
+ css += `${content.base.replaceAll('[breakpoint]', '.')}\n`;
46
+ }
47
+ }
48
+ const baseName = path.basename(absolutePath, '.css');
49
+ const svelteFilePath = path.join(path.dirname(absolutePath), `${baseName}.svelte`);
50
+ if (fs.existsSync(svelteFilePath)) {
51
+ let svelteContent = fs.readFileSync(svelteFilePath, 'utf8');
52
+ svelteContent = svelteContent.replace(/<style[^>]*>[\s\S]*?<\/style>/gi, '');
53
+ svelteContent += `<style>\n${css}</style>`;
54
+ fs.writeFileSync(svelteFilePath, svelteContent, 'utf8');
58
55
  }
59
56
  }
60
57
  });
@@ -0,0 +1,5 @@
1
+ export declare function devicesFormatter({ devices }: {
2
+ devices: {
3
+ [key: string]: number | string;
4
+ };
5
+ }): Promise<string>;
@@ -0,0 +1,66 @@
1
+ import { parserValues } from '../../helpers/parser.js';
2
+ export async function devicesFormatter({ devices }) {
3
+ let css = ``;
4
+ const sortedDevices = Object.entries(devices).sort(([, a], [, b]) => {
5
+ const valueA = typeof a === 'string' ? parseInt(a) : a;
6
+ const valueB = typeof b === 'string' ? parseInt(b) : b;
7
+ return valueB - valueA;
8
+ });
9
+ sortedDevices.forEach(([deviceName, breakpoint], index) => {
10
+ const value = parserValues(breakpoint);
11
+ if (index === 0) {
12
+ // the largest device
13
+ css += `@media (max-width: ${value}) {\n`;
14
+ css += ` .kit-device--d-${deviceName} {\n`;
15
+ css += ` display: none !important;\n`;
16
+ css += ` }\n`;
17
+ css += `}\n\n`;
18
+ css += `@media (min-width: ${value}) {\n`;
19
+ css += ` .kit-device--h-${deviceName} {\n`;
20
+ css += ` display: none !important;\n`;
21
+ css += ` }\n`;
22
+ css += `}\n\n`;
23
+ }
24
+ else if (index === sortedDevices.length - 1) {
25
+ const prevDevice = sortedDevices[index - 1];
26
+ const prevValue = parserValues(prevDevice[1]);
27
+ // the smallest device
28
+ css += `@media (min-width: ${prevValue}) {\n`;
29
+ css += ` .kit-device--d-${deviceName} {\n`;
30
+ css += ` display: none !important;\n`;
31
+ css += ` }\n`;
32
+ css += `}\n\n`;
33
+ css += `@media (max-width: ${prevValue}) {\n`;
34
+ css += ` .kit-device--h-${deviceName} {\n`;
35
+ css += ` display: none !important;\n`;
36
+ css += ` }\n`;
37
+ css += `}\n\n`;
38
+ css += `@media (min-width: ${value}) {\n`;
39
+ css += ` .kit-device--od-${deviceName} {\n`;
40
+ css += ` display: none !important;\n`;
41
+ css += ` }\n`;
42
+ css += `}\n\n`;
43
+ css += `@media (max-width: ${value}) {\n`;
44
+ css += ` .kit-device--oh-${deviceName} {\n`;
45
+ css += ` display: none !important;\n`;
46
+ css += ` }\n`;
47
+ css += `}\n\n`;
48
+ }
49
+ else {
50
+ //intermediate devices
51
+ const nextDevice = sortedDevices[index - 1];
52
+ const nextValue = parserValues(nextDevice[1]);
53
+ css += `@media (max-width: ${value}) {\n`;
54
+ css += ` .kit-device--d-${deviceName} {\n`;
55
+ css += ` display: none !important;\n`;
56
+ css += ` }\n`;
57
+ css += `}\n\n`;
58
+ css += `@media (min-width: ${nextValue}) {\n`;
59
+ css += ` .kit-device--h-${deviceName} {\n`;
60
+ css += ` display: none !important;\n`;
61
+ css += ` }\n`;
62
+ css += `}\n\n`;
63
+ }
64
+ });
65
+ return css.trim();
66
+ }
@@ -1,6 +1,7 @@
1
1
  import type { DevConfiguration } from '../../types/index.js';
2
- export declare function css(config: DevConfiguration): Promise<{
2
+ export declare function liliRabbit(config: DevConfiguration): Promise<{
3
3
  themes: string;
4
4
  typography: string;
5
5
  styles: string;
6
+ devices: string;
6
7
  }>;
@@ -1,10 +1,11 @@
1
1
  import { preset } from '../../config/presets.js';
2
- import { deepMerge } from '../../deepMerge.js';
2
+ import { deepMerge } from '../../helpers/deep-merge.js';
3
3
  import { componentFormatter } from './component.js';
4
- import { stylesFormatter } from './styles.js';
4
+ import { devicesFormatter } from './device.js';
5
+ import { stylesFormatter } from './style.js';
5
6
  import { themesFormatter } from './theme.js';
6
7
  import { typographyFormatter } from './typography.js';
7
- export async function css(config) {
8
+ export async function liliRabbit(config) {
8
9
  // states
9
10
  const defaultTheme = config?.theme?.defaultTheme || preset.theme.defaultTheme;
10
11
  const defaultTypography = config?.typography?.defaultTypography || preset.typography.defaultTypography;
@@ -18,6 +19,9 @@ export async function css(config) {
18
19
  defaultTypography
19
20
  });
20
21
  const styles = await stylesFormatter({ styles: deepMerge(preset.styles, config?.styles || {}) });
22
+ const devices = await devicesFormatter({
23
+ devices: deepMerge(preset.breakpoints.devices, config?.breakpoints?.devices || {})
24
+ });
21
25
  // components
22
26
  await componentFormatter({
23
27
  breakpoints: deepMerge(preset.breakpoints.thresholds, config?.breakpoints?.thresholds || {})
@@ -25,6 +29,7 @@ export async function css(config) {
25
29
  return {
26
30
  themes: themes,
27
31
  typography: typography,
28
- styles: styles
32
+ styles: styles,
33
+ devices: devices
29
34
  };
30
35
  }
@@ -1,25 +1,41 @@
1
1
  import { preset } from '../../config/presets.js';
2
- import { deepMerge } from '../../deepMerge.js';
2
+ import { formatColor } from '../../helpers/colors.js';
3
+ import { deepMerge } from '../../helpers/deep-merge.js';
3
4
  import { parserValues } from '../../helpers/parser.js';
4
5
  export async function themesFormatter({ themes, defaultTheme = 'light' }) {
5
6
  let css = '';
6
7
  for (const [name, values] of Object.entries(themes)) {
7
8
  const ref = values?.dark ? preset.theme.themes.dark : preset.theme.themes.light;
8
- let cssTheme = defaultTheme === name ? `:root,\n.l-theme-${name} {\n` : `.l-theme-${name} {\n`;
9
+ let cssTheme = defaultTheme === name ? `:root,\n.kit-theme--${name} {\n` : `.kit-theme--${name} {\n`;
10
+ function flattenColors(obj, prefix = '') {
11
+ const result = {};
12
+ for (const [key, value] of Object.entries(obj)) {
13
+ const newPrefix = prefix ? `${prefix}-${key}` : key;
14
+ if (typeof value === 'object' && value !== null && !Array.isArray(value)) {
15
+ Object.assign(result, flattenColors(value, newPrefix));
16
+ }
17
+ else {
18
+ result[newPrefix] = value;
19
+ }
20
+ }
21
+ return result;
22
+ }
9
23
  // colors
10
24
  cssTheme += ` color-scheme: ${values?.dark ? 'dark' : 'light'};\n`;
11
- for (const [varName, varValue] of Object.entries(deepMerge(ref.colors, values?.colors) || {})) {
12
- cssTheme += ` --system-${varName}: ${varValue};\n`;
25
+ const mergedColors = deepMerge(ref.colors, values?.colors) || {};
26
+ const flatColors = flattenColors(mergedColors);
27
+ for (const [varName, varValue] of Object.entries(flatColors)) {
28
+ cssTheme += ` --kit-${varName}: ${formatColor(varValue)};\n`;
13
29
  }
14
30
  // variables
15
31
  for (const [name, varValue] of Object.entries(deepMerge(ref.variables, values?.variables) || {})) {
16
32
  if (varValue && typeof varValue === 'object') {
17
33
  for (const [variableName, variableValue] of Object.entries(varValue || {})) {
18
- cssTheme += ` --l-theme-${name}-${variableName}: ${parserValues(variableValue)};\n`;
34
+ cssTheme += ` --kit-${name}-${variableName}: ${formatColor(parserValues(variableValue))};\n`;
19
35
  }
20
36
  }
21
37
  else {
22
- cssTheme += ` --l-theme-${name}: ${parserValues(varValue)};\n`;
38
+ cssTheme += ` --kit-${name}: ${formatColor(parserValues(varValue))};\n`;
23
39
  }
24
40
  }
25
41
  css += cssTheme + '}\n';
@@ -4,7 +4,7 @@ export async function typographyFormatter({ typography, defaultTypography = 'def
4
4
  for (const [name, values] of Object.entries(typography)) {
5
5
  let cssTypo = defaultTypography === name ? `:root {\n` : `.${name} {\n`;
6
6
  for (const [fontName, fontValue] of Object.entries(values || {})) {
7
- cssTypo += ` --kit-font-${fontName}: ${parserValues(fontValue)};\n`;
7
+ cssTypo += ` --kit-font-${fontName}: ${parserValues(fontValue).replaceAll('"', '')};\n`;
8
8
  }
9
9
  css += cssTypo + '}\n';
10
10
  }
@@ -0,0 +1,75 @@
1
+ export declare const standardColors: {
2
+ red: {
3
+ light: string;
4
+ dark: string;
5
+ };
6
+ orange: {
7
+ light: string;
8
+ dark: string;
9
+ };
10
+ yellow: {
11
+ light: string;
12
+ dark: string;
13
+ };
14
+ green: {
15
+ light: string;
16
+ dark: string;
17
+ };
18
+ mint: {
19
+ light: string;
20
+ dark: string;
21
+ };
22
+ teal: {
23
+ light: string;
24
+ dark: string;
25
+ };
26
+ cyan: {
27
+ light: string;
28
+ dark: string;
29
+ };
30
+ blue: {
31
+ light: string;
32
+ dark: string;
33
+ };
34
+ indigo: {
35
+ light: string;
36
+ dark: string;
37
+ };
38
+ purple: {
39
+ light: string;
40
+ dark: string;
41
+ };
42
+ pink: {
43
+ light: string;
44
+ dark: string;
45
+ };
46
+ brown: {
47
+ light: string;
48
+ dark: string;
49
+ };
50
+ gray: {
51
+ light: string;
52
+ dark: string;
53
+ };
54
+ gray2: {
55
+ light: string;
56
+ dark: string;
57
+ };
58
+ gray3: {
59
+ light: string;
60
+ dark: string;
61
+ };
62
+ gray4: {
63
+ light: string;
64
+ dark: string;
65
+ };
66
+ gray5: {
67
+ light: string;
68
+ dark: string;
69
+ };
70
+ gray6: {
71
+ light: string;
72
+ dark: string;
73
+ };
74
+ };
75
+ export default standardColors;
@@ -0,0 +1,75 @@
1
+ export const standardColors = {
2
+ red: {
3
+ light: '#FF3B30',
4
+ dark: '#FF453A'
5
+ },
6
+ orange: {
7
+ light: '#FF9500',
8
+ dark: '#FF9F0A'
9
+ },
10
+ yellow: {
11
+ light: '#FFCC00',
12
+ dark: '#FFD60A'
13
+ },
14
+ green: {
15
+ light: '#34C759',
16
+ dark: '#30D158'
17
+ },
18
+ mint: {
19
+ light: '#00C7BE',
20
+ dark: '#66D4CF'
21
+ },
22
+ teal: {
23
+ light: '#30B0C7',
24
+ dark: '#40CBE0'
25
+ },
26
+ cyan: {
27
+ light: '#32ADE6',
28
+ dark: '#64D2FF'
29
+ },
30
+ blue: {
31
+ light: '#007AFF',
32
+ dark: '#0A84FF'
33
+ },
34
+ indigo: {
35
+ light: '#5856D6',
36
+ dark: '#5E5CE6'
37
+ },
38
+ purple: {
39
+ light: '#AF52DE',
40
+ dark: '#BF5AF2'
41
+ },
42
+ pink: {
43
+ light: '#FF2D55',
44
+ dark: '#FF375F'
45
+ },
46
+ brown: {
47
+ light: '#A2845E',
48
+ dark: '#AC8E68'
49
+ },
50
+ gray: {
51
+ light: '#8E8E93',
52
+ dark: '#8E8E93'
53
+ },
54
+ gray2: {
55
+ light: '#AEAEB2',
56
+ dark: '#636366'
57
+ },
58
+ gray3: {
59
+ light: '#C7C7CC',
60
+ dark: '#48484A'
61
+ },
62
+ gray4: {
63
+ light: '#D1D1D6',
64
+ dark: '#3A3A3C'
65
+ },
66
+ gray5: {
67
+ light: '#E5E5EA',
68
+ dark: '#2C2C2E'
69
+ },
70
+ gray6: {
71
+ light: '#F2F2F7',
72
+ dark: '#1C1C1E'
73
+ }
74
+ };
75
+ export default standardColors;
@@ -0,0 +1 @@
1
+ export declare const formatColor: (input: string) => string;
@@ -1,5 +1,5 @@
1
- import { x11Colors } from '../utils/x11.js';
2
- export const parseColor = (input) => {
1
+ import { x11Colors } from '../core/x11-colors.js';
2
+ export const formatColor = (input) => {
3
3
  input = input.trim();
4
4
  if (input.startsWith('#')) {
5
5
  const rgb = hexToRgb(input);
@@ -1,6 +1,6 @@
1
1
  import path from 'path';
2
2
  import fs from 'fs';
3
- import { terminal } from '../terminal.js';
3
+ import { terminal } from '../core/bin/terminal.js';
4
4
  export const parserValues = (value) => {
5
5
  if (typeof value === 'number')
6
6
  return `${value}px`;
@@ -9,6 +9,7 @@ export const parserValues = (value) => {
9
9
  return value;
10
10
  };
11
11
  export const parserCSSBreakpoints = (css) => {
12
+ css = css.replace(/\/\*[\s\S]*?\*\//g, ''); // clean comments
12
13
  const regex = /([^{]+)\{([^}]+)\}/g;
13
14
  let match;
14
15
  const matchesToRemove = [];
@@ -1,12 +1,13 @@
1
1
  import { fileURLToPath } from 'url';
2
2
  import { dirname } from 'path';
3
- import { terminal } from '../terminal.js';
4
- import { css } from '../core/formatter/index.js';
3
+ import { terminal } from '../core/bin/terminal.js';
4
+ import { liliRabbit } from '../core/formatter/index.js';
5
5
  import { parserConfigLapikit } from '../helpers/parser.js';
6
6
  const __filename = fileURLToPath(import.meta.url);
7
7
  const __dirname = dirname(__filename);
8
8
  import fsPromises from 'fs/promises';
9
9
  import path from 'path';
10
+ import { processImportStyles } from '../core/css.js';
10
11
  const app = process.cwd();
11
12
  export async function lapikit({ config } = {}) {
12
13
  return {
@@ -15,9 +16,16 @@ export async function lapikit({ config } = {}) {
15
16
  if (config) {
16
17
  const configuration = await parserConfigLapikit(app, config);
17
18
  // generate styles
18
- const styles = await css(configuration);
19
- fsPromises.writeFile(path.resolve(__dirname, '../../labs.css'), styles?.themes + '\n\n' + styles?.typography + '\n\n' + styles?.styles || '');
20
- console.log('styles', styles, __dirname);
19
+ const basicStyles = await processImportStyles();
20
+ fsPromises.writeFile(path.resolve(__dirname, '../../styles.css'), basicStyles || '');
21
+ const styles = await liliRabbit(configuration);
22
+ fsPromises.writeFile(path.resolve(__dirname, '../../themes.css'), styles?.devices +
23
+ '\n\n' +
24
+ styles?.typography +
25
+ '\n\n' +
26
+ styles?.styles +
27
+ '\n\n' +
28
+ styles?.themes || '');
21
29
  }
22
30
  terminal('info', 'lapikit is up!');
23
31
  }
@@ -0,0 +1,14 @@
1
+ import type { Snippet } from 'svelte';
2
+ type IdElementType = string | undefined;
3
+ type ClassNameType = string | string[] | undefined;
4
+ type StylePropertiesType = string | undefined;
5
+ export interface Base {
6
+ id?: IdElementType;
7
+ class?: ClassNameType;
8
+ style?: StylePropertiesType;
9
+ [key: string]: any;
10
+ }
11
+ export interface Component extends Base {
12
+ children?: Snippet;
13
+ }
14
+ export {};
@@ -1,3 +1,23 @@
1
+ export interface LapikitConfiguration {
2
+ breakpoints?: {
3
+ devices?: {
4
+ [key: string]: number | string;
5
+ };
6
+ thresholds?: {
7
+ [key: string]: number | string;
8
+ };
9
+ };
10
+ theme?: {
11
+ defaultTheme?: string;
12
+ colorScheme?: boolean;
13
+ themes?: FragThemes;
14
+ };
15
+ typography?: {
16
+ defaultTypography?: string;
17
+ fonts?: FragTypography;
18
+ };
19
+ styles?: FragStyles;
20
+ }
1
21
  export interface DevConfiguration {
2
22
  breakpoints?: {
3
23
  devices?: {
@@ -9,6 +29,7 @@ export interface DevConfiguration {
9
29
  };
10
30
  theme?: {
11
31
  defaultTheme?: string;
32
+ colorScheme?: boolean;
12
33
  themes?: FragThemes;
13
34
  };
14
35
  typography?: {
@@ -21,7 +42,9 @@ export interface FragThemes {
21
42
  [key: string]: {
22
43
  dark?: boolean;
23
44
  colors?: {
24
- [key: string]: string;
45
+ [key: string]: {
46
+ [key: string]: string;
47
+ } | string;
25
48
  };
26
49
  variables?: {
27
50
  [key: string]: string | number;
@@ -1 +1,2 @@
1
1
  export * from './configuration.js';
2
+ export * from './components.js';
@@ -1 +1,2 @@
1
1
  export * from './configuration.js';
2
+ export * from './components.js';
@@ -1,4 +1,4 @@
1
- import { disabledScroll } from '../internal/scroll.js';
1
+ import { disabledScroll } from '../internal/helpers/scroll.js';
2
2
  import { writable } from 'svelte/store';
3
3
  // presets
4
4
  const refModal = false;
@@ -1,8 +1,2 @@
1
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
2
  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 {};