@coveo/atomic 3.34.0-pre.b099da8035 → 3.34.0-pre.b429ebe8aa

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 (299) 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 -4
  4. package/dist/atomic/components/_index.js +0 -2
  5. package/dist/atomic/components/analytics-config.js +1 -1
  6. package/dist/atomic/components/atomic-category-facet.js +1 -1
  7. package/dist/atomic/components/atomic-facet.js +1 -1
  8. package/dist/atomic/components/atomic-field-condition.js +1 -1
  9. package/dist/atomic/components/atomic-field-condition.js.map +1 -1
  10. package/dist/atomic/components/atomic-format-currency.js +1 -1
  11. package/dist/atomic/components/atomic-format-number.js +1 -1
  12. package/dist/atomic/components/atomic-format-unit.js +1 -1
  13. package/dist/atomic/components/atomic-insight-history-toggle.js +2 -2
  14. package/dist/atomic/components/atomic-insight-history-toggle.js.map +1 -1
  15. package/dist/atomic/components/atomic-insight-result-children-template.js +1 -1
  16. package/dist/atomic/components/atomic-insight-result-children-template.js.map +1 -1
  17. package/dist/atomic/components/atomic-insight-result-template.js +1 -1
  18. package/dist/atomic/components/atomic-insight-result-template.js.map +1 -1
  19. package/dist/atomic/components/atomic-insight-user-actions-toggle.js +2 -2
  20. package/dist/atomic/components/atomic-insight-user-actions-toggle.js.map +1 -1
  21. package/dist/atomic/components/atomic-numeric-facet.js +1 -1
  22. package/dist/atomic/components/atomic-quickview-modal2.js +23 -23
  23. package/dist/atomic/components/atomic-quickview-modal2.js.map +1 -1
  24. package/dist/atomic/components/atomic-quickview.js +1 -1
  25. package/dist/atomic/components/atomic-recs-result-template.js +1 -1
  26. package/dist/atomic/components/atomic-recs-result-template.js.map +1 -1
  27. package/dist/atomic/components/atomic-result-children-template.js +1 -1
  28. package/dist/atomic/components/atomic-result-children-template.js.map +1 -1
  29. package/dist/atomic/components/atomic-result-children.js +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-result-list.js +1 -1
  33. package/dist/atomic/components/atomic-result-list.js.map +1 -1
  34. package/dist/atomic/components/atomic-result-table-placeholder2.js +1 -1
  35. package/dist/atomic/components/atomic-result-template.js +1 -1
  36. package/dist/atomic/components/atomic-result-template.js.map +1 -1
  37. package/dist/atomic/components/atomic-search-box-query-suggestions2.js +1 -1
  38. package/dist/atomic/components/atomic-search-box.js +5 -11
  39. package/dist/atomic/components/atomic-search-box.js.map +1 -1
  40. package/dist/atomic/components/atomic-smart-snippet-feedback-modal2.js +2 -2
  41. package/dist/atomic/components/atomic-sort-dropdown.js +2 -2
  42. package/dist/atomic/components/atomic-sort-expression.js +1 -1
  43. package/dist/atomic/components/atomic-tab-manager.js +1 -1
  44. package/dist/atomic/components/clock.js +2 -2
  45. package/dist/atomic/components/components/commerce/atomic-commerce-breadbox/atomic-commerce-breadbox.js +17 -32
  46. package/dist/atomic/components/components/commerce/atomic-product-field-condition/atomic-product-field-condition.js +4 -3
  47. package/dist/atomic/components/components/commerce/atomic-product-template/atomic-product-template.js +3 -2
  48. package/dist/atomic/components/components/common/item-list/table-layout.js +1 -1
  49. package/dist/atomic/components/components/common/product-template/product-template-controller.js +16 -81
  50. package/dist/atomic/components/components/common/template-controller/base-template-controller.js +89 -0
  51. package/dist/atomic/components/components/common/{product-template/product-template-common.js → template-controller/template-utils.js} +11 -12
  52. package/dist/atomic/components/components/common/validate-props-controller/validate-props-controller.js +50 -0
  53. package/dist/atomic/components/components/search/atomic-relevance-inspector/atomic-relevance-inspector.js +100 -0
  54. package/dist/atomic/components/components/search/atomic-search-box-recent-queries/atomic-search-box-recent-queries.js +137 -0
  55. package/dist/atomic/components/components/search/atomic-search-interface/atomic-search-interface.js +11 -24
  56. package/dist/atomic/components/components/search/index.js +2 -0
  57. package/dist/atomic/components/components/search/lazy-index.js +2 -0
  58. package/dist/atomic/components/global/environment.js +1 -1
  59. package/dist/atomic/components/index.js.map +1 -1
  60. package/dist/atomic/components/{result-template-common.js → stencil-result-template-common.js} +1 -1
  61. package/dist/atomic/components/stencil-result-template-common.js.map +1 -0
  62. package/dist/atomic/components/table-element-utils.js.map +1 -1
  63. package/dist/atomic/components/utils/compare-utils.js +49 -0
  64. package/dist/atomic/{p-475124d2.entry.js → p-01511388.entry.js} +2 -2
  65. package/dist/atomic/{p-60800b2f.entry.js → p-0ed76e65.entry.js} +2 -2
  66. package/dist/atomic/{p-7fd5b6ac.entry.js → p-2213060b.entry.js} +2 -2
  67. package/dist/atomic/p-2213060b.entry.js.map +1 -0
  68. package/dist/atomic/{p-e7a25b00.entry.js → p-2895c42c.entry.js} +2 -2
  69. package/dist/atomic/p-2895c42c.entry.js.map +1 -0
  70. package/dist/atomic/{p-16f6c1f3.entry.js → p-2fb49fe8.entry.js} +2 -2
  71. package/dist/atomic/{p-13391e75.entry.js → p-3549a469.entry.js} +2 -2
  72. package/dist/atomic/{p-88af4470.entry.js → p-40c1dfcb.entry.js} +2 -2
  73. package/dist/atomic/{p-2250f505.js → p-4da8f827.js} +2 -2
  74. package/dist/atomic/p-4da8f827.js.map +1 -0
  75. package/dist/atomic/{p-1e59ce29.entry.js → p-4f34763d.entry.js} +2 -2
  76. package/dist/atomic/{p-7c3c5f07.entry.js → p-4f4c9a03.entry.js} +2 -2
  77. package/dist/atomic/p-4f4c9a03.entry.js.map +1 -0
  78. package/dist/atomic/{p-20764605.entry.js → p-52d5461a.entry.js} +2 -2
  79. package/dist/atomic/{p-406a288c.entry.js → p-6078667f.entry.js} +2 -2
  80. package/dist/atomic/{p-992bc2dc.js → p-60be00ad.js} +2 -2
  81. package/dist/atomic/{p-62e85c20.entry.js → p-6694e114.entry.js} +2 -2
  82. package/dist/atomic/p-6694e114.entry.js.map +1 -0
  83. package/dist/atomic/p-6f1bffa2.entry.js +2 -0
  84. package/dist/atomic/p-6f1bffa2.entry.js.map +1 -0
  85. package/dist/atomic/{p-3cbab25b.entry.js → p-7e971d15.entry.js} +2 -2
  86. package/dist/atomic/{p-4601eb93.entry.js → p-83d3857f.entry.js} +2 -2
  87. package/dist/atomic/{p-a1e5f767.entry.js → p-86f950a5.entry.js} +2 -2
  88. package/dist/atomic/p-86f950a5.entry.js.map +1 -0
  89. package/dist/atomic/{p-dbcef3a9.entry.js → p-87f69e53.entry.js} +2 -2
  90. package/dist/atomic/{p-6289adc7.entry.js → p-9239be63.entry.js} +2 -2
  91. package/dist/atomic/{p-aaea2ca1.entry.js → p-9a6ec803.entry.js} +2 -2
  92. package/dist/atomic/{p-aac849b0.entry.js → p-a3fac2ec.entry.js} +2 -2
  93. package/dist/atomic/{p-373448df.entry.js → p-a46d36dd.entry.js} +2 -2
  94. package/dist/atomic/p-a46d36dd.entry.js.map +1 -0
  95. package/dist/atomic/{p-e398835b.entry.js → p-b2b9e83f.entry.js} +2 -2
  96. package/dist/atomic/{p-8fdef8a3.entry.js → p-b313058c.entry.js} +2 -2
  97. package/dist/atomic/{p-0bdd730f.entry.js → p-b6ae0244.entry.js} +2 -2
  98. package/dist/atomic/{p-3a7a1a00.entry.js → p-bbfe727a.entry.js} +2 -2
  99. package/dist/atomic/{p-acd1a1d3.js → p-be0518ae.js} +1 -1
  100. package/dist/atomic/p-be0518ae.js.map +1 -0
  101. package/dist/atomic/{p-97ce3384.entry.js → p-be2a43f4.entry.js} +2 -2
  102. package/dist/atomic/{p-a5714bc4.entry.js → p-d211a422.entry.js} +2 -2
  103. package/dist/atomic/{p-c280cd05.js → p-e1cc5150.js} +1 -1
  104. package/dist/atomic/{p-9260dd7d.entry.js → p-ebd00891.entry.js} +2 -2
  105. package/dist/atomic/p-ebd00891.entry.js.map +1 -0
  106. package/dist/atomic/{p-5678a2ce.entry.js → p-f676b5ba.entry.js} +2 -2
  107. package/dist/atomic/p-f676b5ba.entry.js.map +1 -0
  108. package/dist/cjs/_loader.cjs.js +1 -1
  109. package/dist/cjs/{analytics-config-f75fd435.js → analytics-config-7fafe2ee.js} +2 -2
  110. package/dist/cjs/{analytics-config-f75fd435.js.map → analytics-config-7fafe2ee.js.map} +1 -1
  111. package/dist/cjs/atomic-category-facet.cjs.entry.js +1 -1
  112. package/dist/cjs/atomic-facet.cjs.entry.js +1 -1
  113. package/dist/cjs/atomic-field-condition.cjs.entry.js +3 -3
  114. package/dist/cjs/atomic-field-condition.cjs.entry.js.map +1 -1
  115. package/dist/cjs/atomic-format-currency.cjs.entry.js +1 -1
  116. package/dist/cjs/atomic-format-number.cjs.entry.js +1 -1
  117. package/dist/cjs/atomic-format-unit.cjs.entry.js +1 -1
  118. package/dist/cjs/atomic-insight-history-toggle.cjs.entry.js +2 -2
  119. package/dist/cjs/atomic-insight-history-toggle.cjs.entry.js.map +1 -1
  120. package/dist/cjs/atomic-insight-interface.cjs.entry.js +1 -1
  121. package/dist/cjs/atomic-insight-result-children-template.cjs.entry.js +5 -5
  122. package/dist/cjs/atomic-insight-result-children-template.cjs.entry.js.map +1 -1
  123. package/dist/cjs/atomic-insight-result-template.cjs.entry.js +5 -5
  124. package/dist/cjs/atomic-insight-result-template.cjs.entry.js.map +1 -1
  125. package/dist/cjs/atomic-insight-user-actions-toggle.cjs.entry.js +2 -2
  126. package/dist/cjs/atomic-insight-user-actions-toggle.cjs.entry.js.map +1 -1
  127. package/dist/cjs/atomic-numeric-facet.cjs.entry.js +1 -1
  128. package/dist/cjs/atomic-quickview-modal.cjs.entry.js +23 -23
  129. package/dist/cjs/atomic-quickview-modal.cjs.entry.js.map +1 -1
  130. package/dist/cjs/atomic-quickview.cjs.entry.js +1 -1
  131. package/dist/cjs/atomic-recs-interface.cjs.entry.js +1 -1
  132. package/dist/cjs/atomic-recs-result-template.cjs.entry.js +5 -5
  133. package/dist/cjs/atomic-recs-result-template.cjs.entry.js.map +1 -1
  134. package/dist/cjs/atomic-result-children-template.cjs.entry.js +4 -4
  135. package/dist/cjs/atomic-result-children-template.cjs.entry.js.map +1 -1
  136. package/dist/cjs/atomic-result-children.cjs.entry.js +1 -1
  137. package/dist/cjs/atomic-result-fields-list.cjs.entry.js +1 -1
  138. package/dist/cjs/atomic-result-link.cjs.entry.js +1 -1
  139. package/dist/cjs/atomic-result-list.cjs.entry.js +2 -2
  140. package/dist/cjs/atomic-result-list.cjs.entry.js.map +1 -1
  141. package/dist/cjs/atomic-result-placeholder_8.cjs.entry.js +1 -1
  142. package/dist/cjs/atomic-result-template.cjs.entry.js +4 -4
  143. package/dist/cjs/atomic-result-template.cjs.entry.js.map +1 -1
  144. package/dist/cjs/atomic-search-box-query-suggestions.cjs.entry.js +76 -0
  145. package/dist/cjs/atomic-search-box-query-suggestions.cjs.entry.js.map +1 -0
  146. package/dist/cjs/atomic-search-box.cjs.entry.js +3 -3
  147. package/dist/cjs/atomic-smart-snippet-feedback-modal.cjs.entry.js +2 -2
  148. package/dist/cjs/atomic-sort-dropdown.cjs.entry.js +2 -2
  149. package/dist/cjs/atomic-sort-expression.cjs.entry.js +1 -1
  150. package/dist/cjs/atomic-tab-manager.cjs.entry.js +1 -1
  151. package/dist/cjs/atomic.cjs.js +1 -1
  152. package/dist/cjs/clock-7aeb19d0.js +7 -0
  153. package/dist/cjs/clock-7aeb19d0.js.map +1 -0
  154. package/dist/cjs/index-757bc886.js +2 -6
  155. package/dist/cjs/{result-template-common-84bd4057.js → stencil-result-template-common-bb38948f.js} +2 -2
  156. package/dist/cjs/stencil-result-template-common-bb38948f.js.map +1 -0
  157. package/dist/cjs/{table-element-utils-4865b735.js → table-element-utils-2cc6dc82.js} +1 -1
  158. package/dist/cjs/table-element-utils-2cc6dc82.js.map +1 -0
  159. package/dist/cjs/version.cjs.js +1 -1
  160. package/dist/esm/_loader.js +1 -1
  161. package/dist/esm/{analytics-config-870dc878.js → analytics-config-a8c239d1.js} +2 -2
  162. package/dist/esm/{analytics-config-870dc878.js.map → analytics-config-a8c239d1.js.map} +1 -1
  163. package/dist/esm/atomic-category-facet.entry.js +1 -1
  164. package/dist/esm/atomic-facet.entry.js +1 -1
  165. package/dist/esm/atomic-field-condition.entry.js +2 -2
  166. package/dist/esm/atomic-field-condition.entry.js.map +1 -1
  167. package/dist/esm/atomic-format-currency.entry.js +1 -1
  168. package/dist/esm/atomic-format-number.entry.js +1 -1
  169. package/dist/esm/atomic-format-unit.entry.js +1 -1
  170. package/dist/esm/atomic-insight-history-toggle.entry.js +2 -2
  171. package/dist/esm/atomic-insight-history-toggle.entry.js.map +1 -1
  172. package/dist/esm/atomic-insight-interface.entry.js +1 -1
  173. package/dist/esm/atomic-insight-result-children-template.entry.js +2 -2
  174. package/dist/esm/atomic-insight-result-children-template.entry.js.map +1 -1
  175. package/dist/esm/atomic-insight-result-template.entry.js +2 -2
  176. package/dist/esm/atomic-insight-result-template.entry.js.map +1 -1
  177. package/dist/esm/atomic-insight-user-actions-toggle.entry.js +2 -2
  178. package/dist/esm/atomic-insight-user-actions-toggle.entry.js.map +1 -1
  179. package/dist/esm/atomic-numeric-facet.entry.js +1 -1
  180. package/dist/esm/atomic-quickview-modal.entry.js +23 -23
  181. package/dist/esm/atomic-quickview-modal.entry.js.map +1 -1
  182. package/dist/esm/atomic-quickview.entry.js +1 -1
  183. package/dist/esm/atomic-recs-interface.entry.js +1 -1
  184. package/dist/esm/atomic-recs-result-template.entry.js +2 -2
  185. package/dist/esm/atomic-recs-result-template.entry.js.map +1 -1
  186. package/dist/esm/atomic-result-children-template.entry.js +2 -2
  187. package/dist/esm/atomic-result-children-template.entry.js.map +1 -1
  188. package/dist/esm/atomic-result-children.entry.js +1 -1
  189. package/dist/esm/atomic-result-fields-list.entry.js +1 -1
  190. package/dist/esm/atomic-result-link.entry.js +1 -1
  191. package/dist/esm/atomic-result-list.entry.js +2 -2
  192. package/dist/esm/atomic-result-list.entry.js.map +1 -1
  193. package/dist/esm/atomic-result-placeholder_8.entry.js +1 -1
  194. package/dist/esm/atomic-result-template.entry.js +2 -2
  195. package/dist/esm/atomic-result-template.entry.js.map +1 -1
  196. package/dist/esm/atomic-search-box-query-suggestions.entry.js +72 -0
  197. package/dist/esm/atomic-search-box-query-suggestions.entry.js.map +1 -0
  198. package/dist/esm/atomic-search-box.entry.js +3 -3
  199. package/dist/esm/atomic-smart-snippet-feedback-modal.entry.js +2 -2
  200. package/dist/esm/atomic-sort-dropdown.entry.js +2 -2
  201. package/dist/esm/atomic-sort-expression.entry.js +1 -1
  202. package/dist/esm/atomic-tab-manager.entry.js +1 -1
  203. package/dist/esm/atomic.js +1 -1
  204. package/dist/esm/clock-b1f5d7f7.js +5 -0
  205. package/dist/esm/clock-b1f5d7f7.js.map +1 -0
  206. package/dist/esm/index-3f35faca.js +2 -6
  207. package/dist/esm/{result-template-common-995b94f8.js → stencil-result-template-common-19af5cfb.js} +2 -2
  208. package/dist/esm/stencil-result-template-common-19af5cfb.js.map +1 -0
  209. package/dist/esm/{table-element-utils-49d22ec6.js → table-element-utils-1dbc5ef6.js} +1 -1
  210. package/dist/esm/table-element-utils-1dbc5ef6.js.map +1 -0
  211. package/dist/esm/version.js +1 -1
  212. package/dist/types/components/commerce/atomic-commerce-breadbox/atomic-commerce-breadbox.d.ts +2 -3
  213. package/dist/types/components/common/facets/facet-search/facet-search-input-guard.d.ts +1 -1
  214. package/dist/types/components/common/no-items/guard.d.ts +1 -1
  215. package/dist/types/components/common/product-template/product-template-controller.d.ts +9 -19
  216. package/dist/types/components/common/product-template/stencil-product-template-common.d.ts +1 -1
  217. package/dist/types/components/common/refine-modal/guard.d.ts +1 -1
  218. package/dist/types/components/common/result-templates/result-template-controller.d.ts +16 -0
  219. package/dist/types/components/common/sort/sort-guard.d.ts +1 -1
  220. package/dist/types/components/common/template-controller/base-template-controller.d.ts +36 -0
  221. package/dist/types/components/common/template-controller/template-utils.d.ts +11 -0
  222. package/dist/types/components/common/validate-props-controller/validate-props-controller.d.ts +32 -0
  223. package/dist/types/components/insight/result-templates/atomic-insight-result-children-template/atomic-insight-result-children-template.d.ts +1 -1
  224. package/dist/types/components/search/atomic-relevance-inspector/atomic-relevance-inspector.d.ts +18 -8
  225. package/dist/types/components/search/atomic-search-box-recent-queries/atomic-search-box-recent-queries.d.ts +45 -0
  226. package/dist/types/components/search/atomic-search-interface/atomic-search-interface.d.ts +5 -3
  227. package/dist/types/components/search/index.d.ts +2 -0
  228. package/dist/types/components/search/result-templates/atomic-result-children-template/atomic-result-children-template.d.ts +1 -1
  229. package/dist/types/components.d.ts +0 -102
  230. package/dist/types/directives/hierarchical-path.d.ts +1 -1
  231. package/dist/types/utils/compare-utils.d.ts +9 -0
  232. package/docs/atomic-docs.json +1 -185
  233. package/package.json +1 -1
  234. package/dist/atomic/components/atomic-relevance-inspector.d.ts +0 -11
  235. package/dist/atomic/components/atomic-relevance-inspector.js +0 -53
  236. package/dist/atomic/components/atomic-relevance-inspector.js.map +0 -1
  237. package/dist/atomic/components/atomic-search-box-recent-queries.d.ts +0 -11
  238. package/dist/atomic/components/atomic-search-box-recent-queries.js +0 -8
  239. package/dist/atomic/components/atomic-search-box-recent-queries.js.map +0 -1
  240. package/dist/atomic/components/atomic-search-box-recent-queries2.js +0 -183
  241. package/dist/atomic/components/atomic-search-box-recent-queries2.js.map +0 -1
  242. package/dist/atomic/components/result-template-common.js.map +0 -1
  243. package/dist/atomic/p-2250f505.js.map +0 -1
  244. package/dist/atomic/p-373448df.entry.js.map +0 -1
  245. package/dist/atomic/p-5678a2ce.entry.js.map +0 -1
  246. package/dist/atomic/p-62e85c20.entry.js.map +0 -1
  247. package/dist/atomic/p-7c3c5f07.entry.js.map +0 -1
  248. package/dist/atomic/p-7fd5b6ac.entry.js.map +0 -1
  249. package/dist/atomic/p-9260dd7d.entry.js.map +0 -1
  250. package/dist/atomic/p-a1e5f767.entry.js.map +0 -1
  251. package/dist/atomic/p-acd1a1d3.js.map +0 -1
  252. package/dist/atomic/p-de687bed.entry.js +0 -2
  253. package/dist/atomic/p-de687bed.entry.js.map +0 -1
  254. package/dist/atomic/p-df4397ab.entry.js +0 -2
  255. package/dist/atomic/p-df4397ab.entry.js.map +0 -1
  256. package/dist/atomic/p-e7a25b00.entry.js.map +0 -1
  257. package/dist/cjs/atomic-relevance-inspector.cjs.entry.js +0 -38
  258. package/dist/cjs/atomic-relevance-inspector.cjs.entry.js.map +0 -1
  259. package/dist/cjs/atomic-search-box-query-suggestions_2.cjs.entry.js +0 -234
  260. package/dist/cjs/atomic-search-box-query-suggestions_2.cjs.entry.js.map +0 -1
  261. package/dist/cjs/clock-f03ff827.js +0 -7
  262. package/dist/cjs/clock-f03ff827.js.map +0 -1
  263. package/dist/cjs/result-template-common-84bd4057.js.map +0 -1
  264. package/dist/cjs/table-element-utils-4865b735.js.map +0 -1
  265. package/dist/esm/atomic-relevance-inspector.entry.js +0 -34
  266. package/dist/esm/atomic-relevance-inspector.entry.js.map +0 -1
  267. package/dist/esm/atomic-search-box-query-suggestions_2.entry.js +0 -229
  268. package/dist/esm/atomic-search-box-query-suggestions_2.entry.js.map +0 -1
  269. package/dist/esm/clock-add3e9a5.js +0 -5
  270. package/dist/esm/clock-add3e9a5.js.map +0 -1
  271. package/dist/esm/result-template-common-995b94f8.js.map +0 -1
  272. package/dist/esm/table-element-utils-49d22ec6.js.map +0 -1
  273. package/dist/types/components/common/product-template/product-template-common.d.ts +0 -6
  274. package/dist/types/components/search/search-box-suggestions/atomic-search-box-recent-queries/atomic-search-box-recent-queries.d.ts +0 -37
  275. /package/dist/atomic/components/components/{search/atomic-table-result → common}/table-element-utils.js +0 -0
  276. /package/dist/atomic/{p-475124d2.entry.js.map → p-01511388.entry.js.map} +0 -0
  277. /package/dist/atomic/{p-60800b2f.entry.js.map → p-0ed76e65.entry.js.map} +0 -0
  278. /package/dist/atomic/{p-16f6c1f3.entry.js.map → p-2fb49fe8.entry.js.map} +0 -0
  279. /package/dist/atomic/{p-13391e75.entry.js.map → p-3549a469.entry.js.map} +0 -0
  280. /package/dist/atomic/{p-88af4470.entry.js.map → p-40c1dfcb.entry.js.map} +0 -0
  281. /package/dist/atomic/{p-1e59ce29.entry.js.map → p-4f34763d.entry.js.map} +0 -0
  282. /package/dist/atomic/{p-20764605.entry.js.map → p-52d5461a.entry.js.map} +0 -0
  283. /package/dist/atomic/{p-406a288c.entry.js.map → p-6078667f.entry.js.map} +0 -0
  284. /package/dist/atomic/{p-992bc2dc.js.map → p-60be00ad.js.map} +0 -0
  285. /package/dist/atomic/{p-3cbab25b.entry.js.map → p-7e971d15.entry.js.map} +0 -0
  286. /package/dist/atomic/{p-4601eb93.entry.js.map → p-83d3857f.entry.js.map} +0 -0
  287. /package/dist/atomic/{p-dbcef3a9.entry.js.map → p-87f69e53.entry.js.map} +0 -0
  288. /package/dist/atomic/{p-6289adc7.entry.js.map → p-9239be63.entry.js.map} +0 -0
  289. /package/dist/atomic/{p-aaea2ca1.entry.js.map → p-9a6ec803.entry.js.map} +0 -0
  290. /package/dist/atomic/{p-aac849b0.entry.js.map → p-a3fac2ec.entry.js.map} +0 -0
  291. /package/dist/atomic/{p-e398835b.entry.js.map → p-b2b9e83f.entry.js.map} +0 -0
  292. /package/dist/atomic/{p-8fdef8a3.entry.js.map → p-b313058c.entry.js.map} +0 -0
  293. /package/dist/atomic/{p-0bdd730f.entry.js.map → p-b6ae0244.entry.js.map} +0 -0
  294. /package/dist/atomic/{p-3a7a1a00.entry.js.map → p-bbfe727a.entry.js.map} +0 -0
  295. /package/dist/atomic/{p-97ce3384.entry.js.map → p-be2a43f4.entry.js.map} +0 -0
  296. /package/dist/atomic/{p-a5714bc4.entry.js.map → p-d211a422.entry.js.map} +0 -0
  297. /package/dist/atomic/{p-c280cd05.js.map → p-e1cc5150.js.map} +0 -0
  298. /package/dist/types/components/common/result-templates/{result-template-common.d.ts → stencil-result-template-common.d.ts} +0 -0
  299. /package/dist/types/components/{search/atomic-table-result → common}/table-element-utils.d.ts +0 -0
@@ -4,6 +4,7 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
4
4
  else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
5
  return c > 3 && r && Object.defineProperty(target, key, r), r;
6
6
  };
7
+ import { ProductTemplatesHelpers } from '@coveo/headless/commerce';
7
8
  import { html, LitElement } from 'lit';
8
9
  import { customElement, property, state } from 'lit/decorators.js';
9
10
  import { bindings } from "../../../decorators/bindings";
@@ -11,7 +12,7 @@ import { createProductContextController } from "../../../decorators/commerce/pro
11
12
  import { errorGuard } from "../../../decorators/error-guard";
12
13
  import { LightDomMixin } from "../../../mixins/light-dom";
13
14
  import { mapProperty } from "../../../utils/props-utils";
14
- import { makeDefinedConditions, makeMatchConditions, } from '../../common/product-template/product-template-common';
15
+ import { makeDefinedConditions, makeMatchConditions, } from '../../common/template-controller/template-utils';
15
16
  /**
16
17
  * The `atomic-product-field-condition` component renders its children only when all of the conditions specified through its props are satisfied.
17
18
  * The condition properties can be based on any top-level product property of the `product` object, not restricted to fields (e.g., `ec_name`).
@@ -26,8 +27,8 @@ let AtomicProductFieldCondition = class AtomicProductFieldCondition extends Ligh
26
27
  initialize() { }
27
28
  get conditions() {
28
29
  return [
29
- ...makeDefinedConditions(this.ifDefined, this.ifNotDefined),
30
- ...makeMatchConditions(this.mustMatch, this.mustNotMatch),
30
+ ...makeDefinedConditions(this.ifDefined, this.ifNotDefined, ProductTemplatesHelpers),
31
+ ...makeMatchConditions(this.mustMatch, this.mustNotMatch, ProductTemplatesHelpers),
31
32
  ];
32
33
  }
33
34
  render() {
@@ -4,12 +4,13 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
4
4
  else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
5
  return c > 3 && r && Object.defineProperty(target, key, r), r;
6
6
  };
7
+ import { ProductTemplatesHelpers } from '@coveo/headless/commerce';
7
8
  import { html, LitElement, nothing } from 'lit';
8
9
  import { customElement, property, state } from 'lit/decorators.js';
9
10
  import { errorGuard } from "../../../decorators/error-guard";
10
11
  import { mapProperty } from "../../../utils/props-utils";
11
- import { makeMatchConditions } from '../../common/product-template/product-template-common';
12
12
  import { ProductTemplateController } from '../../common/product-template/product-template-controller';
13
+ import { makeMatchConditions } from '../../common/template-controller/template-utils';
13
14
  import '../atomic-product/atomic-product';
14
15
  /**
15
16
  * * A product template determines the format of the products, depending on the conditions that are defined for each template.
@@ -43,7 +44,7 @@ let AtomicProductTemplate = class AtomicProductTemplate extends LitElement {
43
44
  }
44
45
  connectedCallback() {
45
46
  super.connectedCallback();
46
- this.productTemplateController.matchConditions = makeMatchConditions(this.mustMatch, this.mustNotMatch);
47
+ this.productTemplateController.matchConditions = makeMatchConditions(this.mustMatch, this.mustNotMatch, ProductTemplatesHelpers);
47
48
  }
48
49
  /**
49
50
  * Gets the product template to apply based on the evaluated conditions.
@@ -2,7 +2,7 @@ import { html } from 'lit';
2
2
  import { keyed } from 'lit/directives/keyed.js';
3
3
  import { map } from 'lit/directives/map.js';
4
4
  import { ref } from 'lit/directives/ref.js';
5
- import { tableElementTagName } from '../../search/atomic-table-result/table-element-utils';
5
+ import { tableElementTagName } from '../table-element-utils';
6
6
  export const renderTableLayout = ({ props }) => {
7
7
  const { host, listClasses, logger } = props;
8
8
  const fieldColumns = getFieldTableColumns(props);
@@ -1,94 +1,29 @@
1
- import { aggregate } from '../../../utils/utils';
2
- import { getTemplateNodeType } from './product-template-common';
3
- export class ProductTemplateController {
1
+ import { BaseTemplateController, } from "../template-controller/base-template-controller";
2
+ export class ProductTemplateController extends BaseTemplateController {
4
3
  constructor(host, validParents, allowEmpty = false) {
5
- this.host = host;
6
- this.validParents = validParents;
7
- this.allowEmpty = allowEmpty;
8
- this.matchConditions = [];
9
- this.host.addController(this);
10
- }
11
- hostConnected() {
12
- this.validateTemplate();
13
- }
14
- setError(error) {
15
- this.host.error = error;
16
- }
17
- validateTemplate() {
18
- const hasValidParent = this.validParents
19
- .map((p) => p.toUpperCase())
20
- .includes(this.parentElement?.nodeName || '');
21
- const tagName = this.host.nodeName.toLowerCase();
22
- if (!hasValidParent) {
23
- this.setError(new Error(ProductTemplateController.ERRORS.invalidParent(tagName, this.validParents)));
24
- return;
25
- }
26
- if (this.parentAttr('display') === 'grid') {
27
- this.gridCellLinkTarget = this.parentAttr('grid-cell-link-target');
28
- }
29
- if (!this.template) {
30
- this.setError(new Error(ProductTemplateController.ERRORS.missingTemplate(tagName)));
31
- return;
32
- }
33
- if (!this.allowEmpty && !this.template.innerHTML.trim()) {
34
- this.setError(new Error(ProductTemplateController.ERRORS.emptyTemplate(tagName)));
35
- return;
36
- }
37
- if (this.template.content.querySelector('script')) {
38
- console.warn(ProductTemplateController.WARNINGS.scriptTag, this.host);
39
- }
40
- const { section, other } = groupNodesByType(this.template.content.childNodes);
41
- if (section?.length && other?.length) {
42
- console.warn(ProductTemplateController.WARNINGS.sectionMix, this.host, {
43
- section,
44
- other,
45
- });
46
- }
4
+ super(host, validParents, allowEmpty);
47
5
  }
48
6
  getTemplate(conditions) {
49
- if (this.host.error) {
7
+ const baseTemplate = this.getBaseTemplate(conditions);
8
+ if (!baseTemplate) {
50
9
  return null;
51
10
  }
52
11
  return {
53
- conditions: conditions.concat(this.matchConditions),
54
- content: getTemplateElement(this.host).content,
55
- linkContent: this.getLinkTemplateElement(this.host).content,
56
- priority: 1,
12
+ conditions: baseTemplate.conditions,
13
+ content: baseTemplate.content,
14
+ linkContent: baseTemplate.linkContent,
15
+ priority: baseTemplate.priority,
16
+ };
17
+ }
18
+ getWarnings() {
19
+ return {
20
+ scriptTag: 'Any "script" tags defined inside of "template" elements are not supported and will not be executed when the products are rendered.',
21
+ sectionMix: 'Product templates should only contain section elements or non-section elements, not both. Future updates could unpredictably affect this product template.',
57
22
  };
58
23
  }
59
24
  getDefaultLinkTemplateElement() {
60
25
  const linkTemplate = document.createElement('template');
61
- linkTemplate.innerHTML = `<atomic-product-link>${this.gridCellLinkTarget ? `<a slot="attributes" target="${this.gridCellLinkTarget}"></a>` : ''}</atomic-product-link>`;
26
+ linkTemplate.innerHTML = `<atomic-product-link>${this.currentGridCellLinkTarget ? `<a slot="attributes" target="${this.currentGridCellLinkTarget}"></a>` : ''}</atomic-product-link>`;
62
27
  return linkTemplate;
63
28
  }
64
- getLinkTemplateElement(host) {
65
- return (host.querySelector('template[slot="link"]') ??
66
- this.getDefaultLinkTemplateElement());
67
- }
68
- get parentElement() {
69
- return this.host.parentElement;
70
- }
71
- get template() {
72
- return this.host.querySelector('template');
73
- }
74
- parentAttr(attribute) {
75
- return this.parentElement?.attributes.getNamedItem(attribute)?.value;
76
- }
77
- }
78
- ProductTemplateController.ERRORS = {
79
- invalidParent: (tagName, validParents) => `The "${tagName}" component has to be the child of one of the following: ${validParents
80
- .map((p) => `"${p.toLowerCase()}"`)
81
- .join(', ')}.`,
82
- missingTemplate: (tagName) => `The "${tagName}" component must contain a "template" element as a child.`,
83
- emptyTemplate: (tagName) => `The "template" tag inside "${tagName}" cannot be empty.`,
84
- };
85
- ProductTemplateController.WARNINGS = {
86
- scriptTag: 'Any "script" tags defined inside of "template" elements are not supported and will not be executed when the products are rendered.',
87
- sectionMix: 'Product templates should only contain section elements or non-section elements. Future updates could unpredictably affect this product template.',
88
- };
89
- function getTemplateElement(host) {
90
- return host.querySelector('template:not([slot])');
91
- }
92
- function groupNodesByType(nodes) {
93
- return aggregate(Array.from(nodes), (node) => getTemplateNodeType(node));
94
29
  }
@@ -0,0 +1,89 @@
1
+ import { aggregate } from "../../../utils/utils";
2
+ import { getTemplateNodeType } from './template-utils';
3
+ export class BaseTemplateController {
4
+ constructor(host, validParents, allowEmpty = false) {
5
+ this.host = host;
6
+ this.validParents = validParents;
7
+ this.allowEmpty = allowEmpty;
8
+ this.matchConditions = [];
9
+ this.host.addController(this);
10
+ }
11
+ hostConnected() {
12
+ this.validateTemplate();
13
+ }
14
+ getLinkTemplateElement(host) {
15
+ return (host.querySelector('template[slot="link"]') ??
16
+ this.getDefaultLinkTemplateElement());
17
+ }
18
+ setError(error) {
19
+ this.host.error = error;
20
+ }
21
+ getBaseTemplate(conditions) {
22
+ if (this.host.error) {
23
+ return null;
24
+ }
25
+ return {
26
+ conditions: conditions.concat(this.matchConditions),
27
+ content: getTemplateElement(this.host).content,
28
+ linkContent: this.getLinkTemplateElement(this.host).content,
29
+ priority: 1,
30
+ };
31
+ }
32
+ get parentElement() {
33
+ return this.host.parentElement;
34
+ }
35
+ get template() {
36
+ return this.host.querySelector('template');
37
+ }
38
+ parentAttr(attribute) {
39
+ return this.parentElement?.attributes.getNamedItem(attribute)?.value;
40
+ }
41
+ get currentGridCellLinkTarget() {
42
+ return this.gridCellLinkTarget;
43
+ }
44
+ validateTemplate() {
45
+ const hasValidParent = this.validParents
46
+ .map((p) => p.toUpperCase())
47
+ .includes(this.parentElement?.nodeName || '');
48
+ const tagName = this.host.nodeName.toLowerCase();
49
+ if (!hasValidParent) {
50
+ this.setError(new Error(BaseTemplateController.ERRORS.invalidParent(tagName, this.validParents)));
51
+ return;
52
+ }
53
+ if (this.parentAttr('display') === 'grid') {
54
+ this.gridCellLinkTarget = this.parentAttr('grid-cell-link-target');
55
+ }
56
+ if (!this.template) {
57
+ this.setError(new Error(BaseTemplateController.ERRORS.missingTemplate(tagName)));
58
+ return;
59
+ }
60
+ if (!this.allowEmpty && !this.template.innerHTML.trim()) {
61
+ this.setError(new Error(BaseTemplateController.ERRORS.emptyTemplate(tagName)));
62
+ return;
63
+ }
64
+ const warnings = this.getWarnings();
65
+ if (this.template.content.querySelector('script')) {
66
+ console.warn(warnings.scriptTag, this.host);
67
+ }
68
+ const { section, other } = groupNodesByType(this.template.content.childNodes);
69
+ if (section?.length && other?.length) {
70
+ console.warn(warnings.sectionMix, this.host, {
71
+ section,
72
+ other,
73
+ });
74
+ }
75
+ }
76
+ }
77
+ BaseTemplateController.ERRORS = {
78
+ invalidParent: (tagName, validParents) => `The "${tagName}" component has to be the child of one of the following: ${validParents
79
+ .map((p) => `"${p.toLowerCase()}"`)
80
+ .join(', ')}.`,
81
+ missingTemplate: (tagName) => `The "${tagName}" component must contain a "template" element as a child.`,
82
+ emptyTemplate: (tagName) => `The "template" tag inside "${tagName}" cannot be empty.`,
83
+ };
84
+ function getTemplateElement(host) {
85
+ return host.querySelector('template:not([slot])');
86
+ }
87
+ function groupNodesByType(nodes) {
88
+ return aggregate(Array.from(nodes), (node) => getTemplateNodeType(node));
89
+ }
@@ -1,8 +1,7 @@
1
- import { ProductTemplatesHelpers, } from '@coveo/headless/commerce';
2
- import { intersection } from '../../../utils/set';
3
- import { isElementNode, isVisualNode } from '../../../utils/utils';
4
- import { tableElementTagName } from '../../search/atomic-table-result/table-element-utils';
5
- import { isResultSectionNode } from '../layout/item-layout-sections';
1
+ import { isResultSectionNode } from "../layout/item-layout-sections";
2
+ import { tableElementTagName } from "../table-element-utils";
3
+ import { intersection } from "../../../utils/set";
4
+ import { isElementNode, isVisualNode } from "../../../utils/utils";
6
5
  export function getTemplateNodeType(node) {
7
6
  if (isResultSectionNode(node)) {
8
7
  return 'section';
@@ -16,7 +15,7 @@ export function getTemplateNodeType(node) {
16
15
  }
17
16
  return 'other';
18
17
  }
19
- export function makeMatchConditions(mustMatch, mustNotMatch) {
18
+ export function makeMatchConditions(mustMatch, mustNotMatch, helpers) {
20
19
  const conditions = [];
21
20
  for (const field in mustMatch) {
22
21
  if (mustNotMatch[field]) {
@@ -25,25 +24,25 @@ export function makeMatchConditions(mustMatch, mustNotMatch) {
25
24
  const commonValues = intersection(mustNotMatchValues, mustMatchValues);
26
25
  if (commonValues.size > 0) {
27
26
  console.error(`Conflicting match conditions for field ${field}, the template will be ignored.`, commonValues);
28
- return [() => false];
27
+ return [(() => false)];
29
28
  }
30
29
  }
31
- conditions.push(ProductTemplatesHelpers.fieldMustMatch(field, mustMatch[field]));
30
+ conditions.push(helpers.fieldMustMatch(field, mustMatch[field]));
32
31
  }
33
32
  for (const field in mustNotMatch) {
34
- conditions.push(ProductTemplatesHelpers.fieldMustNotMatch(field, mustNotMatch[field]));
33
+ conditions.push(helpers.fieldMustNotMatch(field, mustNotMatch[field]));
35
34
  }
36
35
  return conditions;
37
36
  }
38
- export function makeDefinedConditions(ifDefined, ifNotDefined) {
37
+ export function makeDefinedConditions(ifDefined, ifNotDefined, helpers) {
39
38
  const conditions = [];
40
39
  if (ifDefined) {
41
40
  const fieldNames = ifDefined.split(',');
42
- conditions.push(ProductTemplatesHelpers.fieldsMustBeDefined(fieldNames));
41
+ conditions.push(helpers.fieldsMustBeDefined(fieldNames));
43
42
  }
44
43
  if (ifNotDefined) {
45
44
  const fieldNames = ifNotDefined.split(',');
46
- conditions.push(ProductTemplatesHelpers.fieldsMustNotBeDefined(fieldNames));
45
+ conditions.push(helpers.fieldsMustNotBeDefined(fieldNames));
47
46
  }
48
47
  return conditions;
49
48
  }
@@ -0,0 +1,50 @@
1
+ import { deepEqual } from "../../../utils/compare-utils";
2
+ /**
3
+ * A reactive controller that validates the props of a Lit component against a
4
+ * provided Bueno schema.
5
+ *
6
+ * It validates the props when the host is connected to the DOM and whenever
7
+ * the host updates, revalidating only if the props have changed since the last
8
+ * validation.
9
+ *
10
+ * If validation fails, the controller sets the `error` property on the host.
11
+ */
12
+ export class ValidatePropsController {
13
+ /**
14
+ * Creates a `ValidatePropsController`.
15
+ *
16
+ * @param host The host element.
17
+ * @param getProps A function that returns the current props to validate.
18
+ * @param schema The Bueno schema to validate the props against.
19
+ */
20
+ constructor(host, getProps, schema) {
21
+ this.host = host;
22
+ this.getProps = getProps;
23
+ this.schema = schema;
24
+ host.addController(this);
25
+ }
26
+ hostConnected() {
27
+ this.currentProps = this.getProps();
28
+ this._validateProps();
29
+ }
30
+ hostUpdate() {
31
+ this.currentProps = this.getProps();
32
+ if (deepEqual(this.currentProps, this.previousProps)) {
33
+ return;
34
+ }
35
+ // @ts-expect-error: we need to clear the error.
36
+ this.host.error = undefined;
37
+ this._validateProps();
38
+ }
39
+ _validateProps() {
40
+ try {
41
+ this.schema.validate(this.currentProps);
42
+ }
43
+ catch (error) {
44
+ this.host.error = error;
45
+ }
46
+ finally {
47
+ this.previousProps = this.currentProps;
48
+ }
49
+ }
50
+ }
@@ -0,0 +1,100 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ import { getOrganizationEndpoint } from '@coveo/headless';
8
+ import { html, LitElement, nothing } from 'lit';
9
+ import { customElement, state } from 'lit/decorators.js';
10
+ import { renderButton } from "../../common/button";
11
+ import { withTailwindStyles } from "../../../decorators/with-tailwind-styles.js";
12
+ import "../../common/atomic-modal/atomic-modal";
13
+ import { bindingGuard } from "../../../decorators/binding-guard";
14
+ import { bindings } from "../../../decorators/bindings";
15
+ import { errorGuard } from "../../../decorators/error-guard";
16
+ /**
17
+ * The `atomic-relevance-inspector` component is used internally to offer insight on search page relevance, as well as information to help troubleshoot issues during development.
18
+ *
19
+ * @internal
20
+ */
21
+ let AtomicRelevanceInspector = class AtomicRelevanceInspector extends LitElement {
22
+ constructor() {
23
+ super(...arguments);
24
+ this.open = false;
25
+ this.initialize = () => {
26
+ this.bindings.interfaceElement.addEventListener('dblclick', this.handleRelevanceInspectorDoubleClick);
27
+ };
28
+ this.handleRelevanceInspectorDoubleClick = (e) => {
29
+ if (e.altKey) {
30
+ this.open = !this.open;
31
+ }
32
+ };
33
+ }
34
+ disconnectedCallback() {
35
+ this.bindings.interfaceElement.removeEventListener('dblclick', this.handleRelevanceInspectorDoubleClick);
36
+ }
37
+ render() {
38
+ return html `
39
+ <atomic-modal
40
+ .isOpen=${this.open}
41
+ @close=${() => this.handleCloseRelevanceInspector()}
42
+ exportparts="footer"
43
+ >
44
+ <p slot="header">Open the relevance inspector</p>
45
+ <p slot="body">
46
+ The Relevance Inspector will open in the Coveo Administration Console.
47
+ </p>
48
+ <div slot="footer" class="flex w-full items-center justify-end">
49
+ ${renderButton({
50
+ props: {
51
+ style: 'outline-primary',
52
+ class: 'mr-2 p-2',
53
+ onClick: () => this.handleCloseRelevanceInspector(),
54
+ text: 'Ignore',
55
+ },
56
+ })(nothing)}
57
+ ${renderButton({
58
+ props: {
59
+ style: 'primary',
60
+ class: 'p-2',
61
+ onClick: () => {
62
+ window.open(this.adminHref, '_blank');
63
+ this.handleCloseRelevanceInspector();
64
+ },
65
+ text: 'Open',
66
+ },
67
+ })(nothing)}
68
+ </div>
69
+ </atomic-modal>
70
+ `;
71
+ }
72
+ handleCloseRelevanceInspector() {
73
+ this.open = false;
74
+ }
75
+ get adminHref() {
76
+ const { organizationId, environment } = this.bindings.engine.state.configuration;
77
+ const admin = getOrganizationEndpoint(organizationId, environment, 'admin');
78
+ const { searchResponseId } = this.bindings.engine.state.search;
79
+ return `${admin}/admin/#/${organizationId}/search/relevanceInspector/${searchResponseId}`;
80
+ }
81
+ };
82
+ __decorate([
83
+ state()
84
+ ], AtomicRelevanceInspector.prototype, "bindings", void 0);
85
+ __decorate([
86
+ state()
87
+ ], AtomicRelevanceInspector.prototype, "error", void 0);
88
+ __decorate([
89
+ state()
90
+ ], AtomicRelevanceInspector.prototype, "open", void 0);
91
+ __decorate([
92
+ bindingGuard(),
93
+ errorGuard()
94
+ ], AtomicRelevanceInspector.prototype, "render", null);
95
+ AtomicRelevanceInspector = __decorate([
96
+ customElement('atomic-relevance-inspector'),
97
+ bindings(),
98
+ withTailwindStyles
99
+ ], AtomicRelevanceInspector);
100
+ export { AtomicRelevanceInspector };
@@ -0,0 +1,137 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ import { buildRecentQueriesList, } from '@coveo/headless';
8
+ import { html, LitElement, nothing } from 'lit';
9
+ import { customElement, property, state } from 'lit/decorators.js';
10
+ import { errorGuard } from "../../../decorators/error-guard";
11
+ import { SafeStorage, StorageItems } from "../../../utils/local-storage-utils";
12
+ import { once } from "../../../utils/utils";
13
+ const Clock = "<svg fill=\"none\" stroke=\"currentColor\" stroke-linejoin=\"round\" stroke-linecap=\"round\" viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"8\" cy=\"8\" r=\"7.5\"/><path d=\"m8.5 4.5v4\"/><path d=\"m10.3066 10.1387-1.80932-1.5768\"/></svg>";
14
+ import { getPartialRecentQueryClearElement, getPartialRecentQueryElement, renderRecentQuery, renderRecentQueryClear, } from '../../common/suggestions/recent-queries';
15
+ import { dispatchSearchBoxSuggestionsEvent } from '../../common/suggestions/suggestions-events';
16
+ /**
17
+ * The `atomic-search-box-recent-queries` component can be added as a child of an `atomic-search-box` component, allowing for the configuration of recent query suggestions.
18
+ */
19
+ let AtomicSearchBoxRecentQueries = class AtomicSearchBoxRecentQueries extends LitElement {
20
+ constructor() {
21
+ super(...arguments);
22
+ /**
23
+ * The maximum number of suggestions to display when the user types in the input field.
24
+ */
25
+ this.maxWithQuery = 3;
26
+ this.warnUser = once(() => this.bindings.engine.logger.warn('The recent queries feature is deactivated because analytics are disabled.'));
27
+ }
28
+ connectedCallback() {
29
+ super.connectedCallback();
30
+ try {
31
+ dispatchSearchBoxSuggestionsEvent((bindings) => {
32
+ this.bindings = bindings;
33
+ return this.initialize();
34
+ }, this, ['atomic-search-box']);
35
+ }
36
+ catch (error) {
37
+ this.error = error;
38
+ }
39
+ }
40
+ initialize() {
41
+ this.storage = new SafeStorage();
42
+ this.recentQueriesList = buildRecentQueriesList(this.bindings.engine, {
43
+ initialState: { queries: this.retrieveLocalStorage() },
44
+ options: {
45
+ maxLength: 1000,
46
+ clearFilters: this.bindings.clearFilters,
47
+ },
48
+ });
49
+ this.recentQueriesList.subscribe(() => this.updateLocalStorage());
50
+ return {
51
+ position: Array.from(this.parentNode.children).indexOf(this),
52
+ renderItems: () => this.renderItems(),
53
+ };
54
+ }
55
+ retrieveLocalStorage() {
56
+ return this.storage.getParsedJSON(StorageItems.RECENT_QUERIES, []);
57
+ }
58
+ updateLocalStorage() {
59
+ if (!this.recentQueriesList.state.analyticsEnabled) {
60
+ return this.disableFeature();
61
+ }
62
+ return this.storage.setJSON(StorageItems.RECENT_QUERIES, this.recentQueriesList.state.queries);
63
+ }
64
+ disableFeature() {
65
+ this.warnUser();
66
+ this.storage.removeItem(StorageItems.RECENT_QUERIES);
67
+ }
68
+ renderItems() {
69
+ if (!this.recentQueriesList.state.analyticsEnabled) {
70
+ return [];
71
+ }
72
+ const query = this.bindings.searchBoxController.state.value;
73
+ const hasQuery = query !== '';
74
+ const max = hasQuery ? this.maxWithQuery : this.maxWithoutQuery;
75
+ const filteredQueries = this.recentQueriesList.state.queries
76
+ .filter((recentQuery) => recentQuery.toLowerCase().startsWith(query.toLowerCase()))
77
+ .slice(0, max);
78
+ const suggestionElements = filteredQueries.map((value) => this.renderItem(value));
79
+ if (suggestionElements.length) {
80
+ suggestionElements.unshift(this.renderClear());
81
+ }
82
+ return suggestionElements;
83
+ }
84
+ renderClear() {
85
+ const partialItem = getPartialRecentQueryClearElement(this.bindings.i18n);
86
+ return {
87
+ ...partialItem,
88
+ content: renderRecentQueryClear({ i18n: this.bindings.i18n }),
89
+ onSelect: () => {
90
+ this.recentQueriesList.clear();
91
+ this.bindings.triggerSuggestions();
92
+ },
93
+ };
94
+ }
95
+ renderItem(value) {
96
+ const query = this.bindings.searchBoxController.state.value;
97
+ const partialItem = getPartialRecentQueryElement(value, this.bindings.i18n);
98
+ return {
99
+ ...partialItem,
100
+ content: renderRecentQuery({
101
+ icon: this.icon || Clock,
102
+ query,
103
+ value,
104
+ }),
105
+ onSelect: () => {
106
+ if (this.bindings.isStandalone) {
107
+ this.bindings.searchBoxController.updateText(value);
108
+ this.bindings.searchBoxController.submit();
109
+ return;
110
+ }
111
+ this.recentQueriesList.executeRecentQuery(this.recentQueriesList.state.queries.indexOf(value));
112
+ },
113
+ };
114
+ }
115
+ render() {
116
+ return html `${nothing}`;
117
+ }
118
+ };
119
+ __decorate([
120
+ state()
121
+ ], AtomicSearchBoxRecentQueries.prototype, "error", void 0);
122
+ __decorate([
123
+ property()
124
+ ], AtomicSearchBoxRecentQueries.prototype, "icon", void 0);
125
+ __decorate([
126
+ property({ type: Number, attribute: 'max-with-query', reflect: true })
127
+ ], AtomicSearchBoxRecentQueries.prototype, "maxWithQuery", void 0);
128
+ __decorate([
129
+ property({ type: Number, attribute: 'max-without-query', reflect: true })
130
+ ], AtomicSearchBoxRecentQueries.prototype, "maxWithoutQuery", void 0);
131
+ __decorate([
132
+ errorGuard()
133
+ ], AtomicSearchBoxRecentQueries.prototype, "render", null);
134
+ AtomicSearchBoxRecentQueries = __decorate([
135
+ customElement('atomic-search-box-recent-queries')
136
+ ], AtomicSearchBoxRecentQueries);
137
+ export { AtomicSearchBoxRecentQueries };