q2-tecton-elements 1.13.0-alpha.0 → 1.13.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (235) 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 +54 -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 +19 -11
  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 +36 -31
  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 +45 -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 +36 -11
  58. package/dist/collection/components/q2-checkbox/styles.css +1 -0
  59. package/dist/collection/components/q2-checkbox-group/index.js +22 -1
  60. package/dist/collection/components/q2-dropdown/index.js +6 -15
  61. package/dist/collection/components/q2-dropdown-item/index.js +5 -5
  62. package/dist/collection/components/q2-editable-field/index.js +3 -6
  63. package/dist/collection/components/q2-icon/icons.js +393 -383
  64. package/dist/collection/components/q2-input/formatting/credit-card.js +15 -13
  65. package/dist/collection/components/q2-input/formatting/currency.js +162 -162
  66. package/dist/collection/components/q2-input/formatting/date.js +1 -1
  67. package/dist/collection/components/q2-input/formatting/generic.js +7 -8
  68. package/dist/collection/components/q2-input/formatting/number.js +6 -9
  69. package/dist/collection/components/q2-input/formatting/numeric.js +5 -5
  70. package/dist/collection/components/q2-input/formatting/phone.js +215 -215
  71. package/dist/collection/components/q2-input/formatting/postal.js +1 -1
  72. package/dist/collection/components/q2-input/index.js +81 -25
  73. package/dist/collection/components/q2-input/styles.css +19 -14
  74. package/dist/collection/components/q2-loading/index.js +4 -4
  75. package/dist/collection/components/q2-loading/skeleton/q2-loading-element/index.js +1 -1
  76. package/dist/collection/components/q2-loading/skeleton/shapes.js +8 -15
  77. package/dist/collection/components/q2-message/index.js +3 -3
  78. package/dist/collection/components/q2-optgroup/index.js +1 -1
  79. package/dist/collection/components/q2-option/index.js +19 -25
  80. package/dist/collection/components/q2-option/styles.css +5 -0
  81. package/dist/collection/components/q2-option-list/index.js +648 -0
  82. package/dist/collection/components/q2-option-list/styles.css +128 -0
  83. package/dist/collection/components/q2-pagination/index.js +275 -0
  84. package/dist/collection/components/q2-pagination/styles.css +120 -0
  85. package/dist/collection/components/q2-pill/index.js +324 -0
  86. package/dist/collection/components/q2-pill/styles.css +229 -0
  87. package/dist/collection/components/q2-radio/index.js +38 -1
  88. package/dist/collection/components/q2-radio-group/index.js +66 -24
  89. package/dist/collection/components/q2-section/index.js +5 -7
  90. package/dist/collection/components/q2-select/index.js +53 -30
  91. package/dist/collection/components/q2-stepper/index.js +8 -10
  92. package/dist/collection/components/q2-stepper/styles.css +5 -5
  93. package/dist/collection/components/q2-stepper-pane/index.js +133 -5
  94. package/dist/collection/components/q2-stepper-vertical/index.js +346 -0
  95. package/dist/collection/components/q2-stepper-vertical/styles.css +273 -0
  96. package/dist/collection/components/q2-tab-container/index.js +11 -7
  97. package/dist/collection/components/q2-tag/index.js +200 -0
  98. package/dist/collection/components/q2-tag/styles.css +141 -0
  99. package/dist/collection/components/q2-textarea/index.js +6 -6
  100. package/dist/collection/components/tecton-tab-pane/index.js +3 -10
  101. package/dist/collection/utils/index.js +25 -13
  102. package/dist/esm/click-elsewhere.entry.js +5 -7
  103. package/dist/esm/{icons-3ee662ea.js → icons-b1e11526.js} +394 -384
  104. package/dist/esm/{index-ec6660af.js → index-0ff8de52.js} +27 -15
  105. package/dist/esm/{index-be8376c0.js → index-dbfb3ecc.js} +112 -65
  106. package/dist/esm/loader.js +3 -3
  107. package/dist/esm/polyfills/css-shim.js +1 -1
  108. package/dist/esm/q2-avatar.entry.js +2 -2
  109. package/dist/esm/q2-badge.entry.js +39 -0
  110. package/dist/esm/q2-btn_2.entry.js +13 -13
  111. package/dist/esm/q2-calendar.entry.js +54 -59
  112. package/dist/esm/q2-card.entry.js +123 -0
  113. package/dist/esm/q2-carousel-pane.entry.js +5 -5
  114. package/dist/esm/q2-carousel.entry.js +318 -106
  115. package/dist/esm/q2-checkbox-group.entry.js +6 -3
  116. package/dist/esm/q2-checkbox.entry.js +19 -11
  117. package/dist/esm/q2-dropdown-item.entry.js +7 -7
  118. package/dist/esm/q2-dropdown.entry.js +8 -17
  119. package/dist/esm/q2-editable-field.entry.js +5 -8
  120. package/dist/esm/q2-icon.entry.js +3 -3
  121. package/dist/esm/q2-input.entry.js +439 -437
  122. package/dist/esm/q2-loading-element.entry.js +3 -3
  123. package/dist/esm/q2-loc.entry.js +2 -2
  124. package/dist/esm/q2-message.entry.js +5 -5
  125. package/dist/esm/q2-optgroup.entry.js +3 -3
  126. package/dist/esm/q2-option-list.entry.js +355 -0
  127. package/dist/esm/q2-option.entry.js +3 -11
  128. package/dist/esm/q2-pagination.entry.js +112 -0
  129. package/dist/esm/q2-pill.entry.js +133 -0
  130. package/dist/esm/q2-radio-group.entry.js +43 -18
  131. package/dist/esm/q2-radio.entry.js +21 -4
  132. package/dist/esm/q2-section.entry.js +5 -7
  133. package/dist/esm/q2-select.entry.js +36 -31
  134. package/dist/esm/q2-stepper-pane.entry.js +42 -4
  135. package/dist/esm/q2-stepper-vertical.entry.js +274 -0
  136. package/dist/esm/q2-stepper.entry.js +10 -12
  137. package/dist/esm/q2-tab-container.entry.js +12 -8
  138. package/dist/esm/q2-tab-pane.entry.js +1 -1
  139. package/dist/esm/q2-tag.entry.js +90 -0
  140. package/dist/esm/q2-tecton-elements.js +3 -3
  141. package/dist/esm/q2-textarea.entry.js +8 -8
  142. package/dist/esm/{shapes-81c11dfe.js → shapes-cff4e1f0.js} +9 -16
  143. package/dist/esm/tecton-tab-pane.entry.js +2 -5
  144. package/dist/loader/index.d.ts +0 -1
  145. package/dist/q2-tecton-elements/{p-75e87cca.entry.js → p-00e8f782.entry.js} +1 -1
  146. package/dist/q2-tecton-elements/p-01ae8461.entry.js +1 -0
  147. package/dist/q2-tecton-elements/p-0900bec1.entry.js +1 -0
  148. package/dist/q2-tecton-elements/p-10264ecb.entry.js +1 -0
  149. package/dist/q2-tecton-elements/{p-fbf7c5e6.entry.js → p-1305ec5f.entry.js} +1 -1
  150. package/dist/q2-tecton-elements/p-148391d6.entry.js +1 -0
  151. package/dist/q2-tecton-elements/p-1dfaee64.entry.js +1 -0
  152. package/dist/q2-tecton-elements/{p-32ad664c.entry.js → p-221abbf6.entry.js} +1 -1
  153. package/dist/q2-tecton-elements/{p-c90a6016.js → p-255b2b4c.js} +1 -1
  154. package/dist/q2-tecton-elements/p-27736b6b.entry.js +1 -0
  155. package/dist/q2-tecton-elements/p-2846ab94.entry.js +1 -0
  156. package/dist/q2-tecton-elements/p-2bc1de01.entry.js +1 -0
  157. package/dist/q2-tecton-elements/{p-8ea2c4f7.entry.js → p-2c15414c.entry.js} +1 -1
  158. package/dist/q2-tecton-elements/p-2caa89fd.js +1 -0
  159. package/dist/q2-tecton-elements/p-327cca41.entry.js +1 -0
  160. package/dist/q2-tecton-elements/p-3a420dbf.entry.js +1 -0
  161. package/dist/q2-tecton-elements/p-3abcb09d.entry.js +1 -0
  162. package/dist/q2-tecton-elements/p-3fe98e3e.entry.js +1 -0
  163. package/dist/q2-tecton-elements/{p-bb2e110a.entry.js → p-430a979b.entry.js} +1 -1
  164. package/dist/q2-tecton-elements/{p-7e6fc65d.entry.js → p-45eb7739.entry.js} +1 -1
  165. package/dist/q2-tecton-elements/{p-750bcd33.entry.js → p-49b2abc4.entry.js} +1 -1
  166. package/dist/q2-tecton-elements/{p-9b50c3c3.entry.js → p-4ab30466.entry.js} +1 -1
  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-ae130f70.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/p-ffbded54.entry.js +1 -0
  184. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js +1 -1
  185. package/dist/test/elements/q2-tag-test.js +151 -0
  186. package/dist/test/helpers.js +20 -9
  187. package/dist/types/components/q2-badge/index.d.ts +13 -0
  188. package/dist/types/components/q2-btn/index.d.ts +3 -3
  189. package/dist/types/components/q2-calendar/helpers.d.ts +1 -0
  190. package/dist/types/components/q2-calendar/index.d.ts +2 -1
  191. package/dist/types/components/q2-calendar/validation.d.ts +1 -1
  192. package/dist/types/components/q2-card/index.d.ts +35 -0
  193. package/dist/types/components/q2-checkbox/index.d.ts +3 -1
  194. package/dist/types/components/q2-checkbox-group/index.d.ts +1 -0
  195. package/dist/types/components/q2-dropdown/index.d.ts +1 -1
  196. package/dist/types/components/q2-editable-field/index.d.ts +1 -1
  197. package/dist/types/components/q2-input/formatting/credit-card.d.ts +1 -3
  198. package/dist/types/components/q2-input/index.d.ts +5 -2
  199. package/dist/types/components/q2-option/index.d.ts +2 -3
  200. package/dist/types/components/q2-option-list/index.d.ts +62 -0
  201. package/dist/types/components/q2-pagination/index.d.ts +30 -0
  202. package/dist/types/components/q2-pill/index.d.ts +39 -0
  203. package/dist/types/components/q2-radio/index.d.ts +4 -1
  204. package/dist/types/components/q2-radio-group/index.d.ts +5 -1
  205. package/dist/types/components/q2-select/index.d.ts +2 -1
  206. package/dist/types/components/q2-stepper/index.d.ts +1 -1
  207. package/dist/types/components/q2-stepper-pane/index.d.ts +16 -1
  208. package/dist/types/components/q2-stepper-vertical/index.d.ts +52 -0
  209. package/dist/types/components/q2-tab-container/index.d.ts +1 -1
  210. package/dist/types/components/q2-tag/index.d.ts +28 -0
  211. package/dist/types/components/tecton-tab-pane/index.d.ts +2 -2
  212. package/dist/types/components.d.ts +235 -11
  213. package/dist/types/global.d.ts +1 -0
  214. package/dist/types/stencil-public-runtime.d.ts +6 -4
  215. package/dist/types/util.d.ts +2 -10
  216. package/dist/types/utils/index.d.ts +1 -0
  217. package/dist/types/workspace/workspace/tecton-production_release_1.13.x/packages/q2-tecton-elements/.stencil/test/elements/q2-tag-test.d.ts +1 -0
  218. package/dist/types/workspace/workspace/{_production_release_1.11.0-alpha → tecton-production_release_1.13.x}/packages/q2-tecton-elements/.stencil/test/helpers.d.ts +6 -3
  219. package/package.json +13 -13
  220. package/dist/q2-tecton-elements/p-06fff43d.entry.js +0 -1
  221. package/dist/q2-tecton-elements/p-080839ed.js +0 -1
  222. package/dist/q2-tecton-elements/p-29a37091.entry.js +0 -1
  223. package/dist/q2-tecton-elements/p-37aba2a4.js +0 -1
  224. package/dist/q2-tecton-elements/p-4cd00f1a.js +0 -1
  225. package/dist/q2-tecton-elements/p-6702eb4d.entry.js +0 -1
  226. package/dist/q2-tecton-elements/p-768e3a5d.entry.js +0 -1
  227. package/dist/q2-tecton-elements/p-843b1ee9.entry.js +0 -1
  228. package/dist/q2-tecton-elements/p-943c7745.entry.js +0 -1
  229. package/dist/q2-tecton-elements/p-95a73559.entry.js +0 -1
  230. package/dist/q2-tecton-elements/p-9a977ee6.entry.js +0 -1
  231. package/dist/q2-tecton-elements/p-b281c349.entry.js +0 -1
  232. package/dist/q2-tecton-elements/p-c5e55b9f.entry.js +0 -1
  233. package/dist/q2-tecton-elements/p-ccbe9158.entry.js +0 -1
  234. package/dist/q2-tecton-elements/p-db6f90ac.entry.js +0 -1
  235. package/dist/q2-tecton-elements/p-fa6eea5c.entry.js +0 -1
@@ -0,0 +1,137 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-7febb200.js');
6
+ const index$1 = require('./index-dd823ee6.js');
7
+
8
+ 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))))}";
9
+
10
+ const Q2Pill = class {
11
+ constructor(hostRef) {
12
+ index.registerInstance(this, hostRef);
13
+ this.change = index.createEvent(this, "change", 7);
14
+ this.selectedOptions = [];
15
+ this.scheduledAfterRender = [];
16
+ /// Helpers ///
17
+ this.determineHasOptions = () => {
18
+ const hasOptions = !!this.hostElement.querySelectorAll('q2-option').length;
19
+ this.hasOptions = hasOptions;
20
+ };
21
+ this.clearSelectedOptions = () => {
22
+ this.selectedOptions = [];
23
+ this.active = false;
24
+ this.open = false;
25
+ this.primaryBtn.focus();
26
+ this.change.emit({ value: null, values: [], active: false });
27
+ };
28
+ /// Event Handlers ///
29
+ this.handleClick = (event) => {
30
+ event.stopPropagation();
31
+ if (this.disabled)
32
+ return;
33
+ if (this.hasOptions) {
34
+ this.optionList.toggle();
35
+ }
36
+ else {
37
+ const { value, label } = this;
38
+ const isActive = (this.active = !this.active);
39
+ const values = isActive ? [{ value, display: label }] : [];
40
+ this.selectedOptions = values;
41
+ this.change.emit({
42
+ value,
43
+ values,
44
+ active: isActive,
45
+ });
46
+ }
47
+ };
48
+ this.handleKeydown = (event) => {
49
+ if (!this.hasOptions || this.disabled)
50
+ return;
51
+ this.optionList.handleExternalKeydown(event);
52
+ };
53
+ this.handleChange = event => {
54
+ if (!this.hasOptions)
55
+ return;
56
+ const { value, values } = event.detail;
57
+ const isActive = !!values.length;
58
+ if (!this.hostElement.onchange) {
59
+ this.selectedOptions = values;
60
+ this.active = isActive;
61
+ }
62
+ this.change.emit({ value, values, active: isActive });
63
+ };
64
+ this.handleFocusout = (event) => {
65
+ const relatedTarget = event.relatedTarget;
66
+ if (Array.from(this.hostElement.children).includes(relatedTarget))
67
+ return;
68
+ if (relatedTarget && !(event.relatedTarget instanceof HTMLElement))
69
+ return;
70
+ if (relatedTarget && relatedTarget.closest('.btn-height-wrapper'))
71
+ return;
72
+ this.optionList.open = false;
73
+ };
74
+ this.handleWrapperClick = () => {
75
+ this.primaryBtn.focus();
76
+ this.primaryBtn.click();
77
+ };
78
+ }
79
+ /// LifeCycle Hooks ///
80
+ componentWillLoad() {
81
+ const observer = new MutationObserver(this.determineHasOptions);
82
+ observer.observe(this.hostElement, { childList: true, attributes: true });
83
+ this.mutationObserver = observer;
84
+ }
85
+ componentDidLoad() {
86
+ index$1.overrideFocus(this.hostElement);
87
+ }
88
+ componentDidRender() {
89
+ this.scheduledAfterRender.forEach(fn => fn());
90
+ this.scheduledAfterRender = [];
91
+ }
92
+ disconnectedCallback() {
93
+ this.mutationObserver.disconnect();
94
+ this.mutationObserver = null;
95
+ }
96
+ /// Getters ///
97
+ get buttonContent() {
98
+ const { label, selectedOptions, hasOptions } = this;
99
+ if (!hasOptions || selectedOptions.length === 0)
100
+ return label;
101
+ else if (selectedOptions.length === 1)
102
+ return selectedOptions[0].display;
103
+ return index$1.loc('tecton.element.pill.activeCount', { count: selectedOptions.length });
104
+ }
105
+ /// Listeners ///
106
+ delegateFocus(event) {
107
+ if (!index$1.isEventFromElement(event, this.hostElement))
108
+ return;
109
+ this.primaryBtn.focus();
110
+ }
111
+ optionListStateEvent({ detail: { open } }) {
112
+ this.open = open;
113
+ if (!open)
114
+ this.primaryBtn.focus();
115
+ }
116
+ /// DOM ///
117
+ generateIcon() {
118
+ const { hasOptions, active } = this;
119
+ const isButton = hasOptions && active;
120
+ const TagName = isButton ? 'button' : 'div';
121
+ const iconName = isButton || !hasOptions ? 'close' : 'chevron-down';
122
+ return (index.h(TagName, { class: "btn-close", onClick: isButton && this.clearSelectedOptions, disabled: isButton && this.disabled, "aria-label": isButton && index$1.loc('tecton.element.pill.clearSelection'), type: isButton && 'button' }, index.h("q2-icon", { type: iconName })));
123
+ }
124
+ render() {
125
+ const { hasOptions, active, open } = this;
126
+ const wrapperClassNames = ['btn-wrapper'];
127
+ if (hasOptions || active)
128
+ wrapperClassNames.push('has-icon');
129
+ if (hasOptions)
130
+ wrapperClassNames.push('has-options');
131
+ return (index.h(index.Fragment, null, index.h("div", { class: wrapperClassNames.join(' ') }, index.h("div", { class: "btn-height-wrapper", onClick: this.handleWrapperClick, tabIndex: -1 }, index.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 && index.h("span", { class: "sr" }, "(", index$1.loc('tecton.element.pill.active'), ")"))), this.generateIcon()), this.hasOptions && (index.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 }, index.h("slot", null)))));
132
+ }
133
+ get hostElement() { return index.getElement(this); }
134
+ };
135
+ Q2Pill.style = stylesCss;
136
+
137
+ exports.q2_pill = Q2Pill;
@@ -2,8 +2,8 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-c2e53804.js');
6
- const index$1 = require('./index-a55d3c34.js');
5
+ const index = require('./index-7febb200.js');
6
+ const index$1 = require('./index-dd823ee6.js');
7
7
 
8
8
  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}";
9
9
 
@@ -16,13 +16,16 @@ const Q2RadioGroup = class {
16
16
  this.hasError = false;
17
17
  this.id = `radio-group-${index$1.createGuid()}`;
18
18
  this.onMutationObserved = () => {
19
- this.valueUpdated();
19
+ this.valueUpdated(this.value);
20
20
  this.nameUpdated();
21
21
  this.disabledUpdated();
22
+ this.readonlyUpdated();
22
23
  this.tileLayoutUpdated();
23
24
  };
24
25
  this.onInnerRadioChange = (event) => {
25
26
  event.stopImmediatePropagation();
27
+ if (this.readonly)
28
+ return;
26
29
  this.change.emit({ value: event.detail.value });
27
30
  };
28
31
  }
@@ -30,17 +33,19 @@ const Q2RadioGroup = class {
30
33
  return Array.from(this.hostElement.querySelectorAll('q2-radio'));
31
34
  }
32
35
  /////// LIFECYCLE HOOK ///////
36
+ componentWillLoad() {
37
+ this.onMutationObserved();
38
+ }
33
39
  componentDidLoad() {
34
40
  const observer = new MutationObserver(this.onMutationObserved);
35
41
  observer.observe(this.hostElement, { childList: true });
36
42
  this.mutationObserver = observer;
37
- this.onMutationObserved();
38
43
  index$1.overrideFocus(this.hostElement);
39
44
  }
40
45
  /////// OBSERVERS ///////
41
- valueUpdated() {
46
+ valueUpdated(newVal) {
42
47
  this.radioElements.forEach(radio => {
43
- radio.checked = this.value === radio.value;
48
+ radio.checked = newVal === radio.value;
44
49
  });
45
50
  }
46
51
  nameUpdated() {
@@ -53,6 +58,10 @@ const Q2RadioGroup = class {
53
58
  radio.groupDisabled = this.disabled;
54
59
  });
55
60
  }
61
+ readonlyUpdated() {
62
+ const readonly = this.readonly;
63
+ this.radioElements.forEach(radio => (radio.groupReadonly = readonly));
64
+ }
56
65
  tileLayoutUpdated() {
57
66
  this.radioElements.forEach(radio => {
58
67
  radio.groupTileLayout = this.tilelayout;
@@ -68,19 +77,22 @@ const Q2RadioGroup = class {
68
77
  delegateFocus(event) {
69
78
  if (!index$1.isEventFromElement(event, this.hostElement))
70
79
  return;
71
- const radio = this.hostElement.querySelector('q2-radio[checked]') ||
72
- this.hostElement.querySelector('q2-radio');
80
+ const radio = this.hostElement.querySelector('q2-radio[checked]') || this.hostElement.querySelector('q2-radio');
73
81
  radio === null || radio === void 0 ? void 0 : radio.dispatchEvent(new FocusEvent('focus'));
74
82
  }
75
83
  keydownHandler(event) {
76
84
  const currentValue = event.target.getAttribute('value') || this.value;
77
85
  let index = this.radioElements.findIndex(el => el === event.target || el.getAttribute('value') === currentValue);
78
86
  let sign = 0;
79
- if (['ArrowLeft', 'Left', 'ArrowUp', 'Up'].includes(event.key)) {
80
- sign = -1;
81
- }
82
- else if (['ArrowRight', 'Right', 'ArrowDown', 'Down'].includes(event.key)) {
83
- sign = 1;
87
+ switch (event.key) {
88
+ case 'ArrowLeft':
89
+ case 'ArrowUp':
90
+ sign = -1;
91
+ break;
92
+ case 'ArrowRight':
93
+ case 'ArrowDown':
94
+ sign = 1;
95
+ break;
84
96
  }
85
97
  if (index === -1 || sign === 0) {
86
98
  return;
@@ -88,18 +100,30 @@ const Q2RadioGroup = class {
88
100
  index += sign;
89
101
  index = sign < 0 ? Math.max(0, index) : Math.min(this.radioElements.length - 1, index);
90
102
  event.preventDefault();
91
- this.value = this.radioElements[index].value;
103
+ if (!this.readonly) {
104
+ this.value = this.radioElements[index].value;
105
+ }
92
106
  this.radioElements[index].dispatchEvent(new FocusEvent('focus'));
93
107
  }
108
+ labelDOM() {
109
+ const { label, optional, readonly } = this;
110
+ let helpText = '';
111
+ if (readonly) {
112
+ helpText = index.h("span", { class: "optional-tag" }, index$1.loc('tecton.element.input.readonly'));
113
+ }
114
+ else if (optional) {
115
+ helpText = index.h("span", { class: "optional-tag" }, index$1.loc('tecton.element.input.optional'));
116
+ }
117
+ return (index.h(index.Fragment, null, label && index$1.loc(label), !!helpText && index.h("span", { class: "optional-tag" }, helpText)));
118
+ }
94
119
  render() {
95
- return (index.h("div", null, this.label || this.optional ? (index.h("div", { class: "group-legend" }, this.label && index$1.loc(this.label), this.optional ? (index.h("span", { class: "optional-tag" }, index$1.loc('tecton.element.input.optional'))) : (''))) : (''), index.h("fieldset", { class: `q2-radio-fieldset ${this.hasError ? 'has-error' : ''}`, onChange: this.onInnerRadioChange, "aria-required": `${!this.optional}` }, this.label || this.optional ? (index.h("legend", { class: "sr-only" }, this.label && index$1.loc(this.label), this.optional ? (index.h("span", { class: "optional-tag" }, index$1.loc('tecton.element.input.optional'))) : (''))) : (''), this.hasError ? (index.h("div", { class: `error-icon-container ${this.label || this.optional ? '' : 'no-label'}` }, index.h("q2-icon", { class: "h(4) w(4) mrg-b(2)", type: "error" }))) : (''), this.inputDom())));
120
+ const showLabel = this.label || this.optional || this.readonly;
121
+ return (index.h("div", null, showLabel && index.h("div", { class: "group-legend" }, this.labelDOM()), index.h("fieldset", { class: `q2-radio-fieldset ${this.hasError ? 'has-error' : ''}`, onChange: this.onInnerRadioChange, "aria-required": `${!this.optional}`, "aria-readonly": `${this.readonly}` }, showLabel && index.h("legend", { class: "sr-only" }, this.labelDOM()), this.hasError ? (index.h("div", { class: `error-icon-container ${!showLabel && 'no-label'}` }, index.h("q2-icon", { class: "h(4) w(4) mrg-b(2)", type: "error" }))) : (''), this.inputDom())));
96
122
  }
97
123
  inputDom() {
98
124
  if (this.tilelayout) {
99
125
  const { tileAlignment } = this;
100
- const alignment = ['left', 'center', 'right'].includes(tileAlignment)
101
- ? tileAlignment
102
- : 'center';
126
+ const alignment = ['left', 'center', 'right'].includes(tileAlignment) ? tileAlignment : 'center';
103
127
  return (index.h("div", { class: `flexed ${alignment}` }, index.h("slot", null)));
104
128
  }
105
129
  else {
@@ -111,6 +135,7 @@ const Q2RadioGroup = class {
111
135
  "value": ["valueUpdated"],
112
136
  "name": ["nameUpdated"],
113
137
  "disabled": ["disabledUpdated"],
138
+ "readonly": ["readonlyUpdated"],
114
139
  "tilelayout": ["tileLayoutUpdated"]
115
140
  }; }
116
141
  };
@@ -2,8 +2,8 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-c2e53804.js');
6
- const index$1 = require('./index-a55d3c34.js');
5
+ const index = require('./index-7febb200.js');
6
+ const index$1 = require('./index-dd823ee6.js');
7
7
 
8
8
  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))}";
9
9
 
@@ -14,11 +14,19 @@ const Q2Radio = class {
14
14
  this.disabled = false;
15
15
  this.checked = false;
16
16
  this.groupDisabled = false;
17
+ this.groupReadonly = false;
17
18
  this.groupTileLayout = false;
18
19
  this.id = `radio-${index$1.createGuid()}`;
20
+ this.isLoaded = false;
19
21
  this.inputChange = (event) => {
20
22
  event.stopPropagation();
21
- this.change.emit({ value: this.value });
23
+ if (this.groupReadonly) {
24
+ event.preventDefault();
25
+ return false;
26
+ }
27
+ if (event.target instanceof HTMLInputElement) {
28
+ this.checked = event.target.checked;
29
+ }
22
30
  };
23
31
  }
24
32
  ////////// LIFECYCLE HOOKS ////////
@@ -26,12 +34,20 @@ const Q2Radio = class {
26
34
  index$1.handleAriaLabel(this);
27
35
  }
28
36
  componentDidLoad() {
37
+ this.isLoaded = true;
29
38
  index$1.overrideFocus(this.hostElement);
30
39
  }
31
40
  ////////// OBSERVERS //////////
32
41
  ariaLabelObserver() {
33
42
  index$1.handleAriaLabel(this);
34
43
  }
44
+ checkedObserver() {
45
+ if (!this.isLoaded)
46
+ return;
47
+ if (!this.checked)
48
+ return;
49
+ this.change.emit({ value: this.value });
50
+ }
35
51
  /////// HOST ELEMENT EVENTS ///////
36
52
  onHostClick(event) {
37
53
  if (this.disabled) {
@@ -48,7 +64,8 @@ const Q2Radio = class {
48
64
  }
49
65
  get hostElement() { return index.getElement(this); }
50
66
  static get watchers() { return {
51
- "ariaLabel": ["ariaLabelObserver"]
67
+ "ariaLabel": ["ariaLabelObserver"],
68
+ "checked": ["checkedObserver"]
52
69
  }; }
53
70
  };
54
71
  Q2Radio.style = stylesCss;
@@ -2,8 +2,8 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-c2e53804.js');
6
- const index$1 = require('./index-a55d3c34.js');
5
+ const index = require('./index-7febb200.js');
6
+ const index$1 = require('./index-dd823ee6.js');
7
7
 
8
8
  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}";
9
9
 
@@ -20,7 +20,7 @@ const Q2Section = class {
20
20
  this.onHeaderClick = () => {
21
21
  this.collapsible &&
22
22
  this.change.emit({
23
- expanded: !this.expanded
23
+ expanded: !this.expanded,
24
24
  });
25
25
  };
26
26
  this.onAnimationStart = () => {
@@ -88,9 +88,7 @@ const Q2Section = class {
88
88
  };
89
89
  }
90
90
  resizeIframe() {
91
- return (window.TectonElements &&
92
- window.TectonElements.resizeIframe &&
93
- window.TectonElements.resizeIframe());
91
+ return window.TectonElements && window.TectonElements.resizeIframe && window.TectonElements.resizeIframe();
94
92
  }
95
93
  componentWillLoad() {
96
94
  this.onHeaderSlotChange();
@@ -161,7 +159,7 @@ const Q2Section = class {
161
159
  }
162
160
  }
163
161
  render() {
164
- return (index.h("section", { class: this.wrapperClasses }, index.h("div", { class: "q2-section-header" }, index.h("div", { class: "q2-section-header-content", id: this.titleId, onClick: this.onHeaderClick }, !this.hasYieldedHeader && !!this.label ? (index.h("h2", { class: "title" }, index$1.loc(this.label))) : (''), index.h("div", { class: "q2-section-header-slot-wrapper" }, index.h("slot", { name: "q2-section-header" }))), this.collapsible && !this.noCollapseIcon ? (index.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 }, index.h("q2-icon", { type: "chevron-up", class: "toggle-icon" }))) : ('')), index.h("div", { class: "q2-section-content-wrapper", id: this.contentId, "aria-labelledby": this.titleId, role: "region", onAnimationStart: this.onAnimationStart, onAnimationEnd: this.onAnimationEnd }, index.h("div", { class: "q2-section-content", tabindex: "-1" }, index.h("slot", null)))));
162
+ return (index.h("section", { class: this.wrapperClasses }, index.h("div", { class: "q2-section-header" }, index.h("div", { class: "q2-section-header-content", id: this.titleId, onClick: this.onHeaderClick }, !this.hasYieldedHeader && !!this.label ? index.h("h2", { class: "title" }, index$1.loc(this.label)) : '', index.h("div", { class: "q2-section-header-slot-wrapper" }, index.h("slot", { name: "q2-section-header" }))), this.collapsible && !this.noCollapseIcon ? (index.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 }, index.h("q2-icon", { type: "chevron-up", class: "toggle-icon" }))) : ('')), index.h("div", { class: "q2-section-content-wrapper", id: this.contentId, "aria-labelledby": this.titleId, role: "region", onAnimationStart: this.onAnimationStart, onAnimationEnd: this.onAnimationEnd }, index.h("div", { class: "q2-section-content", tabindex: "-1" }, index.h("slot", null)))));
165
163
  }
166
164
  get hostElement() { return index.getElement(this); }
167
165
  static get watchers() { return {
@@ -2,8 +2,8 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-c2e53804.js');
6
- const index$1 = require('./index-a55d3c34.js');
5
+ const index = require('./index-7febb200.js');
6
+ const index$1 = require('./index-dd823ee6.js');
7
7
 
8
8
  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}";
9
9
 
@@ -14,6 +14,7 @@ const Q2Select = class {
14
14
  this.input = index.createEvent(this, "input", 7);
15
15
  this.selectedOptions = [];
16
16
  this.disabled = false;
17
+ this.readonly = false;
17
18
  this.multiple = false;
18
19
  this.minRows = 3;
19
20
  this.searchable = false;
@@ -21,12 +22,13 @@ const Q2Select = class {
21
22
  this.optional = false;
22
23
  this.dropdownOpen = false;
23
24
  this.onlyShowingSelected = false;
25
+ this.searchText = '';
24
26
  this.hasCustomDisplay = false;
25
27
  this.inputFocused = false;
26
28
  this.scheduledAfterRender = [];
27
29
  this.keyStore = {
28
30
  queue: [],
29
- lastPressedAt: new Date()
31
+ lastPressedAt: new Date(),
30
32
  };
31
33
  this.guid = index$1.createGuid();
32
34
  this.onMutationObserved = () => {
@@ -71,9 +73,7 @@ const Q2Select = class {
71
73
  return list.find(v => {
72
74
  return (!v.element.disabled &&
73
75
  v.element.display &&
74
- v.element.display
75
- .replace(/\s/g, '')
76
- .match(new RegExp(`^${this.keyStore.queue.join('')}`, 'i')));
76
+ v.element.display.replace(/\s/g, '').match(new RegExp(`^${this.keyStore.queue.join('')}`, 'i')));
77
77
  });
78
78
  };
79
79
  const setFocus = ({ element, index }) => {
@@ -103,13 +103,13 @@ const Q2Select = class {
103
103
  return;
104
104
  this.closeDropdown();
105
105
  };
106
+ /* tslint:disable:cyclomatic-complexity */
106
107
  this.dropdownKeydownHandler = (event) => {
107
108
  event.stopPropagation();
108
109
  const { activeIndex, searchable, optionElements, multiSelectHeader } = this;
109
110
  const { key, shiftKey } = event;
110
- if (multiSelectHeader &&
111
- multiSelectHeader.contains(event.target) &&
112
- [' ', 'Enter'].includes(key))
111
+ if (this.readonly ||
112
+ (multiSelectHeader && multiSelectHeader.contains(event.target) && [' ', 'Enter'].includes(key)))
113
113
  return;
114
114
  switch (key) {
115
115
  case ' ':
@@ -240,10 +240,17 @@ const Q2Select = class {
240
240
  };
241
241
  this.inputInputHandler = (event) => {
242
242
  event.stopPropagation();
243
+ const inputValue = this.inputField.value;
244
+ const eventValue = event.detail.value;
245
+ const didChangeText = inputValue !== eventValue;
246
+ const shouldClearValue = !!this.value && didChangeText;
247
+ if (shouldClearValue) {
248
+ this.selectOption('');
249
+ }
243
250
  if (!this.dropdownOpen)
244
251
  this.openDropdownWithoutActiveElement();
245
- this.searchText = event.detail.value;
246
- this.input.emit({ query: event.detail.value });
252
+ this.searchText = eventValue;
253
+ this.input.emit({ query: eventValue });
247
254
  };
248
255
  this.inputFocusHandler = () => {
249
256
  this.inputFocused = true;
@@ -284,9 +291,7 @@ const Q2Select = class {
284
291
  };
285
292
  }
286
293
  resizeIframe() {
287
- return (window.TectonElements &&
288
- window.TectonElements.resizeIframe &&
289
- window.TectonElements.resizeIframe());
294
+ return window.TectonElements && window.TectonElements.resizeIframe && window.TectonElements.resizeIframe();
290
295
  }
291
296
  getDefaultActiveIndex() {
292
297
  const firstSelected = this.optionElements.findIndex(element => element.selected);
@@ -347,9 +352,7 @@ const Q2Select = class {
347
352
  const selectedOption = this.optionElements.find(option => {
348
353
  return this.value === option.value;
349
354
  });
350
- return ((selectedOption && selectedOption.display && index$1.loc(selectedOption.display)) ||
351
- this.value ||
352
- '');
355
+ return (selectedOption && selectedOption.display && index$1.loc(selectedOption.display)) || this.value || '';
353
356
  }
354
357
  get minPopHeight() {
355
358
  const { minRows } = this;
@@ -366,9 +369,7 @@ const Q2Select = class {
366
369
  // when closed they display the same as non searchable select (what is selected)
367
370
  return this.searchText || '';
368
371
  }
369
- return this.multiple
370
- ? this.calculateMultiSelectSelectedDisplay()
371
- : this.calculateSingleSelectSelectedDisplay();
372
+ return this.multiple ? this.calculateMultiSelectSelectedDisplay() : this.calculateSingleSelectSelectedDisplay();
372
373
  }
373
374
  get selectedOptionsCount() {
374
375
  return this.selectedOptions.length;
@@ -406,7 +407,7 @@ const Q2Select = class {
406
407
  const isSelected = this.selectedOptions.includes(value);
407
408
  if (isSelected) {
408
409
  this.change.emit({
409
- selectedOptions: this.selectedOptions.filter(selectedValue => selectedValue !== value)
410
+ selectedOptions: this.selectedOptions.filter(selectedValue => selectedValue !== value),
410
411
  });
411
412
  }
412
413
  else {
@@ -425,12 +426,16 @@ const Q2Select = class {
425
426
  activeOption === null || activeOption === void 0 ? void 0 : activeOption.scrollIntoView({ block: 'nearest' });
426
427
  }
427
428
  openDropdownWithoutActiveElement() {
429
+ if (this.readonly)
430
+ return;
428
431
  this.activeIndex = undefined;
429
432
  this.setActiveOption();
430
433
  this.dropdownOpen = true;
431
434
  this.scheduledAfterRender.push(this.resizeIframe);
432
435
  }
433
436
  openDropdownWithActiveElement(activeIndex) {
437
+ if (this.readonly)
438
+ return;
434
439
  this.activeIndex = activeIndex;
435
440
  this.dropdownOpen = true;
436
441
  this.setActiveOption();
@@ -540,6 +545,8 @@ const Q2Select = class {
540
545
  });
541
546
  }
542
547
  onHostElementChange(event) {
548
+ if (this.readonly)
549
+ return;
543
550
  if (event.target === this.hostElement && !this.hostElement.onchange) {
544
551
  if (this.multiple) {
545
552
  this.selectedOptions = event.detail.selectedOptions;
@@ -560,14 +567,13 @@ const Q2Select = class {
560
567
  }
561
568
  else {
562
569
  const { display = '', innerText = '' } = option;
563
- const matched = display.toLowerCase().includes(query) ||
564
- innerText.toLowerCase().includes(query);
570
+ const matched = display.toLowerCase().includes(query) || innerText.toLowerCase().includes(query);
565
571
  option.hidden = !matched;
566
572
  if (matched)
567
573
  matchedCount++;
568
574
  }
569
575
  });
570
- let statusMessageLocString = query
576
+ const statusMessageLocString = query
571
577
  ? 'tecton.element.select.searchable.results'
572
578
  : 'tecton.element.select.allOptions';
573
579
  const count = query ? matchedCount : options.length;
@@ -587,12 +593,13 @@ const Q2Select = class {
587
593
  }, 1000);
588
594
  }
589
595
  clickHandler(event) {
590
- const target = event.target;
591
- if (target.localName !== 'q2-option' || target.disabled) {
596
+ const selected = event.target.closest('q2-option');
597
+ if (!selected || (selected.hasAttribute('disabled') && selected.getAttribute('disabled') !== 'false')) {
592
598
  return;
593
599
  }
594
- this.selectOption(target.value, true);
600
+ this.selectOption(selected.getAttribute('value'), true);
595
601
  }
602
+ /* tslint:enable:cyclomatic-complexity */
596
603
  keydownHandler(event) {
597
604
  this.inputKeydownHandler(event);
598
605
  }
@@ -601,16 +608,14 @@ const Q2Select = class {
601
608
  this.errors.length > 0 &&
602
609
  this.errors.map(error => index$1.loc(error))) ||
603
610
  (this.invalid && ['tecton.element.select.invalid']) ||
604
- [], 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 }), index.h("div", { class: "custom-display-content", hidden: !this.hasCustomDisplay || !!this.searchText, onClick: this.onCustomDisplayClick }, index.h("slot", { name: "q2-select-display" })), this.optionsDropdown()));
611
+ [], 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 }), index.h("div", { class: "custom-display-content", hidden: !this.hasCustomDisplay || !!this.searchText, onClick: this.onCustomDisplayClick }, index.h("slot", { name: "q2-select-display" })), this.optionsDropdown()));
605
612
  }
606
613
  optionsDropdown() {
607
614
  const dropDirection = this.privatePopDirection === 'up' ? 'dropup' : '';
608
615
  return (index.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() : '', index.h("div", { class: "q2-select-options", id: "dropdown", role: "listbox" }, index.h("slot", null))));
609
616
  }
610
617
  visibilityToggle() {
611
- return (index.h("div", { class: "multi-select-header", ref: el => (this.multiSelectHeader = el) }, index$1.loc('tecton.element.select.multiHeader.showing'), index.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: index$1.loc('tecton.element.select.multiHeader.allAriaLabel'), "hide-label": true }, index$1.loc('tecton.element.select.multiHeader.all')), index.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: index$1.loc('tecton.element.select.multiHeader.selectedAriaLabel', [
612
- this.selectedOptionsCount
613
- ]), "hide-label": true }, index$1.loc('tecton.element.select.multiHeader.selected', [this.selectedOptionsCount]))));
618
+ return (index.h("div", { class: "multi-select-header", ref: el => (this.multiSelectHeader = el) }, index$1.loc('tecton.element.select.multiHeader.showing'), index.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: index$1.loc('tecton.element.select.multiHeader.allAriaLabel'), "hide-label": true }, index$1.loc('tecton.element.select.multiHeader.all')), index.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: index$1.loc('tecton.element.select.multiHeader.selectedAriaLabel', [this.selectedOptionsCount]), "hide-label": true }, index$1.loc('tecton.element.select.multiHeader.selected', [this.selectedOptionsCount]))));
614
619
  }
615
620
  get hostElement() { return index.getElement(this); }
616
621
  static get watchers() { return {