q2-tecton-elements 1.48.0 → 1.48.1-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (225) hide show
  1. package/dist/cjs/click-elsewhere_2.cjs.entry.js +1 -1
  2. package/dist/cjs/{index-c385e32f.js → index-c9a86a33.js} +1 -1
  3. package/dist/cjs/{index-c385e32f.js.map → index-c9a86a33.js.map} +1 -1
  4. package/dist/cjs/loader.cjs.js +1 -1
  5. package/dist/cjs/q2-calendar.cjs.entry.js +2 -2
  6. package/dist/cjs/q2-calendar.cjs.entry.js.map +1 -1
  7. package/dist/cjs/q2-checkbox-group.cjs.entry.js +1 -1
  8. package/dist/cjs/q2-checkbox-group.cjs.entry.js.map +1 -1
  9. package/dist/cjs/q2-checkbox.cjs.entry.js +1 -1
  10. package/dist/cjs/q2-checkbox.cjs.entry.js.map +1 -1
  11. package/dist/cjs/q2-form.cjs.entry.js +23 -0
  12. package/dist/cjs/q2-form.cjs.entry.js.map +1 -0
  13. package/dist/cjs/q2-input.cjs.entry.js +1 -1
  14. package/dist/cjs/q2-input.cjs.entry.js.map +1 -1
  15. package/dist/cjs/q2-item.cjs.entry.js +1 -1
  16. package/dist/cjs/q2-legend.cjs.entry.js +1 -1
  17. package/dist/cjs/q2-list.cjs.entry.js +1 -1
  18. package/dist/cjs/q2-loc.cjs.entry.js +1 -1
  19. package/dist/cjs/q2-message.cjs.entry.js +1 -1
  20. package/dist/cjs/q2-optgroup.cjs.entry.js +1 -1
  21. package/dist/cjs/q2-option.cjs.entry.js +1 -1
  22. package/dist/cjs/q2-pagination.cjs.entry.js +2 -2
  23. package/dist/cjs/q2-pill.cjs.entry.js +1 -1
  24. package/dist/cjs/q2-radio-group.cjs.entry.js +1 -1
  25. package/dist/cjs/q2-radio-group.cjs.entry.js.map +1 -1
  26. package/dist/cjs/q2-relative-time.cjs.entry.js +2 -2
  27. package/dist/cjs/q2-section.cjs.entry.js +2 -2
  28. package/dist/cjs/q2-select.cjs.entry.js +1 -1
  29. package/dist/cjs/q2-select.cjs.entry.js.map +1 -1
  30. package/dist/cjs/q2-stepper-pane.cjs.entry.js +1 -1
  31. package/dist/cjs/q2-stepper-vertical.cjs.entry.js +1 -1
  32. package/dist/cjs/q2-stepper.cjs.entry.js +1 -1
  33. package/dist/cjs/q2-tab-container.cjs.entry.js +1 -1
  34. package/dist/cjs/q2-tab-pane.cjs.entry.js +1 -1
  35. package/dist/cjs/q2-tag.cjs.entry.js +1 -1
  36. package/dist/cjs/q2-tecton-elements.cjs.js +1 -1
  37. package/dist/cjs/q2-textarea.cjs.entry.js +1 -1
  38. package/dist/cjs/q2-textarea.cjs.entry.js.map +1 -1
  39. package/dist/cjs/tecton-tab-pane.cjs.entry.js +2 -2
  40. package/dist/collection/collection-manifest.json +1 -0
  41. package/dist/collection/components/q2-calendar/q2-calendar.css +2 -0
  42. package/dist/collection/components/q2-checkbox/q2-checkbox.css +2 -0
  43. package/dist/collection/components/q2-checkbox-group/q2-checkbox-group.css +7 -1
  44. package/dist/collection/components/q2-data-table/q2-data-table.js +6 -6
  45. package/dist/collection/components/q2-form/q2-form.css +92 -0
  46. package/dist/collection/components/q2-form/q2-form.js +44 -0
  47. package/dist/collection/components/q2-form/q2-form.js.map +1 -0
  48. package/dist/collection/components/q2-input/q2-input.css +1 -1
  49. package/dist/collection/components/q2-input/q2-input.js +1 -1
  50. package/dist/collection/components/q2-item/q2-item.js +1 -1
  51. package/dist/collection/components/q2-legend/q2-legend.js +1 -1
  52. package/dist/collection/components/q2-list/q2-list.js +1 -1
  53. package/dist/collection/components/q2-loc/q2-loc.js +1 -1
  54. package/dist/collection/components/q2-message/q2-message.js +1 -1
  55. package/dist/collection/components/q2-optgroup/q2-optgroup.js +1 -1
  56. package/dist/collection/components/q2-option/q2-option.js +1 -1
  57. package/dist/collection/components/q2-option-list/q2-option-list.js +2 -2
  58. package/dist/collection/components/q2-pagination/q2-pagination.js +2 -2
  59. package/dist/collection/components/q2-pill/q2-pill.js +1 -1
  60. package/dist/collection/components/q2-popover/q2-popover.js +1 -1
  61. package/dist/collection/components/q2-radio-group/q2-radio-group.css +4 -2
  62. package/dist/collection/components/q2-relative-time/q2-relative-time.js +1 -1
  63. package/dist/collection/components/q2-section/q2-section.js +2 -2
  64. package/dist/collection/components/q2-select/q2-select.css +2 -2
  65. package/dist/collection/components/q2-stepper/q2-stepper.js +1 -1
  66. package/dist/collection/components/q2-stepper-pane/q2-stepper-pane.js +3 -3
  67. package/dist/collection/components/q2-stepper-vertical/q2-stepper-vertical.js +1 -1
  68. package/dist/collection/components/q2-tab-container/q2-tab-container.js +1 -1
  69. package/dist/collection/components/q2-tab-pane/q2-tab-pane.js +1 -1
  70. package/dist/collection/components/q2-tag/q2-tag.js +1 -1
  71. package/dist/collection/components/q2-textarea/q2-textarea.css +2 -2
  72. package/dist/collection/components/tecton-tab-pane/tecton-tab-pane.js +2 -2
  73. package/dist/components/index.js +2 -0
  74. package/dist/components/index.js.map +1 -1
  75. package/dist/components/q2-calendar.js +1 -1
  76. package/dist/components/q2-calendar.js.map +1 -1
  77. package/dist/components/q2-checkbox-group.js +1 -1
  78. package/dist/components/q2-checkbox-group.js.map +1 -1
  79. package/dist/components/q2-checkbox2.js +1 -1
  80. package/dist/components/q2-checkbox2.js.map +1 -1
  81. package/dist/components/q2-form.d.ts +11 -0
  82. package/dist/components/q2-form.js +39 -0
  83. package/dist/components/q2-form.js.map +1 -0
  84. package/dist/components/q2-input2.js +1 -1
  85. package/dist/components/q2-input2.js.map +1 -1
  86. package/dist/components/q2-item.js +1 -1
  87. package/dist/components/q2-legend2.js +1 -1
  88. package/dist/components/q2-list.js +1 -1
  89. package/dist/components/q2-loc.js +1 -1
  90. package/dist/components/q2-message2.js +1 -1
  91. package/dist/components/q2-optgroup2.js +1 -1
  92. package/dist/components/q2-option2.js +1 -1
  93. package/dist/components/q2-pagination.js +2 -2
  94. package/dist/components/q2-pill.js +1 -1
  95. package/dist/components/q2-popover2.js +1 -1
  96. package/dist/components/q2-radio-group.js +1 -1
  97. package/dist/components/q2-radio-group.js.map +1 -1
  98. package/dist/components/q2-relative-time.js +1 -1
  99. package/dist/components/q2-section.js +2 -2
  100. package/dist/components/q2-select2.js +1 -1
  101. package/dist/components/q2-select2.js.map +1 -1
  102. package/dist/components/q2-stepper-pane.js +1 -1
  103. package/dist/components/q2-stepper-vertical.js +1 -1
  104. package/dist/components/q2-stepper.js +1 -1
  105. package/dist/components/q2-tab-container.js +1 -1
  106. package/dist/components/q2-tab-pane.js +1 -1
  107. package/dist/components/q2-tag.js +1 -1
  108. package/dist/components/q2-textarea.js +1 -1
  109. package/dist/components/q2-textarea.js.map +1 -1
  110. package/dist/components/tecton-tab-pane.js +2 -2
  111. package/dist/esm/click-elsewhere_2.entry.js +1 -1
  112. package/dist/esm/{index-f0dfb099.js → index-8582f46d.js} +1 -1
  113. package/dist/esm/{index-f0dfb099.js.map → index-8582f46d.js.map} +1 -1
  114. package/dist/esm/loader.js +1 -1
  115. package/dist/esm/q2-calendar.entry.js +2 -2
  116. package/dist/esm/q2-calendar.entry.js.map +1 -1
  117. package/dist/esm/q2-checkbox-group.entry.js +1 -1
  118. package/dist/esm/q2-checkbox-group.entry.js.map +1 -1
  119. package/dist/esm/q2-checkbox.entry.js +1 -1
  120. package/dist/esm/q2-checkbox.entry.js.map +1 -1
  121. package/dist/esm/q2-form.entry.js +19 -0
  122. package/dist/esm/q2-form.entry.js.map +1 -0
  123. package/dist/esm/q2-input.entry.js +1 -1
  124. package/dist/esm/q2-input.entry.js.map +1 -1
  125. package/dist/esm/q2-item.entry.js +1 -1
  126. package/dist/esm/q2-legend.entry.js +1 -1
  127. package/dist/esm/q2-list.entry.js +1 -1
  128. package/dist/esm/q2-loc.entry.js +1 -1
  129. package/dist/esm/q2-message.entry.js +1 -1
  130. package/dist/esm/q2-optgroup.entry.js +1 -1
  131. package/dist/esm/q2-option.entry.js +1 -1
  132. package/dist/esm/q2-pagination.entry.js +2 -2
  133. package/dist/esm/q2-pill.entry.js +1 -1
  134. package/dist/esm/q2-radio-group.entry.js +1 -1
  135. package/dist/esm/q2-radio-group.entry.js.map +1 -1
  136. package/dist/esm/q2-relative-time.entry.js +2 -2
  137. package/dist/esm/q2-section.entry.js +2 -2
  138. package/dist/esm/q2-select.entry.js +1 -1
  139. package/dist/esm/q2-select.entry.js.map +1 -1
  140. package/dist/esm/q2-stepper-pane.entry.js +1 -1
  141. package/dist/esm/q2-stepper-vertical.entry.js +1 -1
  142. package/dist/esm/q2-stepper.entry.js +1 -1
  143. package/dist/esm/q2-tab-container.entry.js +1 -1
  144. package/dist/esm/q2-tab-pane.entry.js +1 -1
  145. package/dist/esm/q2-tag.entry.js +1 -1
  146. package/dist/esm/q2-tecton-elements.js +1 -1
  147. package/dist/esm/q2-textarea.entry.js +1 -1
  148. package/dist/esm/q2-textarea.entry.js.map +1 -1
  149. package/dist/esm/tecton-tab-pane.entry.js +2 -2
  150. package/dist/q2-tecton-elements/{p-d5776227.entry.js → p-0d6edd2a.entry.js} +2 -2
  151. package/dist/q2-tecton-elements/p-19da46dc.entry.js +2 -0
  152. package/dist/q2-tecton-elements/p-19da46dc.entry.js.map +1 -0
  153. package/dist/q2-tecton-elements/{p-dd18416f.entry.js → p-258f8c9c.entry.js} +2 -2
  154. package/dist/q2-tecton-elements/p-2878a662.entry.js +2 -0
  155. package/dist/q2-tecton-elements/p-2878a662.entry.js.map +1 -0
  156. package/dist/q2-tecton-elements/p-2a8de00d.entry.js +2 -0
  157. package/dist/q2-tecton-elements/p-2a8de00d.entry.js.map +1 -0
  158. package/dist/q2-tecton-elements/{p-ca43e917.entry.js → p-32130845.entry.js} +2 -2
  159. package/dist/q2-tecton-elements/{p-ff39ba49.entry.js → p-366a92d9.entry.js} +2 -2
  160. package/dist/q2-tecton-elements/{p-11982614.entry.js → p-4008aceb.entry.js} +2 -2
  161. package/dist/q2-tecton-elements/{p-f4b28e89.entry.js → p-400f6071.entry.js} +2 -2
  162. package/dist/q2-tecton-elements/{p-f4b28e89.entry.js.map → p-400f6071.entry.js.map} +1 -1
  163. package/dist/q2-tecton-elements/{p-ca17f7ca.entry.js → p-49ecdf18.entry.js} +2 -2
  164. package/dist/q2-tecton-elements/{p-abe30d0c.entry.js → p-6e313705.entry.js} +2 -2
  165. package/dist/q2-tecton-elements/p-79696bef.entry.js +2 -0
  166. package/dist/q2-tecton-elements/p-79696bef.entry.js.map +1 -0
  167. package/dist/q2-tecton-elements/{p-1d824cdf.entry.js → p-828850c1.entry.js} +2 -2
  168. package/dist/q2-tecton-elements/{p-6fdda37e.entry.js → p-861e83de.entry.js} +2 -2
  169. package/dist/q2-tecton-elements/p-8a8d51f1.entry.js +2 -0
  170. package/dist/q2-tecton-elements/p-8a8d51f1.entry.js.map +1 -0
  171. package/dist/q2-tecton-elements/p-8e60bcaa.entry.js +2 -0
  172. package/dist/q2-tecton-elements/{p-6986a60e.entry.js.map → p-8e60bcaa.entry.js.map} +1 -1
  173. package/dist/q2-tecton-elements/{p-9a71bd16.entry.js → p-9a5695db.entry.js} +2 -2
  174. package/dist/q2-tecton-elements/{p-8fc099f5.entry.js → p-9b65cc28.entry.js} +2 -2
  175. package/dist/q2-tecton-elements/{p-3c42c90f.js → p-b6bcef6a.js} +1 -1
  176. package/dist/q2-tecton-elements/{p-f18caa3f.entry.js → p-bc73f69c.entry.js} +2 -2
  177. package/dist/q2-tecton-elements/{p-fb7dd7ab.entry.js → p-d32f8e53.entry.js} +2 -2
  178. package/dist/q2-tecton-elements/{p-a891571c.entry.js → p-d35de465.entry.js} +2 -2
  179. package/dist/q2-tecton-elements/{p-66ae329f.entry.js → p-dfa489ba.entry.js} +2 -2
  180. package/dist/q2-tecton-elements/{p-32b56406.entry.js → p-e793a82c.entry.js} +2 -2
  181. package/dist/q2-tecton-elements/{p-23183c61.entry.js → p-f57c4448.entry.js} +2 -2
  182. package/dist/q2-tecton-elements/{p-0e482a7c.entry.js → p-fcffc029.entry.js} +2 -2
  183. package/dist/q2-tecton-elements/p-fde11d9c.entry.js +2 -0
  184. package/dist/q2-tecton-elements/p-fde11d9c.entry.js.map +1 -0
  185. package/dist/q2-tecton-elements/{p-24719520.entry.js → p-fec9edc8.entry.js} +2 -2
  186. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js +1 -1
  187. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js.map +1 -1
  188. package/dist/test/elements/q2-form-test.e2e.js +93 -0
  189. package/dist/test/elements/q2-form-test.e2e.js.map +1 -0
  190. package/dist/types/components/q2-form/q2-form.d.ts +6 -0
  191. package/dist/types/components.d.ts +21 -0
  192. package/package.json +3 -3
  193. package/dist/q2-tecton-elements/p-24d96969.entry.js +0 -2
  194. package/dist/q2-tecton-elements/p-24d96969.entry.js.map +0 -1
  195. package/dist/q2-tecton-elements/p-33af97b0.entry.js +0 -2
  196. package/dist/q2-tecton-elements/p-33af97b0.entry.js.map +0 -1
  197. package/dist/q2-tecton-elements/p-6986a60e.entry.js +0 -2
  198. package/dist/q2-tecton-elements/p-8a00552f.entry.js +0 -2
  199. package/dist/q2-tecton-elements/p-8a00552f.entry.js.map +0 -1
  200. package/dist/q2-tecton-elements/p-9eafabd5.entry.js +0 -2
  201. package/dist/q2-tecton-elements/p-9eafabd5.entry.js.map +0 -1
  202. package/dist/q2-tecton-elements/p-a03c29f3.entry.js +0 -2
  203. package/dist/q2-tecton-elements/p-a03c29f3.entry.js.map +0 -1
  204. /package/dist/q2-tecton-elements/{p-d5776227.entry.js.map → p-0d6edd2a.entry.js.map} +0 -0
  205. /package/dist/q2-tecton-elements/{p-dd18416f.entry.js.map → p-258f8c9c.entry.js.map} +0 -0
  206. /package/dist/q2-tecton-elements/{p-ca43e917.entry.js.map → p-32130845.entry.js.map} +0 -0
  207. /package/dist/q2-tecton-elements/{p-ff39ba49.entry.js.map → p-366a92d9.entry.js.map} +0 -0
  208. /package/dist/q2-tecton-elements/{p-11982614.entry.js.map → p-4008aceb.entry.js.map} +0 -0
  209. /package/dist/q2-tecton-elements/{p-ca17f7ca.entry.js.map → p-49ecdf18.entry.js.map} +0 -0
  210. /package/dist/q2-tecton-elements/{p-abe30d0c.entry.js.map → p-6e313705.entry.js.map} +0 -0
  211. /package/dist/q2-tecton-elements/{p-1d824cdf.entry.js.map → p-828850c1.entry.js.map} +0 -0
  212. /package/dist/q2-tecton-elements/{p-6fdda37e.entry.js.map → p-861e83de.entry.js.map} +0 -0
  213. /package/dist/q2-tecton-elements/{p-9a71bd16.entry.js.map → p-9a5695db.entry.js.map} +0 -0
  214. /package/dist/q2-tecton-elements/{p-8fc099f5.entry.js.map → p-9b65cc28.entry.js.map} +0 -0
  215. /package/dist/q2-tecton-elements/{p-3c42c90f.js.map → p-b6bcef6a.js.map} +0 -0
  216. /package/dist/q2-tecton-elements/{p-f18caa3f.entry.js.map → p-bc73f69c.entry.js.map} +0 -0
  217. /package/dist/q2-tecton-elements/{p-fb7dd7ab.entry.js.map → p-d32f8e53.entry.js.map} +0 -0
  218. /package/dist/q2-tecton-elements/{p-a891571c.entry.js.map → p-d35de465.entry.js.map} +0 -0
  219. /package/dist/q2-tecton-elements/{p-66ae329f.entry.js.map → p-dfa489ba.entry.js.map} +0 -0
  220. /package/dist/q2-tecton-elements/{p-32b56406.entry.js.map → p-e793a82c.entry.js.map} +0 -0
  221. /package/dist/q2-tecton-elements/{p-23183c61.entry.js.map → p-f57c4448.entry.js.map} +0 -0
  222. /package/dist/q2-tecton-elements/{p-0e482a7c.entry.js.map → p-fcffc029.entry.js.map} +0 -0
  223. /package/dist/q2-tecton-elements/{p-24719520.entry.js.map → p-fec9edc8.entry.js.map} +0 -0
  224. /package/dist/types/workspace/workspace/{_Gitlab_tecton-production_master → on-production_release_1.48.0-pre}/packages/q2-tecton-elements/.stencil/test/elements/q2-detail/slot-component.d.ts +0 -0
  225. /package/dist/types/workspace/workspace/{_Gitlab_tecton-production_master → on-production_release_1.48.0-pre}/packages/q2-tecton-elements/.stencil/test/helpers.d.ts +0 -0
@@ -1 +1 @@
1
- {"version":3,"names":["q2SelectCss","Q2SelectStyle0","Q2Select","this","scheduledAfterRender","showSelectedOptions","showSelected","showAllOptions","onMutationObserved","hostElement","hasPopoverTop","hasPopoverBottom","slotContainer","querySelector","displaySlot","shadowRoot","hasCustomDisplay","assignedNodes","length","children","popTopSlot","topSlotHasNode","popBottomSlot","bottomSlotHasNode","checkSelectedOptions","onOptionListChange","event","stopPropagation","values","detail","handleSelectionChanges","onPopoverState","open","action","searchText","optionList","setActiveElement","inputField","focus","inputKeydownHandler","readonly","disabled","key","hasSlot","isShiftTab","shiftKey","shouldShowActionSheet","executeActionSheet","keysForOptionListToHandle","searchable","value","preventDefault","openDropdownWithoutActiveElement","includes","shouldClearSearchText","clearSearchText","handleExternalKeydown","visibilityToggleKeyDown","isRadioControlKey","setDefaultActiveElement","inputClickHandler","async","toggleDropdown","focusInput","inputInputHandler","eventValue","shouldClearValue","clearValue","prioritizeSearch","input","emit","query","inputFocusHandler","inputFocused","inputBlurHandler","inputChangeHandler","clickedElsewhere","target","localName","onCustomDisplayClick","_a","window","Tecton","useActionSheets","loc","componentWillLoad","handleAriaLabel","buildStructuredSelectedOptions","handleMultilineOptionsUpdate","multilineOptions","componentDidLoad","observer","MutationObserver","observe","childList","subtree","mutationObserver","overrideFocus","setTimeout","checkSelectedDisplay","componentDidRender","forEach","fn","disconnectedCallback","disconnect","innerInputField","_b","innerInputContainer","badgeValue","multiple","optionsLength","selectedOptions","popoverMinHeight","minRows","firstOption","minHeight","getComputedStyle","parseInt","selectedDisplay","calculateMultiSelectSelectedDisplay","calculateSingleSelectSelectedDisplay","selectedDisplaySlot","firstSelectedValue","firstSelectedOptionElement","optionElements","find","Array","from","querySelectorAll","wrapperClasses","errors","classes","isArray","push","join","structuredSelectedOptions","map","option","ariaLabelObserver","valueUpdated","newValue","oldValue","element","multiline","openChanged","isOpen","waitForNextPaint","popoverTopContainer","popoverElement","height","offsetHeight","style","setProperty","removeProperty","_togglePopover","click","dispatchEvent","FocusEvent","openPopover","closePopover","setValue","options","valuesSet","Set","searchOptions","InputEvent","keydownHandler","onHostElementChange","onchange","onClearHandler","onHostElementInput","oninput","trim","toLocaleLowerCase","matchedCount","hidden","title","firstElementChild","tagName","display","innerText","searchParams","matched","some","text","statusMessageLocString","count","setStatusMessage","delegateFocus","fromHost","isRelatedTargetWithinHost","clearSelectedDisplay","isEventFromElement","handleFocusout","isLeavingHost","isHostLosingFocus","closeDropdown","handleSelectedDisplay","result","showActionSheetList","changeDetails","selectedOptionValues","change","undefined","_c","textContent","message","clearTimeout","statusMessageTimer","statusMessage","selected","remove","namedSlot","hasNoValue","selectionClone","cloneNode","clientHeight","outerHTML","replaceChild","document","createElement","slot","appendChild","checkSelectedDisplayHeight","renderCustomDisplay","hasSelectedDisplay","h","name","render","class","onChange","role","ref","el","label","clearable","error","invalid","optional","placeholder","hideLabel","ariaExpanded","ariaControls","ariaHaspopup","iconRight","onClick","onInput","onKeyDown","onFocus","onBlur","badgeTheme","_role","_preventEntry","optionsDropdown","controlElement","direction","popDirection","mode","popoverMode","block","type","id","listLabel","tabindex","visibilityToggle","selectedOptionsCount","checked","htmlFor"],"sources":["src/components/q2-select/q2-select.scss?tag=q2-select&encapsulation=shadow","src/components/q2-select/q2-select.tsx"],"sourcesContent":["@import '../../styles/host.scss';\n@import '../../styles/functions';\n@import '../../styles/dropdowns';\n\n:host {\n --comp-select-margin: #{var-list(\n --tct-select-margin,\n unquote(\n '#{var-list(var-prefixer(select-margin-top), --app-scale-4, 30px)} 0 #{var-list(var-prefixer(select-margin-bottom), --app-scale-4, 30px)}'\n )\n )};\n display: block;\n margin: var(--comp-select-margin);\n}\n\n.q2-select-container {\n position: relative;\n display: block;\n}\n\n.q2-select-input {\n margin: 0;\n\n --tct-input-min-height: #{var-list(var-prefixer(select-input-min-height))};\n --tct-input-max-height: #{var-list(var-prefixer(select-input-max-height), none)};\n}\n\n::slotted([slot='_selected-display']) {\n width: 100%;\n min-height: var(--comp-selected-display-height, 44px);\n}\n\n.custom-display-content {\n position: absolute;\n bottom: 0;\n left: calc(var-list(--tct-scale-2, --app-scale-2x, 10px) + 1px);\n height: 44px;\n width: calc(100% - 34px - var-list(--tct-scale-3, --app-scale-3x, 15px));\n overflow: hidden;\n cursor: pointer;\n transition: left var-list(--tct-tween-2, --app-tween-1, unquote('0.2s ease'));\n}\n\n.custom-display-content:not([hidden]) {\n display: flex;\n align-items: center;\n}\n\n.is-searchable.is-focused .custom-display-content,\n.is-searchable .custom-display-content:active {\n left: calc(var-list(--tct-scale-3, --app-scale-3x, 15px) + 1px);\n}\n\n.has-error .custom-display-content {\n width: calc(100% - 68px - var-list(--tct-scale-3, --app-scale-3x, 15px));\n}\n\n.popover-content {\n display: flex;\n flex-direction: column-reverse;\n}\n\n.popover-bottom-container {\n position: sticky;\n bottom: 0;\n z-index: 5;\n}\n\n.popover-top-container {\n position: sticky;\n top: 0;\n z-index: 5;\n .multi-select-header {\n padding: var(--tct-scale-2, var(--app-scale-2x, 10px)) var(--tct-scale-2, var(--app-scale-2x, 10px));\n background: var(--app-white);\n display: flex;\n gap: var-list(--app-scale-2x, 10px);\n align-items: center;\n\n fieldset {\n margin: 0;\n padding: 0;\n border: 0;\n display: flex;\n gap: var-list(--app-scale-2x, 10px);\n }\n\n legend {\n padding: 0;\n float: left;\n }\n\n label {\n cursor: pointer;\n padding: var-list(\n var-prefixer(select-multi-select-option-padding),\n var-prefixer(btn-badge-padding),\n unquote('2px 5px')\n );\n font-size: var-list(\n var-prefixer(select-multi-select-option-font-size),\n var-prefixer(btn-badge-font-size),\n inherit\n );\n border-radius: var-list(\n var-prefixer(select-multi-select-option-radius),\n var-prefixer(btn-badge-border-radius),\n --app-border-radius-1,\n 3px\n );\n background: var-list(\n --tct-select-multi-select-option-background,\n var-prefixer(select-multi-select-option-bg),\n --tct-badge-background,\n var-prefixer(btn-badge-bg),\n transparent\n );\n color: var-list(\n var-prefixer(select-multi-select-option-color),\n var-prefixer(btn-badge-font-color),\n inherit\n );\n\n &:hover {\n background: var-list(\n --tct-select-multi-select-option-hover-background,\n var-prefixer(select-multi-select-option-hover-background-color),\n var-prefixer(btn-badge-hover-bg),\n var-prefixer(gray-14),\n --app-gray-l3,\n #f2f2f2\n );\n color: var-list(\n --tct-select-multi-select-option-hover-color,\n var-prefixer(select-multi-select-option-color),\n var-prefixer(btn-badge-hover-font-color),\n var-prefixer(gray-5),\n --app-gray-d2,\n #404040\n );\n }\n }\n\n input {\n &:checked + label {\n &,\n &:enabled:hover {\n background: var-list(\n --tct-select-multi-select-option-active-background,\n var-prefixer(select-multi-select-option-active-background-color),\n var-prefixer(btn-primary-bg),\n #2e2e2e\n );\n color: var-list(\n var-prefixer(select-multi-select-option-active-color),\n var-prefixer(btn-primary-font-color),\n --app-white,\n #ffffff\n );\n }\n }\n\n &:disabled + label {\n opacity: var-list(\n var-prefixer(select-multi-select-option-disabled-opacity),\n var-prefixer(btn-disabled-opacity),\n --app-disabled-opacity,\n 0.4\n );\n cursor: not-allowed;\n }\n\n &:focus + label {\n box-shadow: var(--const-double-focus-ring);\n }\n }\n }\n}\n","import {\n Component,\n Prop,\n Element,\n h,\n Listen,\n State,\n EventEmitter,\n Event,\n ComponentInterface,\n Watch,\n Method,\n} from '@stencil/core';\nimport { IEventDetail, Q2InputCustomEvent, Q2OptionListCustomEvent } from 'src/components';\nimport {\n handleAriaLabel,\n isEventFromElement,\n isHostLosingFocus,\n isRelatedTargetWithinHost,\n loc,\n overrideFocus,\n waitForNextPaint,\n} from '../../utils';\nimport { IOptionValue } from '../q2-option-list/q2-option-list';\nimport { shouldShowActionSheet, showActionSheetList } from 'src/utils/action-sheet';\n\n@Component({ tag: 'q2-select', shadow: true, styleUrl: 'q2-select.scss' })\nexport class Q2Select implements ComponentInterface {\n /** Disables all interaction with the field and leverages the disabled visual style of `q2-input`. */\n @Prop({ reflect: true }) disabled: boolean = false;\n\n /**\n * The presence of `errors` will mark the field as invalid, putting it into an error state.\n * @localizable\n */\n @Prop() errors: string[];\n\n /**\n * Hide's the field's `<label>` element from view.\n * @warning\n * Only use when a visible label is impractical.\n */\n @Prop({ reflect: true, mutable: true }) hideLabel: boolean;\n\n /** Renders an icon button when the field is non-empty. Pressing the button clears all input from the field. */\n @Prop({ reflect: true }) clearable: boolean;\n\n /**\n * Instructs the component to use the action sheet workflow for displaying its options.\n *\n * For more information, see [Action Sheets](https://tecton.q2developer.com/guides/action-sheets/).\n * @warning\n * If your `q2-select` renders inside of an iframe, and you are using multiline/robust content options,\n * any custom CSS you apply to your options will not get passed up to the platform which displays the action sheet.\n * For this reason, we strongly suggest using the [q2-card](https://tecton.q2developer.com/ui/q2-card/) component since its styling is managed by Tecton.\n */\n @Prop() hoist: boolean = !!window.Tecton?.useActionSheets;\n\n /** Determines whether to show an error state. Its primary use-case is for an unfilled field. */\n @Prop({ reflect: true }) invalid: boolean;\n\n /**\n * The text that will be used as the label for the field.\n * @localizable\n */\n @Prop({ reflect: true, mutable: true }) label: string;\n\n /**\n * Determines the label that is applied to the option list for accessibility purposes.\n * @localizable\n */\n @Prop() listLabel: string = loc('tecton.element.select.listLabel');\n\n /** The minimum number of rows the component will try to display below or above the component when opened. */\n @Prop() minRows: number = 3;\n\n /** Enables text wrapping for `q2-option` elements. When `false`, the text truncates and does not wrap. */\n @Prop({ reflect: true }) multilineOptions: boolean = false;\n\n /** Enables multi-select functionality. */\n @Prop({ reflect: true }) multiple: boolean = false;\n\n /** Appends \"(optional)\" to the field label, and sets `aria-required` on the nested input tag to `false`. */\n @Prop({ reflect: true }) optional: boolean = false;\n\n /**\n * Text that appears within the field when it is blurred and empty.\n * Placeholder text disappears when the user selects an option.\n * @localizable\n */\n @Prop({ reflect: true }) placeholder: string;\n\n /** @deprecated */\n @Prop({ reflect: true }) popDirection: 'up' | 'down';\n\n /**\n * Determines the display mode of the popover.\n *\n * Providing a value of `legacy` instructs the popover to use absolute positioning instead of fixed positioning.\n *\n * @info\n * This is a temporary solution to work around styling issues related to using fixed positioning for the popover\n * when nested inside of elements with transform properties. This will be removed once the popover API is available\n * for use.\n */\n @Prop({ mutable: true }) popoverMode: 'legacy' = null;\n\n /**\n * Appends \"(read only)\" to the field label, and field becomes unusable, but remains focusable.\n * Takes priority over `optional` if both are `true`.\n */\n @Prop({ reflect: true }) readonly: boolean = false;\n\n /** Enables search functionality. */\n @Prop({ reflect: true }) searchable: boolean = false;\n\n /**\n * Each item in this array should correspond to the value of a `q2-option` element.\n * This property is only relevant for `multiple` (i.e., multi-select) implementations.\n */\n @Prop({ mutable: true }) selectedOptions: string[] = [];\n\n /**\n * The current value for the select. This should correspond to the value of a nested q2-option element.\n * This property is only relevant for single-select implementations.\n */\n @Prop({ mutable: true }) value: string;\n\n /** @deprecated */\n @Prop({ reflect: true, mutable: true }) ariaLabel: string;\n\n @Element() hostElement: HTMLElement;\n\n @State() open: boolean = false;\n @State() showSelected: boolean = false;\n @State() searchText: string = '';\n @State() hasCustomDisplay: boolean = false;\n @State() hasPopoverTop: boolean = false;\n @State() hasPopoverBottom: boolean = false;\n @State() inputFocused: boolean = false;\n @State() statusMessage: string;\n @State() prioritizeSearch: boolean = false;\n @State() structuredSelectedOptions: IOptionValue[] = [];\n\n inputField?: HTMLQ2InputElement;\n optionList: HTMLQ2OptionListElement;\n popoverElement?: HTMLQ2PopoverElement;\n popoverTopContainer?: HTMLDivElement;\n scheduledAfterRender: (() => void)[] = [];\n mutationObserver: MutationObserver;\n\n /// Lifecycle Hooks ///\n componentWillLoad() {\n handleAriaLabel(this);\n this.buildStructuredSelectedOptions();\n this.handleMultilineOptionsUpdate(this.multilineOptions, false);\n }\n\n componentDidLoad() {\n const observer = new MutationObserver(this.onMutationObserved);\n observer.observe(this.hostElement, { childList: true, subtree: true });\n this.mutationObserver = observer;\n this.onMutationObserved();\n overrideFocus(this.hostElement);\n setTimeout(() => this.checkSelectedDisplay(), 0);\n }\n\n componentDidRender() {\n setTimeout(() => {\n this.scheduledAfterRender.forEach(fn => fn());\n this.scheduledAfterRender = [];\n }, 25);\n }\n\n disconnectedCallback() {\n this.mutationObserver?.disconnect();\n this.mutationObserver = null;\n }\n\n /// Getters ///\n get innerInputField(): HTMLInputElement | HTMLButtonElement {\n return this.inputField?.shadowRoot?.querySelector('.input-field');\n }\n\n get innerInputContainer(): HTMLElement {\n return this.inputField?.shadowRoot?.querySelector('.input-container');\n }\n\n get badgeValue(): string {\n if (!this.multiple) return null;\n const optionsLength = this.selectedOptions?.length ?? 0;\n if (this.open && this.searchable) return optionsLength ? `${optionsLength}` : null;\n else return optionsLength > 1 ? `+${optionsLength - 1}` : null;\n }\n\n get popoverMinHeight() {\n const { minRows } = this;\n const firstOption = this.hostElement.querySelector<HTMLQ2OptionElement>('q2-option:not([hidden])');\n let minHeight = firstOption && window.getComputedStyle(firstOption).minHeight;\n\n // Safari doesn't return a min-height for non-visible items\n if (!minHeight || minHeight === '0px') minHeight = '44px';\n\n return minRows * parseInt(minHeight);\n }\n\n get selectedDisplay() {\n if (this.prioritizeSearch || this.searchText) return this.searchText;\n if (this.hasCustomDisplay) return '';\n return this.multiple ? this.calculateMultiSelectSelectedDisplay() : this.calculateSingleSelectSelectedDisplay();\n }\n\n get selectedDisplaySlot() {\n return this.hostElement.querySelector<HTMLElement>('[slot=\"_selected-display\"]');\n }\n\n get firstSelectedValue() {\n return this.multiple ? this.selectedOptions?.[0] : this.value;\n }\n\n get firstSelectedOptionElement() {\n const { firstSelectedValue } = this;\n return firstSelectedValue ? this.optionElements.find(({ value }) => value === firstSelectedValue) : null;\n }\n\n get optionElements() {\n return Array.from(this.hostElement.querySelectorAll<HTMLQ2OptionElement>('q2-option'));\n }\n\n get wrapperClasses() {\n const { errors } = this;\n const classes = ['q2-select-container'];\n if (Array.isArray(errors) && errors.length > 0) classes.push('has-error');\n if (this.inputFocused) classes.push('is-focused');\n if (this.searchable) classes.push('is-searchable');\n return classes.join(' ');\n }\n\n /// Watchers ///\n @Watch('value')\n @Watch('selectedOptions')\n buildStructuredSelectedOptions() {\n const { multiple, selectedOptions, value } = this;\n if (multiple) {\n this.structuredSelectedOptions = !!selectedOptions?.length\n ? selectedOptions.map(option => (typeof option === 'string' ? { value: option } : option))\n : [];\n } else {\n this.structuredSelectedOptions = value ? [{ value }] : [];\n }\n }\n\n @Watch('ariaLabel')\n ariaLabelObserver() {\n handleAriaLabel(this);\n }\n\n @Watch('value')\n valueUpdated() {\n if (this.multiple) return;\n this.clearSearchText();\n }\n\n @Watch('multilineOptions')\n handleMultilineOptionsUpdate(newValue, oldValue) {\n if (newValue === oldValue) return;\n this.optionElements.forEach(element => (element.multiline = newValue));\n }\n\n @Watch('open')\n openChanged(isOpen: boolean) {\n this.scheduledAfterRender.push(async () => {\n await waitForNextPaint();\n const { popoverTopContainer, popoverElement } = this;\n const height = (isOpen && popoverTopContainer?.offsetHeight) || 0;\n if (height) {\n popoverElement.style.setProperty('--comp-popover-top-container-height', `${height}px`);\n } else {\n popoverElement.style.removeProperty('--comp-popover-top-container-height');\n }\n });\n }\n\n /// Events ///\n /**\n * Emitted when an option is selected or deselected.\n *\n * When the multi-select is enabled, the `value` property will be `undefined` and the `selectedOptions` property\n * will contain the selected option values.\n *\n * @legacyEvent\n */\n @Event() change: EventEmitter<{ value: string; selectedOptions: string[] }>;\n\n /**\n * Emitted when the input value changes.\n *\n * Requires the `searchable` prop to be set to `true`.\n */\n @Event() input: EventEmitter<{ query: string }>;\n\n /// Methods ///\n _togglePopover() {\n const { innerInputField } = this;\n innerInputField?.click();\n innerInputField?.focus();\n innerInputField.dispatchEvent(new FocusEvent('focus'));\n }\n\n /**\n * Emulates clicking the `<input>` to display the popover if it is hidden.\n *\n * @testOnly\n */\n @Method()\n async openPopover() {\n if (this.open || this.disabled) return;\n this._togglePopover();\n }\n\n /**\n * Emulates clicking the `<input>` to hide the popover if it is visible.\n *\n * @testOnly\n */\n @Method()\n async closePopover() {\n if (!this.open || this.disabled) return;\n this._togglePopover();\n }\n\n /**\n * Emulates clicking the `<input>` to display the popover and selecting the option(s) with the specified value(s).\n *\n * If the multi-select is enabled and the `closePopover` argument is `true` (default), the popover will be closed\n * after the option(s) are selected.\n *\n * @testOnly\n */\n @Method()\n async setValue(values: string | string[], options: { closePopover?: boolean } = { closePopover: true }) {\n const valuesSet = new Set(Array.isArray(values) ? values : [values]);\n if (!this.open) {\n await this.openPopover();\n await waitForNextPaint();\n }\n\n valuesSet.forEach(value => {\n this.optionElements.find(option => option.value === value)?.click();\n });\n\n if (options.closePopover) {\n await this.closePopover();\n await waitForNextPaint();\n }\n }\n\n /**\n * Emulates focusing the `<input>`, entering the provided value, and emitting an `input` event.\n *\n * @warning\n * Only applicable when the input is searchable.\n *\n * @testOnly\n */\n @Method()\n searchOptions(query: string) {\n if (!this.searchable) return;\n\n const { innerInputField } = this;\n innerInputField.focus();\n innerInputField.dispatchEvent(new FocusEvent('focus'));\n innerInputField.value = query;\n innerInputField.dispatchEvent(new InputEvent('input'));\n }\n\n /// Listeners ///\n @Listen('keydown')\n keydownHandler(event: KeyboardEvent) {\n this.inputKeydownHandler(event);\n }\n\n @Listen('change')\n onHostElementChange(event: CustomEvent<{ value: string; selectedOptions: string[] }>) {\n if (this.readonly || this.disabled) return;\n if (event.target !== this.hostElement || this.hostElement.onchange) return;\n if (this.multiple) {\n this.value = null;\n this.selectedOptions = event.detail.selectedOptions;\n } else {\n this.value = event.detail.value;\n this.selectedOptions = [];\n }\n }\n\n @Listen('clear')\n onClearHandler() {\n this.clearValue();\n }\n\n @Listen('input')\n onHostElementInput(event: CustomEvent) {\n if (!this.searchable || event.target !== this.hostElement || this.hostElement.oninput) return;\n const options = this.optionElements;\n const query = this.searchText.trim().toLocaleLowerCase();\n let matchedCount = 0;\n options.forEach(option => {\n if (query === '') {\n option.hidden = false;\n return;\n }\n\n const title =\n option.firstElementChild?.tagName === 'Q2-CARD'\n ? (option.firstElementChild as HTMLQ2CardElement).title\n : null;\n const { display = '', innerText = '' } = option;\n const searchParams = [display, title, innerText];\n const matched = searchParams.some(text => text?.toLocaleLowerCase().includes(query) ?? false);\n\n option.hidden = !matched;\n if (matched) matchedCount++;\n });\n\n const statusMessageLocString = query\n ? 'tecton.element.select.searchable.results'\n : 'tecton.element.select.allOptions';\n const count = query ? matchedCount : options.length;\n this.setStatusMessage(loc(statusMessageLocString, [count]));\n }\n\n @Listen('focus')\n delegateFocus(event: FocusEvent) {\n const fromHost = isRelatedTargetWithinHost(event, this.hostElement);\n const prioritizeSearch = (this.prioritizeSearch = fromHost && this.searchable);\n if (prioritizeSearch) {\n this.clearSelectedDisplay();\n } else if (isEventFromElement(event, this.hostElement)) {\n this.inputField.shadowRoot.querySelector<HTMLElement>('.input-field').focus();\n }\n }\n\n @Listen('focusout')\n handleFocusout(event: FocusEvent) {\n const isLeavingHost = isHostLosingFocus(event, this.hostElement);\n if (isLeavingHost) this.closeDropdown();\n this.prioritizeSearch = !isLeavingHost && this.searchable;\n }\n\n @Listen('displayChanged')\n handleSelectedDisplay(event: CustomEvent) {\n if (this.multiple) return;\n this.inputField.value = event.detail.display;\n }\n\n /// Helpers ///\n async executeActionSheet(event: MouseEvent | KeyboardEvent) {\n const result = await showActionSheetList(this, event);\n this.handleSelectionChanges(result);\n }\n\n handleSelectionChanges(changeDetails: { value?: string; values?: IOptionValue[] }) {\n const { value = '', values = [] } = changeDetails;\n const selectedOptionValues = values.map(value => value.value);\n const { multiple } = this;\n if (!this.hostElement.onchange) {\n this.selectedOptions = selectedOptionValues;\n }\n\n this.change.emit({\n value: multiple ? undefined : value,\n selectedOptions: multiple ? selectedOptionValues : undefined,\n });\n }\n\n showSelectedOptions = () => {\n this.showSelected = true;\n };\n\n showAllOptions = () => {\n this.showSelected = false;\n };\n\n clearValue() {\n const { multiple } = this;\n this.value = '';\n this.selectedOptions = [];\n this.change.emit({ value: multiple ? undefined : '', selectedOptions: multiple ? [] : undefined });\n }\n\n calculateMultiSelectSelectedDisplay() {\n const { firstSelectedOptionElement, firstSelectedValue, multilineOptions } = this;\n if (!firstSelectedValue) return '';\n if (firstSelectedOptionElement?.display) return loc(firstSelectedOptionElement.display);\n if (multilineOptions && this.searchable) return this.searchText;\n if (multilineOptions) return '';\n return (\n firstSelectedOptionElement?.textContent?.trim() ?? firstSelectedOptionElement?.value ?? firstSelectedValue\n );\n }\n\n calculateSingleSelectSelectedDisplay() {\n const { firstSelectedOptionElement, multilineOptions } = this;\n if (multilineOptions) {\n return (firstSelectedOptionElement?.display && loc(firstSelectedOptionElement.display)) || this.value || '';\n } else {\n return (\n (firstSelectedOptionElement?.display && loc(firstSelectedOptionElement.display)) ||\n firstSelectedOptionElement?.textContent?.trim() ||\n this.value ||\n ''\n );\n }\n }\n\n onMutationObserved = () => {\n const { hostElement, hasPopoverTop, hasPopoverBottom } = this;\n const slotContainer = hostElement.querySelector('.custom-display-content');\n const displaySlot = hostElement.shadowRoot.querySelector<HTMLSlotElement>('slot[name=\"q2-select-display\"]');\n const hasCustomDisplay = !!displaySlot\n ? displaySlot.assignedNodes().length > 0\n : slotContainer.children.length > 0;\n\n if (this.hasCustomDisplay !== hasCustomDisplay) {\n this.hasCustomDisplay = hasCustomDisplay;\n }\n\n const popTopSlot = hostElement.shadowRoot.querySelector<HTMLSlotElement>('slot[name=\"popover-top\"]');\n const topSlotHasNode = popTopSlot.assignedNodes().length > 0;\n if (hasPopoverTop !== topSlotHasNode) {\n this.hasPopoverTop = topSlotHasNode;\n }\n\n const popBottomSlot = hostElement.shadowRoot.querySelector<HTMLSlotElement>('slot[name=\"popover-bottom\"]');\n const bottomSlotHasNode = popBottomSlot.assignedNodes().length > 0;\n if (hasPopoverBottom !== bottomSlotHasNode) {\n this.hasPopoverBottom = bottomSlotHasNode;\n }\n\n this.checkSelectedOptions();\n };\n\n onOptionListChange = (event: Q2OptionListCustomEvent<{ value: string; values: IOptionValue[] }>) => {\n event.stopPropagation();\n const { values } = event.detail;\n\n if (values.length === 0) this.showAllOptions();\n this.handleSelectionChanges(event.detail);\n };\n\n openDropdownWithoutActiveElement() {\n if (this.readonly || this.disabled) return;\n this.optionList.setActiveElement(null);\n this.open = true;\n }\n\n closeDropdown() {\n this.open = false;\n this.clearSearchText();\n }\n\n clearSearchText() {\n if (!this.searchText) return;\n this.searchText = '';\n this.input.emit({ query: '' });\n }\n\n toggleDropdown() {\n if (this.readonly || this.disabled) return;\n\n if (this.open && !this.searchText) {\n this.closeDropdown();\n } else {\n this.openDropdownWithoutActiveElement();\n }\n }\n\n focusInput() {\n this.inputField?.dispatchEvent(new FocusEvent('focus'));\n }\n\n statusMessageTimer: NodeJS.Timeout;\n setStatusMessage(message) {\n clearTimeout(this.statusMessageTimer);\n this.statusMessage = '';\n this.statusMessageTimer = setTimeout(() => {\n this.statusMessage = message;\n }, 1000);\n }\n\n checkSelectedOptions() {\n const { multiple, selectedOptions, value } = this;\n this.optionElements.forEach(option => {\n if (multiple) {\n option.selected = selectedOptions.includes(option.value);\n } else {\n option.selected = option.value === value;\n }\n });\n }\n\n clearSelectedDisplay() {\n this.selectedDisplaySlot?.remove();\n }\n\n checkSelectedDisplay() {\n let namedSlot = this.selectedDisplaySlot;\n const { value, multiple, selectedOptions, multilineOptions, firstSelectedOptionElement, prioritizeSearch } =\n this;\n const hasNoValue = !value && multiple && !selectedOptions?.length;\n if (prioritizeSearch || !multilineOptions || hasNoValue) return this.clearSelectedDisplay();\n\n if (!firstSelectedOptionElement || firstSelectedOptionElement.display) return this.clearSelectedDisplay();\n\n // Clone selected option and remove elements with hide-on-select attribute\n const selectionClone = firstSelectedOptionElement.firstElementChild.cloneNode(true) as HTMLElement;\n selectionClone.querySelectorAll('[hide-on-select]').forEach(element => element.remove());\n\n if (namedSlot) {\n const height = namedSlot.clientHeight === 0 ? 'auto' : `${namedSlot.clientHeight}px`;\n namedSlot.style.setProperty('--comp-selected-display-height', height);\n if (namedSlot.firstElementChild.outerHTML !== selectionClone.outerHTML) {\n namedSlot.replaceChild(selectionClone, namedSlot.firstElementChild);\n }\n } else {\n namedSlot = document.createElement('div');\n namedSlot.slot = '_selected-display';\n namedSlot.appendChild(selectionClone);\n this.hostElement.appendChild(namedSlot);\n }\n return namedSlot;\n }\n\n checkSelectedDisplayHeight() {\n const { selectedDisplaySlot } = this;\n if (!selectedDisplaySlot) return;\n selectedDisplaySlot.style.setProperty('--comp-selected-display-height', '44px');\n }\n\n /// Event handlers ///\n onPopoverState = ({\n detail: { open, action },\n }: CustomEvent<{ open: boolean; action: 'close' | 'select' | 'open' }>) => {\n if (!open || this.searchText) {\n if (action !== 'select') {\n this.optionList.setActiveElement(null);\n }\n this.inputField.focus();\n }\n\n if (this.open === open) return;\n this.open = open;\n };\n\n inputKeydownHandler = (event: KeyboardEvent) => {\n if (this.readonly || this.disabled) return;\n const key = event.key;\n const hasSlot = this.hasPopoverTop || this.hasPopoverBottom;\n const isShiftTab = key === 'Tab' && event.shiftKey;\n if (hasSlot && (key === 'Tab' || key === 'Enter' || isShiftTab)) return;\n if (shouldShowActionSheet(this, event)) {\n return this.executeActionSheet(event);\n }\n\n const keysForOptionListToHandle = [\n 'ArrowDown',\n 'ArrowUp',\n 'PageDown',\n 'PageUp',\n 'Home',\n 'End',\n 'Escape',\n 'Tab',\n ];\n\n if (this.searchable && (key === ' ' || key === 'Enter') && this.inputField.value == '') {\n event.preventDefault();\n if (!this.open) this.openDropdownWithoutActiveElement();\n }\n\n if (this.searchable && !keysForOptionListToHandle.includes(key)) return;\n if (this.shouldClearSearchText(event)) this.clearSearchText();\n\n // Prevent click event from firing when spacebar is pressed\n if (key === ' ') event.preventDefault();\n\n this.optionList.handleExternalKeydown(event);\n };\n\n shouldClearSearchText(event: KeyboardEvent) {\n return this.searchable && !!this.searchText && event.key === 'Escape';\n }\n\n visibilityToggleKeyDown = (event: KeyboardEvent) => {\n const key = event.key;\n const isShiftTab = key === 'Tab' && event.shiftKey;\n const isRadioControlKey = ['ArrowLeft', 'ArrowRight', 'ArrowUp', 'ArrowDown'].includes(key);\n if (isRadioControlKey) event.stopPropagation();\n if (isShiftTab) {\n event.stopPropagation();\n // allows shift+tab keys to select the top slot when present\n if (this.hasPopoverTop) return;\n\n this.optionList.setDefaultActiveElement();\n }\n };\n\n inputClickHandler = async (event: MouseEvent) => {\n event.stopPropagation();\n if (shouldShowActionSheet(this)) {\n return this.executeActionSheet(event);\n }\n this.toggleDropdown();\n this.focusInput();\n };\n\n inputInputHandler = (event: Q2InputCustomEvent<IEventDetail> & InputEvent) => {\n event.stopPropagation();\n const eventValue = event.detail.value;\n const shouldClearValue = !!this.value;\n\n if (shouldClearValue) this.clearValue();\n if (!this.open) this.openDropdownWithoutActiveElement();\n\n this.prioritizeSearch = true;\n this.searchText = eventValue;\n this.input.emit({ query: eventValue });\n };\n\n inputFocusHandler = () => {\n this.inputFocused = true;\n };\n\n inputBlurHandler = () => {\n this.inputFocused = false;\n };\n\n inputChangeHandler = (event: Event) => {\n event.stopPropagation();\n };\n\n clickedElsewhere = (event: CustomEvent) => {\n const target = event.target as HTMLClickElsewhereElement;\n if (target.localName !== 'click-elsewhere') return;\n event.stopPropagation();\n };\n\n onCustomDisplayClick = (event: MouseEvent) => {\n event.stopPropagation();\n this.focusInput();\n this.toggleDropdown();\n };\n\n /// DOM ///\n renderCustomDisplay() {\n const hasSelectedDisplay = this.checkSelectedDisplay();\n if (!hasSelectedDisplay) return;\n this.checkSelectedDisplayHeight();\n\n return (\n <slot\n name=\"_selected-display\"\n slot=\"custom-display\"\n />\n );\n }\n\n render() {\n return (\n <click-elsewhere\n class={this.wrapperClasses}\n onChange={this.clickedElsewhere}\n >\n <div\n aria-live=\"polite\"\n aria-atomic=\"true\"\n role=\"status\"\n class=\"sr\"\n >\n {this.statusMessage}\n </div>\n <q2-input\n ref={el => (this.inputField = el)}\n class=\"q2-select-input\"\n label={(this.label && loc(this.label)) || ''}\n value={this.selectedDisplay}\n clearable={(this.clearable && (!!this.value || !!this.selectedOptions?.length)) || undefined}\n errors={\n (Array.isArray(this.errors) &&\n this.errors.length > 0 &&\n this.errors.map(error => loc(error))) ||\n (this.invalid && ['tecton.element.select.invalid']) ||\n []\n }\n disabled={this.disabled}\n optional={this.optional}\n readonly={!!this.readonly}\n placeholder={this.placeholder || undefined}\n hideLabel={this.hideLabel}\n ariaExpanded={`${this.open}`}\n ariaControls=\"option-list\"\n ariaHaspopup=\"listbox\"\n test-id=\"toggleDropdown\"\n hide-messages\n iconRight=\"chevron-down\"\n onClick={this.inputClickHandler}\n onInput={this.inputInputHandler}\n onKeyDown={this.inputKeydownHandler}\n onFocus={this.inputFocusHandler}\n onBlur={this.inputBlurHandler}\n onChange={this.inputChangeHandler}\n badgeValue={this.badgeValue}\n badgeTheme={this.inputFocused ? 'primary' : undefined}\n _role=\"combobox\"\n _preventEntry={!this.searchable}\n >\n {this.renderCustomDisplay()}\n </q2-input>\n <div\n class=\"custom-display-content\"\n hidden={!this.hasCustomDisplay || !!this.searchText}\n onClick={this.onCustomDisplayClick}\n >\n <slot name=\"q2-select-display\" />\n </div>\n {this.optionsDropdown()}\n </click-elsewhere>\n );\n }\n\n optionsDropdown() {\n return (\n <q2-popover\n ref={el => (this.popoverElement = el)}\n controlElement={this.innerInputContainer}\n open={this.open}\n minHeight={this.popoverMinHeight}\n direction={this.popDirection}\n mode={this.popoverMode || undefined}\n block\n >\n <div class=\"popover-content\">\n <q2-option-list\n onPopoverState={this.onPopoverState}\n ref={el => (this.optionList = el)}\n type=\"listbox\"\n id=\"option-list\"\n show-selected={this.showSelected}\n label={this.listLabel}\n multiple={this.multiple}\n selectedOptions={this.structuredSelectedOptions}\n onChange={this.onOptionListChange}\n >\n <slot />\n </q2-option-list>\n <div\n class=\"popover-top-container\"\n ref={el => (this.popoverTopContainer = el)}\n hidden={!this.multiple && !this.hasPopoverTop}\n tabindex=\"-1\"\n >\n <slot name=\"popover-top\"></slot>\n {this.multiple && this.visibilityToggle()}\n </div>\n </div>\n <div\n class=\"popover-bottom-container\"\n hidden={!this.hasPopoverBottom}\n tabindex=\"-1\"\n >\n <slot name=\"popover-bottom\" />\n </div>\n </q2-popover>\n );\n }\n\n visibilityToggle() {\n const selectedOptionsCount = this.selectedOptions?.length ?? 0;\n const { showSelected } = this;\n return (\n <div class=\"multi-select-header\">\n <fieldset>\n <legend aria-label={loc('tecton.element.select.multiHeader.showing')}>\n {loc('tecton.element.select.multiHeader.showing')}\n </legend>\n <div>\n <input\n class=\"sr\"\n type=\"radio\"\n id=\"all\"\n name=\"viewDisplay\"\n value=\"all\"\n checked={!showSelected}\n aria-label={loc('tecton.element.select.multiHeader.allAriaLabel')}\n test-id=\"allOptionsButton\"\n onClick={this.showAllOptions}\n onKeyDown={this.visibilityToggleKeyDown}\n />\n <label htmlFor=\"all\">{loc('tecton.element.select.multiHeader.all')}</label>\n </div>\n\n <div>\n <input\n class=\"sr\"\n type=\"radio\"\n id=\"selected\"\n disabled={selectedOptionsCount === 0}\n name=\"viewDisplay\"\n value=\"selected\"\n aria-label={loc('tecton.element.select.multiHeader.selectedAriaLabel', [\n selectedOptionsCount,\n ])}\n checked={showSelected}\n test-id=\"selectedOptionsButton\"\n onClick={this.showSelectedOptions}\n onKeyDown={this.visibilityToggleKeyDown}\n />\n <label htmlFor=\"selected\">\n {loc('tecton.element.select.multiHeader.selected', [selectedOptionsCount])}\n </label>\n </div>\n </fieldset>\n </div>\n );\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["q2SelectCss","Q2SelectStyle0","Q2Select","this","scheduledAfterRender","showSelectedOptions","showSelected","showAllOptions","onMutationObserved","hostElement","hasPopoverTop","hasPopoverBottom","slotContainer","querySelector","displaySlot","shadowRoot","hasCustomDisplay","assignedNodes","length","children","popTopSlot","topSlotHasNode","popBottomSlot","bottomSlotHasNode","checkSelectedOptions","onOptionListChange","event","stopPropagation","values","detail","handleSelectionChanges","onPopoverState","open","action","searchText","optionList","setActiveElement","inputField","focus","inputKeydownHandler","readonly","disabled","key","hasSlot","isShiftTab","shiftKey","shouldShowActionSheet","executeActionSheet","keysForOptionListToHandle","searchable","value","preventDefault","openDropdownWithoutActiveElement","includes","shouldClearSearchText","clearSearchText","handleExternalKeydown","visibilityToggleKeyDown","isRadioControlKey","setDefaultActiveElement","inputClickHandler","async","toggleDropdown","focusInput","inputInputHandler","eventValue","shouldClearValue","clearValue","prioritizeSearch","input","emit","query","inputFocusHandler","inputFocused","inputBlurHandler","inputChangeHandler","clickedElsewhere","target","localName","onCustomDisplayClick","_a","window","Tecton","useActionSheets","loc","componentWillLoad","handleAriaLabel","buildStructuredSelectedOptions","handleMultilineOptionsUpdate","multilineOptions","componentDidLoad","observer","MutationObserver","observe","childList","subtree","mutationObserver","overrideFocus","setTimeout","checkSelectedDisplay","componentDidRender","forEach","fn","disconnectedCallback","disconnect","innerInputField","_b","innerInputContainer","badgeValue","multiple","optionsLength","selectedOptions","popoverMinHeight","minRows","firstOption","minHeight","getComputedStyle","parseInt","selectedDisplay","calculateMultiSelectSelectedDisplay","calculateSingleSelectSelectedDisplay","selectedDisplaySlot","firstSelectedValue","firstSelectedOptionElement","optionElements","find","Array","from","querySelectorAll","wrapperClasses","errors","classes","isArray","push","join","structuredSelectedOptions","map","option","ariaLabelObserver","valueUpdated","newValue","oldValue","element","multiline","openChanged","isOpen","waitForNextPaint","popoverTopContainer","popoverElement","height","offsetHeight","style","setProperty","removeProperty","_togglePopover","click","dispatchEvent","FocusEvent","openPopover","closePopover","setValue","options","valuesSet","Set","searchOptions","InputEvent","keydownHandler","onHostElementChange","onchange","onClearHandler","onHostElementInput","oninput","trim","toLocaleLowerCase","matchedCount","hidden","title","firstElementChild","tagName","display","innerText","searchParams","matched","some","text","statusMessageLocString","count","setStatusMessage","delegateFocus","fromHost","isRelatedTargetWithinHost","clearSelectedDisplay","isEventFromElement","handleFocusout","isLeavingHost","isHostLosingFocus","closeDropdown","handleSelectedDisplay","result","showActionSheetList","changeDetails","selectedOptionValues","change","undefined","_c","textContent","message","clearTimeout","statusMessageTimer","statusMessage","selected","remove","namedSlot","hasNoValue","selectionClone","cloneNode","clientHeight","outerHTML","replaceChild","document","createElement","slot","appendChild","checkSelectedDisplayHeight","renderCustomDisplay","hasSelectedDisplay","h","name","render","class","onChange","role","ref","el","label","clearable","error","invalid","optional","placeholder","hideLabel","ariaExpanded","ariaControls","ariaHaspopup","iconRight","onClick","onInput","onKeyDown","onFocus","onBlur","badgeTheme","_role","_preventEntry","optionsDropdown","controlElement","direction","popDirection","mode","popoverMode","block","type","id","listLabel","tabindex","visibilityToggle","selectedOptionsCount","checked","htmlFor"],"sources":["src/components/q2-select/q2-select.scss?tag=q2-select&encapsulation=shadow","src/components/q2-select/q2-select.tsx"],"sourcesContent":["@import '../../styles/host.scss';\n@import '../../styles/functions';\n@import '../../styles/dropdowns';\n\n:host {\n --comp-default-select-margin: #{var-list(var-prefixer(select-margin-top), --app-scale-5x, 25px) 0\n var-list(var-prefixer(select-margin-bottom), --app-scale-5x, 25px)};\n display: block;\n margin: var-list(--tct-select-margin, --comp-default-select-margin);\n}\n\n.q2-select-container {\n position: relative;\n display: block;\n}\n\n.q2-select-input {\n margin: 0;\n\n --tct-input-min-height: #{var-list(var-prefixer(select-input-min-height))};\n --tct-input-max-height: #{var-list(var-prefixer(select-input-max-height), none)};\n}\n\n::slotted([slot='_selected-display']) {\n width: 100%;\n min-height: var(--comp-selected-display-height, 44px);\n}\n\n.custom-display-content {\n position: absolute;\n bottom: 0;\n left: calc(var-list(--tct-scale-2, --app-scale-2x, 10px) + 1px);\n height: 44px;\n width: calc(100% - 34px - var-list(--tct-scale-3, --app-scale-3x, 15px));\n overflow: hidden;\n cursor: pointer;\n transition: left var-list(--tct-tween-2, --app-tween-1, unquote('0.2s ease'));\n}\n\n.custom-display-content:not([hidden]) {\n display: flex;\n align-items: center;\n}\n\n.is-searchable.is-focused .custom-display-content,\n.is-searchable .custom-display-content:active {\n left: calc(var-list(--tct-scale-3, --app-scale-3x, 15px) + 1px);\n}\n\n.has-error .custom-display-content {\n width: calc(100% - 68px - var-list(--tct-scale-3, --app-scale-3x, 15px));\n}\n\n.popover-content {\n display: flex;\n flex-direction: column-reverse;\n}\n\n.popover-bottom-container {\n position: sticky;\n bottom: 0;\n z-index: 5;\n}\n\n.popover-top-container {\n position: sticky;\n top: 0;\n z-index: 5;\n .multi-select-header {\n padding: var(--tct-scale-2, var(--app-scale-2x, 10px)) var(--tct-scale-2, var(--app-scale-2x, 10px));\n background: var(--app-white);\n display: flex;\n gap: var-list(--app-scale-2x, 10px);\n align-items: center;\n\n fieldset {\n margin: 0;\n padding: 0;\n border: 0;\n display: flex;\n gap: var-list(--app-scale-2x, 10px);\n }\n\n legend {\n padding: 0;\n float: left;\n }\n\n label {\n cursor: pointer;\n padding: var-list(\n var-prefixer(select-multi-select-option-padding),\n var-prefixer(btn-badge-padding),\n unquote('2px 5px')\n );\n font-size: var-list(\n var-prefixer(select-multi-select-option-font-size),\n var-prefixer(btn-badge-font-size),\n inherit\n );\n border-radius: var-list(\n var-prefixer(select-multi-select-option-radius),\n var-prefixer(btn-badge-border-radius),\n --app-border-radius-1,\n 3px\n );\n background: var-list(\n --tct-select-multi-select-option-background,\n var-prefixer(select-multi-select-option-bg),\n --tct-badge-background,\n var-prefixer(btn-badge-bg),\n transparent\n );\n color: var-list(\n var-prefixer(select-multi-select-option-color),\n var-prefixer(btn-badge-font-color),\n inherit\n );\n\n &:hover {\n background: var-list(\n --tct-select-multi-select-option-hover-background,\n var-prefixer(select-multi-select-option-hover-background-color),\n var-prefixer(btn-badge-hover-bg),\n var-prefixer(gray-14),\n --app-gray-l3,\n #f2f2f2\n );\n color: var-list(\n --tct-select-multi-select-option-hover-color,\n var-prefixer(select-multi-select-option-color),\n var-prefixer(btn-badge-hover-font-color),\n var-prefixer(gray-5),\n --app-gray-d2,\n #404040\n );\n }\n }\n\n input {\n &:checked + label {\n &,\n &:enabled:hover {\n background: var-list(\n --tct-select-multi-select-option-active-background,\n var-prefixer(select-multi-select-option-active-background-color),\n var-prefixer(btn-primary-bg),\n #2e2e2e\n );\n color: var-list(\n var-prefixer(select-multi-select-option-active-color),\n var-prefixer(btn-primary-font-color),\n --app-white,\n #ffffff\n );\n }\n }\n\n &:disabled + label {\n opacity: var-list(\n var-prefixer(select-multi-select-option-disabled-opacity),\n var-prefixer(btn-disabled-opacity),\n --app-disabled-opacity,\n 0.4\n );\n cursor: not-allowed;\n }\n\n &:focus + label {\n box-shadow: var(--const-double-focus-ring);\n }\n }\n }\n}\n","import {\n Component,\n Prop,\n Element,\n h,\n Listen,\n State,\n EventEmitter,\n Event,\n ComponentInterface,\n Watch,\n Method,\n} from '@stencil/core';\nimport { IEventDetail, Q2InputCustomEvent, Q2OptionListCustomEvent } from 'src/components';\nimport {\n handleAriaLabel,\n isEventFromElement,\n isHostLosingFocus,\n isRelatedTargetWithinHost,\n loc,\n overrideFocus,\n waitForNextPaint,\n} from '../../utils';\nimport { IOptionValue } from '../q2-option-list/q2-option-list';\nimport { shouldShowActionSheet, showActionSheetList } from 'src/utils/action-sheet';\n\n@Component({ tag: 'q2-select', shadow: true, styleUrl: 'q2-select.scss' })\nexport class Q2Select implements ComponentInterface {\n /** Disables all interaction with the field and leverages the disabled visual style of `q2-input`. */\n @Prop({ reflect: true }) disabled: boolean = false;\n\n /**\n * The presence of `errors` will mark the field as invalid, putting it into an error state.\n * @localizable\n */\n @Prop() errors: string[];\n\n /**\n * Hide's the field's `<label>` element from view.\n * @warning\n * Only use when a visible label is impractical.\n */\n @Prop({ reflect: true, mutable: true }) hideLabel: boolean;\n\n /** Renders an icon button when the field is non-empty. Pressing the button clears all input from the field. */\n @Prop({ reflect: true }) clearable: boolean;\n\n /**\n * Instructs the component to use the action sheet workflow for displaying its options.\n *\n * For more information, see [Action Sheets](https://tecton.q2developer.com/guides/action-sheets/).\n * @warning\n * If your `q2-select` renders inside of an iframe, and you are using multiline/robust content options,\n * any custom CSS you apply to your options will not get passed up to the platform which displays the action sheet.\n * For this reason, we strongly suggest using the [q2-card](https://tecton.q2developer.com/ui/q2-card/) component since its styling is managed by Tecton.\n */\n @Prop() hoist: boolean = !!window.Tecton?.useActionSheets;\n\n /** Determines whether to show an error state. Its primary use-case is for an unfilled field. */\n @Prop({ reflect: true }) invalid: boolean;\n\n /**\n * The text that will be used as the label for the field.\n * @localizable\n */\n @Prop({ reflect: true, mutable: true }) label: string;\n\n /**\n * Determines the label that is applied to the option list for accessibility purposes.\n * @localizable\n */\n @Prop() listLabel: string = loc('tecton.element.select.listLabel');\n\n /** The minimum number of rows the component will try to display below or above the component when opened. */\n @Prop() minRows: number = 3;\n\n /** Enables text wrapping for `q2-option` elements. When `false`, the text truncates and does not wrap. */\n @Prop({ reflect: true }) multilineOptions: boolean = false;\n\n /** Enables multi-select functionality. */\n @Prop({ reflect: true }) multiple: boolean = false;\n\n /** Appends \"(optional)\" to the field label, and sets `aria-required` on the nested input tag to `false`. */\n @Prop({ reflect: true }) optional: boolean = false;\n\n /**\n * Text that appears within the field when it is blurred and empty.\n * Placeholder text disappears when the user selects an option.\n * @localizable\n */\n @Prop({ reflect: true }) placeholder: string;\n\n /** @deprecated */\n @Prop({ reflect: true }) popDirection: 'up' | 'down';\n\n /**\n * Determines the display mode of the popover.\n *\n * Providing a value of `legacy` instructs the popover to use absolute positioning instead of fixed positioning.\n *\n * @info\n * This is a temporary solution to work around styling issues related to using fixed positioning for the popover\n * when nested inside of elements with transform properties. This will be removed once the popover API is available\n * for use.\n */\n @Prop({ mutable: true }) popoverMode: 'legacy' = null;\n\n /**\n * Appends \"(read only)\" to the field label, and field becomes unusable, but remains focusable.\n * Takes priority over `optional` if both are `true`.\n */\n @Prop({ reflect: true }) readonly: boolean = false;\n\n /** Enables search functionality. */\n @Prop({ reflect: true }) searchable: boolean = false;\n\n /**\n * Each item in this array should correspond to the value of a `q2-option` element.\n * This property is only relevant for `multiple` (i.e., multi-select) implementations.\n */\n @Prop({ mutable: true }) selectedOptions: string[] = [];\n\n /**\n * The current value for the select. This should correspond to the value of a nested q2-option element.\n * This property is only relevant for single-select implementations.\n */\n @Prop({ mutable: true }) value: string;\n\n /** @deprecated */\n @Prop({ reflect: true, mutable: true }) ariaLabel: string;\n\n @Element() hostElement: HTMLElement;\n\n @State() open: boolean = false;\n @State() showSelected: boolean = false;\n @State() searchText: string = '';\n @State() hasCustomDisplay: boolean = false;\n @State() hasPopoverTop: boolean = false;\n @State() hasPopoverBottom: boolean = false;\n @State() inputFocused: boolean = false;\n @State() statusMessage: string;\n @State() prioritizeSearch: boolean = false;\n @State() structuredSelectedOptions: IOptionValue[] = [];\n\n inputField?: HTMLQ2InputElement;\n optionList: HTMLQ2OptionListElement;\n popoverElement?: HTMLQ2PopoverElement;\n popoverTopContainer?: HTMLDivElement;\n scheduledAfterRender: (() => void)[] = [];\n mutationObserver: MutationObserver;\n\n /// Lifecycle Hooks ///\n componentWillLoad() {\n handleAriaLabel(this);\n this.buildStructuredSelectedOptions();\n this.handleMultilineOptionsUpdate(this.multilineOptions, false);\n }\n\n componentDidLoad() {\n const observer = new MutationObserver(this.onMutationObserved);\n observer.observe(this.hostElement, { childList: true, subtree: true });\n this.mutationObserver = observer;\n this.onMutationObserved();\n overrideFocus(this.hostElement);\n setTimeout(() => this.checkSelectedDisplay(), 0);\n }\n\n componentDidRender() {\n setTimeout(() => {\n this.scheduledAfterRender.forEach(fn => fn());\n this.scheduledAfterRender = [];\n }, 25);\n }\n\n disconnectedCallback() {\n this.mutationObserver?.disconnect();\n this.mutationObserver = null;\n }\n\n /// Getters ///\n get innerInputField(): HTMLInputElement | HTMLButtonElement {\n return this.inputField?.shadowRoot?.querySelector('.input-field');\n }\n\n get innerInputContainer(): HTMLElement {\n return this.inputField?.shadowRoot?.querySelector('.input-container');\n }\n\n get badgeValue(): string {\n if (!this.multiple) return null;\n const optionsLength = this.selectedOptions?.length ?? 0;\n if (this.open && this.searchable) return optionsLength ? `${optionsLength}` : null;\n else return optionsLength > 1 ? `+${optionsLength - 1}` : null;\n }\n\n get popoverMinHeight() {\n const { minRows } = this;\n const firstOption = this.hostElement.querySelector<HTMLQ2OptionElement>('q2-option:not([hidden])');\n let minHeight = firstOption && window.getComputedStyle(firstOption).minHeight;\n\n // Safari doesn't return a min-height for non-visible items\n if (!minHeight || minHeight === '0px') minHeight = '44px';\n\n return minRows * parseInt(minHeight);\n }\n\n get selectedDisplay() {\n if (this.prioritizeSearch || this.searchText) return this.searchText;\n if (this.hasCustomDisplay) return '';\n return this.multiple ? this.calculateMultiSelectSelectedDisplay() : this.calculateSingleSelectSelectedDisplay();\n }\n\n get selectedDisplaySlot() {\n return this.hostElement.querySelector<HTMLElement>('[slot=\"_selected-display\"]');\n }\n\n get firstSelectedValue() {\n return this.multiple ? this.selectedOptions?.[0] : this.value;\n }\n\n get firstSelectedOptionElement() {\n const { firstSelectedValue } = this;\n return firstSelectedValue ? this.optionElements.find(({ value }) => value === firstSelectedValue) : null;\n }\n\n get optionElements() {\n return Array.from(this.hostElement.querySelectorAll<HTMLQ2OptionElement>('q2-option'));\n }\n\n get wrapperClasses() {\n const { errors } = this;\n const classes = ['q2-select-container'];\n if (Array.isArray(errors) && errors.length > 0) classes.push('has-error');\n if (this.inputFocused) classes.push('is-focused');\n if (this.searchable) classes.push('is-searchable');\n return classes.join(' ');\n }\n\n /// Watchers ///\n @Watch('value')\n @Watch('selectedOptions')\n buildStructuredSelectedOptions() {\n const { multiple, selectedOptions, value } = this;\n if (multiple) {\n this.structuredSelectedOptions = !!selectedOptions?.length\n ? selectedOptions.map(option => (typeof option === 'string' ? { value: option } : option))\n : [];\n } else {\n this.structuredSelectedOptions = value ? [{ value }] : [];\n }\n }\n\n @Watch('ariaLabel')\n ariaLabelObserver() {\n handleAriaLabel(this);\n }\n\n @Watch('value')\n valueUpdated() {\n if (this.multiple) return;\n this.clearSearchText();\n }\n\n @Watch('multilineOptions')\n handleMultilineOptionsUpdate(newValue, oldValue) {\n if (newValue === oldValue) return;\n this.optionElements.forEach(element => (element.multiline = newValue));\n }\n\n @Watch('open')\n openChanged(isOpen: boolean) {\n this.scheduledAfterRender.push(async () => {\n await waitForNextPaint();\n const { popoverTopContainer, popoverElement } = this;\n const height = (isOpen && popoverTopContainer?.offsetHeight) || 0;\n if (height) {\n popoverElement.style.setProperty('--comp-popover-top-container-height', `${height}px`);\n } else {\n popoverElement.style.removeProperty('--comp-popover-top-container-height');\n }\n });\n }\n\n /// Events ///\n /**\n * Emitted when an option is selected or deselected.\n *\n * When the multi-select is enabled, the `value` property will be `undefined` and the `selectedOptions` property\n * will contain the selected option values.\n *\n * @legacyEvent\n */\n @Event() change: EventEmitter<{ value: string; selectedOptions: string[] }>;\n\n /**\n * Emitted when the input value changes.\n *\n * Requires the `searchable` prop to be set to `true`.\n */\n @Event() input: EventEmitter<{ query: string }>;\n\n /// Methods ///\n _togglePopover() {\n const { innerInputField } = this;\n innerInputField?.click();\n innerInputField?.focus();\n innerInputField.dispatchEvent(new FocusEvent('focus'));\n }\n\n /**\n * Emulates clicking the `<input>` to display the popover if it is hidden.\n *\n * @testOnly\n */\n @Method()\n async openPopover() {\n if (this.open || this.disabled) return;\n this._togglePopover();\n }\n\n /**\n * Emulates clicking the `<input>` to hide the popover if it is visible.\n *\n * @testOnly\n */\n @Method()\n async closePopover() {\n if (!this.open || this.disabled) return;\n this._togglePopover();\n }\n\n /**\n * Emulates clicking the `<input>` to display the popover and selecting the option(s) with the specified value(s).\n *\n * If the multi-select is enabled and the `closePopover` argument is `true` (default), the popover will be closed\n * after the option(s) are selected.\n *\n * @testOnly\n */\n @Method()\n async setValue(values: string | string[], options: { closePopover?: boolean } = { closePopover: true }) {\n const valuesSet = new Set(Array.isArray(values) ? values : [values]);\n if (!this.open) {\n await this.openPopover();\n await waitForNextPaint();\n }\n\n valuesSet.forEach(value => {\n this.optionElements.find(option => option.value === value)?.click();\n });\n\n if (options.closePopover) {\n await this.closePopover();\n await waitForNextPaint();\n }\n }\n\n /**\n * Emulates focusing the `<input>`, entering the provided value, and emitting an `input` event.\n *\n * @warning\n * Only applicable when the input is searchable.\n *\n * @testOnly\n */\n @Method()\n searchOptions(query: string) {\n if (!this.searchable) return;\n\n const { innerInputField } = this;\n innerInputField.focus();\n innerInputField.dispatchEvent(new FocusEvent('focus'));\n innerInputField.value = query;\n innerInputField.dispatchEvent(new InputEvent('input'));\n }\n\n /// Listeners ///\n @Listen('keydown')\n keydownHandler(event: KeyboardEvent) {\n this.inputKeydownHandler(event);\n }\n\n @Listen('change')\n onHostElementChange(event: CustomEvent<{ value: string; selectedOptions: string[] }>) {\n if (this.readonly || this.disabled) return;\n if (event.target !== this.hostElement || this.hostElement.onchange) return;\n if (this.multiple) {\n this.value = null;\n this.selectedOptions = event.detail.selectedOptions;\n } else {\n this.value = event.detail.value;\n this.selectedOptions = [];\n }\n }\n\n @Listen('clear')\n onClearHandler() {\n this.clearValue();\n }\n\n @Listen('input')\n onHostElementInput(event: CustomEvent) {\n if (!this.searchable || event.target !== this.hostElement || this.hostElement.oninput) return;\n const options = this.optionElements;\n const query = this.searchText.trim().toLocaleLowerCase();\n let matchedCount = 0;\n options.forEach(option => {\n if (query === '') {\n option.hidden = false;\n return;\n }\n\n const title =\n option.firstElementChild?.tagName === 'Q2-CARD'\n ? (option.firstElementChild as HTMLQ2CardElement).title\n : null;\n const { display = '', innerText = '' } = option;\n const searchParams = [display, title, innerText];\n const matched = searchParams.some(text => text?.toLocaleLowerCase().includes(query) ?? false);\n\n option.hidden = !matched;\n if (matched) matchedCount++;\n });\n\n const statusMessageLocString = query\n ? 'tecton.element.select.searchable.results'\n : 'tecton.element.select.allOptions';\n const count = query ? matchedCount : options.length;\n this.setStatusMessage(loc(statusMessageLocString, [count]));\n }\n\n @Listen('focus')\n delegateFocus(event: FocusEvent) {\n const fromHost = isRelatedTargetWithinHost(event, this.hostElement);\n const prioritizeSearch = (this.prioritizeSearch = fromHost && this.searchable);\n if (prioritizeSearch) {\n this.clearSelectedDisplay();\n } else if (isEventFromElement(event, this.hostElement)) {\n this.inputField.shadowRoot.querySelector<HTMLElement>('.input-field').focus();\n }\n }\n\n @Listen('focusout')\n handleFocusout(event: FocusEvent) {\n const isLeavingHost = isHostLosingFocus(event, this.hostElement);\n if (isLeavingHost) this.closeDropdown();\n this.prioritizeSearch = !isLeavingHost && this.searchable;\n }\n\n @Listen('displayChanged')\n handleSelectedDisplay(event: CustomEvent) {\n if (this.multiple) return;\n this.inputField.value = event.detail.display;\n }\n\n /// Helpers ///\n async executeActionSheet(event: MouseEvent | KeyboardEvent) {\n const result = await showActionSheetList(this, event);\n this.handleSelectionChanges(result);\n }\n\n handleSelectionChanges(changeDetails: { value?: string; values?: IOptionValue[] }) {\n const { value = '', values = [] } = changeDetails;\n const selectedOptionValues = values.map(value => value.value);\n const { multiple } = this;\n if (!this.hostElement.onchange) {\n this.selectedOptions = selectedOptionValues;\n }\n\n this.change.emit({\n value: multiple ? undefined : value,\n selectedOptions: multiple ? selectedOptionValues : undefined,\n });\n }\n\n showSelectedOptions = () => {\n this.showSelected = true;\n };\n\n showAllOptions = () => {\n this.showSelected = false;\n };\n\n clearValue() {\n const { multiple } = this;\n this.value = '';\n this.selectedOptions = [];\n this.change.emit({ value: multiple ? undefined : '', selectedOptions: multiple ? [] : undefined });\n }\n\n calculateMultiSelectSelectedDisplay() {\n const { firstSelectedOptionElement, firstSelectedValue, multilineOptions } = this;\n if (!firstSelectedValue) return '';\n if (firstSelectedOptionElement?.display) return loc(firstSelectedOptionElement.display);\n if (multilineOptions && this.searchable) return this.searchText;\n if (multilineOptions) return '';\n return (\n firstSelectedOptionElement?.textContent?.trim() ?? firstSelectedOptionElement?.value ?? firstSelectedValue\n );\n }\n\n calculateSingleSelectSelectedDisplay() {\n const { firstSelectedOptionElement, multilineOptions } = this;\n if (multilineOptions) {\n return (firstSelectedOptionElement?.display && loc(firstSelectedOptionElement.display)) || this.value || '';\n } else {\n return (\n (firstSelectedOptionElement?.display && loc(firstSelectedOptionElement.display)) ||\n firstSelectedOptionElement?.textContent?.trim() ||\n this.value ||\n ''\n );\n }\n }\n\n onMutationObserved = () => {\n const { hostElement, hasPopoverTop, hasPopoverBottom } = this;\n const slotContainer = hostElement.querySelector('.custom-display-content');\n const displaySlot = hostElement.shadowRoot.querySelector<HTMLSlotElement>('slot[name=\"q2-select-display\"]');\n const hasCustomDisplay = !!displaySlot\n ? displaySlot.assignedNodes().length > 0\n : slotContainer.children.length > 0;\n\n if (this.hasCustomDisplay !== hasCustomDisplay) {\n this.hasCustomDisplay = hasCustomDisplay;\n }\n\n const popTopSlot = hostElement.shadowRoot.querySelector<HTMLSlotElement>('slot[name=\"popover-top\"]');\n const topSlotHasNode = popTopSlot.assignedNodes().length > 0;\n if (hasPopoverTop !== topSlotHasNode) {\n this.hasPopoverTop = topSlotHasNode;\n }\n\n const popBottomSlot = hostElement.shadowRoot.querySelector<HTMLSlotElement>('slot[name=\"popover-bottom\"]');\n const bottomSlotHasNode = popBottomSlot.assignedNodes().length > 0;\n if (hasPopoverBottom !== bottomSlotHasNode) {\n this.hasPopoverBottom = bottomSlotHasNode;\n }\n\n this.checkSelectedOptions();\n };\n\n onOptionListChange = (event: Q2OptionListCustomEvent<{ value: string; values: IOptionValue[] }>) => {\n event.stopPropagation();\n const { values } = event.detail;\n\n if (values.length === 0) this.showAllOptions();\n this.handleSelectionChanges(event.detail);\n };\n\n openDropdownWithoutActiveElement() {\n if (this.readonly || this.disabled) return;\n this.optionList.setActiveElement(null);\n this.open = true;\n }\n\n closeDropdown() {\n this.open = false;\n this.clearSearchText();\n }\n\n clearSearchText() {\n if (!this.searchText) return;\n this.searchText = '';\n this.input.emit({ query: '' });\n }\n\n toggleDropdown() {\n if (this.readonly || this.disabled) return;\n\n if (this.open && !this.searchText) {\n this.closeDropdown();\n } else {\n this.openDropdownWithoutActiveElement();\n }\n }\n\n focusInput() {\n this.inputField?.dispatchEvent(new FocusEvent('focus'));\n }\n\n statusMessageTimer: NodeJS.Timeout;\n setStatusMessage(message) {\n clearTimeout(this.statusMessageTimer);\n this.statusMessage = '';\n this.statusMessageTimer = setTimeout(() => {\n this.statusMessage = message;\n }, 1000);\n }\n\n checkSelectedOptions() {\n const { multiple, selectedOptions, value } = this;\n this.optionElements.forEach(option => {\n if (multiple) {\n option.selected = selectedOptions.includes(option.value);\n } else {\n option.selected = option.value === value;\n }\n });\n }\n\n clearSelectedDisplay() {\n this.selectedDisplaySlot?.remove();\n }\n\n checkSelectedDisplay() {\n let namedSlot = this.selectedDisplaySlot;\n const { value, multiple, selectedOptions, multilineOptions, firstSelectedOptionElement, prioritizeSearch } =\n this;\n const hasNoValue = !value && multiple && !selectedOptions?.length;\n if (prioritizeSearch || !multilineOptions || hasNoValue) return this.clearSelectedDisplay();\n\n if (!firstSelectedOptionElement || firstSelectedOptionElement.display) return this.clearSelectedDisplay();\n\n // Clone selected option and remove elements with hide-on-select attribute\n const selectionClone = firstSelectedOptionElement.firstElementChild.cloneNode(true) as HTMLElement;\n selectionClone.querySelectorAll('[hide-on-select]').forEach(element => element.remove());\n\n if (namedSlot) {\n const height = namedSlot.clientHeight === 0 ? 'auto' : `${namedSlot.clientHeight}px`;\n namedSlot.style.setProperty('--comp-selected-display-height', height);\n if (namedSlot.firstElementChild.outerHTML !== selectionClone.outerHTML) {\n namedSlot.replaceChild(selectionClone, namedSlot.firstElementChild);\n }\n } else {\n namedSlot = document.createElement('div');\n namedSlot.slot = '_selected-display';\n namedSlot.appendChild(selectionClone);\n this.hostElement.appendChild(namedSlot);\n }\n return namedSlot;\n }\n\n checkSelectedDisplayHeight() {\n const { selectedDisplaySlot } = this;\n if (!selectedDisplaySlot) return;\n selectedDisplaySlot.style.setProperty('--comp-selected-display-height', '44px');\n }\n\n /// Event handlers ///\n onPopoverState = ({\n detail: { open, action },\n }: CustomEvent<{ open: boolean; action: 'close' | 'select' | 'open' }>) => {\n if (!open || this.searchText) {\n if (action !== 'select') {\n this.optionList.setActiveElement(null);\n }\n this.inputField.focus();\n }\n\n if (this.open === open) return;\n this.open = open;\n };\n\n inputKeydownHandler = (event: KeyboardEvent) => {\n if (this.readonly || this.disabled) return;\n const key = event.key;\n const hasSlot = this.hasPopoverTop || this.hasPopoverBottom;\n const isShiftTab = key === 'Tab' && event.shiftKey;\n if (hasSlot && (key === 'Tab' || key === 'Enter' || isShiftTab)) return;\n if (shouldShowActionSheet(this, event)) {\n return this.executeActionSheet(event);\n }\n\n const keysForOptionListToHandle = [\n 'ArrowDown',\n 'ArrowUp',\n 'PageDown',\n 'PageUp',\n 'Home',\n 'End',\n 'Escape',\n 'Tab',\n ];\n\n if (this.searchable && (key === ' ' || key === 'Enter') && this.inputField.value == '') {\n event.preventDefault();\n if (!this.open) this.openDropdownWithoutActiveElement();\n }\n\n if (this.searchable && !keysForOptionListToHandle.includes(key)) return;\n if (this.shouldClearSearchText(event)) this.clearSearchText();\n\n // Prevent click event from firing when spacebar is pressed\n if (key === ' ') event.preventDefault();\n\n this.optionList.handleExternalKeydown(event);\n };\n\n shouldClearSearchText(event: KeyboardEvent) {\n return this.searchable && !!this.searchText && event.key === 'Escape';\n }\n\n visibilityToggleKeyDown = (event: KeyboardEvent) => {\n const key = event.key;\n const isShiftTab = key === 'Tab' && event.shiftKey;\n const isRadioControlKey = ['ArrowLeft', 'ArrowRight', 'ArrowUp', 'ArrowDown'].includes(key);\n if (isRadioControlKey) event.stopPropagation();\n if (isShiftTab) {\n event.stopPropagation();\n // allows shift+tab keys to select the top slot when present\n if (this.hasPopoverTop) return;\n\n this.optionList.setDefaultActiveElement();\n }\n };\n\n inputClickHandler = async (event: MouseEvent) => {\n event.stopPropagation();\n if (shouldShowActionSheet(this)) {\n return this.executeActionSheet(event);\n }\n this.toggleDropdown();\n this.focusInput();\n };\n\n inputInputHandler = (event: Q2InputCustomEvent<IEventDetail> & InputEvent) => {\n event.stopPropagation();\n const eventValue = event.detail.value;\n const shouldClearValue = !!this.value;\n\n if (shouldClearValue) this.clearValue();\n if (!this.open) this.openDropdownWithoutActiveElement();\n\n this.prioritizeSearch = true;\n this.searchText = eventValue;\n this.input.emit({ query: eventValue });\n };\n\n inputFocusHandler = () => {\n this.inputFocused = true;\n };\n\n inputBlurHandler = () => {\n this.inputFocused = false;\n };\n\n inputChangeHandler = (event: Event) => {\n event.stopPropagation();\n };\n\n clickedElsewhere = (event: CustomEvent) => {\n const target = event.target as HTMLClickElsewhereElement;\n if (target.localName !== 'click-elsewhere') return;\n event.stopPropagation();\n };\n\n onCustomDisplayClick = (event: MouseEvent) => {\n event.stopPropagation();\n this.focusInput();\n this.toggleDropdown();\n };\n\n /// DOM ///\n renderCustomDisplay() {\n const hasSelectedDisplay = this.checkSelectedDisplay();\n if (!hasSelectedDisplay) return;\n this.checkSelectedDisplayHeight();\n\n return (\n <slot\n name=\"_selected-display\"\n slot=\"custom-display\"\n />\n );\n }\n\n render() {\n return (\n <click-elsewhere\n class={this.wrapperClasses}\n onChange={this.clickedElsewhere}\n >\n <div\n aria-live=\"polite\"\n aria-atomic=\"true\"\n role=\"status\"\n class=\"sr\"\n >\n {this.statusMessage}\n </div>\n <q2-input\n ref={el => (this.inputField = el)}\n class=\"q2-select-input\"\n label={(this.label && loc(this.label)) || ''}\n value={this.selectedDisplay}\n clearable={(this.clearable && (!!this.value || !!this.selectedOptions?.length)) || undefined}\n errors={\n (Array.isArray(this.errors) &&\n this.errors.length > 0 &&\n this.errors.map(error => loc(error))) ||\n (this.invalid && ['tecton.element.select.invalid']) ||\n []\n }\n disabled={this.disabled}\n optional={this.optional}\n readonly={!!this.readonly}\n placeholder={this.placeholder || undefined}\n hideLabel={this.hideLabel}\n ariaExpanded={`${this.open}`}\n ariaControls=\"option-list\"\n ariaHaspopup=\"listbox\"\n test-id=\"toggleDropdown\"\n hide-messages\n iconRight=\"chevron-down\"\n onClick={this.inputClickHandler}\n onInput={this.inputInputHandler}\n onKeyDown={this.inputKeydownHandler}\n onFocus={this.inputFocusHandler}\n onBlur={this.inputBlurHandler}\n onChange={this.inputChangeHandler}\n badgeValue={this.badgeValue}\n badgeTheme={this.inputFocused ? 'primary' : undefined}\n _role=\"combobox\"\n _preventEntry={!this.searchable}\n >\n {this.renderCustomDisplay()}\n </q2-input>\n <div\n class=\"custom-display-content\"\n hidden={!this.hasCustomDisplay || !!this.searchText}\n onClick={this.onCustomDisplayClick}\n >\n <slot name=\"q2-select-display\" />\n </div>\n {this.optionsDropdown()}\n </click-elsewhere>\n );\n }\n\n optionsDropdown() {\n return (\n <q2-popover\n ref={el => (this.popoverElement = el)}\n controlElement={this.innerInputContainer}\n open={this.open}\n minHeight={this.popoverMinHeight}\n direction={this.popDirection}\n mode={this.popoverMode || undefined}\n block\n >\n <div class=\"popover-content\">\n <q2-option-list\n onPopoverState={this.onPopoverState}\n ref={el => (this.optionList = el)}\n type=\"listbox\"\n id=\"option-list\"\n show-selected={this.showSelected}\n label={this.listLabel}\n multiple={this.multiple}\n selectedOptions={this.structuredSelectedOptions}\n onChange={this.onOptionListChange}\n >\n <slot />\n </q2-option-list>\n <div\n class=\"popover-top-container\"\n ref={el => (this.popoverTopContainer = el)}\n hidden={!this.multiple && !this.hasPopoverTop}\n tabindex=\"-1\"\n >\n <slot name=\"popover-top\"></slot>\n {this.multiple && this.visibilityToggle()}\n </div>\n </div>\n <div\n class=\"popover-bottom-container\"\n hidden={!this.hasPopoverBottom}\n tabindex=\"-1\"\n >\n <slot name=\"popover-bottom\" />\n </div>\n </q2-popover>\n );\n }\n\n visibilityToggle() {\n const selectedOptionsCount = this.selectedOptions?.length ?? 0;\n const { showSelected } = this;\n return (\n <div class=\"multi-select-header\">\n <fieldset>\n <legend aria-label={loc('tecton.element.select.multiHeader.showing')}>\n {loc('tecton.element.select.multiHeader.showing')}\n </legend>\n <div>\n <input\n class=\"sr\"\n type=\"radio\"\n id=\"all\"\n name=\"viewDisplay\"\n value=\"all\"\n checked={!showSelected}\n aria-label={loc('tecton.element.select.multiHeader.allAriaLabel')}\n test-id=\"allOptionsButton\"\n onClick={this.showAllOptions}\n onKeyDown={this.visibilityToggleKeyDown}\n />\n <label htmlFor=\"all\">{loc('tecton.element.select.multiHeader.all')}</label>\n </div>\n\n <div>\n <input\n class=\"sr\"\n type=\"radio\"\n id=\"selected\"\n disabled={selectedOptionsCount === 0}\n name=\"viewDisplay\"\n value=\"selected\"\n aria-label={loc('tecton.element.select.multiHeader.selectedAriaLabel', [\n selectedOptionsCount,\n ])}\n checked={showSelected}\n test-id=\"selectedOptionsButton\"\n onClick={this.showSelectedOptions}\n onKeyDown={this.visibilityToggleKeyDown}\n />\n <label htmlFor=\"selected\">\n {loc('tecton.element.select.multiHeader.selected', [selectedOptionsCount])}\n </label>\n </div>\n </fieldset>\n </div>\n );\n }\n}\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import{r as e,h as t,F as i,g as s}from"./p-a5f18e27.js";import{d as n}from"./p-3c42c90f.js";import{l as a}from"./p-84190698.js";const r="*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-double-focus-ring, 0 0 0 2px #ffffff, 0 0 0 4px #0066cc)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size:inherit;font-stretch:inherit}:host(.sr),:host(.sr) button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.sr,.sr button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.hidden{display:none}:host([hidden]){display:none}.invisible{visibility:hidden}:host{display:inline}";const o=r;const d=class{constructor(t){e(this,t);this.syncTimer=null;this.trimSuffix=false;this.baseDate=undefined;this.locale=document.documentElement.lang||"en-US";this.messageFormat="short";this.numeric="auto";this.sync=true;this.date=undefined;this.unit=undefined;this.displayedMessage=undefined}componentWillLoad(){this.updateMessage()}connectedCallback(){this.syncUpdated()}disconnectedCallback(){window.clearInterval(this.syncTimer);this.syncTimer=null}get shouldShow(){return!!this.displayedMessage}get isValidDate(){const e=new Date(this.date);const t=n.isValid(e);if(!t)console.warn("Error: Invalid date provided to q2-relative-time.");return t}get dateObject(){return new Date(this.date)}get isBaseDateProvided(){return this.baseDate!==undefined}get isValidBaseDate(){const e=new Date(this.baseDate);const t=n.isValid(e);if(!t&&this.isBaseDateProvided){console.warn("Error: Invalid baseDate provided to q2-relative-time.")}return t}get baseDateObject(){if(this.isBaseDateProvided&&this.isValidBaseDate){this.trimSuffix=true;this.sync=false;return new Date(this.baseDate)}else{this.trimSuffix=false;this.sync=true;return new Date}}get isValidUnit(){if(["second","minute","hour","day","month","quarter","year"].includes(this.unit))return true;return false}get handleNumeric(){if(this.isValidBaseDate)return"always";return this.numeric}syncUpdated(){if(this.sync){this.syncTimer=window.setInterval((()=>{this.updateMessage()}),1e3)}else{window.clearInterval(this.syncTimer);this.syncTimer=null}}updateMessage(){const{isValidDate:e,isBaseDateProvided:t,isValidBaseDate:i,dateObject:s,baseDateObject:r,locale:o,handleNumeric:d,messageFormat:h,isValidUnit:l,unit:u,trimSuffix:c}=this;if(!e||t&&!i){this.sync=false;this.displayedMessage=a("tecton.element.relativeTime.invalidDate");return}const p=n.intlFormatDistance(new Date(s),new Date(r),{locale:o,localeMatcher:"best fit",numeric:d,style:h,unit:l?u:null});if(c){this.displayedMessage=this.trimMessage(p)}else{this.displayedMessage=p}}trimMessage(e){return e.replace(/^in\s?/,"").replace(/\sago$/,"")}async displayedMessageValue(){return this.displayedMessage}async validDateProp(){return this.isValidDate}async validBaseDateProp(){return this.isValidBaseDate}render(){const{shouldShow:e,displayedMessage:s}=this;return t(i,{key:"bc05bc398a991b70bb5c19adde0d739768db76cd"},e?t("time",{dateTime:s},s):null)}get hostElement(){return s(this)}static get watchers(){return{sync:["syncUpdated"],messageFormat:["updateMessage"],locale:["updateMessage"],date:["updateMessage"],baseDate:["updateMessage"],numeric:["updateMessage"],unit:["updateMessage"]}}};d.style=o;export{d as q2_relative_time};
2
- //# sourceMappingURL=p-9a71bd16.entry.js.map
1
+ import{r as e,h as t,F as i,g as s}from"./p-a5f18e27.js";import{d as a}from"./p-b6bcef6a.js";import{l as n}from"./p-84190698.js";const r="*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-double-focus-ring, 0 0 0 2px #ffffff, 0 0 0 4px #0066cc)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size:inherit;font-stretch:inherit}:host(.sr),:host(.sr) button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.sr,.sr button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.hidden{display:none}:host([hidden]){display:none}.invisible{visibility:hidden}:host{display:inline}";const o=r;const d=class{constructor(t){e(this,t);this.syncTimer=null;this.trimSuffix=false;this.baseDate=undefined;this.locale=document.documentElement.lang||"en-US";this.messageFormat="short";this.numeric="auto";this.sync=true;this.date=undefined;this.unit=undefined;this.displayedMessage=undefined}componentWillLoad(){this.updateMessage()}connectedCallback(){this.syncUpdated()}disconnectedCallback(){window.clearInterval(this.syncTimer);this.syncTimer=null}get shouldShow(){return!!this.displayedMessage}get isValidDate(){const e=new Date(this.date);const t=a.isValid(e);if(!t)console.warn("Error: Invalid date provided to q2-relative-time.");return t}get dateObject(){return new Date(this.date)}get isBaseDateProvided(){return this.baseDate!==undefined}get isValidBaseDate(){const e=new Date(this.baseDate);const t=a.isValid(e);if(!t&&this.isBaseDateProvided){console.warn("Error: Invalid baseDate provided to q2-relative-time.")}return t}get baseDateObject(){if(this.isBaseDateProvided&&this.isValidBaseDate){this.trimSuffix=true;this.sync=false;return new Date(this.baseDate)}else{this.trimSuffix=false;this.sync=true;return new Date}}get isValidUnit(){if(["second","minute","hour","day","month","quarter","year"].includes(this.unit))return true;return false}get handleNumeric(){if(this.isValidBaseDate)return"always";return this.numeric}syncUpdated(){if(this.sync){this.syncTimer=window.setInterval((()=>{this.updateMessage()}),1e3)}else{window.clearInterval(this.syncTimer);this.syncTimer=null}}updateMessage(){const{isValidDate:e,isBaseDateProvided:t,isValidBaseDate:i,dateObject:s,baseDateObject:r,locale:o,handleNumeric:d,messageFormat:h,isValidUnit:l,unit:u,trimSuffix:c}=this;if(!e||t&&!i){this.sync=false;this.displayedMessage=n("tecton.element.relativeTime.invalidDate");return}const p=a.intlFormatDistance(new Date(s),new Date(r),{locale:o,localeMatcher:"best fit",numeric:d,style:h,unit:l?u:null});if(c){this.displayedMessage=this.trimMessage(p)}else{this.displayedMessage=p}}trimMessage(e){return e.replace(/^in\s?/,"").replace(/\sago$/,"")}async displayedMessageValue(){return this.displayedMessage}async validDateProp(){return this.isValidDate}async validBaseDateProp(){return this.isValidBaseDate}render(){const{shouldShow:e,displayedMessage:s}=this;return t(i,{key:"441a46ba1701a606f87b53120a7dc8a696dc85e1"},e?t("time",{dateTime:s},s):null)}get hostElement(){return s(this)}static get watchers(){return{sync:["syncUpdated"],messageFormat:["updateMessage"],locale:["updateMessage"],date:["updateMessage"],baseDate:["updateMessage"],numeric:["updateMessage"],unit:["updateMessage"]}}};d.style=o;export{d as q2_relative_time};
2
+ //# sourceMappingURL=p-9a5695db.entry.js.map
@@ -1,2 +1,2 @@
1
- import{r as t,h as e,g as i}from"./p-a5f18e27.js";import{f as s}from"./p-84190698.js";const o="*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-double-focus-ring, 0 0 0 2px #ffffff, 0 0 0 4px #0066cc)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size:inherit;font-stretch:inherit}:host(.sr),:host(.sr) button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.sr,.sr button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.hidden{display:none}:host([hidden]){display:none}.invisible{visibility:hidden}*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-double-focus-ring, 0 0 0 2px #ffffff, 0 0 0 4px #0066cc)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size:inherit;font-stretch:inherit}:host(.sr),:host(.sr) button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.sr,.sr button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.hidden{display:none}:host([hidden]){display:none}.invisible{visibility:hidden}:host([bordered]:not([bordered=false])) ::slotted(q2-item:not(:last-child)),:host([bordered]:not([bordered=false])) .header{border-style:var(--tct-list-item-border-style, solid);border-width:var(--tct-list-item-border-width, 0 0 1px 0);border-color:var(--tct-list-item-border-color, var(--t-gray-12, #d9d9d9))}.header{--comp-default-header-padding:0 var(--app-scale-4x, 20px);display:flex;gap:var(--app-scale-3x, 12px);padding:var(--tct-list-header-padding, var(--comp-default-header-padding));min-height:var(--tct-list-header-min-height, var(--t-list-header-min-height, 44px))}.header-spacebetween{justify-content:space-between}.header-start{justify-content:flex-start}.header-end{justify-content:flex-end}.header .label{width:100%;height:var(--tct-list-label-height, 44px);line-height:var(--tct-list-label-line-height, 44px);font-size:var(--tct-list-label-font-size, var(--app-font-size, 14px));font-weight:var(--tct-list-label-font-weight, 600);color:var(--tct-list-label-font-color, var(--t-text, #4d4d4d))}.main{grid-column:2;grid-row:1}.main-no-action-nor-bullet{grid-column:1}.main-no-bullet{grid-column:1}";const n=o;const r=class{constructor(e){t(this,e);this.scheduledAfterRender=[];this.onMutationObserved=()=>{this.renderTrigger+=1;this.scheduledAfterRender.push((()=>{Array.from(this.hostElement.children).forEach((t=>{if(t.tagName==="Q2-ITEM")t.role="listitem"}))}))};this.label=undefined;this.renderTrigger=0;this.bordered=undefined}componentDidLoad(){if(typeof MutationObserver==="undefined")return;const t=new MutationObserver(this.onMutationObserved);t.observe(this.hostElement,{childList:true,subtree:true});this.mutationObserver=t;this.onMutationObserved()}componentDidRender(){this.scheduledAfterRender.forEach((t=>t()));this.scheduledAfterRender=[]}disconnectedCallback(){if(this.mutationObserver){this.mutationObserver.disconnect();this.mutationObserver=null}}get hasLabelContent(){return!!this.label}get hasFilterSlot(){return!!this.hostElement.querySelector("q2-pill")||s(this.hostElement,"pill")}get headerClasses(){const t=["header"];if(this.hasLabelContent&&this.hasFilterSlot){t.push("header-spacebetween")}else if(this.hasLabelContent&&!this.hasFilterSlot){t.push("header-start")}else if(!this.hasLabelContent&&this.hasFilterSlot){t.push("header-end")}return t.join(" ")}get listClasses(){const t=["list"];return t.join(" ")}render(){return e("div",{key:"5cf0fbf1cf90821aad8380a082925050834930c5",class:this.listClasses,ref:t=>this.listElement=t},(this.hasFilterSlot||this.hasLabelContent)&&e("div",{key:"e34cb030fc9a5ddd52f3b9668f5e4e6606a90ab3",class:this.headerClasses},e("div",{key:"2c698cdc7359ba6404423c7f508b1f3583385de5",class:"label"},this.label),this.hasFilterSlot&&e("slot",{key:"19e450240e0788440e61ea85bf729533c3dfef5f",name:"filter"})),e("div",{key:"44c1a6503f9c80c01b3d58b48641272b580b0add",role:"list"},e("slot",{key:"941440f0f21772302f0ac5ef70a42d4820cca063"})))}get hostElement(){return i(this)}};r.style=n;export{r as q2_list};
2
- //# sourceMappingURL=p-8fc099f5.entry.js.map
1
+ import{r as t,h as e,g as i}from"./p-a5f18e27.js";import{f as s}from"./p-84190698.js";const o="*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-double-focus-ring, 0 0 0 2px #ffffff, 0 0 0 4px #0066cc)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size:inherit;font-stretch:inherit}:host(.sr),:host(.sr) button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.sr,.sr button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.hidden{display:none}:host([hidden]){display:none}.invisible{visibility:hidden}*{box-sizing:border-box}*:active{outline:none}*:focus{outline:none;box-shadow:var(--const-double-focus-ring, 0 0 0 2px #ffffff, 0 0 0 4px #0066cc)}:host{box-shadow:none !important}::-moz-focus-inner{border:none}input,textarea,button{font-family:inherit;font-size:inherit;font-stretch:inherit}:host(.sr),:host(.sr) button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.sr,.sr button{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}.hidden{display:none}:host([hidden]){display:none}.invisible{visibility:hidden}:host([bordered]:not([bordered=false])) ::slotted(q2-item:not(:last-child)),:host([bordered]:not([bordered=false])) .header{border-style:var(--tct-list-item-border-style, solid);border-width:var(--tct-list-item-border-width, 0 0 1px 0);border-color:var(--tct-list-item-border-color, var(--t-gray-12, #d9d9d9))}.header{--comp-default-header-padding:0 var(--app-scale-4x, 20px);display:flex;gap:var(--app-scale-3x, 12px);padding:var(--tct-list-header-padding, var(--comp-default-header-padding));min-height:var(--tct-list-header-min-height, var(--t-list-header-min-height, 44px))}.header-spacebetween{justify-content:space-between}.header-start{justify-content:flex-start}.header-end{justify-content:flex-end}.header .label{width:100%;height:var(--tct-list-label-height, 44px);line-height:var(--tct-list-label-line-height, 44px);font-size:var(--tct-list-label-font-size, var(--app-font-size, 14px));font-weight:var(--tct-list-label-font-weight, 600);color:var(--tct-list-label-font-color, var(--t-text, #4d4d4d))}.main{grid-column:2;grid-row:1}.main-no-action-nor-bullet{grid-column:1}.main-no-bullet{grid-column:1}";const n=o;const r=class{constructor(e){t(this,e);this.scheduledAfterRender=[];this.onMutationObserved=()=>{this.renderTrigger+=1;this.scheduledAfterRender.push((()=>{Array.from(this.hostElement.children).forEach((t=>{if(t.tagName==="Q2-ITEM")t.role="listitem"}))}))};this.label=undefined;this.renderTrigger=0;this.bordered=undefined}componentDidLoad(){if(typeof MutationObserver==="undefined")return;const t=new MutationObserver(this.onMutationObserved);t.observe(this.hostElement,{childList:true,subtree:true});this.mutationObserver=t;this.onMutationObserved()}componentDidRender(){this.scheduledAfterRender.forEach((t=>t()));this.scheduledAfterRender=[]}disconnectedCallback(){if(this.mutationObserver){this.mutationObserver.disconnect();this.mutationObserver=null}}get hasLabelContent(){return!!this.label}get hasFilterSlot(){return!!this.hostElement.querySelector("q2-pill")||s(this.hostElement,"pill")}get headerClasses(){const t=["header"];if(this.hasLabelContent&&this.hasFilterSlot){t.push("header-spacebetween")}else if(this.hasLabelContent&&!this.hasFilterSlot){t.push("header-start")}else if(!this.hasLabelContent&&this.hasFilterSlot){t.push("header-end")}return t.join(" ")}get listClasses(){const t=["list"];return t.join(" ")}render(){return e("div",{key:"03d62cc3436abd29994c02efef17db29f3043371",class:this.listClasses,ref:t=>this.listElement=t},(this.hasFilterSlot||this.hasLabelContent)&&e("div",{key:"62aa472c52425d9bd8474c9927ff1f018a94f588",class:this.headerClasses},e("div",{key:"a288af4640d75ae48443d390bd5a5b591f61732a",class:"label"},this.label),this.hasFilterSlot&&e("slot",{key:"44a788d43c1390890b6c1e1bce642fc9d252e517",name:"filter"})),e("div",{key:"6dff69032b9f6b6d5cc9ed2e032a757a9690dc9d",role:"list"},e("slot",{key:"d1ae622b365cf5f071ea6b2ed1df6c700a977a64"})))}get hostElement(){return i(this)}};r.style=n;export{r as q2_list};
2
+ //# sourceMappingURL=p-9b65cc28.entry.js.map