@wishbone-media/spark 0.5.2 → 0.8.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.
- package/dist/index.js +489 -490
- package/package.json +4 -2
- package/src/components/SparkBrandSelector.vue +7 -1
- package/src/stores/brand-filter.js +62 -29
- package/src/views/SparkForgotPasswordView.vue +75 -0
- package/src/views/SparkLoginView.vue +6 -19
- package/src/views/SparkLogoutView.vue +15 -0
- /package/src/assets/images/{mr-antenna.png → brands/mr-antenna.png} +0 -0
- /package/src/assets/images/{mr-gutter-cleaning.png → brands/mr-gutter-cleaning.png} +0 -0
- /package/src/assets/images/{mr-pest-controller.png → brands/mr-pest-controller.png} +0 -0
package/dist/index.js
CHANGED
|
@@ -1,53 +1,53 @@
|
|
|
1
|
-
import { computed as y, resolveComponent as
|
|
2
|
-
import { library as
|
|
1
|
+
import { computed as y, resolveComponent as S, createElementBlock as u, openBlock as l, normalizeClass as h, createElementVNode as s, createVNode as m, unref as d, renderSlot as C, Fragment as L, renderList as F, createCommentVNode as x, toDisplayString as k, reactive as z, ref as A, inject as te, provide as se, markRaw as G, createBlock as B, withCtx as _, resolveDynamicComponent as E, mergeProps as j, toHandlers as P, createTextVNode as X, withModifiers as V } from "vue";
|
|
2
|
+
import { library as q } from "@fortawesome/fontawesome-svg-core";
|
|
3
3
|
import { FontAwesomeIcon as ne } from "@fortawesome/vue-fontawesome";
|
|
4
|
-
import { faXmark as
|
|
5
|
-
import { defineStore as
|
|
6
|
-
import { TransitionRoot as U, Dialog as
|
|
7
|
-
import { useRouter as
|
|
4
|
+
import { faXmark as oe, faTimes as re, faStreetView as ae, faSortUp as le, faSortDown as ie, faSort as ce, faScaleBalanced as de, faSatelliteDish as ue, faLayerPlus as pe, faLaptopMobile as fe, faInfoCircle as me, faGripDotsVertical as ge, faGearComplex as he, faFlag as ve, faFaceSmileWink as xe, faFaceSmileRelaxed as ye, faExclamationTriangle as be, faEllipsisVertical as _e, faEllipsis as we, faEdit as ke, faComments as Ce, faCircleXmark as Se, faCircleUser as $e, faChevronUp as Be, faChevronRight as Le, faChevronLeft as Ve, faChevronDown as Re, faCheckCircle as Fe, faCheck as Ae, faBullhorn as ze, faBellRing as He, faBarsSort as Ie, faArrowRightToLine as Ne, faArrowLeftToLine as Me } from "@fortawesome/pro-regular-svg-icons";
|
|
5
|
+
import { defineStore as M } from "pinia";
|
|
6
|
+
import { TransitionRoot as U, Dialog as Z, TransitionChild as H, DialogPanel as K } from "@headlessui/vue";
|
|
7
|
+
import { useRouter as Te } from "vue-router";
|
|
8
8
|
const b = {
|
|
9
|
-
farArrowLeftToLine:
|
|
10
|
-
farArrowRightToLine:
|
|
11
|
-
farBarsSort:
|
|
12
|
-
farBellRing:
|
|
13
|
-
farBullhorn:
|
|
14
|
-
farCheck:
|
|
15
|
-
farCheckCircle:
|
|
16
|
-
farChevronDown:
|
|
17
|
-
farChevronLeft:
|
|
18
|
-
farChevronRight:
|
|
19
|
-
farChevronUp:
|
|
20
|
-
farCircleUser:
|
|
21
|
-
farCircleXmark:
|
|
22
|
-
farComments:
|
|
23
|
-
farEdit:
|
|
9
|
+
farArrowLeftToLine: Me,
|
|
10
|
+
farArrowRightToLine: Ne,
|
|
11
|
+
farBarsSort: Ie,
|
|
12
|
+
farBellRing: He,
|
|
13
|
+
farBullhorn: ze,
|
|
14
|
+
farCheck: Ae,
|
|
15
|
+
farCheckCircle: Fe,
|
|
16
|
+
farChevronDown: Re,
|
|
17
|
+
farChevronLeft: Ve,
|
|
18
|
+
farChevronRight: Le,
|
|
19
|
+
farChevronUp: Be,
|
|
20
|
+
farCircleUser: $e,
|
|
21
|
+
farCircleXmark: Se,
|
|
22
|
+
farComments: Ce,
|
|
23
|
+
farEdit: ke,
|
|
24
24
|
farEllipsis: we,
|
|
25
|
-
farEllipsisVertical:
|
|
26
|
-
farExclamationTriangle:
|
|
25
|
+
farEllipsisVertical: _e,
|
|
26
|
+
farExclamationTriangle: be,
|
|
27
27
|
farFaceSmileRelaxed: ye,
|
|
28
28
|
farFaceSmileWink: xe,
|
|
29
|
-
farFlag:
|
|
30
|
-
farGearComplex:
|
|
31
|
-
farGripDotsVertical:
|
|
32
|
-
farInfoCircle:
|
|
29
|
+
farFlag: ve,
|
|
30
|
+
farGearComplex: he,
|
|
31
|
+
farGripDotsVertical: ge,
|
|
32
|
+
farInfoCircle: me,
|
|
33
33
|
farLaptopMobile: fe,
|
|
34
|
-
farLayerPlus:
|
|
35
|
-
farSatelliteDish:
|
|
36
|
-
farScaleBalanced:
|
|
34
|
+
farLayerPlus: pe,
|
|
35
|
+
farSatelliteDish: ue,
|
|
36
|
+
farScaleBalanced: de,
|
|
37
37
|
farSort: ce,
|
|
38
38
|
farSortDown: ie,
|
|
39
39
|
farSortUp: le,
|
|
40
|
-
farStreetView:
|
|
41
|
-
farTimes:
|
|
42
|
-
farXmark:
|
|
40
|
+
farStreetView: ae,
|
|
41
|
+
farTimes: re,
|
|
42
|
+
farXmark: oe
|
|
43
43
|
};
|
|
44
|
-
function
|
|
45
|
-
Object.assign(b, e),
|
|
44
|
+
function xs(e) {
|
|
45
|
+
Object.assign(b, e), q.add(...Object.values(e));
|
|
46
46
|
}
|
|
47
|
-
function
|
|
48
|
-
|
|
47
|
+
function ys(e) {
|
|
48
|
+
q.add(...Object.values(b)), e.component("FontAwesomeIcon", ne);
|
|
49
49
|
}
|
|
50
|
-
const
|
|
50
|
+
const Oe = { class: "flex items-center" }, De = { class: "shrink-0 self-start" }, Ge = { class: "ml-3" }, Ee = { class: "ml-auto pl-3 pt-1 self-start" }, je = { class: "-mx-1.5 -my-1.5" }, bs = {
|
|
51
51
|
__name: "SparkAlert",
|
|
52
52
|
props: {
|
|
53
53
|
type: {
|
|
@@ -58,51 +58,51 @@ const Le = { class: "flex items-center" }, We = { class: "shrink-0 self-start" }
|
|
|
58
58
|
},
|
|
59
59
|
emits: ["close"],
|
|
60
60
|
setup(e) {
|
|
61
|
-
const
|
|
61
|
+
const o = e, r = y(() => ({
|
|
62
62
|
success: "bg-green-50 border-green-200 text-green-700",
|
|
63
63
|
warning: "bg-yellow-50 border-yellow-200 text-yellow-700",
|
|
64
64
|
danger: "bg-red-50 border-red-200 text-red-700",
|
|
65
65
|
info: "bg-blue-50 border-blue-200 text-blue-700"
|
|
66
|
-
})[
|
|
66
|
+
})[o.type]), c = y(() => ({
|
|
67
67
|
success: "text-green-400",
|
|
68
68
|
warning: "text-yellow-400",
|
|
69
69
|
danger: "text-red-400",
|
|
70
70
|
info: "text-blue-400"
|
|
71
|
-
})[
|
|
71
|
+
})[o.type]), g = y(() => ({
|
|
72
72
|
success: "farCheckCircle",
|
|
73
73
|
warning: "farExclamationTriangle",
|
|
74
74
|
danger: "farCircleXmark",
|
|
75
75
|
info: "farInfoCircle"
|
|
76
|
-
})[
|
|
76
|
+
})[o.type]), f = y(() => ({
|
|
77
77
|
success: "text-green-400 hover:bg-green-100",
|
|
78
78
|
warning: "text-yellow-400 hover:bg-yellow-100",
|
|
79
79
|
danger: "text-red-400 hover:bg-red-100",
|
|
80
80
|
info: "text-blue-400 hover:bg-blue-100"
|
|
81
|
-
})[
|
|
82
|
-
return (
|
|
83
|
-
const t =
|
|
84
|
-
return
|
|
85
|
-
class:
|
|
81
|
+
})[o.type]);
|
|
82
|
+
return (a, i) => {
|
|
83
|
+
const t = S("font-awesome-icon");
|
|
84
|
+
return l(), u("div", {
|
|
85
|
+
class: h(["rounded-md border p-4", r.value])
|
|
86
86
|
}, [
|
|
87
|
-
s("div",
|
|
88
|
-
s("div",
|
|
89
|
-
|
|
90
|
-
icon:
|
|
91
|
-
class:
|
|
87
|
+
s("div", Oe, [
|
|
88
|
+
s("div", De, [
|
|
89
|
+
m(t, {
|
|
90
|
+
icon: d(b)[g.value],
|
|
91
|
+
class: h(c.value)
|
|
92
92
|
}, null, 8, ["icon", "class"])
|
|
93
93
|
]),
|
|
94
|
-
s("div",
|
|
95
|
-
|
|
94
|
+
s("div", Ge, [
|
|
95
|
+
C(a.$slots, "default")
|
|
96
96
|
]),
|
|
97
|
-
s("div",
|
|
98
|
-
s("div",
|
|
97
|
+
s("div", Ee, [
|
|
98
|
+
s("div", je, [
|
|
99
99
|
s("button", {
|
|
100
100
|
type: "button",
|
|
101
|
-
class:
|
|
102
|
-
onClick:
|
|
101
|
+
class: h(["inline-flex rounded-md px-2 py-1.5", f.value]),
|
|
102
|
+
onClick: i[0] || (i[0] = (n) => a.$emit("close"))
|
|
103
103
|
}, [
|
|
104
|
-
|
|
105
|
-
icon:
|
|
104
|
+
m(t, {
|
|
105
|
+
icon: d(b).farXmark
|
|
106
106
|
}, null, 8, ["icon"])
|
|
107
107
|
], 2)
|
|
108
108
|
])
|
|
@@ -111,7 +111,7 @@ const Le = { class: "flex items-center" }, We = { class: "shrink-0 self-start" }
|
|
|
111
111
|
], 2);
|
|
112
112
|
};
|
|
113
113
|
}
|
|
114
|
-
},
|
|
114
|
+
}, Pe = { class: "flex grow flex-col gap-y-5 overflow-y-auto bg-white rounded-lg" }, Xe = { class: "flex flex-1 flex-col" }, qe = { class: "divide-y divide-gray-200" }, Ue = { class: "flex px-[22px] py-2.5 text-[12px] items-center" }, Ze = { class: "ml-auto flex items-center" }, Ke = ["onClick"], We = { class: "gap-y-1" }, Ye = { class: "text-base text-gray-800 flex items-center" }, Je = { class: "font-medium" }, Qe = {
|
|
115
115
|
key: 0,
|
|
116
116
|
class: "inline-flex items-center rounded-full bg-green-100 px-1.5 py-0.5 text-xs font-medium text-green-700 ml-1"
|
|
117
117
|
}, et = { class: "text-sm text-gray-500" }, tt = { class: "ml-auto flex items-center" }, st = {
|
|
@@ -166,50 +166,50 @@ const Le = { class: "flex items-center" }, We = { class: "shrink-0 self-start" }
|
|
|
166
166
|
}
|
|
167
167
|
},
|
|
168
168
|
emits: ["close", "select"],
|
|
169
|
-
setup(e, { emit:
|
|
170
|
-
const
|
|
171
|
-
...
|
|
172
|
-
current:
|
|
173
|
-
}))),
|
|
174
|
-
window.open(
|
|
169
|
+
setup(e, { emit: o }) {
|
|
170
|
+
const r = e, c = o, g = y(() => r.appItems.map((a) => ({
|
|
171
|
+
...a,
|
|
172
|
+
current: a.name === r.currentApp
|
|
173
|
+
}))), f = (a) => {
|
|
174
|
+
window.open(a.href, "_blank"), c("select", a);
|
|
175
175
|
};
|
|
176
|
-
return (
|
|
177
|
-
const t =
|
|
178
|
-
return
|
|
179
|
-
s("div",
|
|
180
|
-
s("div",
|
|
176
|
+
return (a, i) => {
|
|
177
|
+
const t = S("font-awesome-icon");
|
|
178
|
+
return l(), u("div", Pe, [
|
|
179
|
+
s("div", Xe, [
|
|
180
|
+
s("div", qe, [
|
|
181
181
|
s("div", Ue, [
|
|
182
|
-
|
|
183
|
-
s("div",
|
|
184
|
-
|
|
185
|
-
icon:
|
|
182
|
+
i[1] || (i[1] = s("div", null, "Mr Group Network", -1)),
|
|
183
|
+
s("div", Ze, [
|
|
184
|
+
m(t, {
|
|
185
|
+
icon: d(b).farTimes,
|
|
186
186
|
class: "h-[15px] w-[15px] shrink-0 text-gray-400 cursor-pointer",
|
|
187
|
-
onClick:
|
|
187
|
+
onClick: i[0] || (i[0] = (n) => c("close"))
|
|
188
188
|
}, null, 8, ["icon"])
|
|
189
189
|
])
|
|
190
190
|
]),
|
|
191
|
-
(
|
|
192
|
-
key:
|
|
193
|
-
class:
|
|
194
|
-
onClick: (
|
|
191
|
+
(l(!0), u(L, null, F(g.value, (n) => (l(), u("div", {
|
|
192
|
+
key: n.name,
|
|
193
|
+
class: h([n.current ? "bg-gray-50" : "hover:bg-gray-50", "flex px-[22px] py-[15px] cursor-pointer"]),
|
|
194
|
+
onClick: (v) => f(n)
|
|
195
195
|
}, [
|
|
196
|
-
s("div",
|
|
197
|
-
s("div",
|
|
198
|
-
s("div",
|
|
199
|
-
|
|
196
|
+
s("div", We, [
|
|
197
|
+
s("div", Ye, [
|
|
198
|
+
s("div", Je, k(n.name), 1),
|
|
199
|
+
n.current ? (l(), u("span", Qe, " Active ")) : x("", !0)
|
|
200
200
|
]),
|
|
201
|
-
s("div", et,
|
|
201
|
+
s("div", et, k(n.description), 1)
|
|
202
202
|
]),
|
|
203
203
|
s("div", tt, [
|
|
204
|
-
|
|
205
|
-
class:
|
|
206
|
-
icon:
|
|
204
|
+
m(t, {
|
|
205
|
+
class: h([n.current ? "text-gray-700" : "text-gray-400", "h-5 w-5 shrink-0"]),
|
|
206
|
+
icon: d(b)[n.icon]
|
|
207
207
|
}, null, 8, ["class", "icon"])
|
|
208
208
|
])
|
|
209
|
-
], 10,
|
|
210
|
-
|
|
209
|
+
], 10, Ke))), 128)),
|
|
210
|
+
i[2] || (i[2] = s("div", null, null, -1))
|
|
211
211
|
]),
|
|
212
|
-
|
|
212
|
+
i[3] || (i[3] = s("div", { class: "mt-auto" }, [
|
|
213
213
|
s("div", { class: "p-6" }, "Learn More"),
|
|
214
214
|
s("div", { class: "bg-gray-50 p-6" }, "Footer")
|
|
215
215
|
], -1))
|
|
@@ -217,87 +217,109 @@ const Le = { class: "flex items-center" }, We = { class: "shrink-0 self-start" }
|
|
|
217
217
|
]);
|
|
218
218
|
};
|
|
219
219
|
}
|
|
220
|
-
}, nt = "", at = "", ot = "", K = I("brandFilter", () => {
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
220
|
+
}, W = M(
|
|
221
|
+
"brandFilter",
|
|
222
|
+
() => {
|
|
223
|
+
const e = z({
|
|
224
|
+
brands: []
|
|
225
|
+
}), o = (f = {}) => {
|
|
226
|
+
if (!f.brands || !Array.isArray(f.brands)) {
|
|
227
|
+
console.warn("useSparkBrandFilterStore: No brands provided to initialize()"), e.brands = [];
|
|
228
|
+
return;
|
|
229
|
+
}
|
|
230
|
+
const a = f.brands.filter((t) => {
|
|
231
|
+
const n = t.id && t.name && t.logo;
|
|
232
|
+
return n || console.warn("useSparkBrandFilterStore: Invalid brand object", t), n;
|
|
233
|
+
}), i = a.filter((t) => t.current);
|
|
234
|
+
i.length === 0 && a.length > 0 ? a[0].current = !0 : i.length > 1 && a.forEach((t) => {
|
|
235
|
+
t.current = t === i[0];
|
|
236
|
+
}), e.brands = a.map((t) => ({
|
|
237
|
+
id: t.id,
|
|
238
|
+
name: t.name,
|
|
239
|
+
logo: t.logo,
|
|
240
|
+
current: t.current || !1
|
|
241
|
+
}));
|
|
242
|
+
}, r = y(() => e.brands.find((f) => f.current) || null), c = y(() => e.brands);
|
|
243
|
+
return {
|
|
244
|
+
state: e,
|
|
245
|
+
initialize: o,
|
|
246
|
+
currentBrand: r,
|
|
247
|
+
allBrands: c,
|
|
248
|
+
toggleBrand: (f) => {
|
|
249
|
+
if (!f || !e.brands.includes(f)) {
|
|
250
|
+
console.warn("useSparkBrandFilterStore: Invalid brand provided to toggleBrand()");
|
|
251
|
+
return;
|
|
252
|
+
}
|
|
253
|
+
e.brands.forEach((a) => {
|
|
254
|
+
a.current = a === f;
|
|
255
|
+
});
|
|
256
|
+
}
|
|
257
|
+
};
|
|
258
|
+
},
|
|
259
|
+
{
|
|
260
|
+
persist: {
|
|
261
|
+
paths: ["state.brands"]
|
|
244
262
|
}
|
|
245
|
-
}
|
|
246
|
-
|
|
263
|
+
}
|
|
264
|
+
), nt = { class: "flex grow flex-col gap-y-5 overflow-y-auto bg-white rounded-lg" }, ot = { class: "flex flex-1 flex-col" }, rt = { class: "divide-y divide-gray-200" }, at = { class: "flex px-[22px] py-2.5 text-[12px] items-center" }, lt = { class: "ml-auto flex items-center" }, it = {
|
|
265
|
+
key: 0,
|
|
266
|
+
class: "flex px-[22px] py-[15px] text-gray-500 text-sm"
|
|
267
|
+
}, ct = ["onClick"], dt = { class: "gap-y-1 flex" }, ut = { class: "flex items-center mr-4" }, pt = ["src", "alt"], ft = { class: "ml-auto flex flex-col" }, mt = { class: "text-base text-gray-800 flex items-center" }, gt = { class: "font-medium" }, ht = {
|
|
247
268
|
key: 0,
|
|
248
269
|
class: "inline-flex items-center rounded-full bg-green-100 px-1.5 py-0.5 text-xs font-medium text-green-700 ml-1"
|
|
249
|
-
},
|
|
270
|
+
}, vt = { class: "text-sm text-gray-500" }, xt = {
|
|
250
271
|
__name: "SparkBrandSelector",
|
|
251
272
|
emits: ["close", "select"],
|
|
252
|
-
setup(e, { emit:
|
|
253
|
-
const
|
|
254
|
-
|
|
273
|
+
setup(e, { emit: o }) {
|
|
274
|
+
const r = o, c = W(), g = (f) => {
|
|
275
|
+
r("select", f);
|
|
255
276
|
};
|
|
256
|
-
return (
|
|
257
|
-
const
|
|
258
|
-
return
|
|
259
|
-
s("div",
|
|
260
|
-
s("div",
|
|
261
|
-
s("div",
|
|
262
|
-
|
|
263
|
-
s("div",
|
|
264
|
-
|
|
265
|
-
icon:
|
|
277
|
+
return (f, a) => {
|
|
278
|
+
const i = S("font-awesome-icon");
|
|
279
|
+
return l(), u("div", nt, [
|
|
280
|
+
s("div", ot, [
|
|
281
|
+
s("div", rt, [
|
|
282
|
+
s("div", at, [
|
|
283
|
+
a[1] || (a[1] = s("div", null, "Filter by Brand", -1)),
|
|
284
|
+
s("div", lt, [
|
|
285
|
+
m(i, {
|
|
286
|
+
icon: d(b).farTimes,
|
|
266
287
|
class: "size-4 text-gray-400 cursor-pointer",
|
|
267
|
-
onClick:
|
|
288
|
+
onClick: a[0] || (a[0] = (t) => r("close"))
|
|
268
289
|
}, null, 8, ["icon"])
|
|
269
290
|
])
|
|
270
291
|
]),
|
|
271
|
-
(
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
292
|
+
d(c).allBrands.length === 0 ? (l(), u("div", it, " No brands configured ")) : x("", !0),
|
|
293
|
+
(l(!0), u(L, null, F(d(c).allBrands, (t) => (l(), u("div", {
|
|
294
|
+
key: t.id,
|
|
295
|
+
class: h([t.current ? "bg-gray-50" : "hover:bg-gray-50", "flex px-[22px] py-[15px] cursor-pointer"]),
|
|
296
|
+
onClick: (n) => g(t)
|
|
275
297
|
}, [
|
|
276
298
|
s("div", dt, [
|
|
277
|
-
s("div",
|
|
299
|
+
s("div", ut, [
|
|
278
300
|
s("img", {
|
|
279
301
|
src: t.logo,
|
|
280
302
|
alt: `${t.name} logo`,
|
|
281
303
|
class: "h-8 w-auto"
|
|
282
|
-
}, null, 8,
|
|
304
|
+
}, null, 8, pt)
|
|
283
305
|
]),
|
|
284
|
-
s("div",
|
|
285
|
-
s("div",
|
|
286
|
-
s("div",
|
|
287
|
-
t.current ? (
|
|
306
|
+
s("div", ft, [
|
|
307
|
+
s("div", mt, [
|
|
308
|
+
s("div", gt, k(t.name), 1),
|
|
309
|
+
t.current ? (l(), u("span", ht, " Current ")) : x("", !0)
|
|
288
310
|
]),
|
|
289
|
-
s("div",
|
|
311
|
+
s("div", vt, k(t.current ? "Current Brand" : "Change to"), 1)
|
|
290
312
|
])
|
|
291
313
|
])
|
|
292
|
-
], 10,
|
|
293
|
-
|
|
314
|
+
], 10, ct))), 128)),
|
|
315
|
+
a[2] || (a[2] = s("div", null, null, -1))
|
|
294
316
|
]),
|
|
295
|
-
|
|
317
|
+
a[3] || (a[3] = s("div", { class: "mt-auto" }, null, -1))
|
|
296
318
|
])
|
|
297
319
|
]);
|
|
298
320
|
};
|
|
299
321
|
}
|
|
300
|
-
},
|
|
322
|
+
}, yt = ["disabled"], Y = {
|
|
301
323
|
__name: "SparkButton",
|
|
302
324
|
props: {
|
|
303
325
|
size: {
|
|
@@ -319,16 +341,16 @@ const Le = { class: "flex items-center" }, We = { class: "shrink-0 self-start" }
|
|
|
319
341
|
}
|
|
320
342
|
},
|
|
321
343
|
setup(e) {
|
|
322
|
-
const
|
|
323
|
-
if (!
|
|
324
|
-
const t =
|
|
344
|
+
const o = e, r = A(null), c = te("buttonGroup", null), g = y(() => {
|
|
345
|
+
if (!c?.isInGroup || !r.value) return null;
|
|
346
|
+
const t = c.getButtonIndex(r.value), n = c.getButtonCount();
|
|
325
347
|
return {
|
|
326
348
|
isFirst: t === 0,
|
|
327
|
-
isLast: t ===
|
|
349
|
+
isLast: t === n - 1,
|
|
328
350
|
index: t,
|
|
329
|
-
total:
|
|
351
|
+
total: n
|
|
330
352
|
};
|
|
331
|
-
}),
|
|
353
|
+
}), f = {
|
|
332
354
|
paddingX: /^px-/,
|
|
333
355
|
paddingY: /^py-/,
|
|
334
356
|
paddingAll: /^p-/,
|
|
@@ -338,42 +360,42 @@ const Le = { class: "flex items-center" }, We = { class: "shrink-0 self-start" }
|
|
|
338
360
|
borderRadius: /^rounded-/,
|
|
339
361
|
background: /^bg-/,
|
|
340
362
|
text: /^text-(?!white|black)/
|
|
341
|
-
},
|
|
342
|
-
if (!
|
|
343
|
-
const
|
|
344
|
-
return [...
|
|
345
|
-
const
|
|
346
|
-
([ee,
|
|
347
|
-
)?.[0],
|
|
348
|
-
([ee,
|
|
363
|
+
}, a = (t, n) => {
|
|
364
|
+
if (!n) return t;
|
|
365
|
+
const v = t.split(" ").filter(Boolean), p = n.split(" ").filter(Boolean);
|
|
366
|
+
return [...v.filter((I) => !p.some((J) => {
|
|
367
|
+
const T = Object.entries(f).find(
|
|
368
|
+
([ee, N]) => N.test(I)
|
|
369
|
+
)?.[0], Q = Object.entries(f).find(
|
|
370
|
+
([ee, N]) => N.test(J)
|
|
349
371
|
)?.[0];
|
|
350
|
-
return
|
|
351
|
-
})), ...
|
|
352
|
-
},
|
|
353
|
-
let t = "",
|
|
354
|
-
switch (
|
|
372
|
+
return T && T === Q;
|
|
373
|
+
})), ...p].join(" ");
|
|
374
|
+
}, i = y(() => {
|
|
375
|
+
let t = "", n = "";
|
|
376
|
+
switch (o.size) {
|
|
355
377
|
case "xs":
|
|
356
|
-
t += " px-2 py-1 text-xs",
|
|
378
|
+
t += " px-2 py-1 text-xs", n = "sm";
|
|
357
379
|
break;
|
|
358
380
|
case "sm":
|
|
359
|
-
t += " px-2 py-1 text-sm",
|
|
381
|
+
t += " px-2 py-1 text-sm", n = "sm";
|
|
360
382
|
break;
|
|
361
383
|
case "md":
|
|
362
|
-
t += " px-2.5 py-1.5 text-sm",
|
|
384
|
+
t += " px-2.5 py-1.5 text-sm", n = "md";
|
|
363
385
|
break;
|
|
364
386
|
case "lg":
|
|
365
|
-
t += " px-3 py-2 text-sm",
|
|
387
|
+
t += " px-3 py-2 text-sm", n = "md";
|
|
366
388
|
break;
|
|
367
389
|
case "xl":
|
|
368
|
-
t += " px-3.5 py-2.5 text-sm",
|
|
390
|
+
t += " px-3.5 py-2.5 text-sm", n = "md";
|
|
369
391
|
break;
|
|
370
392
|
}
|
|
371
|
-
if (
|
|
372
|
-
const { isFirst:
|
|
373
|
-
t += " relative inline-flex items-center focus:z-10",
|
|
393
|
+
if (c?.isInGroup && g.value) {
|
|
394
|
+
const { isFirst: v, isLast: p } = g.value;
|
|
395
|
+
t += " relative inline-flex items-center focus:z-10", v && p ? t += ` rounded-${n}` : v ? t += ` rounded-l-${n} rounded-r-none` : p ? t += ` rounded-r-${n} rounded-l-none -ml-px` : t += " rounded-none -ml-px";
|
|
374
396
|
} else
|
|
375
|
-
t += ` shadow-xs rounded-${
|
|
376
|
-
switch (
|
|
397
|
+
t += ` shadow-xs rounded-${n}`;
|
|
398
|
+
switch (o.variant) {
|
|
377
399
|
case "primary":
|
|
378
400
|
t += " bg-primary-600 hover:bg-primary-500 text-white";
|
|
379
401
|
break;
|
|
@@ -393,44 +415,44 @@ const Le = { class: "flex items-center" }, We = { class: "shrink-0 self-start" }
|
|
|
393
415
|
t += " bg-cyan-600 hover:bg-cyan-500 text-white";
|
|
394
416
|
break;
|
|
395
417
|
default:
|
|
396
|
-
t += ` bg-${
|
|
418
|
+
t += ` bg-${o.variant}-600 hover:bg-${o.variant}-500 text-white`;
|
|
397
419
|
}
|
|
398
|
-
return t =
|
|
420
|
+
return t = a(t, o.buttonClass), t;
|
|
399
421
|
});
|
|
400
|
-
return (t,
|
|
422
|
+
return (t, n) => (l(), u("button", {
|
|
401
423
|
type: "button",
|
|
402
424
|
ref_key: "buttonRef",
|
|
403
|
-
ref:
|
|
404
|
-
class:
|
|
425
|
+
ref: r,
|
|
426
|
+
class: h(i.value),
|
|
405
427
|
disabled: e.disabled,
|
|
406
|
-
onClick:
|
|
428
|
+
onClick: n[0] || (n[0] = (v) => t.$emit("click"))
|
|
407
429
|
}, [
|
|
408
|
-
|
|
409
|
-
], 10,
|
|
430
|
+
C(t.$slots, "default")
|
|
431
|
+
], 10, yt));
|
|
410
432
|
}
|
|
411
|
-
},
|
|
433
|
+
}, _s = {
|
|
412
434
|
__name: "SparkButtonGroup",
|
|
413
435
|
setup(e) {
|
|
414
|
-
const
|
|
436
|
+
const o = A(null);
|
|
415
437
|
return se("buttonGroup", {
|
|
416
438
|
isInGroup: !0,
|
|
417
|
-
getButtonIndex: (
|
|
418
|
-
getButtonCount: () =>
|
|
419
|
-
}), (
|
|
439
|
+
getButtonIndex: (g) => o.value ? Array.from(o.value.children).indexOf(g) : -1,
|
|
440
|
+
getButtonCount: () => o.value?.children.length || 0
|
|
441
|
+
}), (g, f) => (l(), u("div", {
|
|
420
442
|
class: "inline-flex rounded-md shadow-xs",
|
|
421
443
|
ref_key: "groupRef",
|
|
422
|
-
ref:
|
|
444
|
+
ref: o
|
|
423
445
|
}, [
|
|
424
|
-
|
|
446
|
+
C(g.$slots, "default")
|
|
425
447
|
], 512));
|
|
426
448
|
}
|
|
427
|
-
},
|
|
449
|
+
}, bt = { class: "divide-y divide-gray-300 rounded-lg border border-gray-300 text-gray-700 bg-gray-100" }, _t = {
|
|
428
450
|
key: 0,
|
|
429
451
|
class: "p-5"
|
|
430
|
-
},
|
|
452
|
+
}, wt = {
|
|
431
453
|
key: 1,
|
|
432
454
|
class: "p-5"
|
|
433
|
-
},
|
|
455
|
+
}, ws = {
|
|
434
456
|
__name: "SparkCard",
|
|
435
457
|
props: {
|
|
436
458
|
padded: {
|
|
@@ -443,52 +465,52 @@ const Le = { class: "flex items-center" }, We = { class: "shrink-0 self-start" }
|
|
|
443
465
|
}
|
|
444
466
|
},
|
|
445
467
|
setup(e) {
|
|
446
|
-
const
|
|
447
|
-
return (
|
|
448
|
-
|
|
449
|
-
|
|
468
|
+
const o = e;
|
|
469
|
+
return (r, c) => (l(), u("div", bt, [
|
|
470
|
+
r.$slots.header ? (l(), u("div", _t, [
|
|
471
|
+
C(r.$slots, "header")
|
|
450
472
|
])) : x("", !0),
|
|
451
473
|
s("div", {
|
|
452
|
-
class:
|
|
474
|
+
class: h([o.padded ? o.paddedClass : ""])
|
|
453
475
|
}, [
|
|
454
|
-
|
|
476
|
+
C(r.$slots, "default")
|
|
455
477
|
], 2),
|
|
456
|
-
|
|
457
|
-
|
|
478
|
+
r.$slots.footer ? (l(), u("div", wt, [
|
|
479
|
+
C(r.$slots, "footer")
|
|
458
480
|
])) : x("", !0)
|
|
459
481
|
]));
|
|
460
482
|
}
|
|
461
483
|
};
|
|
462
|
-
class
|
|
484
|
+
class kt {
|
|
463
485
|
constructor() {
|
|
464
|
-
this.state =
|
|
486
|
+
this.state = z({
|
|
465
487
|
isVisible: !1,
|
|
466
488
|
content: null,
|
|
467
489
|
props: {},
|
|
468
490
|
eventHandlers: {}
|
|
469
491
|
});
|
|
470
492
|
}
|
|
471
|
-
show = (
|
|
472
|
-
this.state.content =
|
|
493
|
+
show = (o, r = {}, c = {}) => {
|
|
494
|
+
this.state.content = G(o), this.state.props = r, this.state.eventHandlers = c, this.state.isVisible = !0;
|
|
473
495
|
};
|
|
474
496
|
hide = () => {
|
|
475
497
|
this.state.isVisible = !1, this.state.eventHandlers = {};
|
|
476
498
|
};
|
|
477
499
|
}
|
|
478
|
-
const
|
|
500
|
+
const R = new kt(), Ct = { class: "fixed inset-0 z-10 w-screen overflow-y-auto" }, St = { class: "flex min-h-full items-end justify-center p-4 text-center sm:items-center sm:p-0" }, $t = {
|
|
479
501
|
__name: "SparkModalContainer",
|
|
480
502
|
setup(e) {
|
|
481
|
-
return (
|
|
503
|
+
return (o, r) => (l(), B(d(U), {
|
|
482
504
|
as: "template",
|
|
483
|
-
show:
|
|
505
|
+
show: d(R).state.isVisible
|
|
484
506
|
}, {
|
|
485
|
-
default:
|
|
486
|
-
|
|
507
|
+
default: _(() => [
|
|
508
|
+
m(d(Z), {
|
|
487
509
|
class: "relative z-50",
|
|
488
|
-
onClose:
|
|
510
|
+
onClose: d(R).hide
|
|
489
511
|
}, {
|
|
490
|
-
default:
|
|
491
|
-
|
|
512
|
+
default: _(() => [
|
|
513
|
+
m(d(H), {
|
|
492
514
|
as: "template",
|
|
493
515
|
enter: "ease-out duration-300",
|
|
494
516
|
"enter-from": "opacity-0",
|
|
@@ -497,14 +519,14 @@ const H = new Ct(), zt = { class: "fixed inset-0 z-10 w-screen overflow-y-auto"
|
|
|
497
519
|
"leave-from": "opacity-100",
|
|
498
520
|
"leave-to": "opacity-0"
|
|
499
521
|
}, {
|
|
500
|
-
default:
|
|
522
|
+
default: _(() => [...r[0] || (r[0] = [
|
|
501
523
|
s("div", { class: "fixed inset-0 bg-gray-500/75 transition-opacity" }, null, -1)
|
|
502
524
|
])]),
|
|
503
525
|
_: 1
|
|
504
526
|
}),
|
|
505
|
-
s("div",
|
|
506
|
-
s("div",
|
|
507
|
-
|
|
527
|
+
s("div", Ct, [
|
|
528
|
+
s("div", St, [
|
|
529
|
+
m(d(H), {
|
|
508
530
|
as: "template",
|
|
509
531
|
enter: "ease-out duration-300",
|
|
510
532
|
"enter-from": "opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95",
|
|
@@ -513,10 +535,10 @@ const H = new Ct(), zt = { class: "fixed inset-0 z-10 w-screen overflow-y-auto"
|
|
|
513
535
|
"leave-from": "opacity-100 translate-y-0 sm:scale-100",
|
|
514
536
|
"leave-to": "opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95"
|
|
515
537
|
}, {
|
|
516
|
-
default:
|
|
517
|
-
|
|
518
|
-
default:
|
|
519
|
-
(
|
|
538
|
+
default: _(() => [
|
|
539
|
+
m(d(K), { class: "relative transform overflow-hidden rounded-lg bg-white text-left shadow-xl transition-all sm:my-8 sm:w-full sm:max-w-lg" }, {
|
|
540
|
+
default: _(() => [
|
|
541
|
+
(l(), B(E(d(R).state.content), j(d(R).state.props, P(d(R).state.eventHandlers)), null, 16))
|
|
520
542
|
]),
|
|
521
543
|
_: 1
|
|
522
544
|
})
|
|
@@ -532,10 +554,10 @@ const H = new Ct(), zt = { class: "fixed inset-0 z-10 w-screen overflow-y-auto"
|
|
|
532
554
|
_: 1
|
|
533
555
|
}, 8, ["show"]));
|
|
534
556
|
}
|
|
535
|
-
},
|
|
557
|
+
}, Bt = { class: "px-4 pt-5 pb-4 sm:p-6" }, Lt = {
|
|
536
558
|
key: 0,
|
|
537
559
|
class: "text-lg font-medium text-gray-900"
|
|
538
|
-
},
|
|
560
|
+
}, ks = {
|
|
539
561
|
__name: "SparkModalDialog",
|
|
540
562
|
props: {
|
|
541
563
|
title: {
|
|
@@ -585,8 +607,8 @@ const H = new Ct(), zt = { class: "fixed inset-0 z-10 w-screen overflow-y-auto"
|
|
|
585
607
|
"input"
|
|
586
608
|
],
|
|
587
609
|
setup(e) {
|
|
588
|
-
const
|
|
589
|
-
switch (
|
|
610
|
+
const o = e, r = y(() => !o.buttons || o.buttons.length === 0 ? [{ text: "OK", variant: "primary", event: "ok" }] : o.buttons), c = y(() => {
|
|
611
|
+
switch (r.value.length) {
|
|
590
612
|
case 1:
|
|
591
613
|
return "sm:grid sm:grid-flow-row-dense";
|
|
592
614
|
case 2:
|
|
@@ -596,53 +618,53 @@ const H = new Ct(), zt = { class: "fixed inset-0 z-10 w-screen overflow-y-auto"
|
|
|
596
618
|
default:
|
|
597
619
|
return "flex flex-col gap-3";
|
|
598
620
|
}
|
|
599
|
-
}),
|
|
621
|
+
}), g = {
|
|
600
622
|
info: "farInfoCircle",
|
|
601
623
|
success: "farCheckCircle",
|
|
602
624
|
warning: "farExclamationTriangle",
|
|
603
625
|
danger: "farCircleXmark"
|
|
604
|
-
},
|
|
626
|
+
}, f = y(() => o.icon || g[o.type]), a = y(() => ({
|
|
605
627
|
info: "bg-blue-100",
|
|
606
628
|
success: "bg-green-100",
|
|
607
629
|
warning: "bg-yellow-100",
|
|
608
630
|
danger: "bg-red-100"
|
|
609
|
-
})[
|
|
631
|
+
})[o.type]), i = y(() => ({
|
|
610
632
|
info: "text-blue-400",
|
|
611
633
|
success: "text-green-400",
|
|
612
634
|
warning: "text-yellow-400",
|
|
613
635
|
danger: "text-red-400"
|
|
614
|
-
})[
|
|
615
|
-
return (t,
|
|
616
|
-
const
|
|
617
|
-
return
|
|
618
|
-
|
|
636
|
+
})[o.type]);
|
|
637
|
+
return (t, n) => {
|
|
638
|
+
const v = S("font-awesome-icon");
|
|
639
|
+
return l(), u("div", Bt, [
|
|
640
|
+
f.value ? (l(), u("div", {
|
|
619
641
|
key: 0,
|
|
620
|
-
class:
|
|
642
|
+
class: h(["mx-auto flex size-12 items-center justify-center rounded-full", a.value])
|
|
621
643
|
}, [
|
|
622
|
-
|
|
623
|
-
icon:
|
|
624
|
-
class:
|
|
644
|
+
m(v, {
|
|
645
|
+
icon: d(b)[f.value],
|
|
646
|
+
class: h(["h-5 w-5", i.value])
|
|
625
647
|
}, null, 8, ["icon", "class"])
|
|
626
648
|
], 2)) : x("", !0),
|
|
627
649
|
s("div", {
|
|
628
|
-
class:
|
|
650
|
+
class: h(["text-center", { "mt-3 sm:mt-5": f.value }])
|
|
629
651
|
}, [
|
|
630
|
-
e.title ? (
|
|
631
|
-
e.message ? (
|
|
652
|
+
e.title ? (l(), u("h3", Lt, k(e.title), 1)) : x("", !0),
|
|
653
|
+
e.message ? (l(), u("div", {
|
|
632
654
|
key: 1,
|
|
633
|
-
class:
|
|
634
|
-
},
|
|
655
|
+
class: h([{ "mt-2": e.title }, "text-sm text-gray-500"])
|
|
656
|
+
}, k(e.message), 3)) : x("", !0)
|
|
635
657
|
], 2),
|
|
636
658
|
s("div", {
|
|
637
|
-
class:
|
|
659
|
+
class: h(["mt-5 sm:mt-6", c.value])
|
|
638
660
|
}, [
|
|
639
|
-
(
|
|
661
|
+
(l(!0), u(L, null, F(r.value, (p, w) => (l(), B(d(Y), {
|
|
640
662
|
key: w,
|
|
641
|
-
variant:
|
|
642
|
-
onClick: (
|
|
663
|
+
variant: p.variant,
|
|
664
|
+
onClick: (I) => t.$emit(p.event, p)
|
|
643
665
|
}, {
|
|
644
|
-
default:
|
|
645
|
-
|
|
666
|
+
default: _(() => [
|
|
667
|
+
X(k(p.text), 1)
|
|
646
668
|
]),
|
|
647
669
|
_: 2
|
|
648
670
|
}, 1032, ["variant", "onClick"]))), 128))
|
|
@@ -650,7 +672,7 @@ const H = new Ct(), zt = { class: "fixed inset-0 z-10 w-screen overflow-y-auto"
|
|
|
650
672
|
]);
|
|
651
673
|
};
|
|
652
674
|
}
|
|
653
|
-
},
|
|
675
|
+
}, Vt = { class: "fixed inset-0 flex" }, O = {
|
|
654
676
|
__name: "SparkOverlay",
|
|
655
677
|
props: {
|
|
656
678
|
position: {
|
|
@@ -664,19 +686,19 @@ const H = new Ct(), zt = { class: "fixed inset-0 z-10 w-screen overflow-y-auto"
|
|
|
664
686
|
}
|
|
665
687
|
},
|
|
666
688
|
setup(e) {
|
|
667
|
-
const
|
|
668
|
-
return (
|
|
689
|
+
const o = A(null);
|
|
690
|
+
return (r, c) => (l(), B(d(U), {
|
|
669
691
|
show: e.overlayInstance.state.isVisible,
|
|
670
692
|
as: "template"
|
|
671
693
|
}, {
|
|
672
|
-
default:
|
|
673
|
-
|
|
674
|
-
initialFocus:
|
|
694
|
+
default: _(() => [
|
|
695
|
+
m(d(Z), {
|
|
696
|
+
initialFocus: o.value,
|
|
675
697
|
class: "relative z-200",
|
|
676
698
|
onClose: e.overlayInstance.close
|
|
677
699
|
}, {
|
|
678
|
-
default:
|
|
679
|
-
|
|
700
|
+
default: _(() => [
|
|
701
|
+
m(d(H), {
|
|
680
702
|
as: "template",
|
|
681
703
|
enter: "transition-opacity ease-linear duration-150",
|
|
682
704
|
"enter-from": "opacity-0",
|
|
@@ -685,13 +707,13 @@ const H = new Ct(), zt = { class: "fixed inset-0 z-10 w-screen overflow-y-auto"
|
|
|
685
707
|
"leave-from": "opacity-100",
|
|
686
708
|
"leave-to": "opacity-0"
|
|
687
709
|
}, {
|
|
688
|
-
default:
|
|
710
|
+
default: _(() => [...c[0] || (c[0] = [
|
|
689
711
|
s("div", { class: "fixed inset-0 bg-gray-600/30" }, null, -1)
|
|
690
712
|
])]),
|
|
691
713
|
_: 1
|
|
692
714
|
}),
|
|
693
|
-
s("div",
|
|
694
|
-
|
|
715
|
+
s("div", Vt, [
|
|
716
|
+
m(d(H), {
|
|
695
717
|
as: "template",
|
|
696
718
|
enter: "transition ease-in-out duration-150 transform",
|
|
697
719
|
"enter-from": e.position === "left" ? "-translate-x-full opacity-0" : "translate-x-full opacity-0",
|
|
@@ -700,17 +722,17 @@ const H = new Ct(), zt = { class: "fixed inset-0 z-10 w-screen overflow-y-auto"
|
|
|
700
722
|
"leave-from": "translate-x-0 opacity-100",
|
|
701
723
|
"leave-to": e.position === "left" ? "-translate-x-full opacity-0" : "translate-x-full opacity-0"
|
|
702
724
|
}, {
|
|
703
|
-
default:
|
|
704
|
-
|
|
725
|
+
default: _(() => [
|
|
726
|
+
m(d(K), {
|
|
705
727
|
ref_key: "panelRef",
|
|
706
|
-
ref:
|
|
707
|
-
class:
|
|
728
|
+
ref: o,
|
|
729
|
+
class: h([
|
|
708
730
|
"flex w-[400px] py-2.5",
|
|
709
731
|
e.position === "left" ? "relative left-[10px]" : "absolute right-[10px] h-full"
|
|
710
732
|
])
|
|
711
733
|
}, {
|
|
712
|
-
default:
|
|
713
|
-
(
|
|
734
|
+
default: _(() => [
|
|
735
|
+
(l(), B(E(e.overlayInstance.state.content), j({ ...r.$attrs, ...e.overlayInstance.state.props }, P(e.overlayInstance.state.eventHandlers)), null, 16))
|
|
714
736
|
]),
|
|
715
737
|
_: 1
|
|
716
738
|
}, 8, ["class"])
|
|
@@ -726,41 +748,41 @@ const H = new Ct(), zt = { class: "fixed inset-0 z-10 w-screen overflow-y-auto"
|
|
|
726
748
|
}, 8, ["show"]));
|
|
727
749
|
}
|
|
728
750
|
};
|
|
729
|
-
function
|
|
730
|
-
const e =
|
|
751
|
+
function D() {
|
|
752
|
+
const e = z({
|
|
731
753
|
isVisible: !1,
|
|
732
754
|
content: null,
|
|
733
755
|
props: {},
|
|
734
756
|
eventHandlers: {}
|
|
735
|
-
}),
|
|
757
|
+
}), o = () => {
|
|
736
758
|
e.isVisible = !e.isVisible;
|
|
737
|
-
},
|
|
759
|
+
}, r = () => {
|
|
738
760
|
e.isVisible = !1, e.eventHandlers = {};
|
|
739
|
-
},
|
|
761
|
+
}, c = () => {
|
|
740
762
|
e.isVisible = !0;
|
|
741
|
-
},
|
|
742
|
-
e.content =
|
|
763
|
+
}, g = (a, i = {}, t = {}) => {
|
|
764
|
+
e.content = G(a), e.props = i, e.eventHandlers = t;
|
|
743
765
|
};
|
|
744
766
|
return {
|
|
745
767
|
state: e,
|
|
746
|
-
toggle:
|
|
747
|
-
close:
|
|
748
|
-
open:
|
|
749
|
-
setContent:
|
|
750
|
-
show: (
|
|
751
|
-
|
|
768
|
+
toggle: o,
|
|
769
|
+
close: r,
|
|
770
|
+
open: c,
|
|
771
|
+
setContent: g,
|
|
772
|
+
show: (a, i = {}, t = {}) => {
|
|
773
|
+
a && g(a, i, t), c();
|
|
752
774
|
}
|
|
753
775
|
};
|
|
754
776
|
}
|
|
755
|
-
class
|
|
777
|
+
class Rt {
|
|
756
778
|
constructor() {
|
|
757
|
-
this.left =
|
|
779
|
+
this.left = D(), this.right = D();
|
|
758
780
|
}
|
|
759
|
-
showLeft = (
|
|
760
|
-
this.left.show(
|
|
781
|
+
showLeft = (o, r = {}, c = {}) => {
|
|
782
|
+
this.left.show(o, r, c);
|
|
761
783
|
};
|
|
762
|
-
showRight = (
|
|
763
|
-
this.right.show(
|
|
784
|
+
showRight = (o, r = {}, c = {}) => {
|
|
785
|
+
this.right.show(o, r, c);
|
|
764
786
|
};
|
|
765
787
|
closeLeft = () => {
|
|
766
788
|
this.left.close();
|
|
@@ -772,19 +794,19 @@ class Et {
|
|
|
772
794
|
this.left.close(), this.right.close();
|
|
773
795
|
};
|
|
774
796
|
}
|
|
775
|
-
const
|
|
797
|
+
const $ = new Rt(), Ft = { class: "flex grow m-2.5 p-[10px] rounded-lg" }, At = { class: "flex flex-1 flex-col" }, zt = {
|
|
776
798
|
class: "flex flex-1 flex-col gap-y-7",
|
|
777
799
|
role: "list"
|
|
778
|
-
},
|
|
800
|
+
}, Ht = { role: "list" }, It = { class: "flex items-center pb-8" }, Nt = ["href", "onClick"], Mt = {
|
|
779
801
|
key: 2,
|
|
780
802
|
class: "w-full flex justify-center"
|
|
781
|
-
},
|
|
803
|
+
}, Tt = {
|
|
782
804
|
key: 0,
|
|
783
805
|
class: "mt-[5px] flex flex-col gap-[5px]"
|
|
784
|
-
}, Ot = ["href", "onClick"],
|
|
806
|
+
}, Ot = ["href", "onClick"], Dt = {
|
|
785
807
|
key: 1,
|
|
786
808
|
class: "text-[13px]"
|
|
787
|
-
},
|
|
809
|
+
}, Gt = { class: "mt-auto" }, Et = { class: "p-[10px] flex-shrink-0" }, jt = { class: "flex flex-1 items-center gap-x-6" }, Pt = { class: "relative flex flex-1 items-center gap-4" }, Xt = { class: "cursor-pointer" }, qt = ["src"], Ut = { class: "ml-auto" }, Zt = { class: "mr-[10px] pb-[10px] flex-1 flex flex-col" }, Cs = {
|
|
788
810
|
__name: "SparkDefaultContainer",
|
|
789
811
|
props: {
|
|
790
812
|
appStore: {
|
|
@@ -797,109 +819,109 @@ const z = new Et(), kt = { class: "flex grow m-2.5 p-[10px] rounded-lg" }, Qt =
|
|
|
797
819
|
}
|
|
798
820
|
},
|
|
799
821
|
setup(e) {
|
|
800
|
-
const
|
|
801
|
-
|
|
802
|
-
currentApp:
|
|
822
|
+
const o = e, r = W(), c = () => {
|
|
823
|
+
$.showRight(st, {
|
|
824
|
+
currentApp: o.appStore.state.app
|
|
803
825
|
});
|
|
804
|
-
},
|
|
805
|
-
|
|
806
|
-
|
|
826
|
+
}, g = () => {
|
|
827
|
+
$.showLeft(
|
|
828
|
+
xt,
|
|
807
829
|
{},
|
|
808
830
|
{
|
|
809
|
-
select: (
|
|
810
|
-
|
|
831
|
+
select: (i) => {
|
|
832
|
+
r.toggleBrand(i), $.closeLeft();
|
|
811
833
|
}
|
|
812
834
|
}
|
|
813
835
|
);
|
|
814
|
-
},
|
|
815
|
-
return (
|
|
816
|
-
const
|
|
817
|
-
return
|
|
836
|
+
}, f = y(() => o.mainNavStore.state.hidden ? ["w-0 overflow-hidden"] : [o.mainNavStore.state.collapsed ? "w-[80px]" : "w-[240px]"]), a = y(() => o.mainNavStore.state.hidden ? ["pl-2.5"] : [o.mainNavStore.state.collapsed ? "pl-[80px]" : "pl-[240px]"]);
|
|
837
|
+
return (i, t) => {
|
|
838
|
+
const n = S("font-awesome-icon"), v = S("router-view");
|
|
839
|
+
return l(), u(L, null, [
|
|
818
840
|
s("div", {
|
|
819
|
-
class:
|
|
841
|
+
class: h([f.value, "fixed inset-y-0 flex transition-all z-100"])
|
|
820
842
|
}, [
|
|
821
|
-
s("div",
|
|
822
|
-
s("nav",
|
|
823
|
-
s("ul",
|
|
843
|
+
s("div", Ft, [
|
|
844
|
+
s("nav", At, [
|
|
845
|
+
s("ul", zt, [
|
|
824
846
|
s("li", null, [
|
|
825
|
-
s("ul",
|
|
826
|
-
s("li",
|
|
847
|
+
s("ul", Ht, [
|
|
848
|
+
s("li", It, [
|
|
827
849
|
s("a", {
|
|
828
850
|
class: "grid w-[40px] h-[40px] place-items-center rounded-md bg-primary-600 text-white text-[13px] cursor-pointer",
|
|
829
|
-
onClick: t[0] || (t[0] =
|
|
851
|
+
onClick: t[0] || (t[0] = V((p) => e.mainNavStore.goto(e.appStore.state.homeRoute), ["prevent"]))
|
|
830
852
|
}, [
|
|
831
|
-
|
|
832
|
-
icon:
|
|
853
|
+
m(n, {
|
|
854
|
+
icon: d(b)[e.appStore.state.icon],
|
|
833
855
|
class: "size-5"
|
|
834
856
|
}, null, 8, ["icon"])
|
|
835
857
|
]),
|
|
836
|
-
e.mainNavStore.state.collapsed ? x("", !0) : (
|
|
858
|
+
e.mainNavStore.state.collapsed ? x("", !0) : (l(), u("a", {
|
|
837
859
|
key: 0,
|
|
838
|
-
onClick: t[1] || (t[1] =
|
|
860
|
+
onClick: t[1] || (t[1] = V((p) => e.mainNavStore.goto(e.appStore.state.homeRoute), ["prevent"])),
|
|
839
861
|
class: "font-medium text-gray-800 ml-[10px] cursor-pointer"
|
|
840
|
-
},
|
|
862
|
+
}, k(e.appStore.state.app), 1))
|
|
841
863
|
]),
|
|
842
|
-
(
|
|
843
|
-
key:
|
|
844
|
-
class:
|
|
845
|
-
"mt-[10px]":
|
|
864
|
+
(l(!0), u(L, null, F(e.mainNavStore.state.menu, (p) => (l(), u("li", {
|
|
865
|
+
key: p.name,
|
|
866
|
+
class: h({
|
|
867
|
+
"mt-[10px]": p.children
|
|
846
868
|
})
|
|
847
869
|
}, [
|
|
848
870
|
s("a", {
|
|
849
|
-
class:
|
|
850
|
-
"bg-gray-100":
|
|
851
|
-
"hover:bg-gray-100":
|
|
871
|
+
class: h([{
|
|
872
|
+
"bg-gray-100": p.current,
|
|
873
|
+
"hover:bg-gray-100": p?.href
|
|
852
874
|
}, "h-[37px] sgroup flex items-center gap-x-2 rounded-md p-3 text-gray-800 leading-5 transition-all duration-300 ease-in-out"]),
|
|
853
|
-
href:
|
|
854
|
-
onClick:
|
|
875
|
+
href: p?.href,
|
|
876
|
+
onClick: V((w) => e.mainNavStore.goto(p.href), ["prevent"])
|
|
855
877
|
}, [
|
|
856
|
-
|
|
878
|
+
p.icon ? (l(), B(n, {
|
|
857
879
|
key: 0,
|
|
858
|
-
icon:
|
|
859
|
-
class:
|
|
880
|
+
icon: d(b)[p.icon],
|
|
881
|
+
class: h([[(p.current, "text-gray-400")], "size-4"])
|
|
860
882
|
}, null, 8, ["icon", "class"])) : x("", !0),
|
|
861
|
-
e.mainNavStore.state.collapsed ?
|
|
883
|
+
e.mainNavStore.state.collapsed ? p?.children ? (l(), u("div", Mt, [...t[4] || (t[4] = [
|
|
862
884
|
s("div", { class: "w-[10px] h-px bg-gray-400" }, null, -1)
|
|
863
|
-
])])) : x("", !0) : (
|
|
885
|
+
])])) : x("", !0) : (l(), u("span", {
|
|
864
886
|
key: 1,
|
|
865
|
-
class:
|
|
866
|
-
"text-[11px]":
|
|
867
|
-
"text-[13px]": !
|
|
868
|
-
"font-semibold":
|
|
869
|
-
"text-gray-500":
|
|
887
|
+
class: h({
|
|
888
|
+
"text-[11px]": p?.children,
|
|
889
|
+
"text-[13px]": !p?.children,
|
|
890
|
+
"font-semibold": p?.children,
|
|
891
|
+
"text-gray-500": p?.children
|
|
870
892
|
})
|
|
871
|
-
},
|
|
872
|
-
], 10,
|
|
873
|
-
|
|
874
|
-
(
|
|
893
|
+
}, k(p.name), 3))
|
|
894
|
+
], 10, Nt),
|
|
895
|
+
p.children ? (l(), u("ul", Tt, [
|
|
896
|
+
(l(!0), u(L, null, F(p.children, (w) => (l(), u("li", {
|
|
875
897
|
key: w.name
|
|
876
898
|
}, [
|
|
877
899
|
s("a", {
|
|
878
|
-
class:
|
|
900
|
+
class: h([[w.current ? "bg-gray-100" : "", "hover:bg-gray-100"], "h-[37px] sgroup flex items-center gap-x-2 rounded-md p-3 text-gray-800 leading-5 transition-all duration-300 ease-in-out"]),
|
|
879
901
|
href: w.href,
|
|
880
|
-
onClick:
|
|
902
|
+
onClick: V((I) => e.mainNavStore.goto(w.href), ["prevent"])
|
|
881
903
|
}, [
|
|
882
|
-
w.icon ? (
|
|
904
|
+
w.icon ? (l(), B(n, {
|
|
883
905
|
key: 0,
|
|
884
|
-
icon:
|
|
885
|
-
class:
|
|
906
|
+
icon: d(b)[w.icon],
|
|
907
|
+
class: h([[(w.current, "text-gray-400")], "size-4"])
|
|
886
908
|
}, null, 8, ["icon", "class"])) : x("", !0),
|
|
887
|
-
e.mainNavStore.state.collapsed ? x("", !0) : (
|
|
909
|
+
e.mainNavStore.state.collapsed ? x("", !0) : (l(), u("span", Dt, k(w.name), 1))
|
|
888
910
|
], 10, Ot)
|
|
889
911
|
]))), 128))
|
|
890
912
|
])) : x("", !0)
|
|
891
913
|
], 2))), 128))
|
|
892
914
|
])
|
|
893
915
|
]),
|
|
894
|
-
s("li",
|
|
895
|
-
|
|
916
|
+
s("li", Gt, [
|
|
917
|
+
C(i.$slots, "sidebar-footer"),
|
|
896
918
|
s("a", {
|
|
897
919
|
class: "font-medium grid place-content-center gap-x-3 rounded-md h-10 p-2.5 text-gray-800 text-[13px] hover:bg-gray-100 transition-all duration-300 ease-in-out",
|
|
898
920
|
href: "#",
|
|
899
|
-
onClick: t[2] || (t[2] =
|
|
921
|
+
onClick: t[2] || (t[2] = V((p) => e.mainNavStore.toggleCollapsed(), ["prevent"]))
|
|
900
922
|
}, [
|
|
901
|
-
|
|
902
|
-
icon:
|
|
923
|
+
m(n, {
|
|
924
|
+
icon: d(b)[e.mainNavStore.state.collapsed ? "farArrowRightToLine" : "farArrowLeftToLine"],
|
|
903
925
|
class: "class-5"
|
|
904
926
|
}, null, 8, ["icon"])
|
|
905
927
|
])
|
|
@@ -909,44 +931,44 @@ const z = new Et(), kt = { class: "flex grow m-2.5 p-[10px] rounded-lg" }, Qt =
|
|
|
909
931
|
])
|
|
910
932
|
], 2),
|
|
911
933
|
s("div", {
|
|
912
|
-
class:
|
|
934
|
+
class: h([a.value, "h-full transition-all flex flex-col"])
|
|
913
935
|
}, [
|
|
914
|
-
s("div",
|
|
915
|
-
s("div",
|
|
916
|
-
s("div",
|
|
917
|
-
|
|
918
|
-
s("div",
|
|
919
|
-
|
|
920
|
-
icon:
|
|
936
|
+
s("div", Et, [
|
|
937
|
+
s("div", jt, [
|
|
938
|
+
s("div", Pt, [
|
|
939
|
+
C(i.$slots, "header-left", {}, () => [
|
|
940
|
+
s("div", Xt, [
|
|
941
|
+
m(n, {
|
|
942
|
+
icon: d(b).farBarsSort,
|
|
921
943
|
class: "size-5",
|
|
922
|
-
onClick: t[3] || (t[3] = (
|
|
944
|
+
onClick: t[3] || (t[3] = (p) => e.mainNavStore.toggleHidden())
|
|
923
945
|
}, null, 8, ["icon"])
|
|
924
946
|
])
|
|
925
947
|
]),
|
|
926
|
-
|
|
927
|
-
e.appStore.state.showBrandSelector ? (
|
|
948
|
+
C(i.$slots, "header-center", {}, () => [
|
|
949
|
+
e.appStore.state.showBrandSelector ? (l(), u("div", {
|
|
928
950
|
key: 0,
|
|
929
951
|
class: "absolute left-1/2 -translate-x-1/2 cursor-pointer h-9 flex items-center",
|
|
930
|
-
onClick:
|
|
952
|
+
onClick: g
|
|
931
953
|
}, [
|
|
932
|
-
|
|
954
|
+
d(r).currentBrand ? (l(), u("img", {
|
|
933
955
|
key: 0,
|
|
934
|
-
src:
|
|
956
|
+
src: d(r).currentBrand.logo,
|
|
935
957
|
alt: "",
|
|
936
958
|
class: "h-[30px] w-auto"
|
|
937
|
-
}, null, 8,
|
|
959
|
+
}, null, 8, qt)) : x("", !0)
|
|
938
960
|
])) : x("", !0)
|
|
939
961
|
]),
|
|
940
|
-
s("div",
|
|
941
|
-
|
|
942
|
-
e.appStore.state.showAppSelector ? (
|
|
962
|
+
s("div", Ut, [
|
|
963
|
+
C(i.$slots, "header-right", {}, () => [
|
|
964
|
+
e.appStore.state.showAppSelector ? (l(), u("button", {
|
|
943
965
|
key: 0,
|
|
944
966
|
class: "rounded-sm bg-white w-[42px] h-[42px] ring-1 ring-inset ring-gray-300",
|
|
945
967
|
type: "button",
|
|
946
|
-
onClick:
|
|
968
|
+
onClick: c
|
|
947
969
|
}, [
|
|
948
|
-
|
|
949
|
-
icon:
|
|
970
|
+
m(n, {
|
|
971
|
+
icon: d(b).farGripDotsVertical,
|
|
950
972
|
class: "size-4 text-gray-400"
|
|
951
973
|
}, null, 8, ["icon"])
|
|
952
974
|
])) : x("", !0)
|
|
@@ -955,38 +977,38 @@ const z = new Et(), kt = { class: "flex grow m-2.5 p-[10px] rounded-lg" }, Qt =
|
|
|
955
977
|
])
|
|
956
978
|
])
|
|
957
979
|
]),
|
|
958
|
-
s("main",
|
|
959
|
-
|
|
980
|
+
s("main", Zt, [
|
|
981
|
+
m(v)
|
|
960
982
|
])
|
|
961
983
|
], 2),
|
|
962
|
-
|
|
984
|
+
m(d(O), {
|
|
963
985
|
position: "left",
|
|
964
|
-
"overlay-instance":
|
|
965
|
-
onClose:
|
|
986
|
+
"overlay-instance": d($).left,
|
|
987
|
+
onClose: d($).closeLeft
|
|
966
988
|
}, null, 8, ["overlay-instance", "onClose"]),
|
|
967
|
-
|
|
989
|
+
m(d(O), {
|
|
968
990
|
position: "right",
|
|
969
|
-
"overlay-instance":
|
|
970
|
-
onClose:
|
|
991
|
+
"overlay-instance": d($).right,
|
|
992
|
+
onClose: d($).closeRight
|
|
971
993
|
}, null, 8, ["overlay-instance", "onClose"]),
|
|
972
|
-
|
|
994
|
+
m(d($t))
|
|
973
995
|
], 64);
|
|
974
996
|
};
|
|
975
997
|
}
|
|
976
|
-
},
|
|
977
|
-
const
|
|
978
|
-
for (const [
|
|
979
|
-
|
|
980
|
-
return
|
|
981
|
-
},
|
|
982
|
-
function
|
|
983
|
-
const
|
|
984
|
-
return
|
|
985
|
-
|
|
998
|
+
}, Kt = (e, o) => {
|
|
999
|
+
const r = e.__vccOpts || e;
|
|
1000
|
+
for (const [c, g] of o)
|
|
1001
|
+
r[c] = g;
|
|
1002
|
+
return r;
|
|
1003
|
+
}, Wt = {}, Yt = { class: "h-full" };
|
|
1004
|
+
function Jt(e, o) {
|
|
1005
|
+
const r = S("router-view");
|
|
1006
|
+
return l(), u("main", Yt, [
|
|
1007
|
+
m(r)
|
|
986
1008
|
]);
|
|
987
1009
|
}
|
|
988
|
-
const
|
|
989
|
-
const e =
|
|
1010
|
+
const Ss = /* @__PURE__ */ Kt(Wt, [["render", Jt]]), Qt = M("sparkApp", () => {
|
|
1011
|
+
const e = z({
|
|
990
1012
|
app: "",
|
|
991
1013
|
icon: "",
|
|
992
1014
|
homeRoute: "dashboard",
|
|
@@ -995,44 +1017,44 @@ const Ys = /* @__PURE__ */ Vt(_t, [["render", es]]), Ds = I("sparkApp", () => {
|
|
|
995
1017
|
});
|
|
996
1018
|
return {
|
|
997
1019
|
state: e,
|
|
998
|
-
initialize: (
|
|
999
|
-
e.app =
|
|
1020
|
+
initialize: (r = {}) => {
|
|
1021
|
+
e.app = r.app || "", e.icon = r.icon || "", e.homeRoute = r.homeRoute ?? "dashboard", e.showBrandSelector = r.showBrandSelector ?? !0, e.showAppSelector = r.showAppSelector ?? !0;
|
|
1000
1022
|
}
|
|
1001
1023
|
};
|
|
1002
|
-
}),
|
|
1003
|
-
const e =
|
|
1024
|
+
}), $s = M("sparkNav", () => {
|
|
1025
|
+
const e = z({
|
|
1004
1026
|
menu: [],
|
|
1005
1027
|
collapsed: !1,
|
|
1006
1028
|
hidden: !1
|
|
1007
|
-
}),
|
|
1008
|
-
e.menu =
|
|
1009
|
-
},
|
|
1010
|
-
for (const
|
|
1011
|
-
if (
|
|
1012
|
-
if (
|
|
1013
|
-
const
|
|
1014
|
-
if (
|
|
1029
|
+
}), o = Te(), r = (i = []) => {
|
|
1030
|
+
e.menu = i;
|
|
1031
|
+
}, c = (i, t) => {
|
|
1032
|
+
for (const n of i) {
|
|
1033
|
+
if (n.href === t) return n;
|
|
1034
|
+
if (n.children) {
|
|
1035
|
+
const v = c(n.children, t);
|
|
1036
|
+
if (v) return v;
|
|
1015
1037
|
}
|
|
1016
1038
|
}
|
|
1017
1039
|
return null;
|
|
1018
1040
|
};
|
|
1019
1041
|
return {
|
|
1020
1042
|
state: e,
|
|
1021
|
-
initialize:
|
|
1022
|
-
goto: async (
|
|
1023
|
-
if (
|
|
1024
|
-
const t = (
|
|
1025
|
-
|
|
1026
|
-
|
|
1043
|
+
initialize: r,
|
|
1044
|
+
goto: async (i) => {
|
|
1045
|
+
if (i) {
|
|
1046
|
+
const t = (v) => {
|
|
1047
|
+
v.forEach((p) => {
|
|
1048
|
+
p.current = p.href === i, p.children && t(p.children);
|
|
1027
1049
|
});
|
|
1028
1050
|
};
|
|
1029
1051
|
t(e.menu);
|
|
1030
|
-
const
|
|
1031
|
-
if (
|
|
1032
|
-
|
|
1052
|
+
const n = c(e.menu, i);
|
|
1053
|
+
if (n && typeof n.action == "function") {
|
|
1054
|
+
n.action();
|
|
1033
1055
|
return;
|
|
1034
1056
|
}
|
|
1035
|
-
await
|
|
1057
|
+
await o.push(i);
|
|
1036
1058
|
}
|
|
1037
1059
|
},
|
|
1038
1060
|
toggleCollapsed: () => {
|
|
@@ -1042,30 +1064,23 @@ const Ys = /* @__PURE__ */ Vt(_t, [["render", es]]), Ds = I("sparkApp", () => {
|
|
|
1042
1064
|
e.hidden = !e.hidden;
|
|
1043
1065
|
}
|
|
1044
1066
|
};
|
|
1045
|
-
}),
|
|
1067
|
+
}), es = { class: "h-full grid place-content-center relative" }, ts = { class: "absolute top-8 left-8" }, ss = ["src"], ns = {
|
|
1046
1068
|
key: 1,
|
|
1047
1069
|
width: "59",
|
|
1048
1070
|
height: "23",
|
|
1049
1071
|
viewBox: "0 0 59 23",
|
|
1050
1072
|
fill: "none",
|
|
1051
1073
|
xmlns: "http://www.w3.org/2000/svg"
|
|
1052
|
-
}, os = { class: "max-w-sm grid gap-y-1 -mt-8" }, rs = { class: "mb-7" },
|
|
1074
|
+
}, os = { class: "max-w-sm grid gap-y-1 -mt-8" }, rs = { class: "mb-7" }, as = { class: "text-gray-600" }, ls = { class: "grid grid-flow-col justify-between my-1" }, is = {
|
|
1053
1075
|
key: 0,
|
|
1054
1076
|
class: "text-red-600 text-sm mb-2"
|
|
1055
|
-
},
|
|
1056
|
-
key: 0,
|
|
1057
|
-
class: "mt-4 text-center text-sm text-gray-600"
|
|
1058
|
-
}, Hs = {
|
|
1077
|
+
}, cs = { key: 0 }, ds = { key: 1 }, Bs = {
|
|
1059
1078
|
__name: "SparkLoginView",
|
|
1060
1079
|
props: {
|
|
1061
1080
|
logo: {
|
|
1062
1081
|
type: String,
|
|
1063
1082
|
default: ""
|
|
1064
1083
|
},
|
|
1065
|
-
appName: {
|
|
1066
|
-
type: String,
|
|
1067
|
-
default: ""
|
|
1068
|
-
},
|
|
1069
1084
|
onLogin: {
|
|
1070
1085
|
type: Function,
|
|
1071
1086
|
required: !0
|
|
@@ -1073,34 +1088,30 @@ const Ys = /* @__PURE__ */ Vt(_t, [["render", es]]), Ds = I("sparkApp", () => {
|
|
|
1073
1088
|
forgotPasswordRoute: {
|
|
1074
1089
|
type: String,
|
|
1075
1090
|
default: "/forgot-password"
|
|
1076
|
-
},
|
|
1077
|
-
signupRoute: {
|
|
1078
|
-
type: String,
|
|
1079
|
-
default: ""
|
|
1080
1091
|
}
|
|
1081
1092
|
},
|
|
1082
1093
|
emits: ["login-success", "login-error"],
|
|
1083
|
-
setup(e, { emit:
|
|
1084
|
-
const
|
|
1085
|
-
f.value = !0,
|
|
1094
|
+
setup(e, { emit: o }) {
|
|
1095
|
+
const r = Qt(), c = e, g = o, f = A(!1), a = A(""), i = async (t) => {
|
|
1096
|
+
f.value = !0, a.value = "";
|
|
1086
1097
|
try {
|
|
1087
|
-
await
|
|
1088
|
-
} catch (
|
|
1089
|
-
|
|
1098
|
+
await c.onLogin(t), g("login-success");
|
|
1099
|
+
} catch (n) {
|
|
1100
|
+
a.value = n.message || "Login failed. Please try again.", g("login-error", n);
|
|
1090
1101
|
} finally {
|
|
1091
1102
|
f.value = !1;
|
|
1092
1103
|
}
|
|
1093
1104
|
};
|
|
1094
|
-
return (
|
|
1095
|
-
const
|
|
1096
|
-
return
|
|
1097
|
-
s("div",
|
|
1098
|
-
|
|
1105
|
+
return (t, n) => {
|
|
1106
|
+
const v = S("FormKit"), p = S("router-link");
|
|
1107
|
+
return l(), u("div", es, [
|
|
1108
|
+
s("div", ts, [
|
|
1109
|
+
c.logo ? (l(), u("img", {
|
|
1099
1110
|
key: 0,
|
|
1100
|
-
src:
|
|
1111
|
+
src: c.logo,
|
|
1101
1112
|
alt: "Logo",
|
|
1102
1113
|
class: "h-[23px] w-auto"
|
|
1103
|
-
}, null, 8,
|
|
1114
|
+
}, null, 8, ss)) : (l(), u("svg", ns, [...n[0] || (n[0] = [
|
|
1104
1115
|
s("path", {
|
|
1105
1116
|
d: "M49.2029 17.1264V8.03835H44.0829V5.22235H58.0989V8.03835H52.9629V17.1264H49.2029Z",
|
|
1106
1117
|
fill: "#1C64F2"
|
|
@@ -1121,16 +1132,16 @@ const Ys = /* @__PURE__ */ Vt(_t, [["render", es]]), Ds = I("sparkApp", () => {
|
|
|
1121
1132
|
]),
|
|
1122
1133
|
s("div", os, [
|
|
1123
1134
|
s("div", rs, [
|
|
1124
|
-
|
|
1125
|
-
s("p",
|
|
1135
|
+
n[1] || (n[1] = s("h1", { class: "text-4xl text-gray-900 semibold tracking-tight mb-3" }, "Log in", -1)),
|
|
1136
|
+
s("p", as, " Welcome back" + k(d(r).state.app ? ` to ${d(r).state.app}` : "") + "! Please enter your details. ", 1)
|
|
1126
1137
|
]),
|
|
1127
|
-
|
|
1138
|
+
m(v, {
|
|
1128
1139
|
type: "form",
|
|
1129
|
-
onSubmit:
|
|
1140
|
+
onSubmit: i,
|
|
1130
1141
|
actions: !1
|
|
1131
1142
|
}, {
|
|
1132
|
-
default:
|
|
1133
|
-
|
|
1143
|
+
default: _(() => [
|
|
1144
|
+
m(v, {
|
|
1134
1145
|
label: "Email",
|
|
1135
1146
|
name: "email",
|
|
1136
1147
|
placeholder: "Enter your email",
|
|
@@ -1138,7 +1149,7 @@ const Ys = /* @__PURE__ */ Vt(_t, [["render", es]]), Ds = I("sparkApp", () => {
|
|
|
1138
1149
|
validation: "required|email",
|
|
1139
1150
|
"outer-class": "max-w-full"
|
|
1140
1151
|
}),
|
|
1141
|
-
|
|
1152
|
+
m(v, {
|
|
1142
1153
|
label: "Password",
|
|
1143
1154
|
name: "password",
|
|
1144
1155
|
placeholder: "••••••••",
|
|
@@ -1146,49 +1157,37 @@ const Ys = /* @__PURE__ */ Vt(_t, [["render", es]]), Ds = I("sparkApp", () => {
|
|
|
1146
1157
|
validation: "required",
|
|
1147
1158
|
"outer-class": "max-w-full"
|
|
1148
1159
|
}),
|
|
1149
|
-
s("div",
|
|
1150
|
-
|
|
1160
|
+
s("div", ls, [
|
|
1161
|
+
m(v, {
|
|
1151
1162
|
label: "Remember me",
|
|
1152
1163
|
name: "remember",
|
|
1153
1164
|
type: "checkbox"
|
|
1154
1165
|
}),
|
|
1155
|
-
|
|
1156
|
-
to:
|
|
1166
|
+
m(p, {
|
|
1167
|
+
to: c.forgotPasswordRoute,
|
|
1157
1168
|
class: "text-sm text-primary-600 font-semibold"
|
|
1158
1169
|
}, {
|
|
1159
|
-
default:
|
|
1160
|
-
|
|
1170
|
+
default: _(() => [...n[2] || (n[2] = [
|
|
1171
|
+
X(" Forgot password ", -1)
|
|
1161
1172
|
])]),
|
|
1162
1173
|
_: 1
|
|
1163
1174
|
}, 8, ["to"])
|
|
1164
1175
|
]),
|
|
1165
|
-
|
|
1166
|
-
|
|
1176
|
+
a.value ? (l(), u("div", is, k(a.value), 1)) : x("", !0),
|
|
1177
|
+
m(d(Y), {
|
|
1167
1178
|
type: "submit",
|
|
1168
1179
|
size: "xl",
|
|
1169
1180
|
disabled: f.value,
|
|
1170
|
-
"button-class": "w-full"
|
|
1181
|
+
"button-class": "w-full mb-2"
|
|
1171
1182
|
}, {
|
|
1172
|
-
default:
|
|
1173
|
-
f.value ? (
|
|
1183
|
+
default: _(() => [
|
|
1184
|
+
f.value ? (l(), u("span", ds, "Signing in...")) : (l(), u("span", cs, "Sign in"))
|
|
1174
1185
|
]),
|
|
1175
1186
|
_: 1
|
|
1176
1187
|
}, 8, ["disabled"])
|
|
1177
1188
|
]),
|
|
1178
1189
|
_: 1
|
|
1179
|
-
})
|
|
1180
|
-
n.signupRoute ? (r(), i("div", ds, [
|
|
1181
|
-
t[4] || (t[4] = Q(" Don't have an account? ", -1)),
|
|
1182
|
-
u(p, {
|
|
1183
|
-
to: n.signupRoute,
|
|
1184
|
-
class: "text-primary-600 font-semibold"
|
|
1185
|
-
}, {
|
|
1186
|
-
default: B(() => [...t[3] || (t[3] = [
|
|
1187
|
-
Q(" Sign up ", -1)
|
|
1188
|
-
])]),
|
|
1189
|
-
_: 1
|
|
1190
|
-
}, 8, ["to"])
|
|
1191
|
-
])) : x("", !0)
|
|
1190
|
+
})
|
|
1192
1191
|
])
|
|
1193
1192
|
]);
|
|
1194
1193
|
};
|
|
@@ -1196,24 +1195,24 @@ const Ys = /* @__PURE__ */ Vt(_t, [["render", es]]), Ds = I("sparkApp", () => {
|
|
|
1196
1195
|
};
|
|
1197
1196
|
export {
|
|
1198
1197
|
b as Icons,
|
|
1199
|
-
|
|
1198
|
+
bs as SparkAlert,
|
|
1200
1199
|
st as SparkAppSelector,
|
|
1201
|
-
|
|
1202
|
-
|
|
1203
|
-
|
|
1204
|
-
|
|
1205
|
-
|
|
1206
|
-
|
|
1207
|
-
|
|
1208
|
-
|
|
1209
|
-
|
|
1210
|
-
|
|
1211
|
-
|
|
1212
|
-
|
|
1213
|
-
|
|
1214
|
-
|
|
1215
|
-
|
|
1216
|
-
|
|
1217
|
-
|
|
1218
|
-
|
|
1200
|
+
xt as SparkBrandSelector,
|
|
1201
|
+
Y as SparkButton,
|
|
1202
|
+
_s as SparkButtonGroup,
|
|
1203
|
+
ws as SparkCard,
|
|
1204
|
+
Cs as SparkDefaultContainer,
|
|
1205
|
+
Bs as SparkLoginView,
|
|
1206
|
+
$t as SparkModalContainer,
|
|
1207
|
+
ks as SparkModalDialog,
|
|
1208
|
+
O as SparkOverlay,
|
|
1209
|
+
Ss as SparkPublicContainer,
|
|
1210
|
+
xs as addIcons,
|
|
1211
|
+
ys as setupFontAwesome,
|
|
1212
|
+
R as sparkModalService,
|
|
1213
|
+
$ as sparkOverlayService,
|
|
1214
|
+
Qt as useSparkAppStore,
|
|
1215
|
+
W as useSparkBrandFilterStore,
|
|
1216
|
+
$s as useSparkNavStore,
|
|
1217
|
+
D as useSparkOverlay
|
|
1219
1218
|
};
|