@coveo/atomic 3.34.0-pre.af85860e30 → 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 (307) 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/analytics-config.js +1 -1
  6. package/dist/atomic/components/atomic-field-condition.js +1 -1
  7. package/dist/atomic/components/atomic-field-condition.js.map +1 -1
  8. package/dist/atomic/components/atomic-insight-history-toggle.js +2 -2
  9. package/dist/atomic/components/atomic-insight-history-toggle.js.map +1 -1
  10. package/dist/atomic/components/atomic-insight-result-children-template.js +1 -1
  11. package/dist/atomic/components/atomic-insight-result-children-template.js.map +1 -1
  12. package/dist/atomic/components/atomic-insight-result-template.js +1 -1
  13. package/dist/atomic/components/atomic-insight-result-template.js.map +1 -1
  14. package/dist/atomic/components/atomic-insight-user-actions-toggle.js +2 -2
  15. package/dist/atomic/components/atomic-insight-user-actions-toggle.js.map +1 -1
  16. package/dist/{esm/sections-ae00b53a.js → atomic/components/atomic-layout-section-utils.js} +1 -1
  17. package/dist/atomic/components/atomic-layout-section-utils.js.map +1 -0
  18. package/dist/atomic/components/atomic-quickview-modal2.js +22 -22
  19. package/dist/atomic/components/atomic-quickview-modal2.js.map +1 -1
  20. package/dist/atomic/components/atomic-recs-result-template.js +1 -1
  21. package/dist/atomic/components/atomic-recs-result-template.js.map +1 -1
  22. package/dist/atomic/components/atomic-refine-modal2.js +2 -2
  23. package/dist/atomic/components/atomic-refine-modal2.js.map +1 -1
  24. package/dist/atomic/components/atomic-result-children-template.js +1 -1
  25. package/dist/atomic/components/atomic-result-children-template.js.map +1 -1
  26. package/dist/atomic/components/atomic-result-list.js.map +1 -1
  27. package/dist/atomic/components/atomic-result-template.js +1 -1
  28. package/dist/atomic/components/atomic-result-template.js.map +1 -1
  29. package/dist/atomic/components/atomic-search-box.js +2 -8
  30. package/dist/atomic/components/atomic-search-box.js.map +1 -1
  31. package/dist/atomic/components/atomic-smart-snippet-feedback-modal2.js +2 -2
  32. package/dist/atomic/components/atomic-tab-manager.js +1 -1
  33. package/dist/atomic/components/clock.js +2 -2
  34. package/dist/atomic/components/components/commerce/atomic-product-field-condition/atomic-product-field-condition.js +4 -3
  35. package/dist/atomic/components/components/commerce/atomic-product-template/atomic-product-template.js +3 -2
  36. package/dist/atomic/components/components/common/atomic-layout-section/layout.js +1 -1
  37. package/dist/atomic/components/components/common/item-list/table-layout.js +1 -1
  38. package/dist/atomic/components/components/common/layout/display-options.js +1 -1
  39. package/dist/atomic/components/components/common/layout/{sections.js → item-layout-sections.js} +1 -1
  40. package/dist/atomic/components/components/common/product-template/product-template-controller.js +16 -81
  41. package/dist/atomic/components/components/common/template-controller/base-template-controller.js +89 -0
  42. package/dist/atomic/components/components/common/{product-template/product-template-common.js → template-controller/template-utils.js} +11 -12
  43. package/dist/atomic/components/components/insight/atomic-insight-layout/insight-layout.js +1 -1
  44. package/dist/atomic/components/components/search/atomic-search-box-recent-queries/atomic-search-box-recent-queries.js +137 -0
  45. package/dist/atomic/components/components/search/index.js +1 -0
  46. package/dist/atomic/components/components/search/lazy-index.js +1 -0
  47. package/dist/atomic/components/display-options.js +1 -1
  48. package/dist/atomic/components/display-options.js.map +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/insight-layout.js +1 -1
  52. package/dist/atomic/components/insight-layout.js.map +1 -1
  53. package/dist/atomic/components/{sections2.js → item-layout-sections.js} +1 -1
  54. package/dist/atomic/components/item-layout-sections.js.map +1 -0
  55. package/dist/atomic/components/{result-template-common.js → stencil-result-template-common.js} +2 -2
  56. package/dist/atomic/components/stencil-result-template-common.js.map +1 -0
  57. package/dist/atomic/components/table-element-utils.js.map +1 -1
  58. package/dist/atomic/{p-2caa1859.js → p-0e62bdd6.js} +2 -2
  59. package/dist/atomic/p-0e62bdd6.js.map +1 -0
  60. package/dist/atomic/{p-5f706e3d.entry.js → p-170c7da6.entry.js} +2 -2
  61. package/dist/atomic/{p-3857d6a3.entry.js → p-1bbaf206.entry.js} +2 -2
  62. package/dist/atomic/{p-4723ffa5.entry.js → p-20b33c18.entry.js} +2 -2
  63. package/dist/atomic/{p-a4d277c7.entry.js → p-2213060b.entry.js} +2 -2
  64. package/dist/atomic/p-2213060b.entry.js.map +1 -0
  65. package/dist/atomic/{p-d1795580.entry.js → p-2895c42c.entry.js} +2 -2
  66. package/dist/atomic/p-2895c42c.entry.js.map +1 -0
  67. package/dist/atomic/{p-bd3542d2.entry.js → p-36112c34.entry.js} +2 -2
  68. package/dist/atomic/p-36112c34.entry.js.map +1 -0
  69. package/dist/atomic/{p-8bf425b0.entry.js → p-40c1dfcb.entry.js} +2 -2
  70. package/dist/atomic/{p-7709fba4.js → p-4da8f827.js} +2 -2
  71. package/dist/atomic/p-4da8f827.js.map +1 -0
  72. package/dist/atomic/{p-0c098321.entry.js → p-4f34763d.entry.js} +2 -2
  73. package/dist/atomic/{p-86ca8ef9.entry.js → p-4f4c9a03.entry.js} +2 -2
  74. package/dist/atomic/p-4f4c9a03.entry.js.map +1 -0
  75. package/dist/atomic/{p-d82b85ab.entry.js → p-52d5461a.entry.js} +2 -2
  76. package/dist/atomic/{p-406a288c.entry.js → p-6078667f.entry.js} +2 -2
  77. package/dist/atomic/{p-77d560aa.js → p-60be00ad.js} +2 -2
  78. package/dist/atomic/p-6694e114.entry.js +2 -0
  79. package/dist/atomic/p-6694e114.entry.js.map +1 -0
  80. package/dist/atomic/p-6f1bffa2.entry.js +2 -0
  81. package/dist/atomic/p-6f1bffa2.entry.js.map +1 -0
  82. package/dist/atomic/{p-93da1f4e.entry.js → p-6f34dd3a.entry.js} +2 -2
  83. package/dist/atomic/{p-0c0b8d41.entry.js → p-768b172e.entry.js} +2 -2
  84. package/dist/atomic/{p-0b5efb51.entry.js → p-86f950a5.entry.js} +2 -2
  85. package/dist/atomic/p-86f950a5.entry.js.map +1 -0
  86. package/dist/atomic/{p-6289adc7.entry.js → p-9239be63.entry.js} +2 -2
  87. package/dist/atomic/{p-ed8e5c4d.entry.js → p-98dd6df1.entry.js} +2 -2
  88. package/dist/atomic/{p-736f4d7e.entry.js → p-9a6ec803.entry.js} +2 -2
  89. package/dist/atomic/{p-ba8d24ff.entry.js → p-a3fac2ec.entry.js} +2 -2
  90. package/dist/atomic/{p-d6e04719.entry.js → p-a46d36dd.entry.js} +2 -2
  91. package/dist/atomic/p-a46d36dd.entry.js.map +1 -0
  92. package/dist/atomic/{p-1db20a4a.entry.js → p-a5f66ecd.entry.js} +2 -2
  93. package/dist/atomic/{p-acd1a1d3.js → p-be0518ae.js} +1 -1
  94. package/dist/atomic/p-be0518ae.js.map +1 -0
  95. package/dist/atomic/{p-577d34ba.entry.js → p-c4fb6426.entry.js} +2 -2
  96. package/dist/atomic/{p-9c7dbbdf.js → p-cc2b2231.js} +1 -1
  97. package/dist/atomic/p-cc2b2231.js.map +1 -0
  98. package/dist/atomic/{p-9faad55b.entry.js → p-dc128135.entry.js} +2 -2
  99. package/dist/atomic/{p-97748161.js → p-dc28ee14.js} +1 -1
  100. package/dist/{esm/sections-d787040b.js.map → atomic/p-dc28ee14.js.map} +1 -1
  101. package/dist/atomic/{p-c280cd05.js → p-e1cc5150.js} +1 -1
  102. package/dist/atomic/{p-27b8404c.js → p-e62fc40e.js} +2 -2
  103. package/dist/atomic/p-e62fc40e.js.map +1 -0
  104. package/dist/atomic/{p-f71b14b2.entry.js → p-ebd00891.entry.js} +2 -2
  105. package/dist/atomic/p-ebd00891.entry.js.map +1 -0
  106. package/dist/atomic/{p-65dd9017.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-81ebc0cd.js → analytics-config-7fafe2ee.js} +2 -2
  110. package/dist/cjs/{analytics-config-81ebc0cd.js.map → analytics-config-7fafe2ee.js.map} +1 -1
  111. package/dist/cjs/atomic-field-condition.cjs.entry.js +4 -4
  112. package/dist/cjs/atomic-field-condition.cjs.entry.js.map +1 -1
  113. package/dist/cjs/atomic-folded-result-list.cjs.entry.js +2 -2
  114. package/dist/cjs/atomic-insight-folded-result-list.cjs.entry.js +2 -2
  115. package/dist/cjs/atomic-insight-history-toggle.cjs.entry.js +2 -2
  116. package/dist/cjs/atomic-insight-history-toggle.cjs.entry.js.map +1 -1
  117. package/dist/cjs/atomic-insight-interface.cjs.entry.js +3 -3
  118. package/dist/cjs/atomic-insight-layout.cjs.entry.js +2 -2
  119. package/dist/cjs/atomic-insight-result-children-template.cjs.entry.js +6 -6
  120. package/dist/cjs/atomic-insight-result-children-template.cjs.entry.js.map +1 -1
  121. package/dist/cjs/atomic-insight-result-list.cjs.entry.js +2 -2
  122. package/dist/cjs/atomic-insight-result-template.cjs.entry.js +6 -6
  123. package/dist/cjs/atomic-insight-result-template.cjs.entry.js.map +1 -1
  124. package/dist/cjs/atomic-insight-result.cjs.entry.js +2 -2
  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-ipx-recs-list.cjs.entry.js +2 -2
  128. package/dist/cjs/{sections-4b4af2f8.js → atomic-layout-section-utils-08b4fbcd.js} +1 -1
  129. package/dist/cjs/atomic-layout-section-utils-08b4fbcd.js.map +1 -0
  130. package/dist/cjs/atomic-quickview-modal.cjs.entry.js +22 -22
  131. package/dist/cjs/atomic-quickview-modal.cjs.entry.js.map +1 -1
  132. package/dist/cjs/atomic-recs-interface.cjs.entry.js +1 -1
  133. package/dist/cjs/atomic-recs-list.cjs.entry.js +2 -2
  134. package/dist/cjs/atomic-recs-result-template.cjs.entry.js +6 -6
  135. package/dist/cjs/atomic-recs-result-template.cjs.entry.js.map +1 -1
  136. package/dist/cjs/atomic-recs-result.cjs.entry.js +2 -2
  137. package/dist/cjs/atomic-refine-modal.cjs.entry.js +4 -4
  138. package/dist/cjs/atomic-refine-modal.cjs.entry.js.map +1 -1
  139. package/dist/cjs/atomic-result-children-template.cjs.entry.js +5 -5
  140. package/dist/cjs/atomic-result-children-template.cjs.entry.js.map +1 -1
  141. package/dist/cjs/atomic-result-list.cjs.entry.js +3 -3
  142. package/dist/cjs/atomic-result-list.cjs.entry.js.map +1 -1
  143. package/dist/cjs/atomic-result-placeholder_8.cjs.entry.js +2 -2
  144. package/dist/cjs/atomic-result-template.cjs.entry.js +5 -5
  145. package/dist/cjs/atomic-result-template.cjs.entry.js.map +1 -1
  146. package/dist/cjs/atomic-result.cjs.entry.js +2 -2
  147. package/dist/cjs/atomic-search-box-query-suggestions.cjs.entry.js +76 -0
  148. package/dist/cjs/atomic-search-box-query-suggestions.cjs.entry.js.map +1 -0
  149. package/dist/cjs/atomic-smart-snippet-feedback-modal.cjs.entry.js +2 -2
  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/{display-options-14f05862.js → display-options-69531e8d.js} +4 -4
  155. package/dist/cjs/display-options-69531e8d.js.map +1 -0
  156. package/dist/cjs/index-757bc886.js +2 -2
  157. package/dist/cjs/{insight-layout-355a94dd.js → insight-layout-b6ff92fd.js} +11 -11
  158. package/dist/cjs/insight-layout-b6ff92fd.js.map +1 -0
  159. package/dist/cjs/{sections-fbb93b53.js → item-layout-sections-b09ba4b3.js} +1 -1
  160. package/dist/cjs/item-layout-sections-b09ba4b3.js.map +1 -0
  161. package/dist/cjs/{result-template-common-88359dad.js → stencil-result-template-common-bb38948f.js} +4 -4
  162. package/dist/cjs/stencil-result-template-common-bb38948f.js.map +1 -0
  163. package/dist/cjs/{table-element-utils-4865b735.js → table-element-utils-2cc6dc82.js} +1 -1
  164. package/dist/cjs/table-element-utils-2cc6dc82.js.map +1 -0
  165. package/dist/cjs/version.cjs.js +1 -1
  166. package/dist/esm/_loader.js +1 -1
  167. package/dist/esm/{analytics-config-a15cf5c0.js → analytics-config-a8c239d1.js} +2 -2
  168. package/dist/esm/{analytics-config-a15cf5c0.js.map → analytics-config-a8c239d1.js.map} +1 -1
  169. package/dist/esm/atomic-field-condition.entry.js +3 -3
  170. package/dist/esm/atomic-field-condition.entry.js.map +1 -1
  171. package/dist/esm/atomic-folded-result-list.entry.js +2 -2
  172. package/dist/esm/atomic-insight-folded-result-list.entry.js +2 -2
  173. package/dist/esm/atomic-insight-history-toggle.entry.js +2 -2
  174. package/dist/esm/atomic-insight-history-toggle.entry.js.map +1 -1
  175. package/dist/esm/atomic-insight-interface.entry.js +3 -3
  176. package/dist/esm/atomic-insight-layout.entry.js +2 -2
  177. package/dist/esm/atomic-insight-result-children-template.entry.js +3 -3
  178. package/dist/esm/atomic-insight-result-children-template.entry.js.map +1 -1
  179. package/dist/esm/atomic-insight-result-list.entry.js +2 -2
  180. package/dist/esm/atomic-insight-result-template.entry.js +3 -3
  181. package/dist/esm/atomic-insight-result-template.entry.js.map +1 -1
  182. package/dist/esm/atomic-insight-result.entry.js +2 -2
  183. package/dist/esm/atomic-insight-user-actions-toggle.entry.js +2 -2
  184. package/dist/esm/atomic-insight-user-actions-toggle.entry.js.map +1 -1
  185. package/dist/esm/atomic-ipx-recs-list.entry.js +2 -2
  186. package/dist/{atomic/components/sections.js → esm/atomic-layout-section-utils-c8ca7445.js} +1 -1
  187. package/dist/esm/atomic-layout-section-utils-c8ca7445.js.map +1 -0
  188. package/dist/esm/atomic-quickview-modal.entry.js +22 -22
  189. package/dist/esm/atomic-quickview-modal.entry.js.map +1 -1
  190. package/dist/esm/atomic-recs-interface.entry.js +1 -1
  191. package/dist/esm/atomic-recs-list.entry.js +2 -2
  192. package/dist/esm/atomic-recs-result-template.entry.js +3 -3
  193. package/dist/esm/atomic-recs-result-template.entry.js.map +1 -1
  194. package/dist/esm/atomic-recs-result.entry.js +2 -2
  195. package/dist/esm/atomic-refine-modal.entry.js +2 -2
  196. package/dist/esm/atomic-refine-modal.entry.js.map +1 -1
  197. package/dist/esm/atomic-result-children-template.entry.js +3 -3
  198. package/dist/esm/atomic-result-children-template.entry.js.map +1 -1
  199. package/dist/esm/atomic-result-list.entry.js +3 -3
  200. package/dist/esm/atomic-result-list.entry.js.map +1 -1
  201. package/dist/esm/atomic-result-placeholder_8.entry.js +2 -2
  202. package/dist/esm/atomic-result-template.entry.js +3 -3
  203. package/dist/esm/atomic-result-template.entry.js.map +1 -1
  204. package/dist/esm/atomic-result.entry.js +2 -2
  205. package/dist/esm/atomic-search-box-query-suggestions.entry.js +72 -0
  206. package/dist/esm/atomic-search-box-query-suggestions.entry.js.map +1 -0
  207. package/dist/esm/atomic-smart-snippet-feedback-modal.entry.js +2 -2
  208. package/dist/esm/atomic-tab-manager.entry.js +1 -1
  209. package/dist/esm/atomic.js +1 -1
  210. package/dist/esm/clock-b1f5d7f7.js +5 -0
  211. package/dist/esm/clock-b1f5d7f7.js.map +1 -0
  212. package/dist/esm/{display-options-c16840c6.js → display-options-1199eed5.js} +2 -2
  213. package/dist/esm/display-options-1199eed5.js.map +1 -0
  214. package/dist/esm/index-3f35faca.js +2 -2
  215. package/dist/esm/{insight-layout-776b87f2.js → insight-layout-a1e4b795.js} +2 -2
  216. package/dist/esm/insight-layout-a1e4b795.js.map +1 -0
  217. package/dist/esm/{sections-d787040b.js → item-layout-sections-8afb5049.js} +1 -1
  218. package/dist/esm/item-layout-sections-8afb5049.js.map +1 -0
  219. package/dist/esm/{result-template-common-ac9fecab.js → stencil-result-template-common-19af5cfb.js} +3 -3
  220. package/dist/esm/stencil-result-template-common-19af5cfb.js.map +1 -0
  221. package/dist/esm/{table-element-utils-49d22ec6.js → table-element-utils-1dbc5ef6.js} +1 -1
  222. package/dist/esm/table-element-utils-1dbc5ef6.js.map +1 -0
  223. package/dist/esm/version.js +1 -1
  224. package/dist/types/components/common/atomic-layout-section/atomic-layout-section.d.ts +1 -1
  225. package/dist/types/components/common/product-template/product-template-controller.d.ts +9 -19
  226. package/dist/types/components/common/product-template/stencil-product-template-common.d.ts +1 -1
  227. package/dist/types/components/common/result-templates/result-template-controller.d.ts +16 -0
  228. package/dist/types/components/common/template-controller/base-template-controller.d.ts +36 -0
  229. package/dist/types/components/common/template-controller/template-utils.d.ts +11 -0
  230. package/dist/types/components/insight/result-templates/atomic-insight-result-children-template/atomic-insight-result-children-template.d.ts +1 -1
  231. package/dist/types/components/search/atomic-search-box-recent-queries/atomic-search-box-recent-queries.d.ts +45 -0
  232. package/dist/types/components/search/index.d.ts +1 -0
  233. package/dist/types/components/search/result-templates/atomic-result-children-template/atomic-result-children-template.d.ts +1 -1
  234. package/dist/types/components.d.ts +0 -49
  235. package/docs/atomic-docs.json +1 -98
  236. package/package.json +1 -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/components/sections.js.map +0 -1
  244. package/dist/atomic/components/sections2.js.map +0 -1
  245. package/dist/atomic/p-0b5efb51.entry.js.map +0 -1
  246. package/dist/atomic/p-250f34d4.entry.js +0 -2
  247. package/dist/atomic/p-250f34d4.entry.js.map +0 -1
  248. package/dist/atomic/p-27b8404c.js.map +0 -1
  249. package/dist/atomic/p-2caa1859.js.map +0 -1
  250. package/dist/atomic/p-65dd9017.entry.js.map +0 -1
  251. package/dist/atomic/p-7709fba4.js.map +0 -1
  252. package/dist/atomic/p-86ca8ef9.entry.js.map +0 -1
  253. package/dist/atomic/p-97748161.js.map +0 -1
  254. package/dist/atomic/p-9c7dbbdf.js.map +0 -1
  255. package/dist/atomic/p-a4d277c7.entry.js.map +0 -1
  256. package/dist/atomic/p-acd1a1d3.js.map +0 -1
  257. package/dist/atomic/p-bd3542d2.entry.js.map +0 -1
  258. package/dist/atomic/p-d1795580.entry.js.map +0 -1
  259. package/dist/atomic/p-d6e04719.entry.js.map +0 -1
  260. package/dist/atomic/p-ea1b81fa.entry.js +0 -2
  261. package/dist/atomic/p-ea1b81fa.entry.js.map +0 -1
  262. package/dist/atomic/p-f71b14b2.entry.js.map +0 -1
  263. package/dist/cjs/atomic-search-box-query-suggestions_2.cjs.entry.js +0 -234
  264. package/dist/cjs/atomic-search-box-query-suggestions_2.cjs.entry.js.map +0 -1
  265. package/dist/cjs/clock-f03ff827.js +0 -7
  266. package/dist/cjs/clock-f03ff827.js.map +0 -1
  267. package/dist/cjs/display-options-14f05862.js.map +0 -1
  268. package/dist/cjs/insight-layout-355a94dd.js.map +0 -1
  269. package/dist/cjs/result-template-common-88359dad.js.map +0 -1
  270. package/dist/cjs/sections-4b4af2f8.js.map +0 -1
  271. package/dist/cjs/sections-fbb93b53.js.map +0 -1
  272. package/dist/cjs/table-element-utils-4865b735.js.map +0 -1
  273. package/dist/esm/atomic-search-box-query-suggestions_2.entry.js +0 -229
  274. package/dist/esm/atomic-search-box-query-suggestions_2.entry.js.map +0 -1
  275. package/dist/esm/clock-add3e9a5.js +0 -5
  276. package/dist/esm/clock-add3e9a5.js.map +0 -1
  277. package/dist/esm/display-options-c16840c6.js.map +0 -1
  278. package/dist/esm/insight-layout-776b87f2.js.map +0 -1
  279. package/dist/esm/result-template-common-ac9fecab.js.map +0 -1
  280. package/dist/esm/sections-ae00b53a.js.map +0 -1
  281. package/dist/esm/table-element-utils-49d22ec6.js.map +0 -1
  282. package/dist/types/components/common/product-template/product-template-common.d.ts +0 -6
  283. package/dist/types/components/search/search-box-suggestions/atomic-search-box-recent-queries/atomic-search-box-recent-queries.d.ts +0 -37
  284. /package/dist/atomic/components/components/common/atomic-layout-section/{sections.js → atomic-layout-section-utils.js} +0 -0
  285. /package/dist/atomic/components/components/{search/atomic-table-result → common}/table-element-utils.js +0 -0
  286. /package/dist/atomic/{p-5f706e3d.entry.js.map → p-170c7da6.entry.js.map} +0 -0
  287. /package/dist/atomic/{p-3857d6a3.entry.js.map → p-1bbaf206.entry.js.map} +0 -0
  288. /package/dist/atomic/{p-4723ffa5.entry.js.map → p-20b33c18.entry.js.map} +0 -0
  289. /package/dist/atomic/{p-8bf425b0.entry.js.map → p-40c1dfcb.entry.js.map} +0 -0
  290. /package/dist/atomic/{p-0c098321.entry.js.map → p-4f34763d.entry.js.map} +0 -0
  291. /package/dist/atomic/{p-d82b85ab.entry.js.map → p-52d5461a.entry.js.map} +0 -0
  292. /package/dist/atomic/{p-406a288c.entry.js.map → p-6078667f.entry.js.map} +0 -0
  293. /package/dist/atomic/{p-77d560aa.js.map → p-60be00ad.js.map} +0 -0
  294. /package/dist/atomic/{p-93da1f4e.entry.js.map → p-6f34dd3a.entry.js.map} +0 -0
  295. /package/dist/atomic/{p-0c0b8d41.entry.js.map → p-768b172e.entry.js.map} +0 -0
  296. /package/dist/atomic/{p-6289adc7.entry.js.map → p-9239be63.entry.js.map} +0 -0
  297. /package/dist/atomic/{p-ed8e5c4d.entry.js.map → p-98dd6df1.entry.js.map} +0 -0
  298. /package/dist/atomic/{p-736f4d7e.entry.js.map → p-9a6ec803.entry.js.map} +0 -0
  299. /package/dist/atomic/{p-ba8d24ff.entry.js.map → p-a3fac2ec.entry.js.map} +0 -0
  300. /package/dist/atomic/{p-1db20a4a.entry.js.map → p-a5f66ecd.entry.js.map} +0 -0
  301. /package/dist/atomic/{p-577d34ba.entry.js.map → p-c4fb6426.entry.js.map} +0 -0
  302. /package/dist/atomic/{p-9faad55b.entry.js.map → p-dc128135.entry.js.map} +0 -0
  303. /package/dist/atomic/{p-c280cd05.js.map → p-e1cc5150.js.map} +0 -0
  304. /package/dist/types/components/common/atomic-layout-section/{sections.d.ts → atomic-layout-section-utils.d.ts} +0 -0
  305. /package/dist/types/components/common/layout/{sections.d.ts → item-layout-sections.d.ts} +0 -0
  306. /package/dist/types/components/common/result-templates/{result-template-common.d.ts → stencil-result-template-common.d.ts} +0 -0
  307. /package/dist/types/components/{search/atomic-table-result → common}/table-element-utils.d.ts +0 -0
@@ -1,234 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- const index = require('./index-757bc886.js');
6
- const headless = require('@coveo/headless');
7
- const search = require('./search-a4774f02.js');
8
- const stencilQuerySuggestions = require('./stencil-query-suggestions-03268ecc.js');
9
- const suggestionsEvents = require('./suggestions-events-63dd0640.js');
10
- const clock = require('./clock-f03ff827.js');
11
- const localStorageUtils = require('./local-storage-utils-380ce22b.js');
12
- const utils = require('./utils-7153ae6b.js');
13
- const stringUtils = require('./string-utils-bdf08f8c.js');
14
- require('./dom-utils-d4790328.js');
15
- require('./event-utils-9bfcf3c5.js');
16
- require('./purify-85b542e2.js');
17
- require('./_commonjsHelpers-b3309d7b.js');
18
-
19
- const AtomicSearchBoxQuerySuggestions = class {
20
- constructor(hostRef) {
21
- index.registerInstance(this, hostRef);
22
- this.error = undefined;
23
- this.icon = undefined;
24
- this.maxWithQuery = undefined;
25
- this.maxWithoutQuery = undefined;
26
- }
27
- componentWillLoad() {
28
- try {
29
- suggestionsEvents.dispatchSearchBoxSuggestionsEvent((bindings) => {
30
- this.bindings = bindings;
31
- return this.initialize();
32
- }, this.host, ['atomic-search-box']);
33
- }
34
- catch (error) {
35
- this.error = error;
36
- }
37
- }
38
- initialize() {
39
- const engine = this.bindings.engine;
40
- const { registerQuerySuggest, fetchQuerySuggestions } = headless.loadQuerySuggestActions(engine);
41
- engine.dispatch(registerQuerySuggest({
42
- id: this.bindings.id,
43
- count: this.bindings.numberOfQueries,
44
- }));
45
- return {
46
- position: Array.from(this.host.parentNode.children).indexOf(this.host),
47
- onInput: () => engine.dispatch(fetchQuerySuggestions({
48
- id: this.bindings.id,
49
- })),
50
- renderItems: () => this.renderItems(),
51
- };
52
- }
53
- renderItems() {
54
- const hasQuery = this.bindings.searchBoxController.state.value !== '';
55
- const max = hasQuery ? this.maxWithQuery : this.maxWithoutQuery;
56
- return this.bindings.searchBoxController.state.suggestions
57
- .slice(0, max)
58
- .map((suggestion) => this.renderItem(suggestion));
59
- }
60
- renderItem(suggestion) {
61
- const hasQuery = this.bindings.searchBoxController.state.value !== '';
62
- const partialItem = stencilQuerySuggestions.getPartialSearchBoxSuggestionElement(suggestion, this.bindings.i18n);
63
- return {
64
- ...partialItem,
65
- content: (index.h(stencilQuerySuggestions.QuerySuggestionContainer, null, index.h(stencilQuerySuggestions.QuerySuggestionIcon, { icon: this.icon || search.SearchIcon, hasSuggestion: this.bindings.getSuggestions().length > 1 }), index.h(stencilQuerySuggestions.QuerySuggestionText, { suggestion: suggestion, hasQuery: hasQuery }))),
66
- onSelect: () => {
67
- this.bindings.searchBoxController.selectSuggestion(suggestion.rawValue);
68
- },
69
- };
70
- }
71
- render() {
72
- if (this.error) {
73
- return (index.h("atomic-component-error", { key: 'c5e8f0a3254a31cdae54c36868f70432c1673888', element: this.host, error: this.error }));
74
- }
75
- }
76
- get host() { return index.getElement(this); }
77
- };
78
-
79
- const getPartialRecentQueryElement = (value, i18n) => {
80
- return {
81
- part: 'recent-query-item',
82
- query: value,
83
- key: `recent-${stringUtils.encodeForDomAttribute(value)}`,
84
- ariaLabel: i18n.t('recent-query-suggestion-label', {
85
- query: value,
86
- interpolation: { escapeValue: false },
87
- }),
88
- };
89
- };
90
- const getPartialRecentQueryClearElement = (i18n) => {
91
- return {
92
- key: 'recent-query-clear',
93
- ariaLabel: i18n.t('clear-recent-searches', {
94
- interpolation: { escapeValue: false },
95
- }),
96
- part: 'recent-query-title-item suggestion-divider',
97
- hideIfLast: true,
98
- };
99
- };
100
- const RecentQueriesContainer = (_, children) => {
101
- return (index.h("div", { part: "recent-query-content", class: "flex items-center text-left break-all" }, children));
102
- };
103
- const RecentQueryIcon = ({ icon, }) => {
104
- return (index.h("atomic-icon", { part: "recent-query-icon", icon: icon, class: "mr-2 h-4 w-4 shrink-0" }));
105
- };
106
- const RecentQueryText = ({ query, value, }) => {
107
- if (query === '') {
108
- return (index.h("span", { part: "recent-query-text", class: "line-clamp-2 break-all" }, value));
109
- }
110
- return (index.h("span", { part: "recent-query-text", class: "line-clamp-2 break-all", innerHTML: headless.HighlightUtils.highlightString({
111
- content: value,
112
- openingDelimiter: '<span part="recent-query-text-highlight" class="font-bold">',
113
- closingDelimiter: '</span>',
114
- highlights: [
115
- {
116
- offset: query.length,
117
- length: value.length - query.length,
118
- },
119
- ],
120
- }) }));
121
- };
122
- const RecentQueryClear = ({ i18n, }) => {
123
- return (index.h("div", { part: "recent-query-title-content", class: "flex w-full justify-between" },
124
- index.h("span", { class: "font-bold", part: "recent-query-title" }, i18n.t('recent-searches')),
125
- index.h("span", { part: "recent-query-clear" }, i18n.t('clear'))));
126
- };
127
-
128
- const AtomicSearchBoxRecentQueries = class {
129
- constructor(hostRef) {
130
- index.registerInstance(this, hostRef);
131
- /**
132
- * The maximum number of suggestions that will be displayed if the user has typed something into the input field.
133
- */
134
- this.maxWithQuery = 3;
135
- this.warnUser = utils.once(() => this.bindings.engine.logger.warn('Because analytics are disabled, the recent queries feature is deactivated.'));
136
- this.error = undefined;
137
- this.icon = undefined;
138
- this.maxWithQuery = 3;
139
- this.maxWithoutQuery = undefined;
140
- }
141
- componentWillLoad() {
142
- try {
143
- suggestionsEvents.dispatchSearchBoxSuggestionsEvent((bindings) => {
144
- this.bindings = bindings;
145
- return this.initialize();
146
- }, this.host, ['atomic-search-box']);
147
- }
148
- catch (error) {
149
- this.error = error;
150
- }
151
- }
152
- renderIcon() {
153
- return this.icon || clock.Clock;
154
- }
155
- initialize() {
156
- this.storage = new localStorageUtils.SafeStorage();
157
- this.recentQueriesList = headless.buildRecentQueriesList(this.bindings.engine, {
158
- initialState: { queries: this.retrieveLocalStorage() },
159
- options: { maxLength: 1000, clearFilters: this.bindings.clearFilters },
160
- });
161
- this.recentQueriesList.subscribe(() => this.updateLocalStorage());
162
- return {
163
- position: Array.from(this.host.parentNode.children).indexOf(this.host),
164
- renderItems: () => this.renderItems(),
165
- };
166
- }
167
- retrieveLocalStorage() {
168
- return this.storage.getParsedJSON(localStorageUtils.StorageItems.RECENT_QUERIES, []);
169
- }
170
- updateLocalStorage() {
171
- if (!this.recentQueriesList.state.analyticsEnabled) {
172
- return this.disableFeature();
173
- }
174
- return this.storage.setJSON(localStorageUtils.StorageItems.RECENT_QUERIES, this.recentQueriesList.state.queries);
175
- }
176
- disableFeature() {
177
- this.warnUser();
178
- this.storage.removeItem(localStorageUtils.StorageItems.RECENT_QUERIES);
179
- }
180
- renderItems() {
181
- if (!this.recentQueriesList.state.analyticsEnabled) {
182
- return [];
183
- }
184
- const query = this.bindings.searchBoxController.state.value;
185
- const hasQuery = query !== '';
186
- const max = hasQuery ? this.maxWithQuery : this.maxWithoutQuery;
187
- const filteredQueries = this.recentQueriesList.state.queries
188
- .filter((recentQuery) => recentQuery.toLowerCase().startsWith(query.toLowerCase()))
189
- .slice(0, max);
190
- const suggestionElements = filteredQueries.map((value) => this.renderItem(value));
191
- if (suggestionElements.length) {
192
- suggestionElements.unshift(this.renderClear());
193
- }
194
- return suggestionElements;
195
- }
196
- renderClear() {
197
- const partialItem = getPartialRecentQueryClearElement(this.bindings.i18n);
198
- return {
199
- ...partialItem,
200
- content: index.h(RecentQueryClear, { i18n: this.bindings.i18n }),
201
- onSelect: () => {
202
- this.recentQueriesList.clear();
203
- this.bindings.triggerSuggestions();
204
- },
205
- };
206
- }
207
- renderItem(value) {
208
- const query = this.bindings.searchBoxController.state.value;
209
- const partialItem = getPartialRecentQueryElement(value, this.bindings.i18n);
210
- return {
211
- ...partialItem,
212
- content: (index.h(RecentQueriesContainer, null, index.h(RecentQueryIcon, { icon: this.renderIcon() }), index.h(RecentQueryText, { query: query, value: value }))),
213
- onSelect: () => {
214
- if (this.bindings.isStandalone) {
215
- this.bindings.searchBoxController.updateText(value);
216
- this.bindings.searchBoxController.submit();
217
- return;
218
- }
219
- this.recentQueriesList.executeRecentQuery(this.recentQueriesList.state.queries.indexOf(value));
220
- },
221
- };
222
- }
223
- render() {
224
- if (this.error) {
225
- return (index.h("atomic-component-error", { key: 'a428e82c6ce29e81704777cbbf3bea98937b906a', element: this.host, error: this.error }));
226
- }
227
- }
228
- get host() { return index.getElement(this); }
229
- };
230
-
231
- exports.atomic_search_box_query_suggestions = AtomicSearchBoxQuerySuggestions;
232
- exports.atomic_search_box_recent_queries = AtomicSearchBoxRecentQueries;
233
-
234
- //# sourceMappingURL=atomic-search-box-query-suggestions_2.cjs.entry.js.map
@@ -1 +0,0 @@
1
- {"file":"atomic-search-box-query-suggestions.atomic-search-box-recent-queries.entry.cjs.js","mappings":"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","names":["dispatchSearchBoxSuggestionsEvent","loadQuerySuggestActions","getPartialSearchBoxSuggestionElement","h","QuerySuggestionContainer","QuerySuggestionIcon","SearchIcon","QuerySuggestionText","encodeForDomAttribute","HighlightUtils","once","Clock","SafeStorage","buildRecentQueriesList","StorageItems"],"sources":["src/components/search/search-box-suggestions/atomic-search-box-query-suggestions/atomic-search-box-query-suggestions.tsx","src/components/common/suggestions/stencil-recent-queries.tsx","src/components/search/search-box-suggestions/atomic-search-box-recent-queries/atomic-search-box-recent-queries.tsx"],"sourcesContent":["import {\n loadQuerySuggestActions,\n SearchBox,\n SearchEngine,\n Suggestion,\n} from '@coveo/headless';\nimport {Component, Element, Prop, State, h} from '@stencil/core';\nimport SearchIcon from '../../../../images/search.svg';\nimport {\n getPartialSearchBoxSuggestionElement,\n QuerySuggestionContainer,\n QuerySuggestionIcon,\n QuerySuggestionText,\n} from '../../../common/suggestions/stencil-query-suggestions';\nimport {\n dispatchSearchBoxSuggestionsEvent,\n} from '../../../common/suggestions/suggestions-events';\nimport type {\n SearchBoxSuggestionElement,\n SearchBoxSuggestions,\n SearchBoxSuggestionsBindings,\n} from '../../../common/suggestions/suggestions-types';\n\n/**\n * The `atomic-search-box-query-suggestions` component can be added as a child of an `atomic-search-box` component, allowing for the configuration of query suggestion behavior.\n */\n@Component({\n tag: 'atomic-search-box-query-suggestions',\n shadow: true,\n})\nexport class AtomicSearchBoxQuerySuggestions {\n private bindings!: SearchBoxSuggestionsBindings<SearchBox>;\n @Element() private host!: HTMLElement;\n\n @State() public error!: Error;\n\n /**\n * The SVG icon to display.\n *\n * - Use a value that starts with `http://`, `https://`, `./`, or `../`, to fetch and display an icon from a given location.\n * - Use a value that starts with `assets://`, to display an icon from the Atomic package.\n * - Use a stringified SVG to display it directly.\n */\n @Prop() public icon?: string;\n\n /**\n * The maximum number of suggestions that will be displayed if the user has typed something into the input field.\n */\n @Prop({reflect: true}) public maxWithQuery?: number;\n /**\n * The maximum number of suggestions that will be displayed initially when the input field is empty.\n */\n @Prop({reflect: true}) public maxWithoutQuery?: number;\n\n componentWillLoad() {\n try {\n dispatchSearchBoxSuggestionsEvent<SearchBox>(\n (bindings) => {\n this.bindings = bindings;\n return this.initialize();\n },\n this.host,\n ['atomic-search-box']\n );\n } catch (error) {\n this.error = error as Error;\n }\n }\n\n private initialize(): SearchBoxSuggestions {\n const engine = this.bindings.engine as SearchEngine<{\n querySet: string;\n querySuggest: string;\n }>;\n const {registerQuerySuggest, fetchQuerySuggestions} =\n loadQuerySuggestActions(engine);\n\n engine.dispatch(\n registerQuerySuggest({\n id: this.bindings.id,\n count: this.bindings.numberOfQueries,\n })\n );\n\n return {\n position: Array.from(this.host.parentNode!.children).indexOf(this.host),\n onInput: () =>\n engine.dispatch(\n fetchQuerySuggestions({\n id: this.bindings.id,\n })\n ),\n renderItems: () => this.renderItems(),\n };\n }\n\n private renderItems(): SearchBoxSuggestionElement[] {\n const hasQuery = this.bindings.searchBoxController.state.value !== '';\n const max = hasQuery ? this.maxWithQuery : this.maxWithoutQuery;\n return this.bindings.searchBoxController.state.suggestions\n .slice(0, max)\n .map((suggestion) => this.renderItem(suggestion));\n }\n\n private renderItem(suggestion: Suggestion) {\n const hasQuery = this.bindings.searchBoxController.state.value !== '';\n const partialItem = getPartialSearchBoxSuggestionElement(\n suggestion,\n this.bindings.i18n\n );\n\n return {\n ...partialItem,\n content: (\n <QuerySuggestionContainer>\n <QuerySuggestionIcon\n icon={this.icon || SearchIcon}\n hasSuggestion={this.bindings.getSuggestions().length > 1}\n />\n\n <QuerySuggestionText suggestion={suggestion} hasQuery={hasQuery} />\n </QuerySuggestionContainer>\n ),\n onSelect: () => {\n this.bindings.searchBoxController.selectSuggestion(suggestion.rawValue);\n },\n };\n }\n\n public render() {\n if (this.error) {\n return (\n <atomic-component-error\n element={this.host}\n error={this.error}\n ></atomic-component-error>\n );\n }\n }\n}\n","import {HighlightUtils} from '@coveo/headless';\nimport {FunctionalComponent, h} from '@stencil/core';\nimport {i18n} from 'i18next';\nimport {encodeForDomAttribute} from '../../../utils/string-utils';\nimport {SearchBoxSuggestionElement} from './suggestions-types';\n\nexport const getPartialRecentQueryElement = (\n value: string,\n i18n: i18n\n): Pick<SearchBoxSuggestionElement, 'ariaLabel' | 'key' | 'query' | 'part'> => {\n return {\n part: 'recent-query-item',\n query: value,\n key: `recent-${encodeForDomAttribute(value)}`,\n ariaLabel: i18n.t('recent-query-suggestion-label', {\n query: value,\n interpolation: {escapeValue: false},\n }),\n };\n};\n\nexport const getPartialRecentQueryClearElement = (\n i18n: i18n\n): Pick<\n SearchBoxSuggestionElement,\n 'ariaLabel' | 'key' | 'part' | 'hideIfLast'\n> => {\n return {\n key: 'recent-query-clear',\n ariaLabel: i18n.t('clear-recent-searches', {\n interpolation: {escapeValue: false},\n }),\n part: 'recent-query-title-item suggestion-divider',\n hideIfLast: true,\n };\n};\n\nexport const RecentQueriesContainer: FunctionalComponent = (_, children) => {\n return (\n <div\n part=\"recent-query-content\"\n class=\"flex items-center text-left break-all\"\n >\n {children}\n </div>\n );\n};\n\ninterface RecentQueryIconProps {\n icon: string;\n}\n\nexport const RecentQueryIcon: FunctionalComponent<RecentQueryIconProps> = ({\n icon,\n}) => {\n return (\n <atomic-icon\n part=\"recent-query-icon\"\n icon={icon}\n class=\"mr-2 h-4 w-4 shrink-0\"\n ></atomic-icon>\n );\n};\n\ninterface RecentQueryTextProps {\n query: string;\n value: string;\n}\n\nexport const RecentQueryText: FunctionalComponent<RecentQueryTextProps> = ({\n query,\n value,\n}) => {\n if (query === '') {\n return (\n <span part=\"recent-query-text\" class=\"line-clamp-2 break-all\">\n {value}\n </span>\n );\n }\n return (\n <span\n part=\"recent-query-text\"\n class=\"line-clamp-2 break-all\"\n innerHTML={HighlightUtils.highlightString({\n content: value,\n openingDelimiter:\n '<span part=\"recent-query-text-highlight\" class=\"font-bold\">',\n closingDelimiter: '</span>',\n highlights: [\n {\n offset: query.length,\n length: value.length - query.length,\n },\n ],\n })}\n ></span>\n );\n};\n\ninterface RecentQueryClearProps {\n i18n: i18n;\n}\n\nexport const RecentQueryClear: FunctionalComponent<RecentQueryClearProps> = ({\n i18n,\n}) => {\n return (\n <div part=\"recent-query-title-content\" class=\"flex w-full justify-between\">\n <span class=\"font-bold\" part=\"recent-query-title\">\n {i18n.t('recent-searches')}\n </span>\n <span part=\"recent-query-clear\">{i18n.t('clear')}</span>\n </div>\n );\n};\n","import {\n buildRecentQueriesList,\n RecentQueriesList,\n SearchBox,\n} from '@coveo/headless';\nimport {Component, Element, Prop, State, h} from '@stencil/core';\nimport Clock from '../../../../images/clock.svg';\nimport {SafeStorage, StorageItems} from '../../../../utils/local-storage-utils';\nimport {once} from '../../../../utils/utils';\nimport {\n getPartialRecentQueryClearElement,\n getPartialRecentQueryElement,\n RecentQueriesContainer,\n RecentQueryClear,\n RecentQueryIcon,\n RecentQueryText,\n} from '../../../common/suggestions/stencil-recent-queries';\nimport {\n dispatchSearchBoxSuggestionsEvent,\n} from '../../../common/suggestions/suggestions-events';\nimport type {\n SearchBoxSuggestionElement,\n SearchBoxSuggestions,\n SearchBoxSuggestionsBindings,\n} from '../../../common/suggestions/suggestions-types';\nimport {Bindings} from '../../atomic-search-interface/atomic-search-interface';\n\n/**\n * 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.\n */\n@Component({\n tag: 'atomic-search-box-recent-queries',\n shadow: true,\n})\nexport class AtomicSearchBoxRecentQueries {\n private bindings!: SearchBoxSuggestionsBindings<SearchBox, Bindings>;\n private recentQueriesList!: RecentQueriesList;\n private storage!: SafeStorage;\n\n @Element() private host!: HTMLElement;\n\n @State() public error!: Error;\n\n /**\n * The SVG icon to display.\n *\n * - Use a value that starts with `http://`, `https://`, `./`, or `../`, to fetch and display an icon from a given location.\n * - Use a value that starts with `assets://`, to display an icon from the Atomic package.\n * - Use a stringified SVG to display it directly.\n */\n @Prop() public icon?: string;\n\n /**\n * The maximum number of suggestions that will be displayed if the user has typed something into the input field.\n */\n @Prop({reflect: true}) public maxWithQuery = 3;\n /**\n * The maximum number of suggestions that will be displayed initially when the input field is empty.\n */\n @Prop({reflect: true}) public maxWithoutQuery?: number;\n\n componentWillLoad() {\n try {\n dispatchSearchBoxSuggestionsEvent<SearchBox, Bindings>(\n (bindings) => {\n this.bindings = bindings;\n return this.initialize();\n },\n this.host,\n ['atomic-search-box']\n );\n } catch (error) {\n this.error = error as Error;\n }\n }\n\n private renderIcon() {\n return this.icon || Clock;\n }\n\n private initialize(): SearchBoxSuggestions {\n this.storage = new SafeStorage();\n this.recentQueriesList = buildRecentQueriesList(this.bindings.engine, {\n initialState: {queries: this.retrieveLocalStorage()},\n options: {maxLength: 1000, clearFilters: this.bindings.clearFilters},\n });\n\n this.recentQueriesList.subscribe(() => this.updateLocalStorage());\n\n return {\n position: Array.from(this.host.parentNode!.children).indexOf(this.host),\n renderItems: () => this.renderItems(),\n };\n }\n\n private retrieveLocalStorage() {\n return this.storage.getParsedJSON(StorageItems.RECENT_QUERIES, []);\n }\n\n private updateLocalStorage() {\n if (!this.recentQueriesList.state.analyticsEnabled) {\n return this.disableFeature();\n }\n\n return this.storage.setJSON(\n StorageItems.RECENT_QUERIES,\n this.recentQueriesList.state.queries\n );\n }\n\n private warnUser = once(() =>\n this.bindings.engine.logger.warn(\n 'Because analytics are disabled, the recent queries feature is deactivated.'\n )\n );\n\n private disableFeature() {\n this.warnUser();\n this.storage.removeItem(StorageItems.RECENT_QUERIES);\n }\n\n private renderItems(): SearchBoxSuggestionElement[] {\n if (!this.recentQueriesList.state.analyticsEnabled) {\n return [];\n }\n\n const query = this.bindings.searchBoxController.state.value;\n const hasQuery = query !== '';\n const max = hasQuery ? this.maxWithQuery : this.maxWithoutQuery;\n const filteredQueries = this.recentQueriesList.state.queries\n .filter((recentQuery) =>\n recentQuery.toLowerCase().startsWith(query.toLowerCase())\n )\n .slice(0, max);\n\n const suggestionElements: SearchBoxSuggestionElement[] =\n filteredQueries.map((value) => this.renderItem(value));\n if (suggestionElements.length) {\n suggestionElements.unshift(this.renderClear());\n }\n\n return suggestionElements;\n }\n\n private renderClear(): SearchBoxSuggestionElement {\n const partialItem = getPartialRecentQueryClearElement(this.bindings.i18n);\n\n return {\n ...partialItem,\n content: <RecentQueryClear i18n={this.bindings.i18n} />,\n onSelect: () => {\n this.recentQueriesList.clear();\n this.bindings.triggerSuggestions();\n },\n };\n }\n\n private renderItem(value: string): SearchBoxSuggestionElement {\n const query = this.bindings.searchBoxController.state.value;\n const partialItem = getPartialRecentQueryElement(value, this.bindings.i18n);\n return {\n ...partialItem,\n content: (\n <RecentQueriesContainer>\n <RecentQueryIcon icon={this.renderIcon()} />\n <RecentQueryText query={query} value={value} />\n </RecentQueriesContainer>\n ),\n\n onSelect: () => {\n if (this.bindings.isStandalone) {\n this.bindings.searchBoxController.updateText(value);\n this.bindings.searchBoxController.submit();\n return;\n }\n\n this.recentQueriesList.executeRecentQuery(\n this.recentQueriesList.state.queries.indexOf(value)\n );\n },\n };\n }\n\n public render() {\n if (this.error) {\n return (\n <atomic-component-error\n element={this.host}\n error={this.error}\n ></atomic-component-error>\n );\n }\n }\n}\n"],"version":3}
@@ -1,7 +0,0 @@
1
- 'use strict';
2
-
3
- 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>`;
4
-
5
- exports.Clock = Clock;
6
-
7
- //# sourceMappingURL=clock-f03ff827.js.map
@@ -1 +0,0 @@
1
- {"file":"clock-f03ff827.js","mappings":";;;;;;","names":[],"sources":[],"sourcesContent":[],"version":3}
@@ -1 +0,0 @@
1
- {"file":"display-options-14f05862.js","mappings":";;;;AAQA,SAAS,eAAe,CAAC,OAA0B;IACjD,QAAQ,OAAO;QACb,KAAK,MAAM;YACT,OAAO,cAAc,CAAC;QACxB,KAAK,OAAO;YACV,OAAO,eAAe,CAAC;QACzB;YACE,OAAO,cAAc,CAAC;KACzB;AACH,CAAC;AAED,SAAS,eAAe,CAAC,OAA2B;IAClD,QAAQ,OAAO;QACb,KAAK,aAAa;YAChB,OAAO,qBAAqB,CAAC;QAC/B,KAAK,SAAS;YACZ,OAAO,iBAAiB,CAAC;QAC3B;YACE,OAAO,gBAAgB,CAAC;KAC3B;AACH,CAAC;AAED,SAAS,aAAa,CAAC,KAA2B;IAChD,QAAQ,KAAK;QACX,KAAK,OAAO;YACV,OAAO,aAAa,CAAC;QACvB,KAAK,OAAO;YACV,OAAO,aAAa,CAAC;QACvB,KAAK,MAAM;YACT,OAAO,YAAY,CAAC;QACtB;YACE,OAAO,YAAY,CAAC;KACvB;AACH,CAAC;SAEe,yBAAyB,CACvC,OAA0B,EAC1B,OAA2B,EAC3B,KAA2B,EAC3B,SAAkB,EAClB,YAAqB;IAErB,MAAM,OAAO,GAAG,qBAAqB,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;IAE/D,IAAI,SAAS,EAAE;QACb,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;KACzB;IAED,IAAI,YAAY,EAAE;QAChB,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;KAC7B;IACD,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAC3B,CAAC;SAEe,qBAAqB,CACnC,OAA0B,EAC1B,OAA2B,EAC3B,KAA2B;IAE3B,MAAM,OAAO,GAAG;QACd,eAAe,CAAC,OAAO,CAAC;QACxB,eAAe,CAAC,OAAO,CAAC;QACxB,aAAa,CAAC,KAAK,CAAC;KACrB,CAAC;IACF,OAAO,OAAO,CAAC;AACjB,CAAC;MAEY,UAAU;IAMrB,YACE,QAAwB,EACxB,OAA0B,EAC1B,OAA2B,EAC3B,SAA+B;QAE/B,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;KAC5B;IAEO,wBAAwB;QAC9B,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAC/B,8BAA8B,CAC/B,EAAE,YAAY,CAAC,YAAY,CAAC,CAAC;QAC9B,IAAI,CAAC,SAAS,EAAE;YACd,OAAO,SAAS,CAAC;SAClB;QACD,OAAO,SAAiC,CAAC;KAC1C;IAEO,UAAU,CAAC,OAA2B;QAC5C,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,CACnC,CAAC,OAAO,KAAK,OAAO,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,OAAO,CACvD,CAAC;KACH;IAEM,UAAU,CAAC,WAAoB;QACpC,MAAM,OAAO,GAAG,qBAAqB,CACnC,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,wBAAwB,EAAE,IAAI,IAAI,CAAC,SAAS,CAClD,CAAC;QACF,IACE,WAAW;cACPA,yBAAgB,CAAC,WAAW,CAAC;cAC7BA,yBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,EACnC;YACA,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;SAC/B;QACD,OAAO,OAAO,CAAC;KAChB;;;;;;;","names":["containsSections"],"sources":["src/components/common/layout/display-options.ts"],"sourcesContent":["import {containsSections, type ItemSectionTagName} from './sections';\n\nexport type ItemDisplayBasicLayout = 'list' | 'grid';\nexport type ItemDisplayLayout = ItemDisplayBasicLayout | 'table';\nexport type ItemDisplayDensity = 'comfortable' | 'normal' | 'compact';\nexport type ItemDisplayImageSize = 'large' | 'small' | 'icon' | 'none';\nexport type ItemTarget = '_self' | '_blank' | '_parent' | '_top';\n\nfunction getDisplayClass(display: ItemDisplayLayout) {\n switch (display) {\n case 'grid':\n return 'display-grid';\n case 'table':\n return 'display-table';\n default:\n return 'display-list';\n }\n}\n\nfunction getDensityClass(density: ItemDisplayDensity) {\n switch (density) {\n case 'comfortable':\n return 'density-comfortable';\n case 'compact':\n return 'density-compact';\n default:\n return 'density-normal';\n }\n}\n\nfunction getImageClass(image: ItemDisplayImageSize) {\n switch (image) {\n case 'large':\n return 'image-large';\n case 'small':\n return 'image-small';\n case 'none':\n return 'image-none';\n default:\n return 'image-icon';\n }\n}\n\nexport function getItemListDisplayClasses(\n display: ItemDisplayLayout,\n density: ItemDisplayDensity,\n image: ItemDisplayImageSize,\n isLoading: boolean,\n isAppLoading: boolean\n) {\n const classes = getItemDisplayClasses(display, density, image);\n\n if (isLoading) {\n classes.push('loading');\n }\n\n if (isAppLoading) {\n classes.push('placeholder');\n }\n return classes.join(' ');\n}\n\nexport function getItemDisplayClasses(\n display: ItemDisplayLayout,\n density: ItemDisplayDensity,\n image: ItemDisplayImageSize\n) {\n const classes = [\n getDisplayClass(display),\n getDensityClass(density),\n getImageClass(image),\n ];\n return classes;\n}\n\nexport class ItemLayout {\n private children: HTMLCollection;\n private density: ItemDisplayDensity;\n private imageSize: ItemDisplayImageSize;\n private display: ItemDisplayLayout;\n\n constructor(\n children: HTMLCollection,\n display: ItemDisplayLayout,\n density: ItemDisplayDensity,\n imageSize: ItemDisplayImageSize\n ) {\n this.children = children;\n this.display = display;\n this.density = density;\n this.imageSize = imageSize;\n }\n\n private getImageSizeFromSections() {\n const imageSize = this.getSection(\n 'atomic-result-section-visual'\n )?.getAttribute('image-size');\n if (!imageSize) {\n return undefined;\n }\n return imageSize as ItemDisplayImageSize;\n }\n\n private getSection(section: ItemSectionTagName) {\n return Array.from(this.children).find(\n (element) => element.tagName.toLowerCase() === section\n );\n }\n\n public getClasses(HTMLContent?: string) {\n const classes = getItemDisplayClasses(\n this.display,\n this.density,\n this.getImageSizeFromSections() ?? this.imageSize\n );\n if (\n HTMLContent\n ? containsSections(HTMLContent)\n : containsSections(this.children)\n ) {\n classes.push('with-sections');\n }\n return classes;\n }\n}\n"],"version":3}
@@ -1 +0,0 @@
1
- {"file":"insight-layout-355a94dd.js","mappings":";;;;AAKA,MAAM,YAAY,GAAG,qBAAqB,CAAC;AAC3C,MAAM,mBAAmB,GAAG,6BAA6B,CAAC;AAC1D,MAAM,iBAAiB,GAAG,2BAA2B,CAAC;AACtD,MAAM,eAAe,GAAG;IACtB,8BAA8B;IAC9B,4BAA4B;IAC5B,+BAA+B;CAChC,CAAC;AACF,MAAM,qBAAqB,GAAG;IAC5B,0CAA0C;IAC1C,8BAA8B;CAC/B,CAAC;AACF,MAAM,uBAAuB,GAAG,iCAAiC,CAAC;SAElD,gBAAgB,CAAC,gBAAwB;IACvD,OAAO,+BAA+B,gBAAgB,GAAG,CAAC;AAC5D,CAAC;SAEe,kBAAkB,CAAC,OAAoB,EAAE,MAAe;IACtE,MAAM,EAAE,GAAG,OAAO,CAAC,EAAE,CAAC;IACtB,MAAM,cAAc,GAAG,yBAAyB,EAAE,EAAE,CAAC;IAErD,MAAM,OAAO,GAAG,OAAO,CACrBA,oBAAW,CAAC,OAAO,EAAE,QAAQ,CAAC,EAAE,aAAa,CAAC,YAAY,CAAC,CAC5D,CAAC;IAEF,MAAM,cAAc,GAAG,MAAM;UACzB;IACF,cAAc;;;;;;IAMd,cAAc,IAAI,mBAAmB;;IAErC;UACE,EAAE,CAAC;IAEP,MAAM,MAAM,GAAG,GAAGC,wBAAe,CAAC,QAAQ,CAAC;;;;;;;;;;;QAWrC,CAAC,OAAO,GAAG,yBAAyB,GAAG,EAAE;;;MAG3CA,wBAAe,CAAC,QAAQ,CAAC,IAAI,iBAAiB;;;;;MAK9C,eAAe,CAAC,GAAG,CACnB,CAAC,cAAc,KAAK,GAAGA,wBAAe,CAAC,QAAQ,CAAC,IAAI,cAAc;;MAElE,CACD;;MAECA,wBAAe,CAAC,QAAQ,CAAC,IAAI,YAAY;;;KAG1C,CAAC;IAEJ,MAAM,MAAM,GAAG,GAAGA,wBAAe,CAAC,QAAQ,CAAC;;;KAGxC,CAAC;IAEJ,MAAM,OAAO,GAAG;MACZA,wBAAe,CAAC,SAAS,CAAC;;;;MAI1BA,wBAAe,CAAC,SAAS,CAAC,IAAI,qBAAqB,CAAC,IAAI,CAAC,GAAG,CAAC;;;;MAI7DA,wBAAe,CAAC,SAAS,CAAC,IAAI,uBAAuB;;;;KAItD,CAAC;IAEJ,OAAO,CAAC,cAAc,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC;SAC7C,MAAM,CAAC,CAAC,WAAW,KAAK,WAAW,KAAK,EAAE,CAAC;SAC3C,IAAI,CAAC,MAAM,CAAC,CAAC;AAClB;;;;;","names":["findSection","sectionSelector"],"sources":["src/components/insight/atomic-insight-layout/insight-layout.ts"],"sourcesContent":["import {\n findSection,\n sectionSelector,\n} from '../../common/atomic-layout-section/sections';\n\nconst tabsSelector = 'atomic-insight-tabs';\nconst refineModalSelector = 'atomic-insight-refine-modal';\nconst searchBoxSelector = 'atomic-insight-search-box';\nconst toggleSelectors = [\n 'atomic-insight-refine-toggle',\n 'atomic-insight-edit-toggle',\n 'atomic-insight-history-toggle',\n];\nconst smartSnippetSelectors = [\n 'atomic-insight-smart-snippet-suggestions',\n 'atomic-insight-smart-snippet',\n];\nconst generatedAnswerSelector = 'atomic-insight-generated-answer';\n\nexport function makeDesktopQuery(mobileBreakpoint: string) {\n return `only screen and (min-width: ${mobileBreakpoint})`;\n}\n\nexport function buildInsightLayout(element: HTMLElement, widget: boolean) {\n const id = element.id;\n const layoutSelector = `atomic-insight-layout#${id}`;\n\n const hasTabs = Boolean(\n findSection(element, 'search')?.querySelector(tabsSelector)\n );\n\n const interfaceStyle = widget\n ? `\n ${layoutSelector} {\n display: grid;\n grid-template-rows: auto auto 8fr 1fr;\n max-height: 100%;\n box-sizing: border-box;\n }\n ${layoutSelector} ${refineModalSelector} {\n grid-row-start: 5;\n }`\n : '';\n\n const search = `${sectionSelector('search')} {\n width: 100%;\n display: flex;\n flex-wrap: wrap;\n grid-gap: 0.5rem;\n background: var(--atomic-neutral-light);\n padding-top: 1.5rem;\n padding-left: 1.5rem;\n padding-right: 1.5rem;\n box-sizing: border-box;\n min-width: 0;\n ${!hasTabs ? 'padding-bottom: 1.5rem;' : ''}\n }\n\n ${sectionSelector('search')} ${searchBoxSelector} {\n flex-grow: 1;\n height: 2.6rem;\n }\n\n ${toggleSelectors.map(\n (toggleSelector) => `${sectionSelector('search')} ${toggleSelector} {\n flex-shrink: 0;\n }`\n )}\n\n ${sectionSelector('search')} ${tabsSelector} {\n width: 100%;\n }\n `;\n\n const facets = `${sectionSelector('facets')} {\n display: none;\n }\n `;\n\n const results = `\n ${sectionSelector('results')} {\n overflow: auto;\n }\n\n ${sectionSelector('results')} ${smartSnippetSelectors.join(',')} {\n padding: 1.5rem 1.5rem 0px;\n }\n\n ${sectionSelector('results')} ${generatedAnswerSelector} {\n margin-left: 1.5rem;\n margin-right: 1.5rem;\n }\n `;\n\n return [interfaceStyle, search, facets, results]\n .filter((declaration) => declaration !== '')\n .join('\\n\\n');\n}\n"],"version":3}
@@ -1 +0,0 @@
1
- {"file":"result-template-common-88359dad.js","mappings":";;;;;;;;SA0BgB,mBAAmB,CAAC,IAAU;IAC5C,IAAIA,4BAAmB,CAAC,IAAI,CAAC,EAAE;QAC7B,OAAO,SAAS,CAAC;KAClB;IACD,IAAI,CAACC,kBAAY,CAAC,IAAI,CAAC,EAAE;QACvB,OAAO,UAAU,CAAC;KACnB;IACD,IACEC,mBAAa,CAAC,IAAI,CAAC;QACnB,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,KAAKC,qCAAmB,EAClD;QACA,OAAO,yBAAyB,CAAC;KAClC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAS,gBAAgB,CAAC,KAAe;IACvC,OAAOC,eAAS,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,KAAK,mBAAmB,CAAC,IAAI,CAAC,CAAC,CAAC;AAC3E,CAAC;MAEY,oBAAoB;IAK/B,YAAY,EACV,IAAI,EACJ,QAAQ,EACR,YAAY,EACZ,UAAU,GAAG,KAAK,GACQ;QARrB,oBAAe,GAA8B,EAAE,CAAC;QAC/C,uBAAkB,GAAe,OAAO,CAAC;QAQ/C,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,QAAQ,EAAE,YAAY,EAAE,UAAU,CAAC,CAAC;KACjE;IAED,gBAAgB,CACd,IAAoB,EACpB,QAAgC,EAChC,YAAsB,EACtB,UAAU,GAAG,IAAI;QAEjB,MAAM,cAAc,GAAG,YAAY;aAChC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC;aAC3B,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAE,QAAQ,IAAI,EAAE,CAAC,CAAC;QAChD,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;QAE5C,IAAI,CAAC,cAAc,EAAE;YACnB,QAAQ,CACN,IAAI,KAAK,CACP,QAAQ,OAAO,4DAA4D,YAAY;iBACpF,GAAG,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,WAAW,EAAE,GAAG,CAAC;iBAClC,IAAI,CAAC,IAAI,CAAC,GAAG,CACjB,CACF,CAAC;YACF,OAAO;SACR;QAED,IACE,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE,KAAK,KAAK,MAAM,EACxE;YACA,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,YAAY,CACnE,uBAAuB,CACxB,EAAE,KAAmB,CAAC;SACxB;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,CACjC,sBAAsB,CACvB,CAAC;QACF,IAAI,CAAC,QAAQ,EAAE;YACb,QAAQ,CACN,IAAI,KAAK,CACP,QAAQ,OAAO,6DAA6D,CAC7E,CACF,CAAC;YACF,OAAO;SACR;QAED,IAAI,CAAC,UAAU,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE;YAC7C,QAAQ,CACN,IAAI,KAAK,CAAC,8BAA8B,OAAO,oBAAoB,CAAC,CACrE,CAAC;YACF,OAAO;SACR;QAED,IAAI,QAAQ,CAAC,OAAO,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE;YAC5C,OAAO,CAAC,IAAI,CACV,mIAAmI,EACnI,IAAI,CACL,CAAC;SACH;QAED,MAAM,EAAC,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,UAAU,EAAC,GAAG,gBAAgB,CACjE,QAAQ,CAAC,OAAO,CAAC,UAAU,CAC5B,CAAC;QACF,IAAI,YAAY,EAAE,MAAM,IAAI,UAAU,EAAE,MAAM,EAAE;YAC9C,OAAO,CAAC,IAAI,CACV,gJAAgJ,EAChJ,IAAI,EACJ,EAAC,YAAY,EAAE,UAAU,EAAC,CAC3B,CAAC;SACH;KACF;IAED,WAAW,CACT,UAAqC,EACrC,KAAY;QAEZ,IAAI,KAAK,EAAE;YACT,OAAO,IAAI,CAAC;SACb;QAED,OAAO;YACL,UAAU,EAAE,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC;YACnD,OAAO,EAAE,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAQ;YAC/C,WAAW,EAAE,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAQ;YAC5D,QAAQ,EAAE,CAAC;SACZ,CAAC;KACH;IAED,aAAa,CAAC,KAAY;QACxB,IAAI,KAAK,EAAE;YACT,QACEC,oCACE,OAAO,EAAE,IAAI,CAAC,IAAI,EAClB,KAAK,EAAE,KAAK,GACY,EAC1B;SACH;KACF;IAED,6BAA6B;QAC3B,MAAM,YAAY,GAAG,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QACxD,YAAY,CAAC,SAAS,GAAG,uBAAuB,IAAI,CAAC,kBAAkB,GAAG,gCAAgC,IAAI,CAAC,kBAAkB,QAAQ,GAAG,EAAE,uBAAuB,CAAC;QACtK,OAAO,YAAY,CAAC;KACrB;IAED,sBAAsB,CAAC,IAAiB;QACtC,QACE,IAAI,CAAC,aAAa,CAAsB,uBAAuB,CAAC;YAChE,IAAI,CAAC,6BAA6B,EAAE,EACpC;KACH;CACF;AAED,SAAS,kBAAkB,CAAC,IAAiB;IAC3C,OAAO,IAAI,CAAC,aAAa,CAAsB,sBAAsB,CAAE,CAAC;AAC1E,CAAC;SAEe,mBAAmB,CACjC,SAAmC,EACnC,YAAsC;IAEtC,MAAM,UAAU,GAA8B,EAAE,CAAC;IACjD,KAAK,MAAM,KAAK,IAAI,SAAS,EAAE;QAC7B,UAAU,CAAC,IAAI,CACbC,+BAAsB,CAAC,cAAc,CAAC,KAAK,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC,CAC/D,CAAC;KACH;IAED,KAAK,MAAM,KAAK,IAAI,YAAY,EAAE;QAChC,UAAU,CAAC,IAAI,CACbA,+BAAsB,CAAC,iBAAiB,CAAC,KAAK,EAAE,YAAY,CAAC,KAAK,CAAC,CAAC,CACrE,CAAC;KACH;IACD,OAAO,UAAU,CAAC;AACpB,CAAC;SAEe,qBAAqB,CACnC,SAAkB,EAClB,YAAqB;IAErB,MAAM,UAAU,GAA8B,EAAE,CAAC;IACjD,IAAI,SAAS,EAAE;QACb,MAAM,UAAU,GAAG,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACxC,UAAU,CAAC,IAAI,CAACA,+BAAsB,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC,CAAC;KACzE;IAED,IAAI,YAAY,EAAE;QAChB,MAAM,UAAU,GAAG,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC3C,UAAU,CAAC,IAAI,CAACA,+BAAsB,CAAC,sBAAsB,CAAC,UAAU,CAAC,CAAC,CAAC;KAC5E;IACD,OAAO,UAAU,CAAC;AACpB;;;;;;","names":["isResultSectionNode","isVisualNode","isElementNode","tableElementTagName","aggregate","h","ResultTemplatesHelpers"],"sources":["src/components/common/result-templates/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 '../../../utils/utils';\nimport {tableElementTagName} from '../../search/atomic-table-result/table-element-utils';\nimport {ItemTarget} from '../layout/display-options';\nimport {isResultSectionNode} from '../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"],"version":3}
@@ -1 +0,0 @@
1
- {"file":"sections-4b4af2f8.js","mappings":";;SAYgB,WAAW,CAAC,OAAoB,EAAE,OAAgB;IAChE,OAAO,OAAO,CAAC,aAAa,CAC1B,eAAe,CAAC,OAAO,CAAC,CACK,CAAC;AAClC,CAAC;SAEe,eAAe,CAAC,OAAgB;IAC9C,OAAO,kCAAkC,OAAO,IAAI,CAAC;AACvD;;;;;","names":[],"sources":["src/components/common/atomic-layout-section/sections.ts"],"sourcesContent":["import type {AtomicLayoutSection} from './atomic-layout-section';\n\nexport type Section =\n | 'search'\n | 'facets'\n | 'main'\n | 'status'\n | 'results'\n | 'horizontal-facets'\n | 'products'\n | 'pagination';\n\nexport function findSection(element: HTMLElement, section: Section) {\n return element.querySelector(\n sectionSelector(section)\n ) as AtomicLayoutSection | null;\n}\n\nexport function sectionSelector(section: Section) {\n return `atomic-layout-section[section=\"${section}\"]`;\n}\n"],"version":3}
@@ -1 +0,0 @@
1
- {"file":"sections-fbb93b53.js","mappings":";;;;AAEA,MAAM,iBAAiB,GAAG,IAAI,GAAG,CAAC;IAChC,8BAA8B;IAC9B,8BAA8B;IAC9B,+BAA+B;IAC/B,6BAA6B;IAC7B,sCAAsC;IACtC,kCAAkC;IAClC,+BAA+B;IAC/B,uCAAuC;IACvC,gCAAgC;CACxB,CAAC,CAAC;AAEZ,MAAM,kBAAkB,GAAG,IAAI,GAAG,CAAC;IACjC,+BAA+B;IAC/B,+BAA+B;IAC/B,gCAAgC;IAChC,6BAA6B;IAC7B,iCAAiC;IACjC,mCAAmC;IACnC,oCAAoC;IACpC,wCAAwC;IACxC,iCAAiC;CACzB,CAAC,CAAC;AAEZ,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,CAAC,GAAG,iBAAiB,EAAE,GAAG,kBAAkB,CAAC,CAAC,CAAC;SAMvD,mBAAmB,CAAC,OAAa;IAC/C,IAAI,CAACA,mBAAa,CAAC,OAAO,CAAC,EAAE;QAC3B,OAAO,KAAK,CAAC;KACd;IACD,OAAO,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,WAAW,EAAwB,CAAC,CAAC;AAC1E,CAAC;SAEe,gBAAgB,CAAC,OAA2C;IAC1E,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE;QAC/B,OAAO,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;KAC1E;IACD,OAAO,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,KAAK,KAAK,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC;AACzE;;;;;","names":["isElementNode"],"sources":["src/components/common/layout/sections.ts"],"sourcesContent":["import {isElementNode} from '../../../utils/utils';\n\nconst resultSectionTags = new Set([\n 'atomic-result-section-visual',\n 'atomic-result-section-badges',\n 'atomic-result-section-actions',\n 'atomic-result-section-title',\n 'atomic-result-section-title-metadata',\n 'atomic-result-section-emphasized',\n 'atomic-result-section-excerpt',\n 'atomic-result-section-bottom-metadata',\n 'atomic-result-section-children',\n] as const);\n\nconst productSectionTags = new Set([\n 'atomic-product-section-visual',\n 'atomic-product-section-badges',\n 'atomic-product-section-actions',\n 'atomic-product-section-name',\n 'atomic-product-section-metadata',\n 'atomic-product-section-emphasized',\n 'atomic-product-section-description',\n 'atomic-product-section-bottom-metadata',\n 'atomic-product-section-children',\n] as const);\n\nconst allTags = new Set([...resultSectionTags, ...productSectionTags]);\n\ntype SetValueType<T> = T extends Set<infer U> ? U : never;\n\nexport type ItemSectionTagName = SetValueType<typeof allTags>;\n\nexport function isResultSectionNode(element: Node) {\n if (!isElementNode(element)) {\n return false;\n }\n return allTags.has(element.tagName.toLowerCase() as ItemSectionTagName);\n}\n\nexport function containsSections(content: string | NodeList | HTMLCollection) {\n if (typeof content === 'string') {\n return Array.from(allTags.values()).some((tag) => content.includes(tag));\n }\n return Array.from(content).some((child) => isResultSectionNode(child));\n}\n"],"version":3}
@@ -1 +0,0 @@
1
- {"file":"table-element-utils-4865b735.js","mappings":";;MAAa,mBAAmB,GAAG;;;;","names":[],"sources":["src/components/search/atomic-table-result/table-element-utils.ts"],"sourcesContent":["export const tableElementTagName = 'atomic-table-element';\n"],"version":3}
@@ -1,229 +0,0 @@
1
- import { r as registerInstance, h, g as getElement } from './index-3f35faca.js';
2
- import { loadQuerySuggestActions, HighlightUtils, buildRecentQueriesList } from '@coveo/headless';
3
- import { S as SearchIcon } from './search-64cc84a9.js';
4
- import { g as getPartialSearchBoxSuggestionElement, Q as QuerySuggestionText, a as QuerySuggestionIcon, b as QuerySuggestionContainer } from './stencil-query-suggestions-5d6a46d7.js';
5
- import { d as dispatchSearchBoxSuggestionsEvent } from './suggestions-events-b7a6f007.js';
6
- import { C as Clock } from './clock-add3e9a5.js';
7
- import { S as SafeStorage, a as StorageItems } from './local-storage-utils-410269e6.js';
8
- import { o as once } from './utils-7161486d.js';
9
- import { e as encodeForDomAttribute } from './string-utils-5f5a23a8.js';
10
- import './dom-utils-f6086cd3.js';
11
- import './event-utils-8de63ec3.js';
12
- import './purify-c7ebd240.js';
13
- import './_commonjsHelpers-1789f0cf.js';
14
-
15
- const AtomicSearchBoxQuerySuggestions = class {
16
- constructor(hostRef) {
17
- registerInstance(this, hostRef);
18
- this.error = undefined;
19
- this.icon = undefined;
20
- this.maxWithQuery = undefined;
21
- this.maxWithoutQuery = undefined;
22
- }
23
- componentWillLoad() {
24
- try {
25
- dispatchSearchBoxSuggestionsEvent((bindings) => {
26
- this.bindings = bindings;
27
- return this.initialize();
28
- }, this.host, ['atomic-search-box']);
29
- }
30
- catch (error) {
31
- this.error = error;
32
- }
33
- }
34
- initialize() {
35
- const engine = this.bindings.engine;
36
- const { registerQuerySuggest, fetchQuerySuggestions } = loadQuerySuggestActions(engine);
37
- engine.dispatch(registerQuerySuggest({
38
- id: this.bindings.id,
39
- count: this.bindings.numberOfQueries,
40
- }));
41
- return {
42
- position: Array.from(this.host.parentNode.children).indexOf(this.host),
43
- onInput: () => engine.dispatch(fetchQuerySuggestions({
44
- id: this.bindings.id,
45
- })),
46
- renderItems: () => this.renderItems(),
47
- };
48
- }
49
- renderItems() {
50
- const hasQuery = this.bindings.searchBoxController.state.value !== '';
51
- const max = hasQuery ? this.maxWithQuery : this.maxWithoutQuery;
52
- return this.bindings.searchBoxController.state.suggestions
53
- .slice(0, max)
54
- .map((suggestion) => this.renderItem(suggestion));
55
- }
56
- renderItem(suggestion) {
57
- const hasQuery = this.bindings.searchBoxController.state.value !== '';
58
- const partialItem = getPartialSearchBoxSuggestionElement(suggestion, this.bindings.i18n);
59
- return {
60
- ...partialItem,
61
- content: (h(QuerySuggestionContainer, null, h(QuerySuggestionIcon, { icon: this.icon || SearchIcon, hasSuggestion: this.bindings.getSuggestions().length > 1 }), h(QuerySuggestionText, { suggestion: suggestion, hasQuery: hasQuery }))),
62
- onSelect: () => {
63
- this.bindings.searchBoxController.selectSuggestion(suggestion.rawValue);
64
- },
65
- };
66
- }
67
- render() {
68
- if (this.error) {
69
- return (h("atomic-component-error", { key: 'c5e8f0a3254a31cdae54c36868f70432c1673888', element: this.host, error: this.error }));
70
- }
71
- }
72
- get host() { return getElement(this); }
73
- };
74
-
75
- const getPartialRecentQueryElement = (value, i18n) => {
76
- return {
77
- part: 'recent-query-item',
78
- query: value,
79
- key: `recent-${encodeForDomAttribute(value)}`,
80
- ariaLabel: i18n.t('recent-query-suggestion-label', {
81
- query: value,
82
- interpolation: { escapeValue: false },
83
- }),
84
- };
85
- };
86
- const getPartialRecentQueryClearElement = (i18n) => {
87
- return {
88
- key: 'recent-query-clear',
89
- ariaLabel: i18n.t('clear-recent-searches', {
90
- interpolation: { escapeValue: false },
91
- }),
92
- part: 'recent-query-title-item suggestion-divider',
93
- hideIfLast: true,
94
- };
95
- };
96
- const RecentQueriesContainer = (_, children) => {
97
- return (h("div", { part: "recent-query-content", class: "flex items-center text-left break-all" }, children));
98
- };
99
- const RecentQueryIcon = ({ icon, }) => {
100
- return (h("atomic-icon", { part: "recent-query-icon", icon: icon, class: "mr-2 h-4 w-4 shrink-0" }));
101
- };
102
- const RecentQueryText = ({ query, value, }) => {
103
- if (query === '') {
104
- return (h("span", { part: "recent-query-text", class: "line-clamp-2 break-all" }, value));
105
- }
106
- return (h("span", { part: "recent-query-text", class: "line-clamp-2 break-all", innerHTML: HighlightUtils.highlightString({
107
- content: value,
108
- openingDelimiter: '<span part="recent-query-text-highlight" class="font-bold">',
109
- closingDelimiter: '</span>',
110
- highlights: [
111
- {
112
- offset: query.length,
113
- length: value.length - query.length,
114
- },
115
- ],
116
- }) }));
117
- };
118
- const RecentQueryClear = ({ i18n, }) => {
119
- return (h("div", { part: "recent-query-title-content", class: "flex w-full justify-between" },
120
- h("span", { class: "font-bold", part: "recent-query-title" }, i18n.t('recent-searches')),
121
- h("span", { part: "recent-query-clear" }, i18n.t('clear'))));
122
- };
123
-
124
- const AtomicSearchBoxRecentQueries = class {
125
- constructor(hostRef) {
126
- registerInstance(this, hostRef);
127
- /**
128
- * The maximum number of suggestions that will be displayed if the user has typed something into the input field.
129
- */
130
- this.maxWithQuery = 3;
131
- this.warnUser = once(() => this.bindings.engine.logger.warn('Because analytics are disabled, the recent queries feature is deactivated.'));
132
- this.error = undefined;
133
- this.icon = undefined;
134
- this.maxWithQuery = 3;
135
- this.maxWithoutQuery = undefined;
136
- }
137
- componentWillLoad() {
138
- try {
139
- dispatchSearchBoxSuggestionsEvent((bindings) => {
140
- this.bindings = bindings;
141
- return this.initialize();
142
- }, this.host, ['atomic-search-box']);
143
- }
144
- catch (error) {
145
- this.error = error;
146
- }
147
- }
148
- renderIcon() {
149
- return this.icon || Clock;
150
- }
151
- initialize() {
152
- this.storage = new SafeStorage();
153
- this.recentQueriesList = buildRecentQueriesList(this.bindings.engine, {
154
- initialState: { queries: this.retrieveLocalStorage() },
155
- options: { maxLength: 1000, clearFilters: this.bindings.clearFilters },
156
- });
157
- this.recentQueriesList.subscribe(() => this.updateLocalStorage());
158
- return {
159
- position: Array.from(this.host.parentNode.children).indexOf(this.host),
160
- renderItems: () => this.renderItems(),
161
- };
162
- }
163
- retrieveLocalStorage() {
164
- return this.storage.getParsedJSON(StorageItems.RECENT_QUERIES, []);
165
- }
166
- updateLocalStorage() {
167
- if (!this.recentQueriesList.state.analyticsEnabled) {
168
- return this.disableFeature();
169
- }
170
- return this.storage.setJSON(StorageItems.RECENT_QUERIES, this.recentQueriesList.state.queries);
171
- }
172
- disableFeature() {
173
- this.warnUser();
174
- this.storage.removeItem(StorageItems.RECENT_QUERIES);
175
- }
176
- renderItems() {
177
- if (!this.recentQueriesList.state.analyticsEnabled) {
178
- return [];
179
- }
180
- const query = this.bindings.searchBoxController.state.value;
181
- const hasQuery = query !== '';
182
- const max = hasQuery ? this.maxWithQuery : this.maxWithoutQuery;
183
- const filteredQueries = this.recentQueriesList.state.queries
184
- .filter((recentQuery) => recentQuery.toLowerCase().startsWith(query.toLowerCase()))
185
- .slice(0, max);
186
- const suggestionElements = filteredQueries.map((value) => this.renderItem(value));
187
- if (suggestionElements.length) {
188
- suggestionElements.unshift(this.renderClear());
189
- }
190
- return suggestionElements;
191
- }
192
- renderClear() {
193
- const partialItem = getPartialRecentQueryClearElement(this.bindings.i18n);
194
- return {
195
- ...partialItem,
196
- content: h(RecentQueryClear, { i18n: this.bindings.i18n }),
197
- onSelect: () => {
198
- this.recentQueriesList.clear();
199
- this.bindings.triggerSuggestions();
200
- },
201
- };
202
- }
203
- renderItem(value) {
204
- const query = this.bindings.searchBoxController.state.value;
205
- const partialItem = getPartialRecentQueryElement(value, this.bindings.i18n);
206
- return {
207
- ...partialItem,
208
- content: (h(RecentQueriesContainer, null, h(RecentQueryIcon, { icon: this.renderIcon() }), h(RecentQueryText, { query: query, value: value }))),
209
- onSelect: () => {
210
- if (this.bindings.isStandalone) {
211
- this.bindings.searchBoxController.updateText(value);
212
- this.bindings.searchBoxController.submit();
213
- return;
214
- }
215
- this.recentQueriesList.executeRecentQuery(this.recentQueriesList.state.queries.indexOf(value));
216
- },
217
- };
218
- }
219
- render() {
220
- if (this.error) {
221
- return (h("atomic-component-error", { key: 'a428e82c6ce29e81704777cbbf3bea98937b906a', element: this.host, error: this.error }));
222
- }
223
- }
224
- get host() { return getElement(this); }
225
- };
226
-
227
- export { AtomicSearchBoxQuerySuggestions as atomic_search_box_query_suggestions, AtomicSearchBoxRecentQueries as atomic_search_box_recent_queries };
228
-
229
- //# sourceMappingURL=atomic-search-box-query-suggestions_2.entry.js.map