lapikit 0.0.0-insiders.f206df2 → 0.0.0-insiders.f352010

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 (180) 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 -3
  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 -4
  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 +39 -26
  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 -4
  24. package/dist/components/appbar/types.d.ts +1 -1
  25. package/dist/components/aspect-ratio/aspect-ratio.svelte +0 -22
  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 -4
  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 -5
  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 -5
  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 -5
  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 -5
  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 -7
  44. package/dist/components/dropdown/types.d.ts +1 -1
  45. package/dist/components/icon/icon.css +11 -12
  46. package/dist/components/icon/icon.svelte +2 -2
  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 -4
  50. package/dist/components/list/modules/list-item.css +67 -0
  51. package/dist/components/list/modules/list-item.svelte +5 -5
  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 -5
  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 -6
  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 -5
  61. package/dist/components/separator/types.d.ts +1 -1
  62. package/dist/components/spacer/types.d.ts +1 -1
  63. package/dist/components/textfield/textfield.css +16 -23
  64. package/dist/components/textfield/textfield.svelte +4 -4
  65. package/dist/components/textfield/types.d.ts +1 -1
  66. package/dist/components/toolbar/toolbar.css +11 -34
  67. package/dist/components/toolbar/toolbar.svelte +4 -4
  68. package/dist/components/toolbar/types.d.ts +1 -1
  69. package/dist/components/tooltip/tooltip.css +5 -13
  70. package/dist/components/tooltip/tooltip.svelte +5 -5
  71. package/dist/components/tooltip/types.d.ts +1 -1
  72. package/dist/index.d.ts +2 -26
  73. package/dist/index.js +2 -6
  74. package/dist/internal/config/presets.d.ts +149 -0
  75. package/dist/internal/config/presets.js +169 -0
  76. package/dist/internal/config/variables.d.ts +3 -0
  77. package/dist/internal/config/variables.js +3 -0
  78. package/dist/internal/{assets.svelte.js → core/actions/assets.svelte.js} +4 -4
  79. package/dist/internal/core/actions/dropdown.svelte.d.ts +7 -0
  80. package/dist/internal/core/actions/popover.svelte.d.ts +7 -0
  81. package/dist/internal/core/actions/tooltip.svelte.d.ts +7 -0
  82. package/dist/internal/{ripple.js → core/animations/ripple.js} +3 -3
  83. package/dist/internal/core/css.d.ts +1 -0
  84. package/dist/internal/core/css.js +16 -0
  85. package/dist/internal/core/formatter/component.d.ts +5 -0
  86. package/dist/internal/core/formatter/component.js +60 -0
  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 +7 -0
  90. package/dist/internal/core/formatter/index.js +35 -0
  91. package/dist/internal/core/formatter/style.d.ts +4 -0
  92. package/dist/internal/core/formatter/style.js +15 -0
  93. package/dist/internal/core/formatter/theme.d.ts +5 -0
  94. package/dist/internal/core/formatter/theme.js +44 -0
  95. package/dist/internal/core/formatter/typography.d.ts +5 -0
  96. package/dist/internal/core/formatter/typography.js +12 -0
  97. package/dist/internal/core/standard-colors.d.ts +75 -0
  98. package/dist/internal/core/standard-colors.js +75 -0
  99. package/dist/internal/helpers/colors.d.ts +1 -0
  100. package/dist/internal/{colors.js → helpers/colors.js} +2 -2
  101. package/dist/internal/helpers/parser.d.ts +10 -0
  102. package/dist/internal/helpers/parser.js +93 -0
  103. package/dist/{plugin/vitejs.d.ts → internal/plugins/vite.d.ts} +1 -3
  104. package/dist/internal/plugins/vite.js +33 -0
  105. package/dist/internal/types/components.d.ts +14 -0
  106. package/dist/internal/types/configuration.d.ts +63 -0
  107. package/dist/internal/types/configuration.js +1 -0
  108. package/dist/internal/types/index.d.ts +2 -0
  109. package/dist/internal/types/index.js +2 -0
  110. package/dist/stores/components.js +1 -1
  111. package/dist/stores/index.d.ts +1 -0
  112. package/dist/stores/index.js +1 -0
  113. package/dist/stores/themes.d.ts +0 -6
  114. package/dist/stores/themes.js +1 -31
  115. package/dist/stores/viewport.d.ts +7 -0
  116. package/dist/stores/viewport.js +7 -0
  117. package/dist/styles/animation.css +33 -0
  118. package/dist/styles/keyframes.css +30 -0
  119. package/dist/{style/normalize.css → styles/reset.css} +15 -7
  120. package/package.json +7 -4
  121. package/bin/lapikit.js +0 -86
  122. package/bin/legacy.js +0 -34
  123. package/bin/modules/adapter.js +0 -52
  124. package/bin/modules/plugin.js +0 -223
  125. package/bin/modules/preset.js +0 -11
  126. package/dist/internal/colors.d.ts +0 -1
  127. package/dist/internal/index.d.ts +0 -4
  128. package/dist/internal/index.js +0 -4
  129. package/dist/internal/types.d.ts +0 -57
  130. package/dist/internal/unit.d.ts +0 -1
  131. package/dist/internal/unit.js +0 -11
  132. package/dist/plugin/css.d.ts +0 -1
  133. package/dist/plugin/css.js +0 -79
  134. package/dist/plugin/modules/config.d.ts +0 -2
  135. package/dist/plugin/modules/config.js +0 -54
  136. package/dist/plugin/modules/importer.d.ts +0 -1
  137. package/dist/plugin/modules/importer.js +0 -15
  138. package/dist/plugin/preset-v2.d.ts +0 -108
  139. package/dist/plugin/preset-v2.js +0 -126
  140. package/dist/plugin/vitejs.js +0 -55
  141. package/dist/preset.d.ts +0 -2
  142. package/dist/preset.js +0 -92
  143. package/dist/style/animation.css +0 -62
  144. package/dist/style/css.d.ts +0 -2
  145. package/dist/style/css.js +0 -34
  146. package/dist/style/parser/color.d.ts +0 -5
  147. package/dist/style/parser/color.js +0 -88
  148. package/dist/style/parser/component.d.ts +0 -2
  149. package/dist/style/parser/component.js +0 -115
  150. package/dist/style/parser/device.d.ts +0 -2
  151. package/dist/style/parser/device.js +0 -40
  152. package/dist/style/parser/index.d.ts +0 -4
  153. package/dist/style/parser/index.js +0 -4
  154. package/dist/style/parser/variable.d.ts +0 -2
  155. package/dist/style/parser/variable.js +0 -25
  156. package/dist/style/variable.css +0 -12
  157. /package/dist/{components/accordion → actions}/accordion.svelte.js +0 -0
  158. /package/dist/internal/{assets.svelte.d.ts → core/actions/assets.svelte.d.ts} +0 -0
  159. /package/dist/{components/dropdown → internal/core/actions}/dropdown.svelte.js +0 -0
  160. /package/dist/{components/popover → internal/core/actions}/popover.svelte.js +0 -0
  161. /package/dist/{components/tooltip → internal/core/actions}/tooltip.svelte.js +0 -0
  162. /package/dist/internal/{ripple.d.ts → core/animations/ripple.d.ts} +0 -0
  163. /package/dist/internal/{ansi.d.ts → core/bin/ansi.d.ts} +0 -0
  164. /package/dist/internal/{ansi.js → core/bin/ansi.js} +0 -0
  165. /package/dist/internal/{terminal.d.ts → core/bin/terminal.d.ts} +0 -0
  166. /package/dist/internal/{terminal.js → core/bin/terminal.js} +0 -0
  167. /package/dist/internal/{minify.d.ts → core/minify.d.ts} +0 -0
  168. /package/dist/internal/{minify.js → core/minify.js} +0 -0
  169. /package/dist/{utils/x11.d.ts → internal/core/x11-colors.d.ts} +0 -0
  170. /package/dist/{utils/x11.js → internal/core/x11-colors.js} +0 -0
  171. /package/dist/{utils → internal/helpers}/convert.d.ts +0 -0
  172. /package/dist/{utils → internal/helpers}/convert.js +0 -0
  173. /package/dist/internal/{deepMerge.d.ts → helpers/deep-merge.d.ts} +0 -0
  174. /package/dist/internal/{deepMerge.js → helpers/deep-merge.js} +0 -0
  175. /package/dist/internal/{clickOutside.d.ts → helpers/outside.d.ts} +0 -0
  176. /package/dist/internal/{clickOutside.js → helpers/outside.js} +0 -0
  177. /package/dist/internal/{scroll.d.ts → helpers/scroll.d.ts} +0 -0
  178. /package/dist/internal/{scroll.js → helpers/scroll.js} +0 -0
  179. /package/dist/internal/{types.js → types/components.js} +0 -0
  180. /package/dist/{colors.css → themes.css} +0 -0
@@ -1,126 +0,0 @@
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
- styles: {
115
- spacing: '0.125rem', // 2px
116
- shape: {
117
- sm: '0.125rem', // 2px
118
- md: '0.25rem', // 4px
119
- lg: '0.5rem', // 8px
120
- xl: '0.75rem', // 12px
121
- '2xl': '1rem', // 16px
122
- '3xl': '1.5rem', // 24px
123
- full: '9999px' // 9999px
124
- }
125
- }
126
- };
@@ -1,55 +0,0 @@
1
- import { importer } from './modules/importer.js';
2
- import { processCSS } from '../style/css.js';
3
- import { parseConfig } from './modules/config.js';
4
- import { terminal } from '../internal/terminal.js';
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 = await getLapikitConfig(config);
32
- // console.log(value);
33
- await css(value);
34
- }
35
- return {
36
- name: 'lapikit/vite.js',
37
- async configResolved() {
38
- const importedConfig = await importer();
39
- const result = await parseConfig(importedConfig);
40
- await processCSS(result);
41
- terminal('info', 'lapikit is up!');
42
- },
43
- async configureServer(server) {
44
- server.watcher.add('./lapikit.config.js');
45
- server.watcher.on('change', async (filePath) => {
46
- if (String(filePath).includes('lapikit.config.js')) {
47
- const config = await importer();
48
- const result = await parseConfig(config);
49
- await processCSS(result);
50
- terminal('info', 'lapikit config reloaded');
51
- }
52
- });
53
- }
54
- };
55
- }
package/dist/preset.d.ts DELETED
@@ -1,2 +0,0 @@
1
- import type { Lapikit } from './internal/types.js';
2
- export declare const config: Lapikit;
package/dist/preset.js DELETED
@@ -1,92 +0,0 @@
1
- export const config = {
2
- options: {
3
- normalize: true, // true | false
4
- minify: false // true | false
5
- },
6
- theme: {
7
- colorScheme: 'system', // 'light' | 'dark' | 'system'
8
- colors: {
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)' },
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)' },
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)' },
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)' },
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)' },
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)' },
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)' },
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)' },
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)' },
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)' },
29
- container: { light: 'oklch(95% 0 0)', dark: 'oklch(21.15% 0.012 254.09)' },
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)'
33
- }
34
- },
35
- breakpoints: {
36
- mobileBreakpoint: 'sm',
37
- tabletBreakpoint: 'md',
38
- laptopBreakpoint: 'lg',
39
- thresholds: {
40
- _default: 0, // 0px
41
- xs: '28rem', //448px
42
- sm: '40rem', //640px
43
- md: '48rem', //768px
44
- lg: '64rem', //1024px
45
- xl: '80rem', //1280px
46
- '2xl': '96rem', //1536px
47
- '3xl': '112rem' //1792px
48
- }
49
- },
50
- styles: {
51
- spacing: '0.125rem', // 2px
52
- corner: {
53
- active: true, // true | false
54
- radius: {
55
- sm: '0.125rem', // 2px
56
- md: '0.25rem', // 4px
57
- lg: '0.5rem', // 8px
58
- xl: '0.75rem', // 12px
59
- '2xl': '1rem', // 16px
60
- '3xl': '1.5rem', // 24px
61
- full: '9999px' // 9999px
62
- }
63
- },
64
- font: {
65
- sans: [
66
- 'system-ui',
67
- '-apple-system',
68
- 'BlinkMacSystemFont',
69
- 'Segoe UI',
70
- 'Roboto',
71
- 'Helvetica Neue',
72
- 'Arial',
73
- 'sans-serif',
74
- 'Apple Color Emoji',
75
- 'Segoe UI Emoji',
76
- 'Segoe UI Symbol'
77
- ],
78
- mono: [
79
- 'SFMono-Regular',
80
- 'ui-monospace',
81
- 'SF Mono',
82
- 'Menlo',
83
- 'Monaco',
84
- 'Consolas',
85
- 'Liberation Mono',
86
- 'Courier New',
87
- 'monospace'
88
- ],
89
- serif: ['Merriweather', 'Georgia', 'Cambria', 'Times New Roman', 'Times', 'serif']
90
- }
91
- }
92
- };
@@ -1,62 +0,0 @@
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
- }
@@ -1,2 +0,0 @@
1
- import type { Lapikit } from '../internal/types.js';
2
- export declare const processCSS: (config: Lapikit) => Promise<void>;
package/dist/style/css.js DELETED
@@ -1,34 +0,0 @@
1
- import { fileURLToPath } from 'url';
2
- import { dirname } from 'path';
3
- import fs from 'fs';
4
- import fsPromises from 'fs/promises';
5
- import path from 'path';
6
- import { minify } from '../internal/minify.js';
7
- import { colors, component, devices, variables } from './parser/index.js';
8
- import { terminal } from '../internal/terminal.js';
9
- const __filename = fileURLToPath(import.meta.url);
10
- const __dirname = dirname(__filename);
11
- export const processCSS = async (config) => {
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');
15
- let styles = ``;
16
- if (config.options.normalize)
17
- styles += `${_normalize}\n`;
18
- const colorScheme = colors(config);
19
- const deviceDisplay = devices(config);
20
- const variablesStyles = variables(config);
21
- styles += `${colorScheme.root}\n`;
22
- styles += `${variablesStyles}\n`;
23
- styles += `${variablesStyles}\n`;
24
- styles += `${_variables}\n`;
25
- styles += `${colorScheme.className}\n`;
26
- styles += `${deviceDisplay}\n`;
27
- styles += component(config);
28
- styles += `${_animation}\n`;
29
- if (config.options.minify) {
30
- styles = minify(styles);
31
- terminal('success', 'css minified');
32
- }
33
- fsPromises.writeFile(path.resolve(__dirname, '../styles.css'), styles);
34
- };
@@ -1,5 +0,0 @@
1
- import type { Lapikit } from '../../internal/types.js';
2
- export declare const colors: (config: Lapikit) => {
3
- root: string;
4
- className: string;
5
- };
@@ -1,88 +0,0 @@
1
- import { parseColor } from '../../internal/colors.js';
2
- export const colors = (config) => {
3
- const schemes = {
4
- light: {},
5
- dark: {}
6
- };
7
- for (const [property, values] of Object.entries(config.theme.colors)) {
8
- if (typeof values === 'string') {
9
- // for all color scheme
10
- const _refColor = parseColor(values);
11
- schemes['light'][property] = _refColor;
12
- schemes['dark'][property] = _refColor;
13
- }
14
- else {
15
- // with specification
16
- if ('light' in values && 'dark' in values) {
17
- schemes['light'][property] = parseColor(values.light);
18
- schemes['dark'][property] = parseColor(values.dark);
19
- }
20
- else {
21
- const _refColor = 'dark' in values ? parseColor(values['dark']) : parseColor(values['light']);
22
- schemes['light'][property] = _refColor;
23
- schemes['dark'][property] = _refColor;
24
- }
25
- }
26
- }
27
- // css variables
28
- let cssVariables = '';
29
- if (config.theme.colorScheme === 'auto') {
30
- for (const [themeName, colors] of Object.entries(schemes)) {
31
- const used = themeName;
32
- const inversed = used === 'light' ? 'dark' : 'light';
33
- cssVariables += `@media (prefers-color-scheme: ${used}) {\n`;
34
- cssVariables += `:root, .${used} {\n`;
35
- cssVariables += `color-scheme: ${used};\n`;
36
- for (const [colorName, colorValue] of Object.entries(colors)) {
37
- cssVariables += `--kit-${colorName}: ${colorValue};\n`;
38
- }
39
- cssVariables += `}\n`;
40
- cssVariables += `.${inversed} {\n`;
41
- cssVariables += `color-scheme: ${inversed};\n`;
42
- for (const [colorName, colorValue] of Object.entries(schemes[inversed])) {
43
- cssVariables += `--kit-${colorName}: ${colorValue};\n`;
44
- }
45
- cssVariables += `}\n`;
46
- cssVariables += `}\n`;
47
- }
48
- }
49
- else {
50
- const used = config.theme.colorScheme;
51
- const inversed = config.theme.colorScheme === 'light' ? 'dark' : 'light';
52
- cssVariables += `:root, .${used} {\n`;
53
- cssVariables += `color-scheme: ${used};\n`;
54
- for (const [colorName, colorValue] of Object.entries(schemes[used])) {
55
- cssVariables += `--kit-${colorName}: ${colorValue};\n`;
56
- }
57
- cssVariables += `}\n`;
58
- cssVariables += `.${inversed} {\n`;
59
- cssVariables += `color-scheme: ${inversed};\n`;
60
- for (const [colorName, colorValue] of Object.entries(schemes[inversed])) {
61
- cssVariables += `--kit-${colorName}: ${colorValue};\n`;
62
- }
63
- cssVariables += `}\n`;
64
- }
65
- // class
66
- let classStyles = '';
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`;
75
- classStyles += `.${property} {\n`;
76
- classStyles += `--base: var(--kit-${property});\n`;
77
- classStyles += `--on: var(--kit-on-${property}, var(--kit-${property}));\n`;
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`;
83
- }
84
- return {
85
- root: cssVariables,
86
- className: classStyles
87
- };
88
- };
@@ -1,2 +0,0 @@
1
- import type { Lapikit } from '../../internal/types.js';
2
- export declare const component: (config: Lapikit) => string;
@@ -1,115 +0,0 @@
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 component = (config) => {
8
- let css = ``;
9
- const tresholds = {
10
- _default: '',
11
- static: '',
12
- min: '',
13
- max: '',
14
- all: ''
15
- };
16
- function loadComponentCSS(directory) {
17
- fs.readdirSync(directory).forEach((File) => {
18
- const absolutePath = path.join(directory, File);
19
- if (fs.statSync(absolutePath).isDirectory())
20
- return loadComponentCSS(absolutePath);
21
- else if (absolutePath.endsWith('.css') && !absolutePath.includes('/_')) {
22
- const content = parser(fs.readFileSync(absolutePath, 'utf-8'));
23
- tresholds._default += content.allExtracted
24
- .replaceAll('[breakpoint|min]', '[breakpoint]')
25
- .replaceAll('[breakpoint|max]', '[breakpoint]')
26
- .replaceAll('[breakpoint|all]', '[breakpoint]');
27
- tresholds.static += content.defaultExtracted;
28
- tresholds.min += content.minExtracted.replaceAll('[breakpoint|min]', '[breakpoint]');
29
- tresholds.max += content.maxExtracted.replaceAll('[breakpoint|max]', '[breakpoint]');
30
- tresholds.all += content.allModifierExtracted.replaceAll('[breakpoint|all]', '[breakpoint]');
31
- return (css += `${content.cleaned}\n`);
32
- }
33
- });
34
- }
35
- loadComponentCSS(path.resolve(__dirname, '../../components'));
36
- for (const property in config.breakpoints.thresholds) {
37
- if (property !== '_default') {
38
- const name = `.${/^\d/.test(property) ? `\\3${property}` : property}\\:`;
39
- const value = typeof config.breakpoints.thresholds[property] === 'number'
40
- ? `${config.breakpoints.thresholds[property]}px`
41
- : config.breakpoints.thresholds[property];
42
- if (tresholds.static !== '' || tresholds.all !== '' || tresholds.min !== '') {
43
- css += `@media screen and (min-width: ${value}) {\n`;
44
- if (tresholds.static !== '')
45
- css += tresholds.static.replaceAll('[breakpoint]', name);
46
- if (tresholds.all !== '')
47
- css += tresholds.all.replaceAll('[breakpoint]', name);
48
- if (tresholds.min !== '')
49
- css += tresholds.min.replaceAll('[breakpoint]', name);
50
- css += `}\n`;
51
- }
52
- if (tresholds.max !== '' || tresholds.all !== '') {
53
- css += `@media screen and (max-width: ${value}) {\n`;
54
- if (tresholds.max !== '')
55
- css += tresholds.max.replaceAll('[breakpoint]', name);
56
- if (tresholds.all !== '')
57
- css += tresholds.all.replaceAll('[breakpoint]', name);
58
- css += `}\n`;
59
- }
60
- }
61
- else {
62
- css += tresholds._default.replaceAll('[breakpoint]', '.');
63
- }
64
- }
65
- return css;
66
- };
67
- const parser = (css) => {
68
- const regex = /([^{]+)\{([^}]+)\}/g;
69
- let match;
70
- const matchesToRemove = [];
71
- const extractedByType = {
72
- allExtracted: [],
73
- defaultExtracted: [],
74
- minExtracted: [],
75
- maxExtracted: [],
76
- allModifierExtracted: []
77
- };
78
- while ((match = regex.exec(css)) !== null) {
79
- const fullMatch = match[0];
80
- const selectors = match[1].trim();
81
- const body = match[2].trim();
82
- const selectorsArray = selectors.split(',').map((sel) => sel.trim());
83
- let matchedType = null;
84
- if (selectorsArray.some((sel) => sel.includes('[breakpoint|min]'))) {
85
- matchedType = 'minExtracted';
86
- }
87
- else if (selectorsArray.some((sel) => sel.includes('[breakpoint|max]'))) {
88
- matchedType = 'maxExtracted';
89
- }
90
- else if (selectorsArray.some((sel) => sel.includes('[breakpoint|all]'))) {
91
- matchedType = 'allModifierExtracted';
92
- }
93
- else if (selectorsArray.some((sel) => sel.includes('[breakpoint]'))) {
94
- matchedType = 'defaultExtracted';
95
- }
96
- if (matchedType) {
97
- const rule = `${selectors} {\n${body}\n}`;
98
- extractedByType.allExtracted.push(rule);
99
- extractedByType[matchedType].push(rule);
100
- matchesToRemove.push(fullMatch);
101
- }
102
- }
103
- let cleaned = css;
104
- for (const rule of matchesToRemove) {
105
- cleaned = cleaned.replace(rule, '').replace(/\n{2,}/g, '\n\n');
106
- }
107
- return {
108
- allExtracted: extractedByType.allExtracted.join('\n\n').trim(),
109
- defaultExtracted: extractedByType.defaultExtracted.join('\n\n').trim(),
110
- minExtracted: extractedByType.minExtracted.join('\n\n').trim(),
111
- maxExtracted: extractedByType.maxExtracted.join('\n\n').trim(),
112
- allModifierExtracted: extractedByType.allModifierExtracted.join('\n\n').trim(),
113
- cleaned: cleaned.trim()
114
- };
115
- };
@@ -1,2 +0,0 @@
1
- import type { Lapikit } from '../../internal/types.js';
2
- export declare const devices: (config: Lapikit) => string;
@@ -1,40 +0,0 @@
1
- import { setUnit } from '../../internal/unit.js';
2
- export const devices = (config) => {
3
- let css = ``;
4
- const list = {
5
- mobile: config.breakpoints.mobileBreakpoint,
6
- tablet: config.breakpoints.tabletBreakpoint,
7
- laptop: config.breakpoints.laptopBreakpoint
8
- };
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`;
39
- return css;
40
- };
@@ -1,4 +0,0 @@
1
- export * from './color.js';
2
- export * from './component.js';
3
- export * from './device.js';
4
- export * from './variable.js';
@@ -1,4 +0,0 @@
1
- export * from './color.js';
2
- export * from './component.js';
3
- export * from './device.js';
4
- export * from './variable.js';
@@ -1,2 +0,0 @@
1
- import type { Lapikit } from '../../internal/types.js';
2
- export declare const variables: (config?: Lapikit) => string;