q2-tecton-elements 1.65.0 → 1.66.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 (680) hide show
  1. package/dist/bundle-report.json +1904 -742
  2. package/dist/cjs/{action-sheet-CiK2Bap_.js → action-sheet-D71RSc-w.js} +5 -2
  3. package/dist/cjs/action-sheet-D71RSc-w.js.map +1 -0
  4. package/dist/cjs/component-DRAntnCA.js +47 -0
  5. package/dist/cjs/component-DRAntnCA.js.map +1 -0
  6. package/dist/cjs/loader.cjs.js +1 -1
  7. package/dist/cjs/q2-action-group.q2-resize-observer.entry.cjs.js.map +1 -1
  8. package/dist/cjs/q2-action-group_2.cjs.entry.js +121 -45
  9. package/dist/cjs/q2-action-group_2.cjs.entry.js.map +1 -1
  10. package/dist/cjs/q2-action-sheet.cjs.entry.js +9 -5
  11. package/dist/cjs/q2-action-sheet.cjs.entry.js.map +1 -1
  12. package/dist/cjs/q2-action-sheet.entry.cjs.js.map +1 -1
  13. package/dist/cjs/q2-avatar.cjs.entry.js +2 -2
  14. package/dist/cjs/q2-avatar.cjs.entry.js.map +1 -1
  15. package/dist/cjs/q2-avatar.entry.cjs.js.map +1 -1
  16. package/dist/cjs/q2-btn.q2-loading.entry.cjs.js.map +1 -1
  17. package/dist/cjs/q2-btn_2.cjs.entry.js +13 -4
  18. package/dist/cjs/q2-btn_2.cjs.entry.js.map +1 -1
  19. package/dist/cjs/q2-calendar.cjs.entry.js +3 -3
  20. package/dist/cjs/q2-calendar.cjs.entry.js.map +1 -1
  21. package/dist/cjs/q2-calendar.entry.cjs.js.map +1 -1
  22. package/dist/cjs/q2-card-image.cjs.entry.js +5 -5
  23. package/dist/cjs/q2-card-image.cjs.entry.js.map +1 -1
  24. package/dist/cjs/q2-card-image.entry.cjs.js.map +1 -1
  25. package/dist/cjs/q2-card.cjs.entry.js +1 -1
  26. package/dist/cjs/q2-card.cjs.entry.js.map +1 -1
  27. package/dist/cjs/q2-card.entry.cjs.js.map +1 -1
  28. package/dist/cjs/q2-carousel-pane.cjs.entry.js +7 -3
  29. package/dist/cjs/q2-carousel-pane.cjs.entry.js.map +1 -1
  30. package/dist/cjs/q2-carousel-pane.entry.cjs.js.map +1 -1
  31. package/dist/cjs/q2-carousel.cjs.entry.js +12 -2
  32. package/dist/cjs/q2-carousel.cjs.entry.js.map +1 -1
  33. package/dist/cjs/q2-carousel.entry.cjs.js.map +1 -1
  34. package/dist/cjs/q2-chart-area.cjs.entry.js +1 -1
  35. package/dist/cjs/q2-chart-bar.cjs.entry.js +1 -1
  36. package/dist/cjs/q2-chart-donut.cjs.entry.js +1 -1
  37. package/dist/cjs/q2-checkbox-group.cjs.entry.js +5 -1
  38. package/dist/cjs/q2-checkbox-group.cjs.entry.js.map +1 -1
  39. package/dist/cjs/q2-checkbox-group.entry.cjs.js.map +1 -1
  40. package/dist/cjs/q2-checkbox.cjs.entry.js +3 -4
  41. package/dist/cjs/q2-checkbox.cjs.entry.js.map +1 -1
  42. package/dist/cjs/q2-checkbox.entry.cjs.js.map +1 -1
  43. package/dist/cjs/q2-context.cjs.entry.js +1 -1
  44. package/dist/cjs/q2-context.cjs.entry.js.map +1 -1
  45. package/dist/cjs/q2-context.entry.cjs.js.map +1 -1
  46. package/dist/cjs/q2-currency.cjs.entry.js +1 -1
  47. package/dist/cjs/q2-data-table.cjs.entry.js +19 -9
  48. package/dist/cjs/q2-data-table.cjs.entry.js.map +1 -1
  49. package/dist/cjs/q2-data-table.entry.cjs.js.map +1 -1
  50. package/dist/cjs/q2-detail.cjs.entry.js +2 -2
  51. package/dist/cjs/q2-detail.cjs.entry.js.map +1 -1
  52. package/dist/cjs/q2-detail.entry.cjs.js.map +1 -1
  53. package/dist/cjs/q2-dropdown-item.cjs.entry.js +3 -1
  54. package/dist/cjs/q2-dropdown-item.cjs.entry.js.map +1 -1
  55. package/dist/cjs/q2-dropdown-item.entry.cjs.js.map +1 -1
  56. package/dist/cjs/q2-dropdown.cjs.entry.js +33 -8
  57. package/dist/cjs/q2-dropdown.cjs.entry.js.map +1 -1
  58. package/dist/cjs/q2-dropdown.entry.cjs.js.map +1 -1
  59. package/dist/cjs/q2-editable-field.cjs.entry.js +1 -1
  60. package/dist/cjs/q2-example.cjs.entry.js +1 -1
  61. package/dist/cjs/q2-file-picker.cjs.entry.js +2 -2
  62. package/dist/cjs/q2-file-picker.cjs.entry.js.map +1 -1
  63. package/dist/cjs/q2-file-picker.entry.cjs.js.map +1 -1
  64. package/dist/cjs/q2-form.cjs.entry.js +1 -1
  65. package/dist/cjs/q2-formatted-text.cjs.entry.js +1 -1
  66. package/dist/cjs/q2-grid-area.cjs.entry.js +9 -1
  67. package/dist/cjs/q2-grid-area.cjs.entry.js.map +1 -1
  68. package/dist/cjs/q2-grid-area.entry.cjs.js.map +1 -1
  69. package/dist/cjs/q2-icon.cjs.entry.js +6 -0
  70. package/dist/cjs/q2-icon.cjs.entry.js.map +1 -1
  71. package/dist/cjs/q2-icon.entry.cjs.js.map +1 -1
  72. package/dist/cjs/q2-input.cjs.entry.js +8 -6
  73. package/dist/cjs/q2-input.cjs.entry.js.map +1 -1
  74. package/dist/cjs/q2-input.entry.cjs.js.map +1 -1
  75. package/dist/cjs/q2-item.cjs.entry.js +17 -17
  76. package/dist/cjs/q2-item.cjs.entry.js.map +1 -1
  77. package/dist/cjs/q2-item.entry.cjs.js.map +1 -1
  78. package/dist/cjs/q2-legend.cjs.entry.js +1 -1
  79. package/dist/cjs/q2-link.q2-list.entry.cjs.js.map +1 -1
  80. package/dist/cjs/q2-link_2.cjs.entry.js +11 -7
  81. package/dist/cjs/q2-link_2.cjs.entry.js.map +1 -1
  82. package/dist/cjs/q2-message.cjs.entry.js +2 -2
  83. package/dist/cjs/q2-message.cjs.entry.js.map +1 -1
  84. package/dist/cjs/q2-message.entry.cjs.js.map +1 -1
  85. package/dist/cjs/q2-meter.cjs.entry.js +1 -1
  86. package/dist/cjs/q2-modal.cjs.entry.js +2 -2
  87. package/dist/cjs/q2-month-picker.cjs.entry.js +2 -2
  88. package/dist/cjs/q2-mutation-observer.cjs.entry.js +1 -1
  89. package/dist/cjs/q2-optgroup.cjs.entry.js +4 -2
  90. package/dist/cjs/q2-optgroup.cjs.entry.js.map +1 -1
  91. package/dist/cjs/q2-optgroup.entry.cjs.js.map +1 -1
  92. package/dist/cjs/q2-option-list.q2-popover.entry.cjs.js.map +1 -1
  93. package/dist/cjs/q2-option-list_2.cjs.entry.js +5 -3
  94. package/dist/cjs/q2-option-list_2.cjs.entry.js.map +1 -1
  95. package/dist/cjs/q2-option.cjs.entry.js +3 -1
  96. package/dist/cjs/q2-option.cjs.entry.js.map +1 -1
  97. package/dist/cjs/q2-option.entry.cjs.js.map +1 -1
  98. package/dist/cjs/q2-pagination.cjs.entry.js +10 -12
  99. package/dist/cjs/q2-pagination.cjs.entry.js.map +1 -1
  100. package/dist/cjs/q2-pagination.entry.cjs.js.map +1 -1
  101. package/dist/cjs/q2-pill.cjs.entry.js +2 -2
  102. package/dist/cjs/q2-radio.cjs.entry.js +2 -2
  103. package/dist/cjs/q2-radio.cjs.entry.js.map +1 -1
  104. package/dist/cjs/q2-radio.entry.cjs.js.map +1 -1
  105. package/dist/cjs/q2-relative-time.cjs.entry.js +1 -1
  106. package/dist/cjs/q2-section-container.cjs.entry.js +2 -0
  107. package/dist/cjs/q2-section-container.cjs.entry.js.map +1 -1
  108. package/dist/cjs/q2-section-container.entry.cjs.js.map +1 -1
  109. package/dist/cjs/q2-section.cjs.entry.js +2 -2
  110. package/dist/cjs/q2-select.cjs.entry.js +7 -3
  111. package/dist/cjs/q2-select.cjs.entry.js.map +1 -1
  112. package/dist/cjs/q2-select.entry.cjs.js.map +1 -1
  113. package/dist/cjs/q2-stepper-pane.cjs.entry.js +3 -1
  114. package/dist/cjs/q2-stepper-pane.cjs.entry.js.map +1 -1
  115. package/dist/cjs/q2-stepper-pane.entry.cjs.js.map +1 -1
  116. package/dist/cjs/q2-stepper-vertical.cjs.entry.js +1 -1
  117. package/dist/cjs/q2-stepper.cjs.entry.js +6 -2
  118. package/dist/cjs/q2-stepper.cjs.entry.js.map +1 -1
  119. package/dist/cjs/q2-stepper.entry.cjs.js.map +1 -1
  120. package/dist/cjs/q2-tab-container.cjs.entry.js +5 -1
  121. package/dist/cjs/q2-tab-container.cjs.entry.js.map +1 -1
  122. package/dist/cjs/q2-tab-container.entry.cjs.js.map +1 -1
  123. package/dist/cjs/q2-tab-pane.cjs.entry.js +8 -1
  124. package/dist/cjs/q2-tab-pane.cjs.entry.js.map +1 -1
  125. package/dist/cjs/q2-tab-pane.entry.cjs.js.map +1 -1
  126. package/dist/cjs/q2-tag.cjs.entry.js +3 -3
  127. package/dist/cjs/q2-tag.cjs.entry.js.map +1 -1
  128. package/dist/cjs/q2-tag.entry.cjs.js.map +1 -1
  129. package/dist/cjs/q2-tecton-elements.cjs.js +1 -1
  130. package/dist/cjs/q2-textarea.cjs.entry.js +2 -2
  131. package/dist/cjs/q2-textarea.cjs.entry.js.map +1 -1
  132. package/dist/cjs/q2-textarea.entry.cjs.js.map +1 -1
  133. package/dist/cjs/q2-toast.cjs.entry.js +192 -0
  134. package/dist/cjs/q2-toast.cjs.entry.js.map +1 -0
  135. package/dist/cjs/q2-toast.entry.cjs.js.map +1 -0
  136. package/dist/cjs/{sanitize-html-string-DPqrzfM9.js → sanitize-html-string-C2iwHNz5.js} +30 -6
  137. package/dist/cjs/sanitize-html-string-C2iwHNz5.js.map +1 -0
  138. package/dist/cjs/tecton-tab-pane.cjs.entry.js +4 -2
  139. package/dist/cjs/tecton-tab-pane.cjs.entry.js.map +1 -1
  140. package/dist/cjs/tecton-tab-pane.entry.cjs.js.map +1 -1
  141. package/dist/collection/collection-manifest.json +1 -0
  142. package/dist/collection/components/q2-action-group/q2-action-group.css +11 -4
  143. package/dist/collection/components/q2-action-group/q2-action-group.js +121 -45
  144. package/dist/collection/components/q2-action-group/q2-action-group.js.map +1 -1
  145. package/dist/collection/components/q2-action-sheet/q2-action-sheet.css +8 -0
  146. package/dist/collection/components/q2-action-sheet/q2-action-sheet.js +9 -5
  147. package/dist/collection/components/q2-action-sheet/q2-action-sheet.js.map +1 -1
  148. package/dist/collection/components/q2-avatar/q2-avatar.css +3 -0
  149. package/dist/collection/components/q2-avatar/q2-avatar.js +1 -1
  150. package/dist/collection/components/q2-btn/q2-btn.css +9 -1
  151. package/dist/collection/components/q2-btn/q2-btn.js +1 -1
  152. package/dist/collection/components/q2-btn/q2-btn.js.map +1 -1
  153. package/dist/collection/components/q2-calendar/q2-calendar.css +5 -1
  154. package/dist/collection/components/q2-calendar/q2-calendar.js +2 -2
  155. package/dist/collection/components/q2-calendar/q2-calendar.js.map +1 -1
  156. package/dist/collection/components/q2-calendar/q2-month-picker.js +2 -2
  157. package/dist/collection/components/q2-card/q2-card.css +1 -0
  158. package/dist/collection/components/q2-card-image/q2-card-image.js +6 -6
  159. package/dist/collection/components/q2-card-image/q2-card-image.js.map +1 -1
  160. package/dist/collection/components/q2-carousel/q2-carousel.css +1 -1
  161. package/dist/collection/components/q2-carousel/q2-carousel.js +11 -1
  162. package/dist/collection/components/q2-carousel/q2-carousel.js.map +1 -1
  163. package/dist/collection/components/q2-carousel-pane/q2-carousel-pane.css +11 -1
  164. package/dist/collection/components/q2-carousel-pane/q2-carousel-pane.js +6 -2
  165. package/dist/collection/components/q2-carousel-pane/q2-carousel-pane.js.map +1 -1
  166. package/dist/collection/components/q2-chart-area/q2-chart-area.js +1 -1
  167. package/dist/collection/components/q2-chart-bar/q2-chart-bar.js +1 -1
  168. package/dist/collection/components/q2-chart-donut/q2-chart-donut.js +1 -1
  169. package/dist/collection/components/q2-checkbox/q2-checkbox.css +135 -14
  170. package/dist/collection/components/q2-checkbox/q2-checkbox.js +2 -8
  171. package/dist/collection/components/q2-checkbox/q2-checkbox.js.map +1 -1
  172. package/dist/collection/components/q2-checkbox-group/q2-checkbox-group.js +5 -1
  173. package/dist/collection/components/q2-checkbox-group/q2-checkbox-group.js.map +1 -1
  174. package/dist/collection/components/q2-context/q2-context.js +1 -1
  175. package/dist/collection/components/q2-context/q2-context.js.map +1 -1
  176. package/dist/collection/components/q2-currency/q2-currency.js +1 -1
  177. package/dist/collection/components/q2-data-table/q2-data-table.css +3 -0
  178. package/dist/collection/components/q2-data-table/q2-data-table.js +53 -20
  179. package/dist/collection/components/q2-data-table/q2-data-table.js.map +1 -1
  180. package/dist/collection/components/q2-detail/q2-detail.css +6 -0
  181. package/dist/collection/components/q2-detail/q2-detail.js +1 -1
  182. package/dist/collection/components/q2-dropdown/q2-dropdown.css +17 -0
  183. package/dist/collection/components/q2-dropdown/q2-dropdown.js +75 -8
  184. package/dist/collection/components/q2-dropdown/q2-dropdown.js.map +1 -1
  185. package/dist/collection/components/q2-dropdown-item/q2-dropdown-item.css +1 -0
  186. package/dist/collection/components/q2-dropdown-item/q2-dropdown-item.js +2 -0
  187. package/dist/collection/components/q2-dropdown-item/q2-dropdown-item.js.map +1 -1
  188. package/dist/collection/components/q2-editable-field/q2-editable-field.js +1 -1
  189. package/dist/collection/components/q2-example/q2-example.js +1 -1
  190. package/dist/collection/components/q2-file-picker/q2-file-picker.css +4 -1
  191. package/dist/collection/components/q2-file-picker/q2-file-picker.js +4 -4
  192. package/dist/collection/components/q2-file-picker/q2-file-picker.js.map +1 -1
  193. package/dist/collection/components/q2-form/q2-form.js +1 -1
  194. package/dist/collection/components/q2-formatted-text/q2-formatted-text.js +1 -1
  195. package/dist/collection/components/q2-grid/q2-grid.js +30 -30
  196. package/dist/collection/components/q2-grid-area/q2-grid-area.js +51 -43
  197. package/dist/collection/components/q2-grid-area/q2-grid-area.js.map +1 -1
  198. package/dist/collection/components/q2-icon/assets/brand.symbol.svg +1 -1
  199. package/dist/collection/components/q2-icon/assets/browsersos.symbol.svg +1 -1
  200. package/dist/collection/components/q2-icon/assets/cards.symbol.svg +1 -1
  201. package/dist/collection/components/q2-icon/assets/communication.symbol.svg +1 -1
  202. package/dist/collection/components/q2-icon/assets/currencies.symbol.svg +1 -1
  203. package/dist/collection/components/q2-icon/assets/devices.symbol.svg +1 -1
  204. package/dist/collection/components/q2-icon/assets/filetypes.symbol.svg +1 -1
  205. package/dist/collection/components/q2-icon/assets/gestures.symbol.svg +1 -1
  206. package/dist/collection/components/q2-icon/assets/icon-list.json +1 -1
  207. package/dist/collection/components/q2-icon/assets/icon-map.json +1 -1
  208. package/dist/collection/components/q2-icon/assets/legacy.symbol.svg +1 -1
  209. package/dist/collection/components/q2-icon/assets/mobile.symbol.svg +1 -1
  210. package/dist/collection/components/q2-icon/assets/standard.symbol.svg +1 -1
  211. package/dist/collection/components/q2-input/formatting/phone.js +4 -2
  212. package/dist/collection/components/q2-input/formatting/phone.js.map +1 -1
  213. package/dist/collection/components/q2-input/q2-input.css +3 -0
  214. package/dist/collection/components/q2-input/q2-input.js +6 -6
  215. package/dist/collection/components/q2-input/q2-input.js.map +1 -1
  216. package/dist/collection/components/q2-item/q2-item.css +3 -0
  217. package/dist/collection/components/q2-item/q2-item.js +19 -18
  218. package/dist/collection/components/q2-item/q2-item.js.map +1 -1
  219. package/dist/collection/components/q2-legend/q2-legend.js +1 -1
  220. package/dist/collection/components/q2-link/q2-link.css +53 -1
  221. package/dist/collection/components/q2-link/q2-link.js +50 -8
  222. package/dist/collection/components/q2-link/q2-link.js.map +1 -1
  223. package/dist/collection/components/q2-list/q2-list.js +1 -1
  224. package/dist/collection/components/q2-loading/q2-loading.css +1 -1
  225. package/dist/collection/components/q2-loading/q2-loading.js +10 -1
  226. package/dist/collection/components/q2-loading/q2-loading.js.map +1 -1
  227. package/dist/collection/components/q2-message/q2-message.css +1 -0
  228. package/dist/collection/components/q2-message/q2-message.js +1 -1
  229. package/dist/collection/components/q2-meter/q2-meter.js +1 -1
  230. package/dist/collection/components/q2-modal/q2-modal.js +1 -1
  231. package/dist/collection/components/q2-mutation-observer/q2-mutation-observer.js +1 -1
  232. package/dist/collection/components/q2-optgroup/q2-optgroup.css +6 -4
  233. package/dist/collection/components/q2-optgroup/q2-optgroup.js +3 -1
  234. package/dist/collection/components/q2-optgroup/q2-optgroup.js.map +1 -1
  235. package/dist/collection/components/q2-option/q2-option.css +5 -0
  236. package/dist/collection/components/q2-option/q2-option.js +2 -0
  237. package/dist/collection/components/q2-option/q2-option.js.map +1 -1
  238. package/dist/collection/components/q2-option-list/q2-option-list.js +8 -6
  239. package/dist/collection/components/q2-option-list/q2-option-list.js.map +1 -1
  240. package/dist/collection/components/q2-pagination/q2-pagination.css +3 -0
  241. package/dist/collection/components/q2-pagination/q2-pagination.js +20 -17
  242. package/dist/collection/components/q2-pagination/q2-pagination.js.map +1 -1
  243. package/dist/collection/components/q2-pill/q2-pill.js +1 -1
  244. package/dist/collection/components/q2-popover/q2-popover.css +1 -1
  245. package/dist/collection/components/q2-popover/q2-popover.js +1 -1
  246. package/dist/collection/components/q2-radio/q2-radio.css +85 -35
  247. package/dist/collection/components/q2-radio/q2-radio.js +1 -1
  248. package/dist/collection/components/q2-radio/q2-radio.js.map +1 -1
  249. package/dist/collection/components/q2-relative-time/q2-relative-time.js +1 -1
  250. package/dist/collection/components/q2-resize-observer/q2-resize-observer.js +1 -1
  251. package/dist/collection/components/q2-section/q2-section.js +2 -2
  252. package/dist/collection/components/q2-section-container/q2-section-container.js +2 -0
  253. package/dist/collection/components/q2-section-container/q2-section-container.js.map +1 -1
  254. package/dist/collection/components/q2-select/q2-select.js +6 -5
  255. package/dist/collection/components/q2-select/q2-select.js.map +1 -1
  256. package/dist/collection/components/q2-stepper/q2-stepper.css +1 -3
  257. package/dist/collection/components/q2-stepper/q2-stepper.js +6 -2
  258. package/dist/collection/components/q2-stepper/q2-stepper.js.map +1 -1
  259. package/dist/collection/components/q2-stepper-pane/q2-stepper-pane.js +7 -5
  260. package/dist/collection/components/q2-stepper-pane/q2-stepper-pane.js.map +1 -1
  261. package/dist/collection/components/q2-stepper-vertical/q2-stepper-vertical.js +1 -1
  262. package/dist/collection/components/q2-tab-container/q2-tab-container.js +5 -1
  263. package/dist/collection/components/q2-tab-container/q2-tab-container.js.map +1 -1
  264. package/dist/collection/components/q2-tab-pane/q2-tab-pane.js +8 -1
  265. package/dist/collection/components/q2-tab-pane/q2-tab-pane.js.map +1 -1
  266. package/dist/collection/components/q2-tag/q2-tag.css +8 -0
  267. package/dist/collection/components/q2-tag/q2-tag.js +1 -1
  268. package/dist/collection/components/q2-textarea/q2-textarea.css +2 -1
  269. package/dist/collection/components/q2-textarea/q2-textarea.js +1 -1
  270. package/dist/collection/components/q2-toast/q2-toast.css +230 -0
  271. package/dist/collection/components/q2-toast/q2-toast.js +452 -0
  272. package/dist/collection/components/q2-toast/q2-toast.js.map +1 -0
  273. package/dist/collection/components/tecton-tab-pane/tecton-tab-pane.js +4 -2
  274. package/dist/collection/components/tecton-tab-pane/tecton-tab-pane.js.map +1 -1
  275. package/dist/collection/utils/action-sheet.js +3 -0
  276. package/dist/collection/utils/action-sheet.js.map +1 -1
  277. package/dist/collection/utils/component.js +38 -0
  278. package/dist/collection/utils/component.js.map +1 -0
  279. package/dist/collection/utils/helpers.js +6 -1
  280. package/dist/collection/utils/helpers.js.map +1 -1
  281. package/dist/collection/utils/sanitize-html-string.js +6 -0
  282. package/dist/collection/utils/sanitize-html-string.js.map +1 -1
  283. package/dist/components/action-sheet.js +3 -0
  284. package/dist/components/action-sheet.js.map +1 -1
  285. package/dist/components/component.js +42 -0
  286. package/dist/components/component.js.map +1 -0
  287. package/dist/components/index.js +2 -0
  288. package/dist/components/index.js.map +1 -1
  289. package/dist/components/q2-action-group2.js +121 -45
  290. package/dist/components/q2-action-group2.js.map +1 -1
  291. package/dist/components/q2-action-sheet.js +9 -5
  292. package/dist/components/q2-action-sheet.js.map +1 -1
  293. package/dist/components/q2-avatar2.js +2 -2
  294. package/dist/components/q2-avatar2.js.map +1 -1
  295. package/dist/components/q2-btn2.js +2 -2
  296. package/dist/components/q2-btn2.js.map +1 -1
  297. package/dist/components/q2-calendar.js +3 -3
  298. package/dist/components/q2-calendar.js.map +1 -1
  299. package/dist/components/q2-card-image.js +6 -6
  300. package/dist/components/q2-card-image.js.map +1 -1
  301. package/dist/components/q2-card.js +1 -1
  302. package/dist/components/q2-card.js.map +1 -1
  303. package/dist/components/q2-carousel-pane.js +7 -3
  304. package/dist/components/q2-carousel-pane.js.map +1 -1
  305. package/dist/components/q2-carousel.js +12 -2
  306. package/dist/components/q2-carousel.js.map +1 -1
  307. package/dist/components/q2-chart-area.js +1 -1
  308. package/dist/components/q2-chart-bar.js +1 -1
  309. package/dist/components/q2-chart-donut.js +1 -1
  310. package/dist/components/q2-checkbox-group.js +5 -1
  311. package/dist/components/q2-checkbox-group.js.map +1 -1
  312. package/dist/components/q2-checkbox2.js +3 -4
  313. package/dist/components/q2-checkbox2.js.map +1 -1
  314. package/dist/components/q2-context.js +1 -1
  315. package/dist/components/q2-context.js.map +1 -1
  316. package/dist/components/q2-currency.js +1 -1
  317. package/dist/components/q2-data-table.js +20 -9
  318. package/dist/components/q2-data-table.js.map +1 -1
  319. package/dist/components/q2-detail.js +2 -2
  320. package/dist/components/q2-detail.js.map +1 -1
  321. package/dist/components/q2-dropdown-item2.js +3 -1
  322. package/dist/components/q2-dropdown-item2.js.map +1 -1
  323. package/dist/components/q2-dropdown.js +34 -7
  324. package/dist/components/q2-dropdown.js.map +1 -1
  325. package/dist/components/q2-editable-field.js +1 -1
  326. package/dist/components/q2-example.js +1 -1
  327. package/dist/components/q2-file-picker.js +2 -2
  328. package/dist/components/q2-file-picker.js.map +1 -1
  329. package/dist/components/q2-form.js +1 -1
  330. package/dist/components/q2-formatted-text.js +1 -1
  331. package/dist/components/q2-grid-area.js +9 -1
  332. package/dist/components/q2-grid-area.js.map +1 -1
  333. package/dist/components/q2-icon2.js +6 -0
  334. package/dist/components/q2-icon2.js.map +1 -1
  335. package/dist/components/q2-input2.js +8 -6
  336. package/dist/components/q2-input2.js.map +1 -1
  337. package/dist/components/q2-item2.js +17 -17
  338. package/dist/components/q2-item2.js.map +1 -1
  339. package/dist/components/q2-legend2.js +1 -1
  340. package/dist/components/q2-link2.js +12 -6
  341. package/dist/components/q2-link2.js.map +1 -1
  342. package/dist/components/q2-list2.js +1 -1
  343. package/dist/components/q2-loading2.js +11 -2
  344. package/dist/components/q2-loading2.js.map +1 -1
  345. package/dist/components/q2-message2.js +2 -2
  346. package/dist/components/q2-message2.js.map +1 -1
  347. package/dist/components/q2-meter.js +1 -1
  348. package/dist/components/q2-modal.js +1 -1
  349. package/dist/components/q2-month-picker.js +2 -2
  350. package/dist/components/q2-mutation-observer.js +1 -1
  351. package/dist/components/q2-optgroup2.js +4 -2
  352. package/dist/components/q2-optgroup2.js.map +1 -1
  353. package/dist/components/q2-option-list2.js +3 -1
  354. package/dist/components/q2-option-list2.js.map +1 -1
  355. package/dist/components/q2-option2.js +3 -1
  356. package/dist/components/q2-option2.js.map +1 -1
  357. package/dist/components/q2-pagination.js +11 -13
  358. package/dist/components/q2-pagination.js.map +1 -1
  359. package/dist/components/q2-pill.js +1 -1
  360. package/dist/components/q2-popover2.js +2 -2
  361. package/dist/components/q2-popover2.js.map +1 -1
  362. package/dist/components/q2-radio.js +2 -2
  363. package/dist/components/q2-radio.js.map +1 -1
  364. package/dist/components/q2-relative-time.js +1 -1
  365. package/dist/components/q2-resize-observer2.js +1 -1
  366. package/dist/components/q2-section-container.js +2 -0
  367. package/dist/components/q2-section-container.js.map +1 -1
  368. package/dist/components/q2-section.js +2 -2
  369. package/dist/components/q2-select2.js +6 -2
  370. package/dist/components/q2-select2.js.map +1 -1
  371. package/dist/components/q2-stepper-pane.js +3 -1
  372. package/dist/components/q2-stepper-pane.js.map +1 -1
  373. package/dist/components/q2-stepper-vertical.js +1 -1
  374. package/dist/components/q2-stepper.js +7 -3
  375. package/dist/components/q2-stepper.js.map +1 -1
  376. package/dist/components/q2-tab-container.js +5 -1
  377. package/dist/components/q2-tab-container.js.map +1 -1
  378. package/dist/components/q2-tab-pane.js +8 -1
  379. package/dist/components/q2-tab-pane.js.map +1 -1
  380. package/dist/components/q2-tag.js +2 -2
  381. package/dist/components/q2-tag.js.map +1 -1
  382. package/dist/components/q2-textarea.js +2 -2
  383. package/dist/components/q2-textarea.js.map +1 -1
  384. package/dist/components/q2-toast.d.ts +11 -0
  385. package/dist/components/q2-toast.js +233 -0
  386. package/dist/components/q2-toast.js.map +1 -0
  387. package/dist/components/sanitize-html-string.js +28 -5
  388. package/dist/components/sanitize-html-string.js.map +1 -1
  389. package/dist/components/tecton-tab-pane.js +4 -2
  390. package/dist/components/tecton-tab-pane.js.map +1 -1
  391. package/dist/esm/{action-sheet-WwoBwnIp.js → action-sheet-B7adb3xs.js} +5 -2
  392. package/dist/esm/action-sheet-B7adb3xs.js.map +1 -0
  393. package/dist/esm/component-DVxzK3WH.js +42 -0
  394. package/dist/esm/component-DVxzK3WH.js.map +1 -0
  395. package/dist/esm/loader.js +1 -1
  396. package/dist/esm/q2-action-group.q2-resize-observer.entry.js.map +1 -1
  397. package/dist/esm/q2-action-group_2.entry.js +121 -45
  398. package/dist/esm/q2-action-group_2.entry.js.map +1 -1
  399. package/dist/esm/q2-action-sheet.entry.js +9 -5
  400. package/dist/esm/q2-action-sheet.entry.js.map +1 -1
  401. package/dist/esm/q2-avatar.entry.js +2 -2
  402. package/dist/esm/q2-avatar.entry.js.map +1 -1
  403. package/dist/esm/q2-btn.q2-loading.entry.js.map +1 -1
  404. package/dist/esm/q2-btn_2.entry.js +13 -4
  405. package/dist/esm/q2-btn_2.entry.js.map +1 -1
  406. package/dist/esm/q2-calendar.entry.js +3 -3
  407. package/dist/esm/q2-calendar.entry.js.map +1 -1
  408. package/dist/esm/q2-card-image.entry.js +6 -6
  409. package/dist/esm/q2-card-image.entry.js.map +1 -1
  410. package/dist/esm/q2-card.entry.js +1 -1
  411. package/dist/esm/q2-card.entry.js.map +1 -1
  412. package/dist/esm/q2-carousel-pane.entry.js +7 -3
  413. package/dist/esm/q2-carousel-pane.entry.js.map +1 -1
  414. package/dist/esm/q2-carousel.entry.js +12 -2
  415. package/dist/esm/q2-carousel.entry.js.map +1 -1
  416. package/dist/esm/q2-chart-area.entry.js +1 -1
  417. package/dist/esm/q2-chart-bar.entry.js +1 -1
  418. package/dist/esm/q2-chart-donut.entry.js +1 -1
  419. package/dist/esm/q2-checkbox-group.entry.js +5 -1
  420. package/dist/esm/q2-checkbox-group.entry.js.map +1 -1
  421. package/dist/esm/q2-checkbox.entry.js +3 -4
  422. package/dist/esm/q2-checkbox.entry.js.map +1 -1
  423. package/dist/esm/q2-context.entry.js +1 -1
  424. package/dist/esm/q2-context.entry.js.map +1 -1
  425. package/dist/esm/q2-currency.entry.js +1 -1
  426. package/dist/esm/q2-data-table.entry.js +19 -9
  427. package/dist/esm/q2-data-table.entry.js.map +1 -1
  428. package/dist/esm/q2-detail.entry.js +2 -2
  429. package/dist/esm/q2-detail.entry.js.map +1 -1
  430. package/dist/esm/q2-dropdown-item.entry.js +3 -1
  431. package/dist/esm/q2-dropdown-item.entry.js.map +1 -1
  432. package/dist/esm/q2-dropdown.entry.js +33 -8
  433. package/dist/esm/q2-dropdown.entry.js.map +1 -1
  434. package/dist/esm/q2-editable-field.entry.js +1 -1
  435. package/dist/esm/q2-example.entry.js +1 -1
  436. package/dist/esm/q2-file-picker.entry.js +2 -2
  437. package/dist/esm/q2-file-picker.entry.js.map +1 -1
  438. package/dist/esm/q2-form.entry.js +1 -1
  439. package/dist/esm/q2-formatted-text.entry.js +1 -1
  440. package/dist/esm/q2-grid-area.entry.js +10 -2
  441. package/dist/esm/q2-grid-area.entry.js.map +1 -1
  442. package/dist/esm/q2-icon.entry.js +6 -0
  443. package/dist/esm/q2-icon.entry.js.map +1 -1
  444. package/dist/esm/q2-input.entry.js +8 -6
  445. package/dist/esm/q2-input.entry.js.map +1 -1
  446. package/dist/esm/q2-item.entry.js +17 -17
  447. package/dist/esm/q2-item.entry.js.map +1 -1
  448. package/dist/esm/q2-legend.entry.js +1 -1
  449. package/dist/esm/q2-link.q2-list.entry.js.map +1 -1
  450. package/dist/esm/q2-link_2.entry.js +11 -7
  451. package/dist/esm/q2-link_2.entry.js.map +1 -1
  452. package/dist/esm/q2-message.entry.js +2 -2
  453. package/dist/esm/q2-message.entry.js.map +1 -1
  454. package/dist/esm/q2-meter.entry.js +1 -1
  455. package/dist/esm/q2-modal.entry.js +2 -2
  456. package/dist/esm/q2-month-picker.entry.js +2 -2
  457. package/dist/esm/q2-mutation-observer.entry.js +1 -1
  458. package/dist/esm/q2-optgroup.entry.js +4 -2
  459. package/dist/esm/q2-optgroup.entry.js.map +1 -1
  460. package/dist/esm/q2-option-list.q2-popover.entry.js.map +1 -1
  461. package/dist/esm/q2-option-list_2.entry.js +5 -3
  462. package/dist/esm/q2-option-list_2.entry.js.map +1 -1
  463. package/dist/esm/q2-option.entry.js +3 -1
  464. package/dist/esm/q2-option.entry.js.map +1 -1
  465. package/dist/esm/q2-pagination.entry.js +10 -12
  466. package/dist/esm/q2-pagination.entry.js.map +1 -1
  467. package/dist/esm/q2-pill.entry.js +2 -2
  468. package/dist/esm/q2-radio.entry.js +2 -2
  469. package/dist/esm/q2-radio.entry.js.map +1 -1
  470. package/dist/esm/q2-relative-time.entry.js +1 -1
  471. package/dist/esm/q2-section-container.entry.js +2 -0
  472. package/dist/esm/q2-section-container.entry.js.map +1 -1
  473. package/dist/esm/q2-section.entry.js +2 -2
  474. package/dist/esm/q2-select.entry.js +7 -3
  475. package/dist/esm/q2-select.entry.js.map +1 -1
  476. package/dist/esm/q2-stepper-pane.entry.js +3 -1
  477. package/dist/esm/q2-stepper-pane.entry.js.map +1 -1
  478. package/dist/esm/q2-stepper-vertical.entry.js +1 -1
  479. package/dist/esm/q2-stepper.entry.js +7 -3
  480. package/dist/esm/q2-stepper.entry.js.map +1 -1
  481. package/dist/esm/q2-tab-container.entry.js +5 -1
  482. package/dist/esm/q2-tab-container.entry.js.map +1 -1
  483. package/dist/esm/q2-tab-pane.entry.js +9 -2
  484. package/dist/esm/q2-tab-pane.entry.js.map +1 -1
  485. package/dist/esm/q2-tag.entry.js +3 -3
  486. package/dist/esm/q2-tag.entry.js.map +1 -1
  487. package/dist/esm/q2-tecton-elements.js +1 -1
  488. package/dist/esm/q2-textarea.entry.js +2 -2
  489. package/dist/esm/q2-textarea.entry.js.map +1 -1
  490. package/dist/esm/q2-toast.entry.js +190 -0
  491. package/dist/esm/q2-toast.entry.js.map +1 -0
  492. package/dist/esm/{sanitize-html-string-DOVERJq5.js → sanitize-html-string-BPwFpYg-.js} +30 -7
  493. package/dist/esm/sanitize-html-string-BPwFpYg-.js.map +1 -0
  494. package/dist/esm/tecton-tab-pane.entry.js +4 -2
  495. package/dist/esm/tecton-tab-pane.entry.js.map +1 -1
  496. package/dist/jest.e2e-coverage.js +25 -0
  497. package/dist/jest.e2e-coverage.js.map +1 -0
  498. package/dist/q2-tecton-elements/{action-sheet-WwoBwnIp.js → action-sheet-B7adb3xs.js} +19 -14
  499. package/dist/q2-tecton-elements/action-sheet-B7adb3xs.js.map +1 -0
  500. package/dist/q2-tecton-elements/assets/brand.symbol.svg +1 -1
  501. package/dist/q2-tecton-elements/assets/browsersos.symbol.svg +1 -1
  502. package/dist/q2-tecton-elements/assets/cards.symbol.svg +1 -1
  503. package/dist/q2-tecton-elements/assets/communication.symbol.svg +1 -1
  504. package/dist/q2-tecton-elements/assets/currencies.symbol.svg +1 -1
  505. package/dist/q2-tecton-elements/assets/devices.symbol.svg +1 -1
  506. package/dist/q2-tecton-elements/assets/filetypes.symbol.svg +1 -1
  507. package/dist/q2-tecton-elements/assets/gestures.symbol.svg +1 -1
  508. package/dist/q2-tecton-elements/assets/icon-list.json +1 -1
  509. package/dist/q2-tecton-elements/assets/icon-map.json +1 -1
  510. package/dist/q2-tecton-elements/assets/legacy.symbol.svg +1 -1
  511. package/dist/q2-tecton-elements/assets/mobile.symbol.svg +1 -1
  512. package/dist/q2-tecton-elements/assets/standard.symbol.svg +1 -1
  513. package/dist/q2-tecton-elements/component-DVxzK3WH.js +40 -0
  514. package/dist/q2-tecton-elements/component-DVxzK3WH.js.map +1 -0
  515. package/dist/q2-tecton-elements/q2-action-group.q2-resize-observer.entry.esm.js.map +1 -1
  516. package/dist/q2-tecton-elements/q2-action-group_2.entry.js +131 -63
  517. package/dist/q2-tecton-elements/q2-action-group_2.entry.js.map +1 -1
  518. package/dist/q2-tecton-elements/q2-action-sheet.entry.esm.js.map +1 -1
  519. package/dist/q2-tecton-elements/q2-action-sheet.entry.js +79 -75
  520. package/dist/q2-tecton-elements/q2-action-sheet.entry.js.map +1 -1
  521. package/dist/q2-tecton-elements/q2-avatar.entry.esm.js.map +1 -1
  522. package/dist/q2-tecton-elements/q2-avatar.entry.js +7 -7
  523. package/dist/q2-tecton-elements/q2-avatar.entry.js.map +1 -1
  524. package/dist/q2-tecton-elements/q2-btn.q2-loading.entry.esm.js.map +1 -1
  525. package/dist/q2-tecton-elements/q2-btn_2.entry.js +11 -4
  526. package/dist/q2-tecton-elements/q2-btn_2.entry.js.map +1 -1
  527. package/dist/q2-tecton-elements/q2-calendar.entry.esm.js.map +1 -1
  528. package/dist/q2-tecton-elements/q2-calendar.entry.js +4 -3
  529. package/dist/q2-tecton-elements/q2-calendar.entry.js.map +1 -1
  530. package/dist/q2-tecton-elements/q2-card-image.entry.esm.js.map +1 -1
  531. package/dist/q2-tecton-elements/q2-card-image.entry.js +11 -11
  532. package/dist/q2-tecton-elements/q2-card-image.entry.js.map +1 -1
  533. package/dist/q2-tecton-elements/q2-card.entry.esm.js.map +1 -1
  534. package/dist/q2-tecton-elements/q2-card.entry.js +1 -1
  535. package/dist/q2-tecton-elements/q2-card.entry.js.map +1 -1
  536. package/dist/q2-tecton-elements/q2-carousel-pane.entry.esm.js.map +1 -1
  537. package/dist/q2-tecton-elements/q2-carousel-pane.entry.js +25 -20
  538. package/dist/q2-tecton-elements/q2-carousel-pane.entry.js.map +1 -1
  539. package/dist/q2-tecton-elements/q2-carousel.entry.esm.js.map +1 -1
  540. package/dist/q2-tecton-elements/q2-carousel.entry.js +79 -67
  541. package/dist/q2-tecton-elements/q2-carousel.entry.js.map +1 -1
  542. package/dist/q2-tecton-elements/q2-chart-area.entry.js +2 -2
  543. package/dist/q2-tecton-elements/q2-chart-bar.entry.js +2 -2
  544. package/dist/q2-tecton-elements/q2-chart-donut.entry.js +9 -9
  545. package/dist/q2-tecton-elements/q2-checkbox-group.entry.esm.js.map +1 -1
  546. package/dist/q2-tecton-elements/q2-checkbox-group.entry.js +20 -15
  547. package/dist/q2-tecton-elements/q2-checkbox-group.entry.js.map +1 -1
  548. package/dist/q2-tecton-elements/q2-checkbox.entry.esm.js.map +1 -1
  549. package/dist/q2-tecton-elements/q2-checkbox.entry.js +70 -71
  550. package/dist/q2-tecton-elements/q2-checkbox.entry.js.map +1 -1
  551. package/dist/q2-tecton-elements/q2-context.entry.esm.js.map +1 -1
  552. package/dist/q2-tecton-elements/q2-context.entry.js +12 -12
  553. package/dist/q2-tecton-elements/q2-context.entry.js.map +1 -1
  554. package/dist/q2-tecton-elements/q2-currency.entry.js +8 -8
  555. package/dist/q2-tecton-elements/q2-data-table.entry.esm.js.map +1 -1
  556. package/dist/q2-tecton-elements/q2-data-table.entry.js +40 -27
  557. package/dist/q2-tecton-elements/q2-data-table.entry.js.map +1 -1
  558. package/dist/q2-tecton-elements/q2-detail.entry.esm.js.map +1 -1
  559. package/dist/q2-tecton-elements/q2-detail.entry.js +10 -10
  560. package/dist/q2-tecton-elements/q2-detail.entry.js.map +1 -1
  561. package/dist/q2-tecton-elements/q2-dropdown-item.entry.esm.js.map +1 -1
  562. package/dist/q2-tecton-elements/q2-dropdown-item.entry.js +11 -8
  563. package/dist/q2-tecton-elements/q2-dropdown-item.entry.js.map +1 -1
  564. package/dist/q2-tecton-elements/q2-dropdown.entry.esm.js.map +1 -1
  565. package/dist/q2-tecton-elements/q2-dropdown.entry.js +113 -85
  566. package/dist/q2-tecton-elements/q2-dropdown.entry.js.map +1 -1
  567. package/dist/q2-tecton-elements/q2-editable-field.entry.js +1 -1
  568. package/dist/q2-tecton-elements/q2-example.entry.js +1 -1
  569. package/dist/q2-tecton-elements/q2-file-picker.entry.esm.js.map +1 -1
  570. package/dist/q2-tecton-elements/q2-file-picker.entry.js +3 -2
  571. package/dist/q2-tecton-elements/q2-file-picker.entry.js.map +1 -1
  572. package/dist/q2-tecton-elements/q2-form.entry.js +7 -7
  573. package/dist/q2-tecton-elements/q2-formatted-text.entry.js +2 -2
  574. package/dist/q2-tecton-elements/q2-grid-area.entry.esm.js.map +1 -1
  575. package/dist/q2-tecton-elements/q2-grid-area.entry.js +18 -7
  576. package/dist/q2-tecton-elements/q2-grid-area.entry.js.map +1 -1
  577. package/dist/q2-tecton-elements/q2-icon.entry.esm.js.map +1 -1
  578. package/dist/q2-tecton-elements/q2-icon.entry.js +145 -137
  579. package/dist/q2-tecton-elements/q2-icon.entry.js.map +1 -1
  580. package/dist/q2-tecton-elements/q2-input.entry.esm.js.map +1 -1
  581. package/dist/q2-tecton-elements/q2-input.entry.js +14 -8
  582. package/dist/q2-tecton-elements/q2-input.entry.js.map +1 -1
  583. package/dist/q2-tecton-elements/q2-item.entry.esm.js.map +1 -1
  584. package/dist/q2-tecton-elements/q2-item.entry.js +56 -53
  585. package/dist/q2-tecton-elements/q2-item.entry.js.map +1 -1
  586. package/dist/q2-tecton-elements/q2-legend.entry.js +2 -2
  587. package/dist/q2-tecton-elements/q2-link.q2-list.entry.esm.js.map +1 -1
  588. package/dist/q2-tecton-elements/q2-link_2.entry.js +22 -18
  589. package/dist/q2-tecton-elements/q2-link_2.entry.js.map +1 -1
  590. package/dist/q2-tecton-elements/q2-message.entry.esm.js.map +1 -1
  591. package/dist/q2-tecton-elements/q2-message.entry.js +9 -9
  592. package/dist/q2-tecton-elements/q2-message.entry.js.map +1 -1
  593. package/dist/q2-tecton-elements/q2-meter.entry.js +7 -7
  594. package/dist/q2-tecton-elements/q2-modal.entry.js +21 -21
  595. package/dist/q2-tecton-elements/q2-month-picker.entry.js +30 -30
  596. package/dist/q2-tecton-elements/q2-mutation-observer.entry.js +1 -1
  597. package/dist/q2-tecton-elements/q2-optgroup.entry.esm.js.map +1 -1
  598. package/dist/q2-tecton-elements/q2-optgroup.entry.js +15 -12
  599. package/dist/q2-tecton-elements/q2-optgroup.entry.js.map +1 -1
  600. package/dist/q2-tecton-elements/q2-option-list.q2-popover.entry.esm.js.map +1 -1
  601. package/dist/q2-tecton-elements/q2-option-list_2.entry.js +52 -49
  602. package/dist/q2-tecton-elements/q2-option-list_2.entry.js.map +1 -1
  603. package/dist/q2-tecton-elements/q2-option.entry.esm.js.map +1 -1
  604. package/dist/q2-tecton-elements/q2-option.entry.js +15 -12
  605. package/dist/q2-tecton-elements/q2-option.entry.js.map +1 -1
  606. package/dist/q2-tecton-elements/q2-pagination.entry.esm.js.map +1 -1
  607. package/dist/q2-tecton-elements/q2-pagination.entry.js +66 -66
  608. package/dist/q2-tecton-elements/q2-pagination.entry.js.map +1 -1
  609. package/dist/q2-tecton-elements/q2-pill.entry.js +37 -37
  610. package/dist/q2-tecton-elements/q2-radio.entry.esm.js.map +1 -1
  611. package/dist/q2-tecton-elements/q2-radio.entry.js +47 -45
  612. package/dist/q2-tecton-elements/q2-radio.entry.js.map +1 -1
  613. package/dist/q2-tecton-elements/q2-relative-time.entry.js +1 -1
  614. package/dist/q2-tecton-elements/q2-section-container.entry.esm.js.map +1 -1
  615. package/dist/q2-tecton-elements/q2-section-container.entry.js +5 -2
  616. package/dist/q2-tecton-elements/q2-section-container.entry.js.map +1 -1
  617. package/dist/q2-tecton-elements/q2-section.entry.js +11 -11
  618. package/dist/q2-tecton-elements/q2-select.entry.esm.js.map +1 -1
  619. package/dist/q2-tecton-elements/q2-select.entry.js +6 -3
  620. package/dist/q2-tecton-elements/q2-select.entry.js.map +1 -1
  621. package/dist/q2-tecton-elements/q2-stepper-pane.entry.esm.js.map +1 -1
  622. package/dist/q2-tecton-elements/q2-stepper-pane.entry.js +22 -19
  623. package/dist/q2-tecton-elements/q2-stepper-pane.entry.js.map +1 -1
  624. package/dist/q2-tecton-elements/q2-stepper-vertical.entry.js +69 -69
  625. package/dist/q2-tecton-elements/q2-stepper.entry.esm.js.map +1 -1
  626. package/dist/q2-tecton-elements/q2-stepper.entry.js +42 -39
  627. package/dist/q2-tecton-elements/q2-stepper.entry.js.map +1 -1
  628. package/dist/q2-tecton-elements/q2-tab-container.entry.esm.js.map +1 -1
  629. package/dist/q2-tecton-elements/q2-tab-container.entry.js +21 -16
  630. package/dist/q2-tecton-elements/q2-tab-container.entry.js.map +1 -1
  631. package/dist/q2-tecton-elements/q2-tab-pane.entry.esm.js.map +1 -1
  632. package/dist/q2-tecton-elements/q2-tab-pane.entry.js +17 -7
  633. package/dist/q2-tecton-elements/q2-tab-pane.entry.js.map +1 -1
  634. package/dist/q2-tecton-elements/q2-tag.entry.esm.js.map +1 -1
  635. package/dist/q2-tecton-elements/q2-tag.entry.js +65 -65
  636. package/dist/q2-tecton-elements/q2-tag.entry.js.map +1 -1
  637. package/dist/q2-tecton-elements/q2-tecton-elements.esm.js +1 -1
  638. package/dist/q2-tecton-elements/q2-textarea.entry.esm.js.map +1 -1
  639. package/dist/q2-tecton-elements/q2-textarea.entry.js +3 -3
  640. package/dist/q2-tecton-elements/q2-textarea.entry.js.map +1 -1
  641. package/dist/q2-tecton-elements/q2-toast.entry.esm.js.map +1 -0
  642. package/dist/q2-tecton-elements/q2-toast.entry.js +222 -0
  643. package/dist/q2-tecton-elements/q2-toast.entry.js.map +1 -0
  644. package/dist/q2-tecton-elements/{sanitize-html-string-DOVERJq5.js → sanitize-html-string-BPwFpYg-.js} +167 -145
  645. package/dist/q2-tecton-elements/sanitize-html-string-BPwFpYg-.js.map +1 -0
  646. package/dist/q2-tecton-elements/tecton-tab-pane.entry.esm.js.map +1 -1
  647. package/dist/q2-tecton-elements/tecton-tab-pane.entry.js +8 -8
  648. package/dist/q2-tecton-elements/tecton-tab-pane.entry.js.map +1 -1
  649. package/dist/scripts/docs-generator/index.js +1 -1
  650. package/dist/scripts/docs-generator/index.js.map +1 -1
  651. package/dist/types/Users/kvanhouten/Documents/Work/tecton/packages/q2-tecton-elements/.stencil/jest.e2e-coverage.d.ts +1 -0
  652. package/dist/types/components/q2-action-group/q2-action-group.d.ts +7 -4
  653. package/dist/types/components/q2-carousel-pane/q2-carousel-pane.d.ts +1 -0
  654. package/dist/types/components/q2-checkbox/q2-checkbox.d.ts +0 -5
  655. package/dist/types/components/q2-data-table/q2-data-table.d.ts +8 -0
  656. package/dist/types/components/q2-dropdown/q2-dropdown.d.ts +22 -3
  657. package/dist/types/components/q2-grid-area/q2-grid-area.d.ts +2 -0
  658. package/dist/types/components/q2-input/q2-input.d.ts +4 -5
  659. package/dist/types/components/q2-item/q2-item.d.ts +5 -4
  660. package/dist/types/components/q2-link/q2-link.d.ts +4 -0
  661. package/dist/types/components/q2-pagination/q2-pagination.d.ts +11 -3
  662. package/dist/types/components/q2-select/q2-select.d.ts +1 -2
  663. package/dist/types/components/q2-tab-pane/q2-tab-pane.d.ts +2 -0
  664. package/dist/types/components/q2-toast/q2-toast.d.ts +67 -0
  665. package/dist/types/components.d.ts +189 -34
  666. package/dist/types/utils/action-sheet.d.ts +2 -1
  667. package/dist/types/utils/component.d.ts +4 -0
  668. package/dist/types/utils/sanitize-html-string.d.ts +1 -0
  669. package/package.json +11 -7
  670. package/dist/cjs/action-sheet-CiK2Bap_.js.map +0 -1
  671. package/dist/cjs/sanitize-html-string-DPqrzfM9.js.map +0 -1
  672. package/dist/esm/action-sheet-WwoBwnIp.js.map +0 -1
  673. package/dist/esm/sanitize-html-string-DOVERJq5.js.map +0 -1
  674. package/dist/q2-tecton-elements/action-sheet-WwoBwnIp.js.map +0 -1
  675. package/dist/q2-tecton-elements/sanitize-html-string-DOVERJq5.js.map +0 -1
  676. /package/dist/types/Users/kvanhouten/Documents/Work/{tecton_extra → tecton}/packages/q2-tecton-elements/.stencil/jest.setup.d.ts +0 -0
  677. /package/dist/types/Users/kvanhouten/Documents/Work/{tecton_extra → tecton}/packages/q2-tecton-elements/.stencil/scripts/docs-generator/index.d.ts +0 -0
  678. /package/dist/types/Users/kvanhouten/Documents/Work/{tecton_extra → tecton}/packages/q2-tecton-elements/.stencil/scripts/docs-generator/markdown-generator.d.ts +0 -0
  679. /package/dist/types/Users/kvanhouten/Documents/Work/{tecton_extra → tecton}/packages/q2-tecton-elements/.stencil/scripts/docs-generator/tag-handlers.d.ts +0 -0
  680. /package/dist/types/Users/kvanhouten/Documents/Work/{tecton_extra → tecton}/packages/q2-tecton-elements/.stencil/scripts/docs-generator/types.d.ts +0 -0
@@ -0,0 +1,192 @@
1
+ 'use strict';
2
+
3
+ var index = require('./index-BYXz4owL.js');
4
+ var index$1 = require('./index-DyAq0y0v.js');
5
+
6
+ const q2ToastCss = "*{box-sizing:border-box}*:active{outline:none}*:focus-visible{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:block}.toast{--comp-accent-width:1px;--comp-icon-size:32px;--comp-icon-bg:transparent;--comp-text-color:var(--tct-toast-text, var(--tct-gray-2, var(--app-gray-2, #333333)));--comp-subtle-color:var(--tct-toast-subtle, var(--tct-gray-5, var(--app-gray-5, #6b6b6b)));--comp-color-success:var(--tct-stoplight-success, var(--const-stoplight-success, #0e8a00));--comp-color-info:var(--tct-stoplight-info, var(--const-stoplight-info, #0079c1));--comp-color-warning:var(--tct-stoplight-warning, var(--const-stoplight-warning, #c35500));--comp-color-alert:var(--tct-stoplight-alert, var(--const-stoplight-alert, #d20a0a));--comp-color-default:white;display:flex;flex-direction:column;gap:var(--tct-toast-gap, var(--app-scale-2x, 10px));padding-left:3px;border-radius:5px;border:1px solid transparent;background:var(--tct-toast-background, var(--tct-gray-14, var(--app-gray-l3, #ffffff)));color:var(--comp-text-color);box-shadow:var(--tct-toast-shadow, var(--app-shadow-2, 0 12px 24px rgb(0 0 0 / 0.12)));overflow:hidden}.toast.success{border-color:var(--comp-color-success);background-color:var(--comp-color-success);--comp-icon-bg:#e7f5e3}.toast.info{border-color:var(--comp-color-info);background-color:var(--comp-color-info);--comp-icon-bg:#e6f1fb}.toast.warning{border-color:var(--comp-color-warning);background-color:var(--comp-color-warning);--comp-icon-bg:#fff0df}.toast.alert{border-color:var(--comp-color-alert);background-color:var(--comp-color-alert);--comp-icon-bg:#fde6e6}.toast.is-closing{animation-name:shrink;animation-duration:500ms;animation-timing-function:linear;animation-fill-mode:forwards;transform-origin:top;overflow:hidden}.toast.small .container{padding:var(--tct-toast-padding-small, var(--app-scale-2x, 10px))}.toast.default{--comp-border-color:var(--tct-toast-border, var(--tct-gray-9, var(--app-gray-4, #d1d1d1)));--comp-icon-bg:var(--tct-toast-icon-bg, var(--tct-gray-12, var(--app-gray-l2, #f3f3f3)));border-color:var(--comp-border-color)}.header{display:grid;grid-template-columns:var(--comp-icon-size) 1fr auto;gap:var(--tct-toast-gap, var(--app-scale-2x, 10px));align-items:center}.toast.no-icon .header{grid-template-columns:1fr auto}.icon{width:var(--comp-icon-size);height:var(--comp-icon-size);border-radius:50%;display:grid;place-items:center;background:var(--comp-icon-bg)}.icon q2-icon{--tct-icon-size:calc(var(--comp-icon-size) - 6px);--tct-icon-stroke-primary:var(--comp-border-color);--tct-icon-stroke-secondary:var(--comp-border-color);--tct-icon-fill:var(--comp-border-color)}.title{font-weight:600;display:flex;align-items:center}.title-text{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.content{color:var(--comp-subtle-color);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.footer{margin-top:var(--tct-toast-footer-gap, var(--app-scale-2x, 10px));display:flex;align-items:center;justify-content:space-between;gap:var(--tct-toast-footer-spacing, var(--app-scale-2x, 10px));color:var(--comp-subtle-color);font-size:0.875rem}.time{white-space:nowrap}.actions{display:inline-flex;align-items:center;gap:var(--tct-toast-actions-gap, var(--app-scale-2x, 10px))}.close{border:none;background:transparent;padding:2px;margin-left:var(--tct-toast-close-offset, var(--app-scale-1x, 5px));color:var(--comp-subtle-color);cursor:pointer}.close q2-icon{--tct-icon-size:18px}.container{padding:var(--tct-toast-padding, var(--app-scale-3x, 15px));background-color:white}@keyframes shrink{from{transform:scale(1);height:var(--toast-close-height, 0px);opacity:1}to{transform:scale(0);height:0;opacity:0}}";
7
+
8
+ const Q2Toast = class {
9
+ constructor(hostRef) {
10
+ index.registerInstance(this, hostRef);
11
+ this.tctClose = index.createEvent(this, "tctClose", 7);
12
+ this.closeAnimationTimeMs = 500;
13
+ // #endregion
14
+ // #region State Properties
15
+ this.isClosing = false;
16
+ this.isOpen = true;
17
+ // #endregion
18
+ // #region Public Property API
19
+ /** Enables automatic dismissal after a duration. */
20
+ this.autoClose = false;
21
+ /** Controls whether the close button is displayed. */
22
+ this.closable = true;
23
+ /** The duration in milliseconds before auto dismissal. */
24
+ this.duration = 7000;
25
+ /** Manually hide the icon where it would otherwise appear. */
26
+ this.hideIcon = false;
27
+ /**
28
+ * Convenience prop for persistent toasts. When true, sets autoClose to false and closable to true.
29
+ * Aligns with acceptance criteria for showPersistent behavior.
30
+ */
31
+ this.showPersistent = false;
32
+ /** Controls the visual size of the toast. */
33
+ this.size = 'large';
34
+ /** The visual status of the toast. */
35
+ this.type = 'default';
36
+ this.onCloseClick = () => {
37
+ this.dismiss('close');
38
+ };
39
+ }
40
+ // #endregion
41
+ // #region Component Lifecycle Events
42
+ disconnectedCallback() {
43
+ this.clearAutoClose();
44
+ this.clearCloseTimer();
45
+ }
46
+ componentDidLoad() {
47
+ this.startAutoClose();
48
+ }
49
+ // #endregion
50
+ // #region Watchers
51
+ onAutoCloseChange() {
52
+ this.startAutoClose();
53
+ }
54
+ onShowPersistentChange() {
55
+ if (this.showPersistent) {
56
+ this.autoClose = false;
57
+ this.closable = true;
58
+ }
59
+ else {
60
+ this.autoClose = true;
61
+ }
62
+ }
63
+ onSizeChange() {
64
+ if (this.size === 'large') {
65
+ this.showPersistent = true;
66
+ }
67
+ }
68
+ // #endregion
69
+ // #region Local Methods
70
+ get ariaLive() {
71
+ // Alert/error/warning types should be assertive, others polite
72
+ return this.resolvedType === 'alert' || this.resolvedType === 'warning' ? 'assertive' : 'polite';
73
+ }
74
+ get ariaRole() {
75
+ // Alert/error/warning types use "alert" role, others use "status"
76
+ return this.resolvedType === 'alert' || this.resolvedType === 'warning' ? 'alert' : 'status';
77
+ }
78
+ get hasIconSlot() {
79
+ return index$1.hasSlotContent(this.hostElement, 'icon');
80
+ }
81
+ get isLarge() {
82
+ return this.size !== 'small';
83
+ }
84
+ get resolvedIcon() {
85
+ if (this.icon)
86
+ return this.icon;
87
+ const iconMap = {
88
+ success: 'success-filled',
89
+ warning: 'warning-filled',
90
+ alert: 'error-filled',
91
+ info: 'info-filled',
92
+ };
93
+ return iconMap[this.resolvedType];
94
+ }
95
+ get resolvedType() {
96
+ return this.type === 'error' ? 'alert' : this.type;
97
+ }
98
+ get shouldShowIcon() {
99
+ return (this.hasIconSlot || !!this.resolvedIcon) && !this.hideIcon;
100
+ }
101
+ get showFooter() {
102
+ const hasActions = index$1.hasSlotContent(this.hostElement, 'actions');
103
+ const hasTime = index$1.hasSlotContent(this.hostElement, 'time') || !!this.time;
104
+ return this.isLarge && (hasActions || hasTime);
105
+ }
106
+ get srTypeLabel() {
107
+ // Screen reader label for toast type
108
+ const labelMap = {
109
+ success: index$1.loc('tecton.element.toast.type.success'),
110
+ warning: index$1.loc('tecton.element.toast.type.warning'),
111
+ alert: index$1.loc('tecton.element.toast.type.alert'),
112
+ info: index$1.loc('tecton.element.toast.type.info'),
113
+ default: index$1.loc('tecton.element.toast.type.default'),
114
+ };
115
+ return labelMap[this.resolvedType] || '';
116
+ }
117
+ get toastClasses() {
118
+ const classes = ['toast', this.resolvedType, this.size];
119
+ classes.push(this.shouldShowIcon ? 'has-icon' : 'no-icon');
120
+ if (this.isClosing)
121
+ classes.push('is-closing');
122
+ return classes.join(' ');
123
+ }
124
+ clearAutoClose() {
125
+ if (!this.autoCloseTimer)
126
+ return;
127
+ clearTimeout(this.autoCloseTimer);
128
+ this.autoCloseTimer = undefined;
129
+ }
130
+ clearCloseTimer() {
131
+ if (!this.closeTimer)
132
+ return;
133
+ clearTimeout(this.closeTimer);
134
+ this.closeTimer = undefined;
135
+ }
136
+ dismiss(reason) {
137
+ var _a;
138
+ if (!this.isOpen || this.isClosing)
139
+ return;
140
+ this.clearAutoClose();
141
+ this.clearCloseTimer();
142
+ const toastEl = (_a = this.hostElement.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.toast');
143
+ if (toastEl) {
144
+ const height = Math.ceil(toastEl.getBoundingClientRect().height);
145
+ this.hostElement.style.setProperty('--toast-close-height', `${height}px`);
146
+ this.hostElement.style.setProperty('margin-bottom', '0');
147
+ }
148
+ this.isClosing = true;
149
+ this.closeTimer = setTimeout(() => {
150
+ this.isOpen = false;
151
+ this.isClosing = false;
152
+ this.tctClose.emit({ reason });
153
+ }, this.closeAnimationTimeMs);
154
+ }
155
+ startAutoClose() {
156
+ this.clearAutoClose();
157
+ if (!this.autoClose || !this.duration || this.duration <= 0 || !this.isOpen)
158
+ return;
159
+ this.autoCloseTimer = setTimeout(() => {
160
+ this.dismiss('timeout');
161
+ }, this.duration);
162
+ }
163
+ // #endregion
164
+ // #region Render Methods
165
+ renderIcon() {
166
+ if (this.hideIcon)
167
+ return null;
168
+ if (this.hasIconSlot)
169
+ return index.h("slot", { name: "icon" });
170
+ if (!this.resolvedIcon)
171
+ return null;
172
+ return index.h("q2-icon", { type: this.resolvedIcon });
173
+ }
174
+ render() {
175
+ if (!this.isOpen)
176
+ return null;
177
+ return (index.h("div", { class: this.toastClasses, role: this.ariaRole, "aria-live": this.ariaLive, "aria-atomic": "true", "aria-relevant": "all" }, this.srTypeLabel && index.h("span", { class: "sr" }, this.srTypeLabel), index.h("div", { class: "container" }, index.h("div", { class: "header" }, this.shouldShowIcon && index.h("div", { class: "icon" }, this.renderIcon()), index.h("div", { class: "title" }, index.h("span", { class: "title-text" }, index.h("slot", { name: "title" }, this.tctTitle))), this.closable && (index.h("button", { class: "close", type: "button", "aria-label": index$1.loc('tecton.element.toast.close'), onClick: this.onCloseClick }, index.h("q2-icon", { type: "close" })))), this.isLarge && (index.h("div", { class: "content" }, this.message, index.h("slot", null))), this.showFooter && (index.h("div", { class: "footer" }, index.h("div", { class: "time" }, index.h("slot", { name: "time" }, this.time)), index.h("div", { class: "actions" }, index.h("slot", { name: "actions" })))))));
178
+ }
179
+ get hostElement() { return index.getElement(this); }
180
+ static get watchers() { return {
181
+ "autoClose": ["onAutoCloseChange"],
182
+ "duration": ["onAutoCloseChange"],
183
+ "showPersistent": ["onShowPersistentChange"],
184
+ "size": ["onSizeChange"]
185
+ }; }
186
+ };
187
+ Q2Toast.style = q2ToastCss;
188
+
189
+ exports.q2_toast = Q2Toast;
190
+ //# sourceMappingURL=q2-toast.entry.cjs.js.map
191
+
192
+ //# sourceMappingURL=q2-toast.cjs.entry.js.map
@@ -0,0 +1 @@
1
+ {"file":"q2-toast.entry.cjs.js","mappings":"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","names":["hasSlotContent","loc","h"],"sources":["src/components/q2-toast/q2-toast.scss?tag=q2-toast&encapsulation=shadow","src/components/q2-toast/q2-toast.tsx"],"sourcesContent":["@import '../../styles/host.scss';\n@import '../../styles/functions';\n\n:host {\n display: block;\n}\n\n\n.toast {\n --comp-accent-width: 1px;\n --comp-icon-size: 32px;\n --comp-icon-bg: transparent;\n --comp-text-color: #{var-list(--tct-toast-text, --tct-gray-2, --app-gray-2, #333333)};\n --comp-subtle-color: #{var-list(--tct-toast-subtle, --tct-gray-5, --app-gray-5, #6b6b6b)};\n\n\n --comp-color-success: #{var-list(--tct-stoplight-success, --const-stoplight-success, #0e8a00)};\n --comp-color-info: #{var-list(--tct-stoplight-info, --const-stoplight-info, #0079c1)};\n --comp-color-warning: #{var-list(--tct-stoplight-warning, --const-stoplight-warning, #c35500)};\n --comp-color-alert: #{var-list(--tct-stoplight-alert, --const-stoplight-alert, #d20a0a)};\n --comp-color-default: white;\n\n &.success {\n border-color: var(--comp-color-success);\n background-color: var(--comp-color-success);\n --comp-icon-bg: #e7f5e3;\n }\n\n &.info {\n border-color: var(--comp-color-info);\n background-color: var(--comp-color-info);\n --comp-icon-bg: #e6f1fb;\n }\n\n &.warning {\n border-color: var(--comp-color-warning);\n background-color: var(--comp-color-warning);\n --comp-icon-bg: #fff0df;\n }\n\n &.alert {\n border-color: var(--comp-color-alert);\n background-color: var(--comp-color-alert);\n --comp-icon-bg: #fde6e6;\n }\n\n display: flex;\n flex-direction: column;\n gap: var-list(--tct-toast-gap, --app-scale-2x, 10px);\n padding-left: 3px;\n border-radius: 5px;\n border: 1px solid transparent;\n background: var-list(--tct-toast-background, --tct-gray-14, --app-gray-l3, #ffffff);\n color: var(--comp-text-color);\n box-shadow: var-list(--tct-toast-shadow, --app-shadow-2, unquote('0 12px 24px rgb(0 0 0 / 0.12)'));\n overflow:hidden;\n\n &.is-closing{\n animation-name: shrink;\n animation-duration: 500ms;\n animation-timing-function: linear;\n animation-fill-mode: forwards;\n transform-origin: top;\n overflow: hidden;\n }\n\n &.small {\n\n & .container{\n padding: var-list(--tct-toast-padding-small, --app-scale-2x, 10px);\n }\n }\n\n &.default {\n --comp-border-color: #{var-list(--tct-toast-border, --tct-gray-9, --app-gray-4, #d1d1d1)};\n --comp-icon-bg: #{var-list(--tct-toast-icon-bg, --tct-gray-12, --app-gray-l2, #f3f3f3)};\n border-color: var(--comp-border-color);\n }\n}\n\n.header {\n display: grid;\n grid-template-columns: var(--comp-icon-size) 1fr auto;\n gap: var-list(--tct-toast-gap, --app-scale-2x, 10px);\n align-items: center;\n}\n\n.toast.no-icon .header {\n grid-template-columns: 1fr auto;\n}\n\n.icon {\n width: var(--comp-icon-size);\n height: var(--comp-icon-size);\n border-radius: 50%;\n display: grid;\n place-items: center;\n background: var(--comp-icon-bg);\n}\n\n.icon q2-icon {\n --tct-icon-size: calc(var(--comp-icon-size) - 6px);\n --tct-icon-stroke-primary: var(--comp-border-color);\n --tct-icon-stroke-secondary: var(--comp-border-color);\n --tct-icon-fill: var(--comp-border-color);\n}\n\n.title {\n font-weight: 600;\n display: flex;\n align-items: center;\n}\n\n.title-text {\n display: -webkit-box;\n -webkit-line-clamp: 2;\n line-clamp: 2;\n -webkit-box-orient: vertical;\n overflow: hidden;\n}\n\n.content {\n color: var(--comp-subtle-color);\n display: -webkit-box;\n -webkit-line-clamp: 2;\n line-clamp: 2;\n -webkit-box-orient: vertical;\n overflow: hidden;\n}\n\n.footer {\n margin-top: var-list(--tct-toast-footer-gap, --app-scale-2x, 10px);\n display: flex;\n align-items: center;\n justify-content: space-between;\n gap: var-list(--tct-toast-footer-spacing, --app-scale-2x, 10px);\n color: var(--comp-subtle-color);\n font-size: 0.875rem;\n}\n\n.time {\n white-space: nowrap;\n}\n\n.actions {\n display: inline-flex;\n align-items: center;\n gap: var-list(--tct-toast-actions-gap, --app-scale-2x, 10px);\n}\n\n.close {\n border: none;\n background: transparent;\n padding: 2px;\n margin-left: var-list(--tct-toast-close-offset, --app-scale-1x, 5px);\n color: var(--comp-subtle-color);\n cursor: pointer;\n}\n\n.close q2-icon {\n --tct-icon-size: 18px;\n}\n\n.container {\n padding: var-list(--tct-toast-padding, --app-scale-3x, 15px);\n background-color: white;\n}\n\n@keyframes shrink {\n from {\n transform: scale(1);\n height: var(--toast-close-height, 0px);\n opacity: 1;\n }\n\n to {\n transform:scale(0);\n height: 0;\n opacity: 0;\n }\n}\n","import { Component, Prop, h, ComponentInterface, Event, EventEmitter, Element, State, Watch } from '@stencil/core';\nimport { hasSlotContent, loc } from 'src/utils';\n\n/**\n * @slot icon - Optional slot for a custom icon.\n * @slot title - Optional slot for the title content.\n * @slot - Optional slot for the message content.\n * @slot time - Optional slot for the time marker.\n * @slot actions - Optional slot for action links in the footer.\n */\n@Component({ tag: 'q2-toast', shadow: true, styleUrl: 'q2-toast.scss' })\nexport class Q2Toast implements ComponentInterface {\n // #region Own Properties\n\n private autoCloseTimer?: ReturnType<typeof setTimeout>;\n private closeAnimationTimeMs = 500;\n private closeTimer?: ReturnType<typeof setTimeout>;\n\n // #endregion\n // #region Host HTML Element\n\n @Element()\n hostElement: HTMLElement;\n\n // #endregion\n // #region State Properties\n\n @State()\n isClosing: boolean = false;\n\n @State()\n isOpen: boolean = true;\n\n // #endregion\n // #region Public Property API\n\n /** Enables automatic dismissal after a duration. */\n @Prop({ reflect: true })\n autoClose: boolean = false;\n\n /** Controls whether the close button is displayed. */\n @Prop({ reflect: true })\n closable: boolean = true;\n\n /** The duration in milliseconds before auto dismissal. */\n @Prop({ reflect: true })\n duration: number = 7000;\n\n /** Manually hide the icon where it would otherwise appear. */\n @Prop({ reflect: true })\n hideIcon: boolean = false;\n\n /** Optional icon type to display. */\n @Prop()\n icon: string;\n\n /** Optional message for the toast body. */\n @Prop()\n message: string;\n\n /**\n * Convenience prop for persistent toasts. When true, sets autoClose to false and closable to true.\n * Aligns with acceptance criteria for showPersistent behavior.\n */\n @Prop({ reflect: true })\n showPersistent: boolean = false;\n\n /** Controls the visual size of the toast. */\n @Prop({ reflect: true })\n size: 'large' | 'small' = 'large';\n\n /** Optional title for the toast. */\n @Prop()\n tctTitle: string;\n\n /** Optional time marker for the footer. */\n @Prop()\n time: string;\n\n /** The visual status of the toast. */\n @Prop({ reflect: true })\n type: 'warning' | 'info' | 'alert' | 'success' | 'default' | 'error' = 'default';\n\n // #endregion\n // #region Events\n\n /** Emitted when the toast is dismissed. */\n @Event()\n tctClose: EventEmitter<{ reason: 'close' | 'timeout' }>;\n\n // #endregion\n // #region Component Lifecycle Events\n\n disconnectedCallback(): void {\n this.clearAutoClose();\n this.clearCloseTimer();\n }\n\n componentDidLoad(): void {\n this.startAutoClose();\n }\n\n // #endregion\n // #region Watchers\n\n @Watch('autoClose')\n @Watch('duration')\n onAutoCloseChange() {\n this.startAutoClose();\n }\n\n @Watch('showPersistent')\n onShowPersistentChange() {\n if (this.showPersistent) {\n this.autoClose = false;\n this.closable = true;\n } else {\n this.autoClose = true;\n }\n }\n\n @Watch('size')\n onSizeChange() {\n if (this.size === 'large') {\n this.showPersistent = true;\n }\n }\n\n // #endregion\n // #region Local Methods\n\n get ariaLive(): 'assertive' | 'polite' {\n // Alert/error/warning types should be assertive, others polite\n return this.resolvedType === 'alert' || this.resolvedType === 'warning' ? 'assertive' : 'polite';\n }\n\n get ariaRole(): 'alert' | 'status' {\n // Alert/error/warning types use \"alert\" role, others use \"status\"\n return this.resolvedType === 'alert' || this.resolvedType === 'warning' ? 'alert' : 'status';\n }\n\n get hasIconSlot(): boolean {\n return hasSlotContent(this.hostElement, 'icon');\n }\n\n get isLarge(): boolean {\n return this.size !== 'small';\n }\n\n get resolvedIcon(): string {\n if (this.icon) return this.icon;\n\n const iconMap = {\n success: 'success-filled',\n warning: 'warning-filled',\n alert: 'error-filled',\n info: 'info-filled',\n };\n\n return iconMap[this.resolvedType];\n }\n\n get resolvedType(): 'warning' | 'info' | 'alert' | 'success' | 'default' {\n return this.type === 'error' ? 'alert' : this.type;\n }\n\n get shouldShowIcon(): boolean {\n return (this.hasIconSlot || !!this.resolvedIcon) && !this.hideIcon;\n }\n\n get showFooter(): boolean {\n const hasActions = hasSlotContent(this.hostElement, 'actions');\n const hasTime = hasSlotContent(this.hostElement, 'time') || !!this.time;\n return this.isLarge && (hasActions || hasTime);\n }\n\n get srTypeLabel(): string {\n // Screen reader label for toast type\n const labelMap = {\n success: loc('tecton.element.toast.type.success'),\n warning: loc('tecton.element.toast.type.warning'),\n alert: loc('tecton.element.toast.type.alert'),\n info: loc('tecton.element.toast.type.info'),\n default: loc('tecton.element.toast.type.default'),\n };\n return labelMap[this.resolvedType] || '';\n }\n\n get toastClasses(): string {\n const classes = ['toast', this.resolvedType, this.size];\n classes.push(this.shouldShowIcon ? 'has-icon' : 'no-icon');\n if (this.isClosing) classes.push('is-closing');\n return classes.join(' ');\n }\n\n clearAutoClose() {\n if (!this.autoCloseTimer) return;\n clearTimeout(this.autoCloseTimer);\n this.autoCloseTimer = undefined;\n }\n\n clearCloseTimer() {\n if (!this.closeTimer) return;\n clearTimeout(this.closeTimer);\n this.closeTimer = undefined;\n }\n\n dismiss(reason: 'close' | 'timeout') {\n if (!this.isOpen || this.isClosing) return;\n this.clearAutoClose();\n this.clearCloseTimer();\n const toastEl = this.hostElement.shadowRoot?.querySelector('.toast') as HTMLElement | null;\n if (toastEl) {\n const height = Math.ceil(toastEl.getBoundingClientRect().height);\n this.hostElement.style.setProperty('--toast-close-height', `${height}px`);\n this.hostElement.style.setProperty('margin-bottom', '0');\n }\n this.isClosing = true;\n this.closeTimer = setTimeout(() => {\n this.isOpen = false;\n this.isClosing = false;\n this.tctClose.emit({ reason });\n }, this.closeAnimationTimeMs);\n }\n\n onCloseClick = () => {\n this.dismiss('close');\n };\n\n startAutoClose() {\n this.clearAutoClose();\n if (!this.autoClose || !this.duration || this.duration <= 0 || !this.isOpen) return;\n this.autoCloseTimer = setTimeout(() => {\n this.dismiss('timeout');\n }, this.duration);\n }\n\n // #endregion\n // #region Render Methods\n\n renderIcon() {\n if (this.hideIcon) return null;\n if (this.hasIconSlot) return <slot name=\"icon\"></slot>;\n if (!this.resolvedIcon) return null;\n return <q2-icon type={this.resolvedIcon} />;\n }\n\n render() {\n if (!this.isOpen) return null;\n\n return (\n <div\n class={this.toastClasses}\n role={this.ariaRole}\n aria-live={this.ariaLive}\n aria-atomic=\"true\"\n aria-relevant=\"all\"\n >\n {this.srTypeLabel && <span class=\"sr\">{this.srTypeLabel}</span>}\n <div class=\"container\">\n <div class=\"header\">\n {this.shouldShowIcon && <div class=\"icon\">{this.renderIcon()}</div>}\n <div class=\"title\">\n <span class=\"title-text\">\n <slot name=\"title\">{this.tctTitle}</slot>\n </span>\n </div>\n {this.closable && (\n <button\n class=\"close\"\n type=\"button\"\n aria-label={loc('tecton.element.toast.close')}\n onClick={this.onCloseClick}\n >\n <q2-icon type=\"close\" />\n </button>\n )}\n </div>\n {this.isLarge && (\n <div class=\"content\">\n {this.message}\n <slot />\n </div>\n )}\n {this.showFooter && (\n <div class=\"footer\">\n <div class=\"time\">\n <slot name=\"time\">{this.time}</slot>\n </div>\n <div class=\"actions\">\n <slot name=\"actions\"></slot>\n </div>\n </div>\n )}\n </div>\n </div>\n );\n }\n\n // #endregion\n}\n"],"version":3}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"q2-toast.entry.cjs.js","sources":["src/components/q2-toast/q2-toast.scss?tag=q2-toast&encapsulation=shadow","src/components/q2-toast/q2-toast.tsx"],"sourcesContent":["@import '../../styles/host.scss';\n@import '../../styles/functions';\n\n:host {\n display: block;\n}\n\n\n.toast {\n --comp-accent-width: 1px;\n --comp-icon-size: 32px;\n --comp-icon-bg: transparent;\n --comp-text-color: #{var-list(--tct-toast-text, --tct-gray-2, --app-gray-2, #333333)};\n --comp-subtle-color: #{var-list(--tct-toast-subtle, --tct-gray-5, --app-gray-5, #6b6b6b)};\n\n\n --comp-color-success: #{var-list(--tct-stoplight-success, --const-stoplight-success, #0e8a00)};\n --comp-color-info: #{var-list(--tct-stoplight-info, --const-stoplight-info, #0079c1)};\n --comp-color-warning: #{var-list(--tct-stoplight-warning, --const-stoplight-warning, #c35500)};\n --comp-color-alert: #{var-list(--tct-stoplight-alert, --const-stoplight-alert, #d20a0a)};\n --comp-color-default: white;\n\n &.success {\n border-color: var(--comp-color-success);\n background-color: var(--comp-color-success);\n --comp-icon-bg: #e7f5e3;\n }\n\n &.info {\n border-color: var(--comp-color-info);\n background-color: var(--comp-color-info);\n --comp-icon-bg: #e6f1fb;\n }\n\n &.warning {\n border-color: var(--comp-color-warning);\n background-color: var(--comp-color-warning);\n --comp-icon-bg: #fff0df;\n }\n\n &.alert {\n border-color: var(--comp-color-alert);\n background-color: var(--comp-color-alert);\n --comp-icon-bg: #fde6e6;\n }\n\n display: flex;\n flex-direction: column;\n gap: var-list(--tct-toast-gap, --app-scale-2x, 10px);\n padding-left: 3px;\n border-radius: 5px;\n border: 1px solid transparent;\n background: var-list(--tct-toast-background, --tct-gray-14, --app-gray-l3, #ffffff);\n color: var(--comp-text-color);\n box-shadow: var-list(--tct-toast-shadow, --app-shadow-2, unquote('0 12px 24px rgb(0 0 0 / 0.12)'));\n overflow:hidden;\n\n &.is-closing{\n animation-name: shrink;\n animation-duration: 500ms;\n animation-timing-function: linear;\n animation-fill-mode: forwards;\n transform-origin: top;\n overflow: hidden;\n }\n\n &.small {\n\n & .container{\n padding: var-list(--tct-toast-padding-small, --app-scale-2x, 10px);\n }\n }\n\n &.default {\n --comp-border-color: #{var-list(--tct-toast-border, --tct-gray-9, --app-gray-4, #d1d1d1)};\n --comp-icon-bg: #{var-list(--tct-toast-icon-bg, --tct-gray-12, --app-gray-l2, #f3f3f3)};\n border-color: var(--comp-border-color);\n }\n}\n\n.header {\n display: grid;\n grid-template-columns: var(--comp-icon-size) 1fr auto;\n gap: var-list(--tct-toast-gap, --app-scale-2x, 10px);\n align-items: center;\n}\n\n.toast.no-icon .header {\n grid-template-columns: 1fr auto;\n}\n\n.icon {\n width: var(--comp-icon-size);\n height: var(--comp-icon-size);\n border-radius: 50%;\n display: grid;\n place-items: center;\n background: var(--comp-icon-bg);\n}\n\n.icon q2-icon {\n --tct-icon-size: calc(var(--comp-icon-size) - 6px);\n --tct-icon-stroke-primary: var(--comp-border-color);\n --tct-icon-stroke-secondary: var(--comp-border-color);\n --tct-icon-fill: var(--comp-border-color);\n}\n\n.title {\n font-weight: 600;\n display: flex;\n align-items: center;\n}\n\n.title-text {\n display: -webkit-box;\n -webkit-line-clamp: 2;\n line-clamp: 2;\n -webkit-box-orient: vertical;\n overflow: hidden;\n}\n\n.content {\n color: var(--comp-subtle-color);\n display: -webkit-box;\n -webkit-line-clamp: 2;\n line-clamp: 2;\n -webkit-box-orient: vertical;\n overflow: hidden;\n}\n\n.footer {\n margin-top: var-list(--tct-toast-footer-gap, --app-scale-2x, 10px);\n display: flex;\n align-items: center;\n justify-content: space-between;\n gap: var-list(--tct-toast-footer-spacing, --app-scale-2x, 10px);\n color: var(--comp-subtle-color);\n font-size: 0.875rem;\n}\n\n.time {\n white-space: nowrap;\n}\n\n.actions {\n display: inline-flex;\n align-items: center;\n gap: var-list(--tct-toast-actions-gap, --app-scale-2x, 10px);\n}\n\n.close {\n border: none;\n background: transparent;\n padding: 2px;\n margin-left: var-list(--tct-toast-close-offset, --app-scale-1x, 5px);\n color: var(--comp-subtle-color);\n cursor: pointer;\n}\n\n.close q2-icon {\n --tct-icon-size: 18px;\n}\n\n.container {\n padding: var-list(--tct-toast-padding, --app-scale-3x, 15px);\n background-color: white;\n}\n\n@keyframes shrink {\n from {\n transform: scale(1);\n height: var(--toast-close-height, 0px);\n opacity: 1;\n }\n\n to {\n transform:scale(0);\n height: 0;\n opacity: 0;\n }\n}\n","import { Component, Prop, h, ComponentInterface, Event, EventEmitter, Element, State, Watch } from '@stencil/core';\nimport { hasSlotContent, loc } from 'src/utils';\n\n/**\n * @slot icon - Optional slot for a custom icon.\n * @slot title - Optional slot for the title content.\n * @slot - Optional slot for the message content.\n * @slot time - Optional slot for the time marker.\n * @slot actions - Optional slot for action links in the footer.\n */\n@Component({ tag: 'q2-toast', shadow: true, styleUrl: 'q2-toast.scss' })\nexport class Q2Toast implements ComponentInterface {\n // #region Own Properties\n\n private autoCloseTimer?: ReturnType<typeof setTimeout>;\n private closeAnimationTimeMs = 500;\n private closeTimer?: ReturnType<typeof setTimeout>;\n\n // #endregion\n // #region Host HTML Element\n\n @Element()\n hostElement: HTMLElement;\n\n // #endregion\n // #region State Properties\n\n @State()\n isClosing: boolean = false;\n\n @State()\n isOpen: boolean = true;\n\n // #endregion\n // #region Public Property API\n\n /** Enables automatic dismissal after a duration. */\n @Prop({ reflect: true })\n autoClose: boolean = false;\n\n /** Controls whether the close button is displayed. */\n @Prop({ reflect: true })\n closable: boolean = true;\n\n /** The duration in milliseconds before auto dismissal. */\n @Prop({ reflect: true })\n duration: number = 7000;\n\n /** Manually hide the icon where it would otherwise appear. */\n @Prop({ reflect: true })\n hideIcon: boolean = false;\n\n /** Optional icon type to display. */\n @Prop()\n icon: string;\n\n /** Optional message for the toast body. */\n @Prop()\n message: string;\n\n /**\n * Convenience prop for persistent toasts. When true, sets autoClose to false and closable to true.\n * Aligns with acceptance criteria for showPersistent behavior.\n */\n @Prop({ reflect: true })\n showPersistent: boolean = false;\n\n /** Controls the visual size of the toast. */\n @Prop({ reflect: true })\n size: 'large' | 'small' = 'large';\n\n /** Optional title for the toast. */\n @Prop()\n tctTitle: string;\n\n /** Optional time marker for the footer. */\n @Prop()\n time: string;\n\n /** The visual status of the toast. */\n @Prop({ reflect: true })\n type: 'warning' | 'info' | 'alert' | 'success' | 'default' | 'error' = 'default';\n\n // #endregion\n // #region Events\n\n /** Emitted when the toast is dismissed. */\n @Event()\n tctClose: EventEmitter<{ reason: 'close' | 'timeout' }>;\n\n // #endregion\n // #region Component Lifecycle Events\n\n disconnectedCallback(): void {\n this.clearAutoClose();\n this.clearCloseTimer();\n }\n\n componentDidLoad(): void {\n this.startAutoClose();\n }\n\n // #endregion\n // #region Watchers\n\n @Watch('autoClose')\n @Watch('duration')\n onAutoCloseChange() {\n this.startAutoClose();\n }\n\n @Watch('showPersistent')\n onShowPersistentChange() {\n if (this.showPersistent) {\n this.autoClose = false;\n this.closable = true;\n } else {\n this.autoClose = true;\n }\n }\n\n @Watch('size')\n onSizeChange() {\n if (this.size === 'large') {\n this.showPersistent = true;\n }\n }\n\n // #endregion\n // #region Local Methods\n\n get ariaLive(): 'assertive' | 'polite' {\n // Alert/error/warning types should be assertive, others polite\n return this.resolvedType === 'alert' || this.resolvedType === 'warning' ? 'assertive' : 'polite';\n }\n\n get ariaRole(): 'alert' | 'status' {\n // Alert/error/warning types use \"alert\" role, others use \"status\"\n return this.resolvedType === 'alert' || this.resolvedType === 'warning' ? 'alert' : 'status';\n }\n\n get hasIconSlot(): boolean {\n return hasSlotContent(this.hostElement, 'icon');\n }\n\n get isLarge(): boolean {\n return this.size !== 'small';\n }\n\n get resolvedIcon(): string {\n if (this.icon) return this.icon;\n\n const iconMap = {\n success: 'success-filled',\n warning: 'warning-filled',\n alert: 'error-filled',\n info: 'info-filled',\n };\n\n return iconMap[this.resolvedType];\n }\n\n get resolvedType(): 'warning' | 'info' | 'alert' | 'success' | 'default' {\n return this.type === 'error' ? 'alert' : this.type;\n }\n\n get shouldShowIcon(): boolean {\n return (this.hasIconSlot || !!this.resolvedIcon) && !this.hideIcon;\n }\n\n get showFooter(): boolean {\n const hasActions = hasSlotContent(this.hostElement, 'actions');\n const hasTime = hasSlotContent(this.hostElement, 'time') || !!this.time;\n return this.isLarge && (hasActions || hasTime);\n }\n\n get srTypeLabel(): string {\n // Screen reader label for toast type\n const labelMap = {\n success: loc('tecton.element.toast.type.success'),\n warning: loc('tecton.element.toast.type.warning'),\n alert: loc('tecton.element.toast.type.alert'),\n info: loc('tecton.element.toast.type.info'),\n default: loc('tecton.element.toast.type.default'),\n };\n return labelMap[this.resolvedType] || '';\n }\n\n get toastClasses(): string {\n const classes = ['toast', this.resolvedType, this.size];\n classes.push(this.shouldShowIcon ? 'has-icon' : 'no-icon');\n if (this.isClosing) classes.push('is-closing');\n return classes.join(' ');\n }\n\n clearAutoClose() {\n if (!this.autoCloseTimer) return;\n clearTimeout(this.autoCloseTimer);\n this.autoCloseTimer = undefined;\n }\n\n clearCloseTimer() {\n if (!this.closeTimer) return;\n clearTimeout(this.closeTimer);\n this.closeTimer = undefined;\n }\n\n dismiss(reason: 'close' | 'timeout') {\n if (!this.isOpen || this.isClosing) return;\n this.clearAutoClose();\n this.clearCloseTimer();\n const toastEl = this.hostElement.shadowRoot?.querySelector('.toast') as HTMLElement | null;\n if (toastEl) {\n const height = Math.ceil(toastEl.getBoundingClientRect().height);\n this.hostElement.style.setProperty('--toast-close-height', `${height}px`);\n this.hostElement.style.setProperty('margin-bottom', '0');\n }\n this.isClosing = true;\n this.closeTimer = setTimeout(() => {\n this.isOpen = false;\n this.isClosing = false;\n this.tctClose.emit({ reason });\n }, this.closeAnimationTimeMs);\n }\n\n onCloseClick = () => {\n this.dismiss('close');\n };\n\n startAutoClose() {\n this.clearAutoClose();\n if (!this.autoClose || !this.duration || this.duration <= 0 || !this.isOpen) return;\n this.autoCloseTimer = setTimeout(() => {\n this.dismiss('timeout');\n }, this.duration);\n }\n\n // #endregion\n // #region Render Methods\n\n renderIcon() {\n if (this.hideIcon) return null;\n if (this.hasIconSlot) return <slot name=\"icon\"></slot>;\n if (!this.resolvedIcon) return null;\n return <q2-icon type={this.resolvedIcon} />;\n }\n\n render() {\n if (!this.isOpen) return null;\n\n return (\n <div\n class={this.toastClasses}\n role={this.ariaRole}\n aria-live={this.ariaLive}\n aria-atomic=\"true\"\n aria-relevant=\"all\"\n >\n {this.srTypeLabel && <span class=\"sr\">{this.srTypeLabel}</span>}\n <div class=\"container\">\n <div class=\"header\">\n {this.shouldShowIcon && <div class=\"icon\">{this.renderIcon()}</div>}\n <div class=\"title\">\n <span class=\"title-text\">\n <slot name=\"title\">{this.tctTitle}</slot>\n </span>\n </div>\n {this.closable && (\n <button\n class=\"close\"\n type=\"button\"\n aria-label={loc('tecton.element.toast.close')}\n onClick={this.onCloseClick}\n >\n <q2-icon type=\"close\" />\n </button>\n )}\n </div>\n {this.isLarge && (\n <div class=\"content\">\n {this.message}\n <slot />\n </div>\n )}\n {this.showFooter && (\n <div class=\"footer\">\n <div class=\"time\">\n <slot name=\"time\">{this.time}</slot>\n </div>\n <div class=\"actions\">\n <slot name=\"actions\"></slot>\n </div>\n </div>\n )}\n </div>\n </div>\n );\n }\n\n // #endregion\n}\n"],"names":["hasSlotContent","loc","h"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- /*! @license DOMPurify 3.3.0 | (c) Cure53 and other contributors | Released under the Apache license 2.0 and Mozilla Public License 2.0 | github.com/cure53/DOMPurify/blob/3.3.0/LICENSE */
3
+ /*! @license DOMPurify 3.3.2 | (c) Cure53 and other contributors | Released under the Apache license 2.0 and Mozilla Public License 2.0 | github.com/cure53/DOMPurify/blob/3.3.2/LICENSE */
4
4
 
5
5
  const {
6
6
  entries,
@@ -298,7 +298,7 @@ const _createHooksMap = function _createHooksMap() {
298
298
  function createDOMPurify() {
299
299
  let window = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : getGlobal();
300
300
  const DOMPurify = root => createDOMPurify(root);
301
- DOMPurify.version = '3.3.0';
301
+ DOMPurify.version = '3.3.2';
302
302
  DOMPurify.removed = [];
303
303
  if (!window || !window.document || window.document.nodeType !== NODE_TYPE.document || !window.Element) {
304
304
  // Not running in a browser, provide a factory function
@@ -593,7 +593,7 @@ function createDOMPurify() {
593
593
  /* Parse profile info */
594
594
  if (USE_PROFILES) {
595
595
  ALLOWED_TAGS = addToSet({}, text);
596
- ALLOWED_ATTR = [];
596
+ ALLOWED_ATTR = create(null);
597
597
  if (USE_PROFILES.html === true) {
598
598
  addToSet(ALLOWED_TAGS, html$1);
599
599
  addToSet(ALLOWED_ATTR, html);
@@ -614,6 +614,13 @@ function createDOMPurify() {
614
614
  addToSet(ALLOWED_ATTR, xml);
615
615
  }
616
616
  }
617
+ /* Prevent function-based ADD_ATTR / ADD_TAGS from leaking across calls */
618
+ if (!objectHasOwnProperty(cfg, 'ADD_TAGS')) {
619
+ EXTRA_ELEMENT_HANDLING.tagCheck = null;
620
+ }
621
+ if (!objectHasOwnProperty(cfg, 'ADD_ATTR')) {
622
+ EXTRA_ELEMENT_HANDLING.attributeCheck = null;
623
+ }
617
624
  /* Merge configuration parameters */
618
625
  if (cfg.ADD_TAGS) {
619
626
  if (typeof cfg.ADD_TAGS === 'function') {
@@ -644,6 +651,12 @@ function createDOMPurify() {
644
651
  }
645
652
  addToSet(FORBID_CONTENTS, cfg.FORBID_CONTENTS, transformCaseFunc);
646
653
  }
654
+ if (cfg.ADD_FORBID_CONTENTS) {
655
+ if (FORBID_CONTENTS === DEFAULT_FORBID_CONTENTS) {
656
+ FORBID_CONTENTS = clone(FORBID_CONTENTS);
657
+ }
658
+ addToSet(FORBID_CONTENTS, cfg.ADD_FORBID_CONTENTS, transformCaseFunc);
659
+ }
647
660
  /* Add #text in case KEEP_CONTENT is set to true */
648
661
  if (KEEP_CONTENT) {
649
662
  ALLOWED_TAGS['#text'] = true;
@@ -1005,6 +1018,10 @@ function createDOMPurify() {
1005
1018
  */
1006
1019
  // eslint-disable-next-line complexity
1007
1020
  const _isValidAttribute = function _isValidAttribute(lcTag, lcName, value) {
1021
+ /* FORBID_ATTR must always win, even if ADD_ATTR predicate would allow it */
1022
+ if (FORBID_ATTR[lcName]) {
1023
+ return false;
1024
+ }
1008
1025
  /* Make sure attribute cannot clobber */
1009
1026
  if (SANITIZE_DOM && (lcName === 'id' || lcName === 'name') && (value in document || value in formElement)) {
1010
1027
  return false;
@@ -1097,7 +1114,7 @@ function createDOMPurify() {
1097
1114
  value = SANITIZE_NAMED_PROPS_PREFIX + value;
1098
1115
  }
1099
1116
  /* Work around a security issue with comments inside attributes */
1100
- if (SAFE_FOR_XML && regExpTest(/((--!?|])>)|<\/(style|title|textarea)/i, value)) {
1117
+ if (SAFE_FOR_XML && regExpTest(/((--!?|])>)|<\/(style|script|title|xmp|textarea|noscript|iframe|noembed|noframes)/i, value)) {
1101
1118
  _removeAttribute(name, currentNode);
1102
1119
  continue;
1103
1120
  }
@@ -1377,8 +1394,15 @@ function sanitizeHTMLString(htmlString) {
1377
1394
  },
1378
1395
  });
1379
1396
  }
1397
+ function sanitizeActionSheetSlotHtml(htmlString) {
1398
+ return purify(window).sanitize(htmlString, {
1399
+ ALLOWED_TAGS: ['q2-detail', 'span', 'q2-item', 'q2-list', 'q2-item'],
1400
+ ALLOWED_ATTR: ['description', 'alignment', 'slot', 'size', 'stacked', 'style'],
1401
+ });
1402
+ }
1380
1403
 
1404
+ exports.sanitizeActionSheetSlotHtml = sanitizeActionSheetSlotHtml;
1381
1405
  exports.sanitizeHTMLString = sanitizeHTMLString;
1382
- //# sourceMappingURL=sanitize-html-string-DPqrzfM9.js.map
1406
+ //# sourceMappingURL=sanitize-html-string-C2iwHNz5.js.map
1383
1407
 
1384
- //# sourceMappingURL=sanitize-html-string-DPqrzfM9.js.map
1408
+ //# sourceMappingURL=sanitize-html-string-C2iwHNz5.js.map