q2-tecton-elements 1.47.0 → 1.48.1-alpha.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 (331) hide show
  1. package/dist/cjs/click-elsewhere_2.cjs.entry.js +43 -7
  2. package/dist/cjs/click-elsewhere_2.cjs.entry.js.map +1 -1
  3. package/dist/cjs/{index-c385e32f.js → index-c9a86a33.js} +1 -1
  4. package/dist/cjs/{index-c385e32f.js.map → index-c9a86a33.js.map} +1 -1
  5. package/dist/cjs/loader.cjs.js +1 -1
  6. package/dist/cjs/q2-calendar.cjs.entry.js +2 -2
  7. package/dist/cjs/q2-calendar.cjs.entry.js.map +1 -1
  8. package/dist/cjs/q2-chart-donut.cjs.entry.js +7 -4
  9. package/dist/cjs/q2-chart-donut.cjs.entry.js.map +1 -1
  10. package/dist/cjs/q2-checkbox-group.cjs.entry.js +1 -1
  11. package/dist/cjs/q2-checkbox-group.cjs.entry.js.map +1 -1
  12. package/dist/cjs/q2-checkbox.cjs.entry.js +1 -1
  13. package/dist/cjs/q2-checkbox.cjs.entry.js.map +1 -1
  14. package/dist/cjs/q2-data-table.cjs.entry.js +8 -5
  15. package/dist/cjs/q2-data-table.cjs.entry.js.map +1 -1
  16. package/dist/cjs/q2-dropdown-item.cjs.entry.js +13 -4
  17. package/dist/cjs/q2-dropdown-item.cjs.entry.js.map +1 -1
  18. package/dist/cjs/q2-editable-field.cjs.entry.js +36 -27
  19. package/dist/cjs/q2-editable-field.cjs.entry.js.map +1 -1
  20. package/dist/cjs/q2-form.cjs.entry.js +23 -0
  21. package/dist/cjs/q2-form.cjs.entry.js.map +1 -0
  22. package/dist/cjs/q2-input.cjs.entry.js +3 -3
  23. package/dist/cjs/q2-input.cjs.entry.js.map +1 -1
  24. package/dist/cjs/q2-item.cjs.entry.js +1 -1
  25. package/dist/cjs/q2-legend.cjs.entry.js +1 -1
  26. package/dist/cjs/q2-list.cjs.entry.js +1 -1
  27. package/dist/cjs/q2-loc.cjs.entry.js +1 -1
  28. package/dist/cjs/q2-message.cjs.entry.js +1 -1
  29. package/dist/cjs/q2-optgroup.cjs.entry.js +1 -1
  30. package/dist/cjs/q2-option-list.cjs.entry.js +2 -3
  31. package/dist/cjs/q2-option-list.cjs.entry.js.map +1 -1
  32. package/dist/cjs/q2-option.cjs.entry.js +1 -1
  33. package/dist/cjs/q2-pagination.cjs.entry.js +2 -2
  34. package/dist/cjs/q2-pill.cjs.entry.js +1 -1
  35. package/dist/cjs/q2-radio-group.cjs.entry.js +1 -1
  36. package/dist/cjs/q2-radio-group.cjs.entry.js.map +1 -1
  37. package/dist/cjs/q2-relative-time.cjs.entry.js +35 -18
  38. package/dist/cjs/q2-relative-time.cjs.entry.js.map +1 -1
  39. package/dist/cjs/q2-section.cjs.entry.js +2 -2
  40. package/dist/cjs/q2-section.cjs.entry.js.map +1 -1
  41. package/dist/cjs/q2-select.cjs.entry.js +8 -3
  42. package/dist/cjs/q2-select.cjs.entry.js.map +1 -1
  43. package/dist/cjs/q2-stepper-pane.cjs.entry.js +1 -1
  44. package/dist/cjs/q2-stepper-vertical.cjs.entry.js +1 -1
  45. package/dist/cjs/q2-stepper.cjs.entry.js +2 -2
  46. package/dist/cjs/q2-stepper.cjs.entry.js.map +1 -1
  47. package/dist/cjs/q2-tab-container.cjs.entry.js +2 -2
  48. package/dist/cjs/q2-tab-container.cjs.entry.js.map +1 -1
  49. package/dist/cjs/q2-tab-pane.cjs.entry.js +1 -1
  50. package/dist/cjs/q2-tag.cjs.entry.js +1 -1
  51. package/dist/cjs/q2-tecton-elements.cjs.js +1 -1
  52. package/dist/cjs/q2-textarea.cjs.entry.js +1 -1
  53. package/dist/cjs/q2-textarea.cjs.entry.js.map +1 -1
  54. package/dist/cjs/tecton-tab-pane.cjs.entry.js +2 -2
  55. package/dist/collection/collection-manifest.json +1 -0
  56. package/dist/collection/components/q2-calendar/q2-calendar.css +2 -0
  57. package/dist/collection/components/q2-chart-donut/q2-chart-donut.js +7 -4
  58. package/dist/collection/components/q2-chart-donut/q2-chart-donut.js.map +1 -1
  59. package/dist/collection/components/q2-checkbox/q2-checkbox.css +2 -0
  60. package/dist/collection/components/q2-checkbox-group/q2-checkbox-group.css +7 -1
  61. package/dist/collection/components/q2-data-table/q2-data-table.css +15 -1
  62. package/dist/collection/components/q2-data-table/q2-data-table.js +34 -14
  63. package/dist/collection/components/q2-data-table/q2-data-table.js.map +1 -1
  64. package/dist/collection/components/q2-dropdown-item/q2-dropdown-item.js +22 -5
  65. package/dist/collection/components/q2-dropdown-item/q2-dropdown-item.js.map +1 -1
  66. package/dist/collection/components/q2-editable-field/q2-editable-field.js +41 -29
  67. package/dist/collection/components/q2-editable-field/q2-editable-field.js.map +1 -1
  68. package/dist/collection/components/q2-form/q2-form.css +92 -0
  69. package/dist/collection/components/q2-form/q2-form.js +44 -0
  70. package/dist/collection/components/q2-form/q2-form.js.map +1 -0
  71. package/dist/collection/components/q2-input/q2-input.css +1 -1
  72. package/dist/collection/components/q2-input/q2-input.js +23 -20
  73. package/dist/collection/components/q2-input/q2-input.js.map +1 -1
  74. package/dist/collection/components/q2-item/q2-item.js +1 -1
  75. package/dist/collection/components/q2-legend/q2-legend.js +1 -1
  76. package/dist/collection/components/q2-list/q2-list.js +1 -1
  77. package/dist/collection/components/q2-loc/q2-loc.js +1 -1
  78. package/dist/collection/components/q2-message/q2-message.js +1 -1
  79. package/dist/collection/components/q2-optgroup/q2-optgroup.js +1 -1
  80. package/dist/collection/components/q2-option/q2-option.js +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-pagination/q2-pagination.js +2 -2
  84. package/dist/collection/components/q2-pill/q2-pill.js +1 -1
  85. package/dist/collection/components/q2-popover/q2-popover.js +43 -7
  86. package/dist/collection/components/q2-popover/q2-popover.js.map +1 -1
  87. package/dist/collection/components/q2-radio-group/q2-radio-group.css +4 -2
  88. package/dist/collection/components/q2-relative-time/q2-relative-time.js +79 -25
  89. package/dist/collection/components/q2-relative-time/q2-relative-time.js.map +1 -1
  90. package/dist/collection/components/q2-section/q2-section.js +7 -4
  91. package/dist/collection/components/q2-section/q2-section.js.map +1 -1
  92. package/dist/collection/components/q2-select/q2-select.css +2 -2
  93. package/dist/collection/components/q2-select/q2-select.js +7 -2
  94. package/dist/collection/components/q2-select/q2-select.js.map +1 -1
  95. package/dist/collection/components/q2-stepper/q2-stepper.js +2 -2
  96. package/dist/collection/components/q2-stepper/q2-stepper.js.map +1 -1
  97. package/dist/collection/components/q2-stepper-pane/q2-stepper-pane.js +3 -3
  98. package/dist/collection/components/q2-stepper-vertical/q2-stepper-vertical.js +1 -1
  99. package/dist/collection/components/q2-tab-container/q2-tab-container.css +2 -1
  100. package/dist/collection/components/q2-tab-container/q2-tab-container.js +1 -1
  101. package/dist/collection/components/q2-tab-pane/q2-tab-pane.js +1 -1
  102. package/dist/collection/components/q2-tag/q2-tag.js +1 -1
  103. package/dist/collection/components/q2-textarea/q2-textarea.css +2 -2
  104. package/dist/collection/components/tecton-tab-pane/tecton-tab-pane.js +2 -2
  105. package/dist/components/index.js +2 -0
  106. package/dist/components/index.js.map +1 -1
  107. package/dist/components/q2-calendar.js +1 -1
  108. package/dist/components/q2-calendar.js.map +1 -1
  109. package/dist/components/q2-chart-donut.js +7 -4
  110. package/dist/components/q2-chart-donut.js.map +1 -1
  111. package/dist/components/q2-checkbox-group.js +1 -1
  112. package/dist/components/q2-checkbox-group.js.map +1 -1
  113. package/dist/components/q2-checkbox2.js +1 -1
  114. package/dist/components/q2-checkbox2.js.map +1 -1
  115. package/dist/components/q2-data-table.js +10 -6
  116. package/dist/components/q2-data-table.js.map +1 -1
  117. package/dist/components/q2-dropdown-item2.js +16 -6
  118. package/dist/components/q2-dropdown-item2.js.map +1 -1
  119. package/dist/components/q2-editable-field.js +37 -28
  120. package/dist/components/q2-editable-field.js.map +1 -1
  121. package/dist/components/q2-form.d.ts +11 -0
  122. package/dist/components/q2-form.js +39 -0
  123. package/dist/components/q2-form.js.map +1 -0
  124. package/dist/components/q2-input2.js +4 -4
  125. package/dist/components/q2-input2.js.map +1 -1
  126. package/dist/components/q2-item.js +1 -1
  127. package/dist/components/q2-legend2.js +1 -1
  128. package/dist/components/q2-list.js +1 -1
  129. package/dist/components/q2-loc.js +1 -1
  130. package/dist/components/q2-message2.js +1 -1
  131. package/dist/components/q2-optgroup2.js +1 -1
  132. package/dist/components/q2-option-list2.js +2 -3
  133. package/dist/components/q2-option-list2.js.map +1 -1
  134. package/dist/components/q2-option2.js +1 -1
  135. package/dist/components/q2-pagination.js +2 -2
  136. package/dist/components/q2-pill.js +1 -1
  137. package/dist/components/q2-popover2.js +43 -7
  138. package/dist/components/q2-popover2.js.map +1 -1
  139. package/dist/components/q2-radio-group.js +1 -1
  140. package/dist/components/q2-radio-group.js.map +1 -1
  141. package/dist/components/q2-relative-time.js +37 -18
  142. package/dist/components/q2-relative-time.js.map +1 -1
  143. package/dist/components/q2-section.js +2 -2
  144. package/dist/components/q2-section.js.map +1 -1
  145. package/dist/components/q2-select2.js +8 -3
  146. package/dist/components/q2-select2.js.map +1 -1
  147. package/dist/components/q2-stepper-pane.js +1 -1
  148. package/dist/components/q2-stepper-vertical.js +1 -1
  149. package/dist/components/q2-stepper.js +2 -2
  150. package/dist/components/q2-stepper.js.map +1 -1
  151. package/dist/components/q2-tab-container.js +2 -2
  152. package/dist/components/q2-tab-container.js.map +1 -1
  153. package/dist/components/q2-tab-pane.js +1 -1
  154. package/dist/components/q2-tag.js +1 -1
  155. package/dist/components/q2-textarea.js +1 -1
  156. package/dist/components/q2-textarea.js.map +1 -1
  157. package/dist/components/tecton-tab-pane.js +2 -2
  158. package/dist/esm/click-elsewhere_2.entry.js +43 -7
  159. package/dist/esm/click-elsewhere_2.entry.js.map +1 -1
  160. package/dist/esm/{index-f0dfb099.js → index-8582f46d.js} +1 -1
  161. package/dist/esm/{index-f0dfb099.js.map → index-8582f46d.js.map} +1 -1
  162. package/dist/esm/loader.js +1 -1
  163. package/dist/esm/q2-calendar.entry.js +2 -2
  164. package/dist/esm/q2-calendar.entry.js.map +1 -1
  165. package/dist/esm/q2-chart-donut.entry.js +7 -4
  166. package/dist/esm/q2-chart-donut.entry.js.map +1 -1
  167. package/dist/esm/q2-checkbox-group.entry.js +1 -1
  168. package/dist/esm/q2-checkbox-group.entry.js.map +1 -1
  169. package/dist/esm/q2-checkbox.entry.js +1 -1
  170. package/dist/esm/q2-checkbox.entry.js.map +1 -1
  171. package/dist/esm/q2-data-table.entry.js +8 -5
  172. package/dist/esm/q2-data-table.entry.js.map +1 -1
  173. package/dist/esm/q2-dropdown-item.entry.js +14 -5
  174. package/dist/esm/q2-dropdown-item.entry.js.map +1 -1
  175. package/dist/esm/q2-editable-field.entry.js +37 -28
  176. package/dist/esm/q2-editable-field.entry.js.map +1 -1
  177. package/dist/esm/q2-form.entry.js +19 -0
  178. package/dist/esm/q2-form.entry.js.map +1 -0
  179. package/dist/esm/q2-input.entry.js +3 -3
  180. package/dist/esm/q2-input.entry.js.map +1 -1
  181. package/dist/esm/q2-item.entry.js +1 -1
  182. package/dist/esm/q2-legend.entry.js +1 -1
  183. package/dist/esm/q2-list.entry.js +1 -1
  184. package/dist/esm/q2-loc.entry.js +1 -1
  185. package/dist/esm/q2-message.entry.js +1 -1
  186. package/dist/esm/q2-optgroup.entry.js +1 -1
  187. package/dist/esm/q2-option-list.entry.js +2 -3
  188. package/dist/esm/q2-option-list.entry.js.map +1 -1
  189. package/dist/esm/q2-option.entry.js +1 -1
  190. package/dist/esm/q2-pagination.entry.js +2 -2
  191. package/dist/esm/q2-pill.entry.js +1 -1
  192. package/dist/esm/q2-radio-group.entry.js +1 -1
  193. package/dist/esm/q2-radio-group.entry.js.map +1 -1
  194. package/dist/esm/q2-relative-time.entry.js +35 -18
  195. package/dist/esm/q2-relative-time.entry.js.map +1 -1
  196. package/dist/esm/q2-section.entry.js +2 -2
  197. package/dist/esm/q2-section.entry.js.map +1 -1
  198. package/dist/esm/q2-select.entry.js +8 -3
  199. package/dist/esm/q2-select.entry.js.map +1 -1
  200. package/dist/esm/q2-stepper-pane.entry.js +1 -1
  201. package/dist/esm/q2-stepper-vertical.entry.js +1 -1
  202. package/dist/esm/q2-stepper.entry.js +2 -2
  203. package/dist/esm/q2-stepper.entry.js.map +1 -1
  204. package/dist/esm/q2-tab-container.entry.js +2 -2
  205. package/dist/esm/q2-tab-container.entry.js.map +1 -1
  206. package/dist/esm/q2-tab-pane.entry.js +1 -1
  207. package/dist/esm/q2-tag.entry.js +1 -1
  208. package/dist/esm/q2-tecton-elements.js +1 -1
  209. package/dist/esm/q2-textarea.entry.js +1 -1
  210. package/dist/esm/q2-textarea.entry.js.map +1 -1
  211. package/dist/esm/tecton-tab-pane.entry.js +2 -2
  212. package/dist/q2-tecton-elements/{p-d5776227.entry.js → p-0d6edd2a.entry.js} +2 -2
  213. package/dist/q2-tecton-elements/p-19da46dc.entry.js +2 -0
  214. package/dist/q2-tecton-elements/p-19da46dc.entry.js.map +1 -0
  215. package/dist/q2-tecton-elements/{p-dd18416f.entry.js → p-258f8c9c.entry.js} +2 -2
  216. package/dist/q2-tecton-elements/p-2878a662.entry.js +2 -0
  217. package/dist/q2-tecton-elements/p-2878a662.entry.js.map +1 -0
  218. package/dist/q2-tecton-elements/p-2a8de00d.entry.js +2 -0
  219. package/dist/q2-tecton-elements/p-2a8de00d.entry.js.map +1 -0
  220. package/dist/q2-tecton-elements/p-30296b0e.entry.js +2 -0
  221. package/dist/q2-tecton-elements/p-30296b0e.entry.js.map +1 -0
  222. package/dist/q2-tecton-elements/{p-ca43e917.entry.js → p-32130845.entry.js} +2 -2
  223. package/dist/q2-tecton-elements/{p-ff39ba49.entry.js → p-366a92d9.entry.js} +2 -2
  224. package/dist/q2-tecton-elements/p-4008aceb.entry.js +2 -0
  225. package/dist/q2-tecton-elements/p-4008aceb.entry.js.map +1 -0
  226. package/dist/q2-tecton-elements/{p-c9ee763d.entry.js → p-400f6071.entry.js} +2 -2
  227. package/dist/q2-tecton-elements/{p-c9ee763d.entry.js.map → p-400f6071.entry.js.map} +1 -1
  228. package/dist/q2-tecton-elements/p-43236cac.entry.js +2 -0
  229. package/dist/q2-tecton-elements/p-43236cac.entry.js.map +1 -0
  230. package/dist/q2-tecton-elements/{p-ca17f7ca.entry.js → p-49ecdf18.entry.js} +2 -2
  231. package/dist/q2-tecton-elements/{p-6f2de185.entry.js → p-4f7e6e79.entry.js} +2 -2
  232. package/dist/q2-tecton-elements/p-4f7e6e79.entry.js.map +1 -0
  233. package/dist/q2-tecton-elements/{p-a3d58a50.entry.js → p-56dd051a.entry.js} +2 -2
  234. package/dist/q2-tecton-elements/p-56dd051a.entry.js.map +1 -0
  235. package/dist/q2-tecton-elements/{p-abe30d0c.entry.js → p-6e313705.entry.js} +2 -2
  236. package/dist/q2-tecton-elements/p-75bb43b2.entry.js +2 -0
  237. package/dist/q2-tecton-elements/p-75bb43b2.entry.js.map +1 -0
  238. package/dist/q2-tecton-elements/p-79696bef.entry.js +2 -0
  239. package/dist/q2-tecton-elements/p-79696bef.entry.js.map +1 -0
  240. package/dist/q2-tecton-elements/{p-1d824cdf.entry.js → p-828850c1.entry.js} +2 -2
  241. package/dist/q2-tecton-elements/{p-774975fa.entry.js → p-861e83de.entry.js} +2 -2
  242. package/dist/q2-tecton-elements/p-861e83de.entry.js.map +1 -0
  243. package/dist/q2-tecton-elements/p-8a8d51f1.entry.js +2 -0
  244. package/dist/q2-tecton-elements/p-8a8d51f1.entry.js.map +1 -0
  245. package/dist/q2-tecton-elements/p-8e60bcaa.entry.js +2 -0
  246. package/dist/q2-tecton-elements/{p-6eac40be.entry.js.map → p-8e60bcaa.entry.js.map} +1 -1
  247. package/dist/q2-tecton-elements/p-9a5695db.entry.js +2 -0
  248. package/dist/q2-tecton-elements/p-9a5695db.entry.js.map +1 -0
  249. package/dist/q2-tecton-elements/{p-8fc099f5.entry.js → p-9b65cc28.entry.js} +2 -2
  250. package/dist/q2-tecton-elements/{p-3c42c90f.js → p-b6bcef6a.js} +1 -1
  251. package/dist/q2-tecton-elements/{p-f18caa3f.entry.js → p-bc73f69c.entry.js} +2 -2
  252. package/dist/q2-tecton-elements/{p-fb7dd7ab.entry.js → p-d32f8e53.entry.js} +2 -2
  253. package/dist/q2-tecton-elements/{p-a891571c.entry.js → p-d35de465.entry.js} +2 -2
  254. package/dist/q2-tecton-elements/{p-66ae329f.entry.js → p-dfa489ba.entry.js} +2 -2
  255. package/dist/q2-tecton-elements/{p-b849365e.entry.js → p-e793a82c.entry.js} +2 -2
  256. package/dist/q2-tecton-elements/{p-b849365e.entry.js.map → p-e793a82c.entry.js.map} +1 -1
  257. package/dist/q2-tecton-elements/{p-23183c61.entry.js → p-f57c4448.entry.js} +2 -2
  258. package/dist/q2-tecton-elements/{p-0e482a7c.entry.js → p-fcffc029.entry.js} +2 -2
  259. package/dist/q2-tecton-elements/p-fde11d9c.entry.js +2 -0
  260. package/dist/q2-tecton-elements/p-fde11d9c.entry.js.map +1 -0
  261. package/dist/q2-tecton-elements/{p-e25194ce.entry.js → p-fec9edc8.entry.js} +2 -2
  262. package/dist/q2-tecton-elements/p-fec9edc8.entry.js.map +1 -0
  263. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js +1 -1
  264. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js.map +1 -1
  265. package/dist/test/elements/q2-chart-donut-test.e2e.js +9 -1
  266. package/dist/test/elements/q2-chart-donut-test.e2e.js.map +1 -1
  267. package/dist/test/elements/q2-data-table-test.e2e.js +107 -11
  268. package/dist/test/elements/q2-data-table-test.e2e.js.map +1 -1
  269. package/dist/test/elements/q2-dropdown-item-test.e2e.js +183 -104
  270. package/dist/test/elements/q2-dropdown-item-test.e2e.js.map +1 -1
  271. package/dist/test/elements/q2-editable-field-test.e2e.js +436 -418
  272. package/dist/test/elements/q2-editable-field-test.e2e.js.map +1 -1
  273. package/dist/test/elements/q2-form-test.e2e.js +93 -0
  274. package/dist/test/elements/q2-form-test.e2e.js.map +1 -0
  275. package/dist/test/elements/q2-popover-test.spec.js +162 -31
  276. package/dist/test/elements/q2-popover-test.spec.js.map +1 -1
  277. package/dist/test/elements/q2-relative-time-test.e2e.js +65 -40
  278. package/dist/test/elements/q2-relative-time-test.e2e.js.map +1 -1
  279. package/dist/test/elements/q2-select-test.e2e.js +53 -22
  280. package/dist/test/elements/q2-select-test.e2e.js.map +1 -1
  281. package/dist/test/elements/q2-stepper-test.e2e.js +23 -0
  282. package/dist/test/elements/q2-stepper-test.e2e.js.map +1 -1
  283. package/dist/types/components/q2-form/q2-form.d.ts +6 -0
  284. package/dist/types/components/q2-input/q2-input.d.ts +15 -1
  285. package/dist/types/components/q2-popover/q2-popover.d.ts +2 -0
  286. package/dist/types/components/q2-relative-time/q2-relative-time.d.ts +25 -11
  287. package/dist/types/components/q2-section/q2-section.d.ts +10 -2
  288. package/dist/types/components.d.ts +74 -22
  289. package/dist/types/workspace/workspace/{_Gitlab_tecton-production_master → on-production_release_1.48.0-pre}/packages/q2-tecton-elements/.stencil/test/helpers.d.ts +1 -1
  290. package/package.json +3 -3
  291. package/dist/q2-tecton-elements/p-0e27ea75.entry.js +0 -2
  292. package/dist/q2-tecton-elements/p-0e27ea75.entry.js.map +0 -1
  293. package/dist/q2-tecton-elements/p-24d96969.entry.js +0 -2
  294. package/dist/q2-tecton-elements/p-24d96969.entry.js.map +0 -1
  295. package/dist/q2-tecton-elements/p-33af97b0.entry.js +0 -2
  296. package/dist/q2-tecton-elements/p-33af97b0.entry.js.map +0 -1
  297. package/dist/q2-tecton-elements/p-45d70da2.entry.js +0 -2
  298. package/dist/q2-tecton-elements/p-45d70da2.entry.js.map +0 -1
  299. package/dist/q2-tecton-elements/p-52e277b8.entry.js +0 -2
  300. package/dist/q2-tecton-elements/p-52e277b8.entry.js.map +0 -1
  301. package/dist/q2-tecton-elements/p-6eac40be.entry.js +0 -2
  302. package/dist/q2-tecton-elements/p-6f2de185.entry.js.map +0 -1
  303. package/dist/q2-tecton-elements/p-774975fa.entry.js.map +0 -1
  304. package/dist/q2-tecton-elements/p-8a00552f.entry.js +0 -2
  305. package/dist/q2-tecton-elements/p-8a00552f.entry.js.map +0 -1
  306. package/dist/q2-tecton-elements/p-9eafabd5.entry.js +0 -2
  307. package/dist/q2-tecton-elements/p-9eafabd5.entry.js.map +0 -1
  308. package/dist/q2-tecton-elements/p-a03c29f3.entry.js +0 -2
  309. package/dist/q2-tecton-elements/p-a03c29f3.entry.js.map +0 -1
  310. package/dist/q2-tecton-elements/p-a3d58a50.entry.js.map +0 -1
  311. package/dist/q2-tecton-elements/p-e25194ce.entry.js.map +0 -1
  312. package/dist/q2-tecton-elements/p-f450db0b.entry.js +0 -2
  313. package/dist/q2-tecton-elements/p-f450db0b.entry.js.map +0 -1
  314. package/dist/q2-tecton-elements/p-fce6bc58.entry.js +0 -2
  315. package/dist/q2-tecton-elements/p-fce6bc58.entry.js.map +0 -1
  316. /package/dist/q2-tecton-elements/{p-d5776227.entry.js.map → p-0d6edd2a.entry.js.map} +0 -0
  317. /package/dist/q2-tecton-elements/{p-dd18416f.entry.js.map → p-258f8c9c.entry.js.map} +0 -0
  318. /package/dist/q2-tecton-elements/{p-ca43e917.entry.js.map → p-32130845.entry.js.map} +0 -0
  319. /package/dist/q2-tecton-elements/{p-ff39ba49.entry.js.map → p-366a92d9.entry.js.map} +0 -0
  320. /package/dist/q2-tecton-elements/{p-ca17f7ca.entry.js.map → p-49ecdf18.entry.js.map} +0 -0
  321. /package/dist/q2-tecton-elements/{p-abe30d0c.entry.js.map → p-6e313705.entry.js.map} +0 -0
  322. /package/dist/q2-tecton-elements/{p-1d824cdf.entry.js.map → p-828850c1.entry.js.map} +0 -0
  323. /package/dist/q2-tecton-elements/{p-8fc099f5.entry.js.map → p-9b65cc28.entry.js.map} +0 -0
  324. /package/dist/q2-tecton-elements/{p-3c42c90f.js.map → p-b6bcef6a.js.map} +0 -0
  325. /package/dist/q2-tecton-elements/{p-f18caa3f.entry.js.map → p-bc73f69c.entry.js.map} +0 -0
  326. /package/dist/q2-tecton-elements/{p-fb7dd7ab.entry.js.map → p-d32f8e53.entry.js.map} +0 -0
  327. /package/dist/q2-tecton-elements/{p-a891571c.entry.js.map → p-d35de465.entry.js.map} +0 -0
  328. /package/dist/q2-tecton-elements/{p-66ae329f.entry.js.map → p-dfa489ba.entry.js.map} +0 -0
  329. /package/dist/q2-tecton-elements/{p-23183c61.entry.js.map → p-f57c4448.entry.js.map} +0 -0
  330. /package/dist/q2-tecton-elements/{p-0e482a7c.entry.js.map → p-fcffc029.entry.js.map} +0 -0
  331. /package/dist/types/workspace/workspace/{_Gitlab_tecton-production_master → on-production_release_1.48.0-pre}/packages/q2-tecton-elements/.stencil/test/elements/q2-detail/slot-component.d.ts +0 -0
@@ -1,5 +1,6 @@
1
1
  import { h, Fragment } from "@stencil/core";
2
2
  import { isValid as isValidDate, intlFormatDistance } from "date-fns";
3
+ import { loc } from "../../utils";
3
4
  export class Q2RelativeTime {
4
5
  constructor() {
5
6
  /**
@@ -34,21 +35,29 @@ export class Q2RelativeTime {
34
35
  get shouldShow() {
35
36
  return !!this.displayedMessage;
36
37
  }
37
- get validDate() {
38
- const targetDate = new Date(this.date);
39
- return isValidDate(targetDate);
40
- }
41
- get handleDate() {
42
- if (!this.validDate)
38
+ get isValidDate() {
39
+ const date = new Date(this.date);
40
+ const isValid = isValidDate(date);
41
+ if (!isValid)
43
42
  console.warn('Error: Invalid date provided to q2-relative-time.');
43
+ return isValid;
44
+ }
45
+ get dateObject() {
44
46
  return new Date(this.date);
45
47
  }
46
- get validBaseDate() {
47
- const baseDate = new Date(this.baseDate);
48
- return isValidDate(baseDate);
48
+ get isBaseDateProvided() {
49
+ return this.baseDate !== undefined;
49
50
  }
50
- get handleBaseDate() {
51
- if (this.validBaseDate) {
51
+ get isValidBaseDate() {
52
+ const date = new Date(this.baseDate);
53
+ const isValid = isValidDate(date);
54
+ if (!isValid && this.isBaseDateProvided) {
55
+ console.warn('Error: Invalid baseDate provided to q2-relative-time.');
56
+ }
57
+ return isValid;
58
+ }
59
+ get baseDateObject() {
60
+ if (this.isBaseDateProvided && this.isValidBaseDate) {
52
61
  this.trimSuffix = true;
53
62
  this.sync = false;
54
63
  return new Date(this.baseDate);
@@ -65,7 +74,7 @@ export class Q2RelativeTime {
65
74
  return false;
66
75
  }
67
76
  get handleNumeric() {
68
- if (this.validBaseDate)
77
+ if (this.isValidBaseDate)
69
78
  return 'always';
70
79
  return this.numeric;
71
80
  }
@@ -82,13 +91,13 @@ export class Q2RelativeTime {
82
91
  }
83
92
  }
84
93
  updateMessage() {
85
- const { validDate, handleDate, handleBaseDate, locale, handleNumeric, messageFormat, isValidUnit, unit, trimSuffix, } = this;
86
- if (!validDate) {
94
+ const { isValidDate, isBaseDateProvided, isValidBaseDate, dateObject, baseDateObject, locale, handleNumeric, messageFormat, isValidUnit, unit, trimSuffix, } = this;
95
+ if (!isValidDate || (isBaseDateProvided && !isValidBaseDate)) {
87
96
  this.sync = false;
88
- this.displayedMessage = 'Invalid Date Provided';
97
+ this.displayedMessage = loc('tecton.element.relativeTime.invalidDate');
89
98
  return;
90
99
  }
91
- const message = intlFormatDistance(new Date(handleDate), new Date(handleBaseDate), {
100
+ const message = intlFormatDistance(new Date(dateObject), new Date(baseDateObject), {
92
101
  locale,
93
102
  localeMatcher: 'best fit',
94
103
  numeric: handleNumeric,
@@ -111,10 +120,18 @@ export class Q2RelativeTime {
111
120
  async displayedMessageValue() {
112
121
  return this.displayedMessage;
113
122
  }
123
+ /** Checks the provided date prop is a valid date. */
124
+ async validDateProp() {
125
+ return this.isValidDate;
126
+ }
127
+ /** Checks the provided baseDate prop is a valid date. */
128
+ async validBaseDateProp() {
129
+ return this.isValidBaseDate;
130
+ }
114
131
  /// DOM ///
115
132
  render() {
116
133
  const { shouldShow, displayedMessage } = this;
117
- return h(Fragment, { key: '26e452a6b2cda738835ac8675aea30b50846920a' }, shouldShow ? h("time", { dateTime: displayedMessage }, displayedMessage) : null);
134
+ return h(Fragment, { key: '441a46ba1701a606f87b53120a7dc8a696dc85e1' }, shouldShow ? h("time", { dateTime: displayedMessage }, displayedMessage) : null);
118
135
  }
119
136
  static get is() { return "q2-relative-time"; }
120
137
  static get encapsulation() { return "shadow"; }
@@ -148,9 +165,9 @@ export class Q2RelativeTime {
148
165
  "docs": {
149
166
  "tags": [{
150
167
  "name": "warning",
151
- "text": "- Requires a valid `date` value.\n- Providing a valid `baseDate` will disable `sync` and remove the \"in\"/\"ago\" suffixes in the time message.\n- Must be a valid ISO date string."
168
+ "text": "- Requires a valid `date` value.\n- If the provided `baseDate` is invalid, the component will display \"Invalid Date\" and a warning message will be printed in the console.\n- Providing a valid `baseDate` will disable `sync` and remove the \"in\"/\"ago\" suffixes in the time message.\n- Must be a valid ISO date string."
152
169
  }],
153
- "text": "If you want to compare two specific dates, you can provide a valid `date` and `baseDate`, and the component will tell you the elapsed time between the two dates.\nIf `baseDate` is not provided, the date and time at render will be used instead and - if `sync` is true - updated every second to reflect the time between the `date` value and now."
170
+ "text": "If you want to display the length of time between two specific dates, you can provide a valid `date` and `baseDate`, and the component will display the length of time between the two dates.\n\nIf `baseDate` is not provided, the date and time at render will be used instead and - if `sync` is true - updated every second to reflect the time between the `date` value and the time at render."
154
171
  },
155
172
  "attribute": "base-date",
156
173
  "reflect": true
@@ -168,9 +185,9 @@ export class Q2RelativeTime {
168
185
  "docs": {
169
186
  "tags": [{
170
187
  "name": "info",
171
- "text": "It is recommended to use the BCP 47 Language Tags in the ['language-extlang' format](https://www.w3.org/International/articles/language-tags/)."
188
+ "text": "It is recommended to use the BCP 47 Language Tags in the [\"language-extlang\" format](https://www.w3.org/International/articles/language-tags/)."
172
189
  }],
173
- "text": "The language used for the relative time message."
190
+ "text": "The language used for the displayed message."
174
191
  },
175
192
  "attribute": "locale",
176
193
  "reflect": true,
@@ -205,8 +222,11 @@ export class Q2RelativeTime {
205
222
  "required": false,
206
223
  "optional": false,
207
224
  "docs": {
208
- "tags": [],
209
- "text": "Set this to `always` to force the use of numeric values (e.g. \"1 day ago\") rather than relative ones (e.g. \"yesterday\") in the time message."
225
+ "tags": [{
226
+ "name": "info",
227
+ "text": " Set this property to `always` to force the use of numeric values (e.g. \"1 day ago\") rather than relative ones (e.g. \"yesterday\")."
228
+ }],
229
+ "text": "Determines if the displayed message will use numeric or relative values."
210
230
  },
211
231
  "attribute": "numeric",
212
232
  "reflect": true,
@@ -251,7 +271,7 @@ export class Q2RelativeTime {
251
271
  "docs": {
252
272
  "tags": [{
253
273
  "name": "warning",
254
- "text": "Must be a valid ISO date string."
274
+ "text": "- Must be a valid ISO date string.\n- If the provided `date` is invalid, the component will display \"Invalid Date\" and a warning message will be printed in the console."
255
275
  }],
256
276
  "text": "The date you want to calculate relative time from."
257
277
  },
@@ -270,7 +290,7 @@ export class Q2RelativeTime {
270
290
  "optional": false,
271
291
  "docs": {
272
292
  "tags": [],
273
- "text": "Force the unit of measurement."
293
+ "text": "Enforces the use of the provided unit of measurement in the displayed message."
274
294
  },
275
295
  "attribute": "unit",
276
296
  "reflect": true
@@ -300,6 +320,40 @@ export class Q2RelativeTime {
300
320
  "text": "Retrieves the value of the displayed messages.",
301
321
  "tags": []
302
322
  }
323
+ },
324
+ "validDateProp": {
325
+ "complexType": {
326
+ "signature": "() => Promise<boolean>",
327
+ "parameters": [],
328
+ "references": {
329
+ "Promise": {
330
+ "location": "global",
331
+ "id": "global::Promise"
332
+ }
333
+ },
334
+ "return": "Promise<boolean>"
335
+ },
336
+ "docs": {
337
+ "text": "Checks the provided date prop is a valid date.",
338
+ "tags": []
339
+ }
340
+ },
341
+ "validBaseDateProp": {
342
+ "complexType": {
343
+ "signature": "() => Promise<boolean>",
344
+ "parameters": [],
345
+ "references": {
346
+ "Promise": {
347
+ "location": "global",
348
+ "id": "global::Promise"
349
+ }
350
+ },
351
+ "return": "Promise<boolean>"
352
+ },
353
+ "docs": {
354
+ "text": "Checks the provided baseDate prop is a valid date.",
355
+ "tags": []
356
+ }
303
357
  }
304
358
  };
305
359
  }
@@ -1 +1 @@
1
- {"version":3,"file":"q2-relative-time.js","sourceRoot":"","sources":["../../../../src/components/q2-relative-time/q2-relative-time.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Prop, State, Method, Watch, Element, h, ComponentInterface, Fragment } from '@stencil/core';\nimport { isValid as isValidDate, intlFormatDistance } from 'date-fns';\n\n@Component({ tag: 'q2-relative-time', shadow: true, styleUrl: 'q2-relative-time.scss' })\nexport class Q2RelativeTime implements ComponentInterface {\n /**\n * If you want to compare two specific dates, you can provide a valid `date` and `baseDate`, and the component will tell you the elapsed time between the two dates.\n * If `baseDate` is not provided, the date and time at render will be used instead and - if `sync` is true - updated every second to reflect the time between the `date` value and now.\n * @warning\n * - Requires a valid `date` value.\n * - Providing a valid `baseDate` will disable `sync` and remove the \"in\"/\"ago\" suffixes in the time message.\n * - Must be a valid ISO date string.\n */\n @Prop({ reflect: true }) baseDate: Date | string;\n\n /**\n * The language used for the relative time message.\n * @info\n * It is recommended to use the BCP 47 Language Tags in the ['language-extlang' format](https://www.w3.org/International/articles/language-tags/).\n */\n @Prop({ reflect: true }) locale: string = document.documentElement.lang || 'en-US';\n\n /** The length of the relative time message. */\n @Prop({ reflect: true }) messageFormat: 'long' | 'short' | 'narrow' = 'short';\n\n /** Set this to `always` to force the use of numeric values (e.g. \"1 day ago\") rather than relative ones (e.g. \"yesterday\") in the time message. */\n @Prop({ reflect: true }) numeric: 'always' | 'auto' = 'auto';\n\n /**\n * Keep the displayed message updated as time passes in the webpage.\n * @warning\n * If a valid `baseDate` is provided, `sync` will be set to `false`.\n */\n @Prop({ reflect: true, mutable: true }) sync: boolean = true;\n\n /**\n * The date you want to calculate relative time from.\n * @warning\n * Must be a valid ISO date string.\n */\n @Prop({ reflect: true }) date: Date | string;\n\n /** Force the unit of measurement. */\n @Prop({ reflect: true }) unit: 'second' | 'minute' | 'hour' | 'day' | 'month' | 'quarter' | 'year';\n\n /**\n * @private\n * Used to manage the sync timer that updates the time since the component was connected to the DOM.\n * Will be set to null if a valid `baseDate` is provided.\n */\n syncTimer = null;\n\n /** @private Will be set to true if a valid `baseDate` is provided. */\n trimSuffix: boolean = false;\n\n @State() displayedMessage: string;\n\n @Element() hostElement: HTMLElement;\n\n /// Lifecycle Hooks ///\n\n componentWillLoad(): void | Promise<void> {\n this.updateMessage();\n }\n\n connectedCallback(): void {\n this.syncUpdated();\n }\n\n disconnectedCallback(): void {\n window.clearInterval(this.syncTimer);\n this.syncTimer = null;\n }\n\n /// Getters ///\n get shouldShow(): boolean {\n return !!this.displayedMessage;\n }\n\n get validDate(): boolean {\n const targetDate = new Date(this.date);\n return isValidDate(targetDate);\n }\n\n get handleDate(): Date {\n if (!this.validDate) console.warn('Error: Invalid date provided to q2-relative-time.');\n return new Date(this.date);\n }\n\n get validBaseDate(): boolean {\n const baseDate = new Date(this.baseDate);\n return isValidDate(baseDate);\n }\n\n get handleBaseDate(): Date {\n if (this.validBaseDate) {\n this.trimSuffix = true;\n this.sync = false;\n return new Date(this.baseDate);\n } else {\n this.trimSuffix = false;\n this.sync = true;\n return new Date();\n }\n }\n\n get isValidUnit(): boolean {\n if (['second', 'minute', 'hour', 'day', 'month', 'quarter', 'year'].includes(this.unit)) return true;\n return false;\n }\n\n get handleNumeric(): 'always' | 'auto' {\n if (this.validBaseDate) return 'always';\n return this.numeric;\n }\n\n /// Watchers ///\n @Watch('sync')\n syncUpdated() {\n if (this.sync) {\n this.syncTimer = window.setInterval(() => {\n this.updateMessage();\n }, 1000);\n } else {\n window.clearInterval(this.syncTimer);\n this.syncTimer = null;\n }\n }\n\n @Watch('messageFormat')\n @Watch('locale')\n @Watch('date')\n @Watch('baseDate')\n @Watch('numeric')\n @Watch('unit')\n updateMessage() {\n const {\n validDate,\n handleDate,\n handleBaseDate,\n locale,\n handleNumeric,\n messageFormat,\n isValidUnit,\n unit,\n trimSuffix,\n } = this;\n\n if (!validDate) {\n this.sync = false;\n this.displayedMessage = 'Invalid Date Provided';\n return;\n }\n\n const message = intlFormatDistance(new Date(handleDate), new Date(handleBaseDate), {\n locale,\n localeMatcher: 'best fit',\n numeric: handleNumeric,\n style: messageFormat,\n unit: isValidUnit ? unit : null,\n });\n\n if (trimSuffix) {\n this.displayedMessage = this.trimMessage(message);\n } else {\n this.displayedMessage = message;\n }\n }\n\n /// Helpers ///\n trimMessage(message: string): string {\n return message.replace(/^in\\s?/, '').replace(/\\sago$/, '');\n }\n\n /// Methods ///\n /** Retrieves the value of the displayed messages. */\n @Method()\n async displayedMessageValue(): Promise<string> {\n return this.displayedMessage;\n }\n\n /// DOM ///\n\n render() {\n const { shouldShow, displayedMessage } = this;\n\n return <Fragment>{shouldShow ? <time dateTime={displayedMessage}>{displayedMessage}</time> : null}</Fragment>;\n }\n}\n"]}
1
+ {"version":3,"file":"q2-relative-time.js","sourceRoot":"","sources":["../../../../src/components/q2-relative-time/q2-relative-time.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Prop, State, Method, Watch, Element, h, ComponentInterface, Fragment } from '@stencil/core';\nimport { isValid as isValidDate, intlFormatDistance } from 'date-fns';\nimport { loc } from '../../utils';\n\n@Component({ tag: 'q2-relative-time', shadow: true, styleUrl: 'q2-relative-time.scss' })\nexport class Q2RelativeTime implements ComponentInterface {\n /**\n * If you want to display the length of time between two specific dates, you can provide a valid `date` and `baseDate`, and the component will display the length of time between the two dates.\n *\n * If `baseDate` is not provided, the date and time at render will be used instead and - if `sync` is true - updated every second to reflect the time between the `date` value and the time at render.\n *\n * @warning\n * - Requires a valid `date` value.\n * - If the provided `baseDate` is invalid, the component will display \"Invalid Date\" and a warning message will be printed in the console.\n * - Providing a valid `baseDate` will disable `sync` and remove the \"in\"/\"ago\" suffixes in the time message.\n * - Must be a valid ISO date string.\n */\n @Prop({ reflect: true }) baseDate: Date | string;\n\n /**\n * The language used for the displayed message.\n * @info\n * It is recommended to use the BCP 47 Language Tags in the [\"language-extlang\" format](https://www.w3.org/International/articles/language-tags/).\n */\n @Prop({ reflect: true }) locale: string = document.documentElement.lang || 'en-US';\n\n /** The length of the relative time message. */\n @Prop({ reflect: true }) messageFormat: 'long' | 'short' | 'narrow' = 'short';\n\n /**\n * Determines if the displayed message will use numeric or relative values.\n *@info\n * Set this property to `always` to force the use of numeric values (e.g. \"1 day ago\") rather than relative ones (e.g. \"yesterday\").\n */\n @Prop({ reflect: true }) numeric: 'always' | 'auto' = 'auto';\n\n /**\n * Keep the displayed message updated as time passes in the webpage.\n * @warning\n * If a valid `baseDate` is provided, `sync` will be set to `false`.\n */\n @Prop({ reflect: true, mutable: true }) sync: boolean = true;\n\n /**\n * The date you want to calculate relative time from.\n *\n * @warning\n * - Must be a valid ISO date string.\n * - If the provided `date` is invalid, the component will display \"Invalid Date\" and a warning message will be printed in the console.\n */\n @Prop({ reflect: true }) date: Date | string;\n\n /** Enforces the use of the provided unit of measurement in the displayed message. */\n @Prop({ reflect: true }) unit: 'second' | 'minute' | 'hour' | 'day' | 'month' | 'quarter' | 'year';\n\n /**\n * @private\n * Used to manage the sync timer that updates the time since the component was connected to the DOM.\n * Will be set to null if a valid `baseDate` is provided.\n */\n syncTimer = null;\n\n /** @private Will be set to true if a valid `baseDate` is provided. */\n trimSuffix: boolean = false;\n\n @State() displayedMessage: string;\n\n @Element() hostElement: HTMLElement;\n\n /// Lifecycle Hooks ///\n\n componentWillLoad(): void | Promise<void> {\n this.updateMessage();\n }\n\n connectedCallback(): void {\n this.syncUpdated();\n }\n\n disconnectedCallback(): void {\n window.clearInterval(this.syncTimer);\n this.syncTimer = null;\n }\n\n /// Getters ///\n get shouldShow(): boolean {\n return !!this.displayedMessage;\n }\n\n get isValidDate(): boolean {\n const date = new Date(this.date);\n const isValid = isValidDate(date);\n if (!isValid) console.warn('Error: Invalid date provided to q2-relative-time.');\n return isValid;\n }\n\n get dateObject(): Date {\n return new Date(this.date);\n }\n\n get isBaseDateProvided(): boolean {\n return this.baseDate !== undefined;\n }\n\n get isValidBaseDate(): boolean {\n const date = new Date(this.baseDate);\n const isValid = isValidDate(date);\n if (!isValid && this.isBaseDateProvided) {\n console.warn('Error: Invalid baseDate provided to q2-relative-time.');\n }\n return isValid;\n }\n\n get baseDateObject(): Date {\n if (this.isBaseDateProvided && this.isValidBaseDate) {\n this.trimSuffix = true;\n this.sync = false;\n return new Date(this.baseDate);\n } else {\n this.trimSuffix = false;\n this.sync = true;\n return new Date();\n }\n }\n\n get isValidUnit(): boolean {\n if (['second', 'minute', 'hour', 'day', 'month', 'quarter', 'year'].includes(this.unit)) return true;\n return false;\n }\n\n get handleNumeric(): 'always' | 'auto' {\n if (this.isValidBaseDate) return 'always';\n return this.numeric;\n }\n\n /// Watchers ///\n @Watch('sync')\n syncUpdated() {\n if (this.sync) {\n this.syncTimer = window.setInterval(() => {\n this.updateMessage();\n }, 1000);\n } else {\n window.clearInterval(this.syncTimer);\n this.syncTimer = null;\n }\n }\n\n @Watch('messageFormat')\n @Watch('locale')\n @Watch('date')\n @Watch('baseDate')\n @Watch('numeric')\n @Watch('unit')\n updateMessage() {\n const {\n isValidDate,\n isBaseDateProvided,\n isValidBaseDate,\n dateObject,\n baseDateObject,\n locale,\n handleNumeric,\n messageFormat,\n isValidUnit,\n unit,\n trimSuffix,\n } = this;\n\n if (!isValidDate || (isBaseDateProvided && !isValidBaseDate)) {\n this.sync = false;\n this.displayedMessage = loc('tecton.element.relativeTime.invalidDate');\n return;\n }\n\n const message = intlFormatDistance(new Date(dateObject), new Date(baseDateObject), {\n locale,\n localeMatcher: 'best fit',\n numeric: handleNumeric,\n style: messageFormat,\n unit: isValidUnit ? unit : null,\n });\n\n if (trimSuffix) {\n this.displayedMessage = this.trimMessage(message);\n } else {\n this.displayedMessage = message;\n }\n }\n\n /// Helpers ///\n trimMessage(message: string): string {\n return message.replace(/^in\\s?/, '').replace(/\\sago$/, '');\n }\n\n /// Methods ///\n /** Retrieves the value of the displayed messages. */\n @Method()\n async displayedMessageValue(): Promise<string> {\n return this.displayedMessage;\n }\n\n /** Checks the provided date prop is a valid date. */\n @Method()\n async validDateProp(): Promise<boolean> {\n return this.isValidDate;\n }\n\n /** Checks the provided baseDate prop is a valid date. */\n @Method()\n async validBaseDateProp(): Promise<boolean> {\n return this.isValidBaseDate;\n }\n\n /// DOM ///\n\n render() {\n const { shouldShow, displayedMessage } = this;\n\n return <Fragment>{shouldShow ? <time dateTime={displayedMessage}>{displayedMessage}</time> : null}</Fragment>;\n }\n}\n"]}
@@ -153,9 +153,9 @@ export class Q2Section {
153
153
  wrapperClasses.push('is-transitioning');
154
154
  }
155
155
  const showDefaultHeader = !this.hasYieldedHeader && !!this.label;
156
- return (h("section", { key: '4cae0e6f0057c318e45274cdabe74878bad2a995', class: "wrapper" }, h("header", { key: 'bb4439e069cb85a3950cabfcc08d220415229082', class: hasHeader ? 'has-header' : '' }, h("div", { key: '036bd23de5da7bd0c45a31521fdeffa240e398b0', class: "header-content", id: this.titleId, onClick: this.collapsible && this.onHeaderClick }, showDefaultHeader && h("h2", { key: '2742ab3ad5654864b0951637e0b5a5a5028ea34d', class: "title" }, loc(this.label)), h("div", { key: 'b772b2028190079db060d28ebaab67723b030462', ref: el => (this.headerSlotWrapper = el), class: "header-slot-wrapper" }, h("slot", { key: '986a404b7a5297af31d4122ffe4daa4697b90203', ref: (el) => (this.headerSlot = el), name: "q2-section-header" }))), this.collapsible && !this.noCollapseIcon && (h("q2-btn", { key: '678f61529c25ceb257cf7d26abdd46448b0f0d96', label: loc(this.label || 'tecton.element.section.defaultToggleLabel'), ariaExpanded: `${!!this.expanded}`, ariaControls: this.contentId, "test-id": "toggleButton", "hide-label": true, onClick: this.onHeaderClick }, h("q2-icon", { key: '5494baf730dd97d54e1e50b6366dbaea3676ce16', type: "chevron-up" })))), h("div", { key: '33cdc24262ad444f8d61cd557371963e5ebf4ce0', class: wrapperClasses.join(' '), id: this.contentId, "aria-labelledby": this.titleId, role: "region", onTransitionEnd: this.onTransitionEnd, style: this.collapsible && {
156
+ return (h("section", { key: '6e12bfbe36ad6c268079c32b6c39a7618ff12b1d', class: "wrapper" }, h("header", { key: '91f7c8a2655170d49b7729efc60a77eb28ad1d45', class: hasHeader ? 'has-header' : '' }, h("div", { key: '9edb887a2a8730794793674f46542cbd630e2a89', class: "header-content", id: this.titleId, onClick: this.collapsible && this.onHeaderClick }, showDefaultHeader && h("h2", { key: 'a6cb6d0c520d66b5bb35ab726c0e84bd55e0d25a', class: "title" }, loc(this.label)), h("div", { key: '1b01d8e62560f2a0cdf0627aa512a516edd48e62', ref: el => (this.headerSlotWrapper = el), class: "header-slot-wrapper" }, h("slot", { key: 'fbcddb1a7282460a939785da9fdaf2c59b56668e', ref: (el) => (this.headerSlot = el), name: "q2-section-header" }))), this.collapsible && !this.noCollapseIcon && (h("q2-btn", { key: '172089a013090bd461f66847e636aab0a3c477cd', label: loc(this.label || 'tecton.element.section.defaultToggleLabel'), ariaExpanded: `${!!this.expanded}`, ariaControls: this.contentId, "test-id": "toggleButton", "hide-label": true, onClick: this.onHeaderClick }, h("q2-icon", { key: '40e45aefe27e0ee9e1fe15de552b89c298b6a609', type: "chevron-up" })))), h("div", { key: 'f1673a5d32dd9bb781faae906d524091a2aa04a9', class: wrapperClasses.join(' '), id: this.contentId, "aria-labelledby": this.titleId, role: "region", onTransitionEnd: this.onTransitionEnd, style: this.collapsible && {
157
157
  height: this.contentHeight,
158
- } }, h("div", { key: 'f30463473a96a1e5fe8dc4f5951c147a1847d2f4', ref: el => (this.contentContainer = el), class: "content", tabindex: "-1" }, h("slot", { key: 'e41200b2ed13a0e280c223020c7b7ada8d3b6056', ref: (el) => (this.contentSlot = el) })))));
158
+ } }, h("div", { key: 'dbd1ceb839713c3be27407ebe6ba2f9a6a104fbb', ref: el => (this.contentContainer = el), class: "content", tabindex: "-1" }, h("slot", { key: '9692d272736fb8bd861f9e13e398af42489dc403', ref: (el) => (this.contentSlot = el) })))));
159
159
  }
160
160
  static get is() { return "q2-section"; }
161
161
  static get encapsulation() { return "shadow"; }
@@ -216,8 +216,11 @@ export class Q2Section {
216
216
  "required": false,
217
217
  "optional": false,
218
218
  "docs": {
219
- "tags": [],
220
- "text": "The text to display above the `q2-section`. Renders as an `<h2>` element."
219
+ "tags": [{
220
+ "name": "warning",
221
+ "text": "If you are providing a custom header, setting this property is still strongly encouraged for the purposes of\naccessibility."
222
+ }],
223
+ "text": "The text to display above the `q2-section`. Renders as an `<h2>` element.\n\nIt is also used to provided an `aria-label` for the toggle button when the component is collapsible."
221
224
  },
222
225
  "attribute": "label",
223
226
  "reflect": true
@@ -1 +1 @@
1
- {"version":3,"file":"q2-section.js","sourceRoot":"","sources":["../../../../src/components/q2-section/q2-section.tsx"],"names":[],"mappings":"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","sourcesContent":["import {\n Component,\n ComponentInterface,\n Prop,\n Element,\n Listen,\n State,\n Watch,\n h,\n Event,\n EventEmitter,\n} from '@stencil/core';\nimport { isEventFromElement, loc, nextPaint, overrideFocus, resizeIframe } from 'src/utils';\n\n@Component({ tag: 'q2-section', shadow: true, styleUrl: 'q2-section.scss' })\nexport class Q2Section implements ComponentInterface {\n /** Determines if the section is collapsible. */\n @Prop({ reflect: true }) collapsible: boolean;\n\n /** Indicates if the `q2-section` is in an expanded state or not. */\n @Prop({ reflect: true, mutable: true }) expanded: boolean;\n\n /** The text to display above the `q2-section`. Renders as an `<h2>` element. */\n @Prop({ reflect: true }) label: string;\n\n /** Determines if the collapse chevron icon should show in the `q2-section` header. */\n @Prop({ reflect: true }) noCollapseIcon: boolean;\n\n @Element() hostElement: HTMLElement;\n @State() contentHeight: string;\n @State() hideContent: boolean = false;\n @State() hasYieldedHeader: boolean = false;\n\n titleId: string = 'title';\n contentId: string = 'content';\n resizerFn: NodeJS.Timer | undefined;\n headerSlotMutationObserver: MutationObserver;\n contentSlotMutationObserver: MutationObserver;\n contentContainer: HTMLDivElement;\n headerSlotWrapper: HTMLDivElement;\n headerSlot: HTMLSlotElement;\n contentSlot: HTMLSlotElement;\n\n componentWillLoad() {\n this.onHeaderSlotChange();\n const { collapsible, expanded } = this;\n this.contentHeight = collapsible && expanded ? undefined : '0px';\n this.hideContent = !expanded;\n }\n\n componentDidLoad() {\n this.addHeaderSlotListener();\n this.addContentSlotListener();\n overrideFocus(this.hostElement);\n }\n\n disconnectedCallback() {\n this.removeHeaderSlotListener();\n this.removeContentSlotListener();\n }\n\n /// Listeners ///\n @Listen('change')\n defaultChangeHandler(event: CustomEvent) {\n if (event.target === this.hostElement && !this.hostElement.onchange && !!event.detail) {\n this.expanded = event.detail.expanded;\n }\n }\n\n @Listen('focus')\n delegateFocus(event: FocusEvent) {\n if (!isEventFromElement(event, this.hostElement)) return;\n this.contentContainer.focus();\n }\n\n /// Watchers ///\n @Watch('expanded')\n async expandedObserver(expanded: boolean) {\n this.clearResizeInterval();\n this.resizerFn = setInterval(resizeIframe, 5);\n\n if (expanded) {\n this.expandSection();\n } else {\n this.collapseSection();\n }\n }\n\n async collapseSection() {\n this.contentHeight = this.contentContainerHeight;\n await nextPaint(() => {\n this.contentHeight = this.currentHeight;\n });\n }\n\n async expandSection() {\n this.hideContent = false;\n await nextPaint(() => {\n this.contentHeight = this.currentHeight;\n });\n }\n\n @Watch('collapsible')\n collapsibleObserver() {\n this.contentHeight = this.currentHeight;\n }\n\n /// Events ///\n /**\n * Emitted when the section is expanded or collapsed.\n * @legacyEvent\n */\n @Event() change: EventEmitter<{ expanded: boolean }>;\n\n /// Event Handlers ///\n onHeaderClick = () => {\n this.change.emit({\n expanded: !this.expanded,\n });\n };\n\n onTransitionEnd = () => {\n if (this.expanded) {\n this.contentHeight = undefined;\n } else {\n this.hideContent = true;\n }\n\n setTimeout(() => {\n // This gives enough time for all values to get passed over\n // Previously, the interval was never cleared and the fn was called indefinitely then filtered\n // Will revisit in TCT-599\n this.clearResizeInterval();\n }, 1000);\n };\n\n onHeaderSlotChange = () => {\n const hasSlotContent = !!this.hostElement.querySelector('[slot=\"q2-section-header\"]');\n\n if (this.hasYieldedHeader !== hasSlotContent) {\n this.hasYieldedHeader = !!hasSlotContent;\n }\n };\n\n /// Getters ///\n get currentHeight() {\n const { collapsible, expanded } = this;\n if (!collapsible) {\n return null;\n } else if (expanded) {\n return this.contentContainerHeight;\n } else {\n return '0';\n }\n }\n\n get contentContainerHeight() {\n return `${this.contentContainer.offsetHeight || 0}px`;\n }\n\n /// Helpers ///\n clearResizeInterval = () => {\n this.resizerFn && clearInterval(this.resizerFn);\n };\n\n addHeaderSlotListener = () => {\n if (this.headerSlot) {\n this.headerSlot.addEventListener('slotchange', this.onHeaderSlotChange);\n return;\n }\n\n const observer = new MutationObserver(this.onHeaderSlotChange);\n observer.observe(this.headerSlotWrapper, { childList: true });\n this.headerSlotMutationObserver = observer;\n };\n\n removeHeaderSlotListener = () => {\n if (this.headerSlot) {\n this.headerSlot.removeEventListener('slotchange', this.onHeaderSlotChange);\n return;\n }\n\n this.headerSlotMutationObserver.disconnect();\n };\n\n addContentSlotListener = () => {\n if (this.contentSlot) {\n this.contentSlot.addEventListener('slotchange', resizeIframe);\n return;\n }\n\n const observer = new MutationObserver(resizeIframe);\n observer.observe(this.contentContainer, { childList: true, subtree: true });\n this.contentSlotMutationObserver = observer;\n };\n\n removeContentSlotListener = () => {\n if (this.contentSlot) {\n this.contentSlot.removeEventListener('slotchange', resizeIframe);\n return;\n }\n this.contentSlotMutationObserver.disconnect();\n };\n\n render() {\n const hasHeader = this.label || this.hasYieldedHeader;\n const wrapperClasses = ['content-wrapper'];\n const { collapsible, hideContent, contentHeight } = this;\n if (collapsible) {\n if (hideContent) wrapperClasses.push('is-closed');\n else if (contentHeight) wrapperClasses.push('is-transitioning');\n }\n\n const showDefaultHeader = !this.hasYieldedHeader && !!this.label;\n\n return (\n <section class=\"wrapper\">\n <header class={hasHeader ? 'has-header' : ''}>\n <div\n class=\"header-content\"\n id={this.titleId}\n onClick={this.collapsible && this.onHeaderClick}\n >\n {showDefaultHeader && <h2 class=\"title\">{loc(this.label)}</h2>}\n <div\n ref={el => (this.headerSlotWrapper = el)}\n class=\"header-slot-wrapper\"\n >\n <slot\n ref={(el: HTMLSlotElement) => (this.headerSlot = el)}\n name=\"q2-section-header\"\n />\n </div>\n </div>\n {this.collapsible && !this.noCollapseIcon && (\n <q2-btn\n label={loc(this.label || 'tecton.element.section.defaultToggleLabel')}\n ariaExpanded={`${!!this.expanded}`}\n ariaControls={this.contentId}\n test-id=\"toggleButton\"\n hide-label\n onClick={this.onHeaderClick}\n >\n <q2-icon type=\"chevron-up\" />\n </q2-btn>\n )}\n </header>\n <div\n class={wrapperClasses.join(' ')}\n id={this.contentId}\n aria-labelledby={this.titleId}\n role=\"region\"\n onTransitionEnd={this.onTransitionEnd}\n style={\n this.collapsible && {\n height: this.contentHeight,\n }\n }\n >\n <div\n ref={el => (this.contentContainer = el)}\n class=\"content\"\n tabindex=\"-1\"\n >\n <slot ref={(el: HTMLSlotElement) => (this.contentSlot = el)} />\n </div>\n </div>\n </section>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"q2-section.js","sourceRoot":"","sources":["../../../../src/components/q2-section/q2-section.tsx"],"names":[],"mappings":"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","sourcesContent":["import {\n Component,\n ComponentInterface,\n Prop,\n Element,\n Listen,\n State,\n Watch,\n h,\n Event,\n EventEmitter,\n} from '@stencil/core';\nimport { isEventFromElement, loc, nextPaint, overrideFocus, resizeIframe } from 'src/utils';\n\n@Component({ tag: 'q2-section', shadow: true, styleUrl: 'q2-section.scss' })\nexport class Q2Section implements ComponentInterface {\n /** Determines if the section is collapsible. */\n @Prop({ reflect: true }) collapsible: boolean;\n\n /** Indicates if the `q2-section` is in an expanded state or not. */\n @Prop({ reflect: true, mutable: true }) expanded: boolean;\n\n /**\n * The text to display above the `q2-section`. Renders as an `<h2>` element.\n *\n * It is also used to provided an `aria-label` for the toggle button when the component is collapsible.\n *\n * @warning\n * If you are providing a custom header, setting this property is still strongly encouraged for the purposes of\n * accessibility.\n */\n @Prop({ reflect: true }) label: string;\n\n /** Determines if the collapse chevron icon should show in the `q2-section` header. */\n @Prop({ reflect: true }) noCollapseIcon: boolean;\n\n @Element() hostElement: HTMLElement;\n @State() contentHeight: string;\n @State() hideContent: boolean = false;\n @State() hasYieldedHeader: boolean = false;\n\n titleId: string = 'title';\n contentId: string = 'content';\n resizerFn: NodeJS.Timeout | undefined;\n headerSlotMutationObserver: MutationObserver;\n contentSlotMutationObserver: MutationObserver;\n contentContainer: HTMLDivElement;\n headerSlotWrapper: HTMLDivElement;\n headerSlot: HTMLSlotElement;\n contentSlot: HTMLSlotElement;\n\n componentWillLoad() {\n this.onHeaderSlotChange();\n const { collapsible, expanded } = this;\n this.contentHeight = collapsible && expanded ? undefined : '0px';\n this.hideContent = !expanded;\n }\n\n componentDidLoad() {\n this.addHeaderSlotListener();\n this.addContentSlotListener();\n overrideFocus(this.hostElement);\n }\n\n disconnectedCallback() {\n this.removeHeaderSlotListener();\n this.removeContentSlotListener();\n }\n\n /// Listeners ///\n @Listen('change')\n defaultChangeHandler(event: CustomEvent) {\n if (event.target === this.hostElement && !this.hostElement.onchange && !!event.detail) {\n this.expanded = event.detail.expanded;\n }\n }\n\n @Listen('focus')\n delegateFocus(event: FocusEvent) {\n if (!isEventFromElement(event, this.hostElement)) return;\n this.contentContainer.focus();\n }\n\n /// Watchers ///\n @Watch('expanded')\n async expandedObserver(expanded: boolean) {\n this.clearResizeInterval();\n this.resizerFn = setInterval(resizeIframe, 5);\n\n if (expanded) {\n this.expandSection();\n } else {\n this.collapseSection();\n }\n }\n\n async collapseSection() {\n this.contentHeight = this.contentContainerHeight;\n await nextPaint(() => {\n this.contentHeight = this.currentHeight;\n });\n }\n\n async expandSection() {\n this.hideContent = false;\n await nextPaint(() => {\n this.contentHeight = this.currentHeight;\n });\n }\n\n @Watch('collapsible')\n collapsibleObserver() {\n this.contentHeight = this.currentHeight;\n }\n\n /// Events ///\n /**\n * Emitted when the section is expanded or collapsed.\n * @legacyEvent\n */\n @Event() change: EventEmitter<{ expanded: boolean }>;\n\n /// Event Handlers ///\n onHeaderClick = () => {\n this.change.emit({\n expanded: !this.expanded,\n });\n };\n\n onTransitionEnd = () => {\n if (this.expanded) {\n this.contentHeight = undefined;\n } else {\n this.hideContent = true;\n }\n\n setTimeout(() => {\n // This gives enough time for all values to get passed over\n // Previously, the interval was never cleared and the fn was called indefinitely then filtered\n // Will revisit in TCT-599\n this.clearResizeInterval();\n }, 1000);\n };\n\n onHeaderSlotChange = () => {\n const hasSlotContent = !!this.hostElement.querySelector('[slot=\"q2-section-header\"]');\n\n if (this.hasYieldedHeader !== hasSlotContent) {\n this.hasYieldedHeader = !!hasSlotContent;\n }\n };\n\n /// Getters ///\n get currentHeight() {\n const { collapsible, expanded } = this;\n if (!collapsible) {\n return null;\n } else if (expanded) {\n return this.contentContainerHeight;\n } else {\n return '0';\n }\n }\n\n get contentContainerHeight() {\n return `${this.contentContainer.offsetHeight || 0}px`;\n }\n\n /// Helpers ///\n clearResizeInterval = () => {\n this.resizerFn && clearInterval(this.resizerFn);\n };\n\n addHeaderSlotListener = () => {\n if (this.headerSlot) {\n this.headerSlot.addEventListener('slotchange', this.onHeaderSlotChange);\n return;\n }\n\n const observer = new MutationObserver(this.onHeaderSlotChange);\n observer.observe(this.headerSlotWrapper, { childList: true });\n this.headerSlotMutationObserver = observer;\n };\n\n removeHeaderSlotListener = () => {\n if (this.headerSlot) {\n this.headerSlot.removeEventListener('slotchange', this.onHeaderSlotChange);\n return;\n }\n\n this.headerSlotMutationObserver.disconnect();\n };\n\n addContentSlotListener = () => {\n if (this.contentSlot) {\n this.contentSlot.addEventListener('slotchange', resizeIframe);\n return;\n }\n\n const observer = new MutationObserver(resizeIframe);\n observer.observe(this.contentContainer, { childList: true, subtree: true });\n this.contentSlotMutationObserver = observer;\n };\n\n removeContentSlotListener = () => {\n if (this.contentSlot) {\n this.contentSlot.removeEventListener('slotchange', resizeIframe);\n return;\n }\n this.contentSlotMutationObserver.disconnect();\n };\n\n render() {\n const hasHeader = this.label || this.hasYieldedHeader;\n const wrapperClasses = ['content-wrapper'];\n const { collapsible, hideContent, contentHeight } = this;\n if (collapsible) {\n if (hideContent) wrapperClasses.push('is-closed');\n else if (contentHeight) wrapperClasses.push('is-transitioning');\n }\n\n const showDefaultHeader = !this.hasYieldedHeader && !!this.label;\n\n return (\n <section class=\"wrapper\">\n <header class={hasHeader ? 'has-header' : ''}>\n <div\n class=\"header-content\"\n id={this.titleId}\n onClick={this.collapsible && this.onHeaderClick}\n >\n {showDefaultHeader && <h2 class=\"title\">{loc(this.label)}</h2>}\n <div\n ref={el => (this.headerSlotWrapper = el)}\n class=\"header-slot-wrapper\"\n >\n <slot\n ref={(el: HTMLSlotElement) => (this.headerSlot = el)}\n name=\"q2-section-header\"\n />\n </div>\n </div>\n {this.collapsible && !this.noCollapseIcon && (\n <q2-btn\n label={loc(this.label || 'tecton.element.section.defaultToggleLabel')}\n ariaExpanded={`${!!this.expanded}`}\n ariaControls={this.contentId}\n test-id=\"toggleButton\"\n hide-label\n onClick={this.onHeaderClick}\n >\n <q2-icon type=\"chevron-up\" />\n </q2-btn>\n )}\n </header>\n <div\n class={wrapperClasses.join(' ')}\n id={this.contentId}\n aria-labelledby={this.titleId}\n role=\"region\"\n onTransitionEnd={this.onTransitionEnd}\n style={\n this.collapsible && {\n height: this.contentHeight,\n }\n }\n >\n <div\n ref={el => (this.contentContainer = el)}\n class=\"content\"\n tabindex=\"-1\"\n >\n <slot ref={(el: HTMLSlotElement) => (this.contentSlot = el)} />\n </div>\n </div>\n </section>\n );\n }\n}\n"]}
@@ -125,9 +125,9 @@ button {
125
125
  }
126
126
 
127
127
  :host {
128
- --comp-select-margin: var(--tct-select-margin, var(--tct-select-margin-top, var(--t-select-margin-top, var(--app-scale-4, 30px))) 0 var(--tct-select-margin-bottom, var(--t-select-margin-bottom, var(--app-scale-4, 30px))));
128
+ --comp-default-select-margin: var(--tct-select-margin-top, var(--t-select-margin-top, var(--app-scale-5x, 25px))) 0 var(--tct-select-margin-bottom, var(--t-select-margin-bottom, var(--app-scale-5x, 25px)));
129
129
  display: block;
130
- margin: var(--comp-select-margin);
130
+ margin: var(--tct-select-margin, var(--comp-default-select-margin));
131
131
  }
132
132
 
133
133
  .q2-select-container {
@@ -73,6 +73,11 @@ export class Q2Select {
73
73
  'Escape',
74
74
  'Tab',
75
75
  ];
76
+ if (this.searchable && (key === ' ' || key === 'Enter') && this.inputField.value == '') {
77
+ event.preventDefault();
78
+ if (!this.open)
79
+ this.openDropdownWithoutActiveElement();
80
+ }
76
81
  if (this.searchable && !keysForOptionListToHandle.includes(key))
77
82
  return;
78
83
  if (this.shouldClearSearchText(event))
@@ -573,11 +578,11 @@ export class Q2Select {
573
578
  }
574
579
  render() {
575
580
  var _a;
576
- return (h("click-elsewhere", { key: 'cf3dd95373d2528d74dbb80da751d1e87dda8934', class: this.wrapperClasses, onChange: this.clickedElsewhere }, h("div", { key: '04db32f27a8cce31ce9ec6dd41c8602eb4312863', "aria-live": "polite", "aria-atomic": "true", role: "status", class: "sr" }, this.statusMessage), h("q2-input", { key: '016b5582ca7ae2d8d4af6ba40ce3961007956b20', ref: el => (this.inputField = el), class: "q2-select-input", label: (this.label && loc(this.label)) || '', value: this.selectedDisplay, clearable: (this.clearable && (!!this.value || !!((_a = this.selectedOptions) === null || _a === void 0 ? void 0 : _a.length))) || undefined, errors: (Array.isArray(this.errors) &&
581
+ return (h("click-elsewhere", { key: '421fc4811bdf2f8cfb899ee9823ce20e3301032c', class: this.wrapperClasses, onChange: this.clickedElsewhere }, h("div", { key: '1a2b96c2e6dbacfa7dcc8918ff4acab71046dc8d', "aria-live": "polite", "aria-atomic": "true", role: "status", class: "sr" }, this.statusMessage), h("q2-input", { key: 'fd678010a8f0d53a4d93c265204bedf72679221a', ref: el => (this.inputField = el), class: "q2-select-input", label: (this.label && loc(this.label)) || '', value: this.selectedDisplay, clearable: (this.clearable && (!!this.value || !!((_a = this.selectedOptions) === null || _a === void 0 ? void 0 : _a.length))) || undefined, errors: (Array.isArray(this.errors) &&
577
582
  this.errors.length > 0 &&
578
583
  this.errors.map(error => loc(error))) ||
579
584
  (this.invalid && ['tecton.element.select.invalid']) ||
580
- [], disabled: this.disabled, optional: this.optional, readonly: !!this.readonly, placeholder: this.placeholder || undefined, hideLabel: this.hideLabel, ariaExpanded: `${this.open}`, ariaControls: "option-list", ariaHaspopup: "listbox", "test-id": "toggleDropdown", "hide-messages": true, iconRight: "chevron-down", onClick: this.inputClickHandler, onInput: this.inputInputHandler, onKeyDown: this.inputKeydownHandler, onFocus: this.inputFocusHandler, onBlur: this.inputBlurHandler, onChange: this.inputChangeHandler, badgeValue: this.badgeValue, badgeTheme: this.inputFocused ? 'primary' : undefined, _role: "combobox", _preventEntry: !this.searchable }, this.renderCustomDisplay()), h("div", { key: '57d7e1301f3cfb4060c2818617a534679562e058', class: "custom-display-content", hidden: !this.hasCustomDisplay || !!this.searchText, onClick: this.onCustomDisplayClick }, h("slot", { key: '2e7ed4900fad5eda9cb39df1c5c7a8b3c9d9e656', name: "q2-select-display" })), this.optionsDropdown()));
585
+ [], disabled: this.disabled, optional: this.optional, readonly: !!this.readonly, placeholder: this.placeholder || undefined, hideLabel: this.hideLabel, ariaExpanded: `${this.open}`, ariaControls: "option-list", ariaHaspopup: "listbox", "test-id": "toggleDropdown", "hide-messages": true, iconRight: "chevron-down", onClick: this.inputClickHandler, onInput: this.inputInputHandler, onKeyDown: this.inputKeydownHandler, onFocus: this.inputFocusHandler, onBlur: this.inputBlurHandler, onChange: this.inputChangeHandler, badgeValue: this.badgeValue, badgeTheme: this.inputFocused ? 'primary' : undefined, _role: "combobox", _preventEntry: !this.searchable }, this.renderCustomDisplay()), h("div", { key: '26f8c78fb455e7fc9451018ed2745ab53018c270', class: "custom-display-content", hidden: !this.hasCustomDisplay || !!this.searchText, onClick: this.onCustomDisplayClick }, h("slot", { key: '4f76ab176fbd88b99aab88ad9e9a3cb87ccb943b', name: "q2-select-display" })), this.optionsDropdown()));
581
586
  }
582
587
  optionsDropdown() {
583
588
  return (h("q2-popover", { ref: el => (this.popoverElement = el), controlElement: this.innerInputContainer, open: this.open, minHeight: this.popoverMinHeight, direction: this.popDirection, mode: this.popoverMode || undefined, block: true }, h("div", { class: "popover-content" }, h("q2-option-list", { onPopoverState: this.onPopoverState, ref: el => (this.optionList = el), type: "listbox", id: "option-list", "show-selected": this.showSelected, label: this.listLabel, multiple: this.multiple, selectedOptions: this.structuredSelectedOptions, onChange: this.onOptionListChange }, h("slot", null)), h("div", { class: "popover-top-container", ref: el => (this.popoverTopContainer = el), hidden: !this.multiple && !this.hasPopoverTop, tabindex: "-1" }, h("slot", { name: "popover-top" }), this.multiple && this.visibilityToggle())), h("div", { class: "popover-bottom-container", hidden: !this.hasPopoverBottom, tabindex: "-1" }, h("slot", { name: "popover-bottom" }))));