lapikit 0.0.0-insiders.f8b6426 → 0.0.0-insiders.fb12c48
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 +303 -0
- package/bin/helper.js +0 -38
- package/bin/index.js +33 -0
- package/bin/presets.js +26 -0
- package/bin/prompts.js +67 -0
- package/dist/actions/accordion.svelte.d.ts +9 -0
- package/dist/actions/index.d.ts +2 -1
- package/dist/actions/index.js +2 -1
- package/dist/actions/use-theme.d.ts +1 -0
- package/dist/actions/use-theme.js +18 -0
- package/dist/components/accordion/accordion.css +0 -77
- package/dist/components/accordion/accordion.svelte +5 -3
- package/dist/components/accordion/modules/accordion-item.css +68 -0
- package/dist/components/accordion/modules/accordion-item.svelte +4 -4
- package/dist/components/accordion/types.d.ts +1 -1
- package/dist/components/alert/alert.css +11 -18
- package/dist/components/alert/alert.svelte +4 -4
- package/dist/components/alert/types.d.ts +1 -1
- package/dist/components/app/app.css +1 -2
- package/dist/components/app/app.svelte +39 -21
- package/dist/components/app/app.svelte.d.ts +2 -0
- package/dist/components/appbar/appbar.css +8 -18
- package/dist/components/appbar/appbar.svelte +4 -4
- package/dist/components/appbar/types.d.ts +1 -1
- package/dist/components/aspect-ratio/aspect-ratio.svelte +0 -22
- package/dist/components/aspect-ratio/types.d.ts +1 -1
- package/dist/components/avatar/avatar.css +7 -14
- package/dist/components/avatar/avatar.svelte +4 -4
- package/dist/components/avatar/types.d.ts +1 -1
- package/dist/components/button/button.css +29 -36
- package/dist/components/button/button.svelte +5 -5
- package/dist/components/button/types.d.ts +1 -1
- package/dist/components/card/card.css +10 -20
- package/dist/components/card/card.svelte +9 -5
- package/dist/components/card/types.d.ts +3 -1
- package/dist/components/chip/chip.css +30 -37
- package/dist/components/chip/chip.svelte +10 -8
- package/dist/components/chip/types.d.ts +2 -1
- package/dist/components/dialog/dialog.css +15 -20
- package/dist/components/dialog/dialog.svelte +5 -5
- package/dist/components/dialog/types.d.ts +1 -1
- package/dist/components/dropdown/dropdown.css +3 -12
- package/dist/components/dropdown/dropdown.svelte +6 -7
- package/dist/components/dropdown/types.d.ts +1 -1
- package/dist/components/icon/icon.css +11 -12
- package/dist/components/icon/icon.svelte +2 -2
- package/dist/components/icon/types.d.ts +1 -1
- package/dist/components/list/list.css +19 -91
- package/dist/components/list/list.svelte +4 -4
- package/dist/components/list/modules/list-item.css +67 -0
- package/dist/components/list/modules/list-item.svelte +5 -5
- package/dist/components/list/types.d.ts +1 -1
- package/dist/components/modal/modal.css +22 -29
- package/dist/components/modal/modal.svelte +4 -5
- package/dist/components/modal/types.d.ts +1 -1
- package/dist/components/popover/popover.css +3 -12
- package/dist/components/popover/popover.svelte +6 -6
- package/dist/components/popover/types.d.ts +1 -1
- package/dist/components/separator/separator.css +4 -8
- package/dist/components/separator/separator.svelte +5 -5
- package/dist/components/separator/types.d.ts +1 -1
- package/dist/components/spacer/types.d.ts +1 -1
- package/dist/components/textfield/textfield.css +16 -23
- package/dist/components/textfield/textfield.svelte +4 -4
- package/dist/components/textfield/types.d.ts +1 -1
- package/dist/components/toolbar/toolbar.css +11 -34
- package/dist/components/toolbar/toolbar.svelte +4 -4
- package/dist/components/toolbar/types.d.ts +1 -1
- package/dist/components/tooltip/tooltip.css +5 -13
- package/dist/components/tooltip/tooltip.svelte +5 -5
- package/dist/components/tooltip/types.d.ts +1 -1
- package/dist/index.d.ts +3 -1
- package/dist/index.js +23 -3
- package/dist/internal/config/presets.d.ts +149 -0
- package/dist/internal/config/presets.js +169 -0
- package/dist/internal/config/variables.d.ts +3 -0
- package/dist/internal/config/variables.js +3 -0
- package/dist/internal/{assets.svelte.js → core/actions/assets.svelte.js} +4 -4
- package/dist/internal/core/actions/dropdown.svelte.d.ts +7 -0
- package/dist/internal/core/actions/popover.svelte.d.ts +7 -0
- package/dist/internal/core/actions/tooltip.svelte.d.ts +7 -0
- package/dist/internal/{ripple.js → core/animations/ripple.js} +3 -3
- package/dist/internal/core/css.d.ts +1 -0
- package/dist/internal/core/css.js +16 -0
- package/dist/internal/core/formatter/component.d.ts +5 -0
- package/dist/internal/core/formatter/component.js +60 -0
- package/dist/internal/core/formatter/device.d.ts +5 -0
- package/dist/internal/core/formatter/device.js +66 -0
- package/dist/internal/core/formatter/index.d.ts +7 -0
- package/dist/internal/core/formatter/index.js +35 -0
- package/dist/internal/core/formatter/style.d.ts +4 -0
- package/dist/internal/core/formatter/style.js +15 -0
- package/dist/internal/core/formatter/theme.d.ts +5 -0
- package/dist/internal/core/formatter/theme.js +44 -0
- package/dist/internal/core/formatter/typography.d.ts +5 -0
- package/dist/internal/core/formatter/typography.js +12 -0
- package/dist/internal/core/standard-colors.d.ts +75 -0
- package/dist/internal/core/standard-colors.js +75 -0
- package/dist/internal/helpers/colors.d.ts +1 -0
- package/dist/internal/{colors.js → helpers/colors.js} +2 -2
- package/dist/internal/helpers/convert.d.ts +1 -0
- package/dist/internal/helpers/convert.js +17 -0
- package/dist/internal/helpers/deep-merge.d.ts +44 -0
- package/dist/internal/helpers/deep-merge.js +80 -0
- package/dist/internal/helpers/parser.d.ts +10 -0
- package/dist/internal/helpers/parser.js +93 -0
- package/dist/internal/plugins/vite.d.ts +8 -0
- package/dist/internal/plugins/vite.js +33 -0
- package/dist/internal/types/components.d.ts +14 -0
- package/dist/internal/types/configuration.d.ts +63 -0
- package/dist/internal/types/configuration.js +1 -0
- package/dist/internal/types/index.d.ts +2 -0
- package/dist/internal/types/index.js +2 -0
- package/dist/stores/breakpoints.d.ts +6 -0
- package/dist/stores/breakpoints.js +14 -0
- 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 +5 -10
- package/dist/stores/index.js +5 -47
- package/dist/stores/themes.d.ts +2 -0
- package/dist/stores/themes.js +4 -0
- package/dist/stores/viewport.d.ts +7 -0
- package/dist/stores/viewport.js +7 -0
- package/dist/styles/animation.css +33 -0
- package/dist/styles/keyframes.css +30 -0
- package/dist/{style/normalize.css → styles/reset.css} +15 -7
- package/dist/themes.css +0 -0
- package/package.json +12 -5
- package/bin/lapikit.js +0 -79
- package/bin/modules/adapter.js +0 -52
- package/bin/modules/plugin.js +0 -66
- package/bin/modules/preset.js +0 -11
- package/dist/internal/colors.d.ts +0 -1
- package/dist/internal/index.d.ts +0 -4
- package/dist/internal/index.js +0 -4
- package/dist/internal/types.d.ts +0 -57
- package/dist/internal/unit.d.ts +0 -1
- package/dist/internal/unit.js +0 -11
- package/dist/plugin/modules/config.d.ts +0 -2
- package/dist/plugin/modules/config.js +0 -54
- package/dist/plugin/modules/importer.d.ts +0 -1
- package/dist/plugin/modules/importer.js +0 -15
- package/dist/plugin/vitejs.d.ts +0 -6
- package/dist/plugin/vitejs.js +0 -26
- package/dist/preset.d.ts +0 -2
- package/dist/preset.js +0 -92
- package/dist/style/animation.css +0 -62
- package/dist/style/css.d.ts +0 -2
- package/dist/style/css.js +0 -34
- package/dist/style/parser/color.d.ts +0 -5
- package/dist/style/parser/color.js +0 -88
- package/dist/style/parser/component.d.ts +0 -2
- package/dist/style/parser/component.js +0 -115
- package/dist/style/parser/device.d.ts +0 -2
- package/dist/style/parser/device.js +0 -40
- package/dist/style/parser/index.d.ts +0 -4
- package/dist/style/parser/index.js +0 -4
- package/dist/style/parser/variable.d.ts +0 -2
- package/dist/style/parser/variable.js +0 -25
- package/dist/style/variable.css +0 -12
- /package/dist/{components/accordion → actions}/accordion.svelte.js +0 -0
- /package/dist/internal/{assets.svelte.d.ts → core/actions/assets.svelte.d.ts} +0 -0
- /package/dist/{components/dropdown → internal/core/actions}/dropdown.svelte.js +0 -0
- /package/dist/{components/popover → internal/core/actions}/popover.svelte.js +0 -0
- /package/dist/{components/tooltip → internal/core/actions}/tooltip.svelte.js +0 -0
- /package/dist/internal/{ripple.d.ts → core/animations/ripple.d.ts} +0 -0
- /package/dist/internal/{ansi.d.ts → core/bin/ansi.d.ts} +0 -0
- /package/dist/internal/{ansi.js → core/bin/ansi.js} +0 -0
- /package/dist/internal/{terminal.d.ts → core/bin/terminal.d.ts} +0 -0
- /package/dist/internal/{terminal.js → core/bin/terminal.js} +0 -0
- /package/dist/internal/{minify.d.ts → core/minify.d.ts} +0 -0
- /package/dist/internal/{minify.js → core/minify.js} +0 -0
- /package/dist/{utils/x11.d.ts → internal/core/x11-colors.d.ts} +0 -0
- /package/dist/{utils/x11.js → internal/core/x11-colors.js} +0 -0
- /package/dist/internal/{clickOutside.d.ts → helpers/outside.d.ts} +0 -0
- /package/dist/internal/{clickOutside.js → helpers/outside.js} +0 -0
- /package/dist/internal/{scroll.d.ts → helpers/scroll.d.ts} +0 -0
- /package/dist/internal/{scroll.js → helpers/scroll.js} +0 -0
- /package/dist/internal/{types.js → types/components.js} +0 -0
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { fileURLToPath } from 'url';
|
|
2
|
+
import { dirname } from 'path';
|
|
3
|
+
import fs from 'fs';
|
|
4
|
+
import path from 'path';
|
|
5
|
+
import { parserCSSBreakpoints } from '../../helpers/parser.js';
|
|
6
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
7
|
+
const __dirname = dirname(__filename);
|
|
8
|
+
export async function componentFormatter({ breakpoints }) {
|
|
9
|
+
// load svelte component files (includes on components folders)
|
|
10
|
+
function loadSvelteFiles(directory) {
|
|
11
|
+
fs.readdirSync(directory).forEach((File) => {
|
|
12
|
+
const absolutePath = path.join(directory, File);
|
|
13
|
+
if (fs.statSync(absolutePath).isDirectory())
|
|
14
|
+
return loadSvelteFiles(absolutePath);
|
|
15
|
+
else if (absolutePath.endsWith('.css') && !absolutePath.includes('/_')) {
|
|
16
|
+
const fileCSS = fs.readFileSync(absolutePath, 'utf8');
|
|
17
|
+
const content = parserCSSBreakpoints(fileCSS);
|
|
18
|
+
let css = `${content.cleaned}\n`;
|
|
19
|
+
for (const property in breakpoints) {
|
|
20
|
+
if (property !== 'base') {
|
|
21
|
+
const name = `.${/^\d/.test(property) ? `\\3${property}` : property}\\:`;
|
|
22
|
+
const value = typeof breakpoints[property] === 'number'
|
|
23
|
+
? `${breakpoints[property]}px`
|
|
24
|
+
: breakpoints[property];
|
|
25
|
+
if (content.base !== '' || content.minmax !== '' || content.min !== '') {
|
|
26
|
+
css += `\n@media screen and (min-width: ${value}) {\n`;
|
|
27
|
+
if (content.base !== '')
|
|
28
|
+
css += content.base.replaceAll('[breakpoint]', name);
|
|
29
|
+
if (content.minmax !== '')
|
|
30
|
+
css += content.minmax.replaceAll('[breakpoint]', name);
|
|
31
|
+
if (content.min !== '')
|
|
32
|
+
css += content.min.replaceAll('[breakpoint]', name);
|
|
33
|
+
css += `\n}\n`;
|
|
34
|
+
}
|
|
35
|
+
if (content.max !== '' || content.minmax !== '') {
|
|
36
|
+
css += `\n@media screen and (max-width: ${value}) {\n`;
|
|
37
|
+
if (content.max !== '')
|
|
38
|
+
css += content.max.replaceAll('[breakpoint]', `max\\:${name}`);
|
|
39
|
+
if (content.minmax !== '')
|
|
40
|
+
css += content.all.replaceAll('[breakpoint]', `max\\:${name}`);
|
|
41
|
+
css += `\n}\n`;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
css += `${content.base.replaceAll('[breakpoint]', '.')}\n`;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
const baseName = path.basename(absolutePath, '.css');
|
|
49
|
+
const svelteFilePath = path.join(path.dirname(absolutePath), `${baseName}.svelte`);
|
|
50
|
+
if (fs.existsSync(svelteFilePath)) {
|
|
51
|
+
let svelteContent = fs.readFileSync(svelteFilePath, 'utf8');
|
|
52
|
+
svelteContent = svelteContent.replace(/<style[^>]*>[\s\S]*?<\/style>/gi, '');
|
|
53
|
+
svelteContent += `<style>\n${css}</style>`;
|
|
54
|
+
fs.writeFileSync(svelteFilePath, svelteContent, 'utf8');
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
loadSvelteFiles(path.resolve(__dirname, '../../../components'));
|
|
60
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { parserValues } from '../../helpers/parser.js';
|
|
2
|
+
export async function devicesFormatter({ devices }) {
|
|
3
|
+
let css = ``;
|
|
4
|
+
const sortedDevices = Object.entries(devices).sort(([, a], [, b]) => {
|
|
5
|
+
const valueA = typeof a === 'string' ? parseInt(a) : a;
|
|
6
|
+
const valueB = typeof b === 'string' ? parseInt(b) : b;
|
|
7
|
+
return valueB - valueA;
|
|
8
|
+
});
|
|
9
|
+
sortedDevices.forEach(([deviceName, breakpoint], index) => {
|
|
10
|
+
const value = parserValues(breakpoint);
|
|
11
|
+
if (index === 0) {
|
|
12
|
+
// the largest device
|
|
13
|
+
css += `@media (max-width: ${value}) {\n`;
|
|
14
|
+
css += ` .kit-device--d-${deviceName} {\n`;
|
|
15
|
+
css += ` display: none !important;\n`;
|
|
16
|
+
css += ` }\n`;
|
|
17
|
+
css += `}\n\n`;
|
|
18
|
+
css += `@media (min-width: ${value}) {\n`;
|
|
19
|
+
css += ` .kit-device--h-${deviceName} {\n`;
|
|
20
|
+
css += ` display: none !important;\n`;
|
|
21
|
+
css += ` }\n`;
|
|
22
|
+
css += `}\n\n`;
|
|
23
|
+
}
|
|
24
|
+
else if (index === sortedDevices.length - 1) {
|
|
25
|
+
const prevDevice = sortedDevices[index - 1];
|
|
26
|
+
const prevValue = parserValues(prevDevice[1]);
|
|
27
|
+
// the smallest device
|
|
28
|
+
css += `@media (min-width: ${prevValue}) {\n`;
|
|
29
|
+
css += ` .kit-device--d-${deviceName} {\n`;
|
|
30
|
+
css += ` display: none !important;\n`;
|
|
31
|
+
css += ` }\n`;
|
|
32
|
+
css += `}\n\n`;
|
|
33
|
+
css += `@media (max-width: ${prevValue}) {\n`;
|
|
34
|
+
css += ` .kit-device--h-${deviceName} {\n`;
|
|
35
|
+
css += ` display: none !important;\n`;
|
|
36
|
+
css += ` }\n`;
|
|
37
|
+
css += `}\n\n`;
|
|
38
|
+
css += `@media (min-width: ${value}) {\n`;
|
|
39
|
+
css += ` .kit-device--od-${deviceName} {\n`;
|
|
40
|
+
css += ` display: none !important;\n`;
|
|
41
|
+
css += ` }\n`;
|
|
42
|
+
css += `}\n\n`;
|
|
43
|
+
css += `@media (max-width: ${value}) {\n`;
|
|
44
|
+
css += ` .kit-device--oh-${deviceName} {\n`;
|
|
45
|
+
css += ` display: none !important;\n`;
|
|
46
|
+
css += ` }\n`;
|
|
47
|
+
css += `}\n\n`;
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
//intermediate devices
|
|
51
|
+
const nextDevice = sortedDevices[index - 1];
|
|
52
|
+
const nextValue = parserValues(nextDevice[1]);
|
|
53
|
+
css += `@media (max-width: ${value}) {\n`;
|
|
54
|
+
css += ` .kit-device--d-${deviceName} {\n`;
|
|
55
|
+
css += ` display: none !important;\n`;
|
|
56
|
+
css += ` }\n`;
|
|
57
|
+
css += `}\n\n`;
|
|
58
|
+
css += `@media (min-width: ${nextValue}) {\n`;
|
|
59
|
+
css += ` .kit-device--h-${deviceName} {\n`;
|
|
60
|
+
css += ` display: none !important;\n`;
|
|
61
|
+
css += ` }\n`;
|
|
62
|
+
css += `}\n\n`;
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
return css.trim();
|
|
66
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { preset } from '../../config/presets.js';
|
|
2
|
+
import { deepMerge } from '../../helpers/deep-merge.js';
|
|
3
|
+
import { componentFormatter } from './component.js';
|
|
4
|
+
import { devicesFormatter } from './device.js';
|
|
5
|
+
import { stylesFormatter } from './style.js';
|
|
6
|
+
import { themesFormatter } from './theme.js';
|
|
7
|
+
import { typographyFormatter } from './typography.js';
|
|
8
|
+
export async function liliRabbit(config) {
|
|
9
|
+
// states
|
|
10
|
+
const defaultTheme = config?.theme?.defaultTheme || preset.theme.defaultTheme;
|
|
11
|
+
const defaultTypography = config?.typography?.defaultTypography || preset.typography.defaultTypography;
|
|
12
|
+
// formatter
|
|
13
|
+
const themes = await themesFormatter({
|
|
14
|
+
themes: deepMerge(preset.theme.themes, config?.theme?.themes || {}),
|
|
15
|
+
defaultTheme
|
|
16
|
+
});
|
|
17
|
+
const typography = await typographyFormatter({
|
|
18
|
+
typography: deepMerge(preset.typography.fonts, config?.typography?.fonts || {}),
|
|
19
|
+
defaultTypography
|
|
20
|
+
});
|
|
21
|
+
const styles = await stylesFormatter({ styles: deepMerge(preset.styles, config?.styles || {}) });
|
|
22
|
+
const devices = await devicesFormatter({
|
|
23
|
+
devices: deepMerge(preset.breakpoints.devices, config?.breakpoints?.devices || {})
|
|
24
|
+
});
|
|
25
|
+
// components
|
|
26
|
+
await componentFormatter({
|
|
27
|
+
breakpoints: deepMerge(preset.breakpoints.thresholds, config?.breakpoints?.thresholds || {})
|
|
28
|
+
});
|
|
29
|
+
return {
|
|
30
|
+
themes: themes,
|
|
31
|
+
typography: typography,
|
|
32
|
+
styles: styles,
|
|
33
|
+
devices: devices
|
|
34
|
+
};
|
|
35
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { parserValues } from '../../helpers/parser.js';
|
|
2
|
+
export async 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 += ` --system-${name}-${styleName}: ${parserValues(styleValue)};\n`;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
else {
|
|
11
|
+
css += ` --system-${name}: ${parserValues(values)};\n`;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
return (css += '}\n');
|
|
15
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { preset } from '../../config/presets.js';
|
|
2
|
+
import { formatColor } from '../../helpers/colors.js';
|
|
3
|
+
import { deepMerge } from '../../helpers/deep-merge.js';
|
|
4
|
+
import { parserValues } from '../../helpers/parser.js';
|
|
5
|
+
export async function themesFormatter({ themes, defaultTheme = 'light' }) {
|
|
6
|
+
let css = '';
|
|
7
|
+
for (const [name, values] of Object.entries(themes)) {
|
|
8
|
+
const ref = values?.dark ? preset.theme.themes.dark : preset.theme.themes.light;
|
|
9
|
+
let cssTheme = defaultTheme === name ? `:root,\n.kit-theme--${name} {\n` : `.kit-theme--${name} {\n`;
|
|
10
|
+
function flattenColors(obj, prefix = '') {
|
|
11
|
+
const result = {};
|
|
12
|
+
for (const [key, value] of Object.entries(obj)) {
|
|
13
|
+
const newPrefix = prefix ? `${prefix}-${key}` : key;
|
|
14
|
+
if (typeof value === 'object' && value !== null && !Array.isArray(value)) {
|
|
15
|
+
Object.assign(result, flattenColors(value, newPrefix));
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
result[newPrefix] = value;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return result;
|
|
22
|
+
}
|
|
23
|
+
// colors
|
|
24
|
+
cssTheme += ` color-scheme: ${values?.dark ? 'dark' : 'light'};\n`;
|
|
25
|
+
const mergedColors = deepMerge(ref.colors, values?.colors) || {};
|
|
26
|
+
const flatColors = flattenColors(mergedColors);
|
|
27
|
+
for (const [varName, varValue] of Object.entries(flatColors)) {
|
|
28
|
+
cssTheme += ` --kit-${varName}: ${formatColor(varValue)};\n`;
|
|
29
|
+
}
|
|
30
|
+
// variables
|
|
31
|
+
for (const [name, varValue] of Object.entries(deepMerge(ref.variables, values?.variables) || {})) {
|
|
32
|
+
if (varValue && typeof varValue === 'object') {
|
|
33
|
+
for (const [variableName, variableValue] of Object.entries(varValue || {})) {
|
|
34
|
+
cssTheme += ` --kit-${name}-${variableName}: ${formatColor(parserValues(variableValue))};\n`;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
cssTheme += ` --kit-${name}: ${formatColor(parserValues(varValue))};\n`;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
css += cssTheme + '}\n';
|
|
42
|
+
}
|
|
43
|
+
return css;
|
|
44
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { parserValues } from '../../helpers/parser.js';
|
|
2
|
+
export async 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).replaceAll('"', '')};\n`;
|
|
8
|
+
}
|
|
9
|
+
css += cssTypo + '}\n';
|
|
10
|
+
}
|
|
11
|
+
return css;
|
|
12
|
+
}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
export declare const standardColors: {
|
|
2
|
+
red: {
|
|
3
|
+
light: string;
|
|
4
|
+
dark: string;
|
|
5
|
+
};
|
|
6
|
+
orange: {
|
|
7
|
+
light: string;
|
|
8
|
+
dark: string;
|
|
9
|
+
};
|
|
10
|
+
yellow: {
|
|
11
|
+
light: string;
|
|
12
|
+
dark: string;
|
|
13
|
+
};
|
|
14
|
+
green: {
|
|
15
|
+
light: string;
|
|
16
|
+
dark: string;
|
|
17
|
+
};
|
|
18
|
+
mint: {
|
|
19
|
+
light: string;
|
|
20
|
+
dark: string;
|
|
21
|
+
};
|
|
22
|
+
teal: {
|
|
23
|
+
light: string;
|
|
24
|
+
dark: string;
|
|
25
|
+
};
|
|
26
|
+
cyan: {
|
|
27
|
+
light: string;
|
|
28
|
+
dark: string;
|
|
29
|
+
};
|
|
30
|
+
blue: {
|
|
31
|
+
light: string;
|
|
32
|
+
dark: string;
|
|
33
|
+
};
|
|
34
|
+
indigo: {
|
|
35
|
+
light: string;
|
|
36
|
+
dark: string;
|
|
37
|
+
};
|
|
38
|
+
purple: {
|
|
39
|
+
light: string;
|
|
40
|
+
dark: string;
|
|
41
|
+
};
|
|
42
|
+
pink: {
|
|
43
|
+
light: string;
|
|
44
|
+
dark: string;
|
|
45
|
+
};
|
|
46
|
+
brown: {
|
|
47
|
+
light: string;
|
|
48
|
+
dark: string;
|
|
49
|
+
};
|
|
50
|
+
gray: {
|
|
51
|
+
light: string;
|
|
52
|
+
dark: string;
|
|
53
|
+
};
|
|
54
|
+
gray2: {
|
|
55
|
+
light: string;
|
|
56
|
+
dark: string;
|
|
57
|
+
};
|
|
58
|
+
gray3: {
|
|
59
|
+
light: string;
|
|
60
|
+
dark: string;
|
|
61
|
+
};
|
|
62
|
+
gray4: {
|
|
63
|
+
light: string;
|
|
64
|
+
dark: string;
|
|
65
|
+
};
|
|
66
|
+
gray5: {
|
|
67
|
+
light: string;
|
|
68
|
+
dark: string;
|
|
69
|
+
};
|
|
70
|
+
gray6: {
|
|
71
|
+
light: string;
|
|
72
|
+
dark: string;
|
|
73
|
+
};
|
|
74
|
+
};
|
|
75
|
+
export default standardColors;
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
export const standardColors = {
|
|
2
|
+
red: {
|
|
3
|
+
light: '#FF3B30',
|
|
4
|
+
dark: '#FF453A'
|
|
5
|
+
},
|
|
6
|
+
orange: {
|
|
7
|
+
light: '#FF9500',
|
|
8
|
+
dark: '#FF9F0A'
|
|
9
|
+
},
|
|
10
|
+
yellow: {
|
|
11
|
+
light: '#FFCC00',
|
|
12
|
+
dark: '#FFD60A'
|
|
13
|
+
},
|
|
14
|
+
green: {
|
|
15
|
+
light: '#34C759',
|
|
16
|
+
dark: '#30D158'
|
|
17
|
+
},
|
|
18
|
+
mint: {
|
|
19
|
+
light: '#00C7BE',
|
|
20
|
+
dark: '#66D4CF'
|
|
21
|
+
},
|
|
22
|
+
teal: {
|
|
23
|
+
light: '#30B0C7',
|
|
24
|
+
dark: '#40CBE0'
|
|
25
|
+
},
|
|
26
|
+
cyan: {
|
|
27
|
+
light: '#32ADE6',
|
|
28
|
+
dark: '#64D2FF'
|
|
29
|
+
},
|
|
30
|
+
blue: {
|
|
31
|
+
light: '#007AFF',
|
|
32
|
+
dark: '#0A84FF'
|
|
33
|
+
},
|
|
34
|
+
indigo: {
|
|
35
|
+
light: '#5856D6',
|
|
36
|
+
dark: '#5E5CE6'
|
|
37
|
+
},
|
|
38
|
+
purple: {
|
|
39
|
+
light: '#AF52DE',
|
|
40
|
+
dark: '#BF5AF2'
|
|
41
|
+
},
|
|
42
|
+
pink: {
|
|
43
|
+
light: '#FF2D55',
|
|
44
|
+
dark: '#FF375F'
|
|
45
|
+
},
|
|
46
|
+
brown: {
|
|
47
|
+
light: '#A2845E',
|
|
48
|
+
dark: '#AC8E68'
|
|
49
|
+
},
|
|
50
|
+
gray: {
|
|
51
|
+
light: '#8E8E93',
|
|
52
|
+
dark: '#8E8E93'
|
|
53
|
+
},
|
|
54
|
+
gray2: {
|
|
55
|
+
light: '#AEAEB2',
|
|
56
|
+
dark: '#636366'
|
|
57
|
+
},
|
|
58
|
+
gray3: {
|
|
59
|
+
light: '#C7C7CC',
|
|
60
|
+
dark: '#48484A'
|
|
61
|
+
},
|
|
62
|
+
gray4: {
|
|
63
|
+
light: '#D1D1D6',
|
|
64
|
+
dark: '#3A3A3C'
|
|
65
|
+
},
|
|
66
|
+
gray5: {
|
|
67
|
+
light: '#E5E5EA',
|
|
68
|
+
dark: '#2C2C2E'
|
|
69
|
+
},
|
|
70
|
+
gray6: {
|
|
71
|
+
light: '#F2F2F7',
|
|
72
|
+
dark: '#1C1C1E'
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
export default standardColors;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const formatColor: (input: string) => string;
|
|
@@ -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
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Recursively merges two objects together.
|
|
3
|
+
* Properties from the source object override those from the target object.
|
|
4
|
+
* Nested objects are merged recursively.
|
|
5
|
+
*
|
|
6
|
+
* @param target - The base object
|
|
7
|
+
* @param source - The source object to merge (can be null or undefined)
|
|
8
|
+
* @returns A new object containing the merge of both objects
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* ```typescript
|
|
12
|
+
* const obj1 = { primary: { light: 'pink', medium: 'purple' } };
|
|
13
|
+
* const obj2 = { primary: { dark: 'red' } };
|
|
14
|
+
* const result = deepMerge(obj1, obj2);
|
|
15
|
+
* // Result: { primary: { light: 'pink', medium: 'purple', dark: 'red' } }
|
|
16
|
+
*
|
|
17
|
+
* // Works with null/undefined source
|
|
18
|
+
* const result2 = deepMerge(obj1, null);
|
|
19
|
+
* // Result: { primary: { light: 'pink', medium: 'purple' } }
|
|
20
|
+
* ```
|
|
21
|
+
*/
|
|
22
|
+
export declare function deepMerge<T extends Record<string, unknown>, U extends Record<string, unknown>>(target: T, source: U | null | undefined): T & U;
|
|
23
|
+
/**
|
|
24
|
+
* Merges multiple objects together recursively.
|
|
25
|
+
*
|
|
26
|
+
* @param objects - The objects to merge (null and undefined values are ignored)
|
|
27
|
+
* @returns A new object containing the merge of all objects
|
|
28
|
+
*
|
|
29
|
+
* @example
|
|
30
|
+
* ```typescript
|
|
31
|
+
* const result = deepMergeMultiple(
|
|
32
|
+
* { primary: { light: 'pink' } },
|
|
33
|
+
* null,
|
|
34
|
+
* { primary: { dark: 'red' } },
|
|
35
|
+
* undefined,
|
|
36
|
+
* { secondary: { light: 'blue' } }
|
|
37
|
+
* );
|
|
38
|
+
* // Result: {
|
|
39
|
+
* // primary: { light: 'pink', dark: 'red' },
|
|
40
|
+
* // secondary: { light: 'blue' }
|
|
41
|
+
* // }
|
|
42
|
+
* ```
|
|
43
|
+
*/
|
|
44
|
+
export declare function deepMergeMultiple(...objects: (Record<string, unknown> | null | undefined)[]): Record<string, unknown>;
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Checks if a value is a plain object (object literal)
|
|
3
|
+
*/
|
|
4
|
+
function isPlainObject(value) {
|
|
5
|
+
return (value !== null &&
|
|
6
|
+
typeof value === 'object' &&
|
|
7
|
+
Object.prototype.toString.call(value) === '[object Object]');
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* Recursively merges two objects together.
|
|
11
|
+
* Properties from the source object override those from the target object.
|
|
12
|
+
* Nested objects are merged recursively.
|
|
13
|
+
*
|
|
14
|
+
* @param target - The base object
|
|
15
|
+
* @param source - The source object to merge (can be null or undefined)
|
|
16
|
+
* @returns A new object containing the merge of both objects
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* ```typescript
|
|
20
|
+
* const obj1 = { primary: { light: 'pink', medium: 'purple' } };
|
|
21
|
+
* const obj2 = { primary: { dark: 'red' } };
|
|
22
|
+
* const result = deepMerge(obj1, obj2);
|
|
23
|
+
* // Result: { primary: { light: 'pink', medium: 'purple', dark: 'red' } }
|
|
24
|
+
*
|
|
25
|
+
* // Works with null/undefined source
|
|
26
|
+
* const result2 = deepMerge(obj1, null);
|
|
27
|
+
* // Result: { primary: { light: 'pink', medium: 'purple' } }
|
|
28
|
+
* ```
|
|
29
|
+
*/
|
|
30
|
+
export function deepMerge(target, source) {
|
|
31
|
+
// If source is null or undefined, return a copy of target
|
|
32
|
+
if (source == null) {
|
|
33
|
+
return { ...target };
|
|
34
|
+
}
|
|
35
|
+
// Create a copy of the target object to avoid mutations
|
|
36
|
+
const result = { ...target };
|
|
37
|
+
for (const key in source) {
|
|
38
|
+
if (Object.prototype.hasOwnProperty.call(source, key)) {
|
|
39
|
+
const sourceValue = source[key];
|
|
40
|
+
const targetValue = result[key];
|
|
41
|
+
// If both values are plain objects, merge them recursively
|
|
42
|
+
if (isPlainObject(targetValue) && isPlainObject(sourceValue)) {
|
|
43
|
+
result[key] = deepMerge(targetValue, sourceValue);
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
// Otherwise, the source value overrides the target value
|
|
47
|
+
result[key] = sourceValue;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
return result;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Merges multiple objects together recursively.
|
|
55
|
+
*
|
|
56
|
+
* @param objects - The objects to merge (null and undefined values are ignored)
|
|
57
|
+
* @returns A new object containing the merge of all objects
|
|
58
|
+
*
|
|
59
|
+
* @example
|
|
60
|
+
* ```typescript
|
|
61
|
+
* const result = deepMergeMultiple(
|
|
62
|
+
* { primary: { light: 'pink' } },
|
|
63
|
+
* null,
|
|
64
|
+
* { primary: { dark: 'red' } },
|
|
65
|
+
* undefined,
|
|
66
|
+
* { secondary: { light: 'blue' } }
|
|
67
|
+
* );
|
|
68
|
+
* // Result: {
|
|
69
|
+
* // primary: { light: 'pink', dark: 'red' },
|
|
70
|
+
* // secondary: { light: 'blue' }
|
|
71
|
+
* // }
|
|
72
|
+
* ```
|
|
73
|
+
*/
|
|
74
|
+
export function deepMergeMultiple(...objects) {
|
|
75
|
+
return objects
|
|
76
|
+
.filter((obj) => obj != null)
|
|
77
|
+
.reduce((acc, obj) => {
|
|
78
|
+
return deepMerge(acc, obj);
|
|
79
|
+
}, {});
|
|
80
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export declare const parserValues: (value: string | number | Array<string | number>) => string;
|
|
2
|
+
export declare const parserCSSBreakpoints: (css: string) => {
|
|
3
|
+
all: string;
|
|
4
|
+
base: string;
|
|
5
|
+
min: string;
|
|
6
|
+
max: string;
|
|
7
|
+
minmax: string;
|
|
8
|
+
cleaned: string;
|
|
9
|
+
};
|
|
10
|
+
export declare const parserConfigLapikit: (app: string, filePath: string) => Promise<{}>;
|