q2-tecton-elements 1.48.1-alpha.0 → 1.48.2

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 (409) hide show
  1. package/dist/cjs/click-elsewhere_2.cjs.entry.js +82 -74
  2. package/dist/cjs/click-elsewhere_2.cjs.entry.js.map +1 -1
  3. package/dist/cjs/{index-a93362ed.js → index-3f1498f7.js} +33 -1
  4. package/dist/cjs/index-3f1498f7.js.map +1 -0
  5. package/dist/cjs/{index-c9a86a33.js → index-f69742cf.js} +1 -1
  6. package/dist/cjs/{index-c9a86a33.js.map → index-f69742cf.js.map} +1 -1
  7. package/dist/cjs/loader.cjs.js +1 -1
  8. package/dist/cjs/q2-action-sheet.cjs.entry.js +2 -2
  9. package/dist/cjs/q2-avatar.cjs.entry.js +1 -1
  10. package/dist/cjs/q2-btn_2.cjs.entry.js +1 -1
  11. package/dist/cjs/q2-calendar.cjs.entry.js +4 -4
  12. package/dist/cjs/q2-calendar.cjs.entry.js.map +1 -1
  13. package/dist/cjs/q2-card.cjs.entry.js +1 -1
  14. package/dist/cjs/q2-carousel-pane.cjs.entry.js +3 -3
  15. package/dist/cjs/q2-carousel.cjs.entry.js +2 -2
  16. package/dist/cjs/q2-chart-area.cjs.entry.js +2 -2
  17. package/dist/cjs/q2-chart-bar.cjs.entry.js +2 -2
  18. package/dist/cjs/q2-chart-donut.cjs.entry.js +2 -2
  19. package/dist/cjs/q2-checkbox-group.cjs.entry.js +3 -3
  20. package/dist/cjs/q2-checkbox-group.cjs.entry.js.map +1 -1
  21. package/dist/cjs/q2-checkbox.cjs.entry.js +3 -3
  22. package/dist/cjs/q2-checkbox.cjs.entry.js.map +1 -1
  23. package/dist/cjs/q2-currency.cjs.entry.js +1 -1
  24. package/dist/cjs/q2-data-table.cjs.entry.js +2 -2
  25. package/dist/cjs/q2-detail.cjs.entry.js +2 -2
  26. package/dist/cjs/q2-dropdown-item.cjs.entry.js +1 -1
  27. package/dist/cjs/q2-dropdown.cjs.entry.js +4 -2
  28. package/dist/cjs/q2-dropdown.cjs.entry.js.map +1 -1
  29. package/dist/cjs/q2-editable-field.cjs.entry.js +2 -2
  30. package/dist/cjs/q2-icon.cjs.entry.js +1 -1
  31. package/dist/cjs/q2-input.cjs.entry.js +3 -3
  32. package/dist/cjs/q2-input.cjs.entry.js.map +1 -1
  33. package/dist/cjs/q2-item.cjs.entry.js +2 -2
  34. package/dist/cjs/q2-legend.cjs.entry.js +1 -1
  35. package/dist/cjs/q2-list.cjs.entry.js +2 -2
  36. package/dist/cjs/q2-loc.cjs.entry.js +2 -2
  37. package/dist/cjs/q2-message.cjs.entry.js +2 -2
  38. package/dist/cjs/q2-month-picker.cjs.entry.js +3 -3
  39. package/dist/cjs/q2-optgroup.cjs.entry.js +2 -2
  40. package/dist/cjs/q2-option-list.cjs.entry.js +2 -2
  41. package/dist/cjs/q2-option.cjs.entry.js +1 -1
  42. package/dist/cjs/q2-pagination.cjs.entry.js +3 -3
  43. package/dist/cjs/q2-pill.cjs.entry.js +2 -2
  44. package/dist/cjs/q2-radio-group.cjs.entry.js +3 -3
  45. package/dist/cjs/q2-radio-group.cjs.entry.js.map +1 -1
  46. package/dist/cjs/q2-radio.cjs.entry.js +2 -2
  47. package/dist/cjs/q2-relative-time.cjs.entry.js +3 -3
  48. package/dist/cjs/q2-section.cjs.entry.js +3 -3
  49. package/dist/cjs/q2-select.cjs.entry.js +102 -10
  50. package/dist/cjs/q2-select.cjs.entry.js.map +1 -1
  51. package/dist/cjs/q2-stepper-pane.cjs.entry.js +2 -2
  52. package/dist/cjs/q2-stepper-vertical.cjs.entry.js +2 -2
  53. package/dist/cjs/q2-stepper.cjs.entry.js +2 -2
  54. package/dist/cjs/q2-tab-container.cjs.entry.js +2 -2
  55. package/dist/cjs/q2-tab-pane.cjs.entry.js +1 -1
  56. package/dist/cjs/q2-tag.cjs.entry.js +2 -2
  57. package/dist/cjs/q2-tecton-elements.cjs.js +1 -1
  58. package/dist/cjs/q2-textarea.cjs.entry.js +3 -3
  59. package/dist/cjs/q2-textarea.cjs.entry.js.map +1 -1
  60. package/dist/cjs/q2-tooltip.cjs.entry.js +1 -1
  61. package/dist/cjs/tecton-tab-pane.cjs.entry.js +2 -2
  62. package/dist/collection/collection-manifest.json +5 -6
  63. package/dist/collection/components/q2-action-sheet/q2-action-sheet.js +1 -1
  64. package/dist/collection/components/q2-avatar/q2-avatar.js +1 -1
  65. package/dist/collection/components/q2-calendar/q2-calendar.css +0 -2
  66. package/dist/collection/components/q2-calendar/q2-calendar.js +1 -1
  67. package/dist/collection/components/q2-calendar/q2-month-picker.js +2 -2
  68. package/dist/collection/components/q2-carousel/q2-carousel.js +1 -1
  69. package/dist/collection/components/q2-carousel-pane/q2-carousel-pane.js +2 -2
  70. package/dist/collection/components/q2-chart-area/q2-chart-area.js +1 -1
  71. package/dist/collection/components/q2-chart-bar/q2-chart-bar.js +1 -1
  72. package/dist/collection/components/q2-chart-donut/q2-chart-donut.js +1 -1
  73. package/dist/collection/components/q2-checkbox/q2-checkbox.css +0 -2
  74. package/dist/collection/components/q2-checkbox/q2-checkbox.js +1 -1
  75. package/dist/collection/components/q2-checkbox-group/q2-checkbox-group.css +1 -7
  76. package/dist/collection/components/q2-checkbox-group/q2-checkbox-group.js +1 -1
  77. package/dist/collection/components/q2-currency/q2-currency.js +1 -1
  78. package/dist/collection/components/q2-data-table/q2-data-table.js +7 -7
  79. package/dist/collection/components/q2-detail/q2-detail.js +1 -1
  80. package/dist/collection/components/q2-dropdown/q2-dropdown.js +3 -1
  81. package/dist/collection/components/q2-dropdown/q2-dropdown.js.map +1 -1
  82. package/dist/collection/components/q2-editable-field/q2-editable-field.js +1 -1
  83. package/dist/collection/components/q2-input/q2-input.css +1 -1
  84. package/dist/collection/components/q2-input/q2-input.js +2 -2
  85. package/dist/collection/components/q2-item/q2-item.js +1 -1
  86. package/dist/collection/components/q2-legend/q2-legend.js +1 -1
  87. package/dist/collection/components/q2-list/q2-list.js +1 -1
  88. package/dist/collection/components/q2-loc/q2-loc.js +1 -1
  89. package/dist/collection/components/q2-message/q2-message.js +1 -1
  90. package/dist/collection/components/q2-optgroup/q2-optgroup.js +1 -1
  91. package/dist/collection/components/q2-option/q2-option.js +1 -1
  92. package/dist/collection/components/q2-option-list/q2-option-list.js +4 -4
  93. package/dist/collection/components/q2-pagination/q2-pagination.js +2 -2
  94. package/dist/collection/components/q2-pill/q2-pill.js +1 -1
  95. package/dist/collection/components/q2-popover/q2-popover.css +19 -11
  96. package/dist/collection/components/q2-popover/q2-popover.js +83 -74
  97. package/dist/collection/components/q2-popover/q2-popover.js.map +1 -1
  98. package/dist/collection/components/q2-radio/q2-radio.js +1 -1
  99. package/dist/collection/components/q2-radio-group/q2-radio-group.css +2 -4
  100. package/dist/collection/components/q2-radio-group/q2-radio-group.js +1 -1
  101. package/dist/collection/components/q2-relative-time/q2-relative-time.js +1 -1
  102. package/dist/collection/components/q2-section/q2-section.js +2 -2
  103. package/dist/collection/components/q2-select/q2-select.css +2 -2
  104. package/dist/collection/components/q2-select/q2-select.js +109 -10
  105. package/dist/collection/components/q2-select/q2-select.js.map +1 -1
  106. package/dist/collection/components/q2-stepper/q2-stepper.js +1 -1
  107. package/dist/collection/components/q2-stepper-pane/q2-stepper-pane.js +3 -3
  108. package/dist/collection/components/q2-stepper-vertical/q2-stepper-vertical.js +1 -1
  109. package/dist/collection/components/q2-tab-container/q2-tab-container.js +1 -1
  110. package/dist/collection/components/q2-tab-pane/q2-tab-pane.js +1 -1
  111. package/dist/collection/components/q2-tag/q2-tag.js +1 -1
  112. package/dist/collection/components/q2-textarea/q2-textarea.css +2 -2
  113. package/dist/collection/components/q2-textarea/q2-textarea.js +1 -1
  114. package/dist/collection/components/tecton-tab-pane/tecton-tab-pane.js +2 -2
  115. package/dist/collection/utils/index.js +31 -0
  116. package/dist/collection/utils/index.js.map +1 -1
  117. package/dist/components/index.js +0 -2
  118. package/dist/components/index.js.map +1 -1
  119. package/dist/components/index2.js +32 -1
  120. package/dist/components/index2.js.map +1 -1
  121. package/dist/components/q2-action-sheet.js +1 -1
  122. package/dist/components/q2-avatar2.js +1 -1
  123. package/dist/components/q2-calendar.js +2 -2
  124. package/dist/components/q2-calendar.js.map +1 -1
  125. package/dist/components/q2-carousel-pane.js +2 -2
  126. package/dist/components/q2-carousel.js +1 -1
  127. package/dist/components/q2-chart-area.js +1 -1
  128. package/dist/components/q2-chart-bar.js +1 -1
  129. package/dist/components/q2-chart-donut.js +1 -1
  130. package/dist/components/q2-checkbox-group.js +2 -2
  131. package/dist/components/q2-checkbox-group.js.map +1 -1
  132. package/dist/components/q2-checkbox2.js +2 -2
  133. package/dist/components/q2-checkbox2.js.map +1 -1
  134. package/dist/components/q2-currency.js +1 -1
  135. package/dist/components/q2-data-table.js +1 -1
  136. package/dist/components/q2-detail.js +1 -1
  137. package/dist/components/q2-dropdown.js +3 -1
  138. package/dist/components/q2-dropdown.js.map +1 -1
  139. package/dist/components/q2-editable-field.js +1 -1
  140. package/dist/components/q2-input2.js +2 -2
  141. package/dist/components/q2-input2.js.map +1 -1
  142. package/dist/components/q2-item.js +1 -1
  143. package/dist/components/q2-legend2.js +1 -1
  144. package/dist/components/q2-list.js +1 -1
  145. package/dist/components/q2-loc.js +1 -1
  146. package/dist/components/q2-message2.js +1 -1
  147. package/dist/components/q2-month-picker.js +2 -2
  148. package/dist/components/q2-optgroup2.js +1 -1
  149. package/dist/components/q2-option-list2.js +1 -1
  150. package/dist/components/q2-option2.js +1 -1
  151. package/dist/components/q2-pagination.js +2 -2
  152. package/dist/components/q2-pill.js +1 -1
  153. package/dist/components/q2-popover2.js +82 -74
  154. package/dist/components/q2-popover2.js.map +1 -1
  155. package/dist/components/q2-radio-group.js +2 -2
  156. package/dist/components/q2-radio-group.js.map +1 -1
  157. package/dist/components/q2-radio.js +1 -1
  158. package/dist/components/q2-relative-time.js +1 -1
  159. package/dist/components/q2-section.js +2 -2
  160. package/dist/components/q2-select2.js +103 -11
  161. package/dist/components/q2-select2.js.map +1 -1
  162. package/dist/components/q2-stepper-pane.js +1 -1
  163. package/dist/components/q2-stepper-vertical.js +1 -1
  164. package/dist/components/q2-stepper.js +1 -1
  165. package/dist/components/q2-tab-container.js +1 -1
  166. package/dist/components/q2-tab-pane.js +1 -1
  167. package/dist/components/q2-tag.js +1 -1
  168. package/dist/components/q2-textarea.js +2 -2
  169. package/dist/components/q2-textarea.js.map +1 -1
  170. package/dist/components/tecton-tab-pane.js +2 -2
  171. package/dist/esm/click-elsewhere_2.entry.js +82 -74
  172. package/dist/esm/click-elsewhere_2.entry.js.map +1 -1
  173. package/dist/esm/{index-8582f46d.js → index-3184c760.js} +1 -1
  174. package/dist/esm/{index-8582f46d.js.map → index-3184c760.js.map} +1 -1
  175. package/dist/esm/{index-3c5cd75e.js → index-58266aeb.js} +33 -2
  176. package/dist/esm/index-58266aeb.js.map +1 -0
  177. package/dist/esm/loader.js +1 -1
  178. package/dist/esm/q2-action-sheet.entry.js +2 -2
  179. package/dist/esm/q2-avatar.entry.js +1 -1
  180. package/dist/esm/q2-btn_2.entry.js +1 -1
  181. package/dist/esm/q2-calendar.entry.js +4 -4
  182. package/dist/esm/q2-calendar.entry.js.map +1 -1
  183. package/dist/esm/q2-card.entry.js +1 -1
  184. package/dist/esm/q2-carousel-pane.entry.js +3 -3
  185. package/dist/esm/q2-carousel.entry.js +2 -2
  186. package/dist/esm/q2-chart-area.entry.js +2 -2
  187. package/dist/esm/q2-chart-bar.entry.js +2 -2
  188. package/dist/esm/q2-chart-donut.entry.js +2 -2
  189. package/dist/esm/q2-checkbox-group.entry.js +3 -3
  190. package/dist/esm/q2-checkbox-group.entry.js.map +1 -1
  191. package/dist/esm/q2-checkbox.entry.js +3 -3
  192. package/dist/esm/q2-checkbox.entry.js.map +1 -1
  193. package/dist/esm/q2-currency.entry.js +1 -1
  194. package/dist/esm/q2-data-table.entry.js +2 -2
  195. package/dist/esm/q2-detail.entry.js +2 -2
  196. package/dist/esm/q2-dropdown-item.entry.js +1 -1
  197. package/dist/esm/q2-dropdown.entry.js +4 -2
  198. package/dist/esm/q2-dropdown.entry.js.map +1 -1
  199. package/dist/esm/q2-editable-field.entry.js +2 -2
  200. package/dist/esm/q2-icon.entry.js +1 -1
  201. package/dist/esm/q2-input.entry.js +3 -3
  202. package/dist/esm/q2-input.entry.js.map +1 -1
  203. package/dist/esm/q2-item.entry.js +2 -2
  204. package/dist/esm/q2-legend.entry.js +1 -1
  205. package/dist/esm/q2-list.entry.js +2 -2
  206. package/dist/esm/q2-loc.entry.js +2 -2
  207. package/dist/esm/q2-message.entry.js +2 -2
  208. package/dist/esm/q2-month-picker.entry.js +3 -3
  209. package/dist/esm/q2-optgroup.entry.js +2 -2
  210. package/dist/esm/q2-option-list.entry.js +2 -2
  211. package/dist/esm/q2-option.entry.js +1 -1
  212. package/dist/esm/q2-pagination.entry.js +3 -3
  213. package/dist/esm/q2-pill.entry.js +2 -2
  214. package/dist/esm/q2-radio-group.entry.js +3 -3
  215. package/dist/esm/q2-radio-group.entry.js.map +1 -1
  216. package/dist/esm/q2-radio.entry.js +2 -2
  217. package/dist/esm/q2-relative-time.entry.js +3 -3
  218. package/dist/esm/q2-section.entry.js +3 -3
  219. package/dist/esm/q2-select.entry.js +102 -10
  220. package/dist/esm/q2-select.entry.js.map +1 -1
  221. package/dist/esm/q2-stepper-pane.entry.js +2 -2
  222. package/dist/esm/q2-stepper-vertical.entry.js +2 -2
  223. package/dist/esm/q2-stepper.entry.js +2 -2
  224. package/dist/esm/q2-tab-container.entry.js +2 -2
  225. package/dist/esm/q2-tab-pane.entry.js +1 -1
  226. package/dist/esm/q2-tag.entry.js +2 -2
  227. package/dist/esm/q2-tecton-elements.js +1 -1
  228. package/dist/esm/q2-textarea.entry.js +3 -3
  229. package/dist/esm/q2-textarea.entry.js.map +1 -1
  230. package/dist/esm/q2-tooltip.entry.js +1 -1
  231. package/dist/esm/tecton-tab-pane.entry.js +2 -2
  232. package/dist/jest.setup.js +33 -0
  233. package/dist/jest.setup.js.map +1 -0
  234. package/dist/q2-tecton-elements/{p-3fe532bc.entry.js → p-05f5d0ab.entry.js} +2 -2
  235. package/dist/q2-tecton-elements/p-0f9d4d30.entry.js +2 -0
  236. package/dist/q2-tecton-elements/p-0f9d4d30.entry.js.map +1 -0
  237. package/dist/q2-tecton-elements/p-139926a3.entry.js +2 -0
  238. package/dist/q2-tecton-elements/p-139926a3.entry.js.map +1 -0
  239. package/dist/q2-tecton-elements/{p-fcffc029.entry.js → p-149044cd.entry.js} +2 -2
  240. package/dist/q2-tecton-elements/{p-400f6071.entry.js → p-2cbb1756.entry.js} +2 -2
  241. package/dist/q2-tecton-elements/{p-400f6071.entry.js.map → p-2cbb1756.entry.js.map} +1 -1
  242. package/dist/q2-tecton-elements/{p-2d6a9a94.entry.js → p-3468d85d.entry.js} +2 -2
  243. package/dist/q2-tecton-elements/p-3876d25b.entry.js +2 -0
  244. package/dist/q2-tecton-elements/p-3876d25b.entry.js.map +1 -0
  245. package/dist/q2-tecton-elements/{p-f57c4448.entry.js → p-3d6e350e.entry.js} +2 -2
  246. package/dist/q2-tecton-elements/{p-ced89010.entry.js → p-3dff9fb0.entry.js} +2 -2
  247. package/dist/q2-tecton-elements/p-414c5d4e.entry.js +2 -0
  248. package/dist/q2-tecton-elements/p-414c5d4e.entry.js.map +1 -0
  249. package/dist/q2-tecton-elements/{p-35cc1039.entry.js → p-48ecbcc9.entry.js} +2 -2
  250. package/dist/q2-tecton-elements/{p-861e83de.entry.js → p-4ce69e38.entry.js} +2 -2
  251. package/dist/q2-tecton-elements/p-4e58e187.entry.js +2 -0
  252. package/dist/q2-tecton-elements/p-4e58e187.entry.js.map +1 -0
  253. package/dist/q2-tecton-elements/{p-258f8c9c.entry.js → p-502af427.entry.js} +2 -2
  254. package/dist/q2-tecton-elements/{p-7cbb989e.entry.js → p-50476216.entry.js} +2 -2
  255. package/dist/q2-tecton-elements/{p-43236cac.entry.js → p-5234ced7.entry.js} +2 -2
  256. package/dist/q2-tecton-elements/{p-4008aceb.entry.js → p-5538d1df.entry.js} +2 -2
  257. package/dist/q2-tecton-elements/p-5d339d72.entry.js +2 -0
  258. package/dist/q2-tecton-elements/p-5d339d72.entry.js.map +1 -0
  259. package/dist/q2-tecton-elements/{p-4f7e6e79.entry.js → p-63f9a5e5.entry.js} +2 -2
  260. package/dist/q2-tecton-elements/{p-828850c1.entry.js → p-646214e2.entry.js} +2 -2
  261. package/dist/q2-tecton-elements/{p-30296b0e.entry.js → p-65e7dab0.entry.js} +2 -2
  262. package/dist/q2-tecton-elements/{p-d75e4752.entry.js → p-7c5ee4aa.entry.js} +2 -2
  263. package/dist/q2-tecton-elements/p-7ea95f38.js +2 -0
  264. package/dist/q2-tecton-elements/p-7ea95f38.js.map +1 -0
  265. package/dist/q2-tecton-elements/{p-9a5695db.entry.js → p-7fe8e174.entry.js} +2 -2
  266. package/dist/q2-tecton-elements/{p-3f665c56.entry.js → p-803a5897.entry.js} +2 -2
  267. package/dist/q2-tecton-elements/{p-d32f8e53.entry.js → p-871bad24.entry.js} +2 -2
  268. package/dist/q2-tecton-elements/{p-dfa489ba.entry.js → p-8764a131.entry.js} +2 -2
  269. package/dist/q2-tecton-elements/{p-bc73f69c.entry.js → p-8a2b4f10.entry.js} +2 -2
  270. package/dist/q2-tecton-elements/{p-30d70f4a.entry.js → p-97774780.entry.js} +2 -2
  271. package/dist/q2-tecton-elements/{p-81bb9436.entry.js → p-9c129294.entry.js} +2 -2
  272. package/dist/q2-tecton-elements/p-a99e1dc6.entry.js +2 -0
  273. package/dist/q2-tecton-elements/p-a99e1dc6.entry.js.map +1 -0
  274. package/dist/q2-tecton-elements/p-abf27f97.entry.js +2 -0
  275. package/dist/q2-tecton-elements/{p-4b47816d.entry.js.map → p-abf27f97.entry.js.map} +1 -1
  276. package/dist/q2-tecton-elements/{p-9b65cc28.entry.js → p-af3a383f.entry.js} +2 -2
  277. package/dist/q2-tecton-elements/{p-d35de465.entry.js → p-b85b6bc1.entry.js} +2 -2
  278. package/dist/q2-tecton-elements/{p-e793a82c.entry.js → p-b998e684.entry.js} +2 -2
  279. package/dist/q2-tecton-elements/{p-63038a54.entry.js → p-c30c53dc.entry.js} +2 -2
  280. package/dist/q2-tecton-elements/{p-76be9cad.entry.js → p-c37fff1e.entry.js} +2 -2
  281. package/dist/q2-tecton-elements/{p-32130845.entry.js → p-c782a1d6.entry.js} +2 -2
  282. package/dist/q2-tecton-elements/{p-49ecdf18.entry.js → p-cd225920.entry.js} +2 -2
  283. package/dist/q2-tecton-elements/{p-7dafc5da.entry.js → p-cdfe6e9d.entry.js} +2 -2
  284. package/dist/q2-tecton-elements/{p-75bb43b2.entry.js → p-d238dc6b.entry.js} +2 -2
  285. package/dist/q2-tecton-elements/{p-0d6edd2a.entry.js → p-d5776227.entry.js} +2 -2
  286. package/dist/q2-tecton-elements/{p-6e313705.entry.js → p-e08c6b8f.entry.js} +2 -2
  287. package/dist/q2-tecton-elements/{p-56dd051a.entry.js → p-e41f47bc.entry.js} +2 -2
  288. package/dist/q2-tecton-elements/{p-1b89b9c3.entry.js → p-e4241b1a.entry.js} +2 -2
  289. package/dist/q2-tecton-elements/{p-aed969d4.entry.js → p-e654d2d6.entry.js} +2 -2
  290. package/dist/q2-tecton-elements/{p-b6bcef6a.js → p-f1e887f5.js} +1 -1
  291. package/dist/q2-tecton-elements/{p-366a92d9.entry.js → p-ff39ba49.entry.js} +2 -2
  292. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js +1 -1
  293. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js.map +1 -1
  294. package/dist/test/elements/q2-calendar-test.e2e.js +2 -2
  295. package/dist/test/elements/q2-calendar-test.e2e.js.map +1 -1
  296. package/dist/test/elements/q2-dropdown-test.e2e.js +2 -14
  297. package/dist/test/elements/q2-dropdown-test.e2e.js.map +1 -1
  298. package/dist/test/elements/q2-pagination-test.e2e.js +3 -2
  299. package/dist/test/elements/q2-pagination-test.e2e.js.map +1 -1
  300. package/dist/test/elements/q2-pill-test.e2e.js +1 -1
  301. package/dist/test/elements/q2-pill-test.e2e.js.map +1 -1
  302. package/dist/test/elements/q2-popover-test.e2e.js +1 -34
  303. package/dist/test/elements/q2-popover-test.e2e.js.map +1 -1
  304. package/dist/test/elements/q2-popover-test.spec.js +902 -511
  305. package/dist/test/elements/q2-popover-test.spec.js.map +1 -1
  306. package/dist/test/elements/q2-relative-time-test.e2e.js.map +1 -1
  307. package/dist/test/elements/q2-select-test.e2e.js +1 -1
  308. package/dist/test/elements/q2-select-test.e2e.js.map +1 -1
  309. package/dist/test/elements/q2-select-test.spec.js +552 -0
  310. package/dist/test/elements/q2-select-test.spec.js.map +1 -0
  311. package/dist/test/elements/q2-tag-test.e2e.js +1 -1
  312. package/dist/test/elements/q2-tag-test.e2e.js.map +1 -1
  313. package/dist/types/builds/q2e/development/tecton/tecton/packages/q2-tecton-elements/.stencil/jest.setup.d.ts +10 -0
  314. package/dist/types/components/q2-action-sheet/q2-action-sheet.d.ts +60 -0
  315. package/dist/types/components/q2-calendar/q2-calendar.d.ts +324 -0
  316. package/dist/types/components/q2-carousel/q2-carousel.d.ts +2 -2
  317. package/dist/types/components/q2-data-table/q2-data-table.d.ts +223 -0
  318. package/dist/types/components/q2-dropdown/q2-dropdown.d.ts +130 -0
  319. package/dist/types/components/q2-dropdown-item/q2-dropdown-item.d.ts +50 -0
  320. package/dist/types/components/q2-editable-field/q2-editable-field.d.ts +140 -0
  321. package/dist/types/components/q2-loading/skeleton/shapes.d.ts +1 -0
  322. package/dist/types/components/q2-optgroup/q2-optgroup.d.ts +1 -1
  323. package/dist/types/components/q2-option-list/q2-option-list.d.ts +99 -0
  324. package/dist/types/components/q2-pagination/q2-pagination.d.ts +60 -0
  325. package/dist/types/components/q2-pill/q2-pill.d.ts +102 -0
  326. package/dist/types/components/q2-popover/q2-popover.d.ts +5 -5
  327. package/dist/types/components/q2-select/q2-select.d.ts +243 -0
  328. package/dist/types/components/q2-stepper/q2-stepper.d.ts +52 -0
  329. package/dist/types/components/q2-stepper-vertical/q2-stepper-vertical.d.ts +62 -0
  330. package/dist/types/components/q2-tab-container/q2-tab-container.d.ts +2 -2
  331. package/dist/types/components/q2-tag/q2-tag.d.ts +59 -0
  332. package/dist/types/components.d.ts +0 -21
  333. package/dist/types/utils/action-sheet.d.ts +12 -0
  334. package/dist/types/utils/index.d.ts +1 -0
  335. package/package.json +5 -5
  336. package/dist/cjs/index-a93362ed.js.map +0 -1
  337. package/dist/cjs/q2-form.cjs.entry.js +0 -23
  338. package/dist/cjs/q2-form.cjs.entry.js.map +0 -1
  339. package/dist/collection/components/q2-form/q2-form.css +0 -92
  340. package/dist/collection/components/q2-form/q2-form.js +0 -44
  341. package/dist/collection/components/q2-form/q2-form.js.map +0 -1
  342. package/dist/components/q2-form.d.ts +0 -11
  343. package/dist/components/q2-form.js +0 -39
  344. package/dist/components/q2-form.js.map +0 -1
  345. package/dist/esm/index-3c5cd75e.js.map +0 -1
  346. package/dist/esm/q2-form.entry.js +0 -19
  347. package/dist/esm/q2-form.entry.js.map +0 -1
  348. package/dist/q2-tecton-elements/p-19da46dc.entry.js +0 -2
  349. package/dist/q2-tecton-elements/p-19da46dc.entry.js.map +0 -1
  350. package/dist/q2-tecton-elements/p-2878a662.entry.js +0 -2
  351. package/dist/q2-tecton-elements/p-2878a662.entry.js.map +0 -1
  352. package/dist/q2-tecton-elements/p-2a8de00d.entry.js +0 -2
  353. package/dist/q2-tecton-elements/p-2a8de00d.entry.js.map +0 -1
  354. package/dist/q2-tecton-elements/p-4b47816d.entry.js +0 -2
  355. package/dist/q2-tecton-elements/p-79696bef.entry.js +0 -2
  356. package/dist/q2-tecton-elements/p-79696bef.entry.js.map +0 -1
  357. package/dist/q2-tecton-elements/p-84190698.js +0 -2
  358. package/dist/q2-tecton-elements/p-84190698.js.map +0 -1
  359. package/dist/q2-tecton-elements/p-8a8d51f1.entry.js +0 -2
  360. package/dist/q2-tecton-elements/p-8a8d51f1.entry.js.map +0 -1
  361. package/dist/q2-tecton-elements/p-8e60bcaa.entry.js +0 -2
  362. package/dist/q2-tecton-elements/p-8e60bcaa.entry.js.map +0 -1
  363. package/dist/q2-tecton-elements/p-fde11d9c.entry.js +0 -2
  364. package/dist/q2-tecton-elements/p-fde11d9c.entry.js.map +0 -1
  365. package/dist/q2-tecton-elements/p-fec9edc8.entry.js +0 -2
  366. package/dist/q2-tecton-elements/p-fec9edc8.entry.js.map +0 -1
  367. package/dist/test/elements/q2-form-test.e2e.js +0 -93
  368. package/dist/test/elements/q2-form-test.e2e.js.map +0 -1
  369. package/dist/types/components/q2-form/q2-form.d.ts +0 -6
  370. /package/dist/q2-tecton-elements/{p-3fe532bc.entry.js.map → p-05f5d0ab.entry.js.map} +0 -0
  371. /package/dist/q2-tecton-elements/{p-fcffc029.entry.js.map → p-149044cd.entry.js.map} +0 -0
  372. /package/dist/q2-tecton-elements/{p-2d6a9a94.entry.js.map → p-3468d85d.entry.js.map} +0 -0
  373. /package/dist/q2-tecton-elements/{p-f57c4448.entry.js.map → p-3d6e350e.entry.js.map} +0 -0
  374. /package/dist/q2-tecton-elements/{p-ced89010.entry.js.map → p-3dff9fb0.entry.js.map} +0 -0
  375. /package/dist/q2-tecton-elements/{p-35cc1039.entry.js.map → p-48ecbcc9.entry.js.map} +0 -0
  376. /package/dist/q2-tecton-elements/{p-861e83de.entry.js.map → p-4ce69e38.entry.js.map} +0 -0
  377. /package/dist/q2-tecton-elements/{p-258f8c9c.entry.js.map → p-502af427.entry.js.map} +0 -0
  378. /package/dist/q2-tecton-elements/{p-7cbb989e.entry.js.map → p-50476216.entry.js.map} +0 -0
  379. /package/dist/q2-tecton-elements/{p-43236cac.entry.js.map → p-5234ced7.entry.js.map} +0 -0
  380. /package/dist/q2-tecton-elements/{p-4008aceb.entry.js.map → p-5538d1df.entry.js.map} +0 -0
  381. /package/dist/q2-tecton-elements/{p-4f7e6e79.entry.js.map → p-63f9a5e5.entry.js.map} +0 -0
  382. /package/dist/q2-tecton-elements/{p-828850c1.entry.js.map → p-646214e2.entry.js.map} +0 -0
  383. /package/dist/q2-tecton-elements/{p-30296b0e.entry.js.map → p-65e7dab0.entry.js.map} +0 -0
  384. /package/dist/q2-tecton-elements/{p-d75e4752.entry.js.map → p-7c5ee4aa.entry.js.map} +0 -0
  385. /package/dist/q2-tecton-elements/{p-9a5695db.entry.js.map → p-7fe8e174.entry.js.map} +0 -0
  386. /package/dist/q2-tecton-elements/{p-3f665c56.entry.js.map → p-803a5897.entry.js.map} +0 -0
  387. /package/dist/q2-tecton-elements/{p-d32f8e53.entry.js.map → p-871bad24.entry.js.map} +0 -0
  388. /package/dist/q2-tecton-elements/{p-dfa489ba.entry.js.map → p-8764a131.entry.js.map} +0 -0
  389. /package/dist/q2-tecton-elements/{p-bc73f69c.entry.js.map → p-8a2b4f10.entry.js.map} +0 -0
  390. /package/dist/q2-tecton-elements/{p-30d70f4a.entry.js.map → p-97774780.entry.js.map} +0 -0
  391. /package/dist/q2-tecton-elements/{p-81bb9436.entry.js.map → p-9c129294.entry.js.map} +0 -0
  392. /package/dist/q2-tecton-elements/{p-9b65cc28.entry.js.map → p-af3a383f.entry.js.map} +0 -0
  393. /package/dist/q2-tecton-elements/{p-d35de465.entry.js.map → p-b85b6bc1.entry.js.map} +0 -0
  394. /package/dist/q2-tecton-elements/{p-e793a82c.entry.js.map → p-b998e684.entry.js.map} +0 -0
  395. /package/dist/q2-tecton-elements/{p-63038a54.entry.js.map → p-c30c53dc.entry.js.map} +0 -0
  396. /package/dist/q2-tecton-elements/{p-76be9cad.entry.js.map → p-c37fff1e.entry.js.map} +0 -0
  397. /package/dist/q2-tecton-elements/{p-32130845.entry.js.map → p-c782a1d6.entry.js.map} +0 -0
  398. /package/dist/q2-tecton-elements/{p-49ecdf18.entry.js.map → p-cd225920.entry.js.map} +0 -0
  399. /package/dist/q2-tecton-elements/{p-7dafc5da.entry.js.map → p-cdfe6e9d.entry.js.map} +0 -0
  400. /package/dist/q2-tecton-elements/{p-75bb43b2.entry.js.map → p-d238dc6b.entry.js.map} +0 -0
  401. /package/dist/q2-tecton-elements/{p-0d6edd2a.entry.js.map → p-d5776227.entry.js.map} +0 -0
  402. /package/dist/q2-tecton-elements/{p-6e313705.entry.js.map → p-e08c6b8f.entry.js.map} +0 -0
  403. /package/dist/q2-tecton-elements/{p-56dd051a.entry.js.map → p-e41f47bc.entry.js.map} +0 -0
  404. /package/dist/q2-tecton-elements/{p-1b89b9c3.entry.js.map → p-e4241b1a.entry.js.map} +0 -0
  405. /package/dist/q2-tecton-elements/{p-aed969d4.entry.js.map → p-e654d2d6.entry.js.map} +0 -0
  406. /package/dist/q2-tecton-elements/{p-b6bcef6a.js.map → p-f1e887f5.js.map} +0 -0
  407. /package/dist/q2-tecton-elements/{p-366a92d9.entry.js.map → p-ff39ba49.entry.js.map} +0 -0
  408. /package/dist/types/{workspace/workspace/on-production_release_1.48.0-pre → builds/q2e/development/tecton/tecton}/packages/q2-tecton-elements/.stencil/test/elements/q2-detail/slot-component.d.ts +0 -0
  409. /package/dist/types/{workspace/workspace/on-production_release_1.48.0-pre → builds/q2e/development/tecton/tecton}/packages/q2-tecton-elements/.stencil/test/helpers.d.ts +0 -0
@@ -0,0 +1,552 @@
1
+ import { newSpecPage } from "@stencil/core/testing";
2
+ import { Q2Select } from "../../collection/components/q2-select/q2-select";
3
+ import { Q2OptionList } from "../../collection/components/q2-option-list/q2-option-list";
4
+ import * as utils from "../../collection/utils/index";
5
+ // Set up global screen object for testing
6
+ const mockScreen = {
7
+ orientation: {
8
+ type: 'portrait-primary',
9
+ addEventListener: jest.fn(),
10
+ removeEventListener: jest.fn(),
11
+ },
12
+ };
13
+ global.screen = mockScreen;
14
+ Object.defineProperty(window, 'screen', {
15
+ writable: true,
16
+ value: mockScreen,
17
+ });
18
+ // Set up global visualViewport for testing
19
+ const mockVisualViewport = {
20
+ addEventListener: jest.fn(),
21
+ removeEventListener: jest.fn(),
22
+ width: 800,
23
+ height: 600,
24
+ };
25
+ global.visualViewport = mockVisualViewport;
26
+ Object.defineProperty(window, 'visualViewport', {
27
+ value: mockVisualViewport,
28
+ configurable: true,
29
+ });
30
+ const samplePlatformDimensions = {
31
+ scrollY: 0,
32
+ innerHeight: 800,
33
+ innerWidth: 600,
34
+ outletOffset: 20,
35
+ };
36
+ const sampleTectonWindow = {
37
+ inMobileApp: false,
38
+ noStrings: false,
39
+ platformUrl: '',
40
+ platformDimensions: samplePlatformDimensions,
41
+ };
42
+ describe('q2-select', () => {
43
+ afterEach(() => {
44
+ jest.restoreAllMocks();
45
+ });
46
+ let specPage;
47
+ let specSelect;
48
+ let specElement;
49
+ let isMobileSpy;
50
+ let handleAriaLabelSpy;
51
+ let overrideFocusSpy;
52
+ // Helper function to set screen orientation type
53
+ const setOrientationType = (type) => {
54
+ mockScreen.orientation.type = type;
55
+ };
56
+ // Helper function to set document.activeElement
57
+ const setActiveElement = (element) => {
58
+ Object.defineProperty(document, 'activeElement', {
59
+ value: element,
60
+ writable: true,
61
+ configurable: true,
62
+ });
63
+ };
64
+ beforeEach(() => {
65
+ isMobileSpy = jest.spyOn(utils, 'isMobile').mockReturnValue(false);
66
+ handleAriaLabelSpy = jest.spyOn(utils, 'handleAriaLabel');
67
+ overrideFocusSpy = jest.spyOn(utils, 'overrideFocus');
68
+ setOrientationType('landscape-primary');
69
+ mockScreen.orientation.addEventListener.mockClear();
70
+ mockScreen.orientation.removeEventListener.mockClear();
71
+ });
72
+ describe('Props', () => { });
73
+ describe('Events', () => { });
74
+ describe('Component Lifecycle Events', () => {
75
+ describe('disconnectedCallback', () => {
76
+ it('calls disconnect() on mutationObserver', async () => {
77
+ specSelect = new Q2Select();
78
+ specSelect.mutationObserver = new MutationObserver(() => { });
79
+ const disconnectSpy = jest.spyOn(specSelect.mutationObserver, 'disconnect');
80
+ specSelect.disconnectedCallback();
81
+ expect(disconnectSpy).toHaveBeenCalled();
82
+ });
83
+ it('sets mutationObserver to null', async () => {
84
+ specSelect = new Q2Select();
85
+ specSelect.mutationObserver = new MutationObserver(() => { });
86
+ expect(specSelect.mutationObserver).not.toBeNull();
87
+ specSelect.disconnectedCallback();
88
+ expect(specSelect.mutationObserver).toBeNull();
89
+ });
90
+ it('calls destroyEventListeners', async () => {
91
+ specSelect = new Q2Select();
92
+ const destroyEventListenersSpy = jest.spyOn(specSelect, 'destroyEventListeners');
93
+ specSelect.disconnectedCallback();
94
+ expect(destroyEventListenersSpy).toHaveBeenCalled();
95
+ });
96
+ });
97
+ describe('componentWillLoad', () => {
98
+ it('calls handleAriaLabel() helper function', async () => {
99
+ specSelect = new Q2Select();
100
+ specSelect.componentWillLoad();
101
+ expect(handleAriaLabelSpy).toHaveBeenCalled();
102
+ });
103
+ it('calls handleOrientationChange', async () => {
104
+ specSelect = new Q2Select();
105
+ const handleOrientationChangeSpy = jest.spyOn(specSelect, 'handleOrientationChange');
106
+ specSelect.componentWillLoad();
107
+ expect(handleOrientationChangeSpy).toHaveBeenCalled();
108
+ });
109
+ it('calls buildStructuredSelectedOptions', async () => {
110
+ specSelect = new Q2Select();
111
+ const buildOptionsSpy = jest.spyOn(specSelect, 'buildStructuredSelectedOptions');
112
+ specSelect.componentWillLoad();
113
+ expect(buildOptionsSpy).toHaveBeenCalled();
114
+ });
115
+ it('calls handleMultilineOptionsUpdate', async () => {
116
+ specSelect = new Q2Select();
117
+ const handleUpdateSpy = jest.spyOn(specSelect, 'handleMultilineOptionsUpdate');
118
+ specSelect.componentWillLoad();
119
+ expect(handleUpdateSpy).toHaveBeenCalled();
120
+ });
121
+ });
122
+ describe('componentDidLoad', () => {
123
+ it('calls initMutationObserver', async () => {
124
+ specPage = await newSpecPage({
125
+ components: [Q2Select, Q2OptionList],
126
+ html: `<q2-select></q2-select>`,
127
+ });
128
+ specSelect = specPage.rootInstance;
129
+ const initMutationObserverSpy = jest.spyOn(specSelect, 'initMutationObserver');
130
+ specSelect.componentDidLoad();
131
+ expect(initMutationObserverSpy).toHaveBeenCalled();
132
+ });
133
+ it('calls initEventListeners', async () => {
134
+ specPage = await newSpecPage({
135
+ components: [Q2Select],
136
+ html: `<q2-select></q2-select>`,
137
+ });
138
+ specSelect = specPage.rootInstance;
139
+ const initEventListenersSpy = jest.spyOn(specSelect, 'initEventListeners');
140
+ specSelect.componentDidLoad();
141
+ expect(initEventListenersSpy).toHaveBeenCalled();
142
+ });
143
+ it('calls overrideFocus helper', async () => {
144
+ specPage = await newSpecPage({
145
+ components: [Q2Select],
146
+ html: `<q2-select></q2-select>`,
147
+ });
148
+ specSelect = specPage.rootInstance;
149
+ specElement = specPage.root;
150
+ specSelect.componentDidLoad();
151
+ expect(overrideFocusSpy).toHaveBeenCalledWith(specElement);
152
+ });
153
+ it('setTimeout calls checkSelectedDisplay', async () => {
154
+ specPage = await newSpecPage({
155
+ components: [Q2Select],
156
+ html: `<q2-select></q2-select>`,
157
+ });
158
+ specSelect = specPage.rootInstance;
159
+ const checkSelectedDisplaySpy = jest.spyOn(specSelect, 'checkSelectedDisplay');
160
+ jest.useFakeTimers();
161
+ specSelect.componentDidLoad();
162
+ jest.runAllTimers();
163
+ expect(checkSelectedDisplaySpy).toHaveBeenCalled();
164
+ jest.useRealTimers();
165
+ });
166
+ });
167
+ describe('componentDidRender', () => {
168
+ it('calls forEach on scheduledAfterRender', async () => {
169
+ specSelect = new Q2Select();
170
+ specSelect.scheduledAfterRender = [jest.fn()];
171
+ const forEachSpy = jest.spyOn(specSelect.scheduledAfterRender, 'forEach');
172
+ jest.useFakeTimers();
173
+ specSelect.componentDidRender();
174
+ jest.runAllTimers();
175
+ expect(forEachSpy).toHaveBeenCalled();
176
+ jest.useRealTimers();
177
+ });
178
+ });
179
+ });
180
+ describe('Listeners', () => { });
181
+ describe('Public Methods API', () => {
182
+ describe('Public Methods', () => { });
183
+ describe('Test Methods', () => { });
184
+ });
185
+ describe('Watchers', () => {
186
+ describe('openChanged', () => {
187
+ it('calls addTouchEventListeners when isOpen is true', async () => {
188
+ specSelect = new Q2Select();
189
+ const addTouchEventListenersSpy = jest.spyOn(specSelect, 'addTouchEventListeners');
190
+ specSelect.openChanged(true);
191
+ expect(addTouchEventListenersSpy).toHaveBeenCalled();
192
+ });
193
+ it('calls removeTouchEventListeners when isOpen is false', async () => {
194
+ specSelect = new Q2Select();
195
+ const removeTouchEventListenersSpy = jest.spyOn(specSelect, 'removeTouchEventListeners');
196
+ specSelect.openChanged(false);
197
+ expect(removeTouchEventListenersSpy).toHaveBeenCalled();
198
+ });
199
+ });
200
+ });
201
+ describe('Local Methods', () => {
202
+ describe('Getters', () => {
203
+ describe('isModule', () => {
204
+ beforeEach(() => {
205
+ specSelect = new Q2Select();
206
+ });
207
+ it('returns false when window top matches window and platformDimensions is not defined', async () => {
208
+ expect(window.top).toBe(window);
209
+ expect(window.Tecton).toBeUndefined();
210
+ expect(specSelect.isModule).toBe(false);
211
+ });
212
+ it('returns false when window top does not match window and platformDimensions is not defined', async () => {
213
+ const windowSpy = jest.spyOn(window, 'top', 'get').mockReturnValue({});
214
+ expect(window.top).not.toEqual(window);
215
+ expect(window.Tecton).toBeUndefined();
216
+ expect(specSelect.isModule).toBe(false);
217
+ windowSpy.mockRestore();
218
+ });
219
+ it('returns false when window top matches window and platformDimensions is defined', async () => {
220
+ window.Tecton = sampleTectonWindow;
221
+ expect(window.top).toBe(window);
222
+ expect(window.Tecton.platformDimensions).toBeTruthy();
223
+ expect(specSelect.isModule).toBe(false);
224
+ });
225
+ it('returns true when window top does not match window and platformDimensions is defined', async () => {
226
+ const windowSpy = jest.spyOn(window, 'top', 'get').mockReturnValue({});
227
+ window.Tecton = sampleTectonWindow;
228
+ expect(specSelect.isModule).toBe(true);
229
+ windowSpy.mockRestore();
230
+ });
231
+ });
232
+ });
233
+ describe('Methods', () => {
234
+ describe('addTouchEventListeners', () => {
235
+ it('does not add touchstart listener to popover when isMobile is false', async () => {
236
+ specSelect = new Q2Select();
237
+ specSelect.popoverElement = document.createElement('div');
238
+ specSelect.popoverElement.addEventListener = jest.fn();
239
+ isMobileSpy.mockReturnValue(false);
240
+ specSelect.addTouchEventListeners();
241
+ expect(specSelect.popoverElement.addEventListener).not.toHaveBeenCalledWith('touchstart', specSelect.handleTouchStart, { passive: true });
242
+ });
243
+ it('adds touchstart listener when isMobile is true', async () => {
244
+ specSelect = new Q2Select();
245
+ specSelect.popoverElement = document.createElement('div');
246
+ specSelect.popoverElement.addEventListener = jest.fn();
247
+ isMobileSpy.mockReturnValue(true);
248
+ specSelect.addTouchEventListeners();
249
+ expect(specSelect.popoverElement.addEventListener).toHaveBeenCalledWith('touchstart', specSelect.handleTouchStart, { passive: true });
250
+ });
251
+ });
252
+ describe('clickedElsewhere', () => {
253
+ let mockTarget;
254
+ let customEvent;
255
+ beforeEach(async () => {
256
+ specSelect = new Q2Select();
257
+ mockTarget = { localName: 'click-elsewhere' };
258
+ customEvent = { target: mockTarget, stopPropagation: jest.fn() };
259
+ specSelect = new Q2Select();
260
+ specSelect.popoverElement = { open: true };
261
+ jest.spyOn(specSelect, 'innerInputField', 'get').mockReturnValue({ blur: jest.fn() });
262
+ });
263
+ it('does nothing if target.localName is not "click-elsewhere"', async () => {
264
+ mockTarget = { localName: 'div' };
265
+ customEvent = { target: mockTarget };
266
+ specSelect.clickedElsewhere(customEvent);
267
+ });
268
+ it('calls stopPropagation', async () => {
269
+ specSelect.clickedElsewhere(customEvent);
270
+ expect(customEvent.stopPropagation).toHaveBeenCalled();
271
+ });
272
+ it('sets popoverElement.open to false', async () => {
273
+ specSelect.clickedElsewhere(customEvent);
274
+ expect(specSelect.popoverElement.open).toBe(false);
275
+ });
276
+ it('calls blur() on the innerInputField', async () => {
277
+ specSelect.clickedElsewhere(customEvent);
278
+ expect(specSelect.innerInputField.blur).toHaveBeenCalled();
279
+ });
280
+ });
281
+ describe('destroyEventListeners', () => {
282
+ let windowRemoveEventListenerSpy;
283
+ beforeEach(() => {
284
+ isMobileSpy.mockReturnValue(true);
285
+ specSelect = new Q2Select();
286
+ mockScreen.orientation.removeEventListener.mockClear();
287
+ windowRemoveEventListenerSpy = jest.spyOn(window, 'removeEventListener');
288
+ mockVisualViewport.removeEventListener.mockClear();
289
+ });
290
+ it('checks if isMobile', async () => {
291
+ specSelect = new Q2Select();
292
+ specSelect.destroyEventListeners();
293
+ expect(isMobileSpy).toHaveBeenCalled();
294
+ });
295
+ describe('when in mobile environment', () => {
296
+ it('calls removeEventListener on screen.orientation ', async () => {
297
+ specSelect.destroyEventListeners();
298
+ expect(mockScreen.orientation.removeEventListener).toHaveBeenCalledWith('change', specSelect.handleOrientationChange);
299
+ });
300
+ it('calls removeEventListener on window', async () => {
301
+ specSelect.destroyEventListeners();
302
+ expect(windowRemoveEventListenerSpy).toHaveBeenCalledWith('resize', specSelect.handleOrientationChange);
303
+ });
304
+ it('calls removeEventListener on visualViewport', async () => {
305
+ mockVisualViewport.removeEventListener.mockClear();
306
+ specSelect.destroyEventListeners();
307
+ expect(mockVisualViewport.removeEventListener).toHaveBeenCalledWith('resize', specSelect.handleOrientationChange);
308
+ });
309
+ it('calls removeTouchEventListeners', async () => {
310
+ const removeTouchEventListenersSpy = jest.spyOn(specSelect, 'removeTouchEventListeners');
311
+ specSelect.destroyEventListeners();
312
+ expect(removeTouchEventListenersSpy).toHaveBeenCalled();
313
+ });
314
+ });
315
+ it('does NOT remove event listener when NOT mobile', async () => {
316
+ isMobileSpy.mockReturnValue(false);
317
+ specSelect = new Q2Select();
318
+ specSelect.destroyEventListeners();
319
+ expect(mockScreen.orientation.removeEventListener).not.toHaveBeenCalled();
320
+ expect(windowRemoveEventListenerSpy).not.toHaveBeenCalled();
321
+ expect(mockVisualViewport.removeEventListener).not.toHaveBeenCalled();
322
+ });
323
+ });
324
+ describe('handleOrientationChange', () => {
325
+ beforeEach(() => {
326
+ isMobileSpy.mockReturnValue(true);
327
+ specSelect = new Q2Select();
328
+ });
329
+ it('checks if isMobile', async () => {
330
+ specSelect.handleOrientationChange();
331
+ expect(isMobileSpy).toHaveBeenCalled();
332
+ });
333
+ describe('when searchable is initially true', () => {
334
+ beforeEach(() => {
335
+ specSelect.searchable = true;
336
+ specSelect.originalSearchable = true;
337
+ });
338
+ it('sets "searchable" to false if in landscape orientation', async () => {
339
+ setOrientationType('landscape-primary');
340
+ specSelect.handleOrientationChange();
341
+ expect(specSelect.searchable).toBe(false);
342
+ });
343
+ it('does nothing in portrait orientation', async () => {
344
+ setOrientationType('portrait-primary');
345
+ specSelect.handleOrientationChange();
346
+ expect(specSelect.searchable).toBe(true);
347
+ });
348
+ it('restores searchable when returning to portrait', async () => {
349
+ setOrientationType('landscape-primary');
350
+ specSelect.handleOrientationChange();
351
+ expect(specSelect.searchable).toBe(false);
352
+ setOrientationType('portrait-primary');
353
+ specSelect.handleOrientationChange();
354
+ expect(specSelect.searchable).toBe(true);
355
+ });
356
+ });
357
+ describe('when searchable is initially undefined/false', () => {
358
+ it('does nothing', async () => {
359
+ specSelect.originalSearchable = false;
360
+ setOrientationType('landscape-primary');
361
+ specSelect.handleOrientationChange();
362
+ expect(specSelect.searchable).toBe(false);
363
+ });
364
+ });
365
+ });
366
+ describe('handleTouchStart', () => {
367
+ it('does not focus the target if the activeElement is not the hostElement', async () => {
368
+ specPage = await newSpecPage({
369
+ components: [Q2Select],
370
+ html: `<q2-select></q2-select>`,
371
+ });
372
+ specSelect = specPage.rootInstance;
373
+ specElement = specPage.root;
374
+ const element = document.createElement('div');
375
+ const touchEvent = new TouchEvent('touchmove', {
376
+ target: element,
377
+ });
378
+ const focusSpy = jest.spyOn(touchEvent.target, 'focus');
379
+ setActiveElement(element);
380
+ specSelect.handleTouchStart(touchEvent);
381
+ expect(document.activeElement).not.toBe(specElement);
382
+ expect(focusSpy).not.toHaveBeenCalled();
383
+ });
384
+ it('does not call focus on the target if the target is the hostElement', async () => {
385
+ specPage = await newSpecPage({
386
+ components: [Q2Select],
387
+ html: `<q2-select></q2-select>`,
388
+ });
389
+ specSelect = specPage.rootInstance;
390
+ specElement = specPage.root;
391
+ const touchEvent = new TouchEvent('touchmove', {
392
+ target: specElement,
393
+ });
394
+ const focusSpy = jest.spyOn(touchEvent.target, 'focus');
395
+ setActiveElement(specElement);
396
+ specSelect.handleTouchStart(touchEvent);
397
+ expect(touchEvent.target).toBe(specElement);
398
+ expect(focusSpy).not.toHaveBeenCalled();
399
+ });
400
+ describe('when hostElement is activeElement and target is not hostElement', () => {
401
+ let targetFocusSpy;
402
+ let targetElement;
403
+ beforeEach(async () => {
404
+ specPage = await newSpecPage({
405
+ components: [Q2Select],
406
+ html: `<q2-select></q2-select>`,
407
+ });
408
+ specSelect = specPage.rootInstance;
409
+ specElement = specPage.root;
410
+ setActiveElement(specElement);
411
+ specSelect.inputFocused = true;
412
+ expect(document.activeElement).toBe(specElement);
413
+ expect(specSelect.lastTouchWasInPopover).toBe(false);
414
+ targetElement = specElement.shadowRoot.querySelector('q2-popover');
415
+ const touchEvent = new TouchEvent('touchmove', {
416
+ target: targetElement,
417
+ });
418
+ targetFocusSpy = jest.spyOn(targetElement, 'focus');
419
+ expect(touchEvent.target).toBe(targetElement);
420
+ specSelect.handleTouchStart(touchEvent);
421
+ });
422
+ it('sets inputFocused to false', async () => {
423
+ expect(specSelect.inputFocused).toBe(false);
424
+ });
425
+ it('sets lastTouchWasInPopover to true', async () => {
426
+ expect(specSelect.lastTouchWasInPopover).toBe(true);
427
+ });
428
+ it('calls focus on the target element', async () => {
429
+ expect(targetFocusSpy).toHaveBeenCalled();
430
+ });
431
+ });
432
+ });
433
+ describe('initEventListeners', () => {
434
+ let windowAddEventListenerSpy;
435
+ beforeEach(() => {
436
+ isMobileSpy.mockReturnValue(true);
437
+ specSelect = new Q2Select();
438
+ mockScreen.orientation.addEventListener.mockClear();
439
+ windowAddEventListenerSpy = jest.spyOn(window, 'addEventListener');
440
+ mockVisualViewport.addEventListener.mockClear();
441
+ });
442
+ it('checks if isMobile', async () => {
443
+ specSelect = new Q2Select();
444
+ specSelect.initEventListeners();
445
+ expect(isMobileSpy).toHaveBeenCalled();
446
+ });
447
+ describe('when in mobile environment', () => {
448
+ it('calls addEventListener on screen.orientation', async () => {
449
+ specSelect.initEventListeners();
450
+ expect(mockScreen.orientation.addEventListener).toHaveBeenCalledWith('change', specSelect.handleOrientationChange);
451
+ });
452
+ it('calls addEventListener on window', async () => {
453
+ specSelect.initEventListeners();
454
+ expect(windowAddEventListenerSpy).toHaveBeenCalledWith('resize', specSelect.handleOrientationChange);
455
+ });
456
+ it('calls addEventListener on visualViewport', async () => {
457
+ specSelect.initEventListeners();
458
+ expect(mockVisualViewport.addEventListener).toHaveBeenCalledWith('resize', specSelect.handleOrientationChange);
459
+ });
460
+ });
461
+ it('does NOT add event listener when NOT mobile', async () => {
462
+ isMobileSpy.mockReturnValue(false);
463
+ specSelect = new Q2Select();
464
+ specSelect.initEventListeners();
465
+ expect(mockScreen.orientation.addEventListener).not.toHaveBeenCalled();
466
+ expect(mockVisualViewport.addEventListener).not.toHaveBeenCalled();
467
+ expect(windowAddEventListenerSpy).not.toHaveBeenCalled();
468
+ });
469
+ });
470
+ });
471
+ });
472
+ describe('Render Methods', () => { });
473
+ describe('Accessibility', () => {
474
+ describe('Keyboard Controls', () => {
475
+ let handleOptionListExternalKeydownSpy;
476
+ let q2Select;
477
+ beforeEach(async () => {
478
+ specPage = await newSpecPage({
479
+ components: [Q2Select, Q2OptionList],
480
+ html: `<q2-select></q2-select>`,
481
+ });
482
+ q2Select = specPage.root;
483
+ const q2SelectInstance = specPage.rootInstance;
484
+ handleOptionListExternalKeydownSpy = jest.spyOn(q2SelectInstance, 'handleOptionListExternalKeydown');
485
+ });
486
+ afterEach(() => {
487
+ handleOptionListExternalKeydownSpy.mockRestore();
488
+ });
489
+ it("'Tab' keypress not handled by q2-option-list", async () => {
490
+ const event = new KeyboardEvent('keydown', { key: 'Tab' });
491
+ q2Select.dispatchEvent(event);
492
+ await specPage.waitForChanges();
493
+ expect(handleOptionListExternalKeydownSpy).toHaveBeenCalledWith(event);
494
+ });
495
+ it("'Enter' keypress handled by q2-option-list", async () => {
496
+ const event = new KeyboardEvent('keydown', { key: 'Enter' });
497
+ q2Select.dispatchEvent(event);
498
+ await specPage.waitForChanges();
499
+ expect(handleOptionListExternalKeydownSpy).toHaveBeenCalledWith(event);
500
+ });
501
+ it("'ArrowUp' keypress handled by q2-option-list", async () => {
502
+ const event = new KeyboardEvent('keydown', { key: 'ArrowUp' });
503
+ q2Select.dispatchEvent(event);
504
+ await specPage.waitForChanges();
505
+ expect(handleOptionListExternalKeydownSpy).toHaveBeenCalledWith(event);
506
+ });
507
+ it("'ArrowDown' keypress handled by q2-option-list", async () => {
508
+ const event = new KeyboardEvent('keydown', { key: 'ArrowDown' });
509
+ q2Select.dispatchEvent(event);
510
+ await specPage.waitForChanges();
511
+ expect(handleOptionListExternalKeydownSpy).toHaveBeenCalledWith(event);
512
+ });
513
+ it("'Home' keypress handled by q2-option-list", async () => {
514
+ const event = new KeyboardEvent('keydown', { key: 'Home' });
515
+ q2Select.dispatchEvent(event);
516
+ await specPage.waitForChanges();
517
+ expect(handleOptionListExternalKeydownSpy).toHaveBeenCalledWith(event);
518
+ });
519
+ it("'End' keypress handled by q2-option-list", async () => {
520
+ const event = new KeyboardEvent('keydown', { key: 'End' });
521
+ q2Select.dispatchEvent(event);
522
+ await specPage.waitForChanges();
523
+ expect(handleOptionListExternalKeydownSpy).toHaveBeenCalledWith(event);
524
+ });
525
+ it("'PageUp' keypress handled by q2-option-list", async () => {
526
+ const event = new KeyboardEvent('keydown', { key: 'PageUp' });
527
+ q2Select.dispatchEvent(event);
528
+ await specPage.waitForChanges();
529
+ expect(handleOptionListExternalKeydownSpy).toHaveBeenCalledWith(event);
530
+ });
531
+ it("'PageDown' keypress handled by q2-option-list", async () => {
532
+ const event = new KeyboardEvent('keydown', { key: 'PageDown' });
533
+ q2Select.dispatchEvent(event);
534
+ await specPage.waitForChanges();
535
+ expect(handleOptionListExternalKeydownSpy).toHaveBeenCalledWith(event);
536
+ });
537
+ it("'Esc' keypress handled by q2-option-list", async () => {
538
+ const event = new KeyboardEvent('keydown', { key: 'Esc' });
539
+ q2Select.dispatchEvent(event);
540
+ await specPage.waitForChanges();
541
+ expect(handleOptionListExternalKeydownSpy).toHaveBeenCalledWith(event);
542
+ });
543
+ it("'Space' keypress handled by q2-option-list", async () => {
544
+ const event = new KeyboardEvent('keydown', { key: 'Space' });
545
+ q2Select.dispatchEvent(event);
546
+ await specPage.waitForChanges();
547
+ expect(handleOptionListExternalKeydownSpy).toHaveBeenCalledWith(event);
548
+ });
549
+ });
550
+ });
551
+ });
552
+ //# sourceMappingURL=q2-select-test.spec.js.map