q2-tecton-elements 1.13.0-alpha.0 → 1.13.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 (234) hide show
  1. package/dist/cjs/click-elsewhere.cjs.entry.js +5 -7
  2. package/dist/cjs/{icons-4595ee47.js → icons-08ffe5c9.js} +394 -384
  3. package/dist/cjs/{index-c2e53804.js → index-7febb200.js} +112 -65
  4. package/dist/cjs/{index-a55d3c34.js → index-dd823ee6.js} +27 -14
  5. package/dist/cjs/loader.cjs.js +3 -3
  6. package/dist/cjs/q2-avatar.cjs.entry.js +2 -2
  7. package/dist/cjs/q2-badge.cjs.entry.js +43 -0
  8. package/dist/cjs/q2-btn_2.cjs.entry.js +13 -13
  9. package/dist/cjs/q2-calendar.cjs.entry.js +53 -59
  10. package/dist/cjs/q2-card.cjs.entry.js +127 -0
  11. package/dist/cjs/q2-carousel-pane.cjs.entry.js +5 -5
  12. package/dist/cjs/q2-carousel.cjs.entry.js +318 -106
  13. package/dist/cjs/q2-checkbox-group.cjs.entry.js +6 -3
  14. package/dist/cjs/q2-checkbox.cjs.entry.js +18 -10
  15. package/dist/cjs/q2-dropdown-item.cjs.entry.js +7 -7
  16. package/dist/cjs/q2-dropdown.cjs.entry.js +8 -17
  17. package/dist/cjs/q2-editable-field.cjs.entry.js +5 -8
  18. package/dist/cjs/q2-icon.cjs.entry.js +3 -3
  19. package/dist/cjs/q2-input.cjs.entry.js +439 -437
  20. package/dist/cjs/q2-loading-element.cjs.entry.js +3 -3
  21. package/dist/cjs/q2-loc.cjs.entry.js +2 -2
  22. package/dist/cjs/q2-message.cjs.entry.js +5 -5
  23. package/dist/cjs/q2-optgroup.cjs.entry.js +3 -3
  24. package/dist/cjs/q2-option-list.cjs.entry.js +359 -0
  25. package/dist/cjs/q2-option.cjs.entry.js +3 -11
  26. package/dist/cjs/q2-pagination.cjs.entry.js +116 -0
  27. package/dist/cjs/q2-pill.cjs.entry.js +137 -0
  28. package/dist/cjs/q2-radio-group.cjs.entry.js +43 -18
  29. package/dist/cjs/q2-radio.cjs.entry.js +21 -4
  30. package/dist/cjs/q2-section.cjs.entry.js +5 -7
  31. package/dist/cjs/q2-select.cjs.entry.js +23 -26
  32. package/dist/cjs/q2-stepper-pane.cjs.entry.js +42 -4
  33. package/dist/cjs/q2-stepper-vertical.cjs.entry.js +278 -0
  34. package/dist/cjs/q2-stepper.cjs.entry.js +10 -12
  35. package/dist/cjs/q2-tab-container.cjs.entry.js +12 -8
  36. package/dist/cjs/q2-tab-pane.cjs.entry.js +1 -1
  37. package/dist/cjs/q2-tag.cjs.entry.js +94 -0
  38. package/dist/cjs/q2-tecton-elements.cjs.js +3 -3
  39. package/dist/cjs/q2-textarea.cjs.entry.js +8 -8
  40. package/dist/cjs/{shapes-086c0365.js → shapes-305746b5.js} +9 -16
  41. package/dist/cjs/tecton-tab-pane.cjs.entry.js +2 -5
  42. package/dist/collection/collection-manifest.json +10 -3
  43. package/dist/collection/components/click-elsewhere/index.js +4 -6
  44. package/dist/collection/components/q2-badge/index.js +148 -0
  45. package/dist/collection/components/q2-badge/styles.css +134 -0
  46. package/dist/collection/components/q2-btn/index.js +14 -14
  47. package/dist/collection/components/q2-btn/styles.css +1 -1
  48. package/dist/collection/components/q2-calendar/helpers.js +22 -20
  49. package/dist/collection/components/q2-calendar/index.js +44 -37
  50. package/dist/collection/components/q2-calendar/validation.js +4 -2
  51. package/dist/collection/components/q2-card/index.js +347 -0
  52. package/dist/collection/components/q2-card/styles.css +177 -0
  53. package/dist/collection/components/q2-carousel/index.js +11 -16
  54. package/dist/collection/components/q2-carousel/styles.css +3 -3
  55. package/dist/collection/components/q2-carousel-pane/index.js +2 -2
  56. package/dist/collection/components/q2-carousel-pane/styles.css +8 -3
  57. package/dist/collection/components/q2-checkbox/index.js +37 -12
  58. package/dist/collection/components/q2-checkbox-group/index.js +22 -1
  59. package/dist/collection/components/q2-dropdown/index.js +6 -15
  60. package/dist/collection/components/q2-dropdown-item/index.js +5 -5
  61. package/dist/collection/components/q2-editable-field/index.js +3 -6
  62. package/dist/collection/components/q2-icon/icons.js +393 -383
  63. package/dist/collection/components/q2-input/formatting/credit-card.js +15 -13
  64. package/dist/collection/components/q2-input/formatting/currency.js +162 -162
  65. package/dist/collection/components/q2-input/formatting/date.js +1 -1
  66. package/dist/collection/components/q2-input/formatting/generic.js +7 -8
  67. package/dist/collection/components/q2-input/formatting/number.js +6 -9
  68. package/dist/collection/components/q2-input/formatting/numeric.js +5 -5
  69. package/dist/collection/components/q2-input/formatting/phone.js +215 -215
  70. package/dist/collection/components/q2-input/formatting/postal.js +1 -1
  71. package/dist/collection/components/q2-input/index.js +81 -25
  72. package/dist/collection/components/q2-input/styles.css +19 -14
  73. package/dist/collection/components/q2-loading/index.js +4 -4
  74. package/dist/collection/components/q2-loading/skeleton/q2-loading-element/index.js +1 -1
  75. package/dist/collection/components/q2-loading/skeleton/shapes.js +8 -15
  76. package/dist/collection/components/q2-message/index.js +3 -3
  77. package/dist/collection/components/q2-optgroup/index.js +1 -1
  78. package/dist/collection/components/q2-option/index.js +19 -25
  79. package/dist/collection/components/q2-option/styles.css +5 -0
  80. package/dist/collection/components/q2-option-list/index.js +648 -0
  81. package/dist/collection/components/q2-option-list/styles.css +128 -0
  82. package/dist/collection/components/q2-pagination/index.js +275 -0
  83. package/dist/collection/components/q2-pagination/styles.css +120 -0
  84. package/dist/collection/components/q2-pill/index.js +324 -0
  85. package/dist/collection/components/q2-pill/styles.css +229 -0
  86. package/dist/collection/components/q2-radio/index.js +38 -1
  87. package/dist/collection/components/q2-radio-group/index.js +66 -24
  88. package/dist/collection/components/q2-section/index.js +5 -7
  89. package/dist/collection/components/q2-select/index.js +40 -25
  90. package/dist/collection/components/q2-stepper/index.js +8 -10
  91. package/dist/collection/components/q2-stepper/styles.css +5 -5
  92. package/dist/collection/components/q2-stepper-pane/index.js +133 -5
  93. package/dist/collection/components/q2-stepper-vertical/index.js +346 -0
  94. package/dist/collection/components/q2-stepper-vertical/styles.css +273 -0
  95. package/dist/collection/components/q2-tab-container/index.js +11 -7
  96. package/dist/collection/components/q2-tag/index.js +200 -0
  97. package/dist/collection/components/q2-tag/styles.css +141 -0
  98. package/dist/collection/components/q2-textarea/index.js +6 -6
  99. package/dist/collection/components/tecton-tab-pane/index.js +3 -10
  100. package/dist/collection/utils/index.js +25 -13
  101. package/dist/esm/click-elsewhere.entry.js +5 -7
  102. package/dist/esm/{icons-3ee662ea.js → icons-b1e11526.js} +394 -384
  103. package/dist/esm/{index-ec6660af.js → index-0ff8de52.js} +27 -15
  104. package/dist/esm/{index-be8376c0.js → index-dbfb3ecc.js} +112 -65
  105. package/dist/esm/loader.js +3 -3
  106. package/dist/esm/polyfills/css-shim.js +1 -1
  107. package/dist/esm/q2-avatar.entry.js +2 -2
  108. package/dist/esm/q2-badge.entry.js +39 -0
  109. package/dist/esm/q2-btn_2.entry.js +13 -13
  110. package/dist/esm/q2-calendar.entry.js +53 -59
  111. package/dist/esm/q2-card.entry.js +123 -0
  112. package/dist/esm/q2-carousel-pane.entry.js +5 -5
  113. package/dist/esm/q2-carousel.entry.js +318 -106
  114. package/dist/esm/q2-checkbox-group.entry.js +6 -3
  115. package/dist/esm/q2-checkbox.entry.js +18 -10
  116. package/dist/esm/q2-dropdown-item.entry.js +7 -7
  117. package/dist/esm/q2-dropdown.entry.js +8 -17
  118. package/dist/esm/q2-editable-field.entry.js +5 -8
  119. package/dist/esm/q2-icon.entry.js +3 -3
  120. package/dist/esm/q2-input.entry.js +439 -437
  121. package/dist/esm/q2-loading-element.entry.js +3 -3
  122. package/dist/esm/q2-loc.entry.js +2 -2
  123. package/dist/esm/q2-message.entry.js +5 -5
  124. package/dist/esm/q2-optgroup.entry.js +3 -3
  125. package/dist/esm/q2-option-list.entry.js +355 -0
  126. package/dist/esm/q2-option.entry.js +3 -11
  127. package/dist/esm/q2-pagination.entry.js +112 -0
  128. package/dist/esm/q2-pill.entry.js +133 -0
  129. package/dist/esm/q2-radio-group.entry.js +43 -18
  130. package/dist/esm/q2-radio.entry.js +21 -4
  131. package/dist/esm/q2-section.entry.js +5 -7
  132. package/dist/esm/q2-select.entry.js +23 -26
  133. package/dist/esm/q2-stepper-pane.entry.js +42 -4
  134. package/dist/esm/q2-stepper-vertical.entry.js +274 -0
  135. package/dist/esm/q2-stepper.entry.js +10 -12
  136. package/dist/esm/q2-tab-container.entry.js +12 -8
  137. package/dist/esm/q2-tab-pane.entry.js +1 -1
  138. package/dist/esm/q2-tag.entry.js +90 -0
  139. package/dist/esm/q2-tecton-elements.js +3 -3
  140. package/dist/esm/q2-textarea.entry.js +8 -8
  141. package/dist/esm/{shapes-81c11dfe.js → shapes-cff4e1f0.js} +9 -16
  142. package/dist/esm/tecton-tab-pane.entry.js +2 -5
  143. package/dist/loader/index.d.ts +0 -1
  144. package/dist/q2-tecton-elements/{p-75e87cca.entry.js → p-00e8f782.entry.js} +1 -1
  145. package/dist/q2-tecton-elements/p-0900bec1.entry.js +1 -0
  146. package/dist/q2-tecton-elements/p-10264ecb.entry.js +1 -0
  147. package/dist/q2-tecton-elements/p-123cdfb9.entry.js +1 -0
  148. package/dist/q2-tecton-elements/{p-fbf7c5e6.entry.js → p-1305ec5f.entry.js} +1 -1
  149. package/dist/q2-tecton-elements/p-148391d6.entry.js +1 -0
  150. package/dist/q2-tecton-elements/p-1dfaee64.entry.js +1 -0
  151. package/dist/q2-tecton-elements/{p-32ad664c.entry.js → p-221abbf6.entry.js} +1 -1
  152. package/dist/q2-tecton-elements/{p-c90a6016.js → p-255b2b4c.js} +1 -1
  153. package/dist/q2-tecton-elements/p-27736b6b.entry.js +1 -0
  154. package/dist/q2-tecton-elements/p-2846ab94.entry.js +1 -0
  155. package/dist/q2-tecton-elements/p-2bc1de01.entry.js +1 -0
  156. package/dist/q2-tecton-elements/{p-8ea2c4f7.entry.js → p-2c15414c.entry.js} +1 -1
  157. package/dist/q2-tecton-elements/p-2caa89fd.js +1 -0
  158. package/dist/q2-tecton-elements/p-327cca41.entry.js +1 -0
  159. package/dist/q2-tecton-elements/p-3a420dbf.entry.js +1 -0
  160. package/dist/q2-tecton-elements/p-3abcb09d.entry.js +1 -0
  161. package/dist/q2-tecton-elements/p-3fe98e3e.entry.js +1 -0
  162. package/dist/q2-tecton-elements/{p-bb2e110a.entry.js → p-430a979b.entry.js} +1 -1
  163. package/dist/q2-tecton-elements/{p-7e6fc65d.entry.js → p-45eb7739.entry.js} +1 -1
  164. package/dist/q2-tecton-elements/{p-750bcd33.entry.js → p-49b2abc4.entry.js} +1 -1
  165. package/dist/q2-tecton-elements/{p-9b50c3c3.entry.js → p-4ab30466.entry.js} +1 -1
  166. package/dist/q2-tecton-elements/p-50e218c7.entry.js +1 -0
  167. package/dist/q2-tecton-elements/p-5bbf2bfe.entry.js +1 -0
  168. package/dist/q2-tecton-elements/{p-ac859fcc.entry.js → p-6fec9235.entry.js} +1 -1
  169. package/dist/q2-tecton-elements/p-824aebd9.js +1 -0
  170. package/dist/q2-tecton-elements/p-a4ae89cc.entry.js +1 -0
  171. package/dist/q2-tecton-elements/{p-50967020.entry.js → p-a5562aaa.entry.js} +1 -1
  172. package/dist/q2-tecton-elements/p-ae4fed23.entry.js +1 -0
  173. package/dist/q2-tecton-elements/p-b2302cd3.entry.js +1 -0
  174. package/dist/q2-tecton-elements/p-c20cbb2d.entry.js +1 -0
  175. package/dist/q2-tecton-elements/p-ca7a3380.entry.js +1 -0
  176. package/dist/q2-tecton-elements/{p-a6f8d09a.entry.js → p-d33e152c.entry.js} +1 -1
  177. package/dist/q2-tecton-elements/{p-9024859f.entry.js → p-d5218cd6.entry.js} +1 -1
  178. package/dist/q2-tecton-elements/p-d52b435e.entry.js +1 -0
  179. package/dist/q2-tecton-elements/p-dd02cf8d.js +1 -0
  180. package/dist/q2-tecton-elements/{p-07a5d703.entry.js → p-e0e7ae8b.entry.js} +1 -1
  181. package/dist/q2-tecton-elements/{p-7e030e92.entry.js → p-ede12fc1.entry.js} +1 -1
  182. package/dist/q2-tecton-elements/{p-df182f61.entry.js → p-fdfbe75b.entry.js} +1 -1
  183. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js +1 -1
  184. package/dist/test/elements/q2-tag-test.js +151 -0
  185. package/dist/test/helpers.js +20 -9
  186. package/dist/types/components/q2-badge/index.d.ts +13 -0
  187. package/dist/types/components/q2-btn/index.d.ts +3 -3
  188. package/dist/types/components/q2-calendar/helpers.d.ts +1 -0
  189. package/dist/types/components/q2-calendar/index.d.ts +2 -1
  190. package/dist/types/components/q2-calendar/validation.d.ts +1 -1
  191. package/dist/types/components/q2-card/index.d.ts +35 -0
  192. package/dist/types/components/q2-checkbox/index.d.ts +3 -1
  193. package/dist/types/components/q2-checkbox-group/index.d.ts +1 -0
  194. package/dist/types/components/q2-dropdown/index.d.ts +1 -1
  195. package/dist/types/components/q2-editable-field/index.d.ts +1 -1
  196. package/dist/types/components/q2-input/formatting/credit-card.d.ts +1 -3
  197. package/dist/types/components/q2-input/index.d.ts +5 -2
  198. package/dist/types/components/q2-option/index.d.ts +2 -3
  199. package/dist/types/components/q2-option-list/index.d.ts +62 -0
  200. package/dist/types/components/q2-pagination/index.d.ts +30 -0
  201. package/dist/types/components/q2-pill/index.d.ts +39 -0
  202. package/dist/types/components/q2-radio/index.d.ts +4 -1
  203. package/dist/types/components/q2-radio-group/index.d.ts +5 -1
  204. package/dist/types/components/q2-select/index.d.ts +2 -1
  205. package/dist/types/components/q2-stepper/index.d.ts +1 -1
  206. package/dist/types/components/q2-stepper-pane/index.d.ts +16 -1
  207. package/dist/types/components/q2-stepper-vertical/index.d.ts +52 -0
  208. package/dist/types/components/q2-tab-container/index.d.ts +1 -1
  209. package/dist/types/components/q2-tag/index.d.ts +28 -0
  210. package/dist/types/components/tecton-tab-pane/index.d.ts +2 -2
  211. package/dist/types/components.d.ts +235 -11
  212. package/dist/types/global.d.ts +1 -0
  213. package/dist/types/stencil-public-runtime.d.ts +6 -4
  214. package/dist/types/util.d.ts +2 -10
  215. package/dist/types/utils/index.d.ts +1 -0
  216. package/dist/types/workspace/workspace/Tecton_tecton-production_master/packages/q2-tecton-elements/.stencil/test/elements/q2-tag-test.d.ts +1 -0
  217. package/dist/types/workspace/workspace/{_production_release_1.11.0-alpha → Tecton_tecton-production_master}/packages/q2-tecton-elements/.stencil/test/helpers.d.ts +6 -3
  218. package/package.json +13 -13
  219. package/dist/q2-tecton-elements/p-06fff43d.entry.js +0 -1
  220. package/dist/q2-tecton-elements/p-080839ed.js +0 -1
  221. package/dist/q2-tecton-elements/p-29a37091.entry.js +0 -1
  222. package/dist/q2-tecton-elements/p-37aba2a4.js +0 -1
  223. package/dist/q2-tecton-elements/p-4cd00f1a.js +0 -1
  224. package/dist/q2-tecton-elements/p-6702eb4d.entry.js +0 -1
  225. package/dist/q2-tecton-elements/p-768e3a5d.entry.js +0 -1
  226. package/dist/q2-tecton-elements/p-843b1ee9.entry.js +0 -1
  227. package/dist/q2-tecton-elements/p-943c7745.entry.js +0 -1
  228. package/dist/q2-tecton-elements/p-95a73559.entry.js +0 -1
  229. package/dist/q2-tecton-elements/p-9a977ee6.entry.js +0 -1
  230. package/dist/q2-tecton-elements/p-b281c349.entry.js +0 -1
  231. package/dist/q2-tecton-elements/p-c5e55b9f.entry.js +0 -1
  232. package/dist/q2-tecton-elements/p-ccbe9158.entry.js +0 -1
  233. package/dist/q2-tecton-elements/p-db6f90ac.entry.js +0 -1
  234. package/dist/q2-tecton-elements/p-fa6eea5c.entry.js +0 -1
@@ -0,0 +1,133 @@
1
+ import { r as registerInstance, c as createEvent, h, F as Fragment, g as getElement } from './index-dbfb3ecc.js';
2
+ import { o as overrideFocus, l as loc, i as isEventFromElement } from './index-0ff8de52.js';
3
+
4
+ const stylesCss = "*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-global-focus)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size: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:inline-block;position:relative}:host(:not(:last-child)){margin-inline-end:var(--tct-pill-margin, var(--t-pill-margin, var(--app-scale-2x, 10px)))}.btn-wrapper{--comp-pill-min-height:var(--tct-pill-min-height, var(--t-pill-min-height, 44px));--comp-pill-btn-border-width:var(--tct-pill-btn-border-width, var(--t-pill-btn-border-width, 2px));--comp-pill-btn-height:var(--tct-pill-btn-height, var(--t-pill-btn-height, 30px));--comp-close-size:0px;--comp-btn-background:var(--tct-pill-btn-background, var(--t-pill-btn-background, var(--t-base, #ffffff)));--compt-hover-btn-background:var(--tct-pill-hover-btn-background, var(--t-pill-hover-btn-background, var(--t-gray-13, #e6e6e6)));--comp-btn-padding:var(--tct-pill-btn-padding-inline, var(--t-pill-btn-padding-inline, var(--app-scale-3x, 15px)));--comp-btn-color:var(--tct-pill-btn-color, var(--t-pill-btn-color, var(--t-gray-3, #262626)));--comp-active-btn-background:var(--tct-pill-active-btn-background, var(--t-pill-active-btn-background, var(--t-gray-7, #666666)));--comp-active-btn-border-color:var(--tct-pill-active-btn-border-color, var(--t-pill-active-btn-border-color, var(--t-gray-7, #666666)));--comp-hover-active-btn-background:var(--tct-pill-active-btn-background, var(--t-pill-active-btn-background, var(--t-gray-6, #4d4d4d)));--comp-hover-active-btn-border-color:var(--tct-pill-active-btn-background, var(--t-pill-active-btn-background, var(--t-gray-6, #4d4d4d)));position:relative}:host(:not(:empty)) .btn-wrapper,.btn-wrapper.has-icon{--comp-close-size:var(--comp-pill-btn-height)}:host([active]) .btn-wrapper{--comp-btn-color:var(--tct-pill-active-btn-color, var(--t-pill-active-btn-color, var(--t-base, #ffffff)))}:host([theme=primary]) .btn-wrapper{--comp-active-btn-background:var(--t-primary-l5, #61c4ff);--comp-btn-color:var(--t-primary-text, #ffffff);--comp-active-btn-border-color:var(--t-primary-l5, #61c4ff);--comp-hover-active-btn-background:var(--t-primary-l3, #21acff);--comp-hover-active-btn-border-color:var(--t-primary-l3, #21acff)}:host([theme=secondary]) .btn-wrapper{--comp-active-btn-background:var(--t-secondary-l5, #61c4ff);--comp-btn-color:var(--t-secondary-text, #000000);--comp-active-btn-border-color:var(--t-secondary-l5, #61c4ff);--comp-hover-active-btn-background:var(--t-secondary-l3, #21acff);--comp-hover-active-btn-border-color:var(--t-secondary-l3, #21acff)}:host([theme=tertiary]) .btn-wrapper{--comp-active-btn-background:var(--t-tertiary-l5, #61c4ff);--comp-btn-color:var(--t-tertiary-text, #000000);--comp-active-btn-border-color:var(--t-tertiary-l5, #61c4ff);--comp-hover-active-btn-background:var(--t-tertiary-l3, #21acff);--comp-hover-active-btn-border-color:var(--t-tertiary-l3, #21acff)}q2-option-list{position:absolute;left:0}.btn-height-wrapper{height:var(--comp-pill-min-height);display:flex;align-items:center;cursor:pointer}.btn-height-wrapper:focus{box-shadow:none}:host([disabled]) .btn-height-wrapper{cursor:not-allowed}.btn-close,.btn-primary{cursor:pointer;height:var(--comp-pill-btn-height);border-style:solid;border-radius:var(--tct-pill-btn-border-radius, var(--t-pill-btn-border-radius, 30px));transition-property:background, color, padding, width, opacity;transition:var(--tct-pill-btn-tween, var(--t-pill-btn-tween, var(--app-tween-1, 0.2s ease)))}:host([disabled]) .btn-close,:host([disabled]) .btn-primary,:host([disabled]) q2-icon{opacity:var(--tct-pill-disabled-opacity, var(--t-pill-disabled-opacity, var(--tct-disabled-opacity, var(--app-disabled-opacity, 0.4))));cursor:not-allowed}.btn-primary{background:var(--comp-btn-background);border-width:var(--comp-pill-btn-border-width);border-color:var(--tct-pill-btn-border-color, var(--t-pill-btn-border-color, var(--t-gray-9, #999999)));padding-inline:var(--comp-btn-padding);padding-right:calc(var(--comp-btn-padding) + var(--comp-close-size));font-size:var(--tct-pill-btn-font-size, var(--t-pill-btn-font-size, var(--app-font-size, 14px)));color:var(--comp-btn-color);display:block;width:100%;text-align:start}.btn-primary:focus,.btn-primary:hover{background:var(--comp-hover-btn-background)}:host(:not(:empty)) .btn-primary,.has-icon .btn-primary{padding-right:calc(\n var(--tct-pill-icon-gap, var(--t-pill-icon-gap, var(--app-size-1x, 5px))) + var(--comp-close-size)\n )}.has-options .btn-primary{text-overflow:ellipsis;overflow:hidden;white-space:nowrap;max-width:var(--tct-pill-max-width, var(--t-pill-max-width, 200px))}:host([active]) .btn-primary{background:var(--comp-active-btn-background);border-color:var(--comp-active-btn-border-color)}:host([active]) .btn-primary:focus,:host([active]) .btn-primary:hover{background:var(--comp-hover-active-btn-background);border-color:var(--comp-hover-active-btn-border-color)}.btn-close{background:transparent;border-color:transparent;border-width:var(--comp-pill-btn-border-width);width:var(--comp-close-size);height:var(--comp-close-size);padding:0;border:0;display:inline-flex;justify-content:center;align-items:center;position:absolute;right:0;top:50%;transform:translateY(-50%);opacity:0;stroke:var(--comp-btn-color);--tct-icon-stroke-primary:var(--comp-btn-color)}:host(:not(:empty)) .btn-close,.has-icon .btn-close{opacity:1}q2-icon{width:var(--tct-pill-icon-size, var(--t-pill-icon-size, 14px));height:var(--tct-pill-icon-size, var(--t-pill-icon-size, 14px));transition-property:transform;transition:var(--tct-pill-btn-tween, var(--t-pill-btn-tween, var(--app-tween-1, 0.2s ease)))}div.btn-close{pointer-events:none}:host([open]) div.btn-close q2-icon{transform:rotate(180deg)}:host([active]) button.btn-close:focus,:host([active]) button.btn-close:hover{background:var(--tct-pill-hover-close-btn-background, var(--t-pill-hover-close-btn-background, var(--t-top-a1, rgba(13, 13, 13, 0.35))));border-color:var(--tct-pill-hover-close-btn-border-color, var(--t-pill-hover-close-btn-border-color, var(--t-top-a1, rgba(13, 13, 13, 0.35))))}";
5
+
6
+ const Q2Pill = class {
7
+ constructor(hostRef) {
8
+ registerInstance(this, hostRef);
9
+ this.change = createEvent(this, "change", 7);
10
+ this.selectedOptions = [];
11
+ this.scheduledAfterRender = [];
12
+ /// Helpers ///
13
+ this.determineHasOptions = () => {
14
+ const hasOptions = !!this.hostElement.querySelectorAll('q2-option').length;
15
+ this.hasOptions = hasOptions;
16
+ };
17
+ this.clearSelectedOptions = () => {
18
+ this.selectedOptions = [];
19
+ this.active = false;
20
+ this.open = false;
21
+ this.primaryBtn.focus();
22
+ this.change.emit({ value: null, values: [], active: false });
23
+ };
24
+ /// Event Handlers ///
25
+ this.handleClick = (event) => {
26
+ event.stopPropagation();
27
+ if (this.disabled)
28
+ return;
29
+ if (this.hasOptions) {
30
+ this.optionList.toggle();
31
+ }
32
+ else {
33
+ const { value, label } = this;
34
+ const isActive = (this.active = !this.active);
35
+ const values = isActive ? [{ value, display: label }] : [];
36
+ this.selectedOptions = values;
37
+ this.change.emit({
38
+ value,
39
+ values,
40
+ active: isActive,
41
+ });
42
+ }
43
+ };
44
+ this.handleKeydown = (event) => {
45
+ if (!this.hasOptions || this.disabled)
46
+ return;
47
+ this.optionList.handleExternalKeydown(event);
48
+ };
49
+ this.handleChange = event => {
50
+ if (!this.hasOptions)
51
+ return;
52
+ const { value, values } = event.detail;
53
+ const isActive = !!values.length;
54
+ if (!this.hostElement.onchange) {
55
+ this.selectedOptions = values;
56
+ this.active = isActive;
57
+ }
58
+ this.change.emit({ value, values, active: isActive });
59
+ };
60
+ this.handleFocusout = (event) => {
61
+ const relatedTarget = event.relatedTarget;
62
+ if (Array.from(this.hostElement.children).includes(relatedTarget))
63
+ return;
64
+ if (relatedTarget && !(event.relatedTarget instanceof HTMLElement))
65
+ return;
66
+ if (relatedTarget && relatedTarget.closest('.btn-height-wrapper'))
67
+ return;
68
+ this.optionList.open = false;
69
+ };
70
+ this.handleWrapperClick = () => {
71
+ this.primaryBtn.focus();
72
+ this.primaryBtn.click();
73
+ };
74
+ }
75
+ /// LifeCycle Hooks ///
76
+ componentWillLoad() {
77
+ const observer = new MutationObserver(this.determineHasOptions);
78
+ observer.observe(this.hostElement, { childList: true, attributes: true });
79
+ this.mutationObserver = observer;
80
+ }
81
+ componentDidLoad() {
82
+ overrideFocus(this.hostElement);
83
+ }
84
+ componentDidRender() {
85
+ this.scheduledAfterRender.forEach(fn => fn());
86
+ this.scheduledAfterRender = [];
87
+ }
88
+ disconnectedCallback() {
89
+ this.mutationObserver.disconnect();
90
+ this.mutationObserver = null;
91
+ }
92
+ /// Getters ///
93
+ get buttonContent() {
94
+ const { label, selectedOptions, hasOptions } = this;
95
+ if (!hasOptions || selectedOptions.length === 0)
96
+ return label;
97
+ else if (selectedOptions.length === 1)
98
+ return selectedOptions[0].display;
99
+ return loc('tecton.element.pill.activeCount', { count: selectedOptions.length });
100
+ }
101
+ /// Listeners ///
102
+ delegateFocus(event) {
103
+ if (!isEventFromElement(event, this.hostElement))
104
+ return;
105
+ this.primaryBtn.focus();
106
+ }
107
+ optionListStateEvent({ detail: { open } }) {
108
+ this.open = open;
109
+ if (!open)
110
+ this.primaryBtn.focus();
111
+ }
112
+ /// DOM ///
113
+ generateIcon() {
114
+ const { hasOptions, active } = this;
115
+ const isButton = hasOptions && active;
116
+ const TagName = isButton ? 'button' : 'div';
117
+ const iconName = isButton || !hasOptions ? 'close' : 'chevron-down';
118
+ return (h(TagName, { class: "btn-close", onClick: isButton && this.clearSelectedOptions, disabled: isButton && this.disabled, "aria-label": isButton && loc('tecton.element.pill.clearSelection'), type: isButton && 'button' }, h("q2-icon", { type: iconName })));
119
+ }
120
+ render() {
121
+ const { hasOptions, active, open } = this;
122
+ const wrapperClassNames = ['btn-wrapper'];
123
+ if (hasOptions || active)
124
+ wrapperClassNames.push('has-icon');
125
+ if (hasOptions)
126
+ wrapperClassNames.push('has-options');
127
+ return (h(Fragment, null, h("div", { class: wrapperClassNames.join(' ') }, h("div", { class: "btn-height-wrapper", onClick: this.handleWrapperClick, tabIndex: -1 }, h("button", { class: "btn-primary", type: "button", "test-id": "btn-control", ref: el => (this.primaryBtn = el), onClick: this.handleClick, onKeyDown: this.handleKeydown, disabled: this.disabled, onFocusout: this.handleFocusout, "aria-selected": !hasOptions && active ? 'true' : 'false', "aria-roledescription": !hasOptions && 'filter', "aria-controls": hasOptions && 'option-list', "aria-haspopup": hasOptions && 'true', "aria-expanded": hasOptions && open ? 'true' : 'false' }, this.buttonContent, !hasOptions && active && h("span", { class: "sr" }, "(", loc('tecton.element.pill.active'), ")"))), this.generateIcon()), this.hasOptions && (h("q2-option-list", { id: "option-list", ref: el => (this.optionList = el), open: this.open, onChange: this.handleChange, multiple: this.multiple, onFocusout: this.handleFocusout, selectedOptions: this.selectedOptions }, h("slot", null)))));
128
+ }
129
+ get hostElement() { return getElement(this); }
130
+ };
131
+ Q2Pill.style = stylesCss;
132
+
133
+ export { Q2Pill as q2_pill };
@@ -1,5 +1,5 @@
1
- import { r as registerInstance, c as createEvent, h, g as getElement } from './index-be8376c0.js';
2
- import { c as createGuid, o as overrideFocus, i as isEventFromElement, l as loc } from './index-ec6660af.js';
1
+ import { r as registerInstance, c as createEvent, h, F as Fragment, g as getElement } from './index-dbfb3ecc.js';
2
+ import { c as createGuid, o as overrideFocus, i as isEventFromElement, l as loc } from './index-0ff8de52.js';
3
3
 
4
4
  const stylesCss = "*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-global-focus)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size: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{margin-top:var(--tct-scale-2, var(--app-scale-2, 10px))}fieldset{padding:0;margin:0;border:0}fieldset.has-error{border-color:var(--tct-input-error-border-color, var(--const-stoplight-alert, #c30000));border-width:1px;border-style:solid;border-radius:var(--tct-border-radius-1, var(--app-border-radius-1, 2px));position:relative}fieldset.has-error .error-icon-container{top:8px;right:8px;position:absolute;width:40%;text-align:right;background:linear-gradient(to right, transparent, white)}fieldset.has-error legend+div.error-icon-container.no-label{top:28px}.group-legend{font-weight:600}legend.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;border:0}.optional-tag{margin-left:var(--tct-input-label-optional-margin-left, var(--t-input-label-optional-margin-left, var(--tct-scale-1, var(--app-scale-1, 5px))));color:var(--tct-input-label-optional-font-color, var(--t-input-label-optional-font-color, var(--t-textA, var(--t-a11y-gray-color, rgba(77, 77, 77, 0.77)))));font-size:var(--tct-input-label-optional-font-size, var(--t-input-label-optional-font-size, 12px));font-weight:var(--tct-input-label-optional-font-weight, var(--t-input-label-optional-font-weight, 400))}.flexed{margin:0;display:flex;flex-wrap:wrap;align-items:center;justify-content:center}.flexed.left{justify-content:left}.flexed.right{justify-content:right}";
5
5
 
@@ -12,13 +12,16 @@ const Q2RadioGroup = class {
12
12
  this.hasError = false;
13
13
  this.id = `radio-group-${createGuid()}`;
14
14
  this.onMutationObserved = () => {
15
- this.valueUpdated();
15
+ this.valueUpdated(this.value);
16
16
  this.nameUpdated();
17
17
  this.disabledUpdated();
18
+ this.readonlyUpdated();
18
19
  this.tileLayoutUpdated();
19
20
  };
20
21
  this.onInnerRadioChange = (event) => {
21
22
  event.stopImmediatePropagation();
23
+ if (this.readonly)
24
+ return;
22
25
  this.change.emit({ value: event.detail.value });
23
26
  };
24
27
  }
@@ -26,17 +29,19 @@ const Q2RadioGroup = class {
26
29
  return Array.from(this.hostElement.querySelectorAll('q2-radio'));
27
30
  }
28
31
  /////// LIFECYCLE HOOK ///////
32
+ componentWillLoad() {
33
+ this.onMutationObserved();
34
+ }
29
35
  componentDidLoad() {
30
36
  const observer = new MutationObserver(this.onMutationObserved);
31
37
  observer.observe(this.hostElement, { childList: true });
32
38
  this.mutationObserver = observer;
33
- this.onMutationObserved();
34
39
  overrideFocus(this.hostElement);
35
40
  }
36
41
  /////// OBSERVERS ///////
37
- valueUpdated() {
42
+ valueUpdated(newVal) {
38
43
  this.radioElements.forEach(radio => {
39
- radio.checked = this.value === radio.value;
44
+ radio.checked = newVal === radio.value;
40
45
  });
41
46
  }
42
47
  nameUpdated() {
@@ -49,6 +54,10 @@ const Q2RadioGroup = class {
49
54
  radio.groupDisabled = this.disabled;
50
55
  });
51
56
  }
57
+ readonlyUpdated() {
58
+ const readonly = this.readonly;
59
+ this.radioElements.forEach(radio => (radio.groupReadonly = readonly));
60
+ }
52
61
  tileLayoutUpdated() {
53
62
  this.radioElements.forEach(radio => {
54
63
  radio.groupTileLayout = this.tilelayout;
@@ -64,19 +73,22 @@ const Q2RadioGroup = class {
64
73
  delegateFocus(event) {
65
74
  if (!isEventFromElement(event, this.hostElement))
66
75
  return;
67
- const radio = this.hostElement.querySelector('q2-radio[checked]') ||
68
- this.hostElement.querySelector('q2-radio');
76
+ const radio = this.hostElement.querySelector('q2-radio[checked]') || this.hostElement.querySelector('q2-radio');
69
77
  radio === null || radio === void 0 ? void 0 : radio.dispatchEvent(new FocusEvent('focus'));
70
78
  }
71
79
  keydownHandler(event) {
72
80
  const currentValue = event.target.getAttribute('value') || this.value;
73
81
  let index = this.radioElements.findIndex(el => el === event.target || el.getAttribute('value') === currentValue);
74
82
  let sign = 0;
75
- if (['ArrowLeft', 'Left', 'ArrowUp', 'Up'].includes(event.key)) {
76
- sign = -1;
77
- }
78
- else if (['ArrowRight', 'Right', 'ArrowDown', 'Down'].includes(event.key)) {
79
- sign = 1;
83
+ switch (event.key) {
84
+ case 'ArrowLeft':
85
+ case 'ArrowUp':
86
+ sign = -1;
87
+ break;
88
+ case 'ArrowRight':
89
+ case 'ArrowDown':
90
+ sign = 1;
91
+ break;
80
92
  }
81
93
  if (index === -1 || sign === 0) {
82
94
  return;
@@ -84,18 +96,30 @@ const Q2RadioGroup = class {
84
96
  index += sign;
85
97
  index = sign < 0 ? Math.max(0, index) : Math.min(this.radioElements.length - 1, index);
86
98
  event.preventDefault();
87
- this.value = this.radioElements[index].value;
99
+ if (!this.readonly) {
100
+ this.value = this.radioElements[index].value;
101
+ }
88
102
  this.radioElements[index].dispatchEvent(new FocusEvent('focus'));
89
103
  }
104
+ labelDOM() {
105
+ const { label, optional, readonly } = this;
106
+ let helpText = '';
107
+ if (readonly) {
108
+ helpText = h("span", { class: "optional-tag" }, loc('tecton.element.input.readonly'));
109
+ }
110
+ else if (optional) {
111
+ helpText = h("span", { class: "optional-tag" }, loc('tecton.element.input.optional'));
112
+ }
113
+ return (h(Fragment, null, label && loc(label), !!helpText && h("span", { class: "optional-tag" }, helpText)));
114
+ }
90
115
  render() {
91
- return (h("div", null, this.label || this.optional ? (h("div", { class: "group-legend" }, this.label && loc(this.label), this.optional ? (h("span", { class: "optional-tag" }, loc('tecton.element.input.optional'))) : (''))) : (''), h("fieldset", { class: `q2-radio-fieldset ${this.hasError ? 'has-error' : ''}`, onChange: this.onInnerRadioChange, "aria-required": `${!this.optional}` }, this.label || this.optional ? (h("legend", { class: "sr-only" }, this.label && loc(this.label), this.optional ? (h("span", { class: "optional-tag" }, loc('tecton.element.input.optional'))) : (''))) : (''), this.hasError ? (h("div", { class: `error-icon-container ${this.label || this.optional ? '' : 'no-label'}` }, h("q2-icon", { class: "h(4) w(4) mrg-b(2)", type: "error" }))) : (''), this.inputDom())));
116
+ const showLabel = this.label || this.optional || this.readonly;
117
+ return (h("div", null, showLabel && h("div", { class: "group-legend" }, this.labelDOM()), h("fieldset", { class: `q2-radio-fieldset ${this.hasError ? 'has-error' : ''}`, onChange: this.onInnerRadioChange, "aria-required": `${!this.optional}`, "aria-readonly": `${this.readonly}` }, showLabel && h("legend", { class: "sr-only" }, this.labelDOM()), this.hasError ? (h("div", { class: `error-icon-container ${!showLabel && 'no-label'}` }, h("q2-icon", { class: "h(4) w(4) mrg-b(2)", type: "error" }))) : (''), this.inputDom())));
92
118
  }
93
119
  inputDom() {
94
120
  if (this.tilelayout) {
95
121
  const { tileAlignment } = this;
96
- const alignment = ['left', 'center', 'right'].includes(tileAlignment)
97
- ? tileAlignment
98
- : 'center';
122
+ const alignment = ['left', 'center', 'right'].includes(tileAlignment) ? tileAlignment : 'center';
99
123
  return (h("div", { class: `flexed ${alignment}` }, h("slot", null)));
100
124
  }
101
125
  else {
@@ -107,6 +131,7 @@ const Q2RadioGroup = class {
107
131
  "value": ["valueUpdated"],
108
132
  "name": ["nameUpdated"],
109
133
  "disabled": ["disabledUpdated"],
134
+ "readonly": ["readonlyUpdated"],
110
135
  "tilelayout": ["tileLayoutUpdated"]
111
136
  }; }
112
137
  };
@@ -1,5 +1,5 @@
1
- import { r as registerInstance, c as createEvent, h, g as getElement } from './index-be8376c0.js';
2
- import { c as createGuid, h as handleAriaLabel, o as overrideFocus, l as loc } from './index-ec6660af.js';
1
+ import { r as registerInstance, c as createEvent, h, g as getElement } from './index-dbfb3ecc.js';
2
+ import { c as createGuid, h as handleAriaLabel, o as overrideFocus, l as loc } from './index-0ff8de52.js';
3
3
 
4
4
  const stylesCss = "*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-global-focus)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size: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{margin-top:var(--tct-radio-margin-vertical, var(--tct-scale-2, 10px));margin-right:var(--tct-radio-margin-horizontal, var(--tct-scale-3, 15px));display:block}:host .radio-container{margin-bottom:var(--tct-radio-margin-vertical, var(--tct-scale-2, 10px))}:host .radio-container label[for]{font-weight:var(--tct-radio-font-weight, var(--tct-checkbox-font-weight, 400));align-items:center;cursor:pointer;margin-right:1rem;display:grid;grid-template-columns:18px 1fr;gap:var(--tct-scale-1, var(--app-scale-1, 5px))}:host .radio-container svg{border-radius:50%;transition:box-shadow var(--tct-tween-1, var(--app-tween-1, 0.2s ease));outline:0;width:100%}:host .radio-container circle:nth-child(1){stroke-width:2;stroke:var(--tct-radio-stroke-color, var(--tct-gray-11, var(--t-gray-11, var(--tct-gray-l1, var(--app-gray-l1, #cccccc)))))}:host .radio-container input:focus+label svg{box-shadow:var(--tct-global-focus, var(--const-global-focus, 0 0 0 2px #33b4ff))}:host .radio-container input:focus+label circle:nth-child(1){stroke:var(--tct-radio-focus-stroke-color, var(--tct-checkbox-check-stroke-color, var(--t-checkbox-fill, #2e2e2e)))}:host .radio-container input:checked+label circle:nth-child(1){background-color:var(--tct-radio-checked-bg, transparent);stroke:var(--tct-radio-checked-stroke-color, var(--tct-radio-stroke-color, var(--tct-gray-11, var(--t-gray-11, var(--tct-gray-l1, var(--app-gray-l1, #cccccc))))))}:host .radio-container input:checked+label .label-content{font-weight:var(--tct-checkbox-selected-font-weight, 600);letter-spacing:var(--tct-checkbox-selected-letter-spacing, 0.25)}:host .radio-container input:checked+label circle:nth-child(2){fill:var(--tct-radio-checked-fill, var(--tct-checkbox-check-stroke-color, var(--t-checkbox-fill, #2e2e2e)))}:host .radio-tile{flex-basis:100px;flex-grow:0;flex-wrap:wrap}:host .radio-tile label[for]{align-items:center;border-radius:3px;border:2px solid var(--tct-radio-stroke-color, var(--tct-gray-11, var(--t-gray-11, var(--tct-gray-l1, var(--app-gray-l1, #cccccc)))));cursor:pointer;display:block;padding:1rem;position:relative;text-align:center;transition:border-color var(--tct-tween-1, var(--app-tween-1, 0.2s ease));white-space:nowrap}:host .radio-tile input:focus+label{border-color:#0079c1;box-shadow:var(--tct-global-focus, var(--const-global-focus, 0 0 0 2px #33b4ff))}:host .radio-tile input:checked+label{border-color:var(--tct-checkbox-check-stroke-color, var(--t-checkbox-fill, #2e2e2e));box-shadow:inset 0 0 0 2px #ffffff}:host .radio-tile input:checked+label:after{border-bottom-width:3px;border-bottom:5px solid #0079c1;border-left-width:5px;border-left:8px solid transparent;border-right-width:5px;border-right:8px solid transparent;bottom:0;content:\"\";height:0;left:50%;margin-left:-5px;position:absolute;width:0}:host input:disabled+label{cursor:not-allowed;opacity:var(--tct-disabled-opacity, var(--app-disabled-opacity, 0.4))}";
5
5
 
@@ -10,11 +10,19 @@ const Q2Radio = class {
10
10
  this.disabled = false;
11
11
  this.checked = false;
12
12
  this.groupDisabled = false;
13
+ this.groupReadonly = false;
13
14
  this.groupTileLayout = false;
14
15
  this.id = `radio-${createGuid()}`;
16
+ this.isLoaded = false;
15
17
  this.inputChange = (event) => {
16
18
  event.stopPropagation();
17
- this.change.emit({ value: this.value });
19
+ if (this.groupReadonly) {
20
+ event.preventDefault();
21
+ return false;
22
+ }
23
+ if (event.target instanceof HTMLInputElement) {
24
+ this.checked = event.target.checked;
25
+ }
18
26
  };
19
27
  }
20
28
  ////////// LIFECYCLE HOOKS ////////
@@ -22,12 +30,20 @@ const Q2Radio = class {
22
30
  handleAriaLabel(this);
23
31
  }
24
32
  componentDidLoad() {
33
+ this.isLoaded = true;
25
34
  overrideFocus(this.hostElement);
26
35
  }
27
36
  ////////// OBSERVERS //////////
28
37
  ariaLabelObserver() {
29
38
  handleAriaLabel(this);
30
39
  }
40
+ checkedObserver() {
41
+ if (!this.isLoaded)
42
+ return;
43
+ if (!this.checked)
44
+ return;
45
+ this.change.emit({ value: this.value });
46
+ }
31
47
  /////// HOST ELEMENT EVENTS ///////
32
48
  onHostClick(event) {
33
49
  if (this.disabled) {
@@ -44,7 +60,8 @@ const Q2Radio = class {
44
60
  }
45
61
  get hostElement() { return getElement(this); }
46
62
  static get watchers() { return {
47
- "ariaLabel": ["ariaLabelObserver"]
63
+ "ariaLabel": ["ariaLabelObserver"],
64
+ "checked": ["checkedObserver"]
48
65
  }; }
49
66
  };
50
67
  Q2Radio.style = stylesCss;
@@ -1,5 +1,5 @@
1
- import { r as registerInstance, c as createEvent, h, g as getElement } from './index-be8376c0.js';
2
- import { c as createGuid, o as overrideFocus, i as isEventFromElement, l as loc } from './index-ec6660af.js';
1
+ import { r as registerInstance, c as createEvent, h, g as getElement } from './index-dbfb3ecc.js';
2
+ import { c as createGuid, o as overrideFocus, i as isEventFromElement, l as loc } from './index-0ff8de52.js';
3
3
 
4
4
  const stylesCss = "*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-global-focus)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size: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}@keyframes expandVertical{0%{height:0}}@keyframes collapseVertical{100%{height:0}}:host{display:block;background-color:var(--tct-section-bg, var(--t-section-bg, var(--tct-white, var(--app-white, #ffffff))));color:var(--tct-section-font-color, var(--t-section-font-color, #2e2e2e));border-radius:var(--tct-section-border-radius, var(--t-section-border-radius, 3px));margin:var(--tct-scale-3, var(--app-scale-3, 15px))}@media screen and (max-width: 767px){:host{margin:var(--tct-scale-3, var(--app-scale-3, 15px)) 0}}.q2-section-wrapper{display:block;padding:var(--tct-scale-1, var(--app-scale-1, 5px)) 0}.q2-section-wrapper:hover{box-shadow:var(--tct-section-wrapper-hover-box-shadow, inherit)}.q2-section-header{padding:0 var(--tct-scale-3, var(--app-scale-3, 15px));display:flex}.has-header .q2-section-header{min-height:44px}.q2-section-header-content{flex:1 1 100%;min-width:0;align-self:center}.collapsible .q2-section-header-content{cursor:pointer}.title{margin:0;font-size:20px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px}.toggle-icon{transition:transform var(--tct-tween-1, var(--app-tween-1, 0.2s ease))}.collapsed .toggle-icon{transform:rotate(180deg)}.q2-section-content-wrapper{height:auto}.q2-section-content{padding:var(--tct-scale-2, var(--app-scale-2, 10px)) var(--tct-scale-3, var(--app-scale-3, 15px))}.q2-section-content:focus{box-shadow:none}.expanded.animate .q2-section-content-wrapper{animation:expandVertical var(--tct-tween-2, var(--app-tween-2, 0.4s ease)) forwards}.collapsed .q2-section-content-wrapper{height:0;animation:collapseVertical 0s forwards;animation-duration:0;padding-top:0;visibility:hidden;overflow:hidden}.collapsed.animate .q2-section-content-wrapper{animation:collapseVertical var(--tct-tween-1, var(--app-tween-1, 0.2s ease)) forwards}.animate .q2-section-content-wrapper{overflow:hidden}";
5
5
 
@@ -16,7 +16,7 @@ const Q2Section = class {
16
16
  this.onHeaderClick = () => {
17
17
  this.collapsible &&
18
18
  this.change.emit({
19
- expanded: !this.expanded
19
+ expanded: !this.expanded,
20
20
  });
21
21
  };
22
22
  this.onAnimationStart = () => {
@@ -84,9 +84,7 @@ const Q2Section = class {
84
84
  };
85
85
  }
86
86
  resizeIframe() {
87
- return (window.TectonElements &&
88
- window.TectonElements.resizeIframe &&
89
- window.TectonElements.resizeIframe());
87
+ return window.TectonElements && window.TectonElements.resizeIframe && window.TectonElements.resizeIframe();
90
88
  }
91
89
  componentWillLoad() {
92
90
  this.onHeaderSlotChange();
@@ -157,7 +155,7 @@ const Q2Section = class {
157
155
  }
158
156
  }
159
157
  render() {
160
- return (h("section", { class: this.wrapperClasses }, h("div", { class: "q2-section-header" }, h("div", { class: "q2-section-header-content", id: this.titleId, onClick: this.onHeaderClick }, !this.hasYieldedHeader && !!this.label ? (h("h2", { class: "title" }, loc(this.label))) : (''), h("div", { class: "q2-section-header-slot-wrapper" }, h("slot", { name: "q2-section-header" }))), this.collapsible && !this.noCollapseIcon ? (h("q2-btn", { class: `q2-section-content-toggle ${this.expanded ? 'expanded' : 'collapsed'}`, label: this.label, ariaExpanded: !!this.expanded, ariaControls: this.contentId, "test-id": "toggleButton", "hide-label": true, onClick: this.onHeaderClick }, h("q2-icon", { type: "chevron-up", class: "toggle-icon" }))) : ('')), h("div", { class: "q2-section-content-wrapper", id: this.contentId, "aria-labelledby": this.titleId, role: "region", onAnimationStart: this.onAnimationStart, onAnimationEnd: this.onAnimationEnd }, h("div", { class: "q2-section-content", tabindex: "-1" }, h("slot", null)))));
158
+ return (h("section", { class: this.wrapperClasses }, h("div", { class: "q2-section-header" }, h("div", { class: "q2-section-header-content", id: this.titleId, onClick: this.onHeaderClick }, !this.hasYieldedHeader && !!this.label ? h("h2", { class: "title" }, loc(this.label)) : '', h("div", { class: "q2-section-header-slot-wrapper" }, h("slot", { name: "q2-section-header" }))), this.collapsible && !this.noCollapseIcon ? (h("q2-btn", { class: `q2-section-content-toggle ${this.expanded ? 'expanded' : 'collapsed'}`, label: this.label, ariaExpanded: `${!!this.expanded}`, ariaControls: this.contentId, "test-id": "toggleButton", "hide-label": true, onClick: this.onHeaderClick }, h("q2-icon", { type: "chevron-up", class: "toggle-icon" }))) : ('')), h("div", { class: "q2-section-content-wrapper", id: this.contentId, "aria-labelledby": this.titleId, role: "region", onAnimationStart: this.onAnimationStart, onAnimationEnd: this.onAnimationEnd }, h("div", { class: "q2-section-content", tabindex: "-1" }, h("slot", null)))));
161
159
  }
162
160
  get hostElement() { return getElement(this); }
163
161
  static get watchers() { return {
@@ -1,5 +1,5 @@
1
- import { r as registerInstance, c as createEvent, h, g as getElement } from './index-be8376c0.js';
2
- import { c as createGuid, s as setPopProperties, l as loc, h as handleAriaLabel, o as overrideFocus, i as isEventFromElement } from './index-ec6660af.js';
1
+ import { r as registerInstance, c as createEvent, h, g as getElement } from './index-dbfb3ecc.js';
2
+ import { c as createGuid, s as setPopProperties, l as loc, h as handleAriaLabel, o as overrideFocus, i as isEventFromElement } from './index-0ff8de52.js';
3
3
 
4
4
  const stylesCss = "*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-global-focus)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size: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}.q2-element-dropdown{display:none;position:absolute;background-color:var(--app-white);color:var(--t-font-color);left:0;width:100%;z-index:100;margin-top:1px;box-shadow:var(--app-shadow-1);height:0;overflow:hidden;opacity:0;visibility:hidden;transition:opacity var(--app-tween-1);border-radius:var(--tct-dropdown-border-radius, --t-dropdown-border-radius, 0);--comp-scrollbar-size:var(--tct-scrollbar-size, var(--t-scrollbar-size, var(--app-scale-1x, 5px)));--comp-scrollbar-border-radius:var(--tct-scrollbar-border-radius, var(--t-scrollbar-border-radius, var(--app-border-radius-1, 3px)));--comp-scrollbar-color:var(--tct-scrollbar-color, var(--t-scrollbar-color, var(--t-a11y-gray-color, #747474)));scrollbar-width:thin;scrollbar-color:var(--comp-scrollbar-color) transparent}.q2-element-dropdown::-webkit-scrollbar{width:var(--comp-scrollbar-size);height:var(--comp-scrollbar-size);margin:5px}.q2-element-dropdown::-webkit-scrollbar-thumb{background:var(--comp-scrollbar-color);border-radius:var(--comp-scrollbar-border-radius)}.q2-element-dropdown::-webkit-scrollbar-track{background:transparent;border-radius:var(--comp-scrollbar-border-radius)}.q2-element-dropdown.sizable{display:block;height:auto}.dropdown-open .q2-element-dropdown{display:block;height:auto;overflow:auto;opacity:1;visibility:visible}:host([alignment=right]) .q2-element-dropdown{left:auto;right:0}:host{display:block;margin-top:var(--tct-select-margin-top, var(--app-scale-4, 30px));margin-bottom:var(--tct-select-margin-bottom, var(--app-scale-4, 30px))}.q2-select-container{position:relative;display:block}.q2-select-input{margin:0}.custom-display-content{position:absolute;bottom:0;left:calc(var(--tct-scale-2, var(--app-scale-2, 10px)) + 1px);height:44px;width:calc(100% - 34px - var(--tct-scale-3, var(--app-scale-3, 15px)));overflow:hidden;cursor:pointer;transition:left var(--tct-tween-2, var(--app-tween-1, 0.2s ease))}.custom-display-content:not([hidden]){display:flex;align-items:center}.is-searchable.is-focused .custom-display-content,.is-searchable .custom-display-content:active{left:calc(var(--tct-scale-3, var(--app-scale-3, 15px)) + 1px)}.has-error .custom-display-content{width:calc(100% - 68px - var(--tct-scale-3, var(--app-scale-3, 15px)))}.dropdown-open .q2-select-dropdown{overflow-y:auto;max-height:300px}.multi-select-header{padding:var(--tct-scale-1, var(--app-scale-1, 5px)) var(--tct-scale-2, var(--app-scale-2, 10px))}.show-all-options{margin-right:var(--tct-scale-1, var(--app-scale-1, 5px));margin-left:var(--tct-scale-2, var(--app-scale-2, 10px))}.q2-element-dropdown.dropup{bottom:40px}";
5
5
 
@@ -10,6 +10,7 @@ const Q2Select = class {
10
10
  this.input = createEvent(this, "input", 7);
11
11
  this.selectedOptions = [];
12
12
  this.disabled = false;
13
+ this.readonly = false;
13
14
  this.multiple = false;
14
15
  this.minRows = 3;
15
16
  this.searchable = false;
@@ -22,7 +23,7 @@ const Q2Select = class {
22
23
  this.scheduledAfterRender = [];
23
24
  this.keyStore = {
24
25
  queue: [],
25
- lastPressedAt: new Date()
26
+ lastPressedAt: new Date(),
26
27
  };
27
28
  this.guid = createGuid();
28
29
  this.onMutationObserved = () => {
@@ -67,9 +68,7 @@ const Q2Select = class {
67
68
  return list.find(v => {
68
69
  return (!v.element.disabled &&
69
70
  v.element.display &&
70
- v.element.display
71
- .replace(/\s/g, '')
72
- .match(new RegExp(`^${this.keyStore.queue.join('')}`, 'i')));
71
+ v.element.display.replace(/\s/g, '').match(new RegExp(`^${this.keyStore.queue.join('')}`, 'i')));
73
72
  });
74
73
  };
75
74
  const setFocus = ({ element, index }) => {
@@ -99,13 +98,13 @@ const Q2Select = class {
99
98
  return;
100
99
  this.closeDropdown();
101
100
  };
101
+ /* tslint:disable:cyclomatic-complexity */
102
102
  this.dropdownKeydownHandler = (event) => {
103
103
  event.stopPropagation();
104
104
  const { activeIndex, searchable, optionElements, multiSelectHeader } = this;
105
105
  const { key, shiftKey } = event;
106
- if (multiSelectHeader &&
107
- multiSelectHeader.contains(event.target) &&
108
- [' ', 'Enter'].includes(key))
106
+ if (this.readonly ||
107
+ (multiSelectHeader && multiSelectHeader.contains(event.target) && [' ', 'Enter'].includes(key)))
109
108
  return;
110
109
  switch (key) {
111
110
  case ' ':
@@ -280,9 +279,7 @@ const Q2Select = class {
280
279
  };
281
280
  }
282
281
  resizeIframe() {
283
- return (window.TectonElements &&
284
- window.TectonElements.resizeIframe &&
285
- window.TectonElements.resizeIframe());
282
+ return window.TectonElements && window.TectonElements.resizeIframe && window.TectonElements.resizeIframe();
286
283
  }
287
284
  getDefaultActiveIndex() {
288
285
  const firstSelected = this.optionElements.findIndex(element => element.selected);
@@ -343,9 +340,7 @@ const Q2Select = class {
343
340
  const selectedOption = this.optionElements.find(option => {
344
341
  return this.value === option.value;
345
342
  });
346
- return ((selectedOption && selectedOption.display && loc(selectedOption.display)) ||
347
- this.value ||
348
- '');
343
+ return (selectedOption && selectedOption.display && loc(selectedOption.display)) || this.value || '';
349
344
  }
350
345
  get minPopHeight() {
351
346
  const { minRows } = this;
@@ -362,9 +357,7 @@ const Q2Select = class {
362
357
  // when closed they display the same as non searchable select (what is selected)
363
358
  return this.searchText || '';
364
359
  }
365
- return this.multiple
366
- ? this.calculateMultiSelectSelectedDisplay()
367
- : this.calculateSingleSelectSelectedDisplay();
360
+ return this.multiple ? this.calculateMultiSelectSelectedDisplay() : this.calculateSingleSelectSelectedDisplay();
368
361
  }
369
362
  get selectedOptionsCount() {
370
363
  return this.selectedOptions.length;
@@ -402,7 +395,7 @@ const Q2Select = class {
402
395
  const isSelected = this.selectedOptions.includes(value);
403
396
  if (isSelected) {
404
397
  this.change.emit({
405
- selectedOptions: this.selectedOptions.filter(selectedValue => selectedValue !== value)
398
+ selectedOptions: this.selectedOptions.filter(selectedValue => selectedValue !== value),
406
399
  });
407
400
  }
408
401
  else {
@@ -421,12 +414,16 @@ const Q2Select = class {
421
414
  activeOption === null || activeOption === void 0 ? void 0 : activeOption.scrollIntoView({ block: 'nearest' });
422
415
  }
423
416
  openDropdownWithoutActiveElement() {
417
+ if (this.readonly)
418
+ return;
424
419
  this.activeIndex = undefined;
425
420
  this.setActiveOption();
426
421
  this.dropdownOpen = true;
427
422
  this.scheduledAfterRender.push(this.resizeIframe);
428
423
  }
429
424
  openDropdownWithActiveElement(activeIndex) {
425
+ if (this.readonly)
426
+ return;
430
427
  this.activeIndex = activeIndex;
431
428
  this.dropdownOpen = true;
432
429
  this.setActiveOption();
@@ -536,6 +533,8 @@ const Q2Select = class {
536
533
  });
537
534
  }
538
535
  onHostElementChange(event) {
536
+ if (this.readonly)
537
+ return;
539
538
  if (event.target === this.hostElement && !this.hostElement.onchange) {
540
539
  if (this.multiple) {
541
540
  this.selectedOptions = event.detail.selectedOptions;
@@ -556,14 +555,13 @@ const Q2Select = class {
556
555
  }
557
556
  else {
558
557
  const { display = '', innerText = '' } = option;
559
- const matched = display.toLowerCase().includes(query) ||
560
- innerText.toLowerCase().includes(query);
558
+ const matched = display.toLowerCase().includes(query) || innerText.toLowerCase().includes(query);
561
559
  option.hidden = !matched;
562
560
  if (matched)
563
561
  matchedCount++;
564
562
  }
565
563
  });
566
- let statusMessageLocString = query
564
+ const statusMessageLocString = query
567
565
  ? 'tecton.element.select.searchable.results'
568
566
  : 'tecton.element.select.allOptions';
569
567
  const count = query ? matchedCount : options.length;
@@ -589,6 +587,7 @@ const Q2Select = class {
589
587
  }
590
588
  this.selectOption(target.value, true);
591
589
  }
590
+ /* tslint:enable:cyclomatic-complexity */
592
591
  keydownHandler(event) {
593
592
  this.inputKeydownHandler(event);
594
593
  }
@@ -597,16 +596,14 @@ const Q2Select = class {
597
596
  this.errors.length > 0 &&
598
597
  this.errors.map(error => loc(error))) ||
599
598
  (this.invalid && ['tecton.element.select.invalid']) ||
600
- [], disabled: this.disabled, optional: this.optional, hideLabel: this.hideLabel, ariaExpanded: this.dropdownOpen, ariaOwns: "dropdown", ariaHaspopup: "listbox", role: this.searchable ? 'combobox' : null, pseudo: !this.searchable, "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 }), h("div", { class: "custom-display-content", hidden: !this.hasCustomDisplay || !!this.searchText, onClick: this.onCustomDisplayClick }, h("slot", { name: "q2-select-display" })), this.optionsDropdown()));
599
+ [], disabled: this.disabled, optional: this.optional, readonly: this.readonly, hideLabel: this.hideLabel, ariaExpanded: `${!!this.dropdownOpen}`, ariaOwns: "dropdown", ariaHaspopup: "listbox", role: this.searchable ? 'combobox' : null, pseudo: !this.searchable, "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 }), h("div", { class: "custom-display-content", hidden: !this.hasCustomDisplay || !!this.searchText, onClick: this.onCustomDisplayClick }, h("slot", { name: "q2-select-display" })), this.optionsDropdown()));
601
600
  }
602
601
  optionsDropdown() {
603
602
  const dropDirection = this.privatePopDirection === 'up' ? 'dropup' : '';
604
603
  return (h("div", { class: `q2-select-dropdown q2-element-dropdown ${dropDirection}`, ref: el => (this.dropdownContainer = el), onKeyDown: this.dropdownKeydownHandler, onFocusout: this.dropdownFocusoutHandler }, this.multiple ? this.visibilityToggle() : '', h("div", { class: "q2-select-options", id: "dropdown", role: "listbox" }, h("slot", null))));
605
604
  }
606
605
  visibilityToggle() {
607
- return (h("div", { class: "multi-select-header", ref: el => (this.multiSelectHeader = el) }, loc('tecton.element.select.multiHeader.showing'), h("q2-btn", { class: `option-toggle show-all-options${this.onlyShowingSelected ? '' : ' selected'}`, badge: true, "aria-selected": !this.onlyShowingSelected || undefined, "test-id": "allOptionsButton", onClick: this.showAllOptions, label: loc('tecton.element.select.multiHeader.allAriaLabel'), "hide-label": true }, loc('tecton.element.select.multiHeader.all')), h("q2-btn", { class: `option-toggle show-selected-options${this.onlyShowingSelected ? ' selected' : ''}`, "aria-selected": this.onlyShowingSelected || undefined, disabled: this.selectedOptions.length === 0, badge: true, "test-id": "selectedOptionsButton", onClick: this.showSelectedOptions, label: loc('tecton.element.select.multiHeader.selectedAriaLabel', [
608
- this.selectedOptionsCount
609
- ]), "hide-label": true }, loc('tecton.element.select.multiHeader.selected', [this.selectedOptionsCount]))));
606
+ return (h("div", { class: "multi-select-header", ref: el => (this.multiSelectHeader = el) }, loc('tecton.element.select.multiHeader.showing'), h("q2-btn", { class: `option-toggle show-all-options${this.onlyShowingSelected ? '' : ' selected'}`, badge: true, "aria-selected": !this.onlyShowingSelected || undefined, "test-id": "allOptionsButton", onClick: this.showAllOptions, label: loc('tecton.element.select.multiHeader.allAriaLabel'), "hide-label": true }, loc('tecton.element.select.multiHeader.all')), h("q2-btn", { class: `option-toggle show-selected-options${this.onlyShowingSelected ? ' selected' : ''}`, "aria-selected": this.onlyShowingSelected || undefined, disabled: this.selectedOptions.length === 0, badge: true, "test-id": "selectedOptionsButton", onClick: this.showSelectedOptions, label: loc('tecton.element.select.multiHeader.selectedAriaLabel', [this.selectedOptionsCount]), "hide-label": true }, loc('tecton.element.select.multiHeader.selected', [this.selectedOptionsCount]))));
610
607
  }
611
608
  get hostElement() { return getElement(this); }
612
609
  static get watchers() { return {
@@ -1,22 +1,60 @@
1
- import { r as registerInstance, h, g as getElement } from './index-be8376c0.js';
2
- import { c as createGuid, l as loc } from './index-ec6660af.js';
1
+ import { r as registerInstance, c as createEvent, h, F as Fragment, g as getElement } from './index-dbfb3ecc.js';
2
+ import { c as createGuid, n as nextPaint, l as loc } from './index-0ff8de52.js';
3
3
 
4
4
  const stylesCss = "*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-global-focus)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size: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;position:relative}";
5
5
 
6
6
  const Q2StepperPane = class {
7
7
  constructor(hostRef) {
8
8
  registerInstance(this, hostRef);
9
+ this.statusChange = createEvent(this, "statusChange", 7);
10
+ this.activeChange = createEvent(this, "activeChange", 7);
11
+ this.isChildActive = false;
9
12
  }
10
- ////////// LIFECYCLE HOOKS ////////
13
+ /// LifeCycle Hooks ///
11
14
  connectedCallback() {
12
15
  if (!this.hostElement.id)
13
16
  this.hostElement.id = `step-${createGuid()}`;
14
17
  }
18
+ componentWillLoad() {
19
+ this.checkForActiveChildren();
20
+ }
21
+ /// Watchers and Listeners ///
22
+ statusChanged(status) {
23
+ this.statusChange.emit({
24
+ status,
25
+ isActive: !!this.isActive,
26
+ id: this.hostElement.id,
27
+ host: this.hostElement,
28
+ });
29
+ }
30
+ isActiveChanged(isActive) {
31
+ this.activeChange.emit({
32
+ status: this.status || '',
33
+ isActive,
34
+ id: this.hostElement.id,
35
+ host: this.hostElement,
36
+ });
37
+ }
38
+ checkForActiveChildren() {
39
+ if (!this.showWithChildren)
40
+ return;
41
+ nextPaint(() => {
42
+ setTimeout(() => {
43
+ this.isChildActive = !!this.hostElement.querySelector("[slot='children'] > q2-stepper-pane[is-active]");
44
+ });
45
+ });
46
+ }
47
+ /// DOM ///
15
48
  render() {
16
49
  const { label, description, isActive } = this;
17
- return (h("div", { role: "tabpanel", "aria-label": label && loc(label), "aria-description": description && loc(description), tabindex: "0", hidden: !isActive }, h("slot", null)));
50
+ return (h(Fragment, null, h("div", { role: "tabpanel", "aria-label": label && loc(label), "aria-description": description && loc(description), tabindex: "0", hidden: !isActive && !(this.isChildActive && this.showWithChildren) }, h("slot", null)), h("slot", { name: "children" })));
18
51
  }
19
52
  get hostElement() { return getElement(this); }
53
+ static get watchers() { return {
54
+ "status": ["statusChanged"],
55
+ "isActive": ["isActiveChanged"],
56
+ "showWithChildren": ["checkForActiveChildren"]
57
+ }; }
20
58
  };
21
59
  Q2StepperPane.style = stylesCss;
22
60