q2-tecton-elements 1.50.1 → 1.51.1

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 (578) hide show
  1. package/dist/cjs/click-elsewhere_2.cjs.entry.js +21 -12
  2. package/dist/cjs/click-elsewhere_2.cjs.entry.js.map +1 -1
  3. package/dist/cjs/index-9aa4a776.js +235 -0
  4. package/dist/cjs/index-9aa4a776.js.map +1 -0
  5. package/dist/cjs/{index-43010ce4.js → index-f69742cf.js} +1 -1
  6. package/dist/cjs/{index-43010ce4.js.map → index-f69742cf.js.map} +1 -1
  7. package/dist/cjs/loader.cjs.js +1 -1
  8. package/dist/cjs/q2-action-group.cjs.entry.js +50 -0
  9. package/dist/cjs/q2-action-group.cjs.entry.js.map +1 -0
  10. package/dist/cjs/q2-action-sheet.cjs.entry.js +1364 -3
  11. package/dist/cjs/q2-action-sheet.cjs.entry.js.map +1 -1
  12. package/dist/cjs/q2-avatar.cjs.entry.js +1 -1
  13. package/dist/cjs/q2-badge_7.cjs.entry.js +23 -13
  14. package/dist/cjs/q2-badge_7.cjs.entry.js.map +1 -1
  15. package/dist/cjs/q2-calendar.cjs.entry.js +2 -2
  16. package/dist/cjs/q2-card.cjs.entry.js +1 -1
  17. package/dist/cjs/q2-carousel-pane.cjs.entry.js +3 -3
  18. package/dist/cjs/q2-carousel.cjs.entry.js +1 -1
  19. package/dist/cjs/q2-chart-area.cjs.entry.js +2 -2
  20. package/dist/cjs/q2-chart-area.cjs.entry.js.map +1 -1
  21. package/dist/cjs/q2-chart-bar.cjs.entry.js +2 -2
  22. package/dist/cjs/q2-chart-bar.cjs.entry.js.map +1 -1
  23. package/dist/cjs/q2-chart-donut.cjs.entry.js +16 -16
  24. package/dist/cjs/q2-chart-donut.cjs.entry.js.map +1 -1
  25. package/dist/cjs/q2-checkbox-group.cjs.entry.js +2 -2
  26. package/dist/cjs/q2-checkbox-group.cjs.entry.js.map +1 -1
  27. package/dist/cjs/q2-checkbox.cjs.entry.js +1 -1
  28. package/dist/cjs/q2-currency.cjs.entry.js +1 -1
  29. package/dist/cjs/q2-data-table.cjs.entry.js +62 -62
  30. package/dist/cjs/q2-data-table.cjs.entry.js.map +1 -1
  31. package/dist/cjs/q2-detail.cjs.entry.js +2 -2
  32. package/dist/cjs/q2-dropdown-item.cjs.entry.js +2 -2
  33. package/dist/cjs/q2-dropdown-item.cjs.entry.js.map +1 -1
  34. package/dist/cjs/q2-dropdown.cjs.entry.js +79 -7
  35. package/dist/cjs/q2-dropdown.cjs.entry.js.map +1 -1
  36. package/dist/cjs/q2-editable-field.cjs.entry.js +1 -1
  37. package/dist/cjs/q2-formatted-text.cjs.entry.js +72 -0
  38. package/dist/cjs/q2-formatted-text.cjs.entry.js.map +1 -0
  39. package/dist/cjs/q2-item.cjs.entry.js +2 -2
  40. package/dist/cjs/q2-legend.cjs.entry.js +2 -2
  41. package/dist/cjs/q2-legend.cjs.entry.js.map +1 -1
  42. package/dist/cjs/q2-link.cjs.entry.js +64 -0
  43. package/dist/cjs/q2-link.cjs.entry.js.map +1 -0
  44. package/dist/cjs/q2-list.cjs.entry.js +2 -2
  45. package/dist/cjs/q2-loc.cjs.entry.js +2 -2
  46. package/dist/cjs/q2-message.cjs.entry.js +2 -2
  47. package/dist/cjs/q2-month-picker.cjs.entry.js +3 -3
  48. package/dist/cjs/q2-optgroup.cjs.entry.js +2 -2
  49. package/dist/cjs/q2-option-list.cjs.entry.js +9 -4
  50. package/dist/cjs/q2-option-list.cjs.entry.js.map +1 -1
  51. package/dist/cjs/q2-option.cjs.entry.js +1 -1
  52. package/dist/cjs/q2-pagination.cjs.entry.js +90 -9
  53. package/dist/cjs/q2-pagination.cjs.entry.js.map +1 -1
  54. package/dist/cjs/q2-pill.cjs.entry.js +26 -5
  55. package/dist/cjs/q2-pill.cjs.entry.js.map +1 -1
  56. package/dist/cjs/q2-radio-group.cjs.entry.js +2 -2
  57. package/dist/cjs/q2-radio-group.cjs.entry.js.map +1 -1
  58. package/dist/cjs/q2-radio.cjs.entry.js +1 -1
  59. package/dist/cjs/q2-relative-time.cjs.entry.js +3 -3
  60. package/dist/cjs/q2-resize-observer.cjs.entry.js +96 -0
  61. package/dist/cjs/q2-resize-observer.cjs.entry.js.map +1 -0
  62. package/dist/cjs/q2-section.cjs.entry.js +27 -3
  63. package/dist/cjs/q2-section.cjs.entry.js.map +1 -1
  64. package/dist/cjs/q2-select.cjs.entry.js +7 -6
  65. package/dist/cjs/q2-select.cjs.entry.js.map +1 -1
  66. package/dist/cjs/q2-stepper-pane.cjs.entry.js +1 -1
  67. package/dist/cjs/q2-stepper-vertical.cjs.entry.js +2 -2
  68. package/dist/cjs/q2-stepper.cjs.entry.js +39 -3
  69. package/dist/cjs/q2-stepper.cjs.entry.js.map +1 -1
  70. package/dist/cjs/q2-tag.cjs.entry.js +3 -2
  71. package/dist/cjs/q2-tag.cjs.entry.js.map +1 -1
  72. package/dist/cjs/q2-tecton-elements.cjs.js +1 -1
  73. package/dist/cjs/q2-textarea.cjs.entry.js +46 -11
  74. package/dist/cjs/q2-textarea.cjs.entry.js.map +1 -1
  75. package/dist/cjs/q2-tooltip.cjs.entry.js +2 -2
  76. package/dist/cjs/q2-tooltip.cjs.entry.js.map +1 -1
  77. package/dist/cjs/tecton-tab-pane.cjs.entry.js +2 -2
  78. package/dist/collection/collection-manifest.json +4 -0
  79. package/dist/collection/components/q2-action-group/q2-action-group.css +99 -0
  80. package/dist/collection/components/q2-action-group/q2-action-group.js +120 -0
  81. package/dist/collection/components/q2-action-group/q2-action-group.js.map +1 -0
  82. package/dist/collection/components/q2-action-group/test/q2-action-group.e2e.js +30 -0
  83. package/dist/collection/components/q2-action-group/test/q2-action-group.e2e.js.map +1 -0
  84. package/dist/collection/components/q2-action-group/test/q2-action-group.spec.js +156 -0
  85. package/dist/collection/components/q2-action-group/test/q2-action-group.spec.js.map +1 -0
  86. package/dist/collection/components/q2-action-sheet/q2-action-sheet.js +3 -2
  87. package/dist/collection/components/q2-action-sheet/q2-action-sheet.js.map +1 -1
  88. package/dist/collection/components/q2-avatar/q2-avatar.js +1 -1
  89. package/dist/collection/components/q2-avatar/test/q2-avatar-test.e2e.js +14 -9
  90. package/dist/collection/components/q2-avatar/test/q2-avatar-test.e2e.js.map +1 -1
  91. package/dist/collection/components/q2-badge/test/q2-badge-test.e2e.js +14 -9
  92. package/dist/collection/components/q2-badge/test/q2-badge-test.e2e.js.map +1 -1
  93. package/dist/collection/components/q2-btn/test/q2-btn-test.e2e.js +14 -9
  94. package/dist/collection/components/q2-btn/test/q2-btn-test.e2e.js.map +1 -1
  95. package/dist/collection/components/q2-calendar/q2-month-picker.js +2 -2
  96. package/dist/collection/components/q2-calendar/test/q2-calendar-test.e2e.js +227 -223
  97. package/dist/collection/components/q2-calendar/test/q2-calendar-test.e2e.js.map +1 -1
  98. package/dist/collection/components/q2-card/test/q2-card-test.e2e.js +12 -7
  99. package/dist/collection/components/q2-card/test/q2-card-test.e2e.js.map +1 -1
  100. package/dist/collection/components/q2-carousel/test/q2-carousel-test.e2e.js +49 -45
  101. package/dist/collection/components/q2-carousel/test/q2-carousel-test.e2e.js.map +1 -1
  102. package/dist/collection/components/q2-carousel-pane/q2-carousel-pane.js +2 -2
  103. package/dist/collection/components/q2-chart-area/q2-chart-area.js +2 -2
  104. package/dist/collection/components/q2-chart-area/q2-chart-area.js.map +1 -1
  105. package/dist/collection/components/q2-chart-area/test/q2-chart-area-test.e2e.js +12 -7
  106. package/dist/collection/components/q2-chart-area/test/q2-chart-area-test.e2e.js.map +1 -1
  107. package/dist/collection/components/q2-chart-bar/q2-chart-bar.js +2 -2
  108. package/dist/collection/components/q2-chart-bar/q2-chart-bar.js.map +1 -1
  109. package/dist/collection/components/q2-chart-bar/test/q2-chart-bar-test.e2e.js +16 -11
  110. package/dist/collection/components/q2-chart-bar/test/q2-chart-bar-test.e2e.js.map +1 -1
  111. package/dist/collection/components/q2-chart-donut/q2-chart-donut.js +15 -15
  112. package/dist/collection/components/q2-chart-donut/q2-chart-donut.js.map +1 -1
  113. package/dist/collection/components/q2-chart-donut/test/q2-chart-donut-test.e2e.js +32 -26
  114. package/dist/collection/components/q2-chart-donut/test/q2-chart-donut-test.e2e.js.map +1 -1
  115. package/dist/collection/components/q2-checkbox/test/q2-checkbox-test.e2e.js +12 -7
  116. package/dist/collection/components/q2-checkbox/test/q2-checkbox-test.e2e.js.map +1 -1
  117. package/dist/collection/components/q2-checkbox-group/q2-checkbox-group.js +2 -2
  118. package/dist/collection/components/q2-checkbox-group/q2-checkbox-group.js.map +1 -1
  119. package/dist/collection/components/q2-checkbox-group/test/q2-checkbox-group-test.e2e.js +22 -17
  120. package/dist/collection/components/q2-checkbox-group/test/q2-checkbox-group-test.e2e.js.map +1 -1
  121. package/dist/collection/components/q2-currency/q2-currency.js +1 -1
  122. package/dist/collection/components/q2-currency/test/q2-currency-test.e2e.js +12 -7
  123. package/dist/collection/components/q2-currency/test/q2-currency-test.e2e.js.map +1 -1
  124. package/dist/collection/components/q2-data-table/q2-data-table.js +104 -104
  125. package/dist/collection/components/q2-data-table/q2-data-table.js.map +1 -1
  126. package/dist/collection/components/q2-data-table/test/q2-data-table-test.e2e.js +42 -24
  127. package/dist/collection/components/q2-data-table/test/q2-data-table-test.e2e.js.map +1 -1
  128. package/dist/collection/components/q2-detail/q2-detail.js +1 -1
  129. package/dist/collection/components/q2-detail/test/q2-detail-test.e2e.js +12 -7
  130. package/dist/collection/components/q2-detail/test/q2-detail-test.e2e.js.map +1 -1
  131. package/dist/collection/components/q2-dropdown/q2-dropdown.js +207 -7
  132. package/dist/collection/components/q2-dropdown/q2-dropdown.js.map +1 -1
  133. package/dist/collection/components/q2-dropdown/test/q2-dropdown-test.e2e.js +297 -135
  134. package/dist/collection/components/q2-dropdown/test/q2-dropdown-test.e2e.js.map +1 -1
  135. package/dist/collection/components/q2-dropdown-item/q2-dropdown-item.js +1 -1
  136. package/dist/collection/components/q2-dropdown-item/q2-dropdown-item.js.map +1 -1
  137. package/dist/collection/components/q2-dropdown-item/test/q2-dropdown-item-test.e2e.js +18 -13
  138. package/dist/collection/components/q2-dropdown-item/test/q2-dropdown-item-test.e2e.js.map +1 -1
  139. package/dist/collection/components/q2-editable-field/test/q2-editable-field-test.e2e.js +14 -18
  140. package/dist/collection/components/q2-editable-field/test/q2-editable-field-test.e2e.js.map +1 -1
  141. package/dist/collection/components/q2-formatted-text/q2-formatted-text.css +94 -0
  142. package/dist/collection/components/q2-formatted-text/q2-formatted-text.js +230 -0
  143. package/dist/collection/components/q2-formatted-text/q2-formatted-text.js.map +1 -0
  144. package/dist/collection/components/q2-formatted-text/test/q2-formatted-text-test.e2e.js +430 -0
  145. package/dist/collection/components/q2-formatted-text/test/q2-formatted-text-test.e2e.js.map +1 -0
  146. package/dist/collection/components/q2-icon/test/q2-icon-test.e2e.js +14 -9
  147. package/dist/collection/components/q2-icon/test/q2-icon-test.e2e.js.map +1 -1
  148. package/dist/collection/components/q2-input/q2-input.css +9 -0
  149. package/dist/collection/components/q2-input/q2-input.js +7 -8
  150. package/dist/collection/components/q2-input/q2-input.js.map +1 -1
  151. package/dist/collection/components/q2-input/test/q2-input-test.e2e.js +50 -33
  152. package/dist/collection/components/q2-input/test/q2-input-test.e2e.js.map +1 -1
  153. package/dist/collection/components/q2-item/q2-item.js +1 -1
  154. package/dist/collection/components/q2-item/test/q2-item-test.e2e.js +32 -7
  155. package/dist/collection/components/q2-item/test/q2-item-test.e2e.js.map +1 -1
  156. package/dist/collection/components/q2-legend/q2-legend.css +1 -1
  157. package/dist/collection/components/q2-legend/q2-legend.js +1 -1
  158. package/dist/collection/components/q2-legend/test/q2-legend-test.e2e.js +13 -8
  159. package/dist/collection/components/q2-legend/test/q2-legend-test.e2e.js.map +1 -1
  160. package/dist/collection/components/q2-link/q2-link.css +146 -0
  161. package/dist/collection/components/q2-link/q2-link.js +242 -0
  162. package/dist/collection/components/q2-link/q2-link.js.map +1 -0
  163. package/dist/collection/components/q2-link/test/q2-link-test.e2e.js +145 -0
  164. package/dist/collection/components/q2-link/test/q2-link-test.e2e.js.map +1 -0
  165. package/dist/collection/components/q2-list/q2-list.js +1 -1
  166. package/dist/collection/components/q2-list/test/q2-list-test.e2e.js +12 -7
  167. package/dist/collection/components/q2-list/test/q2-list-test.e2e.js.map +1 -1
  168. package/dist/collection/components/q2-loading/test/q2-loading-element-test.e2e.js +14 -9
  169. package/dist/collection/components/q2-loading/test/q2-loading-element-test.e2e.js.map +1 -1
  170. package/dist/collection/components/q2-loading/test/q2-loading-test.e2e.js +14 -9
  171. package/dist/collection/components/q2-loading/test/q2-loading-test.e2e.js.map +1 -1
  172. package/dist/collection/components/q2-loc/q2-loc.js +1 -1
  173. package/dist/collection/components/q2-loc/test/q2-loc-test.e2e.js +16 -11
  174. package/dist/collection/components/q2-loc/test/q2-loc-test.e2e.js.map +1 -1
  175. package/dist/collection/components/q2-message/q2-message.js +1 -1
  176. package/dist/collection/components/q2-message/test/q2-message-test.e2e.js +14 -9
  177. package/dist/collection/components/q2-message/test/q2-message-test.e2e.js.map +1 -1
  178. package/dist/collection/components/q2-optgroup/q2-optgroup.js +1 -1
  179. package/dist/collection/components/q2-optgroup/test/q2-optgroup-test.e2e.js +20 -13
  180. package/dist/collection/components/q2-optgroup/test/q2-optgroup-test.e2e.js.map +1 -1
  181. package/dist/collection/components/q2-option/q2-option.js +1 -1
  182. package/dist/collection/components/q2-option/test/q2-option-test.e2e.js +28 -12
  183. package/dist/collection/components/q2-option/test/q2-option-test.e2e.js.map +1 -1
  184. package/dist/collection/components/q2-option-list/q2-option-list.js +7 -5
  185. package/dist/collection/components/q2-option-list/q2-option-list.js.map +1 -1
  186. package/dist/collection/components/q2-option-list/test/q2-option-list-test.e2e.js +415 -405
  187. package/dist/collection/components/q2-option-list/test/q2-option-list-test.e2e.js.map +1 -1
  188. package/dist/collection/components/q2-pagination/q2-pagination.js +230 -14
  189. package/dist/collection/components/q2-pagination/q2-pagination.js.map +1 -1
  190. package/dist/collection/components/q2-pagination/test/q2-pagination-test.e2e.js +138 -15
  191. package/dist/collection/components/q2-pagination/test/q2-pagination-test.e2e.js.map +1 -1
  192. package/dist/collection/components/q2-pill/q2-pill.css +12 -0
  193. package/dist/collection/components/q2-pill/q2-pill.js +43 -3
  194. package/dist/collection/components/q2-pill/q2-pill.js.map +1 -1
  195. package/dist/collection/components/q2-pill/test/q2-pill-test.e2e.js +412 -212
  196. package/dist/collection/components/q2-pill/test/q2-pill-test.e2e.js.map +1 -1
  197. package/dist/collection/components/q2-popover/q2-popover.js +37 -11
  198. package/dist/collection/components/q2-popover/q2-popover.js.map +1 -1
  199. package/dist/collection/components/q2-popover/test/q2-popover-test.e2e.js +296 -236
  200. package/dist/collection/components/q2-popover/test/q2-popover-test.e2e.js.map +1 -1
  201. package/dist/collection/components/q2-popover/test/q2-popover-test.spec.js +3 -3
  202. package/dist/collection/components/q2-popover/test/q2-popover-test.spec.js.map +1 -1
  203. package/dist/collection/components/q2-radio/test/q2-radio-test.e2e.js +21 -7
  204. package/dist/collection/components/q2-radio/test/q2-radio-test.e2e.js.map +1 -1
  205. package/dist/collection/components/q2-radio-group/q2-radio-group.js +2 -2
  206. package/dist/collection/components/q2-radio-group/q2-radio-group.js.map +1 -1
  207. package/dist/collection/components/q2-radio-group/test/q2-radio-group-test.e2e.js +32 -26
  208. package/dist/collection/components/q2-radio-group/test/q2-radio-group-test.e2e.js.map +1 -1
  209. package/dist/collection/components/q2-relative-time/q2-relative-time.js +1 -1
  210. package/dist/collection/components/q2-relative-time/test/q2-relative-time-test.e2e.js +12 -7
  211. package/dist/collection/components/q2-relative-time/test/q2-relative-time-test.e2e.js.map +1 -1
  212. package/dist/collection/components/q2-resize-observer/q2-resize-observer.css +71 -0
  213. package/dist/collection/components/q2-resize-observer/q2-resize-observer.js +166 -0
  214. package/dist/collection/components/q2-resize-observer/q2-resize-observer.js.map +1 -0
  215. package/dist/collection/components/q2-resize-observer/test/q2-resize-observer.e2e.js +83 -0
  216. package/dist/collection/components/q2-resize-observer/test/q2-resize-observer.e2e.js.map +1 -0
  217. package/dist/collection/components/q2-resize-observer/test/q2-resize-observer.spec.js +66 -0
  218. package/dist/collection/components/q2-resize-observer/test/q2-resize-observer.spec.js.map +1 -0
  219. package/dist/collection/components/q2-section/q2-section.js +78 -2
  220. package/dist/collection/components/q2-section/q2-section.js.map +1 -1
  221. package/dist/collection/components/q2-section/test/q2-section-test.e2e.js +39 -9
  222. package/dist/collection/components/q2-section/test/q2-section-test.e2e.js.map +1 -1
  223. package/dist/collection/components/q2-select/q2-select.js +23 -5
  224. package/dist/collection/components/q2-select/q2-select.js.map +1 -1
  225. package/dist/collection/components/q2-select/test/q2-select-test.e2e.js +695 -676
  226. package/dist/collection/components/q2-select/test/q2-select-test.e2e.js.map +1 -1
  227. package/dist/collection/components/q2-stepper/q2-stepper.js +76 -2
  228. package/dist/collection/components/q2-stepper/q2-stepper.js.map +1 -1
  229. package/dist/collection/components/q2-stepper/test/q2-stepper-test.e2e.js +183 -87
  230. package/dist/collection/components/q2-stepper/test/q2-stepper-test.e2e.js.map +1 -1
  231. package/dist/collection/components/q2-stepper-pane/q2-stepper-pane.js +2 -2
  232. package/dist/collection/components/q2-stepper-pane/test/q2-stepper-pane-test.e2e.js +20 -9
  233. package/dist/collection/components/q2-stepper-pane/test/q2-stepper-pane-test.e2e.js.map +1 -1
  234. package/dist/collection/components/q2-stepper-vertical/q2-stepper-vertical.js +1 -1
  235. package/dist/collection/components/q2-stepper-vertical/test/q2-stepper-vertical-test.e2e.js +71 -67
  236. package/dist/collection/components/q2-stepper-vertical/test/q2-stepper-vertical-test.e2e.js.map +1 -1
  237. package/dist/collection/components/q2-tab-container/q2-tab-container.js +50 -7
  238. package/dist/collection/components/q2-tab-container/q2-tab-container.js.map +1 -1
  239. package/dist/collection/components/q2-tab-container/test/q2-tab-container-test.e2e.js +89 -65
  240. package/dist/collection/components/q2-tab-container/test/q2-tab-container-test.e2e.js.map +1 -1
  241. package/dist/collection/components/q2-tab-pane/q2-tab-pane.js +1 -1
  242. package/dist/collection/components/q2-tab-pane/test/q2-tab-pane-test.e2e.js +14 -9
  243. package/dist/collection/components/q2-tab-pane/test/q2-tab-pane-test.e2e.js.map +1 -1
  244. package/dist/collection/components/q2-tag/q2-tag.js +19 -1
  245. package/dist/collection/components/q2-tag/q2-tag.js.map +1 -1
  246. package/dist/collection/components/q2-tag/test/q2-tag-test.e2e.js +47 -28
  247. package/dist/collection/components/q2-tag/test/q2-tag-test.e2e.js.map +1 -1
  248. package/dist/collection/components/q2-textarea/q2-textarea.js +51 -13
  249. package/dist/collection/components/q2-textarea/q2-textarea.js.map +1 -1
  250. package/dist/collection/components/q2-textarea/test/q2-textarea-test.e2e.js +31 -10
  251. package/dist/collection/components/q2-textarea/test/q2-textarea-test.e2e.js.map +1 -1
  252. package/dist/collection/components/q2-tooltip/q2-tooltip.css +5 -2
  253. package/dist/collection/components/q2-tooltip/test/q2-tooltip-test.e2e.js +51 -13
  254. package/dist/collection/components/q2-tooltip/test/q2-tooltip-test.e2e.js.map +1 -1
  255. package/dist/collection/components/tecton-tab-pane/tecton-tab-pane.js +2 -2
  256. package/dist/collection/components/tecton-tab-pane/test/tecton-tab-pane-test.e2e.js +18 -13
  257. package/dist/collection/components/tecton-tab-pane/test/tecton-tab-pane-test.e2e.js.map +1 -1
  258. package/dist/collection/utils/helpers.js +65 -0
  259. package/dist/collection/utils/helpers.js.map +1 -1
  260. package/dist/collection/utils/index.js +11 -11
  261. package/dist/collection/utils/index.js.map +1 -1
  262. package/dist/collection/utils/sanitize-html-string.js +10 -0
  263. package/dist/collection/utils/sanitize-html-string.js.map +1 -0
  264. package/dist/collection/utils/sanitize-regex-string.js +4 -0
  265. package/dist/collection/utils/sanitize-regex-string.js.map +1 -0
  266. package/dist/components/index.js +8 -0
  267. package/dist/components/index.js.map +1 -1
  268. package/dist/components/index2.js +11 -1356
  269. package/dist/components/index2.js.map +1 -1
  270. package/dist/components/q2-action-group.d.ts +11 -0
  271. package/dist/components/q2-action-group.js +75 -0
  272. package/dist/components/q2-action-group.js.map +1 -0
  273. package/dist/components/q2-action-sheet.js +1363 -2
  274. package/dist/components/q2-action-sheet.js.map +1 -1
  275. package/dist/components/q2-avatar2.js +1 -1
  276. package/dist/components/q2-btn2.js +1 -1
  277. package/dist/components/q2-carousel-pane.js +2 -2
  278. package/dist/components/q2-chart-area.js +1 -1
  279. package/dist/components/q2-chart-area.js.map +1 -1
  280. package/dist/components/q2-chart-bar.js +1 -1
  281. package/dist/components/q2-chart-bar.js.map +1 -1
  282. package/dist/components/q2-chart-donut.js +15 -15
  283. package/dist/components/q2-chart-donut.js.map +1 -1
  284. package/dist/components/q2-checkbox-group.js +2 -2
  285. package/dist/components/q2-checkbox-group.js.map +1 -1
  286. package/dist/components/q2-currency.js +1 -1
  287. package/dist/components/q2-data-table.js +64 -64
  288. package/dist/components/q2-data-table.js.map +1 -1
  289. package/dist/components/q2-detail.js +1 -1
  290. package/dist/components/q2-dropdown-item2.js +1 -1
  291. package/dist/components/q2-dropdown-item2.js.map +1 -1
  292. package/dist/components/q2-dropdown.js +84 -7
  293. package/dist/components/q2-dropdown.js.map +1 -1
  294. package/dist/components/q2-formatted-text.d.ts +11 -0
  295. package/dist/components/q2-formatted-text.js +101 -0
  296. package/dist/components/q2-formatted-text.js.map +1 -0
  297. package/dist/components/q2-input2.js +4 -5
  298. package/dist/components/q2-input2.js.map +1 -1
  299. package/dist/components/q2-item.js +1 -1
  300. package/dist/components/q2-legend2.js +2 -2
  301. package/dist/components/q2-legend2.js.map +1 -1
  302. package/dist/components/q2-link.d.ts +11 -0
  303. package/dist/components/q2-link.js +93 -0
  304. package/dist/components/q2-link.js.map +1 -0
  305. package/dist/components/q2-list.js +1 -1
  306. package/dist/components/q2-loc.js +1 -1
  307. package/dist/components/q2-message2.js +1 -1
  308. package/dist/components/q2-month-picker.js +2 -2
  309. package/dist/components/q2-optgroup2.js +1 -1
  310. package/dist/components/q2-option-list2.js +8 -3
  311. package/dist/components/q2-option-list2.js.map +1 -1
  312. package/dist/components/q2-option2.js +1 -1
  313. package/dist/components/q2-pagination.js +97 -10
  314. package/dist/components/q2-pagination.js.map +1 -1
  315. package/dist/components/q2-pill.js +29 -5
  316. package/dist/components/q2-pill.js.map +1 -1
  317. package/dist/components/q2-popover2.js +22 -12
  318. package/dist/components/q2-popover2.js.map +1 -1
  319. package/dist/components/q2-radio-group.js +2 -2
  320. package/dist/components/q2-radio-group.js.map +1 -1
  321. package/dist/components/q2-relative-time.js +1 -1
  322. package/dist/components/q2-resize-observer.d.ts +11 -0
  323. package/dist/components/q2-resize-observer.js +8 -0
  324. package/dist/components/q2-resize-observer.js.map +1 -0
  325. package/dist/components/q2-resize-observer2.js +112 -0
  326. package/dist/components/q2-resize-observer2.js.map +1 -0
  327. package/dist/components/q2-section.js +30 -4
  328. package/dist/components/q2-section.js.map +1 -1
  329. package/dist/components/q2-select2.js +7 -5
  330. package/dist/components/q2-select2.js.map +1 -1
  331. package/dist/components/q2-stepper-vertical.js +1 -1
  332. package/dist/components/q2-stepper.js +40 -3
  333. package/dist/components/q2-stepper.js.map +1 -1
  334. package/dist/components/q2-tab-container.js +20 -8
  335. package/dist/components/q2-tab-container.js.map +1 -1
  336. package/dist/components/q2-tab-pane.js +1 -1
  337. package/dist/components/q2-tag.js +3 -1
  338. package/dist/components/q2-tag.js.map +1 -1
  339. package/dist/components/q2-textarea.js +49 -12
  340. package/dist/components/q2-textarea.js.map +1 -1
  341. package/dist/components/q2-tooltip.js +1 -1
  342. package/dist/components/q2-tooltip.js.map +1 -1
  343. package/dist/components/tecton-tab-pane.js +2 -2
  344. package/dist/esm/click-elsewhere_2.entry.js +21 -12
  345. package/dist/esm/click-elsewhere_2.entry.js.map +1 -1
  346. package/dist/esm/{index-c6d74f10.js → index-3184c760.js} +1 -1
  347. package/dist/esm/{index-c6d74f10.js.map → index-3184c760.js.map} +1 -1
  348. package/dist/esm/index-844fc010.js +211 -0
  349. package/dist/esm/index-844fc010.js.map +1 -0
  350. package/dist/esm/loader.js +1 -1
  351. package/dist/esm/q2-action-group.entry.js +46 -0
  352. package/dist/esm/q2-action-group.entry.js.map +1 -0
  353. package/dist/esm/q2-action-sheet.entry.js +1363 -2
  354. package/dist/esm/q2-action-sheet.entry.js.map +1 -1
  355. package/dist/esm/q2-avatar.entry.js +1 -1
  356. package/dist/esm/q2-badge_7.entry.js +23 -13
  357. package/dist/esm/q2-badge_7.entry.js.map +1 -1
  358. package/dist/esm/q2-calendar.entry.js +2 -2
  359. package/dist/esm/q2-card.entry.js +1 -1
  360. package/dist/esm/q2-carousel-pane.entry.js +3 -3
  361. package/dist/esm/q2-carousel.entry.js +1 -1
  362. package/dist/esm/q2-chart-area.entry.js +2 -2
  363. package/dist/esm/q2-chart-area.entry.js.map +1 -1
  364. package/dist/esm/q2-chart-bar.entry.js +2 -2
  365. package/dist/esm/q2-chart-bar.entry.js.map +1 -1
  366. package/dist/esm/q2-chart-donut.entry.js +16 -16
  367. package/dist/esm/q2-chart-donut.entry.js.map +1 -1
  368. package/dist/esm/q2-checkbox-group.entry.js +2 -2
  369. package/dist/esm/q2-checkbox-group.entry.js.map +1 -1
  370. package/dist/esm/q2-checkbox.entry.js +1 -1
  371. package/dist/esm/q2-currency.entry.js +1 -1
  372. package/dist/esm/q2-data-table.entry.js +62 -62
  373. package/dist/esm/q2-data-table.entry.js.map +1 -1
  374. package/dist/esm/q2-detail.entry.js +2 -2
  375. package/dist/esm/q2-dropdown-item.entry.js +2 -2
  376. package/dist/esm/q2-dropdown-item.entry.js.map +1 -1
  377. package/dist/esm/q2-dropdown.entry.js +79 -7
  378. package/dist/esm/q2-dropdown.entry.js.map +1 -1
  379. package/dist/esm/q2-editable-field.entry.js +1 -1
  380. package/dist/esm/q2-formatted-text.entry.js +68 -0
  381. package/dist/esm/q2-formatted-text.entry.js.map +1 -0
  382. package/dist/esm/q2-item.entry.js +2 -2
  383. package/dist/esm/q2-legend.entry.js +2 -2
  384. package/dist/esm/q2-legend.entry.js.map +1 -1
  385. package/dist/esm/q2-link.entry.js +60 -0
  386. package/dist/esm/q2-link.entry.js.map +1 -0
  387. package/dist/esm/q2-list.entry.js +2 -2
  388. package/dist/esm/q2-loc.entry.js +2 -2
  389. package/dist/esm/q2-message.entry.js +2 -2
  390. package/dist/esm/q2-month-picker.entry.js +3 -3
  391. package/dist/esm/q2-optgroup.entry.js +2 -2
  392. package/dist/esm/q2-option-list.entry.js +9 -4
  393. package/dist/esm/q2-option-list.entry.js.map +1 -1
  394. package/dist/esm/q2-option.entry.js +1 -1
  395. package/dist/esm/q2-pagination.entry.js +90 -9
  396. package/dist/esm/q2-pagination.entry.js.map +1 -1
  397. package/dist/esm/q2-pill.entry.js +26 -5
  398. package/dist/esm/q2-pill.entry.js.map +1 -1
  399. package/dist/esm/q2-radio-group.entry.js +2 -2
  400. package/dist/esm/q2-radio-group.entry.js.map +1 -1
  401. package/dist/esm/q2-radio.entry.js +1 -1
  402. package/dist/esm/q2-relative-time.entry.js +3 -3
  403. package/dist/esm/q2-resize-observer.entry.js +92 -0
  404. package/dist/esm/q2-resize-observer.entry.js.map +1 -0
  405. package/dist/esm/q2-section.entry.js +27 -3
  406. package/dist/esm/q2-section.entry.js.map +1 -1
  407. package/dist/esm/q2-select.entry.js +7 -6
  408. package/dist/esm/q2-select.entry.js.map +1 -1
  409. package/dist/esm/q2-stepper-pane.entry.js +1 -1
  410. package/dist/esm/q2-stepper-vertical.entry.js +2 -2
  411. package/dist/esm/q2-stepper.entry.js +39 -3
  412. package/dist/esm/q2-stepper.entry.js.map +1 -1
  413. package/dist/esm/q2-tag.entry.js +3 -2
  414. package/dist/esm/q2-tag.entry.js.map +1 -1
  415. package/dist/esm/q2-tecton-elements.js +1 -1
  416. package/dist/esm/q2-textarea.entry.js +47 -12
  417. package/dist/esm/q2-textarea.entry.js.map +1 -1
  418. package/dist/esm/q2-tooltip.entry.js +2 -2
  419. package/dist/esm/q2-tooltip.entry.js.map +1 -1
  420. package/dist/esm/tecton-tab-pane.entry.js +2 -2
  421. package/dist/q2-tecton-elements/{p-0a3a804a.entry.js → p-06701928.entry.js} +2 -2
  422. package/dist/q2-tecton-elements/{p-0a3a804a.entry.js.map → p-06701928.entry.js.map} +1 -1
  423. package/dist/q2-tecton-elements/{p-5d936af5.entry.js → p-07d1c3ae.entry.js} +2 -2
  424. package/dist/q2-tecton-elements/p-1305f7ca.entry.js +2 -0
  425. package/dist/q2-tecton-elements/p-1305f7ca.entry.js.map +1 -0
  426. package/dist/q2-tecton-elements/p-15ac45d6.js +2 -0
  427. package/dist/q2-tecton-elements/p-15ac45d6.js.map +1 -0
  428. package/dist/q2-tecton-elements/{p-ce4e6b41.entry.js → p-16910682.entry.js} +2 -2
  429. package/dist/q2-tecton-elements/p-16910682.entry.js.map +1 -0
  430. package/dist/q2-tecton-elements/p-188eb162.entry.js +3 -0
  431. package/dist/q2-tecton-elements/p-188eb162.entry.js.map +1 -0
  432. package/dist/q2-tecton-elements/{p-58cafc0d.entry.js → p-1c760a89.entry.js} +2 -2
  433. package/dist/q2-tecton-elements/{p-074ae80c.entry.js → p-1c88d057.entry.js} +2 -2
  434. package/dist/q2-tecton-elements/{p-3b0d3cd4.entry.js → p-20a3d6ed.entry.js} +2 -2
  435. package/dist/q2-tecton-elements/p-20a3d6ed.entry.js.map +1 -0
  436. package/dist/q2-tecton-elements/{p-77a0cc0c.entry.js → p-2733583e.entry.js} +2 -2
  437. package/dist/q2-tecton-elements/{p-4116579f.entry.js → p-3e428290.entry.js} +2 -2
  438. package/dist/q2-tecton-elements/p-3e428290.entry.js.map +1 -0
  439. package/dist/q2-tecton-elements/{p-072c5877.entry.js → p-4774e5b3.entry.js} +2 -2
  440. package/dist/q2-tecton-elements/{p-77272c4c.entry.js → p-490ef8e5.entry.js} +2 -2
  441. package/dist/q2-tecton-elements/{p-0a1dff75.entry.js → p-4e10550d.entry.js} +2 -2
  442. package/dist/q2-tecton-elements/p-4e10550d.entry.js.map +1 -0
  443. package/dist/q2-tecton-elements/{p-2ca6d44f.entry.js → p-50f7328f.entry.js} +2 -2
  444. package/dist/q2-tecton-elements/p-5637c486.entry.js +2 -0
  445. package/dist/q2-tecton-elements/p-5637c486.entry.js.map +1 -0
  446. package/dist/q2-tecton-elements/p-56df21b0.entry.js +2 -0
  447. package/dist/q2-tecton-elements/p-56df21b0.entry.js.map +1 -0
  448. package/dist/q2-tecton-elements/{p-34856c71.entry.js → p-5a834214.entry.js} +2 -2
  449. package/dist/q2-tecton-elements/{p-34856c71.entry.js.map → p-5a834214.entry.js.map} +1 -1
  450. package/dist/q2-tecton-elements/p-5f99a4a8.entry.js +2 -0
  451. package/dist/q2-tecton-elements/p-5f99a4a8.entry.js.map +1 -0
  452. package/dist/q2-tecton-elements/p-72d948b4.entry.js +2 -0
  453. package/dist/q2-tecton-elements/p-72d948b4.entry.js.map +1 -0
  454. package/dist/q2-tecton-elements/{p-3c7be0bb.entry.js → p-7903cd15.entry.js} +2 -2
  455. package/dist/q2-tecton-elements/p-7903cd15.entry.js.map +1 -0
  456. package/dist/q2-tecton-elements/{p-d2e1631a.entry.js → p-7906f49e.entry.js} +2 -2
  457. package/dist/q2-tecton-elements/{p-d2e1631a.entry.js.map → p-7906f49e.entry.js.map} +1 -1
  458. package/dist/q2-tecton-elements/{p-2fcaf2d6.entry.js → p-7aef0c08.entry.js} +2 -2
  459. package/dist/q2-tecton-elements/{p-8a4b106d.entry.js → p-7c9a0122.entry.js} +2 -2
  460. package/dist/q2-tecton-elements/p-7c9f8b62.entry.js +2 -0
  461. package/dist/q2-tecton-elements/p-7c9f8b62.entry.js.map +1 -0
  462. package/dist/q2-tecton-elements/{p-cf32b5db.entry.js → p-81fbe718.entry.js} +2 -2
  463. package/dist/q2-tecton-elements/p-81fbe718.entry.js.map +1 -0
  464. package/dist/q2-tecton-elements/{p-6237c775.entry.js → p-896c7008.entry.js} +2 -2
  465. package/dist/q2-tecton-elements/{p-395904b4.entry.js → p-8d07cf91.entry.js} +2 -2
  466. package/dist/q2-tecton-elements/{p-fffb54e9.entry.js → p-8d2b02e1.entry.js} +2 -2
  467. package/dist/q2-tecton-elements/{p-6e6d9793.entry.js → p-95a7c042.entry.js} +2 -2
  468. package/dist/q2-tecton-elements/{p-45407ecc.entry.js → p-96b1406c.entry.js} +2 -2
  469. package/dist/q2-tecton-elements/{p-cb3f48de.entry.js → p-a47597dd.entry.js} +2 -2
  470. package/dist/q2-tecton-elements/p-a47597dd.entry.js.map +1 -0
  471. package/dist/q2-tecton-elements/p-a5d0e252.entry.js +2 -0
  472. package/dist/q2-tecton-elements/p-a5d0e252.entry.js.map +1 -0
  473. package/dist/q2-tecton-elements/{p-2c26295e.entry.js → p-ac6aa392.entry.js} +2 -2
  474. package/dist/q2-tecton-elements/{p-376a0589.entry.js → p-ad057d10.entry.js} +2 -2
  475. package/dist/q2-tecton-elements/{p-ad998f71.entry.js → p-b0e5e9dc.entry.js} +2 -2
  476. package/dist/q2-tecton-elements/p-b0e5e9dc.entry.js.map +1 -0
  477. package/dist/q2-tecton-elements/{p-34696e3f.entry.js → p-b1784be3.entry.js} +2 -2
  478. package/dist/q2-tecton-elements/{p-259b728a.entry.js → p-b7de110e.entry.js} +2 -2
  479. package/dist/q2-tecton-elements/{p-8111547c.entry.js → p-c235ab3f.entry.js} +2 -2
  480. package/dist/q2-tecton-elements/p-c5667d5d.entry.js +2 -0
  481. package/dist/q2-tecton-elements/p-c5667d5d.entry.js.map +1 -0
  482. package/dist/q2-tecton-elements/{p-c81d299a.entry.js → p-e216ef3f.entry.js} +2 -2
  483. package/dist/q2-tecton-elements/p-e2c800ef.entry.js +2 -0
  484. package/dist/q2-tecton-elements/p-e2c800ef.entry.js.map +1 -0
  485. package/dist/q2-tecton-elements/p-f135b265.entry.js +2 -0
  486. package/dist/q2-tecton-elements/p-f135b265.entry.js.map +1 -0
  487. package/dist/q2-tecton-elements/{p-721365be.js → p-f1e887f5.js} +1 -1
  488. package/dist/q2-tecton-elements/{p-6b7c53a8.entry.js → p-f5f23659.entry.js} +2 -2
  489. package/dist/q2-tecton-elements/p-f7867f21.entry.js +2 -0
  490. package/dist/q2-tecton-elements/p-f7867f21.entry.js.map +1 -0
  491. package/dist/q2-tecton-elements/p-ff8f1a32.entry.js +2 -0
  492. package/dist/q2-tecton-elements/p-ff8f1a32.entry.js.map +1 -0
  493. package/dist/q2-tecton-elements/p-fff01dc1.entry.js +2 -0
  494. package/dist/q2-tecton-elements/p-fff01dc1.entry.js.map +1 -0
  495. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js +1 -1
  496. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js.map +1 -1
  497. package/dist/types/components/q2-action-group/q2-action-group.d.ts +30 -0
  498. package/dist/types/components/q2-chart-area/q2-chart-area.d.ts +1 -1
  499. package/dist/types/components/q2-chart-bar/q2-chart-bar.d.ts +1 -1
  500. package/dist/types/components/q2-chart-donut/q2-chart-donut.d.ts +2 -0
  501. package/dist/types/components/q2-data-table/q2-data-table.d.ts +15 -13
  502. package/dist/types/components/q2-dropdown/q2-dropdown.d.ts +41 -2
  503. package/dist/types/components/q2-formatted-text/q2-formatted-text.d.ts +34 -0
  504. package/dist/types/components/q2-input/q2-input.d.ts +10 -9
  505. package/dist/types/components/q2-legend/q2-legend.d.ts +1 -0
  506. package/dist/types/components/q2-link/q2-link.d.ts +36 -0
  507. package/dist/types/components/q2-pagination/q2-pagination.d.ts +60 -3
  508. package/dist/types/components/q2-pill/q2-pill.d.ts +11 -0
  509. package/dist/types/components/q2-popover/q2-popover.d.ts +7 -1
  510. package/dist/types/components/q2-resize-observer/q2-resize-observer.d.ts +28 -0
  511. package/dist/types/components/q2-section/q2-section.d.ts +12 -0
  512. package/dist/types/components/q2-select/q2-select.d.ts +5 -0
  513. package/dist/types/components/q2-stepper/q2-stepper.d.ts +10 -1
  514. package/dist/types/components/q2-tab-container/q2-tab-container.d.ts +8 -2
  515. package/dist/types/components/q2-tag/q2-tag.d.ts +5 -0
  516. package/dist/types/components/q2-textarea/q2-textarea.d.ts +8 -3
  517. package/dist/types/components.d.ts +396 -18
  518. package/dist/types/utils/helpers.d.ts +28 -0
  519. package/dist/types/utils/index.d.ts +3 -3
  520. package/dist/types/utils/sanitize-html-string.d.ts +1 -0
  521. package/dist/types/utils/sanitize-regex-string.d.ts +1 -0
  522. package/package.json +4 -4
  523. package/dist/cjs/index-64d8b839.js +0 -1580
  524. package/dist/cjs/index-64d8b839.js.map +0 -1
  525. package/dist/esm/index-4a80972c.js +0 -1556
  526. package/dist/esm/index-4a80972c.js.map +0 -1
  527. package/dist/q2-tecton-elements/p-0a1dff75.entry.js.map +0 -1
  528. package/dist/q2-tecton-elements/p-3b0d3cd4.entry.js.map +0 -1
  529. package/dist/q2-tecton-elements/p-3c7be0bb.entry.js.map +0 -1
  530. package/dist/q2-tecton-elements/p-403bf3d4.entry.js +0 -2
  531. package/dist/q2-tecton-elements/p-403bf3d4.entry.js.map +0 -1
  532. package/dist/q2-tecton-elements/p-4116579f.entry.js.map +0 -1
  533. package/dist/q2-tecton-elements/p-661ed976.entry.js +0 -2
  534. package/dist/q2-tecton-elements/p-661ed976.entry.js.map +0 -1
  535. package/dist/q2-tecton-elements/p-9a1a4bc0.js +0 -3
  536. package/dist/q2-tecton-elements/p-9a1a4bc0.js.map +0 -1
  537. package/dist/q2-tecton-elements/p-a7a0b8aa.entry.js +0 -2
  538. package/dist/q2-tecton-elements/p-a7a0b8aa.entry.js.map +0 -1
  539. package/dist/q2-tecton-elements/p-aa57b657.entry.js +0 -2
  540. package/dist/q2-tecton-elements/p-aa57b657.entry.js.map +0 -1
  541. package/dist/q2-tecton-elements/p-ad998f71.entry.js.map +0 -1
  542. package/dist/q2-tecton-elements/p-adec9275.entry.js +0 -2
  543. package/dist/q2-tecton-elements/p-adec9275.entry.js.map +0 -1
  544. package/dist/q2-tecton-elements/p-adf0a7c9.entry.js +0 -2
  545. package/dist/q2-tecton-elements/p-adf0a7c9.entry.js.map +0 -1
  546. package/dist/q2-tecton-elements/p-b72fd065.entry.js +0 -2
  547. package/dist/q2-tecton-elements/p-b72fd065.entry.js.map +0 -1
  548. package/dist/q2-tecton-elements/p-c0c658d1.entry.js +0 -2
  549. package/dist/q2-tecton-elements/p-c0c658d1.entry.js.map +0 -1
  550. package/dist/q2-tecton-elements/p-cb3f48de.entry.js.map +0 -1
  551. package/dist/q2-tecton-elements/p-ce4e6b41.entry.js.map +0 -1
  552. package/dist/q2-tecton-elements/p-cf32b5db.entry.js.map +0 -1
  553. package/dist/q2-tecton-elements/p-cf966a0f.entry.js +0 -2
  554. package/dist/q2-tecton-elements/p-cf966a0f.entry.js.map +0 -1
  555. package/dist/q2-tecton-elements/p-dc77bf66.entry.js +0 -2
  556. package/dist/q2-tecton-elements/p-dc77bf66.entry.js.map +0 -1
  557. /package/dist/q2-tecton-elements/{p-5d936af5.entry.js.map → p-07d1c3ae.entry.js.map} +0 -0
  558. /package/dist/q2-tecton-elements/{p-58cafc0d.entry.js.map → p-1c760a89.entry.js.map} +0 -0
  559. /package/dist/q2-tecton-elements/{p-074ae80c.entry.js.map → p-1c88d057.entry.js.map} +0 -0
  560. /package/dist/q2-tecton-elements/{p-77a0cc0c.entry.js.map → p-2733583e.entry.js.map} +0 -0
  561. /package/dist/q2-tecton-elements/{p-072c5877.entry.js.map → p-4774e5b3.entry.js.map} +0 -0
  562. /package/dist/q2-tecton-elements/{p-77272c4c.entry.js.map → p-490ef8e5.entry.js.map} +0 -0
  563. /package/dist/q2-tecton-elements/{p-2ca6d44f.entry.js.map → p-50f7328f.entry.js.map} +0 -0
  564. /package/dist/q2-tecton-elements/{p-2fcaf2d6.entry.js.map → p-7aef0c08.entry.js.map} +0 -0
  565. /package/dist/q2-tecton-elements/{p-8a4b106d.entry.js.map → p-7c9a0122.entry.js.map} +0 -0
  566. /package/dist/q2-tecton-elements/{p-6237c775.entry.js.map → p-896c7008.entry.js.map} +0 -0
  567. /package/dist/q2-tecton-elements/{p-395904b4.entry.js.map → p-8d07cf91.entry.js.map} +0 -0
  568. /package/dist/q2-tecton-elements/{p-fffb54e9.entry.js.map → p-8d2b02e1.entry.js.map} +0 -0
  569. /package/dist/q2-tecton-elements/{p-6e6d9793.entry.js.map → p-95a7c042.entry.js.map} +0 -0
  570. /package/dist/q2-tecton-elements/{p-45407ecc.entry.js.map → p-96b1406c.entry.js.map} +0 -0
  571. /package/dist/q2-tecton-elements/{p-2c26295e.entry.js.map → p-ac6aa392.entry.js.map} +0 -0
  572. /package/dist/q2-tecton-elements/{p-376a0589.entry.js.map → p-ad057d10.entry.js.map} +0 -0
  573. /package/dist/q2-tecton-elements/{p-34696e3f.entry.js.map → p-b1784be3.entry.js.map} +0 -0
  574. /package/dist/q2-tecton-elements/{p-259b728a.entry.js.map → p-b7de110e.entry.js.map} +0 -0
  575. /package/dist/q2-tecton-elements/{p-8111547c.entry.js.map → p-c235ab3f.entry.js.map} +0 -0
  576. /package/dist/q2-tecton-elements/{p-c81d299a.entry.js.map → p-e216ef3f.entry.js.map} +0 -0
  577. /package/dist/q2-tecton-elements/{p-721365be.js.map → p-f1e887f5.js.map} +0 -0
  578. /package/dist/q2-tecton-elements/{p-6b7c53a8.entry.js.map → p-f5f23659.entry.js.map} +0 -0
@@ -15,19 +15,6 @@ describe('q2-dropdown', () => {
15
15
  let lastOption;
16
16
  let lastOptionFocusSpy;
17
17
  let closeDropdownBtn;
18
- describe('[A11y] guideline compliance', () => {
19
- it('Does not have accessibility violations with only label', async () => {
20
- const page = await setup({
21
- html: `
22
- <q2-dropdown label="My Dropdown">
23
- <q2-dropdown-item>Item Text</q2-dropdown-item>
24
- </q2-dropdown>
25
- `,
26
- });
27
- const hasViolations = await evaluateA11y(page);
28
- expect(hasViolations).toBe(false);
29
- });
30
- });
31
18
  it('properly compiles CSS vars and functions', async () => {
32
19
  const page = await setup({ html: '<q2-dropdown></q2-dropdown>' });
33
20
  expect(await getListOfStyleCompilationIssues(page, 'q2-dropdown')).toHaveLength(0);
@@ -192,32 +179,31 @@ describe('q2-dropdown', () => {
192
179
  page = await setup({
193
180
  html: `
194
181
  <q2-dropdown type="custom">
195
- <q2-avatar slot="custom-dropdown-button"></q2-avatar>
182
+ <q2-avatar slot="control"></q2-avatar>
196
183
  <q2-dropdown-item>Item 1 Text</q2-dropdown-item>
197
184
  </q2-dropdown>
198
185
  `,
199
186
  });
200
- const dropdownCustom = await page.find('q2-dropdown >>> [test-id="dropdownButton"]');
201
- expect(dropdownCustom).not.toHaveAttribute('icon');
187
+ const dropdownButton = await page.find('q2-dropdown >>> [test-id="dropdownButton"]');
188
+ expect(dropdownButton).not.toHaveAttribute('icon');
202
189
  });
203
- it('if type custom, show custom-dropdown-button slot', async () => {
190
+ it('if type is custom, show control slotted element', async () => {
204
191
  page = await setup({
205
192
  html: `
206
193
  <q2-dropdown type="custom">
207
- <q2-avatar slot="custom-dropdown-button"></q2-avatar>
194
+ <q2-avatar slot="control"></q2-avatar>
208
195
  <q2-dropdown-item>Item 1 Text</q2-dropdown-item>
209
196
  </q2-dropdown>
210
197
  `,
211
198
  });
212
- const dropdownCustom = await page.find('q2-dropdown >>> [test-id="dropdownButton"]');
213
- expect(dropdownCustom).not.toHaveAttribute('icon');
214
- const dropdownSlot = await page.find('q2-dropdown >>> [test-id="dropdownCustom"]');
215
- expect(dropdownSlot).not.toHaveClass('hidden');
199
+ const dropdownButton = await page.find('q2-dropdown >>> [test-id="dropdownButton"]');
200
+ expect(dropdownButton).not.toHaveAttribute('icon');
201
+ const dropdownControl = await page.find('q2-dropdown >>> [test-id="dropdownControl"]');
202
+ expect(dropdownControl).not.toHaveClass('hidden');
216
203
  const dropdown = await page.find('q2-dropdown');
217
204
  dropdown.setAttribute('type', 'icon');
218
205
  await page.waitForChanges();
219
- const dropdownButton = await page.find('q2-dropdown >>> [test-id="dropdownCustom"]');
220
- expect(dropdownButton).toHaveClass('hidden');
206
+ expect(dropdownControl).toHaveClass('hidden');
221
207
  });
222
208
  describe('focus transferring', () => {
223
209
  const html = `<q2-dropdown style="margin-top: 9999px">
@@ -379,6 +365,165 @@ describe('q2-dropdown', () => {
379
365
  expect(page.root.shadowRoot.querySelector('q2-popover').mode).toBe('legacy');
380
366
  });
381
367
  });
368
+ describe('popoverMaxHeight', () => {
369
+ it('when provided, passes the value to q2-popover', async () => {
370
+ const page = await newSpecPage({
371
+ components: [Q2Popover, Q2Dropdown, Q2DropdownItem],
372
+ html: `
373
+ <q2-dropdown popover-max-height="600">
374
+ <q2-dropdown-item>Item 1 Text</q2-dropdown-item>
375
+ <q2-dropdown-item>Item 2 Text</q2-dropdown-item>
376
+ </q2-dropdown>
377
+ `,
378
+ });
379
+ expect(page.root.shadowRoot.querySelector('q2-popover').maxHeight).toBe(600);
380
+ });
381
+ });
382
+ });
383
+ describe('Methods', () => {
384
+ beforeEach(async () => {
385
+ page = await setup({
386
+ html: `
387
+ <q2-dropdown>
388
+ <q2-dropdown-item value="item-1" test-id="item-1">Item 1 Text</q2-dropdown-item>
389
+ <q2-dropdown-item value="item-2" test-id="item-2">Item 2 Text</q2-dropdown-item>
390
+ </q2-dropdown>
391
+ `,
392
+ });
393
+ dropdown = await page.find('q2-dropdown');
394
+ firstOption = await page.find('q2-dropdown-item[test-id="item-1"]');
395
+ lastOption = await page.find('q2-dropdown-item[test-id="item-2"]');
396
+ });
397
+ describe('selectItem', () => {
398
+ it('does nothing if the dropdown is disabled', async () => {
399
+ const clickSpy = await firstOption.spyOnEvent('click');
400
+ dropdown.setProperty('disabled', true);
401
+ await page.waitForChanges();
402
+ await dropdown.callMethod('selectItem', 'item-1');
403
+ await page.waitForChanges();
404
+ expect(clickSpy).toHaveReceivedEventTimes(0);
405
+ });
406
+ it('does nothing if the provided value does not match any item', async () => {
407
+ const clickSpy = await firstOption.spyOnEvent('click');
408
+ await dropdown.callMethod('selectItem', 'invalid-item-value');
409
+ expect(clickSpy).toHaveReceivedEventTimes(0);
410
+ });
411
+ describe('when provided a valid value', () => {
412
+ it('opens the dropdown if not already open', async () => {
413
+ const popoverStateChangedSpy = await dropdown.spyOnEvent('popoverStateChanged');
414
+ await dropdown.callMethod('selectItem', 'item-1');
415
+ await page.waitForChanges();
416
+ expect(popoverStateChangedSpy).toHaveReceivedEventTimes(2);
417
+ });
418
+ it('clicks the item matching the provided value', async () => {
419
+ const clickSpy = await firstOption.spyOnEvent('click');
420
+ await dropdown.callMethod('selectItem', 'item-1');
421
+ await page.waitForChanges();
422
+ expect(clickSpy).toHaveReceivedEventDetail({ type: 'select', value: 'item-1' });
423
+ });
424
+ });
425
+ });
426
+ describe('selectRemoveItem', () => {
427
+ beforeEach(async () => {
428
+ firstOption.setProperty('removable', true);
429
+ lastOption.setProperty('removable', true);
430
+ await page.waitForChanges();
431
+ });
432
+ it('does nothing if the dropdown is disabled', async () => {
433
+ const clickSpy = await firstOption.spyOnEvent('click');
434
+ dropdown.setProperty('disabled', true);
435
+ await page.waitForChanges();
436
+ await dropdown.callMethod('selectRemoveItem', 'item-1');
437
+ await page.waitForChanges();
438
+ expect(clickSpy).toHaveReceivedEventTimes(0);
439
+ });
440
+ it('does nothing if the provided value does not match any item', async () => {
441
+ const clickSpy = await firstOption.spyOnEvent('click');
442
+ await dropdown.callMethod('selectRemoveItem', 'invalid-item-value');
443
+ expect(clickSpy).toHaveReceivedEventTimes(0);
444
+ });
445
+ it('does nothing if the item is not removable', async () => {
446
+ const clickSpy = await firstOption.spyOnEvent('click');
447
+ firstOption.setProperty('removable', false);
448
+ await page.waitForChanges();
449
+ await dropdown.callMethod('selectRemoveItem', 'item-1');
450
+ await page.waitForChanges();
451
+ expect(clickSpy).toHaveReceivedEventTimes(0);
452
+ });
453
+ describe('when provided a valid value', () => {
454
+ it('opens the dropdown if not already open', async () => {
455
+ const popoverStateChangedSpy = await dropdown.spyOnEvent('popoverStateChanged');
456
+ await dropdown.callMethod('selectRemoveItem', 'item-1');
457
+ await page.waitForChanges();
458
+ expect(popoverStateChangedSpy).toHaveReceivedEventTimes(2);
459
+ });
460
+ it('clicks the remove item button corresponding to the provided value', async () => {
461
+ const clickSpy = await firstOption.spyOnEvent('click');
462
+ await dropdown.callMethod('selectRemoveItem', 'item-1');
463
+ await page.waitForChanges();
464
+ expect(clickSpy).toHaveReceivedEventDetail({ type: 'remove', value: 'item-1' });
465
+ });
466
+ });
467
+ });
468
+ describe('openPopover', () => {
469
+ it('opens the dropdown', async () => {
470
+ const popoverStateChangedSpy = await dropdown.spyOnEvent('popoverStateChanged');
471
+ expect(await dropdown.getProperty('open')).toBeUndefined();
472
+ await dropdown.callMethod('openPopover');
473
+ await page.waitForChanges();
474
+ expect(await dropdown.getProperty('open')).toBe(true);
475
+ expect(popoverStateChangedSpy).toHaveReceivedEventTimes(1);
476
+ });
477
+ it('does nothing if the dropdown is disabled', async () => {
478
+ dropdown.setProperty('disabled', true);
479
+ await page.waitForChanges();
480
+ const popoverStateChangedSpy = await dropdown.spyOnEvent('popoverStateChanged');
481
+ await dropdown.callMethod('openPopover');
482
+ await page.waitForChanges();
483
+ expect(await dropdown.getProperty('open')).toBeUndefined();
484
+ expect(popoverStateChangedSpy).toHaveReceivedEventTimes(0);
485
+ });
486
+ it('does nothing if the dropdown is already open', async () => {
487
+ dropdown.setProperty('open', true);
488
+ await page.waitForChanges();
489
+ const popoverStateChangedSpy = await dropdown.spyOnEvent('popoverStateChanged');
490
+ expect(await dropdown.getProperty('open')).toBe(true);
491
+ await dropdown.callMethod('openPopover');
492
+ await page.waitForChanges();
493
+ expect(await dropdown.getProperty('open')).toBe(true);
494
+ expect(popoverStateChangedSpy).toHaveReceivedEventTimes(0);
495
+ });
496
+ });
497
+ describe('closePopover', () => {
498
+ it('closes the dropdown', async () => {
499
+ dropdown.setProperty('open', true);
500
+ await page.waitForChanges();
501
+ const popoverStateChangedSpy = await dropdown.spyOnEvent('popoverStateChanged');
502
+ expect(await dropdown.getProperty('open')).toBe(true);
503
+ await dropdown.callMethod('closePopover');
504
+ await page.waitForChanges();
505
+ expect(await dropdown.getProperty('open')).toBe(false);
506
+ expect(popoverStateChangedSpy).toHaveReceivedEventTimes(1);
507
+ });
508
+ it('does nothing if the dropdown is disabled', async () => {
509
+ dropdown.setProperty('open', true);
510
+ dropdown.setProperty('disabled', true);
511
+ await page.waitForChanges();
512
+ const popoverStateChangedSpy = await dropdown.spyOnEvent('popoverStateChanged');
513
+ await dropdown.callMethod('closePopover');
514
+ await page.waitForChanges();
515
+ expect(await dropdown.getProperty('open')).toBe(true);
516
+ expect(popoverStateChangedSpy).toHaveReceivedEventTimes(0);
517
+ });
518
+ it('does nothing if the dropdown is already closed', async () => {
519
+ const popoverStateChangedSpy = await dropdown.spyOnEvent('popoverStateChanged');
520
+ expect(await dropdown.getProperty('open')).toBeUndefined();
521
+ await dropdown.callMethod('closePopover');
522
+ await page.waitForChanges();
523
+ expect(await dropdown.getProperty('open')).toBeUndefined();
524
+ expect(popoverStateChangedSpy).toHaveReceivedEventTimes(0);
525
+ });
526
+ });
382
527
  });
383
528
  describe('Events', () => {
384
529
  describe('popoverStateChanged', () => {
@@ -464,117 +609,6 @@ describe('q2-dropdown', () => {
464
609
  });
465
610
  });
466
611
  });
467
- describe('Keyboard', () => {
468
- beforeEach(async () => {
469
- page = await setup({
470
- html: `
471
- <q2-dropdown>
472
- <q2-dropdown-item test-id="option-1">Item 1 Text</q2-dropdown-item>
473
- <q2-dropdown-item test-id="option-2">Item 2 Text</q2-dropdown-item>
474
- </q2-dropdown>
475
- <button>Outside Button</button>
476
- `,
477
- });
478
- dropdown = await page.find('q2-dropdown');
479
- dropdownButton = await page.find('q2-dropdown >>> [test-id="dropdownButton"]');
480
- buttonFocusSpy = await dropdownButton.spyOnEvent('focus');
481
- firstOption = await page.find('q2-dropdown-item:first-of-type');
482
- firstOptionFocusSpy = await firstOption.spyOnEvent('focus');
483
- lastOption = await page.find('q2-dropdown-item:last-of-type');
484
- lastOptionFocusSpy = await lastOption.spyOnEvent('focus');
485
- dropdownContainer = await page.find('q2-dropdown >>> click-elsewhere');
486
- expect(await dropdown.getProperty('open')).toBeUndefined();
487
- expect(buttonFocusSpy).toHaveReceivedEventTimes(0);
488
- expect(dropdownContainer).not.toHaveClass('dropdown-open');
489
- });
490
- describe('toggle button behavior', () => {
491
- describe('when popover is closed', () => {
492
- it('ArrowUp: opens the popover and focuses last item', async () => {
493
- await dropdownButton.press('ArrowUp');
494
- await page.waitForChanges();
495
- expect(dropdownContainer).toHaveClass('dropdown-open');
496
- expect(buttonFocusSpy).toHaveReceivedEventTimes(2);
497
- expect(lastOptionFocusSpy).toHaveReceivedEventTimes(1);
498
- });
499
- it('ArrowDown: opens the popover and focuses first item', async () => {
500
- await dropdownButton.press('ArrowDown');
501
- await page.waitForChanges();
502
- expect(dropdownContainer).toHaveClass('dropdown-open');
503
- expect(buttonFocusSpy).toHaveReceivedEventTimes(2);
504
- expect(firstOptionFocusSpy).toHaveReceivedEventTimes(1);
505
- });
506
- });
507
- describe('when popover is open', () => {
508
- beforeEach(async () => {
509
- dropdown.setProperty('open', true);
510
- await page.waitForChanges();
511
- expect(dropdownContainer).toHaveClass('dropdown-open');
512
- buttonFocusSpy.events = [];
513
- });
514
- it('Escape: closes the popover and focuses toggle button', async () => {
515
- await dropdownButton.press('Escape');
516
- await page.waitForChanges();
517
- expect(dropdownContainer).not.toHaveClass('dropdown-open');
518
- expect(buttonFocusSpy).toHaveReceivedEventTimes(2);
519
- });
520
- it('Tab: closes the popover and focuses next element in tab order', async () => {
521
- const outerButton = await page.find('button');
522
- const outerButtonSpy = await outerButton.spyOnEvent('focus');
523
- await dropdownButton.press('Tab');
524
- await page.waitForChanges();
525
- expect(dropdownContainer).not.toHaveClass('dropdown-open');
526
- expect(buttonFocusSpy).toHaveReceivedEventTimes(2);
527
- expect(outerButtonSpy).toHaveReceivedEventTimes(1);
528
- });
529
- });
530
- });
531
- describe('dropdown item behavior', () => {
532
- describe('when inside popover', () => {
533
- beforeEach(async () => {
534
- dropdown.setProperty('open', true);
535
- await page.waitForChanges();
536
- expect(dropdownContainer).toHaveClass('dropdown-open');
537
- buttonFocusSpy.events = [];
538
- firstOptionFocusSpy.events = [];
539
- lastOptionFocusSpy.events = [];
540
- });
541
- it('Escape: closes the popover and focuses the toggle button', async () => {
542
- await dispatchEvent(page, ['q2-dropdown-item'], 'focus');
543
- expect(firstOptionFocusSpy).toHaveReceivedEventTimes(1);
544
- await page.keyboard.press('Escape');
545
- await page.waitForChanges();
546
- expect(dropdownContainer).not.toHaveClass('dropdown-open');
547
- expect(buttonFocusSpy).toHaveReceivedEventTimes(2);
548
- });
549
- it('Tab: closes the popover and focuses next element in tab order', async () => {
550
- const outerButton = await page.find('button');
551
- const outerButtonSpy = await outerButton.spyOnEvent('focus');
552
- await dispatchEvent(page, ['q2-dropdown-item'], 'focus');
553
- expect(firstOptionFocusSpy).toHaveReceivedEventTimes(1);
554
- await page.keyboard.press('Tab');
555
- await page.waitForChanges();
556
- expect(dropdownContainer).not.toHaveClass('dropdown-open');
557
- expect(buttonFocusSpy).toHaveReceivedEventTimes(0);
558
- expect(outerButtonSpy).toHaveReceivedEventTimes(1);
559
- });
560
- it('ArrowUp: focuses the previous dropdown item', async () => {
561
- await dispatchEvent(page, ['q2-dropdown-item:last-of-type'], 'focus');
562
- expect(firstOptionFocusSpy).toHaveReceivedEventTimes(0);
563
- expect(lastOptionFocusSpy).toHaveReceivedEventTimes(1);
564
- await page.keyboard.press('ArrowUp');
565
- await page.waitForChanges();
566
- expect(firstOptionFocusSpy).toHaveReceivedEventTimes(1);
567
- });
568
- it('ArrowDown: focuses the next dropdown item', async () => {
569
- await dispatchEvent(page, ['q2-dropdown-item'], 'focus');
570
- expect(firstOptionFocusSpy).toHaveReceivedEventTimes(1);
571
- await page.keyboard.press('ArrowDown');
572
- await page.waitForChanges();
573
- expect(lastOptionFocusSpy).toHaveReceivedEventTimes(1);
574
- });
575
- });
576
- });
577
- });
578
612
  describe('Deprecations', () => {
579
613
  it('handles deprecated `popDirection` prop', async () => {
580
614
  page = await setup({
@@ -629,5 +663,133 @@ describe('q2-dropdown', () => {
629
663
  expect(await dropdown.getProperty('popoverAlignment')).toEqual('right');
630
664
  });
631
665
  });
666
+ describe('Accessibility', () => {
667
+ describe('aXe DevTools', () => {
668
+ it('does not have accessibility violations', async () => {
669
+ const page = await setup({
670
+ html: `
671
+ <q2-dropdown label="My Dropdown">
672
+ <q2-dropdown-item>Item Text</q2-dropdown-item>
673
+ </q2-dropdown>
674
+ `,
675
+ });
676
+ const hasViolations = await evaluateA11y(page);
677
+ expect(hasViolations).toBe(false);
678
+ });
679
+ });
680
+ describe('Accessibility Tree', () => { });
681
+ describe('Keyboard Controls', () => {
682
+ beforeEach(async () => {
683
+ page = await setup({
684
+ html: `
685
+ <q2-dropdown>
686
+ <q2-dropdown-item test-id="option-1">Item 1 Text</q2-dropdown-item>
687
+ <q2-dropdown-item test-id="option-2">Item 2 Text</q2-dropdown-item>
688
+ </q2-dropdown>
689
+ <button>Outside Button</button>
690
+ `,
691
+ });
692
+ dropdown = await page.find('q2-dropdown');
693
+ dropdownButton = await page.find('q2-dropdown >>> [test-id="dropdownButton"]');
694
+ buttonFocusSpy = await dropdownButton.spyOnEvent('focus');
695
+ firstOption = await page.find('q2-dropdown-item:first-of-type');
696
+ firstOptionFocusSpy = await firstOption.spyOnEvent('focus');
697
+ lastOption = await page.find('q2-dropdown-item:last-of-type');
698
+ lastOptionFocusSpy = await lastOption.spyOnEvent('focus');
699
+ dropdownContainer = await page.find('q2-dropdown >>> click-elsewhere');
700
+ expect(await dropdown.getProperty('open')).toBeUndefined();
701
+ expect(buttonFocusSpy).toHaveReceivedEventTimes(0);
702
+ expect(dropdownContainer).not.toHaveClass('dropdown-open');
703
+ });
704
+ describe('toggle button behavior', () => {
705
+ describe('when popover is closed', () => {
706
+ it('ArrowUp: opens the popover and focuses last item', async () => {
707
+ await dropdownButton.press('ArrowUp');
708
+ await page.waitForChanges();
709
+ expect(dropdownContainer).toHaveClass('dropdown-open');
710
+ expect(buttonFocusSpy).toHaveReceivedEventTimes(2);
711
+ expect(lastOptionFocusSpy).toHaveReceivedEventTimes(1);
712
+ });
713
+ it('ArrowDown: opens the popover and focuses first item', async () => {
714
+ await dropdownButton.press('ArrowDown');
715
+ await page.waitForChanges();
716
+ expect(dropdownContainer).toHaveClass('dropdown-open');
717
+ expect(buttonFocusSpy).toHaveReceivedEventTimes(2);
718
+ expect(firstOptionFocusSpy).toHaveReceivedEventTimes(1);
719
+ });
720
+ });
721
+ describe('when popover is open', () => {
722
+ beforeEach(async () => {
723
+ dropdown.setProperty('open', true);
724
+ await page.waitForChanges();
725
+ expect(dropdownContainer).toHaveClass('dropdown-open');
726
+ buttonFocusSpy.events = [];
727
+ });
728
+ it('Escape: closes the popover and focuses toggle button', async () => {
729
+ await dropdownButton.press('Escape');
730
+ await page.waitForChanges();
731
+ expect(dropdownContainer).not.toHaveClass('dropdown-open');
732
+ expect(buttonFocusSpy).toHaveReceivedEventTimes(2);
733
+ });
734
+ it('Tab: closes the popover and focuses next element in tab order', async () => {
735
+ const outerButton = await page.find('button');
736
+ const outerButtonSpy = await outerButton.spyOnEvent('focus');
737
+ await dropdownButton.press('Tab');
738
+ await page.waitForChanges();
739
+ expect(dropdownContainer).not.toHaveClass('dropdown-open');
740
+ expect(buttonFocusSpy).toHaveReceivedEventTimes(2);
741
+ expect(outerButtonSpy).toHaveReceivedEventTimes(1);
742
+ });
743
+ });
744
+ });
745
+ describe('dropdown item behavior', () => {
746
+ describe('when inside popover', () => {
747
+ beforeEach(async () => {
748
+ dropdown.setProperty('open', true);
749
+ await page.waitForChanges();
750
+ expect(dropdownContainer).toHaveClass('dropdown-open');
751
+ buttonFocusSpy.events = [];
752
+ firstOptionFocusSpy.events = [];
753
+ lastOptionFocusSpy.events = [];
754
+ });
755
+ it('Escape: closes the popover and focuses the toggle button', async () => {
756
+ await dispatchEvent(page, ['q2-dropdown-item'], 'focus');
757
+ expect(firstOptionFocusSpy).toHaveReceivedEventTimes(1);
758
+ await page.keyboard.press('Escape');
759
+ await page.waitForChanges();
760
+ expect(dropdownContainer).not.toHaveClass('dropdown-open');
761
+ expect(buttonFocusSpy).toHaveReceivedEventTimes(2);
762
+ });
763
+ it('Tab: closes the popover and focuses next element in tab order', async () => {
764
+ const outerButton = await page.find('button');
765
+ const outerButtonSpy = await outerButton.spyOnEvent('focus');
766
+ await dispatchEvent(page, ['q2-dropdown-item'], 'focus');
767
+ expect(firstOptionFocusSpy).toHaveReceivedEventTimes(1);
768
+ await page.keyboard.press('Tab');
769
+ await page.waitForChanges();
770
+ expect(dropdownContainer).not.toHaveClass('dropdown-open');
771
+ expect(buttonFocusSpy).toHaveReceivedEventTimes(0);
772
+ expect(outerButtonSpy).toHaveReceivedEventTimes(1);
773
+ });
774
+ it('ArrowUp: focuses the previous dropdown item', async () => {
775
+ await dispatchEvent(page, ['q2-dropdown-item:last-of-type'], 'focus');
776
+ expect(firstOptionFocusSpy).toHaveReceivedEventTimes(0);
777
+ expect(lastOptionFocusSpy).toHaveReceivedEventTimes(1);
778
+ await page.keyboard.press('ArrowUp');
779
+ await page.waitForChanges();
780
+ expect(firstOptionFocusSpy).toHaveReceivedEventTimes(1);
781
+ });
782
+ it('ArrowDown: focuses the next dropdown item', async () => {
783
+ await dispatchEvent(page, ['q2-dropdown-item'], 'focus');
784
+ expect(firstOptionFocusSpy).toHaveReceivedEventTimes(1);
785
+ await page.keyboard.press('ArrowDown');
786
+ await page.waitForChanges();
787
+ expect(lastOptionFocusSpy).toHaveReceivedEventTimes(1);
788
+ });
789
+ });
790
+ });
791
+ });
792
+ describe('Other', () => { });
793
+ });
632
794
  });
633
795
  //# sourceMappingURL=q2-dropdown-test.e2e.js.map