@strands.gg/accui 1.6.2 → 1.6.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/accui.css +112 -87
- package/dist/nuxt/module.cjs.js.map +1 -1
- package/dist/nuxt/module.es.js.map +1 -1
- package/dist/nuxt/runtime/composables/useStrandsAuth.cjs.js.map +1 -1
- package/dist/nuxt/runtime/composables/useStrandsAuth.es.js.map +1 -1
- package/dist/nuxt/runtime/middleware/auth.global.cjs.js.map +1 -1
- package/dist/nuxt/runtime/middleware/auth.global.es.js.map +1 -1
- package/dist/nuxt/runtime/plugin.client.cjs.js.map +1 -1
- package/dist/nuxt/runtime/plugin.client.es.js.map +1 -1
- package/dist/nuxt/runtime/plugin.server.cjs.js.map +1 -1
- package/dist/nuxt/runtime/plugin.server.es.js.map +1 -1
- package/dist/nuxt-v4/module.cjs.js.map +1 -1
- package/dist/nuxt-v4/module.es.js.map +1 -1
- package/dist/nuxt-v4/runtime/composables/useStrandsAuth.cjs.js.map +1 -1
- package/dist/nuxt-v4/runtime/composables/useStrandsAuth.es.js.map +1 -1
- package/dist/nuxt-v4/runtime/middleware/auth.global.cjs.js.map +1 -1
- package/dist/nuxt-v4/runtime/middleware/auth.global.es.js.map +1 -1
- package/dist/nuxt-v4/runtime/plugin.client.cjs.js.map +1 -1
- package/dist/nuxt-v4/runtime/plugin.client.es.js.map +1 -1
- package/dist/nuxt-v4/runtime/plugin.server.cjs.js.map +1 -1
- package/dist/nuxt-v4/runtime/plugin.server.es.js.map +1 -1
- package/dist/strands-auth-ui.cjs.js +533 -447
- package/dist/strands-auth-ui.cjs.js.map +1 -1
- package/dist/strands-auth-ui.es.js +533 -447
- package/dist/strands-auth-ui.es.js.map +1 -1
- package/dist/useStrandsAuth-CO9JEdxM.js.map +1 -1
- package/dist/useStrandsAuth-z4jAu9Uv.cjs.map +1 -1
- package/dist/useStrandsConfig-Bdk-g0jS.js.map +1 -1
- package/dist/useStrandsConfig-CtmQtE7Y.cjs.map +1 -1
- package/package.json +2 -1
- package/dist/index.d.ts +0 -7
- package/dist/index.d.ts.map +0 -1
- package/dist/nuxt/module.d.ts +0 -5
- package/dist/nuxt/module.d.ts.map +0 -1
- package/dist/nuxt/runtime/composables/useStrandsAuth.d.ts +0 -137
- package/dist/nuxt/runtime/composables/useStrandsAuth.d.ts.map +0 -1
- package/dist/nuxt/runtime/middleware/auth.global.d.ts +0 -3
- package/dist/nuxt/runtime/middleware/auth.global.d.ts.map +0 -1
- package/dist/nuxt/runtime/plugin.client.d.ts +0 -3
- package/dist/nuxt/runtime/plugin.client.d.ts.map +0 -1
- package/dist/nuxt/runtime/plugin.server.d.ts +0 -3
- package/dist/nuxt/runtime/plugin.server.d.ts.map +0 -1
- package/dist/nuxt/runtime/styles.css +0 -78
- package/dist/nuxt/types.d.ts +0 -46
- package/dist/nuxt/types.d.ts.map +0 -1
- package/dist/nuxt-v4/module.d.ts +0 -5
- package/dist/nuxt-v4/module.d.ts.map +0 -1
- package/dist/nuxt-v4/runtime/composables/useStrandsAuth.d.ts +0 -27
- package/dist/nuxt-v4/runtime/composables/useStrandsAuth.d.ts.map +0 -1
- package/dist/nuxt-v4/runtime/middleware/auth.global.d.ts +0 -3
- package/dist/nuxt-v4/runtime/middleware/auth.global.d.ts.map +0 -1
- package/dist/nuxt-v4/runtime/plugin.client.d.ts +0 -3
- package/dist/nuxt-v4/runtime/plugin.client.d.ts.map +0 -1
- package/dist/nuxt-v4/runtime/plugin.server.d.ts +0 -3
- package/dist/nuxt-v4/runtime/plugin.server.d.ts.map +0 -1
- package/dist/nuxt-v4/runtime/styles.css +0 -141
- package/dist/nuxt-v4/types.d.ts +0 -64
- package/dist/nuxt-v4/types.d.ts.map +0 -1
- package/dist/nuxt-v4.d.ts +0 -4
- package/dist/nuxt-v4.d.ts.map +0 -1
- package/dist/nuxt.d.ts +0 -3
- package/dist/nuxt.d.ts.map +0 -1
- package/dist/shared/defaults.d.ts +0 -3
- package/dist/shared/defaults.d.ts.map +0 -1
- package/dist/types/index.d.ts +0 -197
- package/dist/types/index.d.ts.map +0 -1
- package/dist/utils/index.d.ts +0 -2
- package/dist/utils/index.d.ts.map +0 -1
- package/dist/utils/slots.d.ts +0 -2
- package/dist/utils/slots.d.ts.map +0 -1
- package/dist/utils/validation.d.ts +0 -13
- package/dist/utils/validation.d.ts.map +0 -1
- package/dist/vue/components/SignedIn.vue.d.ts +0 -51
- package/dist/vue/components/SignedIn.vue.d.ts.map +0 -1
- package/dist/vue/components/SignedOut.vue.d.ts +0 -54
- package/dist/vue/components/SignedOut.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsAuth.vue.d.ts +0 -23
- package/dist/vue/components/StrandsAuth.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsBackupCodesModal.vue.d.ts +0 -12
- package/dist/vue/components/StrandsBackupCodesModal.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsCompleteSignUp.vue.d.ts +0 -21
- package/dist/vue/components/StrandsCompleteSignUp.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsConfigProvider.vue.d.ts +0 -22
- package/dist/vue/components/StrandsConfigProvider.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsConfirmModal.vue.d.ts +0 -22
- package/dist/vue/components/StrandsConfirmModal.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsEmailMfaSetupModal.vue.d.ts +0 -12
- package/dist/vue/components/StrandsEmailMfaSetupModal.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsHardwareKeySetupModal.vue.d.ts +0 -15
- package/dist/vue/components/StrandsHardwareKeySetupModal.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsLogo.vue.d.ts +0 -8
- package/dist/vue/components/StrandsLogo.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsMFASetup.vue.d.ts +0 -16
- package/dist/vue/components/StrandsMFASetup.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsMfaModal.vue.d.ts +0 -12
- package/dist/vue/components/StrandsMfaModal.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsMfaVerification.vue.d.ts +0 -17
- package/dist/vue/components/StrandsMfaVerification.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsPasswordReset.vue.d.ts +0 -15
- package/dist/vue/components/StrandsPasswordReset.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsSecuredFooter.vue.d.ts +0 -22
- package/dist/vue/components/StrandsSecuredFooter.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsSettingsModal.vue.d.ts +0 -18
- package/dist/vue/components/StrandsSettingsModal.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsSignIn.vue.d.ts +0 -21
- package/dist/vue/components/StrandsSignIn.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsSignUp.vue.d.ts +0 -19
- package/dist/vue/components/StrandsSignUp.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsTotpSetupModal.vue.d.ts +0 -12
- package/dist/vue/components/StrandsTotpSetupModal.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsUserButton.vue.d.ts +0 -19
- package/dist/vue/components/StrandsUserButton.vue.d.ts.map +0 -1
- package/dist/vue/components/StrandsUserProfile.vue.d.ts +0 -26
- package/dist/vue/components/StrandsUserProfile.vue.d.ts.map +0 -1
- package/dist/vue/components/SvgIcon.vue.d.ts +0 -17
- package/dist/vue/components/SvgIcon.vue.d.ts.map +0 -1
- package/dist/vue/components/index.d.ts +0 -23
- package/dist/vue/components/index.d.ts.map +0 -1
- package/dist/vue/composables/useOAuthProviders.d.ts +0 -74
- package/dist/vue/composables/useOAuthProviders.d.ts.map +0 -1
- package/dist/vue/composables/useStrandsAuth.d.ts +0 -124
- package/dist/vue/composables/useStrandsAuth.d.ts.map +0 -1
- package/dist/vue/composables/useStrandsConfig.d.ts +0 -11
- package/dist/vue/composables/useStrandsConfig.d.ts.map +0 -1
- package/dist/vue/composables/useStrandsMfa.d.ts +0 -37
- package/dist/vue/composables/useStrandsMfa.d.ts.map +0 -1
- package/dist/vue/index.d.ts +0 -7
- package/dist/vue/index.d.ts.map +0 -1
- package/dist/vue/plugins/StrandsUIPlugin.d.ts +0 -18
- package/dist/vue/plugins/StrandsUIPlugin.d.ts.map +0 -1
- package/dist/vue/ui/UiAlert.vue.d.ts +0 -31
- package/dist/vue/ui/UiAlert.vue.d.ts.map +0 -1
- package/dist/vue/ui/UiAvatarEditor.vue.d.ts +0 -24
- package/dist/vue/ui/UiAvatarEditor.vue.d.ts.map +0 -1
- package/dist/vue/ui/UiAvatarEditorSimple.vue.d.ts +0 -25
- package/dist/vue/ui/UiAvatarEditorSimple.vue.d.ts.map +0 -1
- package/dist/vue/ui/UiButton.vue.d.ts +0 -40
- package/dist/vue/ui/UiButton.vue.d.ts.map +0 -1
- package/dist/vue/ui/UiCard.vue.d.ts +0 -29
- package/dist/vue/ui/UiCard.vue.d.ts.map +0 -1
- package/dist/vue/ui/UiInput.vue.d.ts +0 -48
- package/dist/vue/ui/UiInput.vue.d.ts.map +0 -1
- package/dist/vue/ui/UiLevelProgress.vue.d.ts +0 -19
- package/dist/vue/ui/UiLevelProgress.vue.d.ts.map +0 -1
- package/dist/vue/ui/UiLink.vue.d.ts +0 -35
- package/dist/vue/ui/UiLink.vue.d.ts.map +0 -1
- package/dist/vue/ui/UiLoader.vue.d.ts +0 -15
- package/dist/vue/ui/UiLoader.vue.d.ts.map +0 -1
- package/dist/vue/ui/UiModal.vue.d.ts +0 -31
- package/dist/vue/ui/UiModal.vue.d.ts.map +0 -1
- package/dist/vue/ui/UiTabs.vue.d.ts +0 -17
- package/dist/vue/ui/UiTabs.vue.d.ts.map +0 -1
- package/dist/vue/ui/UiToggle.vue.d.ts +0 -15
- package/dist/vue/ui/UiToggle.vue.d.ts.map +0 -1
- package/dist/vue/ui/index.d.ts +0 -19
- package/dist/vue/ui/index.d.ts.map +0 -1
- package/dist/vue/utils/levels.d.ts +0 -28
- package/dist/vue/utils/levels.d.ts.map +0 -1
- package/dist/vue/utils/sounds.d.ts +0 -57
- package/dist/vue/utils/sounds.d.ts.map +0 -1
|
@@ -317,6 +317,9 @@ const _sfc_main$v = /* @__PURE__ */ vue.defineComponent({
|
|
|
317
317
|
setup(__props) {
|
|
318
318
|
const props = __props;
|
|
319
319
|
const cardClasses = vue.computed(() => {
|
|
320
|
+
if (props.variant === "clean") {
|
|
321
|
+
return "";
|
|
322
|
+
}
|
|
320
323
|
const baseClasses = ["bg-white text-black border border-gray-200 flex flex-col gap-3"];
|
|
321
324
|
const variantClasses = {
|
|
322
325
|
default: "rounded-lg",
|
|
@@ -850,7 +853,7 @@ const _hoisted_14$c = { class: "bg-white border border-gray-200 rounded-xl p-5 s
|
|
|
850
853
|
const _hoisted_15$c = { class: "flex justify-center" };
|
|
851
854
|
const _hoisted_16$b = ["width", "height"];
|
|
852
855
|
const _hoisted_17$b = { class: "bg-white border border-gray-200 rounded-xl p-5 shadow-sm" };
|
|
853
|
-
const _hoisted_18$
|
|
856
|
+
const _hoisted_18$9 = { class: "space-y-3" };
|
|
854
857
|
const _hoisted_19$8 = { class: "flex items-center gap-3" };
|
|
855
858
|
const _hoisted_20$7 = { class: "flex-1 relative" };
|
|
856
859
|
const _hoisted_21$5 = ["min", "max"];
|
|
@@ -1298,7 +1301,7 @@ const _sfc_main$p = /* @__PURE__ */ vue.defineComponent({
|
|
|
1298
1301
|
]),
|
|
1299
1302
|
vue.createElementVNode("h3", { class: "text-sm font-semibold text-gray-700" }, "Zoom")
|
|
1300
1303
|
], -1)),
|
|
1301
|
-
vue.createElementVNode("div", _hoisted_18$
|
|
1304
|
+
vue.createElementVNode("div", _hoisted_18$9, [
|
|
1302
1305
|
vue.createElementVNode("div", _hoisted_19$8, [
|
|
1303
1306
|
vue.createElementVNode("button", {
|
|
1304
1307
|
onClick: _cache[6] || (_cache[6] = ($event) => {
|
|
@@ -1495,7 +1498,7 @@ const _hoisted_14$b = { class: "zoom-control" };
|
|
|
1495
1498
|
const _hoisted_15$b = ["min", "max"];
|
|
1496
1499
|
const _hoisted_16$a = { class: "action-buttons" };
|
|
1497
1500
|
const _hoisted_17$a = ["disabled"];
|
|
1498
|
-
const _hoisted_18$
|
|
1501
|
+
const _hoisted_18$8 = { class: "preview-section" };
|
|
1499
1502
|
const _hoisted_19$7 = { class: "preview-container" };
|
|
1500
1503
|
const _hoisted_20$6 = ["width", "height"];
|
|
1501
1504
|
const _sfc_main$o = /* @__PURE__ */ vue.defineComponent({
|
|
@@ -1936,7 +1939,7 @@ const _sfc_main$o = /* @__PURE__ */ vue.defineComponent({
|
|
|
1936
1939
|
])
|
|
1937
1940
|
])
|
|
1938
1941
|
]),
|
|
1939
|
-
vue.createElementVNode("div", _hoisted_18$
|
|
1942
|
+
vue.createElementVNode("div", _hoisted_18$8, [
|
|
1940
1943
|
_cache[9] || (_cache[9] = vue.createElementVNode("h3", { class: "text-sm font-medium text-gray-700 mb-3" }, "Preview", -1)),
|
|
1941
1944
|
vue.createElementVNode("div", _hoisted_19$7, [
|
|
1942
1945
|
vue.createElementVNode("canvas", {
|
|
@@ -3234,7 +3237,8 @@ const _sfc_main$m = /* @__PURE__ */ vue.defineComponent({
|
|
|
3234
3237
|
__name: "UiModal",
|
|
3235
3238
|
props: {
|
|
3236
3239
|
open: { type: Boolean, default: false },
|
|
3237
|
-
closeOnOverlayClick: { type: Boolean, default: true }
|
|
3240
|
+
closeOnOverlayClick: { type: Boolean, default: true },
|
|
3241
|
+
fullscreenOnMobile: { type: Boolean, default: true }
|
|
3238
3242
|
},
|
|
3239
3243
|
emits: ["close"],
|
|
3240
3244
|
setup(__props, { emit: __emit }) {
|
|
@@ -3253,7 +3257,7 @@ const _sfc_main$m = /* @__PURE__ */ vue.defineComponent({
|
|
|
3253
3257
|
onClick: handleOverlayClick
|
|
3254
3258
|
}, [
|
|
3255
3259
|
vue.createElementVNode("div", {
|
|
3256
|
-
class: "modal-container",
|
|
3260
|
+
class: vue.normalizeClass(["modal-container", { "modal-container-fullscreen-mobile": _ctx.fullscreenOnMobile }]),
|
|
3257
3261
|
onClick: _cache[0] || (_cache[0] = vue.withModifiers(() => {
|
|
3258
3262
|
}, ["stop"]))
|
|
3259
3263
|
}, [
|
|
@@ -3268,13 +3272,13 @@ const _sfc_main$m = /* @__PURE__ */ vue.defineComponent({
|
|
|
3268
3272
|
vue.renderSlot(_ctx.$slots, "footer", {}, void 0, true)
|
|
3269
3273
|
])) : vue.createCommentVNode("", true)
|
|
3270
3274
|
])
|
|
3271
|
-
])
|
|
3275
|
+
], 2)
|
|
3272
3276
|
])) : vue.createCommentVNode("", true)
|
|
3273
3277
|
]);
|
|
3274
3278
|
};
|
|
3275
3279
|
}
|
|
3276
3280
|
});
|
|
3277
|
-
const StrandsUiModal = /* @__PURE__ */ _export_sfc(_sfc_main$m, [["__scopeId", "data-v-
|
|
3281
|
+
const StrandsUiModal = /* @__PURE__ */ _export_sfc(_sfc_main$m, [["__scopeId", "data-v-53bb98be"]]);
|
|
3278
3282
|
const _imports_0 = "";
|
|
3279
3283
|
const slotHasContent = (slotName, slots) => {
|
|
3280
3284
|
const slot = slots[slotName];
|
|
@@ -3559,7 +3563,7 @@ const _hoisted_14$a = { class: "flex items-center space-x-3" };
|
|
|
3559
3563
|
const _hoisted_15$a = { class: "text-2xl" };
|
|
3560
3564
|
const _hoisted_16$9 = { class: "font-medium text-gray-900" };
|
|
3561
3565
|
const _hoisted_17$9 = { class: "text-sm text-gray-500" };
|
|
3562
|
-
const _hoisted_18$
|
|
3566
|
+
const _hoisted_18$7 = {
|
|
3563
3567
|
key: 2,
|
|
3564
3568
|
class: "text-center"
|
|
3565
3569
|
};
|
|
@@ -3924,7 +3928,7 @@ const _sfc_main$k = /* @__PURE__ */ vue.defineComponent({
|
|
|
3924
3928
|
])
|
|
3925
3929
|
])
|
|
3926
3930
|
])) : vue.createCommentVNode("", true),
|
|
3927
|
-
selectedMethod.value?.device_type === "email" && !emailCodeSent.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_18$
|
|
3931
|
+
selectedMethod.value?.device_type === "email" && !emailCodeSent.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_18$7, [
|
|
3928
3932
|
_cache[10] || (_cache[10] = vue.createElementVNode("p", { class: "text-sm text-gray-600 mb-4" }, "Click below to receive your verification code", -1)),
|
|
3929
3933
|
vue.createVNode(vue.unref(StrandsUiButton), {
|
|
3930
3934
|
variant: "primary",
|
|
@@ -4258,58 +4262,58 @@ function useOAuthProviders(options = {}) {
|
|
|
4258
4262
|
getProviderIcon
|
|
4259
4263
|
};
|
|
4260
4264
|
}
|
|
4261
|
-
const _hoisted_1$h = { class: "
|
|
4262
|
-
const _hoisted_2$g = {
|
|
4263
|
-
const _hoisted_3$g = {
|
|
4265
|
+
const _hoisted_1$h = { class: "text-center mb-8" };
|
|
4266
|
+
const _hoisted_2$g = {
|
|
4264
4267
|
key: 0,
|
|
4265
4268
|
class: "mb-8"
|
|
4266
4269
|
};
|
|
4267
|
-
const
|
|
4270
|
+
const _hoisted_3$g = {
|
|
4268
4271
|
key: 0,
|
|
4269
4272
|
class: "space-y-3 mb-6"
|
|
4270
4273
|
};
|
|
4271
|
-
const
|
|
4272
|
-
const
|
|
4274
|
+
const _hoisted_4$e = { class: "w-5 h-5 flex items-center justify-center" };
|
|
4275
|
+
const _hoisted_5$d = {
|
|
4273
4276
|
key: 0,
|
|
4274
4277
|
class: "w-5 h-5"
|
|
4275
4278
|
};
|
|
4276
|
-
const
|
|
4277
|
-
const
|
|
4279
|
+
const _hoisted_6$c = ["src", "alt"];
|
|
4280
|
+
const _hoisted_7$c = {
|
|
4278
4281
|
key: 1,
|
|
4279
4282
|
viewBox: "0 0 24 24",
|
|
4280
4283
|
class: "w-5 h-5"
|
|
4281
4284
|
};
|
|
4282
|
-
const
|
|
4285
|
+
const _hoisted_8$a = {
|
|
4283
4286
|
key: 2,
|
|
4284
4287
|
class: "w-5 h-5 fill-current",
|
|
4285
4288
|
viewBox: "0 0 24 24"
|
|
4286
4289
|
};
|
|
4287
|
-
const
|
|
4290
|
+
const _hoisted_9$a = {
|
|
4288
4291
|
key: 3,
|
|
4289
4292
|
class: "w-5 h-5 rounded-full bg-neutral-300 flex items-center justify-center"
|
|
4290
4293
|
};
|
|
4291
|
-
const
|
|
4292
|
-
const
|
|
4293
|
-
const
|
|
4294
|
+
const _hoisted_10$a = { class: "text-xs font-semibold text-neutral-600" };
|
|
4295
|
+
const _hoisted_11$a = { class: "font-medium" };
|
|
4296
|
+
const _hoisted_12$a = {
|
|
4294
4297
|
key: 0,
|
|
4295
4298
|
class: "divider-with-text"
|
|
4296
4299
|
};
|
|
4297
|
-
const
|
|
4298
|
-
const
|
|
4300
|
+
const _hoisted_13$a = { class: "divider-text" };
|
|
4301
|
+
const _hoisted_14$9 = {
|
|
4299
4302
|
key: 0,
|
|
4300
4303
|
class: "mb-4"
|
|
4301
4304
|
};
|
|
4302
|
-
const
|
|
4303
|
-
const
|
|
4305
|
+
const _hoisted_15$9 = { class: "flex items-center justify-between mb-2" };
|
|
4306
|
+
const _hoisted_16$8 = {
|
|
4304
4307
|
key: 0,
|
|
4305
4308
|
class: "mt-8 text-center"
|
|
4306
4309
|
};
|
|
4307
|
-
const
|
|
4310
|
+
const _hoisted_17$8 = { class: "text-neutral-400 text-sm" };
|
|
4308
4311
|
const _sfc_main$j = /* @__PURE__ */ vue.defineComponent({
|
|
4309
4312
|
__name: "StrandsAuth",
|
|
4310
4313
|
props: {
|
|
4311
4314
|
mode: { default: "signin" },
|
|
4312
4315
|
redirectUrl: {},
|
|
4316
|
+
inModal: { type: Boolean, default: false },
|
|
4313
4317
|
config: {}
|
|
4314
4318
|
},
|
|
4315
4319
|
emits: ["success", "error", "forgot-password", "password-reset-sent", "mode-changed"],
|
|
@@ -4485,257 +4489,258 @@ const _sfc_main$j = /* @__PURE__ */ vue.defineComponent({
|
|
|
4485
4489
|
emit("mode-changed", newMode);
|
|
4486
4490
|
});
|
|
4487
4491
|
return (_ctx, _cache) => {
|
|
4488
|
-
return vue.openBlock(), vue.createElementBlock("div",
|
|
4489
|
-
vue.
|
|
4490
|
-
|
|
4491
|
-
|
|
4492
|
-
|
|
4493
|
-
|
|
4494
|
-
|
|
4495
|
-
|
|
4496
|
-
|
|
4497
|
-
|
|
4498
|
-
|
|
4499
|
-
class: "text-3xl font-bold text-gradient mb-2"
|
|
4500
|
-
}, vue.toDisplayString(isPasswordReset.value ? "Reset password" : isSignUp.value ? "Create account" : "Welcome back"), 1))
|
|
4501
|
-
]),
|
|
4502
|
-
_: 1
|
|
4503
|
-
}),
|
|
4504
|
-
vue.createVNode(vue.Transition, {
|
|
4505
|
-
name: "fade",
|
|
4506
|
-
mode: "out-in"
|
|
4507
|
-
}, {
|
|
4508
|
-
default: vue.withCtx(() => [
|
|
4509
|
-
(vue.openBlock(), vue.createElementBlock("p", {
|
|
4510
|
-
key: currentMode.value,
|
|
4511
|
-
class: "text-neutral-600"
|
|
4512
|
-
}, vue.toDisplayString(isPasswordReset.value ? "Enter your email address and we'll send you a link to reset your password" : isSignUp.value ? "We'll send you a magic link to get started" : "Sign in to your account to continue"), 1))
|
|
4513
|
-
]),
|
|
4514
|
-
_: 1
|
|
4515
|
-
})
|
|
4516
|
-
]),
|
|
4517
|
-
vue.createVNode(vue.Transition, { name: "height-fade" }, {
|
|
4518
|
-
default: vue.withCtx(() => [
|
|
4519
|
-
!isPasswordReset.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_3$g, [
|
|
4520
|
-
vue.createVNode(vue.unref(_sfc_main$s), {
|
|
4521
|
-
modelValue: currentMode.value,
|
|
4522
|
-
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => currentMode.value = $event),
|
|
4523
|
-
tabs: [
|
|
4524
|
-
{ label: "Sign In", value: "signin" },
|
|
4525
|
-
{ label: "Sign Up", value: "signup" }
|
|
4526
|
-
]
|
|
4527
|
-
}, null, 8, ["modelValue"])
|
|
4528
|
-
])) : vue.createCommentVNode("", true)
|
|
4529
|
-
]),
|
|
4530
|
-
_: 1
|
|
4531
|
-
}),
|
|
4532
|
-
vue.createVNode(vue.Transition, { name: "height-fade" }, {
|
|
4533
|
-
default: vue.withCtx(() => [
|
|
4534
|
-
!isPasswordReset.value && displayProviders.value?.length ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_4$e, [
|
|
4535
|
-
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(displayProviders.value, (provider) => {
|
|
4536
|
-
return vue.openBlock(), vue.createBlock(vue.unref(StrandsUiButton), {
|
|
4537
|
-
key: provider.id,
|
|
4538
|
-
variant: "outline",
|
|
4539
|
-
"full-width": "",
|
|
4540
|
-
disabled: vue.unref(oauthLoading),
|
|
4541
|
-
onClick: ($event) => handleOAuthAuth(provider.id),
|
|
4542
|
-
class: "btn-oauth group"
|
|
4543
|
-
}, {
|
|
4544
|
-
default: vue.withCtx(() => [
|
|
4545
|
-
vue.createElementVNode("div", _hoisted_5$d, [
|
|
4546
|
-
provider.icon || provider.iconUrl ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_6$c, [
|
|
4547
|
-
vue.createElementVNode("img", {
|
|
4548
|
-
src: provider.icon || provider.iconUrl,
|
|
4549
|
-
alt: `${provider.displayName || provider.name} icon`,
|
|
4550
|
-
class: "w-5 h-5"
|
|
4551
|
-
}, null, 8, _hoisted_7$c)
|
|
4552
|
-
])) : provider.id === "google" ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_8$a, _cache[6] || (_cache[6] = [
|
|
4553
|
-
vue.createElementVNode("path", {
|
|
4554
|
-
fill: "#4285F4",
|
|
4555
|
-
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"
|
|
4556
|
-
}, null, -1),
|
|
4557
|
-
vue.createElementVNode("path", {
|
|
4558
|
-
fill: "#34A853",
|
|
4559
|
-
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"
|
|
4560
|
-
}, null, -1),
|
|
4561
|
-
vue.createElementVNode("path", {
|
|
4562
|
-
fill: "#FBBC05",
|
|
4563
|
-
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"
|
|
4564
|
-
}, null, -1),
|
|
4565
|
-
vue.createElementVNode("path", {
|
|
4566
|
-
fill: "#EA4335",
|
|
4567
|
-
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"
|
|
4568
|
-
}, null, -1)
|
|
4569
|
-
]))) : provider.id === "github" ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_9$a, _cache[7] || (_cache[7] = [
|
|
4570
|
-
vue.createElementVNode("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)
|
|
4571
|
-
]))) : (vue.openBlock(), vue.createElementBlock("div", _hoisted_10$a, [
|
|
4572
|
-
vue.createElementVNode("span", _hoisted_11$a, vue.toDisplayString((provider.displayName || provider.name).charAt(0).toUpperCase()), 1)
|
|
4573
|
-
]))
|
|
4574
|
-
]),
|
|
4575
|
-
vue.createElementVNode("span", _hoisted_12$a, " Continue with " + vue.toDisplayString(provider.displayName || provider.name.charAt(0).toUpperCase() + provider.name.slice(1)), 1)
|
|
4576
|
-
]),
|
|
4577
|
-
_: 2
|
|
4578
|
-
}, 1032, ["disabled", "onClick"]);
|
|
4579
|
-
}), 128))
|
|
4580
|
-
])) : vue.createCommentVNode("", true)
|
|
4581
|
-
]),
|
|
4582
|
-
_: 1
|
|
4583
|
-
}),
|
|
4584
|
-
vue.createVNode(vue.Transition, { name: "height-fade" }, {
|
|
4492
|
+
return vue.openBlock(), vue.createElementBlock("div", {
|
|
4493
|
+
class: vue.normalizeClass(props.inModal ? "auth-container-modal w-full min-w-90" : "auth-container w-full min-w-100 max-w-md mx-auto animate-slide-up")
|
|
4494
|
+
}, [
|
|
4495
|
+
vue.createElementVNode("div", {
|
|
4496
|
+
class: vue.normalizeClass(props.inModal ? "auth-content-modal" : "auth-content card-modern")
|
|
4497
|
+
}, [
|
|
4498
|
+
vue.createElementVNode("div", _hoisted_1$h, [
|
|
4499
|
+
vue.createVNode(vue.Transition, {
|
|
4500
|
+
name: "fade",
|
|
4501
|
+
mode: "out-in"
|
|
4502
|
+
}, {
|
|
4585
4503
|
default: vue.withCtx(() => [
|
|
4586
|
-
|
|
4587
|
-
|
|
4588
|
-
|
|
4504
|
+
(vue.openBlock(), vue.createElementBlock("h1", {
|
|
4505
|
+
key: currentMode.value,
|
|
4506
|
+
class: "text-3xl font-bold text-gradient mb-2"
|
|
4507
|
+
}, vue.toDisplayString(isPasswordReset.value ? "Reset password" : isSignUp.value ? "Create account" : "Welcome back"), 1))
|
|
4589
4508
|
]),
|
|
4590
4509
|
_: 1
|
|
4591
4510
|
}),
|
|
4592
|
-
vue.createElementVNode("form", {
|
|
4593
|
-
onSubmit: vue.withModifiers(handleAuth, ["prevent"]),
|
|
4594
|
-
class: "space-y-6"
|
|
4595
|
-
}, [
|
|
4596
|
-
vue.createElementVNode("div", null, [
|
|
4597
|
-
vue.createElementVNode("div", {
|
|
4598
|
-
class: vue.normalizeClass(["email-field-spacing", !isPasswordReset.value && !isSignUp.value ? "has-password" : "no-password"])
|
|
4599
|
-
}, [
|
|
4600
|
-
vue.createVNode(vue.unref(StrandsUiInput), {
|
|
4601
|
-
modelValue: form.email,
|
|
4602
|
-
"onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => form.email = $event),
|
|
4603
|
-
type: "email",
|
|
4604
|
-
label: "Email address",
|
|
4605
|
-
placeholder: "Enter your email",
|
|
4606
|
-
required: "",
|
|
4607
|
-
autocomplete: "email",
|
|
4608
|
-
error: error.value && !form.email ? "Email is required" : ""
|
|
4609
|
-
}, null, 8, ["modelValue", "error"])
|
|
4610
|
-
], 2),
|
|
4611
|
-
vue.createVNode(vue.Transition, { name: "password-fade" }, {
|
|
4612
|
-
default: vue.withCtx(() => [
|
|
4613
|
-
!isPasswordReset.value && !isSignUp.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_15$9, [
|
|
4614
|
-
vue.createElementVNode("div", _hoisted_16$8, [
|
|
4615
|
-
_cache[9] || (_cache[9] = vue.createElementVNode("span", { class: "text-sm font-medium text-gray-700" }, "Password", -1)),
|
|
4616
|
-
vue.createVNode(vue.unref(_sfc_main$t), {
|
|
4617
|
-
variant: "primary",
|
|
4618
|
-
size: "sm",
|
|
4619
|
-
onClick: _cache[2] || (_cache[2] = ($event) => currentMode.value = "reset-password")
|
|
4620
|
-
}, {
|
|
4621
|
-
default: vue.withCtx(() => _cache[8] || (_cache[8] = [
|
|
4622
|
-
vue.createTextVNode(" Forgot password? ", -1)
|
|
4623
|
-
])),
|
|
4624
|
-
_: 1,
|
|
4625
|
-
__: [8]
|
|
4626
|
-
})
|
|
4627
|
-
]),
|
|
4628
|
-
vue.createVNode(vue.unref(StrandsUiInput), {
|
|
4629
|
-
modelValue: form.password,
|
|
4630
|
-
"onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => form.password = $event),
|
|
4631
|
-
type: "password",
|
|
4632
|
-
placeholder: "Enter your password",
|
|
4633
|
-
required: "",
|
|
4634
|
-
autocomplete: "current-password",
|
|
4635
|
-
error: error.value && !form.password ? "Password is required" : ""
|
|
4636
|
-
}, null, 8, ["modelValue", "error"])
|
|
4637
|
-
])) : vue.createCommentVNode("", true)
|
|
4638
|
-
]),
|
|
4639
|
-
_: 1
|
|
4640
|
-
})
|
|
4641
|
-
]),
|
|
4642
|
-
vue.createVNode(vue.unref(StrandsUiButton), {
|
|
4643
|
-
type: "submit",
|
|
4644
|
-
variant: "primary",
|
|
4645
|
-
"full-width": "",
|
|
4646
|
-
disabled: buttonLoading.value || !isFormValid.value,
|
|
4647
|
-
loading: buttonLoading.value,
|
|
4648
|
-
"loading-text": vue.unref(loadingMessage)
|
|
4649
|
-
}, {
|
|
4650
|
-
default: vue.withCtx(() => [
|
|
4651
|
-
vue.createTextVNode(vue.toDisplayString(isPasswordReset.value ? isPasswordResetSubmitted.value ? "Link sent!" : "Send reset link" : isSignUp.value ? "Send magic link" : "Sign in"), 1)
|
|
4652
|
-
]),
|
|
4653
|
-
_: 1
|
|
4654
|
-
}, 8, ["disabled", "loading", "loading-text"])
|
|
4655
|
-
], 32),
|
|
4656
4511
|
vue.createVNode(vue.Transition, {
|
|
4657
|
-
name: "
|
|
4512
|
+
name: "fade",
|
|
4658
4513
|
mode: "out-in"
|
|
4659
4514
|
}, {
|
|
4660
4515
|
default: vue.withCtx(() => [
|
|
4661
|
-
|
|
4662
|
-
key:
|
|
4663
|
-
|
|
4664
|
-
|
|
4665
|
-
class: "mt-6 animate-fade-in"
|
|
4666
|
-
}, null, 8, ["message"])) : vue.createCommentVNode("", true)
|
|
4516
|
+
(vue.openBlock(), vue.createElementBlock("p", {
|
|
4517
|
+
key: currentMode.value,
|
|
4518
|
+
class: "text-neutral-600"
|
|
4519
|
+
}, vue.toDisplayString(isPasswordReset.value ? "Enter your email address and we'll send you a link to reset your password" : isSignUp.value ? "We'll send you a magic link to get started" : "Sign in to your account to continue"), 1))
|
|
4667
4520
|
]),
|
|
4668
4521
|
_: 1
|
|
4669
|
-
})
|
|
4670
|
-
|
|
4671
|
-
|
|
4672
|
-
|
|
4673
|
-
|
|
4674
|
-
|
|
4675
|
-
|
|
4522
|
+
})
|
|
4523
|
+
]),
|
|
4524
|
+
vue.createVNode(vue.Transition, { name: "height-fade" }, {
|
|
4525
|
+
default: vue.withCtx(() => [
|
|
4526
|
+
!isPasswordReset.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_2$g, [
|
|
4527
|
+
vue.createVNode(vue.unref(_sfc_main$s), {
|
|
4528
|
+
modelValue: currentMode.value,
|
|
4529
|
+
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => currentMode.value = $event),
|
|
4530
|
+
tabs: [
|
|
4531
|
+
{ label: "Sign In", value: "signin" },
|
|
4532
|
+
{ label: "Sign Up", value: "signup" }
|
|
4533
|
+
]
|
|
4534
|
+
}, null, 8, ["modelValue"])
|
|
4535
|
+
])) : vue.createCommentVNode("", true)
|
|
4536
|
+
]),
|
|
4537
|
+
_: 1
|
|
4538
|
+
}),
|
|
4539
|
+
vue.createVNode(vue.Transition, { name: "height-fade" }, {
|
|
4540
|
+
default: vue.withCtx(() => [
|
|
4541
|
+
!isPasswordReset.value && displayProviders.value?.length ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_3$g, [
|
|
4542
|
+
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(displayProviders.value, (provider) => {
|
|
4543
|
+
return vue.openBlock(), vue.createBlock(vue.unref(StrandsUiButton), {
|
|
4544
|
+
key: provider.id,
|
|
4545
|
+
variant: "outline",
|
|
4546
|
+
"full-width": "",
|
|
4547
|
+
disabled: vue.unref(oauthLoading),
|
|
4548
|
+
onClick: ($event) => handleOAuthAuth(provider.id),
|
|
4549
|
+
class: "btn-oauth group"
|
|
4676
4550
|
}, {
|
|
4677
|
-
default: vue.withCtx(() =>
|
|
4678
|
-
vue.createElementVNode("
|
|
4679
|
-
|
|
4680
|
-
|
|
4681
|
-
|
|
4682
|
-
|
|
4683
|
-
|
|
4684
|
-
|
|
4685
|
-
|
|
4686
|
-
"
|
|
4687
|
-
|
|
4688
|
-
|
|
4689
|
-
|
|
4690
|
-
|
|
4691
|
-
|
|
4692
|
-
|
|
4693
|
-
|
|
4694
|
-
|
|
4695
|
-
|
|
4696
|
-
|
|
4697
|
-
|
|
4698
|
-
|
|
4699
|
-
|
|
4700
|
-
|
|
4701
|
-
|
|
4702
|
-
|
|
4703
|
-
|
|
4704
|
-
|
|
4705
|
-
|
|
4706
|
-
|
|
4707
|
-
|
|
4708
|
-
|
|
4709
|
-
|
|
4710
|
-
|
|
4711
|
-
|
|
4712
|
-
|
|
4713
|
-
|
|
4714
|
-
|
|
4715
|
-
|
|
4716
|
-
|
|
4717
|
-
|
|
4718
|
-
|
|
4551
|
+
default: vue.withCtx(() => [
|
|
4552
|
+
vue.createElementVNode("div", _hoisted_4$e, [
|
|
4553
|
+
provider.icon || provider.iconUrl ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_5$d, [
|
|
4554
|
+
vue.createElementVNode("img", {
|
|
4555
|
+
src: provider.icon || provider.iconUrl,
|
|
4556
|
+
alt: `${provider.displayName || provider.name} icon`,
|
|
4557
|
+
class: "w-5 h-5"
|
|
4558
|
+
}, null, 8, _hoisted_6$c)
|
|
4559
|
+
])) : provider.id === "google" ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_7$c, _cache[6] || (_cache[6] = [
|
|
4560
|
+
vue.createElementVNode("path", {
|
|
4561
|
+
fill: "#4285F4",
|
|
4562
|
+
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"
|
|
4563
|
+
}, null, -1),
|
|
4564
|
+
vue.createElementVNode("path", {
|
|
4565
|
+
fill: "#34A853",
|
|
4566
|
+
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"
|
|
4567
|
+
}, null, -1),
|
|
4568
|
+
vue.createElementVNode("path", {
|
|
4569
|
+
fill: "#FBBC05",
|
|
4570
|
+
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"
|
|
4571
|
+
}, null, -1),
|
|
4572
|
+
vue.createElementVNode("path", {
|
|
4573
|
+
fill: "#EA4335",
|
|
4574
|
+
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"
|
|
4575
|
+
}, null, -1)
|
|
4576
|
+
]))) : provider.id === "github" ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_8$a, _cache[7] || (_cache[7] = [
|
|
4577
|
+
vue.createElementVNode("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)
|
|
4578
|
+
]))) : (vue.openBlock(), vue.createElementBlock("div", _hoisted_9$a, [
|
|
4579
|
+
vue.createElementVNode("span", _hoisted_10$a, vue.toDisplayString((provider.displayName || provider.name).charAt(0).toUpperCase()), 1)
|
|
4580
|
+
]))
|
|
4581
|
+
]),
|
|
4582
|
+
vue.createElementVNode("span", _hoisted_11$a, " Continue with " + vue.toDisplayString(provider.displayName || provider.name.charAt(0).toUpperCase() + provider.name.slice(1)), 1)
|
|
4583
|
+
]),
|
|
4584
|
+
_: 2
|
|
4585
|
+
}, 1032, ["disabled", "onClick"]);
|
|
4586
|
+
}), 128))
|
|
4587
|
+
])) : vue.createCommentVNode("", true)
|
|
4588
|
+
]),
|
|
4589
|
+
_: 1
|
|
4590
|
+
}),
|
|
4591
|
+
vue.createVNode(vue.Transition, { name: "height-fade" }, {
|
|
4592
|
+
default: vue.withCtx(() => [
|
|
4593
|
+
!isPasswordReset.value && displayProviders.value?.length ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_12$a, [
|
|
4594
|
+
vue.createElementVNode("span", _hoisted_13$a, "Or " + vue.toDisplayString(isSignUp.value ? "create account" : "sign in") + " with email", 1)
|
|
4595
|
+
])) : vue.createCommentVNode("", true)
|
|
4596
|
+
]),
|
|
4597
|
+
_: 1
|
|
4598
|
+
}),
|
|
4599
|
+
vue.createElementVNode("form", {
|
|
4600
|
+
onSubmit: vue.withModifiers(handleAuth, ["prevent"]),
|
|
4601
|
+
class: "space-y-6"
|
|
4602
|
+
}, [
|
|
4603
|
+
vue.createElementVNode("div", null, [
|
|
4604
|
+
vue.createElementVNode("div", {
|
|
4605
|
+
class: vue.normalizeClass(["email-field-spacing", !isPasswordReset.value && !isSignUp.value ? "has-password" : "no-password"])
|
|
4606
|
+
}, [
|
|
4607
|
+
vue.createVNode(vue.unref(StrandsUiInput), {
|
|
4608
|
+
modelValue: form.email,
|
|
4609
|
+
"onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => form.email = $event),
|
|
4610
|
+
type: "email",
|
|
4611
|
+
label: "Email address",
|
|
4612
|
+
placeholder: "Enter your email",
|
|
4613
|
+
required: "",
|
|
4614
|
+
autocomplete: "email",
|
|
4615
|
+
error: error.value && !form.email ? "Email is required" : ""
|
|
4616
|
+
}, null, 8, ["modelValue", "error"])
|
|
4617
|
+
], 2),
|
|
4618
|
+
vue.createVNode(vue.Transition, { name: "password-fade" }, {
|
|
4619
|
+
default: vue.withCtx(() => [
|
|
4620
|
+
!isPasswordReset.value && !isSignUp.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_14$9, [
|
|
4621
|
+
vue.createElementVNode("div", _hoisted_15$9, [
|
|
4622
|
+
_cache[9] || (_cache[9] = vue.createElementVNode("span", { class: "text-sm font-medium text-gray-700" }, "Password", -1)),
|
|
4719
4623
|
vue.createVNode(vue.unref(_sfc_main$t), {
|
|
4720
4624
|
variant: "primary",
|
|
4721
|
-
|
|
4625
|
+
size: "sm",
|
|
4626
|
+
onClick: _cache[2] || (_cache[2] = ($event) => currentMode.value = "reset-password")
|
|
4722
4627
|
}, {
|
|
4723
|
-
default: vue.withCtx(() => _cache[
|
|
4724
|
-
vue.createTextVNode("
|
|
4628
|
+
default: vue.withCtx(() => _cache[8] || (_cache[8] = [
|
|
4629
|
+
vue.createTextVNode(" Forgot password? ", -1)
|
|
4725
4630
|
])),
|
|
4726
4631
|
_: 1,
|
|
4727
|
-
__: [
|
|
4728
|
-
}
|
|
4729
|
-
])
|
|
4730
|
-
|
|
4731
|
-
|
|
4732
|
-
|
|
4632
|
+
__: [8]
|
|
4633
|
+
})
|
|
4634
|
+
]),
|
|
4635
|
+
vue.createVNode(vue.unref(StrandsUiInput), {
|
|
4636
|
+
modelValue: form.password,
|
|
4637
|
+
"onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => form.password = $event),
|
|
4638
|
+
type: "password",
|
|
4639
|
+
placeholder: "Enter your password",
|
|
4640
|
+
required: "",
|
|
4641
|
+
autocomplete: "current-password",
|
|
4642
|
+
error: error.value && !form.password ? "Password is required" : ""
|
|
4643
|
+
}, null, 8, ["modelValue", "error"])
|
|
4644
|
+
])) : vue.createCommentVNode("", true)
|
|
4645
|
+
]),
|
|
4646
|
+
_: 1
|
|
4647
|
+
})
|
|
4648
|
+
]),
|
|
4649
|
+
vue.createVNode(vue.unref(StrandsUiButton), {
|
|
4650
|
+
type: "submit",
|
|
4651
|
+
variant: "primary",
|
|
4652
|
+
"full-width": "",
|
|
4653
|
+
disabled: buttonLoading.value || !isFormValid.value,
|
|
4654
|
+
loading: buttonLoading.value,
|
|
4655
|
+
"loading-text": vue.unref(loadingMessage)
|
|
4656
|
+
}, {
|
|
4657
|
+
default: vue.withCtx(() => [
|
|
4658
|
+
vue.createTextVNode(vue.toDisplayString(isPasswordReset.value ? isPasswordResetSubmitted.value ? "Link sent!" : "Send reset link" : isSignUp.value ? "Send magic link" : "Sign in"), 1)
|
|
4733
4659
|
]),
|
|
4734
4660
|
_: 1
|
|
4735
|
-
}, 8, ["
|
|
4736
|
-
]),
|
|
4737
|
-
|
|
4738
|
-
|
|
4661
|
+
}, 8, ["disabled", "loading", "loading-text"])
|
|
4662
|
+
], 32),
|
|
4663
|
+
vue.createVNode(vue.Transition, {
|
|
4664
|
+
name: "expand",
|
|
4665
|
+
mode: "out-in"
|
|
4666
|
+
}, {
|
|
4667
|
+
default: vue.withCtx(() => [
|
|
4668
|
+
isPasswordReset.value && isPasswordResetSubmitted.value ? (vue.openBlock(), vue.createBlock(vue.unref(_sfc_main$x), {
|
|
4669
|
+
key: "reset-success",
|
|
4670
|
+
variant: "success",
|
|
4671
|
+
message: `Check your email - We've sent a password reset link to ${form.email}`,
|
|
4672
|
+
class: "mt-6 animate-fade-in"
|
|
4673
|
+
}, null, 8, ["message"])) : vue.createCommentVNode("", true)
|
|
4674
|
+
]),
|
|
4675
|
+
_: 1
|
|
4676
|
+
}),
|
|
4677
|
+
vue.createVNode(vue.Transition, { name: "height-fade" }, {
|
|
4678
|
+
default: vue.withCtx(() => [
|
|
4679
|
+
isPasswordReset.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_16$8, [
|
|
4680
|
+
vue.createVNode(vue.unref(_sfc_main$t), {
|
|
4681
|
+
onClick: _cache[4] || (_cache[4] = ($event) => currentMode.value = "signin"),
|
|
4682
|
+
class: "inline-flex items-center gap-2"
|
|
4683
|
+
}, {
|
|
4684
|
+
default: vue.withCtx(() => _cache[10] || (_cache[10] = [
|
|
4685
|
+
vue.createElementVNode("svg", {
|
|
4686
|
+
class: "w-4 h-4",
|
|
4687
|
+
fill: "none",
|
|
4688
|
+
stroke: "currentColor",
|
|
4689
|
+
viewBox: "0 0 24 24"
|
|
4690
|
+
}, [
|
|
4691
|
+
vue.createElementVNode("path", {
|
|
4692
|
+
"stroke-linecap": "round",
|
|
4693
|
+
"stroke-linejoin": "round",
|
|
4694
|
+
"stroke-width": "2",
|
|
4695
|
+
d: "M15 19l-7-7 7-7"
|
|
4696
|
+
})
|
|
4697
|
+
], -1),
|
|
4698
|
+
vue.createTextVNode(" Back to sign in ", -1)
|
|
4699
|
+
])),
|
|
4700
|
+
_: 1,
|
|
4701
|
+
__: [10]
|
|
4702
|
+
})
|
|
4703
|
+
])) : vue.createCommentVNode("", true)
|
|
4704
|
+
]),
|
|
4705
|
+
_: 1
|
|
4706
|
+
}),
|
|
4707
|
+
error.value ? (vue.openBlock(), vue.createBlock(vue.unref(_sfc_main$x), {
|
|
4708
|
+
key: 0,
|
|
4709
|
+
variant: "error",
|
|
4710
|
+
message: error.value,
|
|
4711
|
+
class: "mt-6 animate-fade-in",
|
|
4712
|
+
dismissible: "",
|
|
4713
|
+
onDismiss: _cache[5] || (_cache[5] = ($event) => error.value = "")
|
|
4714
|
+
}, null, 8, ["message"])) : vue.createCommentVNode("", true),
|
|
4715
|
+
vue.createVNode(_sfc_main$l, {
|
|
4716
|
+
config: props.config
|
|
4717
|
+
}, {
|
|
4718
|
+
default: vue.withCtx(() => [
|
|
4719
|
+
vue.unref(getSupportEmail)() ? (vue.openBlock(), vue.createBlock(vue.Transition, {
|
|
4720
|
+
key: 0,
|
|
4721
|
+
name: "support-fade"
|
|
4722
|
+
}, {
|
|
4723
|
+
default: vue.withCtx(() => [
|
|
4724
|
+
vue.createElementVNode("p", _hoisted_17$8, [
|
|
4725
|
+
_cache[12] || (_cache[12] = vue.createTextVNode(" Need help? ", -1)),
|
|
4726
|
+
vue.createVNode(vue.unref(_sfc_main$t), {
|
|
4727
|
+
variant: "primary",
|
|
4728
|
+
href: `mailto:${vue.unref(getSupportEmail)()}`
|
|
4729
|
+
}, {
|
|
4730
|
+
default: vue.withCtx(() => _cache[11] || (_cache[11] = [
|
|
4731
|
+
vue.createTextVNode(" Contact Support ", -1)
|
|
4732
|
+
])),
|
|
4733
|
+
_: 1,
|
|
4734
|
+
__: [11]
|
|
4735
|
+
}, 8, ["href"])
|
|
4736
|
+
])
|
|
4737
|
+
]),
|
|
4738
|
+
_: 1
|
|
4739
|
+
})) : vue.createCommentVNode("", true)
|
|
4740
|
+
]),
|
|
4741
|
+
_: 1
|
|
4742
|
+
}, 8, ["config"])
|
|
4743
|
+
], 2),
|
|
4739
4744
|
vue.createVNode(_sfc_main$k, {
|
|
4740
4745
|
show: showMfaVerification.value,
|
|
4741
4746
|
"available-mfa-methods": vue.unref(availableMfaMethods),
|
|
@@ -4743,11 +4748,11 @@ const _sfc_main$j = /* @__PURE__ */ vue.defineComponent({
|
|
|
4743
4748
|
onClose: handleMfaClose,
|
|
4744
4749
|
onError: handleMfaError
|
|
4745
4750
|
}, null, 8, ["show", "available-mfa-methods"])
|
|
4746
|
-
]);
|
|
4751
|
+
], 2);
|
|
4747
4752
|
};
|
|
4748
4753
|
}
|
|
4749
4754
|
});
|
|
4750
|
-
const StrandsAuth = /* @__PURE__ */ _export_sfc(_sfc_main$j, [["__scopeId", "data-v-
|
|
4755
|
+
const StrandsAuth = /* @__PURE__ */ _export_sfc(_sfc_main$j, [["__scopeId", "data-v-d0fd51f5"]]);
|
|
4751
4756
|
const _hoisted_1$g = { class: "w-full min-w-100 max-w-md mx-auto animate-slide-up" };
|
|
4752
4757
|
const _hoisted_2$f = {
|
|
4753
4758
|
key: 0,
|
|
@@ -11956,7 +11961,7 @@ const _sfc_main$5 = /* @__PURE__ */ vue.defineComponent({
|
|
|
11956
11961
|
user: vue.unref(user),
|
|
11957
11962
|
signOut: vue.unref(signOut)
|
|
11958
11963
|
})
|
|
11959
|
-
])) : _ctx.showFallback && !showLoading.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_2$2, [
|
|
11964
|
+
])) : !vue.unref(isAuthenticated) && _ctx.showFallback && !showLoading.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_2$2, [
|
|
11960
11965
|
vue.renderSlot(_ctx.$slots, "fallback", { signIn }, () => [
|
|
11961
11966
|
vue.createElementVNode("div", { class: "text-center py-8" }, [
|
|
11962
11967
|
_cache[0] || (_cache[0] = vue.createStaticVNode('<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)),
|
|
@@ -12276,14 +12281,16 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
|
12276
12281
|
__name: "StrandsUserButton",
|
|
12277
12282
|
props: {
|
|
12278
12283
|
hideUser: { type: Boolean, default: false },
|
|
12279
|
-
variant: { default: "minimal" }
|
|
12284
|
+
variant: { default: "minimal" },
|
|
12285
|
+
redirectUrl: { default: "/" }
|
|
12280
12286
|
},
|
|
12281
|
-
emits: ["profile-updated", "signed-out"],
|
|
12287
|
+
emits: ["profile-updated", "signed-out", "signed-in"],
|
|
12282
12288
|
setup(__props, { emit: __emit }) {
|
|
12283
12289
|
const emit = __emit;
|
|
12284
12290
|
const { currentUser: user, signOut } = useStrandsAuth.useStrandsAuth();
|
|
12285
12291
|
const showDropdown = vue.ref(false);
|
|
12286
12292
|
const showProfileModal = vue.ref(false);
|
|
12293
|
+
const showSignInModal = vue.ref(false);
|
|
12287
12294
|
const containerRef = vue.ref();
|
|
12288
12295
|
const profileButtonRef = vue.ref();
|
|
12289
12296
|
const displayName = vue.computed(() => {
|
|
@@ -12338,6 +12345,19 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
|
12338
12345
|
const handleProfileError = (error) => {
|
|
12339
12346
|
console.error("Profile error:", error);
|
|
12340
12347
|
};
|
|
12348
|
+
const openSignIn = () => {
|
|
12349
|
+
showSignInModal.value = true;
|
|
12350
|
+
};
|
|
12351
|
+
const closeSignIn = () => {
|
|
12352
|
+
showSignInModal.value = false;
|
|
12353
|
+
};
|
|
12354
|
+
const handleSignedIn = () => {
|
|
12355
|
+
closeSignIn();
|
|
12356
|
+
emit("signed-in");
|
|
12357
|
+
};
|
|
12358
|
+
const handleSignInError = (error) => {
|
|
12359
|
+
console.error("Sign in error:", error);
|
|
12360
|
+
};
|
|
12341
12361
|
const handleSignOut = async () => {
|
|
12342
12362
|
try {
|
|
12343
12363
|
await signOut();
|
|
@@ -12363,206 +12383,272 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
|
12363
12383
|
ref_key: "containerRef",
|
|
12364
12384
|
ref: containerRef
|
|
12365
12385
|
}, [
|
|
12366
|
-
vue.
|
|
12367
|
-
|
|
12368
|
-
|
|
12369
|
-
|
|
12370
|
-
|
|
12371
|
-
|
|
12372
|
-
|
|
12373
|
-
|
|
12374
|
-
|
|
12375
|
-
|
|
12376
|
-
|
|
12377
|
-
|
|
12378
|
-
}, [
|
|
12379
|
-
vue.createElementVNode("div", _hoisted_2, [
|
|
12380
|
-
!_ctx.hideUser ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_3, [
|
|
12381
|
-
vue.createElementVNode("div", _hoisted_4, vue.toDisplayString(displayName.value), 1)
|
|
12382
|
-
])) : vue.createCommentVNode("", true),
|
|
12383
|
-
vue.createElementVNode("div", _hoisted_5, [
|
|
12384
|
-
vue.createElementVNode("div", _hoisted_6, [
|
|
12385
|
-
vue.unref(user)?.avatar ? (vue.openBlock(), vue.createElementBlock("img", {
|
|
12386
|
-
key: 0,
|
|
12387
|
-
src: vue.unref(user).avatar,
|
|
12388
|
-
alt: `${vue.unref(user).firstName || vue.unref(user).email}'s avatar`,
|
|
12389
|
-
class: "w-8 h-8 rounded-full object-cover"
|
|
12390
|
-
}, null, 8, _hoisted_7)) : (vue.openBlock(), vue.createElementBlock("div", _hoisted_8, _cache[0] || (_cache[0] = [
|
|
12391
|
-
vue.createElementVNode("svg", {
|
|
12392
|
-
class: "w-5 h-5 text-gray-600",
|
|
12393
|
-
fill: "currentColor",
|
|
12394
|
-
viewBox: "0 0 20 20"
|
|
12395
|
-
}, [
|
|
12396
|
-
vue.createElementVNode("path", {
|
|
12397
|
-
"fill-rule": "evenodd",
|
|
12398
|
-
d: "M10 9a3 3 0 100-6 3 3 0 000 6zm-7 9a7 7 0 1114 0H3z",
|
|
12399
|
-
"clip-rule": "evenodd"
|
|
12400
|
-
})
|
|
12401
|
-
], -1)
|
|
12402
|
-
])))
|
|
12403
|
-
])
|
|
12404
|
-
]),
|
|
12405
|
-
(vue.openBlock(), vue.createElementBlock("svg", {
|
|
12406
|
-
class: vue.normalizeClass(["w-4 h-4 text-gray-400 transition-transform duration-150", { "transform rotate-180": showDropdown.value }]),
|
|
12407
|
-
fill: "none",
|
|
12408
|
-
stroke: "currentColor",
|
|
12409
|
-
viewBox: "0 0 24 24"
|
|
12410
|
-
}, _cache[1] || (_cache[1] = [
|
|
12411
|
-
vue.createElementVNode("path", {
|
|
12412
|
-
"stroke-linecap": "round",
|
|
12413
|
-
"stroke-linejoin": "round",
|
|
12414
|
-
"stroke-width": "2",
|
|
12415
|
-
d: "M19 9l-7 7-7-7"
|
|
12416
|
-
}, null, -1)
|
|
12417
|
-
]), 2))
|
|
12418
|
-
]),
|
|
12419
|
-
vue.createVNode(vue.Transition, { name: "dropdown" }, {
|
|
12420
|
-
default: vue.withCtx(() => [
|
|
12421
|
-
showDropdown.value ? (vue.openBlock(), vue.createElementBlock("div", {
|
|
12422
|
-
key: 0,
|
|
12423
|
-
class: "absolute right-0 top-full mt-2 w-72 bg-white rounded-lg shadow-lg ring-1 ring-black ring-opacity-5 focus:outline-none z-50",
|
|
12424
|
-
role: "menu",
|
|
12425
|
-
"aria-orientation": "vertical",
|
|
12426
|
-
onKeydown: [
|
|
12427
|
-
vue.withKeys(closeDropdown, ["escape"]),
|
|
12428
|
-
vue.withKeys(vue.withModifiers(focusPrevious, ["prevent"]), ["arrow-up"]),
|
|
12429
|
-
vue.withKeys(vue.withModifiers(focusNext, ["prevent"]), ["arrow-down"]),
|
|
12430
|
-
vue.withKeys(vue.withModifiers(focusFirst, ["prevent"]), ["home"]),
|
|
12431
|
-
vue.withKeys(vue.withModifiers(focusLast, ["prevent"]), ["end"])
|
|
12432
|
-
]
|
|
12386
|
+
vue.createVNode(vue.unref(_sfc_main$5), null, {
|
|
12387
|
+
fallback: vue.withCtx(() => [
|
|
12388
|
+
vue.createElementVNode("button", {
|
|
12389
|
+
onClick: openSignIn,
|
|
12390
|
+
class: "relative flex items-center gap-2 py-2 px-4 rounded-full bg-strands-500 text-white text-sm font-medium hover:bg-strands-600 focus:outline-none focus:ring-2 focus:ring-strands-500 focus:ring-offset-2 transition-all duration-150",
|
|
12391
|
+
"aria-label": "Sign in"
|
|
12392
|
+
}, _cache[8] || (_cache[8] = [
|
|
12393
|
+
vue.createElementVNode("svg", {
|
|
12394
|
+
class: "w-4 h-4",
|
|
12395
|
+
fill: "none",
|
|
12396
|
+
stroke: "currentColor",
|
|
12397
|
+
viewBox: "0 0 24 24"
|
|
12433
12398
|
}, [
|
|
12434
|
-
vue.createElementVNode("
|
|
12435
|
-
|
|
12436
|
-
|
|
12437
|
-
|
|
12438
|
-
|
|
12439
|
-
|
|
12440
|
-
|
|
12441
|
-
|
|
12442
|
-
|
|
12443
|
-
|
|
12444
|
-
|
|
12445
|
-
|
|
12446
|
-
|
|
12447
|
-
|
|
12448
|
-
|
|
12449
|
-
|
|
12450
|
-
|
|
12451
|
-
|
|
12452
|
-
|
|
12453
|
-
|
|
12454
|
-
|
|
12455
|
-
|
|
12456
|
-
|
|
12457
|
-
|
|
12458
|
-
|
|
12459
|
-
|
|
12460
|
-
|
|
12461
|
-
|
|
12462
|
-
|
|
12463
|
-
|
|
12464
|
-
|
|
12465
|
-
|
|
12466
|
-
|
|
12467
|
-
|
|
12468
|
-
])
|
|
12469
|
-
])
|
|
12470
|
-
|
|
12471
|
-
|
|
12472
|
-
|
|
12473
|
-
|
|
12474
|
-
|
|
12475
|
-
|
|
12476
|
-
|
|
12477
|
-
|
|
12478
|
-
|
|
12479
|
-
|
|
12480
|
-
|
|
12481
|
-
|
|
12482
|
-
|
|
12483
|
-
|
|
12484
|
-
|
|
12485
|
-
|
|
12486
|
-
|
|
12487
|
-
|
|
12488
|
-
|
|
12489
|
-
|
|
12490
|
-
|
|
12491
|
-
|
|
12492
|
-
|
|
12493
|
-
|
|
12494
|
-
|
|
12495
|
-
|
|
12496
|
-
|
|
12497
|
-
|
|
12498
|
-
|
|
12499
|
-
|
|
12500
|
-
|
|
12399
|
+
vue.createElementVNode("path", {
|
|
12400
|
+
"stroke-linecap": "round",
|
|
12401
|
+
"stroke-linejoin": "round",
|
|
12402
|
+
"stroke-width": "2",
|
|
12403
|
+
d: "M11 16l-4-4m0 0l4-4m-4 4h14m-5 4v1a3 3 0 01-3 3H6a3 3 0 01-3-3V7a3 3 0 013-3h7a3 3 0 013 3v1"
|
|
12404
|
+
})
|
|
12405
|
+
], -1),
|
|
12406
|
+
vue.createElementVNode("span", null, "Sign In", -1)
|
|
12407
|
+
])),
|
|
12408
|
+
vue.createVNode(vue.unref(StrandsUiModal), {
|
|
12409
|
+
open: showSignInModal.value,
|
|
12410
|
+
onClose: closeSignIn,
|
|
12411
|
+
"fullscreen-on-mobile": false
|
|
12412
|
+
}, {
|
|
12413
|
+
header: vue.withCtx(() => [
|
|
12414
|
+
vue.createElementVNode("div", { class: "flex items-center justify-between" }, [
|
|
12415
|
+
_cache[10] || (_cache[10] = vue.createElementVNode("h2", { class: "text-xl font-semibold text-gray-900" }, "Sign In", -1)),
|
|
12416
|
+
vue.createElementVNode("button", {
|
|
12417
|
+
onClick: closeSignIn,
|
|
12418
|
+
class: "p-1 rounded-lg text-gray-400 hover:text-gray-600 hover:bg-gray-100 transition-colors",
|
|
12419
|
+
"aria-label": "Close sign in"
|
|
12420
|
+
}, _cache[9] || (_cache[9] = [
|
|
12421
|
+
vue.createElementVNode("svg", {
|
|
12422
|
+
class: "w-5 h-5",
|
|
12423
|
+
fill: "none",
|
|
12424
|
+
stroke: "currentColor",
|
|
12425
|
+
viewBox: "0 0 24 24"
|
|
12426
|
+
}, [
|
|
12427
|
+
vue.createElementVNode("path", {
|
|
12428
|
+
"stroke-linecap": "round",
|
|
12429
|
+
"stroke-linejoin": "round",
|
|
12430
|
+
"stroke-width": "2",
|
|
12431
|
+
d: "M6 18L18 6M6 6l12 12"
|
|
12432
|
+
})
|
|
12433
|
+
], -1)
|
|
12434
|
+
]))
|
|
12435
|
+
])
|
|
12436
|
+
]),
|
|
12437
|
+
default: vue.withCtx(() => [
|
|
12438
|
+
vue.createVNode(vue.unref(StrandsAuth), {
|
|
12439
|
+
onSignedIn: handleSignedIn,
|
|
12440
|
+
onError: handleSignInError,
|
|
12441
|
+
"redirect-url": _ctx.redirectUrl,
|
|
12442
|
+
"in-modal": ""
|
|
12443
|
+
}, null, 8, ["redirect-url"])
|
|
12444
|
+
]),
|
|
12445
|
+
_: 1
|
|
12446
|
+
}, 8, ["open"])
|
|
12447
|
+
]),
|
|
12448
|
+
default: vue.withCtx(() => [
|
|
12449
|
+
vue.createElementVNode("button", {
|
|
12450
|
+
onClick: toggleDropdown,
|
|
12451
|
+
onKeydown: [
|
|
12452
|
+
vue.withKeys(toggleDropdown, ["enter"]),
|
|
12453
|
+
vue.withKeys(vue.withModifiers(toggleDropdown, ["prevent"]), ["space"]),
|
|
12454
|
+
vue.withKeys(closeDropdown, ["escape"]),
|
|
12455
|
+
vue.withKeys(vue.withModifiers(openDropdown, ["prevent"]), ["arrow-down"])
|
|
12456
|
+
],
|
|
12457
|
+
class: "relative flex items-center py-2 px-3 rounded-full bg-gray-100 text-gray-900 text-sm font-medium hover:bg-gray-300 focus:outline-none focus:ring-2 focus:ring-indigo-500 focus:ring-offset-2 transition-all duration-150",
|
|
12458
|
+
"aria-haspopup": "true",
|
|
12459
|
+
"aria-expanded": showDropdown.value,
|
|
12460
|
+
"aria-label": "User menu"
|
|
12461
|
+
}, [
|
|
12462
|
+
vue.createElementVNode("div", _hoisted_2, [
|
|
12463
|
+
!_ctx.hideUser ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_3, [
|
|
12464
|
+
vue.createElementVNode("div", _hoisted_4, vue.toDisplayString(displayName.value), 1)
|
|
12465
|
+
])) : vue.createCommentVNode("", true),
|
|
12466
|
+
vue.createElementVNode("div", _hoisted_5, [
|
|
12467
|
+
vue.createElementVNode("div", _hoisted_6, [
|
|
12468
|
+
vue.unref(user)?.avatar ? (vue.openBlock(), vue.createElementBlock("img", {
|
|
12469
|
+
key: 0,
|
|
12470
|
+
src: vue.unref(user).avatar,
|
|
12471
|
+
alt: `${vue.unref(user).firstName || vue.unref(user).email}'s avatar`,
|
|
12472
|
+
class: "w-8 h-8 rounded-full object-cover"
|
|
12473
|
+
}, null, 8, _hoisted_7)) : (vue.openBlock(), vue.createElementBlock("div", _hoisted_8, _cache[0] || (_cache[0] = [
|
|
12501
12474
|
vue.createElementVNode("svg", {
|
|
12502
|
-
class: "w-
|
|
12503
|
-
fill: "
|
|
12504
|
-
|
|
12505
|
-
viewBox: "0 0 24 24"
|
|
12475
|
+
class: "w-5 h-5 text-gray-600",
|
|
12476
|
+
fill: "currentColor",
|
|
12477
|
+
viewBox: "0 0 20 20"
|
|
12506
12478
|
}, [
|
|
12507
12479
|
vue.createElementVNode("path", {
|
|
12508
|
-
"
|
|
12509
|
-
"
|
|
12510
|
-
"
|
|
12511
|
-
d: "M17 16l4-4m0 0l-4-4m4 4H7m6 4v1a3 3 0 01-3 3H6a3 3 0 01-3-3V7a3 3 0 013-3h4a3 3 0 013 3v1"
|
|
12480
|
+
"fill-rule": "evenodd",
|
|
12481
|
+
d: "M10 9a3 3 0 100-6 3 3 0 000 6zm-7 9a7 7 0 1114 0H3z",
|
|
12482
|
+
"clip-rule": "evenodd"
|
|
12512
12483
|
})
|
|
12513
|
-
], -1)
|
|
12514
|
-
|
|
12515
|
-
]))
|
|
12484
|
+
], -1)
|
|
12485
|
+
])))
|
|
12516
12486
|
])
|
|
12517
|
-
])
|
|
12518
|
-
|
|
12519
|
-
|
|
12520
|
-
_: 1
|
|
12521
|
-
})
|
|
12522
|
-
], 40, _hoisted_1),
|
|
12523
|
-
vue.createVNode(vue.unref(StrandsUiModal), {
|
|
12524
|
-
open: showProfileModal.value,
|
|
12525
|
-
onClose: closeProfile,
|
|
12526
|
-
"fullscreen-on-mobile": false
|
|
12527
|
-
}, {
|
|
12528
|
-
header: vue.withCtx(() => [
|
|
12529
|
-
vue.createElementVNode("div", { class: "flex items-center justify-between" }, [
|
|
12530
|
-
_cache[7] || (_cache[7] = vue.createElementVNode("h2", { class: "text-xl font-semibold text-gray-900" }, "User Profile", -1)),
|
|
12531
|
-
vue.createElementVNode("button", {
|
|
12532
|
-
onClick: closeProfile,
|
|
12533
|
-
class: "p-1 rounded-lg text-gray-400 hover:text-gray-600 hover:bg-gray-100 transition-colors",
|
|
12534
|
-
"aria-label": "Close profile"
|
|
12535
|
-
}, _cache[6] || (_cache[6] = [
|
|
12536
|
-
vue.createElementVNode("svg", {
|
|
12537
|
-
class: "w-5 h-5",
|
|
12487
|
+
]),
|
|
12488
|
+
(vue.openBlock(), vue.createElementBlock("svg", {
|
|
12489
|
+
class: vue.normalizeClass(["w-4 h-4 text-gray-400 transition-transform duration-150", { "transform rotate-180": showDropdown.value }]),
|
|
12538
12490
|
fill: "none",
|
|
12539
12491
|
stroke: "currentColor",
|
|
12540
12492
|
viewBox: "0 0 24 24"
|
|
12541
|
-
}, [
|
|
12493
|
+
}, _cache[1] || (_cache[1] = [
|
|
12542
12494
|
vue.createElementVNode("path", {
|
|
12543
12495
|
"stroke-linecap": "round",
|
|
12544
12496
|
"stroke-linejoin": "round",
|
|
12545
12497
|
"stroke-width": "2",
|
|
12546
|
-
d: "
|
|
12547
|
-
})
|
|
12548
|
-
],
|
|
12549
|
-
])
|
|
12550
|
-
|
|
12551
|
-
|
|
12552
|
-
|
|
12553
|
-
|
|
12554
|
-
|
|
12555
|
-
|
|
12556
|
-
|
|
12557
|
-
|
|
12498
|
+
d: "M19 9l-7 7-7-7"
|
|
12499
|
+
}, null, -1)
|
|
12500
|
+
]), 2))
|
|
12501
|
+
]),
|
|
12502
|
+
vue.createVNode(vue.Transition, { name: "dropdown" }, {
|
|
12503
|
+
default: vue.withCtx(() => [
|
|
12504
|
+
showDropdown.value ? (vue.openBlock(), vue.createElementBlock("div", {
|
|
12505
|
+
key: 0,
|
|
12506
|
+
class: "absolute right-0 top-full mt-2 w-72 bg-white rounded-lg shadow-lg ring-1 ring-black ring-opacity-5 focus:outline-none z-50",
|
|
12507
|
+
role: "menu",
|
|
12508
|
+
"aria-orientation": "vertical",
|
|
12509
|
+
onKeydown: [
|
|
12510
|
+
vue.withKeys(closeDropdown, ["escape"]),
|
|
12511
|
+
vue.withKeys(vue.withModifiers(focusPrevious, ["prevent"]), ["arrow-up"]),
|
|
12512
|
+
vue.withKeys(vue.withModifiers(focusNext, ["prevent"]), ["arrow-down"]),
|
|
12513
|
+
vue.withKeys(vue.withModifiers(focusFirst, ["prevent"]), ["home"]),
|
|
12514
|
+
vue.withKeys(vue.withModifiers(focusLast, ["prevent"]), ["end"])
|
|
12515
|
+
]
|
|
12516
|
+
}, [
|
|
12517
|
+
vue.createElementVNode("div", _hoisted_10, [
|
|
12518
|
+
vue.createElementVNode("div", _hoisted_11, [
|
|
12519
|
+
vue.unref(user) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_12, [
|
|
12520
|
+
vue.createVNode(vue.unref(StrandsUiLevelProgress), {
|
|
12521
|
+
size: 80,
|
|
12522
|
+
value: vue.unref(user).xp,
|
|
12523
|
+
max: vue.unref(user).next_level_xp,
|
|
12524
|
+
level: vue.unref(user).level,
|
|
12525
|
+
"level-label": `LEVEL ${vue.unref(user).level}`,
|
|
12526
|
+
"user-settings": vue.unref(user).settings,
|
|
12527
|
+
class: "absolute z-10 top-1/2 left-1/2 transform -translate-x-1/2 -translate-y-1/2 pointer-events-none"
|
|
12528
|
+
}, null, 8, ["value", "max", "level", "level-label", "user-settings"]),
|
|
12529
|
+
vue.unref(user)?.avatar ? (vue.openBlock(), vue.createElementBlock("img", {
|
|
12530
|
+
key: 0,
|
|
12531
|
+
src: vue.unref(user).avatar,
|
|
12532
|
+
alt: `${vue.unref(user).firstName || vue.unref(user).email}'s avatar`,
|
|
12533
|
+
class: "w-14 h-14 rounded-full object-cover"
|
|
12534
|
+
}, null, 8, _hoisted_13)) : (vue.openBlock(), vue.createElementBlock("div", _hoisted_14, _cache[2] || (_cache[2] = [
|
|
12535
|
+
vue.createElementVNode("svg", {
|
|
12536
|
+
class: "w-5 h-5 text-gray-600",
|
|
12537
|
+
fill: "currentColor",
|
|
12538
|
+
viewBox: "0 0 20 20"
|
|
12539
|
+
}, [
|
|
12540
|
+
vue.createElementVNode("path", {
|
|
12541
|
+
"fill-rule": "evenodd",
|
|
12542
|
+
d: "M10 9a3 3 0 100-6 3 3 0 000 6zm-7 9a7 7 0 1114 0H3z",
|
|
12543
|
+
"clip-rule": "evenodd"
|
|
12544
|
+
})
|
|
12545
|
+
], -1)
|
|
12546
|
+
])))
|
|
12547
|
+
])) : vue.createCommentVNode("", true),
|
|
12548
|
+
vue.createElementVNode("div", _hoisted_15, [
|
|
12549
|
+
vue.createElementVNode("div", _hoisted_16, vue.toDisplayString(displayName.value), 1),
|
|
12550
|
+
vue.createElementVNode("div", _hoisted_17, vue.toDisplayString(vue.unref(user)?.email), 1)
|
|
12551
|
+
])
|
|
12552
|
+
]),
|
|
12553
|
+
_cache[5] || (_cache[5] = vue.createElementVNode("div", { class: "h-px bg-gray-200 my-2" }, null, -1)),
|
|
12554
|
+
vue.createElementVNode("div", _hoisted_18, [
|
|
12555
|
+
vue.createElementVNode("button", {
|
|
12556
|
+
ref_key: "profileButtonRef",
|
|
12557
|
+
ref: profileButtonRef,
|
|
12558
|
+
onClick: openProfile,
|
|
12559
|
+
class: "w-full flex items-center space-x-3 px-3 py-2 text-sm text-gray-700 rounded-lg hover:bg-gray-100 focus:bg-gray-100 focus:outline-none transition-colors duration-150",
|
|
12560
|
+
role: "menuitem",
|
|
12561
|
+
tabindex: "-1"
|
|
12562
|
+
}, _cache[3] || (_cache[3] = [
|
|
12563
|
+
vue.createElementVNode("svg", {
|
|
12564
|
+
class: "w-4 h-4 text-gray-400",
|
|
12565
|
+
fill: "none",
|
|
12566
|
+
stroke: "currentColor",
|
|
12567
|
+
viewBox: "0 0 24 24"
|
|
12568
|
+
}, [
|
|
12569
|
+
vue.createElementVNode("path", {
|
|
12570
|
+
"stroke-linecap": "round",
|
|
12571
|
+
"stroke-linejoin": "round",
|
|
12572
|
+
"stroke-width": "2",
|
|
12573
|
+
d: "M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z"
|
|
12574
|
+
})
|
|
12575
|
+
], -1),
|
|
12576
|
+
vue.createTextVNode(" Profile ", -1)
|
|
12577
|
+
]), 512),
|
|
12578
|
+
vue.createElementVNode("button", {
|
|
12579
|
+
onClick: handleSignOut,
|
|
12580
|
+
class: "w-full flex items-center space-x-3 px-3 py-2 text-sm text-red-600 rounded-lg hover:bg-red-50 focus:bg-red-50 focus:outline-none transition-colors duration-150",
|
|
12581
|
+
role: "menuitem",
|
|
12582
|
+
tabindex: "-1"
|
|
12583
|
+
}, _cache[4] || (_cache[4] = [
|
|
12584
|
+
vue.createElementVNode("svg", {
|
|
12585
|
+
class: "w-4 h-4 text-red-500",
|
|
12586
|
+
fill: "none",
|
|
12587
|
+
stroke: "currentColor",
|
|
12588
|
+
viewBox: "0 0 24 24"
|
|
12589
|
+
}, [
|
|
12590
|
+
vue.createElementVNode("path", {
|
|
12591
|
+
"stroke-linecap": "round",
|
|
12592
|
+
"stroke-linejoin": "round",
|
|
12593
|
+
"stroke-width": "2",
|
|
12594
|
+
d: "M17 16l4-4m0 0l-4-4m4 4H7m6 4v1a3 3 0 01-3 3H6a3 3 0 01-3-3V7a3 3 0 013-3h4a3 3 0 013 3v1"
|
|
12595
|
+
})
|
|
12596
|
+
], -1),
|
|
12597
|
+
vue.createTextVNode(" Sign Out ", -1)
|
|
12598
|
+
]))
|
|
12599
|
+
])
|
|
12600
|
+
])
|
|
12601
|
+
], 40, _hoisted_9)) : vue.createCommentVNode("", true)
|
|
12602
|
+
]),
|
|
12603
|
+
_: 1
|
|
12604
|
+
})
|
|
12605
|
+
], 40, _hoisted_1),
|
|
12606
|
+
vue.createVNode(vue.unref(StrandsUiModal), {
|
|
12607
|
+
open: showProfileModal.value,
|
|
12608
|
+
onClose: closeProfile,
|
|
12609
|
+
"fullscreen-on-mobile": false
|
|
12610
|
+
}, {
|
|
12611
|
+
header: vue.withCtx(() => [
|
|
12612
|
+
vue.createElementVNode("div", { class: "flex items-center justify-between" }, [
|
|
12613
|
+
_cache[7] || (_cache[7] = vue.createElementVNode("h2", { class: "text-xl font-semibold text-gray-900" }, "User Profile", -1)),
|
|
12614
|
+
vue.createElementVNode("button", {
|
|
12615
|
+
onClick: closeProfile,
|
|
12616
|
+
class: "p-1 rounded-lg text-gray-400 hover:text-gray-600 hover:bg-gray-100 transition-colors",
|
|
12617
|
+
"aria-label": "Close profile"
|
|
12618
|
+
}, _cache[6] || (_cache[6] = [
|
|
12619
|
+
vue.createElementVNode("svg", {
|
|
12620
|
+
class: "w-5 h-5",
|
|
12621
|
+
fill: "none",
|
|
12622
|
+
stroke: "currentColor",
|
|
12623
|
+
viewBox: "0 0 24 24"
|
|
12624
|
+
}, [
|
|
12625
|
+
vue.createElementVNode("path", {
|
|
12626
|
+
"stroke-linecap": "round",
|
|
12627
|
+
"stroke-linejoin": "round",
|
|
12628
|
+
"stroke-width": "2",
|
|
12629
|
+
d: "M6 18L18 6M6 6l12 12"
|
|
12630
|
+
})
|
|
12631
|
+
], -1)
|
|
12632
|
+
]))
|
|
12633
|
+
])
|
|
12634
|
+
]),
|
|
12635
|
+
default: vue.withCtx(() => [
|
|
12636
|
+
vue.createVNode(vue.unref(StrandsUserProfile), {
|
|
12637
|
+
onProfileUpdated: handleProfileUpdated,
|
|
12638
|
+
onError: handleProfileError,
|
|
12639
|
+
"in-modal": ""
|
|
12640
|
+
})
|
|
12641
|
+
]),
|
|
12642
|
+
_: 1
|
|
12643
|
+
}, 8, ["open"])
|
|
12558
12644
|
]),
|
|
12559
12645
|
_: 1
|
|
12560
|
-
}
|
|
12646
|
+
})
|
|
12561
12647
|
], 512);
|
|
12562
12648
|
};
|
|
12563
12649
|
}
|
|
12564
12650
|
});
|
|
12565
|
-
const StrandsUserButton = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-
|
|
12651
|
+
const StrandsUserButton = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-6fbc9411"]]);
|
|
12566
12652
|
const components = {
|
|
12567
12653
|
StrandsUiAlert: _sfc_main$x,
|
|
12568
12654
|
StrandsUiButton,
|