q2-tecton-elements 1.46.1 → 1.48.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (335) hide show
  1. package/dist/cjs/click-elsewhere_2.cjs.entry.js +48 -14
  2. package/dist/cjs/click-elsewhere_2.cjs.entry.js.map +1 -1
  3. package/dist/cjs/{index-0e15dc8d.js → index-a93362ed.js} +3 -3
  4. package/dist/cjs/index-a93362ed.js.map +1 -0
  5. package/dist/cjs/{index-59fb7c74.js → index-c385e32f.js} +1 -1
  6. package/dist/cjs/{index-59fb7c74.js.map → index-c385e32f.js.map} +1 -1
  7. package/dist/cjs/loader.cjs.js +1 -1
  8. package/dist/cjs/q2-action-sheet.cjs.entry.js +1 -1
  9. package/dist/cjs/q2-btn_2.cjs.entry.js +1 -1
  10. package/dist/cjs/q2-calendar.cjs.entry.js +18 -4
  11. package/dist/cjs/q2-calendar.cjs.entry.js.map +1 -1
  12. package/dist/cjs/q2-card.cjs.entry.js +1 -1
  13. package/dist/cjs/q2-carousel-pane.cjs.entry.js +1 -1
  14. package/dist/cjs/q2-carousel.cjs.entry.js +1 -1
  15. package/dist/cjs/q2-chart-area.cjs.entry.js +1 -1
  16. package/dist/cjs/q2-chart-bar.cjs.entry.js +1 -1
  17. package/dist/cjs/q2-chart-donut.cjs.entry.js +9 -7
  18. package/dist/cjs/q2-chart-donut.cjs.entry.js.map +1 -1
  19. package/dist/cjs/q2-checkbox-group.cjs.entry.js +1 -1
  20. package/dist/cjs/q2-checkbox.cjs.entry.js +1 -1
  21. package/dist/cjs/q2-data-table.cjs.entry.js +9 -6
  22. package/dist/cjs/q2-data-table.cjs.entry.js.map +1 -1
  23. package/dist/cjs/q2-detail.cjs.entry.js +1 -1
  24. package/dist/cjs/q2-dropdown-item.cjs.entry.js +14 -5
  25. package/dist/cjs/q2-dropdown-item.cjs.entry.js.map +1 -1
  26. package/dist/cjs/q2-dropdown.cjs.entry.js +1 -1
  27. package/dist/cjs/q2-editable-field.cjs.entry.js +37 -28
  28. package/dist/cjs/q2-editable-field.cjs.entry.js.map +1 -1
  29. package/dist/cjs/q2-icon.cjs.entry.js +1 -1
  30. package/dist/cjs/q2-input.cjs.entry.js +22 -3
  31. package/dist/cjs/q2-input.cjs.entry.js.map +1 -1
  32. package/dist/cjs/q2-item.cjs.entry.js +2 -2
  33. package/dist/cjs/q2-item.cjs.entry.js.map +1 -1
  34. package/dist/cjs/q2-legend.cjs.entry.js +1 -1
  35. package/dist/cjs/q2-legend.cjs.entry.js.map +1 -1
  36. package/dist/cjs/q2-list.cjs.entry.js +1 -1
  37. package/dist/cjs/q2-loc.cjs.entry.js +1 -1
  38. package/dist/cjs/q2-message.cjs.entry.js +1 -1
  39. package/dist/cjs/q2-month-picker.cjs.entry.js +1 -1
  40. package/dist/cjs/q2-optgroup.cjs.entry.js +1 -1
  41. package/dist/cjs/q2-option-list.cjs.entry.js +3 -4
  42. package/dist/cjs/q2-option-list.cjs.entry.js.map +1 -1
  43. package/dist/cjs/q2-pagination.cjs.entry.js +1 -1
  44. package/dist/cjs/q2-pill.cjs.entry.js +1 -1
  45. package/dist/cjs/q2-radio-group.cjs.entry.js +1 -1
  46. package/dist/cjs/q2-radio.cjs.entry.js +1 -1
  47. package/dist/cjs/q2-relative-time.cjs.entry.js +35 -18
  48. package/dist/cjs/q2-relative-time.cjs.entry.js.map +1 -1
  49. package/dist/cjs/q2-section.cjs.entry.js +3 -3
  50. package/dist/cjs/q2-section.cjs.entry.js.map +1 -1
  51. package/dist/cjs/q2-select.cjs.entry.js +11 -4
  52. package/dist/cjs/q2-select.cjs.entry.js.map +1 -1
  53. package/dist/cjs/q2-stepper-pane.cjs.entry.js +1 -1
  54. package/dist/cjs/q2-stepper-vertical.cjs.entry.js +1 -1
  55. package/dist/cjs/q2-stepper.cjs.entry.js +3 -3
  56. package/dist/cjs/q2-stepper.cjs.entry.js.map +1 -1
  57. package/dist/cjs/q2-tab-container.cjs.entry.js +2 -2
  58. package/dist/cjs/q2-tab-container.cjs.entry.js.map +1 -1
  59. package/dist/cjs/q2-tag.cjs.entry.js +1 -1
  60. package/dist/cjs/q2-tecton-elements.cjs.js +1 -1
  61. package/dist/cjs/q2-textarea.cjs.entry.js +1 -1
  62. package/dist/cjs/q2-tooltip.cjs.entry.js +1 -1
  63. package/dist/collection/components/q2-calendar/q2-calendar.js +16 -2
  64. package/dist/collection/components/q2-calendar/q2-calendar.js.map +1 -1
  65. package/dist/collection/components/q2-chart-donut/q2-chart-donut.js +8 -6
  66. package/dist/collection/components/q2-chart-donut/q2-chart-donut.js.map +1 -1
  67. package/dist/collection/components/q2-data-table/q2-data-table.css +15 -1
  68. package/dist/collection/components/q2-data-table/q2-data-table.js +34 -14
  69. package/dist/collection/components/q2-data-table/q2-data-table.js.map +1 -1
  70. package/dist/collection/components/q2-dropdown-item/q2-dropdown-item.js +22 -5
  71. package/dist/collection/components/q2-dropdown-item/q2-dropdown-item.js.map +1 -1
  72. package/dist/collection/components/q2-editable-field/q2-editable-field.js +41 -29
  73. package/dist/collection/components/q2-editable-field/q2-editable-field.js.map +1 -1
  74. package/dist/collection/components/q2-icon/assets/icon-file-list.json +1 -0
  75. package/dist/collection/components/q2-icon/assets/standard.symbol.svg +1 -1
  76. package/dist/collection/components/q2-input/q2-input.js +123 -5
  77. package/dist/collection/components/q2-input/q2-input.js.map +1 -1
  78. package/dist/collection/components/q2-item/q2-item.js +1 -1
  79. package/dist/collection/components/q2-item/q2-item.js.map +1 -1
  80. package/dist/collection/components/q2-legend/q2-legend.css +1 -1
  81. package/dist/collection/components/q2-option-list/q2-option-list.js +4 -5
  82. package/dist/collection/components/q2-option-list/q2-option-list.js.map +1 -1
  83. package/dist/collection/components/q2-popover/q2-popover.js +47 -13
  84. package/dist/collection/components/q2-popover/q2-popover.js.map +1 -1
  85. package/dist/collection/components/q2-relative-time/q2-relative-time.js +79 -25
  86. package/dist/collection/components/q2-relative-time/q2-relative-time.js.map +1 -1
  87. package/dist/collection/components/q2-section/q2-section.js +7 -4
  88. package/dist/collection/components/q2-section/q2-section.js.map +1 -1
  89. package/dist/collection/components/q2-select/q2-select.js +16 -3
  90. package/dist/collection/components/q2-select/q2-select.js.map +1 -1
  91. package/dist/collection/components/q2-stepper/q2-stepper.js +2 -2
  92. package/dist/collection/components/q2-stepper/q2-stepper.js.map +1 -1
  93. package/dist/collection/components/q2-stepper-pane/q2-stepper-pane.js +2 -2
  94. package/dist/collection/components/q2-tab-container/q2-tab-container.css +2 -1
  95. package/dist/collection/utils/index.js +2 -2
  96. package/dist/collection/utils/index.js.map +1 -1
  97. package/dist/components/index2.js +2 -2
  98. package/dist/components/index2.js.map +1 -1
  99. package/dist/components/q2-calendar.js +16 -2
  100. package/dist/components/q2-calendar.js.map +1 -1
  101. package/dist/components/q2-chart-donut.js +8 -6
  102. package/dist/components/q2-chart-donut.js.map +1 -1
  103. package/dist/components/q2-data-table.js +10 -6
  104. package/dist/components/q2-data-table.js.map +1 -1
  105. package/dist/components/q2-dropdown-item2.js +16 -6
  106. package/dist/components/q2-dropdown-item2.js.map +1 -1
  107. package/dist/components/q2-editable-field.js +37 -28
  108. package/dist/components/q2-editable-field.js.map +1 -1
  109. package/dist/components/q2-input2.js +26 -3
  110. package/dist/components/q2-input2.js.map +1 -1
  111. package/dist/components/q2-item.js +1 -1
  112. package/dist/components/q2-item.js.map +1 -1
  113. package/dist/components/q2-legend2.js +1 -1
  114. package/dist/components/q2-legend2.js.map +1 -1
  115. package/dist/components/q2-option-list2.js +2 -3
  116. package/dist/components/q2-option-list2.js.map +1 -1
  117. package/dist/components/q2-popover2.js +47 -13
  118. package/dist/components/q2-popover2.js.map +1 -1
  119. package/dist/components/q2-relative-time.js +37 -18
  120. package/dist/components/q2-relative-time.js.map +1 -1
  121. package/dist/components/q2-section.js +2 -2
  122. package/dist/components/q2-section.js.map +1 -1
  123. package/dist/components/q2-select2.js +11 -4
  124. package/dist/components/q2-select2.js.map +1 -1
  125. package/dist/components/q2-stepper.js +2 -2
  126. package/dist/components/q2-stepper.js.map +1 -1
  127. package/dist/components/q2-tab-container.js +1 -1
  128. package/dist/components/q2-tab-container.js.map +1 -1
  129. package/dist/esm/click-elsewhere_2.entry.js +48 -14
  130. package/dist/esm/click-elsewhere_2.entry.js.map +1 -1
  131. package/dist/esm/{index-0a702dd6.js → index-3c5cd75e.js} +3 -3
  132. package/dist/esm/index-3c5cd75e.js.map +1 -0
  133. package/dist/esm/{index-c99c4cc6.js → index-f0dfb099.js} +1 -1
  134. package/dist/esm/{index-c99c4cc6.js.map → index-f0dfb099.js.map} +1 -1
  135. package/dist/esm/loader.js +1 -1
  136. package/dist/esm/q2-action-sheet.entry.js +1 -1
  137. package/dist/esm/q2-btn_2.entry.js +1 -1
  138. package/dist/esm/q2-calendar.entry.js +18 -4
  139. package/dist/esm/q2-calendar.entry.js.map +1 -1
  140. package/dist/esm/q2-card.entry.js +1 -1
  141. package/dist/esm/q2-carousel-pane.entry.js +1 -1
  142. package/dist/esm/q2-carousel.entry.js +1 -1
  143. package/dist/esm/q2-chart-area.entry.js +1 -1
  144. package/dist/esm/q2-chart-bar.entry.js +1 -1
  145. package/dist/esm/q2-chart-donut.entry.js +9 -7
  146. package/dist/esm/q2-chart-donut.entry.js.map +1 -1
  147. package/dist/esm/q2-checkbox-group.entry.js +1 -1
  148. package/dist/esm/q2-checkbox.entry.js +1 -1
  149. package/dist/esm/q2-data-table.entry.js +9 -6
  150. package/dist/esm/q2-data-table.entry.js.map +1 -1
  151. package/dist/esm/q2-detail.entry.js +1 -1
  152. package/dist/esm/q2-dropdown-item.entry.js +14 -5
  153. package/dist/esm/q2-dropdown-item.entry.js.map +1 -1
  154. package/dist/esm/q2-dropdown.entry.js +1 -1
  155. package/dist/esm/q2-editable-field.entry.js +37 -28
  156. package/dist/esm/q2-editable-field.entry.js.map +1 -1
  157. package/dist/esm/q2-icon.entry.js +1 -1
  158. package/dist/esm/q2-input.entry.js +22 -3
  159. package/dist/esm/q2-input.entry.js.map +1 -1
  160. package/dist/esm/q2-item.entry.js +2 -2
  161. package/dist/esm/q2-item.entry.js.map +1 -1
  162. package/dist/esm/q2-legend.entry.js +1 -1
  163. package/dist/esm/q2-legend.entry.js.map +1 -1
  164. package/dist/esm/q2-list.entry.js +1 -1
  165. package/dist/esm/q2-loc.entry.js +1 -1
  166. package/dist/esm/q2-message.entry.js +1 -1
  167. package/dist/esm/q2-month-picker.entry.js +1 -1
  168. package/dist/esm/q2-optgroup.entry.js +1 -1
  169. package/dist/esm/q2-option-list.entry.js +3 -4
  170. package/dist/esm/q2-option-list.entry.js.map +1 -1
  171. package/dist/esm/q2-pagination.entry.js +1 -1
  172. package/dist/esm/q2-pill.entry.js +1 -1
  173. package/dist/esm/q2-radio-group.entry.js +1 -1
  174. package/dist/esm/q2-radio.entry.js +1 -1
  175. package/dist/esm/q2-relative-time.entry.js +35 -18
  176. package/dist/esm/q2-relative-time.entry.js.map +1 -1
  177. package/dist/esm/q2-section.entry.js +3 -3
  178. package/dist/esm/q2-section.entry.js.map +1 -1
  179. package/dist/esm/q2-select.entry.js +11 -4
  180. package/dist/esm/q2-select.entry.js.map +1 -1
  181. package/dist/esm/q2-stepper-pane.entry.js +1 -1
  182. package/dist/esm/q2-stepper-vertical.entry.js +1 -1
  183. package/dist/esm/q2-stepper.entry.js +3 -3
  184. package/dist/esm/q2-stepper.entry.js.map +1 -1
  185. package/dist/esm/q2-tab-container.entry.js +2 -2
  186. package/dist/esm/q2-tab-container.entry.js.map +1 -1
  187. package/dist/esm/q2-tag.entry.js +1 -1
  188. package/dist/esm/q2-tecton-elements.js +1 -1
  189. package/dist/esm/q2-textarea.entry.js +1 -1
  190. package/dist/esm/q2-tooltip.entry.js +1 -1
  191. package/dist/q2-tecton-elements/assets/icon-file-list.json +1 -0
  192. package/dist/q2-tecton-elements/assets/standard.symbol.svg +1 -1
  193. package/dist/q2-tecton-elements/p-11982614.entry.js +2 -0
  194. package/dist/q2-tecton-elements/p-11982614.entry.js.map +1 -0
  195. package/dist/q2-tecton-elements/{p-57bf9342.entry.js → p-1b89b9c3.entry.js} +2 -2
  196. package/dist/q2-tecton-elements/{p-2a248a3f.entry.js → p-1d824cdf.entry.js} +2 -2
  197. package/dist/q2-tecton-elements/{p-0bc47914.entry.js → p-23183c61.entry.js} +2 -2
  198. package/dist/q2-tecton-elements/p-24719520.entry.js +2 -0
  199. package/dist/q2-tecton-elements/p-24719520.entry.js.map +1 -0
  200. package/dist/q2-tecton-elements/p-24d96969.entry.js +2 -0
  201. package/dist/q2-tecton-elements/p-24d96969.entry.js.map +1 -0
  202. package/dist/q2-tecton-elements/{p-f1265647.entry.js → p-2d6a9a94.entry.js} +2 -2
  203. package/dist/q2-tecton-elements/p-30296b0e.entry.js +2 -0
  204. package/dist/q2-tecton-elements/p-30296b0e.entry.js.map +1 -0
  205. package/dist/q2-tecton-elements/{p-4570ff06.entry.js → p-30d70f4a.entry.js} +2 -2
  206. package/dist/q2-tecton-elements/{p-d60ccf2f.entry.js → p-32b56406.entry.js} +2 -2
  207. package/dist/q2-tecton-elements/{p-d60ccf2f.entry.js.map → p-32b56406.entry.js.map} +1 -1
  208. package/dist/q2-tecton-elements/{p-79df783e.entry.js → p-33af97b0.entry.js} +2 -2
  209. package/dist/q2-tecton-elements/{p-47868d6d.entry.js → p-35cc1039.entry.js} +2 -2
  210. package/dist/q2-tecton-elements/{p-6559c942.js → p-3c42c90f.js} +1 -1
  211. package/dist/q2-tecton-elements/{p-dc057a9c.entry.js → p-3f665c56.entry.js} +2 -2
  212. package/dist/q2-tecton-elements/{p-12326313.entry.js → p-3fe532bc.entry.js} +2 -2
  213. package/dist/q2-tecton-elements/p-43236cac.entry.js +2 -0
  214. package/dist/q2-tecton-elements/p-43236cac.entry.js.map +1 -0
  215. package/dist/q2-tecton-elements/{p-ef441885.entry.js → p-4b47816d.entry.js} +2 -2
  216. package/dist/q2-tecton-elements/{p-bf32fd9c.entry.js → p-4f7e6e79.entry.js} +2 -2
  217. package/dist/q2-tecton-elements/p-4f7e6e79.entry.js.map +1 -0
  218. package/dist/q2-tecton-elements/{p-e762526f.entry.js → p-56dd051a.entry.js} +2 -2
  219. package/dist/q2-tecton-elements/p-56dd051a.entry.js.map +1 -0
  220. package/dist/q2-tecton-elements/{p-d635e39f.entry.js → p-63038a54.entry.js} +2 -2
  221. package/dist/q2-tecton-elements/{p-e27a23fc.entry.js → p-66ae329f.entry.js} +2 -2
  222. package/dist/q2-tecton-elements/p-6986a60e.entry.js +2 -0
  223. package/dist/q2-tecton-elements/p-6986a60e.entry.js.map +1 -0
  224. package/dist/q2-tecton-elements/{p-dd670d63.entry.js → p-6fdda37e.entry.js} +2 -2
  225. package/dist/q2-tecton-elements/p-6fdda37e.entry.js.map +1 -0
  226. package/dist/q2-tecton-elements/p-75bb43b2.entry.js +2 -0
  227. package/dist/q2-tecton-elements/p-75bb43b2.entry.js.map +1 -0
  228. package/dist/q2-tecton-elements/{p-4f2dfb4d.entry.js → p-76be9cad.entry.js} +2 -2
  229. package/dist/q2-tecton-elements/{p-4194d6ed.entry.js → p-7cbb989e.entry.js} +2 -2
  230. package/dist/q2-tecton-elements/{p-81b76d40.entry.js → p-7dafc5da.entry.js} +2 -2
  231. package/dist/q2-tecton-elements/{p-2132da06.entry.js → p-81bb9436.entry.js} +2 -2
  232. package/dist/q2-tecton-elements/p-84190698.js +2 -0
  233. package/dist/q2-tecton-elements/p-84190698.js.map +1 -0
  234. package/dist/q2-tecton-elements/{p-515d424b.entry.js → p-8a00552f.entry.js} +2 -2
  235. package/dist/q2-tecton-elements/{p-d8fba914.entry.js → p-8fc099f5.entry.js} +2 -2
  236. package/dist/q2-tecton-elements/p-9a71bd16.entry.js +2 -0
  237. package/dist/q2-tecton-elements/p-9a71bd16.entry.js.map +1 -0
  238. package/dist/q2-tecton-elements/{p-fe3c62e0.entry.js → p-9eafabd5.entry.js} +2 -2
  239. package/dist/q2-tecton-elements/{p-ac9414a6.entry.js → p-a03c29f3.entry.js} +2 -2
  240. package/dist/q2-tecton-elements/{p-2c57a367.entry.js → p-a891571c.entry.js} +2 -2
  241. package/dist/q2-tecton-elements/{p-f2251261.entry.js → p-abe30d0c.entry.js} +2 -2
  242. package/dist/q2-tecton-elements/{p-18ec54c0.entry.js → p-ca17f7ca.entry.js} +2 -2
  243. package/dist/q2-tecton-elements/{p-bc141c5b.entry.js → p-ca43e917.entry.js} +2 -2
  244. package/dist/q2-tecton-elements/{p-16891e51.entry.js → p-d75e4752.entry.js} +2 -2
  245. package/dist/q2-tecton-elements/p-dd18416f.entry.js +2 -0
  246. package/dist/q2-tecton-elements/p-dd18416f.entry.js.map +1 -0
  247. package/dist/q2-tecton-elements/{p-ca7ad3c3.entry.js → p-f18caa3f.entry.js} +2 -2
  248. package/dist/q2-tecton-elements/{p-85003c5b.entry.js → p-f4b28e89.entry.js} +2 -2
  249. package/dist/q2-tecton-elements/p-f4b28e89.entry.js.map +1 -0
  250. package/dist/q2-tecton-elements/{p-32e57e9f.entry.js → p-fb7dd7ab.entry.js} +2 -2
  251. package/dist/q2-tecton-elements/p-fb7dd7ab.entry.js.map +1 -0
  252. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js +1 -1
  253. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js.map +1 -1
  254. package/dist/test/elements/q2-calendar-test.e2e.js +33 -35
  255. package/dist/test/elements/q2-calendar-test.e2e.js.map +1 -1
  256. package/dist/test/elements/q2-chart-donut-test.e2e.js +9 -1
  257. package/dist/test/elements/q2-chart-donut-test.e2e.js.map +1 -1
  258. package/dist/test/elements/q2-data-table-test.e2e.js +107 -11
  259. package/dist/test/elements/q2-data-table-test.e2e.js.map +1 -1
  260. package/dist/test/elements/q2-dropdown-item-test.e2e.js +183 -104
  261. package/dist/test/elements/q2-dropdown-item-test.e2e.js.map +1 -1
  262. package/dist/test/elements/q2-editable-field-test.e2e.js +436 -418
  263. package/dist/test/elements/q2-editable-field-test.e2e.js.map +1 -1
  264. package/dist/test/elements/q2-input-test.e2e.js +53 -0
  265. package/dist/test/elements/q2-input-test.e2e.js.map +1 -1
  266. package/dist/test/elements/q2-popover-test.spec.js +162 -31
  267. package/dist/test/elements/q2-popover-test.spec.js.map +1 -1
  268. package/dist/test/elements/q2-relative-time-test.e2e.js +65 -40
  269. package/dist/test/elements/q2-relative-time-test.e2e.js.map +1 -1
  270. package/dist/test/elements/q2-select-test.e2e.js +94 -29
  271. package/dist/test/elements/q2-select-test.e2e.js.map +1 -1
  272. package/dist/test/elements/q2-stepper-test.e2e.js +23 -0
  273. package/dist/test/elements/q2-stepper-test.e2e.js.map +1 -1
  274. package/dist/types/components/q2-input/q2-input.d.ts +38 -1
  275. package/dist/types/components/q2-popover/q2-popover.d.ts +2 -0
  276. package/dist/types/components/q2-relative-time/q2-relative-time.d.ts +25 -11
  277. package/dist/types/components/q2-section/q2-section.d.ts +10 -2
  278. package/dist/types/components.d.ts +81 -24
  279. package/dist/types/workspace/workspace/{tecton-production_release_1.46.x → _Gitlab_tecton-production_master}/packages/q2-tecton-elements/.stencil/test/helpers.d.ts +1 -1
  280. package/package.json +3 -3
  281. package/dist/cjs/index-0e15dc8d.js.map +0 -1
  282. package/dist/esm/index-0a702dd6.js.map +0 -1
  283. package/dist/q2-tecton-elements/p-245ad08f.entry.js +0 -2
  284. package/dist/q2-tecton-elements/p-245ad08f.entry.js.map +0 -1
  285. package/dist/q2-tecton-elements/p-32e57e9f.entry.js.map +0 -1
  286. package/dist/q2-tecton-elements/p-36398b59.entry.js +0 -2
  287. package/dist/q2-tecton-elements/p-36398b59.entry.js.map +0 -1
  288. package/dist/q2-tecton-elements/p-42302f6f.js +0 -2
  289. package/dist/q2-tecton-elements/p-42302f6f.js.map +0 -1
  290. package/dist/q2-tecton-elements/p-65ed80a5.entry.js +0 -2
  291. package/dist/q2-tecton-elements/p-65ed80a5.entry.js.map +0 -1
  292. package/dist/q2-tecton-elements/p-85003c5b.entry.js.map +0 -1
  293. package/dist/q2-tecton-elements/p-97a98211.entry.js +0 -2
  294. package/dist/q2-tecton-elements/p-97a98211.entry.js.map +0 -1
  295. package/dist/q2-tecton-elements/p-aec64fcb.entry.js +0 -2
  296. package/dist/q2-tecton-elements/p-aec64fcb.entry.js.map +0 -1
  297. package/dist/q2-tecton-elements/p-be101dcf.entry.js +0 -2
  298. package/dist/q2-tecton-elements/p-be101dcf.entry.js.map +0 -1
  299. package/dist/q2-tecton-elements/p-bf32fd9c.entry.js.map +0 -1
  300. package/dist/q2-tecton-elements/p-ca0d7eb3.entry.js +0 -2
  301. package/dist/q2-tecton-elements/p-ca0d7eb3.entry.js.map +0 -1
  302. package/dist/q2-tecton-elements/p-ca7dad64.entry.js +0 -2
  303. package/dist/q2-tecton-elements/p-ca7dad64.entry.js.map +0 -1
  304. package/dist/q2-tecton-elements/p-dd670d63.entry.js.map +0 -1
  305. package/dist/q2-tecton-elements/p-e762526f.entry.js.map +0 -1
  306. package/dist/q2-tecton-elements/p-f45b3488.entry.js +0 -2
  307. package/dist/q2-tecton-elements/p-f45b3488.entry.js.map +0 -1
  308. /package/dist/q2-tecton-elements/{p-57bf9342.entry.js.map → p-1b89b9c3.entry.js.map} +0 -0
  309. /package/dist/q2-tecton-elements/{p-2a248a3f.entry.js.map → p-1d824cdf.entry.js.map} +0 -0
  310. /package/dist/q2-tecton-elements/{p-0bc47914.entry.js.map → p-23183c61.entry.js.map} +0 -0
  311. /package/dist/q2-tecton-elements/{p-f1265647.entry.js.map → p-2d6a9a94.entry.js.map} +0 -0
  312. /package/dist/q2-tecton-elements/{p-4570ff06.entry.js.map → p-30d70f4a.entry.js.map} +0 -0
  313. /package/dist/q2-tecton-elements/{p-79df783e.entry.js.map → p-33af97b0.entry.js.map} +0 -0
  314. /package/dist/q2-tecton-elements/{p-47868d6d.entry.js.map → p-35cc1039.entry.js.map} +0 -0
  315. /package/dist/q2-tecton-elements/{p-6559c942.js.map → p-3c42c90f.js.map} +0 -0
  316. /package/dist/q2-tecton-elements/{p-dc057a9c.entry.js.map → p-3f665c56.entry.js.map} +0 -0
  317. /package/dist/q2-tecton-elements/{p-12326313.entry.js.map → p-3fe532bc.entry.js.map} +0 -0
  318. /package/dist/q2-tecton-elements/{p-ef441885.entry.js.map → p-4b47816d.entry.js.map} +0 -0
  319. /package/dist/q2-tecton-elements/{p-d635e39f.entry.js.map → p-63038a54.entry.js.map} +0 -0
  320. /package/dist/q2-tecton-elements/{p-e27a23fc.entry.js.map → p-66ae329f.entry.js.map} +0 -0
  321. /package/dist/q2-tecton-elements/{p-4f2dfb4d.entry.js.map → p-76be9cad.entry.js.map} +0 -0
  322. /package/dist/q2-tecton-elements/{p-4194d6ed.entry.js.map → p-7cbb989e.entry.js.map} +0 -0
  323. /package/dist/q2-tecton-elements/{p-81b76d40.entry.js.map → p-7dafc5da.entry.js.map} +0 -0
  324. /package/dist/q2-tecton-elements/{p-2132da06.entry.js.map → p-81bb9436.entry.js.map} +0 -0
  325. /package/dist/q2-tecton-elements/{p-515d424b.entry.js.map → p-8a00552f.entry.js.map} +0 -0
  326. /package/dist/q2-tecton-elements/{p-d8fba914.entry.js.map → p-8fc099f5.entry.js.map} +0 -0
  327. /package/dist/q2-tecton-elements/{p-fe3c62e0.entry.js.map → p-9eafabd5.entry.js.map} +0 -0
  328. /package/dist/q2-tecton-elements/{p-ac9414a6.entry.js.map → p-a03c29f3.entry.js.map} +0 -0
  329. /package/dist/q2-tecton-elements/{p-2c57a367.entry.js.map → p-a891571c.entry.js.map} +0 -0
  330. /package/dist/q2-tecton-elements/{p-f2251261.entry.js.map → p-abe30d0c.entry.js.map} +0 -0
  331. /package/dist/q2-tecton-elements/{p-18ec54c0.entry.js.map → p-ca17f7ca.entry.js.map} +0 -0
  332. /package/dist/q2-tecton-elements/{p-bc141c5b.entry.js.map → p-ca43e917.entry.js.map} +0 -0
  333. /package/dist/q2-tecton-elements/{p-16891e51.entry.js.map → p-d75e4752.entry.js.map} +0 -0
  334. /package/dist/q2-tecton-elements/{p-ca7ad3c3.entry.js.map → p-f18caa3f.entry.js.map} +0 -0
  335. /package/dist/types/workspace/workspace/{tecton-production_release_1.46.x → _Gitlab_tecton-production_master}/packages/q2-tecton-elements/.stencil/test/elements/q2-detail/slot-component.d.ts +0 -0
@@ -1,12 +1,13 @@
1
1
  import { setTestStrings, setup, dispatchEvent, testDeprecatedAriaLabel, getListOfStyleCompilationIssues, evaluateA11y, } from "../helpers";
2
2
  describe('q2-dropdown-item', () => {
3
- it('properly compiles CSS vars and functions', async () => {
4
- const page = await setup({ html: '<q2-dropdown-item></q2-dropdown-item>' });
5
- expect(await getListOfStyleCompilationIssues(page, 'q2-dropdown-item')).toHaveLength(0);
6
- });
3
+ let page;
4
+ let item;
5
+ let itemBtn;
6
+ let itemSeparator;
7
+ let removeBtn;
7
8
  describe('[A11y] guideline compliance', () => {
8
9
  it('Does not have accessibility violations with only label', async () => {
9
- const page = await setup({
10
+ page = await setup({
10
11
  html: `
11
12
  <div role="menu">
12
13
  <q2-dropdown-item value="itemValue">item text</q2-dropdown-item>
@@ -17,74 +18,38 @@ describe('q2-dropdown-item', () => {
17
18
  expect(hasViolations).toBe(false);
18
19
  });
19
20
  });
21
+ it('properly compiles CSS vars and functions', async () => {
22
+ page = await setup({ html: '<q2-dropdown-item></q2-dropdown-item>' });
23
+ expect(await getListOfStyleCompilationIssues(page, 'q2-dropdown-item')).toHaveLength(0);
24
+ });
20
25
  it('renders base state', async function () {
21
- const page = await setup({
26
+ page = await setup({
22
27
  html: `
23
28
  <q2-dropdown-item value="itemValue">item text</q2-dropdown-item>
24
29
  `,
25
30
  });
26
- const itemBtn = await page.find('q2-dropdown-item >>> [test-id="dropdownItem"]');
31
+ itemBtn = await page.find('q2-dropdown-item >>> [test-id="dropdownItem"]');
27
32
  expect(itemBtn).not.toBeNull();
28
33
  expect(itemBtn.tagName.toLowerCase()).toEqual('q2-btn');
29
34
  expect(itemBtn).toHaveClass('dropdown-item');
30
35
  expect(itemBtn).not.toHaveAttribute('disabled');
31
36
  expect(await itemBtn.getProperty('_role')).toEqual('menuitem');
32
- const itemSeparator = await page.find('q2-dropdown-item >>> [test-id="dropdownItemSeparator"]');
37
+ itemSeparator = await page.find('q2-dropdown-item >>> [test-id="dropdownItemSeparator"]');
33
38
  expect(itemSeparator).toBeNull();
34
39
  const itemSlotText = await page.$eval('q2-dropdown-item', (element) => element.shadowRoot.querySelector('slot').assignedNodes()[0].textContent);
35
40
  expect(itemSlotText).toEqual('item text');
36
- const item = await page.find('q2-dropdown-item');
41
+ item = await page.find('q2-dropdown-item');
37
42
  item.setProperty('disabled', true);
38
43
  await page.waitForChanges();
39
44
  expect(itemBtn).toHaveAttribute('disabled');
40
45
  });
41
- it('renders as separator', async function () {
42
- const page = await setup({
43
- html: `
44
- <q2-dropdown-item value="itemValue" separator>item text</q2-dropdown-item>
45
- `,
46
- });
47
- const itemSeparator = await page.find('q2-dropdown-item >>> [test-id="dropdownItemSeparator"]');
48
- expect(itemSeparator).not.toBeNull();
49
- expect(itemSeparator).toEqualAttribute('role', 'separator');
50
- expect(itemSeparator).toHaveClass('dropdown-separator');
51
- const itemBtn = await page.find('q2-dropdown-item >>> [test-id="dropdownItem"]');
52
- expect(itemBtn).toBeNull();
53
- });
54
- it('handles removability', async function () {
55
- const page = await setup({
56
- html: `
57
- <q2-dropdown-item value="itemValue">item text</q2-dropdown-item>
58
- `,
59
- });
60
- let removeBtn = await page.find('q2-dropdown-item >>> [test-id="removeDropdownItem"]');
61
- expect(removeBtn).toBeNull();
62
- await setTestStrings(page, {
63
- 'tecton.element.dropdownItem.remove': 'Remove Option {0}',
64
- });
65
- const item = await page.find('q2-dropdown-item');
66
- item.setProperty('removable', true);
67
- await page.waitForChanges();
68
- removeBtn = await page.find('q2-dropdown-item >>> [test-id="removeDropdownItem"]');
69
- expect(removeBtn).not.toBeNull();
70
- expect(removeBtn).toHaveClass('remove-dropdown-item');
71
- expect(removeBtn).not.toHaveAttribute('disabled');
72
- expect(removeBtn).toEqualAttribute('label', 'Remove Option ');
73
- expect(await removeBtn.getProperty('_role')).toEqual('menuitem');
74
- item.setProperty('label', 'Item Text');
75
- await page.waitForChanges();
76
- expect(removeBtn).toEqualAttribute('label', 'Remove Option Item Text');
77
- item.setProperty('disabled', true);
78
- await page.waitForChanges();
79
- expect(removeBtn).toHaveAttribute('disabled');
80
- });
81
46
  it('correctly emits click event', async function () {
82
- const page = await setup({
47
+ page = await setup({
83
48
  html: `
84
49
  <q2-dropdown-item value="itemValue" removable>item text</q2-dropdown-item>
85
50
  `,
86
51
  });
87
- const item = await page.find('q2-dropdown-item');
52
+ item = await page.find('q2-dropdown-item');
88
53
  const clickSpy = await item.spyOnEvent('click');
89
54
  await dispatchEvent(page, ['q2-dropdown-item', '[test-id="dropdownItem"]'], 'click');
90
55
  expect(clickSpy).toHaveReceivedEventTimes(1);
@@ -93,56 +58,8 @@ describe('q2-dropdown-item', () => {
93
58
  expect(clickSpy).toHaveReceivedEventTimes(2);
94
59
  expect(clickSpy).toHaveReceivedEventDetail({ type: 'remove', value: 'itemValue' });
95
60
  });
96
- it('does not trigger focus delegator when item or remove btn focused', async function () {
97
- const page = await setup({
98
- html: `
99
- <q2-dropdown-item value="itemValue" removable>item text</q2-dropdown-item>
100
- `,
101
- });
102
- const item = await page.find('q2-dropdown-item');
103
- const itemFocusSpy = await item.spyOnEvent('focus');
104
- const itemBtn = await page.find('q2-dropdown-item >>> [test-id="dropdownItem"]');
105
- const itemBtnFocusSpy = await itemBtn.spyOnEvent('focus');
106
- expect(itemFocusSpy).toHaveReceivedEventTimes(0);
107
- expect(itemBtnFocusSpy).toHaveReceivedEventTimes(0);
108
- await dispatchEvent(page, ['q2-dropdown-item', '[test-id="removeDropdownItem"]'], 'focus');
109
- expect(itemFocusSpy).toHaveReceivedEventTimes(0);
110
- expect(itemBtnFocusSpy).toHaveReceivedEventTimes(0);
111
- await dispatchEvent(page, ['q2-dropdown-item', '[test-id="dropdownItem"]'], 'focus');
112
- expect(itemFocusSpy).toHaveReceivedEventTimes(0);
113
- expect(itemBtnFocusSpy).toHaveReceivedEventTimes(2);
114
- });
115
- it('handles focus manipulation', async function () {
116
- const page = await setup({
117
- html: `
118
- <q2-dropdown-item value="itemValue" removable>item text</q2-dropdown-item>
119
- `,
120
- });
121
- const itemBtn = await page.find('q2-dropdown-item >>> [test-id="dropdownItem"]');
122
- const itemBtnFocusSpy = await itemBtn.spyOnEvent('focus');
123
- const removeBtn = await page.find('q2-dropdown-item >>> [test-id="removeDropdownItem"]');
124
- const removeBtnFocusSpy = await removeBtn.spyOnEvent('focus');
125
- expect(itemBtnFocusSpy).toHaveReceivedEventTimes(0);
126
- expect(removeBtnFocusSpy).toHaveReceivedEventTimes(0);
127
- await dispatchEvent(page, 'q2-dropdown-item', 'focus');
128
- expect(itemBtnFocusSpy).toHaveReceivedEventTimes(2);
129
- await dispatchEvent(page, ['q2-dropdown-item', '[test-id="dropdownItem"]'], 'keydown', {
130
- key: 'ArrowRight',
131
- });
132
- expect(removeBtnFocusSpy).toHaveReceivedEventTimes(2);
133
- await dispatchEvent(page, ['q2-dropdown-item', '[test-id="removeDropdownItem"]'], 'keydown', {
134
- key: 'ArrowLeft',
135
- });
136
- expect(itemBtnFocusSpy).toHaveReceivedEventTimes(4);
137
- await dispatchEvent(page, ['q2-dropdown-item', '[test-id="dropdownItem"]'], 'keydown', {
138
- key: 'Right',
139
- });
140
- expect(removeBtnFocusSpy).toHaveReceivedEventTimes(4);
141
- await dispatchEvent(page, ['q2-dropdown-item', '[test-id="removeDropdownItem"]'], 'keydown', { key: 'Left' });
142
- expect(itemBtnFocusSpy).toHaveReceivedEventTimes(6);
143
- });
144
61
  it('item content is the same width as the q2-btn', async function () {
145
- const page = await setup({
62
+ page = await setup({
146
63
  html: `<q2-dropdown-item>Test</q2-dropdown-item>`,
147
64
  });
148
65
  const { btnWidth, contentWidth, btnPadding } = await page.$eval('q2-dropdown-item', (el) => {
@@ -159,17 +76,179 @@ describe('q2-dropdown-item', () => {
159
76
  });
160
77
  expect(btnWidth).toEqual(contentWidth + btnPadding * 2);
161
78
  });
79
+ describe('Props', () => {
80
+ describe('label', () => {
81
+ describe('when provided', () => {
82
+ it('applies label to itemDOM() button', async () => {
83
+ page = await setup({
84
+ html: `
85
+ <div role="menu">
86
+ <q2-dropdown-item value="itemValue" label="item text"></q2-dropdown-item>
87
+ </div>
88
+ `,
89
+ });
90
+ itemBtn = await page.find('q2-dropdown-item >>> .dropdown-item');
91
+ expect(itemBtn.getAttribute('label')).toEqual('item text');
92
+ });
93
+ });
94
+ describe('when not provided', () => {
95
+ it('tries to use textContent to apply label to itemDOM() button', async () => {
96
+ page = await setup({
97
+ html: `
98
+ <div role="menu">
99
+ <q2-dropdown-item value="itemValue">item text</q2-dropdown-item>
100
+ </div>
101
+ `,
102
+ });
103
+ itemBtn = await page.find('q2-dropdown-item >>> .dropdown-item');
104
+ expect(itemBtn.getAttribute('label')).toEqual('item text');
105
+ });
106
+ it('applies label to itemDOM() button when using q2-loc component (TCT-2678)', async () => {
107
+ page = await setup({
108
+ html: `
109
+ <div role="menu">
110
+ <q2-dropdown-item value="itemValue"><q2-loc value="item text"/></q2-dropdown-item>
111
+ </div>
112
+ `,
113
+ });
114
+ itemBtn = await page.find('q2-dropdown-item >>> .dropdown-item');
115
+ expect(itemBtn.getAttribute('label')).toEqual('item text');
116
+ });
117
+ });
118
+ });
119
+ describe('separator', () => {
120
+ it('renders as a separator', async () => {
121
+ page = await setup({
122
+ html: `
123
+ <q2-dropdown-item value="itemValue" separator>item text</q2-dropdown-item>
124
+ `,
125
+ });
126
+ itemSeparator = await page.find('q2-dropdown-item >>> .dropdown-separator');
127
+ expect(itemSeparator).not.toBeNull();
128
+ expect(itemSeparator).toEqualAttribute('role', 'separator');
129
+ expect(itemSeparator).toHaveClass('dropdown-separator');
130
+ itemBtn = await page.find('q2-dropdown-item >>> .dropdown-item');
131
+ expect(itemBtn).toBeNull();
132
+ });
133
+ });
134
+ describe('removable', () => {
135
+ beforeEach(async () => {
136
+ page = await setup({
137
+ html: ``,
138
+ });
139
+ await setTestStrings(page, {
140
+ 'tecton.element.dropdownItem.remove': 'Remove Option {0}',
141
+ });
142
+ await page.setContent('<q2-dropdown-item value="itemValue" removable></q2-dropdown-item>');
143
+ await page.waitForChanges();
144
+ });
145
+ it('renders a remove button', async () => {
146
+ item = await page.find('q2-dropdown-item');
147
+ removeBtn = await page.find('q2-dropdown-item >>> .remove-dropdown-item');
148
+ expect(removeBtn).not.toBeNull();
149
+ expect(removeBtn).not.toHaveAttribute('disabled');
150
+ expect(removeBtn).toEqualAttribute('label', 'Remove Option ');
151
+ expect(await removeBtn.getProperty('_role')).toEqual('menuitem');
152
+ });
153
+ it('uses item label in remove button label', async () => {
154
+ item = await page.find('q2-dropdown-item');
155
+ item.setProperty('label', 'Item Text');
156
+ await page.waitForChanges();
157
+ removeBtn = await page.find('q2-dropdown-item >>> .remove-dropdown-item');
158
+ expect(removeBtn).not.toBeNull();
159
+ expect(removeBtn).toEqualAttribute('label', 'Remove Option Item Text');
160
+ });
161
+ });
162
+ describe('disabled', () => {
163
+ it('disables the dropdown item', async () => {
164
+ page = await setup({
165
+ html: `
166
+ <div role="menu">
167
+ <q2-dropdown-item value="itemValue" disabled></q2-dropdown-item>
168
+ </div>
169
+ `,
170
+ });
171
+ itemBtn = await page.find('q2-dropdown-item >>> .dropdown-item');
172
+ expect(itemBtn).toHaveAttribute('disabled');
173
+ });
174
+ it('disables the remove button when removable', async () => {
175
+ page = await setup({
176
+ html: `
177
+ <div role="menu">
178
+ <q2-dropdown-item value="itemValue" disabled removable></q2-dropdown-item>
179
+ </div>
180
+ `,
181
+ });
182
+ itemBtn = await page.find('q2-dropdown-item >>> .dropdown-item');
183
+ removeBtn = await page.find('q2-dropdown-item >>> .remove-dropdown-item');
184
+ expect(itemBtn).toHaveAttribute('disabled');
185
+ expect(removeBtn).toHaveAttribute('disabled');
186
+ });
187
+ });
188
+ });
189
+ describe('Focus', () => {
190
+ it('does not trigger focus delegator when item or remove btn focused', async function () {
191
+ page = await setup({
192
+ html: `
193
+ <q2-dropdown-item value="itemValue" removable>item text</q2-dropdown-item>
194
+ `,
195
+ });
196
+ item = await page.find('q2-dropdown-item');
197
+ const itemFocusSpy = await item.spyOnEvent('focus');
198
+ itemBtn = await page.find('q2-dropdown-item >>> [test-id="dropdownItem"]');
199
+ const itemBtnFocusSpy = await itemBtn.spyOnEvent('focus');
200
+ expect(itemFocusSpy).toHaveReceivedEventTimes(0);
201
+ expect(itemBtnFocusSpy).toHaveReceivedEventTimes(0);
202
+ await dispatchEvent(page, ['q2-dropdown-item', '[test-id="removeDropdownItem"]'], 'focus');
203
+ expect(itemFocusSpy).toHaveReceivedEventTimes(0);
204
+ expect(itemBtnFocusSpy).toHaveReceivedEventTimes(0);
205
+ await dispatchEvent(page, ['q2-dropdown-item', '[test-id="dropdownItem"]'], 'focus');
206
+ expect(itemFocusSpy).toHaveReceivedEventTimes(0);
207
+ expect(itemBtnFocusSpy).toHaveReceivedEventTimes(2);
208
+ });
209
+ it('handles focus manipulation', async function () {
210
+ page = await setup({
211
+ html: `
212
+ <q2-dropdown-item value="itemValue" removable>item text</q2-dropdown-item>
213
+ `,
214
+ });
215
+ itemBtn = await page.find('q2-dropdown-item >>> [test-id="dropdownItem"]');
216
+ const itemBtnFocusSpy = await itemBtn.spyOnEvent('focus');
217
+ removeBtn = await page.find('q2-dropdown-item >>> [test-id="removeDropdownItem"]');
218
+ const removeBtnFocusSpy = await removeBtn.spyOnEvent('focus');
219
+ expect(itemBtnFocusSpy).toHaveReceivedEventTimes(0);
220
+ expect(removeBtnFocusSpy).toHaveReceivedEventTimes(0);
221
+ await dispatchEvent(page, 'q2-dropdown-item', 'focus');
222
+ expect(itemBtnFocusSpy).toHaveReceivedEventTimes(2);
223
+ await dispatchEvent(page, ['q2-dropdown-item', '[test-id="dropdownItem"]'], 'keydown', {
224
+ key: 'ArrowRight',
225
+ });
226
+ expect(removeBtnFocusSpy).toHaveReceivedEventTimes(2);
227
+ await dispatchEvent(page, ['q2-dropdown-item', '[test-id="removeDropdownItem"]'], 'keydown', {
228
+ key: 'ArrowLeft',
229
+ });
230
+ expect(itemBtnFocusSpy).toHaveReceivedEventTimes(4);
231
+ await dispatchEvent(page, ['q2-dropdown-item', '[test-id="dropdownItem"]'], 'keydown', {
232
+ key: 'Right',
233
+ });
234
+ expect(removeBtnFocusSpy).toHaveReceivedEventTimes(4);
235
+ await dispatchEvent(page, ['q2-dropdown-item', '[test-id="removeDropdownItem"]'], 'keydown', {
236
+ key: 'Left',
237
+ });
238
+ expect(itemBtnFocusSpy).toHaveReceivedEventTimes(6);
239
+ });
240
+ });
162
241
  describe('Deprecations', () => {
163
242
  it('handles deprecated `ariaLabel` prop', async () => {
164
243
  const label = 'My Label';
165
- const page = await setup({
244
+ page = await setup({
166
245
  html: `<q2-dropdown-item aria-label="${label}">Text</q2-dropdown-item>`,
167
246
  });
168
247
  await page.waitForChanges();
169
248
  await testDeprecatedAriaLabel(await page.find('q2-dropdown-item'), label);
170
- const button = await page.find('q2-dropdown-item >>> [test-id="dropdownItem"]');
171
- expect(button).toEqualAttribute('label', label);
172
- expect(button).toHaveAttribute('hide-label');
249
+ itemBtn = await page.find('q2-dropdown-item >>> .dropdown-item');
250
+ expect(itemBtn).toEqualAttribute('label', label);
251
+ expect(itemBtn).toHaveAttribute('hide-label');
173
252
  });
174
253
  });
175
254
  });
@@ -1 +1 @@
1
- {"version":3,"file":"q2-dropdown-item-test.e2e.js","sourceRoot":"","sources":["../../../test/elements/q2-dropdown-item-test.e2e.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n setTestStrings,\n setup,\n dispatchEvent,\n testDeprecatedAriaLabel,\n getListOfStyleCompilationIssues,\n evaluateA11y,\n} from '../helpers';\n\ndescribe('q2-dropdown-item', () => {\n it('properly compiles CSS vars and functions', async () => {\n const page = await setup({ html: '<q2-dropdown-item></q2-dropdown-item>' });\n expect(await getListOfStyleCompilationIssues(page, 'q2-dropdown-item')).toHaveLength(0);\n });\n\n describe('[A11y] guideline compliance', () => {\n it('Does not have accessibility violations with only label', async () => {\n const page = await setup({\n html: `\n <div role=\"menu\">\n <q2-dropdown-item value=\"itemValue\">item text</q2-dropdown-item>\n </div>\n `,\n });\n const hasViolations = await evaluateA11y(page);\n expect(hasViolations).toBe(false);\n });\n });\n\n it('renders base state', async function (): Promise<void> {\n const page = await setup({\n html: `\n <q2-dropdown-item value=\"itemValue\">item text</q2-dropdown-item>\n `,\n });\n\n const itemBtn = await page.find('q2-dropdown-item >>> [test-id=\"dropdownItem\"]');\n expect(itemBtn).not.toBeNull();\n expect(itemBtn.tagName.toLowerCase()).toEqual('q2-btn');\n expect(itemBtn).toHaveClass('dropdown-item');\n expect(itemBtn).not.toHaveAttribute('disabled');\n expect(await itemBtn.getProperty('_role')).toEqual('menuitem');\n\n const itemSeparator = await page.find('q2-dropdown-item >>> [test-id=\"dropdownItemSeparator\"]');\n expect(itemSeparator).toBeNull();\n\n const itemSlotText = await page.$eval(\n 'q2-dropdown-item',\n (element: HTMLQ2DropdownItemElement) =>\n element.shadowRoot.querySelector('slot').assignedNodes()[0].textContent\n );\n expect(itemSlotText).toEqual('item text');\n\n const item = await page.find('q2-dropdown-item');\n item.setProperty('disabled', true);\n await page.waitForChanges();\n\n expect(itemBtn).toHaveAttribute('disabled');\n });\n\n it('renders as separator', async function (): Promise<void> {\n const page = await setup({\n html: `\n <q2-dropdown-item value=\"itemValue\" separator>item text</q2-dropdown-item>\n `,\n });\n\n const itemSeparator = await page.find('q2-dropdown-item >>> [test-id=\"dropdownItemSeparator\"]');\n expect(itemSeparator).not.toBeNull();\n expect(itemSeparator).toEqualAttribute('role', 'separator');\n expect(itemSeparator).toHaveClass('dropdown-separator');\n\n const itemBtn = await page.find('q2-dropdown-item >>> [test-id=\"dropdownItem\"]');\n expect(itemBtn).toBeNull();\n });\n\n it('handles removability', async function (): Promise<void> {\n const page = await setup({\n html: `\n <q2-dropdown-item value=\"itemValue\">item text</q2-dropdown-item>\n `,\n });\n\n let removeBtn = await page.find('q2-dropdown-item >>> [test-id=\"removeDropdownItem\"]');\n expect(removeBtn).toBeNull();\n\n await setTestStrings(page, {\n 'tecton.element.dropdownItem.remove': 'Remove Option {0}',\n });\n const item = await page.find('q2-dropdown-item');\n item.setProperty('removable', true);\n await page.waitForChanges();\n\n removeBtn = await page.find('q2-dropdown-item >>> [test-id=\"removeDropdownItem\"]');\n expect(removeBtn).not.toBeNull();\n expect(removeBtn).toHaveClass('remove-dropdown-item');\n expect(removeBtn).not.toHaveAttribute('disabled');\n expect(removeBtn).toEqualAttribute('label', 'Remove Option ');\n expect(await removeBtn.getProperty('_role')).toEqual('menuitem');\n\n item.setProperty('label', 'Item Text');\n await page.waitForChanges();\n expect(removeBtn).toEqualAttribute('label', 'Remove Option Item Text');\n\n item.setProperty('disabled', true);\n await page.waitForChanges();\n expect(removeBtn).toHaveAttribute('disabled');\n });\n\n it('correctly emits click event', async function (): Promise<void> {\n const page = await setup({\n html: `\n <q2-dropdown-item value=\"itemValue\" removable>item text</q2-dropdown-item>\n `,\n });\n\n const item = await page.find('q2-dropdown-item');\n const clickSpy = await item.spyOnEvent('click');\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"dropdownItem\"]'], 'click');\n expect(clickSpy).toHaveReceivedEventTimes(1);\n expect(clickSpy).toHaveReceivedEventDetail({ type: 'select', value: 'itemValue' });\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"removeDropdownItem\"]'], 'click');\n expect(clickSpy).toHaveReceivedEventTimes(2);\n expect(clickSpy).toHaveReceivedEventDetail({ type: 'remove', value: 'itemValue' });\n });\n\n it('does not trigger focus delegator when item or remove btn focused', async function (): Promise<void> {\n const page = await setup({\n html: `\n <q2-dropdown-item value=\"itemValue\" removable>item text</q2-dropdown-item>\n `,\n });\n\n const item = await page.find('q2-dropdown-item');\n const itemFocusSpy = await item.spyOnEvent('focus');\n\n const itemBtn = await page.find('q2-dropdown-item >>> [test-id=\"dropdownItem\"]');\n const itemBtnFocusSpy = await itemBtn.spyOnEvent('focus');\n\n expect(itemFocusSpy).toHaveReceivedEventTimes(0);\n expect(itemBtnFocusSpy).toHaveReceivedEventTimes(0);\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"removeDropdownItem\"]'], 'focus');\n expect(itemFocusSpy).toHaveReceivedEventTimes(0);\n expect(itemBtnFocusSpy).toHaveReceivedEventTimes(0);\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"dropdownItem\"]'], 'focus');\n expect(itemFocusSpy).toHaveReceivedEventTimes(0);\n expect(itemBtnFocusSpy).toHaveReceivedEventTimes(2);\n });\n\n it('handles focus manipulation', async function (): Promise<void> {\n const page = await setup({\n html: `\n <q2-dropdown-item value=\"itemValue\" removable>item text</q2-dropdown-item>\n `,\n });\n\n const itemBtn = await page.find('q2-dropdown-item >>> [test-id=\"dropdownItem\"]');\n const itemBtnFocusSpy = await itemBtn.spyOnEvent('focus');\n const removeBtn = await page.find('q2-dropdown-item >>> [test-id=\"removeDropdownItem\"]');\n const removeBtnFocusSpy = await removeBtn.spyOnEvent('focus');\n\n expect(itemBtnFocusSpy).toHaveReceivedEventTimes(0);\n expect(removeBtnFocusSpy).toHaveReceivedEventTimes(0);\n\n await dispatchEvent(page, 'q2-dropdown-item', 'focus');\n expect(itemBtnFocusSpy).toHaveReceivedEventTimes(2);\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"dropdownItem\"]'], 'keydown', {\n key: 'ArrowRight',\n });\n expect(removeBtnFocusSpy).toHaveReceivedEventTimes(2);\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"removeDropdownItem\"]'], 'keydown', {\n key: 'ArrowLeft',\n });\n expect(itemBtnFocusSpy).toHaveReceivedEventTimes(4);\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"dropdownItem\"]'], 'keydown', {\n key: 'Right',\n });\n expect(removeBtnFocusSpy).toHaveReceivedEventTimes(4);\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"removeDropdownItem\"]'], 'keydown', { key: 'Left' });\n expect(itemBtnFocusSpy).toHaveReceivedEventTimes(6);\n });\n\n it('item content is the same width as the q2-btn', async function (): Promise<void> {\n const page = await setup({\n html: `<q2-dropdown-item>Test</q2-dropdown-item>`,\n });\n\n const { btnWidth, contentWidth, btnPadding } = await page.$eval(\n 'q2-dropdown-item',\n (el: HTMLQ2DropdownItemElement) => {\n const itemBtn = el.shadowRoot.querySelector('.dropdown-item');\n const itemContent = el.shadowRoot.querySelector('.dropdown-item-content');\n const contentWidth = itemContent.clientWidth;\n const btnWidth = itemBtn.clientWidth;\n const btnPadding = parseInt(getComputedStyle(itemBtn).getPropertyValue('padding'));\n return {\n btnWidth,\n contentWidth,\n btnPadding,\n };\n }\n );\n\n expect(btnWidth).toEqual(contentWidth + btnPadding * 2);\n });\n\n describe('Deprecations', () => {\n it('handles deprecated `ariaLabel` prop', async () => {\n const label = 'My Label';\n const page = await setup({\n html: `<q2-dropdown-item aria-label=\"${label}\">Text</q2-dropdown-item>`,\n });\n await page.waitForChanges();\n await testDeprecatedAriaLabel(await page.find('q2-dropdown-item'), label);\n const button = await page.find('q2-dropdown-item >>> [test-id=\"dropdownItem\"]');\n expect(button).toEqualAttribute('label', label);\n expect(button).toHaveAttribute('hide-label');\n });\n });\n});\n"]}
1
+ {"version":3,"file":"q2-dropdown-item-test.e2e.js","sourceRoot":"","sources":["../../../test/elements/q2-dropdown-item-test.e2e.ts"],"names":[],"mappings":"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","sourcesContent":["import { E2EElement, E2EPage } from '@stencil/core/testing';\nimport {\n setTestStrings,\n setup,\n dispatchEvent,\n testDeprecatedAriaLabel,\n getListOfStyleCompilationIssues,\n evaluateA11y,\n} from '../helpers';\n\ndescribe('q2-dropdown-item', () => {\n let page: E2EPage;\n let item: E2EElement;\n let itemBtn: E2EElement;\n let itemSeparator: E2EElement;\n let removeBtn: E2EElement;\n\n describe('[A11y] guideline compliance', () => {\n it('Does not have accessibility violations with only label', async () => {\n page = await setup({\n html: `\n <div role=\"menu\">\n <q2-dropdown-item value=\"itemValue\">item text</q2-dropdown-item>\n </div>\n `,\n });\n const hasViolations = await evaluateA11y(page);\n expect(hasViolations).toBe(false);\n });\n });\n\n it('properly compiles CSS vars and functions', async () => {\n page = await setup({ html: '<q2-dropdown-item></q2-dropdown-item>' });\n expect(await getListOfStyleCompilationIssues(page, 'q2-dropdown-item')).toHaveLength(0);\n });\n\n it('renders base state', async function (): Promise<void> {\n page = await setup({\n html: `\n <q2-dropdown-item value=\"itemValue\">item text</q2-dropdown-item>\n `,\n });\n\n itemBtn = await page.find('q2-dropdown-item >>> [test-id=\"dropdownItem\"]');\n expect(itemBtn).not.toBeNull();\n expect(itemBtn.tagName.toLowerCase()).toEqual('q2-btn');\n expect(itemBtn).toHaveClass('dropdown-item');\n expect(itemBtn).not.toHaveAttribute('disabled');\n expect(await itemBtn.getProperty('_role')).toEqual('menuitem');\n\n itemSeparator = await page.find('q2-dropdown-item >>> [test-id=\"dropdownItemSeparator\"]');\n expect(itemSeparator).toBeNull();\n\n const itemSlotText = await page.$eval(\n 'q2-dropdown-item',\n (element: HTMLQ2DropdownItemElement) =>\n element.shadowRoot.querySelector('slot').assignedNodes()[0].textContent\n );\n expect(itemSlotText).toEqual('item text');\n\n item = await page.find('q2-dropdown-item');\n item.setProperty('disabled', true);\n await page.waitForChanges();\n\n expect(itemBtn).toHaveAttribute('disabled');\n });\n\n it('correctly emits click event', async function (): Promise<void> {\n page = await setup({\n html: `\n <q2-dropdown-item value=\"itemValue\" removable>item text</q2-dropdown-item>\n `,\n });\n\n item = await page.find('q2-dropdown-item');\n const clickSpy = await item.spyOnEvent('click');\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"dropdownItem\"]'], 'click');\n expect(clickSpy).toHaveReceivedEventTimes(1);\n expect(clickSpy).toHaveReceivedEventDetail({ type: 'select', value: 'itemValue' });\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"removeDropdownItem\"]'], 'click');\n expect(clickSpy).toHaveReceivedEventTimes(2);\n expect(clickSpy).toHaveReceivedEventDetail({ type: 'remove', value: 'itemValue' });\n });\n\n it('item content is the same width as the q2-btn', async function (): Promise<void> {\n page = await setup({\n html: `<q2-dropdown-item>Test</q2-dropdown-item>`,\n });\n\n const { btnWidth, contentWidth, btnPadding } = await page.$eval(\n 'q2-dropdown-item',\n (el: HTMLQ2DropdownItemElement) => {\n const itemBtn = el.shadowRoot.querySelector('.dropdown-item');\n const itemContent = el.shadowRoot.querySelector('.dropdown-item-content');\n const contentWidth = itemContent.clientWidth;\n const btnWidth = itemBtn.clientWidth;\n const btnPadding = parseInt(getComputedStyle(itemBtn).getPropertyValue('padding'));\n return {\n btnWidth,\n contentWidth,\n btnPadding,\n };\n }\n );\n\n expect(btnWidth).toEqual(contentWidth + btnPadding * 2);\n });\n\n describe('Props', () => {\n describe('label', () => {\n describe('when provided', () => {\n it('applies label to itemDOM() button', async () => {\n page = await setup({\n html: `\n <div role=\"menu\">\n <q2-dropdown-item value=\"itemValue\" label=\"item text\"></q2-dropdown-item>\n </div>\n `,\n });\n itemBtn = await page.find('q2-dropdown-item >>> .dropdown-item');\n expect(itemBtn.getAttribute('label')).toEqual('item text');\n });\n });\n describe('when not provided', () => {\n it('tries to use textContent to apply label to itemDOM() button', async () => {\n page = await setup({\n html: `\n <div role=\"menu\">\n <q2-dropdown-item value=\"itemValue\">item text</q2-dropdown-item>\n </div>\n `,\n });\n itemBtn = await page.find('q2-dropdown-item >>> .dropdown-item');\n expect(itemBtn.getAttribute('label')).toEqual('item text');\n });\n it('applies label to itemDOM() button when using q2-loc component (TCT-2678)', async () => {\n page = await setup({\n html: `\n <div role=\"menu\">\n <q2-dropdown-item value=\"itemValue\"><q2-loc value=\"item text\"/></q2-dropdown-item>\n </div>\n `,\n });\n itemBtn = await page.find('q2-dropdown-item >>> .dropdown-item');\n expect(itemBtn.getAttribute('label')).toEqual('item text');\n });\n });\n });\n\n describe('separator', () => {\n it('renders as a separator', async () => {\n page = await setup({\n html: `\n <q2-dropdown-item value=\"itemValue\" separator>item text</q2-dropdown-item>\n `,\n });\n\n itemSeparator = await page.find('q2-dropdown-item >>> .dropdown-separator');\n expect(itemSeparator).not.toBeNull();\n expect(itemSeparator).toEqualAttribute('role', 'separator');\n expect(itemSeparator).toHaveClass('dropdown-separator');\n\n itemBtn = await page.find('q2-dropdown-item >>> .dropdown-item');\n expect(itemBtn).toBeNull();\n });\n });\n\n describe('removable', () => {\n beforeEach(async () => {\n page = await setup({\n html: ``,\n });\n await setTestStrings(page, {\n 'tecton.element.dropdownItem.remove': 'Remove Option {0}',\n });\n await page.setContent('<q2-dropdown-item value=\"itemValue\" removable></q2-dropdown-item>');\n await page.waitForChanges();\n });\n it('renders a remove button', async () => {\n item = await page.find('q2-dropdown-item');\n removeBtn = await page.find('q2-dropdown-item >>> .remove-dropdown-item');\n\n expect(removeBtn).not.toBeNull();\n expect(removeBtn).not.toHaveAttribute('disabled');\n expect(removeBtn).toEqualAttribute('label', 'Remove Option ');\n expect(await removeBtn.getProperty('_role')).toEqual('menuitem');\n });\n\n it('uses item label in remove button label', async () => {\n item = await page.find('q2-dropdown-item');\n item.setProperty('label', 'Item Text');\n await page.waitForChanges();\n removeBtn = await page.find('q2-dropdown-item >>> .remove-dropdown-item');\n\n expect(removeBtn).not.toBeNull();\n expect(removeBtn).toEqualAttribute('label', 'Remove Option Item Text');\n });\n });\n\n describe('disabled', () => {\n it('disables the dropdown item', async () => {\n page = await setup({\n html: `\n <div role=\"menu\">\n <q2-dropdown-item value=\"itemValue\" disabled></q2-dropdown-item>\n </div>\n `,\n });\n itemBtn = await page.find('q2-dropdown-item >>> .dropdown-item');\n\n expect(itemBtn).toHaveAttribute('disabled');\n });\n\n it('disables the remove button when removable', async () => {\n page = await setup({\n html: `\n <div role=\"menu\">\n <q2-dropdown-item value=\"itemValue\" disabled removable></q2-dropdown-item>\n </div>\n `,\n });\n itemBtn = await page.find('q2-dropdown-item >>> .dropdown-item');\n removeBtn = await page.find('q2-dropdown-item >>> .remove-dropdown-item');\n expect(itemBtn).toHaveAttribute('disabled');\n expect(removeBtn).toHaveAttribute('disabled');\n });\n });\n });\n\n describe('Focus', () => {\n it('does not trigger focus delegator when item or remove btn focused', async function (): Promise<void> {\n page = await setup({\n html: `\n <q2-dropdown-item value=\"itemValue\" removable>item text</q2-dropdown-item>\n `,\n });\n\n item = await page.find('q2-dropdown-item');\n const itemFocusSpy = await item.spyOnEvent('focus');\n\n itemBtn = await page.find('q2-dropdown-item >>> [test-id=\"dropdownItem\"]');\n const itemBtnFocusSpy = await itemBtn.spyOnEvent('focus');\n\n expect(itemFocusSpy).toHaveReceivedEventTimes(0);\n expect(itemBtnFocusSpy).toHaveReceivedEventTimes(0);\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"removeDropdownItem\"]'], 'focus');\n expect(itemFocusSpy).toHaveReceivedEventTimes(0);\n expect(itemBtnFocusSpy).toHaveReceivedEventTimes(0);\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"dropdownItem\"]'], 'focus');\n expect(itemFocusSpy).toHaveReceivedEventTimes(0);\n expect(itemBtnFocusSpy).toHaveReceivedEventTimes(2);\n });\n\n it('handles focus manipulation', async function (): Promise<void> {\n page = await setup({\n html: `\n <q2-dropdown-item value=\"itemValue\" removable>item text</q2-dropdown-item>\n `,\n });\n\n itemBtn = await page.find('q2-dropdown-item >>> [test-id=\"dropdownItem\"]');\n const itemBtnFocusSpy = await itemBtn.spyOnEvent('focus');\n removeBtn = await page.find('q2-dropdown-item >>> [test-id=\"removeDropdownItem\"]');\n const removeBtnFocusSpy = await removeBtn.spyOnEvent('focus');\n\n expect(itemBtnFocusSpy).toHaveReceivedEventTimes(0);\n expect(removeBtnFocusSpy).toHaveReceivedEventTimes(0);\n\n await dispatchEvent(page, 'q2-dropdown-item', 'focus');\n expect(itemBtnFocusSpy).toHaveReceivedEventTimes(2);\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"dropdownItem\"]'], 'keydown', {\n key: 'ArrowRight',\n });\n expect(removeBtnFocusSpy).toHaveReceivedEventTimes(2);\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"removeDropdownItem\"]'], 'keydown', {\n key: 'ArrowLeft',\n });\n expect(itemBtnFocusSpy).toHaveReceivedEventTimes(4);\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"dropdownItem\"]'], 'keydown', {\n key: 'Right',\n });\n expect(removeBtnFocusSpy).toHaveReceivedEventTimes(4);\n\n await dispatchEvent(page, ['q2-dropdown-item', '[test-id=\"removeDropdownItem\"]'], 'keydown', {\n key: 'Left',\n });\n expect(itemBtnFocusSpy).toHaveReceivedEventTimes(6);\n });\n });\n\n describe('Deprecations', () => {\n it('handles deprecated `ariaLabel` prop', async () => {\n const label = 'My Label';\n page = await setup({\n html: `<q2-dropdown-item aria-label=\"${label}\">Text</q2-dropdown-item>`,\n });\n await page.waitForChanges();\n await testDeprecatedAriaLabel(await page.find('q2-dropdown-item'), label);\n itemBtn = await page.find('q2-dropdown-item >>> .dropdown-item');\n expect(itemBtn).toEqualAttribute('label', label);\n expect(itemBtn).toHaveAttribute('hide-label');\n });\n });\n});\n"]}