q2-tecton-elements 1.34.0 → 1.35.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (304) hide show
  1. package/dist/cjs/{action-sheet-4b366e9a.js → action-sheet-ab1abf24.js} +2 -2
  2. package/dist/cjs/action-sheet-ab1abf24.js.map +1 -0
  3. package/dist/cjs/click-elsewhere_2.cjs.entry.js +1 -1
  4. package/dist/cjs/{index-d42bed64.js → index-f6545293.js} +15 -2
  5. package/dist/cjs/index-f6545293.js.map +1 -0
  6. package/dist/cjs/loader.cjs.js +1 -1
  7. package/dist/cjs/q2-action-sheet.cjs.entry.js +1 -1
  8. package/dist/cjs/q2-btn_2.cjs.entry.js +13 -3
  9. package/dist/cjs/q2-btn_2.cjs.entry.js.map +1 -1
  10. package/dist/cjs/q2-calendar.cjs.entry.js +47 -32
  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 +1 -1
  18. package/dist/cjs/q2-checkbox-group.cjs.entry.js +2 -2
  19. package/dist/cjs/q2-checkbox-group.cjs.entry.js.map +1 -1
  20. package/dist/cjs/q2-checkbox.cjs.entry.js +1 -1
  21. package/dist/cjs/q2-data-table.cjs.entry.js +55 -13
  22. package/dist/cjs/q2-data-table.cjs.entry.js.map +1 -1
  23. package/dist/cjs/q2-dropdown-item.cjs.entry.js +1 -1
  24. package/dist/cjs/q2-dropdown.cjs.entry.js +1 -1
  25. package/dist/cjs/q2-editable-field.cjs.entry.js +1 -1
  26. package/dist/cjs/q2-icon.cjs.entry.js +1 -1
  27. package/dist/cjs/q2-input.cjs.entry.js +5 -5
  28. package/dist/cjs/q2-input.cjs.entry.js.map +1 -1
  29. package/dist/cjs/q2-loc.cjs.entry.js +1 -1
  30. package/dist/cjs/q2-message.cjs.entry.js +1 -1
  31. package/dist/cjs/q2-month-picker.cjs.entry.js +1 -1
  32. package/dist/cjs/q2-optgroup_2.cjs.entry.js +2 -2
  33. package/dist/cjs/q2-optgroup_2.cjs.entry.js.map +1 -1
  34. package/dist/cjs/q2-option-list.cjs.entry.js +7 -6
  35. package/dist/cjs/q2-option-list.cjs.entry.js.map +1 -1
  36. package/dist/cjs/q2-pagination.cjs.entry.js +1 -1
  37. package/dist/cjs/q2-pill.cjs.entry.js +8 -8
  38. package/dist/cjs/q2-pill.cjs.entry.js.map +1 -1
  39. package/dist/cjs/q2-radio-group.cjs.entry.js +2 -2
  40. package/dist/cjs/q2-radio-group.cjs.entry.js.map +1 -1
  41. package/dist/cjs/q2-radio.cjs.entry.js +1 -1
  42. package/dist/cjs/q2-section.cjs.entry.js +1 -1
  43. package/dist/cjs/q2-select.cjs.entry.js +7 -4
  44. package/dist/cjs/q2-select.cjs.entry.js.map +1 -1
  45. package/dist/cjs/q2-stepper-pane.cjs.entry.js +1 -1
  46. package/dist/cjs/q2-stepper-vertical.cjs.entry.js +1 -1
  47. package/dist/cjs/q2-stepper.cjs.entry.js +1 -1
  48. package/dist/cjs/q2-tab-container.cjs.entry.js +1 -1
  49. package/dist/cjs/q2-tag.cjs.entry.js +4 -4
  50. package/dist/cjs/q2-tag.cjs.entry.js.map +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-tooltip.cjs.entry.js +2 -2
  54. package/dist/cjs/q2-tooltip.cjs.entry.js.map +1 -1
  55. package/dist/collection/components/q2-btn/index.js +13 -1
  56. package/dist/collection/components/q2-btn/index.js.map +1 -1
  57. package/dist/collection/components/q2-btn/styles.css +71 -71
  58. package/dist/collection/components/q2-calendar/helpers.js +10 -7
  59. package/dist/collection/components/q2-calendar/helpers.js.map +1 -1
  60. package/dist/collection/components/q2-calendar/index.js +53 -26
  61. package/dist/collection/components/q2-calendar/index.js.map +1 -1
  62. package/dist/collection/components/q2-calendar/styles.css +0 -5
  63. package/dist/collection/components/q2-chart-donut/index.js +1 -1
  64. package/dist/collection/components/q2-checkbox-group/index.js +1 -1
  65. package/dist/collection/components/q2-checkbox-group/index.js.map +1 -1
  66. package/dist/collection/components/q2-data-table/index.js +120 -16
  67. package/dist/collection/components/q2-data-table/index.js.map +1 -1
  68. package/dist/collection/components/q2-data-table/styles.css +27 -4
  69. package/dist/collection/components/q2-input/index.js +4 -4
  70. package/dist/collection/components/q2-input/index.js.map +1 -1
  71. package/dist/collection/components/q2-input/styles.css +12 -4
  72. package/dist/collection/components/q2-option/styles.css +1 -1
  73. package/dist/collection/components/q2-option-list/index.js +15 -31
  74. package/dist/collection/components/q2-option-list/index.js.map +1 -1
  75. package/dist/collection/components/q2-pill/index.js +5 -5
  76. package/dist/collection/components/q2-pill/index.js.map +1 -1
  77. package/dist/collection/components/q2-pill/styles.css +15 -15
  78. package/dist/collection/components/q2-radio-group/index.js +1 -1
  79. package/dist/collection/components/q2-radio-group/index.js.map +1 -1
  80. package/dist/collection/components/q2-select/index.js +5 -2
  81. package/dist/collection/components/q2-select/index.js.map +1 -1
  82. package/dist/collection/components/q2-stepper-pane/index.js +2 -2
  83. package/dist/collection/components/q2-tag/index.js +1 -1
  84. package/dist/collection/components/q2-tag/index.js.map +1 -1
  85. package/dist/collection/components/q2-tag/styles.css +6 -6
  86. package/dist/collection/components/q2-tooltip/styles.css +1 -1
  87. package/dist/collection/utils/action-sheet.js +1 -1
  88. package/dist/collection/utils/action-sheet.js.map +1 -1
  89. package/dist/collection/utils/index.js +13 -1
  90. package/dist/collection/utils/index.js.map +1 -1
  91. package/dist/components/action-sheet.js +1 -1
  92. package/dist/components/action-sheet.js.map +1 -1
  93. package/dist/components/index11.js +1 -1
  94. package/dist/components/index13.js +1 -1
  95. package/dist/components/index13.js.map +1 -1
  96. package/dist/components/index14.js +7 -7
  97. package/dist/components/index14.js.map +1 -1
  98. package/dist/components/index16.js +14 -2
  99. package/dist/components/index16.js.map +1 -1
  100. package/dist/components/index5.js +13 -3
  101. package/dist/components/index5.js.map +1 -1
  102. package/dist/components/index9.js +5 -5
  103. package/dist/components/index9.js.map +1 -1
  104. package/dist/components/q2-calendar.js +47 -31
  105. package/dist/components/q2-calendar.js.map +1 -1
  106. package/dist/components/q2-checkbox-group.js +1 -1
  107. package/dist/components/q2-checkbox-group.js.map +1 -1
  108. package/dist/components/q2-data-table.js +57 -13
  109. package/dist/components/q2-data-table.js.map +1 -1
  110. package/dist/components/q2-pill.js +6 -6
  111. package/dist/components/q2-pill.js.map +1 -1
  112. package/dist/components/q2-radio-group.js +1 -1
  113. package/dist/components/q2-radio-group.js.map +1 -1
  114. package/dist/components/q2-select.js +5 -2
  115. package/dist/components/q2-select.js.map +1 -1
  116. package/dist/components/q2-tag.js +2 -2
  117. package/dist/components/q2-tag.js.map +1 -1
  118. package/dist/components/q2-tooltip.js +1 -1
  119. package/dist/components/q2-tooltip.js.map +1 -1
  120. package/dist/docs.json +72 -26
  121. package/dist/esm/{action-sheet-a9597b32.js → action-sheet-bfcbe154.js} +2 -2
  122. package/dist/esm/action-sheet-bfcbe154.js.map +1 -0
  123. package/dist/esm/click-elsewhere_2.entry.js +1 -1
  124. package/dist/esm/{index-a8589748.js → index-35ff2881.js} +15 -3
  125. package/dist/esm/index-35ff2881.js.map +1 -0
  126. package/dist/esm/loader.js +1 -1
  127. package/dist/esm/q2-action-sheet.entry.js +1 -1
  128. package/dist/esm/q2-btn_2.entry.js +13 -3
  129. package/dist/esm/q2-btn_2.entry.js.map +1 -1
  130. package/dist/esm/q2-calendar.entry.js +47 -32
  131. package/dist/esm/q2-calendar.entry.js.map +1 -1
  132. package/dist/esm/q2-card.entry.js +1 -1
  133. package/dist/esm/q2-carousel-pane.entry.js +1 -1
  134. package/dist/esm/q2-carousel.entry.js +1 -1
  135. package/dist/esm/q2-chart-area.entry.js +1 -1
  136. package/dist/esm/q2-chart-bar.entry.js +1 -1
  137. package/dist/esm/q2-chart-donut.entry.js +1 -1
  138. package/dist/esm/q2-checkbox-group.entry.js +2 -2
  139. package/dist/esm/q2-checkbox-group.entry.js.map +1 -1
  140. package/dist/esm/q2-checkbox.entry.js +1 -1
  141. package/dist/esm/q2-data-table.entry.js +55 -13
  142. package/dist/esm/q2-data-table.entry.js.map +1 -1
  143. package/dist/esm/q2-dropdown-item.entry.js +1 -1
  144. package/dist/esm/q2-dropdown.entry.js +1 -1
  145. package/dist/esm/q2-editable-field.entry.js +1 -1
  146. package/dist/esm/q2-icon.entry.js +1 -1
  147. package/dist/esm/q2-input.entry.js +5 -5
  148. package/dist/esm/q2-input.entry.js.map +1 -1
  149. package/dist/esm/q2-loc.entry.js +1 -1
  150. package/dist/esm/q2-message.entry.js +1 -1
  151. package/dist/esm/q2-month-picker.entry.js +1 -1
  152. package/dist/esm/q2-optgroup_2.entry.js +2 -2
  153. package/dist/esm/q2-optgroup_2.entry.js.map +1 -1
  154. package/dist/esm/q2-option-list.entry.js +7 -6
  155. package/dist/esm/q2-option-list.entry.js.map +1 -1
  156. package/dist/esm/q2-pagination.entry.js +1 -1
  157. package/dist/esm/q2-pill.entry.js +8 -8
  158. package/dist/esm/q2-pill.entry.js.map +1 -1
  159. package/dist/esm/q2-radio-group.entry.js +2 -2
  160. package/dist/esm/q2-radio-group.entry.js.map +1 -1
  161. package/dist/esm/q2-radio.entry.js +1 -1
  162. package/dist/esm/q2-section.entry.js +1 -1
  163. package/dist/esm/q2-select.entry.js +7 -4
  164. package/dist/esm/q2-select.entry.js.map +1 -1
  165. package/dist/esm/q2-stepper-pane.entry.js +1 -1
  166. package/dist/esm/q2-stepper-vertical.entry.js +1 -1
  167. package/dist/esm/q2-stepper.entry.js +1 -1
  168. package/dist/esm/q2-tab-container.entry.js +1 -1
  169. package/dist/esm/q2-tag.entry.js +4 -4
  170. package/dist/esm/q2-tag.entry.js.map +1 -1
  171. package/dist/esm/q2-tecton-elements.js +1 -1
  172. package/dist/esm/q2-textarea.entry.js +1 -1
  173. package/dist/esm/q2-tooltip.entry.js +2 -2
  174. package/dist/esm/q2-tooltip.entry.js.map +1 -1
  175. package/dist/q2-tecton-elements/{p-6f421ccd.entry.js → p-073df9e2.entry.js} +2 -2
  176. package/dist/q2-tecton-elements/{p-6f421ccd.entry.js.map → p-073df9e2.entry.js.map} +1 -1
  177. package/dist/q2-tecton-elements/{p-e053b479.entry.js → p-0c1b74e9.entry.js} +2 -2
  178. package/dist/q2-tecton-elements/p-215d5ab4.entry.js +2 -0
  179. package/dist/q2-tecton-elements/p-215d5ab4.entry.js.map +1 -0
  180. package/dist/q2-tecton-elements/{p-3ee95a8d.entry.js → p-2325975a.entry.js} +2 -2
  181. package/dist/q2-tecton-elements/{p-ef3a5fab.entry.js → p-2987498c.entry.js} +2 -2
  182. package/dist/q2-tecton-elements/{p-61ab4d37.entry.js → p-2b91b34e.entry.js} +2 -2
  183. package/dist/q2-tecton-elements/p-2bf5a3bc.entry.js +2 -0
  184. package/dist/q2-tecton-elements/p-2bf5a3bc.entry.js.map +1 -0
  185. package/dist/q2-tecton-elements/p-3c0d391b.entry.js +2 -0
  186. package/dist/q2-tecton-elements/p-3c0d391b.entry.js.map +1 -0
  187. package/dist/q2-tecton-elements/{p-c14bac96.entry.js → p-3fd4f83d.entry.js} +2 -2
  188. package/dist/q2-tecton-elements/p-4fb81d03.entry.js +2 -0
  189. package/dist/q2-tecton-elements/p-4fb81d03.entry.js.map +1 -0
  190. package/dist/q2-tecton-elements/p-55deaceb.entry.js +2 -0
  191. package/dist/q2-tecton-elements/p-55deaceb.entry.js.map +1 -0
  192. package/dist/q2-tecton-elements/{p-5b43fa8f.entry.js → p-57838409.entry.js} +2 -2
  193. package/dist/q2-tecton-elements/{p-07a0c5c5.entry.js → p-586c8654.entry.js} +2 -2
  194. package/dist/q2-tecton-elements/p-654987bf.entry.js +2 -0
  195. package/dist/q2-tecton-elements/p-654987bf.entry.js.map +1 -0
  196. package/dist/q2-tecton-elements/{p-6d411b0b.entry.js → p-68371e6d.entry.js} +2 -2
  197. package/dist/q2-tecton-elements/{p-ab63346c.entry.js → p-6cc730db.entry.js} +2 -2
  198. package/dist/q2-tecton-elements/{p-ddd6f1d0.entry.js → p-70a59bf1.entry.js} +2 -2
  199. package/dist/q2-tecton-elements/p-788adb51.js +2 -0
  200. package/dist/q2-tecton-elements/p-788adb51.js.map +1 -0
  201. package/dist/q2-tecton-elements/{p-e0a066fb.entry.js → p-7a6e33d4.entry.js} +2 -2
  202. package/dist/q2-tecton-elements/{p-5e65c5ca.entry.js → p-82bda2ff.entry.js} +2 -2
  203. package/dist/q2-tecton-elements/{p-22ab9b66.entry.js → p-8c6f8d06.entry.js} +2 -2
  204. package/dist/q2-tecton-elements/{p-032591c6.entry.js → p-8e8a40ca.entry.js} +2 -2
  205. package/dist/q2-tecton-elements/{p-065b910b.js → p-99ab3236.js} +2 -2
  206. package/dist/q2-tecton-elements/p-99ab3236.js.map +1 -0
  207. package/dist/q2-tecton-elements/p-a2d5cda5.entry.js +2 -0
  208. package/dist/q2-tecton-elements/{p-3a35c930.entry.js.map → p-a2d5cda5.entry.js.map} +1 -1
  209. package/dist/q2-tecton-elements/p-ae2fa966.entry.js +2 -0
  210. package/dist/q2-tecton-elements/p-ae2fa966.entry.js.map +1 -0
  211. package/dist/q2-tecton-elements/{p-d57341f4.entry.js → p-b73e7870.entry.js} +2 -2
  212. package/dist/q2-tecton-elements/{p-45399983.entry.js → p-b8d1c16f.entry.js} +2 -2
  213. package/dist/q2-tecton-elements/{p-d33822bb.entry.js → p-c9f32e51.entry.js} +2 -2
  214. package/dist/q2-tecton-elements/{p-dbf471fd.entry.js → p-ce27270b.entry.js} +2 -2
  215. package/dist/q2-tecton-elements/{p-04bf9c63.entry.js → p-cfbd2cb1.entry.js} +2 -2
  216. package/dist/q2-tecton-elements/{p-04bf9c63.entry.js.map → p-cfbd2cb1.entry.js.map} +1 -1
  217. package/dist/q2-tecton-elements/{p-a2995834.entry.js → p-d3827468.entry.js} +2 -2
  218. package/dist/q2-tecton-elements/p-d4da72f0.entry.js +2 -0
  219. package/dist/q2-tecton-elements/p-d4da72f0.entry.js.map +1 -0
  220. package/dist/q2-tecton-elements/{p-d9e6bd63.entry.js → p-deb1e1c8.entry.js} +2 -2
  221. package/dist/q2-tecton-elements/{p-b9a04695.entry.js → p-e5a8f7ff.entry.js} +2 -2
  222. package/dist/q2-tecton-elements/{p-a00d7c46.entry.js → p-ece07c0d.entry.js} +2 -2
  223. package/dist/q2-tecton-elements/{p-c299667d.entry.js → p-f11326c2.entry.js} +2 -2
  224. package/dist/q2-tecton-elements/p-f11326c2.entry.js.map +1 -0
  225. package/dist/q2-tecton-elements/{p-fa584c00.entry.js → p-f637136f.entry.js} +2 -2
  226. package/dist/q2-tecton-elements/{p-a7b64d05.entry.js → p-f6be73b7.entry.js} +2 -2
  227. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js +1 -1
  228. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js.map +1 -1
  229. package/dist/test/elements/q2-btn-test.e2e.js +24 -16
  230. package/dist/test/elements/q2-btn-test.e2e.js.map +1 -1
  231. package/dist/test/elements/q2-calendar/helpers-test.e2e.js +28 -1
  232. package/dist/test/elements/q2-calendar/helpers-test.e2e.js.map +1 -1
  233. package/dist/test/elements/q2-calendar-test.e2e.js +210 -69
  234. package/dist/test/elements/q2-calendar-test.e2e.js.map +1 -1
  235. package/dist/test/elements/q2-data-table-test.e2e.js +232 -3
  236. package/dist/test/elements/q2-data-table-test.e2e.js.map +1 -1
  237. package/dist/test/elements/q2-input-test.e2e.js +55 -36
  238. package/dist/test/elements/q2-input-test.e2e.js.map +1 -1
  239. package/dist/test/elements/q2-option-list-test.e2e.js +9 -9
  240. package/dist/test/elements/q2-option-list-test.e2e.js.map +1 -1
  241. package/dist/test/elements/q2-pill-test.e2e.js +68 -30
  242. package/dist/test/elements/q2-pill-test.e2e.js.map +1 -1
  243. package/dist/test/elements/q2-select-test.e2e.js +54 -18
  244. package/dist/test/elements/q2-select-test.e2e.js.map +1 -1
  245. package/dist/test/elements/q2-tag-test.e2e.js +55 -16
  246. package/dist/test/elements/q2-tag-test.e2e.js.map +1 -1
  247. package/dist/types/components/q2-btn/index.d.ts +2 -0
  248. package/dist/types/components/q2-calendar/helpers.d.ts +1 -0
  249. package/dist/types/components/q2-calendar/index.d.ts +4 -2
  250. package/dist/types/components/q2-data-table/index.d.ts +11 -1
  251. package/dist/types/components/q2-option-list/index.d.ts +4 -5
  252. package/dist/types/components/q2-select/index.d.ts +1 -1
  253. package/dist/types/components.d.ts +15 -10
  254. package/package.json +7 -7
  255. package/dist/cjs/action-sheet-4b366e9a.js.map +0 -1
  256. package/dist/cjs/index-d42bed64.js.map +0 -1
  257. package/dist/esm/action-sheet-a9597b32.js.map +0 -1
  258. package/dist/esm/index-a8589748.js.map +0 -1
  259. package/dist/q2-tecton-elements/p-065b910b.js.map +0 -1
  260. package/dist/q2-tecton-elements/p-1a0969ff.entry.js +0 -2
  261. package/dist/q2-tecton-elements/p-1a0969ff.entry.js.map +0 -1
  262. package/dist/q2-tecton-elements/p-38b6fb76.entry.js +0 -2
  263. package/dist/q2-tecton-elements/p-38b6fb76.entry.js.map +0 -1
  264. package/dist/q2-tecton-elements/p-3a35c930.entry.js +0 -2
  265. package/dist/q2-tecton-elements/p-a1926e65.js +0 -2
  266. package/dist/q2-tecton-elements/p-a1926e65.js.map +0 -1
  267. package/dist/q2-tecton-elements/p-a913651d.entry.js +0 -2
  268. package/dist/q2-tecton-elements/p-a913651d.entry.js.map +0 -1
  269. package/dist/q2-tecton-elements/p-b177f530.entry.js +0 -2
  270. package/dist/q2-tecton-elements/p-b177f530.entry.js.map +0 -1
  271. package/dist/q2-tecton-elements/p-b9478703.entry.js +0 -2
  272. package/dist/q2-tecton-elements/p-b9478703.entry.js.map +0 -1
  273. package/dist/q2-tecton-elements/p-c299667d.entry.js.map +0 -1
  274. package/dist/q2-tecton-elements/p-dce9e778.entry.js +0 -2
  275. package/dist/q2-tecton-elements/p-dce9e778.entry.js.map +0 -1
  276. package/dist/q2-tecton-elements/p-e50113ee.entry.js +0 -2
  277. package/dist/q2-tecton-elements/p-e50113ee.entry.js.map +0 -1
  278. package/dist/q2-tecton-elements/p-fdf8abed.entry.js +0 -2
  279. package/dist/q2-tecton-elements/p-fdf8abed.entry.js.map +0 -1
  280. /package/dist/q2-tecton-elements/{p-e053b479.entry.js.map → p-0c1b74e9.entry.js.map} +0 -0
  281. /package/dist/q2-tecton-elements/{p-3ee95a8d.entry.js.map → p-2325975a.entry.js.map} +0 -0
  282. /package/dist/q2-tecton-elements/{p-ef3a5fab.entry.js.map → p-2987498c.entry.js.map} +0 -0
  283. /package/dist/q2-tecton-elements/{p-61ab4d37.entry.js.map → p-2b91b34e.entry.js.map} +0 -0
  284. /package/dist/q2-tecton-elements/{p-c14bac96.entry.js.map → p-3fd4f83d.entry.js.map} +0 -0
  285. /package/dist/q2-tecton-elements/{p-5b43fa8f.entry.js.map → p-57838409.entry.js.map} +0 -0
  286. /package/dist/q2-tecton-elements/{p-07a0c5c5.entry.js.map → p-586c8654.entry.js.map} +0 -0
  287. /package/dist/q2-tecton-elements/{p-6d411b0b.entry.js.map → p-68371e6d.entry.js.map} +0 -0
  288. /package/dist/q2-tecton-elements/{p-ab63346c.entry.js.map → p-6cc730db.entry.js.map} +0 -0
  289. /package/dist/q2-tecton-elements/{p-ddd6f1d0.entry.js.map → p-70a59bf1.entry.js.map} +0 -0
  290. /package/dist/q2-tecton-elements/{p-e0a066fb.entry.js.map → p-7a6e33d4.entry.js.map} +0 -0
  291. /package/dist/q2-tecton-elements/{p-5e65c5ca.entry.js.map → p-82bda2ff.entry.js.map} +0 -0
  292. /package/dist/q2-tecton-elements/{p-22ab9b66.entry.js.map → p-8c6f8d06.entry.js.map} +0 -0
  293. /package/dist/q2-tecton-elements/{p-032591c6.entry.js.map → p-8e8a40ca.entry.js.map} +0 -0
  294. /package/dist/q2-tecton-elements/{p-d57341f4.entry.js.map → p-b73e7870.entry.js.map} +0 -0
  295. /package/dist/q2-tecton-elements/{p-45399983.entry.js.map → p-b8d1c16f.entry.js.map} +0 -0
  296. /package/dist/q2-tecton-elements/{p-d33822bb.entry.js.map → p-c9f32e51.entry.js.map} +0 -0
  297. /package/dist/q2-tecton-elements/{p-dbf471fd.entry.js.map → p-ce27270b.entry.js.map} +0 -0
  298. /package/dist/q2-tecton-elements/{p-a2995834.entry.js.map → p-d3827468.entry.js.map} +0 -0
  299. /package/dist/q2-tecton-elements/{p-d9e6bd63.entry.js.map → p-deb1e1c8.entry.js.map} +0 -0
  300. /package/dist/q2-tecton-elements/{p-b9a04695.entry.js.map → p-e5a8f7ff.entry.js.map} +0 -0
  301. /package/dist/q2-tecton-elements/{p-a00d7c46.entry.js.map → p-ece07c0d.entry.js.map} +0 -0
  302. /package/dist/q2-tecton-elements/{p-fa584c00.entry.js.map → p-f637136f.entry.js.map} +0 -0
  303. /package/dist/q2-tecton-elements/{p-a7b64d05.entry.js.map → p-f6be73b7.entry.js.map} +0 -0
  304. /package/dist/types/workspace/workspace/{_Gitlab_tecton-production_master → tecton-production_release_1.35.x}/packages/q2-tecton-elements/.stencil/test/helpers.d.ts +0 -0
@@ -1 +1 @@
1
- {"file":"q2-btn.q2-loading.entry.js","mappings":"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","names":["stylesCss","skeletonShapes"],"sources":["./src/components/q2-btn/styles.scss?tag=q2-btn&encapsulation=shadow","./src/components/q2-btn/index.tsx","./src/components/q2-loading/styles.scss?tag=q2-loading&encapsulation=shadow","./src/components/q2-loading/index.tsx"],"sourcesContent":["@import '../../styles/host.scss';\n@import '../../styles/functions';\n@import './mixins';\n\n:host {\n display: inline-block;\n}\n\n:host([hidden]) {\n display: none;\n}\n\n:host([block]) {\n display: block;\n width: 100%;\n}\n\n::slotted(q2-icon) {\n pointer-events: none;\n}\n\n:host {\n --comp-font-weight: 600;\n --comp-border-radius: #{var-list(--tct-btn-border-radius, --app-border-radius-1, 3px)};\n --comp-btn-tween: #{var-list(var-prefixer(btn-tween), --tct-tween-1, --app-tween-1, unquote('0.2s ease'))};\n --comp-btn-fallback-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24);\n --comp-background-alternative: #ebf8ff;\n .btn-height-wrapper {\n height: var(--comp-btn-min-height, 44px);\n cursor: pointer;\n &:active {\n box-shadow: none;\n }\n }\n}\n\nbutton {\n margin: var-list(--tct-scale-0, --app-scale-0x, 0);\n padding: var-list(--tct-scale-0, --app-scale-0x, 0);\n display: inline-block;\n width: 100%;\n hyphens: auto;\n border: var(--tct-btn-border);\n border-radius: var(--tct-btn-border-radius);\n background: transparent;\n box-shadow: none;\n border-radius: 0;\n font-weight: 400;\n color: inherit;\n cursor: pointer;\n transition: var(--comp-btn-tween);\n transition-property: background, color, box-shadow, fill, border-color, border-width;\n outline: 0;\n &:disabled {\n opacity: var-list(var-prefixer(btn-disabled-opacity), --tct-disabled-opacity, --app-disabled-opacity, 0.4);\n cursor: not-allowed;\n }\n\n // Sizes\n :host([size='1']) & {\n padding: var-list(--tct-scale-1, --app-scale-1x, 5px);\n }\n :host([color]:not([size])) &,\n :host([intent]:not([size])) & {\n padding: var-list(var-prefixer(btn-padding), --tct-scale-2, --app-scale-2x, 10px);\n }\n :host([size='2']) & {\n padding: var-list(--tct-scale-2, --app-scale-2x, 10px);\n }\n :host([size='3']) & {\n padding: var-list(--tct-scale-3, --app-scale-3x, 15px);\n }\n :host([size='4x']) & {\n padding: var-list(--tct-scale-4x, --app-scale-4x, 20px);\n }\n :host([size='4']) & {\n padding: var-list(--tct-scale-6x, --app-scale-6x, 30px);\n }\n\n :host([size='small']) & {\n padding: var-list(var-prefixer(btn-padding-size-small), '4px 16px');\n font-size: var-list(var-prefixer(btn-font-size-small), 12px);\n }\n :host([size='medium']) & {\n padding: var-list(var-prefixer(btn-padding-size-medium), '12px 24px');\n font-size: var-list(var-prefixer(btn-font-size-small), 16px);\n }\n :host([size='large']) & {\n padding: var-list(var-prefixer(btn-padding-size-large), '16px 32px');\n font-size: var-list(var-prefixer(btn-font-size-small), 32px);\n }\n\n // Colors\n :host([color]) &,\n :host([intent]) & {\n font-size: var-list(var-prefixer(btn-font-size), inherit);\n }\n\n :host([color='primary']) &,\n :host([intent='workflow-primary']) & {\n --comp-background: #{var-list(--tct-btn-primary-background, --tct-btn-primary-bg)};\n --comp-hover-background: #{var-list(--tct-btn-primary-hover-background, --tct-btn-primary-hover-bg)};\n --comp-color: #{var-list(--tct-btn-primary-font-color, --app-white, #ffffff)};\n --comp-box-shadow: #{var-list(--tct-btn-primary-box-shadow, --comp-btn-fallback-box-shadow)};\n --comp-focus-box-shadow: #{var-list(--tct-btn-primary-focus-box-shadow, --comp-btn-fallback-box-shadow)};\n // different background for active\n --comp-active-background: var(--tct-btn-primary-active-background, #0063a0);\n @include btn-ring(primary, hover, --comp-background, --comp-color, null);\n @include btn-ring(primary, active, transparent, transparent, --comp-box-shadow);\n @include btn-ring(primary, focus-visible, --const-focus-color, --comp-color, null);\n @include btn-intent(primary);\n @include btn-icon-color(primary, --comp-color);\n }\n\n :host([color='secondary']) &,\n :host([intent='workflow-secondary']) & {\n --comp-background: #{var-list(\n --tct-btn-secondary-background,\n --tct-btn-secondary-bg,\n --t-button-default-bg,\n #cccccc\n )};\n --comp-hover-background: #{var-list(--tct-btn-secondary-hover-background, --tct-btn-secondary-hover-bg)};\n --comp-color: var(--tct-btn-secondary-font-color);\n --comp-box-shadow: #{var-list(--tct-btn-secondary-box-shadow, --comp-btn-fallback-box-shadow)};\n --comp-focus-box-shadow: #{var-list(--tct-btn-secondary-focus-box-shadow, --comp-btn-fallback-box-shadow)};\n @include btn-ring(secondary, hover, --comp-color, --app-white, null);\n @include btn-ring(secondary, active, transparent, transparent, --comp-box-shadow);\n @include btn-ring(secondary, focus-visible, --const-focus-color, --app-white, null);\n @include btn-intent(secondary);\n @include btn-icon-color(secondary, --comp-color);\n }\n\n :host([intent='workflow-destroy']) & {\n --comp-background: #{var-list(--tct-btn-destroy-background, --const-stoplight-alert, #c30000)};\n --comp-color: #{var-list(--tct-btn-destroy-font-color, --app-white)};\n --comp-box-shadow: #{var-list(--tct-btn-destroy-box-shadow, --comp-btn-fallback-box-shadow)};\n --comp-focus-box-shadow: #{var-list(--tct-btn-destroy-focus-box-shadow, --comp-btn-fallback-box-shadow)};\n @include btn-ring(destroy, hover, --comp-background, --comp-color, null);\n @include btn-ring(destroy, active, transparent, transparent, --comp-box-shadow);\n @include btn-ring(destroy, focus-visible, --const-focus-color, --comp-color, null);\n @include btn-intent(destroy);\n @include btn-icon-color(destroy, --comp-color);\n }\n\n :host([intent='workflow-escape']) & {\n --comp-background: #{var-list(--tct-btn-escape-background, --app-white, #ffffff)};\n --comp-color: #{var-list(--tct-btn-escape-font-color, --tct-btn-primary-background, --tct-btn-primary-bg)};\n --comp-box-shadow: #{var-list(--tct-btn-escape-box-shadow, --comp-btn-fallback-box-shadow)};\n --comp-hover-box-shadow: #{var-list(--tct-btn-escape-hover-box-shadow, --comp-btn-fallback-box-shadow)};\n --comp-focus-box-shadow: #{var-list(--tct-btn-escape-focus-box-shadow, --comp-btn-fallback-box-shadow)};\n // different background for hover/active/focus\n --comp-hover-background: #{var-list(--tct-btn-escape-hover-background, --comp-background-alternative)};\n --comp-active-background: #{var-list(--tct-btn-escape-active-background, --comp-background-alternative)};\n --comp-focus-background: #{var-list(--tct-btn-escape-focus-background, --comp-background-alternative)};\n @include btn-ring(escape, hover, --comp-color, --comp-background, null);\n @include btn-ring(escape, active, transparent, transparent, --comp-box-shadow);\n @include btn-ring(escape, focus-visible, --const-focus-color, --comp-background, null);\n @include btn-intent(escape);\n @include btn-icon-color(escape, --comp-color);\n }\n\n :host([intent='neutral']) & {\n --comp-background: #{var-list(--tct-btn-neutral-background, --app-white, #ffffff)};\n --comp-color: #{var-list(--tct-btn-neutral-font-color, --tct-btn-primary-background, --tct-btn-primary-bg)};\n --comp-box-shadow: #{var-list(--tct-btn-neutral-box-shadow, --comp-btn-fallback-box-shadow)};\n --comp-focus-box-shadow: #{var-list(--tct-btn-neutral-focus-box-shadow, --comp-btn-fallback-box-shadow)};\n // use outline instead border: because on/off border makes the button shaking on hover/focus/active\n --comp-border-width: 1px;\n --comp-border-style: solid;\n --comp-border-color: var(--comp-color);\n @include btn-ring(neutral, hover, --comp-color, --app-white, null);\n @include btn-ring(neutral, active, transparent, transparent, --comp-box-shadow);\n @include btn-ring(neutral, focus-visible, --const-focus-color, --comp-background, null);\n @include btn-intent(neutral);\n @include btn-icon-color(neutral, --comp-color);\n }\n\n :host([intent='neutral-text']) & {\n --comp-background: #{var-list(\n --tct-btn-neutral-text-background,\n --tct-btn-neutral-text-bg,\n --app-white,\n #ffffff\n )};\n --comp-color: #{var-list(--tct-btn-neutral-text-font-color, --tct-btn-primary-background, --tct-btn-primary-bg)};\n --comp-box-shadow: var(--tct-btn-neutral-text-box-shadow);\n --comp-hover-text-decoration: underline;\n // different background for focus\n --comp-focus-background: #{var-list(--tct-btn-neutral-text-focus-background, --comp-background-alternative)};\n @include btn-ring(neutral-text, hover, --comp-color, --comp-background, null);\n @include btn-ring(neutral-text, active, transparent, transparent, --comp-box-shadow);\n @include btn-ring(neutral-text, focus-visible, --const-focus-color, --app-white, null);\n @include btn-intent(neutral-text);\n @include btn-icon-color(neutral-text, --comp-color);\n }\n\n // different background for loading\n :host([color='primary'][loading]) &,\n :host([intent='workflow-primary'][loading]) & {\n --comp-background: var(--tct-btn-primary-loading-background, #0063a0);\n }\n\n :host([intent='workflow-escape'][loading]) & {\n --comp-background: #{var-list(--tct-btn-escape-loading-background, --comp-background-alternative)};\n }\n\n // Icons\n :host &.icon-only {\n width: var-list(var-prefixer(btn-icon-width), 44px);\n height: var-list(var-prefixer(btn-icon-height), 44px);\n border-radius: var-list(var-prefixer(btn-icon-border-radius), --tct-btn-border-radius, 0);\n\n &:hover,\n &:focus {\n background-color: var-list(\n --tct-btn-icon-hover-background,\n var-prefixer(btn-icon-hover-bg),\n var-prefixer(gray-13),\n --tct-gray-l3,\n --app-gray-l3,\n #f2f2f2\n );\n }\n }\n\n :host(:not([intent])[active]) &.icon-only {\n background-color: var-list(\n --tct-btn-icon-active-background,\n var-prefixer(btn-icon-active-bg),\n var-prefixer(gray-14),\n --tct-gray-l3,\n --app-gray-l3,\n #f2f2f2\n );\n }\n\n :host(:not([intent])) &.icon-only:hover *,\n :host(:not([intent])) &.icon-only:focus *,\n :host(:not([intent])[active]) &.icon-only * {\n color: var-list(var-prefixer(btn-icon-hover-color), var-prefixer(link-hover-color), #080808);\n }\n\n // Badges\n :host([badge]) & {\n padding: var-list(var-prefixer(btn-badge-padding), unquote('2px 5px'));\n font-size: var-list(var-prefixer(btn-badge-font-size), var-prefixer(btn-font-size), inherit);\n border-radius: var-list(\n var-prefixer(btn-badge-border-radius),\n --tct-border-radius-1,\n --app-border-radius-1,\n 3px\n );\n background-color: var-list(--tct-btn-badge-background, var-prefixer(btn-badge-bg), transparent);\n color: var-list(var-prefixer(btn-badge-font-color), inherit);\n\n ::slotted(q2-icon) {\n --tct-icon-size: 1em;\n }\n }\n\n :host([badge]:hover) &:enabled {\n background-color: var-list(\n --tct-btn-badge-hover-background,\n var-prefixer(btn-badge-hover-bg),\n var-prefixer(gray-14),\n --tct-gray-l3,\n --app-gray-l3,\n #f2f2f2\n );\n color: var-list(\n var-prefixer(btn-badge-hover-font-color),\n var-prefixer(gray-5),\n --tct-gray-d2,\n --app-gray-d2,\n #404040\n );\n }\n\n :host(.selected[badge]) &,\n :host([active][badge]) & {\n background-color: var-list(\n --tct-btn-badge-active-background,\n var-prefixer(btn-badge-active-bg),\n --comp-btn-primary-background\n );\n color: var-list(var-prefixer(btn-badge-active-font-color), --comp-btn-primary-font-color);\n }\n}\n\ndiv {\n display: flex;\n align-items: center;\n justify-content: center;\n gap: var-list(--app-scale-1x, 5px);\n\n :host([loading]) .icon-right & {\n flex-direction: row-reverse;\n }\n}\n\nq2-loading {\n --tct-loading-primary-color: currentColor;\n --tct-loading-secondary-color: currentColor;\n --tct-loading-spinner-size: 24px;\n}\n\n:host([loading]) ::slotted(q2-icon) {\n display: none;\n}\n:host([loading]) button {\n pointer-events: none;\n}\n\n:host([block]) button,\n:host([block]) button.icon-only {\n display: block;\n width: 100%;\n}\n","import { Component, State, Prop, h, ComponentInterface, Watch, Listen, Element, Fragment } from '@stencil/core';\nimport { handleAriaLabel, handleColor, isEventFromElement, loc, overrideFocus } from 'src/utils';\n\n@Component({\n tag: 'q2-btn',\n shadow: true,\n styleUrl: 'styles.scss',\n})\nexport class Q2Btn implements ComponentInterface {\n @Prop() ariaExpanded: string;\n @Prop() ariaHasPopup: string;\n @Prop() ariaControls: string;\n @Prop() ariaSelected: string;\n @Prop() ariaPressed: string;\n @Prop() description: string;\n @Prop({ reflect: true, mutable: true }) label: string;\n @Prop({ reflect: true, mutable: true }) hideLabel: boolean;\n @Prop() tabIndex: number;\n @Prop({ reflect: true, mutable: true }) intent:\n | 'workflow-primary'\n | 'workflow-secondary'\n | 'workflow-destroy'\n | 'workflow-escape'\n | 'neutral'\n | 'neutral-text';\n @Prop({ reflect: true }) disabled: boolean;\n @Prop({ reflect: true }) type: string;\n @Prop({ reflect: true }) size: string;\n @Prop({ reflect: true }) loading: boolean;\n @Prop({ reflect: true }) badge: boolean;\n @Prop({ reflect: true }) active: boolean;\n @Prop({ reflect: true }) block: boolean;\n\n /** @deprecated */\n @Prop({ reflect: true, mutable: true }) color: string; // deprecated but need it to use utils/handleColor\n\n /** @deprecated */\n @Prop({ reflect: true }) fab: boolean;\n\n /** @deprecated */\n @Prop({ reflect: true, mutable: true }) ariaLabel: string;\n\n @State() iconPosition: 'left' | 'right' | 'only';\n\n @Element() hostElement: HTMLElement;\n\n primaryBtn: HTMLButtonElement;\n primaryBtnWrapper: HTMLElement;\n ////////// LIFECYCLE HOOKS ////////\n\n componentWillLoad() {\n this.handleIcons();\n handleAriaLabel(this);\n handleColor(this);\n }\n\n componentDidLoad(): void {\n overrideFocus(this.hostElement);\n }\n\n @Listen('click', { capture: true })\n disable(ev: Event) {\n if (this.disabled) {\n ev.stopImmediatePropagation();\n }\n this.primaryBtn.focus();\n }\n\n @Listen('focus')\n delegateFocus(event: FocusEvent) {\n if (!isEventFromElement(event, this.hostElement)) return;\n this.primaryBtn.focus();\n }\n\n //////// Method //////////\n\n ////////// OBSERVERS //////////\n\n @Watch('ariaLabel')\n ariaLabelObserver() {\n handleAriaLabel(this);\n }\n\n handleSlotChange = () => {\n this.handleIcons();\n };\n\n handleIcons = () => {\n // Only allow one icon in the button\n const icon = Array.from(this.hostElement.querySelectorAll(':scope > q2-icon')).reduce((acc, element) => {\n if (acc) element.remove();\n else acc = element;\n return acc;\n }, null);\n\n const hasIcon = !!icon;\n const hasLoc = !!this.hostElement.querySelector('q2-loc');\n const hasText = !!this.hostElement.textContent.trim();\n const hasIconLeft = (hasLoc || hasText) && hasIcon && this.hostElement.firstElementChild === icon;\n const hasIconRight = (hasLoc || hasText) && hasIcon && this.hostElement.lastElementChild === icon;\n const hasIconOnly = !hasIconLeft && !hasIconRight && hasIcon;\n\n let iconPosition;\n if (hasIconOnly) iconPosition = 'only';\n else if (hasIconLeft) iconPosition = 'left';\n else if (hasIconRight) iconPosition = 'right';\n this.iconPosition = iconPosition;\n };\n\n renderButton = () => {\n const { ariaExpanded, ariaHasPopup, ariaSelected, ariaPressed, description, disabled, type, tabindex } =\n this.buttonAttributes;\n const { iconPosition, loading, badge, label, hideLabel } = this;\n const renderLoadingSpinner = iconPosition || loading;\n const isLoadingSpinnerInline = !iconPosition || badge;\n return (\n <Fragment>\n <button\n ref={el => (this.primaryBtn = el ?? this.primaryBtn)}\n aria-expanded={ariaExpanded}\n aria-haspopup={ariaHasPopup}\n aria-label={hideLabel && loc(label)}\n aria-selected={ariaSelected}\n aria-pressed={ariaPressed}\n disabled={disabled}\n type={type}\n tabindex={tabindex}\n test-id=\"q2BtnInnerButton\"\n class={iconPosition ? `icon-${iconPosition}` : ''}\n aria-describedby={!!description ? 'hidden-description' : undefined}\n >\n <div>\n {renderLoadingSpinner && (\n <q2-loading\n hidden={!loading}\n modifiers={isLoadingSpinnerInline ? 'inline' : undefined}\n />\n )}\n {!hideLabel && label ? loc(label) : <slot onSlotchange={this.handleSlotChange} />}\n </div>\n </button>\n {!!description && (\n <div\n id=\"hidden-description\"\n aria-hidden=\"true\"\n class=\"sr\"\n >\n {description}\n </div>\n )}\n </Fragment>\n );\n };\n\n render = () => {\n return this.size === 'small' ? (\n // wrap only for small sized\n <div\n class=\"btn-height-wrapper\"\n ref={el => (this.primaryBtnWrapper = el ?? this.primaryBtnWrapper)}\n tabIndex={-1}\n >\n {this.renderButton()}\n </div>\n ) : (\n this.renderButton()\n );\n };\n\n get buttonAttributes() {\n return {\n ariaExpanded: this.ariaExpanded !== undefined ? `${this.ariaExpanded?.toString() === 'true'}` : undefined,\n ariaHasPopup:\n this.ariaHasPopup !== undefined\n ? `${this.ariaHasPopup === 'true' || this.ariaHasPopup === 'menu'}`\n : undefined,\n ariaLabel: this.label && this.hideLabel ? loc(this.label) : undefined,\n ariaSelected: this.ariaSelected !== undefined ? `${this.ariaSelected?.toString() === 'true'}` : undefined,\n ariaPressed: this.ariaPressed !== undefined ? `${this.ariaPressed?.toString() === 'true'}` : undefined,\n description: this.description !== undefined ? this.description : undefined,\n disabled: this.disabled || false,\n type: this.type || 'button',\n tabindex: this.tabIndex || undefined,\n };\n }\n}\n","@import '../../styles/host.scss';\n@import '../../styles/utility.scss';\n@import '../../styles/functions';\n\n:host {\n display: block;\n}\n\n:host([inline]),\n:host([modifiers*='inline']) {\n display: inline-block;\n}\n\n:host([hidden]) {\n display: none;\n}\n\n:host(:not([inline]):not([modifiers*='inline'])) {\n font-size: var-list(var-prefixer(loading-spinner-size), --app-scale-12x, 60px);\n}\n\n.q2-loading-animation {\n height: 1em;\n width: 1em;\n}\n\n@import './spinners/half-circle-spinner.scss';\n@import './skeleton/skeleton.scss';\n","import { Component, Prop, h, ComponentInterface, Element, Watch } from '@stencil/core';\nimport { handleAriaLabel, loc } from 'src/utils';\nimport skeletonShapes from './skeleton/shapes';\n\n@Component({\n tag: 'q2-loading',\n shadow: true,\n styleUrl: 'styles.scss',\n})\nexport class Q2Loading implements ComponentInterface {\n @Element() hostElement: HTMLElement;\n\n @Prop({ reflect: true }) type: 'spinner' | 'skeleton';\n @Prop({ reflect: true }) shape: string;\n @Prop({ reflect: true }) modifiers: string;\n @Prop({ reflect: true }) counts: string;\n @Prop({ reflect: true, mutable: true }) label: string;\n @Prop({ reflect: true }) inline: boolean;\n\n /** @deprecated */\n @Prop({ reflect: true, mutable: true }) ariaLabel: string;\n\n get loader() {\n const loaderMap = {\n default: this.spinner,\n spinner: this.spinner,\n skeleton: this.skeletonLoader,\n };\n\n return loaderMap[this.type] || loaderMap.default;\n }\n\n get modifiersSet(): Set<string> {\n if (this.type !== 'skeleton' || !this.modifiers) {\n return undefined;\n }\n\n return new Set(this.modifiers.split('-'));\n }\n\n get countsArray(): number[] {\n if (this.type !== 'skeleton' || !this.counts) {\n return undefined;\n }\n\n return this.counts.split('x').map(Number);\n }\n\n get skeletonShape() {\n return skeletonShapes[this.shape]?.(this.countsArray, this.modifiersSet) ?? '';\n }\n\n get spinnerShape() {\n const spinnerMap = {\n default: this.halfCircleSpinner,\n 'half-circle': this.halfCircleSpinner,\n };\n\n return spinnerMap[this.type] || spinnerMap.default;\n }\n\n get localizedLabel() {\n return loc(this.label || 'tecton.element.loading.ariaLabel');\n }\n\n componentWillLoad() {\n handleAriaLabel(this);\n }\n\n @Watch('ariaLabel')\n ariaLabelObserver() {\n handleAriaLabel(this);\n }\n\n render() {\n return this.loader();\n }\n\n halfCircleSpinner = () => {\n return (\n <div\n class=\"q2-loading-animation half-circle-spinner\"\n aria-label={this.localizedLabel}\n >\n <div class=\"circle circle-1\"></div>\n <div class=\"circle circle-2\"></div>\n </div>\n );\n };\n\n spinner = () => {\n return this.halfCircleSpinner();\n };\n\n skeletonLoader = () => {\n return (\n <div\n class=\"q2-loading-skeleton\"\n aria-label={this.localizedLabel}\n >\n {this.shape === 'custom' ? <slot /> : this.skeletonShape}\n <div class=\"q2-loading-skeleton-shimmer\"></div>\n </div>\n );\n };\n}\n"],"version":3}
1
+ {"file":"q2-btn.q2-loading.entry.js","mappings":"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","names":["stylesCss","skeletonShapes"],"sources":["./src/components/q2-btn/styles.scss?tag=q2-btn&encapsulation=shadow","./src/components/q2-btn/index.tsx","./src/components/q2-loading/styles.scss?tag=q2-loading&encapsulation=shadow","./src/components/q2-loading/index.tsx"],"sourcesContent":["@import '../../styles/host.scss';\n@import '../../styles/functions';\n@import './mixins';\n\n:host {\n display: inline-block;\n}\n\n:host([hidden]) {\n display: none;\n}\n\n:host([block]) {\n display: block;\n width: 100%;\n}\n\n::slotted(q2-icon) {\n pointer-events: none;\n}\n\n:host {\n --comp-font-weight: 600;\n --comp-border-radius: #{var-list(--tct-btn-border-radius, --app-border-radius-1, 3px)};\n --comp-btn-tween: #{var-list(var-prefixer(btn-tween), --tct-tween-1, --app-tween-1, unquote('0.2s ease'))};\n --comp-btn-fallback-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24);\n --comp-background-alternative: #ebf8ff;\n .btn-height-wrapper {\n height: var(--comp-btn-min-height, 44px);\n cursor: pointer;\n &:active {\n box-shadow: none;\n }\n }\n}\n\nbutton {\n margin: var-list(--tct-scale-0, --app-scale-0x, 0);\n padding: var-list(--tct-scale-0, --app-scale-0x, 0);\n display: inline-block;\n width: 100%;\n hyphens: auto;\n border: var(--tct-btn-border);\n border-radius: var(--tct-btn-border-radius);\n background: transparent;\n box-shadow: none;\n border-radius: 0;\n font-weight: 400;\n color: inherit;\n cursor: pointer;\n transition: var(--comp-btn-tween);\n transition-property: background, color, box-shadow, fill, border-color, border-width;\n outline: 0;\n &:disabled {\n opacity: var-list(var-prefixer(btn-disabled-opacity), --tct-disabled-opacity, --app-disabled-opacity, 0.4);\n cursor: not-allowed;\n }\n\n // Sizes\n :host([size='1']) & {\n padding: var-list(--tct-scale-1, --app-scale-1x, 5px);\n }\n :host([color]:not([size])) &,\n :host([intent]:not([size])) & {\n padding: var-list(var-prefixer(btn-padding), --tct-scale-2, --app-scale-2x, 10px);\n }\n :host([size='2']) & {\n padding: var-list(--tct-scale-2, --app-scale-2x, 10px);\n }\n :host([size='3']) & {\n padding: var-list(--tct-scale-3, --app-scale-3x, 15px);\n }\n :host([size='4x']) & {\n padding: var-list(--tct-scale-4x, --app-scale-4x, 20px);\n }\n :host([size='4']) & {\n padding: var-list(--tct-scale-6x, --app-scale-6x, 30px);\n }\n\n :host([size='small']) & {\n padding: var-list(var-prefixer(btn-padding-size-small), '4px 16px');\n font-size: var-list(var-prefixer(btn-font-size-small), 12px);\n }\n :host([size='medium']) & {\n padding: var-list(var-prefixer(btn-padding-size-medium), '12px 24px');\n font-size: var-list(var-prefixer(btn-font-size-small), 16px);\n }\n :host([size='large']) & {\n padding: var-list(var-prefixer(btn-padding-size-large), '16px 32px');\n font-size: var-list(var-prefixer(btn-font-size-small), 32px);\n }\n\n // Colors\n :host([color]) &,\n :host([intent]) & {\n font-size: var-list(var-prefixer(btn-font-size), inherit);\n }\n\n :host([color='primary']) &,\n :host([intent='workflow-primary']) & {\n --comp-background: #{var-list(\n --tct-btn-primary-background,\n --tct-btn-primary-bg,\n --t-a11y-active-gray-color-AA,\n #404040\n )};\n --comp-hover-background: #{var-list(--tct-btn-primary-hover-background, --tct-btn-primary-hover-bg)};\n --comp-font-color: #{var-list(--tct-btn-primary-font-color, --app-white, #ffffff)};\n --comp-box-shadow: #{var-list(--tct-btn-primary-box-shadow, --comp-btn-fallback-box-shadow)};\n --comp-focus-box-shadow: #{var-list(--tct-btn-primary-focus-box-shadow, --comp-btn-fallback-box-shadow)};\n // different background for active\n --comp-active-background: var(--tct-btn-primary-active-background, #0063a0);\n @include btn-ring(primary, hover, --comp-background, --comp-font-color, null);\n @include btn-ring(primary, active, transparent, transparent, --comp-box-shadow);\n @include btn-ring(primary, focus-visible, --const-focus-color, --comp-font-color, null);\n @include btn-intent(primary);\n @include btn-icon-color(primary, --comp-font-color);\n }\n\n :host([color='secondary']) &,\n :host([intent='workflow-secondary']) & {\n --comp-background: #{var-list(\n --tct-btn-secondary-background,\n --tct-btn-secondary-bg,\n --t-button-default-bg,\n #cccccc\n )};\n --comp-hover-background: #{var-list(\n --tct-btn-secondary-hover-background,\n --tct-btn-secondary-hover-bg,\n --t-a11y-active-gray-color-AA,\n #404040\n )};\n --comp-hover-font-color: var(--app-white, #ffffff);\n --comp-box-shadow: #{var-list(--tct-btn-secondary-box-shadow, --comp-btn-fallback-box-shadow)};\n --comp-focus-box-shadow: #{var-list(--tct-btn-secondary-focus-box-shadow, --comp-btn-fallback-box-shadow)};\n @include btn-ring(secondary, hover, --comp-hover-background, --app-white, null);\n @include btn-ring(secondary, active, transparent, transparent, --comp-box-shadow);\n @include btn-ring(secondary, focus-visible, --const-focus-color, --app-white, null);\n @include btn-intent(secondary);\n @include btn-icon-color(secondary, --comp-font-color);\n }\n\n :host([intent='workflow-destroy']) & {\n --comp-background: #{var-list(--tct-btn-destroy-background, --const-stoplight-alert, #c30000)};\n --comp-font-color: #{var-list(--tct-btn-destroy-font-color, --app-white)};\n --comp-box-shadow: #{var-list(--tct-btn-destroy-box-shadow, --comp-btn-fallback-box-shadow)};\n --comp-focus-box-shadow: #{var-list(--tct-btn-destroy-focus-box-shadow, --comp-btn-fallback-box-shadow)};\n @include btn-ring(destroy, hover, --comp-background, --comp-font-color, null);\n @include btn-ring(destroy, active, transparent, transparent, --comp-box-shadow);\n @include btn-ring(destroy, focus-visible, --const-focus-color, --comp-font-color, null);\n @include btn-intent(destroy);\n @include btn-icon-color(destroy, --comp-font-color);\n }\n\n :host([intent='workflow-escape']) & {\n --comp-background: #{var-list(--tct-btn-escape-background, --app-white, #ffffff)};\n --comp-font-color: #{var-list(\n --tct-btn-escape-font-color,\n --tct-btn-primary-background,\n --tct-btn-primary-bg,\n --t-a11y-active-gray-color-AA,\n #404040\n )};\n --comp-box-shadow: #{var-list(--tct-btn-escape-box-shadow, --comp-btn-fallback-box-shadow)};\n --comp-hover-box-shadow: #{var-list(--tct-btn-escape-hover-box-shadow, --comp-btn-fallback-box-shadow)};\n --comp-focus-box-shadow: #{var-list(--tct-btn-escape-focus-box-shadow, --comp-btn-fallback-box-shadow)};\n // different background for hover/active/focus\n --comp-hover-background: #{var-list(--tct-btn-escape-hover-background, --comp-background-alternative)};\n --comp-active-background: #{var-list(--tct-btn-escape-active-background, --comp-background-alternative)};\n --comp-focus-background: #{var-list(--tct-btn-escape-focus-background, --comp-background-alternative)};\n @include btn-ring(escape, hover, --comp-font-color, --comp-background, null);\n @include btn-ring(escape, active, transparent, transparent, --comp-box-shadow);\n @include btn-ring(escape, focus-visible, --const-focus-color, --comp-background, null);\n @include btn-intent(escape);\n @include btn-icon-color(escape, --comp-font-color);\n }\n\n :host([intent='neutral']) & {\n --comp-background: #{var-list(--tct-btn-neutral-background, --app-white, #ffffff)};\n --comp-font-color: #{var-list(\n --tct-btn-neutral-font-color,\n --tct-btn-primary-background,\n --tct-btn-primary-bg,\n --t-a11y-active-gray-color-AA,\n #404040\n )};\n --comp-box-shadow: #{var-list(--tct-btn-neutral-box-shadow, --comp-btn-fallback-box-shadow)};\n --comp-focus-box-shadow: #{var-list(--tct-btn-neutral-focus-box-shadow, --comp-btn-fallback-box-shadow)};\n // use outline instead border: because on/off border makes the button shaking on hover/focus/active\n --comp-border-width: 1px;\n --comp-border-style: solid;\n --comp-border-color: var(--comp-font-color);\n @include btn-ring(neutral, hover, --comp-font-color, --app-white, null);\n @include btn-ring(neutral, active, transparent, transparent, --comp-box-shadow);\n @include btn-ring(neutral, focus-visible, --const-focus-color, --comp-background, null);\n @include btn-intent(neutral);\n @include btn-icon-color(neutral, --comp-font-color);\n }\n\n :host([intent='neutral-text']) & {\n --comp-background: #{var-list(\n --tct-btn-neutral-text-background,\n --tct-btn-neutral-text-bg,\n --app-white,\n #ffffff\n )};\n --comp-font-color: #{var-list(\n --tct-btn-neutral-text-font-color,\n --tct-btn-primary-background,\n --tct-btn-primary-bg,\n --t-a11y-active-gray-color-AA,\n #404040\n )};\n --comp-box-shadow: var(--tct-btn-neutral-text-box-shadow);\n --comp-hover-text-decoration: underline;\n // different background for focus\n --comp-focus-background: #{var-list(--tct-btn-neutral-text-focus-background, --comp-background-alternative)};\n @include btn-ring(neutral-text, hover, --comp-font-color, --comp-background, null);\n @include btn-ring(neutral-text, active, transparent, transparent, --comp-box-shadow);\n @include btn-ring(neutral-text, focus-visible, --const-focus-color, --app-white, null);\n @include btn-intent(neutral-text);\n @include btn-icon-color(neutral-text, --comp-font-color);\n }\n\n // different background for loading\n :host([color='primary'][loading]) &,\n :host([intent='workflow-primary'][loading]) & {\n --comp-background: var(--tct-btn-primary-loading-background, #0063a0);\n }\n\n :host([intent='workflow-escape'][loading]) & {\n --comp-background: #{var-list(--tct-btn-escape-loading-background, --comp-background-alternative)};\n }\n\n // Icons\n :host &.icon-only {\n width: var-list(var-prefixer(btn-icon-width), 44px);\n height: var-list(var-prefixer(btn-icon-height), 44px);\n border-radius: var-list(var-prefixer(btn-icon-border-radius), --tct-btn-border-radius, 0);\n\n &:hover,\n &:focus {\n background-color: var-list(\n --tct-btn-icon-hover-background,\n var-prefixer(btn-icon-hover-bg),\n var-prefixer(gray-13),\n --tct-gray-l3,\n --app-gray-l3,\n #f2f2f2\n );\n }\n }\n\n :host(:not([intent])[active]) &.icon-only {\n background-color: var-list(\n --tct-btn-icon-active-background,\n var-prefixer(btn-icon-active-bg),\n var-prefixer(gray-14),\n --tct-gray-l3,\n --app-gray-l3,\n #f2f2f2\n );\n }\n\n :host(:not([intent])) &.icon-only:hover *,\n :host(:not([intent])) &.icon-only:focus *,\n :host(:not([intent])[active]) &.icon-only * {\n color: var-list(var-prefixer(btn-icon-hover-color), var-prefixer(link-hover-color), #080808);\n }\n\n // Badges\n :host([badge]) & {\n padding: var-list(var-prefixer(btn-badge-padding), unquote('2px 5px'));\n font-size: var-list(var-prefixer(btn-badge-font-size), var-prefixer(btn-font-size), inherit);\n border-radius: var-list(\n var-prefixer(btn-badge-border-radius),\n --tct-border-radius-1,\n --app-border-radius-1,\n 3px\n );\n background-color: var-list(--tct-btn-badge-background, var-prefixer(btn-badge-bg), transparent);\n color: var-list(var-prefixer(btn-badge-font-color), inherit);\n\n ::slotted(q2-icon) {\n --tct-icon-size: 1em;\n }\n }\n\n :host([badge]:hover) &:enabled {\n background-color: var-list(\n --tct-btn-badge-hover-background,\n var-prefixer(btn-badge-hover-bg),\n var-prefixer(gray-14),\n --tct-gray-l3,\n --app-gray-l3,\n #f2f2f2\n );\n color: var-list(\n var-prefixer(btn-badge-hover-font-color),\n var-prefixer(gray-5),\n --tct-gray-d2,\n --app-gray-d2,\n #404040\n );\n }\n\n :host(.selected[badge]) &,\n :host([active][badge]) & {\n background-color: var-list(\n --tct-btn-badge-active-background,\n var-prefixer(btn-badge-active-bg),\n --comp-btn-primary-background\n );\n color: var-list(var-prefixer(btn-badge-active-font-color), --comp-btn-primary-font-color);\n }\n}\n\ndiv {\n display: flex;\n align-items: center;\n justify-content: center;\n gap: var-list(--app-scale-1x, 5px);\n\n :host([loading]) .icon-right & {\n flex-direction: row-reverse;\n }\n}\n\nq2-loading {\n --tct-loading-primary-color: currentColor;\n --tct-loading-secondary-color: currentColor;\n --tct-loading-spinner-size: 24px;\n}\n\n:host([loading]) ::slotted(q2-icon) {\n display: none;\n}\n:host([loading]) button {\n pointer-events: none;\n}\n\n:host([block]) button,\n:host([block]) button.icon-only {\n display: block;\n width: 100%;\n}\n","import { Component, State, Prop, h, ComponentInterface, Watch, Listen, Element, Fragment } from '@stencil/core';\nimport {\n handleAriaLabel,\n handleColor,\n isEventFromElement,\n loc,\n overrideFocus,\n handleDeprecationWarning,\n} from 'src/utils';\n\n@Component({\n tag: 'q2-btn',\n shadow: true,\n styleUrl: 'styles.scss',\n})\nexport class Q2Btn implements ComponentInterface {\n @Prop() ariaExpanded: string;\n @Prop() ariaHasPopup: string;\n @Prop() ariaControls: string;\n @Prop() ariaSelected: string;\n @Prop() ariaPressed: string;\n @Prop() description: string;\n @Prop({ reflect: true, mutable: true }) label: string;\n @Prop({ reflect: true, mutable: true }) hideLabel: boolean;\n @Prop() tabIndex: number;\n @Prop({ reflect: true, mutable: true }) intent:\n | 'workflow-primary'\n | 'workflow-secondary'\n | 'workflow-destroy'\n | 'workflow-escape'\n | 'neutral'\n | 'neutral-text';\n @Prop({ reflect: true }) disabled: boolean;\n @Prop({ reflect: true }) type: string;\n @Prop({ reflect: true }) size: string;\n @Prop({ reflect: true }) loading: boolean;\n @Prop({ reflect: true }) badge: boolean;\n @Prop({ reflect: true }) active: boolean;\n @Prop({ reflect: true }) block: boolean;\n\n /** @deprecated */\n @Prop({ reflect: true, mutable: true }) color: string; // deprecated but need it to use utils/handleColor\n\n /** @deprecated */\n @Prop({ reflect: true }) fab: boolean;\n\n /** @deprecated */\n @Prop({ reflect: true, mutable: true }) ariaLabel: string;\n\n @State() iconPosition: 'left' | 'right' | 'only';\n\n @Element() hostElement: HTMLElement;\n\n primaryBtn: HTMLButtonElement;\n primaryBtnWrapper: HTMLElement;\n ////////// LIFECYCLE HOOKS ////////\n\n componentWillLoad() {\n this.handleIcons();\n handleAriaLabel(this);\n handleColor(this);\n }\n\n componentDidLoad(): void {\n this.handleButtonSize();\n overrideFocus(this.hostElement);\n }\n\n @Listen('click', { capture: true })\n disable(ev: Event) {\n if (this.disabled) {\n ev.stopImmediatePropagation();\n }\n this.primaryBtn.focus();\n }\n\n @Listen('focus')\n delegateFocus(event: FocusEvent) {\n if (!isEventFromElement(event, this.hostElement)) return;\n this.primaryBtn.focus();\n }\n\n //////// Method //////////\n\n ////////// OBSERVERS //////////\n\n @Watch('ariaLabel')\n ariaLabelObserver() {\n handleAriaLabel(this);\n }\n\n @Watch('size')\n sizeObserver() {\n this.handleButtonSize();\n }\n\n handleButtonSize = () => {\n if (Number(this.size) <= 4) {\n handleDeprecationWarning(this, 'size', 'prop');\n }\n };\n\n handleSlotChange = () => {\n this.handleIcons();\n };\n\n handleIcons = () => {\n // Only allow one icon in the button\n const icon = Array.from(this.hostElement.querySelectorAll(':scope > q2-icon')).reduce((acc, element) => {\n if (acc) element.remove();\n else acc = element;\n return acc;\n }, null);\n\n const hasIcon = !!icon;\n const hasLoc = !!this.hostElement.querySelector('q2-loc');\n const hasText = !!this.hostElement.textContent.trim();\n const hasIconLeft = (hasLoc || hasText) && hasIcon && this.hostElement.firstElementChild === icon;\n const hasIconRight = (hasLoc || hasText) && hasIcon && this.hostElement.lastElementChild === icon;\n const hasIconOnly = !hasIconLeft && !hasIconRight && hasIcon;\n\n let iconPosition;\n if (hasIconOnly) iconPosition = 'only';\n else if (hasIconLeft) iconPosition = 'left';\n else if (hasIconRight) iconPosition = 'right';\n this.iconPosition = iconPosition;\n };\n\n renderButton = () => {\n const { ariaExpanded, ariaHasPopup, ariaSelected, ariaPressed, description, disabled, type, tabindex } =\n this.buttonAttributes;\n const { iconPosition, loading, badge, label, hideLabel } = this;\n const renderLoadingSpinner = iconPosition || loading;\n const isLoadingSpinnerInline = !iconPosition || badge;\n return (\n <Fragment>\n <button\n ref={el => (this.primaryBtn = el ?? this.primaryBtn)}\n aria-expanded={ariaExpanded}\n aria-haspopup={ariaHasPopup}\n aria-label={hideLabel && loc(label)}\n aria-selected={ariaSelected}\n aria-pressed={ariaPressed}\n disabled={disabled}\n type={type}\n tabindex={tabindex}\n test-id=\"q2BtnInnerButton\"\n class={iconPosition ? `icon-${iconPosition}` : ''}\n aria-describedby={!!description ? 'hidden-description' : undefined}\n >\n <div>\n {renderLoadingSpinner && (\n <q2-loading\n hidden={!loading}\n modifiers={isLoadingSpinnerInline ? 'inline' : undefined}\n />\n )}\n {!hideLabel && label ? loc(label) : <slot onSlotchange={this.handleSlotChange} />}\n </div>\n </button>\n {!!description && (\n <div\n id=\"hidden-description\"\n aria-hidden=\"true\"\n class=\"sr\"\n >\n {description}\n </div>\n )}\n </Fragment>\n );\n };\n\n render = () => {\n return this.size === 'small' ? (\n // wrap only for small sized\n <div\n class=\"btn-height-wrapper\"\n ref={el => (this.primaryBtnWrapper = el ?? this.primaryBtnWrapper)}\n tabIndex={-1}\n >\n {this.renderButton()}\n </div>\n ) : (\n this.renderButton()\n );\n };\n\n get buttonAttributes() {\n return {\n ariaExpanded: this.ariaExpanded !== undefined ? `${this.ariaExpanded?.toString() === 'true'}` : undefined,\n ariaHasPopup:\n this.ariaHasPopup !== undefined\n ? `${this.ariaHasPopup === 'true' || this.ariaHasPopup === 'menu'}`\n : undefined,\n ariaLabel: this.label && this.hideLabel ? loc(this.label) : undefined,\n ariaSelected: this.ariaSelected !== undefined ? `${this.ariaSelected?.toString() === 'true'}` : undefined,\n ariaPressed: this.ariaPressed !== undefined ? `${this.ariaPressed?.toString() === 'true'}` : undefined,\n description: this.description !== undefined ? this.description : undefined,\n disabled: this.disabled || false,\n type: this.type || 'button',\n tabindex: this.tabIndex || undefined,\n };\n }\n}\n","@import '../../styles/host.scss';\n@import '../../styles/utility.scss';\n@import '../../styles/functions';\n\n:host {\n display: block;\n}\n\n:host([inline]),\n:host([modifiers*='inline']) {\n display: inline-block;\n}\n\n:host([hidden]) {\n display: none;\n}\n\n:host(:not([inline]):not([modifiers*='inline'])) {\n font-size: var-list(var-prefixer(loading-spinner-size), --app-scale-12x, 60px);\n}\n\n.q2-loading-animation {\n height: 1em;\n width: 1em;\n}\n\n@import './spinners/half-circle-spinner.scss';\n@import './skeleton/skeleton.scss';\n","import { Component, Prop, h, ComponentInterface, Element, Watch } from '@stencil/core';\nimport { handleAriaLabel, loc } from 'src/utils';\nimport skeletonShapes from './skeleton/shapes';\n\n@Component({\n tag: 'q2-loading',\n shadow: true,\n styleUrl: 'styles.scss',\n})\nexport class Q2Loading implements ComponentInterface {\n @Element() hostElement: HTMLElement;\n\n @Prop({ reflect: true }) type: 'spinner' | 'skeleton';\n @Prop({ reflect: true }) shape: string;\n @Prop({ reflect: true }) modifiers: string;\n @Prop({ reflect: true }) counts: string;\n @Prop({ reflect: true, mutable: true }) label: string;\n @Prop({ reflect: true }) inline: boolean;\n\n /** @deprecated */\n @Prop({ reflect: true, mutable: true }) ariaLabel: string;\n\n get loader() {\n const loaderMap = {\n default: this.spinner,\n spinner: this.spinner,\n skeleton: this.skeletonLoader,\n };\n\n return loaderMap[this.type] || loaderMap.default;\n }\n\n get modifiersSet(): Set<string> {\n if (this.type !== 'skeleton' || !this.modifiers) {\n return undefined;\n }\n\n return new Set(this.modifiers.split('-'));\n }\n\n get countsArray(): number[] {\n if (this.type !== 'skeleton' || !this.counts) {\n return undefined;\n }\n\n return this.counts.split('x').map(Number);\n }\n\n get skeletonShape() {\n return skeletonShapes[this.shape]?.(this.countsArray, this.modifiersSet) ?? '';\n }\n\n get spinnerShape() {\n const spinnerMap = {\n default: this.halfCircleSpinner,\n 'half-circle': this.halfCircleSpinner,\n };\n\n return spinnerMap[this.type] || spinnerMap.default;\n }\n\n get localizedLabel() {\n return loc(this.label || 'tecton.element.loading.ariaLabel');\n }\n\n componentWillLoad() {\n handleAriaLabel(this);\n }\n\n @Watch('ariaLabel')\n ariaLabelObserver() {\n handleAriaLabel(this);\n }\n\n render() {\n return this.loader();\n }\n\n halfCircleSpinner = () => {\n return (\n <div\n class=\"q2-loading-animation half-circle-spinner\"\n aria-label={this.localizedLabel}\n >\n <div class=\"circle circle-1\"></div>\n <div class=\"circle circle-2\"></div>\n </div>\n );\n };\n\n spinner = () => {\n return this.halfCircleSpinner();\n };\n\n skeletonLoader = () => {\n return (\n <div\n class=\"q2-loading-skeleton\"\n aria-label={this.localizedLabel}\n >\n {this.shape === 'custom' ? <slot /> : this.skeletonShape}\n <div class=\"q2-loading-skeleton-shimmer\"></div>\n </div>\n );\n };\n}\n"],"version":3}
@@ -1,5 +1,5 @@
1
1
  import { r as registerInstance, c as createEvent, h, g as getElement } from './index-ebc7f269.js';
2
- import { l as loc, h as handleAriaLabel, o as overrideFocus, i as isEventFromElement, a as handleRenamedProp, w as waitForNextPaint } from './index-a8589748.js';
2
+ import { l as loc, h as handleAriaLabel, o as overrideFocus, i as isEventFromElement, a as handleRenamedProp, w as waitForNextPaint } from './index-35ff2881.js';
3
3
 
4
4
  function _typeof(o) {
5
5
  "@babel/helpers - typeof";
@@ -2631,8 +2631,8 @@ startDate, endDate, formatString = 'mm/dd/yyyy', assume) {
2631
2631
  const monthName = getMonths()[inputDate.getMonth()];
2632
2632
  if (input.length === 10) {
2633
2633
  isValid$1 = true;
2634
- messageType = 'success';
2635
- message = `${loc('tecton.element.calendar.hint.selection')}: ${formatDateLong(inputDate)}`;
2634
+ messageType = null;
2635
+ message = null;
2636
2636
  }
2637
2637
  isAvailable = validDays.includes(inputDate.getDay());
2638
2638
  const isoString = formatDateISO(inputDate);
@@ -2670,7 +2670,13 @@ startDate, endDate, formatString = 'mm/dd/yyyy', assume) {
2670
2670
  }
2671
2671
  function buildInputDate(input, assume) {
2672
2672
  const now = new Date();
2673
- const [month, day, year] = input.split('/');
2673
+ /* tslint:disable:prefer-const */
2674
+ let [month, day, year] = input.split('/');
2675
+ /* tslint:enable:prefer-const */
2676
+ if (month === '0')
2677
+ month = '01';
2678
+ if (day === '0')
2679
+ day = '01';
2674
2680
  if (input.length === 10) {
2675
2681
  return new Date(input);
2676
2682
  }
@@ -2679,9 +2685,6 @@ function buildInputDate(input, assume) {
2679
2685
  const fourDigitYear = !year || year.length < 4 ? assumeYear(month, day, assume) : year;
2680
2686
  return new Date(`${month}/${twoDigitDay}/${fourDigitYear}`);
2681
2687
  }
2682
- else if (month && day && Number(day) === 0) {
2683
- return new Date(''); // invalid date: 09/0/2021
2684
- }
2685
2688
  else if (month) {
2686
2689
  return new Date(`${month}/01/${now.getFullYear()}`);
2687
2690
  }
@@ -2888,7 +2891,7 @@ function addEmptyDates(from, to) {
2888
2891
  return [...Array(to - from).keys()].map(() => (Object.assign({}, emptyDate)));
2889
2892
  }
2890
2893
 
2891
- const stylesCss = "*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-double-focus-ring, 0 0 0 2px #ffffff, 0 0 0 4px #33b4ff #06C)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size:inherit;font-stretch:inherit}:host(.sr),:host(.sr) button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.sr,.sr button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.hidden{display:none}:host([hidden]){display:none}.invisible{visibility:hidden}:host{display:block}:host[hidden]{display:none}click-elsewhere{position:relative;display:block}q2-input{margin:0;cursor:pointer}q2-popover{--comp-min-tappable-size:44px;--comp-table-border-spacing:2px;--comp-min-tappable-size-and-spacing:calc(var(--comp-min-tappable-size) + var(--comp-table-border-spacing));--comp-popover-padding:var(--tct-calendar-popover-padding, var(--t-calendar-popover-padding, var(--app-scale-1x, 5px)));--comp-min-table-width:calc(var(--comp-min-tappable-size-and-spacing) * 7);--comp-table-container-border-spacing:calc(var(--comp-table-border-spacing) * 2);--comp-popover-total-padding:calc(var(--comp-popover-padding) * 2);--tct-popover-min-width:calc(\n var(--comp-min-table-width) + var(--comp-table-container-border-spacing) + var(--comp-popover-total-padding)\n )}.calendar-field-popup{padding:var(--comp-popover-padding)}.calendar-label{--comp-label-padding:var(--tct-calendar-label-padding, var(--tct-calendar-label-vertical-padding, var(--t-calendar-label-vertical-padding, var(--tct-scale-2, var(--app-scale-2x, 10px)))) 0);font-size:var(--tct-calendar-label-font-size, var(--t-calendar-label-font-size, 16px));flex:1 1;flex-basis:calc(100% - var(--tct-btn-icon-width, 44px));margin:0;padding:var(--comp-label-padding)}.calendar-hint{text-align:left;margin:0}.cal-month-heading{padding:0 0 0.75rem;display:flex;justify-content:center;align-items:center;font-size:var(--tct-calendar-month-font-size, var(--t-calendar-month-font-size, 16px));font-weight:var(--tct-calendar-month-font-weight, var(--t-calendar-month-font-weight, 600));text-align:center}.cal-month-text{min-width:82px;display:inline-block}.cal-year-text{min-width:50px;display:inline-block}table{width:100%;margin-bottom:2px;text-align:center;border-spacing:var(--comp-table-border-spacing)}th{font-size:var(--tct-calendar-day-heading-font-size, var(--t-calendar-day-heading-font-size, inherit));font-weight:var(--tct-calendar-day-heading-font-weight, var(--t-calendar-day-heading-font-weight, 600));width:14.285714%}td{height:var(--comp-min-tappable-size);cursor:pointer;border:var(--tct-calendar-day-border, var(--t-calendar-day-border, 0));border-radius:var(--tct-calendar-day-border-radius, var(--t-calendar-day-border-radius))}td.is-unavailable{border:1px solid var(--tct-input-error-border-color, var(--const-stoplight-alert, #c30000))}td.is-valid:hover{border:var(--tct-calendar-day-hover-border, var(--t-calendar-day-hover-border, var(--tct-calendar-day-border, var(--t-calendar-day-border, 0))));border-radius:var(--tct-calendar-day-hover-border-radius, var(--t-calendar-day-hover-border-radius, var(--tct-calendar-day-border-radius, var(--t-calendar-day-border-radius))));background:var(--tct-calendar-day-hover-background, var(--tct-calendar-day-hover-bg, var(--t-calendar-day-hover-bg, var(--tct-gray-14, var(--app-gray14, var(--tct-gray-l4, var(--app-gray-l4, #f2f2f2)))))));color:var(--tct-calendar-day-hover-font-color, var(--t-calendar-day-hover-font-color, inherit))}td[aria-hidden],td[aria-disabled]{pointer-events:none;cursor:not-allowed}td[aria-disabled]{opacity:var(--tct-calendar-day-disabled-opacity, var(--t-calendar-day-disabled-opacity, var(--app-disabled-opacity, 0.4)))}td[aria-selected]{border:var(--tct-calendar-day-selected-border, var(--t-calendar-day-selected-border, var(--tct-calendar-day-border, var(--t-calendar-day-border, 0))));border-radius:var(--tct-calendar-day-selected-border-radius, var(--t-calendar-day-selected-border-radius, var(--tct-calendar-day-border-radius, var(--t-calendar-day-border-radius))));background:var(--tct-calendar-day-selected-background, var(--tct-calendar-day-selected-bg, var(--t-calendar-day-selected-bg, var(--tct-calendar-day-hover-background, var(--tct-calendar-day-hover-bg, var(--t-calendar-day-hover-bg, var(--tct-gray-14, var(--t-gray-14, var(--tct-gray-l4, var(--app-gray-l4, #f2f2f2))))))))));color:var(--tct-calendar-day-selected-font-color, var(--t-calendar-day-selected-font-color, var(--tct-calendar-day-hover-font-color, var(--t-calendar-day-hover-font-color, inherit))));box-shadow:0 0 0 2px var(--tct-calendar-day-selected-outline-color, var(--t-calendar-day-selected-outline-color, var(--tct-stoplight-info, var(--const-stoplight-info, #0079c1))))}.today-decorator{text-transform:uppercase;font-weight:700;font-size:10px;height:12px}.calendar-disclaimer{--comp-disclaimer-border-color:var(--tct-calendar-disclaimer-border-color, var(--t-calendar-disclaimer-border-color, var(--tct-gray-13, var(--t-gray-13, var(--tct-gray-l3, var(--app-gray-l3, #e6e6e6))))));--comp-disclaimer-border-top:var(--tct-calendar-disclaimer-border-top, 1px solid var(--comp-disclaimer-border-color));font-size:var(--tct-calendar-disclaimer-font-size, var(--t-calendar-disclaimer-font-size, var(--tct-font-size-small, var(--app-font-size-small, 12px))));border-top:var(--comp-disclaimer-border-top);padding:var(--tct-calendar-disclaimer-padding, var(--tct-scale-2, var(--app-scale-2x, 10px)));text-align:left}";
2894
+ const stylesCss = "*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-double-focus-ring, 0 0 0 2px #ffffff, 0 0 0 4px #33b4ff #06C)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size:inherit;font-stretch:inherit}:host(.sr),:host(.sr) button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.sr,.sr button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.hidden{display:none}:host([hidden]){display:none}.invisible{visibility:hidden}:host{display:block}:host[hidden]{display:none}click-elsewhere{position:relative;display:block}q2-input{margin:0;cursor:pointer}q2-popover{--comp-min-tappable-size:44px;--comp-table-border-spacing:2px;--comp-min-tappable-size-and-spacing:calc(var(--comp-min-tappable-size) + var(--comp-table-border-spacing));--comp-popover-padding:var(--tct-calendar-popover-padding, var(--t-calendar-popover-padding, var(--app-scale-1x, 5px)));--comp-min-table-width:calc(var(--comp-min-tappable-size-and-spacing) * 7);--comp-table-container-border-spacing:calc(var(--comp-table-border-spacing) * 2);--comp-popover-total-padding:calc(var(--comp-popover-padding) * 2);--tct-popover-min-width:calc(\n var(--comp-min-table-width) + var(--comp-table-container-border-spacing) + var(--comp-popover-total-padding)\n )}.calendar-field-popup{padding:var(--comp-popover-padding)}.calendar-label{--comp-label-padding:var(--tct-calendar-label-padding, var(--tct-calendar-label-vertical-padding, var(--t-calendar-label-vertical-padding, var(--tct-scale-2, var(--app-scale-2x, 10px)))) 0);font-size:var(--tct-calendar-label-font-size, var(--t-calendar-label-font-size, 16px));flex:1 1;flex-basis:calc(100% - var(--tct-btn-icon-width, 44px));margin:0;padding:var(--comp-label-padding)}.cal-month-heading{padding:0 0 0.75rem;display:flex;justify-content:center;align-items:center;font-size:var(--tct-calendar-month-font-size, var(--t-calendar-month-font-size, 16px));font-weight:var(--tct-calendar-month-font-weight, var(--t-calendar-month-font-weight, 600));text-align:center}.cal-month-text{min-width:82px;display:inline-block}.cal-year-text{min-width:50px;display:inline-block}table{width:100%;margin-bottom:2px;text-align:center;border-spacing:var(--comp-table-border-spacing)}th{font-size:var(--tct-calendar-day-heading-font-size, var(--t-calendar-day-heading-font-size, inherit));font-weight:var(--tct-calendar-day-heading-font-weight, var(--t-calendar-day-heading-font-weight, 600));width:14.285714%}td{height:var(--comp-min-tappable-size);cursor:pointer;border:var(--tct-calendar-day-border, var(--t-calendar-day-border, 0));border-radius:var(--tct-calendar-day-border-radius, var(--t-calendar-day-border-radius))}td.is-unavailable{border:1px solid var(--tct-input-error-border-color, var(--const-stoplight-alert, #c30000))}td.is-valid:hover{border:var(--tct-calendar-day-hover-border, var(--t-calendar-day-hover-border, var(--tct-calendar-day-border, var(--t-calendar-day-border, 0))));border-radius:var(--tct-calendar-day-hover-border-radius, var(--t-calendar-day-hover-border-radius, var(--tct-calendar-day-border-radius, var(--t-calendar-day-border-radius))));background:var(--tct-calendar-day-hover-background, var(--tct-calendar-day-hover-bg, var(--t-calendar-day-hover-bg, var(--tct-gray-14, var(--app-gray14, var(--tct-gray-l4, var(--app-gray-l4, #f2f2f2)))))));color:var(--tct-calendar-day-hover-font-color, var(--t-calendar-day-hover-font-color, inherit))}td[aria-hidden],td[aria-disabled]{pointer-events:none;cursor:not-allowed}td[aria-disabled]{opacity:var(--tct-calendar-day-disabled-opacity, var(--t-calendar-day-disabled-opacity, var(--app-disabled-opacity, 0.4)))}td[aria-selected]{border:var(--tct-calendar-day-selected-border, var(--t-calendar-day-selected-border, var(--tct-calendar-day-border, var(--t-calendar-day-border, 0))));border-radius:var(--tct-calendar-day-selected-border-radius, var(--t-calendar-day-selected-border-radius, var(--tct-calendar-day-border-radius, var(--t-calendar-day-border-radius))));background:var(--tct-calendar-day-selected-background, var(--tct-calendar-day-selected-bg, var(--t-calendar-day-selected-bg, var(--tct-calendar-day-hover-background, var(--tct-calendar-day-hover-bg, var(--t-calendar-day-hover-bg, var(--tct-gray-14, var(--t-gray-14, var(--tct-gray-l4, var(--app-gray-l4, #f2f2f2))))))))));color:var(--tct-calendar-day-selected-font-color, var(--t-calendar-day-selected-font-color, var(--tct-calendar-day-hover-font-color, var(--t-calendar-day-hover-font-color, inherit))));box-shadow:0 0 0 2px var(--tct-calendar-day-selected-outline-color, var(--t-calendar-day-selected-outline-color, var(--tct-stoplight-info, var(--const-stoplight-info, #0079c1))))}.today-decorator{text-transform:uppercase;font-weight:700;font-size:10px;height:12px}.calendar-disclaimer{--comp-disclaimer-border-color:var(--tct-calendar-disclaimer-border-color, var(--t-calendar-disclaimer-border-color, var(--tct-gray-13, var(--t-gray-13, var(--tct-gray-l3, var(--app-gray-l3, #e6e6e6))))));--comp-disclaimer-border-top:var(--tct-calendar-disclaimer-border-top, 1px solid var(--comp-disclaimer-border-color));font-size:var(--tct-calendar-disclaimer-font-size, var(--t-calendar-disclaimer-font-size, var(--tct-font-size-small, var(--app-font-size-small, 12px))));border-top:var(--comp-disclaimer-border-top);padding:var(--tct-calendar-disclaimer-padding, var(--tct-scale-2, var(--app-scale-2x, 10px)));text-align:left}";
2892
2895
 
2893
2896
  const Q2Calendar = class {
2894
2897
  constructor(hostRef) {
@@ -3004,9 +3007,7 @@ const Q2Calendar = class {
3004
3007
  }
3005
3008
  };
3006
3009
  this.onInputChange = (event) => {
3007
- if (this.isTypeable) {
3008
- event.stopPropagation();
3009
- }
3010
+ event.stopPropagation();
3010
3011
  };
3011
3012
  this.onInputBlur = () => {
3012
3013
  if (!this.isTypeable)
@@ -3164,6 +3165,7 @@ const Q2Calendar = class {
3164
3165
  this.cutoffTime = undefined;
3165
3166
  this.daysOfWeekChecksum = undefined;
3166
3167
  this.assume = 'current';
3168
+ this.hints = undefined;
3167
3169
  this.errors = undefined;
3168
3170
  this.invalidDates = undefined;
3169
3171
  this.validDates = undefined;
@@ -3234,11 +3236,6 @@ const Q2Calendar = class {
3234
3236
  }, []);
3235
3237
  return weeks;
3236
3238
  }
3237
- get localizedErrors() {
3238
- return ((Array.isArray(this.errors) &&
3239
- this.errors.filter((error) => error).map((error) => error && loc(error))) ||
3240
- []);
3241
- }
3242
3239
  get formattedValue() {
3243
3240
  const { typedValue, dateValue, displayFormat, isTypeable } = this;
3244
3241
  if (isTypeable)
@@ -3291,6 +3288,24 @@ const Q2Calendar = class {
3291
3288
  get isTypeable() {
3292
3289
  return this.typeable;
3293
3290
  }
3291
+ get errorList() {
3292
+ const { errors, hintMessageType, hintMessage, invalid } = this;
3293
+ if (Array.isArray(errors) && errors.length)
3294
+ return errors.filter(error => !!error).map(error => loc(error));
3295
+ if (hintMessageType === 'error' && hintMessage)
3296
+ return [hintMessage];
3297
+ if (invalid)
3298
+ return ['tecton.element.calendar.invalid'];
3299
+ return [];
3300
+ }
3301
+ get hintList() {
3302
+ const { hints, hintMessageType, hintMessage } = this;
3303
+ if (Array.isArray(hints) && hints.length)
3304
+ return hints.filter(hint => !!hint).map(hint => loc(hint));
3305
+ if (hintMessageType === 'info' && hintMessage)
3306
+ return [hintMessage];
3307
+ return [];
3308
+ }
3294
3309
  //////// Host Element Events ////////
3295
3310
  defaultChangeHandler(event) {
3296
3311
  if (event.target === this.hostElement && !this.hostElement.onchange && !!event.detail) {
@@ -3299,10 +3314,11 @@ const Q2Calendar = class {
3299
3314
  }
3300
3315
  defaultErrorHandler(event) {
3301
3316
  if (event.target === this.hostElement && !this.hostElement.onerror) {
3302
- if (Array.isArray(this.errors) && this.errors.includes('tecton.element.calendar.invalidDate')) {
3317
+ const { errors } = this;
3318
+ if (Array.isArray(errors) && errors.includes('tecton.element.calendar.hint.invalidDate')) {
3303
3319
  return;
3304
3320
  }
3305
- this.errors = (this.errors || []).concat(['tecton.element.calendar.invalidDate']);
3321
+ this.errors = (errors || []).concat(['tecton.element.calendar.hint.invalidDate']);
3306
3322
  }
3307
3323
  }
3308
3324
  defaultSuccessHandler(event) {
@@ -3313,8 +3329,9 @@ const Q2Calendar = class {
3313
3329
  this.onsuccess(event);
3314
3330
  }
3315
3331
  else {
3316
- if (Array.isArray(this.errors) && this.errors.includes('tecton.element.calendar.invalidDate')) {
3317
- this.errors = this.errors.filter(x => x !== 'tecton.element.calendar.invalidDate');
3332
+ const { errors } = this;
3333
+ if (Array.isArray(errors) && errors.includes('tecton.element.calendar.hint.invalidDate')) {
3334
+ this.errors = errors.filter(x => x !== 'tecton.element.calendar.hint.invalidDate');
3318
3335
  }
3319
3336
  }
3320
3337
  }
@@ -3367,8 +3384,8 @@ const Q2Calendar = class {
3367
3384
  if (shortFormattedValue) {
3368
3385
  this.setHints({
3369
3386
  isValid: true,
3370
- message: `${loc('tecton.element.calendar.hint.selection')}: ${formatDateLong(newDate)}`,
3371
- messageType: 'success',
3387
+ message: null,
3388
+ messageType: null,
3372
3389
  });
3373
3390
  }
3374
3391
  else {
@@ -3484,14 +3501,14 @@ const Q2Calendar = class {
3484
3501
  return (h("click-elsewhere", { class: this.open ? 'dropdown-open' : undefined, onChange: this.onClickElsewhere }, this.inputField(), h("q2-popover", { ref: el => (this.popoverElement = el), controlElement: this.innerInputField, open: this.open, direction: this.popoverDirection, "aria-label": loc('tecton.element.calendar.dialogLabel'), minHeight: this.popoverMinHeight, align: this.popoverAlignment, block: true }, this.hintField(), this.calendarPopover())));
3485
3502
  }
3486
3503
  hintField() {
3487
- const messageClasses = ['calendar-hint'];
3488
- if (!this.isTypeable)
3489
- messageClasses.push('sr');
3490
- return (h("q2-message", { ref: el => (this.hintMessageElement = el), type: this.hintMessageType, class: messageClasses.join(' ') }, this.hintMessage));
3504
+ if (!this.hintMessage)
3505
+ return;
3506
+ return (h("q2-message", { class: "calendar-hint sr", ref: el => (this.hintMessageElement = el), type: this.hintMessageType }, this.hintMessage));
3491
3507
  }
3492
3508
  setHints({ isValid, message, messageType }) {
3509
+ var _a;
3493
3510
  if (message === this.hintMessage)
3494
- return this.hintMessageElement.present();
3511
+ return (_a = this.hintMessageElement) === null || _a === void 0 ? void 0 : _a.present();
3495
3512
  this.invalid = !isValid;
3496
3513
  this.hintMessage = message;
3497
3514
  this.hintMessageType = messageType;
@@ -3502,15 +3519,13 @@ const Q2Calendar = class {
3502
3519
  this.typedValue = formattedDate;
3503
3520
  this.setHints({
3504
3521
  isValid: true,
3505
- message: `${loc('tecton.element.calendar.hint.selection')}: ${formatDateLong(inputDate)}`,
3506
- messageType: 'success',
3522
+ message: null,
3523
+ messageType: null,
3507
3524
  });
3508
3525
  }
3509
3526
  inputField() {
3510
3527
  const { isTypeable } = this;
3511
- return (h("q2-input", { ref: el => (this.controlElement = el), class: "calendar-input-field", value: this.formattedValue, label: loc(this.label), hideLabel: this.hideLabel, disabled: !!this.disabled, readonly: !!this.readonly, clearable: this.canClear, placeholder: this.computedPlaceholder, optional: !!this.optional, ariaExpanded: `${!!this.open}`, errors: (this.localizedErrors.length > 0 && this.localizedErrors) ||
3512
- (this.invalid && ['tecton.element.calendar.invalid']) ||
3513
- [], onClick: isTypeable ? undefined : this.onInputClick, onChange: this.onInputChange, onInput: this.onInputInput, onKeyDown: this.onInputKeydown, onKeyUp: this.onInputKeyup, onBlur: this.onInputBlur, onFocus: this.onInputFocus, "icon-right": isTypeable ? undefined : 'calendar', "format-modifier": isTypeable ? this.formatModifier : '', pseudo: !isTypeable, type: "date", "hide-messages": true, "test-id": "inputAndCalendarToggle" }, isTypeable && (h("q2-btn", { slot: "input-right", onClick: this.onInputClick, "test-id": "calendarToggle", label: "tecton.element.calendar.toggleAriaLabel", "hide-label": true }, h("q2-icon", { type: "calendar" })))));
3528
+ return (h("q2-input", { ref: el => (this.controlElement = el), class: "calendar-input-field", value: this.formattedValue, label: loc(this.label), hideLabel: this.hideLabel, disabled: !!this.disabled, readonly: !!this.readonly, clearable: this.canClear, placeholder: this.computedPlaceholder, optional: !!this.optional, ariaExpanded: `${!!this.open}`, hints: this.hintList, errors: this.errorList, onClick: isTypeable ? undefined : this.onInputClick, onChange: this.onInputChange, onInput: this.onInputInput, onKeyDown: this.onInputKeydown, onKeyUp: this.onInputKeyup, onBlur: this.onInputBlur, onFocus: this.onInputFocus, "icon-right": isTypeable ? undefined : 'calendar', "format-modifier": isTypeable ? this.formatModifier : '', pseudo: !isTypeable, type: "date", "hide-messages": !isTypeable, "test-id": "inputAndCalendarToggle" }, isTypeable && (h("q2-btn", { slot: "input-right", onClick: this.onInputClick, "test-id": "calendarToggle", label: "tecton.element.calendar.toggleAriaLabel", "hide-label": true }, h("q2-icon", { type: "calendar" })))));
3514
3529
  }
3515
3530
  calendarPopover() {
3516
3531
  const { monthIndex, selectedYear } = this.selectedMonthYear;