@strands.gg/accui 0.0.5 → 0.0.6
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.
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import { defineComponent as
|
|
2
|
-
const
|
|
1
|
+
import { defineComponent as k, computed as x, createElementBlock as r, openBlock as A, normalizeClass as B, createElementVNode as e, createCommentVNode as C, toDisplayString as L, renderSlot as P, createTextVNode as F, useSlots as Ve, ref as U, createBlock as Y, resolveDynamicComponent as he, mergeProps as qe, withCtx as z, onMounted as se, nextTick as de, toRefs as Ce, watch as re, Fragment as le, renderList as ne, unref as b, normalizeStyle as We, inject as Ne, provide as xe, reactive as H, createVNode as N, Transition as K, withModifiers as Ae, withDirectives as O, vModelText as E, createStaticVNode as me } from "vue";
|
|
2
|
+
const Le = { class: "flex items-start" }, Ue = { class: "flex-shrink-0" }, Me = {
|
|
3
3
|
class: "h-5 w-5",
|
|
4
4
|
fill: "currentColor",
|
|
5
5
|
viewBox: "0 0 20 20",
|
|
6
6
|
"aria-hidden": "true"
|
|
7
|
-
},
|
|
7
|
+
}, ze = ["d"], Se = { class: "ml-3 flex-1" }, De = {
|
|
8
8
|
key: 0,
|
|
9
9
|
class: "ml-auto pl-3"
|
|
10
|
-
},
|
|
10
|
+
}, ee = /* @__PURE__ */ k({
|
|
11
11
|
__name: "UiAlert",
|
|
12
12
|
props: {
|
|
13
13
|
variant: { default: "info" },
|
|
@@ -16,81 +16,81 @@ const Me = { class: "flex items-start" }, ze = { class: "flex-shrink-0" }, Se =
|
|
|
16
16
|
dismissible: { type: Boolean, default: !1 }
|
|
17
17
|
},
|
|
18
18
|
emits: ["dismiss"],
|
|
19
|
-
setup(
|
|
20
|
-
const
|
|
21
|
-
const
|
|
19
|
+
setup(y) {
|
|
20
|
+
const p = y, s = x(() => {
|
|
21
|
+
const o = ["rounded-lg border p-4"], g = {
|
|
22
22
|
success: "bg-green-50 border-green-200 text-green-800",
|
|
23
23
|
error: "bg-red-50 border-red-200 text-red-800",
|
|
24
24
|
warning: "bg-yellow-50 border-yellow-200 text-yellow-800",
|
|
25
25
|
info: "bg-blue-50 border-blue-200 text-blue-800"
|
|
26
26
|
};
|
|
27
27
|
return [
|
|
28
|
-
...
|
|
29
|
-
|
|
28
|
+
...o,
|
|
29
|
+
g[p.variant]
|
|
30
30
|
].join(" ");
|
|
31
|
-
}),
|
|
31
|
+
}), l = x(() => [
|
|
32
32
|
"text-sm font-medium mb-1",
|
|
33
33
|
{
|
|
34
34
|
success: "text-green-800",
|
|
35
35
|
error: "text-red-800",
|
|
36
36
|
warning: "text-yellow-800",
|
|
37
37
|
info: "text-blue-800"
|
|
38
|
-
}[
|
|
39
|
-
].join(" ")),
|
|
38
|
+
}[p.variant]
|
|
39
|
+
].join(" ")), d = x(() => [
|
|
40
40
|
"text-sm",
|
|
41
41
|
{
|
|
42
42
|
success: "text-green-700",
|
|
43
43
|
error: "text-red-700",
|
|
44
44
|
warning: "text-yellow-700",
|
|
45
45
|
info: "text-blue-700"
|
|
46
|
-
}[
|
|
47
|
-
].join(" ")),
|
|
46
|
+
}[p.variant]
|
|
47
|
+
].join(" ")), i = x(() => [
|
|
48
48
|
"inline-flex rounded-md p-1.5 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2",
|
|
49
49
|
{
|
|
50
50
|
success: "text-green-400 hover:text-green-500",
|
|
51
51
|
error: "text-red-400 hover:text-red-500",
|
|
52
52
|
warning: "text-yellow-400 hover:text-yellow-500",
|
|
53
53
|
info: "text-blue-400 hover:text-blue-500"
|
|
54
|
-
}[
|
|
55
|
-
].join(" ")),
|
|
54
|
+
}[p.variant]
|
|
55
|
+
].join(" ")), u = x(() => ({
|
|
56
56
|
success: "M10 18a8 8 0 100-16 8 8 0 000 16zm3.707-9.293a1 1 0 00-1.414-1.414L9 10.586 7.707 9.293a1 1 0 00-1.414 1.414l2 2a1 1 0 001.414 0l4-4z",
|
|
57
57
|
error: "M10 18a8 8 0 100-16 8 8 0 000 16zM8.707 7.293a1 1 0 00-1.414 1.414L8.586 10l-1.293 1.293a1 1 0 101.414 1.414L10 11.414l1.293 1.293a1 1 0 001.414-1.414L11.414 10l1.293-1.293a1 1 0 00-1.414-1.414L10 8.586 8.707 7.293z",
|
|
58
58
|
warning: "M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z",
|
|
59
59
|
info: "M18 10a8 8 0 11-16 0 8 8 0 0116 0zm-7-4a1 1 0 11-2 0 1 1 0 012 0zM9 9a1 1 0 000 2v3a1 1 0 001 1h1a1 1 0 100-2v-3a1 1 0 00-1-1H9z"
|
|
60
|
-
})[
|
|
61
|
-
return (
|
|
62
|
-
class:
|
|
60
|
+
})[p.variant]);
|
|
61
|
+
return (o, g) => (A(), r("div", {
|
|
62
|
+
class: B(s.value),
|
|
63
63
|
role: "alert"
|
|
64
64
|
}, [
|
|
65
|
-
e("div",
|
|
66
|
-
e("div",
|
|
67
|
-
(A(),
|
|
65
|
+
e("div", Le, [
|
|
66
|
+
e("div", Ue, [
|
|
67
|
+
(A(), r("svg", Me, [
|
|
68
68
|
e("path", {
|
|
69
69
|
"fill-rule": "evenodd",
|
|
70
|
-
d:
|
|
70
|
+
d: u.value,
|
|
71
71
|
"clip-rule": "evenodd"
|
|
72
|
-
}, null, 8,
|
|
72
|
+
}, null, 8, ze)
|
|
73
73
|
]))
|
|
74
74
|
]),
|
|
75
|
-
e("div",
|
|
76
|
-
|
|
75
|
+
e("div", Se, [
|
|
76
|
+
o.title ? (A(), r("h3", {
|
|
77
77
|
key: 0,
|
|
78
|
-
class:
|
|
79
|
-
}, L(
|
|
78
|
+
class: B(l.value)
|
|
79
|
+
}, L(o.title), 3)) : C("", !0),
|
|
80
80
|
e("div", {
|
|
81
|
-
class:
|
|
81
|
+
class: B(d.value)
|
|
82
82
|
}, [
|
|
83
|
-
|
|
84
|
-
|
|
83
|
+
P(o.$slots, "default", {}, () => [
|
|
84
|
+
F(L(o.message), 1)
|
|
85
85
|
])
|
|
86
86
|
], 2)
|
|
87
87
|
]),
|
|
88
|
-
|
|
88
|
+
o.dismissible ? (A(), r("div", De, [
|
|
89
89
|
e("button", {
|
|
90
90
|
type: "button",
|
|
91
|
-
class:
|
|
92
|
-
onClick:
|
|
93
|
-
},
|
|
91
|
+
class: B(i.value),
|
|
92
|
+
onClick: g[0] || (g[0] = (c) => o.$emit("dismiss"))
|
|
93
|
+
}, g[1] || (g[1] = [
|
|
94
94
|
e("span", { class: "sr-only" }, "Dismiss", -1),
|
|
95
95
|
e("svg", {
|
|
96
96
|
class: "h-5 w-5",
|
|
@@ -104,17 +104,17 @@ const Me = { class: "flex items-start" }, ze = { class: "flex-shrink-0" }, Se =
|
|
|
104
104
|
})
|
|
105
105
|
], -1)
|
|
106
106
|
]), 2)
|
|
107
|
-
])) :
|
|
107
|
+
])) : C("", !0)
|
|
108
108
|
])
|
|
109
109
|
], 2));
|
|
110
110
|
}
|
|
111
|
-
}),
|
|
111
|
+
}), Xe = ["type", "disabled"], ke = {
|
|
112
112
|
key: 0,
|
|
113
113
|
class: "flex items-center justify-center gap-2"
|
|
114
|
-
},
|
|
114
|
+
}, Be = {
|
|
115
115
|
key: 1,
|
|
116
116
|
class: "flex items-center justify-center gap-2"
|
|
117
|
-
},
|
|
117
|
+
}, G = /* @__PURE__ */ k({
|
|
118
118
|
__name: "UiButton",
|
|
119
119
|
props: {
|
|
120
120
|
variant: { default: "primary" },
|
|
@@ -126,35 +126,35 @@ const Me = { class: "flex items-start" }, ze = { class: "flex-shrink-0" }, Se =
|
|
|
126
126
|
fullWidth: { type: Boolean, default: !1 }
|
|
127
127
|
},
|
|
128
128
|
emits: ["click"],
|
|
129
|
-
setup(
|
|
130
|
-
const
|
|
131
|
-
const
|
|
129
|
+
setup(y) {
|
|
130
|
+
const p = y, s = x(() => {
|
|
131
|
+
const l = [
|
|
132
132
|
"inline-flex items-center justify-center font-medium transition-all duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-strands-500 focus-visible:ring-offset-2 disabled:opacity-50 disabled:cursor-not-allowed"
|
|
133
|
-
],
|
|
133
|
+
], d = {
|
|
134
134
|
sm: "px-3 py-2 text-sm rounded-md",
|
|
135
135
|
md: "px-4 py-2.5 text-sm rounded-lg",
|
|
136
136
|
lg: "px-6 py-3 text-base rounded-lg"
|
|
137
|
-
},
|
|
137
|
+
}, i = {
|
|
138
138
|
primary: "bg-strands-500 text-white hover:bg-strands-600 shadow-sm",
|
|
139
139
|
secondary: "bg-gray-200 text-gray-800 hover:bg-gray-300",
|
|
140
140
|
ghost: "text-strands-500 hover:text-strands-600 hover:bg-strands-50",
|
|
141
141
|
outline: "border border-strands-500 text-strands-500 hover:bg-strands-500 hover:text-white"
|
|
142
|
-
},
|
|
142
|
+
}, u = p.fullWidth ? "w-full" : "";
|
|
143
143
|
return [
|
|
144
|
-
...
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
144
|
+
...l,
|
|
145
|
+
d[p.size],
|
|
146
|
+
i[p.variant],
|
|
147
|
+
u
|
|
148
148
|
].filter(Boolean).join(" ");
|
|
149
149
|
});
|
|
150
|
-
return (
|
|
151
|
-
type:
|
|
152
|
-
disabled:
|
|
153
|
-
class:
|
|
154
|
-
onClick:
|
|
150
|
+
return (l, d) => (A(), r("button", {
|
|
151
|
+
type: l.type,
|
|
152
|
+
disabled: l.disabled || l.loading,
|
|
153
|
+
class: B(s.value),
|
|
154
|
+
onClick: d[0] || (d[0] = (i) => l.$emit("click", i))
|
|
155
155
|
}, [
|
|
156
|
-
|
|
157
|
-
|
|
156
|
+
l.loading ? (A(), r("span", ke, [
|
|
157
|
+
d[1] || (d[1] = e("svg", {
|
|
158
158
|
class: "animate-spin w-4 h-4",
|
|
159
159
|
fill: "none",
|
|
160
160
|
viewBox: "0 0 24 24"
|
|
@@ -173,88 +173,88 @@ const Me = { class: "flex items-start" }, ze = { class: "flex-shrink-0" }, Se =
|
|
|
173
173
|
d: "m4 12a8 8 0 0 1 8-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 0 1 4 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
|
|
174
174
|
})
|
|
175
175
|
], -1)),
|
|
176
|
-
e("span", null, L(
|
|
177
|
-
])) : (A(),
|
|
178
|
-
|
|
179
|
-
|
|
176
|
+
e("span", null, L(l.loadingText || "Loading..."), 1)
|
|
177
|
+
])) : (A(), r("span", Be, [
|
|
178
|
+
P(l.$slots, "icon"),
|
|
179
|
+
P(l.$slots, "default")
|
|
180
180
|
]))
|
|
181
|
-
], 10,
|
|
181
|
+
], 10, Xe));
|
|
182
182
|
}
|
|
183
|
-
}),
|
|
183
|
+
}), Fe = {
|
|
184
184
|
key: 0,
|
|
185
185
|
class: "border-b border-gray-200 pb-4 mb-6"
|
|
186
|
-
},
|
|
186
|
+
}, Pe = { class: "space-y-6" }, Ie = {
|
|
187
187
|
key: 1,
|
|
188
188
|
class: "border-t border-gray-200 pt-4 mt-6"
|
|
189
|
-
},
|
|
189
|
+
}, oe = /* @__PURE__ */ k({
|
|
190
190
|
__name: "UiCard",
|
|
191
191
|
props: {
|
|
192
192
|
variant: { default: "default" },
|
|
193
193
|
padding: { default: "md" },
|
|
194
194
|
shadow: { default: "sm" }
|
|
195
195
|
},
|
|
196
|
-
setup(
|
|
197
|
-
const
|
|
198
|
-
const
|
|
196
|
+
setup(y) {
|
|
197
|
+
const p = y, s = x(() => {
|
|
198
|
+
const l = ["bg-white border border-gray-200"], d = {
|
|
199
199
|
default: "rounded-lg",
|
|
200
200
|
modern: "rounded-2xl backdrop-blur-lg",
|
|
201
201
|
minimal: "rounded-md"
|
|
202
|
-
},
|
|
202
|
+
}, i = {
|
|
203
203
|
sm: "p-4",
|
|
204
204
|
md: "p-6",
|
|
205
205
|
lg: "p-8"
|
|
206
|
-
},
|
|
206
|
+
}, u = {
|
|
207
207
|
none: "",
|
|
208
208
|
sm: "shadow-sm",
|
|
209
209
|
md: "shadow-md",
|
|
210
210
|
lg: "shadow-lg"
|
|
211
211
|
};
|
|
212
212
|
return [
|
|
213
|
-
...
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
213
|
+
...l,
|
|
214
|
+
d[p.variant],
|
|
215
|
+
i[p.padding],
|
|
216
|
+
u[p.shadow]
|
|
217
217
|
].filter(Boolean).join(" ");
|
|
218
218
|
});
|
|
219
|
-
return (
|
|
220
|
-
class:
|
|
219
|
+
return (l, d) => (A(), r("div", {
|
|
220
|
+
class: B(s.value)
|
|
221
221
|
}, [
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
])) :
|
|
225
|
-
e("div",
|
|
226
|
-
|
|
222
|
+
l.$slots.header ? (A(), r("div", Fe, [
|
|
223
|
+
P(l.$slots, "header")
|
|
224
|
+
])) : C("", !0),
|
|
225
|
+
e("div", Pe, [
|
|
226
|
+
P(l.$slots, "default")
|
|
227
227
|
]),
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
])) :
|
|
228
|
+
l.$slots.footer ? (A(), r("div", Ie, [
|
|
229
|
+
P(l.$slots, "footer")
|
|
230
|
+
])) : C("", !0)
|
|
231
231
|
], 2));
|
|
232
232
|
}
|
|
233
|
-
}),
|
|
233
|
+
}), je = { class: "space-y-1" }, Ze = ["for"], Te = {
|
|
234
234
|
key: 0,
|
|
235
235
|
class: "text-red-500"
|
|
236
|
-
},
|
|
236
|
+
}, Ye = { class: "relative" }, Ke = ["id", "type", "value", "placeholder", "disabled", "required", "autocomplete"], Qe = {
|
|
237
237
|
key: 0,
|
|
238
238
|
class: "h-5 w-5",
|
|
239
239
|
fill: "none",
|
|
240
240
|
stroke: "currentColor",
|
|
241
241
|
viewBox: "0 0 24 24"
|
|
242
|
-
},
|
|
242
|
+
}, Oe = {
|
|
243
243
|
key: 1,
|
|
244
244
|
class: "h-5 w-5",
|
|
245
245
|
fill: "none",
|
|
246
246
|
stroke: "currentColor",
|
|
247
247
|
viewBox: "0 0 24 24"
|
|
248
|
-
},
|
|
248
|
+
}, Ee = {
|
|
249
249
|
key: 1,
|
|
250
250
|
class: "absolute inset-y-0 left-0 pl-3 flex items-center pointer-events-none"
|
|
251
|
-
},
|
|
251
|
+
}, He = {
|
|
252
252
|
key: 1,
|
|
253
253
|
class: "text-sm text-red-600"
|
|
254
|
-
},
|
|
254
|
+
}, Ge = {
|
|
255
255
|
key: 2,
|
|
256
256
|
class: "text-sm text-gray-500"
|
|
257
|
-
},
|
|
257
|
+
}, _ = /* @__PURE__ */ k({
|
|
258
258
|
__name: "UiInput",
|
|
259
259
|
props: {
|
|
260
260
|
modelValue: {},
|
|
@@ -269,65 +269,65 @@ const Me = { class: "flex items-start" }, ze = { class: "flex-shrink-0" }, Se =
|
|
|
269
269
|
size: { default: "md" }
|
|
270
270
|
},
|
|
271
271
|
emits: ["update:modelValue", "blur", "focus"],
|
|
272
|
-
setup(
|
|
273
|
-
const s =
|
|
272
|
+
setup(y, { emit: p }) {
|
|
273
|
+
const s = y, l = p, d = Ve(), i = U(!1), u = U(`input-${Math.random().toString(36).substr(2, 9)}`), o = x(() => s.type === "password" ? i.value ? "text" : "password" : s.type), g = x(() => {
|
|
274
274
|
const t = [
|
|
275
275
|
"block w-full border-gray-300 rounded-lg shadow-sm focus-visible:ring-strands-500 focus-visible:border-strands-500 transition-colors duration-200 disabled:bg-gray-50 disabled:text-gray-500"
|
|
276
|
-
],
|
|
276
|
+
], m = {
|
|
277
277
|
sm: "px-3 py-2 text-sm",
|
|
278
278
|
md: "px-3 py-2.5 text-sm",
|
|
279
279
|
lg: "px-4 py-3 text-base"
|
|
280
|
-
},
|
|
280
|
+
}, w = s.error ? "border-red-300 focus-visible:ring-red-500 focus-visible:border-red-500" : "", X = d.icon ? "pl-10" : "", V = s.type === "password" ? "pr-10" : "";
|
|
281
281
|
return [
|
|
282
282
|
...t,
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
283
|
+
m[s.size],
|
|
284
|
+
w,
|
|
285
|
+
X,
|
|
286
|
+
V
|
|
287
287
|
].filter(Boolean).join(" ");
|
|
288
288
|
}), c = (t) => {
|
|
289
|
-
const
|
|
290
|
-
|
|
289
|
+
const m = t.target;
|
|
290
|
+
l("update:modelValue", m.value);
|
|
291
291
|
}, f = () => {
|
|
292
|
-
|
|
292
|
+
i.value = !i.value;
|
|
293
293
|
};
|
|
294
|
-
return (t,
|
|
295
|
-
t.label ? (A(),
|
|
294
|
+
return (t, m) => (A(), r("div", je, [
|
|
295
|
+
t.label ? (A(), r("label", {
|
|
296
296
|
key: 0,
|
|
297
|
-
for:
|
|
297
|
+
for: u.value,
|
|
298
298
|
class: "block text-sm font-medium text-gray-700"
|
|
299
299
|
}, [
|
|
300
|
-
|
|
301
|
-
t.required ? (A(),
|
|
302
|
-
], 8,
|
|
303
|
-
e("div",
|
|
300
|
+
F(L(t.label) + " ", 1),
|
|
301
|
+
t.required ? (A(), r("span", Te, "*")) : C("", !0)
|
|
302
|
+
], 8, Ze)) : C("", !0),
|
|
303
|
+
e("div", Ye, [
|
|
304
304
|
e("input", {
|
|
305
|
-
id:
|
|
306
|
-
type:
|
|
305
|
+
id: u.value,
|
|
306
|
+
type: o.value,
|
|
307
307
|
value: t.modelValue,
|
|
308
308
|
placeholder: t.placeholder,
|
|
309
309
|
disabled: t.disabled,
|
|
310
310
|
required: t.required,
|
|
311
311
|
autocomplete: t.autocomplete,
|
|
312
|
-
class:
|
|
312
|
+
class: B(g.value),
|
|
313
313
|
onInput: c,
|
|
314
|
-
onBlur:
|
|
315
|
-
onFocus:
|
|
316
|
-
}, null, 42,
|
|
317
|
-
t.type === "password" ? (A(),
|
|
314
|
+
onBlur: m[0] || (m[0] = (w) => t.$emit("blur", w)),
|
|
315
|
+
onFocus: m[1] || (m[1] = (w) => t.$emit("focus", w))
|
|
316
|
+
}, null, 42, Ke),
|
|
317
|
+
t.type === "password" ? (A(), r("button", {
|
|
318
318
|
key: 0,
|
|
319
319
|
type: "button",
|
|
320
320
|
class: "absolute inset-y-0 right-0 pr-3 flex items-center text-gray-400 hover:text-gray-600 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-strands-500 focus-visible:ring-offset-2 rounded-md",
|
|
321
321
|
onClick: f
|
|
322
322
|
}, [
|
|
323
|
-
|
|
323
|
+
i.value ? (A(), r("svg", Qe, m[2] || (m[2] = [
|
|
324
324
|
e("path", {
|
|
325
325
|
"stroke-linecap": "round",
|
|
326
326
|
"stroke-linejoin": "round",
|
|
327
327
|
"stroke-width": "2",
|
|
328
328
|
d: "M13.875 18.825A10.05 10.05 0 0112 19c-4.478 0-8.268-2.943-9.543-7a9.97 9.97 0 011.563-3.029m5.858.908a3 3 0 114.243 4.243M9.878 9.878l4.242 4.242M9.878 9.878L3 3m6.878 6.878L21 21"
|
|
329
329
|
}, null, -1)
|
|
330
|
-
]))) : (A(),
|
|
330
|
+
]))) : (A(), r("svg", Oe, m[3] || (m[3] = [
|
|
331
331
|
e("path", {
|
|
332
332
|
"stroke-linecap": "round",
|
|
333
333
|
"stroke-linejoin": "round",
|
|
@@ -341,15 +341,15 @@ const Me = { class: "flex items-start" }, ze = { class: "flex-shrink-0" }, Se =
|
|
|
341
341
|
d: "M2.458 12C3.732 7.943 7.523 5 12 5c4.478 0 8.268 2.943 9.542 7-1.274 4.057-5.064 7-9.542 7-4.477 0-8.268-2.943-9.542-7z"
|
|
342
342
|
}, null, -1)
|
|
343
343
|
])))
|
|
344
|
-
])) :
|
|
345
|
-
t.$slots.icon ? (A(),
|
|
346
|
-
|
|
347
|
-
])) :
|
|
344
|
+
])) : C("", !0),
|
|
345
|
+
t.$slots.icon ? (A(), r("div", Ee, [
|
|
346
|
+
P(t.$slots, "icon")
|
|
347
|
+
])) : C("", !0)
|
|
348
348
|
]),
|
|
349
|
-
t.error ? (A(),
|
|
349
|
+
t.error ? (A(), r("p", He, L(t.error), 1)) : t.helpText ? (A(), r("p", Ge, L(t.helpText), 1)) : C("", !0)
|
|
350
350
|
]));
|
|
351
351
|
}
|
|
352
|
-
}),
|
|
352
|
+
}), te = /* @__PURE__ */ k({
|
|
353
353
|
__name: "UiLink",
|
|
354
354
|
props: {
|
|
355
355
|
href: {},
|
|
@@ -360,12 +360,12 @@ const Me = { class: "flex items-start" }, ze = { class: "flex-shrink-0" }, Se =
|
|
|
360
360
|
external: { type: Boolean, default: !1 }
|
|
361
361
|
},
|
|
362
362
|
emits: ["click"],
|
|
363
|
-
setup(
|
|
364
|
-
const s =
|
|
365
|
-
const
|
|
366
|
-
return s.to ?
|
|
367
|
-
}),
|
|
368
|
-
const
|
|
363
|
+
setup(y, { emit: p }) {
|
|
364
|
+
const s = y, l = p, d = x(() => s.to ? "router-link" : s.href ? "a" : "button"), i = x(() => {
|
|
365
|
+
const g = {};
|
|
366
|
+
return s.to ? g.to = s.to : s.href ? (g.href = s.href, s.external && (g.target = "_blank", g.rel = "noopener noreferrer")) : g.type = "button", s.disabled && (g.disabled = !0, g["aria-disabled"] = !0), g;
|
|
367
|
+
}), u = x(() => {
|
|
368
|
+
const g = [
|
|
369
369
|
"inline-flex items-center font-medium transition-colors duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-strands-500 focus-visible:ring-offset-2 disabled:opacity-50 disabled:cursor-not-allowed"
|
|
370
370
|
], c = {
|
|
371
371
|
sm: "text-xs",
|
|
@@ -378,121 +378,121 @@ const Me = { class: "flex items-start" }, ze = { class: "flex-shrink-0" }, Se =
|
|
|
378
378
|
underline: "text-strands-500 hover:text-strands-600 underline decoration-strands-500 underline-offset-2"
|
|
379
379
|
};
|
|
380
380
|
return [
|
|
381
|
-
...
|
|
381
|
+
...g,
|
|
382
382
|
c[s.size],
|
|
383
383
|
f[s.variant]
|
|
384
384
|
].filter(Boolean).join(" ");
|
|
385
|
-
}),
|
|
386
|
-
s.disabled ||
|
|
385
|
+
}), o = (g) => {
|
|
386
|
+
s.disabled || l("click", g);
|
|
387
387
|
};
|
|
388
|
-
return (
|
|
389
|
-
default:
|
|
390
|
-
|
|
388
|
+
return (g, c) => (A(), Y(he(d.value), qe({ class: u.value }, i.value, { onClick: o }), {
|
|
389
|
+
default: z(() => [
|
|
390
|
+
P(g.$slots, "default")
|
|
391
391
|
]),
|
|
392
392
|
_: 3
|
|
393
393
|
}, 16, ["class"]));
|
|
394
394
|
}
|
|
395
|
-
}),
|
|
395
|
+
}), Re = { class: "relative" }, Je = {
|
|
396
396
|
class: "relative flex border-b border-neutral-200",
|
|
397
397
|
role: "tablist"
|
|
398
|
-
},
|
|
398
|
+
}, _e = ["aria-selected", "aria-controls", "id", "onClick"], $e = /* @__PURE__ */ k({
|
|
399
399
|
__name: "UiTabs",
|
|
400
400
|
props: {
|
|
401
401
|
modelValue: {},
|
|
402
402
|
tabs: {}
|
|
403
403
|
},
|
|
404
404
|
emits: ["update:modelValue"],
|
|
405
|
-
setup(
|
|
406
|
-
const s =
|
|
405
|
+
setup(y, { emit: p }) {
|
|
406
|
+
const s = y, l = p, d = U([]), i = U({
|
|
407
407
|
width: "0px",
|
|
408
408
|
left: "0px",
|
|
409
409
|
opacity: "0"
|
|
410
410
|
});
|
|
411
|
-
let
|
|
412
|
-
const
|
|
413
|
-
|
|
411
|
+
let u = -1, o = !1;
|
|
412
|
+
const g = async (t, m) => {
|
|
413
|
+
o || (l("update:modelValue", t), await de(), c(m));
|
|
414
414
|
}, c = async (t) => {
|
|
415
|
-
if (!
|
|
416
|
-
|
|
417
|
-
const
|
|
418
|
-
if (!
|
|
419
|
-
const
|
|
420
|
-
if (
|
|
421
|
-
|
|
422
|
-
width: `${
|
|
423
|
-
left: `${
|
|
415
|
+
if (!d.value[t] || t === u) return;
|
|
416
|
+
o = !0;
|
|
417
|
+
const m = d.value[t], w = m.parentElement;
|
|
418
|
+
if (!w) return;
|
|
419
|
+
const X = m.getBoundingClientRect(), V = w.getBoundingClientRect(), n = X.left - V.left, a = X.width;
|
|
420
|
+
if (u === -1) {
|
|
421
|
+
i.value = {
|
|
422
|
+
width: `${a}px`,
|
|
423
|
+
left: `${n}px`,
|
|
424
424
|
opacity: "1"
|
|
425
|
-
},
|
|
425
|
+
}, u = t, o = !1;
|
|
426
426
|
return;
|
|
427
427
|
}
|
|
428
|
-
const
|
|
429
|
-
|
|
430
|
-
width: `${
|
|
431
|
-
left: `${
|
|
428
|
+
const D = d.value[u].getBoundingClientRect(), Z = D.left - V.left, M = D.width, v = t > u, h = v ? Z : n, q = v ? n + a - Z : Z + M - n;
|
|
429
|
+
i.value = {
|
|
430
|
+
width: `${q}px`,
|
|
431
|
+
left: `${h}px`,
|
|
432
432
|
opacity: "1"
|
|
433
433
|
}, setTimeout(() => {
|
|
434
|
-
|
|
435
|
-
width: `${
|
|
436
|
-
left: `${
|
|
434
|
+
i.value = {
|
|
435
|
+
width: `${a}px`,
|
|
436
|
+
left: `${n}px`,
|
|
437
437
|
opacity: "1"
|
|
438
|
-
},
|
|
439
|
-
|
|
438
|
+
}, u = t, setTimeout(() => {
|
|
439
|
+
o = !1;
|
|
440
440
|
}, 150);
|
|
441
441
|
}, 120);
|
|
442
442
|
};
|
|
443
|
-
|
|
444
|
-
await
|
|
445
|
-
const t = s.tabs.findIndex((
|
|
443
|
+
se(async () => {
|
|
444
|
+
await de();
|
|
445
|
+
const t = s.tabs.findIndex((m) => m.value === s.modelValue);
|
|
446
446
|
t !== -1 && c(t);
|
|
447
|
-
}),
|
|
447
|
+
}), x(
|
|
448
448
|
() => s.tabs.findIndex((t) => t.value === s.modelValue)
|
|
449
449
|
);
|
|
450
|
-
const { modelValue: f } =
|
|
451
|
-
return
|
|
452
|
-
await
|
|
453
|
-
const t = s.tabs.findIndex((
|
|
450
|
+
const { modelValue: f } = Ce(s);
|
|
451
|
+
return re(f, async () => {
|
|
452
|
+
await de();
|
|
453
|
+
const t = s.tabs.findIndex((m) => m.value === s.modelValue);
|
|
454
454
|
t !== -1 && c(t);
|
|
455
|
-
}), (t,
|
|
456
|
-
e("div",
|
|
457
|
-
(A(!0),
|
|
458
|
-
key:
|
|
455
|
+
}), (t, m) => (A(), r("div", Re, [
|
|
456
|
+
e("div", Je, [
|
|
457
|
+
(A(!0), r(le, null, ne(t.tabs, (w, X) => (A(), r("button", {
|
|
458
|
+
key: w.value,
|
|
459
459
|
ref_for: !0,
|
|
460
460
|
ref_key: "tabButtons",
|
|
461
|
-
ref:
|
|
462
|
-
class:
|
|
461
|
+
ref: d,
|
|
462
|
+
class: B([
|
|
463
463
|
"relative flex-1 py-4 px-6 font-medium text-sm transition-colors duration-150",
|
|
464
464
|
"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-strands-500 focus-visible:ring-offset-2 focus-visible:ring-offset-white",
|
|
465
465
|
"hover:text-strands-600",
|
|
466
|
-
|
|
466
|
+
b(f) === w.value ? "text-strands-600" : "text-neutral-600"
|
|
467
467
|
]),
|
|
468
|
-
"aria-selected":
|
|
469
|
-
"aria-controls": `tabpanel-${
|
|
470
|
-
id: `tab-${
|
|
468
|
+
"aria-selected": b(f) === w.value,
|
|
469
|
+
"aria-controls": `tabpanel-${w.value}`,
|
|
470
|
+
id: `tab-${w.value}`,
|
|
471
471
|
role: "tab",
|
|
472
|
-
onClick: (
|
|
473
|
-
}, L(
|
|
472
|
+
onClick: (V) => g(w.value, X)
|
|
473
|
+
}, L(w.label), 11, _e))), 128)),
|
|
474
474
|
e("div", {
|
|
475
475
|
class: "absolute bottom-[-2px] h-[3px] bg-strands-500 rounded-full transition-all duration-150 ease-[cubic-bezier(0.25,0.46,0.45,0.94)]",
|
|
476
|
-
style:
|
|
476
|
+
style: We(i.value)
|
|
477
477
|
}, null, 4)
|
|
478
478
|
])
|
|
479
479
|
]));
|
|
480
480
|
}
|
|
481
|
-
}), st = "", we = (V, g) => {
|
|
482
|
-
const s =
|
|
483
|
-
for (const [
|
|
484
|
-
s[
|
|
481
|
+
}), et = "", ge = (y, p) => {
|
|
482
|
+
const s = y.__vccOpts || y;
|
|
483
|
+
for (const [l, d] of p)
|
|
484
|
+
s[l] = d;
|
|
485
485
|
return s;
|
|
486
|
-
},
|
|
487
|
-
function
|
|
488
|
-
return A(),
|
|
486
|
+
}, tt = {}, st = { class: "flex items-center justify-center gap-2 mt-4 -mb-4 pt-4 border-t border-neutral-200" };
|
|
487
|
+
function At(y, p) {
|
|
488
|
+
return A(), r("div", st, p[0] || (p[0] = [
|
|
489
489
|
e("img", {
|
|
490
|
-
src:
|
|
490
|
+
src: et,
|
|
491
491
|
class: "h-12 w-auto"
|
|
492
492
|
}, null, -1)
|
|
493
493
|
]));
|
|
494
494
|
}
|
|
495
|
-
const
|
|
495
|
+
const ae = /* @__PURE__ */ ge(tt, [["render", At]]), I = {
|
|
496
496
|
signIn: "/api/v1/auth/sign-in",
|
|
497
497
|
signUp: "/api/v1/auth/sign-up",
|
|
498
498
|
signOut: "/api/v1/auth/sign-out",
|
|
@@ -503,109 +503,107 @@ const le = /* @__PURE__ */ we(At, [["render", rt]]), Y = {
|
|
|
503
503
|
verifyEmail: "/api/v1/auth/verify-email",
|
|
504
504
|
oauthProviders: "/api/v1/oauth/providers",
|
|
505
505
|
oauthProvider: "/api/v1/oauth/providers/{provider_id}"
|
|
506
|
-
},
|
|
507
|
-
function
|
|
508
|
-
|
|
506
|
+
}, be = Symbol("strands-config"), ve = U(null);
|
|
507
|
+
function pe(y) {
|
|
508
|
+
ve.value = y, xe(be, y);
|
|
509
509
|
}
|
|
510
|
-
function
|
|
511
|
-
const
|
|
512
|
-
const
|
|
513
|
-
if (!
|
|
510
|
+
function ie(y) {
|
|
511
|
+
const p = Ne(be, null), s = x(() => {
|
|
512
|
+
const i = p || ve.value || y;
|
|
513
|
+
if (!i || !i.baseUrl)
|
|
514
514
|
throw new Error(
|
|
515
515
|
"StrandsAuth configuration is required. Please provide a baseUrl using provideStrandsConfig() or pass it as a prop."
|
|
516
516
|
);
|
|
517
|
-
return
|
|
518
|
-
}),
|
|
519
|
-
const
|
|
517
|
+
return i;
|
|
518
|
+
}), l = x(() => {
|
|
519
|
+
const u = s.value.endpoints || {};
|
|
520
520
|
return {
|
|
521
|
-
signIn:
|
|
522
|
-
signUp:
|
|
523
|
-
signOut:
|
|
524
|
-
refresh:
|
|
525
|
-
passwordReset:
|
|
526
|
-
passwordResetConfirm:
|
|
527
|
-
profile:
|
|
528
|
-
verifyEmail:
|
|
529
|
-
oauthProviders:
|
|
530
|
-
oauthProvider:
|
|
521
|
+
signIn: u.signIn || I.signIn,
|
|
522
|
+
signUp: u.signUp || I.signUp,
|
|
523
|
+
signOut: u.signOut || I.signOut,
|
|
524
|
+
refresh: u.refresh || I.refresh,
|
|
525
|
+
passwordReset: u.passwordReset || I.passwordReset,
|
|
526
|
+
passwordResetConfirm: u.passwordResetConfirm || I.passwordResetConfirm,
|
|
527
|
+
profile: u.profile || I.profile,
|
|
528
|
+
verifyEmail: u.verifyEmail || I.verifyEmail,
|
|
529
|
+
oauthProviders: u.oauthProviders || I.oauthProviders,
|
|
530
|
+
oauthProvider: u.oauthProvider || I.oauthProvider
|
|
531
531
|
};
|
|
532
532
|
});
|
|
533
533
|
return {
|
|
534
534
|
config: s,
|
|
535
|
-
endpoints:
|
|
536
|
-
getUrl: (
|
|
537
|
-
const
|
|
538
|
-
if (!
|
|
535
|
+
endpoints: l,
|
|
536
|
+
getUrl: (i) => {
|
|
537
|
+
const u = s.value;
|
|
538
|
+
if (!u.baseUrl)
|
|
539
539
|
throw new Error("Base URL is required in configuration");
|
|
540
|
-
let
|
|
541
|
-
typeof
|
|
542
|
-
const
|
|
543
|
-
return `${
|
|
540
|
+
let o;
|
|
541
|
+
typeof i == "string" && i in l.value ? o = l.value[i] : typeof i == "string" ? o = i : o = l.value[i];
|
|
542
|
+
const g = u.baseUrl.replace(/\/$/, ""), c = o.startsWith("/") ? o : `/${o}`;
|
|
543
|
+
return `${g}${c}`;
|
|
544
544
|
}
|
|
545
545
|
};
|
|
546
546
|
}
|
|
547
|
-
function
|
|
548
|
-
|
|
547
|
+
function _s(y) {
|
|
548
|
+
ve.value = y;
|
|
549
549
|
}
|
|
550
|
-
function fe(
|
|
551
|
-
const { getUrl:
|
|
550
|
+
function fe(y = {}) {
|
|
551
|
+
const { getUrl: p } = ie(), s = U([]), l = U(!1), d = U(null), i = x(
|
|
552
552
|
() => s.value.filter((t) => t.enabled)
|
|
553
|
-
),
|
|
554
|
-
|
|
555
|
-
r.value = !0, u.value = null;
|
|
553
|
+
), u = async () => {
|
|
554
|
+
l.value = !0, d.value = null;
|
|
556
555
|
try {
|
|
557
|
-
const
|
|
556
|
+
const t = await fetch(p("oauthProviders"), {
|
|
558
557
|
method: "GET",
|
|
559
558
|
headers: {
|
|
560
559
|
"Content-Type": "application/json"
|
|
561
560
|
}
|
|
562
561
|
});
|
|
563
|
-
if (!
|
|
564
|
-
const
|
|
565
|
-
throw new Error(
|
|
562
|
+
if (!t.ok) {
|
|
563
|
+
const w = await t.json().catch(() => ({}));
|
|
564
|
+
throw new Error(w.error?.message || `HTTP ${t.status}: ${t.statusText}`);
|
|
566
565
|
}
|
|
567
|
-
const
|
|
568
|
-
if (!
|
|
569
|
-
throw new Error(
|
|
570
|
-
s.value =
|
|
571
|
-
} catch (
|
|
572
|
-
const
|
|
573
|
-
|
|
566
|
+
const m = await t.json();
|
|
567
|
+
if (!m.success)
|
|
568
|
+
throw new Error(m.error?.message || "Failed to fetch OAuth providers");
|
|
569
|
+
s.value = m.data || [];
|
|
570
|
+
} catch (t) {
|
|
571
|
+
const m = t instanceof Error ? t.message : "Failed to fetch OAuth providers";
|
|
572
|
+
d.value = m, console.error("OAuth providers fetch error:", t);
|
|
574
573
|
} finally {
|
|
575
|
-
|
|
574
|
+
l.value = !1;
|
|
576
575
|
}
|
|
577
|
-
},
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
const h = z.toString(), l = g("oauthProvider").replace("{provider_id}", t), y = h ? `${l}?${h}` : l;
|
|
576
|
+
}, o = async (t, m) => {
|
|
577
|
+
const w = { ...y, ...m }, X = new URLSearchParams();
|
|
578
|
+
w.redirectUrl && X.append("redirect_url", w.redirectUrl), w.scopes && w.scopes.length > 0 && X.append("scopes", w.scopes.join(","));
|
|
579
|
+
const V = X.toString(), n = p("oauthProvider").replace("{provider_id}", t), a = V ? `${n}?${V}` : n;
|
|
582
580
|
try {
|
|
583
|
-
const
|
|
581
|
+
const S = await fetch(a, {
|
|
584
582
|
method: "GET",
|
|
585
583
|
headers: {
|
|
586
584
|
"Content-Type": "application/json"
|
|
587
585
|
}
|
|
588
586
|
});
|
|
589
|
-
if (!
|
|
590
|
-
const
|
|
591
|
-
throw new Error(
|
|
587
|
+
if (!S.ok) {
|
|
588
|
+
const Z = await S.json().catch(() => ({}));
|
|
589
|
+
throw new Error(Z.error?.message || `HTTP ${S.status}: ${S.statusText}`);
|
|
592
590
|
}
|
|
593
|
-
const
|
|
594
|
-
if (!
|
|
595
|
-
throw new Error(
|
|
596
|
-
return
|
|
597
|
-
} catch (
|
|
598
|
-
const
|
|
599
|
-
throw new Error(
|
|
591
|
+
const D = await S.json();
|
|
592
|
+
if (!D.success)
|
|
593
|
+
throw new Error(D.error?.message || "Failed to get OAuth auth URL");
|
|
594
|
+
return D.data.authUrl;
|
|
595
|
+
} catch (S) {
|
|
596
|
+
const D = S instanceof Error ? S.message : "Failed to get OAuth auth URL";
|
|
597
|
+
throw new Error(D);
|
|
600
598
|
}
|
|
601
|
-
},
|
|
599
|
+
}, g = async (t, m) => {
|
|
602
600
|
try {
|
|
603
|
-
const
|
|
604
|
-
window.location.href =
|
|
605
|
-
} catch (
|
|
606
|
-
throw
|
|
601
|
+
const w = await o(t, m);
|
|
602
|
+
window.location.href = w;
|
|
603
|
+
} catch (w) {
|
|
604
|
+
throw d.value = w instanceof Error ? w.message : "Failed to redirect to OAuth provider", w;
|
|
607
605
|
}
|
|
608
|
-
}, c = (t) => s.value.find((
|
|
606
|
+
}, c = (t) => s.value.find((m) => m.id === t), f = (t) => {
|
|
609
607
|
if (t.iconUrl)
|
|
610
608
|
return t.iconUrl;
|
|
611
609
|
switch (t.id.toLowerCase()) {
|
|
@@ -623,44 +621,44 @@ function fe(V = {}) {
|
|
|
623
621
|
}
|
|
624
622
|
};
|
|
625
623
|
return {
|
|
626
|
-
providers:
|
|
627
|
-
enabledProviders:
|
|
628
|
-
loading:
|
|
629
|
-
error:
|
|
630
|
-
fetchProviders:
|
|
631
|
-
getProviderAuthUrl:
|
|
632
|
-
redirectToProvider:
|
|
624
|
+
providers: x(() => s.value),
|
|
625
|
+
enabledProviders: i,
|
|
626
|
+
loading: x(() => l.value),
|
|
627
|
+
error: x(() => d.value),
|
|
628
|
+
fetchProviders: u,
|
|
629
|
+
getProviderAuthUrl: o,
|
|
630
|
+
redirectToProvider: g,
|
|
633
631
|
getProviderById: c,
|
|
634
632
|
getProviderIcon: f
|
|
635
633
|
};
|
|
636
634
|
}
|
|
637
|
-
const
|
|
635
|
+
const at = { class: "w-full max-w-md mx-auto animate-slide-up" }, rt = { class: "text-center mb-8" }, lt = {
|
|
638
636
|
key: "tabs",
|
|
639
637
|
class: "mb-8"
|
|
640
|
-
},
|
|
638
|
+
}, nt = {
|
|
641
639
|
key: "oauth",
|
|
642
640
|
class: "space-y-3 mb-6"
|
|
643
|
-
},
|
|
641
|
+
}, ot = { class: "w-5 h-5 flex items-center justify-center" }, it = {
|
|
644
642
|
key: 0,
|
|
645
643
|
class: "w-5 h-5"
|
|
646
|
-
},
|
|
644
|
+
}, ut = ["src", "alt"], dt = {
|
|
647
645
|
key: 1,
|
|
648
646
|
viewBox: "0 0 24 24",
|
|
649
647
|
class: "w-5 h-5"
|
|
650
|
-
},
|
|
648
|
+
}, ct = {
|
|
651
649
|
key: 2,
|
|
652
650
|
class: "w-5 h-5 fill-current",
|
|
653
651
|
viewBox: "0 0 24 24"
|
|
654
|
-
},
|
|
652
|
+
}, mt = {
|
|
655
653
|
key: 3,
|
|
656
654
|
class: "w-5 h-5 rounded-full bg-neutral-300 flex items-center justify-center"
|
|
657
|
-
},
|
|
655
|
+
}, vt = { class: "text-xs font-semibold text-neutral-600" }, ft = { class: "font-medium" }, pt = {
|
|
658
656
|
key: "divider",
|
|
659
657
|
class: "divider-with-text"
|
|
660
|
-
},
|
|
658
|
+
}, gt = { class: "divider-text" }, bt = { class: "space-y-4" }, wt = { key: "password-section" }, yt = { class: "flex items-center justify-between mb-2" }, Vt = {
|
|
661
659
|
key: "back-link",
|
|
662
660
|
class: "mt-8 text-center"
|
|
663
|
-
},
|
|
661
|
+
}, ht = /* @__PURE__ */ k({
|
|
664
662
|
__name: "StrandsAuth",
|
|
665
663
|
props: {
|
|
666
664
|
mode: { default: "signin" },
|
|
@@ -668,145 +666,143 @@ const lt = { class: "w-full max-w-md mx-auto animate-slide-up" }, nt = { class:
|
|
|
668
666
|
config: {}
|
|
669
667
|
},
|
|
670
668
|
emits: ["success", "error", "forgot-password", "password-reset-sent", "mode-changed"],
|
|
671
|
-
setup(
|
|
672
|
-
const s =
|
|
673
|
-
enabledProviders:
|
|
674
|
-
loading:
|
|
675
|
-
error:
|
|
676
|
-
fetchProviders:
|
|
669
|
+
setup(y, { emit: p }) {
|
|
670
|
+
const s = y, l = p, { getUrl: d } = ie(s.config), {
|
|
671
|
+
enabledProviders: i,
|
|
672
|
+
loading: u,
|
|
673
|
+
error: o,
|
|
674
|
+
fetchProviders: g,
|
|
677
675
|
redirectToProvider: c,
|
|
678
676
|
getProviderIcon: f
|
|
679
677
|
} = fe({
|
|
680
678
|
redirectUrl: s.redirectUrl
|
|
681
679
|
});
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
console.warn("Failed to fetch OAuth providers:",
|
|
680
|
+
se(() => {
|
|
681
|
+
g().catch((h) => {
|
|
682
|
+
console.warn("Failed to fetch OAuth providers:", h);
|
|
685
683
|
});
|
|
686
684
|
});
|
|
687
|
-
const t =
|
|
688
|
-
async signIn(
|
|
689
|
-
|
|
690
|
-
const M = await fetch(u("signIn"), {
|
|
685
|
+
const t = x(() => i.value), m = {
|
|
686
|
+
async signIn(h, q) {
|
|
687
|
+
const W = await fetch(d("signIn"), {
|
|
691
688
|
method: "POST",
|
|
692
689
|
headers: {
|
|
693
690
|
"Content-Type": "application/json"
|
|
694
691
|
},
|
|
695
|
-
body: JSON.stringify({ email:
|
|
692
|
+
body: JSON.stringify({ email: h, password: q })
|
|
696
693
|
});
|
|
697
|
-
if (!
|
|
698
|
-
const
|
|
699
|
-
throw new Error(
|
|
694
|
+
if (!W.ok) {
|
|
695
|
+
const Q = await W.json().catch(() => ({}));
|
|
696
|
+
throw new Error(Q.error?.message || `HTTP ${W.status}: ${W.statusText}`);
|
|
700
697
|
}
|
|
701
|
-
const
|
|
702
|
-
if (!
|
|
703
|
-
throw new Error(
|
|
704
|
-
return
|
|
698
|
+
const R = await W.json();
|
|
699
|
+
if (!R.success)
|
|
700
|
+
throw new Error(R.error?.message || "Sign in failed");
|
|
701
|
+
return R.data;
|
|
705
702
|
},
|
|
706
|
-
async signUp(
|
|
707
|
-
|
|
708
|
-
const T = await fetch(u("signUp"), {
|
|
703
|
+
async signUp(h, q, W, R) {
|
|
704
|
+
const Q = await fetch(d("signUp"), {
|
|
709
705
|
method: "POST",
|
|
710
706
|
headers: {
|
|
711
707
|
"Content-Type": "application/json"
|
|
712
708
|
},
|
|
713
|
-
body: JSON.stringify({ email:
|
|
709
|
+
body: JSON.stringify({ email: h, password: q, firstName: W, lastName: R })
|
|
714
710
|
});
|
|
715
|
-
if (!
|
|
716
|
-
const
|
|
717
|
-
throw new Error(
|
|
711
|
+
if (!Q.ok) {
|
|
712
|
+
const ye = await Q.json().catch(() => ({}));
|
|
713
|
+
throw new Error(ye.error?.message || `HTTP ${Q.status}: ${Q.statusText}`);
|
|
718
714
|
}
|
|
719
|
-
const
|
|
720
|
-
if (!
|
|
721
|
-
throw new Error(
|
|
722
|
-
return
|
|
715
|
+
const ue = await Q.json();
|
|
716
|
+
if (!ue.success)
|
|
717
|
+
throw new Error(ue.error?.message || "Sign up failed");
|
|
718
|
+
return ue.data;
|
|
723
719
|
},
|
|
724
|
-
async requestPasswordReset(
|
|
720
|
+
async requestPasswordReset(h) {
|
|
725
721
|
throw new Error("Password reset functionality is not yet implemented in the API. Please contact support.");
|
|
726
722
|
}
|
|
727
|
-
},
|
|
723
|
+
}, w = U(s.mode), X = U(!1), V = U(""), n = U(!1), a = H({
|
|
728
724
|
firstName: "",
|
|
729
725
|
lastName: "",
|
|
730
726
|
email: "",
|
|
731
727
|
password: "",
|
|
732
728
|
confirmPassword: ""
|
|
733
|
-
}),
|
|
734
|
-
|
|
735
|
-
const
|
|
736
|
-
|
|
729
|
+
}), S = x(() => w.value === "signup"), D = x(() => w.value === "reset-password");
|
|
730
|
+
x(() => a.password === a.confirmPassword);
|
|
731
|
+
const Z = x(() => D.value ? a.email.trim() && !n.value : S.value ? a.email.trim() : a.email.trim() && a.password), M = async () => {
|
|
732
|
+
X.value = !0, V.value = "";
|
|
737
733
|
try {
|
|
738
|
-
if (
|
|
739
|
-
await
|
|
740
|
-
else if (
|
|
741
|
-
const
|
|
742
|
-
|
|
743
|
-
|
|
744
|
-
|
|
745
|
-
|
|
734
|
+
if (D.value)
|
|
735
|
+
await m.requestPasswordReset(a.email), n.value = !0, l("password-reset-sent", a.email);
|
|
736
|
+
else if (S.value) {
|
|
737
|
+
const h = await m.signUp(
|
|
738
|
+
a.email,
|
|
739
|
+
a.password,
|
|
740
|
+
a.firstName,
|
|
741
|
+
a.lastName
|
|
746
742
|
);
|
|
747
|
-
|
|
743
|
+
l("success", h.user);
|
|
748
744
|
} else {
|
|
749
|
-
const
|
|
750
|
-
|
|
745
|
+
const h = await m.signIn(a.email, a.password);
|
|
746
|
+
l("success", h.user);
|
|
751
747
|
}
|
|
752
|
-
} catch (
|
|
753
|
-
const
|
|
754
|
-
|
|
748
|
+
} catch (h) {
|
|
749
|
+
const q = h instanceof Error ? h.message : "An unexpected error occurred";
|
|
750
|
+
V.value = q, l("error", q);
|
|
755
751
|
} finally {
|
|
756
|
-
|
|
752
|
+
X.value = !1;
|
|
757
753
|
}
|
|
758
|
-
},
|
|
754
|
+
}, v = async (h) => {
|
|
759
755
|
try {
|
|
760
|
-
await c(
|
|
756
|
+
await c(h, {
|
|
761
757
|
redirectUrl: s.redirectUrl
|
|
762
758
|
});
|
|
763
|
-
} catch (
|
|
764
|
-
const
|
|
765
|
-
|
|
759
|
+
} catch (q) {
|
|
760
|
+
const W = q instanceof Error ? q.message : `Failed to ${S.value ? "sign up" : "sign in"} with ${h}`;
|
|
761
|
+
V.value = W, l("error", W);
|
|
766
762
|
}
|
|
767
763
|
};
|
|
768
|
-
return
|
|
769
|
-
|
|
770
|
-
}),
|
|
771
|
-
|
|
772
|
-
}), (
|
|
773
|
-
|
|
774
|
-
default:
|
|
775
|
-
e("div",
|
|
776
|
-
|
|
764
|
+
return re(() => s.mode, (h) => {
|
|
765
|
+
w.value = h;
|
|
766
|
+
}), re(w, (h) => {
|
|
767
|
+
V.value = "", n.value = !1, a.firstName = "", a.lastName = "", a.email = "", a.password = "", a.confirmPassword = "", l("mode-changed", h);
|
|
768
|
+
}), (h, q) => (A(), r("div", at, [
|
|
769
|
+
N(b(oe), { variant: "modern" }, {
|
|
770
|
+
default: z(() => [
|
|
771
|
+
e("div", rt, [
|
|
772
|
+
N(K, {
|
|
777
773
|
name: "fade",
|
|
778
774
|
mode: "out-in"
|
|
779
775
|
}, {
|
|
780
|
-
default:
|
|
781
|
-
(A(),
|
|
782
|
-
key:
|
|
776
|
+
default: z(() => [
|
|
777
|
+
(A(), r("h1", {
|
|
778
|
+
key: w.value,
|
|
783
779
|
class: "text-3xl font-bold text-gradient mb-2"
|
|
784
|
-
}, L(
|
|
780
|
+
}, L(D.value ? "Reset password" : S.value ? "Create account" : "Welcome back"), 1))
|
|
785
781
|
]),
|
|
786
782
|
_: 1
|
|
787
783
|
}),
|
|
788
|
-
|
|
784
|
+
N(K, {
|
|
789
785
|
name: "fade",
|
|
790
786
|
mode: "out-in"
|
|
791
787
|
}, {
|
|
792
|
-
default:
|
|
793
|
-
(A(),
|
|
794
|
-
key:
|
|
788
|
+
default: z(() => [
|
|
789
|
+
(A(), r("p", {
|
|
790
|
+
key: w.value,
|
|
795
791
|
class: "text-neutral-600"
|
|
796
|
-
}, L(
|
|
792
|
+
}, L(D.value ? "Enter your email address and we'll send you a link to reset your password" : S.value ? "We'll send you a magic link to get started" : "Sign in to your account to continue"), 1))
|
|
797
793
|
]),
|
|
798
794
|
_: 1
|
|
799
795
|
})
|
|
800
796
|
]),
|
|
801
|
-
|
|
797
|
+
N(K, {
|
|
802
798
|
name: "height-fade",
|
|
803
799
|
mode: "out-in"
|
|
804
800
|
}, {
|
|
805
|
-
default:
|
|
806
|
-
|
|
807
|
-
|
|
808
|
-
modelValue:
|
|
809
|
-
"onUpdate:modelValue":
|
|
801
|
+
default: z(() => [
|
|
802
|
+
D.value ? C("", !0) : (A(), r("div", lt, [
|
|
803
|
+
N(b($e), {
|
|
804
|
+
modelValue: w.value,
|
|
805
|
+
"onUpdate:modelValue": q[0] || (q[0] = (W) => w.value = W),
|
|
810
806
|
tabs: [
|
|
811
807
|
{ label: "Sign In", value: "signin" },
|
|
812
808
|
{ label: "Sign Up", value: "signup" }
|
|
@@ -816,164 +812,158 @@ const lt = { class: "w-full max-w-md mx-auto animate-slide-up" }, nt = { class:
|
|
|
816
812
|
]),
|
|
817
813
|
_: 1
|
|
818
814
|
}),
|
|
819
|
-
|
|
815
|
+
N(K, {
|
|
820
816
|
name: "height-fade",
|
|
821
817
|
mode: "out-in"
|
|
822
818
|
}, {
|
|
823
|
-
default:
|
|
824
|
-
|
|
825
|
-
|
|
826
|
-
|
|
827
|
-
|
|
828
|
-
|
|
829
|
-
|
|
830
|
-
|
|
831
|
-
|
|
832
|
-
|
|
833
|
-
|
|
834
|
-
|
|
835
|
-
|
|
836
|
-
|
|
837
|
-
|
|
838
|
-
|
|
839
|
-
|
|
840
|
-
|
|
841
|
-
|
|
842
|
-
|
|
843
|
-
|
|
844
|
-
|
|
845
|
-
|
|
846
|
-
|
|
847
|
-
|
|
848
|
-
|
|
849
|
-
|
|
850
|
-
|
|
851
|
-
|
|
852
|
-
|
|
853
|
-
|
|
854
|
-
|
|
855
|
-
|
|
856
|
-
|
|
857
|
-
|
|
858
|
-
|
|
859
|
-
|
|
860
|
-
|
|
861
|
-
|
|
862
|
-
|
|
863
|
-
e("span", ft, L((k.displayName || k.name).charAt(0).toUpperCase()), 1)
|
|
864
|
-
]))
|
|
865
|
-
]),
|
|
866
|
-
e("span", gt, " Continue with " + L(k.displayName || k.name.charAt(0).toUpperCase() + k.name.slice(1)), 1)
|
|
819
|
+
default: z(() => [
|
|
820
|
+
!D.value && t.value?.length ? (A(), r("div", nt, [
|
|
821
|
+
(A(!0), r(le, null, ne(t.value, (W) => (A(), Y(b(G), {
|
|
822
|
+
key: W.id,
|
|
823
|
+
variant: "outline",
|
|
824
|
+
"full-width": "",
|
|
825
|
+
disabled: b(u),
|
|
826
|
+
onClick: (R) => v(W.id),
|
|
827
|
+
class: "btn-oauth group"
|
|
828
|
+
}, {
|
|
829
|
+
default: z(() => [
|
|
830
|
+
e("div", ot, [
|
|
831
|
+
W.iconUrl ? (A(), r("div", it, [
|
|
832
|
+
e("img", {
|
|
833
|
+
src: W.iconUrl,
|
|
834
|
+
alt: `${W.displayName || W.name} icon`,
|
|
835
|
+
class: "w-5 h-5"
|
|
836
|
+
}, null, 8, ut)
|
|
837
|
+
])) : W.id === "google" ? (A(), r("svg", dt, q[6] || (q[6] = [
|
|
838
|
+
e("path", {
|
|
839
|
+
fill: "#4285F4",
|
|
840
|
+
d: "M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z"
|
|
841
|
+
}, null, -1),
|
|
842
|
+
e("path", {
|
|
843
|
+
fill: "#34A853",
|
|
844
|
+
d: "M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z"
|
|
845
|
+
}, null, -1),
|
|
846
|
+
e("path", {
|
|
847
|
+
fill: "#FBBC05",
|
|
848
|
+
d: "M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z"
|
|
849
|
+
}, null, -1),
|
|
850
|
+
e("path", {
|
|
851
|
+
fill: "#EA4335",
|
|
852
|
+
d: "M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z"
|
|
853
|
+
}, null, -1)
|
|
854
|
+
]))) : W.id === "github" ? (A(), r("svg", ct, q[7] || (q[7] = [
|
|
855
|
+
e("path", { d: "M12 0c-6.626 0-12 5.373-12 12 0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931 0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176 0 0 1.008-.322 3.301 1.23.957-.266 1.983-.399 3.003-.404 1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221 0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576 4.765-1.589 8.199-6.086 8.199-11.386 0-6.627-5.373-12-12-12z" }, null, -1)
|
|
856
|
+
]))) : (A(), r("div", mt, [
|
|
857
|
+
e("span", vt, L((W.displayName || W.name).charAt(0).toUpperCase()), 1)
|
|
858
|
+
]))
|
|
867
859
|
]),
|
|
868
|
-
|
|
869
|
-
|
|
870
|
-
|
|
871
|
-
|
|
872
|
-
|
|
860
|
+
e("span", ft, " Continue with " + L(W.displayName || W.name.charAt(0).toUpperCase() + W.name.slice(1)), 1)
|
|
861
|
+
]),
|
|
862
|
+
_: 2
|
|
863
|
+
}, 1032, ["disabled", "onClick"]))), 128))
|
|
864
|
+
])) : C("", !0)
|
|
865
|
+
]),
|
|
873
866
|
_: 1
|
|
874
867
|
}),
|
|
875
|
-
|
|
868
|
+
N(K, {
|
|
876
869
|
name: "height-fade",
|
|
877
870
|
mode: "out-in"
|
|
878
871
|
}, {
|
|
879
|
-
default:
|
|
880
|
-
|
|
881
|
-
|
|
882
|
-
|
|
883
|
-
|
|
884
|
-
])) : W("", !0)
|
|
885
|
-
];
|
|
886
|
-
}),
|
|
872
|
+
default: z(() => [
|
|
873
|
+
!D.value && t.value?.length ? (A(), r("div", pt, [
|
|
874
|
+
e("span", gt, "Or " + L(S.value ? "create account" : "sign in") + " with email", 1)
|
|
875
|
+
])) : C("", !0)
|
|
876
|
+
]),
|
|
887
877
|
_: 1
|
|
888
878
|
}),
|
|
889
879
|
e("form", {
|
|
890
|
-
onSubmit:
|
|
880
|
+
onSubmit: Ae(M, ["prevent"]),
|
|
891
881
|
class: "space-y-6"
|
|
892
882
|
}, [
|
|
893
|
-
e("div",
|
|
894
|
-
|
|
895
|
-
modelValue:
|
|
896
|
-
"onUpdate:modelValue":
|
|
883
|
+
e("div", bt, [
|
|
884
|
+
N(b(_), {
|
|
885
|
+
modelValue: a.email,
|
|
886
|
+
"onUpdate:modelValue": q[1] || (q[1] = (W) => a.email = W),
|
|
897
887
|
type: "email",
|
|
898
888
|
label: "Email address",
|
|
899
889
|
placeholder: "Enter your email",
|
|
900
890
|
required: "",
|
|
901
891
|
autocomplete: "email",
|
|
902
|
-
error:
|
|
892
|
+
error: V.value && !a.email ? "Email is required" : ""
|
|
903
893
|
}, null, 8, ["modelValue", "error"]),
|
|
904
|
-
|
|
894
|
+
N(K, {
|
|
905
895
|
name: "height-fade",
|
|
906
896
|
mode: "out-in"
|
|
907
897
|
}, {
|
|
908
|
-
default:
|
|
909
|
-
!
|
|
910
|
-
e("div",
|
|
911
|
-
|
|
912
|
-
|
|
898
|
+
default: z(() => [
|
|
899
|
+
!D.value && !S.value ? (A(), r("div", wt, [
|
|
900
|
+
e("div", yt, [
|
|
901
|
+
q[9] || (q[9] = e("span", { class: "text-sm font-medium text-gray-700" }, "Password", -1)),
|
|
902
|
+
N(b(te), {
|
|
913
903
|
variant: "primary",
|
|
914
904
|
size: "sm",
|
|
915
|
-
onClick:
|
|
905
|
+
onClick: q[2] || (q[2] = (W) => w.value = "reset-password")
|
|
916
906
|
}, {
|
|
917
|
-
default:
|
|
918
|
-
|
|
907
|
+
default: z(() => q[8] || (q[8] = [
|
|
908
|
+
F(" Forgot password? ", -1)
|
|
919
909
|
])),
|
|
920
910
|
_: 1,
|
|
921
911
|
__: [8]
|
|
922
912
|
})
|
|
923
913
|
]),
|
|
924
|
-
|
|
925
|
-
modelValue:
|
|
926
|
-
"onUpdate:modelValue":
|
|
914
|
+
N(b(_), {
|
|
915
|
+
modelValue: a.password,
|
|
916
|
+
"onUpdate:modelValue": q[3] || (q[3] = (W) => a.password = W),
|
|
927
917
|
type: "password",
|
|
928
918
|
placeholder: "Enter your password",
|
|
929
919
|
required: "",
|
|
930
920
|
autocomplete: "current-password",
|
|
931
|
-
error:
|
|
921
|
+
error: V.value && !a.password ? "Password is required" : ""
|
|
932
922
|
}, null, 8, ["modelValue", "error"])
|
|
933
|
-
])) :
|
|
923
|
+
])) : C("", !0)
|
|
934
924
|
]),
|
|
935
925
|
_: 1
|
|
936
926
|
})
|
|
937
927
|
]),
|
|
938
|
-
|
|
928
|
+
N(b(G), {
|
|
939
929
|
type: "submit",
|
|
940
930
|
variant: "primary",
|
|
941
931
|
"full-width": "",
|
|
942
|
-
disabled:
|
|
943
|
-
loading:
|
|
944
|
-
"loading-text":
|
|
932
|
+
disabled: X.value || !Z.value,
|
|
933
|
+
loading: X.value,
|
|
934
|
+
"loading-text": D.value ? "Sending link..." : S.value ? "Sending magic link..." : "Signing in..."
|
|
945
935
|
}, {
|
|
946
|
-
default:
|
|
947
|
-
|
|
936
|
+
default: z(() => [
|
|
937
|
+
F(L(D.value ? n.value ? "Link sent!" : "Send reset link" : S.value ? "Send magic link" : "Sign in"), 1)
|
|
948
938
|
]),
|
|
949
939
|
_: 1
|
|
950
940
|
}, 8, ["disabled", "loading", "loading-text"])
|
|
951
941
|
], 32),
|
|
952
|
-
|
|
942
|
+
N(K, {
|
|
953
943
|
name: "expand",
|
|
954
944
|
mode: "out-in"
|
|
955
945
|
}, {
|
|
956
|
-
default:
|
|
957
|
-
|
|
946
|
+
default: z(() => [
|
|
947
|
+
D.value && n.value ? (A(), Y(b(ee), {
|
|
958
948
|
key: "reset-success",
|
|
959
949
|
variant: "success",
|
|
960
|
-
message: `Check your email - We've sent a password reset link to ${
|
|
950
|
+
message: `Check your email - We've sent a password reset link to ${a.email}`,
|
|
961
951
|
class: "mt-6 animate-fade-in"
|
|
962
|
-
}, null, 8, ["message"])) :
|
|
952
|
+
}, null, 8, ["message"])) : C("", !0)
|
|
963
953
|
]),
|
|
964
954
|
_: 1
|
|
965
955
|
}),
|
|
966
|
-
|
|
956
|
+
N(K, {
|
|
967
957
|
name: "height-fade",
|
|
968
958
|
mode: "out-in"
|
|
969
959
|
}, {
|
|
970
|
-
default:
|
|
971
|
-
|
|
972
|
-
|
|
973
|
-
onClick:
|
|
960
|
+
default: z(() => [
|
|
961
|
+
D.value ? (A(), r("div", Vt, [
|
|
962
|
+
N(b(te), {
|
|
963
|
+
onClick: q[4] || (q[4] = (W) => w.value = "signin"),
|
|
974
964
|
class: "inline-flex items-center gap-2"
|
|
975
965
|
}, {
|
|
976
|
-
default:
|
|
966
|
+
default: z(() => q[10] || (q[10] = [
|
|
977
967
|
e("svg", {
|
|
978
968
|
class: "w-4 h-4",
|
|
979
969
|
fill: "none",
|
|
@@ -987,50 +977,50 @@ const lt = { class: "w-full max-w-md mx-auto animate-slide-up" }, nt = { class:
|
|
|
987
977
|
d: "M15 19l-7-7 7-7"
|
|
988
978
|
})
|
|
989
979
|
], -1),
|
|
990
|
-
|
|
980
|
+
F(" Back to sign in ", -1)
|
|
991
981
|
])),
|
|
992
982
|
_: 1,
|
|
993
983
|
__: [10]
|
|
994
984
|
})
|
|
995
|
-
])) :
|
|
985
|
+
])) : C("", !0)
|
|
996
986
|
]),
|
|
997
987
|
_: 1
|
|
998
988
|
}),
|
|
999
|
-
|
|
989
|
+
V.value ? (A(), Y(b(ee), {
|
|
1000
990
|
key: 0,
|
|
1001
991
|
variant: "error",
|
|
1002
|
-
message:
|
|
992
|
+
message: V.value,
|
|
1003
993
|
class: "mt-6 animate-fade-in",
|
|
1004
994
|
dismissible: "",
|
|
1005
|
-
onDismiss:
|
|
1006
|
-
}, null, 8, ["message"])) :
|
|
1007
|
-
|
|
995
|
+
onDismiss: q[5] || (q[5] = (W) => V.value = "")
|
|
996
|
+
}, null, 8, ["message"])) : C("", !0),
|
|
997
|
+
N(ae)
|
|
1008
998
|
]),
|
|
1009
999
|
_: 1
|
|
1010
1000
|
})
|
|
1011
1001
|
]));
|
|
1012
1002
|
}
|
|
1013
|
-
}),
|
|
1003
|
+
}), $s = /* @__PURE__ */ ge(ht, [["__scopeId", "data-v-7f6add9f"]]), qt = { class: "w-full max-w-md mx-auto animate-slide-up" }, Ct = {
|
|
1014
1004
|
key: 0,
|
|
1015
1005
|
class: "space-y-3 mb-6"
|
|
1016
|
-
},
|
|
1006
|
+
}, Wt = { class: "w-5 h-5 flex items-center justify-center" }, Nt = {
|
|
1017
1007
|
key: 0,
|
|
1018
1008
|
class: "w-5 h-5"
|
|
1019
|
-
},
|
|
1009
|
+
}, xt = ["src", "alt"], Lt = {
|
|
1020
1010
|
key: 1,
|
|
1021
1011
|
viewBox: "0 0 24 24",
|
|
1022
1012
|
class: "w-5 h-5"
|
|
1023
|
-
},
|
|
1013
|
+
}, Ut = {
|
|
1024
1014
|
key: 2,
|
|
1025
1015
|
class: "w-5 h-5 fill-current",
|
|
1026
1016
|
viewBox: "0 0 24 24"
|
|
1027
|
-
},
|
|
1017
|
+
}, Mt = {
|
|
1028
1018
|
key: 3,
|
|
1029
1019
|
class: "w-5 h-5 rounded-full bg-neutral-300 flex items-center justify-center"
|
|
1030
|
-
},
|
|
1020
|
+
}, zt = { class: "text-xs font-semibold text-neutral-600" }, St = { class: "font-medium" }, Dt = {
|
|
1031
1021
|
key: 1,
|
|
1032
1022
|
class: "divider-with-text"
|
|
1033
|
-
},
|
|
1023
|
+
}, Xt = { class: "space-y-4" }, kt = { class: "flex items-center justify-between mb-2" }, Bt = { class: "mt-8 text-center" }, Ft = { class: "text-sm text-neutral-600" }, eA = /* @__PURE__ */ k({
|
|
1034
1024
|
__name: "StrandsSignIn",
|
|
1035
1025
|
props: {
|
|
1036
1026
|
redirectUrl: { default: "/" },
|
|
@@ -1038,213 +1028,210 @@ const lt = { class: "w-full max-w-md mx-auto animate-slide-up" }, nt = { class:
|
|
|
1038
1028
|
config: {}
|
|
1039
1029
|
},
|
|
1040
1030
|
emits: ["success", "error", "forgot-password", "switch-to-signup"],
|
|
1041
|
-
setup(
|
|
1042
|
-
const s =
|
|
1043
|
-
enabledProviders:
|
|
1044
|
-
loading:
|
|
1045
|
-
error:
|
|
1046
|
-
fetchProviders:
|
|
1031
|
+
setup(y, { emit: p }) {
|
|
1032
|
+
const s = y, l = p, { getUrl: d } = ie(s.config), {
|
|
1033
|
+
enabledProviders: i,
|
|
1034
|
+
loading: u,
|
|
1035
|
+
error: o,
|
|
1036
|
+
fetchProviders: g,
|
|
1047
1037
|
redirectToProvider: c
|
|
1048
1038
|
} = fe({
|
|
1049
1039
|
redirectUrl: s.redirectUrl,
|
|
1050
1040
|
scopes: s.oauthScopes
|
|
1051
1041
|
});
|
|
1052
|
-
|
|
1053
|
-
|
|
1054
|
-
console.warn("Failed to fetch OAuth providers:",
|
|
1042
|
+
se(() => {
|
|
1043
|
+
g().catch((V) => {
|
|
1044
|
+
console.warn("Failed to fetch OAuth providers:", V);
|
|
1055
1045
|
});
|
|
1056
1046
|
});
|
|
1057
|
-
const f = U(!1), t = U(""),
|
|
1047
|
+
const f = U(!1), t = U(""), m = H({
|
|
1058
1048
|
email: "",
|
|
1059
1049
|
password: ""
|
|
1060
|
-
}),
|
|
1050
|
+
}), w = async () => {
|
|
1061
1051
|
f.value = !0, t.value = "";
|
|
1062
1052
|
try {
|
|
1063
|
-
console.log("Sign in attempt:",
|
|
1053
|
+
console.log("Sign in attempt:", m), l("success", { email: m.email });
|
|
1064
1054
|
} catch {
|
|
1065
|
-
t.value = "Invalid email or password",
|
|
1055
|
+
t.value = "Invalid email or password", l("error", t.value);
|
|
1066
1056
|
} finally {
|
|
1067
1057
|
f.value = !1;
|
|
1068
1058
|
}
|
|
1069
|
-
},
|
|
1059
|
+
}, X = async (V) => {
|
|
1070
1060
|
try {
|
|
1071
|
-
await c(
|
|
1061
|
+
await c(V, {
|
|
1072
1062
|
redirectUrl: s.redirectUrl,
|
|
1073
1063
|
scopes: s.oauthScopes
|
|
1074
1064
|
});
|
|
1075
|
-
} catch (
|
|
1076
|
-
const
|
|
1077
|
-
t.value =
|
|
1065
|
+
} catch (n) {
|
|
1066
|
+
const a = n instanceof Error ? n.message : `Failed to sign in with ${V}`;
|
|
1067
|
+
t.value = a, l("error", a);
|
|
1078
1068
|
}
|
|
1079
1069
|
};
|
|
1080
|
-
return (
|
|
1081
|
-
|
|
1082
|
-
default:
|
|
1083
|
-
|
|
1084
|
-
|
|
1085
|
-
|
|
1086
|
-
|
|
1087
|
-
|
|
1088
|
-
|
|
1089
|
-
|
|
1090
|
-
|
|
1091
|
-
|
|
1092
|
-
|
|
1093
|
-
|
|
1094
|
-
|
|
1095
|
-
|
|
1096
|
-
|
|
1097
|
-
|
|
1098
|
-
|
|
1099
|
-
|
|
1100
|
-
|
|
1101
|
-
|
|
1102
|
-
|
|
1103
|
-
|
|
1104
|
-
|
|
1105
|
-
|
|
1106
|
-
|
|
1107
|
-
|
|
1108
|
-
|
|
1109
|
-
|
|
1110
|
-
|
|
1111
|
-
|
|
1112
|
-
|
|
1113
|
-
|
|
1114
|
-
|
|
1115
|
-
|
|
1116
|
-
|
|
1117
|
-
|
|
1118
|
-
|
|
1119
|
-
|
|
1120
|
-
|
|
1121
|
-
|
|
1122
|
-
|
|
1123
|
-
|
|
1124
|
-
|
|
1125
|
-
|
|
1126
|
-
e("span", Dt, L((v.displayName || v.name).charAt(0).toUpperCase()), 1)
|
|
1127
|
-
]))
|
|
1128
|
-
]),
|
|
1129
|
-
e("span", Xt, "Continue with " + L(v.displayName || v.name), 1)
|
|
1070
|
+
return (V, n) => (A(), r("div", qt, [
|
|
1071
|
+
N(b(oe), { variant: "modern" }, {
|
|
1072
|
+
default: z(() => [
|
|
1073
|
+
n[13] || (n[13] = e("div", { class: "text-center mb-8" }, [
|
|
1074
|
+
e("h1", { class: "text-3xl font-bold text-gradient mb-2" }, "Welcome back"),
|
|
1075
|
+
e("p", { class: "text-neutral-600" }, "Sign in to your account to continue")
|
|
1076
|
+
], -1)),
|
|
1077
|
+
b(i)?.length ? (A(), r("div", Ct, [
|
|
1078
|
+
(A(!0), r(le, null, ne(b(i), (a) => (A(), Y(b(G), {
|
|
1079
|
+
key: a.id,
|
|
1080
|
+
variant: "outline",
|
|
1081
|
+
"full-width": "",
|
|
1082
|
+
disabled: b(u),
|
|
1083
|
+
onClick: (S) => X(a.id),
|
|
1084
|
+
class: "btn-oauth group"
|
|
1085
|
+
}, {
|
|
1086
|
+
default: z(() => [
|
|
1087
|
+
e("div", Wt, [
|
|
1088
|
+
a.iconUrl ? (A(), r("div", Nt, [
|
|
1089
|
+
e("img", {
|
|
1090
|
+
src: a.iconUrl,
|
|
1091
|
+
alt: `${a.displayName || a.name} icon`,
|
|
1092
|
+
class: "w-5 h-5"
|
|
1093
|
+
}, null, 8, xt)
|
|
1094
|
+
])) : a.id === "google" ? (A(), r("svg", Lt, n[5] || (n[5] = [
|
|
1095
|
+
e("path", {
|
|
1096
|
+
fill: "#4285F4",
|
|
1097
|
+
d: "M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z"
|
|
1098
|
+
}, null, -1),
|
|
1099
|
+
e("path", {
|
|
1100
|
+
fill: "#34A853",
|
|
1101
|
+
d: "M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z"
|
|
1102
|
+
}, null, -1),
|
|
1103
|
+
e("path", {
|
|
1104
|
+
fill: "#FBBC05",
|
|
1105
|
+
d: "M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z"
|
|
1106
|
+
}, null, -1),
|
|
1107
|
+
e("path", {
|
|
1108
|
+
fill: "#EA4335",
|
|
1109
|
+
d: "M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z"
|
|
1110
|
+
}, null, -1)
|
|
1111
|
+
]))) : a.id === "github" ? (A(), r("svg", Ut, n[6] || (n[6] = [
|
|
1112
|
+
e("path", { d: "M12 0c-6.626 0-12 5.373-12 12 0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931 0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176 0 0 1.008-.322 3.301 1.23.957-.266 1.983-.399 3.003-.404 1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221 0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576 4.765-1.589 8.199-6.086 8.199-11.386 0-6.627-5.373-12-12-12z" }, null, -1)
|
|
1113
|
+
]))) : (A(), r("div", Mt, [
|
|
1114
|
+
e("span", zt, L((a.displayName || a.name).charAt(0).toUpperCase()), 1)
|
|
1115
|
+
]))
|
|
1130
1116
|
]),
|
|
1131
|
-
|
|
1132
|
-
|
|
1133
|
-
|
|
1134
|
-
|
|
1135
|
-
|
|
1136
|
-
|
|
1137
|
-
e("
|
|
1138
|
-
|
|
1139
|
-
|
|
1140
|
-
|
|
1141
|
-
|
|
1142
|
-
|
|
1143
|
-
|
|
1144
|
-
|
|
1145
|
-
|
|
1146
|
-
|
|
1147
|
-
|
|
1148
|
-
|
|
1149
|
-
|
|
1117
|
+
e("span", St, "Continue with " + L(a.displayName || a.name), 1)
|
|
1118
|
+
]),
|
|
1119
|
+
_: 2
|
|
1120
|
+
}, 1032, ["disabled", "onClick"]))), 128))
|
|
1121
|
+
])) : C("", !0),
|
|
1122
|
+
b(i)?.length ? (A(), r("div", Dt, n[7] || (n[7] = [
|
|
1123
|
+
e("span", { class: "divider-text" }, "Or sign in with email", -1)
|
|
1124
|
+
]))) : C("", !0),
|
|
1125
|
+
e("form", {
|
|
1126
|
+
onSubmit: Ae(w, ["prevent"]),
|
|
1127
|
+
class: "space-y-6"
|
|
1128
|
+
}, [
|
|
1129
|
+
e("div", Xt, [
|
|
1130
|
+
N(b(_), {
|
|
1131
|
+
id: "email",
|
|
1132
|
+
modelValue: m.email,
|
|
1133
|
+
"onUpdate:modelValue": n[0] || (n[0] = (a) => m.email = a),
|
|
1134
|
+
type: "email",
|
|
1135
|
+
label: "Email address",
|
|
1136
|
+
placeholder: "Enter your email address",
|
|
1137
|
+
autocomplete: "email",
|
|
1138
|
+
required: "",
|
|
1139
|
+
error: t.value ? "Invalid email or password" : void 0
|
|
1140
|
+
}, null, 8, ["modelValue", "error"]),
|
|
1141
|
+
e("div", null, [
|
|
1142
|
+
e("div", kt, [
|
|
1143
|
+
n[9] || (n[9] = e("span", { class: "text-sm font-medium text-neutral-700" }, "Password", -1)),
|
|
1144
|
+
N(b(te), {
|
|
1145
|
+
onClick: n[1] || (n[1] = (a) => V.$emit("forgot-password")),
|
|
1146
|
+
class: "text-sm"
|
|
1147
|
+
}, {
|
|
1148
|
+
default: z(() => n[8] || (n[8] = [
|
|
1149
|
+
F(" Forgot password? ", -1)
|
|
1150
|
+
])),
|
|
1151
|
+
_: 1,
|
|
1152
|
+
__: [8]
|
|
1153
|
+
})
|
|
1154
|
+
]),
|
|
1155
|
+
N(b(_), {
|
|
1156
|
+
id: "password",
|
|
1157
|
+
modelValue: m.password,
|
|
1158
|
+
"onUpdate:modelValue": n[2] || (n[2] = (a) => m.password = a),
|
|
1159
|
+
type: "password",
|
|
1160
|
+
placeholder: "Enter your password",
|
|
1161
|
+
autocomplete: "current-password",
|
|
1150
1162
|
required: "",
|
|
1151
1163
|
error: t.value ? "Invalid email or password" : void 0
|
|
1152
|
-
}, null, 8, ["modelValue", "error"])
|
|
1153
|
-
|
|
1154
|
-
|
|
1155
|
-
|
|
1156
|
-
|
|
1157
|
-
|
|
1158
|
-
|
|
1159
|
-
|
|
1160
|
-
|
|
1161
|
-
|
|
1162
|
-
|
|
1163
|
-
|
|
1164
|
-
|
|
1165
|
-
|
|
1166
|
-
|
|
1167
|
-
|
|
1168
|
-
|
|
1169
|
-
|
|
1170
|
-
|
|
1171
|
-
|
|
1172
|
-
|
|
1173
|
-
|
|
1174
|
-
|
|
1175
|
-
|
|
1176
|
-
|
|
1177
|
-
|
|
1178
|
-
|
|
1179
|
-
|
|
1180
|
-
|
|
1181
|
-
|
|
1182
|
-
|
|
1183
|
-
disabled: f.value || !p.email || !p.password,
|
|
1184
|
-
loading: f.value,
|
|
1185
|
-
"loading-text": "Signing in..."
|
|
1164
|
+
}, null, 8, ["modelValue", "error"])
|
|
1165
|
+
])
|
|
1166
|
+
]),
|
|
1167
|
+
N(b(G), {
|
|
1168
|
+
type: "submit",
|
|
1169
|
+
variant: "primary",
|
|
1170
|
+
"full-width": "",
|
|
1171
|
+
disabled: f.value || !m.email || !m.password,
|
|
1172
|
+
loading: f.value,
|
|
1173
|
+
"loading-text": "Signing in..."
|
|
1174
|
+
}, {
|
|
1175
|
+
default: z(() => n[10] || (n[10] = [
|
|
1176
|
+
F(" Sign in ", -1)
|
|
1177
|
+
])),
|
|
1178
|
+
_: 1,
|
|
1179
|
+
__: [10]
|
|
1180
|
+
}, 8, ["disabled", "loading"])
|
|
1181
|
+
], 32),
|
|
1182
|
+
t.value ? (A(), Y(b(ee), {
|
|
1183
|
+
key: 2,
|
|
1184
|
+
variant: "error",
|
|
1185
|
+
message: t.value,
|
|
1186
|
+
class: "mt-6 animate-fade-in",
|
|
1187
|
+
dismissible: "",
|
|
1188
|
+
onDismiss: n[3] || (n[3] = (a) => t.value = "")
|
|
1189
|
+
}, null, 8, ["message"])) : C("", !0),
|
|
1190
|
+
e("div", Bt, [
|
|
1191
|
+
e("p", Ft, [
|
|
1192
|
+
n[12] || (n[12] = F(" Don't have an account? ", -1)),
|
|
1193
|
+
N(b(te), {
|
|
1194
|
+
onClick: n[4] || (n[4] = (a) => V.$emit("switch-to-signup"))
|
|
1186
1195
|
}, {
|
|
1187
|
-
default:
|
|
1188
|
-
|
|
1196
|
+
default: z(() => n[11] || (n[11] = [
|
|
1197
|
+
F(" Sign up ", -1)
|
|
1189
1198
|
])),
|
|
1190
1199
|
_: 1,
|
|
1191
|
-
__: [
|
|
1192
|
-
}
|
|
1193
|
-
]
|
|
1194
|
-
|
|
1195
|
-
|
|
1196
|
-
|
|
1197
|
-
message: t.value,
|
|
1198
|
-
class: "mt-6 animate-fade-in",
|
|
1199
|
-
dismissible: "",
|
|
1200
|
-
onDismiss: l[3] || (l[3] = (v) => t.value = "")
|
|
1201
|
-
}, null, 8, ["message"])) : W("", !0),
|
|
1202
|
-
e("div", Pt, [
|
|
1203
|
-
e("p", It, [
|
|
1204
|
-
l[12] || (l[12] = j(" Don't have an account? ", -1)),
|
|
1205
|
-
x(w(Ae), {
|
|
1206
|
-
onClick: l[4] || (l[4] = (v) => h.$emit("switch-to-signup"))
|
|
1207
|
-
}, {
|
|
1208
|
-
default: D(() => l[11] || (l[11] = [
|
|
1209
|
-
j(" Sign up ", -1)
|
|
1210
|
-
])),
|
|
1211
|
-
_: 1,
|
|
1212
|
-
__: [11]
|
|
1213
|
-
})
|
|
1214
|
-
])
|
|
1215
|
-
]),
|
|
1216
|
-
x(le)
|
|
1217
|
-
];
|
|
1218
|
-
}),
|
|
1200
|
+
__: [11]
|
|
1201
|
+
})
|
|
1202
|
+
])
|
|
1203
|
+
]),
|
|
1204
|
+
N(ae)
|
|
1205
|
+
]),
|
|
1219
1206
|
_: 1,
|
|
1220
1207
|
__: [13]
|
|
1221
1208
|
})
|
|
1222
1209
|
]));
|
|
1223
1210
|
}
|
|
1224
|
-
}),
|
|
1211
|
+
}), Pt = { class: "w-full max-w-md mx-auto animate-slide-up" }, It = {
|
|
1225
1212
|
key: 0,
|
|
1226
1213
|
class: "space-y-3 mb-6"
|
|
1227
|
-
},
|
|
1214
|
+
}, jt = { class: "w-5 h-5 flex items-center justify-center" }, Zt = {
|
|
1228
1215
|
key: 0,
|
|
1229
1216
|
class: "w-5 h-5"
|
|
1230
|
-
},
|
|
1217
|
+
}, Tt = ["src", "alt"], Yt = {
|
|
1231
1218
|
key: 1,
|
|
1232
1219
|
viewBox: "0 0 24 24",
|
|
1233
1220
|
class: "w-5 h-5"
|
|
1234
|
-
},
|
|
1221
|
+
}, Kt = {
|
|
1235
1222
|
key: 2,
|
|
1236
1223
|
class: "w-5 h-5 fill-current",
|
|
1237
1224
|
viewBox: "0 0 24 24"
|
|
1238
|
-
},
|
|
1225
|
+
}, Qt = {
|
|
1239
1226
|
key: 3,
|
|
1240
1227
|
class: "w-5 h-5 rounded-full bg-neutral-300 flex items-center justify-center"
|
|
1241
|
-
},
|
|
1228
|
+
}, Ot = { class: "text-xs font-semibold text-neutral-600" }, Et = { class: "font-medium" }, Ht = {
|
|
1242
1229
|
key: 1,
|
|
1243
1230
|
class: "divider-with-text"
|
|
1244
|
-
},
|
|
1231
|
+
}, Gt = {
|
|
1245
1232
|
key: 2,
|
|
1246
1233
|
class: "mt-6 animate-fade-in"
|
|
1247
|
-
},
|
|
1234
|
+
}, Rt = { class: "alert-error" }, Jt = { class: "flex items-start gap-3" }, _t = { class: "font-medium" }, $t = { class: "mt-8 text-center" }, es = { class: "text-sm text-neutral-600" }, tA = /* @__PURE__ */ k({
|
|
1248
1235
|
__name: "StrandsSignUp",
|
|
1249
1236
|
props: {
|
|
1250
1237
|
redirectUrl: { default: "/" },
|
|
@@ -1252,634 +1239,627 @@ const lt = { class: "w-full max-w-md mx-auto animate-slide-up" }, nt = { class:
|
|
|
1252
1239
|
config: {}
|
|
1253
1240
|
},
|
|
1254
1241
|
emits: ["success", "error", "switch-to-signin"],
|
|
1255
|
-
setup(
|
|
1256
|
-
const s =
|
|
1257
|
-
enabledProviders:
|
|
1258
|
-
loading:
|
|
1259
|
-
error:
|
|
1260
|
-
fetchProviders:
|
|
1242
|
+
setup(y, { emit: p }) {
|
|
1243
|
+
const s = y, l = p, { getUrl: d } = ie(s.config), {
|
|
1244
|
+
enabledProviders: i,
|
|
1245
|
+
loading: u,
|
|
1246
|
+
error: o,
|
|
1247
|
+
fetchProviders: g,
|
|
1261
1248
|
redirectToProvider: c
|
|
1262
1249
|
} = fe({
|
|
1263
1250
|
redirectUrl: s.redirectUrl,
|
|
1264
1251
|
scopes: s.oauthScopes
|
|
1265
1252
|
});
|
|
1266
|
-
|
|
1267
|
-
|
|
1268
|
-
console.warn("Failed to fetch OAuth providers:",
|
|
1253
|
+
se(() => {
|
|
1254
|
+
g().catch((V) => {
|
|
1255
|
+
console.warn("Failed to fetch OAuth providers:", V);
|
|
1269
1256
|
});
|
|
1270
1257
|
});
|
|
1271
|
-
const f = U(!1), t = U(""),
|
|
1258
|
+
const f = U(!1), t = U(""), m = H({
|
|
1272
1259
|
email: ""
|
|
1273
1260
|
});
|
|
1274
|
-
|
|
1275
|
-
const
|
|
1261
|
+
x(() => m.email.trim() && m.email.includes("@"));
|
|
1262
|
+
const w = async () => {
|
|
1276
1263
|
f.value = !0, t.value = "";
|
|
1277
1264
|
try {
|
|
1278
|
-
console.log("Magic link sign up attempt:", { email:
|
|
1279
|
-
email:
|
|
1265
|
+
console.log("Magic link sign up attempt:", { email: m.email }), l("success", {
|
|
1266
|
+
email: m.email
|
|
1280
1267
|
});
|
|
1281
1268
|
} catch {
|
|
1282
|
-
t.value = "Failed to send magic link",
|
|
1269
|
+
t.value = "Failed to send magic link", l("error", t.value);
|
|
1283
1270
|
} finally {
|
|
1284
1271
|
f.value = !1;
|
|
1285
1272
|
}
|
|
1286
|
-
},
|
|
1273
|
+
}, X = async (V) => {
|
|
1287
1274
|
try {
|
|
1288
|
-
await c(
|
|
1275
|
+
await c(V, {
|
|
1289
1276
|
redirectUrl: s.redirectUrl,
|
|
1290
1277
|
scopes: s.oauthScopes
|
|
1291
1278
|
});
|
|
1292
|
-
} catch (
|
|
1293
|
-
const
|
|
1294
|
-
t.value =
|
|
1279
|
+
} catch (n) {
|
|
1280
|
+
const a = n instanceof Error ? n.message : `Failed to sign up with ${V}`;
|
|
1281
|
+
t.value = a, l("error", a);
|
|
1295
1282
|
}
|
|
1296
1283
|
};
|
|
1297
|
-
return (
|
|
1298
|
-
|
|
1299
|
-
default:
|
|
1300
|
-
|
|
1301
|
-
|
|
1302
|
-
|
|
1303
|
-
|
|
1304
|
-
|
|
1305
|
-
|
|
1306
|
-
|
|
1307
|
-
|
|
1308
|
-
|
|
1309
|
-
|
|
1310
|
-
|
|
1311
|
-
|
|
1312
|
-
|
|
1313
|
-
|
|
1314
|
-
|
|
1315
|
-
|
|
1316
|
-
|
|
1317
|
-
|
|
1318
|
-
|
|
1319
|
-
|
|
1320
|
-
|
|
1321
|
-
|
|
1322
|
-
|
|
1323
|
-
|
|
1324
|
-
|
|
1325
|
-
|
|
1326
|
-
|
|
1327
|
-
|
|
1328
|
-
|
|
1329
|
-
|
|
1330
|
-
|
|
1331
|
-
|
|
1332
|
-
|
|
1333
|
-
|
|
1334
|
-
|
|
1335
|
-
|
|
1336
|
-
|
|
1337
|
-
|
|
1338
|
-
|
|
1339
|
-
|
|
1340
|
-
|
|
1341
|
-
|
|
1342
|
-
|
|
1343
|
-
e("span", Ht, L((v.displayName || v.name).charAt(0).toUpperCase()), 1)
|
|
1344
|
-
]))
|
|
1345
|
-
]),
|
|
1346
|
-
e("span", Gt, "Continue with " + L(v.displayName || v.name), 1)
|
|
1284
|
+
return (V, n) => (A(), r("div", Pt, [
|
|
1285
|
+
N(b(oe), { variant: "modern" }, {
|
|
1286
|
+
default: z(() => [
|
|
1287
|
+
n[8] || (n[8] = e("div", { class: "text-center mb-8" }, [
|
|
1288
|
+
e("h1", { class: "text-3xl font-bold text-gradient mb-2" }, "Create account"),
|
|
1289
|
+
e("p", { class: "text-neutral-600" }, "We'll send you a magic link to get started")
|
|
1290
|
+
], -1)),
|
|
1291
|
+
b(i)?.length ? (A(), r("div", It, [
|
|
1292
|
+
(A(!0), r(le, null, ne(b(i), (a) => (A(), Y(b(G), {
|
|
1293
|
+
key: a.id,
|
|
1294
|
+
variant: "outline",
|
|
1295
|
+
"full-width": "",
|
|
1296
|
+
disabled: b(u),
|
|
1297
|
+
onClick: (S) => X(a.id),
|
|
1298
|
+
class: "btn-oauth group"
|
|
1299
|
+
}, {
|
|
1300
|
+
default: z(() => [
|
|
1301
|
+
e("div", jt, [
|
|
1302
|
+
a.iconUrl ? (A(), r("div", Zt, [
|
|
1303
|
+
e("img", {
|
|
1304
|
+
src: a.iconUrl,
|
|
1305
|
+
alt: `${a.displayName || a.name} icon`,
|
|
1306
|
+
class: "w-5 h-5"
|
|
1307
|
+
}, null, 8, Tt)
|
|
1308
|
+
])) : a.id === "google" ? (A(), r("svg", Yt, n[2] || (n[2] = [
|
|
1309
|
+
e("path", {
|
|
1310
|
+
fill: "#4285F4",
|
|
1311
|
+
d: "M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z"
|
|
1312
|
+
}, null, -1),
|
|
1313
|
+
e("path", {
|
|
1314
|
+
fill: "#34A853",
|
|
1315
|
+
d: "M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z"
|
|
1316
|
+
}, null, -1),
|
|
1317
|
+
e("path", {
|
|
1318
|
+
fill: "#FBBC05",
|
|
1319
|
+
d: "M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z"
|
|
1320
|
+
}, null, -1),
|
|
1321
|
+
e("path", {
|
|
1322
|
+
fill: "#EA4335",
|
|
1323
|
+
d: "M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z"
|
|
1324
|
+
}, null, -1)
|
|
1325
|
+
]))) : a.id === "github" ? (A(), r("svg", Kt, n[3] || (n[3] = [
|
|
1326
|
+
e("path", { d: "M12 0c-6.626 0-12 5.373-12 12 0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931 0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176 0 0 1.008-.322 3.301 1.23.957-.266 1.983-.399 3.003-.404 1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221 0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576 4.765-1.589 8.199-6.086 8.199-11.386 0-6.627-5.373-12-12-12z" }, null, -1)
|
|
1327
|
+
]))) : (A(), r("div", Qt, [
|
|
1328
|
+
e("span", Ot, L((a.displayName || a.name).charAt(0).toUpperCase()), 1)
|
|
1329
|
+
]))
|
|
1347
1330
|
]),
|
|
1348
|
-
|
|
1349
|
-
}, 1032, ["disabled", "onClick"]))), 128))
|
|
1350
|
-
])) : W("", !0),
|
|
1351
|
-
(X = w(o)) != null && X.length ? (A(), a("div", Rt, l[4] || (l[4] = [
|
|
1352
|
-
e("span", { class: "divider-text" }, "Or create account with email", -1)
|
|
1353
|
-
]))) : W("", !0),
|
|
1354
|
-
e("form", {
|
|
1355
|
-
onSubmit: re(m, ["prevent"]),
|
|
1356
|
-
class: "space-y-6"
|
|
1357
|
-
}, [
|
|
1358
|
-
e("div", null, [
|
|
1359
|
-
x(w(ee), {
|
|
1360
|
-
id: "email",
|
|
1361
|
-
modelValue: p.email,
|
|
1362
|
-
"onUpdate:modelValue": l[0] || (l[0] = (v) => p.email = v),
|
|
1363
|
-
type: "email",
|
|
1364
|
-
label: "Email address",
|
|
1365
|
-
placeholder: "Enter your email address",
|
|
1366
|
-
autocomplete: "email",
|
|
1367
|
-
required: "",
|
|
1368
|
-
error: t.value
|
|
1369
|
-
}, null, 8, ["modelValue", "error"])
|
|
1331
|
+
e("span", Et, "Continue with " + L(a.displayName || a.name), 1)
|
|
1370
1332
|
]),
|
|
1371
|
-
|
|
1372
|
-
|
|
1373
|
-
|
|
1374
|
-
|
|
1375
|
-
|
|
1376
|
-
|
|
1377
|
-
|
|
1378
|
-
|
|
1379
|
-
|
|
1380
|
-
|
|
1381
|
-
|
|
1382
|
-
|
|
1383
|
-
|
|
1384
|
-
|
|
1385
|
-
|
|
1386
|
-
|
|
1387
|
-
|
|
1388
|
-
|
|
1389
|
-
|
|
1390
|
-
|
|
1391
|
-
|
|
1392
|
-
|
|
1393
|
-
}, [
|
|
1394
|
-
e("path", {
|
|
1395
|
-
"fill-rule": "evenodd",
|
|
1396
|
-
d: "M10 18a8 8 0 100-16 8 8 0 000 16zM8.28 7.22a.75.75 0 00-1.06 1.06L8.94 10l-1.72 1.72a.75.75 0 101.06 1.06L10 11.06l1.72 1.72a.75.75 0 101.06-1.06L11.06 10l1.72-1.72a.75.75 0 00-1.06-1.06L10 8.94 8.28 7.22z",
|
|
1397
|
-
"clip-rule": "evenodd"
|
|
1398
|
-
})
|
|
1399
|
-
], -1)),
|
|
1400
|
-
e("p", es, L(t.value), 1)
|
|
1401
|
-
])
|
|
1402
|
-
])
|
|
1403
|
-
])) : W("", !0),
|
|
1404
|
-
e("div", ts, [
|
|
1405
|
-
e("p", ss, [
|
|
1406
|
-
l[7] || (l[7] = j(" Already have an account? ", -1)),
|
|
1407
|
-
e("button", {
|
|
1408
|
-
type: "button",
|
|
1409
|
-
class: "font-semibold text-strands-500 hover:text-strands-600 transition-colors duration-200",
|
|
1410
|
-
onClick: l[1] || (l[1] = (v) => h.$emit("switch-to-signin"))
|
|
1411
|
-
}, " Sign in ")
|
|
1412
|
-
])
|
|
1333
|
+
_: 2
|
|
1334
|
+
}, 1032, ["disabled", "onClick"]))), 128))
|
|
1335
|
+
])) : C("", !0),
|
|
1336
|
+
b(i)?.length ? (A(), r("div", Ht, n[4] || (n[4] = [
|
|
1337
|
+
e("span", { class: "divider-text" }, "Or create account with email", -1)
|
|
1338
|
+
]))) : C("", !0),
|
|
1339
|
+
e("form", {
|
|
1340
|
+
onSubmit: Ae(w, ["prevent"]),
|
|
1341
|
+
class: "space-y-6"
|
|
1342
|
+
}, [
|
|
1343
|
+
e("div", null, [
|
|
1344
|
+
N(b(_), {
|
|
1345
|
+
id: "email",
|
|
1346
|
+
modelValue: m.email,
|
|
1347
|
+
"onUpdate:modelValue": n[0] || (n[0] = (a) => m.email = a),
|
|
1348
|
+
type: "email",
|
|
1349
|
+
label: "Email address",
|
|
1350
|
+
placeholder: "Enter your email address",
|
|
1351
|
+
autocomplete: "email",
|
|
1352
|
+
required: "",
|
|
1353
|
+
error: t.value
|
|
1354
|
+
}, null, 8, ["modelValue", "error"])
|
|
1413
1355
|
]),
|
|
1414
|
-
|
|
1415
|
-
|
|
1416
|
-
|
|
1356
|
+
N(b(G), {
|
|
1357
|
+
type: "submit",
|
|
1358
|
+
variant: "primary",
|
|
1359
|
+
"full-width": "",
|
|
1360
|
+
disabled: f.value,
|
|
1361
|
+
loading: f.value,
|
|
1362
|
+
"loading-text": "Sending magic link..."
|
|
1363
|
+
}, {
|
|
1364
|
+
default: z(() => n[5] || (n[5] = [
|
|
1365
|
+
F(" Send magic link ", -1)
|
|
1366
|
+
])),
|
|
1367
|
+
_: 1,
|
|
1368
|
+
__: [5]
|
|
1369
|
+
}, 8, ["disabled", "loading"])
|
|
1370
|
+
], 32),
|
|
1371
|
+
t.value ? (A(), r("div", Gt, [
|
|
1372
|
+
e("div", Rt, [
|
|
1373
|
+
e("div", Jt, [
|
|
1374
|
+
n[6] || (n[6] = e("svg", {
|
|
1375
|
+
class: "w-4 h-4 mt-0.5 flex-shrink-0",
|
|
1376
|
+
fill: "currentColor",
|
|
1377
|
+
viewBox: "0 0 20 20"
|
|
1378
|
+
}, [
|
|
1379
|
+
e("path", {
|
|
1380
|
+
"fill-rule": "evenodd",
|
|
1381
|
+
d: "M10 18a8 8 0 100-16 8 8 0 000 16zM8.28 7.22a.75.75 0 00-1.06 1.06L8.94 10l-1.72 1.72a.75.75 0 101.06 1.06L10 11.06l1.72 1.72a.75.75 0 101.06-1.06L11.06 10l1.72-1.72a.75.75 0 00-1.06-1.06L10 8.94 8.28 7.22z",
|
|
1382
|
+
"clip-rule": "evenodd"
|
|
1383
|
+
})
|
|
1384
|
+
], -1)),
|
|
1385
|
+
e("p", _t, L(t.value), 1)
|
|
1386
|
+
])
|
|
1387
|
+
])
|
|
1388
|
+
])) : C("", !0),
|
|
1389
|
+
e("div", $t, [
|
|
1390
|
+
e("p", es, [
|
|
1391
|
+
n[7] || (n[7] = F(" Already have an account? ", -1)),
|
|
1392
|
+
e("button", {
|
|
1393
|
+
type: "button",
|
|
1394
|
+
class: "font-semibold text-strands-500 hover:text-strands-600 transition-colors duration-200",
|
|
1395
|
+
onClick: n[1] || (n[1] = (a) => V.$emit("switch-to-signin"))
|
|
1396
|
+
}, " Sign in ")
|
|
1397
|
+
])
|
|
1398
|
+
]),
|
|
1399
|
+
N(ae)
|
|
1400
|
+
]),
|
|
1417
1401
|
_: 1,
|
|
1418
1402
|
__: [8]
|
|
1419
1403
|
})
|
|
1420
1404
|
]));
|
|
1421
1405
|
}
|
|
1422
|
-
}),
|
|
1406
|
+
}), ts = { class: "w-full max-w-2xl mx-auto animate-slide-up" }, ss = { class: "card-modern" }, As = { class: "flex flex-col items-center mb-8" }, as = { class: "relative group" }, rs = { class: "w-24 h-24 rounded-full bg-gradient-to-r from-strands-400 to-strands-600 flex items-center justify-center text-white text-2xl font-bold shadow-large" }, ls = { class: "grid grid-cols-1 md:grid-cols-2 gap-6" }, ns = { class: "space-y-4" }, os = ["disabled"], is = {
|
|
1423
1407
|
key: 0,
|
|
1424
1408
|
class: "mt-1 text-sm text-red-600"
|
|
1425
|
-
},
|
|
1409
|
+
}, us = ["disabled"], ds = {
|
|
1426
1410
|
key: 0,
|
|
1427
1411
|
class: "mt-1 text-sm text-red-600"
|
|
1428
|
-
},
|
|
1412
|
+
}, cs = ["disabled"], ms = {
|
|
1429
1413
|
key: 0,
|
|
1430
1414
|
class: "mt-1 text-sm text-red-600"
|
|
1431
|
-
},
|
|
1415
|
+
}, vs = {
|
|
1432
1416
|
key: 1,
|
|
1433
1417
|
class: "mt-1 text-sm text-yellow-600"
|
|
1434
|
-
},
|
|
1418
|
+
}, fs = ["disabled"], ps = {
|
|
1435
1419
|
key: 0,
|
|
1436
1420
|
class: "mt-1 text-sm text-red-600"
|
|
1437
|
-
},
|
|
1421
|
+
}, gs = { class: "space-y-4" }, bs = { class: "space-y-4 p-4 bg-neutral-50 rounded-xl" }, ws = { class: "flex items-center justify-between" }, ys = {
|
|
1438
1422
|
key: 0,
|
|
1439
1423
|
class: "space-y-3"
|
|
1440
|
-
},
|
|
1424
|
+
}, Vs = ["disabled"], hs = { class: "p-4 bg-neutral-50 rounded-xl" }, qs = { class: "flex items-center justify-between" }, Cs = { class: "text-sm text-neutral-600" }, Ws = { class: "p-4 bg-neutral-50 rounded-xl" }, Ns = { class: "flex items-center justify-between" }, xs = { class: "text-sm text-neutral-600" }, Ls = { class: "flex flex-col sm:flex-row gap-3 pt-6 border-t border-neutral-200" }, Us = ["disabled"], Ms = {
|
|
1441
1425
|
key: 0,
|
|
1442
1426
|
class: "flex items-center justify-center gap-2"
|
|
1443
|
-
},
|
|
1427
|
+
}, zs = { key: 1 }, Ss = ["disabled"], Ds = {
|
|
1444
1428
|
key: 0,
|
|
1445
1429
|
class: "mt-6 animate-fade-in"
|
|
1446
|
-
},
|
|
1430
|
+
}, Xs = { class: "alert-success" }, ks = { class: "flex items-start gap-3" }, Bs = { class: "font-medium" }, Fs = {
|
|
1447
1431
|
key: 1,
|
|
1448
1432
|
class: "mt-6 animate-fade-in"
|
|
1449
|
-
},
|
|
1433
|
+
}, Ps = { class: "alert-error" }, Is = { class: "flex items-start gap-3" }, js = { class: "font-medium" }, sA = /* @__PURE__ */ k({
|
|
1450
1434
|
__name: "StrandsUserProfile",
|
|
1451
1435
|
props: {
|
|
1452
1436
|
user: {}
|
|
1453
1437
|
},
|
|
1454
1438
|
emits: ["profile-updated", "error", "manage-sessions", "mfa-toggle"],
|
|
1455
|
-
setup(
|
|
1456
|
-
const s =
|
|
1439
|
+
setup(y, { emit: p }) {
|
|
1440
|
+
const s = y, l = p, d = U(!1), i = U(!1), u = U(""), o = U(""), g = U([
|
|
1457
1441
|
{ id: "1", device: "Chrome on Mac", location: "San Francisco, CA", lastActive: "2 minutes ago", current: !0 },
|
|
1458
1442
|
{ id: "2", device: "Safari on iPhone", location: "San Francisco, CA", lastActive: "1 hour ago", current: !1 }
|
|
1459
|
-
]), c =
|
|
1443
|
+
]), c = H({
|
|
1460
1444
|
firstName: "",
|
|
1461
1445
|
lastName: "",
|
|
1462
1446
|
email: "",
|
|
1463
1447
|
phone: ""
|
|
1464
|
-
}), f =
|
|
1448
|
+
}), f = H({
|
|
1465
1449
|
current: "",
|
|
1466
1450
|
new: "",
|
|
1467
1451
|
confirm: ""
|
|
1468
|
-
}), t =
|
|
1452
|
+
}), t = H({
|
|
1469
1453
|
firstName: "",
|
|
1470
1454
|
lastName: "",
|
|
1471
1455
|
email: "",
|
|
1472
1456
|
phone: ""
|
|
1473
|
-
}),
|
|
1474
|
-
|
|
1475
|
-
|
|
1457
|
+
}), m = x(() => s.user ? c.firstName !== s.user.firstName || c.lastName !== s.user.lastName || c.email !== s.user.email || c.phone !== (s.user.phone || "") : !1), w = x(() => f.current && f.new && f.confirm && f.new === f.confirm && f.new.length >= 8), X = (M, v) => !M && !v ? "U" : `${M?.[0] || ""}${v?.[0] || ""}`.toUpperCase();
|
|
1458
|
+
re(() => s.user, (M) => {
|
|
1459
|
+
M && (c.firstName = M.firstName, c.lastName = M.lastName, c.email = M.email, c.phone = M.phone || "");
|
|
1476
1460
|
}, { immediate: !0 });
|
|
1477
|
-
const
|
|
1478
|
-
|
|
1479
|
-
t[
|
|
1461
|
+
const V = () => {
|
|
1462
|
+
u.value = "", o.value = "", Object.keys(t).forEach((M) => {
|
|
1463
|
+
t[M] = "";
|
|
1480
1464
|
});
|
|
1481
|
-
},
|
|
1482
|
-
|
|
1465
|
+
}, n = async () => {
|
|
1466
|
+
V(), d.value = !0;
|
|
1483
1467
|
try {
|
|
1484
|
-
console.log("Profile update:", c), await new Promise((
|
|
1485
|
-
const
|
|
1468
|
+
console.log("Profile update:", c), await new Promise((v) => setTimeout(v, 1e3));
|
|
1469
|
+
const M = {
|
|
1486
1470
|
...s.user,
|
|
1487
1471
|
...c
|
|
1488
1472
|
};
|
|
1489
|
-
|
|
1473
|
+
u.value = "Profile updated successfully", l("profile-updated", M);
|
|
1490
1474
|
} catch {
|
|
1491
|
-
|
|
1475
|
+
o.value = "Failed to update profile", l("error", o.value);
|
|
1492
1476
|
} finally {
|
|
1493
|
-
|
|
1477
|
+
d.value = !1;
|
|
1494
1478
|
}
|
|
1495
|
-
},
|
|
1496
|
-
if (
|
|
1497
|
-
|
|
1479
|
+
}, a = async () => {
|
|
1480
|
+
if (w.value) {
|
|
1481
|
+
V(), d.value = !0;
|
|
1498
1482
|
try {
|
|
1499
|
-
console.log("Password change:", { current: "***", new: "***" }), await new Promise((
|
|
1483
|
+
console.log("Password change:", { current: "***", new: "***" }), await new Promise((M) => setTimeout(M, 1e3)), u.value = "Password updated successfully", i.value = !1, f.current = "", f.new = "", f.confirm = "";
|
|
1500
1484
|
} catch {
|
|
1501
|
-
|
|
1485
|
+
o.value = "Failed to update password";
|
|
1502
1486
|
} finally {
|
|
1503
|
-
|
|
1487
|
+
d.value = !1;
|
|
1504
1488
|
}
|
|
1505
1489
|
}
|
|
1506
|
-
},
|
|
1490
|
+
}, S = () => {
|
|
1507
1491
|
console.log("Image upload clicked");
|
|
1508
|
-
},
|
|
1509
|
-
|
|
1510
|
-
|
|
1511
|
-
|
|
1512
|
-
s.user && (c.firstName = s.user.firstName, c.lastName = s.user.lastName, c.email = s.user.email, c.phone = s.user.phone || ""), h(), o.value = !1, f.current = "", f.new = "", f.confirm = "";
|
|
1492
|
+
}, D = () => {
|
|
1493
|
+
l("mfa-toggle", !s.user?.mfaEnabled);
|
|
1494
|
+
}, Z = () => {
|
|
1495
|
+
s.user && (c.firstName = s.user.firstName, c.lastName = s.user.lastName, c.email = s.user.email, c.phone = s.user.phone || ""), V(), i.value = !1, f.current = "", f.new = "", f.confirm = "";
|
|
1513
1496
|
};
|
|
1514
|
-
return (
|
|
1515
|
-
|
|
1516
|
-
|
|
1517
|
-
|
|
1518
|
-
|
|
1519
|
-
|
|
1520
|
-
|
|
1521
|
-
|
|
1522
|
-
|
|
1523
|
-
e("div", ls, [
|
|
1524
|
-
e("div", ns, L(z((S = q.user) == null ? void 0 : S.firstName, (C = q.user) == null ? void 0 : C.lastName)), 1),
|
|
1525
|
-
e("button", {
|
|
1526
|
-
class: "absolute inset-0 rounded-full bg-black/40 flex items-center justify-center opacity-0 group-hover:opacity-100 transition-opacity duration-200",
|
|
1527
|
-
onClick: X
|
|
1528
|
-
}, d[9] || (d[9] = [
|
|
1529
|
-
e("svg", {
|
|
1530
|
-
class: "w-6 h-6 text-white",
|
|
1531
|
-
fill: "none",
|
|
1532
|
-
stroke: "currentColor",
|
|
1533
|
-
viewBox: "0 0 24 24"
|
|
1534
|
-
}, [
|
|
1535
|
-
e("path", {
|
|
1536
|
-
"stroke-linecap": "round",
|
|
1537
|
-
"stroke-linejoin": "round",
|
|
1538
|
-
"stroke-width": "2",
|
|
1539
|
-
d: "M3 9a2 2 0 012-2h.93a2 2 0 001.664-.89l.812-1.22A2 2 0 0110.07 4h3.86a2 2 0 011.664.89l.812 1.22A2 2 0 0018.07 7H19a2 2 0 012 2v9a2 2 0 01-2 2H5a2 2 0 01-2-2V9z"
|
|
1540
|
-
}),
|
|
1541
|
-
e("path", {
|
|
1542
|
-
"stroke-linecap": "round",
|
|
1543
|
-
"stroke-linejoin": "round",
|
|
1544
|
-
"stroke-width": "2",
|
|
1545
|
-
d: "M15 13a3 3 0 11-6 0 3 3 0 016 0z"
|
|
1546
|
-
})
|
|
1547
|
-
], -1)
|
|
1548
|
-
]))
|
|
1549
|
-
]),
|
|
1497
|
+
return (M, v) => (A(), r("div", ts, [
|
|
1498
|
+
e("div", ss, [
|
|
1499
|
+
v[22] || (v[22] = e("div", { class: "text-center mb-8" }, [
|
|
1500
|
+
e("h1", { class: "text-3xl font-bold text-gradient mb-2" }, "Profile Settings"),
|
|
1501
|
+
e("p", { class: "text-neutral-600" }, "Manage your account information and preferences")
|
|
1502
|
+
], -1)),
|
|
1503
|
+
e("div", As, [
|
|
1504
|
+
e("div", as, [
|
|
1505
|
+
e("div", rs, L(X(M.user?.firstName, M.user?.lastName)), 1),
|
|
1550
1506
|
e("button", {
|
|
1551
|
-
class: "
|
|
1552
|
-
onClick:
|
|
1553
|
-
},
|
|
1507
|
+
class: "absolute inset-0 rounded-full bg-black/40 flex items-center justify-center opacity-0 group-hover:opacity-100 transition-opacity duration-200",
|
|
1508
|
+
onClick: S
|
|
1509
|
+
}, v[9] || (v[9] = [
|
|
1510
|
+
e("svg", {
|
|
1511
|
+
class: "w-6 h-6 text-white",
|
|
1512
|
+
fill: "none",
|
|
1513
|
+
stroke: "currentColor",
|
|
1514
|
+
viewBox: "0 0 24 24"
|
|
1515
|
+
}, [
|
|
1516
|
+
e("path", {
|
|
1517
|
+
"stroke-linecap": "round",
|
|
1518
|
+
"stroke-linejoin": "round",
|
|
1519
|
+
"stroke-width": "2",
|
|
1520
|
+
d: "M3 9a2 2 0 012-2h.93a2 2 0 001.664-.89l.812-1.22A2 2 0 0110.07 4h3.86a2 2 0 011.664.89l.812 1.22A2 2 0 0018.07 7H19a2 2 0 012 2v9a2 2 0 01-2 2H5a2 2 0 01-2-2V9z"
|
|
1521
|
+
}),
|
|
1522
|
+
e("path", {
|
|
1523
|
+
"stroke-linecap": "round",
|
|
1524
|
+
"stroke-linejoin": "round",
|
|
1525
|
+
"stroke-width": "2",
|
|
1526
|
+
d: "M15 13a3 3 0 11-6 0 3 3 0 016 0z"
|
|
1527
|
+
})
|
|
1528
|
+
], -1)
|
|
1529
|
+
]))
|
|
1554
1530
|
]),
|
|
1555
|
-
e("
|
|
1556
|
-
|
|
1557
|
-
|
|
1558
|
-
},
|
|
1559
|
-
|
|
1560
|
-
|
|
1561
|
-
|
|
1562
|
-
|
|
1563
|
-
|
|
1564
|
-
|
|
1565
|
-
|
|
1566
|
-
|
|
1567
|
-
|
|
1568
|
-
|
|
1569
|
-
|
|
1570
|
-
|
|
1571
|
-
|
|
1572
|
-
|
|
1573
|
-
|
|
1574
|
-
|
|
1575
|
-
|
|
1576
|
-
|
|
1577
|
-
|
|
1578
|
-
|
|
1579
|
-
|
|
1580
|
-
|
|
1531
|
+
e("button", {
|
|
1532
|
+
class: "mt-3 text-sm text-strands-600 hover:text-strands-700 font-medium transition-colors duration-200",
|
|
1533
|
+
onClick: S
|
|
1534
|
+
}, " Change photo ")
|
|
1535
|
+
]),
|
|
1536
|
+
e("form", {
|
|
1537
|
+
onSubmit: Ae(n, ["prevent"]),
|
|
1538
|
+
class: "space-y-6"
|
|
1539
|
+
}, [
|
|
1540
|
+
e("div", ls, [
|
|
1541
|
+
e("div", ns, [
|
|
1542
|
+
v[14] || (v[14] = e("h3", { class: "text-lg font-semibold text-neutral-900 mb-4" }, "Personal Information", -1)),
|
|
1543
|
+
e("div", null, [
|
|
1544
|
+
v[10] || (v[10] = e("label", {
|
|
1545
|
+
for: "firstName",
|
|
1546
|
+
class: "label-modern"
|
|
1547
|
+
}, "First name", -1)),
|
|
1548
|
+
O(e("input", {
|
|
1549
|
+
id: "firstName",
|
|
1550
|
+
"onUpdate:modelValue": v[0] || (v[0] = (h) => c.firstName = h),
|
|
1551
|
+
type: "text",
|
|
1552
|
+
required: "",
|
|
1553
|
+
autocomplete: "given-name",
|
|
1554
|
+
class: B([
|
|
1555
|
+
"input-modern",
|
|
1556
|
+
t.firstName && "input-error"
|
|
1581
1557
|
]),
|
|
1582
|
-
|
|
1558
|
+
placeholder: "Enter your first name",
|
|
1559
|
+
disabled: d.value
|
|
1560
|
+
}, null, 10, os), [
|
|
1561
|
+
[E, c.firstName]
|
|
1583
1562
|
]),
|
|
1584
|
-
|
|
1585
|
-
|
|
1586
|
-
|
|
1587
|
-
|
|
1588
|
-
|
|
1589
|
-
|
|
1590
|
-
|
|
1591
|
-
|
|
1592
|
-
|
|
1593
|
-
|
|
1594
|
-
|
|
1595
|
-
|
|
1596
|
-
|
|
1597
|
-
|
|
1598
|
-
|
|
1599
|
-
|
|
1600
|
-
disabled: u.value
|
|
1601
|
-
}, null, 10, cs), [
|
|
1602
|
-
[R, c.lastName]
|
|
1563
|
+
t.firstName ? (A(), r("p", is, L(t.firstName), 1)) : C("", !0)
|
|
1564
|
+
]),
|
|
1565
|
+
e("div", null, [
|
|
1566
|
+
v[11] || (v[11] = e("label", {
|
|
1567
|
+
for: "lastName",
|
|
1568
|
+
class: "label-modern"
|
|
1569
|
+
}, "Last name", -1)),
|
|
1570
|
+
O(e("input", {
|
|
1571
|
+
id: "lastName",
|
|
1572
|
+
"onUpdate:modelValue": v[1] || (v[1] = (h) => c.lastName = h),
|
|
1573
|
+
type: "text",
|
|
1574
|
+
required: "",
|
|
1575
|
+
autocomplete: "family-name",
|
|
1576
|
+
class: B([
|
|
1577
|
+
"input-modern",
|
|
1578
|
+
t.lastName && "input-error"
|
|
1603
1579
|
]),
|
|
1604
|
-
|
|
1580
|
+
placeholder: "Enter your last name",
|
|
1581
|
+
disabled: d.value
|
|
1582
|
+
}, null, 10, us), [
|
|
1583
|
+
[E, c.lastName]
|
|
1605
1584
|
]),
|
|
1606
|
-
|
|
1607
|
-
|
|
1608
|
-
|
|
1609
|
-
|
|
1610
|
-
|
|
1611
|
-
|
|
1612
|
-
|
|
1613
|
-
|
|
1614
|
-
|
|
1615
|
-
|
|
1616
|
-
|
|
1617
|
-
|
|
1618
|
-
|
|
1619
|
-
|
|
1620
|
-
|
|
1621
|
-
|
|
1622
|
-
disabled: u.value
|
|
1623
|
-
}, null, 10, vs), [
|
|
1624
|
-
[R, c.email]
|
|
1585
|
+
t.lastName ? (A(), r("p", ds, L(t.lastName), 1)) : C("", !0)
|
|
1586
|
+
]),
|
|
1587
|
+
e("div", null, [
|
|
1588
|
+
v[12] || (v[12] = e("label", {
|
|
1589
|
+
for: "email",
|
|
1590
|
+
class: "label-modern"
|
|
1591
|
+
}, "Email address", -1)),
|
|
1592
|
+
O(e("input", {
|
|
1593
|
+
id: "email",
|
|
1594
|
+
"onUpdate:modelValue": v[2] || (v[2] = (h) => c.email = h),
|
|
1595
|
+
type: "email",
|
|
1596
|
+
required: "",
|
|
1597
|
+
autocomplete: "email",
|
|
1598
|
+
class: B([
|
|
1599
|
+
"input-modern",
|
|
1600
|
+
t.email && "input-error"
|
|
1625
1601
|
]),
|
|
1626
|
-
|
|
1627
|
-
|
|
1602
|
+
placeholder: "Enter your email address",
|
|
1603
|
+
disabled: d.value
|
|
1604
|
+
}, null, 10, cs), [
|
|
1605
|
+
[E, c.email]
|
|
1628
1606
|
]),
|
|
1629
|
-
|
|
1630
|
-
|
|
1631
|
-
for: "phone",
|
|
1632
|
-
class: "label-modern"
|
|
1633
|
-
}, "Phone number", -1)),
|
|
1634
|
-
G(e("input", {
|
|
1635
|
-
id: "phone",
|
|
1636
|
-
"onUpdate:modelValue": d[3] || (d[3] = (B) => c.phone = B),
|
|
1637
|
-
type: "tel",
|
|
1638
|
-
autocomplete: "tel",
|
|
1639
|
-
class: I([
|
|
1640
|
-
"input-modern",
|
|
1641
|
-
t.phone && "input-error"
|
|
1642
|
-
]),
|
|
1643
|
-
placeholder: "Enter your phone number",
|
|
1644
|
-
disabled: u.value
|
|
1645
|
-
}, null, 10, gs), [
|
|
1646
|
-
[R, c.phone]
|
|
1647
|
-
]),
|
|
1648
|
-
t.phone ? (A(), a("p", bs, L(t.phone), 1)) : W("", !0)
|
|
1649
|
-
])
|
|
1607
|
+
t.email ? (A(), r("p", ms, L(t.email), 1)) : C("", !0),
|
|
1608
|
+
c.email !== M.user?.email ? (A(), r("p", vs, " Changing your email will require verification ")) : C("", !0)
|
|
1650
1609
|
]),
|
|
1651
|
-
e("div",
|
|
1652
|
-
|
|
1653
|
-
|
|
1654
|
-
|
|
1655
|
-
|
|
1656
|
-
|
|
1657
|
-
|
|
1658
|
-
|
|
1659
|
-
|
|
1660
|
-
|
|
1661
|
-
|
|
1662
|
-
|
|
1663
|
-
|
|
1610
|
+
e("div", null, [
|
|
1611
|
+
v[13] || (v[13] = e("label", {
|
|
1612
|
+
for: "phone",
|
|
1613
|
+
class: "label-modern"
|
|
1614
|
+
}, "Phone number", -1)),
|
|
1615
|
+
O(e("input", {
|
|
1616
|
+
id: "phone",
|
|
1617
|
+
"onUpdate:modelValue": v[3] || (v[3] = (h) => c.phone = h),
|
|
1618
|
+
type: "tel",
|
|
1619
|
+
autocomplete: "tel",
|
|
1620
|
+
class: B([
|
|
1621
|
+
"input-modern",
|
|
1622
|
+
t.phone && "input-error"
|
|
1664
1623
|
]),
|
|
1665
|
-
|
|
1666
|
-
|
|
1667
|
-
|
|
1668
|
-
|
|
1669
|
-
placeholder: "Current password",
|
|
1670
|
-
class: "input-modern",
|
|
1671
|
-
autocomplete: "current-password"
|
|
1672
|
-
}, null, 512), [
|
|
1673
|
-
[R, f.current]
|
|
1674
|
-
]),
|
|
1675
|
-
G(e("input", {
|
|
1676
|
-
"onUpdate:modelValue": d[6] || (d[6] = (B) => f.new = B),
|
|
1677
|
-
type: "password",
|
|
1678
|
-
placeholder: "New password",
|
|
1679
|
-
class: "input-modern",
|
|
1680
|
-
autocomplete: "new-password"
|
|
1681
|
-
}, null, 512), [
|
|
1682
|
-
[R, f.new]
|
|
1683
|
-
]),
|
|
1684
|
-
G(e("input", {
|
|
1685
|
-
"onUpdate:modelValue": d[7] || (d[7] = (B) => f.confirm = B),
|
|
1686
|
-
type: "password",
|
|
1687
|
-
placeholder: "Confirm new password",
|
|
1688
|
-
class: "input-modern",
|
|
1689
|
-
autocomplete: "new-password"
|
|
1690
|
-
}, null, 512), [
|
|
1691
|
-
[R, f.confirm]
|
|
1692
|
-
]),
|
|
1693
|
-
e("button", {
|
|
1694
|
-
type: "button",
|
|
1695
|
-
class: "btn-primary !w-auto px-4 py-2 text-sm",
|
|
1696
|
-
onClick: y,
|
|
1697
|
-
disabled: !m.value
|
|
1698
|
-
}, " Update Password ", 8, qs)
|
|
1699
|
-
])) : W("", !0)
|
|
1624
|
+
placeholder: "Enter your phone number",
|
|
1625
|
+
disabled: d.value
|
|
1626
|
+
}, null, 10, fs), [
|
|
1627
|
+
[E, c.phone]
|
|
1700
1628
|
]),
|
|
1701
|
-
|
|
1702
|
-
|
|
1703
|
-
|
|
1704
|
-
|
|
1705
|
-
|
|
1706
|
-
|
|
1707
|
-
|
|
1708
|
-
|
|
1709
|
-
|
|
1710
|
-
|
|
1711
|
-
|
|
1712
|
-
|
|
1713
|
-
|
|
1714
|
-
|
|
1715
|
-
|
|
1629
|
+
t.phone ? (A(), r("p", ps, L(t.phone), 1)) : C("", !0)
|
|
1630
|
+
])
|
|
1631
|
+
]),
|
|
1632
|
+
e("div", gs, [
|
|
1633
|
+
v[18] || (v[18] = e("h3", { class: "text-lg font-semibold text-neutral-900 mb-4" }, "Security Settings", -1)),
|
|
1634
|
+
e("div", bs, [
|
|
1635
|
+
e("div", ws, [
|
|
1636
|
+
v[15] || (v[15] = e("div", null, [
|
|
1637
|
+
e("h4", { class: "font-medium text-neutral-900" }, "Password"),
|
|
1638
|
+
e("p", { class: "text-sm text-neutral-600" }, "Last updated 30 days ago")
|
|
1639
|
+
], -1)),
|
|
1640
|
+
e("button", {
|
|
1641
|
+
type: "button",
|
|
1642
|
+
class: "btn-secondary !w-auto px-4 py-2 text-sm",
|
|
1643
|
+
onClick: v[4] || (v[4] = (h) => i.value = !i.value)
|
|
1644
|
+
}, L(i.value ? "Cancel" : "Change"), 1)
|
|
1716
1645
|
]),
|
|
1717
|
-
|
|
1718
|
-
e("
|
|
1719
|
-
|
|
1720
|
-
|
|
1721
|
-
|
|
1646
|
+
i.value ? (A(), r("div", ys, [
|
|
1647
|
+
O(e("input", {
|
|
1648
|
+
"onUpdate:modelValue": v[5] || (v[5] = (h) => f.current = h),
|
|
1649
|
+
type: "password",
|
|
1650
|
+
placeholder: "Current password",
|
|
1651
|
+
class: "input-modern",
|
|
1652
|
+
autocomplete: "current-password"
|
|
1653
|
+
}, null, 512), [
|
|
1654
|
+
[E, f.current]
|
|
1655
|
+
]),
|
|
1656
|
+
O(e("input", {
|
|
1657
|
+
"onUpdate:modelValue": v[6] || (v[6] = (h) => f.new = h),
|
|
1658
|
+
type: "password",
|
|
1659
|
+
placeholder: "New password",
|
|
1660
|
+
class: "input-modern",
|
|
1661
|
+
autocomplete: "new-password"
|
|
1662
|
+
}, null, 512), [
|
|
1663
|
+
[E, f.new]
|
|
1664
|
+
]),
|
|
1665
|
+
O(e("input", {
|
|
1666
|
+
"onUpdate:modelValue": v[7] || (v[7] = (h) => f.confirm = h),
|
|
1667
|
+
type: "password",
|
|
1668
|
+
placeholder: "Confirm new password",
|
|
1669
|
+
class: "input-modern",
|
|
1670
|
+
autocomplete: "new-password"
|
|
1671
|
+
}, null, 512), [
|
|
1672
|
+
[E, f.confirm]
|
|
1673
|
+
]),
|
|
1674
|
+
e("button", {
|
|
1675
|
+
type: "button",
|
|
1676
|
+
class: "btn-primary !w-auto px-4 py-2 text-sm",
|
|
1677
|
+
onClick: a,
|
|
1678
|
+
disabled: !w.value
|
|
1679
|
+
}, " Update Password ", 8, Vs)
|
|
1680
|
+
])) : C("", !0)
|
|
1681
|
+
]),
|
|
1682
|
+
e("div", hs, [
|
|
1683
|
+
e("div", qs, [
|
|
1684
|
+
e("div", null, [
|
|
1685
|
+
v[16] || (v[16] = e("h4", { class: "font-medium text-neutral-900" }, "Two-Factor Authentication", -1)),
|
|
1686
|
+
e("p", Cs, L(M.user?.mfaEnabled ? "Enabled" : "Add extra security to your account"), 1)
|
|
1687
|
+
]),
|
|
1688
|
+
e("button", {
|
|
1689
|
+
type: "button",
|
|
1690
|
+
class: B([
|
|
1691
|
+
M.user?.mfaEnabled ? "btn-secondary" : "btn-primary",
|
|
1692
|
+
"!w-auto px-4 py-2 text-sm"
|
|
1722
1693
|
]),
|
|
1723
|
-
|
|
1724
|
-
|
|
1725
|
-
|
|
1726
|
-
|
|
1727
|
-
|
|
1728
|
-
|
|
1694
|
+
onClick: D
|
|
1695
|
+
}, L(M.user?.mfaEnabled ? "Disable" : "Enable"), 3)
|
|
1696
|
+
])
|
|
1697
|
+
]),
|
|
1698
|
+
e("div", Ws, [
|
|
1699
|
+
e("div", Ns, [
|
|
1700
|
+
e("div", null, [
|
|
1701
|
+
v[17] || (v[17] = e("h4", { class: "font-medium text-neutral-900" }, "Active Sessions", -1)),
|
|
1702
|
+
e("p", xs, L(g.value.length) + " active device(s)", 1)
|
|
1703
|
+
]),
|
|
1704
|
+
e("button", {
|
|
1705
|
+
type: "button",
|
|
1706
|
+
class: "btn-secondary !w-auto px-4 py-2 text-sm",
|
|
1707
|
+
onClick: v[8] || (v[8] = (h) => M.$emit("manage-sessions"))
|
|
1708
|
+
}, " Manage ")
|
|
1729
1709
|
])
|
|
1730
1710
|
])
|
|
1731
|
-
]),
|
|
1732
|
-
e("div", Ms, [
|
|
1733
|
-
e("button", {
|
|
1734
|
-
type: "submit",
|
|
1735
|
-
disabled: u.value || !p.value,
|
|
1736
|
-
class: "btn-primary"
|
|
1737
|
-
}, [
|
|
1738
|
-
u.value ? (A(), a("span", Ss, d[19] || (d[19] = [
|
|
1739
|
-
e("svg", {
|
|
1740
|
-
class: "animate-spin w-4 h-4",
|
|
1741
|
-
fill: "none",
|
|
1742
|
-
viewBox: "0 0 24 24"
|
|
1743
|
-
}, [
|
|
1744
|
-
e("circle", {
|
|
1745
|
-
class: "opacity-25",
|
|
1746
|
-
cx: "12",
|
|
1747
|
-
cy: "12",
|
|
1748
|
-
r: "10",
|
|
1749
|
-
stroke: "currentColor",
|
|
1750
|
-
"stroke-width": "4"
|
|
1751
|
-
}),
|
|
1752
|
-
e("path", {
|
|
1753
|
-
class: "opacity-75",
|
|
1754
|
-
fill: "currentColor",
|
|
1755
|
-
d: "m4 12a8 8 0 0 1 8-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 0 1 4 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
|
|
1756
|
-
})
|
|
1757
|
-
], -1),
|
|
1758
|
-
j(" Saving changes... ", -1)
|
|
1759
|
-
]))) : (A(), a("span", Ds, "Save changes"))
|
|
1760
|
-
], 8, zs),
|
|
1761
|
-
e("button", {
|
|
1762
|
-
type: "button",
|
|
1763
|
-
class: "btn-secondary",
|
|
1764
|
-
onClick: F,
|
|
1765
|
-
disabled: u.value
|
|
1766
|
-
}, " Cancel ", 8, Xs)
|
|
1767
1711
|
])
|
|
1768
|
-
]
|
|
1769
|
-
|
|
1770
|
-
e("
|
|
1771
|
-
|
|
1772
|
-
|
|
1773
|
-
|
|
1774
|
-
|
|
1775
|
-
|
|
1712
|
+
]),
|
|
1713
|
+
e("div", Ls, [
|
|
1714
|
+
e("button", {
|
|
1715
|
+
type: "submit",
|
|
1716
|
+
disabled: d.value || !m.value,
|
|
1717
|
+
class: "btn-primary"
|
|
1718
|
+
}, [
|
|
1719
|
+
d.value ? (A(), r("span", Ms, v[19] || (v[19] = [
|
|
1720
|
+
e("svg", {
|
|
1721
|
+
class: "animate-spin w-4 h-4",
|
|
1722
|
+
fill: "none",
|
|
1723
|
+
viewBox: "0 0 24 24"
|
|
1776
1724
|
}, [
|
|
1725
|
+
e("circle", {
|
|
1726
|
+
class: "opacity-25",
|
|
1727
|
+
cx: "12",
|
|
1728
|
+
cy: "12",
|
|
1729
|
+
r: "10",
|
|
1730
|
+
stroke: "currentColor",
|
|
1731
|
+
"stroke-width": "4"
|
|
1732
|
+
}),
|
|
1777
1733
|
e("path", {
|
|
1778
|
-
|
|
1779
|
-
|
|
1780
|
-
"
|
|
1734
|
+
class: "opacity-75",
|
|
1735
|
+
fill: "currentColor",
|
|
1736
|
+
d: "m4 12a8 8 0 0 1 8-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 0 1 4 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
|
|
1781
1737
|
})
|
|
1782
|
-
], -1)
|
|
1783
|
-
|
|
1784
|
-
])
|
|
1738
|
+
], -1),
|
|
1739
|
+
F(" Saving changes... ", -1)
|
|
1740
|
+
]))) : (A(), r("span", zs, "Save changes"))
|
|
1741
|
+
], 8, Us),
|
|
1742
|
+
e("button", {
|
|
1743
|
+
type: "button",
|
|
1744
|
+
class: "btn-secondary",
|
|
1745
|
+
onClick: Z,
|
|
1746
|
+
disabled: d.value
|
|
1747
|
+
}, " Cancel ", 8, Ss)
|
|
1748
|
+
])
|
|
1749
|
+
], 32),
|
|
1750
|
+
u.value ? (A(), r("div", Ds, [
|
|
1751
|
+
e("div", Xs, [
|
|
1752
|
+
e("div", ks, [
|
|
1753
|
+
v[20] || (v[20] = e("svg", {
|
|
1754
|
+
class: "w-4 h-4 mt-0.5 flex-shrink-0",
|
|
1755
|
+
fill: "currentColor",
|
|
1756
|
+
viewBox: "0 0 20 20"
|
|
1757
|
+
}, [
|
|
1758
|
+
e("path", {
|
|
1759
|
+
"fill-rule": "evenodd",
|
|
1760
|
+
d: "M10 18a8 8 0 100-16 8 8 0 000 16zm3.857-9.809a.75.75 0 00-1.214-.882l-3.236 4.53L7.53 10.173a.75.75 0 00-1.06 1.061l2.5 2.5a.75.75 0 001.137-.089l4-5.5z",
|
|
1761
|
+
"clip-rule": "evenodd"
|
|
1762
|
+
})
|
|
1763
|
+
], -1)),
|
|
1764
|
+
e("p", Bs, L(u.value), 1)
|
|
1785
1765
|
])
|
|
1786
|
-
])
|
|
1787
|
-
|
|
1788
|
-
|
|
1789
|
-
|
|
1790
|
-
|
|
1791
|
-
|
|
1792
|
-
|
|
1793
|
-
|
|
1794
|
-
|
|
1795
|
-
|
|
1796
|
-
|
|
1797
|
-
|
|
1798
|
-
|
|
1799
|
-
|
|
1800
|
-
|
|
1801
|
-
|
|
1802
|
-
|
|
1766
|
+
])
|
|
1767
|
+
])) : C("", !0),
|
|
1768
|
+
o.value ? (A(), r("div", Fs, [
|
|
1769
|
+
e("div", Ps, [
|
|
1770
|
+
e("div", Is, [
|
|
1771
|
+
v[21] || (v[21] = e("svg", {
|
|
1772
|
+
class: "w-4 h-4 mt-0.5 flex-shrink-0",
|
|
1773
|
+
fill: "currentColor",
|
|
1774
|
+
viewBox: "0 0 20 20"
|
|
1775
|
+
}, [
|
|
1776
|
+
e("path", {
|
|
1777
|
+
"fill-rule": "evenodd",
|
|
1778
|
+
d: "M10 18a8 8 0 100-16 8 8 0 000 16zM8.28 7.22a.75.75 0 00-1.06 1.06L8.94 10l-1.72 1.72a.75.75 0 101.06 1.06L10 11.06l1.72 1.72a.75.75 0 101.06-1.06L11.06 10l1.72-1.72a.75.75 0 00-1.06-1.06L10 8.94 8.28 7.22z",
|
|
1779
|
+
"clip-rule": "evenodd"
|
|
1780
|
+
})
|
|
1781
|
+
], -1)),
|
|
1782
|
+
e("p", js, L(o.value), 1)
|
|
1803
1783
|
])
|
|
1804
|
-
])
|
|
1805
|
-
|
|
1806
|
-
|
|
1807
|
-
])
|
|
1808
|
-
|
|
1784
|
+
])
|
|
1785
|
+
])) : C("", !0),
|
|
1786
|
+
N(ae)
|
|
1787
|
+
])
|
|
1788
|
+
]));
|
|
1809
1789
|
}
|
|
1810
|
-
}),
|
|
1790
|
+
}), Zs = { class: "w-full max-w-md mx-auto animate-slide-up" }, Ts = { class: "mt-8 text-center" }, AA = /* @__PURE__ */ k({
|
|
1811
1791
|
__name: "StrandsPasswordReset",
|
|
1812
1792
|
emits: ["success", "error", "back-to-signin"],
|
|
1813
|
-
setup(
|
|
1814
|
-
const s =
|
|
1793
|
+
setup(y, { emit: p }) {
|
|
1794
|
+
const s = p, l = U(!1), d = U(""), i = U(!1), u = H({
|
|
1815
1795
|
email: ""
|
|
1816
|
-
}),
|
|
1817
|
-
|
|
1796
|
+
}), o = async () => {
|
|
1797
|
+
l.value = !0, d.value = "";
|
|
1818
1798
|
try {
|
|
1819
|
-
console.log("Password reset request:", { email:
|
|
1799
|
+
console.log("Password reset request:", { email: u.email }), await new Promise((g) => setTimeout(g, 1e3)), i.value = !0, s("success", u.email);
|
|
1820
1800
|
} catch {
|
|
1821
|
-
|
|
1801
|
+
d.value = "Failed to send password reset email. Please try again.", s("error", d.value);
|
|
1822
1802
|
} finally {
|
|
1823
|
-
|
|
1803
|
+
l.value = !1;
|
|
1824
1804
|
}
|
|
1825
1805
|
};
|
|
1826
|
-
return (
|
|
1827
|
-
|
|
1828
|
-
default:
|
|
1806
|
+
return (g, c) => (A(), r("div", Zs, [
|
|
1807
|
+
N(b(oe), { variant: "modern" }, {
|
|
1808
|
+
default: z(() => [
|
|
1829
1809
|
c[4] || (c[4] = e("div", { class: "text-center mb-8" }, [
|
|
1830
1810
|
e("h1", { class: "text-3xl font-bold text-gradient mb-2" }, "Reset password"),
|
|
1831
1811
|
e("p", { class: "text-neutral-600" }, "Enter your email address and we'll send you a link to reset your password")
|
|
1832
1812
|
], -1)),
|
|
1833
1813
|
e("form", {
|
|
1834
|
-
onSubmit:
|
|
1814
|
+
onSubmit: Ae(o, ["prevent"]),
|
|
1835
1815
|
class: "space-y-6"
|
|
1836
1816
|
}, [
|
|
1837
|
-
|
|
1817
|
+
N(b(_), {
|
|
1838
1818
|
id: "email",
|
|
1839
|
-
modelValue:
|
|
1840
|
-
"onUpdate:modelValue": c[0] || (c[0] = (f) =>
|
|
1819
|
+
modelValue: u.email,
|
|
1820
|
+
"onUpdate:modelValue": c[0] || (c[0] = (f) => u.email = f),
|
|
1841
1821
|
type: "email",
|
|
1842
1822
|
label: "Email address",
|
|
1843
1823
|
placeholder: "Enter your email address",
|
|
1844
1824
|
autocomplete: "email",
|
|
1845
1825
|
required: "",
|
|
1846
|
-
disabled:
|
|
1847
|
-
error:
|
|
1826
|
+
disabled: l.value || i.value,
|
|
1827
|
+
error: d.value ? "Email address not found" : void 0
|
|
1848
1828
|
}, null, 8, ["modelValue", "disabled", "error"]),
|
|
1849
|
-
|
|
1829
|
+
N(b(G), {
|
|
1850
1830
|
type: "submit",
|
|
1851
1831
|
variant: "primary",
|
|
1852
1832
|
"full-width": "",
|
|
1853
|
-
disabled:
|
|
1854
|
-
loading:
|
|
1833
|
+
disabled: l.value || !u.email.trim() || i.value,
|
|
1834
|
+
loading: l.value,
|
|
1855
1835
|
"loading-text": "Sending link..."
|
|
1856
1836
|
}, {
|
|
1857
|
-
default:
|
|
1858
|
-
|
|
1837
|
+
default: z(() => [
|
|
1838
|
+
F(L(i.value ? "Link sent!" : "Send reset link"), 1)
|
|
1859
1839
|
]),
|
|
1860
1840
|
_: 1
|
|
1861
1841
|
}, 8, ["disabled", "loading"])
|
|
1862
1842
|
], 32),
|
|
1863
|
-
|
|
1843
|
+
i.value ? (A(), Y(b(ee), {
|
|
1864
1844
|
key: 0,
|
|
1865
1845
|
variant: "success",
|
|
1866
|
-
message: `Check your email - We've sent a password reset link to ${
|
|
1846
|
+
message: `Check your email - We've sent a password reset link to ${u.email}`,
|
|
1867
1847
|
class: "mt-6 animate-fade-in"
|
|
1868
|
-
}, null, 8, ["message"])) :
|
|
1869
|
-
|
|
1848
|
+
}, null, 8, ["message"])) : C("", !0),
|
|
1849
|
+
d.value ? (A(), Y(b(ee), {
|
|
1870
1850
|
key: 1,
|
|
1871
1851
|
variant: "error",
|
|
1872
|
-
message:
|
|
1852
|
+
message: d.value,
|
|
1873
1853
|
class: "mt-6 animate-fade-in",
|
|
1874
1854
|
dismissible: "",
|
|
1875
|
-
onDismiss: c[1] || (c[1] = (f) =>
|
|
1876
|
-
}, null, 8, ["message"])) :
|
|
1877
|
-
e("div",
|
|
1878
|
-
|
|
1879
|
-
onClick: c[2] || (c[2] = (f) =>
|
|
1855
|
+
onDismiss: c[1] || (c[1] = (f) => d.value = "")
|
|
1856
|
+
}, null, 8, ["message"])) : C("", !0),
|
|
1857
|
+
e("div", Ts, [
|
|
1858
|
+
N(b(te), {
|
|
1859
|
+
onClick: c[2] || (c[2] = (f) => g.$emit("back-to-signin")),
|
|
1880
1860
|
class: "inline-flex items-center gap-2"
|
|
1881
1861
|
}, {
|
|
1882
|
-
default:
|
|
1862
|
+
default: z(() => c[3] || (c[3] = [
|
|
1883
1863
|
e("svg", {
|
|
1884
1864
|
class: "w-4 h-4",
|
|
1885
1865
|
fill: "none",
|
|
@@ -1893,228 +1873,225 @@ const lt = { class: "w-full max-w-md mx-auto animate-slide-up" }, nt = { class:
|
|
|
1893
1873
|
d: "M15 19l-7-7 7-7"
|
|
1894
1874
|
})
|
|
1895
1875
|
], -1),
|
|
1896
|
-
|
|
1876
|
+
F(" Back to sign in ", -1)
|
|
1897
1877
|
])),
|
|
1898
1878
|
_: 1,
|
|
1899
1879
|
__: [3]
|
|
1900
1880
|
})
|
|
1901
1881
|
]),
|
|
1902
|
-
|
|
1882
|
+
N(ae)
|
|
1903
1883
|
]),
|
|
1904
1884
|
_: 1,
|
|
1905
1885
|
__: [4]
|
|
1906
1886
|
})
|
|
1907
1887
|
]));
|
|
1908
1888
|
}
|
|
1909
|
-
}),
|
|
1889
|
+
}), Ys = { class: "max-w-md mx-auto bg-white rounded-lg shadow-lg p-6" }, aA = /* @__PURE__ */ k({
|
|
1910
1890
|
__name: "StrandsMFASetup",
|
|
1911
|
-
setup(
|
|
1912
|
-
return (
|
|
1913
|
-
|
|
1891
|
+
setup(y) {
|
|
1892
|
+
return (p, s) => (A(), r("div", Ys, s[0] || (s[0] = [
|
|
1893
|
+
me('<div class="text-center mb-6"><h2 class="text-2xl font-bold text-gray-900">Two-Factor Authentication</h2><p class="text-gray-600 mt-2">Secure your account with 2FA</p></div><div class="space-y-4"><p class="text-gray-500">MFA setup functionality will be implemented here.</p></div>', 2)
|
|
1914
1894
|
])));
|
|
1915
1895
|
}
|
|
1916
|
-
}),
|
|
1917
|
-
function
|
|
1918
|
-
const
|
|
1919
|
-
|
|
1896
|
+
}), j = U(null), J = U(null), $ = U(!1), T = U(!1), ce = U(!1);
|
|
1897
|
+
function we() {
|
|
1898
|
+
const y = x(() => j.value !== null), p = async (o) => {
|
|
1899
|
+
T.value = !0;
|
|
1920
1900
|
try {
|
|
1921
|
-
return console.log("Sign in with:",
|
|
1901
|
+
return console.log("Sign in with:", o), await new Promise((g) => setTimeout(g, 1e3)), j.value = {
|
|
1922
1902
|
id: "1",
|
|
1923
|
-
email:
|
|
1903
|
+
email: o.email,
|
|
1924
1904
|
firstName: "John",
|
|
1925
1905
|
lastName: "Doe",
|
|
1926
1906
|
mfaEnabled: !1,
|
|
1927
1907
|
createdAt: "2024-01-15T10:30:00Z",
|
|
1928
1908
|
updatedAt: "2024-01-20T14:45:00Z"
|
|
1929
|
-
},
|
|
1909
|
+
}, J.value = {
|
|
1930
1910
|
accessToken: "mock-access-token",
|
|
1931
1911
|
refreshToken: "mock-refresh-token",
|
|
1932
1912
|
expiresAt: new Date(Date.now() + 300 * 1e3)
|
|
1933
1913
|
// 5 minutes
|
|
1934
|
-
},
|
|
1914
|
+
}, j.value;
|
|
1935
1915
|
} finally {
|
|
1936
|
-
|
|
1916
|
+
T.value = !1;
|
|
1937
1917
|
}
|
|
1938
|
-
}, s = async (
|
|
1939
|
-
|
|
1918
|
+
}, s = async (o) => {
|
|
1919
|
+
T.value = !0;
|
|
1940
1920
|
try {
|
|
1941
|
-
return console.log("Sign up with:",
|
|
1921
|
+
return console.log("Sign up with:", o), await new Promise((g) => setTimeout(g, 1e3)), j.value = {
|
|
1942
1922
|
id: "1",
|
|
1943
|
-
email:
|
|
1944
|
-
firstName:
|
|
1945
|
-
lastName:
|
|
1923
|
+
email: o.email,
|
|
1924
|
+
firstName: o.firstName,
|
|
1925
|
+
lastName: o.lastName,
|
|
1946
1926
|
mfaEnabled: !1,
|
|
1947
1927
|
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
1948
1928
|
updatedAt: (/* @__PURE__ */ new Date()).toISOString()
|
|
1949
|
-
},
|
|
1929
|
+
}, J.value = {
|
|
1950
1930
|
accessToken: "mock-access-token",
|
|
1951
1931
|
refreshToken: "mock-refresh-token",
|
|
1952
1932
|
expiresAt: new Date(Date.now() + 300 * 1e3)
|
|
1953
1933
|
// 5 minutes
|
|
1954
|
-
},
|
|
1934
|
+
}, j.value;
|
|
1955
1935
|
} finally {
|
|
1956
|
-
|
|
1936
|
+
T.value = !1;
|
|
1957
1937
|
}
|
|
1958
|
-
},
|
|
1959
|
-
|
|
1938
|
+
}, l = async () => {
|
|
1939
|
+
T.value = !0;
|
|
1960
1940
|
try {
|
|
1961
|
-
console.log("Sign out"), await new Promise((
|
|
1941
|
+
console.log("Sign out"), await new Promise((o) => setTimeout(o, 500)), j.value = null, J.value = null;
|
|
1962
1942
|
} finally {
|
|
1963
|
-
|
|
1943
|
+
T.value = !1;
|
|
1964
1944
|
}
|
|
1965
|
-
},
|
|
1966
|
-
if (
|
|
1967
|
-
|
|
1945
|
+
}, d = async () => {
|
|
1946
|
+
if (J.value) {
|
|
1947
|
+
$.value = !0;
|
|
1968
1948
|
try {
|
|
1969
|
-
console.log("Refresh token"),
|
|
1949
|
+
console.log("Refresh token"), J.value.expiresAt = new Date(Date.now() + 300 * 1e3);
|
|
1970
1950
|
} finally {
|
|
1971
|
-
|
|
1951
|
+
$.value = !1;
|
|
1972
1952
|
}
|
|
1973
1953
|
}
|
|
1974
|
-
},
|
|
1975
|
-
|
|
1954
|
+
}, i = async (o) => {
|
|
1955
|
+
$.value = !0;
|
|
1976
1956
|
try {
|
|
1977
|
-
console.log("Update profile:",
|
|
1957
|
+
console.log("Update profile:", o), j.value && Object.assign(j.value, o);
|
|
1978
1958
|
} finally {
|
|
1979
|
-
|
|
1959
|
+
$.value = !1;
|
|
1980
1960
|
}
|
|
1981
|
-
},
|
|
1982
|
-
if (!
|
|
1983
|
-
|
|
1961
|
+
}, u = async () => {
|
|
1962
|
+
if (!ce.value) {
|
|
1963
|
+
T.value = !0;
|
|
1984
1964
|
try {
|
|
1985
|
-
console.log("Initializing auth state"), await new Promise((
|
|
1986
|
-
} catch (
|
|
1987
|
-
console.error("Auth initialization error:",
|
|
1965
|
+
console.log("Initializing auth state"), await new Promise((o) => setTimeout(o, 500)), ce.value = !0;
|
|
1966
|
+
} catch (o) {
|
|
1967
|
+
console.error("Auth initialization error:", o);
|
|
1988
1968
|
} finally {
|
|
1989
|
-
|
|
1969
|
+
T.value = !1;
|
|
1990
1970
|
}
|
|
1991
1971
|
}
|
|
1992
1972
|
};
|
|
1993
|
-
return
|
|
1973
|
+
return ce.value || u(), {
|
|
1994
1974
|
// State
|
|
1995
|
-
user:
|
|
1996
|
-
currentUser:
|
|
1997
|
-
currentSession:
|
|
1998
|
-
isAuthenticated:
|
|
1999
|
-
isLoading:
|
|
2000
|
-
loading:
|
|
1975
|
+
user: x(() => j.value),
|
|
1976
|
+
currentUser: x(() => j.value),
|
|
1977
|
+
currentSession: x(() => J.value),
|
|
1978
|
+
isAuthenticated: y,
|
|
1979
|
+
isLoading: x(() => T.value),
|
|
1980
|
+
loading: x(() => $.value),
|
|
2001
1981
|
// Methods
|
|
2002
|
-
signIn:
|
|
1982
|
+
signIn: p,
|
|
2003
1983
|
signUp: s,
|
|
2004
|
-
signOut:
|
|
2005
|
-
refreshToken:
|
|
2006
|
-
updateProfile:
|
|
2007
|
-
initialize:
|
|
1984
|
+
signOut: l,
|
|
1985
|
+
refreshToken: d,
|
|
1986
|
+
updateProfile: i,
|
|
1987
|
+
initialize: u
|
|
2008
1988
|
};
|
|
2009
1989
|
}
|
|
2010
|
-
const
|
|
1990
|
+
const Ks = {
|
|
2011
1991
|
key: 0,
|
|
2012
1992
|
class: "animate-fade-in"
|
|
2013
|
-
},
|
|
1993
|
+
}, Qs = {
|
|
2014
1994
|
key: 1,
|
|
2015
1995
|
class: "animate-fade-in"
|
|
2016
|
-
},
|
|
1996
|
+
}, rA = /* @__PURE__ */ k({
|
|
2017
1997
|
__name: "SignedIn",
|
|
2018
1998
|
props: {
|
|
2019
1999
|
showFallback: { type: Boolean, default: !0 }
|
|
2020
2000
|
},
|
|
2021
2001
|
emits: ["sign-in-required"],
|
|
2022
|
-
setup(
|
|
2023
|
-
const s =
|
|
2002
|
+
setup(y, { emit: p }) {
|
|
2003
|
+
const s = p, { isAuthenticated: l, user: d, signOut: i } = we(), u = () => {
|
|
2024
2004
|
s("sign-in-required");
|
|
2025
2005
|
};
|
|
2026
|
-
return (
|
|
2027
|
-
|
|
2028
|
-
user:
|
|
2029
|
-
signOut:
|
|
2006
|
+
return (o, g) => b(l) ? (A(), r("div", Ks, [
|
|
2007
|
+
P(o.$slots, "default", {
|
|
2008
|
+
user: b(d),
|
|
2009
|
+
signOut: b(i)
|
|
2030
2010
|
})
|
|
2031
|
-
])) :
|
|
2032
|
-
|
|
2011
|
+
])) : o.showFallback ? (A(), r("div", Qs, [
|
|
2012
|
+
P(o.$slots, "fallback", { signIn: u }, () => [
|
|
2033
2013
|
e("div", { class: "text-center py-8" }, [
|
|
2034
|
-
|
|
2014
|
+
g[0] || (g[0] = me('<div class="w-16 h-16 mx-auto mb-4 bg-neutral-100 rounded-full flex items-center justify-center"><svg class="w-8 h-8 text-neutral-400" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M12 15v2m-6 4h12a2 2 0 002-2v-6a2 2 0 00-2-2H6a2 2 0 00-2 2v6a2 2 0 002 2zm10-10V7a4 4 0 00-8 0v4h8z"></path></svg></div><h3 class="text-lg font-semibold text-neutral-900 mb-2">Sign in required</h3><p class="text-neutral-600 mb-4">You need to be signed in to access this content.</p>', 3)),
|
|
2035
2015
|
e("button", {
|
|
2036
|
-
onClick:
|
|
2016
|
+
onClick: u,
|
|
2037
2017
|
class: "btn-primary !w-auto px-6 py-2"
|
|
2038
2018
|
}, " Sign in ")
|
|
2039
2019
|
])
|
|
2040
2020
|
])
|
|
2041
|
-
])) :
|
|
2021
|
+
])) : C("", !0);
|
|
2042
2022
|
}
|
|
2043
|
-
}),
|
|
2023
|
+
}), Os = {
|
|
2044
2024
|
key: 0,
|
|
2045
2025
|
class: "animate-fade-in"
|
|
2046
|
-
},
|
|
2026
|
+
}, Es = {
|
|
2047
2027
|
key: 1,
|
|
2048
2028
|
class: "animate-fade-in"
|
|
2049
|
-
},
|
|
2029
|
+
}, Hs = { class: "text-center py-8" }, Gs = { class: "text-neutral-600 mb-4" }, Rs = {
|
|
2050
2030
|
key: 2,
|
|
2051
2031
|
class: "animate-pulse"
|
|
2052
|
-
},
|
|
2032
|
+
}, lA = /* @__PURE__ */ k({
|
|
2053
2033
|
__name: "SignedOut",
|
|
2054
2034
|
props: {
|
|
2055
2035
|
showFallback: { type: Boolean, default: !0 }
|
|
2056
2036
|
},
|
|
2057
2037
|
emits: ["sign-in-clicked", "sign-up-clicked"],
|
|
2058
|
-
setup(
|
|
2059
|
-
const s =
|
|
2038
|
+
setup(y, { emit: p }) {
|
|
2039
|
+
const s = p, { isAuthenticated: l, isLoading: d, user: i, signOut: u } = we(), o = () => {
|
|
2060
2040
|
s("sign-in-clicked");
|
|
2061
|
-
},
|
|
2041
|
+
}, g = () => {
|
|
2062
2042
|
s("sign-up-clicked");
|
|
2063
2043
|
};
|
|
2064
|
-
return (c, f) => !
|
|
2065
|
-
|
|
2066
|
-
signIn:
|
|
2067
|
-
signUp:
|
|
2068
|
-
})
|
|
2069
|
-
])) : c.showFallback && w(r) ? (A(), a("div", Gs, [
|
|
2070
|
-
Z(c.$slots, "fallback", {
|
|
2071
|
-
user: w(o),
|
|
2072
|
-
signOut: w(i)
|
|
2073
|
-
}, () => {
|
|
2074
|
-
var t;
|
|
2075
|
-
return [
|
|
2076
|
-
e("div", Rs, [
|
|
2077
|
-
f[1] || (f[1] = e("div", { class: "w-16 h-16 mx-auto mb-4 bg-strands-100 rounded-full flex items-center justify-center" }, [
|
|
2078
|
-
e("svg", {
|
|
2079
|
-
class: "w-8 h-8 text-strands-600",
|
|
2080
|
-
fill: "none",
|
|
2081
|
-
stroke: "currentColor",
|
|
2082
|
-
viewBox: "0 0 24 24"
|
|
2083
|
-
}, [
|
|
2084
|
-
e("path", {
|
|
2085
|
-
"stroke-linecap": "round",
|
|
2086
|
-
"stroke-linejoin": "round",
|
|
2087
|
-
"stroke-width": "2",
|
|
2088
|
-
d: "M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z"
|
|
2089
|
-
})
|
|
2090
|
-
])
|
|
2091
|
-
], -1)),
|
|
2092
|
-
f[2] || (f[2] = e("h3", { class: "text-lg font-semibold text-neutral-900 mb-2" }, "Already signed in", -1)),
|
|
2093
|
-
e("p", Js, "You're currently signed in as " + L((t = w(o)) == null ? void 0 : t.email) + ".", 1),
|
|
2094
|
-
e("button", {
|
|
2095
|
-
onClick: f[0] || (f[0] = //@ts-ignore
|
|
2096
|
-
(...p) => w(i) && w(i)(...p)),
|
|
2097
|
-
class: "btn-secondary !w-auto px-6 py-2"
|
|
2098
|
-
}, " Sign out ")
|
|
2099
|
-
])
|
|
2100
|
-
];
|
|
2044
|
+
return (c, f) => !b(l) && !b(d) ? (A(), r("div", Os, [
|
|
2045
|
+
P(c.$slots, "default", {
|
|
2046
|
+
signIn: o,
|
|
2047
|
+
signUp: g
|
|
2101
2048
|
})
|
|
2102
|
-
])) :
|
|
2103
|
-
|
|
2104
|
-
|
|
2049
|
+
])) : c.showFallback && b(l) ? (A(), r("div", Es, [
|
|
2050
|
+
P(c.$slots, "fallback", {
|
|
2051
|
+
user: b(i),
|
|
2052
|
+
signOut: b(u)
|
|
2053
|
+
}, () => [
|
|
2054
|
+
e("div", Hs, [
|
|
2055
|
+
f[1] || (f[1] = e("div", { class: "w-16 h-16 mx-auto mb-4 bg-strands-100 rounded-full flex items-center justify-center" }, [
|
|
2056
|
+
e("svg", {
|
|
2057
|
+
class: "w-8 h-8 text-strands-600",
|
|
2058
|
+
fill: "none",
|
|
2059
|
+
stroke: "currentColor",
|
|
2060
|
+
viewBox: "0 0 24 24"
|
|
2061
|
+
}, [
|
|
2062
|
+
e("path", {
|
|
2063
|
+
"stroke-linecap": "round",
|
|
2064
|
+
"stroke-linejoin": "round",
|
|
2065
|
+
"stroke-width": "2",
|
|
2066
|
+
d: "M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z"
|
|
2067
|
+
})
|
|
2068
|
+
])
|
|
2069
|
+
], -1)),
|
|
2070
|
+
f[2] || (f[2] = e("h3", { class: "text-lg font-semibold text-neutral-900 mb-2" }, "Already signed in", -1)),
|
|
2071
|
+
e("p", Gs, "You're currently signed in as " + L(b(i)?.email) + ".", 1),
|
|
2072
|
+
e("button", {
|
|
2073
|
+
onClick: f[0] || (f[0] = //@ts-ignore
|
|
2074
|
+
(...t) => b(u) && b(u)(...t)),
|
|
2075
|
+
class: "btn-secondary !w-auto px-6 py-2"
|
|
2076
|
+
}, " Sign out ")
|
|
2077
|
+
])
|
|
2078
|
+
])
|
|
2079
|
+
])) : b(d) ? (A(), r("div", Rs, [
|
|
2080
|
+
P(c.$slots, "loading", {}, () => [
|
|
2081
|
+
f[3] || (f[3] = me('<div class="text-center py-8"><div class="w-16 h-16 mx-auto mb-4 bg-neutral-200 rounded-full flex items-center justify-center"><svg class="animate-spin w-6 h-6 text-neutral-400" fill="none" viewBox="0 0 24 24"><circle class="opacity-25" cx="12" cy="12" r="10" stroke="currentColor" stroke-width="4"></circle><path class="opacity-75" fill="currentColor" d="m4 12a8 8 0 0 1 8-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 0 1 4 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"></path></svg></div><p class="text-neutral-500">Checking authentication...</p></div>', 1))
|
|
2105
2082
|
])
|
|
2106
|
-
])) :
|
|
2083
|
+
])) : C("", !0);
|
|
2107
2084
|
}
|
|
2108
|
-
}),
|
|
2085
|
+
}), nA = /* @__PURE__ */ k({
|
|
2109
2086
|
__name: "StrandsLogo",
|
|
2110
2087
|
props: {
|
|
2111
2088
|
class: { default: "" }
|
|
2112
2089
|
},
|
|
2113
|
-
setup(
|
|
2114
|
-
return (
|
|
2090
|
+
setup(y) {
|
|
2091
|
+
return (p, s) => (A(), r("svg", {
|
|
2115
2092
|
viewBox: "0 0 22571 9413",
|
|
2116
2093
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2117
|
-
class:
|
|
2094
|
+
class: B(p.class),
|
|
2118
2095
|
role: "img",
|
|
2119
2096
|
"aria-label": "Strands Services Logo"
|
|
2120
2097
|
}, s[0] || (s[0] = [
|
|
@@ -2133,40 +2110,40 @@ const Os = {
|
|
|
2133
2110
|
], -1)
|
|
2134
2111
|
]), 2));
|
|
2135
2112
|
}
|
|
2136
|
-
}),
|
|
2113
|
+
}), oA = /* @__PURE__ */ k({
|
|
2137
2114
|
__name: "StrandsConfigProvider",
|
|
2138
2115
|
props: {
|
|
2139
2116
|
config: {}
|
|
2140
2117
|
},
|
|
2141
|
-
setup(
|
|
2142
|
-
const
|
|
2143
|
-
return
|
|
2144
|
-
|
|
2145
|
-
}),
|
|
2118
|
+
setup(y) {
|
|
2119
|
+
const p = y;
|
|
2120
|
+
return se(() => {
|
|
2121
|
+
pe(p.config);
|
|
2122
|
+
}), pe(p.config), (s, l) => P(s.$slots, "default");
|
|
2146
2123
|
}
|
|
2147
2124
|
});
|
|
2148
2125
|
export {
|
|
2149
|
-
|
|
2150
|
-
|
|
2151
|
-
|
|
2152
|
-
|
|
2153
|
-
|
|
2154
|
-
|
|
2155
|
-
|
|
2156
|
-
|
|
2157
|
-
|
|
2158
|
-
|
|
2159
|
-
|
|
2160
|
-
|
|
2161
|
-
|
|
2162
|
-
|
|
2163
|
-
|
|
2164
|
-
|
|
2165
|
-
|
|
2166
|
-
|
|
2167
|
-
|
|
2126
|
+
rA as SignedIn,
|
|
2127
|
+
lA as SignedOut,
|
|
2128
|
+
$s as StrandsAuth,
|
|
2129
|
+
oA as StrandsConfigProvider,
|
|
2130
|
+
nA as StrandsLogo,
|
|
2131
|
+
aA as StrandsMFASetup,
|
|
2132
|
+
AA as StrandsPasswordReset,
|
|
2133
|
+
ae as StrandsSecuredFooter,
|
|
2134
|
+
eA as StrandsSignIn,
|
|
2135
|
+
tA as StrandsSignUp,
|
|
2136
|
+
sA as StrandsUserProfile,
|
|
2137
|
+
ee as UiAlert,
|
|
2138
|
+
G as UiButton,
|
|
2139
|
+
oe as UiCard,
|
|
2140
|
+
_ as UiInput,
|
|
2141
|
+
te as UiLink,
|
|
2142
|
+
$e as UiTabs,
|
|
2143
|
+
pe as provideStrandsConfig,
|
|
2144
|
+
_s as setStrandsConfig,
|
|
2168
2145
|
fe as useOAuthProviders,
|
|
2169
|
-
|
|
2170
|
-
|
|
2146
|
+
we as useStrandsAuth,
|
|
2147
|
+
ie as useStrandsConfig
|
|
2171
2148
|
};
|
|
2172
2149
|
//# sourceMappingURL=strands-auth-ui.es.js.map
|