lapikit 0.0.0-insiders.7e7f172 → 0.0.0-insiders.7eab165
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.
- package/bin/configuration.js +5 -1
- package/bin/presets.js +1 -0
- package/dist/actions/index.d.ts +0 -1
- package/dist/actions/index.js +0 -1
- package/dist/colors.css +0 -0
- package/dist/internal/config/presets.d.ts +108 -0
- package/dist/internal/config/presets.js +121 -0
- package/dist/internal/config/variables.d.ts +6 -0
- package/dist/internal/config/variables.js +6 -0
- package/dist/internal/core/formatter/component.d.ts +1 -0
- package/dist/internal/core/formatter/component.js +20 -0
- package/dist/internal/core/formatter/index.d.ts +4 -0
- package/dist/internal/core/formatter/index.js +21 -0
- package/dist/internal/core/formatter/styles.d.ts +4 -0
- package/dist/internal/core/formatter/styles.js +15 -0
- package/dist/internal/core/formatter/theme.d.ts +5 -0
- package/dist/internal/core/formatter/theme.js +20 -0
- package/dist/internal/core/formatter/typography.d.ts +5 -0
- package/dist/internal/core/formatter/typography.js +12 -0
- package/dist/internal/core/parser-config.d.ts +1 -0
- package/dist/internal/core/parser-config.js +24 -0
- package/dist/internal/helpers/parser.d.ts +1 -0
- package/dist/internal/helpers/parser.js +7 -0
- package/dist/internal/types/configuration.d.ts +40 -0
- package/dist/internal/types/configuration.js +1 -0
- package/dist/internal/types/index.d.ts +1 -0
- package/dist/internal/types/index.js +1 -0
- package/dist/labs/index.d.ts +4 -0
- package/dist/labs/index.js +5 -0
- package/dist/labs/my-component-style-global.svelte +6 -0
- package/dist/labs/my-component-style-global.svelte.d.ts +18 -0
- package/dist/labs/my-component-style-import.svelte +15 -0
- package/dist/labs/my-component-style-import.svelte.d.ts +18 -0
- package/dist/labs/my-component-style-mixed.svelte +23 -0
- package/dist/labs/my-component-style-mixed.svelte.d.ts +18 -0
- package/dist/labs/my-component.svelte +16 -0
- package/dist/labs/my-component.svelte.d.ts +18 -0
- package/dist/labs/style-mixed.css +7 -0
- package/dist/labs/style.css +7 -0
- package/dist/labs.css +25 -0
- package/dist/plugin/css.d.ts +1 -1
- package/dist/plugin/css.js +57 -12
- package/dist/plugin/preset-v2.d.ts +34 -6
- package/dist/plugin/preset-v2.js +55 -9
- package/dist/plugin/vitejs.js +5 -3
- package/package.json +7 -2
package/bin/configuration.js
CHANGED
|
@@ -248,7 +248,7 @@ async function addLapikitToViteConfig(viteConfigFile, pathConfig, typescript) {
|
|
|
248
248
|
}
|
|
249
249
|
|
|
250
250
|
export async function initConfiguration(options) {
|
|
251
|
-
const { typescript, pathConfig, formatCSS } = options;
|
|
251
|
+
const { typescript, pathConfig, formatCSS, pathCSS } = options;
|
|
252
252
|
const ext = typescript ? 'ts' : 'js';
|
|
253
253
|
const targetDir = path.resolve(process.cwd(), pathConfig);
|
|
254
254
|
const targetFile = path.join(targetDir, `lapikit.${ext}`);
|
|
@@ -289,6 +289,10 @@ export async function initConfiguration(options) {
|
|
|
289
289
|
throw error;
|
|
290
290
|
}
|
|
291
291
|
|
|
292
|
+
// Add Import Lapikit css
|
|
293
|
+
if (formatCSS !== 'css') {
|
|
294
|
+
console.log('need custom import (Preview)', pathCSS);
|
|
295
|
+
}
|
|
292
296
|
// Add lapikit to vite.config file
|
|
293
297
|
try {
|
|
294
298
|
const viteConfigFile = await findViteConfigFile(process.cwd(), typescript);
|
package/bin/presets.js
CHANGED
package/dist/actions/index.d.ts
CHANGED
package/dist/actions/index.js
CHANGED
package/dist/colors.css
ADDED
|
File without changes
|
|
@@ -0,0 +1,108 @@
|
|
|
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
|
+
styles: {
|
|
97
|
+
spacing: string;
|
|
98
|
+
shape: {
|
|
99
|
+
sm: string;
|
|
100
|
+
md: string;
|
|
101
|
+
lg: string;
|
|
102
|
+
xl: string;
|
|
103
|
+
'2xl': string;
|
|
104
|
+
'3xl': string;
|
|
105
|
+
full: string;
|
|
106
|
+
};
|
|
107
|
+
};
|
|
108
|
+
};
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { variables } from './variables.js';
|
|
2
|
+
export const preset = {
|
|
3
|
+
breakpoints: {
|
|
4
|
+
devices: {
|
|
5
|
+
desktop: 1024, //64rem (lg)
|
|
6
|
+
tablet: 768, //48rem (md)
|
|
7
|
+
mobile: 375 //28rem (sm)
|
|
8
|
+
},
|
|
9
|
+
thresholds: {
|
|
10
|
+
base: 0, // 0px
|
|
11
|
+
xs: 448, //28rem
|
|
12
|
+
sm: 640, //40rem
|
|
13
|
+
md: 768, //48rem
|
|
14
|
+
lg: 1024, //64rem
|
|
15
|
+
xl: 1280, //80rem
|
|
16
|
+
'2xl': 1536, //96rem
|
|
17
|
+
'3xl': 1792 //112rem
|
|
18
|
+
}
|
|
19
|
+
},
|
|
20
|
+
theme: {
|
|
21
|
+
defaultTheme: 'light',
|
|
22
|
+
themes: {
|
|
23
|
+
light: {
|
|
24
|
+
dark: false,
|
|
25
|
+
colors: {
|
|
26
|
+
blue: '#007AFF',
|
|
27
|
+
green: '#34C759',
|
|
28
|
+
red: '#FF3B30',
|
|
29
|
+
yellow: '#FFCC00',
|
|
30
|
+
orange: '#FF9500',
|
|
31
|
+
purple: '#AF52DE',
|
|
32
|
+
pink: '#FF2D55',
|
|
33
|
+
indigo: '#5856D6',
|
|
34
|
+
cyan: '#5AC8FA',
|
|
35
|
+
gray: '#8E8E93',
|
|
36
|
+
'gray-2': '#AEAEB2',
|
|
37
|
+
'gray-3': '#C7C7CC',
|
|
38
|
+
'gray-4': '#D1D1D6',
|
|
39
|
+
'gray-5': '#E5E5EA',
|
|
40
|
+
'gray-6': '#F2F2F7',
|
|
41
|
+
background: '#FFFFFF',
|
|
42
|
+
'secondary-background': '#F2F2F7',
|
|
43
|
+
'tertiary-background': '#EFEFF4',
|
|
44
|
+
label: '#000000',
|
|
45
|
+
'secondary-label': 'rgba(60,60,67,0.6)'
|
|
46
|
+
},
|
|
47
|
+
variables: variables
|
|
48
|
+
},
|
|
49
|
+
dark: {
|
|
50
|
+
dark: true,
|
|
51
|
+
colors: {
|
|
52
|
+
blue: '#0A84FF',
|
|
53
|
+
green: '#30D158',
|
|
54
|
+
red: '#FF453A',
|
|
55
|
+
yellow: '#FFD60A',
|
|
56
|
+
orange: '#FF9F0A',
|
|
57
|
+
purple: '#BF5AF2',
|
|
58
|
+
pink: '#FF375F',
|
|
59
|
+
indigo: '#5E5CE6',
|
|
60
|
+
cyan: '#64D2FF',
|
|
61
|
+
gray: '#8E8E93',
|
|
62
|
+
'gray-2': '#636366',
|
|
63
|
+
'gray-3': '#48484A',
|
|
64
|
+
'gray-4': '#3A3A3C',
|
|
65
|
+
'gray-5': '#2C2C2E',
|
|
66
|
+
'gray-6': '#1C1C1E',
|
|
67
|
+
background: '#000000',
|
|
68
|
+
'secondary-background': '#1C1C1E',
|
|
69
|
+
'tertiary-background': '#2C2C2E',
|
|
70
|
+
label: '#FFFFFF',
|
|
71
|
+
'secondary-label': 'rgba(235,235,245,0.6)'
|
|
72
|
+
},
|
|
73
|
+
variables: variables
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
},
|
|
77
|
+
typography: {
|
|
78
|
+
defaultTypography: 'default',
|
|
79
|
+
fonts: {
|
|
80
|
+
default: {
|
|
81
|
+
sans: [
|
|
82
|
+
'system-ui',
|
|
83
|
+
'-apple-system',
|
|
84
|
+
'BlinkMacSystemFont',
|
|
85
|
+
'Segoe UI',
|
|
86
|
+
'Roboto',
|
|
87
|
+
'Helvetica Neue',
|
|
88
|
+
'Arial',
|
|
89
|
+
'sans-serif',
|
|
90
|
+
'Apple Color Emoji',
|
|
91
|
+
'Segoe UI Emoji',
|
|
92
|
+
'Segoe UI Symbol'
|
|
93
|
+
],
|
|
94
|
+
mono: [
|
|
95
|
+
'SFMono-Regular',
|
|
96
|
+
'ui-monospace',
|
|
97
|
+
'SF Mono',
|
|
98
|
+
'Menlo',
|
|
99
|
+
'Monaco',
|
|
100
|
+
'Consolas',
|
|
101
|
+
'Liberation Mono',
|
|
102
|
+
'Courier New',
|
|
103
|
+
'monospace'
|
|
104
|
+
],
|
|
105
|
+
serif: ['Merriweather', 'Georgia', 'Cambria', 'Times New Roman', 'Times', 'serif']
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
},
|
|
109
|
+
styles: {
|
|
110
|
+
spacing: '0.125rem', // 2px
|
|
111
|
+
shape: {
|
|
112
|
+
sm: '0.125rem', // 2px
|
|
113
|
+
md: '0.25rem', // 4px
|
|
114
|
+
lg: '0.5rem', // 8px
|
|
115
|
+
xl: '0.75rem', // 12px
|
|
116
|
+
'2xl': '1rem', // 16px
|
|
117
|
+
'3xl': '1.5rem', // 24px
|
|
118
|
+
full: '9999px' // 9999px
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function componentFormatter(): void;
|
|
@@ -0,0 +1,20 @@
|
|
|
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 function componentFormatter() {
|
|
8
|
+
// Format component styles
|
|
9
|
+
function loadCSSFiles(directory) {
|
|
10
|
+
fs.readdirSync(directory).forEach((File) => {
|
|
11
|
+
const absolutePath = path.join(directory, File);
|
|
12
|
+
if (fs.statSync(absolutePath).isDirectory())
|
|
13
|
+
return loadCSSFiles(absolutePath);
|
|
14
|
+
else if (absolutePath.endsWith('.css') && !absolutePath.includes('/_')) {
|
|
15
|
+
console.log(absolutePath);
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
loadCSSFiles(path.resolve(__dirname, '../../../components'));
|
|
20
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { preset } from '../../config/presets.js';
|
|
2
|
+
import { deepMerge } from '../../deepMerge.js';
|
|
3
|
+
import { themesFormatter } from './theme.js';
|
|
4
|
+
import { typographyFormatter } from './typography.js';
|
|
5
|
+
export async function css(config) {
|
|
6
|
+
// states
|
|
7
|
+
const defaultTheme = config?.theme?.defaultTheme || preset.theme.defaultTheme;
|
|
8
|
+
const defaultTypography = config?.typography?.defaultTypography || preset.typography.defaultTypography;
|
|
9
|
+
// formatter
|
|
10
|
+
const themes = themesFormatter({
|
|
11
|
+
themes: deepMerge(preset.theme.themes, config?.theme?.themes || {}),
|
|
12
|
+
defaultTheme
|
|
13
|
+
});
|
|
14
|
+
const typography = typographyFormatter({
|
|
15
|
+
typography: deepMerge(preset.typography.fonts, config?.typography?.fonts || {}),
|
|
16
|
+
defaultTypography
|
|
17
|
+
});
|
|
18
|
+
return {
|
|
19
|
+
styles: [themes, typography]
|
|
20
|
+
};
|
|
21
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { parserValues } from '../../helpers/parser.js';
|
|
2
|
+
export function stylesFormatter({ styles }) {
|
|
3
|
+
let css = `:root {\n`;
|
|
4
|
+
for (const [name, values] of Object.entries(styles)) {
|
|
5
|
+
if (values && typeof values === 'object') {
|
|
6
|
+
for (const [styleName, styleValue] of Object.entries(values || {})) {
|
|
7
|
+
css += ` --prism-${name}-${styleName}: ${parserValues(styleValue)};\n`;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
else {
|
|
11
|
+
css += ` --prism-${name}: ${parserValues(values)};\n`;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
return (css += '}\n');
|
|
15
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { preset } from '../../config/presets.js';
|
|
2
|
+
import { deepMerge } from '../../deepMerge.js';
|
|
3
|
+
export function themesFormatter({ themes, defaultTheme = 'light' }) {
|
|
4
|
+
let css = '';
|
|
5
|
+
for (const [name, values] of Object.entries(themes)) {
|
|
6
|
+
const ref = values?.dark ? preset.theme.themes.dark : preset.theme.themes.light;
|
|
7
|
+
let cssTheme = defaultTheme === name ? `:root,\n.${name} {\n` : `.${name} {\n`;
|
|
8
|
+
// colors
|
|
9
|
+
cssTheme += ` color-scheme: ${values?.dark ? 'dark' : 'light'};\n`;
|
|
10
|
+
for (const [varName, varValue] of Object.entries(deepMerge(ref.colors, values?.colors) || {})) {
|
|
11
|
+
cssTheme += ` --system-${varName}: ${varValue};\n`;
|
|
12
|
+
}
|
|
13
|
+
// variables
|
|
14
|
+
for (const [name, varValue] of Object.entries(deepMerge(ref.variables, values?.variables) || {})) {
|
|
15
|
+
cssTheme += ` --kit-${name}: ${varValue};\n`;
|
|
16
|
+
}
|
|
17
|
+
css += cssTheme + '}\n';
|
|
18
|
+
}
|
|
19
|
+
return css;
|
|
20
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { parserValues } from '../../helpers/parser.js';
|
|
2
|
+
export function typographyFormatter({ typography, defaultTypography = 'default' }) {
|
|
3
|
+
let css = '';
|
|
4
|
+
for (const [name, values] of Object.entries(typography)) {
|
|
5
|
+
let cssTypo = defaultTypography === name ? `:root {\n` : `.${name} {\n`;
|
|
6
|
+
for (const [fontName, fontValue] of Object.entries(values || {})) {
|
|
7
|
+
cssTypo += ` --kit-font-${fontName}: ${parserValues(fontValue)};\n`;
|
|
8
|
+
}
|
|
9
|
+
css += cssTypo + '}\n';
|
|
10
|
+
}
|
|
11
|
+
return css;
|
|
12
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function getLapikitConfig(filePath: string): Promise<{}>;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import path from 'path';
|
|
2
|
+
import fs from 'fs';
|
|
3
|
+
import { terminal } from '../terminal.js';
|
|
4
|
+
const app = process.cwd();
|
|
5
|
+
export async function getLapikitConfig(filePath) {
|
|
6
|
+
const pathConfig = path.resolve(app, filePath);
|
|
7
|
+
if (!fs.existsSync(pathConfig))
|
|
8
|
+
process.exit(1);
|
|
9
|
+
const code = fs.readFileSync(pathConfig, 'utf-8');
|
|
10
|
+
const match = code.match(/createLapikit\s*\(\s*({[\s\S]*?})\s*\)/);
|
|
11
|
+
let options = {};
|
|
12
|
+
if (match && match[1]) {
|
|
13
|
+
try {
|
|
14
|
+
options = new Function('return ' + match[1])();
|
|
15
|
+
}
|
|
16
|
+
catch (e) {
|
|
17
|
+
terminal('error', `error parsing lapikit config: ${e}`);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
terminal('info', 'lapikit config has loaded successfully!');
|
|
22
|
+
}
|
|
23
|
+
return options;
|
|
24
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const parserValues: (value: string | number | Array<string | number>) => string;
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
export interface DevConfiguration {
|
|
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
|
+
themes?: FragThemes;
|
|
13
|
+
};
|
|
14
|
+
typography?: {
|
|
15
|
+
defaultTypography?: string;
|
|
16
|
+
fonts?: FragTypography;
|
|
17
|
+
};
|
|
18
|
+
styles?: FragStyles;
|
|
19
|
+
}
|
|
20
|
+
export interface FragThemes {
|
|
21
|
+
[key: string]: {
|
|
22
|
+
dark?: boolean;
|
|
23
|
+
colors?: {
|
|
24
|
+
[key: string]: string;
|
|
25
|
+
};
|
|
26
|
+
variables?: {
|
|
27
|
+
[key: string]: string | number;
|
|
28
|
+
};
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
export interface FragTypography {
|
|
32
|
+
[key: string]: {
|
|
33
|
+
[key: string]: string | string[];
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
export interface FragStyles {
|
|
37
|
+
[key: string]: string | number | {
|
|
38
|
+
[key: string]: string | number;
|
|
39
|
+
};
|
|
40
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './configuration.js';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './configuration.js';
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { default as CompoGlobal } from './my-component-style-global.svelte';
|
|
2
|
+
export { default as CompoMixed } from './my-component-style-mixed.svelte';
|
|
3
|
+
export { default as CompoLocal } from './my-component.svelte';
|
|
4
|
+
export { default as CompoImport } from './my-component-style-import.svelte';
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
// components
|
|
2
|
+
export { default as CompoGlobal } from './my-component-style-global.svelte';
|
|
3
|
+
export { default as CompoMixed } from './my-component-style-mixed.svelte';
|
|
4
|
+
export { default as CompoLocal } from './my-component.svelte';
|
|
5
|
+
export { default as CompoImport } from './my-component-style-import.svelte';
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
2
|
+
new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
|
|
3
|
+
$$bindings?: Bindings;
|
|
4
|
+
} & Exports;
|
|
5
|
+
(internal: unknown, props: {
|
|
6
|
+
$$events?: Events;
|
|
7
|
+
$$slots?: Slots;
|
|
8
|
+
}): Exports & {
|
|
9
|
+
$set?: any;
|
|
10
|
+
$on?: any;
|
|
11
|
+
};
|
|
12
|
+
z_$$bindings?: Bindings;
|
|
13
|
+
}
|
|
14
|
+
declare const MyComponentStyleGlobal: $$__sveltets_2_IsomorphicComponent<Record<string, never>, {
|
|
15
|
+
[evt: string]: CustomEvent<any>;
|
|
16
|
+
}, {}, {}, string>;
|
|
17
|
+
type MyComponentStyleGlobal = InstanceType<typeof MyComponentStyleGlobal>;
|
|
18
|
+
export default MyComponentStyleGlobal;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
</script>
|
|
3
|
+
|
|
4
|
+
<div class="my-compo-style-import">
|
|
5
|
+
<h1>Hello World Lapikit (import styles)</h1>
|
|
6
|
+
</div>
|
|
7
|
+
|
|
8
|
+
<style>.my-compo-style-import {
|
|
9
|
+
padding: 2.5rem;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
.my-compo-style-import h1 {
|
|
13
|
+
color: orangered;
|
|
14
|
+
}
|
|
15
|
+
</style>
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
2
|
+
new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
|
|
3
|
+
$$bindings?: Bindings;
|
|
4
|
+
} & Exports;
|
|
5
|
+
(internal: unknown, props: {
|
|
6
|
+
$$events?: Events;
|
|
7
|
+
$$slots?: Slots;
|
|
8
|
+
}): Exports & {
|
|
9
|
+
$set?: any;
|
|
10
|
+
$on?: any;
|
|
11
|
+
};
|
|
12
|
+
z_$$bindings?: Bindings;
|
|
13
|
+
}
|
|
14
|
+
declare const MyComponentStyleImport: $$__sveltets_2_IsomorphicComponent<Record<string, never>, {
|
|
15
|
+
[evt: string]: CustomEvent<any>;
|
|
16
|
+
}, {}, {}, string>;
|
|
17
|
+
type MyComponentStyleImport = InstanceType<typeof MyComponentStyleImport>;
|
|
18
|
+
export default MyComponentStyleImport;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
</script>
|
|
3
|
+
|
|
4
|
+
<div class="my-compo-style-mixed">
|
|
5
|
+
<h1>Hello World Lapikit Mixed</h1>
|
|
6
|
+
</div>
|
|
7
|
+
|
|
8
|
+
<style>.my-compo-style-mixed {
|
|
9
|
+
padding: 5.5rem;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
.my-compo-style-mixed h1 {
|
|
13
|
+
color: rgb(101, 52, 218);
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
div {
|
|
17
|
+
padding: 2rem;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
h1 {
|
|
21
|
+
color: rgb(101, 52, 218);
|
|
22
|
+
}
|
|
23
|
+
</style>
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
2
|
+
new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
|
|
3
|
+
$$bindings?: Bindings;
|
|
4
|
+
} & Exports;
|
|
5
|
+
(internal: unknown, props: {
|
|
6
|
+
$$events?: Events;
|
|
7
|
+
$$slots?: Slots;
|
|
8
|
+
}): Exports & {
|
|
9
|
+
$set?: any;
|
|
10
|
+
$on?: any;
|
|
11
|
+
};
|
|
12
|
+
z_$$bindings?: Bindings;
|
|
13
|
+
}
|
|
14
|
+
declare const MyComponentStyleMixed: $$__sveltets_2_IsomorphicComponent<Record<string, never>, {
|
|
15
|
+
[evt: string]: CustomEvent<any>;
|
|
16
|
+
}, {}, {}, string>;
|
|
17
|
+
type MyComponentStyleMixed = InstanceType<typeof MyComponentStyleMixed>;
|
|
18
|
+
export default MyComponentStyleMixed;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
2
|
+
new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
|
|
3
|
+
$$bindings?: Bindings;
|
|
4
|
+
} & Exports;
|
|
5
|
+
(internal: unknown, props: {
|
|
6
|
+
$$events?: Events;
|
|
7
|
+
$$slots?: Slots;
|
|
8
|
+
}): Exports & {
|
|
9
|
+
$set?: any;
|
|
10
|
+
$on?: any;
|
|
11
|
+
};
|
|
12
|
+
z_$$bindings?: Bindings;
|
|
13
|
+
}
|
|
14
|
+
declare const MyComponent: $$__sveltets_2_IsomorphicComponent<Record<string, never>, {
|
|
15
|
+
[evt: string]: CustomEvent<any>;
|
|
16
|
+
}, {}, {}, string>;
|
|
17
|
+
type MyComponent = InstanceType<typeof MyComponent>;
|
|
18
|
+
export default MyComponent;
|
package/dist/labs.css
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/* The future of css lapikit */
|
|
2
|
+
|
|
3
|
+
.my-compo-style-global {
|
|
4
|
+
padding: 1.5rem;
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
.my-compo-style-global h1 {
|
|
8
|
+
color: greenyellow;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
@media (max-width: 480px) {
|
|
12
|
+
:root {
|
|
13
|
+
--active-bp: sm;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
@media (max-width: 768px) {
|
|
17
|
+
:root {
|
|
18
|
+
--active-bp: md;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
@media (max-width: 1024px) {
|
|
22
|
+
:root {
|
|
23
|
+
--active-bp: lg;
|
|
24
|
+
}
|
|
25
|
+
}
|
package/dist/plugin/css.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare function css(configuration: any): void
|
|
1
|
+
export declare function css(configuration: any): Promise<void>;
|
package/dist/plugin/css.js
CHANGED
|
@@ -1,28 +1,73 @@
|
|
|
1
1
|
import { deepMerge } from '../internal/deepMerge.js';
|
|
2
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);
|
|
3
9
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
4
|
-
export function css(configuration) {
|
|
10
|
+
export async function css(configuration) {
|
|
11
|
+
console.log('VALUE configuration', configuration);
|
|
12
|
+
console.log('configuration?.theme?.themes', configuration?.theme?.themes);
|
|
5
13
|
// states
|
|
6
14
|
const defaultTheme = configuration?.theme?.defaultTheme || preset.theme.defaultTheme;
|
|
7
|
-
const themesMerged = deepMerge(configuration?.theme?.themes || {}
|
|
8
|
-
const variablesMerged = deepMerge(configuration?.theme?.variables || {}, preset.theme.variables);
|
|
15
|
+
const themesMerged = deepMerge(preset.theme.themes, configuration?.theme?.themes || {});
|
|
9
16
|
let response = '';
|
|
17
|
+
console.log('VALUE themesMerged', themesMerged);
|
|
10
18
|
for (const [name, values] of Object.entries(themesMerged)) {
|
|
11
|
-
let css =
|
|
12
|
-
|
|
19
|
+
let css = defaultTheme === name ? `:root,\n.${name} {\n` : `.${name} {\n`;
|
|
20
|
+
// ref
|
|
21
|
+
const ref = values?.dark ? preset.theme.themes.dark : preset.theme.themes.light;
|
|
22
|
+
// colors
|
|
13
23
|
css += ` color-scheme: ${values?.dark ? 'dark' : 'light'};\n`;
|
|
14
|
-
for (const [varName, varValue] of Object.entries(values?.colors || {})) {
|
|
24
|
+
for (const [varName, varValue] of Object.entries(deepMerge(ref.colors, values?.colors) || {})) {
|
|
15
25
|
css += ` --system-${varName}: ${varValue};\n`;
|
|
16
26
|
}
|
|
27
|
+
// console.log('VALUE', values, deepMerge(values?.variables, ref.variables));
|
|
28
|
+
// variables
|
|
29
|
+
for (const [name, varValue] of Object.entries(deepMerge(ref.variables, values?.variables) || {})) {
|
|
30
|
+
css += ` --kit-${name}: ${varValue};\n`;
|
|
31
|
+
}
|
|
32
|
+
css += '}\n';
|
|
33
|
+
// console.log(`Themes colors (${name}):`, css);
|
|
34
|
+
response += css;
|
|
35
|
+
}
|
|
36
|
+
// console.log('All themes CSS:', response);
|
|
37
|
+
//typography
|
|
38
|
+
// states
|
|
39
|
+
const defaultTypography = configuration?.typography?.defaultTypography || preset.typography.defaultTypography;
|
|
40
|
+
for (const [name, values] of Object.entries(deepMerge(preset.typography.fonts, configuration?.typography?.fonts || {}))) {
|
|
41
|
+
let css = '';
|
|
42
|
+
css += defaultTypography === name ? `:root {\n` : `.${name} {\n`;
|
|
43
|
+
// fonts
|
|
44
|
+
for (const [fontName, fontValue] of Object.entries(values || {})) {
|
|
45
|
+
css += ` --kit-font-${fontName}: ${parser(fontValue)};\n`;
|
|
46
|
+
}
|
|
17
47
|
css += '}\n';
|
|
18
|
-
console.log(`Themes colors (${name}):`, css);
|
|
19
48
|
response += css;
|
|
20
49
|
}
|
|
21
|
-
//
|
|
22
|
-
response +=
|
|
23
|
-
for (const [name,
|
|
24
|
-
|
|
50
|
+
//styles
|
|
51
|
+
response += `:root {\n`;
|
|
52
|
+
for (const [name, values] of Object.entries(deepMerge(preset.styles, configuration?.styles || {}))) {
|
|
53
|
+
let css = '';
|
|
54
|
+
if (values && typeof values === 'object') {
|
|
55
|
+
for (const [styleName, styleValue] of Object.entries(values || {})) {
|
|
56
|
+
css += ` --prism-${name}-${styleName}: ${parser(styleValue)};\n`;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
css += ` --prism-${name}: ${parser(values)};\n`;
|
|
61
|
+
}
|
|
62
|
+
response += css;
|
|
25
63
|
}
|
|
26
64
|
response += '}\n';
|
|
27
|
-
|
|
65
|
+
fsPromises.writeFile(path.resolve(__dirname, '../colors.css'), response);
|
|
28
66
|
}
|
|
67
|
+
const parser = (value) => {
|
|
68
|
+
if (typeof value === 'number')
|
|
69
|
+
return `${value}px`;
|
|
70
|
+
if (Array.isArray(value))
|
|
71
|
+
return value.join(', ');
|
|
72
|
+
return value;
|
|
73
|
+
};
|
|
@@ -37,12 +37,18 @@ export declare const preset: {
|
|
|
37
37
|
'gray-4': string;
|
|
38
38
|
'gray-5': string;
|
|
39
39
|
'gray-6': string;
|
|
40
|
-
|
|
40
|
+
background: string;
|
|
41
41
|
'secondary-background': string;
|
|
42
42
|
'tertiary-background': string;
|
|
43
43
|
label: string;
|
|
44
44
|
'secondary-label': string;
|
|
45
45
|
};
|
|
46
|
+
variables: {
|
|
47
|
+
info: string;
|
|
48
|
+
success: string;
|
|
49
|
+
error: string;
|
|
50
|
+
warning: string;
|
|
51
|
+
};
|
|
46
52
|
};
|
|
47
53
|
dark: {
|
|
48
54
|
dark: boolean;
|
|
@@ -68,13 +74,35 @@ export declare const preset: {
|
|
|
68
74
|
label: string;
|
|
69
75
|
'secondary-label': string;
|
|
70
76
|
};
|
|
77
|
+
variables: {
|
|
78
|
+
info: string;
|
|
79
|
+
success: string;
|
|
80
|
+
error: string;
|
|
81
|
+
warning: string;
|
|
82
|
+
};
|
|
71
83
|
};
|
|
72
84
|
};
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
85
|
+
};
|
|
86
|
+
typography: {
|
|
87
|
+
defaultTypography: string;
|
|
88
|
+
fonts: {
|
|
89
|
+
default: {
|
|
90
|
+
sans: string[];
|
|
91
|
+
mono: string[];
|
|
92
|
+
serif: string[];
|
|
93
|
+
};
|
|
94
|
+
};
|
|
95
|
+
};
|
|
96
|
+
styles: {
|
|
97
|
+
spacing: string;
|
|
98
|
+
shape: {
|
|
99
|
+
sm: string;
|
|
100
|
+
md: string;
|
|
101
|
+
lg: string;
|
|
102
|
+
xl: string;
|
|
103
|
+
'2xl': string;
|
|
104
|
+
'3xl': string;
|
|
105
|
+
full: string;
|
|
78
106
|
};
|
|
79
107
|
};
|
|
80
108
|
};
|
package/dist/plugin/preset-v2.js
CHANGED
|
@@ -1,3 +1,9 @@
|
|
|
1
|
+
const variables = {
|
|
2
|
+
info: 'var(--system-blue)',
|
|
3
|
+
success: 'var(--system-green)',
|
|
4
|
+
error: 'var(--system-red)',
|
|
5
|
+
warning: 'var(--system-yellow)'
|
|
6
|
+
};
|
|
1
7
|
export const preset = {
|
|
2
8
|
breakpoints: {
|
|
3
9
|
devices: {
|
|
@@ -37,12 +43,13 @@ export const preset = {
|
|
|
37
43
|
'gray-4': '#D1D1D6',
|
|
38
44
|
'gray-5': '#E5E5EA',
|
|
39
45
|
'gray-6': '#F2F2F7',
|
|
40
|
-
|
|
46
|
+
background: '#FFFFFF',
|
|
41
47
|
'secondary-background': '#F2F2F7',
|
|
42
48
|
'tertiary-background': '#EFEFF4',
|
|
43
49
|
label: '#000000',
|
|
44
50
|
'secondary-label': 'rgba(60,60,67,0.6)'
|
|
45
|
-
}
|
|
51
|
+
},
|
|
52
|
+
variables: variables
|
|
46
53
|
},
|
|
47
54
|
dark: {
|
|
48
55
|
dark: true,
|
|
@@ -67,14 +74,53 @@ export const preset = {
|
|
|
67
74
|
'tertiary-background': '#2C2C2E',
|
|
68
75
|
label: '#FFFFFF',
|
|
69
76
|
'secondary-label': 'rgba(235,235,245,0.6)'
|
|
70
|
-
}
|
|
77
|
+
},
|
|
78
|
+
variables: variables
|
|
71
79
|
}
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
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
|
|
78
124
|
}
|
|
79
125
|
}
|
|
80
126
|
};
|
package/dist/plugin/vitejs.js
CHANGED
|
@@ -5,6 +5,7 @@ import { terminal } from '../internal/terminal.js';
|
|
|
5
5
|
import path from 'path';
|
|
6
6
|
import fs from 'fs';
|
|
7
7
|
import { css } from './css.js';
|
|
8
|
+
import { componentFormatter } from '../internal/core/formatter/component.js';
|
|
8
9
|
const app = process.cwd();
|
|
9
10
|
async function getLapikitConfig(filePath) {
|
|
10
11
|
const pathConfig = path.resolve(app, filePath);
|
|
@@ -28,13 +29,14 @@ async function getLapikitConfig(filePath) {
|
|
|
28
29
|
}
|
|
29
30
|
export async function lapikit({ config } = {}) {
|
|
30
31
|
if (config) {
|
|
31
|
-
const value = getLapikitConfig(config);
|
|
32
|
-
console.log(value);
|
|
33
|
-
css(value);
|
|
32
|
+
const value = await getLapikitConfig(config);
|
|
33
|
+
// console.log(value);
|
|
34
|
+
await css(value);
|
|
34
35
|
}
|
|
35
36
|
return {
|
|
36
37
|
name: 'lapikit/vite.js',
|
|
37
38
|
async configResolved() {
|
|
39
|
+
await componentFormatter();
|
|
38
40
|
const importedConfig = await importer();
|
|
39
41
|
const result = await parseConfig(importedConfig);
|
|
40
42
|
await processCSS(result);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "lapikit",
|
|
3
|
-
"version": "0.0.0-insiders.
|
|
3
|
+
"version": "0.0.0-insiders.7eab165",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"publishConfig": {
|
|
6
6
|
"access": "public"
|
|
@@ -50,6 +50,10 @@
|
|
|
50
50
|
"svelte": "./dist/components/index.js",
|
|
51
51
|
"default": "./dist/components/index.js"
|
|
52
52
|
},
|
|
53
|
+
"./labs": {
|
|
54
|
+
"svelte": "./dist/labs/index.js",
|
|
55
|
+
"default": "./dist/labs/index.js"
|
|
56
|
+
},
|
|
53
57
|
"./vite": {
|
|
54
58
|
"default": "./dist/plugin/vitejs.js"
|
|
55
59
|
},
|
|
@@ -59,7 +63,8 @@
|
|
|
59
63
|
"./actions": {
|
|
60
64
|
"default": "./dist/actions/index.js"
|
|
61
65
|
},
|
|
62
|
-
"./css": "./dist/styles.css"
|
|
66
|
+
"./css": "./dist/styles.css",
|
|
67
|
+
"./styles": "./dist/labs.css"
|
|
63
68
|
},
|
|
64
69
|
"peerDependencies": {
|
|
65
70
|
"svelte": "^5.0.0"
|