@strands.gg/accui 1.7.3 → 1.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (30) hide show
  1. package/dist/accui.css +537 -161
  2. package/dist/nuxt/runtime/composables/useStrandsAuth.cjs.js +1 -1
  3. package/dist/nuxt/runtime/composables/useStrandsAuth.es.js +1 -1
  4. package/dist/nuxt/runtime/plugin.client.cjs.js +1 -1
  5. package/dist/nuxt/runtime/plugin.client.es.js +1 -1
  6. package/dist/nuxt/runtime/plugin.server.cjs.js +1 -1
  7. package/dist/nuxt/runtime/plugin.server.es.js +1 -1
  8. package/dist/nuxt-v4/runtime/composables/useStrandsAuth.cjs.js +1 -1
  9. package/dist/nuxt-v4/runtime/composables/useStrandsAuth.es.js +1 -1
  10. package/dist/nuxt-v4/runtime/plugin.client.cjs.js +1 -1
  11. package/dist/nuxt-v4/runtime/plugin.client.es.js +1 -1
  12. package/dist/nuxt-v4/runtime/plugin.server.cjs.js +1 -1
  13. package/dist/nuxt-v4/runtime/plugin.server.es.js +1 -1
  14. package/dist/strands-auth-ui.cjs.js +1108 -704
  15. package/dist/strands-auth-ui.cjs.js.map +1 -1
  16. package/dist/strands-auth-ui.es.js +1109 -705
  17. package/dist/strands-auth-ui.es.js.map +1 -1
  18. package/dist/{useStrandsAuth-CO9JEdxM.js → useStrandsAuth-BA8qEUcp.js} +110 -66
  19. package/dist/useStrandsAuth-BA8qEUcp.js.map +1 -0
  20. package/dist/{useStrandsAuth-z4jAu9Uv.cjs → useStrandsAuth-Co2lLH4X.cjs} +110 -66
  21. package/dist/useStrandsAuth-Co2lLH4X.cjs.map +1 -0
  22. package/dist/{useStrandsConfig-Bdk-g0jS.js → useStrandsConfig-Cxb360Os.js} +13 -3
  23. package/dist/useStrandsConfig-Cxb360Os.js.map +1 -0
  24. package/dist/{useStrandsConfig-CtmQtE7Y.cjs → useStrandsConfig-Dms13Zd0.cjs} +13 -3
  25. package/dist/useStrandsConfig-Dms13Zd0.cjs.map +1 -0
  26. package/package.json +5 -1
  27. package/dist/useStrandsAuth-CO9JEdxM.js.map +0 -1
  28. package/dist/useStrandsAuth-z4jAu9Uv.cjs.map +0 -1
  29. package/dist/useStrandsConfig-Bdk-g0jS.js.map +0 -1
  30. package/dist/useStrandsConfig-CtmQtE7Y.cjs.map +0 -1
@@ -1,23 +1,23 @@
1
1
  import { defineComponent, computed, createElementBlock, openBlock, createElementVNode, normalizeClass, createCommentVNode, toDisplayString, renderSlot, createTextVNode, normalizeStyle, useSlots, ref, createBlock, resolveDynamicComponent, mergeProps, withCtx, onMounted, nextTick, toRefs, watch, Fragment, renderList, unref, reactive, withModifiers, createStaticVNode, withDirectives, vModelText, Teleport, onBeforeUnmount, createVNode, withKeys, Transition, resolveComponent, h, onUnmounted } from "vue";
2
- import { u as useStrandsConfig, p as provideStrandsConfig } from "./useStrandsConfig-Bdk-g0jS.js";
3
- import { s } from "./useStrandsConfig-Bdk-g0jS.js";
4
- import { u as useStrandsAuth } from "./useStrandsAuth-CO9JEdxM.js";
5
- const _hoisted_1$u = { class: "accui-component-scope" };
6
- const _hoisted_2$r = { class: "alert-content" };
7
- const _hoisted_3$q = { class: "alert-icon-container" };
8
- const _hoisted_4$n = {
2
+ import { u as useStrandsConfig, p as provideStrandsConfig } from "./useStrandsConfig-Cxb360Os.js";
3
+ import { s } from "./useStrandsConfig-Cxb360Os.js";
4
+ import { u as useStrandsAuth } from "./useStrandsAuth-BA8qEUcp.js";
5
+ const _hoisted_1$v = { class: "accui-component-scope" };
6
+ const _hoisted_2$s = { class: "alert-content" };
7
+ const _hoisted_3$s = { class: "alert-icon-container" };
8
+ const _hoisted_4$o = {
9
9
  class: "alert-main-icon",
10
10
  fill: "currentColor",
11
11
  viewBox: "0 0 20 20",
12
12
  "aria-hidden": "true"
13
13
  };
14
- const _hoisted_5$k = ["d"];
15
- const _hoisted_6$h = { class: "alert-text-container" };
16
- const _hoisted_7$h = {
14
+ const _hoisted_5$l = ["d"];
15
+ const _hoisted_6$i = { class: "alert-text-container" };
16
+ const _hoisted_7$i = {
17
17
  key: 0,
18
18
  class: "alert-dismiss-container"
19
19
  };
20
- const _sfc_main$w = /* @__PURE__ */ defineComponent({
20
+ const _sfc_main$x = /* @__PURE__ */ defineComponent({
21
21
  __name: "UiAlert",
22
22
  props: {
23
23
  variant: { default: "info" },
@@ -53,22 +53,22 @@ const _sfc_main$w = /* @__PURE__ */ defineComponent({
53
53
  return icons[props.variant];
54
54
  });
55
55
  return (_ctx, _cache) => {
56
- return openBlock(), createElementBlock("div", _hoisted_1$u, [
56
+ return openBlock(), createElementBlock("div", _hoisted_1$v, [
57
57
  createElementVNode("div", {
58
58
  class: normalizeClass(alertClasses.value),
59
59
  role: "alert"
60
60
  }, [
61
- createElementVNode("div", _hoisted_2$r, [
62
- createElementVNode("div", _hoisted_3$q, [
63
- (openBlock(), createElementBlock("svg", _hoisted_4$n, [
61
+ createElementVNode("div", _hoisted_2$s, [
62
+ createElementVNode("div", _hoisted_3$s, [
63
+ (openBlock(), createElementBlock("svg", _hoisted_4$o, [
64
64
  createElementVNode("path", {
65
65
  "fill-rule": "evenodd",
66
66
  d: iconPath.value,
67
67
  "clip-rule": "evenodd"
68
- }, null, 8, _hoisted_5$k)
68
+ }, null, 8, _hoisted_5$l)
69
69
  ]))
70
70
  ]),
71
- createElementVNode("div", _hoisted_6$h, [
71
+ createElementVNode("div", _hoisted_6$i, [
72
72
  _ctx.title ? (openBlock(), createElementBlock("h3", {
73
73
  key: 0,
74
74
  class: normalizeClass(titleClasses.value)
@@ -81,7 +81,7 @@ const _sfc_main$w = /* @__PURE__ */ defineComponent({
81
81
  ], true)
82
82
  ], 2)
83
83
  ]),
84
- _ctx.dismissible ? (openBlock(), createElementBlock("div", _hoisted_7$h, [
84
+ _ctx.dismissible ? (openBlock(), createElementBlock("div", _hoisted_7$i, [
85
85
  createElementVNode("button", {
86
86
  type: "button",
87
87
  class: "alert-dismiss-button",
@@ -114,7 +114,7 @@ const _export_sfc = (sfc, props) => {
114
114
  }
115
115
  return target;
116
116
  };
117
- const StrandsUiAlert = /* @__PURE__ */ _export_sfc(_sfc_main$w, [["__scopeId", "data-v-a396f50a"]]);
117
+ const StrandsUiAlert = /* @__PURE__ */ _export_sfc(_sfc_main$x, [["__scopeId", "data-v-a396f50a"]]);
118
118
  const mainTRC = 2.4;
119
119
  const sRco = 0.2126729, sGco = 0.7151522, sBco = 0.072175;
120
120
  const normBG = 0.56, normTXT = 0.57, revTXT = 0.62, revBG = 0.65;
@@ -269,16 +269,16 @@ const getColorValue = (color) => {
269
269
  }
270
270
  return colorMap[color] || `var(--color-${color}, ${color})`;
271
271
  };
272
- const _hoisted_1$t = ["type", "disabled"];
273
- const _hoisted_2$q = {
272
+ const _hoisted_1$u = ["type", "disabled"];
273
+ const _hoisted_2$r = {
274
274
  key: 0,
275
275
  class: "button-loading-content"
276
276
  };
277
- const _hoisted_3$p = {
277
+ const _hoisted_3$r = {
278
278
  key: 1,
279
279
  class: "button-content"
280
280
  };
281
- const _sfc_main$v = /* @__PURE__ */ defineComponent({
281
+ const _sfc_main$w = /* @__PURE__ */ defineComponent({
282
282
  __name: "UiButton",
283
283
  props: {
284
284
  variant: { default: "primary" },
@@ -399,7 +399,7 @@ const _sfc_main$v = /* @__PURE__ */ defineComponent({
399
399
  style: normalizeStyle(buttonStyles.value),
400
400
  onClick: _cache[0] || (_cache[0] = ($event) => _ctx.$emit("click", $event))
401
401
  }, [
402
- _ctx.loading ? (openBlock(), createElementBlock("span", _hoisted_2$q, [
402
+ _ctx.loading ? (openBlock(), createElementBlock("span", _hoisted_2$r, [
403
403
  _cache[1] || (_cache[1] = createElementVNode("svg", {
404
404
  class: "button-loading-icon",
405
405
  fill: "none",
@@ -420,25 +420,25 @@ const _sfc_main$v = /* @__PURE__ */ defineComponent({
420
420
  })
421
421
  ], -1)),
422
422
  createElementVNode("span", null, toDisplayString(_ctx.loadingText || "Loading..."), 1)
423
- ])) : (openBlock(), createElementBlock("span", _hoisted_3$p, [
423
+ ])) : (openBlock(), createElementBlock("span", _hoisted_3$r, [
424
424
  renderSlot(_ctx.$slots, "icon", {}, void 0, true),
425
425
  renderSlot(_ctx.$slots, "default", {}, void 0, true)
426
426
  ]))
427
- ], 14, _hoisted_1$t);
427
+ ], 14, _hoisted_1$u);
428
428
  };
429
429
  }
430
430
  });
431
- const StrandsUiButton = /* @__PURE__ */ _export_sfc(_sfc_main$v, [["__scopeId", "data-v-9eb74e0b"]]);
432
- const _hoisted_1$s = {
431
+ const StrandsUiButton = /* @__PURE__ */ _export_sfc(_sfc_main$w, [["__scopeId", "data-v-9eb74e0b"]]);
432
+ const _hoisted_1$t = {
433
433
  key: 0,
434
434
  class: "ui-card-header"
435
435
  };
436
- const _hoisted_2$p = { class: "ui-card-content" };
437
- const _hoisted_3$o = {
436
+ const _hoisted_2$q = { class: "ui-card-content" };
437
+ const _hoisted_3$q = {
438
438
  key: 1,
439
439
  class: "ui-card-footer"
440
440
  };
441
- const _sfc_main$u = /* @__PURE__ */ defineComponent({
441
+ const _sfc_main$v = /* @__PURE__ */ defineComponent({
442
442
  __name: "UiCard",
443
443
  props: {
444
444
  variant: { default: "default" },
@@ -454,56 +454,56 @@ const _sfc_main$u = /* @__PURE__ */ defineComponent({
454
454
  `ui-card-shadow-${_ctx.shadow}`
455
455
  ]])
456
456
  }, [
457
- _ctx.$slots["header"] ? (openBlock(), createElementBlock("div", _hoisted_1$s, [
457
+ _ctx.$slots["header"] ? (openBlock(), createElementBlock("div", _hoisted_1$t, [
458
458
  renderSlot(_ctx.$slots, "header", {}, void 0, true)
459
459
  ])) : createCommentVNode("", true),
460
- createElementVNode("div", _hoisted_2$p, [
460
+ createElementVNode("div", _hoisted_2$q, [
461
461
  renderSlot(_ctx.$slots, "default", {}, void 0, true)
462
462
  ]),
463
- _ctx.$slots["footer"] ? (openBlock(), createElementBlock("div", _hoisted_3$o, [
463
+ _ctx.$slots["footer"] ? (openBlock(), createElementBlock("div", _hoisted_3$q, [
464
464
  renderSlot(_ctx.$slots, "footer", {}, void 0, true)
465
465
  ])) : createCommentVNode("", true)
466
466
  ], 2);
467
467
  };
468
468
  }
469
469
  });
470
- const StrandsUiCard = /* @__PURE__ */ _export_sfc(_sfc_main$u, [["__scopeId", "data-v-c8b506ee"]]);
471
- const _hoisted_1$r = { class: "accui-component-scope" };
472
- const _hoisted_2$o = { class: "input-container" };
473
- const _hoisted_3$n = ["for"];
474
- const _hoisted_4$m = {
470
+ const StrandsUiCard = /* @__PURE__ */ _export_sfc(_sfc_main$v, [["__scopeId", "data-v-c8b506ee"]]);
471
+ const _hoisted_1$s = { class: "accui-component-scope" };
472
+ const _hoisted_2$p = { class: "input-container" };
473
+ const _hoisted_3$p = ["for"];
474
+ const _hoisted_4$n = {
475
475
  key: 0,
476
476
  class: "input-required"
477
477
  };
478
- const _hoisted_5$j = { class: "input-wrapper" };
479
- const _hoisted_6$g = ["id", "type", "value", "placeholder", "disabled", "required", "autocomplete", "name", "inputmode", "maxlength"];
480
- const _hoisted_7$g = {
478
+ const _hoisted_5$k = { class: "input-wrapper" };
479
+ const _hoisted_6$h = ["id", "type", "value", "placeholder", "disabled", "required", "autocomplete", "name", "inputmode", "maxlength"];
480
+ const _hoisted_7$h = {
481
481
  key: 0,
482
482
  class: "input-toggle-icon",
483
483
  fill: "none",
484
484
  stroke: "currentColor",
485
485
  viewBox: "0 0 24 24"
486
486
  };
487
- const _hoisted_8$g = {
487
+ const _hoisted_8$h = {
488
488
  key: 1,
489
489
  class: "input-toggle-icon",
490
490
  fill: "none",
491
491
  stroke: "currentColor",
492
492
  viewBox: "0 0 24 24"
493
493
  };
494
- const _hoisted_9$f = {
494
+ const _hoisted_9$g = {
495
495
  key: 1,
496
496
  class: "input-icon-container"
497
497
  };
498
- const _hoisted_10$e = {
498
+ const _hoisted_10$f = {
499
499
  key: 1,
500
500
  class: "input-error-text"
501
501
  };
502
- const _hoisted_11$e = {
502
+ const _hoisted_11$f = {
503
503
  key: 2,
504
504
  class: "input-help-text"
505
505
  };
506
- const _sfc_main$t = /* @__PURE__ */ defineComponent({
506
+ const _sfc_main$u = /* @__PURE__ */ defineComponent({
507
507
  __name: "UiInput",
508
508
  props: {
509
509
  modelValue: {},
@@ -562,17 +562,17 @@ const _sfc_main$t = /* @__PURE__ */ defineComponent({
562
562
  showPassword.value = !showPassword.value;
563
563
  };
564
564
  return (_ctx, _cache) => {
565
- return openBlock(), createElementBlock("div", _hoisted_1$r, [
566
- createElementVNode("div", _hoisted_2$o, [
565
+ return openBlock(), createElementBlock("div", _hoisted_1$s, [
566
+ createElementVNode("div", _hoisted_2$p, [
567
567
  _ctx.label ? (openBlock(), createElementBlock("label", {
568
568
  key: 0,
569
569
  for: inputId.value,
570
570
  class: "input-label"
571
571
  }, [
572
572
  createTextVNode(toDisplayString(_ctx.label) + " ", 1),
573
- _ctx.required ? (openBlock(), createElementBlock("span", _hoisted_4$m, "*")) : createCommentVNode("", true)
574
- ], 8, _hoisted_3$n)) : createCommentVNode("", true),
575
- createElementVNode("div", _hoisted_5$j, [
573
+ _ctx.required ? (openBlock(), createElementBlock("span", _hoisted_4$n, "*")) : createCommentVNode("", true)
574
+ ], 8, _hoisted_3$p)) : createCommentVNode("", true),
575
+ createElementVNode("div", _hoisted_5$k, [
576
576
  createElementVNode("input", {
577
577
  id: inputId.value,
578
578
  type: computedType.value,
@@ -589,21 +589,21 @@ const _sfc_main$t = /* @__PURE__ */ defineComponent({
589
589
  onBlur: _cache[0] || (_cache[0] = ($event) => _ctx.$emit("blur", $event)),
590
590
  onFocus: _cache[1] || (_cache[1] = ($event) => _ctx.$emit("focus", $event)),
591
591
  onKeydown: _cache[2] || (_cache[2] = ($event) => _ctx.$emit("keydown", $event))
592
- }, null, 42, _hoisted_6$g),
592
+ }, null, 42, _hoisted_6$h),
593
593
  _ctx.type === "password" ? (openBlock(), createElementBlock("button", {
594
594
  key: 0,
595
595
  type: "button",
596
596
  class: "input-password-toggle",
597
597
  onClick: togglePasswordVisibility
598
598
  }, [
599
- showPassword.value ? (openBlock(), createElementBlock("svg", _hoisted_7$g, _cache[3] || (_cache[3] = [
599
+ showPassword.value ? (openBlock(), createElementBlock("svg", _hoisted_7$h, _cache[3] || (_cache[3] = [
600
600
  createElementVNode("path", {
601
601
  "stroke-linecap": "round",
602
602
  "stroke-linejoin": "round",
603
603
  "stroke-width": "2",
604
604
  d: "M13.875 18.825A10.05 10.05 0 0112 19c-4.478 0-8.268-2.943-9.543-7a9.97 9.97 0 011.563-3.029m5.858.908a3 3 0 114.243 4.243M9.878 9.878l4.242 4.242M9.878 9.878L3 3m6.878 6.878L21 21"
605
605
  }, null, -1)
606
- ]))) : (openBlock(), createElementBlock("svg", _hoisted_8$g, _cache[4] || (_cache[4] = [
606
+ ]))) : (openBlock(), createElementBlock("svg", _hoisted_8$h, _cache[4] || (_cache[4] = [
607
607
  createElementVNode("path", {
608
608
  "stroke-linecap": "round",
609
609
  "stroke-linejoin": "round",
@@ -618,18 +618,18 @@ const _sfc_main$t = /* @__PURE__ */ defineComponent({
618
618
  }, null, -1)
619
619
  ])))
620
620
  ])) : createCommentVNode("", true),
621
- _ctx.$slots["icon"] ? (openBlock(), createElementBlock("div", _hoisted_9$f, [
621
+ _ctx.$slots["icon"] ? (openBlock(), createElementBlock("div", _hoisted_9$g, [
622
622
  renderSlot(_ctx.$slots, "icon", {}, void 0, true)
623
623
  ])) : createCommentVNode("", true)
624
624
  ]),
625
- _ctx.error ? (openBlock(), createElementBlock("p", _hoisted_10$e, toDisplayString(typeof _ctx.error === "string" ? _ctx.error : _ctx.error.message), 1)) : _ctx.helpText ? (openBlock(), createElementBlock("p", _hoisted_11$e, toDisplayString(_ctx.helpText), 1)) : createCommentVNode("", true)
625
+ _ctx.error ? (openBlock(), createElementBlock("p", _hoisted_10$f, toDisplayString(typeof _ctx.error === "string" ? _ctx.error : _ctx.error.message), 1)) : _ctx.helpText ? (openBlock(), createElementBlock("p", _hoisted_11$f, toDisplayString(_ctx.helpText), 1)) : createCommentVNode("", true)
626
626
  ])
627
627
  ]);
628
628
  };
629
629
  }
630
630
  });
631
- const StrandsUiInput = /* @__PURE__ */ _export_sfc(_sfc_main$t, [["__scopeId", "data-v-1fccfe97"]]);
632
- const _sfc_main$s = /* @__PURE__ */ defineComponent({
631
+ const StrandsUiInput = /* @__PURE__ */ _export_sfc(_sfc_main$u, [["__scopeId", "data-v-1fccfe97"]]);
632
+ const _sfc_main$t = /* @__PURE__ */ defineComponent({
633
633
  __name: "UiLink",
634
634
  props: {
635
635
  href: {},
@@ -712,15 +712,15 @@ const _sfc_main$s = /* @__PURE__ */ defineComponent({
712
712
  };
713
713
  }
714
714
  });
715
- const StrandsUiLink = /* @__PURE__ */ _export_sfc(_sfc_main$s, [["__scopeId", "data-v-878f97a6"]]);
716
- const _hoisted_1$q = { class: "tabs-container" };
717
- const _hoisted_2$n = { class: "tabs-wrapper" };
718
- const _hoisted_3$m = {
715
+ const StrandsUiLink = /* @__PURE__ */ _export_sfc(_sfc_main$t, [["__scopeId", "data-v-878f97a6"]]);
716
+ const _hoisted_1$r = { class: "tabs-container" };
717
+ const _hoisted_2$o = { class: "tabs-wrapper" };
718
+ const _hoisted_3$o = {
719
719
  class: "tabs-list",
720
720
  role: "tablist"
721
721
  };
722
- const _hoisted_4$l = ["aria-selected", "aria-controls", "id", "onClick"];
723
- const _sfc_main$r = /* @__PURE__ */ defineComponent({
722
+ const _hoisted_4$m = ["aria-selected", "aria-controls", "id", "onClick"];
723
+ const _sfc_main$s = /* @__PURE__ */ defineComponent({
724
724
  __name: "UiTabs",
725
725
  props: {
726
726
  modelValue: {},
@@ -807,9 +807,9 @@ const _sfc_main$r = /* @__PURE__ */ defineComponent({
807
807
  }
808
808
  });
809
809
  return (_ctx, _cache) => {
810
- return openBlock(), createElementBlock("div", _hoisted_1$q, [
811
- createElementVNode("div", _hoisted_2$n, [
812
- createElementVNode("div", _hoisted_3$m, [
810
+ return openBlock(), createElementBlock("div", _hoisted_1$r, [
811
+ createElementVNode("div", _hoisted_2$o, [
812
+ createElementVNode("div", _hoisted_3$o, [
813
813
  (openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.tabs, (tab, index) => {
814
814
  return openBlock(), createElementBlock("button", {
815
815
  key: tab.value,
@@ -822,7 +822,7 @@ const _sfc_main$r = /* @__PURE__ */ defineComponent({
822
822
  id: `tab-${tab.value}`,
823
823
  role: "tab",
824
824
  onClick: ($event) => handleTabClick(tab.value, index)
825
- }, toDisplayString(tab.label), 11, _hoisted_4$l);
825
+ }, toDisplayString(tab.label), 11, _hoisted_4$m);
826
826
  }), 128)),
827
827
  createElementVNode("div", {
828
828
  class: "tab-underline",
@@ -834,13 +834,13 @@ const _sfc_main$r = /* @__PURE__ */ defineComponent({
834
834
  };
835
835
  }
836
836
  });
837
- const StrandsUiTabs = /* @__PURE__ */ _export_sfc(_sfc_main$r, [["__scopeId", "data-v-c14b9ef2"]]);
837
+ const StrandsUiTabs = /* @__PURE__ */ _export_sfc(_sfc_main$s, [["__scopeId", "data-v-c14b9ef2"]]);
838
838
  const logo = '<svg width="302" height="438" viewBox="0 0 302 438" fill="none" xmlns="http://www.w3.org/2000/svg">\n<path d="M71.5001 96C71.5001 96 132 106 137 61.5C142 17 117.5 3.50005 94.5001 1.50003C71.5001 -0.499996 16.0001 8.5 2.00014 72.5C-6.5 130.5 71.5003 227.5 165 218C258.5 208.5 280.758 148.5 283.5 121C286.242 93.5 277.5 61.5 238.5 61.5C153 61.5 150.501 185 170.5 235C190.5 285 199 279 213 314C227.001 349 217.296 411.458 183 427C129.456 450.65 92 426 78.5 407.5C65 389 68.0003 357 94.5001 344.5C121 332 212.41 393.5 301.5 361" stroke="black"/>\n</svg>\n';
839
- const _hoisted_1$p = { class: "loader-icon" };
840
- const _hoisted_2$m = ["width", "height"];
841
- const _hoisted_3$l = ["d", "stroke", "stroke-width"];
842
- const _hoisted_4$k = ["d", "stroke", "stroke-width"];
843
- const _sfc_main$q = /* @__PURE__ */ defineComponent({
839
+ const _hoisted_1$q = { class: "loader-icon" };
840
+ const _hoisted_2$n = ["width", "height"];
841
+ const _hoisted_3$n = ["d", "stroke", "stroke-width"];
842
+ const _hoisted_4$l = ["d", "stroke", "stroke-width"];
843
+ const _sfc_main$r = /* @__PURE__ */ defineComponent({
844
844
  __name: "UiLoader",
845
845
  props: {
846
846
  size: { default: 80 },
@@ -863,7 +863,7 @@ const _sfc_main$q = /* @__PURE__ */ defineComponent({
863
863
  return openBlock(), createElementBlock("div", {
864
864
  class: normalizeClass(["loader-container", { "loader-centered": _ctx.centered }])
865
865
  }, [
866
- createElementVNode("div", _hoisted_1$p, [
866
+ createElementVNode("div", _hoisted_1$q, [
867
867
  (openBlock(), createElementBlock("svg", {
868
868
  width: _ctx.size,
869
869
  height: _ctx.size,
@@ -877,7 +877,7 @@ const _sfc_main$q = /* @__PURE__ */ defineComponent({
877
877
  "stroke-linecap": "round",
878
878
  "stroke-linejoin": "round",
879
879
  transform: "translate(81, 13) scale(1.0)"
880
- }, null, 8, _hoisted_3$l),
880
+ }, null, 8, _hoisted_3$n),
881
881
  createElementVNode("path", {
882
882
  d: unref(d),
883
883
  fill: "none",
@@ -887,8 +887,8 @@ const _sfc_main$q = /* @__PURE__ */ defineComponent({
887
887
  "stroke-linejoin": "round",
888
888
  class: "loader-animated-path",
889
889
  transform: "translate(81, 13) scale(1.0)"
890
- }, null, 8, _hoisted_4$k)
891
- ], 8, _hoisted_2$m))
890
+ }, null, 8, _hoisted_4$l)
891
+ ], 8, _hoisted_2$n))
892
892
  ]),
893
893
  _ctx.text ? (openBlock(), createElementBlock("p", {
894
894
  key: 0,
@@ -898,9 +898,9 @@ const _sfc_main$q = /* @__PURE__ */ defineComponent({
898
898
  };
899
899
  }
900
900
  });
901
- const StrandsUiLoader = /* @__PURE__ */ _export_sfc(_sfc_main$q, [["__scopeId", "data-v-1e521ef1"]]);
902
- const _hoisted_1$o = ["aria-pressed", "aria-labelledby"];
903
- const _sfc_main$p = /* @__PURE__ */ defineComponent({
901
+ const StrandsUiLoader = /* @__PURE__ */ _export_sfc(_sfc_main$r, [["__scopeId", "data-v-1e521ef1"]]);
902
+ const _hoisted_1$p = ["aria-pressed", "aria-labelledby"];
903
+ const _sfc_main$q = /* @__PURE__ */ defineComponent({
904
904
  __name: "UiToggle",
905
905
  props: {
906
906
  modelValue: { type: Boolean, default: false },
@@ -940,36 +940,36 @@ const _sfc_main$p = /* @__PURE__ */ defineComponent({
940
940
  createElementVNode("span", {
941
941
  class: normalizeClass(["ui-toggle-thumb", thumbClasses.value])
942
942
  }, null, 2)
943
- ], 10, _hoisted_1$o);
943
+ ], 10, _hoisted_1$p);
944
944
  };
945
945
  }
946
946
  });
947
- const UiToggle = /* @__PURE__ */ _export_sfc(_sfc_main$p, [["__scopeId", "data-v-b790ecf9"]]);
948
- const _hoisted_1$n = { class: "accui-component-scope" };
949
- const _hoisted_2$l = { class: "avatar-editor-simple" };
950
- const _hoisted_3$k = {
947
+ const UiToggle = /* @__PURE__ */ _export_sfc(_sfc_main$q, [["__scopeId", "data-v-b790ecf9"]]);
948
+ const _hoisted_1$o = { class: "accui-component-scope" };
949
+ const _hoisted_2$m = { class: "avatar-editor-simple" };
950
+ const _hoisted_3$m = {
951
951
  key: 1,
952
952
  class: "editor-container"
953
953
  };
954
- const _hoisted_4$j = { class: "editor-main" };
955
- const _hoisted_5$i = { class: "canvas-container" };
956
- const _hoisted_6$f = ["width", "height"];
957
- const _hoisted_7$f = { class: "crop-overlay" };
958
- const _hoisted_8$f = { class: "crop-svg" };
959
- const _hoisted_9$e = { id: "circle-mask" };
960
- const _hoisted_10$d = ["width", "height"];
961
- const _hoisted_11$d = ["cx", "cy", "r"];
962
- const _hoisted_12$d = ["width", "height"];
963
- const _hoisted_13$c = ["cx", "cy", "r"];
964
- const _hoisted_14$c = { class: "controls" };
965
- const _hoisted_15$b = { class: "zoom-control" };
966
- const _hoisted_16$b = ["min", "max"];
967
- const _hoisted_17$a = { class: "action-buttons" };
968
- const _hoisted_18$a = ["disabled"];
969
- const _hoisted_19$7 = { class: "preview-section" };
970
- const _hoisted_20$6 = { class: "preview-container" };
971
- const _hoisted_21$5 = ["width", "height"];
972
- const _sfc_main$o = /* @__PURE__ */ defineComponent({
954
+ const _hoisted_4$k = { class: "editor-main" };
955
+ const _hoisted_5$j = { class: "canvas-container" };
956
+ const _hoisted_6$g = ["width", "height"];
957
+ const _hoisted_7$g = { class: "crop-overlay" };
958
+ const _hoisted_8$g = { class: "crop-svg" };
959
+ const _hoisted_9$f = { id: "circle-mask" };
960
+ const _hoisted_10$e = ["width", "height"];
961
+ const _hoisted_11$e = ["cx", "cy", "r"];
962
+ const _hoisted_12$e = ["width", "height"];
963
+ const _hoisted_13$d = ["cx", "cy", "r"];
964
+ const _hoisted_14$d = { class: "controls" };
965
+ const _hoisted_15$c = { class: "zoom-control" };
966
+ const _hoisted_16$c = ["min", "max"];
967
+ const _hoisted_17$b = { class: "action-buttons" };
968
+ const _hoisted_18$b = ["disabled"];
969
+ const _hoisted_19$8 = { class: "preview-section" };
970
+ const _hoisted_20$7 = { class: "preview-container" };
971
+ const _hoisted_21$6 = ["width", "height"];
972
+ const _sfc_main$p = /* @__PURE__ */ defineComponent({
973
973
  __name: "UiAvatarEditor",
974
974
  props: {
975
975
  size: { default: 300 },
@@ -1252,8 +1252,8 @@ const _sfc_main$o = /* @__PURE__ */ defineComponent({
1252
1252
  }
1253
1253
  }, { immediate: true });
1254
1254
  return (_ctx, _cache) => {
1255
- return openBlock(), createElementBlock("div", _hoisted_1$n, [
1256
- createElementVNode("div", _hoisted_2$l, [
1255
+ return openBlock(), createElementBlock("div", _hoisted_1$o, [
1256
+ createElementVNode("div", _hoisted_2$m, [
1257
1257
  !imageData.value ? (openBlock(), createElementBlock("div", {
1258
1258
  key: 0,
1259
1259
  class: "upload-area",
@@ -1273,9 +1273,9 @@ const _sfc_main$o = /* @__PURE__ */ defineComponent({
1273
1273
  class: "hidden-input",
1274
1274
  onChange: handleFileSelect
1275
1275
  }, null, 544)
1276
- ], 32)) : (openBlock(), createElementBlock("div", _hoisted_3$k, [
1277
- createElementVNode("div", _hoisted_4$j, [
1278
- createElementVNode("div", _hoisted_5$i, [
1276
+ ], 32)) : (openBlock(), createElementBlock("div", _hoisted_3$m, [
1277
+ createElementVNode("div", _hoisted_4$k, [
1278
+ createElementVNode("div", _hoisted_5$j, [
1279
1279
  createElementVNode("canvas", {
1280
1280
  ref_key: "canvas",
1281
1281
  ref: canvas,
@@ -1284,24 +1284,24 @@ const _sfc_main$o = /* @__PURE__ */ defineComponent({
1284
1284
  class: "canvas",
1285
1285
  onMousedown: startDrag,
1286
1286
  onWheel: handleWheel
1287
- }, null, 40, _hoisted_6$f),
1288
- createElementVNode("div", _hoisted_7$f, [
1289
- (openBlock(), createElementBlock("svg", _hoisted_8$f, [
1287
+ }, null, 40, _hoisted_6$g),
1288
+ createElementVNode("div", _hoisted_7$g, [
1289
+ (openBlock(), createElementBlock("svg", _hoisted_8$g, [
1290
1290
  createElementVNode("defs", null, [
1291
- createElementVNode("mask", _hoisted_9$e, [
1291
+ createElementVNode("mask", _hoisted_9$f, [
1292
1292
  createElementVNode("rect", {
1293
1293
  x: "0",
1294
1294
  y: "0",
1295
1295
  width: canvasSize.value,
1296
1296
  height: canvasSize.value,
1297
1297
  fill: "white"
1298
- }, null, 8, _hoisted_10$d),
1298
+ }, null, 8, _hoisted_10$e),
1299
1299
  createElementVNode("circle", {
1300
1300
  cx: canvasSize.value / 2,
1301
1301
  cy: canvasSize.value / 2,
1302
1302
  r: cropRadius.value,
1303
1303
  fill: "black"
1304
- }, null, 8, _hoisted_11$d)
1304
+ }, null, 8, _hoisted_11$e)
1305
1305
  ])
1306
1306
  ]),
1307
1307
  createElementVNode("rect", {
@@ -1312,7 +1312,7 @@ const _sfc_main$o = /* @__PURE__ */ defineComponent({
1312
1312
  fill: "black",
1313
1313
  opacity: "0.5",
1314
1314
  mask: "url(#circle-mask)"
1315
- }, null, 8, _hoisted_12$d),
1315
+ }, null, 8, _hoisted_12$e),
1316
1316
  createElementVNode("circle", {
1317
1317
  cx: canvasSize.value / 2,
1318
1318
  cy: canvasSize.value / 2,
@@ -1321,12 +1321,12 @@ const _sfc_main$o = /* @__PURE__ */ defineComponent({
1321
1321
  stroke: "white",
1322
1322
  "stroke-width": "2",
1323
1323
  class: "crop-circle"
1324
- }, null, 8, _hoisted_13$c)
1324
+ }, null, 8, _hoisted_13$d)
1325
1325
  ]))
1326
1326
  ])
1327
1327
  ]),
1328
- createElementVNode("div", _hoisted_14$c, [
1329
- createElementVNode("div", _hoisted_15$b, [
1328
+ createElementVNode("div", _hoisted_14$d, [
1329
+ createElementVNode("div", _hoisted_15$c, [
1330
1330
  createElementVNode("button", {
1331
1331
  onClick: _cache[2] || (_cache[2] = ($event) => {
1332
1332
  zoom.value = Math.max(minZoom.value, zoom.value - 0.1);
@@ -1360,7 +1360,7 @@ const _sfc_main$o = /* @__PURE__ */ defineComponent({
1360
1360
  constrainImagePosition();
1361
1361
  updateCanvas();
1362
1362
  })
1363
- }, null, 40, _hoisted_16$b), [
1363
+ }, null, 40, _hoisted_16$c), [
1364
1364
  [
1365
1365
  vModelText,
1366
1366
  zoom.value,
@@ -1391,7 +1391,7 @@ const _sfc_main$o = /* @__PURE__ */ defineComponent({
1391
1391
  ], -1)
1392
1392
  ]))
1393
1393
  ]),
1394
- createElementVNode("div", _hoisted_17$a, [
1394
+ createElementVNode("div", _hoisted_17$b, [
1395
1395
  createElementVNode("button", {
1396
1396
  onClick: resetImage,
1397
1397
  class: "btn-secondary"
@@ -1404,20 +1404,20 @@ const _sfc_main$o = /* @__PURE__ */ defineComponent({
1404
1404
  onClick: cropAndUpload,
1405
1405
  disabled: _ctx.uploading,
1406
1406
  class: "btn-primary"
1407
- }, toDisplayString(_ctx.uploading ? "Saving..." : "Save Avatar"), 9, _hoisted_18$a)
1407
+ }, toDisplayString(_ctx.uploading ? "Saving..." : "Save Avatar"), 9, _hoisted_18$b)
1408
1408
  ])
1409
1409
  ])
1410
1410
  ]),
1411
- createElementVNode("div", _hoisted_19$7, [
1411
+ createElementVNode("div", _hoisted_19$8, [
1412
1412
  _cache[9] || (_cache[9] = createElementVNode("h3", { class: "preview-title" }, "Preview", -1)),
1413
- createElementVNode("div", _hoisted_20$6, [
1413
+ createElementVNode("div", _hoisted_20$7, [
1414
1414
  createElementVNode("canvas", {
1415
1415
  ref_key: "previewCanvas",
1416
1416
  ref: previewCanvas,
1417
1417
  width: previewSize.value,
1418
1418
  height: previewSize.value,
1419
1419
  class: "preview-canvas"
1420
- }, null, 8, _hoisted_21$5)
1420
+ }, null, 8, _hoisted_21$6)
1421
1421
  ]),
1422
1422
  _cache[10] || (_cache[10] = createElementVNode("p", { class: "preview-instructions" }, [
1423
1423
  createTextVNode(" Drag image to reposition"),
@@ -1690,22 +1690,22 @@ class SoundEffects {
1690
1690
  }
1691
1691
  }
1692
1692
  const playLevelUp = (level, userSettings) => SoundEffects.playLevelUp(level, userSettings);
1693
- const _hoisted_1$m = { class: "level-progress-container" };
1694
- const _hoisted_2$k = ["width", "height", "viewBox"];
1695
- const _hoisted_3$j = { key: 0 };
1696
- const _hoisted_4$i = ["r"];
1697
- const _hoisted_5$h = ["y"];
1698
- const _hoisted_6$e = ["d", "stroke-width"];
1699
- const _hoisted_7$e = ["d", "stroke", "stroke-width"];
1700
- const _hoisted_8$e = ["d"];
1701
- const _hoisted_9$d = ["d", "stroke", "stroke-width"];
1702
- const _hoisted_10$c = {
1693
+ const _hoisted_1$n = { class: "level-progress-container" };
1694
+ const _hoisted_2$l = ["width", "height", "viewBox"];
1695
+ const _hoisted_3$l = { key: 0 };
1696
+ const _hoisted_4$j = ["r"];
1697
+ const _hoisted_5$i = ["y"];
1698
+ const _hoisted_6$f = ["d", "stroke-width"];
1699
+ const _hoisted_7$f = ["d", "stroke", "stroke-width"];
1700
+ const _hoisted_8$f = ["d"];
1701
+ const _hoisted_9$e = ["d", "stroke", "stroke-width"];
1702
+ const _hoisted_10$d = {
1703
1703
  "font-size": "30",
1704
1704
  "font-weight": "bold",
1705
1705
  fill: "var(--purple-100)",
1706
1706
  style: { "font-family": "'Montserrat', sans-serif", "letter-spacing": "8px" }
1707
1707
  };
1708
- const _hoisted_11$c = {
1708
+ const _hoisted_11$d = {
1709
1709
  "xlink:href": "#labelTextArc",
1710
1710
  startOffset: "50%",
1711
1711
  "text-anchor": "middle",
@@ -1713,14 +1713,14 @@ const _hoisted_11$c = {
1713
1713
  "dominant-baseline": "hanging",
1714
1714
  "text-length": "100%"
1715
1715
  };
1716
- const _hoisted_12$c = ["x1", "y1", "x2", "y2"];
1716
+ const _hoisted_12$d = ["x1", "y1", "x2", "y2"];
1717
1717
  const VIEW_BOX_SIZE = 400;
1718
1718
  const ARC_PADDING = 18;
1719
1719
  const INNER_GAP = 18;
1720
1720
  const ANIMATION_DURATION = 600;
1721
1721
  const LABEL_EXTRA_DEGREES = 12;
1722
1722
  const LABEL_CHAR_DEGREES = 8;
1723
- const _sfc_main$n = /* @__PURE__ */ defineComponent({
1723
+ const _sfc_main$o = /* @__PURE__ */ defineComponent({
1724
1724
  __name: "UiLevelProgress",
1725
1725
  props: {
1726
1726
  value: {},
@@ -1871,21 +1871,21 @@ const _sfc_main$n = /* @__PURE__ */ defineComponent({
1871
1871
  prevLevel = newLevel;
1872
1872
  });
1873
1873
  return (_ctx, _cache) => {
1874
- return openBlock(), createElementBlock("div", _hoisted_1$m, [
1874
+ return openBlock(), createElementBlock("div", _hoisted_1$n, [
1875
1875
  (openBlock(), createElementBlock("svg", {
1876
1876
  width: unref(size),
1877
1877
  height: unref(size),
1878
1878
  viewBox: `0 0 ${unref(viewBox)} ${unref(viewBox)}`,
1879
1879
  style: { "position": "relative" }
1880
1880
  }, [
1881
- levelUpActive.value ? (openBlock(), createElementBlock("g", _hoisted_3$j, [
1881
+ levelUpActive.value ? (openBlock(), createElementBlock("g", _hoisted_3$l, [
1882
1882
  createElementVNode("circle", {
1883
1883
  cx: center,
1884
1884
  cy: center,
1885
1885
  r: innerCircleRadius.value,
1886
1886
  fill: "#a800ff",
1887
1887
  opacity: "0.92"
1888
- }, null, 8, _hoisted_4$i),
1888
+ }, null, 8, _hoisted_4$j),
1889
1889
  createElementVNode("text", {
1890
1890
  x: center,
1891
1891
  y: center + 15,
@@ -1894,7 +1894,7 @@ const _sfc_main$n = /* @__PURE__ */ defineComponent({
1894
1894
  "font-weight": "bold",
1895
1895
  fill: "#fff",
1896
1896
  style: { "font-family": "'Montserrat', sans-serif" }
1897
- }, "Level Up", 8, _hoisted_5$h)
1897
+ }, "Level Up", 8, _hoisted_5$i)
1898
1898
  ])) : createCommentVNode("", true),
1899
1899
  animatedValue.value >= 0 && animatedValue.value < props.max ? (openBlock(), createElementBlock("path", {
1900
1900
  key: 1,
@@ -1903,21 +1903,21 @@ const _sfc_main$n = /* @__PURE__ */ defineComponent({
1903
1903
  "stroke-width": thickness.value,
1904
1904
  fill: "none",
1905
1905
  "stroke-linecap": "round"
1906
- }, null, 8, _hoisted_6$e)) : createCommentVNode("", true),
1906
+ }, null, 8, _hoisted_6$f)) : createCommentVNode("", true),
1907
1907
  createElementVNode("path", {
1908
1908
  d: staticArcPath.value,
1909
1909
  stroke: staticArcGradient.value,
1910
1910
  "stroke-width": labelThickness.value,
1911
1911
  fill: "none",
1912
1912
  "stroke-linecap": "round"
1913
- }, null, 8, _hoisted_7$e),
1913
+ }, null, 8, _hoisted_7$f),
1914
1914
  createElementVNode("path", {
1915
1915
  id: "labelTextArc",
1916
1916
  d: labelTextArcPath.value,
1917
1917
  stroke: "transparent",
1918
1918
  fill: "none",
1919
1919
  transform: "scale(-1, 1) translate(-400, 0)"
1920
- }, null, 8, _hoisted_8$e),
1920
+ }, null, 8, _hoisted_8$f),
1921
1921
  animatedValue.value > 0 && animatedValue.value < props.max ? (openBlock(), createElementBlock("path", {
1922
1922
  key: 2,
1923
1923
  d: progressArcPath.value,
@@ -1925,9 +1925,9 @@ const _sfc_main$n = /* @__PURE__ */ defineComponent({
1925
1925
  "stroke-width": thickness.value,
1926
1926
  fill: "none",
1927
1927
  "stroke-linecap": "round"
1928
- }, null, 8, _hoisted_9$d)) : createCommentVNode("", true),
1929
- createElementVNode("text", _hoisted_10$c, [
1930
- createElementVNode("textPath", _hoisted_11$c, toDisplayString(_ctx.levelLabel), 1)
1928
+ }, null, 8, _hoisted_9$e)) : createCommentVNode("", true),
1929
+ createElementVNode("text", _hoisted_10$d, [
1930
+ createElementVNode("textPath", _hoisted_11$d, toDisplayString(_ctx.levelLabel), 1)
1931
1931
  ]),
1932
1932
  createElementVNode("defs", null, [
1933
1933
  _cache[1] || (_cache[1] = createElementVNode("linearGradient", {
@@ -1962,26 +1962,26 @@ const _sfc_main$n = /* @__PURE__ */ defineComponent({
1962
1962
  offset: "100%",
1963
1963
  "stop-color": "var(--strands-400)"
1964
1964
  }, null, -1)
1965
- ]), 8, _hoisted_12$c)
1965
+ ]), 8, _hoisted_12$d)
1966
1966
  ])
1967
- ], 8, _hoisted_2$k))
1967
+ ], 8, _hoisted_2$l))
1968
1968
  ]);
1969
1969
  };
1970
1970
  }
1971
1971
  });
1972
- const StrandsUiLevelProgress = /* @__PURE__ */ _export_sfc(_sfc_main$n, [["__scopeId", "data-v-09b7355c"]]);
1973
- const _hoisted_1$l = { class: "accui-component-scope" };
1974
- const _hoisted_2$j = { class: "modal-card" };
1975
- const _hoisted_3$i = {
1972
+ const StrandsUiLevelProgress = /* @__PURE__ */ _export_sfc(_sfc_main$o, [["__scopeId", "data-v-09b7355c"]]);
1973
+ const _hoisted_1$m = { class: "accui-component-scope" };
1974
+ const _hoisted_2$k = { class: "modal-card" };
1975
+ const _hoisted_3$k = {
1976
1976
  key: 0,
1977
1977
  class: "modal-header"
1978
1978
  };
1979
- const _hoisted_4$h = { class: "modal-content" };
1980
- const _hoisted_5$g = {
1979
+ const _hoisted_4$i = { class: "modal-content" };
1980
+ const _hoisted_5$h = {
1981
1981
  key: 1,
1982
1982
  class: "modal-footer"
1983
1983
  };
1984
- const _sfc_main$m = /* @__PURE__ */ defineComponent({
1984
+ const _sfc_main$n = /* @__PURE__ */ defineComponent({
1985
1985
  __name: "UiModal",
1986
1986
  props: {
1987
1987
  open: { type: Boolean, default: false },
@@ -1998,7 +1998,7 @@ const _sfc_main$m = /* @__PURE__ */ defineComponent({
1998
1998
  }
1999
1999
  };
2000
2000
  return (_ctx, _cache) => {
2001
- return openBlock(), createElementBlock("div", _hoisted_1$l, [
2001
+ return openBlock(), createElementBlock("div", _hoisted_1$m, [
2002
2002
  (openBlock(), createBlock(Teleport, { to: "body" }, [
2003
2003
  _ctx.open ? (openBlock(), createElementBlock("div", {
2004
2004
  key: 0,
@@ -2010,14 +2010,14 @@ const _sfc_main$m = /* @__PURE__ */ defineComponent({
2010
2010
  onClick: _cache[0] || (_cache[0] = withModifiers(() => {
2011
2011
  }, ["stop"]))
2012
2012
  }, [
2013
- createElementVNode("div", _hoisted_2$j, [
2014
- _ctx.$slots["header"] ? (openBlock(), createElementBlock("div", _hoisted_3$i, [
2013
+ createElementVNode("div", _hoisted_2$k, [
2014
+ _ctx.$slots["header"] ? (openBlock(), createElementBlock("div", _hoisted_3$k, [
2015
2015
  renderSlot(_ctx.$slots, "header", {}, void 0, true)
2016
2016
  ])) : createCommentVNode("", true),
2017
- createElementVNode("div", _hoisted_4$h, [
2017
+ createElementVNode("div", _hoisted_4$i, [
2018
2018
  renderSlot(_ctx.$slots, "default", {}, void 0, true)
2019
2019
  ]),
2020
- _ctx.$slots["footer"] ? (openBlock(), createElementBlock("div", _hoisted_5$g, [
2020
+ _ctx.$slots["footer"] ? (openBlock(), createElementBlock("div", _hoisted_5$h, [
2021
2021
  renderSlot(_ctx.$slots, "footer", {}, void 0, true)
2022
2022
  ])) : createCommentVNode("", true)
2023
2023
  ])
@@ -2028,8 +2028,7 @@ const _sfc_main$m = /* @__PURE__ */ defineComponent({
2028
2028
  };
2029
2029
  }
2030
2030
  });
2031
- const StrandsUiModal = /* @__PURE__ */ _export_sfc(_sfc_main$m, [["__scopeId", "data-v-8a7cf999"]]);
2032
- const _imports_0 = "";
2031
+ const StrandsUiModal = /* @__PURE__ */ _export_sfc(_sfc_main$n, [["__scopeId", "data-v-8a7cf999"]]);
2033
2032
  const slotHasContent = (slotName, slots) => {
2034
2033
  const slot = slots[slotName];
2035
2034
  if (!slot) return false;
@@ -2039,12 +2038,14 @@ const slotHasContent = (slotName, slots) => {
2039
2038
  }
2040
2039
  return Array.isArray(slot) && slot.length > 0;
2041
2040
  };
2042
- const _hoisted_1$k = { class: "accui-component-scope" };
2043
- const _hoisted_2$i = {
2041
+ const securedByLogo = "";
2042
+ const _hoisted_1$l = { class: "accui-component-scope" };
2043
+ const _hoisted_2$j = {
2044
2044
  key: 0,
2045
2045
  class: "secured-logo"
2046
2046
  };
2047
- const _sfc_main$l = /* @__PURE__ */ defineComponent({
2047
+ const _hoisted_3$j = ["src"];
2048
+ const _sfc_main$m = /* @__PURE__ */ defineComponent({
2048
2049
  __name: "StrandsSecuredFooter",
2049
2050
  props: {
2050
2051
  config: {}
@@ -2059,24 +2060,24 @@ const _sfc_main$l = /* @__PURE__ */ defineComponent({
2059
2060
  const slots = useSlots();
2060
2061
  const hasDefaultSlot = computed(() => slotHasContent("default", slots));
2061
2062
  return (_ctx, _cache) => {
2062
- return openBlock(), createElementBlock("div", _hoisted_1$k, [
2063
+ return openBlock(), createElementBlock("div", _hoisted_1$l, [
2063
2064
  shouldShowSecuredBy.value ? (openBlock(), createElementBlock("div", {
2064
2065
  key: 0,
2065
2066
  class: normalizeClass(["secured-footer", { "secured-footer-with-content": hasDefaultSlot.value, "secured-footer-centered": !hasDefaultSlot.value }])
2066
2067
  }, [
2067
2068
  renderSlot(_ctx.$slots, "default", {}, void 0, true),
2068
- shouldShowSecuredBy.value ? (openBlock(), createElementBlock("div", _hoisted_2$i, _cache[0] || (_cache[0] = [
2069
+ shouldShowSecuredBy.value ? (openBlock(), createElementBlock("div", _hoisted_2$j, [
2069
2070
  createElementVNode("img", {
2070
- src: _imports_0,
2071
+ src: unref(securedByLogo),
2071
2072
  class: "secured-logo-image"
2072
- }, null, -1)
2073
- ]))) : createCommentVNode("", true)
2073
+ }, null, 8, _hoisted_3$j)
2074
+ ])) : createCommentVNode("", true)
2074
2075
  ], 2)) : createCommentVNode("", true)
2075
2076
  ]);
2076
2077
  };
2077
2078
  }
2078
2079
  });
2079
- const StrandsSecuredFooter = /* @__PURE__ */ _export_sfc(_sfc_main$l, [["__scopeId", "data-v-5202ff4e"]]);
2080
+ const StrandsSecuredFooter = /* @__PURE__ */ _export_sfc(_sfc_main$m, [["__scopeId", "data-v-6dfcdb8c"]]);
2080
2081
  const mfaDevices = ref([]);
2081
2082
  const mfaEnabled = ref(false);
2082
2083
  const loading = ref(false);
@@ -2285,83 +2286,83 @@ function useStrandsMfa() {
2285
2286
  formatLastUsed
2286
2287
  };
2287
2288
  }
2288
- const _hoisted_1$j = { class: "accui-component-scope" };
2289
- const _hoisted_2$h = { class: "mfa-verification-content" };
2290
- const _hoisted_3$h = {
2289
+ const _hoisted_1$k = { class: "accui-component-scope" };
2290
+ const _hoisted_2$i = { class: "mfa-verification-content" };
2291
+ const _hoisted_3$i = {
2291
2292
  key: 0,
2292
2293
  class: "mfa-verification-loading"
2293
2294
  };
2294
- const _hoisted_4$g = { class: "mfa-verification-loading-text" };
2295
- const _hoisted_5$f = {
2295
+ const _hoisted_4$h = { class: "mfa-verification-loading-text" };
2296
+ const _hoisted_5$g = {
2296
2297
  key: 1,
2297
2298
  class: "mfa-verification-form"
2298
2299
  };
2299
- const _hoisted_6$d = {
2300
+ const _hoisted_6$e = {
2300
2301
  key: 0,
2301
2302
  class: "mfa-methods-section"
2302
2303
  };
2303
- const _hoisted_7$d = { class: "mfa-methods-grid" };
2304
- const _hoisted_8$d = ["onClick"];
2305
- const _hoisted_9$c = { class: "mfa-method-info" };
2306
- const _hoisted_10$b = { class: "mfa-method-name" };
2307
- const _hoisted_11$b = { class: "mfa-method-type" };
2308
- const _hoisted_12$b = {
2304
+ const _hoisted_7$e = { class: "mfa-methods-grid" };
2305
+ const _hoisted_8$e = ["onClick"];
2306
+ const _hoisted_9$d = { class: "mfa-method-info" };
2307
+ const _hoisted_10$c = { class: "mfa-method-name" };
2308
+ const _hoisted_11$c = { class: "mfa-method-type" };
2309
+ const _hoisted_12$c = {
2309
2310
  key: 0,
2310
2311
  class: "mfa-method-check"
2311
2312
  };
2312
- const _hoisted_13$b = {
2313
+ const _hoisted_13$c = {
2313
2314
  key: 1,
2314
2315
  class: "mfa-single-method"
2315
2316
  };
2316
- const _hoisted_14$b = { class: "mfa-single-method-content" };
2317
- const _hoisted_15$a = { class: "mfa-single-method-name" };
2318
- const _hoisted_16$a = { class: "mfa-single-method-type" };
2319
- const _hoisted_17$9 = {
2317
+ const _hoisted_14$c = { class: "mfa-single-method-content" };
2318
+ const _hoisted_15$b = { class: "mfa-single-method-name" };
2319
+ const _hoisted_16$b = { class: "mfa-single-method-type" };
2320
+ const _hoisted_17$a = {
2320
2321
  key: 2,
2321
2322
  class: "mfa-email-request"
2322
2323
  };
2323
- const _hoisted_18$9 = {
2324
+ const _hoisted_18$a = {
2324
2325
  key: 3,
2325
2326
  class: "mfa-hardware-section"
2326
2327
  };
2327
- const _hoisted_19$6 = { class: "mfa-hardware-prompt" };
2328
- const _hoisted_20$5 = { class: "mfa-hardware-prompt-content" };
2329
- const _hoisted_21$4 = { class: "mfa-hardware-prompt-icon" };
2330
- const _hoisted_22$4 = { class: "mfa-hardware-prompt-text" };
2331
- const _hoisted_23$3 = { class: "mfa-hardware-prompt-title" };
2332
- const _hoisted_24$3 = { class: "mfa-hardware-prompt-description" };
2333
- const _hoisted_25$2 = { class: "mfa-backup-option" };
2334
- const _hoisted_26$2 = {
2328
+ const _hoisted_19$7 = { class: "mfa-hardware-prompt" };
2329
+ const _hoisted_20$6 = { class: "mfa-hardware-prompt-content" };
2330
+ const _hoisted_21$5 = { class: "mfa-hardware-prompt-icon" };
2331
+ const _hoisted_22$5 = { class: "mfa-hardware-prompt-text" };
2332
+ const _hoisted_23$4 = { class: "mfa-hardware-prompt-title" };
2333
+ const _hoisted_24$4 = { class: "mfa-hardware-prompt-description" };
2334
+ const _hoisted_25$3 = { class: "mfa-backup-option" };
2335
+ const _hoisted_26$3 = {
2335
2336
  key: 0,
2336
2337
  class: "mfa-backup-input-section"
2337
2338
  };
2338
- const _hoisted_27$2 = { class: "mfa-backup-warning" };
2339
- const _hoisted_28$2 = {
2339
+ const _hoisted_27$3 = { class: "mfa-backup-warning" };
2340
+ const _hoisted_28$3 = {
2340
2341
  key: 4,
2341
2342
  class: "mfa-code-section"
2342
2343
  };
2343
- const _hoisted_29$1 = {
2344
+ const _hoisted_29$2 = {
2344
2345
  key: 0,
2345
2346
  class: "mfa-email-confirmation"
2346
2347
  };
2347
- const _hoisted_30$1 = { class: "mfa-email-confirmation-content" };
2348
- const _hoisted_31$1 = {
2348
+ const _hoisted_30$2 = { class: "mfa-email-confirmation-content" };
2349
+ const _hoisted_31$2 = {
2349
2350
  key: 1,
2350
2351
  class: "mfa-totp-help"
2351
2352
  };
2352
- const _hoisted_32$1 = { class: "mfa-device-name-text" };
2353
- const _hoisted_33$1 = {
2353
+ const _hoisted_32$2 = { class: "mfa-device-name-text" };
2354
+ const _hoisted_33$2 = {
2354
2355
  key: 2,
2355
2356
  class: "mfa-email-resend"
2356
2357
  };
2357
- const _hoisted_34$1 = { class: "mfa-backup-option" };
2358
- const _hoisted_35$1 = {
2358
+ const _hoisted_34$2 = { class: "mfa-backup-option" };
2359
+ const _hoisted_35$2 = {
2359
2360
  key: 3,
2360
2361
  class: "mfa-backup-input-section"
2361
2362
  };
2362
- const _hoisted_36$1 = { class: "mfa-backup-warning" };
2363
- const _hoisted_37$1 = { class: "mfa-verification-footer" };
2364
- const _sfc_main$k = /* @__PURE__ */ defineComponent({
2363
+ const _hoisted_36$2 = { class: "mfa-backup-warning" };
2364
+ const _hoisted_37$2 = { class: "mfa-verification-footer" };
2365
+ const _sfc_main$l = /* @__PURE__ */ defineComponent({
2365
2366
  __name: "StrandsMfaVerification",
2366
2367
  props: {
2367
2368
  show: { type: Boolean },
@@ -2638,7 +2639,7 @@ const _sfc_main$k = /* @__PURE__ */ defineComponent({
2638
2639
  }
2639
2640
  };
2640
2641
  return (_ctx, _cache) => {
2641
- return openBlock(), createElementBlock("div", _hoisted_1$j, [
2642
+ return openBlock(), createElementBlock("div", _hoisted_1$k, [
2642
2643
  createVNode(StrandsUiModal, {
2643
2644
  open: _ctx.show,
2644
2645
  "card-class": "mfa-verification-modal",
@@ -2651,7 +2652,7 @@ const _sfc_main$k = /* @__PURE__ */ defineComponent({
2651
2652
  ], -1)
2652
2653
  ])),
2653
2654
  footer: withCtx(() => [
2654
- createElementVNode("div", _hoisted_37$1, [
2655
+ createElementVNode("div", _hoisted_37$2, [
2655
2656
  createVNode(unref(StrandsUiButton), {
2656
2657
  variant: "secondary",
2657
2658
  onClick: closeModal,
@@ -2678,14 +2679,14 @@ const _sfc_main$k = /* @__PURE__ */ defineComponent({
2678
2679
  ])
2679
2680
  ]),
2680
2681
  default: withCtx(() => [
2681
- createElementVNode("div", _hoisted_2$h, [
2682
- loading2.value && !emailCodeSent.value ? (openBlock(), createElementBlock("div", _hoisted_3$h, [
2682
+ createElementVNode("div", _hoisted_2$i, [
2683
+ loading2.value && !emailCodeSent.value ? (openBlock(), createElementBlock("div", _hoisted_3$i, [
2683
2684
  createVNode(unref(StrandsUiLoader), { size: 24 }),
2684
- createElementVNode("span", _hoisted_4$g, toDisplayString(unref(isSendingMfaEmail) || unref(isVerifyingMfa) ? unref(authLoadingMessage) : "Loading..."), 1)
2685
- ])) : (openBlock(), createElementBlock("div", _hoisted_5$f, [
2686
- availableMethods.value.length > 1 ? (openBlock(), createElementBlock("div", _hoisted_6$d, [
2685
+ createElementVNode("span", _hoisted_4$h, toDisplayString(unref(isSendingMfaEmail) || unref(isVerifyingMfa) ? unref(authLoadingMessage) : "Loading..."), 1)
2686
+ ])) : (openBlock(), createElementBlock("div", _hoisted_5$g, [
2687
+ availableMethods.value.length > 1 ? (openBlock(), createElementBlock("div", _hoisted_6$e, [
2687
2688
  _cache[7] || (_cache[7] = createElementVNode("p", { class: "mfa-methods-title" }, "Choose verification method:", -1)),
2688
- createElementVNode("div", _hoisted_7$d, [
2689
+ createElementVNode("div", _hoisted_7$e, [
2689
2690
  (openBlock(true), createElementBlock(Fragment, null, renderList(availableMethods.value, (method) => {
2690
2691
  return openBlock(), createElementBlock("button", {
2691
2692
  key: method.id,
@@ -2699,29 +2700,29 @@ const _sfc_main$k = /* @__PURE__ */ defineComponent({
2699
2700
  size: 20,
2700
2701
  class: "mfa-method-icon"
2701
2702
  })),
2702
- createElementVNode("div", _hoisted_9$c, [
2703
- createElementVNode("p", _hoisted_10$b, toDisplayString(method.device_name), 1),
2704
- createElementVNode("p", _hoisted_11$b, toDisplayString(unref(getDeviceTypeName)(method.device_type)), 1)
2703
+ createElementVNode("div", _hoisted_9$d, [
2704
+ createElementVNode("p", _hoisted_10$c, toDisplayString(method.device_name), 1),
2705
+ createElementVNode("p", _hoisted_11$c, toDisplayString(unref(getDeviceTypeName)(method.device_type)), 1)
2705
2706
  ]),
2706
- selectedMethod.value?.id === method.id ? (openBlock(), createElementBlock("div", _hoisted_12$b, [
2707
+ selectedMethod.value?.id === method.id ? (openBlock(), createElementBlock("div", _hoisted_12$c, [
2707
2708
  createVNode(IconCheckCircle, { size: 20 })
2708
2709
  ])) : createCommentVNode("", true)
2709
- ], 10, _hoisted_8$d);
2710
+ ], 10, _hoisted_8$e);
2710
2711
  }), 128))
2711
2712
  ])
2712
- ])) : selectedMethod.value ? (openBlock(), createElementBlock("div", _hoisted_13$b, [
2713
- createElementVNode("div", _hoisted_14$b, [
2713
+ ])) : selectedMethod.value ? (openBlock(), createElementBlock("div", _hoisted_13$c, [
2714
+ createElementVNode("div", _hoisted_14$c, [
2714
2715
  (openBlock(), createBlock(resolveDynamicComponent(getDeviceIconComponent(selectedMethod.value.device_type)), {
2715
2716
  size: 24,
2716
2717
  class: "mfa-single-method-icon"
2717
2718
  })),
2718
2719
  createElementVNode("div", null, [
2719
- createElementVNode("h3", _hoisted_15$a, toDisplayString(selectedMethod.value.device_name), 1),
2720
- createElementVNode("p", _hoisted_16$a, toDisplayString(unref(getDeviceTypeName)(selectedMethod.value.device_type)), 1)
2720
+ createElementVNode("h3", _hoisted_15$b, toDisplayString(selectedMethod.value.device_name), 1),
2721
+ createElementVNode("p", _hoisted_16$b, toDisplayString(unref(getDeviceTypeName)(selectedMethod.value.device_type)), 1)
2721
2722
  ])
2722
2723
  ])
2723
2724
  ])) : createCommentVNode("", true),
2724
- selectedMethod.value?.device_type === "email" && !emailCodeSent.value ? (openBlock(), createElementBlock("div", _hoisted_17$9, [
2725
+ selectedMethod.value?.device_type === "email" && !emailCodeSent.value ? (openBlock(), createElementBlock("div", _hoisted_17$a, [
2725
2726
  _cache[9] || (_cache[9] = createElementVNode("p", { class: "mfa-email-request-text" }, "Click below to receive your verification code", -1)),
2726
2727
  createVNode(unref(StrandsUiButton), {
2727
2728
  variant: "primary",
@@ -2736,18 +2737,18 @@ const _sfc_main$k = /* @__PURE__ */ defineComponent({
2736
2737
  __: [8]
2737
2738
  }, 8, ["disabled", "loading"])
2738
2739
  ])) : createCommentVNode("", true),
2739
- selectedMethod.value?.device_type === "hardware" || selectedMethod.value?.device_type === "passkey" ? (openBlock(), createElementBlock("div", _hoisted_18$9, [
2740
- createElementVNode("div", _hoisted_19$6, [
2741
- createElementVNode("div", _hoisted_20$5, [
2742
- createElementVNode("div", _hoisted_21$4, [
2740
+ selectedMethod.value?.device_type === "hardware" || selectedMethod.value?.device_type === "passkey" ? (openBlock(), createElementBlock("div", _hoisted_18$a, [
2741
+ createElementVNode("div", _hoisted_19$7, [
2742
+ createElementVNode("div", _hoisted_20$6, [
2743
+ createElementVNode("div", _hoisted_21$5, [
2743
2744
  (openBlock(), createBlock(resolveDynamicComponent(selectedMethod.value.device_type === "passkey" ? IconShield : IconKeyRound), {
2744
2745
  size: 24,
2745
2746
  class: "mfa-hardware-icon-svg"
2746
2747
  }))
2747
2748
  ]),
2748
- createElementVNode("div", _hoisted_22$4, [
2749
- createElementVNode("h4", _hoisted_23$3, toDisplayString(selectedMethod.value.device_type === "passkey" ? "Use your passkey" : "Touch your hardware key"), 1),
2750
- createElementVNode("p", _hoisted_24$3, toDisplayString(selectedMethod.value.device_type === "passkey" ? "Use biometrics, PIN, or device security to authenticate" : "Insert and touch your hardware key to authenticate"), 1)
2749
+ createElementVNode("div", _hoisted_22$5, [
2750
+ createElementVNode("h4", _hoisted_23$4, toDisplayString(selectedMethod.value.device_type === "passkey" ? "Use your passkey" : "Touch your hardware key"), 1),
2751
+ createElementVNode("p", _hoisted_24$4, toDisplayString(selectedMethod.value.device_type === "passkey" ? "Use biometrics, PIN, or device security to authenticate" : "Insert and touch your hardware key to authenticate"), 1)
2751
2752
  ])
2752
2753
  ])
2753
2754
  ]),
@@ -2762,7 +2763,7 @@ const _sfc_main$k = /* @__PURE__ */ defineComponent({
2762
2763
  ]),
2763
2764
  _: 1
2764
2765
  }, 8, ["disabled", "loading"]),
2765
- createElementVNode("div", _hoisted_25$2, [
2766
+ createElementVNode("div", _hoisted_25$3, [
2766
2767
  createVNode(unref(StrandsUiButton), {
2767
2768
  variant: "ghost",
2768
2769
  size: "sm",
@@ -2779,8 +2780,8 @@ const _sfc_main$k = /* @__PURE__ */ defineComponent({
2779
2780
  _: 1
2780
2781
  })
2781
2782
  ]),
2782
- showBackupCodeInput.value ? (openBlock(), createElementBlock("div", _hoisted_26$2, [
2783
- createElementVNode("div", _hoisted_27$2, [
2783
+ showBackupCodeInput.value ? (openBlock(), createElementBlock("div", _hoisted_26$3, [
2784
+ createElementVNode("div", _hoisted_27$3, [
2784
2785
  createVNode(IconAlertTriangle, {
2785
2786
  size: 20,
2786
2787
  class: "mfa-backup-warning-icon"
@@ -2803,9 +2804,9 @@ const _sfc_main$k = /* @__PURE__ */ defineComponent({
2803
2804
  }, null, 8, ["modelValue", "error", "disabled"])
2804
2805
  ])) : createCommentVNode("", true)
2805
2806
  ])) : createCommentVNode("", true),
2806
- selectedMethod.value && selectedMethod.value.device_type !== "hardware" && selectedMethod.value.device_type !== "passkey" && (selectedMethod.value.device_type !== "email" || emailCodeSent.value) ? (openBlock(), createElementBlock("div", _hoisted_28$2, [
2807
- selectedMethod.value.device_type === "email" && emailCodeSent.value ? (openBlock(), createElementBlock("div", _hoisted_29$1, [
2808
- createElementVNode("div", _hoisted_30$1, [
2807
+ selectedMethod.value && selectedMethod.value.device_type !== "hardware" && selectedMethod.value.device_type !== "passkey" && (selectedMethod.value.device_type !== "email" || emailCodeSent.value) ? (openBlock(), createElementBlock("div", _hoisted_28$3, [
2808
+ selectedMethod.value.device_type === "email" && emailCodeSent.value ? (openBlock(), createElementBlock("div", _hoisted_29$2, [
2809
+ createElementVNode("div", _hoisted_30$2, [
2809
2810
  createVNode(IconCheckCircle, {
2810
2811
  size: 20,
2811
2812
  class: "mfa-email-confirmation-icon"
@@ -2831,11 +2832,11 @@ const _sfc_main$k = /* @__PURE__ */ defineComponent({
2831
2832
  autocomplete: selectedMethod.value.device_type === "totp" ? "one-time-code" : "one-time-code",
2832
2833
  inputmode: "numeric"
2833
2834
  }, null, 8, ["modelValue", "placeholder", "error", "disabled", "name", "autocomplete"]),
2834
- selectedMethod.value.device_type === "totp" ? (openBlock(), createElementBlock("div", _hoisted_31$1, [
2835
+ selectedMethod.value.device_type === "totp" ? (openBlock(), createElementBlock("div", _hoisted_31$2, [
2835
2836
  _cache[12] || (_cache[12] = createTextVNode(" Open your authenticator app and enter the 6-digit code for ", -1)),
2836
- createElementVNode("span", _hoisted_32$1, '"' + toDisplayString(selectedMethod.value.device_name) + '"', 1)
2837
+ createElementVNode("span", _hoisted_32$2, '"' + toDisplayString(selectedMethod.value.device_name) + '"', 1)
2837
2838
  ])) : createCommentVNode("", true),
2838
- selectedMethod.value.device_type === "email" ? (openBlock(), createElementBlock("div", _hoisted_33$1, [
2839
+ selectedMethod.value.device_type === "email" ? (openBlock(), createElementBlock("div", _hoisted_33$2, [
2839
2840
  createVNode(unref(StrandsUiButton), {
2840
2841
  variant: "ghost",
2841
2842
  size: "sm",
@@ -2849,7 +2850,7 @@ const _sfc_main$k = /* @__PURE__ */ defineComponent({
2849
2850
  _: 1
2850
2851
  }, 8, ["disabled"])
2851
2852
  ])) : createCommentVNode("", true),
2852
- createElementVNode("div", _hoisted_34$1, [
2853
+ createElementVNode("div", _hoisted_34$2, [
2853
2854
  createVNode(unref(StrandsUiButton), {
2854
2855
  variant: "ghost",
2855
2856
  size: "sm",
@@ -2866,8 +2867,8 @@ const _sfc_main$k = /* @__PURE__ */ defineComponent({
2866
2867
  _: 1
2867
2868
  })
2868
2869
  ]),
2869
- showBackupCodeInput.value ? (openBlock(), createElementBlock("div", _hoisted_35$1, [
2870
- createElementVNode("div", _hoisted_36$1, [
2870
+ showBackupCodeInput.value ? (openBlock(), createElementBlock("div", _hoisted_35$2, [
2871
+ createElementVNode("div", _hoisted_36$2, [
2871
2872
  createVNode(IconAlertTriangle, {
2872
2873
  size: 20,
2873
2874
  class: "mfa-backup-warning-icon"
@@ -2899,7 +2900,7 @@ const _sfc_main$k = /* @__PURE__ */ defineComponent({
2899
2900
  };
2900
2901
  }
2901
2902
  });
2902
- const StrandsMfaVerification = /* @__PURE__ */ _export_sfc(_sfc_main$k, [["__scopeId", "data-v-d95e0731"]]);
2903
+ const StrandsMfaVerification = /* @__PURE__ */ _export_sfc(_sfc_main$l, [["__scopeId", "data-v-d95e0731"]]);
2903
2904
  function useOAuthProviders(options = {}) {
2904
2905
  const { getUrl, config } = useStrandsConfig();
2905
2906
  const providers = ref([]);
@@ -3029,54 +3030,54 @@ function useOAuthProviders(options = {}) {
3029
3030
  getProviderIcon
3030
3031
  };
3031
3032
  }
3032
- const _hoisted_1$i = { class: "accui-component-scope" };
3033
- const _hoisted_2$g = { class: "auth-header" };
3034
- const _hoisted_3$g = {
3033
+ const _hoisted_1$j = { class: "accui-component-scope" };
3034
+ const _hoisted_2$h = { class: "auth-header" };
3035
+ const _hoisted_3$h = {
3035
3036
  key: 0,
3036
3037
  class: "auth-tabs-container"
3037
3038
  };
3038
- const _hoisted_4$f = {
3039
+ const _hoisted_4$g = {
3039
3040
  key: 0,
3040
3041
  class: "auth-oauth-providers"
3041
3042
  };
3042
- const _hoisted_5$e = { class: "auth-oauth-icon-container" };
3043
- const _hoisted_6$c = {
3043
+ const _hoisted_5$f = { class: "auth-oauth-icon-container" };
3044
+ const _hoisted_6$d = {
3044
3045
  key: 0,
3045
3046
  class: "auth-oauth-icon"
3046
3047
  };
3047
- const _hoisted_7$c = ["src", "alt"];
3048
- const _hoisted_8$c = {
3048
+ const _hoisted_7$d = ["src", "alt"];
3049
+ const _hoisted_8$d = {
3049
3050
  key: 1,
3050
3051
  viewBox: "0 0 24 24",
3051
3052
  class: "auth-oauth-icon"
3052
3053
  };
3053
- const _hoisted_9$b = {
3054
+ const _hoisted_9$c = {
3054
3055
  key: 2,
3055
3056
  class: "auth-oauth-icon auth-oauth-github",
3056
3057
  viewBox: "0 0 24 24"
3057
3058
  };
3058
- const _hoisted_10$a = {
3059
+ const _hoisted_10$b = {
3059
3060
  key: 3,
3060
3061
  class: "auth-oauth-generic-icon"
3061
3062
  };
3062
- const _hoisted_11$a = { class: "auth-oauth-generic-text" };
3063
- const _hoisted_12$a = { class: "auth-oauth-text" };
3064
- const _hoisted_13$a = {
3063
+ const _hoisted_11$b = { class: "auth-oauth-generic-text" };
3064
+ const _hoisted_12$b = { class: "auth-oauth-text" };
3065
+ const _hoisted_13$b = {
3065
3066
  key: 0,
3066
3067
  class: "auth-divider"
3067
3068
  };
3068
- const _hoisted_14$a = { class: "auth-divider-text" };
3069
- const _hoisted_15$9 = {
3069
+ const _hoisted_14$b = { class: "auth-divider-text" };
3070
+ const _hoisted_15$a = {
3070
3071
  key: 0,
3071
3072
  class: "auth-password-field"
3072
3073
  };
3073
- const _hoisted_16$9 = { class: "auth-password-header" };
3074
- const _hoisted_17$8 = {
3074
+ const _hoisted_16$a = { class: "auth-password-header" };
3075
+ const _hoisted_17$9 = {
3075
3076
  key: 0,
3076
3077
  class: "auth-back-link-container"
3077
3078
  };
3078
- const _hoisted_18$8 = { class: "auth-support-text" };
3079
- const _sfc_main$j = /* @__PURE__ */ defineComponent({
3079
+ const _hoisted_18$9 = { class: "auth-support-text" };
3080
+ const _sfc_main$k = /* @__PURE__ */ defineComponent({
3080
3081
  __name: "StrandsAuth",
3081
3082
  props: {
3082
3083
  mode: { default: "signin" },
@@ -3337,14 +3338,14 @@ const _sfc_main$j = /* @__PURE__ */ defineComponent({
3337
3338
  element.style.overflow = "";
3338
3339
  };
3339
3340
  return (_ctx, _cache) => {
3340
- return openBlock(), createElementBlock("div", _hoisted_1$i, [
3341
+ return openBlock(), createElementBlock("div", _hoisted_1$j, [
3341
3342
  createElementVNode("div", {
3342
3343
  class: normalizeClass(props.inModal ? "auth-container-modal auth-full-width auth-min-width" : "auth-container auth-full-width auth-min-width auth-max-width auth-center auth-slide-up")
3343
3344
  }, [
3344
3345
  createElementVNode("div", {
3345
3346
  class: normalizeClass(props.inModal ? "auth-content-modal" : "auth-content auth-card-modern")
3346
3347
  }, [
3347
- createElementVNode("div", _hoisted_2$g, [
3348
+ createElementVNode("div", _hoisted_2$h, [
3348
3349
  createVNode(Transition, {
3349
3350
  name: "fade",
3350
3351
  mode: "out-in"
@@ -3379,7 +3380,7 @@ const _sfc_main$j = /* @__PURE__ */ defineComponent({
3379
3380
  onAfterLeave
3380
3381
  }, {
3381
3382
  default: withCtx(() => [
3382
- !isPasswordReset.value ? (openBlock(), createElementBlock("div", _hoisted_3$g, [
3383
+ !isPasswordReset.value ? (openBlock(), createElementBlock("div", _hoisted_3$h, [
3383
3384
  createVNode(unref(StrandsUiTabs), {
3384
3385
  modelValue: currentMode.value,
3385
3386
  "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => currentMode.value = $event),
@@ -3401,7 +3402,7 @@ const _sfc_main$j = /* @__PURE__ */ defineComponent({
3401
3402
  onAfterLeave
3402
3403
  }, {
3403
3404
  default: withCtx(() => [
3404
- !isPasswordReset.value && displayProviders.value?.length ? (openBlock(), createElementBlock("div", _hoisted_4$f, [
3405
+ !isPasswordReset.value && displayProviders.value?.length ? (openBlock(), createElementBlock("div", _hoisted_4$g, [
3405
3406
  (openBlock(true), createElementBlock(Fragment, null, renderList(displayProviders.value, (provider) => {
3406
3407
  return openBlock(), createBlock(unref(StrandsUiButton), {
3407
3408
  key: provider.id,
@@ -3412,14 +3413,14 @@ const _sfc_main$j = /* @__PURE__ */ defineComponent({
3412
3413
  class: "auth-oauth-button"
3413
3414
  }, {
3414
3415
  default: withCtx(() => [
3415
- createElementVNode("div", _hoisted_5$e, [
3416
- provider.icon || provider.iconUrl ? (openBlock(), createElementBlock("div", _hoisted_6$c, [
3416
+ createElementVNode("div", _hoisted_5$f, [
3417
+ provider.icon || provider.iconUrl ? (openBlock(), createElementBlock("div", _hoisted_6$d, [
3417
3418
  createElementVNode("img", {
3418
3419
  src: provider.icon || provider.iconUrl,
3419
3420
  alt: `${provider.displayName || provider.name} icon`,
3420
3421
  class: "auth-oauth-icon"
3421
- }, null, 8, _hoisted_7$c)
3422
- ])) : provider.id === "google" ? (openBlock(), createElementBlock("svg", _hoisted_8$c, _cache[6] || (_cache[6] = [
3422
+ }, null, 8, _hoisted_7$d)
3423
+ ])) : provider.id === "google" ? (openBlock(), createElementBlock("svg", _hoisted_8$d, _cache[6] || (_cache[6] = [
3423
3424
  createElementVNode("path", {
3424
3425
  fill: "#4285F4",
3425
3426
  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"
@@ -3436,13 +3437,13 @@ const _sfc_main$j = /* @__PURE__ */ defineComponent({
3436
3437
  fill: "#EA4335",
3437
3438
  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"
3438
3439
  }, null, -1)
3439
- ]))) : provider.id === "github" ? (openBlock(), createElementBlock("svg", _hoisted_9$b, _cache[7] || (_cache[7] = [
3440
+ ]))) : provider.id === "github" ? (openBlock(), createElementBlock("svg", _hoisted_9$c, _cache[7] || (_cache[7] = [
3440
3441
  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)
3441
- ]))) : (openBlock(), createElementBlock("div", _hoisted_10$a, [
3442
- createElementVNode("span", _hoisted_11$a, toDisplayString((provider.displayName || provider.name).charAt(0).toUpperCase()), 1)
3442
+ ]))) : (openBlock(), createElementBlock("div", _hoisted_10$b, [
3443
+ createElementVNode("span", _hoisted_11$b, toDisplayString((provider.displayName || provider.name).charAt(0).toUpperCase()), 1)
3443
3444
  ]))
3444
3445
  ]),
3445
- createElementVNode("span", _hoisted_12$a, " Continue with " + toDisplayString(provider.displayName || provider.name.charAt(0).toUpperCase() + provider.name.slice(1)), 1)
3446
+ createElementVNode("span", _hoisted_12$b, " Continue with " + toDisplayString(provider.displayName || provider.name.charAt(0).toUpperCase() + provider.name.slice(1)), 1)
3446
3447
  ]),
3447
3448
  _: 2
3448
3449
  }, 1032, ["disabled", "onClick"]);
@@ -3460,8 +3461,8 @@ const _sfc_main$j = /* @__PURE__ */ defineComponent({
3460
3461
  onAfterLeave
3461
3462
  }, {
3462
3463
  default: withCtx(() => [
3463
- !isPasswordReset.value && displayProviders.value?.length ? (openBlock(), createElementBlock("div", _hoisted_13$a, [
3464
- createElementVNode("span", _hoisted_14$a, "Or " + toDisplayString(isSignUp.value ? "create account" : "sign in") + " with email", 1)
3464
+ !isPasswordReset.value && displayProviders.value?.length ? (openBlock(), createElementBlock("div", _hoisted_13$b, [
3465
+ createElementVNode("span", _hoisted_14$b, "Or " + toDisplayString(isSignUp.value ? "create account" : "sign in") + " with email", 1)
3465
3466
  ])) : createCommentVNode("", true)
3466
3467
  ]),
3467
3468
  _: 1
@@ -3494,8 +3495,8 @@ const _sfc_main$j = /* @__PURE__ */ defineComponent({
3494
3495
  onAfterLeave
3495
3496
  }, {
3496
3497
  default: withCtx(() => [
3497
- !isPasswordReset.value && !isSignUp.value ? (openBlock(), createElementBlock("div", _hoisted_15$9, [
3498
- createElementVNode("div", _hoisted_16$9, [
3498
+ !isPasswordReset.value && !isSignUp.value ? (openBlock(), createElementBlock("div", _hoisted_15$a, [
3499
+ createElementVNode("div", _hoisted_16$a, [
3499
3500
  _cache[9] || (_cache[9] = createElementVNode("span", { class: "auth-password-label" }, "Password", -1)),
3500
3501
  createVNode(unref(StrandsUiLink), {
3501
3502
  variant: "primary",
@@ -3560,7 +3561,7 @@ const _sfc_main$j = /* @__PURE__ */ defineComponent({
3560
3561
  onAfterLeave
3561
3562
  }, {
3562
3563
  default: withCtx(() => [
3563
- isPasswordReset.value ? (openBlock(), createElementBlock("div", _hoisted_17$8, [
3564
+ isPasswordReset.value ? (openBlock(), createElementBlock("div", _hoisted_17$9, [
3564
3565
  createVNode(unref(StrandsUiLink), {
3565
3566
  onClick: _cache[4] || (_cache[4] = ($event) => currentMode.value = "signin"),
3566
3567
  class: "auth-back-link"
@@ -3605,7 +3606,7 @@ const _sfc_main$j = /* @__PURE__ */ defineComponent({
3605
3606
  name: "support-fade"
3606
3607
  }, {
3607
3608
  default: withCtx(() => [
3608
- createElementVNode("p", _hoisted_18$8, [
3609
+ createElementVNode("p", _hoisted_18$9, [
3609
3610
  _cache[12] || (_cache[12] = createTextVNode(" Need help? ", -1)),
3610
3611
  createVNode(unref(StrandsUiLink), {
3611
3612
  variant: "primary",
@@ -3637,47 +3638,47 @@ const _sfc_main$j = /* @__PURE__ */ defineComponent({
3637
3638
  };
3638
3639
  }
3639
3640
  });
3640
- const StrandsAuth = /* @__PURE__ */ _export_sfc(_sfc_main$j, [["__scopeId", "data-v-6f6cb2ad"]]);
3641
- const _hoisted_1$h = { class: "accui-component-scope" };
3642
- const _hoisted_2$f = { class: "accui-w-full accui-min-w-100 accui-max-w-md accui-mx-auto accui-animate-slide-up" };
3643
- const _hoisted_3$f = {
3641
+ const StrandsAuth = /* @__PURE__ */ _export_sfc(_sfc_main$k, [["__scopeId", "data-v-ba0feb8a"]]);
3642
+ const _hoisted_1$i = { class: "accui-component-scope" };
3643
+ const _hoisted_2$g = { class: "accui-w-full accui-min-w-100 accui-max-w-md accui-mx-auto accui-animate-slide-up" };
3644
+ const _hoisted_3$g = {
3644
3645
  key: 0,
3645
3646
  class: "accui-space-y-3 accui-mb-6"
3646
3647
  };
3647
- const _hoisted_4$e = { class: "accui-w-5 accui-h-5 accui-flex accui-items-center accui-justify-center" };
3648
- const _hoisted_5$d = {
3648
+ const _hoisted_4$f = { class: "accui-w-5 accui-h-5 accui-flex accui-items-center accui-justify-center" };
3649
+ const _hoisted_5$e = {
3649
3650
  key: 0,
3650
3651
  class: "accui-w-5 accui-h-5"
3651
3652
  };
3652
- const _hoisted_6$b = ["src", "alt"];
3653
- const _hoisted_7$b = {
3653
+ const _hoisted_6$c = ["src", "alt"];
3654
+ const _hoisted_7$c = {
3654
3655
  key: 1,
3655
3656
  viewBox: "0 0 24 24",
3656
3657
  class: "accui-w-5 accui-h-5"
3657
3658
  };
3658
- const _hoisted_8$b = {
3659
+ const _hoisted_8$c = {
3659
3660
  key: 2,
3660
3661
  class: "accui-w-5 accui-h-5 accui-fill-current",
3661
3662
  viewBox: "0 0 24 24"
3662
3663
  };
3663
- const _hoisted_9$a = {
3664
+ const _hoisted_9$b = {
3664
3665
  key: 3,
3665
3666
  class: "accui-w-5 accui-h-5 accui-rounded-full accui-bg-neutral-300 accui-flex accui-items-center accui-justify-center"
3666
3667
  };
3667
- const _hoisted_10$9 = { class: "accui-text-xs accui-font-semibold accui-text-neutral-600" };
3668
- const _hoisted_11$9 = { class: "accui-font-medium" };
3669
- const _hoisted_12$9 = {
3668
+ const _hoisted_10$a = { class: "accui-text-xs accui-font-semibold accui-text-neutral-600" };
3669
+ const _hoisted_11$a = { class: "accui-font-medium" };
3670
+ const _hoisted_12$a = {
3670
3671
  key: 1,
3671
3672
  class: "divider-with-text"
3672
3673
  };
3673
- const _hoisted_13$9 = { class: "email-field-spacing has-password" };
3674
- const _hoisted_14$9 = { class: "accui-mb-4" };
3675
- const _hoisted_15$8 = { class: "accui-text-center accui-mt-4" };
3676
- const _hoisted_16$8 = { class: "accui-mt-8 accui-text-center" };
3677
- const _hoisted_17$7 = { class: "accui-text-sm accui-text-neutral-600" };
3678
- const _hoisted_18$7 = { key: 0 };
3679
- const _hoisted_19$5 = { class: "accui-text-neutral-400 accui-text-sm" };
3680
- const _sfc_main$i = /* @__PURE__ */ defineComponent({
3674
+ const _hoisted_13$a = { class: "email-field-spacing has-password" };
3675
+ const _hoisted_14$a = { class: "accui-mb-4" };
3676
+ const _hoisted_15$9 = { class: "accui-text-center accui-mt-4" };
3677
+ const _hoisted_16$9 = { class: "accui-mt-8 accui-text-center" };
3678
+ const _hoisted_17$8 = { class: "accui-text-sm accui-text-neutral-600" };
3679
+ const _hoisted_18$8 = { key: 0 };
3680
+ const _hoisted_19$6 = { class: "accui-text-neutral-400 accui-text-sm" };
3681
+ const _sfc_main$j = /* @__PURE__ */ defineComponent({
3681
3682
  __name: "StrandsSignIn",
3682
3683
  props: {
3683
3684
  redirectUrl: {},
@@ -3765,15 +3766,15 @@ const _sfc_main$i = /* @__PURE__ */ defineComponent({
3765
3766
  }
3766
3767
  };
3767
3768
  return (_ctx, _cache) => {
3768
- return openBlock(), createElementBlock("div", _hoisted_1$h, [
3769
- createElementVNode("div", _hoisted_2$f, [
3769
+ return openBlock(), createElementBlock("div", _hoisted_1$i, [
3770
+ createElementVNode("div", _hoisted_2$g, [
3770
3771
  createVNode(unref(StrandsUiCard), { variant: "modern" }, {
3771
3772
  default: withCtx(() => [
3772
3773
  _cache[15] || (_cache[15] = createElementVNode("div", { class: "accui-text-center accui-mb-8" }, [
3773
3774
  createElementVNode("h1", { class: "accui-text-3xl accui-font-bold accui-text-gradient accui-mb-2" }, "Welcome back"),
3774
3775
  createElementVNode("p", { class: "accui-text-neutral-600" }, "Sign in to your account to continue")
3775
3776
  ], -1)),
3776
- unref(enabledProviders)?.length ? (openBlock(), createElementBlock("div", _hoisted_3$f, [
3777
+ unref(enabledProviders)?.length ? (openBlock(), createElementBlock("div", _hoisted_3$g, [
3777
3778
  (openBlock(true), createElementBlock(Fragment, null, renderList(unref(enabledProviders), (provider) => {
3778
3779
  return openBlock(), createBlock(unref(StrandsUiButton), {
3779
3780
  key: provider.id,
@@ -3784,14 +3785,14 @@ const _sfc_main$i = /* @__PURE__ */ defineComponent({
3784
3785
  class: "btn-oauth accui-group"
3785
3786
  }, {
3786
3787
  default: withCtx(() => [
3787
- createElementVNode("div", _hoisted_4$e, [
3788
- provider.icon || provider.iconUrl ? (openBlock(), createElementBlock("div", _hoisted_5$d, [
3788
+ createElementVNode("div", _hoisted_4$f, [
3789
+ provider.icon || provider.iconUrl ? (openBlock(), createElementBlock("div", _hoisted_5$e, [
3789
3790
  createElementVNode("img", {
3790
3791
  src: provider.icon || provider.iconUrl,
3791
3792
  alt: `${provider.displayName || provider.name} icon`,
3792
3793
  class: "accui-w-5 accui-h-5"
3793
- }, null, 8, _hoisted_6$b)
3794
- ])) : provider.id === "google" ? (openBlock(), createElementBlock("svg", _hoisted_7$b, _cache[5] || (_cache[5] = [
3794
+ }, null, 8, _hoisted_6$c)
3795
+ ])) : provider.id === "google" ? (openBlock(), createElementBlock("svg", _hoisted_7$c, _cache[5] || (_cache[5] = [
3795
3796
  createElementVNode("path", {
3796
3797
  fill: "#4285F4",
3797
3798
  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"
@@ -3808,19 +3809,19 @@ const _sfc_main$i = /* @__PURE__ */ defineComponent({
3808
3809
  fill: "#EA4335",
3809
3810
  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"
3810
3811
  }, null, -1)
3811
- ]))) : provider.id === "github" ? (openBlock(), createElementBlock("svg", _hoisted_8$b, _cache[6] || (_cache[6] = [
3812
+ ]))) : provider.id === "github" ? (openBlock(), createElementBlock("svg", _hoisted_8$c, _cache[6] || (_cache[6] = [
3812
3813
  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)
3813
- ]))) : (openBlock(), createElementBlock("div", _hoisted_9$a, [
3814
- createElementVNode("span", _hoisted_10$9, toDisplayString((provider.displayName || provider.name).charAt(0).toUpperCase()), 1)
3814
+ ]))) : (openBlock(), createElementBlock("div", _hoisted_9$b, [
3815
+ createElementVNode("span", _hoisted_10$a, toDisplayString((provider.displayName || provider.name).charAt(0).toUpperCase()), 1)
3815
3816
  ]))
3816
3817
  ]),
3817
- createElementVNode("span", _hoisted_11$9, "Continue with " + toDisplayString(provider.displayName || provider.name), 1)
3818
+ createElementVNode("span", _hoisted_11$a, "Continue with " + toDisplayString(provider.displayName || provider.name), 1)
3818
3819
  ]),
3819
3820
  _: 2
3820
3821
  }, 1032, ["disabled", "onClick"]);
3821
3822
  }), 128))
3822
3823
  ])) : createCommentVNode("", true),
3823
- unref(enabledProviders)?.length ? (openBlock(), createElementBlock("div", _hoisted_12$9, _cache[7] || (_cache[7] = [
3824
+ unref(enabledProviders)?.length ? (openBlock(), createElementBlock("div", _hoisted_12$a, _cache[7] || (_cache[7] = [
3824
3825
  createElementVNode("span", { class: "divider-text" }, "Or sign in with email", -1)
3825
3826
  ]))) : createCommentVNode("", true),
3826
3827
  createElementVNode("form", {
@@ -3828,7 +3829,7 @@ const _sfc_main$i = /* @__PURE__ */ defineComponent({
3828
3829
  class: "accui-gap-6 accui-flex accui-flex-col"
3829
3830
  }, [
3830
3831
  createElementVNode("div", null, [
3831
- createElementVNode("div", _hoisted_13$9, [
3832
+ createElementVNode("div", _hoisted_13$a, [
3832
3833
  createVNode(unref(StrandsUiInput), {
3833
3834
  id: "email",
3834
3835
  modelValue: form.email,
@@ -3841,7 +3842,7 @@ const _sfc_main$i = /* @__PURE__ */ defineComponent({
3841
3842
  error: error.value ? "Invalid email or password" : void 0
3842
3843
  }, null, 8, ["modelValue", "error"])
3843
3844
  ]),
3844
- createElementVNode("div", _hoisted_14$9, [
3845
+ createElementVNode("div", _hoisted_14$a, [
3845
3846
  _cache[8] || (_cache[8] = createElementVNode("span", { class: "accui-text-sm accui-font-medium accui-text-neutral-700 accui-block accui-mb-2" }, "Password", -1)),
3846
3847
  createVNode(unref(StrandsUiInput), {
3847
3848
  id: "password",
@@ -3870,7 +3871,7 @@ const _sfc_main$i = /* @__PURE__ */ defineComponent({
3870
3871
  __: [9]
3871
3872
  }, 8, ["disabled", "loading"])
3872
3873
  ], 32),
3873
- createElementVNode("div", _hoisted_15$8, [
3874
+ createElementVNode("div", _hoisted_15$9, [
3874
3875
  createVNode(unref(StrandsUiLink), {
3875
3876
  onClick: _cache[2] || (_cache[2] = ($event) => _ctx.$emit("forgot-password")),
3876
3877
  class: "accui-text-sm"
@@ -3890,8 +3891,8 @@ const _sfc_main$i = /* @__PURE__ */ defineComponent({
3890
3891
  dismissible: "",
3891
3892
  onDismiss: _cache[3] || (_cache[3] = ($event) => error.value = "")
3892
3893
  }, null, 8, ["message"])) : createCommentVNode("", true),
3893
- createElementVNode("div", _hoisted_16$8, [
3894
- createElementVNode("p", _hoisted_17$7, [
3894
+ createElementVNode("div", _hoisted_16$9, [
3895
+ createElementVNode("p", _hoisted_17$8, [
3895
3896
  _cache[12] || (_cache[12] = createTextVNode(" Don't have an account? ", -1)),
3896
3897
  createVNode(unref(StrandsUiLink), {
3897
3898
  onClick: _cache[4] || (_cache[4] = ($event) => _ctx.$emit("switch-to-signup"))
@@ -3908,8 +3909,8 @@ const _sfc_main$i = /* @__PURE__ */ defineComponent({
3908
3909
  config: props.config
3909
3910
  }, {
3910
3911
  default: withCtx(() => [
3911
- unref(getSupportEmail)() ? (openBlock(), createElementBlock("div", _hoisted_18$7, [
3912
- createElementVNode("p", _hoisted_19$5, [
3912
+ unref(getSupportEmail)() ? (openBlock(), createElementBlock("div", _hoisted_18$8, [
3913
+ createElementVNode("p", _hoisted_19$6, [
3913
3914
  _cache[14] || (_cache[14] = createTextVNode(" Need help? ", -1)),
3914
3915
  createVNode(unref(StrandsUiLink), {
3915
3916
  variant: "primary",
@@ -3943,58 +3944,58 @@ const _sfc_main$i = /* @__PURE__ */ defineComponent({
3943
3944
  };
3944
3945
  }
3945
3946
  });
3946
- const StrandsSignIn = /* @__PURE__ */ _export_sfc(_sfc_main$i, [["__scopeId", "data-v-87adc9ee"]]);
3947
- const _hoisted_1$g = { class: "accui-component-scope" };
3948
- const _hoisted_2$e = { class: "signup-container" };
3949
- const _hoisted_3$e = { class: "signup-success" };
3950
- const _hoisted_4$d = { class: "signup-success-title" };
3951
- const _hoisted_5$c = { class: "signup-success-message" };
3952
- const _hoisted_6$a = {
3947
+ const StrandsSignIn = /* @__PURE__ */ _export_sfc(_sfc_main$j, [["__scopeId", "data-v-87adc9ee"]]);
3948
+ const _hoisted_1$h = { class: "accui-component-scope" };
3949
+ const _hoisted_2$f = { class: "signup-container" };
3950
+ const _hoisted_3$f = { class: "signup-success" };
3951
+ const _hoisted_4$e = { class: "signup-success-title" };
3952
+ const _hoisted_5$d = { class: "signup-success-message" };
3953
+ const _hoisted_6$b = {
3953
3954
  key: 0,
3954
3955
  class: "signup-success-email"
3955
3956
  };
3956
- const _hoisted_7$a = {
3957
+ const _hoisted_7$b = {
3957
3958
  key: 0,
3958
3959
  class: "oauth-providers"
3959
3960
  };
3960
- const _hoisted_8$a = { class: "oauth-icon-container" };
3961
- const _hoisted_9$9 = {
3961
+ const _hoisted_8$b = { class: "oauth-icon-container" };
3962
+ const _hoisted_9$a = {
3962
3963
  key: 0,
3963
3964
  class: "oauth-icon"
3964
3965
  };
3965
- const _hoisted_10$8 = ["src", "alt"];
3966
- const _hoisted_11$8 = {
3966
+ const _hoisted_10$9 = ["src", "alt"];
3967
+ const _hoisted_11$9 = {
3967
3968
  key: 1,
3968
3969
  viewBox: "0 0 24 24",
3969
3970
  class: "oauth-icon"
3970
3971
  };
3971
- const _hoisted_12$8 = {
3972
+ const _hoisted_12$9 = {
3972
3973
  key: 2,
3973
3974
  class: "oauth-icon oauth-icon-github",
3974
3975
  viewBox: "0 0 24 24"
3975
3976
  };
3976
- const _hoisted_13$8 = {
3977
+ const _hoisted_13$9 = {
3977
3978
  key: 3,
3978
3979
  class: "oauth-icon-fallback"
3979
3980
  };
3980
- const _hoisted_14$8 = { class: "oauth-icon-fallback-text" };
3981
- const _hoisted_15$7 = { class: "oauth-button-text" };
3982
- const _hoisted_16$7 = {
3981
+ const _hoisted_14$9 = { class: "oauth-icon-fallback-text" };
3982
+ const _hoisted_15$8 = { class: "oauth-button-text" };
3983
+ const _hoisted_16$8 = {
3983
3984
  key: 1,
3984
3985
  class: "divider-with-text"
3985
3986
  };
3986
- const _hoisted_17$6 = {
3987
+ const _hoisted_17$7 = {
3987
3988
  key: 2,
3988
3989
  class: "signup-error"
3989
3990
  };
3990
- const _hoisted_18$6 = { class: "signup-error-content" };
3991
- const _hoisted_19$4 = { class: "signup-error-icon-container" };
3992
- const _hoisted_20$4 = { class: "signup-error-message" };
3993
- const _hoisted_21$3 = { class: "signup-signin-link" };
3994
- const _hoisted_22$3 = { class: "signup-signin-text" };
3995
- const _hoisted_23$2 = { key: 0 };
3996
- const _hoisted_24$2 = { class: "signup-support-text" };
3997
- const _sfc_main$h = /* @__PURE__ */ defineComponent({
3991
+ const _hoisted_18$7 = { class: "signup-error-content" };
3992
+ const _hoisted_19$5 = { class: "signup-error-icon-container" };
3993
+ const _hoisted_20$5 = { class: "signup-error-message" };
3994
+ const _hoisted_21$4 = { class: "signup-signin-link" };
3995
+ const _hoisted_22$4 = { class: "signup-signin-text" };
3996
+ const _hoisted_23$3 = { key: 0 };
3997
+ const _hoisted_24$3 = { class: "signup-support-text" };
3998
+ const _sfc_main$i = /* @__PURE__ */ defineComponent({
3998
3999
  __name: "StrandsSignUp",
3999
4000
  props: {
4000
4001
  redirectUrl: {},
@@ -4120,18 +4121,18 @@ const _sfc_main$h = /* @__PURE__ */ defineComponent({
4120
4121
  }
4121
4122
  };
4122
4123
  return (_ctx, _cache) => {
4123
- return openBlock(), createElementBlock("div", _hoisted_1$g, [
4124
- createElementVNode("div", _hoisted_2$e, [
4124
+ return openBlock(), createElementBlock("div", _hoisted_1$h, [
4125
+ createElementVNode("div", _hoisted_2$f, [
4125
4126
  signupSuccess.value ? (openBlock(), createBlock(unref(StrandsUiCard), {
4126
4127
  key: 0,
4127
4128
  variant: "modern"
4128
4129
  }, {
4129
4130
  default: withCtx(() => [
4130
- createElementVNode("div", _hoisted_3$e, [
4131
+ createElementVNode("div", _hoisted_3$f, [
4131
4132
  _cache[3] || (_cache[3] = createElementVNode("div", { class: "signup-success-icon" }, "📧", -1)),
4132
- createElementVNode("h1", _hoisted_4$d, toDisplayString(successTitle.value), 1),
4133
- createElementVNode("p", _hoisted_5$c, toDisplayString(successMessage.value), 1),
4134
- successEmail.value ? (openBlock(), createElementBlock("div", _hoisted_6$a, [
4133
+ createElementVNode("h1", _hoisted_4$e, toDisplayString(successTitle.value), 1),
4134
+ createElementVNode("p", _hoisted_5$d, toDisplayString(successMessage.value), 1),
4135
+ successEmail.value ? (openBlock(), createElementBlock("div", _hoisted_6$b, [
4135
4136
  createElementVNode("strong", null, toDisplayString(successEmail.value), 1)
4136
4137
  ])) : createCommentVNode("", true),
4137
4138
  _cache[4] || (_cache[4] = createElementVNode("p", { class: "signup-success-instructions" }, " Click the link in your email to complete your account setup. The link will expire in 24 hours. ", -1)),
@@ -4158,7 +4159,7 @@ const _sfc_main$h = /* @__PURE__ */ defineComponent({
4158
4159
  createElementVNode("h1", { class: "signup-title" }, "Create account"),
4159
4160
  createElementVNode("p", { class: "signup-subtitle" }, "We'll send you a magic link to get started")
4160
4161
  ], -1)),
4161
- unref(enabledProviders)?.length ? (openBlock(), createElementBlock("div", _hoisted_7$a, [
4162
+ unref(enabledProviders)?.length ? (openBlock(), createElementBlock("div", _hoisted_7$b, [
4162
4163
  (openBlock(true), createElementBlock(Fragment, null, renderList(unref(enabledProviders), (provider) => {
4163
4164
  return openBlock(), createBlock(unref(StrandsUiButton), {
4164
4165
  key: provider.id,
@@ -4169,14 +4170,14 @@ const _sfc_main$h = /* @__PURE__ */ defineComponent({
4169
4170
  class: "btn-oauth group"
4170
4171
  }, {
4171
4172
  default: withCtx(() => [
4172
- createElementVNode("div", _hoisted_8$a, [
4173
- provider.icon || provider.iconUrl ? (openBlock(), createElementBlock("div", _hoisted_9$9, [
4173
+ createElementVNode("div", _hoisted_8$b, [
4174
+ provider.icon || provider.iconUrl ? (openBlock(), createElementBlock("div", _hoisted_9$a, [
4174
4175
  createElementVNode("img", {
4175
4176
  src: provider.icon || provider.iconUrl,
4176
4177
  alt: `${provider.displayName || provider.name} icon`,
4177
4178
  class: "oauth-icon-image"
4178
- }, null, 8, _hoisted_10$8)
4179
- ])) : provider.id === "google" ? (openBlock(), createElementBlock("svg", _hoisted_11$8, _cache[5] || (_cache[5] = [
4179
+ }, null, 8, _hoisted_10$9)
4180
+ ])) : provider.id === "google" ? (openBlock(), createElementBlock("svg", _hoisted_11$9, _cache[5] || (_cache[5] = [
4180
4181
  createElementVNode("path", {
4181
4182
  fill: "#4285F4",
4182
4183
  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"
@@ -4193,19 +4194,19 @@ const _sfc_main$h = /* @__PURE__ */ defineComponent({
4193
4194
  fill: "#EA4335",
4194
4195
  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"
4195
4196
  }, null, -1)
4196
- ]))) : provider.id === "github" ? (openBlock(), createElementBlock("svg", _hoisted_12$8, _cache[6] || (_cache[6] = [
4197
+ ]))) : provider.id === "github" ? (openBlock(), createElementBlock("svg", _hoisted_12$9, _cache[6] || (_cache[6] = [
4197
4198
  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)
4198
- ]))) : (openBlock(), createElementBlock("div", _hoisted_13$8, [
4199
- createElementVNode("span", _hoisted_14$8, toDisplayString((provider.displayName || provider.name).charAt(0).toUpperCase()), 1)
4199
+ ]))) : (openBlock(), createElementBlock("div", _hoisted_13$9, [
4200
+ createElementVNode("span", _hoisted_14$9, toDisplayString((provider.displayName || provider.name).charAt(0).toUpperCase()), 1)
4200
4201
  ]))
4201
4202
  ]),
4202
- createElementVNode("span", _hoisted_15$7, "Continue with " + toDisplayString(provider.displayName || provider.name), 1)
4203
+ createElementVNode("span", _hoisted_15$8, "Continue with " + toDisplayString(provider.displayName || provider.name), 1)
4203
4204
  ]),
4204
4205
  _: 2
4205
4206
  }, 1032, ["disabled", "onClick"]);
4206
4207
  }), 128))
4207
4208
  ])) : createCommentVNode("", true),
4208
- unref(enabledProviders)?.length ? (openBlock(), createElementBlock("div", _hoisted_16$7, _cache[7] || (_cache[7] = [
4209
+ unref(enabledProviders)?.length ? (openBlock(), createElementBlock("div", _hoisted_16$8, _cache[7] || (_cache[7] = [
4209
4210
  createElementVNode("span", { class: "divider-text" }, "Or create account with email", -1)
4210
4211
  ]))) : createCommentVNode("", true),
4211
4212
  createElementVNode("form", {
@@ -4240,9 +4241,9 @@ const _sfc_main$h = /* @__PURE__ */ defineComponent({
4240
4241
  __: [8]
4241
4242
  }, 8, ["disabled", "loading"])
4242
4243
  ], 32),
4243
- error.value ? (openBlock(), createElementBlock("div", _hoisted_17$6, [
4244
- createElementVNode("div", _hoisted_18$6, [
4245
- createElementVNode("div", _hoisted_19$4, [
4244
+ error.value ? (openBlock(), createElementBlock("div", _hoisted_17$7, [
4245
+ createElementVNode("div", _hoisted_18$7, [
4246
+ createElementVNode("div", _hoisted_19$5, [
4246
4247
  _cache[9] || (_cache[9] = createElementVNode("svg", {
4247
4248
  class: "signup-error-icon",
4248
4249
  fill: "currentColor",
@@ -4254,12 +4255,12 @@ const _sfc_main$h = /* @__PURE__ */ defineComponent({
4254
4255
  "clip-rule": "evenodd"
4255
4256
  })
4256
4257
  ], -1)),
4257
- createElementVNode("p", _hoisted_20$4, toDisplayString(error.value), 1)
4258
+ createElementVNode("p", _hoisted_20$5, toDisplayString(error.value), 1)
4258
4259
  ])
4259
4260
  ])
4260
4261
  ])) : createCommentVNode("", true),
4261
- createElementVNode("div", _hoisted_21$3, [
4262
- createElementVNode("p", _hoisted_22$3, [
4262
+ createElementVNode("div", _hoisted_21$4, [
4263
+ createElementVNode("p", _hoisted_22$4, [
4263
4264
  _cache[10] || (_cache[10] = createTextVNode(" Already have an account? ", -1)),
4264
4265
  createElementVNode("button", {
4265
4266
  type: "button",
@@ -4272,8 +4273,8 @@ const _sfc_main$h = /* @__PURE__ */ defineComponent({
4272
4273
  config: props.config
4273
4274
  }, {
4274
4275
  default: withCtx(() => [
4275
- unref(getSupportEmail)() ? (openBlock(), createElementBlock("div", _hoisted_23$2, [
4276
- createElementVNode("p", _hoisted_24$2, [
4276
+ unref(getSupportEmail)() ? (openBlock(), createElementBlock("div", _hoisted_23$3, [
4277
+ createElementVNode("p", _hoisted_24$3, [
4277
4278
  _cache[12] || (_cache[12] = createTextVNode(" Need help? ", -1)),
4278
4279
  createVNode(unref(StrandsUiLink), {
4279
4280
  variant: "primary",
@@ -4299,40 +4300,40 @@ const _sfc_main$h = /* @__PURE__ */ defineComponent({
4299
4300
  };
4300
4301
  }
4301
4302
  });
4302
- const StrandsSignUp = /* @__PURE__ */ _export_sfc(_sfc_main$h, [["__scopeId", "data-v-ab42f1ba"]]);
4303
- const _hoisted_1$f = { class: "accui-component-scope" };
4304
- const _hoisted_2$d = {
4303
+ const StrandsSignUp = /* @__PURE__ */ _export_sfc(_sfc_main$i, [["__scopeId", "data-v-ab42f1ba"]]);
4304
+ const _hoisted_1$g = { class: "accui-component-scope" };
4305
+ const _hoisted_2$e = {
4305
4306
  key: 0,
4306
4307
  class: "complete-signup-container"
4307
4308
  };
4308
- const _hoisted_3$d = { class: "complete-signup-success" };
4309
- const _hoisted_4$c = {
4309
+ const _hoisted_3$e = { class: "complete-signup-success" };
4310
+ const _hoisted_4$d = {
4310
4311
  key: 1,
4311
4312
  class: "complete-signup-container"
4312
4313
  };
4313
- const _hoisted_5$b = { class: "complete-signup-error" };
4314
- const _hoisted_6$9 = {
4314
+ const _hoisted_5$c = { class: "complete-signup-error" };
4315
+ const _hoisted_6$a = {
4315
4316
  key: 2,
4316
4317
  class: "complete-signup-container"
4317
4318
  };
4318
- const _hoisted_7$9 = { class: "complete-signup-header" };
4319
- const _hoisted_8$9 = {
4319
+ const _hoisted_7$a = { class: "complete-signup-header" };
4320
+ const _hoisted_8$a = {
4320
4321
  key: 0,
4321
4322
  class: "complete-signup-email-info"
4322
4323
  };
4323
- const _hoisted_9$8 = { class: "complete-signup-email-text" };
4324
- const _hoisted_10$7 = { class: "complete-signup-email-highlight" };
4325
- const _hoisted_11$7 = {
4324
+ const _hoisted_9$9 = { class: "complete-signup-email-text" };
4325
+ const _hoisted_10$8 = { class: "complete-signup-email-highlight" };
4326
+ const _hoisted_11$8 = {
4326
4327
  key: 0,
4327
4328
  class: "complete-signup-support"
4328
4329
  };
4329
- const _hoisted_12$7 = { class: "complete-signup-support-text" };
4330
- const _hoisted_13$7 = {
4330
+ const _hoisted_12$8 = { class: "complete-signup-support-text" };
4331
+ const _hoisted_13$8 = {
4331
4332
  key: 3,
4332
4333
  class: "complete-signup-container"
4333
4334
  };
4334
- const _hoisted_14$7 = { class: "complete-signup-warning" };
4335
- const _sfc_main$g = /* @__PURE__ */ defineComponent({
4335
+ const _hoisted_14$8 = { class: "complete-signup-warning" };
4336
+ const _sfc_main$h = /* @__PURE__ */ defineComponent({
4336
4337
  __name: "StrandsCompleteSignUp",
4337
4338
  props: {
4338
4339
  token: {},
@@ -4462,11 +4463,11 @@ const _sfc_main$g = /* @__PURE__ */ defineComponent({
4462
4463
  }
4463
4464
  };
4464
4465
  return (_ctx, _cache) => {
4465
- return openBlock(), createElementBlock("div", _hoisted_1$f, [
4466
- registrationComplete.value ? (openBlock(), createElementBlock("div", _hoisted_2$d, [
4466
+ return openBlock(), createElementBlock("div", _hoisted_1$g, [
4467
+ registrationComplete.value ? (openBlock(), createElementBlock("div", _hoisted_2$e, [
4467
4468
  createVNode(unref(StrandsUiCard), { variant: "modern" }, {
4468
4469
  default: withCtx(() => [
4469
- createElementVNode("div", _hoisted_3$d, [
4470
+ createElementVNode("div", _hoisted_3$e, [
4470
4471
  _cache[7] || (_cache[7] = createElementVNode("div", { class: "complete-signup-success-icon" }, "🎉", -1)),
4471
4472
  _cache[8] || (_cache[8] = createElementVNode("h1", { class: "complete-signup-success-title" }, "Welcome to Strands!", -1)),
4472
4473
  _cache[9] || (_cache[9] = createElementVNode("p", { class: "complete-signup-success-message" }, " Your account has been created successfully. ", -1)),
@@ -4487,10 +4488,10 @@ const _sfc_main$g = /* @__PURE__ */ defineComponent({
4487
4488
  ]),
4488
4489
  _: 1
4489
4490
  })
4490
- ])) : invalidToken.value ? (openBlock(), createElementBlock("div", _hoisted_4$c, [
4491
+ ])) : invalidToken.value ? (openBlock(), createElementBlock("div", _hoisted_4$d, [
4491
4492
  createVNode(unref(StrandsUiCard), { variant: "modern" }, {
4492
4493
  default: withCtx(() => [
4493
- createElementVNode("div", _hoisted_5$b, [
4494
+ createElementVNode("div", _hoisted_5$c, [
4494
4495
  _cache[12] || (_cache[12] = createElementVNode("div", { class: "complete-signup-error-icon" }, "❌", -1)),
4495
4496
  _cache[13] || (_cache[13] = createElementVNode("h1", { class: "complete-signup-error-title" }, "Invalid Link", -1)),
4496
4497
  _cache[14] || (_cache[14] = createElementVNode("p", { class: "complete-signup-error-message" }, " This registration link is invalid or has expired. ", -1)),
@@ -4511,16 +4512,16 @@ const _sfc_main$g = /* @__PURE__ */ defineComponent({
4511
4512
  ]),
4512
4513
  _: 1
4513
4514
  })
4514
- ])) : _ctx.token ? (openBlock(), createElementBlock("div", _hoisted_6$9, [
4515
+ ])) : _ctx.token ? (openBlock(), createElementBlock("div", _hoisted_6$a, [
4515
4516
  createVNode(unref(StrandsUiCard), { variant: "modern" }, {
4516
4517
  default: withCtx(() => [
4517
- createElementVNode("div", _hoisted_7$9, [
4518
+ createElementVNode("div", _hoisted_7$a, [
4518
4519
  _cache[17] || (_cache[17] = createElementVNode("h1", { class: "complete-signup-title" }, "Complete Your Registration", -1)),
4519
4520
  _cache[18] || (_cache[18] = createElementVNode("p", { class: "complete-signup-subtitle" }, "Set up your account details to finish registration", -1)),
4520
- email.value ? (openBlock(), createElementBlock("div", _hoisted_8$9, [
4521
- createElementVNode("p", _hoisted_9$8, [
4521
+ email.value ? (openBlock(), createElementBlock("div", _hoisted_8$a, [
4522
+ createElementVNode("p", _hoisted_9$9, [
4522
4523
  _cache[16] || (_cache[16] = createTextVNode("Creating account for: ", -1)),
4523
- createElementVNode("span", _hoisted_10$7, toDisplayString(email.value), 1)
4524
+ createElementVNode("span", _hoisted_10$8, toDisplayString(email.value), 1)
4524
4525
  ])
4525
4526
  ])) : createCommentVNode("", true)
4526
4527
  ]),
@@ -4594,8 +4595,8 @@ const _sfc_main$g = /* @__PURE__ */ defineComponent({
4594
4595
  config: props.config
4595
4596
  }, {
4596
4597
  default: withCtx(() => [
4597
- unref(getSupportEmail)() ? (openBlock(), createElementBlock("div", _hoisted_11$7, [
4598
- createElementVNode("p", _hoisted_12$7, [
4598
+ unref(getSupportEmail)() ? (openBlock(), createElementBlock("div", _hoisted_11$8, [
4599
+ createElementVNode("p", _hoisted_12$8, [
4599
4600
  _cache[22] || (_cache[22] = createTextVNode(" Need help? ", -1)),
4600
4601
  createVNode(unref(StrandsUiLink), {
4601
4602
  variant: "primary",
@@ -4615,10 +4616,10 @@ const _sfc_main$g = /* @__PURE__ */ defineComponent({
4615
4616
  ]),
4616
4617
  _: 1
4617
4618
  })
4618
- ])) : (openBlock(), createElementBlock("div", _hoisted_13$7, [
4619
+ ])) : (openBlock(), createElementBlock("div", _hoisted_13$8, [
4619
4620
  createVNode(unref(StrandsUiCard), { variant: "modern" }, {
4620
4621
  default: withCtx(() => [
4621
- createElementVNode("div", _hoisted_14$7, [
4622
+ createElementVNode("div", _hoisted_14$8, [
4622
4623
  _cache[24] || (_cache[24] = createElementVNode("div", { class: "complete-signup-warning-icon" }, "⚠️", -1)),
4623
4624
  _cache[25] || (_cache[25] = createElementVNode("h1", { class: "complete-signup-warning-title" }, "Missing Token", -1)),
4624
4625
  _cache[26] || (_cache[26] = createElementVNode("p", { class: "complete-signup-warning-message" }, " No registration token was provided. ", -1)),
@@ -4644,49 +4645,49 @@ const _sfc_main$g = /* @__PURE__ */ defineComponent({
4644
4645
  };
4645
4646
  }
4646
4647
  });
4647
- const StrandsCompleteSignUp = /* @__PURE__ */ _export_sfc(_sfc_main$g, [["__scopeId", "data-v-b08a9ea5"]]);
4648
- const _hoisted_1$e = { class: "accui-component-scope" };
4649
- const _hoisted_2$c = {
4648
+ const StrandsCompleteSignUp = /* @__PURE__ */ _export_sfc(_sfc_main$h, [["__scopeId", "data-v-b08a9ea5"]]);
4649
+ const _hoisted_1$f = { class: "accui-component-scope" };
4650
+ const _hoisted_2$d = {
4650
4651
  key: 0,
4651
4652
  class: "step-container"
4652
4653
  };
4653
- const _hoisted_3$c = { class: "step-actions" };
4654
- const _hoisted_4$b = {
4654
+ const _hoisted_3$d = { class: "step-actions" };
4655
+ const _hoisted_4$c = {
4655
4656
  key: 1,
4656
4657
  class: "step-container"
4657
4658
  };
4658
- const _hoisted_5$a = { class: "qr-container" };
4659
- const _hoisted_6$8 = {
4659
+ const _hoisted_5$b = { class: "qr-container" };
4660
+ const _hoisted_6$9 = {
4660
4661
  key: 0,
4661
4662
  class: "qr-wrapper"
4662
4663
  };
4663
- const _hoisted_7$8 = ["src"];
4664
- const _hoisted_8$8 = {
4664
+ const _hoisted_7$9 = ["src"];
4665
+ const _hoisted_8$9 = {
4665
4666
  key: 1,
4666
4667
  class: "qr-loading"
4667
4668
  };
4668
- const _hoisted_9$7 = { class: "manual-entry" };
4669
- const _hoisted_10$6 = { class: "manual-code" };
4670
- const _hoisted_11$6 = {
4669
+ const _hoisted_9$8 = { class: "manual-entry" };
4670
+ const _hoisted_10$7 = { class: "manual-code" };
4671
+ const _hoisted_11$7 = {
4671
4672
  key: 0,
4672
4673
  class: "bg-yellow-50 border border-yellow-200 rounded-lg p-4"
4673
4674
  };
4674
- const _hoisted_12$6 = { class: "flex justify-end space-x-3 pt-4" };
4675
- const _hoisted_13$6 = {
4675
+ const _hoisted_12$7 = { class: "flex justify-end space-x-3 pt-4" };
4676
+ const _hoisted_13$7 = {
4676
4677
  key: 2,
4677
4678
  class: "space-y-4"
4678
4679
  };
4679
- const _hoisted_14$6 = { class: "totp-setup-step-actions" };
4680
- const _hoisted_15$6 = {
4680
+ const _hoisted_14$7 = { class: "totp-setup-step-actions" };
4681
+ const _hoisted_15$7 = {
4681
4682
  key: 3,
4682
4683
  class: "totp-setup-step"
4683
4684
  };
4684
- const _hoisted_16$6 = { class: "totp-setup-backup-codes" };
4685
- const _hoisted_17$5 = { class: "totp-setup-backup-grid-wrapper" };
4686
- const _hoisted_18$5 = { class: "totp-setup-backup-grid" };
4687
- const _hoisted_19$3 = { class: "totp-setup-backup-actions" };
4688
- const _hoisted_20$3 = { class: "totp-setup-final-actions" };
4689
- const _sfc_main$f = /* @__PURE__ */ defineComponent({
4685
+ const _hoisted_16$7 = { class: "totp-setup-backup-codes" };
4686
+ const _hoisted_17$6 = { class: "totp-setup-backup-grid-wrapper" };
4687
+ const _hoisted_18$6 = { class: "totp-setup-backup-grid" };
4688
+ const _hoisted_19$4 = { class: "totp-setup-backup-actions" };
4689
+ const _hoisted_20$4 = { class: "totp-setup-final-actions" };
4690
+ const _sfc_main$g = /* @__PURE__ */ defineComponent({
4690
4691
  __name: "StrandsTotpSetupModal",
4691
4692
  props: {
4692
4693
  show: { type: Boolean }
@@ -4771,7 +4772,7 @@ const _sfc_main$f = /* @__PURE__ */ defineComponent({
4771
4772
  emit("success");
4772
4773
  };
4773
4774
  return (_ctx, _cache) => {
4774
- return openBlock(), createElementBlock("div", _hoisted_1$e, [
4775
+ return openBlock(), createElementBlock("div", _hoisted_1$f, [
4775
4776
  createVNode(StrandsUiModal, {
4776
4777
  open: _ctx.show,
4777
4778
  onClose: closeModal,
@@ -4801,7 +4802,7 @@ const _sfc_main$f = /* @__PURE__ */ defineComponent({
4801
4802
  ])
4802
4803
  ]),
4803
4804
  default: withCtx(() => [
4804
- step.value === 1 ? (openBlock(), createElementBlock("div", _hoisted_2$c, [
4805
+ step.value === 1 ? (openBlock(), createElementBlock("div", _hoisted_2$d, [
4805
4806
  _cache[9] || (_cache[9] = createElementVNode("div", null, [
4806
4807
  createElementVNode("h3", { class: "step-title" }, "Name Your Device"),
4807
4808
  createElementVNode("p", { class: "step-description" }, ' Give this authenticator a memorable name (e.g., "iPhone", "Work Phone") ')
@@ -4814,7 +4815,7 @@ const _sfc_main$f = /* @__PURE__ */ defineComponent({
4814
4815
  error: deviceNameError.value,
4815
4816
  disabled: unref(loading2)
4816
4817
  }, null, 8, ["modelValue", "error", "disabled"]),
4817
- createElementVNode("div", _hoisted_3$c, [
4818
+ createElementVNode("div", _hoisted_3$d, [
4818
4819
  createVNode(unref(StrandsUiButton), {
4819
4820
  variant: "secondary",
4820
4821
  onClick: closeModal,
@@ -4840,27 +4841,27 @@ const _sfc_main$f = /* @__PURE__ */ defineComponent({
4840
4841
  }, 8, ["disabled", "loading"])
4841
4842
  ])
4842
4843
  ])) : createCommentVNode("", true),
4843
- step.value === 2 ? (openBlock(), createElementBlock("div", _hoisted_4$b, [
4844
+ step.value === 2 ? (openBlock(), createElementBlock("div", _hoisted_4$c, [
4844
4845
  _cache[14] || (_cache[14] = createElementVNode("div", null, [
4845
4846
  createElementVNode("h3", { class: "step-title" }, "Scan QR Code"),
4846
4847
  createElementVNode("p", { class: "step-description" }, " Scan this QR code with your authenticator app (Google Authenticator, Authy, etc.) ")
4847
4848
  ], -1)),
4848
- createElementVNode("div", _hoisted_5$a, [
4849
- qrCodeDataUrl.value ? (openBlock(), createElementBlock("div", _hoisted_6$8, [
4849
+ createElementVNode("div", _hoisted_5$b, [
4850
+ qrCodeDataUrl.value ? (openBlock(), createElementBlock("div", _hoisted_6$9, [
4850
4851
  createElementVNode("img", {
4851
4852
  src: qrCodeDataUrl.value,
4852
4853
  alt: "TOTP QR Code",
4853
4854
  class: "qr-image"
4854
- }, null, 8, _hoisted_7$8)
4855
- ])) : (openBlock(), createElementBlock("div", _hoisted_8$8, [
4855
+ }, null, 8, _hoisted_7$9)
4856
+ ])) : (openBlock(), createElementBlock("div", _hoisted_8$9, [
4856
4857
  createVNode(unref(StrandsUiLoader), { size: 24 })
4857
4858
  ]))
4858
4859
  ]),
4859
- createElementVNode("div", _hoisted_9$7, [
4860
+ createElementVNode("div", _hoisted_9$8, [
4860
4861
  _cache[10] || (_cache[10] = createElementVNode("p", { class: "manual-label" }, " Can't scan? Enter this code manually: ", -1)),
4861
- createElementVNode("code", _hoisted_10$6, toDisplayString(totpSetupData.value?.secret || "..."), 1)
4862
+ createElementVNode("code", _hoisted_10$7, toDisplayString(totpSetupData.value?.secret || "..."), 1)
4862
4863
  ]),
4863
- totpSetupData.value?.backup_codes ? (openBlock(), createElementBlock("div", _hoisted_11$6, _cache[11] || (_cache[11] = [
4864
+ totpSetupData.value?.backup_codes ? (openBlock(), createElementBlock("div", _hoisted_11$7, _cache[11] || (_cache[11] = [
4864
4865
  createElementVNode("div", { class: "flex items-start space-x-2" }, [
4865
4866
  createElementVNode("svg", {
4866
4867
  class: "w-5 h-5 text-yellow-600 mt-0.5 flex-shrink-0",
@@ -4879,7 +4880,7 @@ const _sfc_main$f = /* @__PURE__ */ defineComponent({
4879
4880
  ])
4880
4881
  ], -1)
4881
4882
  ]))) : createCommentVNode("", true),
4882
- createElementVNode("div", _hoisted_12$6, [
4883
+ createElementVNode("div", _hoisted_12$7, [
4883
4884
  createVNode(unref(StrandsUiButton), {
4884
4885
  variant: "secondary",
4885
4886
  onClick: _cache[1] || (_cache[1] = ($event) => step.value = 1),
@@ -4904,7 +4905,7 @@ const _sfc_main$f = /* @__PURE__ */ defineComponent({
4904
4905
  }, 8, ["disabled"])
4905
4906
  ])
4906
4907
  ])) : createCommentVNode("", true),
4907
- step.value === 3 ? (openBlock(), createElementBlock("div", _hoisted_13$6, [
4908
+ step.value === 3 ? (openBlock(), createElementBlock("div", _hoisted_13$7, [
4908
4909
  _cache[17] || (_cache[17] = createElementVNode("div", null, [
4909
4910
  createElementVNode("h3", { class: "text-lg font-semibold text-gray-900 mb-2" }, "Verify Setup"),
4910
4911
  createElementVNode("p", { class: "text-sm text-gray-600 mb-4" }, " Enter the 6-digit code from your authenticator app to complete setup ")
@@ -4919,7 +4920,7 @@ const _sfc_main$f = /* @__PURE__ */ defineComponent({
4919
4920
  disabled: unref(loading2),
4920
4921
  onInput: onVerificationCodeInput
4921
4922
  }, null, 8, ["modelValue", "error", "disabled"]),
4922
- createElementVNode("div", _hoisted_14$6, [
4923
+ createElementVNode("div", _hoisted_14$7, [
4923
4924
  createVNode(unref(StrandsUiButton), {
4924
4925
  variant: "secondary",
4925
4926
  onClick: _cache[4] || (_cache[4] = ($event) => step.value = 2),
@@ -4945,7 +4946,7 @@ const _sfc_main$f = /* @__PURE__ */ defineComponent({
4945
4946
  }, 8, ["disabled", "loading"])
4946
4947
  ])
4947
4948
  ])) : createCommentVNode("", true),
4948
- step.value === 4 ? (openBlock(), createElementBlock("div", _hoisted_15$6, [
4949
+ step.value === 4 ? (openBlock(), createElementBlock("div", _hoisted_15$7, [
4949
4950
  _cache[21] || (_cache[21] = createElementVNode("div", { class: "totp-setup-success" }, [
4950
4951
  createElementVNode("div", { class: "totp-setup-success-icon" }, [
4951
4952
  createElementVNode("svg", {
@@ -4965,7 +4966,7 @@ const _sfc_main$f = /* @__PURE__ */ defineComponent({
4965
4966
  createElementVNode("h3", { class: "totp-setup-step-title" }, "TOTP Setup Complete!"),
4966
4967
  createElementVNode("p", { class: "totp-setup-success-description" }, " Your authenticator app is now active for two-factor authentication. ")
4967
4968
  ], -1)),
4968
- createElementVNode("div", _hoisted_16$6, [
4969
+ createElementVNode("div", _hoisted_16$7, [
4969
4970
  _cache[19] || (_cache[19] = createElementVNode("div", { class: "totp-setup-backup-header" }, [
4970
4971
  createElementVNode("svg", {
4971
4972
  class: "totp-setup-backup-warning-icon",
@@ -4983,8 +4984,8 @@ const _sfc_main$f = /* @__PURE__ */ defineComponent({
4983
4984
  createElementVNode("p", { class: "totp-setup-backup-header-description" }, " Store these codes in a safe place. Each code can only be used once. ")
4984
4985
  ])
4985
4986
  ], -1)),
4986
- createElementVNode("div", _hoisted_17$5, [
4987
- createElementVNode("div", _hoisted_18$5, [
4987
+ createElementVNode("div", _hoisted_17$6, [
4988
+ createElementVNode("div", _hoisted_18$6, [
4988
4989
  (openBlock(true), createElementBlock(Fragment, null, renderList(totpSetupData.value?.backup_codes, (code, index) => {
4989
4990
  return openBlock(), createElementBlock("div", {
4990
4991
  key: index,
@@ -4993,7 +4994,7 @@ const _sfc_main$f = /* @__PURE__ */ defineComponent({
4993
4994
  }), 128))
4994
4995
  ])
4995
4996
  ]),
4996
- createElementVNode("div", _hoisted_19$3, [
4997
+ createElementVNode("div", _hoisted_19$4, [
4997
4998
  createVNode(unref(StrandsUiButton), {
4998
4999
  variant: "secondary",
4999
5000
  size: "sm",
@@ -5007,7 +5008,7 @@ const _sfc_main$f = /* @__PURE__ */ defineComponent({
5007
5008
  })
5008
5009
  ])
5009
5010
  ]),
5010
- createElementVNode("div", _hoisted_20$3, [
5011
+ createElementVNode("div", _hoisted_20$4, [
5011
5012
  createVNode(unref(StrandsUiButton), {
5012
5013
  variant: "primary",
5013
5014
  onClick: finish
@@ -5027,25 +5028,25 @@ const _sfc_main$f = /* @__PURE__ */ defineComponent({
5027
5028
  };
5028
5029
  }
5029
5030
  });
5030
- const StrandsTotpSetupModal = /* @__PURE__ */ _export_sfc(_sfc_main$f, [["__scopeId", "data-v-d3ba73e3"]]);
5031
- const _hoisted_1$d = { class: "accui-component-scope" };
5032
- const _hoisted_2$b = {
5031
+ const StrandsTotpSetupModal = /* @__PURE__ */ _export_sfc(_sfc_main$g, [["__scopeId", "data-v-d3ba73e3"]]);
5032
+ const _hoisted_1$e = { class: "accui-component-scope" };
5033
+ const _hoisted_2$c = {
5033
5034
  key: 0,
5034
5035
  class: "email-mfa-setup-step"
5035
5036
  };
5036
- const _hoisted_3$b = { class: "email-mfa-setup-step-actions" };
5037
- const _hoisted_4$a = {
5037
+ const _hoisted_3$c = { class: "email-mfa-setup-step-actions" };
5038
+ const _hoisted_4$b = {
5038
5039
  key: 1,
5039
5040
  class: "email-mfa-setup-step"
5040
5041
  };
5041
- const _hoisted_5$9 = { class: "email-mfa-setup-resend-section" };
5042
- const _hoisted_6$7 = { class: "email-mfa-setup-step-actions" };
5043
- const _hoisted_7$7 = {
5042
+ const _hoisted_5$a = { class: "email-mfa-setup-resend-section" };
5043
+ const _hoisted_6$8 = { class: "email-mfa-setup-step-actions" };
5044
+ const _hoisted_7$8 = {
5044
5045
  key: 2,
5045
5046
  class: "email-mfa-setup-step"
5046
5047
  };
5047
- const _hoisted_8$7 = { class: "email-mfa-setup-final-actions" };
5048
- const _sfc_main$e = /* @__PURE__ */ defineComponent({
5048
+ const _hoisted_8$8 = { class: "email-mfa-setup-final-actions" };
5049
+ const _sfc_main$f = /* @__PURE__ */ defineComponent({
5049
5050
  __name: "StrandsEmailMfaSetupModal",
5050
5051
  props: {
5051
5052
  show: { type: Boolean }
@@ -5153,7 +5154,7 @@ const _sfc_main$e = /* @__PURE__ */ defineComponent({
5153
5154
  emit("success");
5154
5155
  };
5155
5156
  return (_ctx, _cache) => {
5156
- return openBlock(), createElementBlock("div", _hoisted_1$d, [
5157
+ return openBlock(), createElementBlock("div", _hoisted_1$e, [
5157
5158
  createVNode(StrandsUiModal, {
5158
5159
  open: _ctx.show,
5159
5160
  onClose: closeModal,
@@ -5183,7 +5184,7 @@ const _sfc_main$e = /* @__PURE__ */ defineComponent({
5183
5184
  ])
5184
5185
  ]),
5185
5186
  default: withCtx(() => [
5186
- step.value === 1 ? (openBlock(), createElementBlock("div", _hoisted_2$b, [
5187
+ step.value === 1 ? (openBlock(), createElementBlock("div", _hoisted_2$c, [
5187
5188
  _cache[7] || (_cache[7] = createElementVNode("div", null, [
5188
5189
  createElementVNode("h3", { class: "email-mfa-setup-step-title" }, "Name Your Email 2FA"),
5189
5190
  createElementVNode("p", { class: "email-mfa-setup-step-description" }, ' Give this email 2FA method a memorable name (e.g., "Personal Email", "Work Email") ')
@@ -5215,7 +5216,7 @@ const _sfc_main$e = /* @__PURE__ */ defineComponent({
5215
5216
  ])
5216
5217
  ])
5217
5218
  ], -1)),
5218
- createElementVNode("div", _hoisted_3$b, [
5219
+ createElementVNode("div", _hoisted_3$c, [
5219
5220
  createVNode(unref(StrandsUiButton), {
5220
5221
  variant: "secondary",
5221
5222
  onClick: closeModal,
@@ -5241,7 +5242,7 @@ const _sfc_main$e = /* @__PURE__ */ defineComponent({
5241
5242
  }, 8, ["disabled", "loading"])
5242
5243
  ])
5243
5244
  ])) : createCommentVNode("", true),
5244
- step.value === 2 ? (openBlock(), createElementBlock("div", _hoisted_4$a, [
5245
+ step.value === 2 ? (openBlock(), createElementBlock("div", _hoisted_4$b, [
5245
5246
  _cache[11] || (_cache[11] = createElementVNode("div", null, [
5246
5247
  createElementVNode("h3", { class: "email-mfa-setup-step-title" }, "Test Email 2FA"),
5247
5248
  createElementVNode("p", { class: "email-mfa-setup-step-description" }, " We've sent a test verification code to your email. Enter it below to complete setup. ")
@@ -5275,7 +5276,7 @@ const _sfc_main$e = /* @__PURE__ */ defineComponent({
5275
5276
  disabled: unref(loading2),
5276
5277
  onInput: onVerificationCodeInput
5277
5278
  }, null, 8, ["modelValue", "error", "disabled"]),
5278
- createElementVNode("div", _hoisted_5$9, [
5279
+ createElementVNode("div", _hoisted_5$a, [
5279
5280
  createVNode(unref(StrandsUiButton), {
5280
5281
  variant: "secondary",
5281
5282
  size: "sm",
@@ -5288,7 +5289,7 @@ const _sfc_main$e = /* @__PURE__ */ defineComponent({
5288
5289
  _: 1
5289
5290
  }, 8, ["disabled"])
5290
5291
  ]),
5291
- createElementVNode("div", _hoisted_6$7, [
5292
+ createElementVNode("div", _hoisted_6$8, [
5292
5293
  createVNode(unref(StrandsUiButton), {
5293
5294
  variant: "secondary",
5294
5295
  onClick: _cache[2] || (_cache[2] = ($event) => step.value = 1),
@@ -5314,7 +5315,7 @@ const _sfc_main$e = /* @__PURE__ */ defineComponent({
5314
5315
  }, 8, ["disabled", "loading"])
5315
5316
  ])
5316
5317
  ])) : createCommentVNode("", true),
5317
- step.value === 3 ? (openBlock(), createElementBlock("div", _hoisted_7$7, [
5318
+ step.value === 3 ? (openBlock(), createElementBlock("div", _hoisted_7$8, [
5318
5319
  _cache[14] || (_cache[14] = createElementVNode("div", { class: "email-mfa-setup-completion" }, [
5319
5320
  createElementVNode("div", { class: "email-mfa-setup-completion-icon" }, [
5320
5321
  createElementVNode("svg", {
@@ -5353,7 +5354,7 @@ const _sfc_main$e = /* @__PURE__ */ defineComponent({
5353
5354
  ])
5354
5355
  ])
5355
5356
  ], -1)),
5356
- createElementVNode("div", _hoisted_8$7, [
5357
+ createElementVNode("div", _hoisted_8$8, [
5357
5358
  createVNode(unref(StrandsUiButton), {
5358
5359
  variant: "primary",
5359
5360
  onClick: finish
@@ -5373,45 +5374,45 @@ const _sfc_main$e = /* @__PURE__ */ defineComponent({
5373
5374
  };
5374
5375
  }
5375
5376
  });
5376
- const StrandsEmailMfaSetupModal = /* @__PURE__ */ _export_sfc(_sfc_main$e, [["__scopeId", "data-v-188dcefe"]]);
5377
- const _hoisted_1$c = { class: "accui-component-scope" };
5378
- const _hoisted_2$a = {
5377
+ const StrandsEmailMfaSetupModal = /* @__PURE__ */ _export_sfc(_sfc_main$f, [["__scopeId", "data-v-188dcefe"]]);
5378
+ const _hoisted_1$d = { class: "accui-component-scope" };
5379
+ const _hoisted_2$b = {
5379
5380
  key: 0,
5380
5381
  class: "hardware-key-setup-step"
5381
5382
  };
5382
- const _hoisted_3$a = { class: "hardware-key-setup-actions" };
5383
- const _hoisted_4$9 = {
5383
+ const _hoisted_3$b = { class: "hardware-key-setup-actions" };
5384
+ const _hoisted_4$a = {
5384
5385
  key: 1,
5385
5386
  class: "hardware-key-setup-step"
5386
5387
  };
5387
- const _hoisted_5$8 = { class: "hardware-key-setup-instructions" };
5388
- const _hoisted_6$6 = { class: "hardware-key-setup-instructions-header" };
5389
- const _hoisted_7$6 = { class: "hardware-key-setup-instructions-list" };
5390
- const _hoisted_8$6 = { class: "hardware-key-setup-actions" };
5391
- const _hoisted_9$6 = {
5388
+ const _hoisted_5$9 = { class: "hardware-key-setup-instructions" };
5389
+ const _hoisted_6$7 = { class: "hardware-key-setup-instructions-header" };
5390
+ const _hoisted_7$7 = { class: "hardware-key-setup-instructions-list" };
5391
+ const _hoisted_8$7 = { class: "hardware-key-setup-actions" };
5392
+ const _hoisted_9$7 = {
5392
5393
  key: 2,
5393
5394
  class: "hardware-key-setup-step"
5394
5395
  };
5395
- const _hoisted_10$5 = { class: "hardware-key-setup-progress" };
5396
- const _hoisted_11$5 = { class: "hardware-key-setup-progress-icon" };
5397
- const _hoisted_12$5 = { class: "hardware-key-setup-progress-message" };
5398
- const _hoisted_13$5 = {
5396
+ const _hoisted_10$6 = { class: "hardware-key-setup-progress" };
5397
+ const _hoisted_11$6 = { class: "hardware-key-setup-progress-icon" };
5398
+ const _hoisted_12$6 = { class: "hardware-key-setup-progress-message" };
5399
+ const _hoisted_13$6 = {
5399
5400
  key: 3,
5400
5401
  class: "hardware-key-setup-step"
5401
5402
  };
5402
- const _hoisted_14$5 = { class: "hardware-key-setup-backup-codes" };
5403
- const _hoisted_15$5 = { class: "hardware-key-setup-codes-container" };
5404
- const _hoisted_16$5 = { class: "hardware-key-setup-codes-grid" };
5405
- const _hoisted_17$4 = { class: "hardware-key-setup-copy-action" };
5406
- const _hoisted_18$4 = { class: "hardware-key-setup-final-action" };
5407
- const _hoisted_19$2 = {
5403
+ const _hoisted_14$6 = { class: "hardware-key-setup-backup-codes" };
5404
+ const _hoisted_15$6 = { class: "hardware-key-setup-codes-container" };
5405
+ const _hoisted_16$6 = { class: "hardware-key-setup-codes-grid" };
5406
+ const _hoisted_17$5 = { class: "hardware-key-setup-copy-action" };
5407
+ const _hoisted_18$5 = { class: "hardware-key-setup-final-action" };
5408
+ const _hoisted_19$3 = {
5408
5409
  key: 4,
5409
5410
  class: "hardware-key-setup-step"
5410
5411
  };
5411
- const _hoisted_20$2 = { class: "hardware-key-setup-error" };
5412
- const _hoisted_21$2 = { class: "hardware-key-setup-error-message" };
5413
- const _hoisted_22$2 = { class: "hardware-key-setup-actions" };
5414
- const _sfc_main$d = /* @__PURE__ */ defineComponent({
5412
+ const _hoisted_20$3 = { class: "hardware-key-setup-error" };
5413
+ const _hoisted_21$3 = { class: "hardware-key-setup-error-message" };
5414
+ const _hoisted_22$3 = { class: "hardware-key-setup-actions" };
5415
+ const _sfc_main$e = /* @__PURE__ */ defineComponent({
5415
5416
  __name: "StrandsHardwareKeySetupModal",
5416
5417
  props: {
5417
5418
  show: { type: Boolean },
@@ -5676,7 +5677,7 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5676
5677
  emit("success");
5677
5678
  };
5678
5679
  return (_ctx, _cache) => {
5679
- return openBlock(), createElementBlock("div", _hoisted_1$c, [
5680
+ return openBlock(), createElementBlock("div", _hoisted_1$d, [
5680
5681
  createVNode(StrandsUiModal, {
5681
5682
  open: _ctx.show,
5682
5683
  onClose: closeModal,
@@ -5706,7 +5707,7 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5706
5707
  ])
5707
5708
  ]),
5708
5709
  default: withCtx(() => [
5709
- step.value === 1 ? (openBlock(), createElementBlock("div", _hoisted_2$a, [
5710
+ step.value === 1 ? (openBlock(), createElementBlock("div", _hoisted_2$b, [
5710
5711
  _cache[7] || (_cache[7] = createElementVNode("div", null, [
5711
5712
  createElementVNode("h3", { class: "hardware-key-setup-step-title" }, "Name Your Hardware Key"),
5712
5713
  createElementVNode("p", { class: "hardware-key-setup-step-description" }, ' Give your hardware key a memorable name (e.g., "YubiKey 5", "Work Security Key") ')
@@ -5719,7 +5720,7 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5719
5720
  error: deviceNameError.value,
5720
5721
  disabled: loading2.value
5721
5722
  }, null, 8, ["modelValue", "error", "disabled"]),
5722
- createElementVNode("div", _hoisted_3$a, [
5723
+ createElementVNode("div", _hoisted_3$b, [
5723
5724
  createVNode(unref(StrandsUiButton), {
5724
5725
  variant: "secondary",
5725
5726
  onClick: closeModal,
@@ -5745,7 +5746,7 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5745
5746
  }, 8, ["disabled", "loading"])
5746
5747
  ])
5747
5748
  ])) : createCommentVNode("", true),
5748
- step.value === 2 ? (openBlock(), createElementBlock("div", _hoisted_4$9, [
5749
+ step.value === 2 ? (openBlock(), createElementBlock("div", _hoisted_4$a, [
5749
5750
  _cache[18] || (_cache[18] = createElementVNode("div", null, [
5750
5751
  createElementVNode("h3", { class: "hardware-key-setup-step-title" }, "Register Hardware Key"),
5751
5752
  createElementVNode("p", { class: "hardware-key-setup-step-description" }, " Insert your hardware key and follow your browser's prompts to complete registration. ")
@@ -5771,8 +5772,8 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5771
5772
  createElementVNode("p", { class: "hardware-key-setup-substatus" }, 'Click "Register Key" when ready')
5772
5773
  ])
5773
5774
  ], -1)),
5774
- createElementVNode("div", _hoisted_5$8, [
5775
- createElementVNode("div", _hoisted_6$6, [
5775
+ createElementVNode("div", _hoisted_5$9, [
5776
+ createElementVNode("div", _hoisted_6$7, [
5776
5777
  _cache[15] || (_cache[15] = createElementVNode("svg", {
5777
5778
  class: "hardware-key-setup-info-icon",
5778
5779
  fill: "currentColor",
@@ -5786,7 +5787,7 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5786
5787
  ], -1)),
5787
5788
  createElementVNode("div", null, [
5788
5789
  _cache[14] || (_cache[14] = createElementVNode("p", { class: "hardware-key-setup-instructions-title" }, "Setup Instructions", -1)),
5789
- createElementVNode("ul", _hoisted_7$6, [
5790
+ createElementVNode("ul", _hoisted_7$7, [
5790
5791
  props.deviceType === "passkey" ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
5791
5792
  _cache[8] || (_cache[8] = createElementVNode("li", null, "• Your browser will prompt you to create a passkey", -1)),
5792
5793
  _cache[9] || (_cache[9] = createElementVNode("li", null, "• Use Touch ID, Face ID, Windows Hello, or PIN", -1)),
@@ -5800,7 +5801,7 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5800
5801
  ])
5801
5802
  ])
5802
5803
  ]),
5803
- createElementVNode("div", _hoisted_8$6, [
5804
+ createElementVNode("div", _hoisted_8$7, [
5804
5805
  createVNode(unref(StrandsUiButton), {
5805
5806
  variant: "secondary",
5806
5807
  onClick: _cache[1] || (_cache[1] = ($event) => step.value = 1),
@@ -5826,16 +5827,16 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5826
5827
  }, 8, ["disabled", "loading"])
5827
5828
  ])
5828
5829
  ])) : createCommentVNode("", true),
5829
- step.value === 3 ? (openBlock(), createElementBlock("div", _hoisted_9$6, [
5830
- createElementVNode("div", _hoisted_10$5, [
5831
- createElementVNode("div", _hoisted_11$5, [
5830
+ step.value === 3 ? (openBlock(), createElementBlock("div", _hoisted_9$7, [
5831
+ createElementVNode("div", _hoisted_10$6, [
5832
+ createElementVNode("div", _hoisted_11$6, [
5832
5833
  createVNode(unref(StrandsUiLoader), {
5833
5834
  size: 24,
5834
5835
  class: "hardware-key-setup-loader"
5835
5836
  })
5836
5837
  ]),
5837
5838
  _cache[20] || (_cache[20] = createElementVNode("h3", { class: "hardware-key-setup-step-title" }, "Registering Hardware Key", -1)),
5838
- createElementVNode("p", _hoisted_12$5, toDisplayString(registrationMessage.value), 1)
5839
+ createElementVNode("p", _hoisted_12$6, toDisplayString(registrationMessage.value), 1)
5839
5840
  ]),
5840
5841
  _cache[21] || (_cache[21] = createElementVNode("div", { class: "hardware-key-setup-progress-indicator" }, [
5841
5842
  createElementVNode("div", { class: "hardware-key-setup-progress-content" }, [
@@ -5860,7 +5861,7 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5860
5861
  ])
5861
5862
  ], -1))
5862
5863
  ])) : createCommentVNode("", true),
5863
- step.value === 4 ? (openBlock(), createElementBlock("div", _hoisted_13$5, [
5864
+ step.value === 4 ? (openBlock(), createElementBlock("div", _hoisted_13$6, [
5864
5865
  _cache[25] || (_cache[25] = createElementVNode("div", { class: "hardware-key-setup-success" }, [
5865
5866
  createElementVNode("div", { class: "hardware-key-setup-success-icon" }, [
5866
5867
  createElementVNode("svg", {
@@ -5880,7 +5881,7 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5880
5881
  createElementVNode("h3", { class: "hardware-key-setup-step-title" }, "Hardware Key Setup Complete!"),
5881
5882
  createElementVNode("p", { class: "hardware-key-setup-success-message" }, " Your hardware key is now active for two-factor authentication. ")
5882
5883
  ], -1)),
5883
- createElementVNode("div", _hoisted_14$5, [
5884
+ createElementVNode("div", _hoisted_14$6, [
5884
5885
  _cache[23] || (_cache[23] = createElementVNode("div", { class: "hardware-key-setup-backup-codes-header" }, [
5885
5886
  createElementVNode("svg", {
5886
5887
  class: "hardware-key-setup-warning-icon",
@@ -5898,8 +5899,8 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5898
5899
  createElementVNode("p", { class: "hardware-key-setup-backup-codes-description" }, " Store these codes in a safe place. Each code can only be used once if you lose your hardware key. ")
5899
5900
  ])
5900
5901
  ], -1)),
5901
- createElementVNode("div", _hoisted_15$5, [
5902
- createElementVNode("div", _hoisted_16$5, [
5902
+ createElementVNode("div", _hoisted_15$6, [
5903
+ createElementVNode("div", _hoisted_16$6, [
5903
5904
  (openBlock(true), createElementBlock(Fragment, null, renderList(backupCodes.value, (code, index) => {
5904
5905
  return openBlock(), createElementBlock("div", {
5905
5906
  key: index,
@@ -5908,7 +5909,7 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5908
5909
  }), 128))
5909
5910
  ])
5910
5911
  ]),
5911
- createElementVNode("div", _hoisted_17$4, [
5912
+ createElementVNode("div", _hoisted_17$5, [
5912
5913
  createVNode(unref(StrandsUiButton), {
5913
5914
  variant: "secondary",
5914
5915
  size: "sm",
@@ -5922,7 +5923,7 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5922
5923
  })
5923
5924
  ])
5924
5925
  ]),
5925
- createElementVNode("div", _hoisted_18$4, [
5926
+ createElementVNode("div", _hoisted_18$5, [
5926
5927
  createVNode(unref(StrandsUiButton), {
5927
5928
  variant: "primary",
5928
5929
  onClick: finish
@@ -5935,8 +5936,8 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5935
5936
  })
5936
5937
  ])
5937
5938
  ])) : createCommentVNode("", true),
5938
- step.value === 5 ? (openBlock(), createElementBlock("div", _hoisted_19$2, [
5939
- createElementVNode("div", _hoisted_20$2, [
5939
+ step.value === 5 ? (openBlock(), createElementBlock("div", _hoisted_19$3, [
5940
+ createElementVNode("div", _hoisted_20$3, [
5940
5941
  _cache[26] || (_cache[26] = createElementVNode("div", { class: "hardware-key-setup-error-icon" }, [
5941
5942
  createElementVNode("svg", {
5942
5943
  class: "hardware-key-setup-error-x",
@@ -5953,9 +5954,9 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5953
5954
  ])
5954
5955
  ], -1)),
5955
5956
  _cache[27] || (_cache[27] = createElementVNode("h3", { class: "hardware-key-setup-step-title" }, "Registration Failed", -1)),
5956
- createElementVNode("p", _hoisted_21$2, toDisplayString(errorMessage.value), 1)
5957
+ createElementVNode("p", _hoisted_21$3, toDisplayString(errorMessage.value), 1)
5957
5958
  ]),
5958
- createElementVNode("div", _hoisted_22$2, [
5959
+ createElementVNode("div", _hoisted_22$3, [
5959
5960
  createVNode(unref(StrandsUiButton), {
5960
5961
  variant: "secondary",
5961
5962
  onClick: _cache[2] || (_cache[2] = ($event) => step.value = 1)
@@ -5985,36 +5986,36 @@ const _sfc_main$d = /* @__PURE__ */ defineComponent({
5985
5986
  };
5986
5987
  }
5987
5988
  });
5988
- const StrandsHardwareKeySetupModal = /* @__PURE__ */ _export_sfc(_sfc_main$d, [["__scopeId", "data-v-4bb5b430"]]);
5989
- const _hoisted_1$b = { class: "accui-component-scope" };
5990
- const _hoisted_2$9 = {
5989
+ const StrandsHardwareKeySetupModal = /* @__PURE__ */ _export_sfc(_sfc_main$e, [["__scopeId", "data-v-4bb5b430"]]);
5990
+ const _hoisted_1$c = { class: "accui-component-scope" };
5991
+ const _hoisted_2$a = {
5991
5992
  key: 0,
5992
5993
  class: "backup-codes-loading"
5993
5994
  };
5994
- const _hoisted_3$9 = {
5995
+ const _hoisted_3$a = {
5995
5996
  key: 1,
5996
5997
  class: "backup-codes-content"
5997
5998
  };
5998
- const _hoisted_4$8 = {
5999
+ const _hoisted_4$9 = {
5999
6000
  key: 0,
6000
6001
  class: "backup-codes-device-info"
6001
6002
  };
6002
- const _hoisted_5$7 = { class: "backup-codes-device-content" };
6003
- const _hoisted_6$5 = { class: "backup-codes-device-name" };
6004
- const _hoisted_7$5 = { class: "backup-codes-device-type" };
6005
- const _hoisted_8$5 = { key: 1 };
6006
- const _hoisted_9$5 = { class: "backup-codes-grid-wrapper" };
6007
- const _hoisted_10$4 = { class: "backup-codes-grid" };
6008
- const _hoisted_11$4 = { class: "backup-codes-actions" };
6009
- const _hoisted_12$4 = { class: "backup-codes-main-actions" };
6010
- const _hoisted_13$4 = { class: "backup-codes-main-actions-content" };
6011
- const _hoisted_14$4 = {
6003
+ const _hoisted_5$8 = { class: "backup-codes-device-content" };
6004
+ const _hoisted_6$6 = { class: "backup-codes-device-name" };
6005
+ const _hoisted_7$6 = { class: "backup-codes-device-type" };
6006
+ const _hoisted_8$6 = { key: 1 };
6007
+ const _hoisted_9$6 = { class: "backup-codes-grid-wrapper" };
6008
+ const _hoisted_10$5 = { class: "backup-codes-grid" };
6009
+ const _hoisted_11$5 = { class: "backup-codes-actions" };
6010
+ const _hoisted_12$5 = { class: "backup-codes-main-actions" };
6011
+ const _hoisted_13$5 = { class: "backup-codes-main-actions-content" };
6012
+ const _hoisted_14$5 = {
6012
6013
  key: 2,
6013
6014
  class: "backup-codes-regenerate-warning"
6014
6015
  };
6015
- const _hoisted_15$4 = { class: "backup-codes-regenerate-content" };
6016
- const _hoisted_16$4 = { class: "backup-codes-regenerate-actions" };
6017
- const _sfc_main$c = /* @__PURE__ */ defineComponent({
6016
+ const _hoisted_15$5 = { class: "backup-codes-regenerate-content" };
6017
+ const _hoisted_16$5 = { class: "backup-codes-regenerate-actions" };
6018
+ const _sfc_main$d = /* @__PURE__ */ defineComponent({
6018
6019
  __name: "StrandsBackupCodesModal",
6019
6020
  props: {
6020
6021
  show: { type: Boolean },
@@ -6097,7 +6098,7 @@ const _sfc_main$c = /* @__PURE__ */ defineComponent({
6097
6098
  URL.revokeObjectURL(url);
6098
6099
  };
6099
6100
  return (_ctx, _cache) => {
6100
- return openBlock(), createElementBlock("div", _hoisted_1$b, [
6101
+ return openBlock(), createElementBlock("div", _hoisted_1$c, [
6101
6102
  createVNode(StrandsUiModal, {
6102
6103
  open: _ctx.show,
6103
6104
  onClose: closeModal,
@@ -6127,16 +6128,16 @@ const _sfc_main$c = /* @__PURE__ */ defineComponent({
6127
6128
  ])
6128
6129
  ]),
6129
6130
  default: withCtx(() => [
6130
- unref(loading2) ? (openBlock(), createElementBlock("div", _hoisted_2$9, [
6131
+ unref(loading2) ? (openBlock(), createElementBlock("div", _hoisted_2$a, [
6131
6132
  createVNode(unref(StrandsUiLoader), { size: 24 }),
6132
6133
  _cache[3] || (_cache[3] = createElementVNode("span", { class: "backup-codes-loading-text" }, "Loading backup codes...", -1))
6133
- ])) : (openBlock(), createElementBlock("div", _hoisted_3$9, [
6134
- _ctx.device ? (openBlock(), createElementBlock("div", _hoisted_4$8, [
6135
- createElementVNode("div", _hoisted_5$7, [
6134
+ ])) : (openBlock(), createElementBlock("div", _hoisted_3$a, [
6135
+ _ctx.device ? (openBlock(), createElementBlock("div", _hoisted_4$9, [
6136
+ createElementVNode("div", _hoisted_5$8, [
6136
6137
  _cache[4] || (_cache[4] = createElementVNode("span", { class: "backup-codes-device-icon" }, "📱", -1)),
6137
6138
  createElementVNode("div", null, [
6138
- createElementVNode("h3", _hoisted_6$5, toDisplayString(_ctx.device.device_name), 1),
6139
- createElementVNode("p", _hoisted_7$5, toDisplayString(unref(getDeviceTypeName)(_ctx.device.device_type)), 1)
6139
+ createElementVNode("h3", _hoisted_6$6, toDisplayString(_ctx.device.device_name), 1),
6140
+ createElementVNode("p", _hoisted_7$6, toDisplayString(unref(getDeviceTypeName)(_ctx.device.device_type)), 1)
6140
6141
  ])
6141
6142
  ])
6142
6143
  ])) : createCommentVNode("", true),
@@ -6164,10 +6165,10 @@ const _sfc_main$c = /* @__PURE__ */ defineComponent({
6164
6165
  ])
6165
6166
  ])
6166
6167
  ], -1)),
6167
- backupCodes.value.length > 0 ? (openBlock(), createElementBlock("div", _hoisted_8$5, [
6168
+ backupCodes.value.length > 0 ? (openBlock(), createElementBlock("div", _hoisted_8$6, [
6168
6169
  _cache[7] || (_cache[7] = createElementVNode("h3", { class: "backup-codes-section-title" }, "Your Backup Codes", -1)),
6169
- createElementVNode("div", _hoisted_9$5, [
6170
- createElementVNode("div", _hoisted_10$4, [
6170
+ createElementVNode("div", _hoisted_9$6, [
6171
+ createElementVNode("div", _hoisted_10$5, [
6171
6172
  (openBlock(true), createElementBlock(Fragment, null, renderList(backupCodes.value, (code, index) => {
6172
6173
  return openBlock(), createElementBlock("div", {
6173
6174
  key: index,
@@ -6176,7 +6177,7 @@ const _sfc_main$c = /* @__PURE__ */ defineComponent({
6176
6177
  }), 128))
6177
6178
  ])
6178
6179
  ]),
6179
- createElementVNode("div", _hoisted_11$4, [
6180
+ createElementVNode("div", _hoisted_11$5, [
6180
6181
  createVNode(unref(StrandsUiButton), {
6181
6182
  variant: "secondary",
6182
6183
  size: "sm",
@@ -6201,8 +6202,8 @@ const _sfc_main$c = /* @__PURE__ */ defineComponent({
6201
6202
  })
6202
6203
  ])
6203
6204
  ])) : createCommentVNode("", true),
6204
- createElementVNode("div", _hoisted_12$4, [
6205
- createElementVNode("div", _hoisted_13$4, [
6205
+ createElementVNode("div", _hoisted_12$5, [
6206
+ createElementVNode("div", _hoisted_13$5, [
6206
6207
  createVNode(unref(StrandsUiButton), {
6207
6208
  variant: "secondary",
6208
6209
  onClick: regenerateCodes,
@@ -6227,8 +6228,8 @@ const _sfc_main$c = /* @__PURE__ */ defineComponent({
6227
6228
  })
6228
6229
  ])
6229
6230
  ]),
6230
- showRegenerateWarning.value ? (openBlock(), createElementBlock("div", _hoisted_14$4, [
6231
- createElementVNode("div", _hoisted_15$4, [
6231
+ showRegenerateWarning.value ? (openBlock(), createElementBlock("div", _hoisted_14$5, [
6232
+ createElementVNode("div", _hoisted_15$5, [
6232
6233
  _cache[14] || (_cache[14] = createElementVNode("svg", {
6233
6234
  class: "backup-codes-regenerate-icon",
6234
6235
  fill: "currentColor",
@@ -6243,7 +6244,7 @@ const _sfc_main$c = /* @__PURE__ */ defineComponent({
6243
6244
  createElementVNode("div", null, [
6244
6245
  _cache[12] || (_cache[12] = createElementVNode("p", { class: "backup-codes-regenerate-title" }, "Regenerate Backup Codes?", -1)),
6245
6246
  _cache[13] || (_cache[13] = createElementVNode("p", { class: "backup-codes-regenerate-description" }, " This will invalidate all current backup codes. Make sure to save the new ones. ", -1)),
6246
- createElementVNode("div", _hoisted_16$4, [
6247
+ createElementVNode("div", _hoisted_16$5, [
6247
6248
  createVNode(unref(StrandsUiButton), {
6248
6249
  variant: "primary",
6249
6250
  size: "sm",
@@ -6280,12 +6281,12 @@ const _sfc_main$c = /* @__PURE__ */ defineComponent({
6280
6281
  };
6281
6282
  }
6282
6283
  });
6283
- const StrandsBackupCodesModal = /* @__PURE__ */ _export_sfc(_sfc_main$c, [["__scopeId", "data-v-ab2930f9"]]);
6284
- const _hoisted_1$a = { class: "accui-component-scope" };
6285
- const _hoisted_2$8 = { class: "confirm-modal-title" };
6286
- const _hoisted_3$8 = { class: "confirm-modal-message" };
6287
- const _hoisted_4$7 = { class: "confirm-modal-actions" };
6288
- const _sfc_main$b = /* @__PURE__ */ defineComponent({
6284
+ const StrandsBackupCodesModal = /* @__PURE__ */ _export_sfc(_sfc_main$d, [["__scopeId", "data-v-ab2930f9"]]);
6285
+ const _hoisted_1$b = { class: "accui-component-scope" };
6286
+ const _hoisted_2$9 = { class: "confirm-modal-title" };
6287
+ const _hoisted_3$9 = { class: "confirm-modal-message" };
6288
+ const _hoisted_4$8 = { class: "confirm-modal-actions" };
6289
+ const _sfc_main$c = /* @__PURE__ */ defineComponent({
6289
6290
  __name: "StrandsConfirmModal",
6290
6291
  props: {
6291
6292
  show: { type: Boolean },
@@ -6307,17 +6308,17 @@ const _sfc_main$b = /* @__PURE__ */ defineComponent({
6307
6308
  emit("cancel");
6308
6309
  };
6309
6310
  return (_ctx, _cache) => {
6310
- return openBlock(), createElementBlock("div", _hoisted_1$a, [
6311
+ return openBlock(), createElementBlock("div", _hoisted_1$b, [
6311
6312
  createVNode(StrandsUiModal, {
6312
6313
  open: _ctx.show,
6313
6314
  "card-class": "confirm-modal"
6314
6315
  }, {
6315
6316
  header: withCtx(() => [
6316
- createElementVNode("h2", _hoisted_2$8, toDisplayString(_ctx.title), 1)
6317
+ createElementVNode("h2", _hoisted_2$9, toDisplayString(_ctx.title), 1)
6317
6318
  ]),
6318
6319
  default: withCtx(() => [
6319
- createElementVNode("p", _hoisted_3$8, toDisplayString(_ctx.message), 1),
6320
- createElementVNode("div", _hoisted_4$7, [
6320
+ createElementVNode("p", _hoisted_3$9, toDisplayString(_ctx.message), 1),
6321
+ createElementVNode("div", _hoisted_4$8, [
6321
6322
  createVNode(unref(StrandsUiButton), {
6322
6323
  variant: "secondary",
6323
6324
  onClick: handleCancel,
@@ -6347,57 +6348,57 @@ const _sfc_main$b = /* @__PURE__ */ defineComponent({
6347
6348
  };
6348
6349
  }
6349
6350
  });
6350
- const StrandsConfirmModal = /* @__PURE__ */ _export_sfc(_sfc_main$b, [["__scopeId", "data-v-22fcdfc7"]]);
6351
- const _hoisted_1$9 = { class: "accui-component-scope" };
6352
- const _hoisted_2$7 = {
6351
+ const StrandsConfirmModal = /* @__PURE__ */ _export_sfc(_sfc_main$c, [["__scopeId", "data-v-22fcdfc7"]]);
6352
+ const _hoisted_1$a = { class: "accui-component-scope" };
6353
+ const _hoisted_2$8 = {
6353
6354
  key: 0,
6354
6355
  class: "mfa-loading"
6355
6356
  };
6356
- const _hoisted_3$7 = {
6357
+ const _hoisted_3$8 = {
6357
6358
  key: 1,
6358
6359
  class: "mfa-content"
6359
6360
  };
6360
- const _hoisted_4$6 = { class: "mfa-status-overview" };
6361
- const _hoisted_5$6 = { class: "mfa-status-content" };
6362
- const _hoisted_6$4 = { class: "mfa-status-subtitle" };
6363
- const _hoisted_7$4 = { class: "mfa-status-badges" };
6364
- const _hoisted_8$4 = {
6361
+ const _hoisted_4$7 = { class: "mfa-status-overview" };
6362
+ const _hoisted_5$7 = { class: "mfa-status-content" };
6363
+ const _hoisted_6$5 = { class: "mfa-status-subtitle" };
6364
+ const _hoisted_7$5 = { class: "mfa-status-badges" };
6365
+ const _hoisted_8$5 = {
6365
6366
  key: 0,
6366
6367
  class: "mfa-status-badge mfa-status-badge-enabled"
6367
6368
  };
6368
- const _hoisted_9$4 = {
6369
+ const _hoisted_9$5 = {
6369
6370
  key: 1,
6370
6371
  class: "mfa-status-badge mfa-status-badge-disabled"
6371
6372
  };
6372
- const _hoisted_10$3 = { class: "mfa-tabs-container" };
6373
- const _hoisted_11$3 = {
6373
+ const _hoisted_10$4 = { class: "mfa-tabs-container" };
6374
+ const _hoisted_11$4 = {
6374
6375
  class: "mfa-tabs-nav",
6375
6376
  "aria-label": "Tabs"
6376
6377
  };
6377
- const _hoisted_12$3 = {
6378
+ const _hoisted_12$4 = {
6378
6379
  key: 0,
6379
6380
  class: "mfa-add-devices"
6380
6381
  };
6381
- const _hoisted_13$3 = { class: "mfa-device-options" };
6382
- const _hoisted_14$3 = { class: "mfa-device-layout" };
6383
- const _hoisted_15$3 = { class: "mfa-device-icon-container mfa-device-icon-totp" };
6384
- const _hoisted_16$3 = { class: "mfa-device-action" };
6385
- const _hoisted_17$3 = { class: "mfa-device-layout" };
6386
- const _hoisted_18$3 = { class: "mfa-device-icon-container mfa-device-icon-email" };
6387
- const _hoisted_19$1 = { class: "mfa-device-action" };
6388
- const _hoisted_20$1 = {
6382
+ const _hoisted_13$4 = { class: "mfa-device-options" };
6383
+ const _hoisted_14$4 = { class: "mfa-device-layout" };
6384
+ const _hoisted_15$4 = { class: "mfa-device-icon-container mfa-device-icon-totp" };
6385
+ const _hoisted_16$4 = { class: "mfa-device-action" };
6386
+ const _hoisted_17$4 = { class: "mfa-device-layout" };
6387
+ const _hoisted_18$4 = { class: "mfa-device-icon-container mfa-device-icon-email" };
6388
+ const _hoisted_19$2 = { class: "mfa-device-action" };
6389
+ const _hoisted_20$2 = {
6389
6390
  key: 1,
6390
6391
  class: "mfa-manage-devices"
6391
6392
  };
6392
- const _hoisted_21$1 = { class: "mfa-devices-list" };
6393
- const _hoisted_22$1 = { class: "mfa-device-card-content" };
6394
- const _hoisted_23$1 = { class: "mfa-device-card-info" };
6395
- const _hoisted_24$1 = { class: "mfa-device-card-details" };
6396
- const _hoisted_25$1 = { class: "mfa-device-card-name" };
6397
- const _hoisted_26$1 = { class: "mfa-device-card-type" };
6398
- const _hoisted_27$1 = { class: "mfa-device-card-last-used" };
6399
- const _hoisted_28$1 = { class: "mfa-device-card-actions" };
6400
- const _sfc_main$a = /* @__PURE__ */ defineComponent({
6393
+ const _hoisted_21$2 = { class: "mfa-devices-list" };
6394
+ const _hoisted_22$2 = { class: "mfa-device-card-content" };
6395
+ const _hoisted_23$2 = { class: "mfa-device-card-info" };
6396
+ const _hoisted_24$2 = { class: "mfa-device-card-details" };
6397
+ const _hoisted_25$2 = { class: "mfa-device-card-name" };
6398
+ const _hoisted_26$2 = { class: "mfa-device-card-type" };
6399
+ const _hoisted_27$2 = { class: "mfa-device-card-last-used" };
6400
+ const _hoisted_28$2 = { class: "mfa-device-card-actions" };
6401
+ const _sfc_main$b = /* @__PURE__ */ defineComponent({
6401
6402
  __name: "StrandsMfaModal",
6402
6403
  props: {
6403
6404
  show: { type: Boolean }
@@ -6530,7 +6531,7 @@ const _sfc_main$a = /* @__PURE__ */ defineComponent({
6530
6531
  }
6531
6532
  };
6532
6533
  return (_ctx, _cache) => {
6533
- return openBlock(), createElementBlock("div", _hoisted_1$9, [
6534
+ return openBlock(), createElementBlock("div", _hoisted_1$a, [
6534
6535
  createVNode(StrandsUiModal, {
6535
6536
  open: showModal.value,
6536
6537
  onClose: closeModal,
@@ -6560,29 +6561,29 @@ const _sfc_main$a = /* @__PURE__ */ defineComponent({
6560
6561
  ])
6561
6562
  ]),
6562
6563
  default: withCtx(() => [
6563
- unref(mfaLoading) ? (openBlock(), createElementBlock("div", _hoisted_2$7, [
6564
+ unref(mfaLoading) ? (openBlock(), createElementBlock("div", _hoisted_2$8, [
6564
6565
  createVNode(unref(StrandsUiLoader), { size: 32 }),
6565
6566
  _cache[10] || (_cache[10] = createElementVNode("span", { class: "mfa-loading-text" }, "Loading MFA settings...", -1))
6566
- ])) : (openBlock(), createElementBlock("div", _hoisted_3$7, [
6567
- createElementVNode("div", _hoisted_4$6, [
6568
- createElementVNode("div", _hoisted_5$6, [
6567
+ ])) : (openBlock(), createElementBlock("div", _hoisted_3$8, [
6568
+ createElementVNode("div", _hoisted_4$7, [
6569
+ createElementVNode("div", _hoisted_5$7, [
6569
6570
  createElementVNode("div", null, [
6570
6571
  _cache[11] || (_cache[11] = createElementVNode("h3", { class: "mfa-status-title" }, "Two-Factor Authentication", -1)),
6571
- createElementVNode("p", _hoisted_6$4, toDisplayString(unref(mfaEnabled2) ? "Enabled" : "Add extra security to your account"), 1)
6572
+ createElementVNode("p", _hoisted_6$5, toDisplayString(unref(mfaEnabled2) ? "Enabled" : "Add extra security to your account"), 1)
6572
6573
  ]),
6573
- createElementVNode("div", _hoisted_7$4, [
6574
- unref(mfaEnabled2) ? (openBlock(), createElementBlock("span", _hoisted_8$4, [
6574
+ createElementVNode("div", _hoisted_7$5, [
6575
+ unref(mfaEnabled2) ? (openBlock(), createElementBlock("span", _hoisted_8$5, [
6575
6576
  createVNode(Shield, {
6576
6577
  size: 12,
6577
6578
  class: "mfa-badge-icon"
6578
6579
  }),
6579
6580
  _cache[12] || (_cache[12] = createTextVNode(" Enabled ", -1))
6580
- ])) : (openBlock(), createElementBlock("span", _hoisted_9$4, " Not Enabled "))
6581
+ ])) : (openBlock(), createElementBlock("span", _hoisted_9$5, " Not Enabled "))
6581
6582
  ])
6582
6583
  ])
6583
6584
  ]),
6584
- createElementVNode("div", _hoisted_10$3, [
6585
- createElementVNode("nav", _hoisted_11$3, [
6585
+ createElementVNode("div", _hoisted_10$4, [
6586
+ createElementVNode("nav", _hoisted_11$4, [
6586
6587
  createElementVNode("button", {
6587
6588
  onClick: _cache[0] || (_cache[0] = ($event) => activeTab.value = "add"),
6588
6589
  class: normalizeClass([
@@ -6600,16 +6601,16 @@ const _sfc_main$a = /* @__PURE__ */ defineComponent({
6600
6601
  }, " Active Devices (" + toDisplayString(unref(activeMfaDevices).length) + ") ", 3)) : createCommentVNode("", true)
6601
6602
  ])
6602
6603
  ]),
6603
- activeTab.value === "add" ? (openBlock(), createElementBlock("div", _hoisted_12$3, [
6604
+ activeTab.value === "add" ? (openBlock(), createElementBlock("div", _hoisted_12$4, [
6604
6605
  createElementVNode("div", null, [
6605
6606
  _cache[17] || (_cache[17] = createElementVNode("h3", { class: "mfa-section-title" }, "Choose Your Authentication Method", -1)),
6606
- createElementVNode("div", _hoisted_13$3, [
6607
+ createElementVNode("div", _hoisted_13$4, [
6607
6608
  createElementVNode("div", {
6608
6609
  class: "mfa-device-option",
6609
6610
  onClick: startTotpSetup
6610
6611
  }, [
6611
- createElementVNode("div", _hoisted_14$3, [
6612
- createElementVNode("div", _hoisted_15$3, [
6612
+ createElementVNode("div", _hoisted_14$4, [
6613
+ createElementVNode("div", _hoisted_15$4, [
6613
6614
  createVNode(Smartphone, {
6614
6615
  size: 24,
6615
6616
  class: "mfa-device-icon"
@@ -6621,7 +6622,7 @@ const _sfc_main$a = /* @__PURE__ */ defineComponent({
6621
6622
  createElementVNode("p", { class: "mfa-device-description" }, " Use Google Authenticator, Authy, or any TOTP-compatible app to generate secure codes ")
6622
6623
  ])
6623
6624
  ], -1)),
6624
- createElementVNode("div", _hoisted_16$3, [
6625
+ createElementVNode("div", _hoisted_16$4, [
6625
6626
  createVNode(unref(StrandsUiButton), {
6626
6627
  variant: "primary",
6627
6628
  size: "md",
@@ -6641,8 +6642,8 @@ const _sfc_main$a = /* @__PURE__ */ defineComponent({
6641
6642
  class: "mfa-device-option",
6642
6643
  onClick: startEmailMfaSetup
6643
6644
  }, [
6644
- createElementVNode("div", _hoisted_17$3, [
6645
- createElementVNode("div", _hoisted_18$3, [
6645
+ createElementVNode("div", _hoisted_17$4, [
6646
+ createElementVNode("div", _hoisted_18$4, [
6646
6647
  createVNode(Mail, {
6647
6648
  size: 24,
6648
6649
  class: "mfa-device-icon"
@@ -6654,7 +6655,7 @@ const _sfc_main$a = /* @__PURE__ */ defineComponent({
6654
6655
  createElementVNode("p", { class: "mfa-device-description" }, " Receive verification codes directly in your email inbox for easy access ")
6655
6656
  ])
6656
6657
  ], -1)),
6657
- createElementVNode("div", _hoisted_19$1, [
6658
+ createElementVNode("div", _hoisted_19$2, [
6658
6659
  createVNode(unref(StrandsUiButton), {
6659
6660
  variant: "primary",
6660
6661
  size: "md",
@@ -6672,17 +6673,17 @@ const _sfc_main$a = /* @__PURE__ */ defineComponent({
6672
6673
  ])
6673
6674
  ])
6674
6675
  ])
6675
- ])) : activeTab.value === "manage" && unref(activeMfaDevices).length > 0 ? (openBlock(), createElementBlock("div", _hoisted_20$1, [
6676
+ ])) : activeTab.value === "manage" && unref(activeMfaDevices).length > 0 ? (openBlock(), createElementBlock("div", _hoisted_20$2, [
6676
6677
  createElementVNode("div", null, [
6677
6678
  _cache[21] || (_cache[21] = createElementVNode("h3", { class: "mfa-section-title" }, "Manage Your Active Devices", -1)),
6678
- createElementVNode("div", _hoisted_21$1, [
6679
+ createElementVNode("div", _hoisted_21$2, [
6679
6680
  (openBlock(true), createElementBlock(Fragment, null, renderList(unref(activeMfaDevices), (device) => {
6680
6681
  return openBlock(), createElementBlock("div", {
6681
6682
  key: device.id,
6682
6683
  class: "mfa-device-card"
6683
6684
  }, [
6684
- createElementVNode("div", _hoisted_22$1, [
6685
- createElementVNode("div", _hoisted_23$1, [
6685
+ createElementVNode("div", _hoisted_22$2, [
6686
+ createElementVNode("div", _hoisted_23$2, [
6686
6687
  createElementVNode("div", {
6687
6688
  class: normalizeClass(["mfa-device-card-icon-container", getDeviceIconBackground(device.device_type)])
6688
6689
  }, [
@@ -6691,13 +6692,13 @@ const _sfc_main$a = /* @__PURE__ */ defineComponent({
6691
6692
  class: "mfa-device-card-icon"
6692
6693
  }))
6693
6694
  ], 2),
6694
- createElementVNode("div", _hoisted_24$1, [
6695
- createElementVNode("h4", _hoisted_25$1, toDisplayString(device.device_name), 1),
6696
- createElementVNode("p", _hoisted_26$1, toDisplayString(unref(getDeviceTypeName)(device.device_type)), 1),
6697
- createElementVNode("p", _hoisted_27$1, " Last used " + toDisplayString(unref(formatLastUsed)(device.last_used_at)), 1)
6695
+ createElementVNode("div", _hoisted_24$2, [
6696
+ createElementVNode("h4", _hoisted_25$2, toDisplayString(device.device_name), 1),
6697
+ createElementVNode("p", _hoisted_26$2, toDisplayString(unref(getDeviceTypeName)(device.device_type)), 1),
6698
+ createElementVNode("p", _hoisted_27$2, " Last used " + toDisplayString(unref(formatLastUsed)(device.last_used_at)), 1)
6698
6699
  ])
6699
6700
  ]),
6700
- createElementVNode("div", _hoisted_28$1, [
6701
+ createElementVNode("div", _hoisted_28$2, [
6701
6702
  device.device_type === "totp" || device.device_type === "hardware" || device.device_type === "passkey" ? (openBlock(), createBlock(unref(StrandsUiButton), {
6702
6703
  key: 0,
6703
6704
  variant: "secondary",
@@ -6807,17 +6808,17 @@ const _sfc_main$a = /* @__PURE__ */ defineComponent({
6807
6808
  };
6808
6809
  }
6809
6810
  });
6810
- const StrandsMfaModal = /* @__PURE__ */ _export_sfc(_sfc_main$a, [["__scopeId", "data-v-7b615ace"]]);
6811
- const _hoisted_1$8 = { class: "accui-component-scope" };
6812
- const _hoisted_2$6 = { class: "settings-header" };
6813
- const _hoisted_3$6 = { class: "settings-content" };
6814
- const _hoisted_4$5 = { class: "settings-section" };
6815
- const _hoisted_5$5 = { class: "settings-option" };
6816
- const _hoisted_6$3 = { class: "settings-option-content" };
6817
- const _hoisted_7$3 = { class: "settings-option" };
6818
- const _hoisted_8$3 = { class: "settings-option-content" };
6819
- const _hoisted_9$3 = { class: "settings-footer" };
6820
- const _sfc_main$9 = /* @__PURE__ */ defineComponent({
6811
+ const StrandsMfaModal = /* @__PURE__ */ _export_sfc(_sfc_main$b, [["__scopeId", "data-v-7b615ace"]]);
6812
+ const _hoisted_1$9 = { class: "accui-component-scope" };
6813
+ const _hoisted_2$7 = { class: "settings-header" };
6814
+ const _hoisted_3$7 = { class: "settings-content" };
6815
+ const _hoisted_4$6 = { class: "settings-section" };
6816
+ const _hoisted_5$6 = { class: "settings-option" };
6817
+ const _hoisted_6$4 = { class: "settings-option-content" };
6818
+ const _hoisted_7$4 = { class: "settings-option" };
6819
+ const _hoisted_8$4 = { class: "settings-option-content" };
6820
+ const _hoisted_9$4 = { class: "settings-footer" };
6821
+ const _sfc_main$a = /* @__PURE__ */ defineComponent({
6821
6822
  __name: "StrandsSettingsModal",
6822
6823
  props: {
6823
6824
  open: { type: Boolean, default: false }
@@ -6857,14 +6858,14 @@ const _sfc_main$9 = /* @__PURE__ */ defineComponent({
6857
6858
  }
6858
6859
  };
6859
6860
  return (_ctx, _cache) => {
6860
- return openBlock(), createElementBlock("div", _hoisted_1$8, [
6861
+ return openBlock(), createElementBlock("div", _hoisted_1$9, [
6861
6862
  createVNode(StrandsUiModal, {
6862
6863
  open: true,
6863
6864
  onClose: _cache[6] || (_cache[6] = ($event) => _ctx.$emit("close")),
6864
6865
  "card-class": "max-w-lg"
6865
6866
  }, {
6866
6867
  header: withCtx(() => [
6867
- createElementVNode("div", _hoisted_2$6, [
6868
+ createElementVNode("div", _hoisted_2$7, [
6868
6869
  _cache[8] || (_cache[8] = createElementVNode("h2", { class: "settings-title" }, "Settings", -1)),
6869
6870
  createElementVNode("button", {
6870
6871
  class: "settings-close-button",
@@ -6888,7 +6889,7 @@ const _sfc_main$9 = /* @__PURE__ */ defineComponent({
6888
6889
  ])
6889
6890
  ]),
6890
6891
  footer: withCtx(() => [
6891
- createElementVNode("div", _hoisted_9$3, [
6892
+ createElementVNode("div", _hoisted_9$4, [
6892
6893
  createVNode(StrandsUiButton, {
6893
6894
  variant: "secondary",
6894
6895
  onClick: _cache[5] || (_cache[5] = ($event) => _ctx.$emit("close"))
@@ -6912,11 +6913,11 @@ const _sfc_main$9 = /* @__PURE__ */ defineComponent({
6912
6913
  ])
6913
6914
  ]),
6914
6915
  default: withCtx(() => [
6915
- createElementVNode("div", _hoisted_3$6, [
6916
- createElementVNode("div", _hoisted_4$5, [
6916
+ createElementVNode("div", _hoisted_3$7, [
6917
+ createElementVNode("div", _hoisted_4$6, [
6917
6918
  _cache[11] || (_cache[11] = createElementVNode("h3", { class: "settings-section-title" }, "Audio Preferences", -1)),
6918
- createElementVNode("div", _hoisted_5$5, [
6919
- createElementVNode("div", _hoisted_6$3, [
6919
+ createElementVNode("div", _hoisted_5$6, [
6920
+ createElementVNode("div", _hoisted_6$4, [
6920
6921
  _cache[9] || (_cache[9] = createElementVNode("div", { class: "settings-option-info" }, [
6921
6922
  createElementVNode("label", {
6922
6923
  for: "level-up-sounds",
@@ -6934,8 +6935,8 @@ const _sfc_main$9 = /* @__PURE__ */ defineComponent({
6934
6935
  }, null, 8, ["modelValue"])
6935
6936
  ])
6936
6937
  ]),
6937
- createElementVNode("div", _hoisted_7$3, [
6938
- createElementVNode("div", _hoisted_8$3, [
6938
+ createElementVNode("div", _hoisted_7$4, [
6939
+ createElementVNode("div", _hoisted_8$4, [
6939
6940
  _cache[10] || (_cache[10] = createElementVNode("div", { class: "settings-option-info" }, [
6940
6941
  createElementVNode("label", {
6941
6942
  for: "milestone-sounds",
@@ -6962,7 +6963,382 @@ const _sfc_main$9 = /* @__PURE__ */ defineComponent({
6962
6963
  };
6963
6964
  }
6964
6965
  });
6965
- const StrandsSettingsModal = /* @__PURE__ */ _export_sfc(_sfc_main$9, [["__scopeId", "data-v-f0e4ff21"]]);
6966
+ const StrandsSettingsModal = /* @__PURE__ */ _export_sfc(_sfc_main$a, [["__scopeId", "data-v-f0e4ff21"]]);
6967
+ const _hoisted_1$8 = { class: "modal-header-content" };
6968
+ const _hoisted_2$6 = { class: "modal-subtitle" };
6969
+ const _hoisted_3$6 = { class: "strands-sessions-modal" };
6970
+ const _hoisted_4$5 = {
6971
+ key: 0,
6972
+ class: "sessions-loading"
6973
+ };
6974
+ const _hoisted_5$5 = {
6975
+ key: 1,
6976
+ class: "sessions-empty"
6977
+ };
6978
+ const _hoisted_6$3 = {
6979
+ key: 2,
6980
+ class: "sessions-container"
6981
+ };
6982
+ const _hoisted_7$3 = {
6983
+ key: 0,
6984
+ class: "session-stats"
6985
+ };
6986
+ const _hoisted_8$3 = { class: "stat-card" };
6987
+ const _hoisted_9$3 = { class: "stat-value" };
6988
+ const _hoisted_10$3 = { class: "stat-card" };
6989
+ const _hoisted_11$3 = { class: "stat-value" };
6990
+ const _hoisted_12$3 = {
6991
+ key: 0,
6992
+ class: "stat-card"
6993
+ };
6994
+ const _hoisted_13$3 = { class: "stat-value" };
6995
+ const _hoisted_14$3 = { class: "sessions-list" };
6996
+ const _hoisted_15$3 = { class: "session-header" };
6997
+ const _hoisted_16$3 = { class: "session-device" };
6998
+ const _hoisted_17$3 = { class: "device-icon" };
6999
+ const _hoisted_18$3 = { class: "device-info" };
7000
+ const _hoisted_19$1 = { class: "device-name" };
7001
+ const _hoisted_20$1 = {
7002
+ key: 0,
7003
+ class: "current-badge"
7004
+ };
7005
+ const _hoisted_21$1 = { class: "device-type" };
7006
+ const _hoisted_22$1 = { key: 1 };
7007
+ const _hoisted_23$1 = { key: 1 };
7008
+ const _hoisted_24$1 = { class: "session-details" };
7009
+ const _hoisted_25$1 = { class: "detail-row" };
7010
+ const _hoisted_26$1 = { class: "detail-icon" };
7011
+ const _hoisted_27$1 = { class: "detail-text" };
7012
+ const _hoisted_28$1 = {
7013
+ key: 0,
7014
+ class: "detail-row"
7015
+ };
7016
+ const _hoisted_29$1 = { class: "detail-icon" };
7017
+ const _hoisted_30$1 = { class: "detail-text" };
7018
+ const _hoisted_31$1 = { class: "detail-row" };
7019
+ const _hoisted_32$1 = { class: "detail-icon" };
7020
+ const _hoisted_33$1 = { class: "detail-text" };
7021
+ const _hoisted_34$1 = { class: "detail-row" };
7022
+ const _hoisted_35$1 = { class: "detail-icon" };
7023
+ const _hoisted_36$1 = { class: "detail-text" };
7024
+ const _hoisted_37$1 = {
7025
+ key: 1,
7026
+ class: "bulk-actions"
7027
+ };
7028
+ const _hoisted_38$1 = { key: 1 };
7029
+ const _sfc_main$9 = /* @__PURE__ */ defineComponent({
7030
+ __name: "StrandsSessionsModal",
7031
+ props: {
7032
+ modelValue: { type: Boolean }
7033
+ },
7034
+ emits: ["update:modelValue", "sessionsUpdated", "currentSessionRevoked"],
7035
+ setup(__props, { emit: __emit }) {
7036
+ const Monitor = { template: `<svg :width="size" :height="size" fill="none" stroke="currentColor" viewBox="0 0 24 24"><rect x="2" y="7" width="20" height="10" rx="2" ry="2"/><line x1="8" y1="21" x2="16" y2="21"/><line x1="12" y1="17" x2="12" y2="21"/></svg>`, props: ["size"] };
7037
+ const Smartphone = { template: `<svg :width="size" :height="size" fill="none" stroke="currentColor" viewBox="0 0 24 24"><rect x="5" y="2" width="14" height="20" rx="2" ry="2"/><line x1="12" y1="18" x2="12.01" y2="18"/></svg>`, props: ["size"] };
7038
+ const Tablet = { template: `<svg :width="size" :height="size" fill="none" stroke="currentColor" viewBox="0 0 24 24"><rect x="4" y="2" width="16" height="20" rx="2" ry="2"/><line x1="12" y1="18" x2="12.01" y2="18"/></svg>`, props: ["size"] };
7039
+ const MapPin = { template: `<svg :width="size" :height="size" fill="none" stroke="currentColor" viewBox="0 0 24 24"><path d="M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0118 0z"/><circle cx="12" cy="10" r="3"/></svg>`, props: ["size"] };
7040
+ const Globe = { template: `<svg :width="size" :height="size" fill="none" stroke="currentColor" viewBox="0 0 24 24"><circle cx="12" cy="12" r="10"/><line x1="2" y1="12" x2="22" y2="12"/><path d="M12 2a15.3 15.3 0 014 10 15.3 15.3 0 01-4 10 15.3 15.3 0 01-4-10 15.3 15.3 0 014-10z"/></svg>`, props: ["size"] };
7041
+ const Clock = { template: `<svg :width="size" :height="size" fill="none" stroke="currentColor" viewBox="0 0 24 24"><circle cx="12" cy="12" r="10"/><polyline points="12 6 12 12 16 14"/></svg>`, props: ["size"] };
7042
+ const Calendar = { template: `<svg :width="size" :height="size" fill="none" stroke="currentColor" viewBox="0 0 24 24"><rect x="3" y="4" width="18" height="18" rx="2" ry="2"/><line x1="16" y1="2" x2="16" y2="6"/><line x1="8" y1="2" x2="8" y2="6"/><line x1="3" y1="10" x2="21" y2="10"/></svg>`, props: ["size"] };
7043
+ const props = __props;
7044
+ const emit = __emit;
7045
+ const { getUserSessions, getSessionStats, revokeSession, revokeAllOtherSessions, signOut } = useStrandsAuth();
7046
+ const visible = ref(props.modelValue);
7047
+ const loading2 = ref(false);
7048
+ const sessions = ref([]);
7049
+ const stats = ref(null);
7050
+ const revokingSession = ref(null);
7051
+ const revokingAll = ref(false);
7052
+ const error = ref(null);
7053
+ watch(() => props.modelValue, (newVal) => {
7054
+ visible.value = newVal;
7055
+ if (newVal) {
7056
+ loadSessions();
7057
+ }
7058
+ });
7059
+ const loadSessions = async () => {
7060
+ loading2.value = true;
7061
+ error.value = null;
7062
+ try {
7063
+ const [sessionsData, statsData] = await Promise.all([
7064
+ getUserSessions(),
7065
+ getSessionStats()
7066
+ ]);
7067
+ sessions.value = sessionsData || [];
7068
+ stats.value = statsData || null;
7069
+ } catch (err) {
7070
+ console.error("Failed to load sessions:", err);
7071
+ error.value = "Failed to load sessions. Please try again.";
7072
+ sessions.value = [];
7073
+ } finally {
7074
+ loading2.value = false;
7075
+ }
7076
+ };
7077
+ const handleClose = () => {
7078
+ visible.value = false;
7079
+ emit("update:modelValue", false);
7080
+ };
7081
+ const handleRevokeSession = async (sessionId) => {
7082
+ if (!confirm("Are you sure you want to end this session? The device will be signed out.")) {
7083
+ return;
7084
+ }
7085
+ revokingSession.value = sessionId;
7086
+ try {
7087
+ await revokeSession(sessionId);
7088
+ await loadSessions();
7089
+ emit("sessionsUpdated");
7090
+ } catch (err) {
7091
+ console.error("Failed to revoke session:", err);
7092
+ alert("Failed to end session. Please try again.");
7093
+ } finally {
7094
+ revokingSession.value = null;
7095
+ }
7096
+ };
7097
+ const handleRevokeAllOther = async () => {
7098
+ if (!confirm("Are you sure you want to end all other sessions? You will be signed out on all other devices.")) {
7099
+ return;
7100
+ }
7101
+ revokingAll.value = true;
7102
+ try {
7103
+ await revokeAllOtherSessions();
7104
+ await loadSessions();
7105
+ emit("sessionsUpdated");
7106
+ } catch (err) {
7107
+ console.error("Failed to revoke sessions:", err);
7108
+ alert("Failed to end sessions. Please try again.");
7109
+ } finally {
7110
+ revokingAll.value = false;
7111
+ }
7112
+ };
7113
+ const handleRevokeCurrentSession = async (sessionId) => {
7114
+ if (!confirm("Are you sure you want to sign out? You will need to sign in again to access your account.")) {
7115
+ return;
7116
+ }
7117
+ revokingSession.value = sessionId;
7118
+ try {
7119
+ await revokeSession(sessionId);
7120
+ await signOut();
7121
+ visible.value = false;
7122
+ emit("update:modelValue", false);
7123
+ emit("sessionsUpdated");
7124
+ emit("currentSessionRevoked");
7125
+ } catch (err) {
7126
+ console.error("Failed to revoke current session:", err);
7127
+ alert("Failed to sign out. Please try again.");
7128
+ } finally {
7129
+ revokingSession.value = null;
7130
+ }
7131
+ };
7132
+ const getDeviceIcon = (deviceType) => {
7133
+ switch (deviceType?.toLowerCase()) {
7134
+ case "mobile":
7135
+ return Smartphone;
7136
+ case "tablet":
7137
+ return Tablet;
7138
+ default:
7139
+ return Monitor;
7140
+ }
7141
+ };
7142
+ const formatTimeAgo = (date) => {
7143
+ if (!date) return "Unknown";
7144
+ const now = /* @__PURE__ */ new Date();
7145
+ const then = new Date(date);
7146
+ const seconds = Math.floor((now.getTime() - then.getTime()) / 1e3);
7147
+ if (seconds < 60) return "just now";
7148
+ if (seconds < 3600) return `${Math.floor(seconds / 60)} minutes ago`;
7149
+ if (seconds < 86400) return `${Math.floor(seconds / 3600)} hours ago`;
7150
+ if (seconds < 604800) return `${Math.floor(seconds / 86400)} days ago`;
7151
+ return then.toLocaleDateString();
7152
+ };
7153
+ const formatDate2 = (date) => {
7154
+ if (!date) return "Unknown";
7155
+ return new Date(date).toLocaleDateString("en-US", {
7156
+ month: "short",
7157
+ day: "numeric",
7158
+ year: "numeric",
7159
+ hour: "2-digit",
7160
+ minute: "2-digit"
7161
+ });
7162
+ };
7163
+ if (visible.value) {
7164
+ loadSessions();
7165
+ }
7166
+ return (_ctx, _cache) => {
7167
+ return openBlock(), createBlock(unref(StrandsUiModal), {
7168
+ open: visible.value,
7169
+ onClose: handleClose
7170
+ }, {
7171
+ header: withCtx(() => [
7172
+ createElementVNode("div", _hoisted_1$8, [
7173
+ _cache[0] || (_cache[0] = createElementVNode("h2", { class: "modal-title" }, "Active Sessions", -1)),
7174
+ createElementVNode("p", _hoisted_2$6, "Manage your " + toDisplayString(sessions.value.length) + " active device" + toDisplayString(sessions.value.length !== 1 ? "s" : ""), 1)
7175
+ ])
7176
+ ]),
7177
+ default: withCtx(() => [
7178
+ createElementVNode("div", _hoisted_3$6, [
7179
+ loading2.value ? (openBlock(), createElementBlock("div", _hoisted_4$5, [
7180
+ createVNode(unref(StrandsUiLoader), { size: 40 }),
7181
+ _cache[1] || (_cache[1] = createElementVNode("p", { class: "loading-text" }, "Loading sessions...", -1))
7182
+ ])) : sessions.value.length === 0 ? (openBlock(), createElementBlock("div", _hoisted_5$5, _cache[2] || (_cache[2] = [
7183
+ createElementVNode("div", { class: "empty-icon" }, [
7184
+ createElementVNode("svg", {
7185
+ width: "48",
7186
+ height: "48",
7187
+ viewBox: "0 0 24 24",
7188
+ fill: "none",
7189
+ stroke: "currentColor",
7190
+ "stroke-width": "1.5"
7191
+ }, [
7192
+ createElementVNode("rect", {
7193
+ x: "2",
7194
+ y: "4",
7195
+ width: "20",
7196
+ height: "16",
7197
+ rx: "2"
7198
+ }),
7199
+ createElementVNode("line", {
7200
+ x1: "8",
7201
+ y1: "10",
7202
+ x2: "16",
7203
+ y2: "10"
7204
+ }),
7205
+ createElementVNode("line", {
7206
+ x1: "8",
7207
+ y1: "14",
7208
+ x2: "12",
7209
+ y2: "14"
7210
+ })
7211
+ ])
7212
+ ], -1),
7213
+ createElementVNode("h3", { class: "empty-title" }, "No Active Sessions", -1),
7214
+ createElementVNode("p", { class: "empty-description" }, "You don't have any active sessions at the moment.", -1)
7215
+ ]))) : (openBlock(), createElementBlock("div", _hoisted_6$3, [
7216
+ stats.value ? (openBlock(), createElementBlock("div", _hoisted_7$3, [
7217
+ createElementVNode("div", _hoisted_8$3, [
7218
+ _cache[3] || (_cache[3] = createElementVNode("span", { class: "stat-label" }, "Total Sessions", -1)),
7219
+ createElementVNode("span", _hoisted_9$3, toDisplayString(stats.value.total_sessions), 1)
7220
+ ]),
7221
+ createElementVNode("div", _hoisted_10$3, [
7222
+ _cache[4] || (_cache[4] = createElementVNode("span", { class: "stat-label" }, "Active Devices", -1)),
7223
+ createElementVNode("span", _hoisted_11$3, toDisplayString(stats.value.active_sessions), 1)
7224
+ ]),
7225
+ stats.value.unique_locations && stats.value.unique_locations.length > 0 ? (openBlock(), createElementBlock("div", _hoisted_12$3, [
7226
+ _cache[5] || (_cache[5] = createElementVNode("span", { class: "stat-label" }, "Locations", -1)),
7227
+ createElementVNode("span", _hoisted_13$3, toDisplayString(stats.value.unique_locations.length), 1)
7228
+ ])) : createCommentVNode("", true)
7229
+ ])) : createCommentVNode("", true),
7230
+ createElementVNode("div", _hoisted_14$3, [
7231
+ (openBlock(true), createElementBlock(Fragment, null, renderList(sessions.value, (session) => {
7232
+ return openBlock(), createElementBlock("div", {
7233
+ key: session.id,
7234
+ class: normalizeClass(["session-card", { "current-session": session.is_current }])
7235
+ }, [
7236
+ createElementVNode("div", _hoisted_15$3, [
7237
+ createElementVNode("div", _hoisted_16$3, [
7238
+ createElementVNode("div", _hoisted_17$3, [
7239
+ (openBlock(), createBlock(resolveDynamicComponent(getDeviceIcon(session.device_type)), { size: 20 }))
7240
+ ]),
7241
+ createElementVNode("div", _hoisted_18$3, [
7242
+ createElementVNode("h4", _hoisted_19$1, [
7243
+ createTextVNode(toDisplayString(session.device_name || "Unknown Device") + " ", 1),
7244
+ session.is_current ? (openBlock(), createElementBlock("span", _hoisted_20$1, "Current")) : createCommentVNode("", true)
7245
+ ]),
7246
+ createElementVNode("p", _hoisted_21$1, toDisplayString(session.device_type || "Unknown type"), 1)
7247
+ ])
7248
+ ]),
7249
+ session.is_current ? (openBlock(), createBlock(unref(StrandsUiButton), {
7250
+ key: 0,
7251
+ variant: "outline",
7252
+ size: "sm",
7253
+ onClick: ($event) => handleRevokeCurrentSession(session.id),
7254
+ disabled: revokingSession.value === session.id,
7255
+ class: "current-session-button"
7256
+ }, {
7257
+ default: withCtx(() => [
7258
+ revokingSession.value === session.id ? (openBlock(), createBlock(unref(StrandsUiLoader), {
7259
+ key: 0,
7260
+ size: 16
7261
+ })) : (openBlock(), createElementBlock("span", _hoisted_22$1, "Sign Out"))
7262
+ ]),
7263
+ _: 2
7264
+ }, 1032, ["onClick", "disabled"])) : (openBlock(), createBlock(unref(StrandsUiButton), {
7265
+ key: 1,
7266
+ variant: "outline",
7267
+ size: "sm",
7268
+ onClick: ($event) => handleRevokeSession(session.id),
7269
+ disabled: revokingSession.value === session.id
7270
+ }, {
7271
+ default: withCtx(() => [
7272
+ revokingSession.value === session.id ? (openBlock(), createBlock(unref(StrandsUiLoader), {
7273
+ key: 0,
7274
+ size: 16
7275
+ })) : (openBlock(), createElementBlock("span", _hoisted_23$1, "End Session"))
7276
+ ]),
7277
+ _: 2
7278
+ }, 1032, ["onClick", "disabled"]))
7279
+ ]),
7280
+ createElementVNode("div", _hoisted_24$1, [
7281
+ createElementVNode("div", _hoisted_25$1, [
7282
+ createElementVNode("span", _hoisted_26$1, [
7283
+ createVNode(MapPin, { size: 14 })
7284
+ ]),
7285
+ createElementVNode("span", _hoisted_27$1, [
7286
+ session.city && session.country ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
7287
+ createTextVNode(toDisplayString(session.city) + ", " + toDisplayString(session.country), 1)
7288
+ ], 64)) : session.country ? (openBlock(), createElementBlock(Fragment, { key: 1 }, [
7289
+ createTextVNode(toDisplayString(session.country), 1)
7290
+ ], 64)) : (openBlock(), createElementBlock(Fragment, { key: 2 }, [
7291
+ createTextVNode(" Location unknown ")
7292
+ ], 64))
7293
+ ])
7294
+ ]),
7295
+ session.ip_address ? (openBlock(), createElementBlock("div", _hoisted_28$1, [
7296
+ createElementVNode("span", _hoisted_29$1, [
7297
+ createVNode(Globe, { size: 14 })
7298
+ ]),
7299
+ createElementVNode("span", _hoisted_30$1, toDisplayString(session.ip_address), 1)
7300
+ ])) : createCommentVNode("", true),
7301
+ createElementVNode("div", _hoisted_31$1, [
7302
+ createElementVNode("span", _hoisted_32$1, [
7303
+ createVNode(Clock, { size: 14 })
7304
+ ]),
7305
+ createElementVNode("span", _hoisted_33$1, " Last active " + toDisplayString(formatTimeAgo(session.last_activity_at || session.created_at)), 1)
7306
+ ]),
7307
+ createElementVNode("div", _hoisted_34$1, [
7308
+ createElementVNode("span", _hoisted_35$1, [
7309
+ createVNode(Calendar, { size: 14 })
7310
+ ]),
7311
+ createElementVNode("span", _hoisted_36$1, " Started " + toDisplayString(formatDate2(session.created_at)), 1)
7312
+ ])
7313
+ ])
7314
+ ], 2);
7315
+ }), 128))
7316
+ ]),
7317
+ sessions.value.length > 1 ? (openBlock(), createElementBlock("div", _hoisted_37$1, [
7318
+ createVNode(unref(StrandsUiButton), {
7319
+ variant: "outline",
7320
+ onClick: handleRevokeAllOther,
7321
+ disabled: revokingAll.value
7322
+ }, {
7323
+ default: withCtx(() => [
7324
+ revokingAll.value ? (openBlock(), createBlock(unref(StrandsUiLoader), {
7325
+ key: 0,
7326
+ size: 16
7327
+ })) : (openBlock(), createElementBlock("span", _hoisted_38$1, "End All Other Sessions"))
7328
+ ]),
7329
+ _: 1
7330
+ }, 8, ["disabled"]),
7331
+ _cache[6] || (_cache[6] = createElementVNode("p", { class: "bulk-actions-hint" }, " This will sign you out on all other devices ", -1))
7332
+ ])) : createCommentVNode("", true)
7333
+ ]))
7334
+ ])
7335
+ ]),
7336
+ _: 1
7337
+ }, 8, ["open"]);
7338
+ };
7339
+ }
7340
+ });
7341
+ const StrandsSessionsModal = /* @__PURE__ */ _export_sfc(_sfc_main$9, [["__scopeId", "data-v-60345e8c"]]);
6966
7342
  const _hoisted_1$7 = { class: "accui-component-scope" };
6967
7343
  const _hoisted_2$5 = { class: "profile-image-section" };
6968
7344
  const _hoisted_3$5 = { class: "profile-image-container" };
@@ -7019,33 +7395,35 @@ const _hoisted_29 = {
7019
7395
  const _hoisted_30 = { class: "profile-field-section" };
7020
7396
  const _hoisted_31 = { class: "profile-field-header" };
7021
7397
  const _hoisted_32 = { class: "profile-field-subtitle" };
7022
- const _hoisted_33 = {
7398
+ const _hoisted_33 = { key: 0 };
7399
+ const _hoisted_34 = { key: 1 };
7400
+ const _hoisted_35 = {
7023
7401
  key: 0,
7024
7402
  class: "profile-actions-section"
7025
7403
  };
7026
- const _hoisted_34 = {
7404
+ const _hoisted_36 = {
7027
7405
  key: 0,
7028
7406
  class: "animate-fade-in"
7029
7407
  };
7030
- const _hoisted_35 = { class: "alert-success" };
7031
- const _hoisted_36 = { class: "profile-help-item" };
7032
- const _hoisted_37 = { class: "profile-alert-message" };
7033
- const _hoisted_38 = {
7408
+ const _hoisted_37 = { class: "alert-success" };
7409
+ const _hoisted_38 = { class: "profile-help-item" };
7410
+ const _hoisted_39 = { class: "profile-alert-message" };
7411
+ const _hoisted_40 = {
7034
7412
  key: 1,
7035
7413
  class: "animate-fade-in"
7036
7414
  };
7037
- const _hoisted_39 = { class: "alert-error" };
7038
- const _hoisted_40 = { class: "profile-help-item" };
7039
- const _hoisted_41 = { class: "profile-alert-message" };
7040
- const _hoisted_42 = { class: "profile-footer-actions" };
7041
- const _hoisted_43 = { key: 0 };
7042
- const _hoisted_44 = { class: "profile-footer-text" };
7043
- const _hoisted_45 = {
7415
+ const _hoisted_41 = { class: "alert-error" };
7416
+ const _hoisted_42 = { class: "profile-help-item" };
7417
+ const _hoisted_43 = { class: "profile-alert-message" };
7418
+ const _hoisted_44 = { class: "profile-footer-actions" };
7419
+ const _hoisted_45 = { key: 0 };
7420
+ const _hoisted_46 = { class: "profile-footer-text" };
7421
+ const _hoisted_47 = {
7044
7422
  key: 1,
7045
7423
  class: "profile-avatar-modal-overlay"
7046
7424
  };
7047
- const _hoisted_46 = { class: "profile-avatar-modal" };
7048
- const _hoisted_47 = { class: "profile-avatar-modal-content" };
7425
+ const _hoisted_48 = { class: "profile-avatar-modal" };
7426
+ const _hoisted_49 = { class: "profile-avatar-modal-content" };
7049
7427
  const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7050
7428
  __name: "StrandsUserProfile",
7051
7429
  props: {
@@ -7062,7 +7440,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7062
7440
  const props = __props;
7063
7441
  const emit = __emit;
7064
7442
  const { getSupportEmail, getUrl } = useStrandsConfig(props.config);
7065
- const { fetchProfile, updateProfile, changeEmail, changeUsername, getUsernameCooldown, checkUsernameAvailability, currentUser: authUser, currentSession, isAuthenticated, refreshToken, signOut } = useStrandsAuth();
7443
+ const { fetchProfile, updateProfile, changeEmail, changeUsername, getUsernameCooldown, checkUsernameAvailability, getUserSessions, currentUser: authUser, currentSession, isAuthenticated, refreshToken, signOut } = useStrandsAuth();
7066
7444
  const { activeMfaDevices, fetchMfaDevices } = useStrandsMfa();
7067
7445
  const internalUser = ref(null);
7068
7446
  const fetchingProfile = ref(false);
@@ -7092,6 +7470,8 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7092
7470
  const successMessage = ref("");
7093
7471
  const errorMessage = ref("");
7094
7472
  const activeSessions = ref([]);
7473
+ const loadingSessions = ref(false);
7474
+ const showSessionsModal = ref(false);
7095
7475
  const usernameChangeData = reactive({
7096
7476
  canChange: true,
7097
7477
  cooldownEnd: null,
@@ -7190,7 +7570,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7190
7570
  count: counts.totp,
7191
7571
  label: counts.totp === 1 ? "Auth app" : "Auth apps",
7192
7572
  icon: Smartphone,
7193
- color: "bg-blue-50 text-blue-700 border-blue-200"
7573
+ color: "chip-blue"
7194
7574
  });
7195
7575
  }
7196
7576
  if (counts.email > 0) {
@@ -7199,7 +7579,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7199
7579
  count: counts.email,
7200
7580
  label: "Email",
7201
7581
  icon: Mail,
7202
- color: "bg-green-50 text-green-700 border-green-200"
7582
+ color: "chip-green"
7203
7583
  });
7204
7584
  }
7205
7585
  if (counts.hardware > 0 || counts.passkey > 0) {
@@ -7209,7 +7589,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7209
7589
  count: totalHardware,
7210
7590
  label: totalHardware === 1 ? "Key" : "Keys",
7211
7591
  icon: KeyRound,
7212
- color: "bg-purple-50 text-purple-700 border-purple-200"
7592
+ color: "chip-purple"
7213
7593
  });
7214
7594
  }
7215
7595
  return chips;
@@ -7284,6 +7664,18 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7284
7664
  fetchingProfile.value = false;
7285
7665
  }
7286
7666
  };
7667
+ const loadUserSessions = async () => {
7668
+ if (!isAuthenticated.value) return;
7669
+ loadingSessions.value = true;
7670
+ try {
7671
+ const sessions = await getUserSessions();
7672
+ activeSessions.value = sessions || [];
7673
+ } catch (err) {
7674
+ console.error("Failed to load sessions:", err);
7675
+ } finally {
7676
+ loadingSessions.value = false;
7677
+ }
7678
+ };
7287
7679
  watch(() => currentUser.value, (user) => {
7288
7680
  if (user) {
7289
7681
  form.firstName = user.firstName || "";
@@ -7293,6 +7685,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7293
7685
  }, { immediate: true });
7294
7686
  onMounted(() => {
7295
7687
  fetchUserProfile();
7688
+ loadUserSessions();
7296
7689
  });
7297
7690
  const clearMessages = () => {
7298
7691
  successMessage.value = "";
@@ -7593,6 +7986,9 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7593
7986
  const handleSettingsUpdated = (settings) => {
7594
7987
  successMessage.value = "Settings updated successfully";
7595
7988
  };
7989
+ const handleSessionsUpdated = () => {
7990
+ loadUserSessions();
7991
+ };
7596
7992
  const handleCancel = () => {
7597
7993
  const user = currentUser.value;
7598
7994
  if (user) {
@@ -7645,7 +8041,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7645
8041
  createElementVNode("div", {
7646
8042
  class: normalizeClass(_ctx.inModal ? "profile-content-modal profile-content-layout" : "profile-content profile-card-modern profile-content-layout")
7647
8043
  }, [
7648
- _cache[31] || (_cache[31] = createElementVNode("div", { class: "profile-header" }, [
8044
+ _cache[32] || (_cache[32] = createElementVNode("div", { class: "profile-header" }, [
7649
8045
  createElementVNode("h1", { class: "profile-title" }, "Profile Settings"),
7650
8046
  createElementVNode("p", { class: "profile-subtitle" }, "Manage your account information and preferences")
7651
8047
  ], -1)),
@@ -7677,7 +8073,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7677
8073
  key: 0,
7678
8074
  size: 24,
7679
8075
  variant: "dark"
7680
- })) : (openBlock(), createElementBlock("svg", _hoisted_9$2, _cache[15] || (_cache[15] = [
8076
+ })) : (openBlock(), createElementBlock("svg", _hoisted_9$2, _cache[16] || (_cache[16] = [
7681
8077
  createElementVNode("path", {
7682
8078
  "stroke-linecap": "round",
7683
8079
  "stroke-linejoin": "round",
@@ -7709,7 +8105,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7709
8105
  }, [
7710
8106
  createElementVNode("div", _hoisted_10$2, [
7711
8107
  createElementVNode("div", _hoisted_11$2, [
7712
- _cache[18] || (_cache[18] = createElementVNode("h3", { class: "profile-section-title" }, "Personal Information", -1)),
8108
+ _cache[19] || (_cache[19] = createElementVNode("h3", { class: "profile-section-title" }, "Personal Information", -1)),
7713
8109
  createVNode(unref(StrandsUiInput), {
7714
8110
  id: "firstName",
7715
8111
  modelValue: form.firstName,
@@ -7735,7 +8131,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7735
8131
  createElementVNode("div", _hoisted_12$2, [
7736
8132
  createElementVNode("div", _hoisted_13$2, [
7737
8133
  createElementVNode("div", null, [
7738
- _cache[16] || (_cache[16] = createElementVNode("h4", { class: "profile-setting-title" }, "Email Address", -1)),
8134
+ _cache[17] || (_cache[17] = createElementVNode("h4", { class: "profile-setting-title" }, "Email Address", -1)),
7739
8135
  createElementVNode("p", _hoisted_14$2, toDisplayString(currentUser.value?.email), 1)
7740
8136
  ]),
7741
8137
  createVNode(unref(StrandsUiButton), {
@@ -7787,7 +8183,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7787
8183
  createElementVNode("div", _hoisted_16$2, [
7788
8184
  createElementVNode("div", _hoisted_17$2, [
7789
8185
  createElementVNode("div", null, [
7790
- _cache[17] || (_cache[17] = createElementVNode("h4", { class: "profile-field-title" }, "Username", -1)),
8186
+ _cache[18] || (_cache[18] = createElementVNode("h4", { class: "profile-field-title" }, "Username", -1)),
7791
8187
  createElementVNode("p", _hoisted_18$2, toDisplayString(currentUser.value?.username || "No username set"), 1)
7792
8188
  ]),
7793
8189
  createVNode(unref(StrandsUiButton), {
@@ -7797,7 +8193,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7797
8193
  onClick: handleToggleUsernameChange
7798
8194
  }, {
7799
8195
  default: withCtx(() => [
7800
- createTextVNode(toDisplayString(usernameChangeData.cooldownEnd ? `Wait ${usernameChangeData.daysRemaining} day${usernameChangeData.daysRemaining === 1 ? "" : "s"}` : showUsernameChange.value ? "Cancel" : currentUser.value?.username ? "Change" : "Set Username"), 1)
8196
+ createTextVNode(toDisplayString(usernameChangeData.cooldownEnd ? `Wait ${usernameChangeData.daysRemaining} day${usernameChangeData.daysRemaining === 1 ? "" : "s"} to change` : showUsernameChange.value ? "Cancel" : currentUser.value?.username ? "Change" : "Set Username"), 1)
7801
8197
  ]),
7802
8198
  _: 1
7803
8199
  }, 8, ["disabled"])
@@ -7835,11 +8231,11 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7835
8231
  ])
7836
8232
  ]),
7837
8233
  createElementVNode("div", _hoisted_20, [
7838
- _cache[24] || (_cache[24] = createElementVNode("h3", { class: "profile-section-title" }, "Security Settings", -1)),
8234
+ _cache[25] || (_cache[25] = createElementVNode("h3", { class: "profile-section-title" }, "Security Settings", -1)),
7839
8235
  createElementVNode("div", _hoisted_21, [
7840
8236
  createElementVNode("div", _hoisted_22, [
7841
8237
  createElementVNode("div", null, [
7842
- _cache[19] || (_cache[19] = createElementVNode("h4", { class: "profile-field-title" }, "Password", -1)),
8238
+ _cache[20] || (_cache[20] = createElementVNode("h4", { class: "profile-field-title" }, "Password", -1)),
7843
8239
  createElementVNode("p", _hoisted_23, "Last updated " + toDisplayString(passwordLastUpdated.value), 1)
7844
8240
  ]),
7845
8241
  createVNode(unref(StrandsUiButton), {
@@ -7883,11 +8279,11 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7883
8279
  onClick: handlePasswordChange,
7884
8280
  disabled: !isPasswordFormValid.value
7885
8281
  }, {
7886
- default: withCtx(() => _cache[20] || (_cache[20] = [
8282
+ default: withCtx(() => _cache[21] || (_cache[21] = [
7887
8283
  createTextVNode(" Update Password ", -1)
7888
8284
  ])),
7889
8285
  _: 1,
7890
- __: [20]
8286
+ __: [21]
7891
8287
  }, 8, ["disabled"])
7892
8288
  ])) : createCommentVNode("", true)
7893
8289
  ]),
@@ -7898,7 +8294,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7898
8294
  createElementVNode("div", _hoisted_26, [
7899
8295
  createElementVNode("div", _hoisted_27, [
7900
8296
  createElementVNode("div", null, [
7901
- _cache[21] || (_cache[21] = createElementVNode("h4", { class: "profile-field-title" }, "Two-Factor Authentication", -1)),
8297
+ _cache[22] || (_cache[22] = createElementVNode("h4", { class: "profile-field-title" }, "Two-Factor Authentication", -1)),
7902
8298
  createElementVNode("p", _hoisted_28, toDisplayString(currentUser.value?.mfaEnabled ? "Enabled" : "Add extra security to your account"), 1)
7903
8299
  ]),
7904
8300
  mfaDeviceChips.value.length > 0 ? (openBlock(), createElementBlock("div", _hoisted_29, [
@@ -7933,26 +8329,28 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7933
8329
  createElementVNode("div", _hoisted_30, [
7934
8330
  createElementVNode("div", _hoisted_31, [
7935
8331
  createElementVNode("div", null, [
7936
- _cache[22] || (_cache[22] = createElementVNode("h4", { class: "profile-field-title" }, "Active Sessions", -1)),
7937
- createElementVNode("p", _hoisted_32, toDisplayString(activeSessions.value.length) + " active device(s)", 1)
8332
+ _cache[23] || (_cache[23] = createElementVNode("h4", { class: "profile-field-title" }, "Active Sessions", -1)),
8333
+ createElementVNode("p", _hoisted_32, [
8334
+ loadingSessions.value ? (openBlock(), createElementBlock("span", _hoisted_33, "Loading sessions...")) : (openBlock(), createElementBlock("span", _hoisted_34, toDisplayString(activeSessions.value.length) + " active device" + toDisplayString(activeSessions.value.length !== 1 ? "s" : ""), 1))
8335
+ ])
7938
8336
  ]),
7939
8337
  createVNode(unref(StrandsUiButton), {
7940
8338
  variant: "secondary",
7941
8339
  size: "sm",
7942
- onClick: _cache[11] || (_cache[11] = ($event) => _ctx.$emit("manage-sessions")),
7943
- disabled: ""
8340
+ onClick: _cache[11] || (_cache[11] = ($event) => showSessionsModal.value = true),
8341
+ disabled: loadingSessions.value
7944
8342
  }, {
7945
- default: withCtx(() => _cache[23] || (_cache[23] = [
7946
- createTextVNode(" Coming Soon ", -1)
8343
+ default: withCtx(() => _cache[24] || (_cache[24] = [
8344
+ createTextVNode(" Manage ", -1)
7947
8345
  ])),
7948
8346
  _: 1,
7949
- __: [23]
7950
- })
8347
+ __: [24]
8348
+ }, 8, ["disabled"])
7951
8349
  ])
7952
8350
  ])
7953
8351
  ])
7954
8352
  ]),
7955
- hasChanges.value ? (openBlock(), createElementBlock("div", _hoisted_33, [
8353
+ hasChanges.value ? (openBlock(), createElementBlock("div", _hoisted_35, [
7956
8354
  createVNode(unref(StrandsUiButton), {
7957
8355
  type: "submit",
7958
8356
  variant: "primary",
@@ -7969,18 +8367,18 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7969
8367
  onClick: handleCancel,
7970
8368
  disabled: loading2.value
7971
8369
  }, {
7972
- default: withCtx(() => _cache[25] || (_cache[25] = [
8370
+ default: withCtx(() => _cache[26] || (_cache[26] = [
7973
8371
  createTextVNode(" Cancel ", -1)
7974
8372
  ])),
7975
8373
  _: 1,
7976
- __: [25]
8374
+ __: [26]
7977
8375
  }, 8, ["disabled"])
7978
8376
  ])) : createCommentVNode("", true)
7979
8377
  ], 32),
7980
- successMessage.value ? (openBlock(), createElementBlock("div", _hoisted_34, [
7981
- createElementVNode("div", _hoisted_35, [
7982
- createElementVNode("div", _hoisted_36, [
7983
- _cache[26] || (_cache[26] = createElementVNode("svg", {
8378
+ successMessage.value ? (openBlock(), createElementBlock("div", _hoisted_36, [
8379
+ createElementVNode("div", _hoisted_37, [
8380
+ createElementVNode("div", _hoisted_38, [
8381
+ _cache[27] || (_cache[27] = createElementVNode("svg", {
7984
8382
  class: "profile-help-icon",
7985
8383
  fill: "currentColor",
7986
8384
  viewBox: "0 0 20 20"
@@ -7991,14 +8389,14 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
7991
8389
  "clip-rule": "evenodd"
7992
8390
  })
7993
8391
  ], -1)),
7994
- createElementVNode("p", _hoisted_37, toDisplayString(successMessage.value), 1)
8392
+ createElementVNode("p", _hoisted_39, toDisplayString(successMessage.value), 1)
7995
8393
  ])
7996
8394
  ])
7997
8395
  ])) : createCommentVNode("", true),
7998
- errorMessage.value ? (openBlock(), createElementBlock("div", _hoisted_38, [
7999
- createElementVNode("div", _hoisted_39, [
8000
- createElementVNode("div", _hoisted_40, [
8001
- _cache[27] || (_cache[27] = createElementVNode("svg", {
8396
+ errorMessage.value ? (openBlock(), createElementBlock("div", _hoisted_40, [
8397
+ createElementVNode("div", _hoisted_41, [
8398
+ createElementVNode("div", _hoisted_42, [
8399
+ _cache[28] || (_cache[28] = createElementVNode("svg", {
8002
8400
  class: "profile-help-icon",
8003
8401
  fill: "currentColor",
8004
8402
  viewBox: "0 0 20 20"
@@ -8009,7 +8407,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
8009
8407
  "clip-rule": "evenodd"
8010
8408
  })
8011
8409
  ], -1)),
8012
- createElementVNode("p", _hoisted_41, toDisplayString(errorMessage.value), 1)
8410
+ createElementVNode("p", _hoisted_43, toDisplayString(errorMessage.value), 1)
8013
8411
  ])
8014
8412
  ])
8015
8413
  ])) : createCommentVNode("", true),
@@ -8017,7 +8415,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
8017
8415
  config: props.config
8018
8416
  }, {
8019
8417
  default: withCtx(() => [
8020
- createElementVNode("div", _hoisted_42, [
8418
+ createElementVNode("div", _hoisted_44, [
8021
8419
  createVNode(unref(StrandsUiButton), {
8022
8420
  color: "red",
8023
8421
  onClick: handleSignOut,
@@ -8034,7 +8432,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
8034
8432
  onClick: _cache[12] || (_cache[12] = ($event) => showSettingsModal.value = true),
8035
8433
  class: "profile-sign-out-button"
8036
8434
  }, {
8037
- default: withCtx(() => _cache[28] || (_cache[28] = [
8435
+ default: withCtx(() => _cache[29] || (_cache[29] = [
8038
8436
  createElementVNode("svg", {
8039
8437
  class: "profile-action-icon",
8040
8438
  fill: "none",
@@ -8056,21 +8454,21 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
8056
8454
  ], -1)
8057
8455
  ])),
8058
8456
  _: 1,
8059
- __: [28]
8457
+ __: [29]
8060
8458
  })
8061
8459
  ]),
8062
- unref(getSupportEmail)() ? (openBlock(), createElementBlock("div", _hoisted_43, [
8063
- createElementVNode("p", _hoisted_44, [
8064
- _cache[30] || (_cache[30] = createTextVNode(" Need help? ", -1)),
8460
+ unref(getSupportEmail)() ? (openBlock(), createElementBlock("div", _hoisted_45, [
8461
+ createElementVNode("p", _hoisted_46, [
8462
+ _cache[31] || (_cache[31] = createTextVNode(" Need help? ", -1)),
8065
8463
  createVNode(unref(StrandsUiLink), {
8066
8464
  variant: "primary",
8067
8465
  href: `mailto:${unref(getSupportEmail)()}`
8068
8466
  }, {
8069
- default: withCtx(() => _cache[29] || (_cache[29] = [
8467
+ default: withCtx(() => _cache[30] || (_cache[30] = [
8070
8468
  createTextVNode(" Contact Support ", -1)
8071
8469
  ])),
8072
8470
  _: 1,
8073
- __: [29]
8471
+ __: [30]
8074
8472
  }, 8, ["href"])
8075
8473
  ])
8076
8474
  ])) : createCommentVNode("", true)
@@ -8088,15 +8486,20 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
8088
8486
  onClose: _cache[14] || (_cache[14] = ($event) => showSettingsModal.value = false),
8089
8487
  onSettingsUpdated: handleSettingsUpdated
8090
8488
  })) : createCommentVNode("", true),
8091
- showAvatarEditor.value ? (openBlock(), createElementBlock("div", _hoisted_45, [
8092
- createElementVNode("div", _hoisted_46, [
8093
- createElementVNode("div", _hoisted_47, [
8489
+ createVNode(StrandsSessionsModal, {
8490
+ modelValue: showSessionsModal.value,
8491
+ "onUpdate:modelValue": _cache[15] || (_cache[15] = ($event) => showSessionsModal.value = $event),
8492
+ onSessionsUpdated: handleSessionsUpdated
8493
+ }, null, 8, ["modelValue"]),
8494
+ showAvatarEditor.value ? (openBlock(), createElementBlock("div", _hoisted_47, [
8495
+ createElementVNode("div", _hoisted_48, [
8496
+ createElementVNode("div", _hoisted_49, [
8094
8497
  createElementVNode("div", { class: "profile-avatar-modal-header" }, [
8095
- _cache[33] || (_cache[33] = createElementVNode("h2", { class: "profile-modal-title" }, "Edit Avatar", -1)),
8498
+ _cache[34] || (_cache[34] = createElementVNode("h2", { class: "profile-modal-title" }, "Edit Avatar", -1)),
8096
8499
  createElementVNode("button", {
8097
8500
  onClick: handleAvatarEditorClose,
8098
8501
  class: "profile-avatar-modal-close"
8099
- }, _cache[32] || (_cache[32] = [
8502
+ }, _cache[33] || (_cache[33] = [
8100
8503
  createElementVNode("svg", {
8101
8504
  class: "profile-avatar-modal-close-icon",
8102
8505
  fill: "none",
@@ -8126,7 +8529,7 @@ const _sfc_main$8 = /* @__PURE__ */ defineComponent({
8126
8529
  };
8127
8530
  }
8128
8531
  });
8129
- const StrandsUserProfile = /* @__PURE__ */ _export_sfc(_sfc_main$8, [["__scopeId", "data-v-b880e15b"]]);
8532
+ const StrandsUserProfile = /* @__PURE__ */ _export_sfc(_sfc_main$8, [["__scopeId", "data-v-dcc0db9b"]]);
8130
8533
  const _hoisted_1$6 = { class: "accui-component-scope" };
8131
8534
  const _hoisted_2$4 = { class: "accui-w-full accui-min-w-100 accui-max-w-md accui-mx-auto accui-animate-slide-up" };
8132
8535
  const _hoisted_3$4 = { class: "accui-mt-8 accui-text-center" };
@@ -9389,13 +9792,14 @@ export {
9389
9792
  StrandsMfaVerification,
9390
9793
  StrandsPasswordReset,
9391
9794
  StrandsSecuredFooter,
9795
+ StrandsSessionsModal,
9392
9796
  StrandsSettingsModal,
9393
9797
  StrandsSignIn,
9394
9798
  StrandsSignUp,
9395
9799
  StrandsTotpSetupModal,
9396
9800
  StrandsUIPlugin,
9397
9801
  StrandsUiAlert,
9398
- _sfc_main$o as StrandsUiAvatarEditor,
9802
+ _sfc_main$p as StrandsUiAvatarEditor,
9399
9803
  StrandsUiButton,
9400
9804
  StrandsUiCard,
9401
9805
  StrandsUiInput,
@@ -9409,8 +9813,8 @@ export {
9409
9813
  StrandsUserProfile,
9410
9814
  _sfc_main$1 as SvgIcon,
9411
9815
  StrandsUiAlert as UiAlert,
9412
- _sfc_main$o as UiAvatarEditor,
9413
- _sfc_main$o as UiAvatarEditorSimple,
9816
+ _sfc_main$p as UiAvatarEditor,
9817
+ _sfc_main$p as UiAvatarEditorSimple,
9414
9818
  StrandsUiButton as UiButton,
9415
9819
  StrandsUiCard as UiCard,
9416
9820
  StrandsUiInput as UiInput,