@nanoporetech-digital/components 8.7.2 → 8.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (136) hide show
  1. package/dist/cjs/{fade-NeUskjyB.js → fade-DBKqk3wh.js} +1 -1
  2. package/dist/cjs/{fullscreen-D5cgtwoy.js → fullscreen-lcdCtrG6.js} +1 -1
  3. package/dist/cjs/index-DGttnXif.js +4 -0
  4. package/dist/cjs/{lazyload-Dm1NcTJ1.js → lazyload-BjSSEx9f.js} +1 -1
  5. package/dist/cjs/loader.cjs.js +1 -1
  6. package/dist/cjs/nano-avatar_5.cjs.entry.js +7 -7
  7. package/dist/cjs/nano-components.cjs.js +1 -1
  8. package/dist/cjs/nano-icon-button_2.cjs.entry.js +2 -2
  9. package/dist/cjs/nano-input-otp.cjs.entry.js +710 -0
  10. package/dist/cjs/nano-intersection-observe.cjs.entry.js +1 -1
  11. package/dist/cjs/nano-masked-overflow.cjs.entry.js +3 -3
  12. package/dist/cjs/nano-menu-drawer.cjs.entry.js +2 -2
  13. package/dist/cjs/nano-more-less.cjs.entry.js +2 -2
  14. package/dist/cjs/nano-rating.cjs.entry.js +4 -4
  15. package/dist/cjs/nano-resize-observe.cjs.entry.js +2 -2
  16. package/dist/cjs/nano-slide.cjs.entry.js +1 -1
  17. package/dist/cjs/{nano-slides-ycRcUf0g.js → nano-slides-CryCLfsK.js} +7 -7
  18. package/dist/cjs/nano-slides.cjs.entry.js +1 -1
  19. package/dist/cjs/nano-sortable.cjs.entry.js +1 -1
  20. package/dist/cjs/nano-step-accordion.cjs.entry.js +1 -1
  21. package/dist/cjs/nano-step-breadcrumb.cjs.entry.js +2 -2
  22. package/dist/cjs/nano-sticker.cjs.entry.js +2 -2
  23. package/dist/cjs/nano-tab-content.cjs.entry.js +2 -2
  24. package/dist/cjs/nano-tab.cjs.entry.js +2 -2
  25. package/dist/cjs/nano-table.cjs.entry.js +2 -2
  26. package/dist/cjs/{page-dots--38yVfTZ.js → page-dots-DR1fLjRi.js} +1 -1
  27. package/dist/collection/collection-manifest.json +1 -0
  28. package/dist/collection/components/breadcrumb/breadcrumb.js +1 -1
  29. package/dist/collection/components/input-otp/input-otp-interface.js +1 -0
  30. package/dist/collection/components/input-otp/input-otp.css +184 -0
  31. package/dist/collection/components/input-otp/input-otp.js +1044 -0
  32. package/dist/collection/components/intersection-observe/intersection-observe.js +1 -1
  33. package/dist/collection/components/masked-overflow/masked-overflow.js +3 -3
  34. package/dist/collection/components/menu-drawer/menu-drawer.js +2 -2
  35. package/dist/collection/components/more-less/more-less.js +2 -2
  36. package/dist/collection/components/rating/rating.js +4 -4
  37. package/dist/collection/components/resize-observe/resize-observe.js +2 -2
  38. package/dist/collection/components/select/select.js +7 -7
  39. package/dist/collection/components/slides/slide.js +1 -1
  40. package/dist/collection/components/slides/slides.js +3 -3
  41. package/dist/collection/components/sortable/sortable.js +1 -1
  42. package/dist/collection/components/step-accordion/step-accordion.js +1 -1
  43. package/dist/collection/components/step-breadcrumb/step-breadcrumb.js +2 -2
  44. package/dist/collection/components/sticker/sticker.js +2 -2
  45. package/dist/collection/components/table/table.js +2 -2
  46. package/dist/collection/components/tabs/tab-content.js +2 -2
  47. package/dist/collection/components/tabs/tab.js +2 -2
  48. package/dist/collection/components/tooltip/tooltip.js +2 -2
  49. package/dist/components/masked-overflow.js +3 -3
  50. package/dist/components/nano-input-otp.d.ts +11 -0
  51. package/dist/components/nano-input-otp.js +749 -0
  52. package/dist/components/nano-intersection-observe.js +1 -1
  53. package/dist/components/nano-menu-drawer.js +2 -2
  54. package/dist/components/nano-more-less.js +2 -2
  55. package/dist/components/nano-rating.js +4 -4
  56. package/dist/components/nano-slide.js +1 -1
  57. package/dist/components/nano-sortable.js +1 -1
  58. package/dist/components/nano-step-accordion.js +1 -1
  59. package/dist/components/nano-step-breadcrumb.js +2 -2
  60. package/dist/components/nano-tab-content.js +2 -2
  61. package/dist/components/nano-tab.js +2 -2
  62. package/dist/components/nano-table.js +2 -2
  63. package/dist/components/resize-observe.js +2 -2
  64. package/dist/components/select.js +7 -7
  65. package/dist/components/slides.js +3 -3
  66. package/dist/components/sticker.js +2 -2
  67. package/dist/components/tooltip.js +2 -2
  68. package/dist/esm/{fade-BA6b-Fk9.js → fade-D980mOvm.js} +1 -1
  69. package/dist/esm/{fullscreen-De_yN4cg.js → fullscreen-CjInlYb9.js} +1 -1
  70. package/dist/esm/index-BM3Om9WE.js +4 -0
  71. package/dist/esm/{lazyload-Cl8k3tPs.js → lazyload-B9B4e3ZI.js} +1 -1
  72. package/dist/esm/loader.js +1 -1
  73. package/dist/esm/nano-avatar_5.entry.js +7 -7
  74. package/dist/esm/nano-components.js +1 -1
  75. package/dist/esm/nano-icon-button_2.entry.js +2 -2
  76. package/dist/esm/nano-input-otp.entry.js +708 -0
  77. package/dist/esm/nano-intersection-observe.entry.js +1 -1
  78. package/dist/esm/nano-masked-overflow.entry.js +3 -3
  79. package/dist/esm/nano-menu-drawer.entry.js +2 -2
  80. package/dist/esm/nano-more-less.entry.js +2 -2
  81. package/dist/esm/nano-rating.entry.js +4 -4
  82. package/dist/esm/nano-resize-observe.entry.js +2 -2
  83. package/dist/esm/nano-slide.entry.js +1 -1
  84. package/dist/esm/{nano-slides-GrbOydfa.js → nano-slides-xbY6lXX9.js} +7 -7
  85. package/dist/esm/nano-slides.entry.js +1 -1
  86. package/dist/esm/nano-sortable.entry.js +1 -1
  87. package/dist/esm/nano-step-accordion.entry.js +1 -1
  88. package/dist/esm/nano-step-breadcrumb.entry.js +2 -2
  89. package/dist/esm/nano-sticker.entry.js +2 -2
  90. package/dist/esm/nano-tab-content.entry.js +2 -2
  91. package/dist/esm/nano-tab.entry.js +2 -2
  92. package/dist/esm/nano-table.entry.js +2 -2
  93. package/dist/esm/{page-dots-CSf81OuJ.js → page-dots-CCfERISy.js} +1 -1
  94. package/dist/nano-components/{fade-BA6b-Fk9.js → fade-D980mOvm.js} +1 -1
  95. package/dist/nano-components/{fullscreen-De_yN4cg.js → fullscreen-CjInlYb9.js} +1 -1
  96. package/dist/nano-components/lazyload-B9B4e3ZI.js +4 -0
  97. package/dist/nano-components/nano-avatar_5.entry.js +1 -1
  98. package/dist/nano-components/nano-components.esm.js +1 -1
  99. package/dist/nano-components/nano-icon-button_2.entry.js +1 -1
  100. package/dist/nano-components/nano-input-otp.entry.js +4 -0
  101. package/dist/nano-components/nano-intersection-observe.entry.js +1 -1
  102. package/dist/nano-components/nano-masked-overflow.entry.js +1 -1
  103. package/dist/nano-components/nano-menu-drawer.entry.js +1 -1
  104. package/dist/nano-components/nano-more-less.entry.js +1 -1
  105. package/dist/nano-components/nano-rating.entry.js +1 -1
  106. package/dist/nano-components/nano-resize-observe.entry.js +1 -1
  107. package/dist/nano-components/nano-slide.entry.js +1 -1
  108. package/dist/nano-components/{nano-slides-GrbOydfa.js → nano-slides-xbY6lXX9.js} +3 -3
  109. package/dist/nano-components/nano-slides.entry.js +1 -1
  110. package/dist/nano-components/nano-sortable.entry.js +1 -1
  111. package/dist/nano-components/nano-step-accordion.entry.js +1 -1
  112. package/dist/nano-components/nano-step-breadcrumb.entry.js +1 -1
  113. package/dist/nano-components/nano-sticker.entry.js +1 -1
  114. package/dist/nano-components/nano-tab-content.entry.js +1 -1
  115. package/dist/nano-components/nano-tab.entry.js +1 -1
  116. package/dist/nano-components/nano-table.entry.js +1 -1
  117. package/dist/nano-components/{page-dots-CSf81OuJ.js → page-dots-CCfERISy.js} +1 -1
  118. package/dist/types/components/input-otp/input-otp-interface.d.ts +24 -0
  119. package/dist/types/components/input-otp/input-otp.d.ts +281 -0
  120. package/dist/types/components.d.ts +179 -0
  121. package/docs-json.json +614 -2
  122. package/docs-vscode.json +79 -0
  123. package/hydrate/index.js +779 -43
  124. package/hydrate/index.mjs +779 -43
  125. package/package.json +2 -2
  126. package/dist/nano-components/lazyload-Cl8k3tPs.js +0 -4
  127. /package/dist/types/builds/{QrfEi4pt → sxrVAURy}/0/Digital/nano-components/packages/components/.stencil/plugins/stencil/vue-output/generate-vue-component.d.ts +0 -0
  128. /package/dist/types/builds/{QrfEi4pt → sxrVAURy}/0/Digital/nano-components/packages/components/.stencil/plugins/stencil/vue-output/index.d.ts +0 -0
  129. /package/dist/types/builds/{QrfEi4pt → sxrVAURy}/0/Digital/nano-components/packages/components/.stencil/plugins/stencil/vue-output/output-vue.d.ts +0 -0
  130. /package/dist/types/builds/{QrfEi4pt → sxrVAURy}/0/Digital/nano-components/packages/components/.stencil/plugins/stencil/vue-output/plugin.d.ts +0 -0
  131. /package/dist/types/builds/{QrfEi4pt → sxrVAURy}/0/Digital/nano-components/packages/components/.stencil/plugins/stencil/vue-output/types.d.ts +0 -0
  132. /package/dist/types/builds/{QrfEi4pt → sxrVAURy}/0/Digital/nano-components/packages/components/.stencil/plugins/stencil/vue-output/utils.d.ts +0 -0
  133. /package/dist/types/builds/{QrfEi4pt → sxrVAURy}/0/Digital/nano-components/packages/components/.stencil/stencil.config.d.ts +0 -0
  134. /package/dist/types/builds/{QrfEi4pt → sxrVAURy}/0/Digital/nano-components/packages/components/.stencil/stencil.config.prod.d.ts +0 -0
  135. /package/dist/types/builds/{QrfEi4pt → sxrVAURy}/0/Digital/nano-components/packages/components/.stencil/testing/mocks/intersection-observer.d.ts +0 -0
  136. /package/dist/types/builds/{QrfEi4pt → sxrVAURy}/0/Digital/nano-components/packages/components/.stencil/wdio.conf.d.ts +0 -0
package/hydrate/index.mjs CHANGED
@@ -9788,7 +9788,7 @@ const DateRegxps = {
9788
9788
  m: '(\\d{1,2})',
9789
9789
  y: '(\\d{4})',
9790
9790
  };
9791
- let inputIds$1 = 0;
9791
+ let inputIds$2 = 0;
9792
9792
  /**
9793
9793
  * Enables date selection and input in a form.
9794
9794
  *
@@ -9814,7 +9814,7 @@ class DateInput {
9814
9814
  input;
9815
9815
  directInput = false;
9816
9816
  dateOrderIndeces = { d: 0, m: 1, y: 3 };
9817
- inputId = `nano-input-${inputIds$1++}`;
9817
+ inputId = `nano-input-${inputIds$2++}`;
9818
9818
  locale = window.navigator.languages ||
9819
9819
  window.navigator.language ||
9820
9820
  undefined;
@@ -17039,7 +17039,7 @@ const FormControl = (props, children) => {
17039
17039
 
17040
17040
  const inputCss = ".sc-nano-input-h, *.sc-nano-input, *.sc-nano-input::before, *.sc-nano-input::after {\n box-sizing: border-box;\n}\n[hidden].sc-nano-input {\n display: none !important;\n}\n@media (prefers-reduced-motion: reduce) {\n .sc-nano-input-h, *.sc-nano-input, *.sc-nano-input::before, *.sc-nano-input::after {\n animation-duration: 0.01ms !important;\n animation-iteration-count: 1 !important;\n transition-duration: 0.01ms !important;\n scroll-behavior: auto !important;\n }\n }.sc-nano-input-h, *.sc-nano-input, *.sc-nano-input::before, *.sc-nano-input::after {\n box-sizing: border-box;\n}\n[hidden].sc-nano-input {\n display: none !important;\n}\n@media (prefers-reduced-motion: reduce) {\n .sc-nano-input-h, *.sc-nano-input, *.sc-nano-input::before, *.sc-nano-input::after {\n animation-duration: 0.01ms !important;\n animation-iteration-count: 1 !important;\n transition-duration: 0.01ms !important;\n scroll-behavior: auto !important;\n }\n }slot-fb.sc-nano-input {\n display: contents !important;\n}\n\n[disabled].sc-nano-input-h:not([disabled=false]) {\n opacity: 0.5;\n position: relative;\n}\n[disabled].sc-nano-input-h:not([disabled=false])::after {\n content: \"\";\n position: absolute;\n inset: 0;\n cursor: not-allowed;\n}\n\n.form-ctrl.sc-nano-input {\n min-inline-size: 100%;\n display: block;\n}\n.form-ctrl.has-helper-end.sc-nano-input {\n display: flex;\n gap: 1rem;\n container-type: inline-size;\n}\n.form-ctrl.has-helper-end.sc-nano-input .form-ctrl__wrapper.sc-nano-input {\n flex: 1 1 100%;\n}\n.form-ctrl.has-helper-end.sc-nano-input .form-ctrl__helper-end.sc-nano-input {\n display: none;\n}\n@container (min-width: 350px) {\n .form-ctrl.has-helper-end .form-ctrl__helper-end {\n display: block !important;\n }\n .form-ctrl.has-helper-end .form-ctrl__helper {\n display: none !important;\n }\n}\n\n.form-ctrl__wrapper.sc-nano-input {\n display: block;\n}\n\nlabel.sc-nano-input, .form-ctrl__more.sc-nano-input, .form-ctrl__error.sc-nano-input, .form-ctrl__helper.sc-nano-input {\n display: block;\n}\nlabel.visually-hide.sc-nano-input, .form-ctrl__more.visually-hide.sc-nano-input, .form-ctrl__error.visually-hide.sc-nano-input, .form-ctrl__helper.visually-hide.sc-nano-input {\n clip-path: inset(50%);\n block-size: 1px;\n overflow: hidden;\n position: absolute;\n white-space: nowrap;\n inline-size: 1px;\n}\n\n.form-ctrl__float-label.sc-nano-input {\n padding-block: 0;\n padding-inline: var(--padding-start) 0;\n color: var(--label-color);\n position: absolute;\n font-size: 1em;\n transform: translateY(-50%);\n inset-block-start: 50%;\n transition: all 0.125s ease-in;\n opacity: 1;\n}\n.has-focus.sc-nano-input-h .form-ctrl__float-label.sc-nano-input, .has-value.sc-nano-input-h .form-ctrl__float-label.sc-nano-input {\n transform: none;\n font-size: 0.75em;\n opacity: 0.7;\n inset-block-start: var(--padding-top);\n}\n.form-ctrl__float-label.sc-nano-input .form-ctrl__label-charcount.sc-nano-input {\n opacity: 0;\n transition: opacity 0.125s ease-in;\n}\n.has-focus.sc-nano-input-h .form-ctrl__float-label.sc-nano-input .form-ctrl__label-charcount.sc-nano-input, .has-value.sc-nano-input-h .form-ctrl__float-label.sc-nano-input .form-ctrl__label-charcount.sc-nano-input {\n opacity: 1;\n}\n\n.form-ctrl__label.sc-nano-input {\n color: var(--label-color);\n font-size: var(--label-font-size);\n padding-block-end: var(--padding-bottom);\n line-height: 1;\n display: flex;\n align-items: center;\n}\n.form-ctrl__label.sc-nano-input .form-ctrl__label-wrap.sc-nano-input {\n flex: 1;\n overflow-x: clip;\n white-space: nowrap;\n text-overflow: ellipsis;\n}\n.form-ctrl__label.sc-nano-input .form-ctrl__label-placeholder.sc-nano-input {\n margin-block: unset;\n margin-inline: 0 5px;\n opacity: 0;\n appearance: none;\n transition: 0.3s ease opacity;\n font-size: 0.85em;\n}\n.form-ctrl__label.sc-nano-input .form-ctrl__label-charcount.sc-nano-input {\n margin-block: unset;\n margin-inline: auto 0;\n font-size: var(--nano-font-size-2xs);\n opacity: 0.5;\n}\n.has-value.sc-nano-input-h .form-ctrl__label.sc-nano-input .form-ctrl__label-placeholder.sc-nano-input {\n opacity: 0.5;\n}\n\n.has-float-label.sc-nano-input .select__multi-input.sc-nano-input, .has-float-label.sc-nano-input .select__native-input.sc-nano-input, .has-float-label.sc-nano-input .input__native-ctrl.sc-nano-input {\n opacity: 0;\n transition: opacity 0.125s ease-in;\n}\n.has-focus.sc-nano-input-h .has-float-label.sc-nano-input .select__multi-input.sc-nano-input, .has-value.sc-nano-input-h .has-float-label.sc-nano-input .select__multi-input.sc-nano-input, .has-focus.sc-nano-input-h .has-float-label.sc-nano-input .select__native-input.sc-nano-input, .has-value.sc-nano-input-h .has-float-label.sc-nano-input .select__native-input.sc-nano-input, .has-focus.sc-nano-input-h .has-float-label.sc-nano-input .input__native-ctrl.sc-nano-input, .has-value.sc-nano-input-h .has-float-label.sc-nano-input .input__native-ctrl.sc-nano-input {\n opacity: 1;\n}\n\n.form-ctrl__more.sc-nano-input {\n position: relative;\n margin-block: var(--padding-bottom) 0;\n margin-inline: 0;\n opacity: 0;\n display: none;\n transition: all var(--nano-transition-fast) ease;\n transition-behavior: allow-discrete;\n}\n.form-ctrl__more.sc-nano-input > *.sc-nano-input {\n grid-column: 1;\n grid-row: 1;\n}\n.has-helper.sc-nano-input .form-ctrl__more.sc-nano-input, .has-error.sc-nano-input .form-ctrl__more.sc-nano-input {\n display: grid;\n opacity: 1;\n}\n\n.form-ctrl__helper.sc-nano-input, .form-ctrl__error.sc-nano-input {\n font-size: var(--more-font-size);\n line-height: 1.2;\n transition: 0.3s ease-out opacity;\n}\n\n.form-ctrl__helper.sc-nano-input {\n font-style: italic;\n color: var(--help-msg-color);\n}\n[show-inline-error].sc-nano-input-h:not([show-inline-error=false]).is-invalid .form-ctrl__helper.sc-nano-input {\n opacity: 0;\n}\n\n.form-ctrl__helper-end.sc-nano-input {\n flex: 1 1 30%;\n min-inline-size: 150px;\n font-size: var(--invalid-msg-font-size);\n color: var(--help-msg-color);\n font-style: italic;\n}\n\n.form-ctrl__error.sc-nano-input {\n opacity: 0;\n color: var(--invalid-msg-color);\n font-style: italic;\n}\n.is-invalid.sc-nano-input-h:not([disabled]) .form-ctrl__error.sc-nano-input {\n opacity: 1;\n}\n\n.form-ctrl__input.sc-nano-input {\n font-family: inherit;\n font-size: inherit;\n font-stretch: inherit;\n font-style: inherit;\n font-weight: inherit;\n letter-spacing: inherit;\n text-decoration: inherit;\n text-overflow: inherit;\n text-transform: inherit;\n text-align: inherit;\n white-space: inherit;\n color: inherit;\n border-radius: var(--input-border-radius);\n inline-size: 100%;\n padding: 0 !important;\n position: relative;\n flex: 1 0 auto;\n display: flex;\n background: var(--input-bg-color);\n border: var(--input-border-style) var(--input-border-width);\n font-size: var(--input-font-size);\n padding-inline-start: calc(var(--input-invalid-border-hint-width) - var(--input-border-width)) !important;\n}\n.form-ctrl__input.sc-nano-input:focus-visible, .form-ctrl__input.sc-nano-input:focus-within, .has-focus.sc-nano-input-h .form-ctrl__input.sc-nano-input {\n outline: var(--nano-focus-ring-color) solid 3px;\n outline-offset: -2px;\n}\n.is-invalid.sc-nano-input-h:not([disabled]) .form-ctrl__input.sc-nano-input {\n border-inline-start: solid var(--color-invalid) var(--input-invalid-border-hint-width);\n padding-inline-start: 0 !important;\n}\n.is-invalid.has-focus.sc-nano-input-h:not([disabled]) .form-ctrl__input.sc-nano-input {\n border-color: var(--color-invalid);\n border-inline-start: solid var(--color-invalid) var(--input-invalid-border-hint-width);\n padding-inline-start: 0 !important;\n}\n\n.form-ctrl__input-wrap.sc-nano-input {\n display: flex;\n flex: 1;\n max-inline-size: 100%;\n align-items: center;\n}\n[type=textarea].sc-nano-input-h .form-ctrl__input-wrap.sc-nano-input {\n align-items: start;\n}\n\n.form-ctrl__clear-btn.sc-nano-input, .form-ctrl__slot-end.sc-nano-input, .form-ctrl__slot-start.sc-nano-input, .form-ctrl__slot-value-end.sc-nano-input {\n margin-block: 0;\n margin-inline: 0;\n font-size: 1em;\n border: 0;\n outline: none;\n background-color: transparent;\n background-repeat: no-repeat;\n display: flex;\n align-items: center;\n inline-size: auto;\n padding-inline-end: var(--padding-end);\n padding-block: var(--padding-top) var(--padding-bottom);\n}\n.form-ctrl__clear-btn.sc-nano-input:empty, .form-ctrl__slot-end.sc-nano-input:empty, .form-ctrl__slot-start.sc-nano-input:empty, .form-ctrl__slot-value-end.sc-nano-input:empty {\n display: none;\n}\n\n.form-ctrl__slot-end.sc-nano-input {\n padding-block: calc(var(--padding-top) / 2) calc(var(--padding-bottom) / 2);\n}\n\n.form-ctrl__slot-start.sc-nano-input {\n padding-inline-end: 0;\n}\n.has-float-label.sc-nano-input .form-ctrl__slot-start.sc-nano-input {\n display: none;\n}\n\n.form-ctrl__slot-start.sc-nano-input-s > *, .form-ctrl__slot-start.sc-nano-input-s > *, .form-ctrl__slot-start .sc-nano-input-s > *, .form-ctrl__slot-end.sc-nano-input-s > *, .form-ctrl__slot-end .sc-nano-input-s > *, .form-ctrl__slot-value-end.sc-nano-input-s > :not(slot-fb), .form-ctrl__slot-value-end .sc-nano-input-s > :not(slot-fb) {\n padding-inline: unset;\n align-items: center;\n display: flex;\n block-size: 100%;\n z-index: 1;\n}\n.sc-nano-input-h[disabled]:not([disabled=false]) .form-ctrl__slot-start.sc-nano-input-s > *, .form-ctrl__slot-start.sc-nano-input-s > *, .form-ctrl__slot-start .sc-nano-input-s > *, .sc-nano-input-h[disabled]:not([disabled=false]) .form-ctrl__slot-end.sc-nano-input-s > *, .form-ctrl__slot-end .sc-nano-input-s > *, .sc-nano-input-h[disabled]:not([disabled=false]) .form-ctrl__slot-value-end.sc-nano-input-s > :not(slot-fb), .form-ctrl__slot-value-end .sc-nano-input-s > :not(slot-fb) {\n pointer-events: none;\n}\n\n.form-ctrl__slot-start.sc-nano-input-s > *, .form-ctrl__slot-start.sc-nano-input-s > *, .form-ctrl__slot-start .sc-nano-input-s > * {\n margin-inline: var(--padding-start) 0;\n}\n\n.form-ctrl__slot-value-end.sc-nano-input-s > *, .form-ctrl__slot-value-end.sc-nano-input-s > *, .form-ctrl__slot-value-end .sc-nano-input-s > *, .form-ctrl__slot-value-end.sc-nano-input *.sc-nano-input {\n pointer-events: none;\n}\n\n.form-ctrl__clear-btn.sc-nano-input {\n color: var(--clear-btn-color);\n padding: 0;\n opacity: 0;\n inline-size: 0;\n appearance: none;\n align-items: center;\n overflow: hidden;\n padding-block: var(--padding-top) var(--padding-bottom);\n}\n.is-invalid.sc-nano-input-h .form-ctrl__clear-btn.sc-nano-input {\n color: var(--clear-btn-color--invalid);\n}\n.has-value.sc-nano-input-h .form-ctrl__clear-btn.sc-nano-input {\n padding-inline: 0 var(--padding-end);\n opacity: 1;\n inline-size: auto;\n}\n.form-ctrl__clear-btn.sc-nano-input:hover {\n color: var(--clear-btn-color--hover);\n}\n\n.form-ctrl__validation-icon.sc-nano-input {\n padding-block: var(--padding-top) var(--padding-bottom);\n padding-inline-end: var(--padding-end);\n display: grid;\n grid-template-areas: \"overlay\";\n}\n.sc-nano-input-h:not(.is-invalid .form-ctrl__validation-icon.sc-nano-input, .is-valid).sc-nano-input-h .form-ctrl__validation-icon.sc-nano-input {\n display: none;\n}\n\n.form-ctrl__error-icon.sc-nano-input, .form-ctrl__success-icon.sc-nano-input {\n color: var(--color-valid);\n opacity: 0;\n transition: 0.3s ease-out opacity;\n grid-area: overlay;\n}\n\n.is-valid.sc-nano-input-h .form-ctrl__success-icon.sc-nano-input {\n opacity: 1;\n}\n\n.form-ctrl__error-icon.sc-nano-input {\n color: var(--color-invalid);\n}\n.is-invalid.sc-nano-input-h .form-ctrl__error-icon.sc-nano-input {\n opacity: 1;\n}\n\n.sc-nano-input-h {\n \n --placeholder-color: var(--nano-color-neutral-1000);\n --padding-top: var(--nano-spacing-sm);\n --padding-end: var(--nano-spacing-sm);\n --padding-bottom: var(--nano-spacing-sm);\n --padding-start: var(--nano-spacing-sm);\n --color-invalid: var(--nano-color-danger-1100);\n --color-valid: var(--nano-color-success-1000);\n --input-font-size: var(--nano-font-size-sm);\n --input-text-color: var(--nano-color-base-1000);\n --input-border-width: 1px;\n --input-border-color: var(--nano-color-neutral-300);\n --input-border-radius: 0px;\n --input-invalid-border-hint-width: 2px;\n --input-border-style: solid var(--input-border-color);\n --input-border-style--focus: solid var(--input-border-width) var(--nano-color-primary-700);\n --input-bg-color: var(--nano-color-base-0);\n --invalid-msg-color: var(--color-invalid);\n --help-msg-color: var(--nano-color-base-1000);\n --more-font-size: var(--nano-font-size-2xs);\n --clear-btn-color: rgb(var(--nano-color-base-rgb-1000) / 60%);\n --clear-btn-color--hover: rgb(var(--nano-color-base-rgb-1000) / 100%);\n --clear-btn-color--invalid: rgb(var(--color-invalid) / 100%);\n --label-color: var(--nano-color-base-1000);\n --label-font-size: var(--nano-font-size-xs);\n position: relative;\n inline-size: 100%;\n padding: 0 !important;\n color: currentcolor;\n display: block;\n}\n\n[type=date].sc-nano-input-h .input__date-trigger.sc-nano-input {\n color: var(--nano-color-primary-1200);\n}\n[type=date].sc-nano-input-h .input__date-dropdown.sc-nano-input {\n --overflow: visible;\n}\n[type=date].sc-nano-input-h .input__date-close.sc-nano-input {\n position: absolute;\n inset-inline-end: 0;\n inset-block: 0;\n opacity: 0;\n z-index: 2;\n}\n[type=date].sc-nano-input-h .input__date-close.sc-nano-input:focus {\n opacity: 1;\n}\n@supports selector(::-moz-placeholder) {\n [type=date].sc-nano-input-h .form-ctrl__input-wrap.sc-nano-input {\n justify-content: end;\n min-block-size: 2.5em;\n }\n [type=date].sc-nano-input-h .input__native-ctrl.sc-nano-input {\n position: absolute;\n inset-inline-start: 0;\n inset-block-start: 0;\n }\n [type=date].sc-nano-input-h .input__date-dropdown.sc-nano-input {\n background-color: var(--nano-color-base-0);\n }\n}\n\n.input__native-ctrl.sc-nano-input {\n font-family: inherit;\n font-size: inherit;\n font-stretch: inherit;\n font-style: inherit;\n font-weight: inherit;\n letter-spacing: inherit;\n text-decoration: inherit;\n text-overflow: inherit;\n text-transform: inherit;\n text-align: inherit;\n white-space: inherit;\n color: inherit;\n appearance: none;\n -webkit-rtl-ordering: logical;\n padding-block: 0;\n padding-inline: var(--padding-start) var(--padding-end);\n border-radius: var(--input-border-radius);\n text-overflow: ellipsis;\n color: var(--input-text-color);\n display: inline-block;\n flex: 1;\n inline-size: 100%;\n max-inline-size: 100%;\n max-block-size: 100%;\n border: 0;\n outline: none;\n background: transparent;\n margin: 0;\n box-sizing: border-box;\n resize: none;\n overflow: hidden;\n line-height: 2.5em;\n min-block-size: 2.5em;\n \n}\n.has-float-label.sc-nano-input .input__native-ctrl.sc-nano-input {\n line-height: 2.1em;\n min-block-size: 2.1em;\n padding-block-start: 1.4em;\n}\n.input__native-ctrl.sc-nano-input::placeholder {\n color: var(--placeholder-color);\n font-family: inherit;\n font-style: initial;\n font-weight: initial;\n line-height: inherit;\n min-block-size: initial;\n}\n.input__native-ctrl.sc-nano-input::-moz-placeholder {\n line-height: 2.8em;\n text-overflow: ellipsis;\n}\n.input__native-ctrl.sc-nano-input:-webkit-autofill {\n background-color: transparent;\n}\n.input__native-ctrl.sc-nano-input::-webkit-search-decoration, .input__native-ctrl.sc-nano-input::-webkit-search-cancel-button, .input__native-ctrl.sc-nano-input::-webkit-search-results-button, .input__native-ctrl.sc-nano-input::-webkit-search-results-decoration {\n appearance: none;\n}\n.input__native-ctrl.sc-nano-input::-webkit-calendar-picker-indicator {\n display: none;\n}\n.input__native-ctrl.sc-nano-input::-webkit-datetime-edit {\n display: block;\n padding: 0;\n}\n.input__native-ctrl.sc-nano-input:invalid {\n box-shadow: none;\n}\n.input__native-ctrl.sc-nano-input::-ms-clear, .input__native-ctrl.sc-nano-input::-ms-reveal {\n display: none;\n}\n.input__native-ctrl.input__resizable.sc-nano-input {\n resize: vertical;\n overflow: auto;\n}\n.form-ctrl__textarea.sc-nano-input .input__native-ctrl.sc-nano-input {\n line-height: 1.5em;\n padding-block: calc(var(--padding-top) - 3px) 0.5em;\n white-space: pre-wrap;\n}\n.form-ctrl__textarea.sc-nano-input .input__native-ctrl.sc-nano-input::placeholder {\n line-height: 1.5em;\n}\n.has-float-label.sc-nano-input .form-ctrl__textarea.sc-nano-input .input__native-ctrl.sc-nano-input {\n padding-block-start: 1.75em;\n}\n[readonly].sc-nano-input-h:not([readonly=false]) .input__native-ctrl.sc-nano-input {\n -webkit-user-select: none;\n user-select: none;\n}";
17041
17041
 
17042
- let inputIds = 0;
17042
+ let inputIds$1 = 0;
17043
17043
  /**
17044
17044
  * Inputs collect text data from the user.
17045
17045
  *
@@ -17057,7 +17057,7 @@ let inputIds = 0;
17057
17057
  */
17058
17058
  class Input {
17059
17059
  nativeInput;
17060
- inputId = `nano-input-${inputIds++}`;
17060
+ inputId = `nano-input-${inputIds$1++}`;
17061
17061
  didBlurAfterEdit = false;
17062
17062
  rtl = false;
17063
17063
  mo;
@@ -17723,6 +17723,741 @@ class Input {
17723
17723
  }; }
17724
17724
  }
17725
17725
 
17726
+ const inputOtpCss = ".sc-nano-input-otp-h,*.sc-nano-input-otp,*.sc-nano-input-otp::before,*.sc-nano-input-otp::after{box-sizing:border-box}[hidden].sc-nano-input-otp{display:none !important}@media (prefers-reduced-motion: reduce){.sc-nano-input-otp-h,*.sc-nano-input-otp,*.sc-nano-input-otp::before,*.sc-nano-input-otp::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}}.sc-nano-input-otp-h,*.sc-nano-input-otp,*.sc-nano-input-otp::before,*.sc-nano-input-otp::after{box-sizing:border-box}[hidden].sc-nano-input-otp{display:none !important}@media (prefers-reduced-motion: reduce){.sc-nano-input-otp-h,*.sc-nano-input-otp,*.sc-nano-input-otp::before,*.sc-nano-input-otp::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}}.sc-nano-input-otp-h{--margin-top:0;--margin-end:0;--margin-bottom:0;--margin-start:0;--padding-top:var(--nano-spacing-md);--padding-end:0;--padding-bottom:var(--nano-spacing-xl);--padding-start:0;--color:initial;--min-width:40px;--width:40px;--height:50px;--gap:8px;--separator-width:7px;--separator-height:1px;--separator-border-radius:0;--separator-color:var(--nano-color-primary-1000);--highlight-color-valid:var(--nano-color-success-1100);--highlight-color-invalid:var(--nano-color-warning-1100);--border-radius:8px;--border-color:var(--nano-color-neutral-700);--border-width:1px;display:block;position:relative}.input-otp-group.sc-nano-input-otp{margin:var(--margin-top) var(--margin-end) var(--margin-bottom) var(--margin-start);padding:var(--padding-top) var(--padding-end) var(--padding-bottom) var(--padding-start);display:flex;align-items:center;justify-content:center;gap:var(--gap)}.native-wrapper.sc-nano-input-otp{display:flex;align-items:center;justify-content:center;min-inline-size:var(--min-width)}.native-input.sc-nano-input-otp{border-radius:var(--border-radius);inline-size:var(--width);min-inline-size:inherit;block-size:var(--height);border-width:var(--border-width);border-style:solid;border-color:var(--border-color);background:var(--background);color:var(--color);font-size:inherit;text-align:center;appearance:none}.input-otp-description.sc-nano-input-otp{color:currentcolor;font-size:var(--nano-font-size-xs);line-height:var(--nano-line-height-normal);text-align:center;position:relative;inset-inline-start:-24px}.input-otp-description-hidden.sc-nano-input-otp{display:none}.input-otp-separator.sc-nano-input-otp{border-radius:var(--separator-border-radius);flex-shrink:0;inline-size:var(--separator-width);block-size:var(--separator-height);background:var(--separator-color)}.input-otp-disabled.sc-nano-input-otp-h{--color:var(--nano-color-neutral-700);opacity:0.5}.input-otp-disabled.sc-nano-input-otp-h,.input-otp-disabled.sc-nano-input-otp-h .native-input.sc-nano-input-otp:disabled{cursor:not-allowed}.has-focus.sc-nano-input-otp-h .native-input.sc-nano-input-otp:focus{outline:var(--nano-focus-ring)}.nano-invalid.sc-nano-input-otp-h .native-input.sc-nano-input-otp{border-color:var(--highlight-color-invalid)}.nano-valid.sc-nano-input-otp-h .native-input.sc-nano-input-otp{border-color:var(--highlight-color-valid)}.input-otp-icon.sc-nano-input-otp{inline-size:24px;block-size:24px;display:flex;align-items:center}.input-otp-icon--valid.sc-nano-input-otp{color:var(--nano-color-success-1100)}.input-otp-icon--invalid.sc-nano-input-otp{color:var(--nano-color-warning-1100)}";
17727
+
17728
+ /**
17729
+ * A component for entering one-time passwords (OTP) with multiple input fields.
17730
+ *
17731
+ * @version 8.7.2
17732
+ * @status new
17733
+ *
17734
+ * @slot - The default slot for the input description.
17735
+ * @slot validity-icon - A slot for a custom validity icon. If not provided, a default icon will be used.
17736
+ */
17737
+ class InputOTP {
17738
+ constructor(hostRef) {
17739
+ registerInstance(this, hostRef);
17740
+ this.nanoInput = createEvent(this, "nanoInput", 7);
17741
+ this.nanoChange = createEvent(this, "nanoChange", 7);
17742
+ this.nanoComplete = createEvent(this, "nanoComplete", 7);
17743
+ this.nanoBlur = createEvent(this, "nanoBlur", 7);
17744
+ this.nanoFocus = createEvent(this, "nanoFocus", 7);
17745
+ }
17746
+ inputRefs = [];
17747
+ inputId = `nano-input-otp-${inputIds++}`;
17748
+ /**
17749
+ * Stores the initial value of the input when it receives focus.
17750
+ * Used to determine if the value changed during the focus session
17751
+ * to avoid emitting unnecessary change events on blur.
17752
+ */
17753
+ focusedValue;
17754
+ /**
17755
+ * Tracks whether the user is navigating through input boxes using keyboard navigation
17756
+ * (arrow keys, tab) versus mouse clicks. This is used to determine the appropriate
17757
+ * focus behavior when an input box is focused.
17758
+ */
17759
+ isKeyboardNavigation = false;
17760
+ get el() { return getElement(this); }
17761
+ inputValues = [];
17762
+ hasFocus = false;
17763
+ previousInputValues = [];
17764
+ invalid = false;
17765
+ valid = false;
17766
+ /**
17767
+ * If `true`, the user cannot interact with the input.
17768
+ */
17769
+ disabled = false;
17770
+ /**
17771
+ * A hint to the browser for which keyboard to display.
17772
+ * Possible values: `"none"`, `"text"`, `"tel"`, `"url"`,
17773
+ * `"email"`, `"numeric"`, `"decimal"`, and `"search"`.
17774
+ *
17775
+ * For numbers (type="number"): "numeric"
17776
+ * For text (type="text"): "text"
17777
+ */
17778
+ inputmode;
17779
+ /**
17780
+ * The number of input boxes to display.
17781
+ */
17782
+ length = 6;
17783
+ /**
17784
+ * A regex pattern string for allowed characters. Defaults based on type.
17785
+ *
17786
+ * For numbers (`type="number"`): `"[\p{N}]"`
17787
+ * For text (`type="text"`): `"[\p{L}\p{N}]"`
17788
+ */
17789
+ pattern;
17790
+ /**
17791
+ * If `true`, the user cannot modify the value.
17792
+ */
17793
+ readonly = false;
17794
+ /**
17795
+ * The type of input allowed in the input boxes.
17796
+ */
17797
+ type = 'number';
17798
+ /**
17799
+ * The value of the input group.
17800
+ */
17801
+ value = '';
17802
+ /**
17803
+ * If `true`, allows the input to be completely filled with invalid values.
17804
+ * By default, if any input box contains an invalid value, the entire input group
17805
+ * is marked as invalid.
17806
+ * Default is `false`.
17807
+ */
17808
+ allowInvalid = false;
17809
+ /**
17810
+ * If `true`, shows a validity icon when all input boxes are filled.
17811
+ * A check icon is shown if all values are valid, and an X icon is shown if any value is invalid.
17812
+ * This does not affect the `invalid` or `valid` states of the input group.
17813
+ * Default is `false`.
17814
+ * */
17815
+ showValidity = false;
17816
+ /**
17817
+ * The `nanoInput` event is fired each time the user modifies the input's value.
17818
+ * Unlike the `nanoChange` event, the `nanoInput` event is fired for each alteration
17819
+ * to the input's value. This typically happens for each keystroke as the user types.
17820
+ *
17821
+ * For elements that accept text input (`type=text`, `type=tel`, etc.), the interface
17822
+ * is [`InputEvent`](https://developer.mozilla.org/en-US/docs/Web/API/InputEvent); for others,
17823
+ * the interface is [`Event`](https://developer.mozilla.org/en-US/docs/Web/API/Event). If
17824
+ * the input is cleared on edit, the type is `null`.
17825
+ */
17826
+ nanoInput;
17827
+ /**
17828
+ * The `nanoChange` event is fired when the user modifies the input's value.
17829
+ * Unlike the `nanoInput` event, the `nanoChange` event is only fired when changes
17830
+ * are committed, not as the user types.
17831
+ *
17832
+ * The `nanoChange` event fires when the `<nano-input-otp>` component loses
17833
+ * focus after its value has changed.
17834
+ *
17835
+ * This event will not emit when programmatically setting the `value` property.
17836
+ */
17837
+ nanoChange;
17838
+ /**
17839
+ * Emitted when all input boxes have been filled with valid values.
17840
+ */
17841
+ nanoComplete;
17842
+ /**
17843
+ * Emitted when the input group loses focus.
17844
+ */
17845
+ nanoBlur;
17846
+ /**
17847
+ * Emitted when the input group has focus.
17848
+ */
17849
+ nanoFocus;
17850
+ /**
17851
+ * Sets focus to an input box.
17852
+ * @param index - The index of the input box to focus (0-based).
17853
+ * If provided and the input box has a value, the input box at that index will be focused.
17854
+ * Otherwise, the first empty input box or the last input if all are filled will be focused.
17855
+ */
17856
+ async setFocus(index) {
17857
+ if (typeof index === 'number') {
17858
+ const validIndex = Math.max(0, Math.min(index, this.length - 1));
17859
+ this.inputRefs[validIndex]?.focus();
17860
+ }
17861
+ else {
17862
+ const tabbableIndex = this.getTabbableIndex();
17863
+ this.inputRefs[tabbableIndex]?.focus();
17864
+ }
17865
+ }
17866
+ valueChanged() {
17867
+ this.initializeValues();
17868
+ this.updateTabIndexes();
17869
+ this.computeValidity();
17870
+ }
17871
+ componentWillLoad() {
17872
+ this.initializeValues();
17873
+ this.computeValidity();
17874
+ }
17875
+ componentDidLoad() {
17876
+ this.updateTabIndexes();
17877
+ }
17878
+ /**
17879
+ * Get the regex pattern for allowed characters.
17880
+ * If a pattern is provided, use it to create a regex pattern
17881
+ * Otherwise, use the default regex pattern based on type
17882
+ */
17883
+ get validKeyPattern() {
17884
+ return new RegExp(`^${this.getPattern()}$`, 'u');
17885
+ }
17886
+ get specialCharsPattern() {
17887
+ return new RegExp(`^[\\p{S}\\p{P}]$`, 'u');
17888
+ }
17889
+ /**
17890
+ * Gets the string pattern to pass to the input element
17891
+ * and use in the regex for allowed characters.
17892
+ * @returns {string} The regex pattern string for allowed characters.
17893
+ */
17894
+ getPattern() {
17895
+ const { pattern, type } = this;
17896
+ if (pattern) {
17897
+ return pattern;
17898
+ }
17899
+ return type === 'number' ? '[\\p{N}]' : '[\\p{L}\\p{N}]';
17900
+ }
17901
+ /**
17902
+ * Get the default value for inputmode.
17903
+ * If inputmode is provided, use it.
17904
+ * Otherwise, use the default inputmode based on type
17905
+ * @returns {string} The inputmode to use for the input boxes.
17906
+ */
17907
+ getInputmode() {
17908
+ const { inputmode } = this;
17909
+ if (inputmode) {
17910
+ return inputmode;
17911
+ }
17912
+ if (this.type == 'number') {
17913
+ return 'numeric';
17914
+ }
17915
+ else {
17916
+ return 'text';
17917
+ }
17918
+ }
17919
+ /**
17920
+ * Initializes the input values array based on the current value prop.
17921
+ * This splits the value into individual characters and validates them against
17922
+ * the allowed pattern. The values are then used as the values in the native
17923
+ * input boxes and the value of the input group is updated.
17924
+ */
17925
+ initializeValues() {
17926
+ // Clear all input values
17927
+ this.inputValues = Array(this.length).fill('');
17928
+ // If the value is null, undefined, or an empty string, return
17929
+ if (this.value == null || String(this.value).length === 0) {
17930
+ return;
17931
+ }
17932
+ // Split the value into individual characters and validate
17933
+ // them against the allowed pattern if invalid characters are allowed, else just put them in
17934
+ const chars = String(this.value).split('').slice(0, this.length);
17935
+ chars.forEach((char, index) => {
17936
+ if (this.allowInvalid && !this.specialCharsPattern.test(char)) {
17937
+ this.inputValues[index] = char;
17938
+ }
17939
+ else if (this.validKeyPattern.test(char)) {
17940
+ this.inputValues[index] = char;
17941
+ }
17942
+ });
17943
+ // Update the value without emitting events
17944
+ this.value = this.inputValues.join('');
17945
+ this.previousInputValues = [...this.inputValues];
17946
+ }
17947
+ /**
17948
+ * Returns `true` if the document or host element
17949
+ * has a `dir` set to `rtl`. The host value will always
17950
+ * take priority over the root document value.
17951
+ * @returns {boolean} True if RTL direction is set, false otherwise.
17952
+ */
17953
+ isRTL = (hostEl) => {
17954
+ if (hostEl) {
17955
+ if (hostEl.dir !== '') {
17956
+ return hostEl.dir.toLowerCase() === 'rtl';
17957
+ }
17958
+ }
17959
+ return document?.dir.toLowerCase() === 'rtl';
17960
+ };
17961
+ /**
17962
+ * Updates the value of the input group.
17963
+ * This updates the value of the input group and emits an `nanoChange` event.
17964
+ * If all of the input boxes are filled, it emits an `nanoComplete` event.
17965
+ */
17966
+ updateValue(event) {
17967
+ const { inputValues, length } = this;
17968
+ const newValue = this.getValidChars(inputValues.join('')).join('');
17969
+ this.value = newValue;
17970
+ this.computeValidity();
17971
+ this.emitNanoInput(event);
17972
+ if (newValue.length === length) {
17973
+ this.nanoComplete.emit({ value: newValue, valid: this.valid });
17974
+ }
17975
+ }
17976
+ /**
17977
+ * Emits an `nanoChange` event.
17978
+ * This API should be called for user committed changes.
17979
+ * This API should not be used for external value changes.
17980
+ */
17981
+ emitNanoChange(event) {
17982
+ const { value } = this;
17983
+ // Checks for both null and undefined values
17984
+ const newValue = value == null ? value : value.toString();
17985
+ this.computeValidity();
17986
+ this.nanoChange.emit({
17987
+ value: newValue?.toString(),
17988
+ event,
17989
+ valid: this.valid,
17990
+ });
17991
+ }
17992
+ /**
17993
+ * Emits an `nanoInput` event.
17994
+ * This is used to emit the input value when the user types,
17995
+ * backspaces, or pastes.
17996
+ */
17997
+ emitNanoInput(event) {
17998
+ const { value } = this;
17999
+ // Checks for both null and undefined values
18000
+ const newValue = value == null ? value : value.toString();
18001
+ this.computeValidity();
18002
+ this.nanoInput.emit({
18003
+ value: newValue?.toString(),
18004
+ event,
18005
+ valid: this.valid,
18006
+ });
18007
+ }
18008
+ /**
18009
+ * Handles the focus behavior for the input OTP component.
18010
+ *
18011
+ * Focus behavior:
18012
+ * 1. Keyboard navigation: Allow normal focus movement
18013
+ * 2. Mouse click:
18014
+ * - If clicked box has value: Focus that box
18015
+ * - If clicked box is empty: Focus first empty box
18016
+ *
18017
+ * Emits the `nanoFocus` event when the input group gains focus.
18018
+ * @returns {(event: FocusEvent) => void} Event handler for focus events.
18019
+ */
18020
+ onFocus = (index) => (event) => {
18021
+ const { inputRefs } = this;
18022
+ // Only emit nanoFocus and set the focusedValue when the
18023
+ // component first gains focus
18024
+ if (!this.hasFocus) {
18025
+ this.nanoFocus.emit(event);
18026
+ this.focusedValue = this.value;
18027
+ }
18028
+ this.hasFocus = true;
18029
+ let finalIndex = index;
18030
+ if (!this.isKeyboardNavigation) {
18031
+ // If the clicked box has a value, focus it
18032
+ // Otherwise focus the first empty box
18033
+ const targetIndex = this.inputValues[index]
18034
+ ? index
18035
+ : this.getFirstEmptyIndex();
18036
+ finalIndex = targetIndex === -1 ? this.length - 1 : targetIndex;
18037
+ // Focus the target box
18038
+ this.inputRefs[finalIndex]?.focus();
18039
+ }
18040
+ // Update tabIndexes to match the focused box
18041
+ inputRefs.forEach((input, i) => {
18042
+ input.tabIndex = i === finalIndex ? 0 : -1;
18043
+ });
18044
+ // Reset the keyboard navigation flag
18045
+ this.isKeyboardNavigation = false;
18046
+ };
18047
+ /**
18048
+ * Handles the blur behavior for the input OTP component.
18049
+ * Emits the `nanoBlur` event when the input group loses focus.
18050
+ */
18051
+ onBlur = (event) => {
18052
+ const { inputRefs } = this;
18053
+ const relatedTarget = event.relatedTarget;
18054
+ // Do not emit blur if we're moving to another input box in the same component
18055
+ const isInternalFocus = relatedTarget != null &&
18056
+ inputRefs.includes(relatedTarget);
18057
+ if (!isInternalFocus) {
18058
+ this.hasFocus = false;
18059
+ // Reset tabIndexes when focus leaves the component
18060
+ this.updateTabIndexes();
18061
+ // Always emit nanoBlur when focus leaves the component
18062
+ this.nanoBlur.emit(event);
18063
+ // Only emit nanoChange if the value has actually changed
18064
+ if (this.focusedValue !== this.value) {
18065
+ this.emitNanoChange(event);
18066
+ }
18067
+ }
18068
+ };
18069
+ /**
18070
+ * Focuses the next input box.
18071
+ */
18072
+ focusNext(currentIndex) {
18073
+ const { inputRefs, length } = this;
18074
+ if (currentIndex < length - 1) {
18075
+ inputRefs[currentIndex + 1]?.focus();
18076
+ }
18077
+ }
18078
+ /**
18079
+ * Focuses the previous input box.
18080
+ */
18081
+ focusPrevious(currentIndex) {
18082
+ const { inputRefs } = this;
18083
+ if (currentIndex > 0) {
18084
+ inputRefs[currentIndex - 1]?.focus();
18085
+ }
18086
+ }
18087
+ /**
18088
+ * Searches through the input values and returns the index
18089
+ * of the first empty input.
18090
+ * Returns -1 if all inputs are filled.
18091
+ * @returns {number} The index of the first empty input, or -1 if all are filled.
18092
+ */
18093
+ getFirstEmptyIndex() {
18094
+ const { inputValues, length } = this;
18095
+ // Create an array of the same length as the input OTP
18096
+ // and fill it with the input values
18097
+ const values = Array.from({ length }, (_, i) => inputValues[i] || '');
18098
+ return values.findIndex((value) => !value || value === '') ?? -1;
18099
+ }
18100
+ /**
18101
+ * Returns the index of the input that should be tabbed to.
18102
+ * If all inputs are filled, returns the last input's index.
18103
+ * Otherwise, returns the index of the first empty input.
18104
+ * @returns {number} The index to tab to.
18105
+ */
18106
+ getTabbableIndex() {
18107
+ const { length } = this;
18108
+ const firstEmptyIndex = this.getFirstEmptyIndex();
18109
+ return firstEmptyIndex === -1 ? length - 1 : firstEmptyIndex;
18110
+ }
18111
+ /**
18112
+ * Updates the tabIndexes for the input boxes.
18113
+ * This is used to ensure that the correct input is
18114
+ * focused when the user navigates using the tab key.
18115
+ */
18116
+ updateTabIndexes() {
18117
+ const { inputRefs, inputValues, length } = this;
18118
+ // Find first empty index after any filled boxes
18119
+ let firstEmptyIndex = -1;
18120
+ for (let i = 0; i < length; i++) {
18121
+ if (!inputValues[i] || inputValues[i] === '') {
18122
+ firstEmptyIndex = i;
18123
+ break;
18124
+ }
18125
+ }
18126
+ // Update tabIndex and aria-hidden for all inputs
18127
+ inputRefs.forEach((input, index) => {
18128
+ const shouldBeTabbable = firstEmptyIndex === -1
18129
+ ? index === length - 1
18130
+ : firstEmptyIndex === index;
18131
+ input.tabIndex = shouldBeTabbable ? 0 : -1;
18132
+ // If the input is empty and not the first empty input,
18133
+ // it should be hidden from screen readers.
18134
+ const isEmpty = !inputValues[index] || inputValues[index] === '';
18135
+ input.setAttribute('aria-hidden', isEmpty && !shouldBeTabbable ? 'true' : 'false');
18136
+ });
18137
+ }
18138
+ /**
18139
+ * Handles keyboard navigation for the OTP component.
18140
+ *
18141
+ * Navigation:
18142
+ * - Backspace: Clears current input and moves to previous box if empty
18143
+ * - Arrow Left/Right: Moves focus between input boxes
18144
+ * - Tab: Allows normal tab navigation between components
18145
+ * @returns {(event: KeyboardEvent) => void} Event handler for keydown events.
18146
+ */
18147
+ onKeyDown = (index) => (event) => {
18148
+ const { length } = this;
18149
+ const rtl = this.isRTL(this.el);
18150
+ const input = event.target;
18151
+ // Meta shortcuts are used to copy, paste, and select text
18152
+ // We don't want to handle these keys here
18153
+ const metaShortcuts = ['a', 'c', 'v', 'x', 'r', 'z', 'y'];
18154
+ const isTextSelection = input.selectionStart !== input.selectionEnd;
18155
+ // Return if the key is a meta shortcut or the input value
18156
+ // text is selected and let the onPaste / onInput handler manage it
18157
+ if (isTextSelection ||
18158
+ ((event.metaKey || event.ctrlKey) &&
18159
+ metaShortcuts.includes(event.key.toLowerCase()))) {
18160
+ return;
18161
+ }
18162
+ if (event.key === 'Backspace') {
18163
+ if (this.inputValues[index]) {
18164
+ // Shift all values to the right of the current index left by one
18165
+ for (let i = index; i < length - 1; i++) {
18166
+ this.inputValues[i] = this.inputValues[i + 1];
18167
+ }
18168
+ // Clear the last box
18169
+ this.inputValues[length - 1] = '';
18170
+ // Update all inputRefs to match inputValues
18171
+ for (let i = 0; i < length; i++) {
18172
+ this.inputRefs[i].value = this.inputValues[i] || '';
18173
+ }
18174
+ this.updateValue(event);
18175
+ event.preventDefault();
18176
+ }
18177
+ else if (!this.inputValues[index] && index > 0) {
18178
+ // If current input is empty, move to previous input
18179
+ this.focusPrevious(index);
18180
+ }
18181
+ }
18182
+ else if (event.key === 'ArrowLeft' || event.key === 'ArrowRight') {
18183
+ this.isKeyboardNavigation = true;
18184
+ event.preventDefault();
18185
+ const isLeft = event.key === 'ArrowLeft';
18186
+ const shouldMoveNext = (isLeft && rtl) || (!isLeft && !rtl);
18187
+ // Only allow moving to the next input if the current has a value
18188
+ if (shouldMoveNext) {
18189
+ if (this.inputValues[index] && index < length - 1) {
18190
+ this.focusNext(index);
18191
+ }
18192
+ }
18193
+ else {
18194
+ this.focusPrevious(index);
18195
+ }
18196
+ }
18197
+ else if (event.key === 'Tab') {
18198
+ this.isKeyboardNavigation = true;
18199
+ // Let all tab events proceed normally
18200
+ return;
18201
+ }
18202
+ };
18203
+ /**
18204
+ * Processes all input scenarios for each input box.
18205
+ *
18206
+ * This function manages:
18207
+ * 1. Autofill handling
18208
+ * 2. Input validation
18209
+ * 3. Full selection replacement or typing in an empty box
18210
+ * 4. Inserting in the middle with available space (shifting)
18211
+ * 5. Single character replacement
18212
+ * @returns {(event: InputEvent) => void} Event handler for input events.
18213
+ */
18214
+ onInput = (index) => (event) => {
18215
+ const { length, validKeyPattern, allowInvalid } = this;
18216
+ const input = event.target;
18217
+ const value = input.value;
18218
+ const previousValue = this.previousInputValues[index] || '';
18219
+ // 1. Autofill handling
18220
+ // If the length of the value increases by more than 1 from the previous
18221
+ // value, treat this as autofill. This is to prevent the case where the
18222
+ // user is typing a single character into an input box containing a value
18223
+ // as that will trigger this function with a value length of 2 characters.
18224
+ const isAutofill = value.length - previousValue.length > 1;
18225
+ if (isAutofill) {
18226
+ // Distribute valid characters across input boxes
18227
+ const validChars = this.getValidChars(value);
18228
+ // If there are no valid characters coming from the
18229
+ // autofill, all input refs have to be cleared after the
18230
+ // browser has finished the autofill behavior
18231
+ if (validChars.length === 0) {
18232
+ requestAnimationFrame(() => {
18233
+ this.inputRefs.forEach((input) => {
18234
+ input.value = '';
18235
+ });
18236
+ });
18237
+ }
18238
+ for (let i = 0; i < length; i++) {
18239
+ this.inputValues[i] = validChars[i] || '';
18240
+ this.inputRefs[i].value = validChars[i] || '';
18241
+ }
18242
+ this.updateValue(event);
18243
+ // Focus the first empty input box or the last input box if all boxes
18244
+ // are filled after a small delay to ensure the input boxes have been
18245
+ // updated before moving the focus
18246
+ setTimeout(() => {
18247
+ const nextIndex = validChars.length < length ? validChars.length : length - 1;
18248
+ this.inputRefs[nextIndex]?.focus();
18249
+ }, 20);
18250
+ this.previousInputValues = [...this.inputValues];
18251
+ return;
18252
+ }
18253
+ // 2. Input validation
18254
+ // If the character entered is invalid (does not match the pattern),
18255
+ // restore the previous value and exit
18256
+ if ((!allowInvalid &&
18257
+ value.length > 0 &&
18258
+ !validKeyPattern.test(value[value.length - 1])) ||
18259
+ (allowInvalid && this.specialCharsPattern.test(value[value.length - 1]))) {
18260
+ input.value = this.inputValues[index] || '';
18261
+ this.previousInputValues = [...this.inputValues];
18262
+ return;
18263
+ }
18264
+ // 3. Full selection replacement or typing in an empty box
18265
+ // If the user selects all text in the input box and types, or if the
18266
+ // input box is empty, replace only this input box. If the box is empty,
18267
+ // move to the next box, otherwise stay focused on this box.
18268
+ const isAllSelected = input.selectionStart === 0 && input.selectionEnd === value.length;
18269
+ const isEmpty = !this.inputValues[index];
18270
+ if (isAllSelected || isEmpty) {
18271
+ this.inputValues[index] = value;
18272
+ input.value = value;
18273
+ this.updateValue(event);
18274
+ this.focusNext(index);
18275
+ this.previousInputValues = [...this.inputValues];
18276
+ return;
18277
+ }
18278
+ // 4. Inserting in the middle with available space (shifting)
18279
+ // If typing in a filled input box and there are empty boxes at the end,
18280
+ // shift all values starting at the current box to the right, and insert
18281
+ // the new character at the current box.
18282
+ const hasAvailableBoxAtEnd = this.inputValues[this.inputValues.length - 1] === '';
18283
+ if (this.inputValues[index] && hasAvailableBoxAtEnd && value.length === 2) {
18284
+ // Get the inserted character (from event or by diffing value/previousValue)
18285
+ let newChar = event.data;
18286
+ if (!newChar) {
18287
+ newChar =
18288
+ value.split('').find((c, i) => c !== previousValue[i]) ||
18289
+ value[value.length - 1];
18290
+ }
18291
+ // Validate the new character before shifting
18292
+ if (!allowInvalid && !validKeyPattern.test(newChar)) {
18293
+ input.value = this.inputValues[index] || '';
18294
+ this.previousInputValues = [...this.inputValues];
18295
+ return;
18296
+ }
18297
+ // Shift values right from the end to the insertion point
18298
+ for (let i = this.inputValues.length - 1; i > index; i--) {
18299
+ this.inputValues[i] = this.inputValues[i - 1];
18300
+ this.inputRefs[i].value = this.inputValues[i] || '';
18301
+ }
18302
+ this.inputValues[index] = newChar;
18303
+ this.inputRefs[index].value = newChar;
18304
+ this.updateValue(event);
18305
+ this.previousInputValues = [...this.inputValues];
18306
+ return;
18307
+ }
18308
+ // 5. Single character replacement
18309
+ // Handles replacing a single character in a box containing a value based
18310
+ // on the cursor position. We need the cursor position to determine which
18311
+ // character was the last character typed. For example, if the user types "2"
18312
+ // in an input box with the cursor at the beginning of the value of "6",
18313
+ // the value will be "26", but we want to grab the "2" as the last character
18314
+ // typed.
18315
+ const cursorPos = input.selectionStart ?? value.length;
18316
+ const newCharIndex = cursorPos - 1;
18317
+ const newChar = value[newCharIndex] ?? value[0];
18318
+ // Check if the new character is valid before updating the value
18319
+ if (!allowInvalid && !validKeyPattern.test(newChar)) {
18320
+ input.value = this.inputValues[index] || '';
18321
+ this.previousInputValues = [...this.inputValues];
18322
+ return;
18323
+ }
18324
+ this.inputValues[index] = newChar;
18325
+ input.value = newChar;
18326
+ this.updateValue(event);
18327
+ this.previousInputValues = [...this.inputValues];
18328
+ };
18329
+ /**
18330
+ * Handles pasting text into the input OTP component.
18331
+ * This function prevents the default paste behavior and
18332
+ * validates the pasted text against the allowed pattern.
18333
+ * It then updates the value of the input group and focuses
18334
+ * the next empty input after pasting.
18335
+ */
18336
+ onPaste = (event) => {
18337
+ const { inputRefs, length } = this;
18338
+ event.preventDefault();
18339
+ const pastedText = event.clipboardData?.getData('text');
18340
+ // If there is no pasted text, still emit the input change event
18341
+ // because this is how the native input element behaves
18342
+ // but return early because there is nothing to paste.
18343
+ if (!pastedText) {
18344
+ this.emitNanoInput(event);
18345
+ return;
18346
+ }
18347
+ const validChars = this.getValidChars(pastedText);
18348
+ // Always paste starting at the first box
18349
+ validChars.forEach((char, index) => {
18350
+ if (index < length) {
18351
+ this.inputRefs[index].value = char;
18352
+ this.inputValues[index] = char;
18353
+ }
18354
+ });
18355
+ // Update the value so that all input boxes are updated
18356
+ this.value = validChars.join('');
18357
+ this.updateValue(event);
18358
+ // Focus the next empty input after pasting
18359
+ // If all boxes are filled, focus the last input
18360
+ const nextEmptyIndex = validChars.length < length ? validChars.length : length - 1;
18361
+ inputRefs[nextEmptyIndex]?.focus();
18362
+ };
18363
+ /**
18364
+ * Determines if a separator should be shown for a given index by:
18365
+ * - Checking if the total length is even (no separator for odd lengths)
18366
+ * - If even, showing a separator after the middle index
18367
+ *
18368
+ * @param index - The index to check for a separator.
18369
+ * @returns {boolean} True if a separator should be shown after the given index, false otherwise.
18370
+ */
18371
+ showSeparator(index) {
18372
+ const { length } = this;
18373
+ if (length < 3 || length % 2 !== 0)
18374
+ return false;
18375
+ return index === length / 2 - 1;
18376
+ }
18377
+ /**
18378
+ * Filters the input string to only include valid characters based on the
18379
+ * `validKeyPattern` regex. If `allowInvalid` is true, it will also
18380
+ * exclude special characters. The resulting array is sliced to the
18381
+ * maximum length of the input OTP.
18382
+ * @param str - The input string to filter.
18383
+ * @returns {string[]} An array of valid characters.
18384
+ */
18385
+ getValidChars(str) {
18386
+ const { allowInvalid, validKeyPattern, length } = this;
18387
+ const allChars = str.split('');
18388
+ return (allowInvalid
18389
+ ? allChars.filter((char) => char.trim() !== '' && !this.specialCharsPattern.test(char))
18390
+ : allChars.filter((char) => char.trim() !== '' && validKeyPattern.test(char))).slice(0, length);
18391
+ }
18392
+ /**
18393
+ * Computes the validity of the input group based on the current input values.
18394
+ * Sets the following `invalid` and `valid` states:
18395
+ * - `invalid` is true if `allowInvalid` is true and any input value is invalid.
18396
+ * - `valid` is true if all input boxes are filled with valid values.
18397
+ */
18398
+ computeValidity() {
18399
+ const { inputValues } = this;
18400
+ this.invalid =
18401
+ this.allowInvalid &&
18402
+ this.inputValues.some((val) => val !== '' && !this.validKeyPattern.test(val));
18403
+ this.valid =
18404
+ this.inputValues.length === this.length &&
18405
+ this.inputValues.every((val) => val !== '' && this.validKeyPattern.test(val));
18406
+ inputValues.some((v) => v !== '' && !this.validKeyPattern.test(v));
18407
+ }
18408
+ render() {
18409
+ const { disabled, el, hasFocus, inputId, inputRefs, inputValues, length, readonly, invalid, valid, } = this;
18410
+ const inputmode = this.getInputmode();
18411
+ const tabbableIndex = this.getTabbableIndex();
18412
+ const pattern = this.getPattern();
18413
+ const hasDescription = el.querySelector('.input-otp-description')?.textContent?.trim() !== '';
18414
+ return (hAsync(Host, { key: 'f397a0775d2d961ccc9013206fae72a8d0ad90ae', class: {
18415
+ 'has-focus': hasFocus,
18416
+ 'input-otp-disabled': disabled,
18417
+ 'input-otp-readonly': readonly,
18418
+ 'nano-invalid': invalid,
18419
+ 'nano-valid': valid,
18420
+ } }, hAsync("div", { key: 'add5fe905af87f4c9b87d29c66134ede52ff2b6b', role: "group", "aria-label": "One-time password input", class: "input-otp-group" }, Array.from({ length }).map((_, index) => (hAsync(Fragment, null, hAsync("div", { class: "native-wrapper" }, hAsync("input", { class: "native-input", id: `${inputId}-${index}`, "aria-label": `Input ${index + 1} of ${length}`, type: "text", inputmode: inputmode, pattern: pattern, disabled: disabled, readOnly: readonly, tabIndex: index === tabbableIndex ? 0 : -1, value: inputValues[index] || '', autocomplete: "one-time-code", ref: (el) => (inputRefs[index] = el), onInput: this.onInput(index), onBlur: this.onBlur, onFocus: this.onFocus(index), onKeyDown: this.onKeyDown(index), onPaste: this.onPaste })), this.showSeparator(index) && hAsync("div", { class: "input-otp-separator" })))), this.showValidity && (hAsync("div", { key: '71d38d8f343be559d187f1c5710a64733cf7ceaa', class: {
18421
+ 'input-otp-icon': true,
18422
+ 'input-otp-icon--valid': valid,
18423
+ 'input-otp-icon--invalid': invalid,
18424
+ } }, hAsync("slot", { key: '14529ecc57a6268932bc1485f0a425bb6cb45c51', name: "validity-icon" }, hAsync("nano-icon", { key: '65669a6b4ca76011b721e76fb68b7f9bfeb87092', hidden: !valid, name: "light/circle-check", class: "input-otp-valid-icon", "aria-label": "Valid input" }))))), hAsync("div", { key: '3e677ab8517765759a0cc4a0aa6f0fec58767c90', class: {
18425
+ 'input-otp-description': true,
18426
+ 'input-otp-description-hidden': !hasDescription,
18427
+ 'input-otp-description-inset': this.showValidity,
18428
+ } }, hAsync("slot", { key: 'e875d5c5d7ed8f804b9866618b7ed5e5211dd7b1' }))));
18429
+ }
18430
+ static get watchers() { return {
18431
+ "value": ["valueChanged"]
18432
+ }; }
18433
+ static get style() { return inputOtpCss; }
18434
+ static get cmpMeta() { return {
18435
+ "$flags$": 262,
18436
+ "$tagName$": "nano-input-otp",
18437
+ "$members$": {
18438
+ "disabled": [516],
18439
+ "inputmode": [1],
18440
+ "length": [2],
18441
+ "pattern": [1],
18442
+ "readonly": [516],
18443
+ "type": [1],
18444
+ "value": [1032],
18445
+ "allowInvalid": [516, "allow-invalid"],
18446
+ "showValidity": [516, "show-validity"],
18447
+ "inputValues": [32],
18448
+ "hasFocus": [32],
18449
+ "previousInputValues": [32],
18450
+ "invalid": [32],
18451
+ "valid": [32],
18452
+ "setFocus": [64]
18453
+ },
18454
+ "$listeners$": undefined,
18455
+ "$lazyBundleId$": "-",
18456
+ "$attrsToReflect$": [["disabled", "disabled"], ["readonly", "readonly"], ["allowInvalid", "allow-invalid"], ["showValidity", "show-validity"]]
18457
+ }; }
18458
+ }
18459
+ let inputIds = 0;
18460
+
17726
18461
  /**
17727
18462
  * A thin, declarative interface to the [IntersectionObserver API](https://developer.mozilla.org/en-US/docs/Web/API/IntersectionObserver).
17728
18463
  *
@@ -17861,7 +18596,7 @@ class IntersectionObserve {
17861
18596
  this.removeIO();
17862
18597
  }
17863
18598
  render() {
17864
- return (h(Host, { key: 'aadf019427b2d2c3020fd6e667d5932fd14aea45', class: "nano-intersection-observe" }, h("slot", { key: 'eae74417c304de7b8e377229b603d88468a5c7f5', ref: (slot) => (this.defaultSlot = slot), onSlotchange: this.handleSlotChange })));
18599
+ return (h(Host, { key: 'c837369d760b533f7bbed5ade5994206923e6ffa', class: "nano-intersection-observe" }, h("slot", { key: 'c12806aaf721afbd10a14a3f6c23bd08217128b6', ref: (slot) => (this.defaultSlot = slot), onSlotchange: this.handleSlotChange })));
17865
18600
  }
17866
18601
  static get watchers() { return {
17867
18602
  "root": ["handleRootChange"],
@@ -18206,7 +18941,7 @@ class MaskedOverflow {
18206
18941
  }
18207
18942
  }
18208
18943
  render() {
18209
- return (h(Host, { key: '49485c7d6a96e8dd122f862abd2bd2f95b2343e7', dir: this.isRtl ? 'rtl' : null, class: "nano-masked-overflow", "has-scroll-controls": this.hasScrollControls }, h("div", { key: 'acd0541992b9dda0c1ab6414e67cd8a71f429918', part: "base", class: {
18944
+ return (h(Host, { key: 'cace0ef58ad901ea08d057420906d95ffa2600dd', dir: this.isRtl ? 'rtl' : null, class: "nano-masked-overflow", "has-scroll-controls": this.hasScrollControls }, h("div", { key: '6133235c4eb2be34c93cb681cd612ae7d227e8eb', part: "base", class: {
18210
18945
  onav: true,
18211
18946
  [`onav--${this.orientation}`]: true,
18212
18947
  'onav--has-scroll-controls': this.hasScrollControls,
@@ -18215,12 +18950,12 @@ class MaskedOverflow {
18215
18950
  'onav--no-transitions': this.instantReCalc,
18216
18951
  'onnav--has-indicator': this.showIndicator,
18217
18952
  'onnav--hide-scrollbars': this.hideScrollbars && this.hideScrollbars !== 'false',
18218
- }, onClick: this.handleClick, onKeyDown: this.handleKeyDown }, h("div", { key: 'ba25b3551a2b6be4906d538cbaabf0ba8cb859f6', class: "onav__nav" }, this.scrollControls && (h("nano-icon-button", { key: '72ca6ae1ef0300fc91a95d347702bac94fec97ac', part: "scroll-button scroll-button-prev", class: {
18953
+ }, onClick: this.handleClick, onKeyDown: this.handleKeyDown }, h("div", { key: '56f5264594f6963dddbdbad7ecd6c25ae4c0732a', class: "onav__nav" }, this.scrollControls && (h("nano-icon-button", { key: 'be07616305b1753d843f346420149055b59f8023', part: "scroll-button scroll-button-prev", class: {
18219
18954
  'onav__scroll-button': true,
18220
18955
  'onav__scroll-button--start': true,
18221
18956
  }, ref: (btn) => (this.startBtn = btn), onClick: () => this.handleBtnClick(false), label: "Click to scroll", iconName: this.orientation === 'horizontal'
18222
18957
  ? 'light/chevron-left'
18223
- : 'light/chevron-up' })), h("div", { key: '34893f5e055e8b44a78cb0706e974ee45261bdb8', part: "scroller", ref: (el) => (this.nav = el), class: "onav__scroller", onScroll: this.handleScroll, tabindex: this.hasScrollControls ? 0 : undefined, role: "region", "aria-label": this.label || undefined }, h("div", { key: '19ea27abc4878c5ab034e8ac0ee7085f19607a92', part: "items", ref: (el) => (this.itemContainer = el), class: "onav__items" }, this.showIndicator && (h("div", { key: '6cfdb83598367d649e6705fe709e89d8a8b505a6', part: "indicator", ref: (el) => (this.activeIndicator = el), class: "onav__active-indicator" })), h("slot", { key: '43f3164d6c962f951ac672f79d48943c44e0514e', onSlotchange: this.slotChangeHandler }))), this.scrollControls && (h("nano-icon-button", { key: 'eaa09e8faa9343fca660d1f2e0a4b5366b7c6668', part: "scroll-button scroll-button-next", class: {
18958
+ : 'light/chevron-up' })), h("div", { key: '33c5125be511e2ed550ea4a4130ada309d6d4884', part: "scroller", ref: (el) => (this.nav = el), class: "onav__scroller", onScroll: this.handleScroll, tabindex: this.hasScrollControls ? 0 : undefined, role: "region", "aria-label": this.label || undefined }, h("div", { key: 'c7e3fa9f1272bcd57694aa7dd433f2da1ca4d4cb', part: "items", ref: (el) => (this.itemContainer = el), class: "onav__items" }, this.showIndicator && (h("div", { key: '5029cad9fb763501e8e670f3347e55e7eafbcb87', part: "indicator", ref: (el) => (this.activeIndicator = el), class: "onav__active-indicator" })), h("slot", { key: '1438ac0d40a0ec2952cf9b66bc2f854d5b96c690', onSlotchange: this.slotChangeHandler }))), this.scrollControls && (h("nano-icon-button", { key: '05dea3796c9d9e758c229f76fcb4dde2bd90fa65', part: "scroll-button scroll-button-next", class: {
18224
18959
  'onav__scroll-button': true,
18225
18960
  'onav__scroll-button--end': true,
18226
18961
  }, ref: (btn) => (this.endBtn = btn), onClick: () => this.handleBtnClick(true), label: "Click to scroll", iconName: this.orientation === 'horizontal'
@@ -18661,14 +19396,14 @@ class MenuDrawer {
18661
19396
  disconnectedCallback() {
18662
19397
  }
18663
19398
  render() {
18664
- return (h(Host, { key: '4ad542c84da0045168bcee1df744cb94c2a1196e', class: {
19399
+ return (h(Host, { key: '48267091ca0646f3a1717e2dc3ab21ab3d4b9b28', class: {
18665
19400
  open: this.open,
18666
19401
  'secondary-open': this.secondaryOpen,
18667
19402
  hide: this.hide,
18668
19403
  loading: this.isLoading,
18669
19404
  'has-global-nav': !!this.globalNav,
18670
19405
  'nano-menu-drawer': true,
18671
- }, dir: this.el.ownerDocument.dir === 'rtl' ? 'rtl' : null }, h("div", { key: 'b00cad9c3696b9c373e8d98fcd1f86c2c7b23aa2', ref: (div) => (this.containerDiv = div), class: "container" }, h("div", { key: 'a7746088c4458802d386f1c3d092e0a386fe4bd6', class: `content-wrap ${this.secondaryOpen ? 'secondary-open' : ''}` }, h("nav", { key: '993f550de47fc9410aa04bf98d9d076a6290637c', ref: (div) => (this.contentDiv = div), class: "content" }, h("div", { key: '3da3d0268df95d3080938e33f6e80d659dce1525', class: "head" }, h("button", { key: 'af104da5e67aaf06194317086daa6a5d4c008b6a', onClick: this.toggle, class: "collapse-btn" }, h("nano-icon", { key: 'b6e85eb6690440da7ccd893ccd9feb082d7a4552', name: "light/arrow-right-to-line" }), h("span", { key: '443c2afa504892d6de2a75a126e09c484540c677', class: "visually-hidden" }, "collapse / expand menu"))), h("slot", { key: '275ab007d04f3bde8269f0b4927aec81d1e47ccd' }), this.slotCtrl.has('foot') && (h("div", { key: 'c0eb043b9447264d48ca65d6e51c986c05ba10eb', class: "foot" }, h("slot", { key: 'bee82590231f9cfffc15c22ba0fafb313298e232', name: "foot" }))))))));
19406
+ }, dir: this.el.ownerDocument.dir === 'rtl' ? 'rtl' : null }, h("div", { key: 'f73a9c15c9760493b38ac5b199f2d374eb99ffd0', ref: (div) => (this.containerDiv = div), class: "container" }, h("div", { key: 'a2a254a08025a5d4f33ecd10fb25ee2bedddc657', class: `content-wrap ${this.secondaryOpen ? 'secondary-open' : ''}` }, h("nav", { key: '4c93989684795be81b332aa12638424493eda51f', ref: (div) => (this.contentDiv = div), class: "content" }, h("div", { key: 'fb7fdba72b7e211dd99020b9a78dde35c11f0c7e', class: "head" }, h("button", { key: '1829973a4d5bb9c4053bd5a5b8d7d24befc02599', onClick: this.toggle, class: "collapse-btn" }, h("nano-icon", { key: '614bca81c5086ed499a62d38540f6c107f5c779e', name: "light/arrow-right-to-line" }), h("span", { key: 'da6cbb5a0c0f0a908afac83b01322bc5bfede0b5', class: "visually-hidden" }, "collapse / expand menu"))), h("slot", { key: 'd3ddb04ad19784a71575ff50c2cbd4410b70dcb6' }), this.slotCtrl.has('foot') && (h("div", { key: '5282ecb332f91aaedf7996f1a86165656187f12a', class: "foot" }, h("slot", { key: 'c0c227384d0ec749a03c1fdfe5764923f08c2405', name: "foot" }))))))));
18672
19407
  }
18673
19408
  static get watchers() { return {
18674
19409
  "open": ["openChange"]
@@ -22994,7 +23729,7 @@ class NanoStepAccordion {
22994
23729
  }
22995
23730
  }
22996
23731
  render() {
22997
- return (h("nano-accordion", { key: 'd92d8997c0486e26c132793db92b12e04d46a384', alwaysOpen: true, onNanoToggle: (event) => this.handleToggle(event) }, this.steps.map((step, index) => (h("nano-details", { open: index === this.activeStep, disabled: !step.enabled, class: {
23732
+ return (h("nano-accordion", { key: '1edc585b390f5dd6c1fe6edaf103e096b8d02d06', alwaysOpen: true, onNanoToggle: (event) => this.handleToggle(event) }, this.steps.map((step, index) => (h("nano-details", { open: index === this.activeStep, disabled: !step.enabled, class: {
22998
23733
  step: true,
22999
23734
  'step--active': index === this.activeStep,
23000
23735
  'step--complete': step.complete,
@@ -23123,10 +23858,10 @@ class NanoStepBreadcrumb {
23123
23858
  };
23124
23859
  render() {
23125
23860
  const Wrapper = this.steps.filter((step) => step.href).length > 0 ? 'nav' : 'div';
23126
- return (h(Host, { key: 'c4d0e767abe4ee65f8e70534844e7ff254455af0' }, h(Wrapper, { key: '6df94c5a9df7ae957b5ff243ecbe78e7c57233b3', class: "step-wrapper" }, h("ul", { key: 'ba1838191a0b888b630bfaba5125ae868f8aab38', class: `step-list desktop ${this.cacheKey}` }, this.steps.map((step, index) => (h("li", { class: "step-item-wrapper", key: index }, h(this.ControlTag, { step: step, index: index }))))), h("div", { key: '64ae2c870494d376f4bb6484e97a5217dc4be311', class: `step-list mobile ${this.cacheKey}` }, h("nano-dropdown", { key: '08d3dc468d594177b922ae91fb1ff02ed79d282c', dialogTitle: "Steps", class: "step-dropdown" }, h("button", { key: '88ef0602628d800a3517da3c06e2eea1dad5a7dd', slot: "trigger", class: "step-trigger" }, h("div", { key: '9d60be986e00fdd6814a910641cf94ef97fb2eed', class: "step-progress-circle", role: "progressbar", "aria-valuenow": "2", "aria-valuemin": "0", "aria-valuemax": "5", style: {
23861
+ return (h(Host, { key: 'e54c227339a1e973cad1889abb1828cef81061a1' }, h(Wrapper, { key: '9a9ef044e63d1cebb713c0e9184ed58ed7865a32', class: "step-wrapper" }, h("ul", { key: 'cf3ef2fa474ae023be0059434fc03f1bfeade40c', class: `step-list desktop ${this.cacheKey}` }, this.steps.map((step, index) => (h("li", { class: "step-item-wrapper", key: index }, h(this.ControlTag, { step: step, index: index }))))), h("div", { key: '18a9e9e00597e8ef15df7134a29dabb5f51fad93', class: `step-list mobile ${this.cacheKey}` }, h("nano-dropdown", { key: '0e174964823bc2c6e1cc0bcd4e1d320bc3e74e11', dialogTitle: "Steps", class: "step-dropdown" }, h("button", { key: '75863494b5e948c53b91f15e083270ac142abe61', slot: "trigger", class: "step-trigger" }, h("div", { key: '093819821dc278086f12d5f8cb008649b43b3230', class: "step-progress-circle", role: "progressbar", "aria-valuenow": "2", "aria-valuemin": "0", "aria-valuemax": "5", style: {
23127
23862
  '--value': '' + (this.activeStep + 1),
23128
23863
  '--max': '' + this.steps.length,
23129
- } }, h("span", { key: '9e6eb88c9fc12f4228f55fe04cb2e1ce9a92e1f2', class: "step-progress-text" }, h("strong", { key: '5e999ae958a2c43f5d8998e9083e91b11ea9041d' }, this.activeStep + 1), " of", ' ', this.steps.length)), h("div", { key: 'ccb66003ef35b256ae8d0d34c8cad7535680d05b', class: "step-trigger-text" }, h("div", { key: '87f8a73802c33c289860b0eb530edae379fa5ebf', class: "step-trigger-now" }, this.steps[this.activeStep | 0]?.title || 'Select a step'), h("div", { key: '9b00c5ae99376028ec077e782f430b0346580119', class: "step-trigger-next" }, this.steps[this.activeStep + 1]?.title || 'Next step')), h("nano-icon", { key: '5073cf36a3a15599df7fa3816a62e72af257ab99', class: "step-trigger-icon", name: "light/chevron-down" })), h("nano-menu", { key: '18f15bb2439661286c019a6f20272db72a6ad1b1' }, this.steps.map((step, index) => (h("nano-nav-item", { class: {
23864
+ } }, h("span", { key: 'da12da205c5e4942dc6b158ab4366a87b3d600c0', class: "step-progress-text" }, h("strong", { key: '15298a28fd78508485b54ed24df255087560e627' }, this.activeStep + 1), " of", ' ', this.steps.length)), h("div", { key: 'a67108bd294391381e5e9fa17e6132844eb510c4', class: "step-trigger-text" }, h("div", { key: '46906878f501008c8ceab76276d4f5b47469d9e3', class: "step-trigger-now" }, this.steps[this.activeStep | 0]?.title || 'Select a step'), h("div", { key: '898e4abb1800652352efe446e45c48d3673a656c', class: "step-trigger-next" }, this.steps[this.activeStep + 1]?.title || 'Next step')), h("nano-icon", { key: 'f972d82aaed693d49536862f45c268646dd8742b', class: "step-trigger-icon", name: "light/chevron-down" })), h("nano-menu", { key: '2b6555a0ef2743486e940d75cb3486110f88cad1' }, this.steps.map((step, index) => (h("nano-nav-item", { class: {
23130
23865
  'step-item-mobile': true,
23131
23866
  'step-item-mobile step-item--active': index === this.activeStep,
23132
23867
  'step-item-mobile step-item--complete': step.complete,
@@ -23213,12 +23948,12 @@ class NanoTab {
23213
23948
  }
23214
23949
  };
23215
23950
  render() {
23216
- return (h(Host, { key: '67fe232bda16bf41bf1268a1891cfeb6483ebd02', id: this.host.id || this.tabId, role: "tab", "aria-disabled": this.disabled ? 'true' : 'false', "aria-selected": this.active ? 'true' : 'false', class: "nano-tab" }, h("div", { key: '6f07d7d5a89071e094fe3deb19e88ec66a524f3d', part: `base${this.active ? ' base--active' : ''}${this.disabled ? ' base--disabled' : ''}${this.closable ? ' base--closable' : ''}`, class: {
23951
+ return (h(Host, { key: 'ad80886d87f28ad3a2ae019f361662f21c6617b3', id: this.host.id || this.tabId, role: "tab", "aria-disabled": this.disabled ? 'true' : 'false', "aria-selected": this.active ? 'true' : 'false', class: "nano-tab" }, h("div", { key: '445b8acdf4a87b4541f8bc1b9354c91bad6d77a4', part: `base${this.active ? ' base--active' : ''}${this.disabled ? ' base--disabled' : ''}${this.closable ? ' base--closable' : ''}`, class: {
23217
23952
  tab: true,
23218
23953
  'tab--active': this.active,
23219
23954
  'tab--disabled': this.disabled,
23220
23955
  'tab--closable': this.closable,
23221
- } }, h("slot", { key: '4c8dce458c8ae3ed526d4aed7332650be891510c', name: "start" }), h("div", { key: 'e71cced02347ffaa432b5711af54666ac0a6cfd6', part: "label", ref: (el) => (this.tab = el), tabindex: this.disabled || !this.active ? '-1' : '0', class: "tab__label" }, h("slot", { key: '382f7f77b009e3a5cf3af3d3b94b02e639bf2934' })), h("slot", { key: '82a2c81ab573d3c78b7d913f4b7ab146e7c6d5b2', name: "end" }), this.closable && !this.disabled && (h("nano-icon-button", { key: '14e812f9acd5e081a1eba5014f6d4fe4b79371e2', label: "Close this tab", iconName: "light/xmark", class: "tab__close-button", onClick: this.handleCloseClick, onKeyDown: this.handleCloseKeydown, part: "close-button" })))));
23956
+ } }, h("slot", { key: 'a72a156f0792fb7943c46d7edc6da51d222f4285', name: "start" }), h("div", { key: 'e7c654c4efe7bafaa41fdbafaae96976f4089f67', part: "label", ref: (el) => (this.tab = el), tabindex: this.disabled || !this.active ? '-1' : '0', class: "tab__label" }, h("slot", { key: '65f9a3b5342dfca0a8e6ec9be289f3ad4bb5da4e' })), h("slot", { key: 'e044937dc98a2650b58f7a792e0e190de80e2d00', name: "end" }), this.closable && !this.disabled && (h("nano-icon-button", { key: 'c7809dea53cb6ca1660f58f06f3a861f18950cba', label: "Close this tab", iconName: "light/xmark", class: "tab__close-button", onClick: this.handleCloseClick, onKeyDown: this.handleCloseKeydown, part: "close-button" })))));
23222
23957
  }
23223
23958
  static get style() { return tabCss; }
23224
23959
  static get cmpMeta() { return {
@@ -23264,10 +23999,10 @@ class NanoTabContent {
23264
23999
  requestAnimationFrame(() => (this.ready = true));
23265
24000
  }
23266
24001
  render() {
23267
- return (h(Host, { key: '7afee777be86f5847c5ac4c8de6babae3199b01d', id: this.host.id || this.tabContentId, style: { display: this.active ? 'block' : 'none' }, role: "tabpanel", "aria-hidden": this.active ? 'false' : 'true', class: {
24002
+ return (h(Host, { key: '3118031c009c947f2a7882a8dd65556b686d1c9d', id: this.host.id || this.tabContentId, style: { display: this.active ? 'block' : 'none' }, role: "tabpanel", "aria-hidden": this.active ? 'false' : 'true', class: {
23268
24003
  ready: this.ready,
23269
24004
  'nano-tab-content': true,
23270
- } }, h("div", { key: 'c316e2c15458eeb9fb6162d81060b81a1132e795', part: "base", class: "nano-tab-content" }, h("slot", { key: '532eedd714e732749cfe9b303b1f4c633e89491c' }))));
24005
+ } }, h("div", { key: 'cab097ece6d3473e5fc425dbde951fcaf399c5ba', part: "base", class: "nano-tab-content" }, h("slot", { key: 'b4ce04af8ea780022c5a9e63a16f1d087432a931' }))));
23271
24006
  }
23272
24007
  static get style() { return tabContentCss; }
23273
24008
  static get cmpMeta() { return {
@@ -23846,10 +24581,10 @@ class NanoTable {
23846
24581
  this.cleanUpObservers();
23847
24582
  }
23848
24583
  render() {
23849
- return (h(Host, { key: 'dfcda7c6604792e025f1ed4997395857ad786be3', class: {
24584
+ return (h(Host, { key: '75c4089a6d670a16eea3fca8d079ac9a827c4cfa', class: {
23850
24585
  'nano-table': true,
23851
24586
  'nano-table--props-ready': this.propsReady,
23852
- } }, this.scrollable && (h("nano-masked-overflow", { key: '2ef0536af50f22134e4c0d295172817287c46196', hideScrollbars: false, scrollControls: false, label: this.caption?.textContent || undefined, class: "nano-table__overflow-container" }, h("div", { key: '1b9ba48be1ccf92ac46f9873ac08b43a51cfcabc', class: "nano-table__overflow" }))), h("slot", { key: 'ab86c4eab83b69cb4ba31b22ae18f9cb0c31033a' })));
24587
+ } }, this.scrollable && (h("nano-masked-overflow", { key: '90a1e07d2daa97047c3be1381717a8ae3b53b5e1', hideScrollbars: false, scrollControls: false, label: this.caption?.textContent || undefined, class: "nano-table__overflow-container" }, h("div", { key: 'badc595c9931fb6198ab38b4e09cdf4201fcc064', class: "nano-table__overflow" }))), h("slot", { key: 'd3fd5902fccc42b3412e9cb1950b054b5a69a525' })));
23853
24588
  }
23854
24589
  static get watchers() { return {
23855
24590
  "compact": ["handleCompactChange"],
@@ -24921,8 +25656,8 @@ let Rating$1 = class Rating {
24921
25656
  this.handleShowHideElements();
24922
25657
  }
24923
25658
  render() {
24924
- return (h(Host, { key: 'cdfbe00c8ce785ad89f711c8488b514dba8f3fb6', class: "nano-more-less" }, h("slot", { key: '8c17f3540c587129feff6905e518e01f4866b90d', onSlotchange: () => this.handleShowHideElements() }), this.children?.length > this.maxToShow && [
24925
- h("div", { key: 'fd937a181108336345a5278b4e2e230feb13f891', style: { display: this.show ? 'none' : 'contents' }, class: "button-wrapper", part: "button-wrapper button-wrapper--less", onClick: (e) => this.handleClick(e) }, h("slot", { key: 'bd7c0630e06de922c8ed48e5efc0db640594c776', name: "less" }, h("button", { key: '8c924f74b1b7939d17a9defd02ccb41ecd403257', part: "button button--less" }, "Show more (+", this.children.length - this.maxToShow, ")"))),
25659
+ return (h(Host, { key: '85aea064a37e2a66a31e8bab208eba423aa32a4e', class: "nano-more-less" }, h("slot", { key: 'c7288c755fa9cb24abb335158fe9ae1e116a012e', onSlotchange: () => this.handleShowHideElements() }), this.children?.length > this.maxToShow && [
25660
+ h("div", { key: 'ff18caab62f14cdff9cc5953cda9d4980e6e4b6a', style: { display: this.show ? 'none' : 'contents' }, class: "button-wrapper", part: "button-wrapper button-wrapper--less", onClick: (e) => this.handleClick(e) }, h("slot", { key: '8a7a856af8fca1221c308c2a0982e09b9c9da74f', name: "less" }, h("button", { key: '33578129514a86169e642f32fb9a66d257412719', part: "button button--less" }, "Show more (+", this.children.length - this.maxToShow, ")"))),
24926
25661
  !this.noHideBtn ? (h("div", { style: { display: this.show ? 'contents' : 'none' }, class: "button-wrapper", part: "button-wrapper button-wrapper--more", onClick: (e) => this.handleClick(e) }, h("slot", { name: "more" }, h("button", { part: "button button--more" }, "Show less (-", this.children.length - this.maxToShow, ")")))) : (''),
24927
25662
  ]));
24928
25663
  }
@@ -25143,20 +25878,20 @@ class Rating {
25143
25878
  else {
25144
25879
  displayValue = this.isHovering ? this.hoverValue : this.value;
25145
25880
  }
25146
- return (h(Host, { key: 'bacb1319a8119e09eb7223396c0fd308d8f1bcf0', class: "nano-rating" }, h("label", { key: 'e96dd3dc5d27aad666c9273fb48a0dde49b05bcd', class: `rating-label${this.hideLabel ? ' visually-hidden' : ''}`, part: "label", htmlFor: this.name }, h("slot", { key: 'a50e1bb855e58080b964cde932b6e850be44cff5', name: "label" }, this.label)), h("input", { key: 'c95ba7bf46db99df309030b4e7c9a006909e47a7', class: "range-input visually-hidden", name: this.name, id: this.name, disabled: this.disabled || this.readonly, required: this.required, value: this.value, onFocus: () => {
25881
+ return (h(Host, { key: 'b28d1a7ff7743338ff5ae18c386e49ee20f8df8e', class: "nano-rating" }, h("label", { key: '6fda8cf5da0b9ed38776ec3a9b93ec4fc02598b0', class: `rating-label${this.hideLabel ? ' visually-hidden' : ''}`, part: "label", htmlFor: this.name }, h("slot", { key: 'e92e2482a6aefd90bd27b5831ec75f0fb12fcd8b', name: "label" }, this.label)), h("input", { key: 'ef40cee201942dc8f0851f2ee4d785d3b1d27936', class: "range-input visually-hidden", name: this.name, id: this.name, disabled: this.disabled || this.readonly, required: this.required, value: this.value, onFocus: () => {
25147
25882
  this.setFocus();
25148
- } }), h("div", { key: 'a04e24da1bf879b551f31b3692e990e912739643', class: "rating-wrap" }, h("div", { key: '2686f949da578a7bcdbd3043f131edccc24f0f30', dir: this.isRtl ? 'rtl' : null, ref: (el) => (this.rating = el), part: "base", class: {
25883
+ } }), h("div", { key: '46c610322bc3b802d822cd22bfdcf3ad32f7e4d2', class: "rating-wrap" }, h("div", { key: 'fd509ff1f80a8172c00f2b320e6f5dbfd1252676', dir: this.isRtl ? 'rtl' : null, ref: (el) => (this.rating = el), part: "base", class: {
25149
25884
  rating: true,
25150
25885
  'rating--readonly': this.readonly,
25151
25886
  'rating--disabled': this.disabled,
25152
- }, "aria-disabled": this.disabled ? 'true' : 'false', "aria-readonly": this.readonly ? 'true' : 'false', "aria-valuenow": this.value, "aria-valuemin": 0, "aria-valuemax": this.max, tabIndex: this.disabled ? -1 : 0, onClick: this.handleClick, onKeyDown: this.handleKeyDown, onMouseEnter: this.handleMouseEnter, onMouseLeave: this.handleMouseLeave, onMouseMove: this.handleMouseMove, onFocus: this.handleFocus, onBlur: this.handleBlur }, h("span", { key: '890e0a8296994061f88cdfa42811ff61d1fbb2b2', class: "rating__symbols rating__symbols--inactive" }, counter.map((index) => (h("span", { class: {
25887
+ }, "aria-disabled": this.disabled ? 'true' : 'false', "aria-readonly": this.readonly ? 'true' : 'false', "aria-valuenow": this.value, "aria-valuemin": 0, "aria-valuemax": this.max, tabIndex: this.disabled ? -1 : 0, onClick: this.handleClick, onKeyDown: this.handleKeyDown, onMouseEnter: this.handleMouseEnter, onMouseLeave: this.handleMouseLeave, onMouseMove: this.handleMouseMove, onFocus: this.handleFocus, onBlur: this.handleBlur }, h("span", { key: 'd03101004803060722fd234f3500a5f7ac6e0603', class: "rating__symbols rating__symbols--inactive" }, counter.map((index) => (h("span", { class: {
25153
25888
  rating__symbol: true,
25154
25889
  'rating__symbol--hover': this.isHovering && Math.ceil(displayValue) === index + 1,
25155
25890
  },
25156
25891
  // Users can click the current value to clear the rating. When this happens, we set this.isHovering to
25157
25892
  // false to prevent the hover state from confusing them as they move the mouse out of the control. This
25158
25893
  // extra mouseenter will reinstate it if they happen to mouse over an adjacent symbol.
25159
- onMouseEnter: this.handleMouseEnter, innerHTML: this.symbol(index + 1) })))), h("span", { key: 'fad1f1de103c1451d848a215c9c7b18084f172ce', ref: (span) => (this.indicator = span), class: "rating__symbols rating__symbols--indicator", style: {
25894
+ onMouseEnter: this.handleMouseEnter, innerHTML: this.symbol(index + 1) })))), h("span", { key: '2e5b35988ef0b699c515fd86a5ab14b3a98f9215', ref: (span) => (this.indicator = span), class: "rating__symbols rating__symbols--indicator", style: {
25160
25895
  clip: this.clip(displayValue),
25161
25896
  } }, counter.map((index) => (h("span", { class: {
25162
25897
  rating__symbol: true,
@@ -25428,13 +26163,13 @@ class ResizeObserve {
25428
26163
  }
25429
26164
  }
25430
26165
  render() {
25431
- return (h(Host, { key: '3d1301e7d8a6c0f96188ea4dadddcc3f71a349cc', class: {
26166
+ return (h(Host, { key: '5db8e84066e7fd3d903f19e2256844331580947a', class: {
25432
26167
  'nano-resize-observe': true,
25433
26168
  'content-fit-x': this.contentFitX,
25434
26169
  'content-fit-y': this.contentFitY,
25435
26170
  'content-nofit-x': this.contentFitX === false,
25436
26171
  'content-nofit-y': this.contentFitY === false,
25437
- } }, h("slot", { key: '363d69b62debe81c7d3d1790d4dead42538f7118' }), !!this.notifyContentFit &&
26172
+ } }, h("slot", { key: 'ee5842c110b25f82eacbb4ba618d33dad345e732' }), !!this.notifyContentFit &&
25438
26173
  (this.contentFitX !== null || this.contentFitY !== null) && [
25439
26174
  this.contentFitX ? (h("slot", { name: "content-fit-x" })) : (h("slot", { name: "content-nofit-x" })),
25440
26175
  this.contentFitY ? (h("slot", { name: "content-fit-y" })) : (h("slot", { name: "content-nofit-y" })),
@@ -26165,30 +26900,30 @@ class Select {
26165
26900
  disabled,
26166
26901
  clearControl: this.clearable,
26167
26902
  }))(this);
26168
- return (h(Host, { key: '0648eef02c3e5fc9891e3aee3baa81eae2fc2b5e', type: this.multiple ? 'select-multiple' : 'select-one', "aria-disabled": this.disabled ? 'true' : null, class: {
26903
+ return (h(Host, { key: 'fff4c3c510b9c343af91cd44cd31a437bbd15a78', type: this.multiple ? 'select-multiple' : 'select-one', "aria-disabled": this.disabled ? 'true' : null, class: {
26169
26904
  'has-value': !!this.value.length || !!this.inputSearchVal.length,
26170
26905
  'has-focus': this.hasFocus,
26171
26906
  'is-invalid': this._invalid === true,
26172
26907
  'is-valid': this._invalid === false,
26173
26908
  'nano-select': true,
26174
- } }, h(FormControlWrap, { key: '36dcb0e4ef701eaf17ddf03f8f64cf83dee35b07', ...wrapOptions, class: {
26909
+ } }, h(FormControlWrap, { key: '57e3eca97027e9195328c5da6e10c46000ffe67e', ...wrapOptions, class: {
26175
26910
  'has-error': !!this.errorMessage &&
26176
26911
  this.showInlineError &&
26177
26912
  this._invalid === true,
26178
26913
  'has-helper': this.hasHelperSlot,
26179
26914
  'is-open': this.hasOpened,
26180
26915
  masked: this.mask,
26181
- } }, h(FormControl, { key: '6adbd4bf79d59de4a8d8f20c6dc287b9f70c9e5c', ...controlOptions, ref: (el) => (this.selectWrap = el), onClearText: this.clearSelectValue, control: this.el, endValueSlot: h("slot", { name: "down-arrow" }, h("nano-icon", { class: "select__down-arrow", name: "light/chevron-down" })), showInlineError: this.showInlineError }, this.multiple && (h("div", { key: 'eaf182a6e691f3490a2e26522be8daef9f3c0e58', class: "select__multi-wrap select" }, this.multipleValues(labelId, moreId, helperEndId))), !this.multiple && [
26182
- this.mask && (h("div", { key: 'd08b3d345fde15bd92a9d3237c9f0265b39a1cbb', class: "select__mask" }, this.getLabel(this.value))),
26183
- h("input", { key: '29eb562d57d5af570132b502652fbf0109563481', ref: (input) => (this.inputCtrl = input), id: this.selectId, class: "select__native-input", "aria-labelledby": labelId + ' ' + moreId + ' ' + helperEndId, disabled: this.disabled, form: this.form, placeholder: this.placeholder, readonly: true, required: this.required, value: this.getLabel(this.value), onFocus: this.onFocus }),
26184
- ])), !this.readonly && !this.disabled && (h("nano-datalist", { key: 'c7135aca51ac7e0b3f23fc63b8e8fef3d5d0d4a8', ref: (el) => (this.datalist = el), selected: this.valArray, type: this.multiple ? 'selectMulti' : 'select', options: this._options.length ? this._options : undefined, onNanoDeselect: (e) => {
26916
+ } }, h(FormControl, { key: 'be1a38b3b662d7cd40ce738ef9185d18dae22318', ...controlOptions, ref: (el) => (this.selectWrap = el), onClearText: this.clearSelectValue, control: this.el, endValueSlot: h("slot", { name: "down-arrow" }, h("nano-icon", { class: "select__down-arrow", name: "light/chevron-down" })), showInlineError: this.showInlineError }, this.multiple && (h("div", { key: '89b7b5b75ef67513c228f230c11122333448408f', class: "select__multi-wrap select" }, this.multipleValues(labelId, moreId, helperEndId))), !this.multiple && [
26917
+ this.mask && (h("div", { key: 'efd35e47435a363be382ceae43d4348479cd50b5', class: "select__mask" }, this.getLabel(this.value))),
26918
+ h("input", { key: '236a63937ee3c981bbc2e4d77d72516f4d614326', ref: (input) => (this.inputCtrl = input), id: this.selectId, class: "select__native-input", "aria-labelledby": labelId + ' ' + moreId + ' ' + helperEndId, disabled: this.disabled, form: this.form, placeholder: this.placeholder, readonly: true, required: this.required, value: this.getLabel(this.value), onFocus: this.onFocus }),
26919
+ ])), !this.readonly && !this.disabled && (h("nano-datalist", { key: 'c0e2707266e76ed2714cbd91727c828e4e0e9861', ref: (el) => (this.datalist = el), selected: this.valArray, type: this.multiple ? 'selectMulti' : 'select', options: this._options.length ? this._options : undefined, onNanoDeselect: (e) => {
26185
26920
  e.preventDefault();
26186
26921
  this.removeValue(e.detail.value);
26187
26922
  }, onNanoOptionsUpdated: this.setOptions, onNanoSelect: this.setValue,
26188
26923
  // @ts-expect-error - this bubbles from the nano-dropdown
26189
26924
  onNanoShow: () => (this.hasOpened = true), onNanoHide: () => (this.hasOpened = false) }, this.allowCustomValues &&
26190
26925
  this.multiple &&
26191
- !!this.inputSearchVal && (h("nano-option", { key: 'c1bfe32d20443e5be164a400e5553e30488f26be', slot: "list-top", value: this.inputSearchVal, selected: false, label: this.inputSearchVal, onNanoSelect: () => this.inputCtrl.focus() }, h("span", { key: 'aad3f8699ac6e9538055437e30d040ba686b0c46', slot: "check-icon" }), "Add '", this.inputSearchVal, "'")), h("slot", { key: 'bbbc2b303f78dcdc9aaf19c78279099b389159c4' }))), h("select", { key: '87e9d612386dc3b0baf0a79b6de750d22043c967', id: this.selectId + '-hidden', class: "select__native-ctrl", ref: (select) => (this.nativeSelect = select), "aria-labelledby": labelId + ' ' + moreId + ' ' + helperEndId, disabled: this.disabled, form: this.form, multiple: this.multiple, name: this.name, required: this.required, onInvalid: this.handleInvalid }, this.allowCustomValues &&
26926
+ !!this.inputSearchVal && (h("nano-option", { key: 'bfc7c0f31d962d89369ff173236bebbca134885d', slot: "list-top", value: this.inputSearchVal, selected: false, label: this.inputSearchVal, onNanoSelect: () => this.inputCtrl.focus() }, h("span", { key: '2f2f299440d4aca0c718308ad819873cf5f71163', slot: "check-icon" }), "Add '", this.inputSearchVal, "'")), h("slot", { key: '5c41abf1e6e6c7b897538beb6b4509ae5f845ce6' }))), h("select", { key: '3443483daf9d524e98cb3614f67a630b349b033f', id: this.selectId + '-hidden', class: "select__native-ctrl", ref: (select) => (this.nativeSelect = select), "aria-labelledby": labelId + ' ' + moreId + ' ' + helperEndId, disabled: this.disabled, form: this.form, multiple: this.multiple, name: this.name, required: this.required, onInvalid: this.handleInvalid }, this.allowCustomValues &&
26192
26927
  this.valArray.map((val) => {
26193
26928
  return (h("option", { value: val, selected: true }, val));
26194
26929
  }), !this.allowCustomValues &&
@@ -26331,7 +27066,7 @@ let Slide$2 = class Slide {
26331
27066
  });
26332
27067
  }
26333
27068
  render() {
26334
- return (h(Host, { key: '3d5f03684b14b0944b06802a26955b035ae20a9f', class: "nano-slide" }, h("slot", { key: '5115d41ae13fb0980ae656c106b9105b5f14703b' })));
27069
+ return (h(Host, { key: '599510bff6daf72dca9b1de41767aea575eae98a', class: "nano-slide" }, h("slot", { key: '911f54eb0ad7ee91d7ea358f2e581d55793416ee' })));
26335
27070
  }
26336
27071
  static get watchers() { return {
26337
27072
  "ready": ["readyChange"]
@@ -29310,15 +30045,15 @@ class Slides {
29310
30045
  this.destroyflickity();
29311
30046
  }
29312
30047
  render() {
29313
- return (h(Host, { key: '905eab94c6853e11f8103ade8a2711515a957a88', class: "nano-slides" }, h("div", { key: 'a6ca3bf953dc8ad8643b5f196bbbb4cad5696739', class: {
30048
+ return (h(Host, { key: 'e259a3a5de2c5dc025ab6dc61c3a41e1f812f077', class: "nano-slides" }, h("div", { key: '74abbe2dd44755ae5e5c5c766e6833c74c152aa8', class: {
29314
30049
  slideshow: true,
29315
30050
  ready: this.ready,
29316
30051
  'not-ready': !this.ready,
29317
- }, part: "base" }, h("div", { key: 'ebf38a42c8c0ee4a192e2c10c7e882f4953cf707', ref: (div) => (this.flickityEl = div), class: {
30052
+ }, part: "base" }, h("div", { key: '1a0a00d3ad6651a06fe46f1beff537f9cd483fc7', ref: (div) => (this.flickityEl = div), class: {
29318
30053
  'flickity-container': true,
29319
30054
  'slides-ready': this.slidesReady,
29320
30055
  'slides-not-ready': !this.slidesReady,
29321
- }, part: "slide-container" }, h("slot", { key: 'ac8e76e6ee701ef38a73a1f753cbf7ad30ef9c59' })), h("div", { key: 'e74cad0bd4ec8e2e15308b26550a697ff3dd4dcb', class: "ui-extras" }, h("slot", { key: '8b7b6cfb6ba0e531a8c7707f5f65cba334e8eba6', name: "ui" })))));
30056
+ }, part: "slide-container" }, h("slot", { key: '7a0edeee40901099cc455337acad6e798041f4f1' })), h("div", { key: 'bef46a7658a4ff89d02a2feb6dbcdd64d8e965f2', class: "ui-extras" }, h("slot", { key: '2f0603645945a8e77de9252036363e770e8e424d', name: "ui" })))));
29322
30057
  }
29323
30058
  static get watchers() { return {
29324
30059
  "options": ["optionsChanged"],
@@ -30096,7 +30831,7 @@ class Sortable {
30096
30831
  }
30097
30832
  }
30098
30833
  render() {
30099
- return (h(Host, { key: 'f9329f87a60f9b77ad917b9bbf0aa526f4779e82', class: "nano-sortable" }, h("div", { key: 'c30a6d47b7a932906b17f0cd0cec80e0c7ea38ef', class: "sortable__live-region", "aria-live": "polite", "aria-relevant": "additions", "aria-atomic": "true", role: "log", part: "announcements" }, this.ariaTextList.map((str) => (h("div", null, str)))), h("slot", { key: 'a377bb437eb590b3f77d10f105b2fa09e0d21cbd' })));
30834
+ return (h(Host, { key: 'db8dbc8b62755164c30650a9485205f8ea2c6107', class: "nano-sortable" }, h("div", { key: '0c4646d0cf095e9970787ae4a5101765f0f5fe4f', class: "sortable__live-region", "aria-live": "polite", "aria-relevant": "additions", "aria-atomic": "true", role: "log", part: "announcements" }, this.ariaTextList.map((str) => (h("div", null, str)))), h("slot", { key: '41e538783cb246a7ada58353374228a833b4fc4a' })));
30100
30835
  }
30101
30836
  static get watchers() { return {
30102
30837
  "itemSelector": ["handleItemSelectorChange"],
@@ -31095,12 +31830,12 @@ class Sticker {
31095
31830
  this.hasBootstrapped = false;
31096
31831
  }
31097
31832
  render() {
31098
- return (h(Host, { key: 'd0e4e1b0cc7c63db0389ee67b999c30347f7e16b', sticky: !this.isRootSticker && !this.stickToEle && this.isSticky, hide: this.hide && this.isStuck, siblings: this.stuckCounter, index: this.stickerIndex, stuck: this.isStuck && this.isSticky, "placed-bottom": this.positions.includes('bottom'), "placed-top": this.positions.includes('top'), "placed-end": this.positions.includes('end'), "placed-start": this.positions.includes('start'), class: "nano-sticker" }, h("div", { key: '6f9852e2cfeb2e203e5dde6f71e7a042a996dd86', class: {
31833
+ return (h(Host, { key: '6626d945b580e7e23d940db522958250e89261ad', sticky: !this.isRootSticker && !this.stickToEle && this.isSticky, hide: this.hide && this.isStuck, siblings: this.stuckCounter, index: this.stickerIndex, stuck: this.isStuck && this.isSticky, "placed-bottom": this.positions.includes('bottom'), "placed-top": this.positions.includes('top'), "placed-end": this.positions.includes('end'), "placed-start": this.positions.includes('start'), class: "nano-sticker" }, h("div", { key: '1e4b7f859218a5ed2256f7f860dcffa4b1b8f5be', class: {
31099
31834
  sticker: true,
31100
31835
  sticky: this.isRootSticker && this.isSticky,
31101
31836
  stuck: this.isStuck && this.isRootSticker && this.isSticky,
31102
31837
  hide: this.isRootSticker && this.hide && this.isStuck,
31103
- }, ref: (div) => (this.sticker = div) }, h("div", { key: '1e54d0ebe57b52c95a64acbb6d46f8c9d9778dd3', class: "sticker-content", ref: (div) => (this.content = div) }, h("slot", { key: 'e8359edd6c73c5006ff1c90a91ecafad07e5c915' })))));
31838
+ }, ref: (div) => (this.sticker = div) }, h("div", { key: '4f7cd61f38b78433296a9708ddbd702d97cf2435', class: "sticker-content", ref: (div) => (this.content = div) }, h("slot", { key: 'a88a8500ee1ea99324f9b1b7390675486035496c' })))));
31104
31839
  }
31105
31840
  static get watchers() { return {
31106
31841
  "trigger": ["updateTriggerOffset"],
@@ -31389,10 +32124,10 @@ class Tooltip {
31389
32124
  this.popover.destroy();
31390
32125
  }
31391
32126
  render() {
31392
- return (h(Host, { key: '94758bb18228b14884cf2be79228e554de84013f', onKeyDown: this.handleKeyDown, onMouseOver: this.handleMouseOver, onMouseOut: this.handleMouseOut, onBlur: this.handleBlur, onFocus: this.handleFocus, onClick: this.handleClick, class: "nano-tooltip" }, h("slot", { key: '45589386e68d89c21abbb50513678152e8bce9d1', onSlotchange: this.handleSlotChange }), h("div", { key: '6a76c101c35d45458f0a680753a381cc95631b87', ref: (el) => (this.tooltipPositioner = el), class: "tooltip-positioner", popover: "manual" }, h("div", { key: 'd3b2cc9c9018c9a0a5dc4cef256c8b9c568cd0b4', part: "base", ref: (el) => (this.tooltip = el), class: {
32127
+ return (h(Host, { key: '30c71d884cf8fc1c2e97092dad0fb5d6695c77a8', onKeyDown: this.handleKeyDown, onMouseOver: this.handleMouseOver, onMouseOut: this.handleMouseOut, onBlur: this.handleBlur, onFocus: this.handleFocus, onClick: this.handleClick, class: "nano-tooltip" }, h("slot", { key: 'b7e7893c178d99abeb0f1e5a35892fddc8ab302a', onSlotchange: this.handleSlotChange }), h("div", { key: '83aae47d9745dcce88f6119ffa63b3bea809dc17', ref: (el) => (this.tooltipPositioner = el), class: "tooltip-positioner", popover: "manual" }, h("div", { key: 'f5cd2aa11ef281358d11057c866b298202398fc2', part: "base", ref: (el) => (this.tooltip = el), class: {
31393
32128
  tooltip: true,
31394
32129
  'tooltip--open': this.open,
31395
- }, role: "tooltip", "aria-hidden": this.open ? 'false' : 'true' }, h("slot", { key: '1c51cdc6a7ec88107e3290b0b9750198e7176c20', name: "content", onSlotchange: () => this.setLabel() }, this.content), h("div", { key: '00f090eee000e6bba713dc21a1d53c348eb94a76', class: "tooltip-arrow", "data-popper-arrow": true })))));
32130
+ }, role: "tooltip", "aria-hidden": this.open ? 'false' : 'true' }, h("slot", { key: '0dc5a5f28b439406f2d19dc4822b221bbb65a9e8', name: "content", onSlotchange: () => this.setLabel() }, this.content), h("div", { key: 'd196bcffcfd4b26cf085ec21cc7965a369dd55ab', class: "tooltip-arrow", "data-popper-arrow": true })))));
31396
32131
  }
31397
32132
  static get watchers() { return {
31398
32133
  "content": ["setLabel"],
@@ -31446,6 +32181,7 @@ registerComponents([
31446
32181
  IconButton,
31447
32182
  Img,
31448
32183
  Input,
32184
+ InputOTP,
31449
32185
  IntersectionObserve,
31450
32186
  MaskedOverflow,
31451
32187
  Menu,