q2-tecton-elements 1.67.2 → 1.68.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.
- package/dist/bundle-report.json +22598 -10670
- package/dist/cjs/click-elsewhere.q2-option-list.q2-popover.entry.cjs.js.map +1 -1
- package/dist/cjs/click-elsewhere_3.cjs.entry.js +46 -32
- package/dist/cjs/click-elsewhere_3.cjs.entry.js.map +1 -1
- package/dist/cjs/{component-DRAntnCA.js → component-iASoq6gx.js} +9 -3
- package/dist/cjs/component-iASoq6gx.js.map +1 -0
- package/dist/cjs/{index-YvKoRT-t.js → index-DmGkqdX2.js} +3 -3
- package/dist/cjs/index-DmGkqdX2.js.map +1 -0
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/cjs/q2-action-group.q2-resize-observer.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-action-group_2.cjs.entry.js +2 -2
- package/dist/cjs/q2-action-group_2.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-action-sheet.cjs.entry.js +109 -4
- package/dist/cjs/q2-action-sheet.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-action-sheet.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-avatar.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-avatar.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-badge.cjs.entry.js +1 -1
- package/dist/cjs/q2-badge.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-badge.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-btn.q2-loading.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-btn_2.cjs.entry.js +1 -1
- package/dist/cjs/q2-btn_2.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-calendar.cjs.entry.js +6 -3
- package/dist/cjs/q2-calendar.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-calendar.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-card-image.cjs.entry.js +2 -2
- package/dist/cjs/q2-card-image.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-card-image.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-card.cjs.entry.js +1 -1
- package/dist/cjs/q2-card.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-card.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-carousel-pane.cjs.entry.js +3 -3
- package/dist/cjs/q2-carousel-pane.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-carousel-pane.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-carousel.cjs.entry.js +162 -29
- package/dist/cjs/q2-carousel.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-carousel.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-chart-area.cjs.entry.js +1 -1
- package/dist/cjs/q2-chart-bar.cjs.entry.js +1 -1
- package/dist/cjs/q2-chart-donut.cjs.entry.js +3 -2
- package/dist/cjs/q2-chart-donut.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-chart-donut.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-checkbox-group.cjs.entry.js +2 -2
- package/dist/cjs/q2-checkbox-group.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-checkbox-group.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-checkbox.q2-tag.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-checkbox_2.cjs.entry.js +3 -3
- package/dist/cjs/q2-checkbox_2.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-context.cjs.entry.js +2 -2
- package/dist/cjs/q2-context.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-context.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-currency.cjs.entry.js +2 -3
- package/dist/cjs/q2-currency.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-currency.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-data-table.cjs.entry.js +2 -2
- package/dist/cjs/q2-data-table.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-data-table.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-detail.cjs.entry.js +2 -2
- package/dist/cjs/q2-detail.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-detail.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-dropdown-item.cjs.entry.js +2 -2
- package/dist/cjs/q2-dropdown-item.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-dropdown-item.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-dropdown.cjs.entry.js +3 -5
- package/dist/cjs/q2-dropdown.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-dropdown.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-editable-field.cjs.entry.js +1 -1
- package/dist/cjs/q2-editable-field.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-editable-field.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-example.cjs.entry.js +1 -1
- package/dist/cjs/q2-file-picker.cjs.entry.js +1 -1
- package/dist/cjs/q2-file-picker.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-file-picker.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-form.cjs.entry.js +2 -2
- package/dist/cjs/q2-form.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-form.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-formatted-text.cjs.entry.js +1 -1
- package/dist/cjs/q2-formatted-text.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-formatted-text.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-grid-area.cjs.entry.js +1 -1
- package/dist/cjs/q2-grid.cjs.entry.js +32 -8
- package/dist/cjs/q2-grid.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-grid.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-icon.cjs.entry.js +1 -1
- package/dist/cjs/q2-icon.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-icon.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-input.cjs.entry.js +8 -5
- package/dist/cjs/q2-input.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-input.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-item.cjs.entry.js +2 -2
- package/dist/cjs/q2-item.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-item.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-legend.cjs.entry.js +2 -3
- package/dist/cjs/q2-legend.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-legend.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-link.q2-list.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-link_2.cjs.entry.js +2 -2
- package/dist/cjs/q2-link_2.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-loc.cjs.entry.js +1 -1
- package/dist/cjs/q2-message.cjs.entry.js +3 -3
- package/dist/cjs/q2-message.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-message.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-meter.cjs.entry.js +2 -2
- package/dist/cjs/q2-meter.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-meter.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-modal.cjs.entry.js +3 -3
- package/dist/cjs/q2-modal.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-modal.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-month-picker.cjs.entry.js +1 -1
- package/dist/cjs/q2-mutation-observer.cjs.entry.js +1 -1
- package/dist/cjs/q2-optgroup.cjs.entry.js +3 -3
- package/dist/cjs/q2-optgroup.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-optgroup.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-option.cjs.entry.js +3 -3
- package/dist/cjs/q2-option.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-option.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-otp.cjs.entry.js +373 -0
- package/dist/cjs/q2-otp.cjs.entry.js.map +1 -0
- package/dist/cjs/q2-otp.entry.cjs.js.map +1 -0
- package/dist/cjs/q2-pagination.cjs.entry.js +4 -4
- package/dist/cjs/q2-pagination.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-pagination.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-pill.cjs.entry.js +24 -15
- package/dist/cjs/q2-pill.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-pill.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-radio-group.cjs.entry.js +1 -1
- package/dist/cjs/q2-radio-group.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-radio-group.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-radio.cjs.entry.js +3 -3
- package/dist/cjs/q2-radio.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-radio.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-relative-time.cjs.entry.js +2 -2
- package/dist/cjs/q2-section-container.cjs.entry.js +1 -1
- package/dist/cjs/q2-section.cjs.entry.js +3 -3
- package/dist/cjs/q2-section.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-section.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-select.cjs.entry.js +1 -1
- package/dist/cjs/q2-select.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-select.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-stepper-pane.cjs.entry.js +3 -3
- package/dist/cjs/q2-stepper-vertical.cjs.entry.js +2 -2
- package/dist/cjs/q2-stepper-vertical.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-stepper-vertical.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-stepper.cjs.entry.js +2 -2
- package/dist/cjs/q2-stepper.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-stepper.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-tab-container.cjs.entry.js +3 -3
- package/dist/cjs/q2-tab-container.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-tab-container.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-tab-pane.cjs.entry.js +2 -2
- package/dist/cjs/q2-tecton-elements.cjs.js +1 -1
- package/dist/cjs/q2-textarea.cjs.entry.js +1 -1
- package/dist/cjs/q2-textarea.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-textarea.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-toast.cjs.entry.js +1 -1
- package/dist/cjs/q2-toast.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-toast.entry.cjs.js.map +1 -1
- package/dist/cjs/q2-tooltip.cjs.entry.js +124 -5
- package/dist/cjs/q2-tooltip.cjs.entry.js.map +1 -1
- package/dist/cjs/q2-tooltip.entry.cjs.js.map +1 -1
- package/dist/cjs/{sanitize-html-string-CW6y5624.js → sanitize-html-string-D17Pr7-c.js} +21 -4
- package/dist/cjs/{sanitize-html-string-CW6y5624.js.map → sanitize-html-string-D17Pr7-c.js.map} +1 -1
- package/dist/cjs/tecton-tab-pane.cjs.entry.js +2 -2
- package/dist/collection/collection-manifest.json +1 -0
- package/dist/collection/components/click-elsewhere/click-elsewhere.js +2 -0
- package/dist/collection/components/click-elsewhere/click-elsewhere.js.map +1 -1
- package/dist/collection/components/q2-action-group/q2-action-group.css +14 -0
- package/dist/collection/components/q2-action-sheet/q2-action-sheet.css +16 -0
- package/dist/collection/components/q2-action-sheet/q2-action-sheet.js +107 -2
- package/dist/collection/components/q2-action-sheet/q2-action-sheet.js.map +1 -1
- package/dist/collection/components/q2-avatar/q2-avatar.css +24 -0
- package/dist/collection/components/q2-avatar/test/q2-avatar-test.vr.js +61 -0
- package/dist/collection/components/q2-avatar/test/q2-avatar-test.vr.js.map +1 -0
- package/dist/collection/components/q2-badge/q2-badge.css +30 -0
- package/dist/collection/components/q2-badge/test/q2-badge-test.vr.js +34 -0
- package/dist/collection/components/q2-badge/test/q2-badge-test.vr.js.map +1 -0
- package/dist/collection/components/q2-btn/q2-btn.css +279 -0
- package/dist/collection/components/q2-btn/test/q2-btn-test.vr.js +80 -0
- package/dist/collection/components/q2-btn/test/q2-btn-test.vr.js.map +1 -0
- package/dist/collection/components/q2-calendar/q2-calendar.css +36 -0
- package/dist/collection/components/q2-calendar/q2-calendar.js +5 -2
- package/dist/collection/components/q2-calendar/q2-calendar.js.map +1 -1
- package/dist/collection/components/q2-calendar/test/q2-calendar-test.vr.js +170 -0
- package/dist/collection/components/q2-calendar/test/q2-calendar-test.vr.js.map +1 -0
- package/dist/collection/components/q2-card/q2-card.css +62 -0
- package/dist/collection/components/q2-card/test/q2-card-test.vr.js +72 -0
- package/dist/collection/components/q2-card/test/q2-card-test.vr.js.map +1 -0
- package/dist/collection/components/q2-card-image/q2-card-image.css +74 -13
- package/dist/collection/components/q2-card-image/test/q2-card-image-test.vr.js +152 -0
- package/dist/collection/components/q2-card-image/test/q2-card-image-test.vr.js.map +1 -0
- package/dist/collection/components/q2-carousel/q2-carousel.css +78 -13
- package/dist/collection/components/q2-carousel/q2-carousel.js +241 -27
- package/dist/collection/components/q2-carousel/q2-carousel.js.map +1 -1
- package/dist/collection/components/q2-carousel/test/q2-carousel-test.vr.js +104 -0
- package/dist/collection/components/q2-carousel/test/q2-carousel-test.vr.js.map +1 -0
- package/dist/collection/components/q2-carousel-pane/q2-carousel-pane.css +26 -1
- package/dist/collection/components/q2-chart-area/test/q2-chart-area-test.vr.js +126 -0
- package/dist/collection/components/q2-chart-area/test/q2-chart-area-test.vr.js.map +1 -0
- package/dist/collection/components/q2-chart-bar/test/q2-chart-bar-test.vr.js +105 -0
- package/dist/collection/components/q2-chart-bar/test/q2-chart-bar-test.vr.js.map +1 -0
- package/dist/collection/components/q2-chart-donut/q2-chart-donut.css +29 -0
- package/dist/collection/components/q2-chart-donut/q2-chart-donut.js +21 -1
- package/dist/collection/components/q2-chart-donut/q2-chart-donut.js.map +1 -1
- package/dist/collection/components/q2-chart-donut/test/q2-chart-donut-test.vr.js +151 -0
- package/dist/collection/components/q2-chart-donut/test/q2-chart-donut-test.vr.js.map +1 -0
- package/dist/collection/components/q2-checkbox/q2-checkbox.css +128 -0
- package/dist/collection/components/q2-checkbox/test/q2-checkbox-test.vr.js +69 -0
- package/dist/collection/components/q2-checkbox/test/q2-checkbox-test.vr.js.map +1 -0
- package/dist/collection/components/q2-checkbox-group/q2-checkbox-group.css +21 -0
- package/dist/collection/components/q2-checkbox-group/test/q2-checkbox-group-test.vr.js +61 -0
- package/dist/collection/components/q2-checkbox-group/test/q2-checkbox-group-test.vr.js.map +1 -0
- package/dist/collection/components/q2-context/q2-context.css +16 -0
- package/dist/collection/components/q2-context/test/q2-context-test.vr.js +95 -0
- package/dist/collection/components/q2-context/test/q2-context-test.vr.js.map +1 -0
- package/dist/collection/components/q2-currency/q2-currency.css +31 -0
- package/dist/collection/components/q2-currency/q2-currency.js +3 -4
- package/dist/collection/components/q2-currency/q2-currency.js.map +1 -1
- package/dist/collection/components/q2-currency/test/q2-currency-test.vr.js +79 -0
- package/dist/collection/components/q2-currency/test/q2-currency-test.vr.js.map +1 -0
- package/dist/collection/components/q2-data-table/q2-data-table.css +51 -0
- package/dist/collection/components/q2-data-table/q2-data-table.js +1 -1
- package/dist/collection/components/q2-data-table/test/q2-data-table-test.vr.js +79 -0
- package/dist/collection/components/q2-data-table/test/q2-data-table-test.vr.js.map +1 -0
- package/dist/collection/components/q2-detail/q2-detail.css +42 -0
- package/dist/collection/components/q2-detail/q2-detail.js +1 -1
- package/dist/collection/components/q2-dropdown/q2-dropdown.css +8 -0
- package/dist/collection/components/q2-dropdown/q2-dropdown.js +2 -4
- package/dist/collection/components/q2-dropdown/q2-dropdown.js.map +1 -1
- package/dist/collection/components/q2-dropdown-item/q2-dropdown-item.css +11 -0
- package/dist/collection/components/q2-editable-field/q2-editable-field.css +5 -0
- package/dist/collection/components/q2-editable-field/test/q2-editable-field-test.vr.js +89 -0
- package/dist/collection/components/q2-editable-field/test/q2-editable-field-test.vr.js.map +1 -0
- package/dist/collection/components/q2-example/q2-example.js +1 -1
- package/dist/collection/components/q2-file-picker/q2-file-picker.css +64 -0
- package/dist/collection/components/q2-file-picker/test/q2-file-picker-test.vr.js +92 -0
- package/dist/collection/components/q2-file-picker/test/q2-file-picker-test.vr.js.map +1 -0
- package/dist/collection/components/q2-form/q2-form.css +34 -20
- package/dist/collection/components/q2-form/q2-form.js +1 -1
- package/dist/collection/components/q2-formatted-text/q2-formatted-text.css +14 -0
- package/dist/collection/components/q2-formatted-text/q2-formatted-text.js +1 -1
- package/dist/collection/components/q2-formatted-text/test/q2-formatted-text-test.vr.js +55 -0
- package/dist/collection/components/q2-formatted-text/test/q2-formatted-text-test.vr.js.map +1 -0
- package/dist/collection/components/q2-grid/q2-grid.css +13 -0
- package/dist/collection/components/q2-grid/q2-grid.js +31 -7
- package/dist/collection/components/q2-grid/q2-grid.js.map +1 -1
- package/dist/collection/components/q2-icon/assets/standard.symbol.svg +1 -1
- package/dist/collection/components/q2-icon/q2-icon.css +15 -0
- package/dist/collection/components/q2-icon/test/q2-icon-test.vr.js +55 -0
- package/dist/collection/components/q2-icon/test/q2-icon-test.vr.js.map +1 -0
- package/dist/collection/components/q2-input/q2-input.css +104 -0
- package/dist/collection/components/q2-input/q2-input.js +6 -3
- package/dist/collection/components/q2-input/q2-input.js.map +1 -1
- package/dist/collection/components/q2-input/test/q2-input-test.vr.js +97 -0
- package/dist/collection/components/q2-input/test/q2-input-test.vr.js.map +1 -0
- package/dist/collection/components/q2-item/q2-item.css +28 -0
- package/dist/collection/components/q2-item/q2-item.js +1 -1
- package/dist/collection/components/q2-legend/q2-legend.css +16 -0
- package/dist/collection/components/q2-legend/q2-legend.js +21 -3
- package/dist/collection/components/q2-legend/q2-legend.js.map +1 -1
- package/dist/collection/components/q2-link/q2-link.css +20 -0
- package/dist/collection/components/q2-link/test/q2-link-test.vr.js +70 -0
- package/dist/collection/components/q2-link/test/q2-link-test.vr.js.map +1 -0
- package/dist/collection/components/q2-list/q2-list.css +14 -0
- package/dist/collection/components/q2-list/q2-list.js +1 -1
- package/dist/collection/components/q2-list/test/q2-list-test.vr.js +58 -0
- package/dist/collection/components/q2-list/test/q2-list-test.vr.js.map +1 -0
- package/dist/collection/components/q2-loading/q2-loading.css +9 -0
- package/dist/collection/components/q2-message/q2-message.css +29 -1
- package/dist/collection/components/q2-message/q2-message.js +1 -1
- package/dist/collection/components/q2-message/test/q2-message-test.vr.js +57 -0
- package/dist/collection/components/q2-message/test/q2-message-test.vr.js.map +1 -0
- package/dist/collection/components/q2-meter/q2-meter.css +40 -0
- package/dist/collection/components/q2-meter/q2-meter.js +1 -1
- package/dist/collection/components/q2-meter/test/q2-meter-test.vr.js +78 -0
- package/dist/collection/components/q2-meter/test/q2-meter-test.vr.js.map +1 -0
- package/dist/collection/components/q2-modal/q2-modal.css +21 -0
- package/dist/collection/components/q2-modal/q2-modal.js +1 -1
- package/dist/collection/components/q2-modal/test/q2-modal-test.vr.js +107 -0
- package/dist/collection/components/q2-modal/test/q2-modal-test.vr.js.map +1 -0
- package/dist/collection/components/q2-mutation-observer/q2-mutation-observer.js +1 -1
- package/dist/collection/components/q2-optgroup/q2-optgroup.css +11 -0
- package/dist/collection/components/q2-optgroup/q2-optgroup.js +1 -1
- package/dist/collection/components/q2-option/q2-option.css +9 -0
- package/dist/collection/components/q2-option/q2-option.js +1 -1
- package/dist/collection/components/q2-option/q2-option.js.map +1 -1
- package/dist/collection/components/q2-option-list/q2-option-list.css +3 -0
- package/dist/collection/components/q2-option-list/q2-option-list.js +37 -28
- package/dist/collection/components/q2-option-list/q2-option-list.js.map +1 -1
- package/dist/collection/components/q2-otp/q2-otp.css +312 -0
- package/dist/collection/components/q2-otp/q2-otp.js +873 -0
- package/dist/collection/components/q2-otp/q2-otp.js.map +1 -0
- package/dist/collection/components/q2-pagination/q2-pagination.css +22 -0
- package/dist/collection/components/q2-pagination/q2-pagination.js +3 -3
- package/dist/collection/components/q2-pagination/test/q2-pagination-test.vr.js +145 -0
- package/dist/collection/components/q2-pagination/test/q2-pagination-test.vr.js.map +1 -0
- package/dist/collection/components/q2-pill/q2-pill.css +53 -0
- package/dist/collection/components/q2-pill/q2-pill.js +23 -14
- package/dist/collection/components/q2-pill/q2-pill.js.map +1 -1
- package/dist/collection/components/q2-pill/test/q2-pill-test.vr.js +110 -0
- package/dist/collection/components/q2-pill/test/q2-pill-test.vr.js.map +1 -0
- package/dist/collection/components/q2-popover/q2-popover.css +20 -0
- package/dist/collection/components/q2-popover/q2-popover.js +5 -2
- package/dist/collection/components/q2-popover/q2-popover.js.map +1 -1
- package/dist/collection/components/q2-radio/q2-radio.css +52 -1
- package/dist/collection/components/q2-radio/q2-radio.js +2 -2
- package/dist/collection/components/q2-radio/q2-radio.js.map +1 -1
- package/dist/collection/components/q2-radio/test/q2-radio-test.vr.js +73 -0
- package/dist/collection/components/q2-radio/test/q2-radio-test.vr.js.map +1 -0
- package/dist/collection/components/q2-radio-group/q2-radio-group.css +22 -0
- package/dist/collection/components/q2-radio-group/test/q2-radio-group-test.vr.js +99 -0
- package/dist/collection/components/q2-radio-group/test/q2-radio-group-test.vr.js.map +1 -0
- package/dist/collection/components/q2-relative-time/q2-relative-time.js +1 -1
- package/dist/collection/components/q2-resize-observer/q2-resize-observer.js +1 -1
- package/dist/collection/components/q2-section/q2-section.css +26 -0
- package/dist/collection/components/q2-section/q2-section.js +2 -2
- package/dist/collection/components/q2-section/test/q2-section-test.vr.js +68 -0
- package/dist/collection/components/q2-section/test/q2-section-test.vr.js.map +1 -0
- package/dist/collection/components/q2-select/q2-select.css +17 -0
- package/dist/collection/components/q2-select/test/q2-select-test.vr.js +107 -0
- package/dist/collection/components/q2-select/test/q2-select-test.vr.js.map +1 -0
- package/dist/collection/components/q2-stepper/q2-stepper.css +36 -0
- package/dist/collection/components/q2-stepper/q2-stepper.js +1 -1
- package/dist/collection/components/q2-stepper/test/q2-stepper-test.vr.js +86 -0
- package/dist/collection/components/q2-stepper/test/q2-stepper-test.vr.js.map +1 -0
- package/dist/collection/components/q2-stepper-pane/q2-stepper-pane.js +1 -1
- package/dist/collection/components/q2-stepper-vertical/q2-stepper-vertical.css +31 -0
- package/dist/collection/components/q2-stepper-vertical/q2-stepper-vertical.js +1 -1
- package/dist/collection/components/q2-stepper-vertical/test/q2-stepper-vertical-test.vr.js +97 -0
- package/dist/collection/components/q2-stepper-vertical/test/q2-stepper-vertical-test.vr.js.map +1 -0
- package/dist/collection/components/q2-tab-container/q2-tab-container.css +38 -0
- package/dist/collection/components/q2-tab-container/q2-tab-container.js +1 -1
- package/dist/collection/components/q2-tab-container/test/q2-tab-container-test.vr.js +78 -0
- package/dist/collection/components/q2-tab-container/test/q2-tab-container-test.vr.js.map +1 -0
- package/dist/collection/components/q2-tab-pane/q2-tab-pane.js +1 -1
- package/dist/collection/components/q2-tag/q2-tag.css +30 -1
- package/dist/collection/components/q2-tag/q2-tag.js +1 -1
- package/dist/collection/components/q2-tag/test/q2-tag-test.vr.js +83 -0
- package/dist/collection/components/q2-tag/test/q2-tag-test.vr.js.map +1 -0
- package/dist/collection/components/q2-textarea/q2-textarea.css +80 -0
- package/dist/collection/components/q2-textarea/test/q2-textarea-test.vr.js +102 -0
- package/dist/collection/components/q2-textarea/test/q2-textarea-test.vr.js.map +1 -0
- package/dist/collection/components/q2-toast/q2-toast.css +15 -0
- package/dist/collection/components/q2-tooltip/q2-tooltip.css +31 -0
- package/dist/collection/components/q2-tooltip/q2-tooltip.js +135 -4
- package/dist/collection/components/q2-tooltip/q2-tooltip.js.map +1 -1
- package/dist/collection/components/q2-tooltip/test/q2-tooltip-test.vr.js +76 -0
- package/dist/collection/components/q2-tooltip/test/q2-tooltip-test.vr.js.map +1 -0
- package/dist/collection/components/tecton-tab-pane/tecton-tab-pane.js +2 -2
- package/dist/collection/utils/component.js +7 -1
- package/dist/collection/utils/component.js.map +1 -1
- package/dist/collection/utils/index.js +1 -1
- package/dist/collection/utils/index.js.map +1 -1
- package/dist/collection/utils/sanitize-html-string.js +19 -2
- package/dist/collection/utils/sanitize-html-string.js.map +1 -1
- package/dist/collection/utils/test/vr-helpers.js +98 -0
- package/dist/collection/utils/test/vr-helpers.js.map +1 -0
- package/dist/components/click-elsewhere2.js +2 -0
- package/dist/components/click-elsewhere2.js.map +1 -1
- package/dist/components/component.js +7 -1
- package/dist/components/component.js.map +1 -1
- package/dist/components/index.js +2 -0
- package/dist/components/index.js.map +1 -1
- package/dist/components/index2.js +1 -1
- package/dist/components/index2.js.map +1 -1
- package/dist/components/q2-action-group2.js.map +1 -1
- package/dist/components/q2-action-sheet.js +107 -2
- package/dist/components/q2-action-sheet.js.map +1 -1
- package/dist/components/q2-avatar2.js.map +1 -1
- package/dist/components/q2-badge2.js.map +1 -1
- package/dist/components/q2-btn2.js.map +1 -1
- package/dist/components/q2-calendar.js +5 -2
- package/dist/components/q2-calendar.js.map +1 -1
- package/dist/components/q2-card-image.js +1 -1
- package/dist/components/q2-card-image.js.map +1 -1
- package/dist/components/q2-card.js.map +1 -1
- package/dist/components/q2-carousel-pane.js +1 -135
- package/dist/components/q2-carousel-pane.js.map +1 -1
- package/dist/components/q2-carousel-pane2.js +140 -0
- package/dist/components/q2-carousel-pane2.js.map +1 -0
- package/dist/components/q2-carousel.js +173 -29
- package/dist/components/q2-carousel.js.map +1 -1
- package/dist/components/q2-chart-donut.js +3 -1
- package/dist/components/q2-chart-donut.js.map +1 -1
- package/dist/components/q2-checkbox-group.js.map +1 -1
- package/dist/components/q2-checkbox2.js.map +1 -1
- package/dist/components/q2-context.js +1 -1
- package/dist/components/q2-context.js.map +1 -1
- package/dist/components/q2-currency.js +3 -4
- package/dist/components/q2-currency.js.map +1 -1
- package/dist/components/q2-data-table.js +1 -1
- package/dist/components/q2-data-table.js.map +1 -1
- package/dist/components/q2-detail.js +1 -1
- package/dist/components/q2-detail.js.map +1 -1
- package/dist/components/q2-dropdown-item2.js.map +1 -1
- package/dist/components/q2-dropdown.js +2 -4
- package/dist/components/q2-dropdown.js.map +1 -1
- package/dist/components/q2-editable-field.js.map +1 -1
- package/dist/components/q2-example.js +1 -1
- package/dist/components/q2-file-picker.js.map +1 -1
- package/dist/components/q2-form.js +2 -2
- package/dist/components/q2-form.js.map +1 -1
- package/dist/components/q2-formatted-text.js +1 -1
- package/dist/components/q2-formatted-text.js.map +1 -1
- package/dist/components/q2-grid.js +32 -8
- package/dist/components/q2-grid.js.map +1 -1
- package/dist/components/q2-icon2.js.map +1 -1
- package/dist/components/q2-input2.js +7 -4
- package/dist/components/q2-input2.js.map +1 -1
- package/dist/components/q2-item2.js +1 -1
- package/dist/components/q2-item2.js.map +1 -1
- package/dist/components/q2-legend2.js +3 -3
- package/dist/components/q2-legend2.js.map +1 -1
- package/dist/components/q2-link2.js.map +1 -1
- package/dist/components/q2-list2.js +1 -1
- package/dist/components/q2-list2.js.map +1 -1
- package/dist/components/q2-loading2.js.map +1 -1
- package/dist/components/q2-message2.js +2 -2
- package/dist/components/q2-message2.js.map +1 -1
- package/dist/components/q2-meter.js +1 -1
- package/dist/components/q2-meter.js.map +1 -1
- package/dist/components/q2-modal.js +1 -1
- package/dist/components/q2-modal.js.map +1 -1
- package/dist/components/q2-mutation-observer.js +1 -1
- package/dist/components/q2-optgroup2.js +1 -1
- package/dist/components/q2-optgroup2.js.map +1 -1
- package/dist/components/q2-option-list2.js +37 -28
- package/dist/components/q2-option-list2.js.map +1 -1
- package/dist/components/q2-option2.js +1 -1
- package/dist/components/q2-option2.js.map +1 -1
- package/dist/components/q2-otp.d.ts +11 -0
- package/dist/components/q2-otp.js +439 -0
- package/dist/components/q2-otp.js.map +1 -0
- package/dist/components/q2-pagination.js +3 -3
- package/dist/components/q2-pagination.js.map +1 -1
- package/dist/components/q2-pill.js +23 -14
- package/dist/components/q2-pill.js.map +1 -1
- package/dist/components/q2-popover2.js +5 -2
- package/dist/components/q2-popover2.js.map +1 -1
- package/dist/components/q2-radio-group.js.map +1 -1
- package/dist/components/q2-radio.js +2 -2
- package/dist/components/q2-radio.js.map +1 -1
- package/dist/components/q2-relative-time.js +1 -1
- package/dist/components/q2-resize-observer2.js +1 -1
- package/dist/components/q2-section.js +2 -2
- package/dist/components/q2-section.js.map +1 -1
- package/dist/components/q2-select2.js.map +1 -1
- package/dist/components/q2-stepper-pane.js +1 -1
- package/dist/components/q2-stepper-vertical.js +1 -1
- package/dist/components/q2-stepper-vertical.js.map +1 -1
- package/dist/components/q2-stepper.js +1 -1
- package/dist/components/q2-stepper.js.map +1 -1
- package/dist/components/q2-tab-container.js +1 -1
- package/dist/components/q2-tab-container.js.map +1 -1
- package/dist/components/q2-tab-pane.js +1 -1
- package/dist/components/q2-tag2.js +2 -2
- package/dist/components/q2-tag2.js.map +1 -1
- package/dist/components/q2-textarea.js.map +1 -1
- package/dist/components/q2-toast.js.map +1 -1
- package/dist/components/q2-tooltip2.js +124 -5
- package/dist/components/q2-tooltip2.js.map +1 -1
- package/dist/components/sanitize-html-string.js +19 -2
- package/dist/components/sanitize-html-string.js.map +1 -1
- package/dist/components/tecton-tab-pane.js +2 -2
- package/dist/esm/click-elsewhere.q2-option-list.q2-popover.entry.js.map +1 -1
- package/dist/esm/click-elsewhere_3.entry.js +46 -32
- package/dist/esm/click-elsewhere_3.entry.js.map +1 -1
- package/dist/esm/{component-DVxzK3WH.js → component-DaQM9u3s.js} +9 -3
- package/dist/esm/component-DaQM9u3s.js.map +1 -0
- package/dist/esm/{index-C4PILj1_.js → index-C5gj0T_3.js} +4 -4
- package/dist/esm/index-C5gj0T_3.js.map +1 -0
- package/dist/esm/loader.js +1 -1
- package/dist/esm/q2-action-group.q2-resize-observer.entry.js.map +1 -1
- package/dist/esm/q2-action-group_2.entry.js +2 -2
- package/dist/esm/q2-action-group_2.entry.js.map +1 -1
- package/dist/esm/q2-action-sheet.entry.js +109 -4
- package/dist/esm/q2-action-sheet.entry.js.map +1 -1
- package/dist/esm/q2-avatar.entry.js.map +1 -1
- package/dist/esm/q2-badge.entry.js +1 -1
- package/dist/esm/q2-badge.entry.js.map +1 -1
- package/dist/esm/q2-btn.q2-loading.entry.js.map +1 -1
- package/dist/esm/q2-btn_2.entry.js +1 -1
- package/dist/esm/q2-btn_2.entry.js.map +1 -1
- package/dist/esm/q2-calendar.entry.js +6 -3
- package/dist/esm/q2-calendar.entry.js.map +1 -1
- package/dist/esm/q2-card-image.entry.js +2 -2
- package/dist/esm/q2-card-image.entry.js.map +1 -1
- package/dist/esm/q2-card.entry.js +1 -1
- package/dist/esm/q2-card.entry.js.map +1 -1
- package/dist/esm/q2-carousel-pane.entry.js +3 -3
- package/dist/esm/q2-carousel-pane.entry.js.map +1 -1
- package/dist/esm/q2-carousel.entry.js +162 -29
- package/dist/esm/q2-carousel.entry.js.map +1 -1
- package/dist/esm/q2-chart-area.entry.js +1 -1
- package/dist/esm/q2-chart-bar.entry.js +1 -1
- package/dist/esm/q2-chart-donut.entry.js +3 -2
- package/dist/esm/q2-chart-donut.entry.js.map +1 -1
- package/dist/esm/q2-checkbox-group.entry.js +2 -2
- package/dist/esm/q2-checkbox-group.entry.js.map +1 -1
- package/dist/esm/q2-checkbox.q2-tag.entry.js.map +1 -1
- package/dist/esm/q2-checkbox_2.entry.js +3 -3
- package/dist/esm/q2-checkbox_2.entry.js.map +1 -1
- package/dist/esm/q2-context.entry.js +2 -2
- package/dist/esm/q2-context.entry.js.map +1 -1
- package/dist/esm/q2-currency.entry.js +3 -4
- package/dist/esm/q2-currency.entry.js.map +1 -1
- package/dist/esm/q2-data-table.entry.js +2 -2
- package/dist/esm/q2-data-table.entry.js.map +1 -1
- package/dist/esm/q2-detail.entry.js +2 -2
- package/dist/esm/q2-detail.entry.js.map +1 -1
- package/dist/esm/q2-dropdown-item.entry.js +2 -2
- package/dist/esm/q2-dropdown-item.entry.js.map +1 -1
- package/dist/esm/q2-dropdown.entry.js +3 -5
- package/dist/esm/q2-dropdown.entry.js.map +1 -1
- package/dist/esm/q2-editable-field.entry.js +1 -1
- package/dist/esm/q2-editable-field.entry.js.map +1 -1
- package/dist/esm/q2-example.entry.js +1 -1
- package/dist/esm/q2-file-picker.entry.js +1 -1
- package/dist/esm/q2-file-picker.entry.js.map +1 -1
- package/dist/esm/q2-form.entry.js +2 -2
- package/dist/esm/q2-form.entry.js.map +1 -1
- package/dist/esm/q2-formatted-text.entry.js +1 -1
- package/dist/esm/q2-formatted-text.entry.js.map +1 -1
- package/dist/esm/q2-grid-area.entry.js +1 -1
- package/dist/esm/q2-grid.entry.js +33 -9
- package/dist/esm/q2-grid.entry.js.map +1 -1
- package/dist/esm/q2-icon.entry.js +1 -1
- package/dist/esm/q2-icon.entry.js.map +1 -1
- package/dist/esm/q2-input.entry.js +8 -5
- package/dist/esm/q2-input.entry.js.map +1 -1
- package/dist/esm/q2-item.entry.js +2 -2
- package/dist/esm/q2-item.entry.js.map +1 -1
- package/dist/esm/q2-legend.entry.js +2 -3
- package/dist/esm/q2-legend.entry.js.map +1 -1
- package/dist/esm/q2-link.q2-list.entry.js.map +1 -1
- package/dist/esm/q2-link_2.entry.js +2 -2
- package/dist/esm/q2-link_2.entry.js.map +1 -1
- package/dist/esm/q2-loc.entry.js +1 -1
- package/dist/esm/q2-message.entry.js +3 -3
- package/dist/esm/q2-message.entry.js.map +1 -1
- package/dist/esm/q2-meter.entry.js +2 -2
- package/dist/esm/q2-meter.entry.js.map +1 -1
- package/dist/esm/q2-modal.entry.js +3 -3
- package/dist/esm/q2-modal.entry.js.map +1 -1
- package/dist/esm/q2-month-picker.entry.js +1 -1
- package/dist/esm/q2-mutation-observer.entry.js +1 -1
- package/dist/esm/q2-optgroup.entry.js +3 -3
- package/dist/esm/q2-optgroup.entry.js.map +1 -1
- package/dist/esm/q2-option.entry.js +3 -3
- package/dist/esm/q2-option.entry.js.map +1 -1
- package/dist/esm/q2-otp.entry.js +371 -0
- package/dist/esm/q2-otp.entry.js.map +1 -0
- package/dist/esm/q2-pagination.entry.js +4 -4
- package/dist/esm/q2-pagination.entry.js.map +1 -1
- package/dist/esm/q2-pill.entry.js +24 -15
- package/dist/esm/q2-pill.entry.js.map +1 -1
- package/dist/esm/q2-radio-group.entry.js +1 -1
- package/dist/esm/q2-radio-group.entry.js.map +1 -1
- package/dist/esm/q2-radio.entry.js +3 -3
- package/dist/esm/q2-radio.entry.js.map +1 -1
- package/dist/esm/q2-relative-time.entry.js +2 -2
- package/dist/esm/q2-section-container.entry.js +1 -1
- package/dist/esm/q2-section.entry.js +3 -3
- package/dist/esm/q2-section.entry.js.map +1 -1
- package/dist/esm/q2-select.entry.js +1 -1
- package/dist/esm/q2-select.entry.js.map +1 -1
- package/dist/esm/q2-stepper-pane.entry.js +3 -3
- package/dist/esm/q2-stepper-vertical.entry.js +2 -2
- package/dist/esm/q2-stepper-vertical.entry.js.map +1 -1
- package/dist/esm/q2-stepper.entry.js +2 -2
- package/dist/esm/q2-stepper.entry.js.map +1 -1
- package/dist/esm/q2-tab-container.entry.js +3 -3
- package/dist/esm/q2-tab-container.entry.js.map +1 -1
- package/dist/esm/q2-tab-pane.entry.js +2 -2
- package/dist/esm/q2-tecton-elements.js +1 -1
- package/dist/esm/q2-textarea.entry.js +1 -1
- package/dist/esm/q2-textarea.entry.js.map +1 -1
- package/dist/esm/q2-toast.entry.js +1 -1
- package/dist/esm/q2-toast.entry.js.map +1 -1
- package/dist/esm/q2-tooltip.entry.js +124 -5
- package/dist/esm/q2-tooltip.entry.js.map +1 -1
- package/dist/esm/{sanitize-html-string-B35VmRc9.js → sanitize-html-string-DPHNpMWE.js} +21 -4
- package/dist/{q2-tecton-elements/sanitize-html-string-B35VmRc9.js.map → esm/sanitize-html-string-DPHNpMWE.js.map} +1 -1
- package/dist/esm/tecton-tab-pane.entry.js +2 -2
- package/dist/playwright.config.js +12 -0
- package/dist/playwright.config.js.map +1 -0
- package/dist/q2-tecton-elements/assets/standard.symbol.svg +1 -1
- package/dist/q2-tecton-elements/click-elsewhere.q2-option-list.q2-popover.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/click-elsewhere_3.entry.js +44 -35
- package/dist/q2-tecton-elements/click-elsewhere_3.entry.js.map +1 -1
- package/dist/q2-tecton-elements/component-DaQM9u3s.js +46 -0
- package/dist/q2-tecton-elements/component-DaQM9u3s.js.map +1 -0
- package/dist/q2-tecton-elements/{index-C4PILj1_.js → index-C5gj0T_3.js} +4 -4
- package/dist/q2-tecton-elements/index-C5gj0T_3.js.map +1 -0
- package/dist/q2-tecton-elements/q2-action-group.q2-resize-observer.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-action-group_2.entry.js +2 -2
- package/dist/q2-tecton-elements/q2-action-group_2.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-action-sheet.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-action-sheet.entry.js +166 -70
- package/dist/q2-tecton-elements/q2-action-sheet.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-avatar.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-avatar.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-badge.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-badge.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-badge.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-btn.q2-loading.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-btn_2.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-btn_2.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-calendar.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-calendar.entry.js +4 -4
- package/dist/q2-tecton-elements/q2-calendar.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-card-image.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-card-image.entry.js +2 -2
- package/dist/q2-tecton-elements/q2-card-image.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-card.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-card.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-card.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-carousel-pane.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-carousel-pane.entry.js +6 -6
- package/dist/q2-tecton-elements/q2-carousel-pane.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-carousel.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-carousel.entry.js +402 -271
- package/dist/q2-tecton-elements/q2-carousel.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-chart-area.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-chart-bar.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-chart-donut.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-chart-donut.entry.js +18 -16
- package/dist/q2-tecton-elements/q2-chart-donut.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-checkbox-group.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-checkbox-group.entry.js +2 -2
- package/dist/q2-tecton-elements/q2-checkbox-group.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-checkbox.q2-tag.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-checkbox_2.entry.js +7 -7
- package/dist/q2-tecton-elements/q2-checkbox_2.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-context.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-context.entry.js +2 -2
- package/dist/q2-tecton-elements/q2-context.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-currency.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-currency.entry.js +34 -33
- package/dist/q2-tecton-elements/q2-currency.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-data-table.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-data-table.entry.js +4 -4
- package/dist/q2-tecton-elements/q2-data-table.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-detail.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-detail.entry.js +4 -4
- package/dist/q2-tecton-elements/q2-detail.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-dropdown-item.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-dropdown-item.entry.js +2 -2
- package/dist/q2-tecton-elements/q2-dropdown-item.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-dropdown.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-dropdown.entry.js +18 -19
- package/dist/q2-tecton-elements/q2-dropdown.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-editable-field.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-editable-field.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-editable-field.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-example.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-file-picker.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-file-picker.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-file-picker.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-form.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-form.entry.js +9 -9
- package/dist/q2-tecton-elements/q2-form.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-formatted-text.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-formatted-text.entry.js +2 -2
- package/dist/q2-tecton-elements/q2-formatted-text.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-grid-area.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-grid.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-grid.entry.js +39 -14
- package/dist/q2-tecton-elements/q2-grid.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-icon.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-icon.entry.js +52 -52
- package/dist/q2-tecton-elements/q2-icon.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-input.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-input.entry.js +10 -6
- package/dist/q2-tecton-elements/q2-input.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-item.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-item.entry.js +14 -14
- package/dist/q2-tecton-elements/q2-item.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-legend.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-legend.entry.js +4 -5
- package/dist/q2-tecton-elements/q2-legend.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-link.q2-list.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-link_2.entry.js +7 -7
- package/dist/q2-tecton-elements/q2-link_2.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-loc.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-message.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-message.entry.js +28 -28
- package/dist/q2-tecton-elements/q2-message.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-meter.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-meter.entry.js +8 -8
- package/dist/q2-tecton-elements/q2-meter.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-modal.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-modal.entry.js +53 -53
- package/dist/q2-tecton-elements/q2-modal.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-month-picker.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-mutation-observer.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-optgroup.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-optgroup.entry.js +6 -6
- package/dist/q2-tecton-elements/q2-optgroup.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-option.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-option.entry.js +3 -3
- package/dist/q2-tecton-elements/q2-option.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-otp.entry.esm.js.map +1 -0
- package/dist/q2-tecton-elements/q2-otp.entry.js +453 -0
- package/dist/q2-tecton-elements/q2-otp.entry.js.map +1 -0
- package/dist/q2-tecton-elements/q2-pagination.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-pagination.entry.js +29 -29
- package/dist/q2-tecton-elements/q2-pagination.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-pill.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-pill.entry.js +43 -28
- package/dist/q2-tecton-elements/q2-pill.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-radio-group.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-radio-group.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-radio-group.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-radio.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-radio.entry.js +10 -10
- package/dist/q2-tecton-elements/q2-radio.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-relative-time.entry.js +2 -2
- package/dist/q2-tecton-elements/q2-section-container.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-section.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-section.entry.js +21 -21
- package/dist/q2-tecton-elements/q2-section.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-select.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-select.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-select.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-stepper-pane.entry.js +10 -10
- package/dist/q2-tecton-elements/q2-stepper-vertical.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-stepper-vertical.entry.js +5 -5
- package/dist/q2-tecton-elements/q2-stepper-vertical.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-stepper.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-stepper.entry.js +33 -33
- package/dist/q2-tecton-elements/q2-stepper.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-tab-container.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-tab-container.entry.js +14 -14
- package/dist/q2-tecton-elements/q2-tab-container.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-tab-pane.entry.js +6 -6
- package/dist/q2-tecton-elements/q2-tecton-elements.esm.js +1 -1
- package/dist/q2-tecton-elements/q2-textarea.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-textarea.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-textarea.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-toast.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-toast.entry.js +1 -1
- package/dist/q2-tecton-elements/q2-toast.entry.js.map +1 -1
- package/dist/q2-tecton-elements/q2-tooltip.entry.esm.js.map +1 -1
- package/dist/q2-tecton-elements/q2-tooltip.entry.js +136 -20
- package/dist/q2-tecton-elements/q2-tooltip.entry.js.map +1 -1
- package/dist/q2-tecton-elements/{sanitize-html-string-B35VmRc9.js → sanitize-html-string-DPHNpMWE.js} +147 -142
- package/dist/{esm/sanitize-html-string-B35VmRc9.js.map → q2-tecton-elements/sanitize-html-string-DPHNpMWE.js.map} +1 -1
- package/dist/q2-tecton-elements/tecton-tab-pane.entry.js +6 -6
- package/dist/types/builds/q2e/development/tecton/tecton/packages/q2-tecton-elements/.stencil/playwright.config.d.ts +2 -0
- package/dist/types/components/q2-action-sheet/q2-action-sheet.d.ts +22 -0
- package/dist/types/components/q2-avatar/test/q2-avatar-test.vr.d.ts +1 -0
- package/dist/types/components/q2-badge/test/q2-badge-test.vr.d.ts +1 -0
- package/dist/types/components/q2-btn/test/q2-btn-test.vr.d.ts +1 -0
- package/dist/types/components/q2-calendar/test/q2-calendar-test.vr.d.ts +1 -0
- package/dist/types/components/q2-card/test/q2-card-test.vr.d.ts +1 -0
- package/dist/types/components/q2-card-image/test/q2-card-image-test.vr.d.ts +1 -0
- package/dist/types/components/q2-carousel/q2-carousel.d.ts +29 -0
- package/dist/types/components/q2-carousel/test/q2-carousel-test.vr.d.ts +1 -0
- package/dist/types/components/q2-chart-area/test/q2-chart-area-test.vr.d.ts +1 -0
- package/dist/types/components/q2-chart-bar/test/q2-chart-bar-test.vr.d.ts +1 -0
- package/dist/types/components/q2-chart-donut/q2-chart-donut.d.ts +2 -0
- package/dist/types/components/q2-chart-donut/test/q2-chart-donut-test.vr.d.ts +1 -0
- package/dist/types/components/q2-checkbox/test/q2-checkbox-test.vr.d.ts +1 -0
- package/dist/types/components/q2-checkbox-group/test/q2-checkbox-group-test.vr.d.ts +1 -0
- package/dist/types/components/q2-context/test/q2-context-test.vr.d.ts +1 -0
- package/dist/types/components/q2-currency/test/q2-currency-test.vr.d.ts +1 -0
- package/dist/types/components/q2-data-table/test/q2-data-table-test.vr.d.ts +1 -0
- package/dist/types/components/q2-editable-field/test/q2-editable-field-test.vr.d.ts +1 -0
- package/dist/types/components/q2-file-picker/test/q2-file-picker-test.vr.d.ts +1 -0
- package/dist/types/components/q2-formatted-text/test/q2-formatted-text-test.vr.d.ts +1 -0
- package/dist/types/components/q2-grid/q2-grid.d.ts +10 -0
- package/dist/types/components/q2-icon/test/q2-icon-test.vr.d.ts +1 -0
- package/dist/types/components/q2-input/test/q2-input-test.vr.d.ts +1 -0
- package/dist/types/components/q2-legend/q2-legend.d.ts +2 -0
- package/dist/types/components/q2-link/test/q2-link-test.vr.d.ts +1 -0
- package/dist/types/components/q2-list/test/q2-list-test.vr.d.ts +1 -0
- package/dist/types/components/q2-message/test/q2-message-test.vr.d.ts +1 -0
- package/dist/types/components/q2-meter/test/q2-meter-test.vr.d.ts +1 -0
- package/dist/types/components/q2-modal/test/q2-modal-test.vr.d.ts +1 -0
- package/dist/types/components/q2-otp/q2-otp.d.ts +159 -0
- package/dist/types/components/q2-pagination/test/q2-pagination-test.vr.d.ts +1 -0
- package/dist/types/components/q2-pill/q2-pill.d.ts +5 -2
- package/dist/types/components/q2-pill/test/q2-pill-test.vr.d.ts +1 -0
- package/dist/types/components/q2-radio/q2-radio.d.ts +1 -1
- package/dist/types/components/q2-radio/test/q2-radio-test.vr.d.ts +1 -0
- package/dist/types/components/q2-radio-group/test/q2-radio-group-test.vr.d.ts +1 -0
- package/dist/types/components/q2-section/test/q2-section-test.vr.d.ts +1 -0
- package/dist/types/components/q2-select/test/q2-select-test.vr.d.ts +1 -0
- package/dist/types/components/q2-stepper/test/q2-stepper-test.vr.d.ts +1 -0
- package/dist/types/components/q2-stepper-vertical/test/q2-stepper-vertical-test.vr.d.ts +1 -0
- package/dist/types/components/q2-tab-container/test/q2-tab-container-test.vr.d.ts +1 -0
- package/dist/types/components/q2-tag/test/q2-tag-test.vr.d.ts +1 -0
- package/dist/types/components/q2-textarea/test/q2-textarea-test.vr.d.ts +1 -0
- package/dist/types/components/q2-tooltip/q2-tooltip.d.ts +4 -0
- package/dist/types/components/q2-tooltip/test/q2-tooltip-test.vr.d.ts +1 -0
- package/dist/types/components.d.ts +306 -2
- package/dist/types/utils/component.d.ts +1 -1
- package/dist/types/utils/test/vr-helpers.d.ts +14 -0
- package/package.json +12 -3
- package/dist/cjs/component-DRAntnCA.js.map +0 -1
- package/dist/cjs/index-YvKoRT-t.js.map +0 -1
- package/dist/esm/component-DVxzK3WH.js.map +0 -1
- package/dist/esm/index-C4PILj1_.js.map +0 -1
- package/dist/q2-tecton-elements/component-DVxzK3WH.js +0 -40
- package/dist/q2-tecton-elements/component-DVxzK3WH.js.map +0 -1
- package/dist/q2-tecton-elements/index-C4PILj1_.js.map +0 -1
|
@@ -0,0 +1,453 @@
|
|
|
1
|
+
import { r as t, c as e, h as i, g as o } from "./index-CGkHOjh1.js";
|
|
2
|
+
|
|
3
|
+
import { c as s, o as r, i as a, l as n } from "./index-C5gj0T_3.js";
|
|
4
|
+
|
|
5
|
+
const c = "*{box-sizing:border-box}*:active{outline:none}*:focus-visible{outline:none;box-shadow:var(--const-double-focus-ring, 0 0 0 2px #ffffff, 0 0 0 4px #0066cc)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size:inherit;font-stretch:inherit}:host(.sr),:host(.sr) button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.sr,.sr button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.hidden{display:none}:host([hidden]){display:none}.invisible{visibility:hidden}:host{--comp-default-otp-margin:var(--tct-otp-margin-top, var(--t-otp-margin-top, var(--app-scale-5x, 25px))) 0 var(--tct-otp-margin-bottom, var(--t-otp-margin-bottom, var(--app-scale-5x, 25px)));--comp-otp-tween:var(--tct-otp-tween, var(--tct-tween-2, var(--app-tween-2, 0.4s ease)));--comp-otp-vertical-gap:var(--tct-otp-vertical-gap, var(--app-scale-4x, 20px));--comp-otp-field-size:44px;--comp-otp-field-gap:var(--tct-otp-field-gap, var(--app-scale-2x, 10px));--comp-otp-field-background:var(--tct-otp-field-background, var(--t-base, #FFFFFF));--comp-otp-field-border-color:var(--tct-otp-field-border-color, var(--t-a11y-gray-color-AA, #404040));--comp-otp-field-border-radius:var(--tct-otp-field-border-radius, var(--tct-border-radius-2, var(--app-border-radius-2, 8px)));--comp-otp-field-border-width:var(--tct-otp-field-border-width, 1px);--comp-otp-field-font-color:var(--tct-otp-field-font-color, var(--t-text, inherit));--comp-otp-field-font-size:var(--tct-otp-field-font-size, var(--app-font-size, 16px));--comp-otp-field-masked-color:var(--tct-otp-field-masked-color, var(--tct-otp-field-font-color, var(--t-text, #1f1f1f)));--comp-otp-field-masked-size:var(--tct-otp-field-masked-size, var(--tct-otp-field-masked-font-size, 8px));--comp-otp-field-font-weight:var(--tct-otp-field-font-weight, 400);--comp-otp-field-focus-box-shadow:var(--tct-otp-field-focus-box-shadow, var(--const-double-focus-ring, 0 0 0 2px #ffffff, 0 0 0 4px #0066cc));--comp-otp-field-error-border-color:var(--tct-otp-field-error-border-color, var(--const-stoplight-alert, #C30000));--comp-otp-field-error-focus-ring-color:var(--tct-otp-field-error-focus-ring-color, #c30000);--comp-otp-field-error-focus-box-shadow:var(--tct-otp-field-error-focus-box-shadow, 0 0 0 2px #ffffff, 0 0 0 4px var(--comp-otp-field-error-focus-ring-color));--comp-otp-field-success-border-color:var(--tct-otp-field-success-border-color, var(--const-stoplight-success, #0e8a00));--comp-otp-field-success-focus-ring-color:var(--tct-otp-field-success-focus-ring-color, #0e8a00);--comp-otp-field-success-focus-box-shadow:var(--tct-otp-field-success-focus-box-shadow, 0 0 0 2px #ffffff, 0 0 0 4px var(--comp-otp-field-success-focus-ring-color));--comp-otp-field-disabled-opacity:var(--tct-otp-field-disabled-opacity, var(--tct-disabled-opacity, var(--app-disabled-opacity, 0.4)));--comp-otp-separator-color:var(--tct-otp-separator-color, var(--t-textA, var(--t-a11y-gray-color, #4d4d4d)));--comp-otp-separator-font-size:var(--tct-otp-separator-font-size, 20px);--comp-otp-separator-font-weight:var(--tct-otp-separator-font-weight, 600);display:flex;justify-content:center;margin:var(--tct-otp-margin, var(--comp-default-otp-margin));font-size:var(--tct-input-font-size, var(--t-input-font-size, var(--app-font-size, inherit)))}:host([hidden]){display:none}.otp-container{align-items:center;display:inline-flex;flex-direction:column;gap:var(--comp-otp-vertical-gap);max-width:100%}.otp-label{display:block;color:var(--tct-input-label-font-color, var(--t-input-label-font-color, inherit));font-size:var(--tct-input-label-font-size, var(--t-input-label-font-size, inherit));font-weight:var(--tct-input-label-font-weight, var(--t-input-label-font-weight, 600));letter-spacing:var(--tct-input-label-letter-spacing, var(--t-input-label-letter-spacing, inherit));line-height:var(--tct-input-label-line-height, var(--t-input-label-line-height, inherit));text-align:center;text-transform:var(--tct-input-label-text-transform, var(--t-input-label-text-transform, none));transition:color var(--comp-otp-tween);width:100%}.helper-text{color:var(--tct-otp-helper-font-color, var(--t-textA, var(--t-a11y-gray-color, rgba(77, 77, 77, 0.77))));font-size:var(--tct-otp-helper-font-size, var(--app-font-size-small, 12px));text-align:center}.otp-content{align-items:center;display:inline-flex;flex-direction:column;gap:var(--comp-otp-vertical-gap);max-width:100%}.send-code-hidden{clip:rect(0, 0, 0, 0);height:1px;overflow:hidden;position:absolute;width:1px}.otp-control-group{align-items:center;display:flex;flex-direction:column;gap:var(--comp-otp-vertical-gap);max-width:100%;width:max-content}.fields-container{align-items:center;display:flex;flex-wrap:nowrap;gap:var(--comp-otp-field-gap);justify-content:center;pointer-events:none;position:relative;width:max-content}.fields-shell{max-width:100%;padding:4px;position:relative;width:max-content}.otp-hidden-input{appearance:none;-webkit-appearance:none;background:transparent;border:0;caret-color:transparent;color:transparent;cursor:text;font-size:16px;height:100%;inset:0;margin:0;opacity:1;outline:none;padding:0;pointer-events:auto;position:absolute;width:100%;z-index:1;-webkit-tap-highlight-color:transparent;-webkit-text-fill-color:transparent}.otp-hidden-input::selection{background:transparent;color:transparent}.otp-hidden-input:focus,.otp-hidden-input:focus-visible{outline:none;box-shadow:none}.otp-hidden-input:disabled{cursor:not-allowed}.otp-slot{align-items:center;background:var(--comp-otp-field-background);border-color:var(--comp-otp-field-border-color);border-radius:var(--comp-otp-field-border-radius);border-style:solid;border-width:var(--comp-otp-field-border-width);box-sizing:border-box;color:var(--comp-otp-field-font-color);display:flex;flex:0 0 var(--comp-otp-field-size);height:var(--comp-otp-field-size);justify-content:center;position:relative;transition:border-color var(--comp-otp-tween), box-shadow var(--comp-otp-tween), opacity var(--comp-otp-tween);width:var(--comp-otp-field-size)}.otp-slot.is-active{border-color:var(--tct-otp-field-focus-border-color, var(--comp-otp-field-border-color));box-shadow:var(--comp-otp-field-focus-box-shadow)}.otp-slot .otp-caret{animation:otp-caret-blink 1s step-end infinite;background:currentColor;display:block;height:50%;pointer-events:none;width:2px}.state-error .otp-slot{border-color:var(--comp-otp-field-error-border-color)}.state-error .otp-slot.is-active{box-shadow:var(--comp-otp-field-error-focus-box-shadow)}.state-success .otp-slot{border-color:var(--comp-otp-field-success-border-color)}.state-success .otp-slot.is-active{box-shadow:var(--comp-otp-field-success-focus-box-shadow)}:host([disabled]) .otp-slot{opacity:var(--comp-otp-field-disabled-opacity)}:host([disabled]) .otp-hidden-input{cursor:not-allowed}@keyframes otp-caret-blink{0%,100%{opacity:1}50%{opacity:0}}.otp-char{color:var(--comp-otp-field-font-color);font-family:inherit;font-size:var(--comp-otp-field-font-size);font-weight:var(--comp-otp-field-font-weight);line-height:1;pointer-events:none;user-select:none}.otp-dot{background:var(--comp-otp-field-masked-color);border-radius:50%;display:block;height:var(--comp-otp-field-masked-size);pointer-events:none;width:var(--comp-otp-field-masked-size)}.otp-separator{color:var(--comp-otp-separator-color);font-size:var(--comp-otp-separator-font-size);font-weight:var(--comp-otp-separator-font-weight)}.submit-button{width:100%}.processing-overlay{align-items:center;background:var(--tct-otp-processing-overlay-background, rgba(255, 255, 255, 0.72));border-radius:var(--comp-otp-field-border-radius);display:flex;inset:0;justify-content:center;pointer-events:auto;position:absolute;--tct-loading-spinner-size:var(--tct-otp-processing-spinner-size, 32px);z-index:1}.otp-message{margin:0;text-align:center;width:100%}";
|
|
6
|
+
|
|
7
|
+
const l = class {
|
|
8
|
+
constructor(i) {
|
|
9
|
+
t(this, i);
|
|
10
|
+
this.tctClear = e(this, "tctClear", 7);
|
|
11
|
+
this.tctComplete = e(this, "tctComplete", 7);
|
|
12
|
+
this.tctInput = e(this, "tctInput", 7);
|
|
13
|
+
this.tctSendCode = e(this, "tctSendCode", 7);
|
|
14
|
+
this.tctSubmit = e(this, "tctSubmit", 7);
|
|
15
|
+
// #region Own Properties
|
|
16
|
+
this.defaultSendCodeLabel = "tecton.element.otp.sendCode";
|
|
17
|
+
this.defaultSendCodeLabelValue = "Send code";
|
|
18
|
+
this.defaultSubmitLabel = "tecton.element.otp.verify";
|
|
19
|
+
this.defaultSubmitLabelValue = "Verify";
|
|
20
|
+
this.guid = s();
|
|
21
|
+
this.hasAutoFocused = false;
|
|
22
|
+
// #endregion
|
|
23
|
+
// #region State Properties
|
|
24
|
+
this.hasFocus = false;
|
|
25
|
+
// #endregion
|
|
26
|
+
// #region Public Property API
|
|
27
|
+
/** Focuses the first one-time password field when the component loads. */ this.autoFocus = false;
|
|
28
|
+
/** Triggers submission when the last field is filled. */ this.autoSubmit = false;
|
|
29
|
+
/** Clears all fields and returns focus to the first field when `state` becomes `error`. */ this.clearOnError = false;
|
|
30
|
+
/** Disables all one-time password fields. */ this.disabled = false;
|
|
31
|
+
/** Number of one-time password fields. */ this.length = 4 | 6 | 8;
|
|
32
|
+
/** Obscures entered characters. */ this.masked = false;
|
|
33
|
+
/** Toggles helper text visibility. */ this.showHelperText = false;
|
|
34
|
+
/**
|
|
35
|
+
* Renders fields in two equal groups with a dash separator.
|
|
36
|
+
* @private
|
|
37
|
+
*/ this.split = false;
|
|
38
|
+
/** The composed one-time password value. */ this.value = "";
|
|
39
|
+
this.handleFocusIn = () => {
|
|
40
|
+
if (this.state === "error") {
|
|
41
|
+
this.value = "";
|
|
42
|
+
if (this.inputRef) this.inputRef.value = "";
|
|
43
|
+
this.state = undefined;
|
|
44
|
+
}
|
|
45
|
+
this.hasFocus = true;
|
|
46
|
+
};
|
|
47
|
+
this.handleFocusOut = t => {
|
|
48
|
+
if (this.autoFocus && this.hasAutoFocused && !this.value && !t.relatedTarget) {
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
this.hasFocus = false;
|
|
52
|
+
};
|
|
53
|
+
this.handleInputEvent = () => {
|
|
54
|
+
if (this.disabled || this.locksInput) {
|
|
55
|
+
this.inputRef.value = this.value;
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
const t = this.filterDigits(this.inputRef.value);
|
|
59
|
+
this.inputRef.value = t;
|
|
60
|
+
if (this.state === "error") {
|
|
61
|
+
this.state = undefined;
|
|
62
|
+
}
|
|
63
|
+
this.value = t;
|
|
64
|
+
this.tctInput.emit({
|
|
65
|
+
value: t
|
|
66
|
+
});
|
|
67
|
+
if (t.length === this.normalizedLength) {
|
|
68
|
+
this.handleComplete(t);
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
this.handleKeyDown = t => {
|
|
72
|
+
if (t.key !== "Enter") return;
|
|
73
|
+
if (this.disabled || this.locksInput || !this.isComplete) return;
|
|
74
|
+
t.preventDefault();
|
|
75
|
+
this.submit();
|
|
76
|
+
};
|
|
77
|
+
this.handlePaste = t => {
|
|
78
|
+
var e, i;
|
|
79
|
+
t.preventDefault();
|
|
80
|
+
if (this.disabled || this.locksInput) return;
|
|
81
|
+
const o = (i = (e = t.clipboardData) === null || e === void 0 ? void 0 : e.getData("text")) !== null && i !== void 0 ? i : "";
|
|
82
|
+
const s = this.filterDigits(o);
|
|
83
|
+
this.inputRef.value = s;
|
|
84
|
+
if (this.state === "error") {
|
|
85
|
+
this.state = undefined;
|
|
86
|
+
}
|
|
87
|
+
this.value = s;
|
|
88
|
+
this.tctInput.emit({
|
|
89
|
+
value: s
|
|
90
|
+
});
|
|
91
|
+
if (s.length === this.normalizedLength) {
|
|
92
|
+
this.handleComplete(s);
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
this.handleSendCodeClick = () => {
|
|
96
|
+
var t;
|
|
97
|
+
if (this.disabled) return;
|
|
98
|
+
(t = this.inputRef) === null || t === void 0 ? void 0 : t.focus();
|
|
99
|
+
this.state = undefined;
|
|
100
|
+
this.tctSendCode.emit();
|
|
101
|
+
};
|
|
102
|
+
this.handleSubmitClick = () => {
|
|
103
|
+
if (this.isVerifying || this.isSuccess) return;
|
|
104
|
+
this.submit();
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
// #endregion
|
|
108
|
+
// #region Component Lifecycle Events
|
|
109
|
+
componentWillLoad() {
|
|
110
|
+
this.value = this.filterDigits(this.value);
|
|
111
|
+
}
|
|
112
|
+
componentDidLoad() {
|
|
113
|
+
r(this.hostElement);
|
|
114
|
+
this.focusOnLoad();
|
|
115
|
+
}
|
|
116
|
+
componentDidRender() {
|
|
117
|
+
this.focusOnLoad();
|
|
118
|
+
}
|
|
119
|
+
// #endregion
|
|
120
|
+
// #region Listeners
|
|
121
|
+
onHostElementFocus(t) {
|
|
122
|
+
var e, i;
|
|
123
|
+
if (this.disabled || this.locksInput) return;
|
|
124
|
+
if (!a(t, this.hostElement)) return;
|
|
125
|
+
if (this.isAwaitingSendCode) {
|
|
126
|
+
(e = this.sendCodeRef) === null || e === void 0 ? void 0 : e.focus();
|
|
127
|
+
return;
|
|
128
|
+
}
|
|
129
|
+
(i = this.inputRef) === null || i === void 0 ? void 0 : i.focus();
|
|
130
|
+
}
|
|
131
|
+
// #endregion
|
|
132
|
+
// #region Public Methods API
|
|
133
|
+
/**
|
|
134
|
+
* Clears all fields, focuses the first field, and emits `tctClear`.
|
|
135
|
+
*/
|
|
136
|
+
async clear() {
|
|
137
|
+
this.clearValue(true);
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Clears the component and resets error, success, and processing state.
|
|
141
|
+
*/ async reset() {
|
|
142
|
+
this.clearValue(true);
|
|
143
|
+
this.state = undefined;
|
|
144
|
+
}
|
|
145
|
+
// #endregion
|
|
146
|
+
// #region Watchers
|
|
147
|
+
autoFocusObserver() {
|
|
148
|
+
this.focusOnLoad();
|
|
149
|
+
}
|
|
150
|
+
lengthObserver() {
|
|
151
|
+
if (this.value.length > this.normalizedLength) {
|
|
152
|
+
this.value = this.value.slice(0, this.normalizedLength);
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
stateObserver(t) {
|
|
156
|
+
if (t === null) {
|
|
157
|
+
Promise.resolve().then((() => {
|
|
158
|
+
if (this.state === null) this.state = undefined;
|
|
159
|
+
}));
|
|
160
|
+
return;
|
|
161
|
+
}
|
|
162
|
+
if (t === "error" && this.clearOnError) {
|
|
163
|
+
this.clearValue(true);
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
valueObserver() {
|
|
167
|
+
const t = this.filterDigits(this.value);
|
|
168
|
+
if (t !== this.value) {
|
|
169
|
+
this.value = t;
|
|
170
|
+
}
|
|
171
|
+
if (this.inputRef && this.inputRef.value !== t) {
|
|
172
|
+
this.inputRef.value = t;
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
// #endregion
|
|
176
|
+
// #region Local Methods
|
|
177
|
+
get activeSlotIndex() {
|
|
178
|
+
return Math.min(this.value.length, this.normalizedLength - 1);
|
|
179
|
+
}
|
|
180
|
+
get componentId() {
|
|
181
|
+
return `q2-otp-${this.guid}`;
|
|
182
|
+
}
|
|
183
|
+
get describedBy() {
|
|
184
|
+
const t = [];
|
|
185
|
+
if (this.state === "error" && this.errorMessage) t.push(this.messageId);
|
|
186
|
+
if (this.state === "success" && this.successMessage) t.push(this.messageId);
|
|
187
|
+
return t.length ? t.join(" ") : undefined;
|
|
188
|
+
}
|
|
189
|
+
get hasVisibleHelperText() {
|
|
190
|
+
return this.showHelperText && !!this.helperText;
|
|
191
|
+
}
|
|
192
|
+
get helperTextId() {
|
|
193
|
+
return `${this.componentId}-helper-text`;
|
|
194
|
+
}
|
|
195
|
+
get inputAriaLabel() {
|
|
196
|
+
const t = `${this.localizedLabel} (${this.normalizedLength} ${n("tecton.element.otp.digits")})`;
|
|
197
|
+
return [ this.hasVisibleHelperText ? this.localizedHelperText : "", t ].filter(Boolean).join(" ");
|
|
198
|
+
}
|
|
199
|
+
get isAwaitingSendCode() {
|
|
200
|
+
return this.state === "ready";
|
|
201
|
+
}
|
|
202
|
+
get isComplete() {
|
|
203
|
+
return this.value.length === this.normalizedLength;
|
|
204
|
+
}
|
|
205
|
+
get isSuccess() {
|
|
206
|
+
return this.state === "success";
|
|
207
|
+
}
|
|
208
|
+
get isVerifying() {
|
|
209
|
+
return this.state === "verifying";
|
|
210
|
+
}
|
|
211
|
+
get labelId() {
|
|
212
|
+
return `${this.componentId}-label`;
|
|
213
|
+
}
|
|
214
|
+
get localizedHelperText() {
|
|
215
|
+
return n(this.helperText);
|
|
216
|
+
}
|
|
217
|
+
get localizedLabel() {
|
|
218
|
+
return n(this.label);
|
|
219
|
+
}
|
|
220
|
+
get localizedProcessingLabel() {
|
|
221
|
+
return n(this.processingLabel || "Verifying");
|
|
222
|
+
}
|
|
223
|
+
get localizedSendCodeLabel() {
|
|
224
|
+
if (this.sendCodeLabel) return n(this.sendCodeLabel);
|
|
225
|
+
const t = n(this.defaultSendCodeLabel);
|
|
226
|
+
return t === this.defaultSendCodeLabel ? this.defaultSendCodeLabelValue : t;
|
|
227
|
+
}
|
|
228
|
+
get localizedSubmitLabel() {
|
|
229
|
+
if (this.submitLabel) return n(this.submitLabel);
|
|
230
|
+
const t = n(this.defaultSubmitLabel);
|
|
231
|
+
return t === this.defaultSubmitLabel ? this.defaultSubmitLabelValue : t;
|
|
232
|
+
}
|
|
233
|
+
get locksInput() {
|
|
234
|
+
return this.isVerifying || this.isSuccess;
|
|
235
|
+
}
|
|
236
|
+
get messageId() {
|
|
237
|
+
return `${this.componentId}-message`;
|
|
238
|
+
}
|
|
239
|
+
get normalizedLength() {
|
|
240
|
+
const t = Number(this.length);
|
|
241
|
+
return [ 4, 6, 8 ].includes(t) ? t : 6;
|
|
242
|
+
}
|
|
243
|
+
clearValue(t = false) {
|
|
244
|
+
var e;
|
|
245
|
+
this.value = "";
|
|
246
|
+
if (this.inputRef) this.inputRef.value = "";
|
|
247
|
+
(e = this.inputRef) === null || e === void 0 ? void 0 : e.focus();
|
|
248
|
+
if (t) this.tctClear.emit({
|
|
249
|
+
value: ""
|
|
250
|
+
});
|
|
251
|
+
}
|
|
252
|
+
filterDigits(t) {
|
|
253
|
+
return t.replace(/\D/g, "").slice(0, this.normalizedLength);
|
|
254
|
+
}
|
|
255
|
+
focusOnLoad() {
|
|
256
|
+
if (!this.autoFocus || this.hasAutoFocused || this.disabled || this.locksInput) return;
|
|
257
|
+
setTimeout((() => {
|
|
258
|
+
if (!this.autoFocus || this.hasAutoFocused || this.disabled || this.locksInput || !this.inputRef) {
|
|
259
|
+
return;
|
|
260
|
+
}
|
|
261
|
+
this.hasAutoFocused = true;
|
|
262
|
+
this.hasFocus = true;
|
|
263
|
+
this.inputRef.focus();
|
|
264
|
+
}), 100);
|
|
265
|
+
}
|
|
266
|
+
handleComplete(t) {
|
|
267
|
+
this.tctComplete.emit({
|
|
268
|
+
value: t
|
|
269
|
+
});
|
|
270
|
+
if (this.autoSubmit) {
|
|
271
|
+
setTimeout((() => this.submit(t)), 150);
|
|
272
|
+
}
|
|
273
|
+
}
|
|
274
|
+
submit(t = this.value) {
|
|
275
|
+
this.state = "verifying";
|
|
276
|
+
this.tctSubmit.emit({
|
|
277
|
+
value: t
|
|
278
|
+
});
|
|
279
|
+
}
|
|
280
|
+
// #endregion
|
|
281
|
+
// #region Render Methods
|
|
282
|
+
renderFields() {
|
|
283
|
+
return Array.from({
|
|
284
|
+
length: this.normalizedLength
|
|
285
|
+
}, ((t, e) => {
|
|
286
|
+
const o = this.value[e] || "";
|
|
287
|
+
const s = this.hasFocus && e === this.activeSlotIndex;
|
|
288
|
+
const r = !!o;
|
|
289
|
+
return [ this.split && e === this.normalizedLength / 2 && i("span", {
|
|
290
|
+
"aria-hidden": "true",
|
|
291
|
+
class: "otp-separator"
|
|
292
|
+
}, "-"), i("div", {
|
|
293
|
+
class: {
|
|
294
|
+
"otp-slot": true,
|
|
295
|
+
"is-active": s,
|
|
296
|
+
"has-value": r
|
|
297
|
+
}
|
|
298
|
+
}, s && !r ? i("span", {
|
|
299
|
+
class: "otp-caret",
|
|
300
|
+
"aria-hidden": "true"
|
|
301
|
+
}) : this.masked && r ? i("span", {
|
|
302
|
+
class: "otp-dot"
|
|
303
|
+
}) : i("span", {
|
|
304
|
+
class: "otp-char"
|
|
305
|
+
}, o)) ];
|
|
306
|
+
}));
|
|
307
|
+
}
|
|
308
|
+
renderHelperText() {
|
|
309
|
+
if (!this.hasVisibleHelperText) return;
|
|
310
|
+
return i("div", {
|
|
311
|
+
class: "helper-text",
|
|
312
|
+
id: this.helperTextId
|
|
313
|
+
}, this.localizedHelperText);
|
|
314
|
+
}
|
|
315
|
+
renderLabel() {
|
|
316
|
+
if (!this.label) return;
|
|
317
|
+
return i("div", {
|
|
318
|
+
class: "otp-label",
|
|
319
|
+
id: this.labelId
|
|
320
|
+
}, this.localizedLabel);
|
|
321
|
+
}
|
|
322
|
+
renderMessage() {
|
|
323
|
+
if (this.state === "error" && this.errorMessage) {
|
|
324
|
+
return i("q2-message", {
|
|
325
|
+
appearance: "minimal",
|
|
326
|
+
class: "otp-message",
|
|
327
|
+
id: this.messageId,
|
|
328
|
+
type: "error"
|
|
329
|
+
}, n(this.errorMessage));
|
|
330
|
+
}
|
|
331
|
+
if (this.state === "success" && this.successMessage) {
|
|
332
|
+
return i("q2-message", {
|
|
333
|
+
appearance: "minimal",
|
|
334
|
+
class: "otp-message",
|
|
335
|
+
id: this.messageId,
|
|
336
|
+
type: "success"
|
|
337
|
+
}, n(this.successMessage));
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
renderProcessingOverlay() {
|
|
341
|
+
if (this.autoSubmit && this.isVerifying) {
|
|
342
|
+
return i("div", {
|
|
343
|
+
class: "processing-overlay"
|
|
344
|
+
}, i("q2-loading", {
|
|
345
|
+
label: this.localizedProcessingLabel
|
|
346
|
+
}));
|
|
347
|
+
}
|
|
348
|
+
}
|
|
349
|
+
renderSendCodeButton() {
|
|
350
|
+
if (!this.isAwaitingSendCode) return;
|
|
351
|
+
return i("q2-btn", {
|
|
352
|
+
block: true,
|
|
353
|
+
class: "send-code-button",
|
|
354
|
+
disabled: this.disabled,
|
|
355
|
+
intent: "workflow-primary",
|
|
356
|
+
label: this.localizedSendCodeLabel,
|
|
357
|
+
onClick: this.handleSendCodeClick,
|
|
358
|
+
ref: t => this.sendCodeRef = t
|
|
359
|
+
});
|
|
360
|
+
}
|
|
361
|
+
renderSubmitArea() {
|
|
362
|
+
if (this.isSuccess) {
|
|
363
|
+
return i("q2-btn", {
|
|
364
|
+
block: true,
|
|
365
|
+
class: "submit-button",
|
|
366
|
+
intent: "neutral",
|
|
367
|
+
onClick: this.handleSubmitClick
|
|
368
|
+
}, i("q2-icon", {
|
|
369
|
+
type: "checkmark"
|
|
370
|
+
}), n("Success"));
|
|
371
|
+
}
|
|
372
|
+
return i("q2-btn", {
|
|
373
|
+
block: true,
|
|
374
|
+
class: "submit-button",
|
|
375
|
+
disabled: this.disabled || !this.isComplete,
|
|
376
|
+
intent: "workflow-primary",
|
|
377
|
+
label: this.isVerifying ? this.localizedProcessingLabel : this.localizedSubmitLabel,
|
|
378
|
+
loading: this.isVerifying,
|
|
379
|
+
onClick: this.handleSubmitClick
|
|
380
|
+
});
|
|
381
|
+
}
|
|
382
|
+
render() {
|
|
383
|
+
return i("div", {
|
|
384
|
+
key: "3befb9c99f5fa35e6f7d653b256306513499e2fe",
|
|
385
|
+
"aria-busy": this.isVerifying ? "true" : undefined,
|
|
386
|
+
"aria-labelledby": this.label ? this.labelId : undefined,
|
|
387
|
+
class: {
|
|
388
|
+
"otp-container": true,
|
|
389
|
+
"has-focus": this.hasFocus,
|
|
390
|
+
"is-masked": this.masked,
|
|
391
|
+
"send-code-pending": this.isAwaitingSendCode,
|
|
392
|
+
"state-error": this.state === "error",
|
|
393
|
+
"state-success": this.state === "success",
|
|
394
|
+
"state-verifying": this.isVerifying,
|
|
395
|
+
[`length-${this.normalizedLength}`]: true
|
|
396
|
+
},
|
|
397
|
+
role: "group"
|
|
398
|
+
}, this.renderSendCodeButton(), i("div", {
|
|
399
|
+
key: "813749faba075fda49bc4aa05366479b386b9256",
|
|
400
|
+
class: {
|
|
401
|
+
"otp-content": true,
|
|
402
|
+
"send-code-hidden": this.isAwaitingSendCode
|
|
403
|
+
}
|
|
404
|
+
}, this.renderLabel(), i("div", {
|
|
405
|
+
key: "b9e4967cebebbec209359b6463502d9daab9a587",
|
|
406
|
+
class: "otp-control-group"
|
|
407
|
+
}, i("div", {
|
|
408
|
+
key: "611bff112f241cde331858545954a9dd3ce4d116",
|
|
409
|
+
class: "fields-shell"
|
|
410
|
+
}, i("div", {
|
|
411
|
+
key: "38b2d554c171c8b20ec075e2f9ccb6822274214d",
|
|
412
|
+
class: "fields-container"
|
|
413
|
+
}, i("input", {
|
|
414
|
+
key: "3a2f27e7aa17940b070b1c7ce9b472d8c498192e",
|
|
415
|
+
"aria-describedby": this.describedBy,
|
|
416
|
+
"aria-invalid": this.state === "error" ? "true" : "false",
|
|
417
|
+
"aria-label": this.inputAriaLabel,
|
|
418
|
+
autocomplete: "one-time-code",
|
|
419
|
+
autofocus: this.autoFocus,
|
|
420
|
+
class: "otp-hidden-input",
|
|
421
|
+
disabled: this.disabled || this.isVerifying || this.isSuccess,
|
|
422
|
+
inputmode: "numeric",
|
|
423
|
+
maxLength: this.normalizedLength,
|
|
424
|
+
onBlur: this.handleFocusOut,
|
|
425
|
+
onFocus: this.handleFocusIn,
|
|
426
|
+
onInput: this.handleInputEvent,
|
|
427
|
+
onKeyDown: this.handleKeyDown,
|
|
428
|
+
onPaste: this.handlePaste,
|
|
429
|
+
pattern: "[0-9]*",
|
|
430
|
+
ref: t => this.inputRef = t,
|
|
431
|
+
"test-id": "q2OtpInput",
|
|
432
|
+
type: "text",
|
|
433
|
+
value: this.value
|
|
434
|
+
}), this.renderFields()), this.renderProcessingOverlay()), this.renderSubmitArea(), this.renderMessage()), this.renderHelperText()));
|
|
435
|
+
}
|
|
436
|
+
get hostElement() {
|
|
437
|
+
return o(this);
|
|
438
|
+
}
|
|
439
|
+
static get watchers() {
|
|
440
|
+
return {
|
|
441
|
+
autoFocus: [ "autoFocusObserver" ],
|
|
442
|
+
length: [ "lengthObserver" ],
|
|
443
|
+
state: [ "stateObserver" ],
|
|
444
|
+
value: [ "valueObserver" ]
|
|
445
|
+
};
|
|
446
|
+
}
|
|
447
|
+
};
|
|
448
|
+
|
|
449
|
+
l.style = c;
|
|
450
|
+
|
|
451
|
+
export { l as q2_otp };
|
|
452
|
+
//# sourceMappingURL=q2-otp.entry.esm.js.map
|
|
453
|
+
//# sourceMappingURL=q2-otp.entry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["q2OtpCss","Q2Otp","constructor","hostRef","this","defaultSendCodeLabel","defaultSendCodeLabelValue","defaultSubmitLabel","defaultSubmitLabelValue","guid","createGuid","hasAutoFocused","hasFocus","autoFocus","autoSubmit","clearOnError","disabled","length","masked","showHelperText","split","value","handleFocusIn","state","inputRef","undefined","handleFocusOut","event","relatedTarget","handleInputEvent","locksInput","digits","filterDigits","tctInput","emit","normalizedLength","handleComplete","handleKeyDown","key","isComplete","preventDefault","submit","handlePaste","pastedValue","_b","_a","clipboardData","getData","handleSendCodeClick","focus","tctSendCode","handleSubmitClick","isVerifying","isSuccess","componentWillLoad","componentDidLoad","overrideFocus","hostElement","focusOnLoad","componentDidRender","onHostElementFocus","isEventFromElement","isAwaitingSendCode","sendCodeRef","clear","clearValue","reset","autoFocusObserver","lengthObserver","slice","stateObserver","Promise","resolve","then","valueObserver","activeSlotIndex","Math","min","componentId","describedBy","ids","errorMessage","push","messageId","successMessage","join","hasVisibleHelperText","helperText","helperTextId","inputAriaLabel","inputLabel","localizedLabel","loc","localizedHelperText","filter","Boolean","labelId","label","localizedProcessingLabel","processingLabel","localizedSendCodeLabel","sendCodeLabel","localizedSubmitLabel","submitLabel","Number","includes","emitEvent","tctClear","replace","setTimeout","tctComplete","tctSubmit","renderFields","Array","from","_","index","char","isActive","hasValue","h","class","renderHelperText","id","renderLabel","renderMessage","appearance","type","renderProcessingOverlay","renderSendCodeButton","block","intent","onClick","ref","el","renderSubmitArea","loading","render","role","autocomplete","autofocus","inputmode","maxLength","onBlur","onFocus","onInput","onKeyDown","onPaste","pattern"],"sources":["src/components/q2-otp/q2-otp.scss?tag=q2-otp&encapsulation=shadow","src/components/q2-otp/q2-otp.tsx"],"sourcesContent":["@import '../../styles/host';\n@import '../../styles/functions';\n\n:host {\n --comp-default-otp-margin: #{var-list(var-prefixer(otp-margin-top), --app-scale-5x, 25px) 0\n var-list(var-prefixer(otp-margin-bottom), --app-scale-5x, 25px)};\n --comp-otp-tween: #{var-list(--tct-otp-tween, --tct-tween-2, --app-tween-2, unquote('0.4s ease'))};\n --comp-otp-vertical-gap: #{var-list(--tct-otp-vertical-gap, --app-scale-4x, 20px)};\n --comp-otp-field-size: 44px;\n --comp-otp-field-gap: #{var-list(--tct-otp-field-gap, --app-scale-2x, 10px)};\n --comp-otp-field-background: #{var-list(--tct-otp-field-background, --t-base, #FFFFFF)};\n --comp-otp-field-border-color: #{var-list(--tct-otp-field-border-color, --t-a11y-gray-color-AA, #404040)};\n --comp-otp-field-border-radius: #{var-list(\n --tct-otp-field-border-radius,\n --tct-border-radius-2,\n --app-border-radius-2,\n 8px\n )};\n --comp-otp-field-border-width: #{var-list(--tct-otp-field-border-width, 1px)};\n --comp-otp-field-font-color: #{var-list(--tct-otp-field-font-color, --t-text, inherit)};\n --comp-otp-field-font-size: #{var-list(--tct-otp-field-font-size, --app-font-size, 16px)};\n --comp-otp-field-masked-color: #{var-list(--tct-otp-field-masked-color, --tct-otp-field-font-color, --t-text, #1f1f1f)};\n --comp-otp-field-masked-size: #{var-list(--tct-otp-field-masked-size, --tct-otp-field-masked-font-size, 8px)};\n --comp-otp-field-font-weight: #{var-list(--tct-otp-field-font-weight, 400)};\n --comp-otp-field-focus-box-shadow: #{var-list(\n --tct-otp-field-focus-box-shadow,\n --const-double-focus-ring,\n unquote('0 0 0 2px #ffffff, 0 0 0 4px #0066cc')\n )};\n --comp-otp-field-error-border-color: #{var-list(--tct-otp-field-error-border-color, --const-stoplight-alert, #C30000)};\n --comp-otp-field-error-focus-ring-color: #{var-list(--tct-otp-field-error-focus-ring-color, #c30000)};\n --comp-otp-field-error-focus-box-shadow: #{var-list(\n --tct-otp-field-error-focus-box-shadow,\n unquote('0 0 0 2px #ffffff, 0 0 0 4px var(--comp-otp-field-error-focus-ring-color)')\n )};\n --comp-otp-field-success-border-color: #{var-list(--tct-otp-field-success-border-color, --const-stoplight-success, #0e8a00)};\n --comp-otp-field-success-focus-ring-color: #{var-list(--tct-otp-field-success-focus-ring-color, #0e8a00)};\n --comp-otp-field-success-focus-box-shadow: #{var-list(\n --tct-otp-field-success-focus-box-shadow,\n unquote('0 0 0 2px #ffffff, 0 0 0 4px var(--comp-otp-field-success-focus-ring-color)')\n )};\n --comp-otp-field-disabled-opacity: #{var-list(\n --tct-otp-field-disabled-opacity,\n --tct-disabled-opacity,\n --app-disabled-opacity,\n 0.4\n )};\n --comp-otp-separator-color: #{var-list(--tct-otp-separator-color, --t-textA, --t-a11y-gray-color, #4d4d4d)};\n --comp-otp-separator-font-size: #{var-list(--tct-otp-separator-font-size, 20px)};\n --comp-otp-separator-font-weight: #{var-list(--tct-otp-separator-font-weight, 600)};\n\n display: flex;\n justify-content: center;\n margin: var-list(--tct-otp-margin, --comp-default-otp-margin);\n font-size: var-list(var-prefixer(input-font-size), --app-font-size, inherit);\n}\n\n:host([hidden]) {\n display: none;\n}\n\n.otp-container {\n align-items: center;\n display: inline-flex;\n flex-direction: column;\n gap: var(--comp-otp-vertical-gap);\n max-width: 100%;\n}\n\n.otp-label {\n display: block;\n color: var-list(var-prefixer(input-label-font-color), inherit);\n font-size: var-list(var-prefixer(input-label-font-size), inherit);\n font-weight: var-list(var-prefixer(input-label-font-weight), 600);\n letter-spacing: var-list(var-prefixer(input-label-letter-spacing), inherit);\n line-height: var-list(var-prefixer(input-label-line-height), inherit);\n text-align: center;\n text-transform: var-list(var-prefixer(input-label-text-transform), none);\n transition: color var(--comp-otp-tween);\n width: 100%;\n}\n\n.helper-text {\n color: var-list(--tct-otp-helper-font-color, --t-textA, --t-a11y-gray-color, rgba(77, 77, 77, 0.77));\n font-size: var-list(--tct-otp-helper-font-size, --app-font-size-small, 12px);\n text-align: center;\n}\n\n.otp-content {\n align-items: center;\n display: inline-flex;\n flex-direction: column;\n gap: var(--comp-otp-vertical-gap);\n max-width: 100%;\n}\n\n.send-code-hidden {\n clip: rect(0, 0, 0, 0);\n height: 1px;\n overflow: hidden;\n position: absolute;\n width: 1px;\n}\n\n.otp-control-group {\n align-items: center;\n display: flex;\n flex-direction: column;\n gap: var(--comp-otp-vertical-gap);\n max-width: 100%;\n width: max-content;\n}\n\n.fields-container {\n align-items: center;\n display: flex;\n flex-wrap: nowrap;\n gap: var(--comp-otp-field-gap);\n justify-content: center;\n pointer-events: none;\n position: relative;\n width: max-content;\n}\n\n.fields-shell {\n max-width: 100%;\n padding: 4px;\n position: relative;\n width: max-content;\n}\n\n.otp-hidden-input {\n appearance: none;\n -webkit-appearance: none;\n background: transparent;\n border: 0;\n caret-color: transparent;\n color: transparent;\n cursor: text;\n font-size: 16px;\n height: 100%;\n inset: 0;\n margin: 0;\n opacity: 1;\n outline: none;\n padding: 0;\n pointer-events: auto;\n position: absolute;\n width: 100%;\n z-index: 1;\n -webkit-tap-highlight-color: transparent;\n -webkit-text-fill-color: transparent;\n\n &::selection {\n background: transparent;\n color: transparent;\n }\n\n &:focus,\n &:focus-visible {\n outline: none;\n box-shadow: none;\n }\n\n &:disabled {\n cursor: not-allowed;\n }\n}\n\n.otp-slot {\n align-items: center;\n background: var(--comp-otp-field-background);\n border-color: var(--comp-otp-field-border-color);\n border-radius: var(--comp-otp-field-border-radius);\n border-style: solid;\n border-width: var(--comp-otp-field-border-width);\n box-sizing: border-box;\n color: var(--comp-otp-field-font-color);\n display: flex;\n flex: 0 0 var(--comp-otp-field-size);\n height: var(--comp-otp-field-size);\n justify-content: center;\n position: relative;\n transition:\n border-color var(--comp-otp-tween),\n box-shadow var(--comp-otp-tween),\n opacity var(--comp-otp-tween);\n width: var(--comp-otp-field-size);\n\n &.is-active {\n border-color: var-list(--tct-otp-field-focus-border-color, --comp-otp-field-border-color);\n box-shadow: var(--comp-otp-field-focus-box-shadow);\n }\n\n .otp-caret {\n animation: otp-caret-blink 1s step-end infinite;\n background: currentColor;\n display: block;\n height: 50%;\n pointer-events: none;\n width: 2px;\n }\n\n .state-error & {\n border-color: var(--comp-otp-field-error-border-color);\n\n &.is-active {\n box-shadow: var(--comp-otp-field-error-focus-box-shadow);\n }\n }\n\n .state-success & {\n border-color: var(--comp-otp-field-success-border-color);\n\n &.is-active {\n box-shadow: var(--comp-otp-field-success-focus-box-shadow);\n }\n }\n}\n\n:host([disabled]) .otp-slot {\n opacity: var(--comp-otp-field-disabled-opacity);\n}\n\n:host([disabled]) .otp-hidden-input {\n cursor: not-allowed;\n}\n\n@keyframes otp-caret-blink {\n 0%, 100% { opacity: 1; }\n 50% { opacity: 0; }\n}\n\n.otp-char {\n color: var(--comp-otp-field-font-color);\n font-family: inherit;\n font-size: var(--comp-otp-field-font-size);\n font-weight: var(--comp-otp-field-font-weight);\n line-height: 1;\n pointer-events: none;\n user-select: none;\n}\n\n.otp-dot {\n background: var(--comp-otp-field-masked-color);\n border-radius: 50%;\n display: block;\n height: var(--comp-otp-field-masked-size);\n pointer-events: none;\n width: var(--comp-otp-field-masked-size);\n}\n\n.otp-separator {\n color: var(--comp-otp-separator-color);\n font-size: var(--comp-otp-separator-font-size);\n font-weight: var(--comp-otp-separator-font-weight);\n}\n\n.submit-button {\n width: 100%;\n}\n\n.processing-overlay {\n align-items: center;\n background: var(--tct-otp-processing-overlay-background, rgba(255, 255, 255, 0.72));\n border-radius: var(--comp-otp-field-border-radius);\n display: flex;\n inset: 0;\n justify-content: center;\n pointer-events: auto;\n position: absolute;\n --tct-loading-spinner-size: var(--tct-otp-processing-spinner-size, 32px);\n z-index: 1;\n}\n\n.otp-message {\n margin: 0;\n text-align: center;\n width: 100%;\n}\n","import { Component, Element, Event, EventEmitter, h, Listen, Method, Prop, State, Watch } from '@stencil/core';\nimport { createGuid, isEventFromElement, loc, overrideFocus } from 'src/utils';\n\n/**\n * @name One-Time Password\n * @category Forms\n * @summary Use for entering a short one-time verification code.\n */\n@Component({ tag: 'q2-otp', shadow: true, styleUrl: 'q2-otp.scss' })\nexport class Q2Otp {\n // #region Own Properties\n\n private readonly defaultSendCodeLabel = 'tecton.element.otp.sendCode';\n private readonly defaultSendCodeLabelValue = 'Send code';\n private readonly defaultSubmitLabel = 'tecton.element.otp.verify';\n private readonly defaultSubmitLabelValue = 'Verify';\n guid = createGuid();\n hasAutoFocused = false;\n inputRef: HTMLInputElement;\n sendCodeRef: HTMLElement;\n\n // #endregion\n // #region Host HTML Element\n\n @Element()\n hostElement: HTMLElement;\n\n // #endregion\n // #region State Properties\n\n @State()\n hasFocus: boolean = false;\n\n // #endregion\n // #region Public Property API\n\n /** Focuses the first one-time password field when the component loads. */\n @Prop({ reflect: true })\n autoFocus: boolean = false;\n\n /** Triggers submission when the last field is filled. */\n @Prop({ reflect: true })\n autoSubmit: boolean = false;\n\n /** Clears all fields and returns focus to the first field when `state` becomes `error`. */\n @Prop({ reflect: true })\n clearOnError: boolean = false;\n\n /** Disables all one-time password fields. */\n @Prop({ reflect: true })\n disabled: boolean = false;\n\n /**\n * Error message rendered below the submit area.\n * @localizable\n */\n @Prop()\n errorMessage: string;\n\n /**\n * Helper text content.\n * @localizable\n */\n @Prop()\n helperText: string;\n\n /**\n * Visible label above the one-time password fields.\n * @localizable\n */\n @Prop({ reflect: true })\n label: string;\n\n /** Number of one-time password fields. */\n @Prop({ reflect: true })\n length: number = 4 | 6 | 8;\n\n /** Obscures entered characters. */\n @Prop({ reflect: true })\n masked: boolean = false;\n\n /**\n * Button text during processing.\n * @localizable\n */\n @Prop()\n processingLabel: string;\n\n /**\n * Button text for the send-code action.\n * @localizable\n */\n @Prop()\n sendCodeLabel: string;\n\n /** Toggles helper text visibility. */\n @Prop({ reflect: true })\n showHelperText: boolean = false;\n\n /**\n * Renders fields in two equal groups with a dash separator.\n * @private\n */\n @Prop({ reflect: true })\n split: boolean = false;\n\n /**\n * Sets the visual status for the one-time password fields.\n *\n * - `ready` — Shows the send-code button and hides the input fields until the user requests a code.\n * - `error` — Displays an error style on the fields. If `errorMessage` is set, it renders below the submit area.\n * When `clearOnError` is enabled, all fields are cleared and focus returns to the first field.\n * - `success` — Locks the input, replaces the submit button with a success indicator, and displays the\n * `successMessage` if provided.\n * - `verifying` — Locks the input and puts the submit button into a loading state. When combined with `autoSubmit`,\n * a processing overlay with `processingLabel` is shown over the fields.\n */\n @Prop({ reflect: true, mutable: true })\n state: 'error' | 'ready' | 'success' | 'verifying' | undefined;\n\n /**\n * Renders a submit button with this label.\n * @localizable\n */\n @Prop()\n submitLabel: string;\n\n /**\n * Success message rendered below the submit area.\n * @localizable\n */\n @Prop()\n successMessage: string;\n\n /** The composed one-time password value. */\n @Prop({ mutable: true })\n value: string = '';\n\n // #endregion\n // #region Events\n\n /** Emitted when the fields are cleared. */\n @Event()\n tctClear: EventEmitter<{ value: string }>;\n\n /** Emitted when all fields are filled. */\n @Event()\n tctComplete: EventEmitter<{ value: string }>;\n\n /** Emitted when any field value changes. */\n @Event()\n tctInput: EventEmitter<{ value: string }>;\n\n /** Emitted when the send-code button is clicked. */\n @Event()\n tctSendCode: EventEmitter<void>;\n\n /** Emitted when the submit button is clicked or auto-submit triggers. */\n @Event()\n tctSubmit: EventEmitter<{ value: string }>;\n\n // #endregion\n // #region Component Lifecycle Events\n\n componentWillLoad(): void {\n this.value = this.filterDigits(this.value);\n }\n\n componentDidLoad(): void {\n overrideFocus(this.hostElement);\n this.focusOnLoad();\n }\n\n componentDidRender(): void {\n this.focusOnLoad();\n }\n\n // #endregion\n // #region Listeners\n\n @Listen('focus')\n onHostElementFocus(event: FocusEvent): void {\n if (this.disabled || this.locksInput) return;\n if (!isEventFromElement(event, this.hostElement)) return;\n if (this.isAwaitingSendCode) {\n this.sendCodeRef?.focus();\n return;\n }\n this.inputRef?.focus();\n }\n\n // #endregion\n // #region Public Methods API\n\n /**\n * Clears all fields, focuses the first field, and emits `tctClear`.\n */\n @Method()\n async clear(): Promise<void> {\n this.clearValue(true);\n }\n\n /**\n * Clears the component and resets error, success, and processing state.\n */\n @Method()\n async reset(): Promise<void> {\n this.clearValue(true);\n this.state = undefined;\n }\n\n // #endregion\n // #region Watchers\n\n @Watch('autoFocus')\n autoFocusObserver(): void {\n this.focusOnLoad();\n }\n\n @Watch('length')\n lengthObserver(): void {\n if (this.value.length > this.normalizedLength) {\n this.value = this.value.slice(0, this.normalizedLength);\n }\n }\n\n @Watch('state')\n stateObserver(state: string | null): void {\n if (state === null) {\n Promise.resolve().then(() => {\n if (this.state === null) this.state = undefined;\n });\n return;\n }\n\n if (state === 'error' && this.clearOnError) {\n this.clearValue(true);\n }\n }\n\n @Watch('value')\n valueObserver(): void {\n const digits = this.filterDigits(this.value);\n if (digits !== this.value) {\n this.value = digits;\n }\n if (this.inputRef && this.inputRef.value !== digits) {\n this.inputRef.value = digits;\n }\n }\n\n // #endregion\n // #region Local Methods\n\n get activeSlotIndex(): number {\n return Math.min(this.value.length, this.normalizedLength - 1);\n }\n\n get componentId(): string {\n return `q2-otp-${this.guid}`;\n }\n\n get describedBy(): string | undefined {\n const ids = [];\n if (this.state === 'error' && this.errorMessage) ids.push(this.messageId);\n if (this.state === 'success' && this.successMessage) ids.push(this.messageId);\n return ids.length ? ids.join(' ') : undefined;\n }\n\n get hasVisibleHelperText(): boolean {\n return this.showHelperText && !!this.helperText;\n }\n\n get helperTextId(): string {\n return `${this.componentId}-helper-text`;\n }\n\n get inputAriaLabel(): string {\n const inputLabel = `${this.localizedLabel} (${this.normalizedLength} ${loc('tecton.element.otp.digits')})`;\n return [this.hasVisibleHelperText ? this.localizedHelperText : '', inputLabel].filter(Boolean).join(' ');\n }\n\n get isAwaitingSendCode(): boolean {\n return this.state === 'ready';\n }\n\n get isComplete(): boolean {\n return this.value.length === this.normalizedLength;\n }\n\n get isSuccess(): boolean {\n return this.state === 'success';\n }\n\n get isVerifying(): boolean {\n return this.state === 'verifying';\n }\n\n get labelId(): string {\n return `${this.componentId}-label`;\n }\n\n get localizedHelperText(): string {\n return loc(this.helperText);\n }\n\n get localizedLabel(): string {\n return loc(this.label);\n }\n\n get localizedProcessingLabel(): string {\n return loc(this.processingLabel || 'Verifying');\n }\n\n get localizedSendCodeLabel(): string {\n if (this.sendCodeLabel) return loc(this.sendCodeLabel);\n\n const localizedLabel = loc(this.defaultSendCodeLabel);\n return localizedLabel === this.defaultSendCodeLabel ? this.defaultSendCodeLabelValue : localizedLabel;\n }\n\n get localizedSubmitLabel(): string {\n if (this.submitLabel) return loc(this.submitLabel);\n\n const localizedLabel = loc(this.defaultSubmitLabel);\n return localizedLabel === this.defaultSubmitLabel ? this.defaultSubmitLabelValue : localizedLabel;\n }\n\n get locksInput(): boolean {\n return this.isVerifying || this.isSuccess;\n }\n\n get messageId(): string {\n return `${this.componentId}-message`;\n }\n\n get normalizedLength() {\n const length = Number(this.length);\n return [4, 6, 8].includes(length) ? length : 6;\n }\n\n clearValue(emitEvent = false): void {\n this.value = '';\n if (this.inputRef) this.inputRef.value = '';\n this.inputRef?.focus();\n if (emitEvent) this.tctClear.emit({ value: '' });\n }\n\n filterDigits(value: string): string {\n return value.replace(/\\D/g, '').slice(0, this.normalizedLength);\n }\n\n focusOnLoad(): void {\n if (!this.autoFocus || this.hasAutoFocused || this.disabled || this.locksInput) return;\n\n setTimeout(() => {\n if (!this.autoFocus || this.hasAutoFocused || this.disabled || this.locksInput || !this.inputRef) {\n return;\n }\n\n this.hasAutoFocused = true;\n this.hasFocus = true;\n this.inputRef.focus();\n }, 100);\n }\n\n handleComplete(digits: string): void {\n this.tctComplete.emit({ value: digits });\n\n if (this.autoSubmit) {\n setTimeout(() => this.submit(digits), 150);\n }\n }\n\n handleFocusIn = () => {\n if (this.state === 'error') {\n this.value = '';\n if (this.inputRef) this.inputRef.value = '';\n this.state = undefined;\n }\n this.hasFocus = true;\n };\n\n handleFocusOut = (event: FocusEvent) => {\n if (this.autoFocus && this.hasAutoFocused && !this.value && !event.relatedTarget) {\n return;\n }\n this.hasFocus = false;\n };\n\n handleInputEvent = () => {\n if (this.disabled || this.locksInput) {\n this.inputRef.value = this.value;\n return;\n }\n\n const digits = this.filterDigits(this.inputRef.value);\n this.inputRef.value = digits;\n\n if (this.state === 'error') {\n this.state = undefined;\n }\n\n this.value = digits;\n this.tctInput.emit({ value: digits });\n\n if (digits.length === this.normalizedLength) {\n this.handleComplete(digits);\n }\n };\n\n handleKeyDown = (event: KeyboardEvent) => {\n if (event.key !== 'Enter') return;\n if (this.disabled || this.locksInput || !this.isComplete) return;\n\n event.preventDefault();\n this.submit();\n };\n\n handlePaste = (event: ClipboardEvent) => {\n event.preventDefault();\n if (this.disabled || this.locksInput) return;\n\n const pastedValue = event.clipboardData?.getData('text') ?? '';\n const digits = this.filterDigits(pastedValue);\n\n this.inputRef.value = digits;\n\n if (this.state === 'error') {\n this.state = undefined;\n }\n\n this.value = digits;\n this.tctInput.emit({ value: digits });\n\n if (digits.length === this.normalizedLength) {\n this.handleComplete(digits);\n }\n };\n\n handleSendCodeClick = () => {\n if (this.disabled) return;\n\n this.inputRef?.focus();\n this.state = undefined;\n this.tctSendCode.emit();\n };\n\n handleSubmitClick = () => {\n if (this.isVerifying || this.isSuccess) return;\n this.submit();\n };\n\n submit(value = this.value): void {\n this.state = 'verifying';\n this.tctSubmit.emit({ value });\n }\n\n // #endregion\n // #region Render Methods\n\n renderFields() {\n return Array.from({ length: this.normalizedLength }, (_, index) => {\n const char = this.value[index] || '';\n const isActive = this.hasFocus && index === this.activeSlotIndex;\n const hasValue = !!char;\n\n return [\n this.split && index === this.normalizedLength / 2 && (\n <span\n aria-hidden=\"true\"\n class=\"otp-separator\"\n >\n -\n </span>\n ),\n <div\n class={{\n 'otp-slot': true,\n 'is-active': isActive,\n 'has-value': hasValue,\n }}\n >\n {isActive && !hasValue ? (\n <span\n class=\"otp-caret\"\n aria-hidden=\"true\"\n />\n ) : this.masked && hasValue ? (\n <span class=\"otp-dot\" />\n ) : (\n <span class=\"otp-char\">{char}</span>\n )}\n </div>,\n ];\n });\n }\n\n renderHelperText() {\n if (!this.hasVisibleHelperText) return;\n return (\n <div\n class=\"helper-text\"\n id={this.helperTextId}\n >\n {this.localizedHelperText}\n </div>\n );\n }\n\n renderLabel() {\n if (!this.label) return;\n return (\n <div\n class=\"otp-label\"\n id={this.labelId}\n >\n {this.localizedLabel}\n </div>\n );\n }\n\n renderMessage() {\n if (this.state === 'error' && this.errorMessage) {\n return (\n <q2-message\n appearance=\"minimal\"\n class=\"otp-message\"\n id={this.messageId}\n type=\"error\"\n >\n {loc(this.errorMessage)}\n </q2-message>\n );\n }\n\n if (this.state === 'success' && this.successMessage) {\n return (\n <q2-message\n appearance=\"minimal\"\n class=\"otp-message\"\n id={this.messageId}\n type=\"success\"\n >\n {loc(this.successMessage)}\n </q2-message>\n );\n }\n }\n\n renderProcessingOverlay() {\n if (this.autoSubmit && this.isVerifying) {\n return (\n <div class=\"processing-overlay\">\n <q2-loading label={this.localizedProcessingLabel} />\n </div>\n );\n }\n }\n\n renderSendCodeButton() {\n if (!this.isAwaitingSendCode) return;\n\n return (\n <q2-btn\n block\n class=\"send-code-button\"\n disabled={this.disabled}\n intent=\"workflow-primary\"\n label={this.localizedSendCodeLabel}\n onClick={this.handleSendCodeClick}\n ref={el => (this.sendCodeRef = el)}\n />\n );\n }\n\n renderSubmitArea() {\n if (this.isSuccess) {\n return (\n <q2-btn\n block\n class=\"submit-button\"\n intent=\"neutral\"\n onClick={this.handleSubmitClick}\n >\n <q2-icon type=\"checkmark\" />\n {loc('Success')}\n </q2-btn>\n );\n }\n\n return (\n <q2-btn\n block\n class=\"submit-button\"\n disabled={this.disabled || !this.isComplete}\n intent=\"workflow-primary\"\n label={this.isVerifying ? this.localizedProcessingLabel : this.localizedSubmitLabel}\n loading={this.isVerifying}\n onClick={this.handleSubmitClick}\n />\n );\n }\n\n render() {\n return (\n <div\n aria-busy={this.isVerifying ? 'true' : undefined}\n aria-labelledby={this.label ? this.labelId : undefined}\n class={{\n 'otp-container': true,\n 'has-focus': this.hasFocus,\n 'is-masked': this.masked,\n 'send-code-pending': this.isAwaitingSendCode,\n 'state-error': this.state === 'error',\n 'state-success': this.state === 'success',\n 'state-verifying': this.isVerifying,\n [`length-${this.normalizedLength}`]: true,\n }}\n role=\"group\"\n >\n {this.renderSendCodeButton()}\n <div class={{ 'otp-content': true, 'send-code-hidden': this.isAwaitingSendCode }}>\n {this.renderLabel()}\n <div class=\"otp-control-group\">\n <div class=\"fields-shell\">\n <div class=\"fields-container\">\n <input\n aria-describedby={this.describedBy}\n aria-invalid={this.state === 'error' ? 'true' : 'false'}\n aria-label={this.inputAriaLabel}\n autocomplete=\"one-time-code\"\n autofocus={this.autoFocus}\n class=\"otp-hidden-input\"\n disabled={this.disabled || this.isVerifying || this.isSuccess}\n inputmode=\"numeric\"\n maxLength={this.normalizedLength}\n onBlur={this.handleFocusOut}\n onFocus={this.handleFocusIn}\n onInput={this.handleInputEvent}\n onKeyDown={this.handleKeyDown}\n onPaste={this.handlePaste}\n pattern=\"[0-9]*\"\n ref={el => (this.inputRef = el)}\n test-id=\"q2OtpInput\"\n type=\"text\"\n value={this.value}\n />\n {this.renderFields()}\n </div>\n {this.renderProcessingOverlay()}\n </div>\n {this.renderSubmitArea()}\n {this.renderMessage()}\n </div>\n {this.renderHelperText()}\n </div>\n </div>\n );\n }\n\n // #endregion\n}\n"],"mappings":"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","ignoreList":[]}
|