@coveo/atomic 3.37.1 → 3.37.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (285) hide show
  1. package/dist/atomic/_atomic.esm.js +1 -1
  2. package/dist/atomic/atomic.esm.js.map +1 -1
  3. package/dist/atomic/components/_index.d.ts +0 -2
  4. package/dist/atomic/components/_index.js +0 -1
  5. package/dist/atomic/components/atomic-automatic-facet-generator2.js +1 -1
  6. package/dist/atomic/components/atomic-automatic-facet-generator2.js.map +1 -1
  7. package/dist/atomic/components/atomic-category-facet.js +2 -2
  8. package/dist/atomic/components/atomic-category-facet.js.map +1 -1
  9. package/dist/atomic/components/atomic-color-facet.js +1 -1
  10. package/dist/atomic/components/atomic-color-facet.js.map +1 -1
  11. package/dist/atomic/components/atomic-insight-facet.js +2 -2
  12. package/dist/atomic/components/atomic-insight-facet.js.map +1 -1
  13. package/dist/atomic/components/atomic-insight-numeric-facet.js +2 -2
  14. package/dist/atomic/components/atomic-insight-numeric-facet.js.map +1 -1
  15. package/dist/atomic/components/atomic-insight-timeframe-facet.js +1 -1
  16. package/dist/atomic/components/atomic-insight-timeframe-facet.js.map +1 -1
  17. package/dist/atomic/components/atomic-ipx-recs-list.js +1 -2
  18. package/dist/atomic/components/atomic-ipx-recs-list.js.map +1 -1
  19. package/dist/atomic/components/atomic-numeric-facet.js +2 -2
  20. package/dist/atomic/components/atomic-numeric-facet.js.map +1 -1
  21. package/dist/atomic/components/atomic-quickview-modal2.js +1 -1
  22. package/dist/atomic/components/atomic-quickview.js +1 -1
  23. package/dist/atomic/components/atomic-rating-facet.js +1 -1
  24. package/dist/atomic/components/atomic-rating-facet.js.map +1 -1
  25. package/dist/atomic/components/atomic-rating-range-facet.js +1 -1
  26. package/dist/atomic/components/atomic-rating-range-facet.js.map +1 -1
  27. package/dist/atomic/components/atomic-recs-interface.js +1 -1
  28. package/dist/atomic/components/atomic-recs-list.js +1 -2
  29. package/dist/atomic/components/atomic-recs-list.js.map +1 -1
  30. package/dist/atomic/components/atomic-result-fields-list.js +1 -1
  31. package/dist/atomic/components/atomic-result-link.js +1 -1
  32. package/dist/atomic/components/atomic-smart-snippet-feedback-modal2.js +2 -2
  33. package/dist/atomic/components/atomic-tab-manager.js +1 -1
  34. package/dist/atomic/components/atomic-timeframe-facet.js +1 -1
  35. package/dist/atomic/components/atomic-timeframe-facet.js.map +1 -1
  36. package/dist/atomic/components/components/commerce/atomic-commerce-facets/atomic-commerce-facets.js +12 -12
  37. package/dist/atomic/components/components/commerce/atomic-commerce-interface/atomic-commerce-interface.js +1 -1
  38. package/dist/atomic/components/components/commerce/atomic-commerce-product-list/atomic-commerce-product-list.js +1 -1
  39. package/dist/atomic/components/components/commerce/atomic-commerce-recommendation-interface/atomic-commerce-recommendation-interface.js +1 -1
  40. package/dist/atomic/components/components/common/tabs/tab-wrapper.js +9 -0
  41. package/dist/atomic/components/components/insight/atomic-insight-interface/atomic-insight-interface.js +1 -1
  42. package/dist/atomic/components/components/search/atomic-external/atomic-external.js +1 -1
  43. package/dist/atomic/components/components/search/atomic-result-list/atomic-result-list.js +434 -0
  44. package/dist/atomic/components/components/search/atomic-result-template/atomic-result-template.js +1 -0
  45. package/dist/atomic/components/components/search/atomic-search-interface/atomic-search-interface.js +1 -1
  46. package/dist/atomic/components/components/search/index.js +1 -0
  47. package/dist/atomic/components/components/search/lazy-index.js +1 -0
  48. package/dist/atomic/components/decorators/bindings.js +1 -1
  49. package/dist/atomic/components/global/environment.js +1 -1
  50. package/dist/atomic/components/index.js.map +1 -1
  51. package/dist/atomic/components/stencil-carousel.js +16 -1
  52. package/dist/atomic/components/stencil-carousel.js.map +1 -1
  53. package/dist/atomic/components/{facet-placeholder.js → stencil-facet-placeholder.js} +1 -1
  54. package/dist/atomic/components/stencil-facet-placeholder.js.map +1 -0
  55. package/dist/atomic/components/stencil-result-template-common.js +2 -1
  56. package/dist/atomic/components/stencil-result-template-common.js.map +1 -1
  57. package/dist/atomic/components/timeframe-facet-common.js +1 -1
  58. package/dist/atomic/components/timeframe-facet-common.js.map +1 -1
  59. package/dist/atomic/components/utils/tab-utils.js +17 -0
  60. package/dist/atomic/{p-f8bbecdd.entry.js → p-0d3407e9.entry.js} +2 -2
  61. package/dist/atomic/{p-b986c752.entry.js → p-1fdd2a5a.entry.js} +2 -2
  62. package/dist/atomic/p-1fdd2a5a.entry.js.map +1 -0
  63. package/dist/atomic/p-2a979ae5.entry.js +2 -0
  64. package/dist/atomic/{p-564e93ba.entry.js.map → p-2a979ae5.entry.js.map} +1 -1
  65. package/dist/atomic/p-2d624182.entry.js +2 -0
  66. package/dist/atomic/{p-6e47c9a8.entry.js.map → p-2d624182.entry.js.map} +1 -1
  67. package/dist/atomic/{p-561a531c.entry.js → p-3302a10f.entry.js} +2 -2
  68. package/dist/atomic/{p-04e08959.entry.js → p-3a426d47.entry.js} +2 -2
  69. package/dist/atomic/p-3a426d47.entry.js.map +1 -0
  70. package/dist/atomic/{p-7dfced62.entry.js → p-4362ec1f.entry.js} +2 -2
  71. package/dist/atomic/p-4362ec1f.entry.js.map +1 -0
  72. package/dist/atomic/{p-8deeef5f.entry.js → p-4b46b80f.entry.js} +2 -2
  73. package/dist/atomic/{p-408ffc88.entry.js → p-50353e9d.entry.js} +2 -2
  74. package/dist/atomic/p-50353e9d.entry.js.map +1 -0
  75. package/dist/atomic/{p-b528927d.entry.js → p-52721bf1.entry.js} +2 -2
  76. package/dist/atomic/p-52721bf1.entry.js.map +1 -0
  77. package/dist/atomic/{p-8deb6142.entry.js → p-594e3243.entry.js} +2 -2
  78. package/dist/atomic/p-5bdd4fca.entry.js +2 -0
  79. package/dist/atomic/{p-e351c8ed.entry.js.map → p-5bdd4fca.entry.js.map} +1 -1
  80. package/dist/atomic/{p-4239e0ec.entry.js → p-7632eb9d.entry.js} +2 -2
  81. package/dist/atomic/p-7632eb9d.entry.js.map +1 -0
  82. package/dist/atomic/{p-99203e57.entry.js → p-9a66fe53.entry.js} +2 -2
  83. package/dist/atomic/p-9a66fe53.entry.js.map +1 -0
  84. package/dist/atomic/{p-0d955dec.entry.js → p-9f3b431f.entry.js} +2 -2
  85. package/dist/atomic/{p-29bbd3d3.js → p-a598dc5b.js} +1 -1
  86. package/dist/atomic/p-a598dc5b.js.map +1 -0
  87. package/dist/atomic/p-acf4faf8.js +2 -0
  88. package/dist/atomic/p-acf4faf8.js.map +1 -0
  89. package/dist/atomic/p-c6763212.entry.js +2 -0
  90. package/dist/atomic/{p-1f4853b1.entry.js.map → p-c6763212.entry.js.map} +1 -1
  91. package/dist/atomic/p-c827c5e3.entry.js +2 -0
  92. package/dist/atomic/{p-7ccbf77d.entry.js.map → p-c827c5e3.entry.js.map} +1 -1
  93. package/dist/atomic/p-caf548dd.js +2 -0
  94. package/dist/atomic/p-caf548dd.js.map +1 -0
  95. package/dist/atomic/{p-3e077971.js → p-da20ee92.js} +2 -2
  96. package/dist/atomic/p-da20ee92.js.map +1 -0
  97. package/dist/atomic/{p-7b718df8.entry.js → p-e0e50820.entry.js} +2 -2
  98. package/dist/atomic/{p-27765040.entry.js → p-ecb92feb.entry.js} +2 -2
  99. package/dist/atomic/{p-27765040.entry.js.map → p-ecb92feb.entry.js.map} +1 -1
  100. package/dist/atomic/{p-3119dcb8.entry.js → p-f2893341.entry.js} +2 -2
  101. package/dist/atomic/{p-906fd94d.entry.js → p-f29cee57.entry.js} +2 -2
  102. package/dist/atomic/p-f29cee57.entry.js.map +1 -0
  103. package/dist/atomic/{p-2cd906b9.entry.js → p-f350c5c4.entry.js} +2 -2
  104. package/dist/atomic/p-f350c5c4.entry.js.map +1 -0
  105. package/dist/atomic/p-fef9f7d9.entry.js +2 -0
  106. package/dist/atomic/{p-7b11e602.entry.js.map → p-fef9f7d9.entry.js.map} +1 -1
  107. package/dist/cjs/_loader.cjs.js +1 -1
  108. package/dist/cjs/atomic-automatic-facet_2.cjs.entry.js +4 -4
  109. package/dist/cjs/atomic-automatic-facet_2.cjs.entry.js.map +1 -1
  110. package/dist/cjs/atomic-category-facet.cjs.entry.js +4 -4
  111. package/dist/cjs/atomic-category-facet.cjs.entry.js.map +1 -1
  112. package/dist/cjs/atomic-color-facet.cjs.entry.js +4 -4
  113. package/dist/cjs/atomic-color-facet.cjs.entry.js.map +1 -1
  114. package/dist/cjs/atomic-field-condition.cjs.entry.js +1 -2
  115. package/dist/cjs/atomic-field-condition.cjs.entry.js.map +1 -1
  116. package/dist/cjs/atomic-insight-facet.cjs.entry.js +3 -3
  117. package/dist/cjs/atomic-insight-facet.cjs.entry.js.map +1 -1
  118. package/dist/cjs/atomic-insight-numeric-facet.cjs.entry.js +3 -3
  119. package/dist/cjs/atomic-insight-numeric-facet.cjs.entry.js.map +1 -1
  120. package/dist/cjs/atomic-insight-result-children-template.cjs.entry.js +1 -2
  121. package/dist/cjs/atomic-insight-result-children-template.cjs.entry.js.map +1 -1
  122. package/dist/cjs/atomic-insight-result-template.cjs.entry.js +1 -2
  123. package/dist/cjs/atomic-insight-result-template.cjs.entry.js.map +1 -1
  124. package/dist/cjs/atomic-insight-timeframe-facet.cjs.entry.js +3 -3
  125. package/dist/cjs/atomic-insight-timeframe-facet.cjs.entry.js.map +1 -1
  126. package/dist/cjs/atomic-ipx-recs-list.cjs.entry.js +4 -5
  127. package/dist/cjs/atomic-ipx-recs-list.cjs.entry.js.map +1 -1
  128. package/dist/cjs/atomic-numeric-facet.cjs.entry.js +3 -3
  129. package/dist/cjs/atomic-numeric-facet.cjs.entry.js.map +1 -1
  130. package/dist/cjs/atomic-quickview-modal.cjs.entry.js +1 -1
  131. package/dist/cjs/atomic-quickview.cjs.entry.js +1 -1
  132. package/dist/cjs/atomic-rating-facet.cjs.entry.js +4 -4
  133. package/dist/cjs/atomic-rating-facet.cjs.entry.js.map +1 -1
  134. package/dist/cjs/atomic-rating-range-facet.cjs.entry.js +4 -4
  135. package/dist/cjs/atomic-rating-range-facet.cjs.entry.js.map +1 -1
  136. package/dist/cjs/atomic-recs-interface.cjs.entry.js +1 -1
  137. package/dist/cjs/atomic-recs-list.cjs.entry.js +4 -5
  138. package/dist/cjs/atomic-recs-list.cjs.entry.js.map +1 -1
  139. package/dist/cjs/atomic-recs-result-template.cjs.entry.js +1 -2
  140. package/dist/cjs/atomic-recs-result-template.cjs.entry.js.map +1 -1
  141. package/dist/cjs/atomic-result-fields-list.cjs.entry.js +1 -1
  142. package/dist/cjs/atomic-result-link.cjs.entry.js +1 -1
  143. package/dist/cjs/atomic-smart-snippet-feedback-modal.cjs.entry.js +2 -2
  144. package/dist/cjs/atomic-tab-manager.cjs.entry.js +1 -1
  145. package/dist/cjs/atomic-timeframe-facet.cjs.entry.js +3 -3
  146. package/dist/cjs/atomic-timeframe-facet.cjs.entry.js.map +1 -1
  147. package/dist/cjs/atomic.cjs.js +1 -1
  148. package/dist/cjs/index-1df73594.js +0 -4
  149. package/dist/cjs/{stencil-carousel-2beaa7d2.js → stencil-carousel-72557b3b.js} +17 -1
  150. package/dist/cjs/stencil-carousel-72557b3b.js.map +1 -0
  151. package/dist/cjs/{facet-placeholder-e86f105c.js → stencil-facet-placeholder-d3c0a675.js} +1 -1
  152. package/dist/cjs/stencil-facet-placeholder-d3c0a675.js.map +1 -0
  153. package/dist/cjs/{stencil-result-template-common-268ba233.js → stencil-result-template-common-46913299.js} +4 -3
  154. package/dist/cjs/stencil-result-template-common-46913299.js.map +1 -0
  155. package/dist/cjs/{timeframe-facet-common-16ba58fd.js → timeframe-facet-common-4fa4cc95.js} +5 -5
  156. package/dist/cjs/timeframe-facet-common-4fa4cc95.js.map +1 -0
  157. package/dist/cjs/version.cjs.js +2 -2
  158. package/dist/esm/_loader.js +1 -1
  159. package/dist/esm/atomic-automatic-facet_2.entry.js +1 -1
  160. package/dist/esm/atomic-automatic-facet_2.entry.js.map +1 -1
  161. package/dist/esm/atomic-category-facet.entry.js +2 -2
  162. package/dist/esm/atomic-category-facet.entry.js.map +1 -1
  163. package/dist/esm/atomic-color-facet.entry.js +1 -1
  164. package/dist/esm/atomic-color-facet.entry.js.map +1 -1
  165. package/dist/esm/atomic-field-condition.entry.js +1 -2
  166. package/dist/esm/atomic-field-condition.entry.js.map +1 -1
  167. package/dist/esm/atomic-insight-facet.entry.js +2 -2
  168. package/dist/esm/atomic-insight-facet.entry.js.map +1 -1
  169. package/dist/esm/atomic-insight-numeric-facet.entry.js +2 -2
  170. package/dist/esm/atomic-insight-numeric-facet.entry.js.map +1 -1
  171. package/dist/esm/atomic-insight-result-children-template.entry.js +1 -2
  172. package/dist/esm/atomic-insight-result-children-template.entry.js.map +1 -1
  173. package/dist/esm/atomic-insight-result-template.entry.js +1 -2
  174. package/dist/esm/atomic-insight-result-template.entry.js.map +1 -1
  175. package/dist/esm/atomic-insight-timeframe-facet.entry.js +2 -2
  176. package/dist/esm/atomic-insight-timeframe-facet.entry.js.map +1 -1
  177. package/dist/esm/atomic-ipx-recs-list.entry.js +3 -4
  178. package/dist/esm/atomic-ipx-recs-list.entry.js.map +1 -1
  179. package/dist/esm/atomic-numeric-facet.entry.js +2 -2
  180. package/dist/esm/atomic-numeric-facet.entry.js.map +1 -1
  181. package/dist/esm/atomic-quickview-modal.entry.js +1 -1
  182. package/dist/esm/atomic-quickview.entry.js +1 -1
  183. package/dist/esm/atomic-rating-facet.entry.js +1 -1
  184. package/dist/esm/atomic-rating-facet.entry.js.map +1 -1
  185. package/dist/esm/atomic-rating-range-facet.entry.js +1 -1
  186. package/dist/esm/atomic-rating-range-facet.entry.js.map +1 -1
  187. package/dist/esm/atomic-recs-interface.entry.js +1 -1
  188. package/dist/esm/atomic-recs-list.entry.js +3 -4
  189. package/dist/esm/atomic-recs-list.entry.js.map +1 -1
  190. package/dist/esm/atomic-recs-result-template.entry.js +1 -2
  191. package/dist/esm/atomic-recs-result-template.entry.js.map +1 -1
  192. package/dist/esm/atomic-result-fields-list.entry.js +1 -1
  193. package/dist/esm/atomic-result-link.entry.js +1 -1
  194. package/dist/esm/atomic-smart-snippet-feedback-modal.entry.js +2 -2
  195. package/dist/esm/atomic-tab-manager.entry.js +1 -1
  196. package/dist/esm/atomic-timeframe-facet.entry.js +2 -2
  197. package/dist/esm/atomic-timeframe-facet.entry.js.map +1 -1
  198. package/dist/esm/atomic.js +1 -1
  199. package/dist/esm/index-a59c51bd.js +0 -4
  200. package/dist/esm/{stencil-carousel-be6f0bc1.js → stencil-carousel-a9540851.js} +17 -2
  201. package/dist/esm/stencil-carousel-a9540851.js.map +1 -0
  202. package/dist/esm/{facet-placeholder-7e0836c1.js → stencil-facet-placeholder-8201b5c9.js} +1 -1
  203. package/dist/esm/stencil-facet-placeholder-8201b5c9.js.map +1 -0
  204. package/dist/esm/{stencil-result-template-common-cddca36d.js → stencil-result-template-common-8be1ff35.js} +3 -2
  205. package/dist/esm/stencil-result-template-common-8be1ff35.js.map +1 -0
  206. package/dist/esm/{timeframe-facet-common-906a271d.js → timeframe-facet-common-4c8d95f2.js} +2 -2
  207. package/dist/esm/timeframe-facet-common-4c8d95f2.js.map +1 -0
  208. package/dist/esm/version.js +2 -2
  209. package/dist/types/components/commerce/atomic-commerce-product-list/atomic-commerce-product-list.d.ts +1 -1
  210. package/dist/types/components/{context → common/context}/bindings-context.d.ts +1 -1
  211. package/dist/types/components/common/facets/facet-placeholder/facet-placeholder.d.ts +2 -5
  212. package/dist/types/components/common/facets/facet-placeholder/stencil-facet-placeholder.d.ts +10 -0
  213. package/dist/types/components/common/template-controller/base-template-controller.d.ts +2 -1
  214. package/dist/types/components/search/atomic-result/atomic-result.d.ts +1 -1
  215. package/dist/types/components/search/{result-lists/atomic-result-list → atomic-result-list}/atomic-result-list.d.ts +45 -33
  216. package/dist/types/components/search/atomic-result-section-visual/atomic-result-section-visual.d.ts +1 -1
  217. package/dist/types/components/search/atomic-result-template/atomic-result-template.d.ts +1 -0
  218. package/dist/types/components/search/index.d.ts +1 -0
  219. package/dist/types/components.d.ts +0 -70
  220. package/docs/atomic-docs.json +1 -359
  221. package/package.json +5 -5
  222. package/dist/atomic/components/atomic-result-list.d.ts +0 -11
  223. package/dist/atomic/components/atomic-result-list.js +0 -343
  224. package/dist/atomic/components/atomic-result-list.js.map +0 -1
  225. package/dist/atomic/components/facet-placeholder.js.map +0 -1
  226. package/dist/atomic/components/stencil-display-grid.js +0 -20
  227. package/dist/atomic/components/stencil-display-grid.js.map +0 -1
  228. package/dist/atomic/components/table-element-utils.js +0 -5
  229. package/dist/atomic/components/table-element-utils.js.map +0 -1
  230. package/dist/atomic/p-023c1f4f.js +0 -2
  231. package/dist/atomic/p-023c1f4f.js.map +0 -1
  232. package/dist/atomic/p-04e08959.entry.js.map +0 -1
  233. package/dist/atomic/p-0a9d79a3.entry.js +0 -2
  234. package/dist/atomic/p-0a9d79a3.entry.js.map +0 -1
  235. package/dist/atomic/p-1f4853b1.entry.js +0 -2
  236. package/dist/atomic/p-2324ab77.js +0 -2
  237. package/dist/atomic/p-2324ab77.js.map +0 -1
  238. package/dist/atomic/p-29bbd3d3.js.map +0 -1
  239. package/dist/atomic/p-2cd906b9.entry.js.map +0 -1
  240. package/dist/atomic/p-3e077971.js.map +0 -1
  241. package/dist/atomic/p-408ffc88.entry.js.map +0 -1
  242. package/dist/atomic/p-4239e0ec.entry.js.map +0 -1
  243. package/dist/atomic/p-564e93ba.entry.js +0 -2
  244. package/dist/atomic/p-6e47c9a8.entry.js +0 -2
  245. package/dist/atomic/p-7b11e602.entry.js +0 -2
  246. package/dist/atomic/p-7ccbf77d.entry.js +0 -2
  247. package/dist/atomic/p-7dfced62.entry.js.map +0 -1
  248. package/dist/atomic/p-8b38c143.js +0 -2
  249. package/dist/atomic/p-8b38c143.js.map +0 -1
  250. package/dist/atomic/p-906fd94d.entry.js.map +0 -1
  251. package/dist/atomic/p-99203e57.entry.js.map +0 -1
  252. package/dist/atomic/p-b528927d.entry.js.map +0 -1
  253. package/dist/atomic/p-b986c752.entry.js.map +0 -1
  254. package/dist/atomic/p-be0518ae.js +0 -2
  255. package/dist/atomic/p-be0518ae.js.map +0 -1
  256. package/dist/atomic/p-e351c8ed.entry.js +0 -2
  257. package/dist/cjs/atomic-result-list.cjs.entry.js +0 -303
  258. package/dist/cjs/atomic-result-list.cjs.entry.js.map +0 -1
  259. package/dist/cjs/facet-placeholder-e86f105c.js.map +0 -1
  260. package/dist/cjs/stencil-carousel-2beaa7d2.js.map +0 -1
  261. package/dist/cjs/stencil-display-grid-04536fdc.js +0 -22
  262. package/dist/cjs/stencil-display-grid-04536fdc.js.map +0 -1
  263. package/dist/cjs/stencil-result-template-common-268ba233.js.map +0 -1
  264. package/dist/cjs/table-element-utils-2cc6dc82.js +0 -7
  265. package/dist/cjs/table-element-utils-2cc6dc82.js.map +0 -1
  266. package/dist/cjs/timeframe-facet-common-16ba58fd.js.map +0 -1
  267. package/dist/esm/atomic-result-list.entry.js +0 -299
  268. package/dist/esm/atomic-result-list.entry.js.map +0 -1
  269. package/dist/esm/facet-placeholder-7e0836c1.js.map +0 -1
  270. package/dist/esm/stencil-carousel-be6f0bc1.js.map +0 -1
  271. package/dist/esm/stencil-display-grid-02c4f5d0.js +0 -20
  272. package/dist/esm/stencil-display-grid-02c4f5d0.js.map +0 -1
  273. package/dist/esm/stencil-result-template-common-cddca36d.js.map +0 -1
  274. package/dist/esm/table-element-utils-1dbc5ef6.js +0 -5
  275. package/dist/esm/table-element-utils-1dbc5ef6.js.map +0 -1
  276. package/dist/esm/timeframe-facet-common-906a271d.js.map +0 -1
  277. package/dist/types/components/common/tabs/stencil-tab-guard.d.ts +0 -11
  278. /package/dist/atomic/components/components/{context → common/context}/bindings-context.js +0 -0
  279. /package/dist/atomic/{p-f8bbecdd.entry.js.map → p-0d3407e9.entry.js.map} +0 -0
  280. /package/dist/atomic/{p-561a531c.entry.js.map → p-3302a10f.entry.js.map} +0 -0
  281. /package/dist/atomic/{p-8deeef5f.entry.js.map → p-4b46b80f.entry.js.map} +0 -0
  282. /package/dist/atomic/{p-8deb6142.entry.js.map → p-594e3243.entry.js.map} +0 -0
  283. /package/dist/atomic/{p-0d955dec.entry.js.map → p-9f3b431f.entry.js.map} +0 -0
  284. /package/dist/atomic/{p-7b718df8.entry.js.map → p-e0e50820.entry.js.map} +0 -0
  285. /package/dist/atomic/{p-3119dcb8.entry.js.map → p-f2893341.entry.js.map} +0 -0
@@ -1 +0,0 @@
1
- {"file":"atomic-result-list.js","mappings":"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","names":["AtomicResultList"],"sources":["src/components/common/item-list/stencil-display-table.tsx","src/components/common/tabs/stencil-tab-guard.tsx","src/components/search/result-lists/atomic-result-list/atomic-result-list.pcss?tag=atomic-result-list&encapsulation=shadow","src/components/search/result-lists/atomic-result-list/atomic-result-list.tsx"],"sourcesContent":["// The Lit equivalent of this file is table-layout.ts\nimport {FunctionalComponent, VNode, h} from '@stencil/core';\nimport {tableElementTagName} from '../table-element-utils.js';\nimport {AnyItem} from './unfolded-item.js';\nimport {ItemRenderingFunction} from './stencil-item-list-common.js';\n\ninterface TableColumnsProps {\n templateContentForFirstItem: DocumentFragment;\n firstItem: AnyItem;\n itemRenderingFunction?: ItemRenderingFunction;\n}\n\ninterface DisplayTableProps extends TableColumnsProps {\n logger: Pick<Console, 'error'>;\n host: HTMLElement;\n listClasses: string;\n}\n\ninterface TableDataProps extends TableColumnsProps {\n key: string;\n}\n\ninterface DisplayTableRowProps {\n key: string;\n rowIndex: number;\n setRef: (element?: HTMLElement) => void;\n}\n\nconst getFieldTableColumns = (props: TableColumnsProps) => {\n if (props.itemRenderingFunction) {\n return getFieldTableColumnsFromRenderingFunction(props);\n }\n return getFieldTableColumnsFromHTMLTemplate(props);\n};\n\nconst getFieldTableColumnsFromRenderingFunction = (\n props: Pick<TableColumnsProps, 'itemRenderingFunction' | 'firstItem'>\n): HTMLAtomicTableElementElement[] => {\n const contentOfRenderingFunction = document.createElement('div');\n\n const contentOfRenderingFunctionAsString = props.itemRenderingFunction!(\n props.firstItem,\n document.createElement('div')\n );\n contentOfRenderingFunction.innerHTML = contentOfRenderingFunctionAsString;\n\n return Array.from(\n contentOfRenderingFunction.querySelectorAll(tableElementTagName)\n );\n};\n\nconst getFieldTableColumnsFromHTMLTemplate = (\n props: Pick<DisplayTableProps, 'templateContentForFirstItem'>\n): HTMLAtomicTableElementElement[] =>\n Array.from(\n props.templateContentForFirstItem.querySelectorAll(tableElementTagName)\n );\n\n/**\n * @deprecated should only be used for Stencil components.\n */\nexport const DisplayTable: FunctionalComponent<DisplayTableProps> = (\n props,\n children\n) => {\n const fieldColumns = getFieldTableColumns(props);\n\n if (!fieldColumns.length) {\n props.logger.error(\n 'atomic-table-element elements missing in the template to display columns.',\n props.host\n );\n }\n\n return (\n <table class={`list-root ${props.listClasses}`} part=\"result-table\">\n <thead part=\"result-table-heading\">\n <tr part=\"result-table-heading-row\">\n {fieldColumns.map((column) => (\n <th part=\"result-table-heading-cell\">\n <atomic-text value={column.getAttribute('label')!}></atomic-text>\n </th>\n ))}\n </tr>\n </thead>\n <tbody part=\"result-table-body\">{...children}</tbody>\n </table>\n );\n};\n\n/**\n * @deprecated should only be used for Stencil components.\n */\nexport const DisplayTableRow: FunctionalComponent<DisplayTableRowProps> = (\n {key, rowIndex, setRef},\n children\n) => {\n return (\n <tr\n key={key}\n part={\n 'result-table-row ' +\n (rowIndex % 2 === 1 ? 'result-table-row-even' : 'result-table-row-odd')\n }\n ref={(element) => setRef(element)}\n >\n {...children}\n </tr>\n );\n};\n\n/**\n * @deprecated should only be used for Stencil components.\n */\nexport const DisplayTableData: FunctionalComponent<\n TableDataProps & {\n renderItem: (content: HTMLAtomicTableElementElement) => VNode;\n }\n> = (props) => {\n const fieldColumns = getFieldTableColumns(props);\n\n let currentItemColumns = fieldColumns;\n if (props.itemRenderingFunction && props.firstItem) {\n const contentDiv = document.createElement('div');\n const renderedHTML = props.itemRenderingFunction(\n props.firstItem,\n document.createElement('div'),\n undefined\n );\n contentDiv.innerHTML = renderedHTML;\n currentItemColumns = Array.from(\n contentDiv.querySelectorAll(tableElementTagName)\n );\n }\n\n return currentItemColumns.map((column, index) => {\n const label =\n fieldColumns[index]?.getAttribute('label') ||\n column.getAttribute('label');\n const key = label + props.key;\n return (\n <td key={key} part=\"result-table-cell\">\n {props.renderItem(column)}\n </td>\n );\n });\n};\n","import {Fragment, FunctionalComponent, h} from '@stencil/core';\nimport {shouldDisplayOnCurrentTab} from '../../../utils/tab-utils';\nimport {Hidden} from '../stencil-hidden';\n\ninterface TabGuardProps {\n tabsIncluded: string | string[];\n tabsExcluded: string | string[];\n activeTab: string;\n}\n\n/**\n * @deprecated should only be used for Stencil components.\n */\nexport const TabGuard: FunctionalComponent<TabGuardProps> = (\n {tabsIncluded, tabsExcluded, activeTab},\n children\n) => {\n if (\n !shouldDisplayOnCurrentTab([...tabsIncluded], [...tabsExcluded], activeTab)\n ) {\n return <Hidden></Hidden>;\n }\n return <Fragment>{...children}</Fragment>;\n};\n","@import '../../../../global/global.pcss';\n@import '../../../common/item-list/styles/placeholders.pcss';\n@import '../../../common/item-list/styles/table-display.pcss';\n@import '../../../common/item-list/styles/list-display.pcss';\n@import '../../../common/item-list/styles/grid-display.pcss';\n\natomic-result:not(.hydrated) {\n visibility: hidden;\n}\n","import {\n ResultList,\n ResultListState,\n buildResultList,\n ResultsPerPageState,\n ResultsPerPage,\n buildResultsPerPage,\n buildInteractiveResult,\n Result,\n TabManager,\n TabManagerState,\n buildTabManager,\n} from '@coveo/headless';\nimport {Component, Element, State, Prop, Method, h, Watch} from '@stencil/core';\nimport {\n BindStateToController,\n InitializableComponent,\n InitializeBindings,\n} from '../../../../utils/initialization-utils';\nimport {ArrayProp} from '../../../../utils/props-utils';\nimport {FocusTargetController} from '../../../../utils/stencil-accessibility-utils';\nimport {randomID} from '../../../../utils/utils';\nimport {ResultsPlaceholdersGuard} from '../../../common/atomic-result-placeholder/stencil-placeholders';\nimport {createAppLoadedListener} from '../../../common/interface/store';\nimport {ItemDisplayGuard} from '../../../common/item-list/stencil-item-display-guard';\nimport {ItemListGuard} from '../../../common/item-list/stencil-item-list-guard';\nimport {ResultTemplateProvider} from '../../../common/item-list/result-template-provider';\nimport {DisplayGrid} from '../../../common/item-list/stencil-display-grid';\nimport {\n DisplayTableData,\n DisplayTable,\n DisplayTableRow,\n} from '../../../common/item-list/stencil-display-table';\nimport {DisplayWrapper} from '../../../common/item-list/stencil-display-wrapper';\nimport {\n ItemListCommon,\n ItemRenderingFunction,\n} from '../../../common/item-list/stencil-item-list-common';\nimport {\n ItemDisplayDensity,\n ItemDisplayImageSize,\n ItemDisplayLayout,\n getItemListDisplayClasses,\n} from '../../../common/layout/display-options';\nimport {TabGuard} from '../../../common/tabs/stencil-tab-guard';\nimport {Bindings} from '../../atomic-search-interface/atomic-search-interface';\n\n/**\n * The `atomic-result-list` component is responsible for displaying query results by applying one or more result templates.\n *\n * @slot default - The default slot where the result templates are inserted.\n * @part result-list - The element containing every result of a result list\n * @part outline - The element displaying an outline or a divider around a result\n * @part result-list-grid-clickable-container - The parent of the result & the clickable link encompassing it, when results are displayed as a grid\n * @part result-list-grid-clickable - The clickable link encompassing the result when results are displayed as a grid\n * @part result-table - The element of the result table containing a heading and a body\n * @part result-table-heading - The element containing the row of cells in the result table's heading\n * @part result-table-heading-row - The element containing cells of the result table's heading\n * @part result-table-heading-cell - The element representing a cell of the result table's heading\n * @part result-table-body - The element containing the rows of the result table's body\n * @part result-table-row - The element containing the cells of a row in the result table's body\n * @part result-table-row-odd - The element containing the cells of an odd row in the result table's body\n * @part result-table-row-even - The element containing the cells of an even row in the result table's body\n * @part result-table-cell - The element representing a cell of the result table's body\n */\n@Component({\n tag: 'atomic-result-list',\n styleUrl: 'atomic-result-list.pcss',\n shadow: true,\n})\nexport class AtomicResultList implements InitializableComponent {\n @InitializeBindings() public bindings!: Bindings;\n public resultList!: ResultList;\n public resultsPerPage!: ResultsPerPage;\n private loadingFlag = randomID('firstResultLoaded-');\n private itemRenderingFunction: ItemRenderingFunction;\n private nextNewResultTarget?: FocusTargetController;\n private itemTemplateProvider!: ResultTemplateProvider;\n private resultListCommon!: ItemListCommon;\n\n @Element() public host!: HTMLDivElement;\n\n @BindStateToController('resultList')\n @State()\n private resultListState!: ResultListState;\n @BindStateToController('resultsPerPage')\n @State()\n private resultsPerPageState!: ResultsPerPageState;\n public tabManager!: TabManager;\n @BindStateToController('tabManager')\n @State()\n public tabManagerState!: TabManagerState;\n @State() private resultTemplateRegistered = false;\n @State() public error!: Error;\n @State() private isAppLoaded = false;\n\n @State() private templateHasError = false;\n\n /**\n * The desired layout to use when displaying results. Layouts affect how many results to display per row and how visually distinct they are from each other.\n */\n @Prop({reflect: true}) public display: ItemDisplayLayout = 'list';\n /**\n * The spacing of various elements in the result list, including the gap between results, the gap between parts of a result, and the font sizes of different parts in a result.\n */\n @Prop({reflect: true}) public density: ItemDisplayDensity = 'normal';\n\n /**\n * The expected size of the image displayed in the results.\n */\n @Prop({reflect: true, mutable: true})\n public imageSize: ItemDisplayImageSize = 'icon';\n\n /**\n * The tabs on which the result list can be displayed. This property should not be used at the same time as `tabs-excluded`.\n *\n * Set this property as a stringified JSON array, e.g.,\n * ```html\n * <atomic-result-list tabs-included='[\"tabIDA\", \"tabIDB\"]'></atomic-result-list snippet>\n * ```\n * If you don't set this property, the result list can be displayed on any tab. Otherwise, the result list can only be displayed on the specified tabs.\n */\n @ArrayProp()\n @Prop({reflect: true, mutable: true})\n public tabsIncluded: string[] | string = '[]';\n\n /**\n * The tabs on which this result list must not be displayed. This property should not be used at the same time as `tabs-included`.\n *\n * Set this property as a stringified JSON array, e.g.,\n * ```html\n * <atomic-result-list tabs-excluded='[\"tabIDA\", \"tabIDB\"]'></atomic-result-list>\n * ```\n * If you don't set this property, the result list can be displayed on any tab. Otherwise, the result list won't be displayed on any of the specified tabs.\n */\n @ArrayProp()\n @Prop({reflect: true, mutable: true})\n public tabsExcluded: string[] | string = '[]';\n\n /**\n * Sets a rendering function to bypass the standard HTML template mechanism for rendering results.\n * You can use this function while working with web frameworks that don't use plain HTML syntax, e.g., React, Angular or Vue.\n *\n * Do not use this method if you integrate Atomic in a plain HTML deployment.\n *\n * @param resultRenderingFunction\n */\n @Method() public async setRenderFunction(\n resultRenderingFunction: ItemRenderingFunction\n ) {\n this.itemRenderingFunction = resultRenderingFunction;\n }\n\n public get focusTarget() {\n if (!this.nextNewResultTarget) {\n this.nextNewResultTarget = new FocusTargetController(this);\n }\n return this.nextNewResultTarget;\n }\n\n public initialize() {\n if (this.host.innerHTML.includes('<atomic-result-children')) {\n console.warn(\n 'Folded results will not render any children for the \"atomic-result-list\". Please use \"atomic-folded-result-list\" instead.'\n );\n }\n this.tabManager = buildTabManager(this.bindings.engine);\n this.resultList = buildResultList(this.bindings.engine);\n this.resultsPerPage = buildResultsPerPage(this.bindings.engine);\n this.itemTemplateProvider = new ResultTemplateProvider({\n includeDefaultTemplate: true,\n templateElements: Array.from(\n this.host.querySelectorAll('atomic-result-template')\n ),\n getResultTemplateRegistered: () => this.resultTemplateRegistered,\n getTemplateHasError: () => this.templateHasError,\n setResultTemplateRegistered: (value: boolean) => {\n this.resultTemplateRegistered = value;\n },\n setTemplateHasError: (value: boolean) => {\n this.templateHasError = value;\n },\n bindings: this.bindings,\n });\n\n this.resultListCommon = new ItemListCommon({\n engineSubscribe: this.bindings.engine.subscribe,\n getCurrentNumberOfItems: () => this.resultListState.results.length,\n getIsLoading: () => this.resultListState.isLoading,\n host: this.host,\n loadingFlag: this.loadingFlag,\n nextNewItemTarget: this.focusTarget,\n store: this.bindings.store,\n });\n createAppLoadedListener(this.bindings.store, (isAppLoaded) => {\n this.isAppLoaded = isAppLoaded;\n });\n }\n\n @Watch('tabManagerState')\n watchTabManagerState(\n newValue: {activeTab: string},\n oldValue: {activeTab: string}\n ) {\n if (newValue?.activeTab !== oldValue?.activeTab) {\n this.bindings.store.unsetLoadingFlag(this.loadingFlag);\n }\n }\n\n public render() {\n this.resultListCommon.updateBreakpoints();\n const listClasses = this.computeListDisplayClasses();\n\n return (\n <TabGuard\n tabsIncluded={this.tabsIncluded}\n tabsExcluded={this.tabsExcluded}\n activeTab={this.tabManagerState.activeTab}\n >\n <ItemListGuard\n hasError={this.resultListState.hasError}\n hasTemplate={this.resultTemplateRegistered}\n templateHasError={this.itemTemplateProvider.hasError}\n firstRequestExecuted={this.resultListState.firstSearchExecuted}\n hasItems={this.resultListState.hasResults}\n >\n <DisplayWrapper display={this.display} listClasses={listClasses}>\n <ResultsPlaceholdersGuard\n density={this.density}\n display={this.display}\n imageSize={this.imageSize}\n displayPlaceholders={!this.isAppLoaded}\n numberOfPlaceholders={this.resultsPerPageState.numberOfResults}\n ></ResultsPlaceholdersGuard>\n <ItemDisplayGuard\n firstRequestExecuted={this.resultListState.firstSearchExecuted}\n hasItems={this.resultListState.hasResults}\n >\n {this.display === 'table'\n ? this.renderAsTable()\n : this.display === 'grid'\n ? this.renderAsGrid()\n : this.renderAsList()}\n </ItemDisplayGuard>\n </DisplayWrapper>\n </ItemListGuard>\n </TabGuard>\n );\n }\n\n private getPropsForAtomicResult(result: Result) {\n return {\n interactiveResult: buildInteractiveResult(this.bindings.engine, {\n options: {result},\n }),\n result,\n renderingFunction: this.itemRenderingFunction,\n loadingFlag: this.loadingFlag,\n key: this.resultListCommon.getResultId(\n result.uniqueId,\n this.resultListState.searchResponseId,\n this.density,\n this.imageSize\n ),\n content: this.itemTemplateProvider.getTemplateContent(result),\n linkContent:\n this.display === 'grid'\n ? this.itemTemplateProvider.getLinkTemplateContent(result)\n : this.itemTemplateProvider.getEmptyLinkTemplateContent(),\n store: this.bindings.store,\n density: this.density,\n imageSize: this.imageSize,\n display: this.display,\n };\n }\n\n private computeListDisplayClasses() {\n const displayPlaceholders = !this.isAppLoaded;\n\n return getItemListDisplayClasses(\n this.display,\n this.density,\n this.imageSize,\n this.resultListState.firstSearchExecuted &&\n this.resultListState.isLoading,\n displayPlaceholders\n );\n }\n\n private renderAsGrid() {\n return this.resultListState.results.map((result, i) => {\n const propsForAtomicResult = this.getPropsForAtomicResult(result);\n return (\n <DisplayGrid\n selectorForItem=\"atomic-result\"\n item={result}\n {...propsForAtomicResult.interactiveResult}\n setRef={(element) =>\n element && this.resultListCommon.setNewResultRef(element, i)\n }\n >\n <atomic-result {...this} {...propsForAtomicResult}></atomic-result>\n </DisplayGrid>\n );\n });\n }\n\n private renderAsTable() {\n if (!this.resultListState.hasResults) {\n return;\n }\n const listClasses = this.computeListDisplayClasses();\n const firstItem = this.resultListState.results[0];\n\n const propsForTableColumns = {\n firstItem,\n templateContentForFirstItem:\n this.itemTemplateProvider.getTemplateContent(firstItem),\n };\n\n return (\n <DisplayTable\n {...propsForTableColumns}\n listClasses={listClasses}\n itemRenderingFunction={this.itemRenderingFunction}\n logger={this.bindings.engine.logger}\n host={this.host}\n >\n {this.resultListState.results.map((result, i) => {\n const {renderingFunction,...propsForAtomicResult} = this.getPropsForAtomicResult(result);\n return (\n <DisplayTableRow\n {...propsForAtomicResult}\n rowIndex={i}\n setRef={(element) =>\n element && this.resultListCommon.setNewResultRef(element, i)\n }\n >\n <DisplayTableData\n {...propsForTableColumns}\n {...propsForAtomicResult}\n itemRenderingFunction={this.itemRenderingFunction}\n renderItem={(content) => {\n return (\n <atomic-result\n {...propsForAtomicResult}\n content={content}\n ></atomic-result>\n );\n }}\n ></DisplayTableData>\n </DisplayTableRow>\n );\n })}\n </DisplayTable>\n );\n }\n\n private renderAsList() {\n return this.resultListState.results.map((result, i) => {\n const propsForAtomicResult = this.getPropsForAtomicResult(result);\n return (\n <atomic-result\n {...propsForAtomicResult}\n ref={(element: HTMLElement) =>\n element && this.resultListCommon.setNewResultRef(element, i)\n }\n part=\"outline\"\n ></atomic-result>\n );\n });\n }\n}\n"],"version":3}
@@ -1 +0,0 @@
1
- {"file":"facet-placeholder.js","mappings":";;AAOA;;;MAGa,gBAAgB,GAA+C,CAAC,EAC3E,cAAc,EACd,WAAW,GACZ;IACC,MAAM,WAAW,GAAG,EAAE,CAAC;IACvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,cAAc,EAAE,CAAC,EAAE,EAAE;QACvC,WAAW,CAAC,IAAI,CACd,WACE,KAAK,EAAC,0BAA0B,EAChC,KAAK,EAAE,EAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAC,GACjC,CACR,CAAC;KACH;IAED,QACE,WACE,IAAI,EAAC,aAAa,EAClB,KAAK,EAAC,uEAAuE,iBACjE,MAAM;QAElB,WAAK,KAAK,EAAC,wBAAwB,EAAC,KAAK,EAAE,EAAC,KAAK,EAAE,KAAK,EAAC,GAAQ;QAChE,CAAC,WAAW,IAAI,WAAK,KAAK,EAAC,MAAM,IAAE,WAAW,CAAO,CAClD,EACN;AACJ;;;;","names":[],"sources":["src/components/common/facets/facet-placeholder/facet-placeholder.tsx"],"sourcesContent":["import {FunctionalComponent, h} from '@stencil/core';\n\ninterface FacetPlaceholderProps {\n numberOfValues: number;\n isCollapsed: boolean;\n}\n\n/**\n * @deprecated should only be used for Stencil components.\n */\nexport const FacetPlaceholder: FunctionalComponent<FacetPlaceholderProps> = ({\n numberOfValues,\n isCollapsed,\n}) => {\n const facetValues = [];\n for (let i = 0; i < numberOfValues; i++) {\n facetValues.push(\n <div\n class=\"bg-neutral mt-4 flex h-5\"\n style={{width: '100%', opacity: '0.5'}}\n ></div>\n );\n }\n\n return (\n <div\n part=\"placeholder\"\n class=\"bg-background border-neutral mb-4 animate-pulse rounded-lg border p-7\"\n aria-hidden=\"true\"\n >\n <div class=\"bg-neutral h-8 rounded\" style={{width: '75%'}}></div>\n {!isCollapsed && <div class=\"mt-7\">{facetValues}</div>}\n </div>\n );\n};\n"],"version":3}
@@ -1,20 +0,0 @@
1
- import { h } from '@stencil/core/internal/client';
2
-
3
- // The Lit equivalent of this file is grid-layout.ts
4
- /**
5
- * @deprecated should only be used for Stencil components.
6
- */
7
- const DisplayGrid = ({ setRef, selectorForItem }, children) => {
8
- let ref;
9
- return (h("div", { part: "result-list-grid-clickable-container outline", ref: (element) => {
10
- ref = element;
11
- setRef(element);
12
- }, onClick: (event) => {
13
- event.preventDefault();
14
- ref?.querySelector(selectorForItem)?.click();
15
- } }, ...children));
16
- };
17
-
18
- export { DisplayGrid as D };
19
-
20
- //# sourceMappingURL=stencil-display-grid.js.map
@@ -1 +0,0 @@
1
- {"file":"stencil-display-grid.js","mappings":";;AAAA;AAYA;;;MAGa,WAAW,GAA0C,CAChE,EAAC,MAAM,EAAE,eAAe,EAAC,EACzB,QAAQ;IAER,IAAI,GAA4B,CAAC;IACjC,QACE,WACE,IAAI,EAAC,8CAA8C,EACnD,GAAG,EAAE,CAAC,OAAO;YACX,GAAG,GAAG,OAAO,CAAC;YACd,MAAM,CAAC,OAAO,CAAC,CAAC;SACjB,EACD,OAAO,EAAE,CAAC,KAAK;YACb,KAAK,CAAC,cAAc,EAAE,CAAC;YACtB,GAAG,EAAE,aAAa,CAAC,eAAe,CAAiB,EAAE,KAAK,EAAE,CAAC;SAC/D,OAEG,QAAQ,CACR,EACN;AACJ;;;;","names":[],"sources":["src/components/common/item-list/stencil-display-grid.tsx"],"sourcesContent":["// The Lit equivalent of this file is grid-layout.ts\nimport {FunctionalComponent, h} from '@stencil/core';\n\ninterface DisplayGridProps {\n selectorForItem: string;\n item: {clickUri: string; title: string};\n setRef: (element?: HTMLElement) => void;\n select: () => void;\n beginDelayedSelect: () => void;\n cancelPendingSelect: () => void;\n}\n\n/**\n * @deprecated should only be used for Stencil components.\n */\nexport const DisplayGrid: FunctionalComponent<DisplayGridProps> = (\n {setRef, selectorForItem},\n children\n) => {\n let ref: HTMLElement | undefined;\n return (\n <div\n part=\"result-list-grid-clickable-container outline\"\n ref={(element) => {\n ref = element;\n setRef(element);\n }}\n onClick={(event) => {\n event.preventDefault();\n (ref?.querySelector(selectorForItem) as HTMLElement)?.click();\n }}\n >\n {...children}\n </div>\n );\n};\n"],"version":3}
@@ -1,5 +0,0 @@
1
- const tableElementTagName = 'atomic-table-element';
2
-
3
- export { tableElementTagName as t };
4
-
5
- //# sourceMappingURL=table-element-utils.js.map
@@ -1 +0,0 @@
1
- {"file":"table-element-utils.js","mappings":"MAAa,mBAAmB,GAAG;;;;","names":[],"sources":["src/components/common/table-element-utils.ts"],"sourcesContent":["export const tableElementTagName = 'atomic-table-element';\n"],"version":3}
@@ -1,2 +0,0 @@
1
- import{ResultTemplatesHelpers as t}from"@coveo/headless";import{h as e}from"./p-b201b267.js";import{a as n,i as o,b as r}from"./p-a08b085f.js";import{t as s}from"./p-be0518ae.js";import{i}from"./p-e3129f8f.js";function a(t){if(i(t)){return"section"}if(!o(t)){return"metadata"}if(r(t)&&t.tagName.toLowerCase()===s){return"table-column-definition"}return"other"}function l(t){return n(Array.from(t),(t=>a(t)))}class c{constructor({host:t,setError:e,validParents:n,allowEmpty:o=false}){this.matchConditions=[];this.gridCellLinkTarget="_self";this.host=t;this.validateTemplate(t,e,n,o)}validateTemplate(t,e,n,o=true){const r=n.map((t=>t.toUpperCase())).includes(t.parentElement?.nodeName||"");const s=t.nodeName.toLowerCase();if(!r){e(new Error(`The "${s}" component has to be the child of one of the following: ${n.map((t=>`"${t.toLowerCase()}"`)).join(", ")}.`));return}if(t.parentElement?.attributes.getNamedItem("display")?.value==="grid"){this.gridCellLinkTarget=t.parentElement?.attributes.getNamedItem("grid-cell-link-target")?.value}const i=t.querySelector("template:not([slot])");if(!i){e(new Error(`The "${s}" component has to contain a "template" element as a child.`));return}if(!o&&!i.innerHTML.trim()){e(new Error(`The "template" tag inside "${s}" cannot be empty.`));return}if(i.content.querySelector("script")){console.warn('Any "script" tags defined inside of "template" elements are not supported and will not be executed when the results are rendered.',t)}const{section:a,other:c}=l(i.content.childNodes);if(a?.length&&c?.length){console.warn("Result templates should only contain section elements or non-section elements. Future updates could unpredictably affect this result template.",t,{sectionNodes:a,otherNodes:c})}}getTemplate(t,e){if(e){return null}return{conditions:t.concat(this.matchConditions),content:m(this.host).content,linkContent:this.getLinkTemplateElement(this.host).content,priority:1}}renderIfError(t){if(t){return e("atomic-component-error",{element:this.host,error:t})}}getDefaultLinkTemplateElement(){const t=document.createElement("template");t.innerHTML=`<atomic-result-link>${this.gridCellLinkTarget?`<a slot="attributes" target="${this.gridCellLinkTarget}"></a>`:""}</atomic-result-link>`;return t}getLinkTemplateElement(t){return t.querySelector('template[slot="link"]')??this.getDefaultLinkTemplateElement()}}function m(t){return t.querySelector("template:not([slot])")}function u(e,n){const o=[];for(const n in e){o.push(t.fieldMustMatch(n,e[n]))}for(const e in n){o.push(t.fieldMustNotMatch(e,n[e]))}return o}function f(e,n){const o=[];if(e){const n=e.split(",");o.push(t.fieldsMustBeDefined(n))}if(n){const e=n.split(",");o.push(t.fieldsMustNotBeDefined(e))}return o}export{c as R,f as a,u as m};
2
- //# sourceMappingURL=p-023c1f4f.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["getTemplateNodeType","node","isResultSectionNode","isVisualNode","isElementNode","tagName","toLowerCase","tableElementTagName","groupNodesByType","nodes","aggregate","Array","from","ResultTemplateCommon","constructor","host","setError","validParents","allowEmpty","this","matchConditions","gridCellLinkTarget","validateTemplate","hasValidParent","map","p","toUpperCase","includes","parentElement","nodeName","Error","join","attributes","getNamedItem","value","template","querySelector","innerHTML","trim","content","console","warn","section","sectionNodes","other","otherNodes","childNodes","length","getTemplate","conditions","error","concat","getTemplateElement","linkContent","getLinkTemplateElement","priority","renderIfError","h","element","getDefaultLinkTemplateElement","linkTemplate","document","createElement","makeMatchConditions","mustMatch","mustNotMatch","field","push","ResultTemplatesHelpers","fieldMustMatch","fieldMustNotMatch","makeDefinedConditions","ifDefined","ifNotDefined","fieldNames","split","fieldsMustBeDefined","fieldsMustNotBeDefined"],"sources":["src/components/common/result-templates/stencil-result-template-common.tsx"],"sourcesContent":["import {\n ResultTemplate,\n ResultTemplateCondition,\n ResultTemplatesHelpers,\n} from '@coveo/headless';\nimport {h} from '@stencil/core';\nimport {aggregate, isElementNode, isVisualNode} from '@/src/utils/utils';\nimport {tableElementTagName} from '../table-element-utils';\nimport {ItemTarget} from '../layout/display-options';\nimport {isResultSectionNode} from '../layout/item-layout-sections';\n\nexport type TemplateContent = DocumentFragment;\n\ninterface ResultTemplateCommonProps {\n allowEmpty?: boolean;\n host: HTMLDivElement;\n validParents: string[];\n setError: (error: Error) => void;\n}\n\ntype TemplateNodeType =\n | 'section'\n | 'metadata'\n | 'table-column-definition'\n | 'other';\n\nexport function getTemplateNodeType(node: Node): TemplateNodeType {\n if (isResultSectionNode(node)) {\n return 'section';\n }\n if (!isVisualNode(node)) {\n return 'metadata';\n }\n if (\n isElementNode(node) &&\n node.tagName.toLowerCase() === tableElementTagName\n ) {\n return 'table-column-definition';\n }\n return 'other';\n}\n\nfunction groupNodesByType(nodes: NodeList) {\n return aggregate(Array.from(nodes), (node) => getTemplateNodeType(node));\n}\n\nexport class ResultTemplateCommon {\n private host: HTMLDivElement;\n public matchConditions: ResultTemplateCondition[] = [];\n private gridCellLinkTarget: ItemTarget = '_self';\n\n constructor({\n host,\n setError,\n validParents,\n allowEmpty = false,\n }: ResultTemplateCommonProps) {\n this.host = host;\n this.validateTemplate(host, setError, validParents, allowEmpty);\n }\n\n validateTemplate(\n host: HTMLDivElement,\n setError: (error: Error) => void,\n validParents: string[],\n allowEmpty = true\n ) {\n const hasValidParent = validParents\n .map((p) => p.toUpperCase())\n .includes(host.parentElement?.nodeName || '');\n const tagName = host.nodeName.toLowerCase();\n\n if (!hasValidParent) {\n setError(\n new Error(\n `The \"${tagName}\" component has to be the child of one of the following: ${validParents\n .map((p) => `\"${p.toLowerCase()}\"`)\n .join(', ')}.`\n )\n );\n return;\n }\n\n if (\n host.parentElement?.attributes.getNamedItem('display')?.value === 'grid'\n ) {\n this.gridCellLinkTarget = host.parentElement?.attributes.getNamedItem(\n 'grid-cell-link-target'\n )?.value as ItemTarget;\n }\n\n const template = host.querySelector<HTMLTemplateElement>(\n 'template:not([slot])'\n );\n if (!template) {\n setError(\n new Error(\n `The \"${tagName}\" component has to contain a \"template\" element as a child.`\n )\n );\n return;\n }\n\n if (!allowEmpty && !template.innerHTML.trim()) {\n setError(\n new Error(`The \"template\" tag inside \"${tagName}\" cannot be empty.`)\n );\n return;\n }\n\n if (template.content.querySelector('script')) {\n console.warn(\n 'Any \"script\" tags defined inside of \"template\" elements are not supported and will not be executed when the results are rendered.',\n host\n );\n }\n\n const {section: sectionNodes, other: otherNodes} = groupNodesByType(\n template.content.childNodes\n );\n if (sectionNodes?.length && otherNodes?.length) {\n console.warn(\n 'Result templates should only contain section elements or non-section elements. Future updates could unpredictably affect this result template.',\n host,\n {sectionNodes, otherNodes}\n );\n }\n }\n\n getTemplate(\n conditions: ResultTemplateCondition[],\n error: Error\n ): ResultTemplate<TemplateContent> | null {\n if (error) {\n return null;\n }\n\n return {\n conditions: conditions.concat(this.matchConditions),\n content: getTemplateElement(this.host).content!,\n linkContent: this.getLinkTemplateElement(this.host).content!,\n priority: 1,\n };\n }\n\n renderIfError(error: Error) {\n if (error) {\n return (\n <atomic-component-error\n element={this.host}\n error={error}\n ></atomic-component-error>\n );\n }\n }\n\n getDefaultLinkTemplateElement() {\n const linkTemplate = document.createElement('template');\n linkTemplate.innerHTML = `<atomic-result-link>${this.gridCellLinkTarget ? `<a slot=\"attributes\" target=\"${this.gridCellLinkTarget}\"></a>` : ''}</atomic-result-link>`;\n return linkTemplate;\n }\n\n getLinkTemplateElement(host: HTMLElement) {\n return (\n host.querySelector<HTMLTemplateElement>('template[slot=\"link\"]') ??\n this.getDefaultLinkTemplateElement()\n );\n }\n}\n\nfunction getTemplateElement(host: HTMLElement) {\n return host.querySelector<HTMLTemplateElement>('template:not([slot])')!;\n}\n\nexport function makeMatchConditions(\n mustMatch: Record<string, string[]>,\n mustNotMatch: Record<string, string[]>\n): ResultTemplateCondition[] {\n const conditions: ResultTemplateCondition[] = [];\n for (const field in mustMatch) {\n conditions.push(\n ResultTemplatesHelpers.fieldMustMatch(field, mustMatch[field])\n );\n }\n\n for (const field in mustNotMatch) {\n conditions.push(\n ResultTemplatesHelpers.fieldMustNotMatch(field, mustNotMatch[field])\n );\n }\n return conditions;\n}\n\nexport function makeDefinedConditions(\n ifDefined?: string,\n ifNotDefined?: string\n): ResultTemplateCondition[] {\n const conditions: ResultTemplateCondition[] = [];\n if (ifDefined) {\n const fieldNames = ifDefined.split(',');\n conditions.push(ResultTemplatesHelpers.fieldsMustBeDefined(fieldNames));\n }\n\n if (ifNotDefined) {\n const fieldNames = ifNotDefined.split(',');\n conditions.push(ResultTemplatesHelpers.fieldsMustNotBeDefined(fieldNames));\n }\n return conditions;\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1 +0,0 @@
1
- {"version":3,"names":["ColorFacetCheckbox","props","children","id","randomID","count","numberOfResults","toLocaleString","i18n","language","ariaLabel","t","value","displayValue","formattedCount","partValue","match","RegExp","toString","labelRef","h","key","class","role","part","isSelected","onClick","onMouseDown","e","createRipple","color","parent","ref","htmlFor","text","atomicColorFacetCss","AtomicColorFacetStyle0","AtomicColorFacet","this","resultIndexToFocusOnShowMore","label","tabsIncluded","tabsExcluded","numberOfValues","withSearch","sortCriteria","resultsMustMatch","displayValuesAs","isCollapsed","headingLevel","filterFacetCount","injectionDepth","dependsOn","allowedValues","customSort","initialize","length","console","warn","searchStatus","buildSearchStatus","bindings","engine","facet","buildFacet","options","facetOptions","tabManager","buildTabManager","announceFacetSearchResultsWithAriaLive","msg","facetSearchAriaMessage","facetId","state","facetInfo","element","host","isHidden","store","registerFacet","initializePopover","hasValues","values","numberOfActiveValues","numberOfSelectedValues","initializeDependenciesManager","focusTargets","showLessFocus","FocusTargetController","showMoreFocus","headerFocus","disconnectedCallback","isConnected","dependenciesManager","stopWatching","searchStatusState","hasError","enabled","componentShouldUpdate","next","prev","propName","shouldUpdateFacetSearchComponent","facetSearch","facetState","filter","buildFacetConditionsManager","conditions","parseDependsOn","renderHeader","FacetHeader","onClearFilters","focusAfterSearch","deselectAll","onToggleCollapse","headerRef","el","setTarget","renderSearchInput","FacetSearchInput","query","onChange","clear","updateCaptions","getFieldCaptions","field","updateText","search","onClear","renderValue","facetValue","isShowLessFocusTarget","isShowMoreFocusTarget","getFieldValueCaption","isExcluded","partValueWithDisplayValue","replace","partValueWithAPIValue","searchQuery","buttonRef","FacetValueLabelHighlight","FacetValueBox","renderValuesContainer","classes","FacetValuesGroup","renderValues","map","i","toggleSelect","renderSearchResults","rawValue","select","renderMatches","FacetSearchMatches","numberOfMatches","hasMoreMatches","moreValuesAvailable","showMoreMatches","showMoreResults","renderShowMoreLess","FacetShowMoreLess","onShowMore","showMoreValues","onShowLess","showLessValues","canShowLessValues","canShowMoreValues","undefined","tabs","included","excluded","render","Hidden","firstSearchExecuted","FacetPlaceholder","FacetContainer","shouldDisplaySearchResults","__decorate","InitializeBindings","BindStateToController","ArrayProp","MapProp","AriaLiveRegion"],"sources":["src/components/search/facets/color-facet-checkbox/color-facet-checkbox.tsx","src/components/search/facets/atomic-color-facet/atomic-color-facet.pcss?tag=atomic-color-facet&encapsulation=shadow","src/components/search/facets/atomic-color-facet/atomic-color-facet.tsx"],"sourcesContent":["import {FunctionalComponent, h} from '@stencil/core';\nimport {createRipple} from '../../../../utils/ripple-utils';\nimport {randomID} from '../../../../utils/utils';\nimport {FacetValueProps} from '../../../common/facets/stencil-facet-common';\n\n/**\n * @deprecated should only be used for Stencil components.\n */\nexport const ColorFacetCheckbox: FunctionalComponent<FacetValueProps> = (\n props,\n children\n) => {\n const id = randomID('facet-value-');\n const count = props.numberOfResults.toLocaleString(props.i18n.language);\n const ariaLabel = props.i18n.t('facet-value', {\n value: props.displayValue,\n count: props.numberOfResults,\n formattedCount: count,\n });\n const partValue = props.displayValue\n .match(new RegExp('-?[_a-zA-Z]+[_a-zA-Z0-9-]*'))\n ?.toString();\n let labelRef: HTMLLabelElement;\n\n return (\n <li key={props.displayValue} class=\"relative flex items-center\">\n <button\n id={id}\n role=\"checkbox\"\n part={`value-checkbox value-${partValue}${\n props.isSelected ? ' value-checkbox-checked' : ''\n }`}\n onClick={() => props.onClick()}\n onMouseDown={(e) =>\n createRipple(e, {color: 'neutral', parent: labelRef})\n }\n aria-checked={props.isSelected.toString()}\n class={`value-checkbox ${props.isSelected ? 'ring-primary' : ''}`}\n aria-label={ariaLabel}\n ></button>\n <label\n ref={(ref) => (labelRef = ref!)}\n htmlFor={id}\n part=\"value-checkbox-label\"\n onMouseDown={(e) => createRipple(e, {color: 'neutral'})}\n >\n {children}\n <span part=\"value-count\" class=\"value-count\">\n {props.i18n.t('between-parentheses', {\n text: count,\n })}\n </span>\n </label>\n </li>\n );\n};\n","@import '../../../common/facets/facet-common.pcss';\n@import '../../../common/facets/facet-search/facet-search.pcss';\n@import '../../../common/facets/facet-value-box/facet-value-box.pcss';\n@import '../color-facet-checkbox/color-facet-checkbox.pcss';\n\n/**\n * @prop --atomic-facet-color-boxes-per-row: Number of facet values for the Color Facet to display per row, when the display is 'box'\n * @prop --atomic-facet-color-boxes-gap: Gap value for facet values for the Color Facet , when the display is 'box'\n */\n.box-color-container {\n @apply grid px-2;\n grid-template-columns: repeat(var(--atomic-facet-color-boxes-per-row, 3), minmax(0, 1fr));\n gap: var(--atomic-facet-color-boxes-gap, 0.5rem);\n}\n","import {\n Facet,\n buildFacet,\n FacetState,\n FacetOptions,\n FacetSortCriterion,\n SearchStatus,\n SearchStatusState,\n buildSearchStatus,\n FacetValue,\n buildFacetConditionsManager,\n FacetConditionsManager,\n FacetResultsMustMatch,\n FacetValueRequest,\n CategoryFacetValueRequest,\n buildTabManager,\n TabManager,\n TabManagerState,\n} from '@coveo/headless';\nimport {Component, h, State, Prop, VNode, Element} from '@stencil/core';\nimport {\n getFieldCaptions,\n getFieldValueCaption,\n} from '../../../../utils/field-utils';\nimport {\n BindStateToController,\n InitializableComponent,\n InitializeBindings,\n} from '../../../../utils/initialization-utils';\nimport {ArrayProp, MapProp} from '../../../../utils/props-utils';\nimport {\n AriaLiveRegion,\n FocusTargetController,\n} from '../../../../utils/stencil-accessibility-utils';\nimport {parseDependsOn} from '../../../common/facets/depends-on';\nimport {FacetInfo} from '../../../common/facets/facet-common-store';\nimport {FacetContainer} from '../../../common/facets/facet-container/stencil-facet-container';\nimport {FacetHeader} from '../../../common/facets/facet-header/stencil-facet-header';\nimport {FacetPlaceholder} from '../../../common/facets/facet-placeholder/facet-placeholder';\nimport {announceFacetSearchResultsWithAriaLive} from '../../../common/facets/facet-search/facet-search-aria-live';\nimport {\n shouldUpdateFacetSearchComponent,\n shouldDisplaySearchResults,\n} from '../../../common/facets/facet-search/facet-search-utils';\nimport {FacetSearchInput} from '../../../common/facets/facet-search/stencil-facet-search-input';\nimport {FacetSearchMatches} from '../../../common/facets/facet-search/stencil-facet-search-matches';\nimport {FacetShowMoreLess} from '../../../common/facets/facet-show-more-less/stencil-facet-show-more-less';\nimport {FacetValueBox} from '../../../common/facets/facet-value-box/stencil-facet-value-box';\nimport {FacetValueLabelHighlight} from '../../../common/facets/facet-value-label-highlight/stencil-facet-value-label-highlight';\nimport {FacetValuesGroup} from '../../../common/facets/facet-values-group/stencil-facet-values-group';\nimport {initializePopover} from '../../../common/facets/popover/popover-type';\nimport {Hidden} from '../../../common/stencil-hidden';\nimport {Bindings} from '../../atomic-search-interface/atomic-search-interface';\nimport {ColorFacetCheckbox} from '../color-facet-checkbox/color-facet-checkbox';\n\n/**\n * A facet is a list of values for a certain field occurring in the results, ordered using a configurable criteria (e.g., number of occurrences).\n * An `atomic-color-facet` displays a facet of the results for the current query as colors.\n *\n * @part facet - The wrapper for the entire facet.\n * @part placeholder - The placeholder shown before the first search is executed.\n *\n * @part label-button - The button that displays the label and allows to expand/collapse the facet.\n * @part label-button-icon - The label button icon.\n * @part clear-button - The button that resets the actively selected facet values.\n * @part clear-button-icon - The clear button icon.\n *\n * @part search-wrapper - The search box wrapper.\n * @part search-input - The search box input.\n * @part search-icon - The search box submit button.\n * @part search-clear-button - The button to clear the search box of input.\n * @part more-matches - The label indicating there are more matches for the current facet search query.\n * @part no-matches - The label indicating there are no matches for the current facet search query.\n * @part matches-query - The highlighted query inside the matches labels.\n * @part search-highlight - The highlighted query inside the facet values.\n *\n * @part values - The facet values container.\n * @part value-label - The facet value label, common for all displays.\n * @part value-count - The facet value count, common for all displays.\n * @part default-color-value - The default part name used to customize color facet values. Should be defined before dynamic parts.\n * @part value-* - The dynamic part name used to customize a facet value. The `*` is a syntactical placeholder for a specific facet value. For example, if the component's `field` property is set to 'filetype' and your source has a `YouTubeVideo` file type, the part would be targeted like this: `atomic-color-facet::part(value-YouTubeVideo)...`.\n *\n * @part value-box - The facet value when display is 'box'.\n * @part value-box-selected - The selected facet value when display is 'box'.\n * @part value-checkbox - The facet value checkbox, available when display is 'checkbox'.\n * @part value-checkbox-checked - The checked facet value checkbox, available when display is 'checkbox'.\n * @part value-checkbox-label - The facet value checkbox clickable label, available when display is 'checkbox'.\n *\n * @part show-more - The show more results button.\n * @part show-less - The show less results button.\n * @part show-more-less-icon - The icons of the show more & show less buttons.\n */\n@Component({\n tag: 'atomic-color-facet',\n styleUrl: 'atomic-color-facet.pcss',\n shadow: true,\n})\nexport class AtomicColorFacet implements InitializableComponent {\n @InitializeBindings() public bindings!: Bindings;\n public facet!: Facet;\n private dependenciesManager?: FacetConditionsManager;\n private resultIndexToFocusOnShowMore = 0;\n public searchStatus!: SearchStatus;\n public tabManager!: TabManager;\n @Element() private host!: HTMLElement;\n\n @BindStateToController('facet')\n @State()\n public facetState!: FacetState;\n @BindStateToController('searchStatus')\n @State()\n public searchStatusState!: SearchStatusState;\n @BindStateToController('tabManager')\n @State()\n public tabManagerState!: TabManagerState;\n @State() public error!: Error;\n\n /**\n * Specifies a unique identifier for the facet.\n */\n @Prop({mutable: true, reflect: true}) public facetId?: string;\n /**\n * The non-localized label for the facet.\n * Used in the `atomic-breadbox` component through the bindings store.\n */\n @Prop({reflect: true}) public label = 'no-label';\n /**\n * The field whose values you want to display in the facet.\n */\n @Prop({reflect: true}) public field!: string;\n /**\n * The tabs on which the facet can be displayed. This property should not be used at the same time as `tabs-excluded`.\n *\n * Set this property as a stringified JSON array, e.g.,\n * ```html\n * <atomic-timeframe-facet tabs-included='[\"tabIDA\", \"tabIDB\"]'></atomic-timeframe-facet>\n * ```\n * If you don't set this property, the facet can be displayed on any tab. Otherwise, the facet can only be displayed on the specified tabs.\n */\n @ArrayProp()\n @Prop({reflect: true, mutable: true})\n public tabsIncluded: string[] | string = '[]';\n\n /**\n * The tabs on which this facet must not be displayed. This property should not be used at the same time as `tabs-included`.\n *\n * Set this property as a stringified JSON array, e.g.,\n * ```html\n * <atomic-timeframe-facet tabs-excluded='[\"tabIDA\", \"tabIDB\"]'></atomic-timeframe-facet>\n * ```\n * If you don't set this property, the facet can be displayed on any tab. Otherwise, the facet won't be displayed on any of the specified tabs.\n */\n @ArrayProp()\n @Prop({reflect: true, mutable: true})\n public tabsExcluded: string[] | string = '[]';\n\n /**\n * The number of values to request for this facet.\n * Also determines the number of additional values to request each time more values are shown.\n */\n @Prop({reflect: true}) public numberOfValues = 8;\n /**\n * Whether this facet should contain a search box.\n *\n */\n @Prop({reflect: true}) public withSearch = true;\n /**\n * The sort criterion to apply to the returned facet values.\n * Possible values are 'score', 'alphanumeric', 'alphanumericDescending', 'occurrences', alphanumericNatural', 'alphanumericNaturalDescending' and 'automatic'.\n */\n @Prop({reflect: true}) public sortCriteria: FacetSortCriterion = 'automatic';\n /**\n * Specifies how a result must match the selected facet values.\n * Allowed values:\n * - `atLeastOneValue`: A result will match if at least one of the corresponding facet values is selected.\n * - `allValues`: A result will match if all corresponding facet values are selected.\n */\n @Prop({reflect: true}) public resultsMustMatch: FacetResultsMustMatch =\n 'atLeastOneValue';\n /**\n * Whether to display the facet values as checkboxes (multiple selection) or boxes (multiple selection).\n * Possible values are 'checkbox', and 'box'.\n */\n @Prop({reflect: true}) public displayValuesAs: 'checkbox' | 'box' = 'box';\n /**\n * Specifies whether the facet is collapsed. When the facet is the child of an `atomic-facet-manager` component, the facet manager controls this property.\n */\n @Prop({reflect: true, mutable: true}) public isCollapsed = false;\n /**\n * The [heading level](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/Heading_Elements) to use for the heading over the facet, from 1 to 6.\n */\n @Prop({reflect: true}) public headingLevel = 0;\n /**\n * Whether to exclude the parents of folded results when estimating the result count for each facet value.\n *\n *\n * Note: Resulting count is only an estimation, in some cases this value could be incorrect.\n */\n @Prop({reflect: true}) public filterFacetCount = true;\n /**\n * The maximum number of results to scan in the index to ensure that the facet lists all potential facet values.\n * Note: A high injectionDepth may negatively impact the facet request performance.\n * Minimum: `0`\n * Default: `1000`\n */\n @Prop({reflect: true}) public injectionDepth = 1000;\n // @Prop() public customSort?: string; TODO: KIT-753 Add customSort option for facet\n\n /**\n * The required facets and values for this facet to be displayed.\n * Examples:\n * ```html\n * <atomic-facet facet-id=\"abc\" field=\"objecttype\" ...></atomic-facet>\n *\n * <!-- To show the facet when any value is selected in the facet with id \"abc\": -->\n * <atomic-color-facet\n * depends-on-abc\n * ...\n * ></atomic-color-facet>\n *\n * <!-- To show the facet when value \"doc\" is selected in the facet with id \"abc\": -->\n * <atomic-color-facet\n * depends-on-abc=\"doc\"\n * ...\n * ></atomic-color-facet>\n * ```\n */\n @MapProp() @Prop() public dependsOn: Record<string, string> = {};\n\n /**\n * Specifies an explicit list of `allowedValues` in the Search API request. This list is in the form of a JSON string.\n *\n * If you specify a list of values for this option, the facet only uses these values (if they are available in\n * the current result set).\n *\n * Example:\n *\n * The following facet only uses the `Contact`, `Account`, and `File` values of the `objecttype` field. Even if the\n * current result set contains other `objecttype` values, such as `Message` or `Product`, the facet does not use\n * them.\n *\n * ```html\n * <atomic-color-facet field=\"objecttype\" allowed-values='[\"Contact\",\"Account\",\"File\"]'></atomic-color-facet>\n * ```\n *\n * The maximum amount of allowed values is 25.\n *\n * The default value is `undefined`, and the facet uses all available values for its `field` in the current result set.\n */\n @ArrayProp()\n @Prop({mutable: true})\n public allowedValues: string[] | string = '[]';\n\n /**\n * Identifies the facet values that must appear at the top, in this order.\n * This parameter can be used in conjunction with the `sortCriteria` parameter.\n *\n * Facet values not part of the `customSort` list will be sorted according to the `sortCriteria`.\n *\n * Example:\n *\n * The following facet will sort the `Contact`, `Account`, and `File` values at the top of the list for the `objecttype` field.\n *\n * If there are more than these 3 values available, the rest of the list will be sorted using `occurrences`.\n *\n * ```html\n * <atomic-color-facet field=\"objecttype\" custom-sort='[\"Contact\",\"Account\",\"File\"]' sort-criteria='occurrences'></atomic-color-facet>\n * ```\n * The maximum amount of custom sort values is 25.\n *\n * The default value is `undefined`, and the facet values will be sorted using only the `sortCriteria`.\n */\n @ArrayProp()\n @Prop({mutable: true})\n public customSort: string[] | string = '[]';\n\n private showLessFocus?: FocusTargetController;\n\n private showMoreFocus?: FocusTargetController;\n\n private headerFocus?: FocusTargetController;\n\n @AriaLiveRegion('facet-search')\n protected facetSearchAriaMessage!: string;\n\n public initialize() {\n if (\n [...this.tabsIncluded].length > 0 &&\n [...this.tabsExcluded].length > 0\n ) {\n console.warn(\n 'Values for both \"tabs-included\" and \"tabs-excluded\" have been provided. This is could lead to unexpected behaviors.'\n );\n }\n this.searchStatus = buildSearchStatus(this.bindings.engine);\n this.facet = buildFacet(this.bindings.engine, {options: this.facetOptions});\n this.tabManager = buildTabManager(this.bindings.engine);\n announceFacetSearchResultsWithAriaLive(\n this.facet,\n this.label,\n (msg) => (this.facetSearchAriaMessage = msg),\n this.bindings.i18n\n );\n this.facetId = this.facet.state.facetId;\n const facetInfo: FacetInfo = {\n label: () => this.bindings.i18n.t(this.label),\n facetId: this.facetId!,\n element: this.host,\n isHidden: () => this.isHidden,\n };\n this.bindings.store.registerFacet('facets', facetInfo);\n initializePopover(this.host, {\n ...facetInfo,\n hasValues: () => !!this.facet.state.values.length,\n numberOfActiveValues: () => this.numberOfSelectedValues,\n });\n this.initializeDependenciesManager();\n }\n\n private get focusTargets() {\n if (!this.showLessFocus) {\n this.showLessFocus = new FocusTargetController(this);\n }\n if (!this.showMoreFocus) {\n this.showMoreFocus = new FocusTargetController(this);\n }\n if (!this.headerFocus) {\n this.headerFocus = new FocusTargetController(this);\n }\n\n return {\n showLessFocus: this.showLessFocus,\n showMoreFocus: this.showMoreFocus,\n headerFocus: this.headerFocus,\n };\n }\n\n public disconnectedCallback() {\n if (this.host.isConnected) {\n return;\n }\n this.dependenciesManager?.stopWatching();\n }\n\n private get isHidden() {\n return (\n this.searchStatusState.hasError ||\n !this.facet.state.enabled ||\n !this.facet.state.values.length\n );\n }\n\n public componentShouldUpdate(\n next: unknown,\n prev: unknown,\n propName: keyof AtomicColorFacet\n ) {\n if (propName === 'facetState' && prev && this.withSearch) {\n return shouldUpdateFacetSearchComponent(\n (next as FacetState).facetSearch,\n (prev as FacetState).facetSearch\n );\n }\n\n return true;\n }\n\n private get numberOfSelectedValues() {\n return this.facetState.values.filter(({state}) => state === 'selected')\n .length;\n }\n\n private initializeDependenciesManager() {\n this.dependenciesManager = buildFacetConditionsManager(\n this.bindings.engine,\n {\n facetId: this.facetId!,\n conditions: parseDependsOn<\n FacetValueRequest | CategoryFacetValueRequest\n >(this.dependsOn),\n }\n );\n }\n\n private renderHeader() {\n return (\n <FacetHeader\n i18n={this.bindings.i18n}\n label={this.label}\n onClearFilters={() => {\n this.focusTargets.headerFocus.focusAfterSearch();\n this.facet.deselectAll();\n }}\n numberOfActiveValues={this.numberOfSelectedValues}\n isCollapsed={this.isCollapsed}\n headingLevel={this.headingLevel}\n onToggleCollapse={() => (this.isCollapsed = !this.isCollapsed)}\n headerRef={(el) => this.focusTargets.headerFocus.setTarget(el)}\n ></FacetHeader>\n );\n }\n\n private renderSearchInput() {\n if (!this.withSearch) {\n return;\n }\n\n return (\n <FacetSearchInput\n i18n={this.bindings.i18n}\n label={this.label}\n query={this.facetState.facetSearch.query}\n onChange={(value) => {\n if (value === '') {\n this.facet.facetSearch.clear();\n return;\n }\n this.facet.facetSearch.updateCaptions(\n getFieldCaptions(this.field, this.bindings.i18n)\n );\n this.facet.facetSearch.updateText(value);\n this.facet.facetSearch.search();\n }}\n onClear={() => this.facet.facetSearch.clear()}\n ></FacetSearchInput>\n );\n }\n\n private renderValue(\n facetValue: FacetValue,\n onClick: () => void,\n isShowLessFocusTarget: boolean,\n isShowMoreFocusTarget: boolean\n ) {\n const displayValue = getFieldValueCaption(\n this.facetId!,\n facetValue.value,\n this.bindings.i18n\n );\n const isSelected = facetValue.state === 'selected';\n const isExcluded = facetValue.state === 'excluded';\n const partValueWithDisplayValue = displayValue.replace(/[^a-z0-9]/gi, '');\n const partValueWithAPIValue = facetValue.value.replace(/[^a-z0-9]/gi, '');\n switch (this.displayValuesAs) {\n case 'checkbox':\n return (\n <ColorFacetCheckbox\n displayValue={displayValue}\n numberOfResults={facetValue.numberOfResults}\n isSelected={isSelected}\n i18n={this.bindings.i18n}\n onClick={onClick}\n searchQuery={this.facetState.facetSearch.query}\n buttonRef={(element) => {\n isShowLessFocusTarget &&\n this.focusTargets.showLessFocus.setTarget(element);\n isShowMoreFocusTarget &&\n this.focusTargets.showMoreFocus.setTarget(element);\n }}\n >\n <FacetValueLabelHighlight\n displayValue={displayValue}\n isSelected={isSelected}\n searchQuery={this.facetState.facetSearch.query}\n ></FacetValueLabelHighlight>\n </ColorFacetCheckbox>\n );\n case 'box':\n return (\n <FacetValueBox\n displayValue={displayValue}\n numberOfResults={facetValue.numberOfResults}\n isSelected={isSelected}\n i18n={this.bindings.i18n}\n onClick={onClick}\n searchQuery={this.facetState.facetSearch.query}\n buttonRef={(element) => {\n isShowLessFocusTarget &&\n this.focusTargets.showLessFocus.setTarget(element);\n isShowMoreFocusTarget &&\n this.focusTargets.showMoreFocus.setTarget(element);\n }}\n >\n <div\n part={`value-${partValueWithDisplayValue} value-${partValueWithAPIValue} default-color-value`}\n class=\"value-box-color bg-neutral-dark mb-2 h-12 w-full rounded-md\"\n ></div>\n <FacetValueLabelHighlight\n displayValue={displayValue}\n isSelected={isSelected}\n isExcluded={isExcluded}\n searchQuery={this.facetState.facetSearch.query}\n ></FacetValueLabelHighlight>\n </FacetValueBox>\n );\n }\n }\n\n private renderValuesContainer(children: VNode[], query?: string) {\n const classes = `mt-3 ${\n this.displayValuesAs === 'box' ? 'box-color-container' : ''\n }`;\n return (\n <FacetValuesGroup\n i18n={this.bindings.i18n}\n label={this.label}\n query={query}\n >\n <ul class={classes} part=\"values\">\n {children}\n </ul>\n </FacetValuesGroup>\n );\n }\n\n private renderValues() {\n return this.renderValuesContainer(\n this.facetState.values.map((value, i) =>\n this.renderValue(\n value,\n () => this.facet.toggleSelect(value),\n i === 0,\n i ===\n (this.sortCriteria === 'automatic'\n ? 0\n : this.resultIndexToFocusOnShowMore)\n )\n )\n );\n }\n\n private renderSearchResults() {\n return this.renderValuesContainer(\n this.facetState.facetSearch.values.map((value) =>\n this.renderValue(\n {\n state: 'idle',\n numberOfResults: value.count,\n value: value.rawValue,\n },\n () => this.facet.facetSearch.select(value),\n false,\n false\n )\n ),\n this.facetState.facetSearch.query\n );\n }\n\n private renderMatches() {\n return (\n <FacetSearchMatches\n i18n={this.bindings.i18n}\n query={this.facetState.facetSearch.query}\n numberOfMatches={this.facetState.facetSearch.values.length}\n hasMoreMatches={this.facetState.facetSearch.moreValuesAvailable}\n showMoreMatches={() => this.facet.facetSearch.showMoreResults()}\n ></FacetSearchMatches>\n );\n }\n\n private renderShowMoreLess() {\n return (\n <FacetShowMoreLess\n label={this.label}\n i18n={this.bindings.i18n}\n onShowMore={() => {\n this.resultIndexToFocusOnShowMore = this.facet.state.values.length;\n this.focusTargets.showMoreFocus.focusAfterSearch();\n this.facet.showMoreValues();\n }}\n onShowLess={() => {\n this.focusTargets.showLessFocus.focusAfterSearch();\n this.facet.showLessValues();\n }}\n canShowLessValues={this.facetState.canShowLessValues}\n canShowMoreValues={this.facetState.canShowMoreValues}\n ></FacetShowMoreLess>\n );\n }\n\n private get facetOptions(): FacetOptions {\n return {\n facetId: this.facetId,\n field: this.field,\n numberOfValues: this.numberOfValues,\n sortCriteria: this.sortCriteria,\n resultsMustMatch: this.resultsMustMatch,\n facetSearch: {numberOfValues: this.numberOfValues},\n injectionDepth: this.injectionDepth,\n filterFacetCount: this.filterFacetCount,\n allowedValues: this.allowedValues.length\n ? [...this.allowedValues]\n : undefined,\n customSort: this.customSort.length ? [...this.customSort] : undefined,\n tabs: {\n included: [...this.tabsIncluded],\n excluded: [...this.tabsExcluded],\n },\n };\n }\n\n public render() {\n if (this.searchStatusState.hasError || !this.facet.state.enabled) {\n return <Hidden></Hidden>;\n }\n\n if (!this.searchStatusState.firstSearchExecuted) {\n return (\n <FacetPlaceholder\n numberOfValues={this.numberOfValues}\n isCollapsed={this.isCollapsed}\n ></FacetPlaceholder>\n );\n }\n\n if (!this.facetState.values.length) {\n return <Hidden></Hidden>;\n }\n\n return (\n <FacetContainer>\n {this.renderHeader()}\n {!this.isCollapsed && [\n this.renderSearchInput(),\n shouldDisplaySearchResults(this.facetState.facetSearch)\n ? [this.renderSearchResults(), this.renderMatches()]\n : [this.renderValues(), this.renderShowMoreLess()],\n ]}\n </FacetContainer>\n );\n }\n}\n"],"mappings":"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","ignoreList":[]}