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.
@@ -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
- 'sveltekit(), lapikit()'
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() is not already present
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() after sveltekit()
215
+ // Add lapikit after sveltekit()
214
216
  if (pluginLine.includes(',')) {
215
- lines[j] = lines[j].replace('sveltekit()', 'sveltekit(), lapikit()');
217
+ lines[j] = lines[j].replace('sveltekit()', `sveltekit(), ${lapikitPlugin}`);
216
218
  } else {
217
219
  lines[j] = lines[j].replace('sveltekit()', 'sveltekit(),');
218
- // Insert lapikit() on the next line with proper indentation
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}lapikit()`);
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
@@ -8,6 +8,7 @@ function presets({ adapterCSS }) {
8
8
 
9
9
  if (adapterCSS === 'css') {
10
10
  content += `// Styles\n`;
11
+ content += `import 'lapikit/styles';\n`;
11
12
  content += `import 'lapikit/css';\n\n`;
12
13
  }
13
14
 
@@ -1,2 +1 @@
1
1
  export * from '../components/accordion/accordion.svelte.js';
2
- export * from '../internal/mediaQueries.js';
@@ -1,2 +1 @@
1
1
  export * from '../components/accordion/accordion.svelte.js';
2
- export * from '../internal/mediaQueries.js';
File without changes
@@ -4,21 +4,12 @@
4
4
  colorSchemeSystem,
5
5
  modalOpen,
6
6
  setOpenModal,
7
- updateThemeStore,
8
- viewportWidth
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 local = localStorage.getItem('@lapikit/theme');
40
- if (local !== null) updateThemeStore(local as 'dark' | 'light' | 'system');
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
- breakpoints.set(breakpointMerged);
11
- console.log('Breakpoints found:', breakpointMerged);
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
+ };
@@ -1,6 +1,10 @@
1
1
  import type { ViteDevServer } from 'vite';
2
- export declare function lapikit(): Promise<{
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 {};
@@ -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
- export async function lapikit() {
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 config = await importer();
10
- const result = await parseConfig(config);
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
  },
@@ -1,6 +1,6 @@
1
1
  import { type Writable } from 'svelte/store';
2
2
  type Breakpoints = {
3
- [key: string]: number | string;
3
+ [key: string]: number;
4
4
  };
5
5
  export declare const breakpoints: Writable<Breakpoints>;
6
6
  export {};
@@ -3,21 +3,12 @@ import { writable } from 'svelte/store';
3
3
  // presets
4
4
  const ref = {
5
5
  base: 0, // 0px
6
- xs: '28rem', //448px
7
- sm: '40rem', //640px
8
- md: '48rem', //768px
9
- lg: '64rem', //1024px
10
- xl: '80rem', //1280px
11
- '2xl': '96rem', //1536px
12
- '3xl': '112rem' //1792px
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
+ };
@@ -0,0 +1,6 @@
1
+ import { type Writable } from 'svelte/store';
2
+ type Devices = {
3
+ [key: string]: number;
4
+ };
5
+ export declare const devices: Writable<Devices>;
6
+ export {};
@@ -0,0 +1,9 @@
1
+ // store devices
2
+ import { writable } from 'svelte/store';
3
+ // presets
4
+ const ref = {
5
+ desktop: 1024, //64rem (lg)
6
+ tablet: 768, //48rem (md)
7
+ mobile: 375 //28rem (sm)
8
+ };
9
+ export const devices = writable(ref);
@@ -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 './viewports.js';
13
- export { mediaQueries, mediaQueriesReactive, mediaQuery } from '../internal/mediaQueries.js';
2
+ export * from './devices.js';
3
+ export * from './themes.js';
4
+ export * from './components.js';
@@ -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 './viewports.js';
50
- export { mediaQueries, mediaQueriesReactive, mediaQuery } from '../internal/mediaQueries.js';
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.cfec658",
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;
@@ -1,2 +0,0 @@
1
- import { type Writable } from 'svelte/store';
2
- export declare const viewportWidth: Writable<number>;
@@ -1,5 +0,0 @@
1
- // store viewport and screen dimensions
2
- import { writable } from 'svelte/store';
3
- // presets
4
- const refWidth = 0;
5
- export const viewportWidth = writable(refWidth);