@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.
Files changed (160) hide show
  1. package/dist/accui.css +112 -87
  2. package/dist/nuxt/module.cjs.js.map +1 -1
  3. package/dist/nuxt/module.es.js.map +1 -1
  4. package/dist/nuxt/runtime/composables/useStrandsAuth.cjs.js.map +1 -1
  5. package/dist/nuxt/runtime/composables/useStrandsAuth.es.js.map +1 -1
  6. package/dist/nuxt/runtime/middleware/auth.global.cjs.js.map +1 -1
  7. package/dist/nuxt/runtime/middleware/auth.global.es.js.map +1 -1
  8. package/dist/nuxt/runtime/plugin.client.cjs.js.map +1 -1
  9. package/dist/nuxt/runtime/plugin.client.es.js.map +1 -1
  10. package/dist/nuxt/runtime/plugin.server.cjs.js.map +1 -1
  11. package/dist/nuxt/runtime/plugin.server.es.js.map +1 -1
  12. package/dist/nuxt-v4/module.cjs.js.map +1 -1
  13. package/dist/nuxt-v4/module.es.js.map +1 -1
  14. package/dist/nuxt-v4/runtime/composables/useStrandsAuth.cjs.js.map +1 -1
  15. package/dist/nuxt-v4/runtime/composables/useStrandsAuth.es.js.map +1 -1
  16. package/dist/nuxt-v4/runtime/middleware/auth.global.cjs.js.map +1 -1
  17. package/dist/nuxt-v4/runtime/middleware/auth.global.es.js.map +1 -1
  18. package/dist/nuxt-v4/runtime/plugin.client.cjs.js.map +1 -1
  19. package/dist/nuxt-v4/runtime/plugin.client.es.js.map +1 -1
  20. package/dist/nuxt-v4/runtime/plugin.server.cjs.js.map +1 -1
  21. package/dist/nuxt-v4/runtime/plugin.server.es.js.map +1 -1
  22. package/dist/strands-auth-ui.cjs.js +533 -447
  23. package/dist/strands-auth-ui.cjs.js.map +1 -1
  24. package/dist/strands-auth-ui.es.js +533 -447
  25. package/dist/strands-auth-ui.es.js.map +1 -1
  26. package/dist/useStrandsAuth-CO9JEdxM.js.map +1 -1
  27. package/dist/useStrandsAuth-z4jAu9Uv.cjs.map +1 -1
  28. package/dist/useStrandsConfig-Bdk-g0jS.js.map +1 -1
  29. package/dist/useStrandsConfig-CtmQtE7Y.cjs.map +1 -1
  30. package/package.json +2 -1
  31. package/dist/index.d.ts +0 -7
  32. package/dist/index.d.ts.map +0 -1
  33. package/dist/nuxt/module.d.ts +0 -5
  34. package/dist/nuxt/module.d.ts.map +0 -1
  35. package/dist/nuxt/runtime/composables/useStrandsAuth.d.ts +0 -137
  36. package/dist/nuxt/runtime/composables/useStrandsAuth.d.ts.map +0 -1
  37. package/dist/nuxt/runtime/middleware/auth.global.d.ts +0 -3
  38. package/dist/nuxt/runtime/middleware/auth.global.d.ts.map +0 -1
  39. package/dist/nuxt/runtime/plugin.client.d.ts +0 -3
  40. package/dist/nuxt/runtime/plugin.client.d.ts.map +0 -1
  41. package/dist/nuxt/runtime/plugin.server.d.ts +0 -3
  42. package/dist/nuxt/runtime/plugin.server.d.ts.map +0 -1
  43. package/dist/nuxt/runtime/styles.css +0 -78
  44. package/dist/nuxt/types.d.ts +0 -46
  45. package/dist/nuxt/types.d.ts.map +0 -1
  46. package/dist/nuxt-v4/module.d.ts +0 -5
  47. package/dist/nuxt-v4/module.d.ts.map +0 -1
  48. package/dist/nuxt-v4/runtime/composables/useStrandsAuth.d.ts +0 -27
  49. package/dist/nuxt-v4/runtime/composables/useStrandsAuth.d.ts.map +0 -1
  50. package/dist/nuxt-v4/runtime/middleware/auth.global.d.ts +0 -3
  51. package/dist/nuxt-v4/runtime/middleware/auth.global.d.ts.map +0 -1
  52. package/dist/nuxt-v4/runtime/plugin.client.d.ts +0 -3
  53. package/dist/nuxt-v4/runtime/plugin.client.d.ts.map +0 -1
  54. package/dist/nuxt-v4/runtime/plugin.server.d.ts +0 -3
  55. package/dist/nuxt-v4/runtime/plugin.server.d.ts.map +0 -1
  56. package/dist/nuxt-v4/runtime/styles.css +0 -141
  57. package/dist/nuxt-v4/types.d.ts +0 -64
  58. package/dist/nuxt-v4/types.d.ts.map +0 -1
  59. package/dist/nuxt-v4.d.ts +0 -4
  60. package/dist/nuxt-v4.d.ts.map +0 -1
  61. package/dist/nuxt.d.ts +0 -3
  62. package/dist/nuxt.d.ts.map +0 -1
  63. package/dist/shared/defaults.d.ts +0 -3
  64. package/dist/shared/defaults.d.ts.map +0 -1
  65. package/dist/types/index.d.ts +0 -197
  66. package/dist/types/index.d.ts.map +0 -1
  67. package/dist/utils/index.d.ts +0 -2
  68. package/dist/utils/index.d.ts.map +0 -1
  69. package/dist/utils/slots.d.ts +0 -2
  70. package/dist/utils/slots.d.ts.map +0 -1
  71. package/dist/utils/validation.d.ts +0 -13
  72. package/dist/utils/validation.d.ts.map +0 -1
  73. package/dist/vue/components/SignedIn.vue.d.ts +0 -51
  74. package/dist/vue/components/SignedIn.vue.d.ts.map +0 -1
  75. package/dist/vue/components/SignedOut.vue.d.ts +0 -54
  76. package/dist/vue/components/SignedOut.vue.d.ts.map +0 -1
  77. package/dist/vue/components/StrandsAuth.vue.d.ts +0 -23
  78. package/dist/vue/components/StrandsAuth.vue.d.ts.map +0 -1
  79. package/dist/vue/components/StrandsBackupCodesModal.vue.d.ts +0 -12
  80. package/dist/vue/components/StrandsBackupCodesModal.vue.d.ts.map +0 -1
  81. package/dist/vue/components/StrandsCompleteSignUp.vue.d.ts +0 -21
  82. package/dist/vue/components/StrandsCompleteSignUp.vue.d.ts.map +0 -1
  83. package/dist/vue/components/StrandsConfigProvider.vue.d.ts +0 -22
  84. package/dist/vue/components/StrandsConfigProvider.vue.d.ts.map +0 -1
  85. package/dist/vue/components/StrandsConfirmModal.vue.d.ts +0 -22
  86. package/dist/vue/components/StrandsConfirmModal.vue.d.ts.map +0 -1
  87. package/dist/vue/components/StrandsEmailMfaSetupModal.vue.d.ts +0 -12
  88. package/dist/vue/components/StrandsEmailMfaSetupModal.vue.d.ts.map +0 -1
  89. package/dist/vue/components/StrandsHardwareKeySetupModal.vue.d.ts +0 -15
  90. package/dist/vue/components/StrandsHardwareKeySetupModal.vue.d.ts.map +0 -1
  91. package/dist/vue/components/StrandsLogo.vue.d.ts +0 -8
  92. package/dist/vue/components/StrandsLogo.vue.d.ts.map +0 -1
  93. package/dist/vue/components/StrandsMFASetup.vue.d.ts +0 -16
  94. package/dist/vue/components/StrandsMFASetup.vue.d.ts.map +0 -1
  95. package/dist/vue/components/StrandsMfaModal.vue.d.ts +0 -12
  96. package/dist/vue/components/StrandsMfaModal.vue.d.ts.map +0 -1
  97. package/dist/vue/components/StrandsMfaVerification.vue.d.ts +0 -17
  98. package/dist/vue/components/StrandsMfaVerification.vue.d.ts.map +0 -1
  99. package/dist/vue/components/StrandsPasswordReset.vue.d.ts +0 -15
  100. package/dist/vue/components/StrandsPasswordReset.vue.d.ts.map +0 -1
  101. package/dist/vue/components/StrandsSecuredFooter.vue.d.ts +0 -22
  102. package/dist/vue/components/StrandsSecuredFooter.vue.d.ts.map +0 -1
  103. package/dist/vue/components/StrandsSettingsModal.vue.d.ts +0 -18
  104. package/dist/vue/components/StrandsSettingsModal.vue.d.ts.map +0 -1
  105. package/dist/vue/components/StrandsSignIn.vue.d.ts +0 -21
  106. package/dist/vue/components/StrandsSignIn.vue.d.ts.map +0 -1
  107. package/dist/vue/components/StrandsSignUp.vue.d.ts +0 -19
  108. package/dist/vue/components/StrandsSignUp.vue.d.ts.map +0 -1
  109. package/dist/vue/components/StrandsTotpSetupModal.vue.d.ts +0 -12
  110. package/dist/vue/components/StrandsTotpSetupModal.vue.d.ts.map +0 -1
  111. package/dist/vue/components/StrandsUserButton.vue.d.ts +0 -19
  112. package/dist/vue/components/StrandsUserButton.vue.d.ts.map +0 -1
  113. package/dist/vue/components/StrandsUserProfile.vue.d.ts +0 -26
  114. package/dist/vue/components/StrandsUserProfile.vue.d.ts.map +0 -1
  115. package/dist/vue/components/SvgIcon.vue.d.ts +0 -17
  116. package/dist/vue/components/SvgIcon.vue.d.ts.map +0 -1
  117. package/dist/vue/components/index.d.ts +0 -23
  118. package/dist/vue/components/index.d.ts.map +0 -1
  119. package/dist/vue/composables/useOAuthProviders.d.ts +0 -74
  120. package/dist/vue/composables/useOAuthProviders.d.ts.map +0 -1
  121. package/dist/vue/composables/useStrandsAuth.d.ts +0 -124
  122. package/dist/vue/composables/useStrandsAuth.d.ts.map +0 -1
  123. package/dist/vue/composables/useStrandsConfig.d.ts +0 -11
  124. package/dist/vue/composables/useStrandsConfig.d.ts.map +0 -1
  125. package/dist/vue/composables/useStrandsMfa.d.ts +0 -37
  126. package/dist/vue/composables/useStrandsMfa.d.ts.map +0 -1
  127. package/dist/vue/index.d.ts +0 -7
  128. package/dist/vue/index.d.ts.map +0 -1
  129. package/dist/vue/plugins/StrandsUIPlugin.d.ts +0 -18
  130. package/dist/vue/plugins/StrandsUIPlugin.d.ts.map +0 -1
  131. package/dist/vue/ui/UiAlert.vue.d.ts +0 -31
  132. package/dist/vue/ui/UiAlert.vue.d.ts.map +0 -1
  133. package/dist/vue/ui/UiAvatarEditor.vue.d.ts +0 -24
  134. package/dist/vue/ui/UiAvatarEditor.vue.d.ts.map +0 -1
  135. package/dist/vue/ui/UiAvatarEditorSimple.vue.d.ts +0 -25
  136. package/dist/vue/ui/UiAvatarEditorSimple.vue.d.ts.map +0 -1
  137. package/dist/vue/ui/UiButton.vue.d.ts +0 -40
  138. package/dist/vue/ui/UiButton.vue.d.ts.map +0 -1
  139. package/dist/vue/ui/UiCard.vue.d.ts +0 -29
  140. package/dist/vue/ui/UiCard.vue.d.ts.map +0 -1
  141. package/dist/vue/ui/UiInput.vue.d.ts +0 -48
  142. package/dist/vue/ui/UiInput.vue.d.ts.map +0 -1
  143. package/dist/vue/ui/UiLevelProgress.vue.d.ts +0 -19
  144. package/dist/vue/ui/UiLevelProgress.vue.d.ts.map +0 -1
  145. package/dist/vue/ui/UiLink.vue.d.ts +0 -35
  146. package/dist/vue/ui/UiLink.vue.d.ts.map +0 -1
  147. package/dist/vue/ui/UiLoader.vue.d.ts +0 -15
  148. package/dist/vue/ui/UiLoader.vue.d.ts.map +0 -1
  149. package/dist/vue/ui/UiModal.vue.d.ts +0 -31
  150. package/dist/vue/ui/UiModal.vue.d.ts.map +0 -1
  151. package/dist/vue/ui/UiTabs.vue.d.ts +0 -17
  152. package/dist/vue/ui/UiTabs.vue.d.ts.map +0 -1
  153. package/dist/vue/ui/UiToggle.vue.d.ts +0 -15
  154. package/dist/vue/ui/UiToggle.vue.d.ts.map +0 -1
  155. package/dist/vue/ui/index.d.ts +0 -19
  156. package/dist/vue/ui/index.d.ts.map +0 -1
  157. package/dist/vue/utils/levels.d.ts +0 -28
  158. package/dist/vue/utils/levels.d.ts.map +0 -1
  159. package/dist/vue/utils/sounds.d.ts +0 -57
  160. 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$a = { class: "space-y-3" };
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$a, [
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$9 = { class: "preview-section" };
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$9, [
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-c61f001d"]]);
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$8 = {
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$8, [
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: "w-full min-w-100 max-w-md mx-auto animate-slide-up" };
4262
- const _hoisted_2$g = { class: "text-center mb-8" };
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 _hoisted_4$e = {
4270
+ const _hoisted_3$g = {
4268
4271
  key: 0,
4269
4272
  class: "space-y-3 mb-6"
4270
4273
  };
4271
- const _hoisted_5$d = { class: "w-5 h-5 flex items-center justify-center" };
4272
- const _hoisted_6$c = {
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 _hoisted_7$c = ["src", "alt"];
4277
- const _hoisted_8$a = {
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 _hoisted_9$a = {
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 _hoisted_10$a = {
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 _hoisted_11$a = { class: "text-xs font-semibold text-neutral-600" };
4292
- const _hoisted_12$a = { class: "font-medium" };
4293
- const _hoisted_13$a = {
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 _hoisted_14$9 = { class: "divider-text" };
4298
- const _hoisted_15$9 = {
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 _hoisted_16$8 = { class: "flex items-center justify-between mb-2" };
4303
- const _hoisted_17$8 = {
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 _hoisted_18$7 = { class: "text-neutral-400 text-sm" };
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", _hoisted_1$h, [
4489
- vue.createVNode(vue.unref(_sfc_main$v), { variant: "modern" }, {
4490
- default: vue.withCtx(() => [
4491
- vue.createElementVNode("div", _hoisted_2$g, [
4492
- vue.createVNode(vue.Transition, {
4493
- name: "fade",
4494
- mode: "out-in"
4495
- }, {
4496
- default: vue.withCtx(() => [
4497
- (vue.openBlock(), vue.createElementBlock("h1", {
4498
- key: currentMode.value,
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
- !isPasswordReset.value && displayProviders.value?.length ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_13$a, [
4587
- vue.createElementVNode("span", _hoisted_14$9, "Or " + vue.toDisplayString(isSignUp.value ? "create account" : "sign in") + " with email", 1)
4588
- ])) : vue.createCommentVNode("", true)
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: "expand",
4512
+ name: "fade",
4658
4513
  mode: "out-in"
4659
4514
  }, {
4660
4515
  default: vue.withCtx(() => [
4661
- isPasswordReset.value && isPasswordResetSubmitted.value ? (vue.openBlock(), vue.createBlock(vue.unref(_sfc_main$x), {
4662
- key: "reset-success",
4663
- variant: "success",
4664
- message: `Check your email - We've sent a password reset link to ${form.email}`,
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
- vue.createVNode(vue.Transition, { name: "height-fade" }, {
4671
- default: vue.withCtx(() => [
4672
- isPasswordReset.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_17$8, [
4673
- vue.createVNode(vue.unref(_sfc_main$t), {
4674
- onClick: _cache[4] || (_cache[4] = ($event) => currentMode.value = "signin"),
4675
- class: "inline-flex items-center gap-2"
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(() => _cache[10] || (_cache[10] = [
4678
- vue.createElementVNode("svg", {
4679
- class: "w-4 h-4",
4680
- fill: "none",
4681
- stroke: "currentColor",
4682
- viewBox: "0 0 24 24"
4683
- }, [
4684
- vue.createElementVNode("path", {
4685
- "stroke-linecap": "round",
4686
- "stroke-linejoin": "round",
4687
- "stroke-width": "2",
4688
- d: "M15 19l-7-7 7-7"
4689
- })
4690
- ], -1),
4691
- vue.createTextVNode(" Back to sign in ", -1)
4692
- ])),
4693
- _: 1,
4694
- __: [10]
4695
- })
4696
- ])) : vue.createCommentVNode("", true)
4697
- ]),
4698
- _: 1
4699
- }),
4700
- error.value ? (vue.openBlock(), vue.createBlock(vue.unref(_sfc_main$x), {
4701
- key: 0,
4702
- variant: "error",
4703
- message: error.value,
4704
- class: "mt-6 animate-fade-in",
4705
- dismissible: "",
4706
- onDismiss: _cache[5] || (_cache[5] = ($event) => error.value = "")
4707
- }, null, 8, ["message"])) : vue.createCommentVNode("", true),
4708
- vue.createVNode(_sfc_main$l, {
4709
- config: props.config
4710
- }, {
4711
- default: vue.withCtx(() => [
4712
- vue.unref(getSupportEmail)() ? (vue.openBlock(), vue.createBlock(vue.Transition, {
4713
- key: 0,
4714
- name: "support-fade"
4715
- }, {
4716
- default: vue.withCtx(() => [
4717
- vue.createElementVNode("p", _hoisted_18$7, [
4718
- _cache[12] || (_cache[12] = vue.createTextVNode(" Need help? ", -1)),
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
- href: `mailto:${vue.unref(getSupportEmail)()}`
4625
+ size: "sm",
4626
+ onClick: _cache[2] || (_cache[2] = ($event) => currentMode.value = "reset-password")
4722
4627
  }, {
4723
- default: vue.withCtx(() => _cache[11] || (_cache[11] = [
4724
- vue.createTextVNode(" Contact Support ", -1)
4628
+ default: vue.withCtx(() => _cache[8] || (_cache[8] = [
4629
+ vue.createTextVNode(" Forgot password? ", -1)
4725
4630
  ])),
4726
4631
  _: 1,
4727
- __: [11]
4728
- }, 8, ["href"])
4729
- ])
4730
- ]),
4731
- _: 1
4732
- })) : vue.createCommentVNode("", true)
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, ["config"])
4736
- ]),
4737
- _: 1
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-a8f59d58"]]);
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.createElementVNode("button", {
12367
- onClick: toggleDropdown,
12368
- onKeydown: [
12369
- vue.withKeys(toggleDropdown, ["enter"]),
12370
- vue.withKeys(vue.withModifiers(toggleDropdown, ["prevent"]), ["space"]),
12371
- vue.withKeys(closeDropdown, ["escape"]),
12372
- vue.withKeys(vue.withModifiers(openDropdown, ["prevent"]), ["arrow-down"])
12373
- ],
12374
- 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",
12375
- "aria-haspopup": "true",
12376
- "aria-expanded": showDropdown.value,
12377
- "aria-label": "User menu"
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("div", _hoisted_10, [
12435
- vue.createElementVNode("div", _hoisted_11, [
12436
- vue.unref(user) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_12, [
12437
- vue.createVNode(vue.unref(StrandsUiLevelProgress), {
12438
- size: 80,
12439
- value: vue.unref(user).xp,
12440
- max: vue.unref(user).next_level_xp,
12441
- level: vue.unref(user).level,
12442
- "level-label": `LEVEL ${vue.unref(user).level}`,
12443
- "user-settings": vue.unref(user).settings,
12444
- class: "absolute z-10 top-1/2 left-1/2 transform -translate-x-1/2 -translate-y-1/2 pointer-events-none"
12445
- }, null, 8, ["value", "max", "level", "level-label", "user-settings"]),
12446
- vue.unref(user)?.avatar ? (vue.openBlock(), vue.createElementBlock("img", {
12447
- key: 0,
12448
- src: vue.unref(user).avatar,
12449
- alt: `${vue.unref(user).firstName || vue.unref(user).email}'s avatar`,
12450
- class: "w-14 h-14 rounded-full object-cover"
12451
- }, null, 8, _hoisted_13)) : (vue.openBlock(), vue.createElementBlock("div", _hoisted_14, _cache[2] || (_cache[2] = [
12452
- vue.createElementVNode("svg", {
12453
- class: "w-5 h-5 text-gray-600",
12454
- fill: "currentColor",
12455
- viewBox: "0 0 20 20"
12456
- }, [
12457
- vue.createElementVNode("path", {
12458
- "fill-rule": "evenodd",
12459
- d: "M10 9a3 3 0 100-6 3 3 0 000 6zm-7 9a7 7 0 1114 0H3z",
12460
- "clip-rule": "evenodd"
12461
- })
12462
- ], -1)
12463
- ])))
12464
- ])) : vue.createCommentVNode("", true),
12465
- vue.createElementVNode("div", _hoisted_15, [
12466
- vue.createElementVNode("div", _hoisted_16, vue.toDisplayString(displayName.value), 1),
12467
- vue.createElementVNode("div", _hoisted_17, vue.toDisplayString(vue.unref(user)?.email), 1)
12468
- ])
12469
- ]),
12470
- _cache[5] || (_cache[5] = vue.createElementVNode("div", { class: "h-px bg-gray-200 my-2" }, null, -1)),
12471
- vue.createElementVNode("div", _hoisted_18, [
12472
- vue.createElementVNode("button", {
12473
- ref_key: "profileButtonRef",
12474
- ref: profileButtonRef,
12475
- onClick: openProfile,
12476
- 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",
12477
- role: "menuitem",
12478
- tabindex: "-1"
12479
- }, _cache[3] || (_cache[3] = [
12480
- vue.createElementVNode("svg", {
12481
- class: "w-4 h-4 text-gray-400",
12482
- fill: "none",
12483
- stroke: "currentColor",
12484
- viewBox: "0 0 24 24"
12485
- }, [
12486
- vue.createElementVNode("path", {
12487
- "stroke-linecap": "round",
12488
- "stroke-linejoin": "round",
12489
- "stroke-width": "2",
12490
- d: "M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z"
12491
- })
12492
- ], -1),
12493
- vue.createTextVNode(" Profile ", -1)
12494
- ]), 512),
12495
- vue.createElementVNode("button", {
12496
- onClick: handleSignOut,
12497
- 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",
12498
- role: "menuitem",
12499
- tabindex: "-1"
12500
- }, _cache[4] || (_cache[4] = [
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-4 h-4 text-red-500",
12503
- fill: "none",
12504
- stroke: "currentColor",
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
- "stroke-linecap": "round",
12509
- "stroke-linejoin": "round",
12510
- "stroke-width": "2",
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
- vue.createTextVNode(" Sign Out ", -1)
12515
- ]))
12484
+ ], -1)
12485
+ ])))
12516
12486
  ])
12517
- ])
12518
- ], 40, _hoisted_9)) : vue.createCommentVNode("", true)
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: "M6 18L18 6M6 6l12 12"
12547
- })
12548
- ], -1)
12549
- ]))
12550
- ])
12551
- ]),
12552
- default: vue.withCtx(() => [
12553
- vue.createVNode(StrandsUserProfile, {
12554
- onProfileUpdated: handleProfileUpdated,
12555
- onError: handleProfileError,
12556
- "in-modal": ""
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
- }, 8, ["open"])
12646
+ })
12561
12647
  ], 512);
12562
12648
  };
12563
12649
  }
12564
12650
  });
12565
- const StrandsUserButton = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-55619755"]]);
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,