lapikit 0.0.0-insiders.cfec658 → 0.0.0-insiders.cff5778
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 +17 -11
- 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/components/app/app.svelte +8 -15
- package/dist/index.d.ts +17 -0
- package/dist/index.js +16 -2
- package/dist/plugin/css.d.ts +1 -0
- package/dist/plugin/css.js +59 -0
- package/dist/plugin/preset-v2.d.ts +96 -0
- package/dist/plugin/preset-v2.js +114 -0
- package/dist/plugin/vitejs.d.ts +5 -1
- package/dist/plugin/vitejs.js +32 -3
- package/dist/stores/breakpoints.d.ts +1 -1
- package/dist/stores/breakpoints.js +7 -16
- package/dist/stores/components.d.ts +8 -0
- package/dist/stores/components.js +26 -0
- package/dist/stores/devices.d.ts +6 -0
- package/dist/stores/devices.js +9 -0
- package/dist/stores/index.d.ts +3 -12
- package/dist/stores/index.js +3 -49
- package/dist/stores/themes.d.ts +8 -0
- package/dist/stores/themes.js +34 -0
- package/dist/utils/convert.d.ts +1 -0
- package/dist/utils/convert.js +17 -0
- package/package.json +3 -2
- package/dist/internal/mediaQueries.d.ts +0 -20
- package/dist/internal/mediaQueries.js +0 -88
- package/dist/stores/viewports.d.ts +0 -2
- package/dist/stores/viewports.js +0 -5
package/bin/configuration.js
CHANGED
|
@@ -133,10 +133,12 @@ async function findViteConfigFile(projectPath, typescript) {
|
|
|
133
133
|
}
|
|
134
134
|
}
|
|
135
135
|
|
|
136
|
-
async function addLapikitToViteConfig(viteConfigFile) {
|
|
136
|
+
async function addLapikitToViteConfig(viteConfigFile, pathConfig, typescript) {
|
|
137
137
|
try {
|
|
138
138
|
const content = await fs.readFile(viteConfigFile, 'utf-8');
|
|
139
139
|
const lapikitImport = `import { lapikit } from 'lapikit/vite';`;
|
|
140
|
+
const configPath = `${pathConfig}/lapikit.${typescript ? 'ts' : 'js'}`;
|
|
141
|
+
const lapikitPlugin = `lapikit({ config: '${configPath}' })`;
|
|
140
142
|
|
|
141
143
|
// Check if lapikit import already exists
|
|
142
144
|
if (content.includes(lapikitImport) || content.includes(`from 'lapikit/vite'`)) {
|
|
@@ -183,10 +185,10 @@ async function addLapikitToViteConfig(viteConfigFile) {
|
|
|
183
185
|
const pluginMatch = line.match(/plugins:\s*\[(.*)\]/);
|
|
184
186
|
if (pluginMatch) {
|
|
185
187
|
const pluginsContent = pluginMatch[1];
|
|
186
|
-
if (!pluginsContent.includes('lapikit
|
|
188
|
+
if (!pluginsContent.includes('lapikit')) {
|
|
187
189
|
const newPluginsContent = pluginsContent.replace(
|
|
188
190
|
/sveltekit\(\)/,
|
|
189
|
-
|
|
191
|
+
`sveltekit(), ${lapikitPlugin}`
|
|
190
192
|
);
|
|
191
193
|
lines[i] = line.replace(pluginsContent, newPluginsContent);
|
|
192
194
|
pluginAdded = true;
|
|
@@ -200,24 +202,24 @@ async function addLapikitToViteConfig(viteConfigFile) {
|
|
|
200
202
|
const pluginLine = lines[j].trim();
|
|
201
203
|
|
|
202
204
|
if (pluginLine.includes('sveltekit()') && !pluginAdded) {
|
|
203
|
-
// Check if lapikit
|
|
205
|
+
// Check if lapikit is not already present
|
|
204
206
|
let hasLapikit = false;
|
|
205
207
|
for (let k = i; k < lines.length && !lines[k].includes(']'); k++) {
|
|
206
|
-
if (lines[k].includes('lapikit
|
|
208
|
+
if (lines[k].includes('lapikit')) {
|
|
207
209
|
hasLapikit = true;
|
|
208
210
|
break;
|
|
209
211
|
}
|
|
210
212
|
}
|
|
211
213
|
|
|
212
214
|
if (!hasLapikit) {
|
|
213
|
-
// Add lapikit
|
|
215
|
+
// Add lapikit after sveltekit()
|
|
214
216
|
if (pluginLine.includes(',')) {
|
|
215
|
-
lines[j] = lines[j].replace('sveltekit()',
|
|
217
|
+
lines[j] = lines[j].replace('sveltekit()', `sveltekit(), ${lapikitPlugin}`);
|
|
216
218
|
} else {
|
|
217
219
|
lines[j] = lines[j].replace('sveltekit()', 'sveltekit(),');
|
|
218
|
-
// Insert lapikit
|
|
220
|
+
// Insert lapikit on the next line with proper indentation
|
|
219
221
|
const indentation = lines[j].match(/^\s*/)[0];
|
|
220
|
-
lines.splice(j + 1, 0, `${indentation}
|
|
222
|
+
lines.splice(j + 1, 0, `${indentation}${lapikitPlugin}`);
|
|
221
223
|
}
|
|
222
224
|
pluginAdded = true;
|
|
223
225
|
}
|
|
@@ -246,7 +248,7 @@ async function addLapikitToViteConfig(viteConfigFile) {
|
|
|
246
248
|
}
|
|
247
249
|
|
|
248
250
|
export async function initConfiguration(options) {
|
|
249
|
-
const { typescript, pathConfig, formatCSS } = options;
|
|
251
|
+
const { typescript, pathConfig, formatCSS, pathCSS } = options;
|
|
250
252
|
const ext = typescript ? 'ts' : 'js';
|
|
251
253
|
const targetDir = path.resolve(process.cwd(), pathConfig);
|
|
252
254
|
const targetFile = path.join(targetDir, `lapikit.${ext}`);
|
|
@@ -287,10 +289,14 @@ export async function initConfiguration(options) {
|
|
|
287
289
|
throw error;
|
|
288
290
|
}
|
|
289
291
|
|
|
292
|
+
// Add Import Lapikit css
|
|
293
|
+
if (formatCSS !== 'css') {
|
|
294
|
+
console.log('need custom import (Preview)', pathCSS);
|
|
295
|
+
}
|
|
290
296
|
// Add lapikit to vite.config file
|
|
291
297
|
try {
|
|
292
298
|
const viteConfigFile = await findViteConfigFile(process.cwd(), typescript);
|
|
293
|
-
await addLapikitToViteConfig(viteConfigFile);
|
|
299
|
+
await addLapikitToViteConfig(viteConfigFile, pathConfig, typescript);
|
|
294
300
|
} catch (error) {
|
|
295
301
|
terminal('warn', `Warning: Could not update vite.config file: ${error.message}`);
|
|
296
302
|
terminal('error', `Error adding lapikit to vite config: ${error.message}`);
|
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
|
|
@@ -4,21 +4,12 @@
|
|
|
4
4
|
colorSchemeSystem,
|
|
5
5
|
modalOpen,
|
|
6
6
|
setOpenModal,
|
|
7
|
-
|
|
8
|
-
|
|
7
|
+
useColorScheme,
|
|
8
|
+
useTheme
|
|
9
9
|
} from '../../stores/index.js';
|
|
10
10
|
import type { Snippet } from 'svelte';
|
|
11
11
|
let { children }: { children: Snippet } = $props();
|
|
12
12
|
|
|
13
|
-
// states
|
|
14
|
-
let innerWidth = $state(0);
|
|
15
|
-
|
|
16
|
-
$effect(() => {
|
|
17
|
-
if (BROWSER) {
|
|
18
|
-
viewportWidth.set(innerWidth);
|
|
19
|
-
}
|
|
20
|
-
});
|
|
21
|
-
|
|
22
13
|
$effect.pre(() => {
|
|
23
14
|
if (!BROWSER) return;
|
|
24
15
|
// system
|
|
@@ -36,13 +27,15 @@
|
|
|
36
27
|
});
|
|
37
28
|
|
|
38
29
|
// local
|
|
39
|
-
const
|
|
40
|
-
|
|
30
|
+
const localColorScheme = localStorage.getItem('@lapikit/color-scheme');
|
|
31
|
+
const localTheme = localStorage.getItem('@lapikit/theme');
|
|
32
|
+
|
|
33
|
+
// apply local settings
|
|
34
|
+
if (localColorScheme !== null) useColorScheme(localColorScheme as 'dark' | 'light' | 'system');
|
|
35
|
+
if (localTheme !== null) useTheme(localTheme as string);
|
|
41
36
|
});
|
|
42
37
|
</script>
|
|
43
38
|
|
|
44
|
-
<svelte:window bind:innerWidth />
|
|
45
|
-
|
|
46
39
|
{@render children?.()}
|
|
47
40
|
|
|
48
41
|
<!-- svelte-ignore a11y_no_static_element_interactions -->
|
package/dist/index.d.ts
CHANGED
|
@@ -1,10 +1,27 @@
|
|
|
1
1
|
interface Lapikit {
|
|
2
2
|
adapterCSS: string;
|
|
3
3
|
breakpoints: {
|
|
4
|
+
devices: {
|
|
5
|
+
[key: string]: string;
|
|
6
|
+
};
|
|
4
7
|
thresholds: {
|
|
5
8
|
[key: string]: number | string;
|
|
6
9
|
};
|
|
7
10
|
};
|
|
11
|
+
theme: {
|
|
12
|
+
defaultTheme: string;
|
|
13
|
+
themes: {
|
|
14
|
+
[key: string]: {
|
|
15
|
+
dark: boolean;
|
|
16
|
+
colors: {
|
|
17
|
+
[key: string]: string;
|
|
18
|
+
};
|
|
19
|
+
variables: {
|
|
20
|
+
[key: string]: string;
|
|
21
|
+
};
|
|
22
|
+
};
|
|
23
|
+
};
|
|
24
|
+
};
|
|
8
25
|
}
|
|
9
26
|
declare function createLapikit(lapikit: Lapikit): void;
|
|
10
27
|
export default createLapikit;
|
package/dist/index.js
CHANGED
|
@@ -1,14 +1,28 @@
|
|
|
1
1
|
import { deepMerge } from './internal/deepMerge.js';
|
|
2
2
|
import { breakpoints } from './stores/breakpoints.js';
|
|
3
3
|
import { get } from 'svelte/store';
|
|
4
|
+
import { valueToPx } from './utils/convert.js';
|
|
5
|
+
import { devices } from './stores/devices.js';
|
|
4
6
|
function createLapikit(lapikit) {
|
|
5
7
|
console.log('Creating a new Lapikit instance...');
|
|
6
8
|
console.log('Options loaded:', lapikit);
|
|
7
9
|
if (lapikit?.breakpoints?.thresholds) {
|
|
8
10
|
const currentBreakpoints = get(breakpoints);
|
|
9
11
|
const breakpointMerged = deepMerge(currentBreakpoints, lapikit.breakpoints.thresholds);
|
|
10
|
-
|
|
11
|
-
|
|
12
|
+
const formattedBreakpoints = Object.fromEntries(Object.entries(breakpointMerged).map(([key, value]) => [key, valueToPx(value)]));
|
|
13
|
+
breakpoints.set(formattedBreakpoints);
|
|
14
|
+
console.log('Breakpoints found:', formattedBreakpoints);
|
|
15
|
+
}
|
|
16
|
+
if (lapikit?.breakpoints?.devices) {
|
|
17
|
+
const currentDevices = get(devices);
|
|
18
|
+
const currentBreakpoints = get(breakpoints);
|
|
19
|
+
const deviceMerged = deepMerge(currentDevices, lapikit.breakpoints.devices);
|
|
20
|
+
const formattedDevices = Object.fromEntries(Object.entries(deviceMerged).map(([key, deviceKey]) => {
|
|
21
|
+
const breakpointValue = currentBreakpoints[deviceKey];
|
|
22
|
+
return [key, valueToPx(breakpointValue)];
|
|
23
|
+
}));
|
|
24
|
+
devices.set(formattedDevices);
|
|
25
|
+
console.log('Devices found:', formattedDevices);
|
|
12
26
|
}
|
|
13
27
|
}
|
|
14
28
|
export default createLapikit;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function css(configuration: any): void;
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { deepMerge } from '../internal/deepMerge.js';
|
|
2
|
+
import { preset } from './preset-v2.js';
|
|
3
|
+
import { fileURLToPath } from 'url';
|
|
4
|
+
import { dirname } from 'path';
|
|
5
|
+
import fsPromises from 'fs/promises';
|
|
6
|
+
import path from 'path';
|
|
7
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
8
|
+
const __dirname = dirname(__filename);
|
|
9
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
10
|
+
export function css(configuration) {
|
|
11
|
+
console.log('VALUE configuration', configuration);
|
|
12
|
+
// states
|
|
13
|
+
const defaultTheme = configuration?.theme?.defaultTheme || preset.theme.defaultTheme;
|
|
14
|
+
const themesMerged = deepMerge(configuration?.theme?.themes || {}, preset.theme.themes);
|
|
15
|
+
let response = '';
|
|
16
|
+
console.log('VALUE themesMerged', themesMerged);
|
|
17
|
+
for (const [name, values] of Object.entries(themesMerged)) {
|
|
18
|
+
let css = defaultTheme === name ? `:root,\n.${name} {\n` : `.${name} {\n`;
|
|
19
|
+
// ref
|
|
20
|
+
const ref = values?.dark ? preset.theme.themes.dark : preset.theme.themes.light;
|
|
21
|
+
// colors
|
|
22
|
+
css += ` color-scheme: ${values?.dark ? 'dark' : 'light'};\n`;
|
|
23
|
+
for (const [varName, varValue] of Object.entries(deepMerge(values?.colors, ref.colors) || {})) {
|
|
24
|
+
css += ` --system-${varName}: ${varValue};\n`;
|
|
25
|
+
}
|
|
26
|
+
// console.log('VALUE', values, deepMerge(values?.variables, ref.variables));
|
|
27
|
+
// variables
|
|
28
|
+
for (const [name, varValue] of Object.entries(deepMerge(values?.variables, ref.variables) || {})) {
|
|
29
|
+
css += ` --kit-${name}: ${varValue};\n`;
|
|
30
|
+
}
|
|
31
|
+
css += '}\n';
|
|
32
|
+
// console.log(`Themes colors (${name}):`, css);
|
|
33
|
+
response += css;
|
|
34
|
+
}
|
|
35
|
+
// console.log('All themes CSS:', response);
|
|
36
|
+
// typography
|
|
37
|
+
// states
|
|
38
|
+
// const defaultTypography =
|
|
39
|
+
// configuration?.typography?.defaultTypography || preset.typography.defaultTypography;
|
|
40
|
+
// const fontsMerged = deepMerge(configuration?.typography?.fonts || {}, preset.typography.fonts);
|
|
41
|
+
// for (const [name, values] of Object.entries(fontsMerged)) {
|
|
42
|
+
// let css = '';
|
|
43
|
+
// css += defaultTypography === name ? `:root,\n.${name} {\n` : `.${name} {\n`;
|
|
44
|
+
// // fonts
|
|
45
|
+
// for (const [fontName, fontValue] of Object.entries(values?.font || {})) {
|
|
46
|
+
// css += ` --kit-font-${fontName}: ${parser(fontValue)};\n`;
|
|
47
|
+
// }
|
|
48
|
+
// css += '}\n';
|
|
49
|
+
// response += css;
|
|
50
|
+
// }
|
|
51
|
+
fsPromises.writeFile(path.resolve(__dirname, '../colors.css'), response);
|
|
52
|
+
}
|
|
53
|
+
const parser = (value) => {
|
|
54
|
+
if (typeof value === 'number')
|
|
55
|
+
return `${value}px`;
|
|
56
|
+
if (Array.isArray(value))
|
|
57
|
+
return value.join(', ');
|
|
58
|
+
return value;
|
|
59
|
+
};
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
export declare const preset: {
|
|
2
|
+
breakpoints: {
|
|
3
|
+
devices: {
|
|
4
|
+
desktop: number;
|
|
5
|
+
tablet: number;
|
|
6
|
+
mobile: number;
|
|
7
|
+
};
|
|
8
|
+
thresholds: {
|
|
9
|
+
base: number;
|
|
10
|
+
xs: number;
|
|
11
|
+
sm: number;
|
|
12
|
+
md: number;
|
|
13
|
+
lg: number;
|
|
14
|
+
xl: number;
|
|
15
|
+
'2xl': number;
|
|
16
|
+
'3xl': number;
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
theme: {
|
|
20
|
+
defaultTheme: string;
|
|
21
|
+
themes: {
|
|
22
|
+
light: {
|
|
23
|
+
dark: boolean;
|
|
24
|
+
colors: {
|
|
25
|
+
blue: string;
|
|
26
|
+
green: string;
|
|
27
|
+
red: string;
|
|
28
|
+
yellow: string;
|
|
29
|
+
orange: string;
|
|
30
|
+
purple: string;
|
|
31
|
+
pink: string;
|
|
32
|
+
indigo: string;
|
|
33
|
+
cyan: string;
|
|
34
|
+
gray: string;
|
|
35
|
+
'gray-2': string;
|
|
36
|
+
'gray-3': string;
|
|
37
|
+
'gray-4': string;
|
|
38
|
+
'gray-5': string;
|
|
39
|
+
'gray-6': string;
|
|
40
|
+
background: string;
|
|
41
|
+
'secondary-background': string;
|
|
42
|
+
'tertiary-background': string;
|
|
43
|
+
label: string;
|
|
44
|
+
'secondary-label': string;
|
|
45
|
+
};
|
|
46
|
+
variables: {
|
|
47
|
+
info: string;
|
|
48
|
+
success: string;
|
|
49
|
+
error: string;
|
|
50
|
+
warning: string;
|
|
51
|
+
};
|
|
52
|
+
};
|
|
53
|
+
dark: {
|
|
54
|
+
dark: boolean;
|
|
55
|
+
colors: {
|
|
56
|
+
blue: string;
|
|
57
|
+
green: string;
|
|
58
|
+
red: string;
|
|
59
|
+
yellow: string;
|
|
60
|
+
orange: string;
|
|
61
|
+
purple: string;
|
|
62
|
+
pink: string;
|
|
63
|
+
indigo: string;
|
|
64
|
+
cyan: string;
|
|
65
|
+
gray: string;
|
|
66
|
+
'gray-2': string;
|
|
67
|
+
'gray-3': string;
|
|
68
|
+
'gray-4': string;
|
|
69
|
+
'gray-5': string;
|
|
70
|
+
'gray-6': string;
|
|
71
|
+
background: string;
|
|
72
|
+
'secondary-background': string;
|
|
73
|
+
'tertiary-background': string;
|
|
74
|
+
label: string;
|
|
75
|
+
'secondary-label': string;
|
|
76
|
+
};
|
|
77
|
+
variables: {
|
|
78
|
+
info: string;
|
|
79
|
+
success: string;
|
|
80
|
+
error: string;
|
|
81
|
+
warning: string;
|
|
82
|
+
};
|
|
83
|
+
};
|
|
84
|
+
};
|
|
85
|
+
};
|
|
86
|
+
typography: {
|
|
87
|
+
defaultTypography: string;
|
|
88
|
+
fonts: {
|
|
89
|
+
default: {
|
|
90
|
+
sans: string[];
|
|
91
|
+
mono: string[];
|
|
92
|
+
serif: string[];
|
|
93
|
+
};
|
|
94
|
+
};
|
|
95
|
+
};
|
|
96
|
+
};
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
const variables = {
|
|
2
|
+
info: 'var(--system-blue)',
|
|
3
|
+
success: 'var(--system-green)',
|
|
4
|
+
error: 'var(--system-red)',
|
|
5
|
+
warning: 'var(--system-yellow)'
|
|
6
|
+
};
|
|
7
|
+
export const preset = {
|
|
8
|
+
breakpoints: {
|
|
9
|
+
devices: {
|
|
10
|
+
desktop: 1024, //64rem (lg)
|
|
11
|
+
tablet: 768, //48rem (md)
|
|
12
|
+
mobile: 375 //28rem (sm)
|
|
13
|
+
},
|
|
14
|
+
thresholds: {
|
|
15
|
+
base: 0, // 0px
|
|
16
|
+
xs: 448, //28rem
|
|
17
|
+
sm: 640, //40rem
|
|
18
|
+
md: 768, //48rem
|
|
19
|
+
lg: 1024, //64rem
|
|
20
|
+
xl: 1280, //80rem
|
|
21
|
+
'2xl': 1536, //96rem
|
|
22
|
+
'3xl': 1792 //112rem
|
|
23
|
+
}
|
|
24
|
+
},
|
|
25
|
+
theme: {
|
|
26
|
+
defaultTheme: 'light',
|
|
27
|
+
themes: {
|
|
28
|
+
light: {
|
|
29
|
+
dark: false,
|
|
30
|
+
colors: {
|
|
31
|
+
blue: '#007AFF',
|
|
32
|
+
green: '#34C759',
|
|
33
|
+
red: '#FF3B30',
|
|
34
|
+
yellow: '#FFCC00',
|
|
35
|
+
orange: '#FF9500',
|
|
36
|
+
purple: '#AF52DE',
|
|
37
|
+
pink: '#FF2D55',
|
|
38
|
+
indigo: '#5856D6',
|
|
39
|
+
cyan: '#5AC8FA',
|
|
40
|
+
gray: '#8E8E93',
|
|
41
|
+
'gray-2': '#AEAEB2',
|
|
42
|
+
'gray-3': '#C7C7CC',
|
|
43
|
+
'gray-4': '#D1D1D6',
|
|
44
|
+
'gray-5': '#E5E5EA',
|
|
45
|
+
'gray-6': '#F2F2F7',
|
|
46
|
+
background: '#FFFFFF',
|
|
47
|
+
'secondary-background': '#F2F2F7',
|
|
48
|
+
'tertiary-background': '#EFEFF4',
|
|
49
|
+
label: '#000000',
|
|
50
|
+
'secondary-label': 'rgba(60,60,67,0.6)'
|
|
51
|
+
},
|
|
52
|
+
variables: variables
|
|
53
|
+
},
|
|
54
|
+
dark: {
|
|
55
|
+
dark: true,
|
|
56
|
+
colors: {
|
|
57
|
+
blue: '#0A84FF',
|
|
58
|
+
green: '#30D158',
|
|
59
|
+
red: '#FF453A',
|
|
60
|
+
yellow: '#FFD60A',
|
|
61
|
+
orange: '#FF9F0A',
|
|
62
|
+
purple: '#BF5AF2',
|
|
63
|
+
pink: '#FF375F',
|
|
64
|
+
indigo: '#5E5CE6',
|
|
65
|
+
cyan: '#64D2FF',
|
|
66
|
+
gray: '#8E8E93',
|
|
67
|
+
'gray-2': '#636366',
|
|
68
|
+
'gray-3': '#48484A',
|
|
69
|
+
'gray-4': '#3A3A3C',
|
|
70
|
+
'gray-5': '#2C2C2E',
|
|
71
|
+
'gray-6': '#1C1C1E',
|
|
72
|
+
background: '#000000',
|
|
73
|
+
'secondary-background': '#1C1C1E',
|
|
74
|
+
'tertiary-background': '#2C2C2E',
|
|
75
|
+
label: '#FFFFFF',
|
|
76
|
+
'secondary-label': 'rgba(235,235,245,0.6)'
|
|
77
|
+
},
|
|
78
|
+
variables: variables
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
},
|
|
82
|
+
typography: {
|
|
83
|
+
defaultTypography: 'default',
|
|
84
|
+
fonts: {
|
|
85
|
+
default: {
|
|
86
|
+
sans: [
|
|
87
|
+
'system-ui',
|
|
88
|
+
'-apple-system',
|
|
89
|
+
'BlinkMacSystemFont',
|
|
90
|
+
'Segoe UI',
|
|
91
|
+
'Roboto',
|
|
92
|
+
'Helvetica Neue',
|
|
93
|
+
'Arial',
|
|
94
|
+
'sans-serif',
|
|
95
|
+
'Apple Color Emoji',
|
|
96
|
+
'Segoe UI Emoji',
|
|
97
|
+
'Segoe UI Symbol'
|
|
98
|
+
],
|
|
99
|
+
mono: [
|
|
100
|
+
'SFMono-Regular',
|
|
101
|
+
'ui-monospace',
|
|
102
|
+
'SF Mono',
|
|
103
|
+
'Menlo',
|
|
104
|
+
'Monaco',
|
|
105
|
+
'Consolas',
|
|
106
|
+
'Liberation Mono',
|
|
107
|
+
'Courier New',
|
|
108
|
+
'monospace'
|
|
109
|
+
],
|
|
110
|
+
serif: ['Merriweather', 'Georgia', 'Cambria', 'Times New Roman', 'Times', 'serif']
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
};
|
package/dist/plugin/vitejs.d.ts
CHANGED
|
@@ -1,6 +1,10 @@
|
|
|
1
1
|
import type { ViteDevServer } from 'vite';
|
|
2
|
-
|
|
2
|
+
type Lapikit = {
|
|
3
|
+
config?: string;
|
|
4
|
+
};
|
|
5
|
+
export declare function lapikit({ config }?: Lapikit): Promise<{
|
|
3
6
|
name: string;
|
|
4
7
|
configResolved(): Promise<void>;
|
|
5
8
|
configureServer(server: ViteDevServer): Promise<void>;
|
|
6
9
|
}>;
|
|
10
|
+
export {};
|
package/dist/plugin/vitejs.js
CHANGED
|
@@ -2,12 +2,41 @@ import { importer } from './modules/importer.js';
|
|
|
2
2
|
import { processCSS } from '../style/css.js';
|
|
3
3
|
import { parseConfig } from './modules/config.js';
|
|
4
4
|
import { terminal } from '../internal/terminal.js';
|
|
5
|
-
|
|
5
|
+
import path from 'path';
|
|
6
|
+
import fs from 'fs';
|
|
7
|
+
import { css } from './css.js';
|
|
8
|
+
const app = process.cwd();
|
|
9
|
+
async function getLapikitConfig(filePath) {
|
|
10
|
+
const pathConfig = path.resolve(app, filePath);
|
|
11
|
+
if (!fs.existsSync(pathConfig))
|
|
12
|
+
process.exit(1);
|
|
13
|
+
const code = fs.readFileSync(pathConfig, 'utf-8');
|
|
14
|
+
const match = code.match(/createLapikit\s*\(\s*({[\s\S]*?})\s*\)/);
|
|
15
|
+
let options = {};
|
|
16
|
+
if (match && match[1]) {
|
|
17
|
+
try {
|
|
18
|
+
options = new Function('return ' + match[1])();
|
|
19
|
+
}
|
|
20
|
+
catch (e) {
|
|
21
|
+
console.error('Error parsing lapikit config:', e);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
console.error('Lapikit not found');
|
|
26
|
+
}
|
|
27
|
+
return options;
|
|
28
|
+
}
|
|
29
|
+
export async function lapikit({ config } = {}) {
|
|
30
|
+
if (config) {
|
|
31
|
+
const value = getLapikitConfig(config);
|
|
32
|
+
console.log(value);
|
|
33
|
+
css(value);
|
|
34
|
+
}
|
|
6
35
|
return {
|
|
7
36
|
name: 'lapikit/vite.js',
|
|
8
37
|
async configResolved() {
|
|
9
|
-
const
|
|
10
|
-
const result = await parseConfig(
|
|
38
|
+
const importedConfig = await importer();
|
|
39
|
+
const result = await parseConfig(importedConfig);
|
|
11
40
|
await processCSS(result);
|
|
12
41
|
terminal('info', 'lapikit is up!');
|
|
13
42
|
},
|
|
@@ -3,21 +3,12 @@ import { writable } from 'svelte/store';
|
|
|
3
3
|
// presets
|
|
4
4
|
const ref = {
|
|
5
5
|
base: 0, // 0px
|
|
6
|
-
xs:
|
|
7
|
-
sm:
|
|
8
|
-
md:
|
|
9
|
-
lg:
|
|
10
|
-
xl:
|
|
11
|
-
'2xl':
|
|
12
|
-
'3xl':
|
|
6
|
+
xs: 448, //28rem
|
|
7
|
+
sm: 640, //40rem
|
|
8
|
+
md: 768, //48rem
|
|
9
|
+
lg: 1024, //64rem
|
|
10
|
+
xl: 1280, //80rem
|
|
11
|
+
'2xl': 1536, //96rem
|
|
12
|
+
'3xl': 1792 //112rem
|
|
13
13
|
};
|
|
14
14
|
export const breakpoints = writable(ref);
|
|
15
|
-
// export function setBreakpoints(newBreakpoints: Breakpoints) {
|
|
16
|
-
// breakpoints.set(newBreakpoints);
|
|
17
|
-
// }
|
|
18
|
-
// export function updateBreakpoint(key: string, value: number) {
|
|
19
|
-
// breakpoints.update((bp) => ({
|
|
20
|
-
// ...bp,
|
|
21
|
-
// [key]: value
|
|
22
|
-
// }));
|
|
23
|
-
// }
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { type Writable } from 'svelte/store';
|
|
2
|
+
type ModalState = boolean | 'persistent';
|
|
3
|
+
export declare const modalOpen: Writable<ModalState>;
|
|
4
|
+
export declare const modalStack: Writable<string[]>;
|
|
5
|
+
export declare function setOpenModal(state: boolean | 'persistent'): void;
|
|
6
|
+
export declare const pushModal: (id: string) => void;
|
|
7
|
+
export declare const popModal: (id: string) => void;
|
|
8
|
+
export {};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { disabledScroll } from '../internal/scroll.js';
|
|
2
|
+
import { writable } from 'svelte/store';
|
|
3
|
+
// presets
|
|
4
|
+
const refModal = false;
|
|
5
|
+
// states
|
|
6
|
+
export const modalOpen = writable(refModal);
|
|
7
|
+
export const modalStack = writable([]);
|
|
8
|
+
export function setOpenModal(state) {
|
|
9
|
+
modalOpen.set(state);
|
|
10
|
+
}
|
|
11
|
+
export const pushModal = (id) => {
|
|
12
|
+
modalStack.update((stack) => {
|
|
13
|
+
let values = stack;
|
|
14
|
+
if (!stack.includes(id))
|
|
15
|
+
values = [...stack, id];
|
|
16
|
+
disabledScroll(values.length !== 0 ? true : false);
|
|
17
|
+
return values;
|
|
18
|
+
});
|
|
19
|
+
};
|
|
20
|
+
export const popModal = (id) => {
|
|
21
|
+
modalStack.update((stack) => {
|
|
22
|
+
const newStack = stack.filter((m) => m !== id);
|
|
23
|
+
disabledScroll(newStack.length !== 0 ? true : false);
|
|
24
|
+
return newStack.length === 0 ? [] : newStack;
|
|
25
|
+
});
|
|
26
|
+
};
|
package/dist/stores/index.d.ts
CHANGED
|
@@ -1,13 +1,4 @@
|
|
|
1
|
-
import { type Writable } from 'svelte/store';
|
|
2
|
-
export declare const colorScheme: Writable<'system' | 'dark' | 'light'>;
|
|
3
|
-
export declare const colorSchemeSystem: Writable<'dark' | 'light'>;
|
|
4
|
-
export declare const modalOpen: Writable<boolean | 'persistent'>;
|
|
5
|
-
export declare const modalStack: Writable<string[]>;
|
|
6
|
-
export declare function updateThemeStore(update: 'system' | 'dark' | 'light'): void;
|
|
7
|
-
export declare function setColorScheme(scheme: 'system' | 'dark' | 'light'): void;
|
|
8
|
-
export declare function setOpenModal(state: boolean | 'persistent'): void;
|
|
9
|
-
export declare const pushModal: (id: string) => void;
|
|
10
|
-
export declare const popModal: (id: string) => void;
|
|
11
1
|
export * from './breakpoints.js';
|
|
12
|
-
export * from './
|
|
13
|
-
export
|
|
2
|
+
export * from './devices.js';
|
|
3
|
+
export * from './themes.js';
|
|
4
|
+
export * from './components.js';
|
package/dist/stores/index.js
CHANGED
|
@@ -1,50 +1,4 @@
|
|
|
1
|
-
import { disabledScroll } from '../internal/scroll.js';
|
|
2
|
-
import { writable } from 'svelte/store';
|
|
3
|
-
// states
|
|
4
|
-
const colorScheme_default = 'system';
|
|
5
|
-
const modalOpen_default = false;
|
|
6
|
-
const isBrowser = typeof window !== 'undefined';
|
|
7
|
-
export const colorScheme = writable(colorScheme_default);
|
|
8
|
-
export const colorSchemeSystem = writable('light');
|
|
9
|
-
export const modalOpen = writable(modalOpen_default);
|
|
10
|
-
export const modalStack = writable([]);
|
|
11
|
-
export function updateThemeStore(update) {
|
|
12
|
-
colorScheme.update(() => {
|
|
13
|
-
if (isBrowser) {
|
|
14
|
-
const ref = document.documentElement.classList;
|
|
15
|
-
if (update === 'system')
|
|
16
|
-
ref.remove('light', 'dark');
|
|
17
|
-
else {
|
|
18
|
-
ref.remove(update === 'dark' ? 'light' : 'dark');
|
|
19
|
-
ref.add(update === 'dark' ? 'dark' : 'light');
|
|
20
|
-
}
|
|
21
|
-
localStorage.setItem('@lapikit/theme', update);
|
|
22
|
-
}
|
|
23
|
-
return update;
|
|
24
|
-
});
|
|
25
|
-
}
|
|
26
|
-
export function setColorScheme(scheme) {
|
|
27
|
-
updateThemeStore(scheme);
|
|
28
|
-
}
|
|
29
|
-
export function setOpenModal(state) {
|
|
30
|
-
modalOpen.set(state);
|
|
31
|
-
}
|
|
32
|
-
export const pushModal = (id) => {
|
|
33
|
-
modalStack.update((stack) => {
|
|
34
|
-
let values = stack;
|
|
35
|
-
if (!stack.includes(id))
|
|
36
|
-
values = [...stack, id];
|
|
37
|
-
disabledScroll(values.length !== 0 ? true : false);
|
|
38
|
-
return values;
|
|
39
|
-
});
|
|
40
|
-
};
|
|
41
|
-
export const popModal = (id) => {
|
|
42
|
-
modalStack.update((stack) => {
|
|
43
|
-
const newStack = stack.filter((m) => m !== id);
|
|
44
|
-
disabledScroll(newStack.length !== 0 ? true : false);
|
|
45
|
-
return newStack.length === 0 ? [] : newStack;
|
|
46
|
-
});
|
|
47
|
-
};
|
|
48
1
|
export * from './breakpoints.js';
|
|
49
|
-
export * from './
|
|
50
|
-
export
|
|
2
|
+
export * from './devices.js';
|
|
3
|
+
export * from './themes.js';
|
|
4
|
+
export * from './components.js';
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { type Writable } from 'svelte/store';
|
|
2
|
+
type PreferColorScheme = 'system' | 'dark' | 'light';
|
|
3
|
+
export declare const colorScheme: Writable<PreferColorScheme>;
|
|
4
|
+
export declare const colorSchemeSystem: Writable<'dark' | 'light'>;
|
|
5
|
+
export declare const theme: Writable<string>;
|
|
6
|
+
export declare function useColorScheme(scheme: PreferColorScheme, key?: string): void;
|
|
7
|
+
export declare function useTheme(name: string, key?: string): void;
|
|
8
|
+
export {};
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { writable } from 'svelte/store';
|
|
2
|
+
// presets
|
|
3
|
+
const colorSchemeRef = 'system';
|
|
4
|
+
const themeRef = 'lapikit';
|
|
5
|
+
// states
|
|
6
|
+
const isBrowser = typeof window !== 'undefined';
|
|
7
|
+
export const colorScheme = writable(colorSchemeRef);
|
|
8
|
+
export const colorSchemeSystem = writable('light');
|
|
9
|
+
export const theme = writable(themeRef);
|
|
10
|
+
export function useColorScheme(scheme, key = '@lapikit/color-scheme') {
|
|
11
|
+
colorScheme.update(() => {
|
|
12
|
+
if (isBrowser) {
|
|
13
|
+
const ref = document.documentElement.classList;
|
|
14
|
+
if (scheme === 'system')
|
|
15
|
+
ref.remove('light', 'dark');
|
|
16
|
+
else {
|
|
17
|
+
ref.remove(scheme === 'dark' ? 'light' : 'dark');
|
|
18
|
+
ref.add(scheme === 'dark' ? 'dark' : 'light');
|
|
19
|
+
}
|
|
20
|
+
localStorage.setItem(key, scheme);
|
|
21
|
+
}
|
|
22
|
+
return scheme;
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
export function useTheme(name, key = '@lapikit/theme') {
|
|
26
|
+
theme.update(() => {
|
|
27
|
+
if (isBrowser) {
|
|
28
|
+
const html = document.documentElement;
|
|
29
|
+
html.setAttribute('data-theme', name);
|
|
30
|
+
localStorage.setItem(key, name);
|
|
31
|
+
}
|
|
32
|
+
return name;
|
|
33
|
+
});
|
|
34
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function valueToPx(value: string | number): number;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export function valueToPx(value) {
|
|
2
|
+
if (typeof value === 'number')
|
|
3
|
+
return value;
|
|
4
|
+
if (typeof value === 'string') {
|
|
5
|
+
if (value.endsWith('rem')) {
|
|
6
|
+
return parseFloat(value) * 16;
|
|
7
|
+
}
|
|
8
|
+
if (value.endsWith('em')) {
|
|
9
|
+
return parseFloat(value) * 16;
|
|
10
|
+
}
|
|
11
|
+
if (value.endsWith('px')) {
|
|
12
|
+
return parseFloat(value);
|
|
13
|
+
}
|
|
14
|
+
return parseFloat(value);
|
|
15
|
+
}
|
|
16
|
+
return 0;
|
|
17
|
+
}
|
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.cff5778",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"publishConfig": {
|
|
6
6
|
"access": "public"
|
|
@@ -59,7 +59,8 @@
|
|
|
59
59
|
"./actions": {
|
|
60
60
|
"default": "./dist/actions/index.js"
|
|
61
61
|
},
|
|
62
|
-
"./css": "./dist/styles.css"
|
|
62
|
+
"./css": "./dist/styles.css",
|
|
63
|
+
"./styles": "./dist/colors.css"
|
|
63
64
|
},
|
|
64
65
|
"peerDependencies": {
|
|
65
66
|
"svelte": "^5.0.0"
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Non-reactive media queries function
|
|
3
|
-
* Use this in JavaScript code when you need a one-time check
|
|
4
|
-
* @param {...Array<["min"|"max", string]>} args - ex: [ ["min", "xs"], ["max", "lg"] ]
|
|
5
|
-
* @returns {boolean}
|
|
6
|
-
*/
|
|
7
|
-
export declare function mediaQueries(...args: Array<['min' | 'max', string]> | ['min' | 'max', string]): boolean;
|
|
8
|
-
/**
|
|
9
|
-
* Reactive media queries that returns a store
|
|
10
|
-
* Use this in Svelte templates for automatic reactivity
|
|
11
|
-
* @param {...Array<["min"|"max", string]>} args - ex: [ ["min", "xs"], ["max", "lg"] ]
|
|
12
|
-
* @returns {import('svelte/store').Readable<boolean>}
|
|
13
|
-
*/
|
|
14
|
-
export declare function mediaQueriesReactive(...args: Array<['min' | 'max', string]> | ['min' | 'max', string]): import("svelte/store").Readable<boolean>;
|
|
15
|
-
/**
|
|
16
|
-
* Convenient function for direct use in Svelte templates
|
|
17
|
-
* Returns a readable store that updates automatically
|
|
18
|
-
* Usage: $mediaQuery(['min', 'md']) in template
|
|
19
|
-
*/
|
|
20
|
-
export declare const mediaQuery: typeof mediaQueriesReactive;
|
|
@@ -1,88 +0,0 @@
|
|
|
1
|
-
import { get, derived } from 'svelte/store';
|
|
2
|
-
import { breakpoints } from '../stores/breakpoints.js';
|
|
3
|
-
import { viewportWidth } from '../stores/viewports.js';
|
|
4
|
-
// Converts rem/em/px to number of pixels
|
|
5
|
-
function toPx(value) {
|
|
6
|
-
if (typeof value === 'number')
|
|
7
|
-
return value;
|
|
8
|
-
if (typeof value === 'string') {
|
|
9
|
-
if (value.endsWith('rem')) {
|
|
10
|
-
return parseFloat(value) * 16;
|
|
11
|
-
}
|
|
12
|
-
if (value.endsWith('em')) {
|
|
13
|
-
return parseFloat(value) * 16;
|
|
14
|
-
}
|
|
15
|
-
if (value.endsWith('px')) {
|
|
16
|
-
return parseFloat(value);
|
|
17
|
-
}
|
|
18
|
-
return parseFloat(value);
|
|
19
|
-
}
|
|
20
|
-
return 0;
|
|
21
|
-
}
|
|
22
|
-
/**
|
|
23
|
-
* Non-reactive media queries function
|
|
24
|
-
* Use this in JavaScript code when you need a one-time check
|
|
25
|
-
* @param {...Array<["min"|"max", string]>} args - ex: [ ["min", "xs"], ["max", "lg"] ]
|
|
26
|
-
* @returns {boolean}
|
|
27
|
-
*/
|
|
28
|
-
export function mediaQueries(...args) {
|
|
29
|
-
const bp = get(breakpoints);
|
|
30
|
-
const width = get(viewportWidth) || (typeof window !== 'undefined' ? window.innerWidth : 0);
|
|
31
|
-
// Parse arguments
|
|
32
|
-
let queries = [];
|
|
33
|
-
if (Array.isArray(args[0]) && typeof args[0][0] === 'string') {
|
|
34
|
-
queries = args;
|
|
35
|
-
}
|
|
36
|
-
else if (typeof args[0] === 'string') {
|
|
37
|
-
queries = [args];
|
|
38
|
-
}
|
|
39
|
-
let result = true;
|
|
40
|
-
for (const [type, key] of queries) {
|
|
41
|
-
const value = bp[key];
|
|
42
|
-
const px = toPx(value);
|
|
43
|
-
if (type === 'min') {
|
|
44
|
-
result = result && width >= px;
|
|
45
|
-
}
|
|
46
|
-
else if (type === 'max') {
|
|
47
|
-
result = result && width <= px;
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
return result;
|
|
51
|
-
}
|
|
52
|
-
/**
|
|
53
|
-
* Reactive media queries that returns a store
|
|
54
|
-
* Use this in Svelte templates for automatic reactivity
|
|
55
|
-
* @param {...Array<["min"|"max", string]>} args - ex: [ ["min", "xs"], ["max", "lg"] ]
|
|
56
|
-
* @returns {import('svelte/store').Readable<boolean>}
|
|
57
|
-
*/
|
|
58
|
-
export function mediaQueriesReactive(...args) {
|
|
59
|
-
return derived([breakpoints, viewportWidth], ([$breakpoints, $viewportWidth]) => {
|
|
60
|
-
const width = $viewportWidth || (typeof window !== 'undefined' ? window.innerWidth : 0);
|
|
61
|
-
// Parse arguments same way as non-reactive version
|
|
62
|
-
let queries = [];
|
|
63
|
-
if (Array.isArray(args[0]) && typeof args[0][0] === 'string') {
|
|
64
|
-
queries = args;
|
|
65
|
-
}
|
|
66
|
-
else if (typeof args[0] === 'string') {
|
|
67
|
-
queries = [args];
|
|
68
|
-
}
|
|
69
|
-
let result = true;
|
|
70
|
-
for (const [type, key] of queries) {
|
|
71
|
-
const value = $breakpoints[key];
|
|
72
|
-
const px = toPx(value);
|
|
73
|
-
if (type === 'min') {
|
|
74
|
-
result = result && width >= px;
|
|
75
|
-
}
|
|
76
|
-
else if (type === 'max') {
|
|
77
|
-
result = result && width <= px;
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
return result;
|
|
81
|
-
});
|
|
82
|
-
}
|
|
83
|
-
/**
|
|
84
|
-
* Convenient function for direct use in Svelte templates
|
|
85
|
-
* Returns a readable store that updates automatically
|
|
86
|
-
* Usage: $mediaQuery(['min', 'md']) in template
|
|
87
|
-
*/
|
|
88
|
-
export const mediaQuery = mediaQueriesReactive;
|