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.
Files changed (807) hide show
  1. package/dist/bundle-report.json +22598 -10670
  2. package/dist/cjs/click-elsewhere.q2-option-list.q2-popover.entry.cjs.js.map +1 -1
  3. package/dist/cjs/click-elsewhere_3.cjs.entry.js +46 -32
  4. package/dist/cjs/click-elsewhere_3.cjs.entry.js.map +1 -1
  5. package/dist/cjs/{component-DRAntnCA.js → component-iASoq6gx.js} +9 -3
  6. package/dist/cjs/component-iASoq6gx.js.map +1 -0
  7. package/dist/cjs/{index-YvKoRT-t.js → index-DmGkqdX2.js} +3 -3
  8. package/dist/cjs/index-DmGkqdX2.js.map +1 -0
  9. package/dist/cjs/loader.cjs.js +1 -1
  10. package/dist/cjs/q2-action-group.q2-resize-observer.entry.cjs.js.map +1 -1
  11. package/dist/cjs/q2-action-group_2.cjs.entry.js +2 -2
  12. package/dist/cjs/q2-action-group_2.cjs.entry.js.map +1 -1
  13. package/dist/cjs/q2-action-sheet.cjs.entry.js +109 -4
  14. package/dist/cjs/q2-action-sheet.cjs.entry.js.map +1 -1
  15. package/dist/cjs/q2-action-sheet.entry.cjs.js.map +1 -1
  16. package/dist/cjs/q2-avatar.cjs.entry.js.map +1 -1
  17. package/dist/cjs/q2-avatar.entry.cjs.js.map +1 -1
  18. package/dist/cjs/q2-badge.cjs.entry.js +1 -1
  19. package/dist/cjs/q2-badge.cjs.entry.js.map +1 -1
  20. package/dist/cjs/q2-badge.entry.cjs.js.map +1 -1
  21. package/dist/cjs/q2-btn.q2-loading.entry.cjs.js.map +1 -1
  22. package/dist/cjs/q2-btn_2.cjs.entry.js +1 -1
  23. package/dist/cjs/q2-btn_2.cjs.entry.js.map +1 -1
  24. package/dist/cjs/q2-calendar.cjs.entry.js +6 -3
  25. package/dist/cjs/q2-calendar.cjs.entry.js.map +1 -1
  26. package/dist/cjs/q2-calendar.entry.cjs.js.map +1 -1
  27. package/dist/cjs/q2-card-image.cjs.entry.js +2 -2
  28. package/dist/cjs/q2-card-image.cjs.entry.js.map +1 -1
  29. package/dist/cjs/q2-card-image.entry.cjs.js.map +1 -1
  30. package/dist/cjs/q2-card.cjs.entry.js +1 -1
  31. package/dist/cjs/q2-card.cjs.entry.js.map +1 -1
  32. package/dist/cjs/q2-card.entry.cjs.js.map +1 -1
  33. package/dist/cjs/q2-carousel-pane.cjs.entry.js +3 -3
  34. package/dist/cjs/q2-carousel-pane.cjs.entry.js.map +1 -1
  35. package/dist/cjs/q2-carousel-pane.entry.cjs.js.map +1 -1
  36. package/dist/cjs/q2-carousel.cjs.entry.js +162 -29
  37. package/dist/cjs/q2-carousel.cjs.entry.js.map +1 -1
  38. package/dist/cjs/q2-carousel.entry.cjs.js.map +1 -1
  39. package/dist/cjs/q2-chart-area.cjs.entry.js +1 -1
  40. package/dist/cjs/q2-chart-bar.cjs.entry.js +1 -1
  41. package/dist/cjs/q2-chart-donut.cjs.entry.js +3 -2
  42. package/dist/cjs/q2-chart-donut.cjs.entry.js.map +1 -1
  43. package/dist/cjs/q2-chart-donut.entry.cjs.js.map +1 -1
  44. package/dist/cjs/q2-checkbox-group.cjs.entry.js +2 -2
  45. package/dist/cjs/q2-checkbox-group.cjs.entry.js.map +1 -1
  46. package/dist/cjs/q2-checkbox-group.entry.cjs.js.map +1 -1
  47. package/dist/cjs/q2-checkbox.q2-tag.entry.cjs.js.map +1 -1
  48. package/dist/cjs/q2-checkbox_2.cjs.entry.js +3 -3
  49. package/dist/cjs/q2-checkbox_2.cjs.entry.js.map +1 -1
  50. package/dist/cjs/q2-context.cjs.entry.js +2 -2
  51. package/dist/cjs/q2-context.cjs.entry.js.map +1 -1
  52. package/dist/cjs/q2-context.entry.cjs.js.map +1 -1
  53. package/dist/cjs/q2-currency.cjs.entry.js +2 -3
  54. package/dist/cjs/q2-currency.cjs.entry.js.map +1 -1
  55. package/dist/cjs/q2-currency.entry.cjs.js.map +1 -1
  56. package/dist/cjs/q2-data-table.cjs.entry.js +2 -2
  57. package/dist/cjs/q2-data-table.cjs.entry.js.map +1 -1
  58. package/dist/cjs/q2-data-table.entry.cjs.js.map +1 -1
  59. package/dist/cjs/q2-detail.cjs.entry.js +2 -2
  60. package/dist/cjs/q2-detail.cjs.entry.js.map +1 -1
  61. package/dist/cjs/q2-detail.entry.cjs.js.map +1 -1
  62. package/dist/cjs/q2-dropdown-item.cjs.entry.js +2 -2
  63. package/dist/cjs/q2-dropdown-item.cjs.entry.js.map +1 -1
  64. package/dist/cjs/q2-dropdown-item.entry.cjs.js.map +1 -1
  65. package/dist/cjs/q2-dropdown.cjs.entry.js +3 -5
  66. package/dist/cjs/q2-dropdown.cjs.entry.js.map +1 -1
  67. package/dist/cjs/q2-dropdown.entry.cjs.js.map +1 -1
  68. package/dist/cjs/q2-editable-field.cjs.entry.js +1 -1
  69. package/dist/cjs/q2-editable-field.cjs.entry.js.map +1 -1
  70. package/dist/cjs/q2-editable-field.entry.cjs.js.map +1 -1
  71. package/dist/cjs/q2-example.cjs.entry.js +1 -1
  72. package/dist/cjs/q2-file-picker.cjs.entry.js +1 -1
  73. package/dist/cjs/q2-file-picker.cjs.entry.js.map +1 -1
  74. package/dist/cjs/q2-file-picker.entry.cjs.js.map +1 -1
  75. package/dist/cjs/q2-form.cjs.entry.js +2 -2
  76. package/dist/cjs/q2-form.cjs.entry.js.map +1 -1
  77. package/dist/cjs/q2-form.entry.cjs.js.map +1 -1
  78. package/dist/cjs/q2-formatted-text.cjs.entry.js +1 -1
  79. package/dist/cjs/q2-formatted-text.cjs.entry.js.map +1 -1
  80. package/dist/cjs/q2-formatted-text.entry.cjs.js.map +1 -1
  81. package/dist/cjs/q2-grid-area.cjs.entry.js +1 -1
  82. package/dist/cjs/q2-grid.cjs.entry.js +32 -8
  83. package/dist/cjs/q2-grid.cjs.entry.js.map +1 -1
  84. package/dist/cjs/q2-grid.entry.cjs.js.map +1 -1
  85. package/dist/cjs/q2-icon.cjs.entry.js +1 -1
  86. package/dist/cjs/q2-icon.cjs.entry.js.map +1 -1
  87. package/dist/cjs/q2-icon.entry.cjs.js.map +1 -1
  88. package/dist/cjs/q2-input.cjs.entry.js +8 -5
  89. package/dist/cjs/q2-input.cjs.entry.js.map +1 -1
  90. package/dist/cjs/q2-input.entry.cjs.js.map +1 -1
  91. package/dist/cjs/q2-item.cjs.entry.js +2 -2
  92. package/dist/cjs/q2-item.cjs.entry.js.map +1 -1
  93. package/dist/cjs/q2-item.entry.cjs.js.map +1 -1
  94. package/dist/cjs/q2-legend.cjs.entry.js +2 -3
  95. package/dist/cjs/q2-legend.cjs.entry.js.map +1 -1
  96. package/dist/cjs/q2-legend.entry.cjs.js.map +1 -1
  97. package/dist/cjs/q2-link.q2-list.entry.cjs.js.map +1 -1
  98. package/dist/cjs/q2-link_2.cjs.entry.js +2 -2
  99. package/dist/cjs/q2-link_2.cjs.entry.js.map +1 -1
  100. package/dist/cjs/q2-loc.cjs.entry.js +1 -1
  101. package/dist/cjs/q2-message.cjs.entry.js +3 -3
  102. package/dist/cjs/q2-message.cjs.entry.js.map +1 -1
  103. package/dist/cjs/q2-message.entry.cjs.js.map +1 -1
  104. package/dist/cjs/q2-meter.cjs.entry.js +2 -2
  105. package/dist/cjs/q2-meter.cjs.entry.js.map +1 -1
  106. package/dist/cjs/q2-meter.entry.cjs.js.map +1 -1
  107. package/dist/cjs/q2-modal.cjs.entry.js +3 -3
  108. package/dist/cjs/q2-modal.cjs.entry.js.map +1 -1
  109. package/dist/cjs/q2-modal.entry.cjs.js.map +1 -1
  110. package/dist/cjs/q2-month-picker.cjs.entry.js +1 -1
  111. package/dist/cjs/q2-mutation-observer.cjs.entry.js +1 -1
  112. package/dist/cjs/q2-optgroup.cjs.entry.js +3 -3
  113. package/dist/cjs/q2-optgroup.cjs.entry.js.map +1 -1
  114. package/dist/cjs/q2-optgroup.entry.cjs.js.map +1 -1
  115. package/dist/cjs/q2-option.cjs.entry.js +3 -3
  116. package/dist/cjs/q2-option.cjs.entry.js.map +1 -1
  117. package/dist/cjs/q2-option.entry.cjs.js.map +1 -1
  118. package/dist/cjs/q2-otp.cjs.entry.js +373 -0
  119. package/dist/cjs/q2-otp.cjs.entry.js.map +1 -0
  120. package/dist/cjs/q2-otp.entry.cjs.js.map +1 -0
  121. package/dist/cjs/q2-pagination.cjs.entry.js +4 -4
  122. package/dist/cjs/q2-pagination.cjs.entry.js.map +1 -1
  123. package/dist/cjs/q2-pagination.entry.cjs.js.map +1 -1
  124. package/dist/cjs/q2-pill.cjs.entry.js +24 -15
  125. package/dist/cjs/q2-pill.cjs.entry.js.map +1 -1
  126. package/dist/cjs/q2-pill.entry.cjs.js.map +1 -1
  127. package/dist/cjs/q2-radio-group.cjs.entry.js +1 -1
  128. package/dist/cjs/q2-radio-group.cjs.entry.js.map +1 -1
  129. package/dist/cjs/q2-radio-group.entry.cjs.js.map +1 -1
  130. package/dist/cjs/q2-radio.cjs.entry.js +3 -3
  131. package/dist/cjs/q2-radio.cjs.entry.js.map +1 -1
  132. package/dist/cjs/q2-radio.entry.cjs.js.map +1 -1
  133. package/dist/cjs/q2-relative-time.cjs.entry.js +2 -2
  134. package/dist/cjs/q2-section-container.cjs.entry.js +1 -1
  135. package/dist/cjs/q2-section.cjs.entry.js +3 -3
  136. package/dist/cjs/q2-section.cjs.entry.js.map +1 -1
  137. package/dist/cjs/q2-section.entry.cjs.js.map +1 -1
  138. package/dist/cjs/q2-select.cjs.entry.js +1 -1
  139. package/dist/cjs/q2-select.cjs.entry.js.map +1 -1
  140. package/dist/cjs/q2-select.entry.cjs.js.map +1 -1
  141. package/dist/cjs/q2-stepper-pane.cjs.entry.js +3 -3
  142. package/dist/cjs/q2-stepper-vertical.cjs.entry.js +2 -2
  143. package/dist/cjs/q2-stepper-vertical.cjs.entry.js.map +1 -1
  144. package/dist/cjs/q2-stepper-vertical.entry.cjs.js.map +1 -1
  145. package/dist/cjs/q2-stepper.cjs.entry.js +2 -2
  146. package/dist/cjs/q2-stepper.cjs.entry.js.map +1 -1
  147. package/dist/cjs/q2-stepper.entry.cjs.js.map +1 -1
  148. package/dist/cjs/q2-tab-container.cjs.entry.js +3 -3
  149. package/dist/cjs/q2-tab-container.cjs.entry.js.map +1 -1
  150. package/dist/cjs/q2-tab-container.entry.cjs.js.map +1 -1
  151. package/dist/cjs/q2-tab-pane.cjs.entry.js +2 -2
  152. package/dist/cjs/q2-tecton-elements.cjs.js +1 -1
  153. package/dist/cjs/q2-textarea.cjs.entry.js +1 -1
  154. package/dist/cjs/q2-textarea.cjs.entry.js.map +1 -1
  155. package/dist/cjs/q2-textarea.entry.cjs.js.map +1 -1
  156. package/dist/cjs/q2-toast.cjs.entry.js +1 -1
  157. package/dist/cjs/q2-toast.cjs.entry.js.map +1 -1
  158. package/dist/cjs/q2-toast.entry.cjs.js.map +1 -1
  159. package/dist/cjs/q2-tooltip.cjs.entry.js +124 -5
  160. package/dist/cjs/q2-tooltip.cjs.entry.js.map +1 -1
  161. package/dist/cjs/q2-tooltip.entry.cjs.js.map +1 -1
  162. package/dist/cjs/{sanitize-html-string-CW6y5624.js → sanitize-html-string-D17Pr7-c.js} +21 -4
  163. package/dist/cjs/{sanitize-html-string-CW6y5624.js.map → sanitize-html-string-D17Pr7-c.js.map} +1 -1
  164. package/dist/cjs/tecton-tab-pane.cjs.entry.js +2 -2
  165. package/dist/collection/collection-manifest.json +1 -0
  166. package/dist/collection/components/click-elsewhere/click-elsewhere.js +2 -0
  167. package/dist/collection/components/click-elsewhere/click-elsewhere.js.map +1 -1
  168. package/dist/collection/components/q2-action-group/q2-action-group.css +14 -0
  169. package/dist/collection/components/q2-action-sheet/q2-action-sheet.css +16 -0
  170. package/dist/collection/components/q2-action-sheet/q2-action-sheet.js +107 -2
  171. package/dist/collection/components/q2-action-sheet/q2-action-sheet.js.map +1 -1
  172. package/dist/collection/components/q2-avatar/q2-avatar.css +24 -0
  173. package/dist/collection/components/q2-avatar/test/q2-avatar-test.vr.js +61 -0
  174. package/dist/collection/components/q2-avatar/test/q2-avatar-test.vr.js.map +1 -0
  175. package/dist/collection/components/q2-badge/q2-badge.css +30 -0
  176. package/dist/collection/components/q2-badge/test/q2-badge-test.vr.js +34 -0
  177. package/dist/collection/components/q2-badge/test/q2-badge-test.vr.js.map +1 -0
  178. package/dist/collection/components/q2-btn/q2-btn.css +279 -0
  179. package/dist/collection/components/q2-btn/test/q2-btn-test.vr.js +80 -0
  180. package/dist/collection/components/q2-btn/test/q2-btn-test.vr.js.map +1 -0
  181. package/dist/collection/components/q2-calendar/q2-calendar.css +36 -0
  182. package/dist/collection/components/q2-calendar/q2-calendar.js +5 -2
  183. package/dist/collection/components/q2-calendar/q2-calendar.js.map +1 -1
  184. package/dist/collection/components/q2-calendar/test/q2-calendar-test.vr.js +170 -0
  185. package/dist/collection/components/q2-calendar/test/q2-calendar-test.vr.js.map +1 -0
  186. package/dist/collection/components/q2-card/q2-card.css +62 -0
  187. package/dist/collection/components/q2-card/test/q2-card-test.vr.js +72 -0
  188. package/dist/collection/components/q2-card/test/q2-card-test.vr.js.map +1 -0
  189. package/dist/collection/components/q2-card-image/q2-card-image.css +74 -13
  190. package/dist/collection/components/q2-card-image/test/q2-card-image-test.vr.js +152 -0
  191. package/dist/collection/components/q2-card-image/test/q2-card-image-test.vr.js.map +1 -0
  192. package/dist/collection/components/q2-carousel/q2-carousel.css +78 -13
  193. package/dist/collection/components/q2-carousel/q2-carousel.js +241 -27
  194. package/dist/collection/components/q2-carousel/q2-carousel.js.map +1 -1
  195. package/dist/collection/components/q2-carousel/test/q2-carousel-test.vr.js +104 -0
  196. package/dist/collection/components/q2-carousel/test/q2-carousel-test.vr.js.map +1 -0
  197. package/dist/collection/components/q2-carousel-pane/q2-carousel-pane.css +26 -1
  198. package/dist/collection/components/q2-chart-area/test/q2-chart-area-test.vr.js +126 -0
  199. package/dist/collection/components/q2-chart-area/test/q2-chart-area-test.vr.js.map +1 -0
  200. package/dist/collection/components/q2-chart-bar/test/q2-chart-bar-test.vr.js +105 -0
  201. package/dist/collection/components/q2-chart-bar/test/q2-chart-bar-test.vr.js.map +1 -0
  202. package/dist/collection/components/q2-chart-donut/q2-chart-donut.css +29 -0
  203. package/dist/collection/components/q2-chart-donut/q2-chart-donut.js +21 -1
  204. package/dist/collection/components/q2-chart-donut/q2-chart-donut.js.map +1 -1
  205. package/dist/collection/components/q2-chart-donut/test/q2-chart-donut-test.vr.js +151 -0
  206. package/dist/collection/components/q2-chart-donut/test/q2-chart-donut-test.vr.js.map +1 -0
  207. package/dist/collection/components/q2-checkbox/q2-checkbox.css +128 -0
  208. package/dist/collection/components/q2-checkbox/test/q2-checkbox-test.vr.js +69 -0
  209. package/dist/collection/components/q2-checkbox/test/q2-checkbox-test.vr.js.map +1 -0
  210. package/dist/collection/components/q2-checkbox-group/q2-checkbox-group.css +21 -0
  211. package/dist/collection/components/q2-checkbox-group/test/q2-checkbox-group-test.vr.js +61 -0
  212. package/dist/collection/components/q2-checkbox-group/test/q2-checkbox-group-test.vr.js.map +1 -0
  213. package/dist/collection/components/q2-context/q2-context.css +16 -0
  214. package/dist/collection/components/q2-context/test/q2-context-test.vr.js +95 -0
  215. package/dist/collection/components/q2-context/test/q2-context-test.vr.js.map +1 -0
  216. package/dist/collection/components/q2-currency/q2-currency.css +31 -0
  217. package/dist/collection/components/q2-currency/q2-currency.js +3 -4
  218. package/dist/collection/components/q2-currency/q2-currency.js.map +1 -1
  219. package/dist/collection/components/q2-currency/test/q2-currency-test.vr.js +79 -0
  220. package/dist/collection/components/q2-currency/test/q2-currency-test.vr.js.map +1 -0
  221. package/dist/collection/components/q2-data-table/q2-data-table.css +51 -0
  222. package/dist/collection/components/q2-data-table/q2-data-table.js +1 -1
  223. package/dist/collection/components/q2-data-table/test/q2-data-table-test.vr.js +79 -0
  224. package/dist/collection/components/q2-data-table/test/q2-data-table-test.vr.js.map +1 -0
  225. package/dist/collection/components/q2-detail/q2-detail.css +42 -0
  226. package/dist/collection/components/q2-detail/q2-detail.js +1 -1
  227. package/dist/collection/components/q2-dropdown/q2-dropdown.css +8 -0
  228. package/dist/collection/components/q2-dropdown/q2-dropdown.js +2 -4
  229. package/dist/collection/components/q2-dropdown/q2-dropdown.js.map +1 -1
  230. package/dist/collection/components/q2-dropdown-item/q2-dropdown-item.css +11 -0
  231. package/dist/collection/components/q2-editable-field/q2-editable-field.css +5 -0
  232. package/dist/collection/components/q2-editable-field/test/q2-editable-field-test.vr.js +89 -0
  233. package/dist/collection/components/q2-editable-field/test/q2-editable-field-test.vr.js.map +1 -0
  234. package/dist/collection/components/q2-example/q2-example.js +1 -1
  235. package/dist/collection/components/q2-file-picker/q2-file-picker.css +64 -0
  236. package/dist/collection/components/q2-file-picker/test/q2-file-picker-test.vr.js +92 -0
  237. package/dist/collection/components/q2-file-picker/test/q2-file-picker-test.vr.js.map +1 -0
  238. package/dist/collection/components/q2-form/q2-form.css +34 -20
  239. package/dist/collection/components/q2-form/q2-form.js +1 -1
  240. package/dist/collection/components/q2-formatted-text/q2-formatted-text.css +14 -0
  241. package/dist/collection/components/q2-formatted-text/q2-formatted-text.js +1 -1
  242. package/dist/collection/components/q2-formatted-text/test/q2-formatted-text-test.vr.js +55 -0
  243. package/dist/collection/components/q2-formatted-text/test/q2-formatted-text-test.vr.js.map +1 -0
  244. package/dist/collection/components/q2-grid/q2-grid.css +13 -0
  245. package/dist/collection/components/q2-grid/q2-grid.js +31 -7
  246. package/dist/collection/components/q2-grid/q2-grid.js.map +1 -1
  247. package/dist/collection/components/q2-icon/assets/standard.symbol.svg +1 -1
  248. package/dist/collection/components/q2-icon/q2-icon.css +15 -0
  249. package/dist/collection/components/q2-icon/test/q2-icon-test.vr.js +55 -0
  250. package/dist/collection/components/q2-icon/test/q2-icon-test.vr.js.map +1 -0
  251. package/dist/collection/components/q2-input/q2-input.css +104 -0
  252. package/dist/collection/components/q2-input/q2-input.js +6 -3
  253. package/dist/collection/components/q2-input/q2-input.js.map +1 -1
  254. package/dist/collection/components/q2-input/test/q2-input-test.vr.js +97 -0
  255. package/dist/collection/components/q2-input/test/q2-input-test.vr.js.map +1 -0
  256. package/dist/collection/components/q2-item/q2-item.css +28 -0
  257. package/dist/collection/components/q2-item/q2-item.js +1 -1
  258. package/dist/collection/components/q2-legend/q2-legend.css +16 -0
  259. package/dist/collection/components/q2-legend/q2-legend.js +21 -3
  260. package/dist/collection/components/q2-legend/q2-legend.js.map +1 -1
  261. package/dist/collection/components/q2-link/q2-link.css +20 -0
  262. package/dist/collection/components/q2-link/test/q2-link-test.vr.js +70 -0
  263. package/dist/collection/components/q2-link/test/q2-link-test.vr.js.map +1 -0
  264. package/dist/collection/components/q2-list/q2-list.css +14 -0
  265. package/dist/collection/components/q2-list/q2-list.js +1 -1
  266. package/dist/collection/components/q2-list/test/q2-list-test.vr.js +58 -0
  267. package/dist/collection/components/q2-list/test/q2-list-test.vr.js.map +1 -0
  268. package/dist/collection/components/q2-loading/q2-loading.css +9 -0
  269. package/dist/collection/components/q2-message/q2-message.css +29 -1
  270. package/dist/collection/components/q2-message/q2-message.js +1 -1
  271. package/dist/collection/components/q2-message/test/q2-message-test.vr.js +57 -0
  272. package/dist/collection/components/q2-message/test/q2-message-test.vr.js.map +1 -0
  273. package/dist/collection/components/q2-meter/q2-meter.css +40 -0
  274. package/dist/collection/components/q2-meter/q2-meter.js +1 -1
  275. package/dist/collection/components/q2-meter/test/q2-meter-test.vr.js +78 -0
  276. package/dist/collection/components/q2-meter/test/q2-meter-test.vr.js.map +1 -0
  277. package/dist/collection/components/q2-modal/q2-modal.css +21 -0
  278. package/dist/collection/components/q2-modal/q2-modal.js +1 -1
  279. package/dist/collection/components/q2-modal/test/q2-modal-test.vr.js +107 -0
  280. package/dist/collection/components/q2-modal/test/q2-modal-test.vr.js.map +1 -0
  281. package/dist/collection/components/q2-mutation-observer/q2-mutation-observer.js +1 -1
  282. package/dist/collection/components/q2-optgroup/q2-optgroup.css +11 -0
  283. package/dist/collection/components/q2-optgroup/q2-optgroup.js +1 -1
  284. package/dist/collection/components/q2-option/q2-option.css +9 -0
  285. package/dist/collection/components/q2-option/q2-option.js +1 -1
  286. package/dist/collection/components/q2-option/q2-option.js.map +1 -1
  287. package/dist/collection/components/q2-option-list/q2-option-list.css +3 -0
  288. package/dist/collection/components/q2-option-list/q2-option-list.js +37 -28
  289. package/dist/collection/components/q2-option-list/q2-option-list.js.map +1 -1
  290. package/dist/collection/components/q2-otp/q2-otp.css +312 -0
  291. package/dist/collection/components/q2-otp/q2-otp.js +873 -0
  292. package/dist/collection/components/q2-otp/q2-otp.js.map +1 -0
  293. package/dist/collection/components/q2-pagination/q2-pagination.css +22 -0
  294. package/dist/collection/components/q2-pagination/q2-pagination.js +3 -3
  295. package/dist/collection/components/q2-pagination/test/q2-pagination-test.vr.js +145 -0
  296. package/dist/collection/components/q2-pagination/test/q2-pagination-test.vr.js.map +1 -0
  297. package/dist/collection/components/q2-pill/q2-pill.css +53 -0
  298. package/dist/collection/components/q2-pill/q2-pill.js +23 -14
  299. package/dist/collection/components/q2-pill/q2-pill.js.map +1 -1
  300. package/dist/collection/components/q2-pill/test/q2-pill-test.vr.js +110 -0
  301. package/dist/collection/components/q2-pill/test/q2-pill-test.vr.js.map +1 -0
  302. package/dist/collection/components/q2-popover/q2-popover.css +20 -0
  303. package/dist/collection/components/q2-popover/q2-popover.js +5 -2
  304. package/dist/collection/components/q2-popover/q2-popover.js.map +1 -1
  305. package/dist/collection/components/q2-radio/q2-radio.css +52 -1
  306. package/dist/collection/components/q2-radio/q2-radio.js +2 -2
  307. package/dist/collection/components/q2-radio/q2-radio.js.map +1 -1
  308. package/dist/collection/components/q2-radio/test/q2-radio-test.vr.js +73 -0
  309. package/dist/collection/components/q2-radio/test/q2-radio-test.vr.js.map +1 -0
  310. package/dist/collection/components/q2-radio-group/q2-radio-group.css +22 -0
  311. package/dist/collection/components/q2-radio-group/test/q2-radio-group-test.vr.js +99 -0
  312. package/dist/collection/components/q2-radio-group/test/q2-radio-group-test.vr.js.map +1 -0
  313. package/dist/collection/components/q2-relative-time/q2-relative-time.js +1 -1
  314. package/dist/collection/components/q2-resize-observer/q2-resize-observer.js +1 -1
  315. package/dist/collection/components/q2-section/q2-section.css +26 -0
  316. package/dist/collection/components/q2-section/q2-section.js +2 -2
  317. package/dist/collection/components/q2-section/test/q2-section-test.vr.js +68 -0
  318. package/dist/collection/components/q2-section/test/q2-section-test.vr.js.map +1 -0
  319. package/dist/collection/components/q2-select/q2-select.css +17 -0
  320. package/dist/collection/components/q2-select/test/q2-select-test.vr.js +107 -0
  321. package/dist/collection/components/q2-select/test/q2-select-test.vr.js.map +1 -0
  322. package/dist/collection/components/q2-stepper/q2-stepper.css +36 -0
  323. package/dist/collection/components/q2-stepper/q2-stepper.js +1 -1
  324. package/dist/collection/components/q2-stepper/test/q2-stepper-test.vr.js +86 -0
  325. package/dist/collection/components/q2-stepper/test/q2-stepper-test.vr.js.map +1 -0
  326. package/dist/collection/components/q2-stepper-pane/q2-stepper-pane.js +1 -1
  327. package/dist/collection/components/q2-stepper-vertical/q2-stepper-vertical.css +31 -0
  328. package/dist/collection/components/q2-stepper-vertical/q2-stepper-vertical.js +1 -1
  329. package/dist/collection/components/q2-stepper-vertical/test/q2-stepper-vertical-test.vr.js +97 -0
  330. package/dist/collection/components/q2-stepper-vertical/test/q2-stepper-vertical-test.vr.js.map +1 -0
  331. package/dist/collection/components/q2-tab-container/q2-tab-container.css +38 -0
  332. package/dist/collection/components/q2-tab-container/q2-tab-container.js +1 -1
  333. package/dist/collection/components/q2-tab-container/test/q2-tab-container-test.vr.js +78 -0
  334. package/dist/collection/components/q2-tab-container/test/q2-tab-container-test.vr.js.map +1 -0
  335. package/dist/collection/components/q2-tab-pane/q2-tab-pane.js +1 -1
  336. package/dist/collection/components/q2-tag/q2-tag.css +30 -1
  337. package/dist/collection/components/q2-tag/q2-tag.js +1 -1
  338. package/dist/collection/components/q2-tag/test/q2-tag-test.vr.js +83 -0
  339. package/dist/collection/components/q2-tag/test/q2-tag-test.vr.js.map +1 -0
  340. package/dist/collection/components/q2-textarea/q2-textarea.css +80 -0
  341. package/dist/collection/components/q2-textarea/test/q2-textarea-test.vr.js +102 -0
  342. package/dist/collection/components/q2-textarea/test/q2-textarea-test.vr.js.map +1 -0
  343. package/dist/collection/components/q2-toast/q2-toast.css +15 -0
  344. package/dist/collection/components/q2-tooltip/q2-tooltip.css +31 -0
  345. package/dist/collection/components/q2-tooltip/q2-tooltip.js +135 -4
  346. package/dist/collection/components/q2-tooltip/q2-tooltip.js.map +1 -1
  347. package/dist/collection/components/q2-tooltip/test/q2-tooltip-test.vr.js +76 -0
  348. package/dist/collection/components/q2-tooltip/test/q2-tooltip-test.vr.js.map +1 -0
  349. package/dist/collection/components/tecton-tab-pane/tecton-tab-pane.js +2 -2
  350. package/dist/collection/utils/component.js +7 -1
  351. package/dist/collection/utils/component.js.map +1 -1
  352. package/dist/collection/utils/index.js +1 -1
  353. package/dist/collection/utils/index.js.map +1 -1
  354. package/dist/collection/utils/sanitize-html-string.js +19 -2
  355. package/dist/collection/utils/sanitize-html-string.js.map +1 -1
  356. package/dist/collection/utils/test/vr-helpers.js +98 -0
  357. package/dist/collection/utils/test/vr-helpers.js.map +1 -0
  358. package/dist/components/click-elsewhere2.js +2 -0
  359. package/dist/components/click-elsewhere2.js.map +1 -1
  360. package/dist/components/component.js +7 -1
  361. package/dist/components/component.js.map +1 -1
  362. package/dist/components/index.js +2 -0
  363. package/dist/components/index.js.map +1 -1
  364. package/dist/components/index2.js +1 -1
  365. package/dist/components/index2.js.map +1 -1
  366. package/dist/components/q2-action-group2.js.map +1 -1
  367. package/dist/components/q2-action-sheet.js +107 -2
  368. package/dist/components/q2-action-sheet.js.map +1 -1
  369. package/dist/components/q2-avatar2.js.map +1 -1
  370. package/dist/components/q2-badge2.js.map +1 -1
  371. package/dist/components/q2-btn2.js.map +1 -1
  372. package/dist/components/q2-calendar.js +5 -2
  373. package/dist/components/q2-calendar.js.map +1 -1
  374. package/dist/components/q2-card-image.js +1 -1
  375. package/dist/components/q2-card-image.js.map +1 -1
  376. package/dist/components/q2-card.js.map +1 -1
  377. package/dist/components/q2-carousel-pane.js +1 -135
  378. package/dist/components/q2-carousel-pane.js.map +1 -1
  379. package/dist/components/q2-carousel-pane2.js +140 -0
  380. package/dist/components/q2-carousel-pane2.js.map +1 -0
  381. package/dist/components/q2-carousel.js +173 -29
  382. package/dist/components/q2-carousel.js.map +1 -1
  383. package/dist/components/q2-chart-donut.js +3 -1
  384. package/dist/components/q2-chart-donut.js.map +1 -1
  385. package/dist/components/q2-checkbox-group.js.map +1 -1
  386. package/dist/components/q2-checkbox2.js.map +1 -1
  387. package/dist/components/q2-context.js +1 -1
  388. package/dist/components/q2-context.js.map +1 -1
  389. package/dist/components/q2-currency.js +3 -4
  390. package/dist/components/q2-currency.js.map +1 -1
  391. package/dist/components/q2-data-table.js +1 -1
  392. package/dist/components/q2-data-table.js.map +1 -1
  393. package/dist/components/q2-detail.js +1 -1
  394. package/dist/components/q2-detail.js.map +1 -1
  395. package/dist/components/q2-dropdown-item2.js.map +1 -1
  396. package/dist/components/q2-dropdown.js +2 -4
  397. package/dist/components/q2-dropdown.js.map +1 -1
  398. package/dist/components/q2-editable-field.js.map +1 -1
  399. package/dist/components/q2-example.js +1 -1
  400. package/dist/components/q2-file-picker.js.map +1 -1
  401. package/dist/components/q2-form.js +2 -2
  402. package/dist/components/q2-form.js.map +1 -1
  403. package/dist/components/q2-formatted-text.js +1 -1
  404. package/dist/components/q2-formatted-text.js.map +1 -1
  405. package/dist/components/q2-grid.js +32 -8
  406. package/dist/components/q2-grid.js.map +1 -1
  407. package/dist/components/q2-icon2.js.map +1 -1
  408. package/dist/components/q2-input2.js +7 -4
  409. package/dist/components/q2-input2.js.map +1 -1
  410. package/dist/components/q2-item2.js +1 -1
  411. package/dist/components/q2-item2.js.map +1 -1
  412. package/dist/components/q2-legend2.js +3 -3
  413. package/dist/components/q2-legend2.js.map +1 -1
  414. package/dist/components/q2-link2.js.map +1 -1
  415. package/dist/components/q2-list2.js +1 -1
  416. package/dist/components/q2-list2.js.map +1 -1
  417. package/dist/components/q2-loading2.js.map +1 -1
  418. package/dist/components/q2-message2.js +2 -2
  419. package/dist/components/q2-message2.js.map +1 -1
  420. package/dist/components/q2-meter.js +1 -1
  421. package/dist/components/q2-meter.js.map +1 -1
  422. package/dist/components/q2-modal.js +1 -1
  423. package/dist/components/q2-modal.js.map +1 -1
  424. package/dist/components/q2-mutation-observer.js +1 -1
  425. package/dist/components/q2-optgroup2.js +1 -1
  426. package/dist/components/q2-optgroup2.js.map +1 -1
  427. package/dist/components/q2-option-list2.js +37 -28
  428. package/dist/components/q2-option-list2.js.map +1 -1
  429. package/dist/components/q2-option2.js +1 -1
  430. package/dist/components/q2-option2.js.map +1 -1
  431. package/dist/components/q2-otp.d.ts +11 -0
  432. package/dist/components/q2-otp.js +439 -0
  433. package/dist/components/q2-otp.js.map +1 -0
  434. package/dist/components/q2-pagination.js +3 -3
  435. package/dist/components/q2-pagination.js.map +1 -1
  436. package/dist/components/q2-pill.js +23 -14
  437. package/dist/components/q2-pill.js.map +1 -1
  438. package/dist/components/q2-popover2.js +5 -2
  439. package/dist/components/q2-popover2.js.map +1 -1
  440. package/dist/components/q2-radio-group.js.map +1 -1
  441. package/dist/components/q2-radio.js +2 -2
  442. package/dist/components/q2-radio.js.map +1 -1
  443. package/dist/components/q2-relative-time.js +1 -1
  444. package/dist/components/q2-resize-observer2.js +1 -1
  445. package/dist/components/q2-section.js +2 -2
  446. package/dist/components/q2-section.js.map +1 -1
  447. package/dist/components/q2-select2.js.map +1 -1
  448. package/dist/components/q2-stepper-pane.js +1 -1
  449. package/dist/components/q2-stepper-vertical.js +1 -1
  450. package/dist/components/q2-stepper-vertical.js.map +1 -1
  451. package/dist/components/q2-stepper.js +1 -1
  452. package/dist/components/q2-stepper.js.map +1 -1
  453. package/dist/components/q2-tab-container.js +1 -1
  454. package/dist/components/q2-tab-container.js.map +1 -1
  455. package/dist/components/q2-tab-pane.js +1 -1
  456. package/dist/components/q2-tag2.js +2 -2
  457. package/dist/components/q2-tag2.js.map +1 -1
  458. package/dist/components/q2-textarea.js.map +1 -1
  459. package/dist/components/q2-toast.js.map +1 -1
  460. package/dist/components/q2-tooltip2.js +124 -5
  461. package/dist/components/q2-tooltip2.js.map +1 -1
  462. package/dist/components/sanitize-html-string.js +19 -2
  463. package/dist/components/sanitize-html-string.js.map +1 -1
  464. package/dist/components/tecton-tab-pane.js +2 -2
  465. package/dist/esm/click-elsewhere.q2-option-list.q2-popover.entry.js.map +1 -1
  466. package/dist/esm/click-elsewhere_3.entry.js +46 -32
  467. package/dist/esm/click-elsewhere_3.entry.js.map +1 -1
  468. package/dist/esm/{component-DVxzK3WH.js → component-DaQM9u3s.js} +9 -3
  469. package/dist/esm/component-DaQM9u3s.js.map +1 -0
  470. package/dist/esm/{index-C4PILj1_.js → index-C5gj0T_3.js} +4 -4
  471. package/dist/esm/index-C5gj0T_3.js.map +1 -0
  472. package/dist/esm/loader.js +1 -1
  473. package/dist/esm/q2-action-group.q2-resize-observer.entry.js.map +1 -1
  474. package/dist/esm/q2-action-group_2.entry.js +2 -2
  475. package/dist/esm/q2-action-group_2.entry.js.map +1 -1
  476. package/dist/esm/q2-action-sheet.entry.js +109 -4
  477. package/dist/esm/q2-action-sheet.entry.js.map +1 -1
  478. package/dist/esm/q2-avatar.entry.js.map +1 -1
  479. package/dist/esm/q2-badge.entry.js +1 -1
  480. package/dist/esm/q2-badge.entry.js.map +1 -1
  481. package/dist/esm/q2-btn.q2-loading.entry.js.map +1 -1
  482. package/dist/esm/q2-btn_2.entry.js +1 -1
  483. package/dist/esm/q2-btn_2.entry.js.map +1 -1
  484. package/dist/esm/q2-calendar.entry.js +6 -3
  485. package/dist/esm/q2-calendar.entry.js.map +1 -1
  486. package/dist/esm/q2-card-image.entry.js +2 -2
  487. package/dist/esm/q2-card-image.entry.js.map +1 -1
  488. package/dist/esm/q2-card.entry.js +1 -1
  489. package/dist/esm/q2-card.entry.js.map +1 -1
  490. package/dist/esm/q2-carousel-pane.entry.js +3 -3
  491. package/dist/esm/q2-carousel-pane.entry.js.map +1 -1
  492. package/dist/esm/q2-carousel.entry.js +162 -29
  493. package/dist/esm/q2-carousel.entry.js.map +1 -1
  494. package/dist/esm/q2-chart-area.entry.js +1 -1
  495. package/dist/esm/q2-chart-bar.entry.js +1 -1
  496. package/dist/esm/q2-chart-donut.entry.js +3 -2
  497. package/dist/esm/q2-chart-donut.entry.js.map +1 -1
  498. package/dist/esm/q2-checkbox-group.entry.js +2 -2
  499. package/dist/esm/q2-checkbox-group.entry.js.map +1 -1
  500. package/dist/esm/q2-checkbox.q2-tag.entry.js.map +1 -1
  501. package/dist/esm/q2-checkbox_2.entry.js +3 -3
  502. package/dist/esm/q2-checkbox_2.entry.js.map +1 -1
  503. package/dist/esm/q2-context.entry.js +2 -2
  504. package/dist/esm/q2-context.entry.js.map +1 -1
  505. package/dist/esm/q2-currency.entry.js +3 -4
  506. package/dist/esm/q2-currency.entry.js.map +1 -1
  507. package/dist/esm/q2-data-table.entry.js +2 -2
  508. package/dist/esm/q2-data-table.entry.js.map +1 -1
  509. package/dist/esm/q2-detail.entry.js +2 -2
  510. package/dist/esm/q2-detail.entry.js.map +1 -1
  511. package/dist/esm/q2-dropdown-item.entry.js +2 -2
  512. package/dist/esm/q2-dropdown-item.entry.js.map +1 -1
  513. package/dist/esm/q2-dropdown.entry.js +3 -5
  514. package/dist/esm/q2-dropdown.entry.js.map +1 -1
  515. package/dist/esm/q2-editable-field.entry.js +1 -1
  516. package/dist/esm/q2-editable-field.entry.js.map +1 -1
  517. package/dist/esm/q2-example.entry.js +1 -1
  518. package/dist/esm/q2-file-picker.entry.js +1 -1
  519. package/dist/esm/q2-file-picker.entry.js.map +1 -1
  520. package/dist/esm/q2-form.entry.js +2 -2
  521. package/dist/esm/q2-form.entry.js.map +1 -1
  522. package/dist/esm/q2-formatted-text.entry.js +1 -1
  523. package/dist/esm/q2-formatted-text.entry.js.map +1 -1
  524. package/dist/esm/q2-grid-area.entry.js +1 -1
  525. package/dist/esm/q2-grid.entry.js +33 -9
  526. package/dist/esm/q2-grid.entry.js.map +1 -1
  527. package/dist/esm/q2-icon.entry.js +1 -1
  528. package/dist/esm/q2-icon.entry.js.map +1 -1
  529. package/dist/esm/q2-input.entry.js +8 -5
  530. package/dist/esm/q2-input.entry.js.map +1 -1
  531. package/dist/esm/q2-item.entry.js +2 -2
  532. package/dist/esm/q2-item.entry.js.map +1 -1
  533. package/dist/esm/q2-legend.entry.js +2 -3
  534. package/dist/esm/q2-legend.entry.js.map +1 -1
  535. package/dist/esm/q2-link.q2-list.entry.js.map +1 -1
  536. package/dist/esm/q2-link_2.entry.js +2 -2
  537. package/dist/esm/q2-link_2.entry.js.map +1 -1
  538. package/dist/esm/q2-loc.entry.js +1 -1
  539. package/dist/esm/q2-message.entry.js +3 -3
  540. package/dist/esm/q2-message.entry.js.map +1 -1
  541. package/dist/esm/q2-meter.entry.js +2 -2
  542. package/dist/esm/q2-meter.entry.js.map +1 -1
  543. package/dist/esm/q2-modal.entry.js +3 -3
  544. package/dist/esm/q2-modal.entry.js.map +1 -1
  545. package/dist/esm/q2-month-picker.entry.js +1 -1
  546. package/dist/esm/q2-mutation-observer.entry.js +1 -1
  547. package/dist/esm/q2-optgroup.entry.js +3 -3
  548. package/dist/esm/q2-optgroup.entry.js.map +1 -1
  549. package/dist/esm/q2-option.entry.js +3 -3
  550. package/dist/esm/q2-option.entry.js.map +1 -1
  551. package/dist/esm/q2-otp.entry.js +371 -0
  552. package/dist/esm/q2-otp.entry.js.map +1 -0
  553. package/dist/esm/q2-pagination.entry.js +4 -4
  554. package/dist/esm/q2-pagination.entry.js.map +1 -1
  555. package/dist/esm/q2-pill.entry.js +24 -15
  556. package/dist/esm/q2-pill.entry.js.map +1 -1
  557. package/dist/esm/q2-radio-group.entry.js +1 -1
  558. package/dist/esm/q2-radio-group.entry.js.map +1 -1
  559. package/dist/esm/q2-radio.entry.js +3 -3
  560. package/dist/esm/q2-radio.entry.js.map +1 -1
  561. package/dist/esm/q2-relative-time.entry.js +2 -2
  562. package/dist/esm/q2-section-container.entry.js +1 -1
  563. package/dist/esm/q2-section.entry.js +3 -3
  564. package/dist/esm/q2-section.entry.js.map +1 -1
  565. package/dist/esm/q2-select.entry.js +1 -1
  566. package/dist/esm/q2-select.entry.js.map +1 -1
  567. package/dist/esm/q2-stepper-pane.entry.js +3 -3
  568. package/dist/esm/q2-stepper-vertical.entry.js +2 -2
  569. package/dist/esm/q2-stepper-vertical.entry.js.map +1 -1
  570. package/dist/esm/q2-stepper.entry.js +2 -2
  571. package/dist/esm/q2-stepper.entry.js.map +1 -1
  572. package/dist/esm/q2-tab-container.entry.js +3 -3
  573. package/dist/esm/q2-tab-container.entry.js.map +1 -1
  574. package/dist/esm/q2-tab-pane.entry.js +2 -2
  575. package/dist/esm/q2-tecton-elements.js +1 -1
  576. package/dist/esm/q2-textarea.entry.js +1 -1
  577. package/dist/esm/q2-textarea.entry.js.map +1 -1
  578. package/dist/esm/q2-toast.entry.js +1 -1
  579. package/dist/esm/q2-toast.entry.js.map +1 -1
  580. package/dist/esm/q2-tooltip.entry.js +124 -5
  581. package/dist/esm/q2-tooltip.entry.js.map +1 -1
  582. package/dist/esm/{sanitize-html-string-B35VmRc9.js → sanitize-html-string-DPHNpMWE.js} +21 -4
  583. package/dist/{q2-tecton-elements/sanitize-html-string-B35VmRc9.js.map → esm/sanitize-html-string-DPHNpMWE.js.map} +1 -1
  584. package/dist/esm/tecton-tab-pane.entry.js +2 -2
  585. package/dist/playwright.config.js +12 -0
  586. package/dist/playwright.config.js.map +1 -0
  587. package/dist/q2-tecton-elements/assets/standard.symbol.svg +1 -1
  588. package/dist/q2-tecton-elements/click-elsewhere.q2-option-list.q2-popover.entry.esm.js.map +1 -1
  589. package/dist/q2-tecton-elements/click-elsewhere_3.entry.js +44 -35
  590. package/dist/q2-tecton-elements/click-elsewhere_3.entry.js.map +1 -1
  591. package/dist/q2-tecton-elements/component-DaQM9u3s.js +46 -0
  592. package/dist/q2-tecton-elements/component-DaQM9u3s.js.map +1 -0
  593. package/dist/q2-tecton-elements/{index-C4PILj1_.js → index-C5gj0T_3.js} +4 -4
  594. package/dist/q2-tecton-elements/index-C5gj0T_3.js.map +1 -0
  595. package/dist/q2-tecton-elements/q2-action-group.q2-resize-observer.entry.esm.js.map +1 -1
  596. package/dist/q2-tecton-elements/q2-action-group_2.entry.js +2 -2
  597. package/dist/q2-tecton-elements/q2-action-group_2.entry.js.map +1 -1
  598. package/dist/q2-tecton-elements/q2-action-sheet.entry.esm.js.map +1 -1
  599. package/dist/q2-tecton-elements/q2-action-sheet.entry.js +166 -70
  600. package/dist/q2-tecton-elements/q2-action-sheet.entry.js.map +1 -1
  601. package/dist/q2-tecton-elements/q2-avatar.entry.esm.js.map +1 -1
  602. package/dist/q2-tecton-elements/q2-avatar.entry.js.map +1 -1
  603. package/dist/q2-tecton-elements/q2-badge.entry.esm.js.map +1 -1
  604. package/dist/q2-tecton-elements/q2-badge.entry.js +1 -1
  605. package/dist/q2-tecton-elements/q2-badge.entry.js.map +1 -1
  606. package/dist/q2-tecton-elements/q2-btn.q2-loading.entry.esm.js.map +1 -1
  607. package/dist/q2-tecton-elements/q2-btn_2.entry.js +1 -1
  608. package/dist/q2-tecton-elements/q2-btn_2.entry.js.map +1 -1
  609. package/dist/q2-tecton-elements/q2-calendar.entry.esm.js.map +1 -1
  610. package/dist/q2-tecton-elements/q2-calendar.entry.js +4 -4
  611. package/dist/q2-tecton-elements/q2-calendar.entry.js.map +1 -1
  612. package/dist/q2-tecton-elements/q2-card-image.entry.esm.js.map +1 -1
  613. package/dist/q2-tecton-elements/q2-card-image.entry.js +2 -2
  614. package/dist/q2-tecton-elements/q2-card-image.entry.js.map +1 -1
  615. package/dist/q2-tecton-elements/q2-card.entry.esm.js.map +1 -1
  616. package/dist/q2-tecton-elements/q2-card.entry.js +1 -1
  617. package/dist/q2-tecton-elements/q2-card.entry.js.map +1 -1
  618. package/dist/q2-tecton-elements/q2-carousel-pane.entry.esm.js.map +1 -1
  619. package/dist/q2-tecton-elements/q2-carousel-pane.entry.js +6 -6
  620. package/dist/q2-tecton-elements/q2-carousel-pane.entry.js.map +1 -1
  621. package/dist/q2-tecton-elements/q2-carousel.entry.esm.js.map +1 -1
  622. package/dist/q2-tecton-elements/q2-carousel.entry.js +402 -271
  623. package/dist/q2-tecton-elements/q2-carousel.entry.js.map +1 -1
  624. package/dist/q2-tecton-elements/q2-chart-area.entry.js +1 -1
  625. package/dist/q2-tecton-elements/q2-chart-bar.entry.js +1 -1
  626. package/dist/q2-tecton-elements/q2-chart-donut.entry.esm.js.map +1 -1
  627. package/dist/q2-tecton-elements/q2-chart-donut.entry.js +18 -16
  628. package/dist/q2-tecton-elements/q2-chart-donut.entry.js.map +1 -1
  629. package/dist/q2-tecton-elements/q2-checkbox-group.entry.esm.js.map +1 -1
  630. package/dist/q2-tecton-elements/q2-checkbox-group.entry.js +2 -2
  631. package/dist/q2-tecton-elements/q2-checkbox-group.entry.js.map +1 -1
  632. package/dist/q2-tecton-elements/q2-checkbox.q2-tag.entry.esm.js.map +1 -1
  633. package/dist/q2-tecton-elements/q2-checkbox_2.entry.js +7 -7
  634. package/dist/q2-tecton-elements/q2-checkbox_2.entry.js.map +1 -1
  635. package/dist/q2-tecton-elements/q2-context.entry.esm.js.map +1 -1
  636. package/dist/q2-tecton-elements/q2-context.entry.js +2 -2
  637. package/dist/q2-tecton-elements/q2-context.entry.js.map +1 -1
  638. package/dist/q2-tecton-elements/q2-currency.entry.esm.js.map +1 -1
  639. package/dist/q2-tecton-elements/q2-currency.entry.js +34 -33
  640. package/dist/q2-tecton-elements/q2-currency.entry.js.map +1 -1
  641. package/dist/q2-tecton-elements/q2-data-table.entry.esm.js.map +1 -1
  642. package/dist/q2-tecton-elements/q2-data-table.entry.js +4 -4
  643. package/dist/q2-tecton-elements/q2-data-table.entry.js.map +1 -1
  644. package/dist/q2-tecton-elements/q2-detail.entry.esm.js.map +1 -1
  645. package/dist/q2-tecton-elements/q2-detail.entry.js +4 -4
  646. package/dist/q2-tecton-elements/q2-detail.entry.js.map +1 -1
  647. package/dist/q2-tecton-elements/q2-dropdown-item.entry.esm.js.map +1 -1
  648. package/dist/q2-tecton-elements/q2-dropdown-item.entry.js +2 -2
  649. package/dist/q2-tecton-elements/q2-dropdown-item.entry.js.map +1 -1
  650. package/dist/q2-tecton-elements/q2-dropdown.entry.esm.js.map +1 -1
  651. package/dist/q2-tecton-elements/q2-dropdown.entry.js +18 -19
  652. package/dist/q2-tecton-elements/q2-dropdown.entry.js.map +1 -1
  653. package/dist/q2-tecton-elements/q2-editable-field.entry.esm.js.map +1 -1
  654. package/dist/q2-tecton-elements/q2-editable-field.entry.js +1 -1
  655. package/dist/q2-tecton-elements/q2-editable-field.entry.js.map +1 -1
  656. package/dist/q2-tecton-elements/q2-example.entry.js +1 -1
  657. package/dist/q2-tecton-elements/q2-file-picker.entry.esm.js.map +1 -1
  658. package/dist/q2-tecton-elements/q2-file-picker.entry.js +1 -1
  659. package/dist/q2-tecton-elements/q2-file-picker.entry.js.map +1 -1
  660. package/dist/q2-tecton-elements/q2-form.entry.esm.js.map +1 -1
  661. package/dist/q2-tecton-elements/q2-form.entry.js +9 -9
  662. package/dist/q2-tecton-elements/q2-form.entry.js.map +1 -1
  663. package/dist/q2-tecton-elements/q2-formatted-text.entry.esm.js.map +1 -1
  664. package/dist/q2-tecton-elements/q2-formatted-text.entry.js +2 -2
  665. package/dist/q2-tecton-elements/q2-formatted-text.entry.js.map +1 -1
  666. package/dist/q2-tecton-elements/q2-grid-area.entry.js +1 -1
  667. package/dist/q2-tecton-elements/q2-grid.entry.esm.js.map +1 -1
  668. package/dist/q2-tecton-elements/q2-grid.entry.js +39 -14
  669. package/dist/q2-tecton-elements/q2-grid.entry.js.map +1 -1
  670. package/dist/q2-tecton-elements/q2-icon.entry.esm.js.map +1 -1
  671. package/dist/q2-tecton-elements/q2-icon.entry.js +52 -52
  672. package/dist/q2-tecton-elements/q2-icon.entry.js.map +1 -1
  673. package/dist/q2-tecton-elements/q2-input.entry.esm.js.map +1 -1
  674. package/dist/q2-tecton-elements/q2-input.entry.js +10 -6
  675. package/dist/q2-tecton-elements/q2-input.entry.js.map +1 -1
  676. package/dist/q2-tecton-elements/q2-item.entry.esm.js.map +1 -1
  677. package/dist/q2-tecton-elements/q2-item.entry.js +14 -14
  678. package/dist/q2-tecton-elements/q2-item.entry.js.map +1 -1
  679. package/dist/q2-tecton-elements/q2-legend.entry.esm.js.map +1 -1
  680. package/dist/q2-tecton-elements/q2-legend.entry.js +4 -5
  681. package/dist/q2-tecton-elements/q2-legend.entry.js.map +1 -1
  682. package/dist/q2-tecton-elements/q2-link.q2-list.entry.esm.js.map +1 -1
  683. package/dist/q2-tecton-elements/q2-link_2.entry.js +7 -7
  684. package/dist/q2-tecton-elements/q2-link_2.entry.js.map +1 -1
  685. package/dist/q2-tecton-elements/q2-loc.entry.js +1 -1
  686. package/dist/q2-tecton-elements/q2-message.entry.esm.js.map +1 -1
  687. package/dist/q2-tecton-elements/q2-message.entry.js +28 -28
  688. package/dist/q2-tecton-elements/q2-message.entry.js.map +1 -1
  689. package/dist/q2-tecton-elements/q2-meter.entry.esm.js.map +1 -1
  690. package/dist/q2-tecton-elements/q2-meter.entry.js +8 -8
  691. package/dist/q2-tecton-elements/q2-meter.entry.js.map +1 -1
  692. package/dist/q2-tecton-elements/q2-modal.entry.esm.js.map +1 -1
  693. package/dist/q2-tecton-elements/q2-modal.entry.js +53 -53
  694. package/dist/q2-tecton-elements/q2-modal.entry.js.map +1 -1
  695. package/dist/q2-tecton-elements/q2-month-picker.entry.js +1 -1
  696. package/dist/q2-tecton-elements/q2-mutation-observer.entry.js +1 -1
  697. package/dist/q2-tecton-elements/q2-optgroup.entry.esm.js.map +1 -1
  698. package/dist/q2-tecton-elements/q2-optgroup.entry.js +6 -6
  699. package/dist/q2-tecton-elements/q2-optgroup.entry.js.map +1 -1
  700. package/dist/q2-tecton-elements/q2-option.entry.esm.js.map +1 -1
  701. package/dist/q2-tecton-elements/q2-option.entry.js +3 -3
  702. package/dist/q2-tecton-elements/q2-option.entry.js.map +1 -1
  703. package/dist/q2-tecton-elements/q2-otp.entry.esm.js.map +1 -0
  704. package/dist/q2-tecton-elements/q2-otp.entry.js +453 -0
  705. package/dist/q2-tecton-elements/q2-otp.entry.js.map +1 -0
  706. package/dist/q2-tecton-elements/q2-pagination.entry.esm.js.map +1 -1
  707. package/dist/q2-tecton-elements/q2-pagination.entry.js +29 -29
  708. package/dist/q2-tecton-elements/q2-pagination.entry.js.map +1 -1
  709. package/dist/q2-tecton-elements/q2-pill.entry.esm.js.map +1 -1
  710. package/dist/q2-tecton-elements/q2-pill.entry.js +43 -28
  711. package/dist/q2-tecton-elements/q2-pill.entry.js.map +1 -1
  712. package/dist/q2-tecton-elements/q2-radio-group.entry.esm.js.map +1 -1
  713. package/dist/q2-tecton-elements/q2-radio-group.entry.js +1 -1
  714. package/dist/q2-tecton-elements/q2-radio-group.entry.js.map +1 -1
  715. package/dist/q2-tecton-elements/q2-radio.entry.esm.js.map +1 -1
  716. package/dist/q2-tecton-elements/q2-radio.entry.js +10 -10
  717. package/dist/q2-tecton-elements/q2-radio.entry.js.map +1 -1
  718. package/dist/q2-tecton-elements/q2-relative-time.entry.js +2 -2
  719. package/dist/q2-tecton-elements/q2-section-container.entry.js +1 -1
  720. package/dist/q2-tecton-elements/q2-section.entry.esm.js.map +1 -1
  721. package/dist/q2-tecton-elements/q2-section.entry.js +21 -21
  722. package/dist/q2-tecton-elements/q2-section.entry.js.map +1 -1
  723. package/dist/q2-tecton-elements/q2-select.entry.esm.js.map +1 -1
  724. package/dist/q2-tecton-elements/q2-select.entry.js +1 -1
  725. package/dist/q2-tecton-elements/q2-select.entry.js.map +1 -1
  726. package/dist/q2-tecton-elements/q2-stepper-pane.entry.js +10 -10
  727. package/dist/q2-tecton-elements/q2-stepper-vertical.entry.esm.js.map +1 -1
  728. package/dist/q2-tecton-elements/q2-stepper-vertical.entry.js +5 -5
  729. package/dist/q2-tecton-elements/q2-stepper-vertical.entry.js.map +1 -1
  730. package/dist/q2-tecton-elements/q2-stepper.entry.esm.js.map +1 -1
  731. package/dist/q2-tecton-elements/q2-stepper.entry.js +33 -33
  732. package/dist/q2-tecton-elements/q2-stepper.entry.js.map +1 -1
  733. package/dist/q2-tecton-elements/q2-tab-container.entry.esm.js.map +1 -1
  734. package/dist/q2-tecton-elements/q2-tab-container.entry.js +14 -14
  735. package/dist/q2-tecton-elements/q2-tab-container.entry.js.map +1 -1
  736. package/dist/q2-tecton-elements/q2-tab-pane.entry.js +6 -6
  737. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js +1 -1
  738. package/dist/q2-tecton-elements/q2-textarea.entry.esm.js.map +1 -1
  739. package/dist/q2-tecton-elements/q2-textarea.entry.js +1 -1
  740. package/dist/q2-tecton-elements/q2-textarea.entry.js.map +1 -1
  741. package/dist/q2-tecton-elements/q2-toast.entry.esm.js.map +1 -1
  742. package/dist/q2-tecton-elements/q2-toast.entry.js +1 -1
  743. package/dist/q2-tecton-elements/q2-toast.entry.js.map +1 -1
  744. package/dist/q2-tecton-elements/q2-tooltip.entry.esm.js.map +1 -1
  745. package/dist/q2-tecton-elements/q2-tooltip.entry.js +136 -20
  746. package/dist/q2-tecton-elements/q2-tooltip.entry.js.map +1 -1
  747. package/dist/q2-tecton-elements/{sanitize-html-string-B35VmRc9.js → sanitize-html-string-DPHNpMWE.js} +147 -142
  748. package/dist/{esm/sanitize-html-string-B35VmRc9.js.map → q2-tecton-elements/sanitize-html-string-DPHNpMWE.js.map} +1 -1
  749. package/dist/q2-tecton-elements/tecton-tab-pane.entry.js +6 -6
  750. package/dist/types/builds/q2e/development/tecton/tecton/packages/q2-tecton-elements/.stencil/playwright.config.d.ts +2 -0
  751. package/dist/types/components/q2-action-sheet/q2-action-sheet.d.ts +22 -0
  752. package/dist/types/components/q2-avatar/test/q2-avatar-test.vr.d.ts +1 -0
  753. package/dist/types/components/q2-badge/test/q2-badge-test.vr.d.ts +1 -0
  754. package/dist/types/components/q2-btn/test/q2-btn-test.vr.d.ts +1 -0
  755. package/dist/types/components/q2-calendar/test/q2-calendar-test.vr.d.ts +1 -0
  756. package/dist/types/components/q2-card/test/q2-card-test.vr.d.ts +1 -0
  757. package/dist/types/components/q2-card-image/test/q2-card-image-test.vr.d.ts +1 -0
  758. package/dist/types/components/q2-carousel/q2-carousel.d.ts +29 -0
  759. package/dist/types/components/q2-carousel/test/q2-carousel-test.vr.d.ts +1 -0
  760. package/dist/types/components/q2-chart-area/test/q2-chart-area-test.vr.d.ts +1 -0
  761. package/dist/types/components/q2-chart-bar/test/q2-chart-bar-test.vr.d.ts +1 -0
  762. package/dist/types/components/q2-chart-donut/q2-chart-donut.d.ts +2 -0
  763. package/dist/types/components/q2-chart-donut/test/q2-chart-donut-test.vr.d.ts +1 -0
  764. package/dist/types/components/q2-checkbox/test/q2-checkbox-test.vr.d.ts +1 -0
  765. package/dist/types/components/q2-checkbox-group/test/q2-checkbox-group-test.vr.d.ts +1 -0
  766. package/dist/types/components/q2-context/test/q2-context-test.vr.d.ts +1 -0
  767. package/dist/types/components/q2-currency/test/q2-currency-test.vr.d.ts +1 -0
  768. package/dist/types/components/q2-data-table/test/q2-data-table-test.vr.d.ts +1 -0
  769. package/dist/types/components/q2-editable-field/test/q2-editable-field-test.vr.d.ts +1 -0
  770. package/dist/types/components/q2-file-picker/test/q2-file-picker-test.vr.d.ts +1 -0
  771. package/dist/types/components/q2-formatted-text/test/q2-formatted-text-test.vr.d.ts +1 -0
  772. package/dist/types/components/q2-grid/q2-grid.d.ts +10 -0
  773. package/dist/types/components/q2-icon/test/q2-icon-test.vr.d.ts +1 -0
  774. package/dist/types/components/q2-input/test/q2-input-test.vr.d.ts +1 -0
  775. package/dist/types/components/q2-legend/q2-legend.d.ts +2 -0
  776. package/dist/types/components/q2-link/test/q2-link-test.vr.d.ts +1 -0
  777. package/dist/types/components/q2-list/test/q2-list-test.vr.d.ts +1 -0
  778. package/dist/types/components/q2-message/test/q2-message-test.vr.d.ts +1 -0
  779. package/dist/types/components/q2-meter/test/q2-meter-test.vr.d.ts +1 -0
  780. package/dist/types/components/q2-modal/test/q2-modal-test.vr.d.ts +1 -0
  781. package/dist/types/components/q2-otp/q2-otp.d.ts +159 -0
  782. package/dist/types/components/q2-pagination/test/q2-pagination-test.vr.d.ts +1 -0
  783. package/dist/types/components/q2-pill/q2-pill.d.ts +5 -2
  784. package/dist/types/components/q2-pill/test/q2-pill-test.vr.d.ts +1 -0
  785. package/dist/types/components/q2-radio/q2-radio.d.ts +1 -1
  786. package/dist/types/components/q2-radio/test/q2-radio-test.vr.d.ts +1 -0
  787. package/dist/types/components/q2-radio-group/test/q2-radio-group-test.vr.d.ts +1 -0
  788. package/dist/types/components/q2-section/test/q2-section-test.vr.d.ts +1 -0
  789. package/dist/types/components/q2-select/test/q2-select-test.vr.d.ts +1 -0
  790. package/dist/types/components/q2-stepper/test/q2-stepper-test.vr.d.ts +1 -0
  791. package/dist/types/components/q2-stepper-vertical/test/q2-stepper-vertical-test.vr.d.ts +1 -0
  792. package/dist/types/components/q2-tab-container/test/q2-tab-container-test.vr.d.ts +1 -0
  793. package/dist/types/components/q2-tag/test/q2-tag-test.vr.d.ts +1 -0
  794. package/dist/types/components/q2-textarea/test/q2-textarea-test.vr.d.ts +1 -0
  795. package/dist/types/components/q2-tooltip/q2-tooltip.d.ts +4 -0
  796. package/dist/types/components/q2-tooltip/test/q2-tooltip-test.vr.d.ts +1 -0
  797. package/dist/types/components.d.ts +306 -2
  798. package/dist/types/utils/component.d.ts +1 -1
  799. package/dist/types/utils/test/vr-helpers.d.ts +14 -0
  800. package/package.json +12 -3
  801. package/dist/cjs/component-DRAntnCA.js.map +0 -1
  802. package/dist/cjs/index-YvKoRT-t.js.map +0 -1
  803. package/dist/esm/component-DVxzK3WH.js.map +0 -1
  804. package/dist/esm/index-C4PILj1_.js.map +0 -1
  805. package/dist/q2-tecton-elements/component-DVxzK3WH.js +0 -40
  806. package/dist/q2-tecton-elements/component-DVxzK3WH.js.map +0 -1
  807. package/dist/q2-tecton-elements/index-C4PILj1_.js.map +0 -1
@@ -0,0 +1,371 @@
1
+ import { r as registerInstance, c as createEvent, h, g as getElement } from './index-CGkHOjh1.js';
2
+ import { c as createGuid, o as overrideFocus, i as isEventFromElement, l as loc } from './index-C5gj0T_3.js';
3
+
4
+ const q2OtpCss = "*{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%}";
5
+
6
+ const Q2Otp = class {
7
+ constructor(hostRef) {
8
+ registerInstance(this, hostRef);
9
+ this.tctClear = createEvent(this, "tctClear", 7);
10
+ this.tctComplete = createEvent(this, "tctComplete", 7);
11
+ this.tctInput = createEvent(this, "tctInput", 7);
12
+ this.tctSendCode = createEvent(this, "tctSendCode", 7);
13
+ this.tctSubmit = createEvent(this, "tctSubmit", 7);
14
+ // #region Own Properties
15
+ this.defaultSendCodeLabel = 'tecton.element.otp.sendCode';
16
+ this.defaultSendCodeLabelValue = 'Send code';
17
+ this.defaultSubmitLabel = 'tecton.element.otp.verify';
18
+ this.defaultSubmitLabelValue = 'Verify';
19
+ this.guid = createGuid();
20
+ this.hasAutoFocused = false;
21
+ // #endregion
22
+ // #region State Properties
23
+ this.hasFocus = false;
24
+ // #endregion
25
+ // #region Public Property API
26
+ /** Focuses the first one-time password field when the component loads. */
27
+ this.autoFocus = false;
28
+ /** Triggers submission when the last field is filled. */
29
+ this.autoSubmit = false;
30
+ /** Clears all fields and returns focus to the first field when `state` becomes `error`. */
31
+ this.clearOnError = false;
32
+ /** Disables all one-time password fields. */
33
+ this.disabled = false;
34
+ /** Number of one-time password fields. */
35
+ this.length = 4 | 6 | 8;
36
+ /** Obscures entered characters. */
37
+ this.masked = false;
38
+ /** Toggles helper text visibility. */
39
+ this.showHelperText = false;
40
+ /**
41
+ * Renders fields in two equal groups with a dash separator.
42
+ * @private
43
+ */
44
+ this.split = false;
45
+ /** The composed one-time password value. */
46
+ this.value = '';
47
+ this.handleFocusIn = () => {
48
+ if (this.state === 'error') {
49
+ this.value = '';
50
+ if (this.inputRef)
51
+ this.inputRef.value = '';
52
+ this.state = undefined;
53
+ }
54
+ this.hasFocus = true;
55
+ };
56
+ this.handleFocusOut = (event) => {
57
+ if (this.autoFocus && this.hasAutoFocused && !this.value && !event.relatedTarget) {
58
+ return;
59
+ }
60
+ this.hasFocus = false;
61
+ };
62
+ this.handleInputEvent = () => {
63
+ if (this.disabled || this.locksInput) {
64
+ this.inputRef.value = this.value;
65
+ return;
66
+ }
67
+ const digits = this.filterDigits(this.inputRef.value);
68
+ this.inputRef.value = digits;
69
+ if (this.state === 'error') {
70
+ this.state = undefined;
71
+ }
72
+ this.value = digits;
73
+ this.tctInput.emit({ value: digits });
74
+ if (digits.length === this.normalizedLength) {
75
+ this.handleComplete(digits);
76
+ }
77
+ };
78
+ this.handleKeyDown = (event) => {
79
+ if (event.key !== 'Enter')
80
+ return;
81
+ if (this.disabled || this.locksInput || !this.isComplete)
82
+ return;
83
+ event.preventDefault();
84
+ this.submit();
85
+ };
86
+ this.handlePaste = (event) => {
87
+ var _a, _b;
88
+ event.preventDefault();
89
+ if (this.disabled || this.locksInput)
90
+ return;
91
+ const pastedValue = (_b = (_a = event.clipboardData) === null || _a === void 0 ? void 0 : _a.getData('text')) !== null && _b !== void 0 ? _b : '';
92
+ const digits = this.filterDigits(pastedValue);
93
+ this.inputRef.value = digits;
94
+ if (this.state === 'error') {
95
+ this.state = undefined;
96
+ }
97
+ this.value = digits;
98
+ this.tctInput.emit({ value: digits });
99
+ if (digits.length === this.normalizedLength) {
100
+ this.handleComplete(digits);
101
+ }
102
+ };
103
+ this.handleSendCodeClick = () => {
104
+ var _a;
105
+ if (this.disabled)
106
+ return;
107
+ (_a = this.inputRef) === null || _a === void 0 ? void 0 : _a.focus();
108
+ this.state = undefined;
109
+ this.tctSendCode.emit();
110
+ };
111
+ this.handleSubmitClick = () => {
112
+ if (this.isVerifying || this.isSuccess)
113
+ return;
114
+ this.submit();
115
+ };
116
+ }
117
+ // #endregion
118
+ // #region Component Lifecycle Events
119
+ componentWillLoad() {
120
+ this.value = this.filterDigits(this.value);
121
+ }
122
+ componentDidLoad() {
123
+ overrideFocus(this.hostElement);
124
+ this.focusOnLoad();
125
+ }
126
+ componentDidRender() {
127
+ this.focusOnLoad();
128
+ }
129
+ // #endregion
130
+ // #region Listeners
131
+ onHostElementFocus(event) {
132
+ var _a, _b;
133
+ if (this.disabled || this.locksInput)
134
+ return;
135
+ if (!isEventFromElement(event, this.hostElement))
136
+ return;
137
+ if (this.isAwaitingSendCode) {
138
+ (_a = this.sendCodeRef) === null || _a === void 0 ? void 0 : _a.focus();
139
+ return;
140
+ }
141
+ (_b = this.inputRef) === null || _b === void 0 ? void 0 : _b.focus();
142
+ }
143
+ // #endregion
144
+ // #region Public Methods API
145
+ /**
146
+ * Clears all fields, focuses the first field, and emits `tctClear`.
147
+ */
148
+ async clear() {
149
+ this.clearValue(true);
150
+ }
151
+ /**
152
+ * Clears the component and resets error, success, and processing state.
153
+ */
154
+ async reset() {
155
+ this.clearValue(true);
156
+ this.state = undefined;
157
+ }
158
+ // #endregion
159
+ // #region Watchers
160
+ autoFocusObserver() {
161
+ this.focusOnLoad();
162
+ }
163
+ lengthObserver() {
164
+ if (this.value.length > this.normalizedLength) {
165
+ this.value = this.value.slice(0, this.normalizedLength);
166
+ }
167
+ }
168
+ stateObserver(state) {
169
+ if (state === null) {
170
+ Promise.resolve().then(() => {
171
+ if (this.state === null)
172
+ this.state = undefined;
173
+ });
174
+ return;
175
+ }
176
+ if (state === 'error' && this.clearOnError) {
177
+ this.clearValue(true);
178
+ }
179
+ }
180
+ valueObserver() {
181
+ const digits = this.filterDigits(this.value);
182
+ if (digits !== this.value) {
183
+ this.value = digits;
184
+ }
185
+ if (this.inputRef && this.inputRef.value !== digits) {
186
+ this.inputRef.value = digits;
187
+ }
188
+ }
189
+ // #endregion
190
+ // #region Local Methods
191
+ get activeSlotIndex() {
192
+ return Math.min(this.value.length, this.normalizedLength - 1);
193
+ }
194
+ get componentId() {
195
+ return `q2-otp-${this.guid}`;
196
+ }
197
+ get describedBy() {
198
+ const ids = [];
199
+ if (this.state === 'error' && this.errorMessage)
200
+ ids.push(this.messageId);
201
+ if (this.state === 'success' && this.successMessage)
202
+ ids.push(this.messageId);
203
+ return ids.length ? ids.join(' ') : undefined;
204
+ }
205
+ get hasVisibleHelperText() {
206
+ return this.showHelperText && !!this.helperText;
207
+ }
208
+ get helperTextId() {
209
+ return `${this.componentId}-helper-text`;
210
+ }
211
+ get inputAriaLabel() {
212
+ const inputLabel = `${this.localizedLabel} (${this.normalizedLength} ${loc('tecton.element.otp.digits')})`;
213
+ return [this.hasVisibleHelperText ? this.localizedHelperText : '', inputLabel].filter(Boolean).join(' ');
214
+ }
215
+ get isAwaitingSendCode() {
216
+ return this.state === 'ready';
217
+ }
218
+ get isComplete() {
219
+ return this.value.length === this.normalizedLength;
220
+ }
221
+ get isSuccess() {
222
+ return this.state === 'success';
223
+ }
224
+ get isVerifying() {
225
+ return this.state === 'verifying';
226
+ }
227
+ get labelId() {
228
+ return `${this.componentId}-label`;
229
+ }
230
+ get localizedHelperText() {
231
+ return loc(this.helperText);
232
+ }
233
+ get localizedLabel() {
234
+ return loc(this.label);
235
+ }
236
+ get localizedProcessingLabel() {
237
+ return loc(this.processingLabel || 'Verifying');
238
+ }
239
+ get localizedSendCodeLabel() {
240
+ if (this.sendCodeLabel)
241
+ return loc(this.sendCodeLabel);
242
+ const localizedLabel = loc(this.defaultSendCodeLabel);
243
+ return localizedLabel === this.defaultSendCodeLabel ? this.defaultSendCodeLabelValue : localizedLabel;
244
+ }
245
+ get localizedSubmitLabel() {
246
+ if (this.submitLabel)
247
+ return loc(this.submitLabel);
248
+ const localizedLabel = loc(this.defaultSubmitLabel);
249
+ return localizedLabel === this.defaultSubmitLabel ? this.defaultSubmitLabelValue : localizedLabel;
250
+ }
251
+ get locksInput() {
252
+ return this.isVerifying || this.isSuccess;
253
+ }
254
+ get messageId() {
255
+ return `${this.componentId}-message`;
256
+ }
257
+ get normalizedLength() {
258
+ const length = Number(this.length);
259
+ return [4, 6, 8].includes(length) ? length : 6;
260
+ }
261
+ clearValue(emitEvent = false) {
262
+ var _a;
263
+ this.value = '';
264
+ if (this.inputRef)
265
+ this.inputRef.value = '';
266
+ (_a = this.inputRef) === null || _a === void 0 ? void 0 : _a.focus();
267
+ if (emitEvent)
268
+ this.tctClear.emit({ value: '' });
269
+ }
270
+ filterDigits(value) {
271
+ return value.replace(/\D/g, '').slice(0, this.normalizedLength);
272
+ }
273
+ focusOnLoad() {
274
+ if (!this.autoFocus || this.hasAutoFocused || this.disabled || this.locksInput)
275
+ return;
276
+ setTimeout(() => {
277
+ if (!this.autoFocus || this.hasAutoFocused || this.disabled || this.locksInput || !this.inputRef) {
278
+ return;
279
+ }
280
+ this.hasAutoFocused = true;
281
+ this.hasFocus = true;
282
+ this.inputRef.focus();
283
+ }, 100);
284
+ }
285
+ handleComplete(digits) {
286
+ this.tctComplete.emit({ value: digits });
287
+ if (this.autoSubmit) {
288
+ setTimeout(() => this.submit(digits), 150);
289
+ }
290
+ }
291
+ submit(value = this.value) {
292
+ this.state = 'verifying';
293
+ this.tctSubmit.emit({ value });
294
+ }
295
+ // #endregion
296
+ // #region Render Methods
297
+ renderFields() {
298
+ return Array.from({ length: this.normalizedLength }, (_, index) => {
299
+ const char = this.value[index] || '';
300
+ const isActive = this.hasFocus && index === this.activeSlotIndex;
301
+ const hasValue = !!char;
302
+ return [
303
+ this.split && index === this.normalizedLength / 2 && (h("span", { "aria-hidden": "true", class: "otp-separator" }, "-")),
304
+ h("div", { class: {
305
+ 'otp-slot': true,
306
+ 'is-active': isActive,
307
+ 'has-value': hasValue,
308
+ } }, isActive && !hasValue ? (h("span", { class: "otp-caret", "aria-hidden": "true" })) : this.masked && hasValue ? (h("span", { class: "otp-dot" })) : (h("span", { class: "otp-char" }, char))),
309
+ ];
310
+ });
311
+ }
312
+ renderHelperText() {
313
+ if (!this.hasVisibleHelperText)
314
+ return;
315
+ return (h("div", { class: "helper-text", id: this.helperTextId }, this.localizedHelperText));
316
+ }
317
+ renderLabel() {
318
+ if (!this.label)
319
+ return;
320
+ return (h("div", { class: "otp-label", id: this.labelId }, this.localizedLabel));
321
+ }
322
+ renderMessage() {
323
+ if (this.state === 'error' && this.errorMessage) {
324
+ return (h("q2-message", { appearance: "minimal", class: "otp-message", id: this.messageId, type: "error" }, loc(this.errorMessage)));
325
+ }
326
+ if (this.state === 'success' && this.successMessage) {
327
+ return (h("q2-message", { appearance: "minimal", class: "otp-message", id: this.messageId, type: "success" }, loc(this.successMessage)));
328
+ }
329
+ }
330
+ renderProcessingOverlay() {
331
+ if (this.autoSubmit && this.isVerifying) {
332
+ return (h("div", { class: "processing-overlay" }, h("q2-loading", { label: this.localizedProcessingLabel })));
333
+ }
334
+ }
335
+ renderSendCodeButton() {
336
+ if (!this.isAwaitingSendCode)
337
+ return;
338
+ return (h("q2-btn", { block: true, class: "send-code-button", disabled: this.disabled, intent: "workflow-primary", label: this.localizedSendCodeLabel, onClick: this.handleSendCodeClick, ref: el => (this.sendCodeRef = el) }));
339
+ }
340
+ renderSubmitArea() {
341
+ if (this.isSuccess) {
342
+ return (h("q2-btn", { block: true, class: "submit-button", intent: "neutral", onClick: this.handleSubmitClick }, h("q2-icon", { type: "checkmark" }), loc('Success')));
343
+ }
344
+ return (h("q2-btn", { block: true, class: "submit-button", disabled: this.disabled || !this.isComplete, intent: "workflow-primary", label: this.isVerifying ? this.localizedProcessingLabel : this.localizedSubmitLabel, loading: this.isVerifying, onClick: this.handleSubmitClick }));
345
+ }
346
+ render() {
347
+ return (h("div", { key: '3befb9c99f5fa35e6f7d653b256306513499e2fe', "aria-busy": this.isVerifying ? 'true' : undefined, "aria-labelledby": this.label ? this.labelId : undefined, class: {
348
+ 'otp-container': true,
349
+ 'has-focus': this.hasFocus,
350
+ 'is-masked': this.masked,
351
+ 'send-code-pending': this.isAwaitingSendCode,
352
+ 'state-error': this.state === 'error',
353
+ 'state-success': this.state === 'success',
354
+ 'state-verifying': this.isVerifying,
355
+ [`length-${this.normalizedLength}`]: true,
356
+ }, role: "group" }, this.renderSendCodeButton(), h("div", { key: '813749faba075fda49bc4aa05366479b386b9256', class: { 'otp-content': true, 'send-code-hidden': this.isAwaitingSendCode } }, this.renderLabel(), h("div", { key: 'b9e4967cebebbec209359b6463502d9daab9a587', class: "otp-control-group" }, h("div", { key: '611bff112f241cde331858545954a9dd3ce4d116', class: "fields-shell" }, h("div", { key: '38b2d554c171c8b20ec075e2f9ccb6822274214d', class: "fields-container" }, h("input", { key: '3a2f27e7aa17940b070b1c7ce9b472d8c498192e', "aria-describedby": this.describedBy, "aria-invalid": this.state === 'error' ? 'true' : 'false', "aria-label": this.inputAriaLabel, autocomplete: "one-time-code", autofocus: this.autoFocus, class: "otp-hidden-input", disabled: this.disabled || this.isVerifying || this.isSuccess, inputmode: "numeric", maxLength: this.normalizedLength, onBlur: this.handleFocusOut, onFocus: this.handleFocusIn, onInput: this.handleInputEvent, onKeyDown: this.handleKeyDown, onPaste: this.handlePaste, pattern: "[0-9]*", ref: el => (this.inputRef = el), "test-id": "q2OtpInput", type: "text", value: this.value }), this.renderFields()), this.renderProcessingOverlay()), this.renderSubmitArea(), this.renderMessage()), this.renderHelperText())));
357
+ }
358
+ get hostElement() { return getElement(this); }
359
+ static get watchers() { return {
360
+ "autoFocus": ["autoFocusObserver"],
361
+ "length": ["lengthObserver"],
362
+ "state": ["stateObserver"],
363
+ "value": ["valueObserver"]
364
+ }; }
365
+ };
366
+ Q2Otp.style = q2OtpCss;
367
+
368
+ export { Q2Otp as q2_otp };
369
+ //# sourceMappingURL=q2-otp.entry.js.map
370
+
371
+ //# sourceMappingURL=q2-otp.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"q2-otp.entry.js","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"],"names":[],"mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  import { r as registerInstance, c as createEvent, h, g as getElement } from './index-CGkHOjh1.js';
2
- import { n as nextPaint, o as overrideFocus, i as isEventFromElement, l as loc } from './index-C4PILj1_.js';
2
+ import { n as nextPaint, o as overrideFocus, i as isEventFromElement, l as loc } from './index-C5gj0T_3.js';
3
3
  import { m as mirrorEmit } from './mirror-emit-DUjY_ucm.js';
4
4
 
5
5
  const q2PaginationCss = "*{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{display:flex;width:100%}:host([alignment=right]){justify-content:flex-end}:host([alignment=center]){justify-content:center}:host([alignment=left]){justify-content:flex-start}:host([hidden]){display:none}.container{display:inline-flex;column-gap:var(--tct-pagination-column-gap, var(--t-pagination-column-gap, var(--app-scale-2x, 10px)));align-items:center;height:var(--tct-pagination-height, var(--t-pagination-height, 44px));color:var(--tct-pagination-color, inherit);font-size:var(--tct-pagination-font-size, inherit);font-weight:var(--tct-pagination-font-weight, inherit)}.container.stacked{flex-direction:column;column-gap:0;row-gap:var(--tct-pagination-row-gap, var(--app-scale-2x, 10px));height:auto;align-items:stretch}.container.stacked .description{text-align:center}.container.stacked .controls{justify-content:center}.container.stacked .per-page{display:flex;justify-content:center}.container.stacked q2-select{--tct-select-margin:0;width:var(--tct-pagination-perpage-width, 60%)}.controls{display:flex}.btn-group{display:flex;gap:var(--tct-pagination-btn-gap, var(--t-pagination-btn-gap, 0))}.description,.input-display{white-space:nowrap}.input-display{display:grid;grid-template-columns:auto var(--tct-pagination-input-width, 50px) auto;align-items:center;gap:var(--tct-pagination-controls-gap, var(--t-pagination-controls-gap, var(--app-scale-1x, 5px)))}.input-display[hidden]{display:none}.input-wrapper{height:var(--tct-pagination-height, var(--t-pagination-height, 44px));display:flex;align-items:center}q2-btn{--tct-btn-border-radius:var(--tct-pagination-btn-border-radius, var(--t-pagination-btn-border-radius));--tct-btn-border:var(--tct-pagination-btn-border, var(--t-pagination-btn-border));--tct-btn-icon-hover-background:var(--tct-pagination-btn-hover-background, var(--app-gray-l3, #f2f2f2));--tct-icon-stroke-primary:var(--tct-pagination-btn-icon-stroke-primary, var(--app-gray, #747474));--tct-icon-stroke-secondary:var(--tct-pagination-btn-icon-stroke-secondary, var(--app-gray, #747474))}q2-icon{--tct-icon-size:var(--tct-pagination-icon-size, var(--t-pagination-icon-size, 12px));color:var(--tct-pagination-icon-color, var(--t-pagination-icon-color, var(--t-text, #4d4d4d)))}q2-input{--tct-input-margin-top:0;--tct-input-margin-bottom:0;--tct-input-height:var(--tct-pagination-input-height, var(--t-pagination-input-height, 30px));--tct-input-min-height:var(--tct-input-height);--tct-input-align:center}q2-select{--tct-select-input-min-height:var(--tct-pagination-select-height, var(--t-pagination-select-height, 30px));--tct-select-input-max-height:var(--tct-pagination-select-height, var(--t-pagination-select-height, 30px));width:var(--tct-pagination-perpage-width, var(--t-pagination-perpage-width, 100%));min-width:var(--tct-pagination-perpage-min-width, var(--t-pagination-perpage-min-width, 110px))}";
@@ -305,7 +305,7 @@ const Q2Pagination = class {
305
305
  total,
306
306
  });
307
307
  }
308
- return (h("nav", { key: '0947c1d04f042cb5f096d74146cc700e7993f277', class: this.containerClasses.join(' '), ref: el => (this.containerElement = el), "aria-label": loc('tecton.element.pagination.title') }, h("div", { key: '6da46e6c76dffa66026057e53c7515bcf00576e0', class: "description", "test-id": "description" }, pagesOnly
308
+ return (h("nav", { key: '8763672430fe7db0f31881ddb56ae2e145db2e1d', class: this.containerClasses.join(' '), ref: el => (this.containerElement = el), "aria-label": loc('tecton.element.pagination.title') }, h("div", { key: 'ed956602d3b7d8aef4265f98e9c83224e3d9ddfb', class: "description", "test-id": "description" }, pagesOnly
309
309
  ? loc('tecton.element.pagination.pages', {
310
310
  current: page,
311
311
  total: totalPages,
@@ -314,10 +314,10 @@ const Q2Pagination = class {
314
314
  range: currentRange,
315
315
  recordType: recordType.toLowerCase(),
316
316
  total: total.toLocaleString(),
317
- })), h("div", { key: '35963f235d6b549eedb8c9a443ecde053ecd8682', class: "controls" }, h("div", { key: '7016ffd2c95a76d34fd7ca112472a2a1067d7012', class: "btn-group" }, h("q2-btn", { key: 'a2a826b5ed84cedf548eaaf8aa2a8f95ad5085e6', ref: el => (this.firstPageBtn = el), label: loc('tecton.element.pagination.goToFirstPage'), disabled: disabled || onFirstPage, hidden: isFullViewHidden, onTctClick: () => this.handlePageChange(1), "test-id": "firstPageBtn", "hide-label": true }, h("q2-icon", { key: '7ebc8f748c55786954292287b4f593841a367e28', type: "chevron-double-left" })), h("q2-btn", { key: 'dfd853b3bee34fe837dc9c621829fa59c44bc81c', ref: el => (this.prevPageBtn = el), label: prevButtonLabel, disabled: disabled || onFirstPage, onTctClick: () => this.handlePageChange(page - 1), "test-id": "prevPageBtn", "hide-label": true }, h("q2-icon", { key: '519ef8ea441d04291b4393ba1ab03cd2198e88b3', type: "chevron-left" }))), h("div", { key: 'fd9d2f84689b857d134babd6d7d38de5f347488d', class: "input-display", hidden: isFullViewHidden }, h("span", { key: 'c8a48d708096badc6796a9caef840c807aa06db7', "aria-hidden": "true" }, loc('tecton.element.pagination.page')), h("div", { key: '1e9965fa782cdf724e261294ad22eb34305c1c69', class: "input-wrapper", onClick: () => this.inputField.dispatchEvent(new FocusEvent('focus')) }, h("q2-input", { key: 'e61dc0d32f806ffbee54736755f8c2c8fb3dc2a4', ref: el => (this.inputField = el), type: "number", value: `${page}`, min: 1, max: this.totalPages, hideLabel: true, optional: true, label: `${loc('tecton.element.pagination.page')} (${loc('tecton.element.pagination.ofPages', [totalPages.toLocaleString()])})`, onChange: event => event.stopImmediatePropagation(), onTctChange: event => {
317
+ })), h("div", { key: '97e385cf0f32b0f4aff62c501010eda743f731d4', class: "controls" }, h("div", { key: '5a21d4a3cd3d20fb7e533001537ba6533a135b7e', class: "btn-group" }, h("q2-btn", { key: 'fab99b68ddede211b84ea09ec2c0aa908b20c84f', ref: el => (this.firstPageBtn = el), label: loc('tecton.element.pagination.goToFirstPage'), disabled: disabled || onFirstPage, hidden: isFullViewHidden, onTctClick: () => this.handlePageChange(1), "test-id": "firstPageBtn", "hide-label": true }, h("q2-icon", { key: '78ddca1e5e40f1006ccc76d37a2acbef3a9b367e', type: "chevron-double-left" })), h("q2-btn", { key: 'ee99beff9982742339575be746768f0e0ba4b7dd', ref: el => (this.prevPageBtn = el), label: prevButtonLabel, disabled: disabled || onFirstPage, onTctClick: () => this.handlePageChange(page - 1), "test-id": "prevPageBtn", "hide-label": true }, h("q2-icon", { key: '2217e33508d661f4633aae1fc2a7606239c5cca3', type: "chevron-left" }))), h("div", { key: '0ef2e367f04e294dc5d55155d9cd1dd438b5d1e9', class: "input-display", hidden: isFullViewHidden }, h("span", { key: '94e65818ce517fe5b3039dc28321cf02f9bdd62a', "aria-hidden": "true" }, loc('tecton.element.pagination.page')), h("div", { key: '77b516a12af1e9473713088085481b41e7378dc6', class: "input-wrapper", onClick: () => this.inputField.dispatchEvent(new FocusEvent('focus')) }, h("q2-input", { key: 'f994ddf1fd6cbfe66bd7551f3d08d752177d079b', ref: el => (this.inputField = el), type: "number", value: `${page}`, min: 1, max: this.totalPages, hideLabel: true, optional: true, label: `${loc('tecton.element.pagination.page')} (${loc('tecton.element.pagination.ofPages', [totalPages.toLocaleString()])})`, onChange: event => event.stopImmediatePropagation(), onTctChange: event => {
318
318
  event.stopPropagation();
319
319
  this.handlePageChange(event.detail.value);
320
- }, "test-id": "pageInput", current: "page", disabled: disabled })), h("span", { key: 'ea7d626698765518e2e5dcd2118b20106413134d', "aria-hidden": "true" }, loc('tecton.element.pagination.ofPages', [totalPages.toLocaleString()]))), h("div", { key: 'eb93f6858f18c382d5ebe97007c7de6a3313e6cf', class: "btn-group" }, h("q2-btn", { key: '0ab9275fbfbc3514571f2fb308b1a15345816cf5', ref: el => (this.nextPageBtn = el), label: nextButtonLabel, disabled: disabled || onLastPage, onTctClick: () => this.handlePageChange(page + 1), "test-id": "nextPageBtn", "hide-label": true }, h("q2-icon", { key: '9968130c79eaaa564f1ca47ccc9e09a0d9ec564b', type: "chevron-right" })), h("q2-btn", { key: '08c3ebf15360ba2f1ccf56d2b12c458a2ebdb71e', ref: el => (this.lastPageBtn = el), label: "tecton.element.pagination.goToLastPage", disabled: disabled || onLastPage, hidden: isFullViewHidden, onTctClick: () => this.handlePageChange(totalPages), "test-id": "lastPageBtn", "hide-label": true }, h("q2-icon", { key: '83351e90f2645f9c2e8854ff46a684a9f43f339b', type: "chevron-double-right" })))), h("div", { key: 'dcdb653d221e0a92910a6ece5e234126e66c8410', class: "per-page", hidden: isFullViewHidden || !((_a = this.perPageIncrements) === null || _a === void 0 ? void 0 : _a.length) }, showPerPageSelect && this.renderPerPage())));
320
+ }, "test-id": "pageInput", current: "page", disabled: disabled })), h("span", { key: '5e2e425ef6f23d54014d1ac55cfc70dc637b8ac6', "aria-hidden": "true" }, loc('tecton.element.pagination.ofPages', [totalPages.toLocaleString()]))), h("div", { key: '0c786061e114793b5ea6a99dac53e3419a48867c', class: "btn-group" }, h("q2-btn", { key: '57bd0ac272a6d80000795511615ed198d0baf6ee', ref: el => (this.nextPageBtn = el), label: nextButtonLabel, disabled: disabled || onLastPage, onTctClick: () => this.handlePageChange(page + 1), "test-id": "nextPageBtn", "hide-label": true }, h("q2-icon", { key: '939f705dee78a26c664c82f783481316f5ff0813', type: "chevron-right" })), h("q2-btn", { key: '5e3c35772a15c571bad68f57f53494fe83af0959', ref: el => (this.lastPageBtn = el), label: "tecton.element.pagination.goToLastPage", disabled: disabled || onLastPage, hidden: isFullViewHidden, onTctClick: () => this.handlePageChange(totalPages), "test-id": "lastPageBtn", "hide-label": true }, h("q2-icon", { key: 'f9d2eb19cc20b1b2e68e8f0dfd0825a3a6f83263', type: "chevron-double-right" })))), h("div", { key: '983fb48580f634ff33f5ba6bec3af9304c67c99d', class: "per-page", hidden: isFullViewHidden || !((_a = this.perPageIncrements) === null || _a === void 0 ? void 0 : _a.length) }, showPerPageSelect && this.renderPerPage())));
321
321
  }
322
322
  get hostElement() { return getElement(this); }
323
323
  static get watchers() { return {