@stachelock/ui 0.2.0 → 0.2.1
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/dist/index.js +391 -188
- package/dist/index.js.map +1 -1
- package/dist/src/index.d.ts +2 -0
- package/dist/src/index.d.ts.map +1 -1
- package/package.json +1 -1
- package/scripts/generateRecursiveIndex.cjs +6 -2
package/dist/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { a as
|
|
2
|
-
import { defineAsyncComponent as
|
|
3
|
-
import
|
|
1
|
+
import { a as ut, g as gt, s as bt } from "./id-DafBB_QF.js";
|
|
2
|
+
import { defineAsyncComponent as k, defineComponent as _, computed as R, ref as H, watch as W, createElementBlock as p, openBlock as c, normalizeClass as G, createCommentVNode as h, createElementVNode as n, toDisplayString as u, reactive as Y, createVNode as d } from "vue";
|
|
3
|
+
import m from "./components/TextInput.js";
|
|
4
4
|
import { _ as q } from "./UiAvatar.vue_vue_type_script_setup_true_lang-CDNjUA1L.js";
|
|
5
5
|
import J from "./components/Badge.js";
|
|
6
6
|
import { _ as K } from "./UiBreadcrumb.vue_vue_type_script_setup_true_lang-quGuN9v4.js";
|
|
@@ -9,56 +9,56 @@ import { _ as X } from "./UiLoading.vue_vue_type_script_setup_true_lang-DCz52-Me
|
|
|
9
9
|
import Z from "./components/LoadingDots.js";
|
|
10
10
|
import { _ as ee } from "./UiModal.vue_vue_type_script_setup_true_lang-SAo39zpS.js";
|
|
11
11
|
import { _ as te } from "./UiNavLink.vue_vue_type_script_setup_true_lang-Bz5oiCCk.js";
|
|
12
|
-
import { _ as
|
|
12
|
+
import { _ as oe } from "./UiProgressBar.vue_vue_type_script_setup_true_lang-0zFKwh43.js";
|
|
13
13
|
import { _ as ae } from "./UiTable.vue_vue_type_script_setup_true_lang-hI1_xamh.js";
|
|
14
|
-
import { _ as
|
|
15
|
-
import { _ as
|
|
16
|
-
import { _ as
|
|
17
|
-
import { _ as
|
|
14
|
+
import { _ as se } from "./UiTransition.vue_vue_type_script_setup_true_lang-DwBTj18t.js";
|
|
15
|
+
import { _ as $ } from "./CalendarHeader.vue_vue_type_script_setup_true_lang-Cirr0hMB.js";
|
|
16
|
+
import { _ as C } from "./DayCalendar.vue_vue_type_script_setup_true_lang-xE5bCa3O.js";
|
|
17
|
+
import { _ as v } from "./EventCard.vue_vue_type_script_setup_true_lang-YV1lfgUY.js";
|
|
18
18
|
import { _ as S } from "./EventsList.vue_vue_type_script_setup_true_lang-Cn_WOpZi.js";
|
|
19
19
|
import { _ as w } from "./MonthCalendar.vue_vue_type_script_setup_true_lang-B9Bs0z8j.js";
|
|
20
|
-
import { _ as
|
|
20
|
+
import { _ as I } from "./WeekCalendar.vue_vue_type_script_setup_true_lang-DAFQiRI9.js";
|
|
21
21
|
import { _ as T } from "./YearCalendar.vue_vue_type_script_setup_true_lang-BfJkvmpN.js";
|
|
22
|
-
import { _ as
|
|
22
|
+
import { _ as F } from "./DynamicForm.vue_vue_type_script_setup_true_lang-BpfPAZiT.js";
|
|
23
23
|
import { _ as L } from "./DynamicFormField.vue_vue_type_script_setup_true_lang-DvT03FIS.js";
|
|
24
24
|
import { _ as g } from "./CheckboxInput.vue_vue_type_script_setup_true_lang-tYAo46wK.js";
|
|
25
|
-
import { _ } from "./ComboboxInput.vue_vue_type_script_setup_true_lang-2dJNxQUF.js";
|
|
26
|
-
import { _ as
|
|
27
|
-
import { _ as
|
|
28
|
-
import { _ as
|
|
29
|
-
import { _ as
|
|
30
|
-
import { _ as
|
|
31
|
-
import { _ as
|
|
25
|
+
import { _ as b } from "./ComboboxInput.vue_vue_type_script_setup_true_lang-2dJNxQUF.js";
|
|
26
|
+
import { _ as x } from "./TextAreaInput.vue_vue_type_script_setup_true_lang-CbR651TU.js";
|
|
27
|
+
import { _ as y } from "./SwitchInput.vue_vue_type_script_setup_true_lang-BFr2SByh.js";
|
|
28
|
+
import { _ as f } from "./SelectInput.vue_vue_type_script_setup_true_lang-BPjHLHdM.js";
|
|
29
|
+
import { _ as E } from "./TagifyInput.vue_vue_type_script_setup_true_lang-DRR6jt_8.js";
|
|
30
|
+
import { _ as j } from "./DashboardLayout.vue_vue_type_script_setup_true_lang-BVQR4s1E.js";
|
|
31
|
+
import { _ as A } from "./DefaultLayout.vue_vue_type_script_setup_true_lang-BZAz6aC-.js";
|
|
32
32
|
import { _ as D } from "./HeaderLayout.vue_vue_type_script_setup_true_lang-BY2G6hCc.js";
|
|
33
|
-
import { _ as
|
|
34
|
-
import { _ as
|
|
35
|
-
import { _ as
|
|
36
|
-
import
|
|
37
|
-
import
|
|
38
|
-
const
|
|
33
|
+
import { _ as O } from "./NavigationGroup.vue_vue_type_script_setup_true_lang-2WURj34G.js";
|
|
34
|
+
import { _ as M } from "./NavigationItem.vue_vue_type_script_setup_true_lang-DiNg3gz2.js";
|
|
35
|
+
import { _ as N } from "./SidebarLayout.vue_vue_type_script_setup_true_lang-J1nfUTdM.js";
|
|
36
|
+
import U from "./calendars/CalendarDashboard.js";
|
|
37
|
+
import V from "./forms/FormFieldWrapper.js";
|
|
38
|
+
const re = {
|
|
39
39
|
text: {
|
|
40
40
|
component: "TextInput",
|
|
41
|
-
loader: () => Promise.resolve(
|
|
41
|
+
loader: () => Promise.resolve(m)
|
|
42
42
|
},
|
|
43
43
|
email: {
|
|
44
44
|
component: "TextInput",
|
|
45
|
-
loader: () => Promise.resolve(
|
|
45
|
+
loader: () => Promise.resolve(m)
|
|
46
46
|
},
|
|
47
47
|
password: {
|
|
48
48
|
component: "TextInput",
|
|
49
|
-
loader: () => Promise.resolve(
|
|
49
|
+
loader: () => Promise.resolve(m)
|
|
50
50
|
},
|
|
51
51
|
number: {
|
|
52
52
|
component: "TextInput",
|
|
53
|
-
loader: () => Promise.resolve(
|
|
53
|
+
loader: () => Promise.resolve(m)
|
|
54
54
|
},
|
|
55
55
|
tel: {
|
|
56
56
|
component: "TextInput",
|
|
57
|
-
loader: () => Promise.resolve(
|
|
57
|
+
loader: () => Promise.resolve(m)
|
|
58
58
|
},
|
|
59
59
|
url: {
|
|
60
60
|
component: "TextInput",
|
|
61
|
-
loader: () => Promise.resolve(
|
|
61
|
+
loader: () => Promise.resolve(m)
|
|
62
62
|
},
|
|
63
63
|
textarea: {
|
|
64
64
|
component: "TextAreaInput",
|
|
@@ -82,28 +82,28 @@ const le = {
|
|
|
82
82
|
}
|
|
83
83
|
};
|
|
84
84
|
class ne {
|
|
85
|
-
componentMap = { ...
|
|
85
|
+
componentMap = { ...re };
|
|
86
86
|
loadedComponents = /* @__PURE__ */ new Map();
|
|
87
87
|
/**
|
|
88
88
|
* Register a new component type
|
|
89
89
|
*/
|
|
90
|
-
register(e,
|
|
91
|
-
this.componentMap[e] = { component:
|
|
90
|
+
register(e, a, s) {
|
|
91
|
+
this.componentMap[e] = { component: a, loader: s }, this.loadedComponents.delete(e);
|
|
92
92
|
}
|
|
93
93
|
/**
|
|
94
94
|
* Get a component for a field type
|
|
95
95
|
*/
|
|
96
96
|
getComponent(e) {
|
|
97
|
-
const
|
|
98
|
-
if (!
|
|
97
|
+
const a = this.componentMap[e];
|
|
98
|
+
if (!a)
|
|
99
99
|
return console.warn(`Component type "${e}" is not registered`), null;
|
|
100
100
|
if (this.loadedComponents.has(e))
|
|
101
101
|
return this.loadedComponents.get(e);
|
|
102
|
-
const
|
|
103
|
-
loader:
|
|
102
|
+
const s = k({
|
|
103
|
+
loader: a.loader,
|
|
104
104
|
delay: 0
|
|
105
105
|
});
|
|
106
|
-
return this.loadedComponents.set(e,
|
|
106
|
+
return this.loadedComponents.set(e, s), s;
|
|
107
107
|
}
|
|
108
108
|
/**
|
|
109
109
|
* Check if a component type is registered
|
|
@@ -130,23 +130,222 @@ class ne {
|
|
|
130
130
|
this.loadedComponents.clear();
|
|
131
131
|
}
|
|
132
132
|
}
|
|
133
|
-
const
|
|
134
|
-
function
|
|
135
|
-
|
|
133
|
+
const P = new ne();
|
|
134
|
+
function nt(o, e, a) {
|
|
135
|
+
P.register(o, e, a);
|
|
136
136
|
}
|
|
137
|
-
function
|
|
138
|
-
return
|
|
137
|
+
function lt(o) {
|
|
138
|
+
return P.getComponent(o);
|
|
139
139
|
}
|
|
140
|
-
const
|
|
140
|
+
const le = {
|
|
141
|
+
colors: {
|
|
142
|
+
primary: {
|
|
143
|
+
50: "#edeff9",
|
|
144
|
+
100: "#dbdff2",
|
|
145
|
+
200: "#b8bfe6",
|
|
146
|
+
300: "#949ed9",
|
|
147
|
+
400: "#717ecd",
|
|
148
|
+
500: "#4d5ec0",
|
|
149
|
+
600: "#3e4b9a",
|
|
150
|
+
700: "#2e3873",
|
|
151
|
+
800: "#1f264d",
|
|
152
|
+
900: "#0f1326"
|
|
153
|
+
},
|
|
154
|
+
stachelock: {
|
|
155
|
+
50: "#edeff9",
|
|
156
|
+
100: "#dbdff2",
|
|
157
|
+
200: "#b8bfe6",
|
|
158
|
+
300: "#949ed9",
|
|
159
|
+
400: "#717ecd",
|
|
160
|
+
500: "#4d5ec0",
|
|
161
|
+
600: "#3e4b9a",
|
|
162
|
+
700: "#2e3873",
|
|
163
|
+
800: "#1f264d",
|
|
164
|
+
900: "#0f1326"
|
|
165
|
+
}
|
|
166
|
+
},
|
|
167
|
+
spacing: {
|
|
168
|
+
0: "0",
|
|
169
|
+
1: "0.25rem",
|
|
170
|
+
2: "0.5rem",
|
|
171
|
+
3: "0.75rem",
|
|
172
|
+
4: "1rem",
|
|
173
|
+
5: "1.25rem",
|
|
174
|
+
6: "1.5rem",
|
|
175
|
+
8: "2rem",
|
|
176
|
+
10: "2.5rem",
|
|
177
|
+
12: "3rem",
|
|
178
|
+
16: "4rem",
|
|
179
|
+
20: "5rem",
|
|
180
|
+
24: "6rem",
|
|
181
|
+
32: "8rem",
|
|
182
|
+
40: "10rem",
|
|
183
|
+
48: "12rem",
|
|
184
|
+
56: "14rem",
|
|
185
|
+
64: "16rem",
|
|
186
|
+
72: "18rem",
|
|
187
|
+
80: "20rem",
|
|
188
|
+
96: "24rem"
|
|
189
|
+
},
|
|
190
|
+
borderRadius: {
|
|
191
|
+
none: "0",
|
|
192
|
+
sm: "0.125rem",
|
|
193
|
+
DEFAULT: "0.25rem",
|
|
194
|
+
md: "0.375rem",
|
|
195
|
+
lg: "0.5rem",
|
|
196
|
+
xl: "0.75rem",
|
|
197
|
+
"2xl": "1rem",
|
|
198
|
+
"3xl": "1.5rem",
|
|
199
|
+
full: "9999px"
|
|
200
|
+
},
|
|
201
|
+
shadows: {
|
|
202
|
+
sm: "0 1px 2px 0 rgb(0 0 0 / 0.05)",
|
|
203
|
+
DEFAULT: "0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1)",
|
|
204
|
+
md: "0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1)",
|
|
205
|
+
lg: "0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1)",
|
|
206
|
+
xl: "0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1)",
|
|
207
|
+
"2xl": "0 25px 50px -12px rgb(0 0 0 / 0.25)",
|
|
208
|
+
inner: "inset 0 2px 4px 0 rgb(0 0 0 / 0.05)",
|
|
209
|
+
none: "none"
|
|
210
|
+
},
|
|
211
|
+
typography: {
|
|
212
|
+
fontFamily: {
|
|
213
|
+
sans: ["Inter", "ui-sans-serif", "system-ui", "sans-serif"],
|
|
214
|
+
serif: ["ui-serif", "Georgia", "Cambria", "serif"],
|
|
215
|
+
mono: ["ui-monospace", "SFMono-Regular", "Menlo", "Monaco", "Consolas", "monospace"]
|
|
216
|
+
},
|
|
217
|
+
fontSize: {
|
|
218
|
+
xs: "0.75rem",
|
|
219
|
+
sm: "0.875rem",
|
|
220
|
+
base: "1rem",
|
|
221
|
+
lg: "1.125rem",
|
|
222
|
+
xl: "1.25rem",
|
|
223
|
+
"2xl": "1.5rem",
|
|
224
|
+
"3xl": "1.875rem",
|
|
225
|
+
"4xl": "2.25rem",
|
|
226
|
+
"5xl": "3rem",
|
|
227
|
+
"6xl": "3.75rem",
|
|
228
|
+
"7xl": "4.5rem",
|
|
229
|
+
"8xl": "6rem",
|
|
230
|
+
"9xl": "8rem"
|
|
231
|
+
}
|
|
232
|
+
},
|
|
233
|
+
breakpoints: {
|
|
234
|
+
sm: "640px",
|
|
235
|
+
md: "768px",
|
|
236
|
+
lg: "1024px",
|
|
237
|
+
xl: "1280px",
|
|
238
|
+
"2xl": "1536px"
|
|
239
|
+
}
|
|
240
|
+
};
|
|
241
|
+
function it(o, e = le) {
|
|
242
|
+
const a = { ...e };
|
|
243
|
+
function s(r, l) {
|
|
244
|
+
if (l && typeof l == "object" && !Array.isArray(l))
|
|
245
|
+
for (const t in l)
|
|
246
|
+
l.hasOwnProperty(t) && (r[t] && typeof r[t] == "object" && !Array.isArray(r[t]) ? r[t] = s(r[t], l[t]) : r[t] = l[t]);
|
|
247
|
+
return r;
|
|
248
|
+
}
|
|
249
|
+
return s(a, o);
|
|
250
|
+
}
|
|
251
|
+
function mt(o) {
|
|
252
|
+
let e = `:root {
|
|
253
|
+
`;
|
|
254
|
+
return o.colors && Object.entries(o.colors).forEach(([a, s]) => {
|
|
255
|
+
typeof s == "object" && s !== null && Object.entries(s).forEach(([r, l]) => {
|
|
256
|
+
const t = r === "DEFAULT" ? a : `${a}-${r}`;
|
|
257
|
+
e += ` --sl-color-${t}: ${l};
|
|
258
|
+
`;
|
|
259
|
+
});
|
|
260
|
+
}), o.spacing && Object.entries(o.spacing).forEach(([a, s]) => {
|
|
261
|
+
e += ` --sl-spacing-${a}: ${s};
|
|
262
|
+
`;
|
|
263
|
+
}), o.borderRadius && Object.entries(o.borderRadius).forEach(([a, s]) => {
|
|
264
|
+
const r = a === "DEFAULT" ? "radius" : `radius-${a}`;
|
|
265
|
+
e += ` --sl-${r}: ${s};
|
|
266
|
+
`;
|
|
267
|
+
}), o.shadows && Object.entries(o.shadows).forEach(([a, s]) => {
|
|
268
|
+
const r = a === "DEFAULT" ? "shadow" : `shadow-${a}`;
|
|
269
|
+
e += ` --sl-${r}: ${s};
|
|
270
|
+
`;
|
|
271
|
+
}), o.typography && (o.typography.fontFamily && Object.entries(o.typography.fontFamily).forEach(([a, s]) => {
|
|
272
|
+
e += ` --sl-font-family-${a}: ${s.join(", ")};
|
|
273
|
+
`;
|
|
274
|
+
}), o.typography.fontSize && Object.entries(o.typography.fontSize).forEach(([a, s]) => {
|
|
275
|
+
e += ` --sl-font-size-${a}: ${s};
|
|
276
|
+
`;
|
|
277
|
+
})), o.breakpoints && Object.entries(o.breakpoints).forEach(([a, s]) => {
|
|
278
|
+
e += ` --sl-breakpoint-${a}: ${s};
|
|
279
|
+
`;
|
|
280
|
+
}), e += ` --sl-ring-color: var(--sl-color-primary-600, #3e4b9a);
|
|
281
|
+
`, e += ` --sl-ring-offset-color: #ffffff;
|
|
282
|
+
`, e += ` --sl-ring-width: 2px;
|
|
283
|
+
`, e += ` --sl-outline-color: var(--sl-color-primary-600, #3e4b9a);
|
|
284
|
+
`, e += ` --sl-outline-width: 2px;
|
|
285
|
+
`, e += `}
|
|
286
|
+
|
|
287
|
+
`, e += `@media (prefers-color-scheme: dark) {
|
|
288
|
+
`, e += ` :root {
|
|
289
|
+
`, e += ` --sl-ring-color: var(--sl-color-primary-600, #3e4b9a);
|
|
290
|
+
`, e += ` }
|
|
291
|
+
`, e += `}
|
|
292
|
+
`, e;
|
|
293
|
+
}
|
|
294
|
+
function dt(o) {
|
|
295
|
+
let e = `export default {
|
|
296
|
+
`;
|
|
297
|
+
return e += ` prefix: "sl-",
|
|
298
|
+
`, e += ` theme: {
|
|
299
|
+
`, e += ` extend: {
|
|
300
|
+
`, o.colors && (e += ` colors: {
|
|
301
|
+
`, Object.entries(o.colors).forEach(([a, s]) => {
|
|
302
|
+
typeof s == "object" && s !== null && (e += ` "${a}": {
|
|
303
|
+
`, Object.entries(s).forEach(([r, l]) => {
|
|
304
|
+
e += ` "${r === "DEFAULT" ? "DEFAULT" : r}": "${l}",
|
|
305
|
+
`;
|
|
306
|
+
}), e += ` },
|
|
307
|
+
`);
|
|
308
|
+
}), e += ` },
|
|
309
|
+
`), o.spacing && (e += ` spacing: {
|
|
310
|
+
`, Object.entries(o.spacing).forEach(([a, s]) => {
|
|
311
|
+
e += ` "${a}": "${s}",
|
|
312
|
+
`;
|
|
313
|
+
}), e += ` },
|
|
314
|
+
`), o.borderRadius && (e += ` borderRadius: {
|
|
315
|
+
`, Object.entries(o.borderRadius).forEach(([a, s]) => {
|
|
316
|
+
e += ` "${a === "DEFAULT" ? "DEFAULT" : a}": "${s}",
|
|
317
|
+
`;
|
|
318
|
+
}), e += ` },
|
|
319
|
+
`), o.shadows && (e += ` boxShadow: {
|
|
320
|
+
`, Object.entries(o.shadows).forEach(([a, s]) => {
|
|
321
|
+
e += ` "${a === "DEFAULT" ? "DEFAULT" : a}": "${s}",
|
|
322
|
+
`;
|
|
323
|
+
}), e += ` },
|
|
324
|
+
`), o.typography && (o.typography.fontFamily && (e += ` fontFamily: {
|
|
325
|
+
`, Object.entries(o.typography.fontFamily).forEach(([a, s]) => {
|
|
326
|
+
e += ` "${a}": [${s.map((r) => `"${r}"`).join(", ")}],
|
|
327
|
+
`;
|
|
328
|
+
}), e += ` },
|
|
329
|
+
`), o.typography.fontSize && (e += ` fontSize: {
|
|
330
|
+
`, Object.entries(o.typography.fontSize).forEach(([a, s]) => {
|
|
331
|
+
e += ` "${a}": "${s}",
|
|
332
|
+
`;
|
|
333
|
+
}), e += ` },
|
|
334
|
+
`)), e += ` },
|
|
335
|
+
`, e += ` },
|
|
336
|
+
`, e += `};
|
|
337
|
+
`, e;
|
|
338
|
+
}
|
|
339
|
+
const ie = {
|
|
141
340
|
viewBox: "0 0 36 36",
|
|
142
341
|
class: "sl-transform -sl-rotate-90 sl-w-full sl-h-full"
|
|
143
|
-
}, me = ["stroke-dasharray"],
|
|
342
|
+
}, me = ["stroke-dasharray"], de = {
|
|
144
343
|
key: 0,
|
|
145
344
|
class: "sl-absolute sl-top-1/2 sl-left-1/2 sl-transform -sl-translate-x-1/2 -sl-translate-y-1/2 sl-text-center"
|
|
146
|
-
},
|
|
345
|
+
}, pe = {
|
|
147
346
|
key: 1,
|
|
148
347
|
class: "sl-absolute sl-top-1/2 sl-left-1/2 sl-transform -sl-translate-x-1/2 -sl-translate-y-1/2 sl-text-center sl-text-xs"
|
|
149
|
-
},
|
|
348
|
+
}, ce = /* @__PURE__ */ _({
|
|
150
349
|
__name: "UiRadialProgressBar",
|
|
151
350
|
props: {
|
|
152
351
|
progress: {
|
|
@@ -166,8 +365,8 @@ const re = {
|
|
|
166
365
|
default: "md"
|
|
167
366
|
}
|
|
168
367
|
},
|
|
169
|
-
setup(
|
|
170
|
-
const e =
|
|
368
|
+
setup(o) {
|
|
369
|
+
const e = o, a = R(() => {
|
|
171
370
|
switch (e.size) {
|
|
172
371
|
case "xs":
|
|
173
372
|
return "sl-h-4 sl-w-4";
|
|
@@ -180,47 +379,47 @@ const re = {
|
|
|
180
379
|
default:
|
|
181
380
|
return "sl-h-8 sl-w-8";
|
|
182
381
|
}
|
|
183
|
-
}),
|
|
184
|
-
return W(() => e.progress, (
|
|
185
|
-
|
|
186
|
-
}), (
|
|
187
|
-
class: G(["sl-relative",
|
|
382
|
+
}), s = H(e.progress);
|
|
383
|
+
return W(() => e.progress, (r) => {
|
|
384
|
+
s.value = r;
|
|
385
|
+
}), (r, l) => (c(), p("div", {
|
|
386
|
+
class: G(["sl-relative", a.value])
|
|
188
387
|
}, [
|
|
189
|
-
(
|
|
190
|
-
|
|
388
|
+
(c(), p("svg", ie, [
|
|
389
|
+
l[0] || (l[0] = n("path", {
|
|
191
390
|
class: "sl-fill-none sl-stroke-gray-300",
|
|
192
391
|
"stroke-width": "3.8",
|
|
193
392
|
d: "M18 2.0845 a 15.9155 15.9155 0 0 1 0 31.831 a 15.9155 15.9155 0 0 1 0 -31.831"
|
|
194
393
|
}, null, -1)),
|
|
195
|
-
|
|
394
|
+
n("path", {
|
|
196
395
|
class: "sl-fill-none sl-stroke-stachelock-600 sl-stroke-linecap-round sl-transition-[stroke-dasharray] sl-duration-500 sl-ease-out",
|
|
197
|
-
"stroke-dasharray":
|
|
396
|
+
"stroke-dasharray": s.value + ", 100",
|
|
198
397
|
"stroke-width": "3.8",
|
|
199
398
|
d: "M18 2.0845 a 15.9155 15.9155 0 0 1 0 31.831 a 15.9155 15.9155 0 0 1 0 -31.831"
|
|
200
399
|
}, null, 8, me)
|
|
201
400
|
])),
|
|
202
|
-
|
|
203
|
-
|
|
401
|
+
o.label && o.label.length > 0 ? (c(), p("div", de, u(o.label), 1)) : h("", !0),
|
|
402
|
+
o.showProgressLabel ? (c(), p("div", pe, u(s.value) + "% ", 1)) : h("", !0)
|
|
204
403
|
], 2));
|
|
205
404
|
}
|
|
206
|
-
}),
|
|
405
|
+
}), fe = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
207
406
|
__proto__: null,
|
|
208
|
-
CalendarDashboard:
|
|
209
|
-
CalendarHeader:
|
|
210
|
-
DayCalendar:
|
|
211
|
-
EventCard:
|
|
407
|
+
CalendarDashboard: U,
|
|
408
|
+
CalendarHeader: $,
|
|
409
|
+
DayCalendar: C,
|
|
410
|
+
EventCard: v,
|
|
212
411
|
EventsList: S,
|
|
213
412
|
MonthCalendar: w,
|
|
214
|
-
WeekCalendar:
|
|
413
|
+
WeekCalendar: I,
|
|
215
414
|
YearCalendar: T
|
|
216
|
-
}, Symbol.toStringTag, { value: "Module" })),
|
|
415
|
+
}, Symbol.toStringTag, { value: "Module" })), ue = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
217
416
|
__proto__: null,
|
|
218
|
-
DynamicForm:
|
|
417
|
+
DynamicForm: F,
|
|
219
418
|
FormField: L,
|
|
220
|
-
FormFieldWrapper:
|
|
221
|
-
}, Symbol.toStringTag, { value: "Module" })),
|
|
419
|
+
FormFieldWrapper: V
|
|
420
|
+
}, Symbol.toStringTag, { value: "Module" })), ge = { class: "sl-bg-white sl-rounded-lg sl-shadow sl-p-6" }, be = { class: "sl-space-y-8" }, xe = { class: "sl-grid sl-grid-cols-1 sl-md:grid-cols-2 sl-gap-6" }, ye = { class: "sl-bg-gray-50 sl-rounded-md sl-p-4 sl-text-sm sl-text-gray-700" }, he = { class: "sl-whitespace-pre-wrap" }, B = /* @__PURE__ */ _({
|
|
222
421
|
__name: "InputsShowcase",
|
|
223
|
-
setup(
|
|
422
|
+
setup(o) {
|
|
224
423
|
const e = Y({
|
|
225
424
|
text: "",
|
|
226
425
|
textArea: "",
|
|
@@ -229,18 +428,18 @@ const re = {
|
|
|
229
428
|
selectedFruit: null,
|
|
230
429
|
selectedLanguages: [],
|
|
231
430
|
selectedCity: null
|
|
232
|
-
}),
|
|
431
|
+
}), a = [
|
|
233
432
|
{ id: 1, name: "Apple" },
|
|
234
433
|
{ id: 2, name: "Banana" },
|
|
235
434
|
{ id: 3, name: "Cherry" },
|
|
236
435
|
{ id: 4, name: "Durian", disabled: !0 }
|
|
237
|
-
],
|
|
436
|
+
], s = [
|
|
238
437
|
{ id: 1, name: "TypeScript" },
|
|
239
438
|
{ id: 2, name: "JavaScript" },
|
|
240
439
|
{ id: 3, name: "Python" },
|
|
241
440
|
{ id: 4, name: "Go" },
|
|
242
441
|
{ id: 5, name: "Rust" }
|
|
243
|
-
],
|
|
442
|
+
], r = [
|
|
244
443
|
{ id: 1, name: "New York" },
|
|
245
444
|
{ id: 2, name: "San Francisco" },
|
|
246
445
|
{ id: 3, name: "Seattle" },
|
|
@@ -250,165 +449,165 @@ const re = {
|
|
|
250
449
|
{ id: 7, name: "Miami" },
|
|
251
450
|
{ id: 8, name: "Boston" }
|
|
252
451
|
];
|
|
253
|
-
return (
|
|
254
|
-
t[15] || (t[15] =
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
t[7] || (t[7] =
|
|
258
|
-
d(
|
|
452
|
+
return (l, t) => (c(), p("section", ge, [
|
|
453
|
+
t[15] || (t[15] = n("h2", { class: "sl-text-xl sl-font-semibold sl-mb-4" }, "All Inputs Showcase", -1)),
|
|
454
|
+
n("div", be, [
|
|
455
|
+
n("div", null, [
|
|
456
|
+
t[7] || (t[7] = n("h3", { class: "sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2" }, "Text Input", -1)),
|
|
457
|
+
d(m, {
|
|
259
458
|
name: "demoText",
|
|
260
459
|
label: "Text Input",
|
|
261
460
|
placeholder: "Type something...",
|
|
262
461
|
value: e.text,
|
|
263
|
-
"onUpdate:value": t[0] || (t[0] = (
|
|
462
|
+
"onUpdate:value": t[0] || (t[0] = (i) => e.text = i)
|
|
264
463
|
}, null, 8, ["value"])
|
|
265
464
|
]),
|
|
266
|
-
|
|
267
|
-
t[8] || (t[8] =
|
|
268
|
-
d(
|
|
465
|
+
n("div", null, [
|
|
466
|
+
t[8] || (t[8] = n("h3", { class: "sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2" }, "Text Area", -1)),
|
|
467
|
+
d(x, {
|
|
269
468
|
name: "demoTextArea",
|
|
270
469
|
label: "Text Area",
|
|
271
470
|
placeholder: "Write a longer message...",
|
|
272
471
|
rows: 4,
|
|
273
472
|
maxlength: 200,
|
|
274
473
|
modelValue: e.textArea,
|
|
275
|
-
"onUpdate:modelValue": t[1] || (t[1] = (
|
|
474
|
+
"onUpdate:modelValue": t[1] || (t[1] = (i) => e.textArea = i)
|
|
276
475
|
}, null, 8, ["modelValue"])
|
|
277
476
|
]),
|
|
278
|
-
|
|
279
|
-
t[9] || (t[9] =
|
|
280
|
-
d(
|
|
477
|
+
n("div", null, [
|
|
478
|
+
t[9] || (t[9] = n("h3", { class: "sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2" }, "Switch", -1)),
|
|
479
|
+
d(y, {
|
|
281
480
|
name: "demoSwitch",
|
|
282
481
|
label: "Enable feature",
|
|
283
482
|
modelValue: e.switchOn,
|
|
284
|
-
"onUpdate:modelValue": t[2] || (t[2] = (
|
|
483
|
+
"onUpdate:modelValue": t[2] || (t[2] = (i) => e.switchOn = i),
|
|
285
484
|
textTrue: "ON",
|
|
286
485
|
textFalse: "OFF"
|
|
287
486
|
}, null, 8, ["modelValue"])
|
|
288
487
|
]),
|
|
289
|
-
|
|
290
|
-
t[10] || (t[10] =
|
|
488
|
+
n("div", null, [
|
|
489
|
+
t[10] || (t[10] = n("h3", { class: "sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2" }, "Checkbox", -1)),
|
|
291
490
|
d(g, {
|
|
292
491
|
name: "demoCheckbox",
|
|
293
492
|
label: "I agree to the terms",
|
|
294
493
|
modelValue: e.checkbox,
|
|
295
|
-
"onUpdate:modelValue": t[3] || (t[3] = (
|
|
494
|
+
"onUpdate:modelValue": t[3] || (t[3] = (i) => e.checkbox = i)
|
|
296
495
|
}, null, 8, ["modelValue"])
|
|
297
496
|
]),
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
t[11] || (t[11] =
|
|
301
|
-
d(
|
|
497
|
+
n("div", xe, [
|
|
498
|
+
n("div", null, [
|
|
499
|
+
t[11] || (t[11] = n("h3", { class: "sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2" }, "Select (Single)", -1)),
|
|
500
|
+
d(f, {
|
|
302
501
|
name: "demoSelect",
|
|
303
502
|
label: "Favorite Fruit",
|
|
304
503
|
placeholder: "Select a fruit",
|
|
305
|
-
items:
|
|
504
|
+
items: a,
|
|
306
505
|
modelValue: e.selectedFruit,
|
|
307
|
-
"onUpdate:modelValue": t[4] || (t[4] = (
|
|
506
|
+
"onUpdate:modelValue": t[4] || (t[4] = (i) => e.selectedFruit = i)
|
|
308
507
|
}, null, 8, ["modelValue"])
|
|
309
508
|
]),
|
|
310
|
-
|
|
311
|
-
t[12] || (t[12] =
|
|
312
|
-
d(
|
|
509
|
+
n("div", null, [
|
|
510
|
+
t[12] || (t[12] = n("h3", { class: "sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2" }, "Select (Multiple)", -1)),
|
|
511
|
+
d(f, {
|
|
313
512
|
name: "demoSelectMulti",
|
|
314
513
|
label: "Favorite Languages",
|
|
315
514
|
placeholder: "Select languages",
|
|
316
|
-
items:
|
|
515
|
+
items: s,
|
|
317
516
|
multiple: "",
|
|
318
517
|
showAll: "",
|
|
319
518
|
modelValue: e.selectedLanguages,
|
|
320
|
-
"onUpdate:modelValue": t[5] || (t[5] = (
|
|
519
|
+
"onUpdate:modelValue": t[5] || (t[5] = (i) => e.selectedLanguages = i)
|
|
321
520
|
}, null, 8, ["modelValue"])
|
|
322
521
|
])
|
|
323
522
|
]),
|
|
324
|
-
|
|
325
|
-
t[13] || (t[13] =
|
|
326
|
-
d(
|
|
523
|
+
n("div", null, [
|
|
524
|
+
t[13] || (t[13] = n("h3", { class: "sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2" }, "Combobox", -1)),
|
|
525
|
+
d(b, {
|
|
327
526
|
name: "demoCombobox",
|
|
328
527
|
label: "Search a City",
|
|
329
528
|
placeholder: "Start typing...",
|
|
330
|
-
items:
|
|
529
|
+
items: r,
|
|
331
530
|
modelValue: e.selectedCity,
|
|
332
|
-
"onUpdate:modelValue": t[6] || (t[6] = (
|
|
531
|
+
"onUpdate:modelValue": t[6] || (t[6] = (i) => e.selectedCity = i)
|
|
333
532
|
}, null, 8, ["modelValue"])
|
|
334
533
|
]),
|
|
335
|
-
|
|
336
|
-
t[14] || (t[14] =
|
|
337
|
-
|
|
534
|
+
n("div", ye, [
|
|
535
|
+
t[14] || (t[14] = n("div", { class: "sl-font-semibold sl-mb-1" }, "State", -1)),
|
|
536
|
+
n("pre", he, u(e), 1)
|
|
338
537
|
])
|
|
339
538
|
])
|
|
340
539
|
]));
|
|
341
540
|
}
|
|
342
|
-
}),
|
|
541
|
+
}), _e = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
343
542
|
__proto__: null,
|
|
344
543
|
CheckboxInput: g,
|
|
345
|
-
ComboboxInput:
|
|
346
|
-
InputsShowcase:
|
|
347
|
-
SelectInput:
|
|
348
|
-
SwitchInput:
|
|
349
|
-
TagifyInput:
|
|
350
|
-
TextAreaInput:
|
|
351
|
-
}, Symbol.toStringTag, { value: "Module" })),
|
|
544
|
+
ComboboxInput: b,
|
|
545
|
+
InputsShowcase: B,
|
|
546
|
+
SelectInput: f,
|
|
547
|
+
SwitchInput: y,
|
|
548
|
+
TagifyInput: E,
|
|
549
|
+
TextAreaInput: x
|
|
550
|
+
}, Symbol.toStringTag, { value: "Module" })), $e = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
352
551
|
__proto__: null,
|
|
353
|
-
DashboardLayout:
|
|
354
|
-
DefaultLayout:
|
|
552
|
+
DashboardLayout: j,
|
|
553
|
+
DefaultLayout: A,
|
|
355
554
|
HeaderLayout: D,
|
|
356
|
-
NavigationGroup:
|
|
357
|
-
NavigationItem:
|
|
358
|
-
SidebarLayout:
|
|
555
|
+
NavigationGroup: O,
|
|
556
|
+
NavigationItem: M,
|
|
557
|
+
SidebarLayout: N
|
|
359
558
|
}, Symbol.toStringTag, { value: "Module" })), Ce = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
360
559
|
__proto__: null,
|
|
361
560
|
Avatar: q,
|
|
362
561
|
Badge: J,
|
|
363
562
|
Breadcrumb: K,
|
|
364
563
|
Button: Q,
|
|
365
|
-
CalendarDashboard:
|
|
366
|
-
CalendarHeader:
|
|
564
|
+
CalendarDashboard: U,
|
|
565
|
+
CalendarHeader: $,
|
|
367
566
|
CheckboxInput: g,
|
|
368
|
-
ComboboxInput:
|
|
369
|
-
DashboardLayout:
|
|
370
|
-
DayCalendar:
|
|
371
|
-
DefaultLayout:
|
|
372
|
-
DynamicForm:
|
|
373
|
-
EventCard:
|
|
567
|
+
ComboboxInput: b,
|
|
568
|
+
DashboardLayout: j,
|
|
569
|
+
DayCalendar: C,
|
|
570
|
+
DefaultLayout: A,
|
|
571
|
+
DynamicForm: F,
|
|
572
|
+
EventCard: v,
|
|
374
573
|
EventsList: S,
|
|
375
574
|
FormField: L,
|
|
376
|
-
FormFieldWrapper:
|
|
575
|
+
FormFieldWrapper: V,
|
|
377
576
|
HeaderLayout: D,
|
|
378
|
-
InputsShowcase:
|
|
577
|
+
InputsShowcase: B,
|
|
379
578
|
Loading: X,
|
|
380
579
|
LoadingDots: Z,
|
|
381
580
|
Modal: ee,
|
|
382
581
|
MonthCalendar: w,
|
|
383
582
|
NavLink: te,
|
|
384
|
-
NavigationGroup:
|
|
385
|
-
NavigationItem:
|
|
386
|
-
ProgressBar:
|
|
387
|
-
RadialProgressBar:
|
|
388
|
-
SelectInput:
|
|
389
|
-
SidebarLayout:
|
|
390
|
-
SwitchInput:
|
|
583
|
+
NavigationGroup: O,
|
|
584
|
+
NavigationItem: M,
|
|
585
|
+
ProgressBar: oe,
|
|
586
|
+
RadialProgressBar: ce,
|
|
587
|
+
SelectInput: f,
|
|
588
|
+
SidebarLayout: N,
|
|
589
|
+
SwitchInput: y,
|
|
391
590
|
Table: ae,
|
|
392
|
-
TagifyInput:
|
|
393
|
-
TextAreaInput:
|
|
394
|
-
TextInput:
|
|
395
|
-
Transition:
|
|
396
|
-
WeekCalendar:
|
|
591
|
+
TagifyInput: E,
|
|
592
|
+
TextAreaInput: x,
|
|
593
|
+
TextInput: m,
|
|
594
|
+
Transition: se,
|
|
595
|
+
WeekCalendar: I,
|
|
397
596
|
YearCalendar: T
|
|
398
597
|
}, Symbol.toStringTag, { value: "Module" })), ve = {
|
|
399
598
|
...Ce,
|
|
400
|
-
|
|
401
|
-
...
|
|
402
|
-
...
|
|
403
|
-
...
|
|
404
|
-
},
|
|
405
|
-
install(
|
|
406
|
-
const { prefix:
|
|
407
|
-
Object.entries(ve).forEach(([
|
|
408
|
-
if (
|
|
409
|
-
|
|
410
|
-
const z =
|
|
411
|
-
|
|
599
|
+
...$e,
|
|
600
|
+
..._e,
|
|
601
|
+
...fe,
|
|
602
|
+
...ue
|
|
603
|
+
}, pt = {
|
|
604
|
+
install(o, e = {}) {
|
|
605
|
+
const { prefix: a = "Sl", installAll: s = !1, components: r } = e;
|
|
606
|
+
Object.entries(ve).forEach(([l, t]) => {
|
|
607
|
+
if (s || r && r.includes(l) || !r && !s) {
|
|
608
|
+
o.component(l, t);
|
|
609
|
+
const z = l.startsWith(a) ? l : `${a}${l}`;
|
|
610
|
+
o.component(z, t);
|
|
412
611
|
}
|
|
413
612
|
});
|
|
414
613
|
}
|
|
@@ -418,48 +617,52 @@ export {
|
|
|
418
617
|
J as Badge,
|
|
419
618
|
K as Breadcrumb,
|
|
420
619
|
Q as Button,
|
|
421
|
-
|
|
422
|
-
|
|
620
|
+
U as CalendarDashboard,
|
|
621
|
+
$ as CalendarHeader,
|
|
423
622
|
g as CheckboxInput,
|
|
424
|
-
|
|
623
|
+
b as ComboboxInput,
|
|
425
624
|
ne as ComponentRegistry,
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
625
|
+
j as DashboardLayout,
|
|
626
|
+
C as DayCalendar,
|
|
627
|
+
A as DefaultLayout,
|
|
628
|
+
F as DynamicForm,
|
|
629
|
+
v as EventCard,
|
|
431
630
|
S as EventsList,
|
|
432
631
|
L as FormField,
|
|
433
|
-
|
|
632
|
+
V as FormFieldWrapper,
|
|
434
633
|
D as HeaderLayout,
|
|
435
|
-
|
|
634
|
+
B as InputsShowcase,
|
|
436
635
|
X as Loading,
|
|
437
636
|
Z as LoadingDots,
|
|
438
637
|
ee as Modal,
|
|
439
638
|
w as MonthCalendar,
|
|
440
639
|
te as NavLink,
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
640
|
+
O as NavigationGroup,
|
|
641
|
+
M as NavigationItem,
|
|
642
|
+
oe as ProgressBar,
|
|
643
|
+
ce as RadialProgressBar,
|
|
644
|
+
f as SelectInput,
|
|
645
|
+
N as SidebarLayout,
|
|
646
|
+
pt as StachelockUI,
|
|
647
|
+
y as SwitchInput,
|
|
449
648
|
ae as Table,
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
649
|
+
E as TagifyInput,
|
|
650
|
+
x as TextAreaInput,
|
|
651
|
+
m as TextInput,
|
|
652
|
+
se as Transition,
|
|
653
|
+
I as WeekCalendar,
|
|
455
654
|
T as YearCalendar,
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
655
|
+
P as componentRegistry,
|
|
656
|
+
pt as default,
|
|
657
|
+
re as defaultComponentMap,
|
|
658
|
+
le as defaultDesignTokens,
|
|
659
|
+
mt as generateCSSVariables,
|
|
660
|
+
ut as generateDeterministicId,
|
|
661
|
+
gt as generateId,
|
|
662
|
+
dt as generateTailwindConfig,
|
|
663
|
+
lt as getComponent,
|
|
664
|
+
it as mergeDesignTokens,
|
|
665
|
+
nt as registerComponent,
|
|
666
|
+
bt as sanitizeId
|
|
464
667
|
};
|
|
465
668
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../src/utils/component-registry.ts","../src/components/UiRadialProgressBar.vue","../src/components/inputs/InputsShowcase.vue","../src/plugin.ts"],"sourcesContent":["import { defineAsyncComponent, type Component } from 'vue'\nimport UiTextInput from '../components/UiTextInput.vue'\nimport type { ComponentMap } from '../types/form'\n\n/**\n * Default component map for dynamic forms\n */\nexport const defaultComponentMap: ComponentMap = {\n text: {\n component: 'TextInput',\n loader: () => Promise.resolve(UiTextInput)\n },\n email: {\n component: 'TextInput',\n loader: () => Promise.resolve(UiTextInput)\n },\n password: {\n component: 'TextInput',\n loader: () => Promise.resolve(UiTextInput)\n },\n number: {\n component: 'TextInput',\n loader: () => Promise.resolve(UiTextInput)\n },\n tel: {\n component: 'TextInput',\n loader: () => Promise.resolve(UiTextInput)\n },\n url: {\n component: 'TextInput',\n loader: () => Promise.resolve(UiTextInput)\n },\n textarea: {\n component: 'TextAreaInput',\n loader: () => import('../components/inputs/TextAreaInput.vue')\n },\n select: {\n component: 'SelectInput',\n loader: () => import('../components/inputs/SelectInput.vue')\n },\n combobox: {\n component: 'ComboboxInput',\n loader: () => import('../components/inputs/ComboboxInput.vue')\n },\n checkbox: {\n component: 'CheckboxInput',\n loader: () => import('../components/inputs/CheckboxInput.vue')\n },\n switch: {\n component: 'SwitchInput',\n loader: () => import('../components/inputs/SwitchInput.vue')\n }\n}\n\n/**\n * Component registry class for managing dynamic form components\n */\nexport class ComponentRegistry {\n private componentMap: ComponentMap = { ...defaultComponentMap }\n private loadedComponents: Map<string, Component> = new Map()\n\n /**\n * Register a new component type\n */\n register(type: string, component: string, loader: () => Promise<any>): void {\n this.componentMap[type] = { component, loader }\n // Clear cached component if it exists\n this.loadedComponents.delete(type)\n }\n\n /**\n * Get a component for a field type\n */\n getComponent(type: string): Component | null {\n const mapItem = this.componentMap[type]\n if (!mapItem) {\n console.warn(`Component type \"${type}\" is not registered`)\n return null\n }\n\n // Return cached component if available\n if (this.loadedComponents.has(type)) {\n return this.loadedComponents.get(type)!\n }\n\n // Create async component\n const asyncComponent = defineAsyncComponent({\n loader: mapItem.loader,\n delay: 0\n })\n\n this.loadedComponents.set(type, asyncComponent)\n return asyncComponent\n }\n\n /**\n * Check if a component type is registered\n */\n hasComponent(type: string): boolean {\n return type in this.componentMap\n }\n\n /**\n * Get all registered component types\n */\n getRegisteredTypes(): string[] {\n return Object.keys(this.componentMap)\n }\n\n /**\n * Unregister a component type\n */\n unregister(type: string): void {\n delete this.componentMap[type]\n this.loadedComponents.delete(type)\n }\n\n /**\n * Clear all cached components\n */\n clearCache(): void {\n this.loadedComponents.clear()\n }\n}\n\n// Global component registry instance\nexport const componentRegistry = new ComponentRegistry()\n\n/**\n * Register a component type globally\n */\nexport function registerComponent(type: string, component: string, loader: () => Promise<any>): void {\n componentRegistry.register(type, component, loader)\n}\n\n/**\n * Get a component for a field type\n */\nexport function getComponent(type: string): Component | null {\n return componentRegistry.getComponent(type)\n}\n","<template>\n <div class=\"sl-relative\" :class=\"sizeClass\">\n <svg viewBox=\"0 0 36 36\" class=\"sl-transform -sl-rotate-90 sl-w-full sl-h-full\">\n <path class=\"sl-fill-none sl-stroke-gray-300\" stroke-width=\"3.8\"\n d=\"M18 2.0845 a 15.9155 15.9155 0 0 1 0 31.831 a 15.9155 15.9155 0 0 1 0 -31.831\" />\n <path\n class=\"sl-fill-none sl-stroke-stachelock-600 sl-stroke-linecap-round sl-transition-[stroke-dasharray] sl-duration-500 sl-ease-out\"\n :stroke-dasharray=\"progress + ', 100'\" stroke-width=\"3.8\"\n d=\"M18 2.0845 a 15.9155 15.9155 0 0 1 0 31.831 a 15.9155 15.9155 0 0 1 0 -31.831\" />\n </svg>\n <div v-if=\"label && label.length > 0\"\n class=\"sl-absolute sl-top-1/2 sl-left-1/2 sl-transform -sl-translate-x-1/2 -sl-translate-y-1/2 sl-text-center\">{{ label }}</div>\n <div v-if=\"showProgressLabel\"\n class=\"sl-absolute sl-top-1/2 sl-left-1/2 sl-transform -sl-translate-x-1/2 -sl-translate-y-1/2 sl-text-center sl-text-xs\">\n {{ progress }}%\n </div>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, ref, watch } from 'vue';\n\ntype RadialProgressBarSize = 'xs' | 'sm' | 'md' | 'lg';\n\nconst props = defineProps({\n progress: {\n type: Number,\n default: 0\n },\n label: {\n type: String,\n default: ''\n },\n showProgressLabel: {\n type: Boolean,\n default: false\n },\n size: {\n type: String as () => RadialProgressBarSize,\n default: 'md'\n }\n});\n\nconst sizeClass = computed(() => {\n switch (props.size) {\n case 'xs':\n return 'sl-h-4 sl-w-4'\n case 'sm':\n return 'sl-h-8 sl-w-8'\n case 'md':\n return 'sl-h-12 sl-w-12'\n case 'lg':\n return 'sl-h-16 sl-w-16'\n default:\n return 'sl-h-8 sl-w-8'\n }\n});\n\nconst progress = ref(props.progress);\n\nwatch(() => props.progress, (newValue) => {\n progress.value = newValue;\n});\n</script>\n\n<style scoped>\n</style>\n","<template>\n <section class=\"sl-bg-white sl-rounded-lg sl-shadow sl-p-6\">\n <h2 class=\"sl-text-xl sl-font-semibold sl-mb-4\">All Inputs Showcase</h2>\n\n <div class=\"sl-space-y-8\">\n <!-- Text Input -->\n <div>\n <h3 class=\"sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2\">Text Input</h3>\n <TextInput\n name=\"demoText\"\n label=\"Text Input\"\n placeholder=\"Type something...\"\n v-model:value=\"state.text\"\n />\n </div>\n\n <!-- Text Area Input -->\n <div>\n <h3 class=\"sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2\">Text Area</h3>\n <TextAreaInput\n name=\"demoTextArea\"\n label=\"Text Area\"\n placeholder=\"Write a longer message...\"\n :rows=\"4\"\n :maxlength=\"200\"\n v-model=\"state.textArea\"\n />\n </div>\n\n <!-- Switch Input -->\n <div>\n <h3 class=\"sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2\">Switch</h3>\n <SwitchInput\n name=\"demoSwitch\"\n label=\"Enable feature\"\n v-model=\"state.switchOn\"\n textTrue=\"ON\"\n textFalse=\"OFF\"\n />\n </div>\n\n <!-- Checkbox Input -->\n <div>\n <h3 class=\"sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2\">Checkbox</h3>\n <CheckboxInput\n name=\"demoCheckbox\"\n label=\"I agree to the terms\"\n v-model=\"state.checkbox\"\n />\n </div>\n\n <!-- Select Input -->\n <div class=\"sl-grid sl-grid-cols-1 sl-md:grid-cols-2 sl-gap-6\">\n <div>\n <h3 class=\"sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2\">Select (Single)</h3>\n <SelectInput\n name=\"demoSelect\"\n label=\"Favorite Fruit\"\n placeholder=\"Select a fruit\"\n :items=\"fruits\"\n v-model=\"state.selectedFruit\"\n />\n </div>\n <div>\n <h3 class=\"sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2\">Select (Multiple)</h3>\n <SelectInput\n name=\"demoSelectMulti\"\n label=\"Favorite Languages\"\n placeholder=\"Select languages\"\n :items=\"languages\"\n multiple\n showAll\n v-model=\"state.selectedLanguages\"\n />\n </div>\n </div>\n\n <!-- Combobox Input -->\n <div>\n <h3 class=\"sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2\">Combobox</h3>\n <ComboboxInput\n name=\"demoCombobox\"\n label=\"Search a City\"\n placeholder=\"Start typing...\"\n :items=\"cities\"\n v-model=\"state.selectedCity\"\n />\n </div>\n\n <!-- Current State -->\n <div class=\"sl-bg-gray-50 sl-rounded-md sl-p-4 sl-text-sm sl-text-gray-700\">\n <div class=\"sl-font-semibold sl-mb-1\">State</div>\n <pre class=\"sl-whitespace-pre-wrap\">{{ state }}</pre>\n </div>\n </div>\n </section>\n</template>\n\n<script setup lang=\"ts\">\nimport { reactive } from 'vue'\nimport TextInput from '../UiTextInput.vue'\nimport TextAreaInput from './TextAreaInput.vue'\nimport SwitchInput from './SwitchInput.vue'\nimport CheckboxInput from './CheckboxInput.vue'\nimport SelectInput from './SelectInput.vue'\nimport ComboboxInput from './ComboboxInput.vue'\n\nconst state = reactive({\n text: '',\n textArea: '',\n switchOn: false,\n checkbox: false,\n selectedFruit: null as null | { id: number; name: string },\n selectedLanguages: [] as Array<{ id: number; name: string }>,\n selectedCity: null as null | { id: number; name: string },\n})\n\nconst fruits = [\n { id: 1, name: 'Apple' },\n { id: 2, name: 'Banana' },\n { id: 3, name: 'Cherry' },\n { id: 4, name: 'Durian', disabled: true },\n]\n\nconst languages = [\n { id: 1, name: 'TypeScript' },\n { id: 2, name: 'JavaScript' },\n { id: 3, name: 'Python' },\n { id: 4, name: 'Go' },\n { id: 5, name: 'Rust' },\n]\n\nconst cities = [\n { id: 1, name: 'New York' },\n { id: 2, name: 'San Francisco' },\n { id: 3, name: 'Seattle' },\n { id: 4, name: 'Austin' },\n { id: 5, name: 'Chicago' },\n { id: 6, name: 'Denver' },\n { id: 7, name: 'Miami' },\n { id: 8, name: 'Boston' },\n]\n</script>\n\n\n","import type { App } from 'vue';\nimport * as components from './components';\nimport * as layouts from './components/layouts';\nimport * as inputs from './components/inputs';\nimport * as calendars from './components/calendars';\nimport * as forms from './components/forms';\n\n// Combine all components\nconst allComponents = {\n ...components,\n ...layouts,\n ...inputs,\n ...calendars,\n ...forms,\n};\n\n// Plugin interface\nexport interface StachelockUIOptions {\n /**\n * Component name prefix (default: 'Sl')\n */\n prefix?: string;\n /**\n * Array of component names to install globally\n */\n components?: string[];\n /**\n * Whether to install all components globally\n */\n installAll?: boolean;\n}\n\n// Vue plugin\nexport const StachelockUI = {\n install(app: App, options: StachelockUIOptions = {}) {\n const { prefix = 'Sl', installAll = false, components: selectedComponents } = options;\n\n // Register components\n Object.entries(allComponents).forEach(([name, component]) => {\n const shouldInstall = installAll || \n (selectedComponents && selectedComponents.includes(name)) ||\n (!selectedComponents && !installAll);\n\n if (shouldInstall) {\n // Register non-prefixed\n app.component(name, component);\n // Also register prefixed alias for back-compat\n const prefixedName = name.startsWith(prefix) ? name : `${prefix}${name}`;\n app.component(prefixedName, component);\n }\n });\n }\n};\n\nexport default StachelockUI;\n"],"names":["defaultComponentMap","UiTextInput","ComponentRegistry","type","component","loader","mapItem","asyncComponent","defineAsyncComponent","componentRegistry","registerComponent","getComponent","props","__props","sizeClass","computed","progress","ref","watch","newValue","_createElementBlock","_normalizeClass","_openBlock","_hoisted_1","_createElementVNode","_hoisted_3","_toDisplayString","_hoisted_4","state","reactive","fruits","languages","cities","_cache","_hoisted_2","_createVNode","TextInput","$event","TextAreaInput","SwitchInput","CheckboxInput","SelectInput","ComboboxInput","_hoisted_5","allComponents","components","layouts","inputs","calendars","forms","StachelockUI","app","options","prefix","installAll","selectedComponents","name","prefixedName"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../src/utils/component-registry.ts","../src/config/design-tokens.ts","../src/config/css-variables.ts","../src/components/UiRadialProgressBar.vue","../src/components/inputs/InputsShowcase.vue","../src/plugin.ts"],"sourcesContent":["import { defineAsyncComponent, type Component } from 'vue'\nimport UiTextInput from '../components/UiTextInput.vue'\nimport type { ComponentMap } from '../types/form'\n\n/**\n * Default component map for dynamic forms\n */\nexport const defaultComponentMap: ComponentMap = {\n text: {\n component: 'TextInput',\n loader: () => Promise.resolve(UiTextInput)\n },\n email: {\n component: 'TextInput',\n loader: () => Promise.resolve(UiTextInput)\n },\n password: {\n component: 'TextInput',\n loader: () => Promise.resolve(UiTextInput)\n },\n number: {\n component: 'TextInput',\n loader: () => Promise.resolve(UiTextInput)\n },\n tel: {\n component: 'TextInput',\n loader: () => Promise.resolve(UiTextInput)\n },\n url: {\n component: 'TextInput',\n loader: () => Promise.resolve(UiTextInput)\n },\n textarea: {\n component: 'TextAreaInput',\n loader: () => import('../components/inputs/TextAreaInput.vue')\n },\n select: {\n component: 'SelectInput',\n loader: () => import('../components/inputs/SelectInput.vue')\n },\n combobox: {\n component: 'ComboboxInput',\n loader: () => import('../components/inputs/ComboboxInput.vue')\n },\n checkbox: {\n component: 'CheckboxInput',\n loader: () => import('../components/inputs/CheckboxInput.vue')\n },\n switch: {\n component: 'SwitchInput',\n loader: () => import('../components/inputs/SwitchInput.vue')\n }\n}\n\n/**\n * Component registry class for managing dynamic form components\n */\nexport class ComponentRegistry {\n private componentMap: ComponentMap = { ...defaultComponentMap }\n private loadedComponents: Map<string, Component> = new Map()\n\n /**\n * Register a new component type\n */\n register(type: string, component: string, loader: () => Promise<any>): void {\n this.componentMap[type] = { component, loader }\n // Clear cached component if it exists\n this.loadedComponents.delete(type)\n }\n\n /**\n * Get a component for a field type\n */\n getComponent(type: string): Component | null {\n const mapItem = this.componentMap[type]\n if (!mapItem) {\n console.warn(`Component type \"${type}\" is not registered`)\n return null\n }\n\n // Return cached component if available\n if (this.loadedComponents.has(type)) {\n return this.loadedComponents.get(type)!\n }\n\n // Create async component\n const asyncComponent = defineAsyncComponent({\n loader: mapItem.loader,\n delay: 0\n })\n\n this.loadedComponents.set(type, asyncComponent)\n return asyncComponent\n }\n\n /**\n * Check if a component type is registered\n */\n hasComponent(type: string): boolean {\n return type in this.componentMap\n }\n\n /**\n * Get all registered component types\n */\n getRegisteredTypes(): string[] {\n return Object.keys(this.componentMap)\n }\n\n /**\n * Unregister a component type\n */\n unregister(type: string): void {\n delete this.componentMap[type]\n this.loadedComponents.delete(type)\n }\n\n /**\n * Clear all cached components\n */\n clearCache(): void {\n this.loadedComponents.clear()\n }\n}\n\n// Global component registry instance\nexport const componentRegistry = new ComponentRegistry()\n\n/**\n * Register a component type globally\n */\nexport function registerComponent(type: string, component: string, loader: () => Promise<any>): void {\n componentRegistry.register(type, component, loader)\n}\n\n/**\n * Get a component for a field type\n */\nexport function getComponent(type: string): Component | null {\n return componentRegistry.getComponent(type)\n}\n","export interface StachelockUIDesignTokens {\n colors?: {\n primary?: {\n 50?: string;\n 100?: string;\n 200?: string;\n 300?: string;\n 400?: string;\n 500?: string;\n 600?: string;\n 700?: string;\n 800?: string;\n 900?: string;\n };\n stachelock?: {\n 50?: string;\n 100?: string;\n 200?: string;\n 300?: string;\n 400?: string;\n 500?: string;\n 600?: string;\n 700?: string;\n 800?: string;\n 900?: string;\n };\n [key: string]: any;\n };\n spacing?: {\n [key: string]: string;\n };\n borderRadius?: {\n [key: string]: string;\n };\n shadows?: {\n [key: string]: string;\n };\n typography?: {\n fontFamily?: {\n [key: string]: string[];\n };\n fontSize?: {\n [key: string]: string;\n };\n };\n breakpoints?: {\n [key: string]: string;\n };\n}\n\nexport const defaultDesignTokens: StachelockUIDesignTokens = {\n colors: {\n primary: {\n 50: '#edeff9',\n 100: '#dbdff2',\n 200: '#b8bfe6',\n 300: '#949ed9',\n 400: '#717ecd',\n 500: '#4d5ec0',\n 600: '#3e4b9a',\n 700: '#2e3873',\n 800: '#1f264d',\n 900: '#0f1326',\n },\n stachelock: {\n 50: '#edeff9',\n 100: '#dbdff2',\n 200: '#b8bfe6',\n 300: '#949ed9',\n 400: '#717ecd',\n 500: '#4d5ec0',\n 600: '#3e4b9a',\n 700: '#2e3873',\n 800: '#1f264d',\n 900: '#0f1326',\n },\n },\n spacing: {\n '0': '0',\n '1': '0.25rem',\n '2': '0.5rem',\n '3': '0.75rem',\n '4': '1rem',\n '5': '1.25rem',\n '6': '1.5rem',\n '8': '2rem',\n '10': '2.5rem',\n '12': '3rem',\n '16': '4rem',\n '20': '5rem',\n '24': '6rem',\n '32': '8rem',\n '40': '10rem',\n '48': '12rem',\n '56': '14rem',\n '64': '16rem',\n '72': '18rem',\n '80': '20rem',\n '96': '24rem',\n },\n borderRadius: {\n 'none': '0',\n 'sm': '0.125rem',\n 'DEFAULT': '0.25rem',\n 'md': '0.375rem',\n 'lg': '0.5rem',\n 'xl': '0.75rem',\n '2xl': '1rem',\n '3xl': '1.5rem',\n 'full': '9999px',\n },\n shadows: {\n 'sm': '0 1px 2px 0 rgb(0 0 0 / 0.05)',\n 'DEFAULT': '0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1)',\n 'md': '0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1)',\n 'lg': '0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1)',\n 'xl': '0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1)',\n '2xl': '0 25px 50px -12px rgb(0 0 0 / 0.25)',\n 'inner': 'inset 0 2px 4px 0 rgb(0 0 0 / 0.05)',\n 'none': 'none',\n },\n typography: {\n fontFamily: {\n sans: ['Inter', 'ui-sans-serif', 'system-ui', 'sans-serif'],\n serif: ['ui-serif', 'Georgia', 'Cambria', 'serif'],\n mono: ['ui-monospace', 'SFMono-Regular', 'Menlo', 'Monaco', 'Consolas', 'monospace'],\n },\n fontSize: {\n 'xs': '0.75rem',\n 'sm': '0.875rem',\n 'base': '1rem',\n 'lg': '1.125rem',\n 'xl': '1.25rem',\n '2xl': '1.5rem',\n '3xl': '1.875rem',\n '4xl': '2.25rem',\n '5xl': '3rem',\n '6xl': '3.75rem',\n '7xl': '4.5rem',\n '8xl': '6rem',\n '9xl': '8rem',\n },\n },\n breakpoints: {\n 'sm': '640px',\n 'md': '768px',\n 'lg': '1024px',\n 'xl': '1280px',\n '2xl': '1536px',\n },\n};\n\nexport function mergeDesignTokens(\n customTokens: StachelockUIDesignTokens,\n defaults: StachelockUIDesignTokens = defaultDesignTokens\n): StachelockUIDesignTokens {\n const merged = { ...defaults };\n \n // Deep merge function for nested objects\n function deepMerge(target: any, source: any): any {\n if (source && typeof source === 'object' && !Array.isArray(source)) {\n for (const key in source) {\n if (source.hasOwnProperty(key)) {\n if (target[key] && typeof target[key] === 'object' && !Array.isArray(target[key])) {\n target[key] = deepMerge(target[key], source[key]);\n } else {\n target[key] = source[key];\n }\n }\n }\n }\n return target;\n }\n \n return deepMerge(merged, customTokens);\n}\n","import type { StachelockUIDesignTokens } from './design-tokens';\n\nexport function generateCSSVariables(tokens: StachelockUIDesignTokens): string {\n let css = ':root {\\n';\n \n // Generate color variables\n if (tokens.colors) {\n Object.entries(tokens.colors).forEach(([colorName, colorShades]) => {\n if (typeof colorShades === 'object' && colorShades !== null) {\n Object.entries(colorShades).forEach(([shade, value]) => {\n const variableName = shade === 'DEFAULT' ? colorName : `${colorName}-${shade}`;\n css += ` --sl-color-${variableName}: ${value};\\n`;\n });\n }\n });\n }\n \n // Generate spacing variables\n if (tokens.spacing) {\n Object.entries(tokens.spacing).forEach(([name, value]) => {\n css += ` --sl-spacing-${name}: ${value};\\n`;\n });\n }\n \n // Generate border radius variables\n if (tokens.borderRadius) {\n Object.entries(tokens.borderRadius).forEach(([name, value]) => {\n const variableName = name === 'DEFAULT' ? 'radius' : `radius-${name}`;\n css += ` --sl-${variableName}: ${value};\\n`;\n });\n }\n \n // Generate shadow variables\n if (tokens.shadows) {\n Object.entries(tokens.shadows).forEach(([name, value]) => {\n const variableName = name === 'DEFAULT' ? 'shadow' : `shadow-${name}`;\n css += ` --sl-${variableName}: ${value};\\n`;\n });\n }\n \n // Generate typography variables\n if (tokens.typography) {\n if (tokens.typography.fontFamily) {\n Object.entries(tokens.typography.fontFamily).forEach(([name, fonts]) => {\n css += ` --sl-font-family-${name}: ${fonts.join(', ')};\\n`;\n });\n }\n \n if (tokens.typography.fontSize) {\n Object.entries(tokens.typography.fontSize).forEach(([name, size]) => {\n css += ` --sl-font-size-${name}: ${size};\\n`;\n });\n }\n }\n \n // Generate breakpoint variables\n if (tokens.breakpoints) {\n Object.entries(tokens.breakpoints).forEach(([name, value]) => {\n css += ` --sl-breakpoint-${name}: ${value};\\n`;\n });\n }\n \n // Add some computed variables\n css += ` --sl-ring-color: var(--sl-color-primary-600, #3e4b9a);\\n`;\n css += ` --sl-ring-offset-color: #ffffff;\\n`;\n css += ` --sl-ring-width: 2px;\\n`;\n css += ` --sl-outline-color: var(--sl-color-primary-600, #3e4b9a);\\n`;\n css += ` --sl-outline-width: 2px;\\n`;\n \n css += '}\\n\\n';\n \n // Add dark mode variables\n css += '@media (prefers-color-scheme: dark) {\\n';\n css += ' :root {\\n';\n css += ' --sl-ring-color: var(--sl-color-primary-600, #3e4b9a);\\n';\n css += ' }\\n';\n css += '}\\n';\n \n return css;\n}\n\nexport function generateTailwindConfig(tokens: StachelockUIDesignTokens): string {\n let config = 'export default {\\n';\n config += ' prefix: \"sl-\",\\n';\n config += ' theme: {\\n';\n config += ' extend: {\\n';\n \n // Colors\n if (tokens.colors) {\n config += ' colors: {\\n';\n Object.entries(tokens.colors).forEach(([colorName, colorShades]) => {\n if (typeof colorShades === 'object' && colorShades !== null) {\n config += ` \"${colorName}\": {\\n`;\n Object.entries(colorShades).forEach(([shade, value]) => {\n const shadeName = shade === 'DEFAULT' ? 'DEFAULT' : shade;\n config += ` \"${shadeName}\": \"${value}\",\\n`;\n });\n config += ' },\\n';\n }\n });\n config += ' },\\n';\n }\n \n // Spacing\n if (tokens.spacing) {\n config += ' spacing: {\\n';\n Object.entries(tokens.spacing).forEach(([name, value]) => {\n config += ` \"${name}\": \"${value}\",\\n`;\n });\n config += ' },\\n';\n }\n \n // Border radius\n if (tokens.borderRadius) {\n config += ' borderRadius: {\\n';\n Object.entries(tokens.borderRadius).forEach(([name, value]) => {\n const configName = name === 'DEFAULT' ? 'DEFAULT' : name;\n config += ` \"${configName}\": \"${value}\",\\n`;\n });\n config += ' },\\n';\n }\n \n // Shadows\n if (tokens.shadows) {\n config += ' boxShadow: {\\n';\n Object.entries(tokens.shadows).forEach(([name, value]) => {\n const configName = name === 'DEFAULT' ? 'DEFAULT' : name;\n config += ` \"${configName}\": \"${value}\",\\n`;\n });\n config += ' },\\n';\n }\n \n // Typography\n if (tokens.typography) {\n if (tokens.typography.fontFamily) {\n config += ' fontFamily: {\\n';\n Object.entries(tokens.typography.fontFamily).forEach(([name, fonts]) => {\n config += ` \"${name}\": [${fonts.map(f => `\"${f}\"`).join(', ')}],\\n`;\n });\n config += ' },\\n';\n }\n \n if (tokens.typography.fontSize) {\n config += ' fontSize: {\\n';\n Object.entries(tokens.typography.fontSize).forEach(([name, size]) => {\n config += ` \"${name}\": \"${size}\",\\n`;\n });\n config += ' },\\n';\n }\n }\n \n config += ' },\\n';\n config += ' },\\n';\n config += '};\\n';\n \n return config;\n}\n","<template>\n <div class=\"sl-relative\" :class=\"sizeClass\">\n <svg viewBox=\"0 0 36 36\" class=\"sl-transform -sl-rotate-90 sl-w-full sl-h-full\">\n <path class=\"sl-fill-none sl-stroke-gray-300\" stroke-width=\"3.8\"\n d=\"M18 2.0845 a 15.9155 15.9155 0 0 1 0 31.831 a 15.9155 15.9155 0 0 1 0 -31.831\" />\n <path\n class=\"sl-fill-none sl-stroke-stachelock-600 sl-stroke-linecap-round sl-transition-[stroke-dasharray] sl-duration-500 sl-ease-out\"\n :stroke-dasharray=\"progress + ', 100'\" stroke-width=\"3.8\"\n d=\"M18 2.0845 a 15.9155 15.9155 0 0 1 0 31.831 a 15.9155 15.9155 0 0 1 0 -31.831\" />\n </svg>\n <div v-if=\"label && label.length > 0\"\n class=\"sl-absolute sl-top-1/2 sl-left-1/2 sl-transform -sl-translate-x-1/2 -sl-translate-y-1/2 sl-text-center\">{{ label }}</div>\n <div v-if=\"showProgressLabel\"\n class=\"sl-absolute sl-top-1/2 sl-left-1/2 sl-transform -sl-translate-x-1/2 -sl-translate-y-1/2 sl-text-center sl-text-xs\">\n {{ progress }}%\n </div>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, ref, watch } from 'vue';\n\ntype RadialProgressBarSize = 'xs' | 'sm' | 'md' | 'lg';\n\nconst props = defineProps({\n progress: {\n type: Number,\n default: 0\n },\n label: {\n type: String,\n default: ''\n },\n showProgressLabel: {\n type: Boolean,\n default: false\n },\n size: {\n type: String as () => RadialProgressBarSize,\n default: 'md'\n }\n});\n\nconst sizeClass = computed(() => {\n switch (props.size) {\n case 'xs':\n return 'sl-h-4 sl-w-4'\n case 'sm':\n return 'sl-h-8 sl-w-8'\n case 'md':\n return 'sl-h-12 sl-w-12'\n case 'lg':\n return 'sl-h-16 sl-w-16'\n default:\n return 'sl-h-8 sl-w-8'\n }\n});\n\nconst progress = ref(props.progress);\n\nwatch(() => props.progress, (newValue) => {\n progress.value = newValue;\n});\n</script>\n\n<style scoped>\n</style>\n","<template>\n <section class=\"sl-bg-white sl-rounded-lg sl-shadow sl-p-6\">\n <h2 class=\"sl-text-xl sl-font-semibold sl-mb-4\">All Inputs Showcase</h2>\n\n <div class=\"sl-space-y-8\">\n <!-- Text Input -->\n <div>\n <h3 class=\"sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2\">Text Input</h3>\n <TextInput\n name=\"demoText\"\n label=\"Text Input\"\n placeholder=\"Type something...\"\n v-model:value=\"state.text\"\n />\n </div>\n\n <!-- Text Area Input -->\n <div>\n <h3 class=\"sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2\">Text Area</h3>\n <TextAreaInput\n name=\"demoTextArea\"\n label=\"Text Area\"\n placeholder=\"Write a longer message...\"\n :rows=\"4\"\n :maxlength=\"200\"\n v-model=\"state.textArea\"\n />\n </div>\n\n <!-- Switch Input -->\n <div>\n <h3 class=\"sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2\">Switch</h3>\n <SwitchInput\n name=\"demoSwitch\"\n label=\"Enable feature\"\n v-model=\"state.switchOn\"\n textTrue=\"ON\"\n textFalse=\"OFF\"\n />\n </div>\n\n <!-- Checkbox Input -->\n <div>\n <h3 class=\"sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2\">Checkbox</h3>\n <CheckboxInput\n name=\"demoCheckbox\"\n label=\"I agree to the terms\"\n v-model=\"state.checkbox\"\n />\n </div>\n\n <!-- Select Input -->\n <div class=\"sl-grid sl-grid-cols-1 sl-md:grid-cols-2 sl-gap-6\">\n <div>\n <h3 class=\"sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2\">Select (Single)</h3>\n <SelectInput\n name=\"demoSelect\"\n label=\"Favorite Fruit\"\n placeholder=\"Select a fruit\"\n :items=\"fruits\"\n v-model=\"state.selectedFruit\"\n />\n </div>\n <div>\n <h3 class=\"sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2\">Select (Multiple)</h3>\n <SelectInput\n name=\"demoSelectMulti\"\n label=\"Favorite Languages\"\n placeholder=\"Select languages\"\n :items=\"languages\"\n multiple\n showAll\n v-model=\"state.selectedLanguages\"\n />\n </div>\n </div>\n\n <!-- Combobox Input -->\n <div>\n <h3 class=\"sl-text-sm sl-font-medium sl-text-gray-700 sl-mb-2\">Combobox</h3>\n <ComboboxInput\n name=\"demoCombobox\"\n label=\"Search a City\"\n placeholder=\"Start typing...\"\n :items=\"cities\"\n v-model=\"state.selectedCity\"\n />\n </div>\n\n <!-- Current State -->\n <div class=\"sl-bg-gray-50 sl-rounded-md sl-p-4 sl-text-sm sl-text-gray-700\">\n <div class=\"sl-font-semibold sl-mb-1\">State</div>\n <pre class=\"sl-whitespace-pre-wrap\">{{ state }}</pre>\n </div>\n </div>\n </section>\n</template>\n\n<script setup lang=\"ts\">\nimport { reactive } from 'vue'\nimport TextInput from '../UiTextInput.vue'\nimport TextAreaInput from './TextAreaInput.vue'\nimport SwitchInput from './SwitchInput.vue'\nimport CheckboxInput from './CheckboxInput.vue'\nimport SelectInput from './SelectInput.vue'\nimport ComboboxInput from './ComboboxInput.vue'\n\nconst state = reactive({\n text: '',\n textArea: '',\n switchOn: false,\n checkbox: false,\n selectedFruit: null as null | { id: number; name: string },\n selectedLanguages: [] as Array<{ id: number; name: string }>,\n selectedCity: null as null | { id: number; name: string },\n})\n\nconst fruits = [\n { id: 1, name: 'Apple' },\n { id: 2, name: 'Banana' },\n { id: 3, name: 'Cherry' },\n { id: 4, name: 'Durian', disabled: true },\n]\n\nconst languages = [\n { id: 1, name: 'TypeScript' },\n { id: 2, name: 'JavaScript' },\n { id: 3, name: 'Python' },\n { id: 4, name: 'Go' },\n { id: 5, name: 'Rust' },\n]\n\nconst cities = [\n { id: 1, name: 'New York' },\n { id: 2, name: 'San Francisco' },\n { id: 3, name: 'Seattle' },\n { id: 4, name: 'Austin' },\n { id: 5, name: 'Chicago' },\n { id: 6, name: 'Denver' },\n { id: 7, name: 'Miami' },\n { id: 8, name: 'Boston' },\n]\n</script>\n\n\n","import type { App } from 'vue';\nimport * as components from './components';\nimport * as layouts from './components/layouts';\nimport * as inputs from './components/inputs';\nimport * as calendars from './components/calendars';\nimport * as forms from './components/forms';\n\n// Combine all components\nconst allComponents = {\n ...components,\n ...layouts,\n ...inputs,\n ...calendars,\n ...forms,\n};\n\n// Plugin interface\nexport interface StachelockUIOptions {\n /**\n * Component name prefix (default: 'Sl')\n */\n prefix?: string;\n /**\n * Array of component names to install globally\n */\n components?: string[];\n /**\n * Whether to install all components globally\n */\n installAll?: boolean;\n}\n\n// Vue plugin\nexport const StachelockUI = {\n install(app: App, options: StachelockUIOptions = {}) {\n const { prefix = 'Sl', installAll = false, components: selectedComponents } = options;\n\n // Register components\n Object.entries(allComponents).forEach(([name, component]) => {\n const shouldInstall = installAll || \n (selectedComponents && selectedComponents.includes(name)) ||\n (!selectedComponents && !installAll);\n\n if (shouldInstall) {\n // Register non-prefixed\n app.component(name, component);\n // Also register prefixed alias for back-compat\n const prefixedName = name.startsWith(prefix) ? name : `${prefix}${name}`;\n app.component(prefixedName, component);\n }\n });\n }\n};\n\nexport default StachelockUI;\n"],"names":["defaultComponentMap","UiTextInput","ComponentRegistry","type","component","loader","mapItem","asyncComponent","defineAsyncComponent","componentRegistry","registerComponent","getComponent","defaultDesignTokens","mergeDesignTokens","customTokens","defaults","merged","deepMerge","target","source","key","generateCSSVariables","tokens","css","colorName","colorShades","shade","value","variableName","name","fonts","size","generateTailwindConfig","config","f","props","__props","sizeClass","computed","progress","ref","watch","newValue","_createElementBlock","_normalizeClass","_openBlock","_hoisted_1","_createElementVNode","_hoisted_3","_toDisplayString","_hoisted_4","state","reactive","fruits","languages","cities","_cache","_hoisted_2","_createVNode","TextInput","$event","TextAreaInput","SwitchInput","CheckboxInput","SelectInput","ComboboxInput","_hoisted_5","allComponents","components","layouts","inputs","calendars","forms","StachelockUI","app","options","prefix","installAll","selectedComponents","prefixedName"],"mappings":"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"}
|
package/dist/src/index.d.ts
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
export * from './types';
|
|
2
2
|
export * from './utils/id';
|
|
3
3
|
export * from './utils/component-registry';
|
|
4
|
+
export * from './config/design-tokens';
|
|
5
|
+
export * from './config/css-variables';
|
|
4
6
|
export * from './components';
|
|
5
7
|
export * from './components/layouts';
|
|
6
8
|
export * from './components/inputs';
|
package/dist/src/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AACA,cAAc,SAAS,CAAC;AAGxB,cAAc,YAAY,CAAC;AAC3B,cAAc,4BAA4B,CAAC;AAG3C,cAAc,cAAc,CAAC;AAG7B,cAAc,sBAAsB,CAAC;AAGrC,cAAc,qBAAqB,CAAC;AAGpC,cAAc,wBAAwB,CAAC;AAGvC,cAAc,oBAAoB,CAAC;AAGnC,OAAO,EAAE,YAAY,EAAE,KAAK,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAClE,OAAO,EAAE,YAAY,IAAI,OAAO,EAAE,MAAM,UAAU,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AACA,cAAc,SAAS,CAAC;AAGxB,cAAc,YAAY,CAAC;AAC3B,cAAc,4BAA4B,CAAC;AAG3C,cAAc,wBAAwB,CAAC;AACvC,cAAc,wBAAwB,CAAC;AAGvC,cAAc,cAAc,CAAC;AAG7B,cAAc,sBAAsB,CAAC;AAGrC,cAAc,qBAAqB,CAAC;AAGpC,cAAc,wBAAwB,CAAC;AAGvC,cAAc,oBAAoB,CAAC;AAGnC,OAAO,EAAE,YAAY,EAAE,KAAK,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAClE,OAAO,EAAE,YAAY,IAAI,OAAO,EAAE,MAAM,UAAU,CAAC"}
|
package/package.json
CHANGED
|
@@ -120,6 +120,10 @@ function generateMainIndexFile(srcDirectoryPath) {
|
|
|
120
120
|
"export * from './utils/id';",
|
|
121
121
|
"export * from './utils/component-registry';",
|
|
122
122
|
"",
|
|
123
|
+
"// Configuration System",
|
|
124
|
+
"export * from './config/design-tokens';",
|
|
125
|
+
"export * from './config/css-variables';",
|
|
126
|
+
"",
|
|
123
127
|
"// Base UI Components",
|
|
124
128
|
"export * from './components';",
|
|
125
129
|
"",
|
|
@@ -233,8 +237,8 @@ function main() {
|
|
|
233
237
|
// Generate main index file
|
|
234
238
|
generateMainIndexFile(srcDirectoryPath);
|
|
235
239
|
|
|
236
|
-
//
|
|
237
|
-
generatePluginFile(srcDirectoryPath);
|
|
240
|
+
// Don't generate plugin file - we have a custom one
|
|
241
|
+
// generatePluginFile(srcDirectoryPath);
|
|
238
242
|
|
|
239
243
|
console.log('\n✨ All index files generated successfully!');
|
|
240
244
|
} catch (error) {
|