@salmexio/ui 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (82) hide show
  1. package/README.md +7 -0
  2. package/dist/app.html +11 -0
  3. package/dist/feedback/Alert/Alert.svelte +538 -0
  4. package/dist/feedback/Alert/Alert.svelte.d.ts +30 -0
  5. package/dist/feedback/Alert/Alert.svelte.d.ts.map +1 -0
  6. package/dist/feedback/Alert/index.d.ts +2 -0
  7. package/dist/feedback/Alert/index.d.ts.map +1 -0
  8. package/dist/feedback/Alert/index.js +1 -0
  9. package/dist/feedback/Spinner/Spinner.svelte +421 -0
  10. package/dist/feedback/Spinner/Spinner.svelte.d.ts +25 -0
  11. package/dist/feedback/Spinner/Spinner.svelte.d.ts.map +1 -0
  12. package/dist/feedback/Spinner/index.d.ts +2 -0
  13. package/dist/feedback/Spinner/index.d.ts.map +1 -0
  14. package/dist/feedback/Spinner/index.js +1 -0
  15. package/dist/feedback/index.d.ts +3 -0
  16. package/dist/feedback/index.d.ts.map +1 -0
  17. package/dist/feedback/index.js +2 -0
  18. package/dist/forms/TextInput/TextInput.svelte +576 -0
  19. package/dist/forms/TextInput/TextInput.svelte.d.ts +50 -0
  20. package/dist/forms/TextInput/TextInput.svelte.d.ts.map +1 -0
  21. package/dist/forms/TextInput/index.d.ts +2 -0
  22. package/dist/forms/TextInput/index.d.ts.map +1 -0
  23. package/dist/forms/TextInput/index.js +1 -0
  24. package/dist/forms/index.d.ts +2 -0
  25. package/dist/forms/index.d.ts.map +1 -0
  26. package/dist/forms/index.js +1 -0
  27. package/dist/index.d.ts +7 -0
  28. package/dist/index.d.ts.map +1 -0
  29. package/dist/index.js +6 -0
  30. package/dist/layout/Card/Card.svelte +283 -0
  31. package/dist/layout/Card/Card.svelte.d.ts +35 -0
  32. package/dist/layout/Card/Card.svelte.d.ts.map +1 -0
  33. package/dist/layout/Card/index.d.ts +2 -0
  34. package/dist/layout/Card/index.d.ts.map +1 -0
  35. package/dist/layout/Card/index.js +1 -0
  36. package/dist/layout/Container/Container.svelte +202 -0
  37. package/dist/layout/Container/Container.svelte.d.ts +25 -0
  38. package/dist/layout/Container/Container.svelte.d.ts.map +1 -0
  39. package/dist/layout/Container/index.d.ts +2 -0
  40. package/dist/layout/Container/index.d.ts.map +1 -0
  41. package/dist/layout/Container/index.js +1 -0
  42. package/dist/layout/index.d.ts +3 -0
  43. package/dist/layout/index.d.ts.map +1 -0
  44. package/dist/layout/index.js +2 -0
  45. package/dist/navigation/Tabs/Tabs.svelte +448 -0
  46. package/dist/navigation/Tabs/Tabs.svelte.d.ts +59 -0
  47. package/dist/navigation/Tabs/Tabs.svelte.d.ts.map +1 -0
  48. package/dist/navigation/Tabs/index.d.ts +3 -0
  49. package/dist/navigation/Tabs/index.d.ts.map +1 -0
  50. package/dist/navigation/Tabs/index.js +1 -0
  51. package/dist/navigation/index.d.ts +3 -0
  52. package/dist/navigation/index.d.ts.map +1 -0
  53. package/dist/navigation/index.js +1 -0
  54. package/dist/primitives/Badge/Badge.svelte +351 -0
  55. package/dist/primitives/Badge/Badge.svelte.d.ts +35 -0
  56. package/dist/primitives/Badge/Badge.svelte.d.ts.map +1 -0
  57. package/dist/primitives/Badge/index.d.ts +2 -0
  58. package/dist/primitives/Badge/index.d.ts.map +1 -0
  59. package/dist/primitives/Badge/index.js +1 -0
  60. package/dist/primitives/Button/Button.svelte +383 -0
  61. package/dist/primitives/Button/Button.svelte.d.ts +47 -0
  62. package/dist/primitives/Button/Button.svelte.d.ts.map +1 -0
  63. package/dist/primitives/Button/index.d.ts +2 -0
  64. package/dist/primitives/Button/index.d.ts.map +1 -0
  65. package/dist/primitives/Button/index.js +1 -0
  66. package/dist/primitives/index.d.ts +3 -0
  67. package/dist/primitives/index.d.ts.map +1 -0
  68. package/dist/primitives/index.js +2 -0
  69. package/dist/routes/+layout.svelte +5 -0
  70. package/dist/routes/+layout.svelte.d.ts +6 -0
  71. package/dist/routes/+layout.svelte.d.ts.map +1 -0
  72. package/dist/routes/+page.svelte +6 -0
  73. package/dist/routes/+page.svelte.d.ts +27 -0
  74. package/dist/routes/+page.svelte.d.ts.map +1 -0
  75. package/dist/styles/tokens.css +340 -0
  76. package/dist/utils/cn.d.ts +9 -0
  77. package/dist/utils/cn.d.ts.map +1 -0
  78. package/dist/utils/cn.js +29 -0
  79. package/dist/utils/index.d.ts +2 -0
  80. package/dist/utils/index.d.ts.map +1 -0
  81. package/dist/utils/index.js +1 -0
  82. package/package.json +84 -0
@@ -0,0 +1,283 @@
1
+ <!--
2
+ @component Card
3
+
4
+ Win2K × Basquiat — Panel with canvas background, bold 3px borders, flat shadow.
5
+ Optional header/footer, interactive mode, semantic element support.
6
+
7
+ @example
8
+ <Card><p>Content</p></Card>
9
+ <Card variant="accent" accentColor="success" header={...} footer={...} />
10
+ -->
11
+ <script lang="ts">
12
+ import type { Snippet } from 'svelte';
13
+ import { cn } from '../../utils/cn.js';
14
+
15
+ type CardPadding = 'none' | 'sm' | 'md' | 'lg' | 'xl';
16
+ type CardVariant = 'default' | 'elevated' | 'outlined' | 'accent';
17
+ type AccentColor = 'primary' | 'success' | 'warning' | 'error' | 'info';
18
+
19
+ interface Props {
20
+ variant?: CardVariant;
21
+ padding?: CardPadding;
22
+ accentColor?: AccentColor;
23
+ interactive?: boolean;
24
+ asButton?: boolean;
25
+ as?: 'div' | 'article' | 'section';
26
+ id?: string;
27
+ ariaLabelledby?: string;
28
+ class?: string;
29
+ header?: Snippet;
30
+ footer?: Snippet;
31
+ children?: Snippet;
32
+ onclick?: (event: MouseEvent) => void;
33
+ onkeydown?: (event: KeyboardEvent) => void;
34
+ testId?: string;
35
+ }
36
+
37
+ let {
38
+ variant = 'default',
39
+ padding = 'md',
40
+ accentColor = 'primary',
41
+ interactive = false,
42
+ asButton = false,
43
+ as = 'div',
44
+ id,
45
+ ariaLabelledby,
46
+ class: className = '',
47
+ header,
48
+ footer,
49
+ children,
50
+ onclick,
51
+ onkeydown,
52
+ testId
53
+ }: Props = $props();
54
+
55
+ const paddingValues: Record<CardPadding, string> = {
56
+ none: '0',
57
+ sm: 'var(--salmex-space-4)',
58
+ md: 'var(--salmex-space-6)',
59
+ lg: 'var(--salmex-space-8)',
60
+ xl: 'var(--salmex-space-10)'
61
+ };
62
+
63
+ const currentPadding = $derived(paddingValues[padding]);
64
+
65
+ function handleKeydown(e: KeyboardEvent) {
66
+ if (e.key === 'Enter' || e.key === ' ') {
67
+ e.preventDefault();
68
+ (e.currentTarget as HTMLElement).click();
69
+ }
70
+ onkeydown?.(e);
71
+ }
72
+ </script>
73
+
74
+ {#snippet cardContent()}
75
+ {#if header}
76
+ <div
77
+ class="salmex-card-header"
78
+ style="margin: calc(-1 * {currentPadding}) calc(-1 * {currentPadding}) {currentPadding}; padding: var(--salmex-space-4) {currentPadding};"
79
+ >
80
+ {@render header()}
81
+ </div>
82
+ {/if}
83
+ {#if children}
84
+ <div class="salmex-card-content">
85
+ {@render children()}
86
+ </div>
87
+ {/if}
88
+ {#if footer}
89
+ <div
90
+ class="salmex-card-footer"
91
+ style="margin: {currentPadding} calc(-1 * {currentPadding}) calc(-1 * {currentPadding}); padding: var(--salmex-space-4) {currentPadding};"
92
+ >
93
+ {@render footer()}
94
+ </div>
95
+ {/if}
96
+ {/snippet}
97
+
98
+ {#if asButton}
99
+ <button
100
+ type="button"
101
+ {id}
102
+ class={cn(
103
+ 'salmex-card',
104
+ `salmex-card-${variant}`,
105
+ `salmex-card-padding-${padding}`,
106
+ interactive && 'salmex-card-interactive',
107
+ variant === 'accent' && `salmex-card-accent-${accentColor}`,
108
+ className
109
+ )}
110
+ aria-labelledby={ariaLabelledby}
111
+ data-testid={testId}
112
+ onclick={onclick}
113
+ onkeydown={handleKeydown}
114
+ >
115
+ {@render cardContent()}
116
+ </button>
117
+ {:else if interactive || onclick}
118
+ <svelte:element
119
+ this={as}
120
+ {id}
121
+ class={cn(
122
+ 'salmex-card',
123
+ `salmex-card-${variant}`,
124
+ `salmex-card-padding-${padding}`,
125
+ 'salmex-card-interactive',
126
+ variant === 'accent' && `salmex-card-accent-${accentColor}`,
127
+ className
128
+ )}
129
+ role="button"
130
+ tabindex={0}
131
+ aria-labelledby={ariaLabelledby}
132
+ data-testid={testId}
133
+ onclick={onclick}
134
+ onkeydown={handleKeydown}
135
+ >
136
+ {@render cardContent()}
137
+ </svelte:element>
138
+ {:else}
139
+ <svelte:element
140
+ this={as}
141
+ {id}
142
+ class={cn(
143
+ 'salmex-card',
144
+ `salmex-card-${variant}`,
145
+ `salmex-card-padding-${padding}`,
146
+ variant === 'accent' && `salmex-card-accent-${accentColor}`,
147
+ className
148
+ )}
149
+ aria-labelledby={ariaLabelledby}
150
+ data-testid={testId}
151
+ >
152
+ {@render cardContent()}
153
+ </svelte:element>
154
+ {/if}
155
+
156
+ <style>
157
+ .salmex-card {
158
+ position: relative;
159
+ overflow: hidden;
160
+ border-radius: var(--salmex-radius-none);
161
+ transition: transform var(--salmex-transition-base), box-shadow var(--salmex-transition-base);
162
+ /* Bold 3px border, flat shadow — Win2K × Basquiat */
163
+ border: 3px solid rgb(var(--salmex-border-dark));
164
+ box-shadow: var(--salmex-shadow-lg);
165
+ }
166
+
167
+ button.salmex-card {
168
+ width: 100%;
169
+ text-align: left;
170
+ font: inherit;
171
+ cursor: pointer;
172
+ }
173
+
174
+ .salmex-card-padding-none {
175
+ padding: 0;
176
+ }
177
+
178
+ .salmex-card-padding-sm {
179
+ padding: var(--salmex-space-4);
180
+ }
181
+
182
+ .salmex-card-padding-md {
183
+ padding: var(--salmex-space-6);
184
+ }
185
+
186
+ .salmex-card-padding-lg {
187
+ padding: var(--salmex-space-8);
188
+ }
189
+
190
+ .salmex-card-padding-xl {
191
+ padding: var(--salmex-space-10);
192
+ }
193
+
194
+ /* Default — canvas/paper surface */
195
+ .salmex-card-default {
196
+ background: rgb(var(--salmex-window-surface));
197
+ }
198
+
199
+ .salmex-card-elevated {
200
+ background: rgb(var(--salmex-bg-primary));
201
+ box-shadow: var(--salmex-shadow-lg), 0 6px 0 rgb(0 0 0 / 0.15);
202
+ }
203
+
204
+ .salmex-card-outlined {
205
+ background: transparent;
206
+ border-width: 3px;
207
+ }
208
+
209
+ .salmex-card-accent-primary,
210
+ .salmex-card-accent-success,
211
+ .salmex-card-accent-warning,
212
+ .salmex-card-accent-error,
213
+ .salmex-card-accent-info {
214
+ border-left-width: 6px;
215
+ background: rgb(var(--salmex-window-surface));
216
+ }
217
+
218
+ .salmex-card-accent-primary {
219
+ border-left-color: rgb(var(--salmex-electric-blue));
220
+ }
221
+
222
+ .salmex-card-accent-success {
223
+ border-left-color: rgb(var(--salmex-urban-green));
224
+ }
225
+
226
+ .salmex-card-accent-warning {
227
+ border-left-color: rgb(var(--salmex-spray-orange));
228
+ }
229
+
230
+ .salmex-card-accent-error {
231
+ border-left-color: rgb(var(--salmex-street-red));
232
+ }
233
+
234
+ .salmex-card-accent-info {
235
+ border-left-color: rgb(var(--salmex-info));
236
+ }
237
+
238
+ .salmex-card-interactive:hover {
239
+ transform: translateY(-2px);
240
+ box-shadow: 5px 7px 0 rgb(0 0 0 / 0.35);
241
+ }
242
+
243
+ .salmex-card-interactive:active {
244
+ transform: translate(2px, 2px);
245
+ box-shadow: 3px 3px 0 rgb(0 0 0 / 0.4);
246
+ }
247
+
248
+ .salmex-card-interactive:focus-visible {
249
+ outline: none;
250
+ box-shadow: 5px 7px 0 rgb(0 0 0 / 0.35), 0 0 0 2px rgb(var(--salmex-midnight-black)), 0 0 0 5px rgb(var(--salmex-crown-yellow));
251
+ }
252
+
253
+ :global([data-theme='dark']) .salmex-card-interactive:focus-visible {
254
+ box-shadow: 5px 7px 0 rgb(0 0 0 / 0.35), 0 0 0 3px rgb(var(--salmex-crown-yellow));
255
+ }
256
+
257
+ .salmex-card-header {
258
+ border-bottom: 2px solid rgb(var(--salmex-border-default));
259
+ font-weight: 700;
260
+ text-transform: uppercase;
261
+ letter-spacing: 0.3px;
262
+ }
263
+
264
+ .salmex-card-footer {
265
+ border-top: 2px solid rgb(var(--salmex-border-default));
266
+ }
267
+
268
+ .salmex-card-content {
269
+ display: block;
270
+ }
271
+
272
+ @media (prefers-reduced-motion: reduce) {
273
+ .salmex-card {
274
+ transition: none;
275
+ }
276
+ .salmex-card-interactive:hover {
277
+ transform: none;
278
+ }
279
+ .salmex-card-interactive:active {
280
+ transform: none;
281
+ }
282
+ }
283
+ </style>
@@ -0,0 +1,35 @@
1
+ import type { Snippet } from 'svelte';
2
+ type CardPadding = 'none' | 'sm' | 'md' | 'lg' | 'xl';
3
+ type CardVariant = 'default' | 'elevated' | 'outlined' | 'accent';
4
+ type AccentColor = 'primary' | 'success' | 'warning' | 'error' | 'info';
5
+ interface Props {
6
+ variant?: CardVariant;
7
+ padding?: CardPadding;
8
+ accentColor?: AccentColor;
9
+ interactive?: boolean;
10
+ asButton?: boolean;
11
+ as?: 'div' | 'article' | 'section';
12
+ id?: string;
13
+ ariaLabelledby?: string;
14
+ class?: string;
15
+ header?: Snippet;
16
+ footer?: Snippet;
17
+ children?: Snippet;
18
+ onclick?: (event: MouseEvent) => void;
19
+ onkeydown?: (event: KeyboardEvent) => void;
20
+ testId?: string;
21
+ }
22
+ /**
23
+ * Card
24
+ *
25
+ * Win2K × Basquiat — Panel with canvas background, bold 3px borders, flat shadow.
26
+ * Optional header/footer, interactive mode, semantic element support.
27
+ *
28
+ * @example
29
+ * <Card><p>Content</p></Card>
30
+ * <Card variant="accent" accentColor="success" header={...} footer={...} />
31
+ */
32
+ declare const Card: import("svelte").Component<Props, {}, "">;
33
+ type Card = ReturnType<typeof Card>;
34
+ export default Card;
35
+ //# sourceMappingURL=Card.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Card.svelte.d.ts","sourceRoot":"","sources":["../../../src/layout/Card/Card.svelte.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AAIrC,KAAK,WAAW,GAAG,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;AACtD,KAAK,WAAW,GAAG,SAAS,GAAG,UAAU,GAAG,UAAU,GAAG,QAAQ,CAAC;AAClE,KAAK,WAAW,GAAG,SAAS,GAAG,SAAS,GAAG,SAAS,GAAG,OAAO,GAAG,MAAM,CAAC;AAExE,UAAU,KAAK;IACd,OAAO,CAAC,EAAE,WAAW,CAAC;IACtB,OAAO,CAAC,EAAE,WAAW,CAAC;IACtB,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,EAAE,CAAC,EAAE,KAAK,GAAG,SAAS,GAAG,SAAS,CAAC;IACnC,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,UAAU,KAAK,IAAI,CAAC;IACtC,SAAS,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,IAAI,CAAC;IAC3C,MAAM,CAAC,EAAE,MAAM,CAAC;CAChB;AAuGF;;;;;;;;;GASG;AACH,QAAA,MAAM,IAAI,2CAAwC,CAAC;AACnD,KAAK,IAAI,GAAG,UAAU,CAAC,OAAO,IAAI,CAAC,CAAC;AACpC,eAAe,IAAI,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { default as Card } from './Card.svelte';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/layout/Card/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,MAAM,eAAe,CAAC"}
@@ -0,0 +1 @@
1
+ export { default as Card } from './Card.svelte';
@@ -0,0 +1,202 @@
1
+ <!--
2
+ @component Container
3
+
4
+ Win2K × Basquiat — Responsive layout wrapper. Max-width, padding, optional centering.
5
+ Sharp edges, no rounded corners; supports semantic elements.
6
+ -->
7
+ <script lang="ts">
8
+ import type { Snippet } from 'svelte';
9
+ import type { HTMLAttributes } from 'svelte/elements';
10
+ import { cn } from '../../utils/cn.js';
11
+
12
+ type ContainerSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl' | 'prose' | 'full';
13
+ type ContainerPadding = 'none' | 'sm' | 'md' | 'lg' | 'xl';
14
+
15
+ interface Props extends Omit<HTMLAttributes<HTMLDivElement>, 'class'> {
16
+ size?: ContainerSize;
17
+ paddingX?: ContainerPadding;
18
+ paddingY?: ContainerPadding;
19
+ padding?: ContainerPadding;
20
+ centered?: boolean;
21
+ as?: 'div' | 'main' | 'section' | 'article';
22
+ id?: string;
23
+ class?: string;
24
+ children?: Snippet;
25
+ }
26
+
27
+ let {
28
+ size = 'xl',
29
+ paddingX,
30
+ paddingY,
31
+ padding = 'md',
32
+ centered = true,
33
+ as = 'div',
34
+ id,
35
+ class: className = '',
36
+ children,
37
+ ...restProps
38
+ }: Props = $props();
39
+
40
+ const resolvedPaddingX = $derived(paddingX ?? padding);
41
+ const resolvedPaddingY = $derived(paddingY ?? 'none');
42
+ </script>
43
+
44
+ <svelte:element
45
+ this={as}
46
+ {id}
47
+ class={cn(
48
+ 'salmex-container',
49
+ `salmex-container-${size}`,
50
+ `salmex-container-px-${resolvedPaddingX}`,
51
+ `salmex-container-py-${resolvedPaddingY}`,
52
+ centered && 'salmex-container-centered',
53
+ className
54
+ )}
55
+ {...restProps}
56
+ >
57
+ {#if children}
58
+ {@render children()}
59
+ {/if}
60
+ </svelte:element>
61
+
62
+ <style>
63
+ .salmex-container {
64
+ width: 100%;
65
+ }
66
+
67
+ .salmex-container-centered {
68
+ margin-left: auto;
69
+ margin-right: auto;
70
+ }
71
+
72
+ .salmex-container-xs {
73
+ max-width: 20rem;
74
+ }
75
+
76
+ .salmex-container-sm {
77
+ max-width: 42rem;
78
+ }
79
+
80
+ .salmex-container-md {
81
+ max-width: 56rem;
82
+ }
83
+
84
+ .salmex-container-lg {
85
+ max-width: 64rem;
86
+ }
87
+
88
+ .salmex-container-xl {
89
+ max-width: 72rem;
90
+ }
91
+
92
+ .salmex-container-2xl {
93
+ max-width: 80rem;
94
+ }
95
+
96
+ .salmex-container-prose {
97
+ max-width: 65ch;
98
+ }
99
+
100
+ .salmex-container-full {
101
+ max-width: 100%;
102
+ }
103
+
104
+ .salmex-container-px-none {
105
+ padding-left: 0;
106
+ padding-right: 0;
107
+ }
108
+
109
+ .salmex-container-px-sm {
110
+ padding-left: var(--salmex-space-4);
111
+ padding-right: var(--salmex-space-4);
112
+ }
113
+
114
+ .salmex-container-px-md {
115
+ padding-left: var(--salmex-space-6);
116
+ padding-right: var(--salmex-space-6);
117
+ }
118
+
119
+ .salmex-container-px-lg {
120
+ padding-left: var(--salmex-space-8);
121
+ padding-right: var(--salmex-space-8);
122
+ }
123
+
124
+ .salmex-container-px-xl {
125
+ padding-left: var(--salmex-space-10);
126
+ padding-right: var(--salmex-space-10);
127
+ }
128
+
129
+ @media (min-width: 640px) {
130
+ .salmex-container-px-sm {
131
+ padding-left: var(--salmex-space-6);
132
+ padding-right: var(--salmex-space-6);
133
+ }
134
+ .salmex-container-px-md {
135
+ padding-left: var(--salmex-space-8);
136
+ padding-right: var(--salmex-space-8);
137
+ }
138
+ .salmex-container-px-lg {
139
+ padding-left: var(--salmex-space-10);
140
+ padding-right: var(--salmex-space-10);
141
+ }
142
+ .salmex-container-px-xl {
143
+ padding-left: var(--salmex-space-12);
144
+ padding-right: var(--salmex-space-12);
145
+ }
146
+ }
147
+
148
+ @media (min-width: 1024px) {
149
+ .salmex-container-px-md {
150
+ padding-left: var(--salmex-space-10);
151
+ padding-right: var(--salmex-space-10);
152
+ }
153
+ .salmex-container-px-lg {
154
+ padding-left: var(--salmex-space-12);
155
+ padding-right: var(--salmex-space-12);
156
+ }
157
+ .salmex-container-px-xl {
158
+ padding-left: 42px;
159
+ padding-right: 42px;
160
+ }
161
+ }
162
+
163
+ .salmex-container-py-none {
164
+ padding-top: 0;
165
+ padding-bottom: 0;
166
+ }
167
+
168
+ .salmex-container-py-sm {
169
+ padding-top: var(--salmex-space-4);
170
+ padding-bottom: var(--salmex-space-4);
171
+ }
172
+
173
+ .salmex-container-py-md {
174
+ padding-top: var(--salmex-space-6);
175
+ padding-bottom: var(--salmex-space-6);
176
+ }
177
+
178
+ .salmex-container-py-lg {
179
+ padding-top: var(--salmex-space-8);
180
+ padding-bottom: var(--salmex-space-8);
181
+ }
182
+
183
+ .salmex-container-py-xl {
184
+ padding-top: var(--salmex-space-10);
185
+ padding-bottom: var(--salmex-space-10);
186
+ }
187
+
188
+ @media (min-width: 640px) {
189
+ .salmex-container-py-md {
190
+ padding-top: var(--salmex-space-8);
191
+ padding-bottom: var(--salmex-space-8);
192
+ }
193
+ .salmex-container-py-lg {
194
+ padding-top: var(--salmex-space-10);
195
+ padding-bottom: var(--salmex-space-10);
196
+ }
197
+ .salmex-container-py-xl {
198
+ padding-top: var(--salmex-space-12);
199
+ padding-bottom: var(--salmex-space-12);
200
+ }
201
+ }
202
+ </style>
@@ -0,0 +1,25 @@
1
+ import type { Snippet } from 'svelte';
2
+ import type { HTMLAttributes } from 'svelte/elements';
3
+ type ContainerSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl' | 'prose' | 'full';
4
+ type ContainerPadding = 'none' | 'sm' | 'md' | 'lg' | 'xl';
5
+ interface Props extends Omit<HTMLAttributes<HTMLDivElement>, 'class'> {
6
+ size?: ContainerSize;
7
+ paddingX?: ContainerPadding;
8
+ paddingY?: ContainerPadding;
9
+ padding?: ContainerPadding;
10
+ centered?: boolean;
11
+ as?: 'div' | 'main' | 'section' | 'article';
12
+ id?: string;
13
+ class?: string;
14
+ children?: Snippet;
15
+ }
16
+ /**
17
+ * Container
18
+ *
19
+ * Win2K × Basquiat — Responsive layout wrapper. Max-width, padding, optional centering.
20
+ * Sharp edges, no rounded corners; supports semantic elements.
21
+ */
22
+ declare const Container: import("svelte").Component<Props, {}, "">;
23
+ type Container = ReturnType<typeof Container>;
24
+ export default Container;
25
+ //# sourceMappingURL=Container.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Container.svelte.d.ts","sourceRoot":"","sources":["../../../src/layout/Container/Container.svelte.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AACtC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAIrD,KAAK,aAAa,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,KAAK,GAAG,OAAO,GAAG,MAAM,CAAC;AACjF,KAAK,gBAAgB,GAAG,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;AAE3D,UAAU,KAAM,SAAQ,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,OAAO,CAAC;IACpE,IAAI,CAAC,EAAE,aAAa,CAAC;IACrB,QAAQ,CAAC,EAAE,gBAAgB,CAAC;IAC5B,QAAQ,CAAC,EAAE,gBAAgB,CAAC;IAC5B,OAAO,CAAC,EAAE,gBAAgB,CAAC;IAC3B,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,EAAE,CAAC,EAAE,KAAK,GAAG,MAAM,GAAG,SAAS,GAAG,SAAS,CAAC;IAC5C,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACnB;AA4CF;;;;;GAKG;AACH,QAAA,MAAM,SAAS,2CAAwC,CAAC;AACxD,KAAK,SAAS,GAAG,UAAU,CAAC,OAAO,SAAS,CAAC,CAAC;AAC9C,eAAe,SAAS,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { default as Container } from './Container.svelte';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/layout/Container/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,SAAS,EAAE,MAAM,oBAAoB,CAAC"}
@@ -0,0 +1 @@
1
+ export { default as Container } from './Container.svelte';
@@ -0,0 +1,3 @@
1
+ export { Card } from './Card/index.js';
2
+ export { Container } from './Container/index.js';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/layout/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AACvC,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { Card } from './Card/index.js';
2
+ export { Container } from './Container/index.js';