@coveo/atomic 3.34.0-pre.3832d9ea2f → 3.34.0-pre.3b5ceb1fe2

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 (374) 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 -6
  4. package/dist/atomic/components/_index.js +0 -3
  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-format-currency.js +1 -1
  9. package/dist/atomic/components/atomic-format-number.js +1 -1
  10. package/dist/atomic/components/atomic-format-unit.js +1 -1
  11. package/dist/atomic/components/atomic-insight-history-toggle.js +2 -2
  12. package/dist/atomic/components/atomic-insight-history-toggle.js.map +1 -1
  13. package/dist/atomic/components/atomic-insight-pager.js +38 -2
  14. package/dist/atomic/components/atomic-insight-pager.js.map +1 -1
  15. package/dist/atomic/components/atomic-insight-user-actions-toggle.js +2 -2
  16. package/dist/atomic/components/atomic-insight-user-actions-toggle.js.map +1 -1
  17. package/dist/{esm/sections-ae00b53a.js → atomic/components/atomic-layout-section-utils.js} +1 -1
  18. package/dist/atomic/components/atomic-layout-section-utils.js.map +1 -0
  19. package/dist/atomic/components/atomic-numeric-facet.js +1 -1
  20. package/dist/atomic/components/atomic-query-error.js +1 -1
  21. package/dist/atomic/components/atomic-quickview-modal2.js +1 -1
  22. package/dist/atomic/components/atomic-quickview.js +1 -1
  23. package/dist/atomic/components/atomic-refine-modal2.js +2 -2
  24. package/dist/atomic/components/atomic-refine-modal2.js.map +1 -1
  25. package/dist/atomic/components/atomic-refine-toggle.js +1 -1
  26. package/dist/atomic/components/atomic-result-children.js +1 -1
  27. package/dist/atomic/components/atomic-result-fields-list.js +1 -1
  28. package/dist/atomic/components/atomic-result-link.js +1 -1
  29. package/dist/atomic/components/atomic-result-list.js +1 -1
  30. package/dist/atomic/components/atomic-result-table-placeholder2.js +1 -1
  31. package/dist/atomic/components/atomic-search-box-query-suggestions2.js +1 -1
  32. package/dist/atomic/components/atomic-search-box.js +5 -11
  33. package/dist/atomic/components/atomic-search-box.js.map +1 -1
  34. package/dist/atomic/components/atomic-smart-snippet-feedback-modal2.js +2 -2
  35. package/dist/atomic/components/atomic-sort-dropdown.js +2 -2
  36. package/dist/atomic/components/atomic-sort-expression.js +1 -1
  37. package/dist/atomic/components/atomic-tab-manager.js +1 -1
  38. package/dist/atomic/components/clock.js +2 -2
  39. package/dist/atomic/components/components/commerce/atomic-commerce-breadbox/atomic-commerce-breadbox.js +17 -32
  40. package/dist/atomic/components/components/commerce/atomic-commerce-pager/atomic-commerce-pager.js +25 -11
  41. package/dist/atomic/components/components/common/atomic-layout-section/layout.js +1 -1
  42. package/dist/atomic/components/components/common/layout/display-options.js +1 -1
  43. package/dist/atomic/components/components/common/layout/{sections.js → item-layout-sections.js} +1 -1
  44. package/dist/atomic/components/components/common/product-template/product-template-common.js +1 -1
  45. package/dist/atomic/components/components/common/validate-props-controller/validate-props-controller.js +50 -0
  46. package/dist/atomic/components/components/insight/atomic-insight-layout/insight-layout.js +1 -1
  47. package/dist/atomic/components/components/search/atomic-pager/atomic-pager.js +188 -0
  48. package/dist/atomic/components/components/search/atomic-relevance-inspector/atomic-relevance-inspector.js +100 -0
  49. package/dist/atomic/components/components/search/atomic-search-box-recent-queries/atomic-search-box-recent-queries.js +137 -0
  50. package/dist/atomic/components/components/search/atomic-search-interface/atomic-search-interface.js +17 -24
  51. package/dist/atomic/components/components/search/index.js +3 -0
  52. package/dist/atomic/components/components/search/lazy-index.js +3 -0
  53. package/dist/atomic/components/display-options.js +1 -1
  54. package/dist/atomic/components/display-options.js.map +1 -1
  55. package/dist/atomic/components/global/environment.js +1 -1
  56. package/dist/atomic/components/index.js.map +1 -1
  57. package/dist/atomic/components/insight-layout.js +1 -1
  58. package/dist/atomic/components/insight-layout.js.map +1 -1
  59. package/dist/atomic/components/{sections2.js → item-layout-sections.js} +1 -1
  60. package/dist/atomic/components/item-layout-sections.js.map +1 -0
  61. package/dist/atomic/components/result-template-common.js +1 -1
  62. package/dist/atomic/components/result-template-common.js.map +1 -1
  63. package/dist/atomic/components/utils/compare-utils.js +49 -0
  64. package/dist/atomic/{p-44ef70b6.entry.js → p-01511388.entry.js} +2 -2
  65. package/dist/atomic/{p-2caa1859.js → p-0e62bdd6.js} +2 -2
  66. package/dist/atomic/p-0e62bdd6.js.map +1 -0
  67. package/dist/atomic/{p-8acb1466.entry.js → p-0ed76e65.entry.js} +2 -2
  68. package/dist/atomic/{p-5f706e3d.entry.js → p-170c7da6.entry.js} +2 -2
  69. package/dist/atomic/{p-3857d6a3.entry.js → p-1bbaf206.entry.js} +2 -2
  70. package/dist/atomic/{p-4723ffa5.entry.js → p-20b33c18.entry.js} +2 -2
  71. package/dist/atomic/{p-7709fba4.js → p-2250f505.js} +2 -2
  72. package/dist/atomic/p-2250f505.js.map +1 -0
  73. package/dist/atomic/{p-8103bad3.entry.js → p-2fb49fe8.entry.js} +2 -2
  74. package/dist/atomic/{p-74822069.entry.js → p-3549a469.entry.js} +2 -2
  75. package/dist/atomic/{p-45c76d98.entry.js → p-36112c34.entry.js} +2 -2
  76. package/dist/atomic/p-36112c34.entry.js.map +1 -0
  77. package/dist/atomic/{p-d6e04719.entry.js → p-373448df.entry.js} +2 -2
  78. package/dist/atomic/{p-6abd5b2b.entry.js → p-3e9db2b5.entry.js} +2 -2
  79. package/dist/atomic/{p-4b9a166f.entry.js → p-40c1dfcb.entry.js} +2 -2
  80. package/dist/atomic/{p-37a28729.entry.js → p-4f4c9a03.entry.js} +2 -2
  81. package/dist/atomic/{p-e3edbf14.entry.js → p-52d5461a.entry.js} +2 -2
  82. package/dist/atomic/{p-0402ee69.entry.js → p-59f043a0.entry.js} +2 -2
  83. package/dist/atomic/{p-406a288c.entry.js → p-6078667f.entry.js} +2 -2
  84. package/dist/atomic/p-62e85c20.entry.js +2 -0
  85. package/dist/atomic/p-6f1bffa2.entry.js +2 -0
  86. package/dist/atomic/p-6f1bffa2.entry.js.map +1 -0
  87. package/dist/atomic/{p-93da1f4e.entry.js → p-6f34dd3a.entry.js} +2 -2
  88. package/dist/atomic/{p-0c0b8d41.entry.js → p-768b172e.entry.js} +2 -2
  89. package/dist/atomic/{p-3b98377b.js → p-7c9bc45a.js} +2 -2
  90. package/dist/atomic/{p-f073a78d.entry.js → p-7e971d15.entry.js} +2 -2
  91. package/dist/atomic/{p-a4d277c7.entry.js → p-7fd5b6ac.entry.js} +2 -2
  92. package/dist/atomic/{p-dfc385b7.entry.js → p-83d3857f.entry.js} +2 -2
  93. package/dist/atomic/{p-df1d50c8.entry.js → p-87f69e53.entry.js} +2 -2
  94. package/dist/atomic/{p-679739d9.entry.js → p-8af1302f.entry.js} +2 -2
  95. package/dist/atomic/{p-6289adc7.entry.js → p-9239be63.entry.js} +2 -2
  96. package/dist/atomic/{p-f71b14b2.entry.js → p-9260dd7d.entry.js} +2 -2
  97. package/dist/atomic/{p-ed8e5c4d.entry.js → p-98dd6df1.entry.js} +2 -2
  98. package/dist/atomic/{p-b7cd0342.entry.js → p-9a6ec803.entry.js} +2 -2
  99. package/dist/atomic/{p-0b5efb51.entry.js → p-a1e5f767.entry.js} +2 -2
  100. package/dist/atomic/{p-1db20a4a.entry.js → p-a5f66ecd.entry.js} +2 -2
  101. package/dist/atomic/{p-aa616502.entry.js → p-af1b4924.entry.js} +2 -2
  102. package/dist/atomic/{p-d2d22ab2.entry.js → p-b2b9e83f.entry.js} +2 -2
  103. package/dist/atomic/{p-62afcf79.entry.js → p-b313058c.entry.js} +2 -2
  104. package/dist/atomic/{p-4ae14373.entry.js → p-b6ae0244.entry.js} +2 -2
  105. package/dist/atomic/{p-20019654.entry.js → p-bbfe727a.entry.js} +2 -2
  106. package/dist/atomic/{p-30411cd4.entry.js → p-be2a43f4.entry.js} +2 -2
  107. package/dist/atomic/{p-577d34ba.entry.js → p-c4fb6426.entry.js} +2 -2
  108. package/dist/atomic/{p-9c7dbbdf.js → p-cc2b2231.js} +1 -1
  109. package/dist/atomic/p-cc2b2231.js.map +1 -0
  110. package/dist/atomic/{p-b4ad3036.entry.js → p-d211a422.entry.js} +2 -2
  111. package/dist/atomic/{p-9faad55b.entry.js → p-dc128135.entry.js} +2 -2
  112. package/dist/atomic/{p-97748161.js → p-dc28ee14.js} +1 -1
  113. package/dist/{esm/sections-d787040b.js.map → atomic/p-dc28ee14.js.map} +1 -1
  114. package/dist/atomic/{p-c280cd05.js → p-e1cc5150.js} +1 -1
  115. package/dist/atomic/{p-27b8404c.js → p-e62fc40e.js} +2 -2
  116. package/dist/atomic/p-e62fc40e.js.map +1 -0
  117. package/dist/atomic/{p-d1795580.entry.js → p-e7a25b00.entry.js} +2 -2
  118. package/dist/atomic/{p-5e569db1.entry.js → p-f82d3840.entry.js} +2 -2
  119. package/dist/atomic/p-fdcd187d.entry.js +2 -0
  120. package/dist/atomic/p-fdcd187d.entry.js.map +1 -0
  121. package/dist/cjs/_loader.cjs.js +1 -1
  122. package/dist/cjs/{analytics-config-c1c73100.js → analytics-config-69119818.js} +2 -2
  123. package/dist/cjs/{analytics-config-c1c73100.js.map → analytics-config-69119818.js.map} +1 -1
  124. package/dist/cjs/atomic-category-facet.cjs.entry.js +1 -1
  125. package/dist/cjs/atomic-facet.cjs.entry.js +1 -1
  126. package/dist/cjs/atomic-field-condition.cjs.entry.js +2 -2
  127. package/dist/cjs/atomic-folded-result-list.cjs.entry.js +2 -2
  128. package/dist/cjs/atomic-format-currency.cjs.entry.js +1 -1
  129. package/dist/cjs/atomic-format-number.cjs.entry.js +1 -1
  130. package/dist/cjs/atomic-format-unit.cjs.entry.js +1 -1
  131. package/dist/cjs/atomic-insight-folded-result-list.cjs.entry.js +2 -2
  132. package/dist/cjs/atomic-insight-history-toggle.cjs.entry.js +2 -2
  133. package/dist/cjs/atomic-insight-history-toggle.cjs.entry.js.map +1 -1
  134. package/dist/cjs/atomic-insight-interface.cjs.entry.js +3 -3
  135. package/dist/cjs/atomic-insight-layout.cjs.entry.js +2 -2
  136. package/dist/cjs/atomic-insight-pager.cjs.entry.js +41 -7
  137. package/dist/cjs/atomic-insight-pager.cjs.entry.js.map +1 -1
  138. package/dist/cjs/atomic-insight-result-children-template.cjs.entry.js +2 -2
  139. package/dist/cjs/atomic-insight-result-list.cjs.entry.js +2 -2
  140. package/dist/cjs/atomic-insight-result-template.cjs.entry.js +2 -2
  141. package/dist/cjs/atomic-insight-result.cjs.entry.js +2 -2
  142. package/dist/cjs/atomic-insight-user-actions-toggle.cjs.entry.js +2 -2
  143. package/dist/cjs/atomic-insight-user-actions-toggle.cjs.entry.js.map +1 -1
  144. package/dist/cjs/atomic-ipx-recs-list.cjs.entry.js +2 -2
  145. package/dist/cjs/{sections-4b4af2f8.js → atomic-layout-section-utils-08b4fbcd.js} +1 -1
  146. package/dist/cjs/atomic-layout-section-utils-08b4fbcd.js.map +1 -0
  147. package/dist/cjs/atomic-numeric-facet.cjs.entry.js +1 -1
  148. package/dist/cjs/atomic-query-error.cjs.entry.js +1 -1
  149. package/dist/cjs/atomic-quickview-modal.cjs.entry.js +1 -1
  150. package/dist/cjs/atomic-quickview.cjs.entry.js +1 -1
  151. package/dist/cjs/atomic-recs-interface.cjs.entry.js +1 -1
  152. package/dist/cjs/atomic-recs-list.cjs.entry.js +2 -2
  153. package/dist/cjs/atomic-recs-result-template.cjs.entry.js +2 -2
  154. package/dist/cjs/atomic-recs-result.cjs.entry.js +2 -2
  155. package/dist/cjs/atomic-refine-modal.cjs.entry.js +4 -4
  156. package/dist/cjs/atomic-refine-modal.cjs.entry.js.map +1 -1
  157. package/dist/cjs/atomic-refine-toggle.cjs.entry.js +1 -1
  158. package/dist/cjs/atomic-result-children-template.cjs.entry.js +2 -2
  159. package/dist/cjs/atomic-result-children.cjs.entry.js +1 -1
  160. package/dist/cjs/atomic-result-fields-list.cjs.entry.js +1 -1
  161. package/dist/cjs/atomic-result-link.cjs.entry.js +1 -1
  162. package/dist/cjs/atomic-result-list.cjs.entry.js +3 -3
  163. package/dist/cjs/atomic-result-placeholder_8.cjs.entry.js +3 -3
  164. package/dist/cjs/atomic-result-template.cjs.entry.js +2 -2
  165. package/dist/cjs/atomic-result.cjs.entry.js +2 -2
  166. package/dist/cjs/atomic-search-box-query-suggestions.cjs.entry.js +76 -0
  167. package/dist/cjs/atomic-search-box-query-suggestions.cjs.entry.js.map +1 -0
  168. package/dist/cjs/atomic-search-box.cjs.entry.js +3 -3
  169. package/dist/cjs/atomic-smart-snippet-feedback-modal.cjs.entry.js +2 -2
  170. package/dist/cjs/atomic-sort-dropdown.cjs.entry.js +2 -2
  171. package/dist/cjs/atomic-sort-expression.cjs.entry.js +1 -1
  172. package/dist/cjs/atomic-tab-manager.cjs.entry.js +1 -1
  173. package/dist/cjs/atomic.cjs.js +1 -1
  174. package/dist/cjs/clock-7aeb19d0.js +7 -0
  175. package/dist/cjs/clock-7aeb19d0.js.map +1 -0
  176. package/dist/cjs/{display-options-14f05862.js → display-options-69531e8d.js} +4 -4
  177. package/dist/cjs/display-options-69531e8d.js.map +1 -0
  178. package/dist/cjs/index-757bc886.js +2 -10
  179. package/dist/cjs/{insight-layout-355a94dd.js → insight-layout-b6ff92fd.js} +11 -11
  180. package/dist/cjs/insight-layout-b6ff92fd.js.map +1 -0
  181. package/dist/cjs/{sections-fbb93b53.js → item-layout-sections-b09ba4b3.js} +1 -1
  182. package/dist/cjs/item-layout-sections-b09ba4b3.js.map +1 -0
  183. package/dist/cjs/{result-template-common-88359dad.js → result-template-common-84bd4057.js} +3 -3
  184. package/dist/cjs/result-template-common-84bd4057.js.map +1 -0
  185. package/dist/cjs/version.cjs.js +1 -1
  186. package/dist/esm/_loader.js +1 -1
  187. package/dist/esm/{analytics-config-91e5bdcd.js → analytics-config-c2472d74.js} +2 -2
  188. package/dist/esm/{analytics-config-91e5bdcd.js.map → analytics-config-c2472d74.js.map} +1 -1
  189. package/dist/esm/atomic-category-facet.entry.js +1 -1
  190. package/dist/esm/atomic-facet.entry.js +1 -1
  191. package/dist/esm/atomic-field-condition.entry.js +2 -2
  192. package/dist/esm/atomic-folded-result-list.entry.js +2 -2
  193. package/dist/esm/atomic-format-currency.entry.js +1 -1
  194. package/dist/esm/atomic-format-number.entry.js +1 -1
  195. package/dist/esm/atomic-format-unit.entry.js +1 -1
  196. package/dist/esm/atomic-insight-folded-result-list.entry.js +2 -2
  197. package/dist/esm/atomic-insight-history-toggle.entry.js +2 -2
  198. package/dist/esm/atomic-insight-history-toggle.entry.js.map +1 -1
  199. package/dist/esm/atomic-insight-interface.entry.js +3 -3
  200. package/dist/esm/atomic-insight-layout.entry.js +2 -2
  201. package/dist/esm/atomic-insight-pager.entry.js +38 -4
  202. package/dist/esm/atomic-insight-pager.entry.js.map +1 -1
  203. package/dist/esm/atomic-insight-result-children-template.entry.js +2 -2
  204. package/dist/esm/atomic-insight-result-list.entry.js +2 -2
  205. package/dist/esm/atomic-insight-result-template.entry.js +2 -2
  206. package/dist/esm/atomic-insight-result.entry.js +2 -2
  207. package/dist/esm/atomic-insight-user-actions-toggle.entry.js +2 -2
  208. package/dist/esm/atomic-insight-user-actions-toggle.entry.js.map +1 -1
  209. package/dist/esm/atomic-ipx-recs-list.entry.js +2 -2
  210. package/dist/{atomic/components/sections.js → esm/atomic-layout-section-utils-c8ca7445.js} +1 -1
  211. package/dist/esm/atomic-layout-section-utils-c8ca7445.js.map +1 -0
  212. package/dist/esm/atomic-numeric-facet.entry.js +1 -1
  213. package/dist/esm/atomic-query-error.entry.js +1 -1
  214. package/dist/esm/atomic-quickview-modal.entry.js +1 -1
  215. package/dist/esm/atomic-quickview.entry.js +1 -1
  216. package/dist/esm/atomic-recs-interface.entry.js +1 -1
  217. package/dist/esm/atomic-recs-list.entry.js +2 -2
  218. package/dist/esm/atomic-recs-result-template.entry.js +2 -2
  219. package/dist/esm/atomic-recs-result.entry.js +2 -2
  220. package/dist/esm/atomic-refine-modal.entry.js +2 -2
  221. package/dist/esm/atomic-refine-modal.entry.js.map +1 -1
  222. package/dist/esm/atomic-refine-toggle.entry.js +1 -1
  223. package/dist/esm/atomic-result-children-template.entry.js +2 -2
  224. package/dist/esm/atomic-result-children.entry.js +1 -1
  225. package/dist/esm/atomic-result-fields-list.entry.js +1 -1
  226. package/dist/esm/atomic-result-link.entry.js +1 -1
  227. package/dist/esm/atomic-result-list.entry.js +3 -3
  228. package/dist/esm/atomic-result-placeholder_8.entry.js +3 -3
  229. package/dist/esm/atomic-result-template.entry.js +2 -2
  230. package/dist/esm/atomic-result.entry.js +2 -2
  231. package/dist/esm/atomic-search-box-query-suggestions.entry.js +72 -0
  232. package/dist/esm/atomic-search-box-query-suggestions.entry.js.map +1 -0
  233. package/dist/esm/atomic-search-box.entry.js +3 -3
  234. package/dist/esm/atomic-smart-snippet-feedback-modal.entry.js +2 -2
  235. package/dist/esm/atomic-sort-dropdown.entry.js +2 -2
  236. package/dist/esm/atomic-sort-expression.entry.js +1 -1
  237. package/dist/esm/atomic-tab-manager.entry.js +1 -1
  238. package/dist/esm/atomic.js +1 -1
  239. package/dist/esm/clock-b1f5d7f7.js +5 -0
  240. package/dist/esm/clock-b1f5d7f7.js.map +1 -0
  241. package/dist/esm/{display-options-c16840c6.js → display-options-1199eed5.js} +2 -2
  242. package/dist/esm/display-options-1199eed5.js.map +1 -0
  243. package/dist/esm/index-3f35faca.js +2 -10
  244. package/dist/esm/{insight-layout-776b87f2.js → insight-layout-a1e4b795.js} +2 -2
  245. package/dist/esm/insight-layout-a1e4b795.js.map +1 -0
  246. package/dist/esm/{sections-d787040b.js → item-layout-sections-8afb5049.js} +1 -1
  247. package/dist/esm/item-layout-sections-8afb5049.js.map +1 -0
  248. package/dist/esm/{result-template-common-ac9fecab.js → result-template-common-995b94f8.js} +2 -2
  249. package/dist/esm/result-template-common-995b94f8.js.map +1 -0
  250. package/dist/esm/version.js +1 -1
  251. package/dist/types/components/commerce/atomic-commerce-breadbox/atomic-commerce-breadbox.d.ts +2 -3
  252. package/dist/types/components/commerce/atomic-commerce-pager/atomic-commerce-pager.d.ts +5 -3
  253. package/dist/types/components/common/atomic-layout-section/atomic-layout-section.d.ts +1 -1
  254. package/dist/types/components/common/facets/facet-search/facet-search-input-guard.d.ts +1 -1
  255. package/dist/types/components/common/no-items/guard.d.ts +1 -1
  256. package/dist/types/components/common/refine-modal/guard.d.ts +1 -1
  257. package/dist/types/components/common/sort/sort-guard.d.ts +1 -1
  258. package/dist/types/components/common/validate-props-controller/validate-props-controller.d.ts +32 -0
  259. package/dist/types/components/search/atomic-pager/atomic-pager.d.ts +28 -16
  260. package/dist/types/components/search/atomic-relevance-inspector/atomic-relevance-inspector.d.ts +18 -8
  261. package/dist/types/components/search/atomic-search-box-recent-queries/atomic-search-box-recent-queries.d.ts +45 -0
  262. package/dist/types/components/search/atomic-search-interface/atomic-search-interface.d.ts +6 -3
  263. package/dist/types/components/search/index.d.ts +3 -0
  264. package/dist/types/components.d.ts +0 -167
  265. package/dist/types/directives/hierarchical-path.d.ts +1 -1
  266. package/dist/types/utils/compare-utils.d.ts +9 -0
  267. package/docs/atomic-docs.json +1 -351
  268. package/package.json +3 -1
  269. package/dist/atomic/components/atomic-pager.d.ts +0 -11
  270. package/dist/atomic/components/atomic-pager.js +0 -134
  271. package/dist/atomic/components/atomic-pager.js.map +0 -1
  272. package/dist/atomic/components/atomic-relevance-inspector.d.ts +0 -11
  273. package/dist/atomic/components/atomic-relevance-inspector.js +0 -53
  274. package/dist/atomic/components/atomic-relevance-inspector.js.map +0 -1
  275. package/dist/atomic/components/atomic-search-box-recent-queries.d.ts +0 -11
  276. package/dist/atomic/components/atomic-search-box-recent-queries.js +0 -8
  277. package/dist/atomic/components/atomic-search-box-recent-queries.js.map +0 -1
  278. package/dist/atomic/components/atomic-search-box-recent-queries2.js +0 -183
  279. package/dist/atomic/components/atomic-search-box-recent-queries2.js.map +0 -1
  280. package/dist/atomic/components/sections.js.map +0 -1
  281. package/dist/atomic/components/sections2.js.map +0 -1
  282. package/dist/atomic/components/stencil-pager-navigation.js +0 -42
  283. package/dist/atomic/components/stencil-pager-navigation.js.map +0 -1
  284. package/dist/atomic/p-1201bf3d.entry.js +0 -2
  285. package/dist/atomic/p-1201bf3d.entry.js.map +0 -1
  286. package/dist/atomic/p-145e3a1c.entry.js +0 -2
  287. package/dist/atomic/p-145e3a1c.entry.js.map +0 -1
  288. package/dist/atomic/p-211d7d6a.js +0 -2
  289. package/dist/atomic/p-211d7d6a.js.map +0 -1
  290. package/dist/atomic/p-250f34d4.entry.js +0 -2
  291. package/dist/atomic/p-27b8404c.js.map +0 -1
  292. package/dist/atomic/p-2caa1859.js.map +0 -1
  293. package/dist/atomic/p-45c76d98.entry.js.map +0 -1
  294. package/dist/atomic/p-516b8165.entry.js +0 -2
  295. package/dist/atomic/p-516b8165.entry.js.map +0 -1
  296. package/dist/atomic/p-7709fba4.js.map +0 -1
  297. package/dist/atomic/p-97748161.js.map +0 -1
  298. package/dist/atomic/p-9c7dbbdf.js.map +0 -1
  299. package/dist/atomic/p-d8028950.entry.js +0 -2
  300. package/dist/atomic/p-d8028950.entry.js.map +0 -1
  301. package/dist/cjs/atomic-pager.cjs.entry.js +0 -121
  302. package/dist/cjs/atomic-pager.cjs.entry.js.map +0 -1
  303. package/dist/cjs/atomic-relevance-inspector.cjs.entry.js +0 -38
  304. package/dist/cjs/atomic-relevance-inspector.cjs.entry.js.map +0 -1
  305. package/dist/cjs/atomic-search-box-query-suggestions_2.cjs.entry.js +0 -234
  306. package/dist/cjs/atomic-search-box-query-suggestions_2.cjs.entry.js.map +0 -1
  307. package/dist/cjs/clock-f03ff827.js +0 -7
  308. package/dist/cjs/clock-f03ff827.js.map +0 -1
  309. package/dist/cjs/display-options-14f05862.js.map +0 -1
  310. package/dist/cjs/insight-layout-355a94dd.js.map +0 -1
  311. package/dist/cjs/result-template-common-88359dad.js.map +0 -1
  312. package/dist/cjs/sections-4b4af2f8.js.map +0 -1
  313. package/dist/cjs/sections-fbb93b53.js.map +0 -1
  314. package/dist/cjs/stencil-pager-navigation-c20b8a95.js +0 -48
  315. package/dist/cjs/stencil-pager-navigation-c20b8a95.js.map +0 -1
  316. package/dist/esm/atomic-pager.entry.js +0 -117
  317. package/dist/esm/atomic-pager.entry.js.map +0 -1
  318. package/dist/esm/atomic-relevance-inspector.entry.js +0 -34
  319. package/dist/esm/atomic-relevance-inspector.entry.js.map +0 -1
  320. package/dist/esm/atomic-search-box-query-suggestions_2.entry.js +0 -229
  321. package/dist/esm/atomic-search-box-query-suggestions_2.entry.js.map +0 -1
  322. package/dist/esm/clock-add3e9a5.js +0 -5
  323. package/dist/esm/clock-add3e9a5.js.map +0 -1
  324. package/dist/esm/display-options-c16840c6.js.map +0 -1
  325. package/dist/esm/insight-layout-776b87f2.js.map +0 -1
  326. package/dist/esm/result-template-common-ac9fecab.js.map +0 -1
  327. package/dist/esm/sections-ae00b53a.js.map +0 -1
  328. package/dist/esm/stencil-pager-navigation-7261a834.js +0 -42
  329. package/dist/esm/stencil-pager-navigation-7261a834.js.map +0 -1
  330. package/dist/types/components/search/search-box-suggestions/atomic-search-box-recent-queries/atomic-search-box-recent-queries.d.ts +0 -37
  331. /package/dist/atomic/components/components/common/atomic-layout-section/{sections.js → atomic-layout-section-utils.js} +0 -0
  332. /package/dist/atomic/{p-44ef70b6.entry.js.map → p-01511388.entry.js.map} +0 -0
  333. /package/dist/atomic/{p-8acb1466.entry.js.map → p-0ed76e65.entry.js.map} +0 -0
  334. /package/dist/atomic/{p-5f706e3d.entry.js.map → p-170c7da6.entry.js.map} +0 -0
  335. /package/dist/atomic/{p-3857d6a3.entry.js.map → p-1bbaf206.entry.js.map} +0 -0
  336. /package/dist/atomic/{p-4723ffa5.entry.js.map → p-20b33c18.entry.js.map} +0 -0
  337. /package/dist/atomic/{p-8103bad3.entry.js.map → p-2fb49fe8.entry.js.map} +0 -0
  338. /package/dist/atomic/{p-74822069.entry.js.map → p-3549a469.entry.js.map} +0 -0
  339. /package/dist/atomic/{p-d6e04719.entry.js.map → p-373448df.entry.js.map} +0 -0
  340. /package/dist/atomic/{p-6abd5b2b.entry.js.map → p-3e9db2b5.entry.js.map} +0 -0
  341. /package/dist/atomic/{p-4b9a166f.entry.js.map → p-40c1dfcb.entry.js.map} +0 -0
  342. /package/dist/atomic/{p-37a28729.entry.js.map → p-4f4c9a03.entry.js.map} +0 -0
  343. /package/dist/atomic/{p-e3edbf14.entry.js.map → p-52d5461a.entry.js.map} +0 -0
  344. /package/dist/atomic/{p-0402ee69.entry.js.map → p-59f043a0.entry.js.map} +0 -0
  345. /package/dist/atomic/{p-406a288c.entry.js.map → p-6078667f.entry.js.map} +0 -0
  346. /package/dist/atomic/{p-250f34d4.entry.js.map → p-62e85c20.entry.js.map} +0 -0
  347. /package/dist/atomic/{p-93da1f4e.entry.js.map → p-6f34dd3a.entry.js.map} +0 -0
  348. /package/dist/atomic/{p-0c0b8d41.entry.js.map → p-768b172e.entry.js.map} +0 -0
  349. /package/dist/atomic/{p-3b98377b.js.map → p-7c9bc45a.js.map} +0 -0
  350. /package/dist/atomic/{p-f073a78d.entry.js.map → p-7e971d15.entry.js.map} +0 -0
  351. /package/dist/atomic/{p-a4d277c7.entry.js.map → p-7fd5b6ac.entry.js.map} +0 -0
  352. /package/dist/atomic/{p-dfc385b7.entry.js.map → p-83d3857f.entry.js.map} +0 -0
  353. /package/dist/atomic/{p-df1d50c8.entry.js.map → p-87f69e53.entry.js.map} +0 -0
  354. /package/dist/atomic/{p-679739d9.entry.js.map → p-8af1302f.entry.js.map} +0 -0
  355. /package/dist/atomic/{p-6289adc7.entry.js.map → p-9239be63.entry.js.map} +0 -0
  356. /package/dist/atomic/{p-f71b14b2.entry.js.map → p-9260dd7d.entry.js.map} +0 -0
  357. /package/dist/atomic/{p-ed8e5c4d.entry.js.map → p-98dd6df1.entry.js.map} +0 -0
  358. /package/dist/atomic/{p-b7cd0342.entry.js.map → p-9a6ec803.entry.js.map} +0 -0
  359. /package/dist/atomic/{p-0b5efb51.entry.js.map → p-a1e5f767.entry.js.map} +0 -0
  360. /package/dist/atomic/{p-1db20a4a.entry.js.map → p-a5f66ecd.entry.js.map} +0 -0
  361. /package/dist/atomic/{p-aa616502.entry.js.map → p-af1b4924.entry.js.map} +0 -0
  362. /package/dist/atomic/{p-d2d22ab2.entry.js.map → p-b2b9e83f.entry.js.map} +0 -0
  363. /package/dist/atomic/{p-62afcf79.entry.js.map → p-b313058c.entry.js.map} +0 -0
  364. /package/dist/atomic/{p-4ae14373.entry.js.map → p-b6ae0244.entry.js.map} +0 -0
  365. /package/dist/atomic/{p-20019654.entry.js.map → p-bbfe727a.entry.js.map} +0 -0
  366. /package/dist/atomic/{p-30411cd4.entry.js.map → p-be2a43f4.entry.js.map} +0 -0
  367. /package/dist/atomic/{p-577d34ba.entry.js.map → p-c4fb6426.entry.js.map} +0 -0
  368. /package/dist/atomic/{p-b4ad3036.entry.js.map → p-d211a422.entry.js.map} +0 -0
  369. /package/dist/atomic/{p-9faad55b.entry.js.map → p-dc128135.entry.js.map} +0 -0
  370. /package/dist/atomic/{p-c280cd05.js.map → p-e1cc5150.js.map} +0 -0
  371. /package/dist/atomic/{p-d1795580.entry.js.map → p-e7a25b00.entry.js.map} +0 -0
  372. /package/dist/atomic/{p-5e569db1.entry.js.map → p-f82d3840.entry.js.map} +0 -0
  373. /package/dist/types/components/common/atomic-layout-section/{sections.d.ts → atomic-layout-section-utils.d.ts} +0 -0
  374. /package/dist/types/components/common/layout/{sections.d.ts → item-layout-sections.d.ts} +0 -0
@@ -0,0 +1,188 @@
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
+ var AtomicPager_1;
8
+ import { NumberValue, Schema } from '@coveo/bueno';
9
+ import { buildPager, buildSearchStatus, } from '@coveo/headless';
10
+ import { html, LitElement } from 'lit';
11
+ import { customElement, property, state } from 'lit/decorators.js';
12
+ import { keyed } from 'lit/directives/keyed.js';
13
+ import { when } from 'lit/directives/when.js';
14
+ import { createAppLoadedListener } from "../../common/interface/store";
15
+ import { renderPagerNavigation } from "../../common/pager/pager-navigation";
16
+ import { bindStateToController } from "../../../decorators/bind-state";
17
+ import { bindingGuard } from "../../../decorators/binding-guard";
18
+ import { bindings } from "../../../decorators/bindings";
19
+ import { errorGuard } from "../../../decorators/error-guard";
20
+ import { withTailwindStyles } from "../../../decorators/with-tailwind-styles";
21
+ import { InitializeBindingsMixin } from "../../../mixins/bindings-mixin";
22
+ import { randomID } from "../../../utils/utils";
23
+ const ArrowLeftIcon = "<svg viewBox=\"0 0 20 20\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"m11.5 4.8-4.3 4.5c-.3.4-.3.9 0 1.3l4.3 4.6c.3.4.9.4 1.2 0s.3-.9 0-1.3l-3.7-4 3.7-3.9c.3-.4.3-.9 0-1.3-.3-.3-.9-.3-1.2.1z\"/></svg>";
24
+ const ArrowRightIcon = "<svg viewBox=\"0 0 20 20\"><path d=\"m8.5 15.2 4.3-4.6c.3-.4.3-.9 0-1.3l-4.4-4.5c-.3-.4-.9-.4-1.2 0s-.3.9 0 1.3l3.7 4-3.7 3.9c-.3.4-.3.9 0 1.3.4.3 1 .3 1.3-.1z\"/></svg>";
25
+ import { renderPageButtons, renderPagerNextButton, renderPagerPageButton, renderPagerPreviousButton, } from '../../common/pager/pager-buttons';
26
+ /**
27
+ * The `atomic-pager` provides buttons that allow the end user to navigate through the different result pages.
28
+ *
29
+ * @part buttons - The list of the next/previous buttons and page-buttons.
30
+ * @part page-buttons - The list of page buttons.
31
+ * @part page-button - The individual page buttons.
32
+ * @part active-page-button - The active page button.
33
+ * @part previous-button - The previous page button.
34
+ * @part next-button - The next page button.
35
+ * @part previous-button-icon - The icon displayed on the "previous page" button.
36
+ * @part next-button-icon - The icon displayed on the "next page" button.
37
+ *
38
+ * @event atomic/scrollToTop - Emitted when the user clicks any of the buttons rendered by the component.
39
+ */
40
+ let AtomicPager = AtomicPager_1 = class AtomicPager extends InitializeBindingsMixin(LitElement) {
41
+ constructor() {
42
+ super(...arguments);
43
+ this.isAppLoaded = false;
44
+ /**
45
+ * The maximum number of page buttons to display in the pager.
46
+ */
47
+ this.numberOfPages = 5;
48
+ /**
49
+ * The SVG icon to render on the "previous page" button.
50
+ *
51
+ * - Use a value that starts with `http://`, `https://`, `./`, or `../`, to fetch and display an icon from a given location.
52
+ * - Use a value that starts with `assets://`, to display an icon from the Atomic package.
53
+ * - Use a stringified SVG to display it directly.
54
+ */
55
+ this.previousButtonIcon = ArrowLeftIcon;
56
+ /**
57
+ * The SVG icon to render on the "next page" button.
58
+ *
59
+ * - Use a value that starts with `http://`, `https://`, `./`, or `../`, to fetch and display an icon from a given location.
60
+ * - Use a value that starts with `assets://`, to display an icon from the Atomic package.
61
+ * - Use a stringified SVG to display it directly.
62
+ */
63
+ this.nextButtonIcon = ArrowRightIcon;
64
+ this.radioGroupName = randomID('atomic-pager-');
65
+ }
66
+ initialize() {
67
+ this.validateProps();
68
+ this.searchStatus = buildSearchStatus(this.bindings.engine);
69
+ this.pager = buildPager(this.bindings.engine, {
70
+ options: { numberOfPages: this.numberOfPages },
71
+ });
72
+ createAppLoadedListener(this.bindings.store, (isAppLoaded) => {
73
+ this.isAppLoaded = isAppLoaded;
74
+ });
75
+ }
76
+ willUpdate(changedProperties) {
77
+ if (changedProperties.has('numberOfPages')) {
78
+ this.validateProps();
79
+ }
80
+ }
81
+ render() {
82
+ const currentGroupName = `${this.radioGroupName}-${this.pagerState.currentPages.join('-')}`;
83
+ return html `${when(!this.searchStatusState.hasError &&
84
+ this.searchStatusState.hasResults &&
85
+ this.isAppLoaded, () => html `
86
+ ${renderPagerNavigation({
87
+ props: {
88
+ i18n: this.bindings.i18n,
89
+ },
90
+ })(html `
91
+ ${renderPagerPreviousButton({
92
+ props: {
93
+ icon: this.previousButtonIcon,
94
+ disabled: !this.pagerState.hasPreviousPage,
95
+ i18n: this.bindings.i18n,
96
+ onClick: () => {
97
+ this.pager.previousPage();
98
+ this.focusOnFirstResultAndScrollToTop();
99
+ },
100
+ },
101
+ })}
102
+ ${renderPageButtons({
103
+ props: {
104
+ i18n: this.bindings.i18n,
105
+ },
106
+ })(html `${this.pagerState.currentPages.map((pageNumber, index) => keyed(`page-${pageNumber}-${index}`, renderPagerPageButton({
107
+ props: {
108
+ isSelected: this.pager.isCurrentPage(pageNumber),
109
+ ariaLabel: this.bindings.i18n.t('page-number', {
110
+ pageNumber,
111
+ }),
112
+ onChecked: () => {
113
+ this.pager.selectPage(pageNumber);
114
+ this.focusOnFirstResultAndScrollToTop();
115
+ },
116
+ page: pageNumber,
117
+ groupName: currentGroupName,
118
+ text: pageNumber.toLocaleString(this.bindings.i18n.language),
119
+ },
120
+ })))}`)}
121
+ ${renderPagerNextButton({
122
+ props: {
123
+ icon: this.nextButtonIcon,
124
+ disabled: !this.pagerState.hasNextPage,
125
+ i18n: this.bindings.i18n,
126
+ onClick: () => {
127
+ this.pager.nextPage();
128
+ this.focusOnFirstResultAndScrollToTop();
129
+ },
130
+ },
131
+ })}
132
+ `)}`)}`;
133
+ }
134
+ validateProps() {
135
+ try {
136
+ AtomicPager_1.propsSchema.validate({
137
+ numberOfPages: this.numberOfPages,
138
+ });
139
+ }
140
+ catch (error) {
141
+ this.error = error;
142
+ return;
143
+ }
144
+ }
145
+ async focusOnFirstResultAndScrollToTop() {
146
+ await this.bindings.store.state.resultList?.focusOnFirstResultAfterNextSearch();
147
+ this.dispatchEvent(new CustomEvent('atomic/scrollToTop'));
148
+ }
149
+ };
150
+ AtomicPager.propsSchema = new Schema({
151
+ numberOfPages: new NumberValue({ min: 0 }),
152
+ });
153
+ __decorate([
154
+ state()
155
+ ], AtomicPager.prototype, "bindings", void 0);
156
+ __decorate([
157
+ state()
158
+ ], AtomicPager.prototype, "error", void 0);
159
+ __decorate([
160
+ state()
161
+ ], AtomicPager.prototype, "isAppLoaded", void 0);
162
+ __decorate([
163
+ bindStateToController('pager'),
164
+ state()
165
+ ], AtomicPager.prototype, "pagerState", void 0);
166
+ __decorate([
167
+ bindStateToController('searchStatus'),
168
+ state()
169
+ ], AtomicPager.prototype, "searchStatusState", void 0);
170
+ __decorate([
171
+ property({ reflect: true, attribute: 'number-of-pages', type: Number })
172
+ ], AtomicPager.prototype, "numberOfPages", void 0);
173
+ __decorate([
174
+ property({ reflect: true, attribute: 'previous-button-icon', type: String })
175
+ ], AtomicPager.prototype, "previousButtonIcon", void 0);
176
+ __decorate([
177
+ property({ reflect: true, attribute: 'next-button-icon', type: String })
178
+ ], AtomicPager.prototype, "nextButtonIcon", void 0);
179
+ __decorate([
180
+ bindingGuard(),
181
+ errorGuard()
182
+ ], AtomicPager.prototype, "render", null);
183
+ AtomicPager = AtomicPager_1 = __decorate([
184
+ customElement('atomic-pager'),
185
+ bindings(),
186
+ withTailwindStyles
187
+ ], AtomicPager);
188
+ export { AtomicPager };
@@ -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 };
@@ -8,7 +8,7 @@ import { buildSearchEngine, buildSearchStatus, buildUrlManager, EcommerceDefault
8
8
  import { provide } from '@lit/context';
9
9
  import i18next from 'i18next';
10
10
  import { css, html, LitElement } from 'lit';
11
- import { customElement, property, state } from 'lit/decorators.js';
11
+ import { customElement, property, query, state } from 'lit/decorators.js';
12
12
  import { when } from 'lit/directives/when.js';
13
13
  import { InterfaceController, } from "../../common/interface/interface-controller";
14
14
  import { MobileBreakpointController } from "../../common/layout/mobile-breakpoint-controller";
@@ -21,6 +21,7 @@ import { withTailwindStyles } from "../../../decorators/with-tailwind-styles.js"
21
21
  import { ChildrenUpdateCompleteMixin } from "../../../mixins/children-update-complete-mixin";
22
22
  import { markParentAsReady } from "../../../utils/init-queue";
23
23
  import { SafeStorage, StorageItems, } from "../../../utils/local-storage-utils";
24
+ import "../atomic-relevance-inspector/atomic-relevance-inspector";
24
25
  import { getAnalyticsConfig } from './analytics-config';
25
26
  import { createSearchStore } from './store';
26
27
  // TODO - Remove once all components that use atomic-modal have been migrated.
@@ -35,7 +36,6 @@ let AtomicSearchInterface = class AtomicSearchInterface extends ChildrenUpdateCo
35
36
  constructor() {
36
37
  super();
37
38
  this.bindings = {};
38
- this.relevanceInspectorIsOpen = false;
39
39
  this.unsubscribeUrlManager = () => { };
40
40
  this.unsubscribeSearchStatus = () => { };
41
41
  this.initialized = false;
@@ -105,11 +105,6 @@ let AtomicSearchInterface = class AtomicSearchInterface extends ChildrenUpdateCo
105
105
  this.handleInitialization = (event) => {
106
106
  this.interfaceController.onComponentInitializing(event);
107
107
  };
108
- this.handleRelevanceInspectorDoubleClick = (e) => {
109
- if (e.altKey) {
110
- this.relevanceInspectorIsOpen = !this.relevanceInspectorIsOpen;
111
- }
112
- };
113
108
  this.onHashChange = () => {
114
109
  this.urlManager.synchronize(this.fragment);
115
110
  };
@@ -122,15 +117,13 @@ let AtomicSearchInterface = class AtomicSearchInterface extends ChildrenUpdateCo
122
117
  connectedCallback() {
123
118
  super.connectedCallback();
124
119
  this.store.setLoadingFlag(FirstSearchExecutedFlag);
125
- this.initRelevanceInspector();
126
120
  this.addEventListener('atomic/initializeComponent', this.handleInitialization);
127
121
  this.addEventListener('atomic/scrollToTop', this.scrollToTop);
128
- this.addEventListener('atomic/relevanceInspector/close', this.closeRelevanceInspector);
129
122
  }
130
123
  willUpdate(changedProperties) {
131
124
  super.willUpdate(changedProperties);
132
125
  if (changedProperties.has('fieldsToInclude')) {
133
- this.initFieldsToInclude();
126
+ this.updateFieldsToInclude();
134
127
  }
135
128
  }
136
129
  disconnectedCallback() {
@@ -144,8 +137,6 @@ let AtomicSearchInterface = class AtomicSearchInterface extends ChildrenUpdateCo
144
137
  window.removeEventListener('hashchange', this.onHashChange);
145
138
  this.removeEventListener('atomic/initializeComponent', this.handleInitialization);
146
139
  this.removeEventListener('atomic/scrollToTop', this.scrollToTop);
147
- this.removeEventListener('atomic/relevanceInspector/close', this.closeRelevanceInspector);
148
- this.removeEventListener('dblclick', this.handleRelevanceInspectorDoubleClick);
149
140
  }
150
141
  // TODO - (v4) KIT-4991: Make private.
151
142
  scrollToTop() {
@@ -156,8 +147,13 @@ let AtomicSearchInterface = class AtomicSearchInterface extends ChildrenUpdateCo
156
147
  }
157
148
  scrollContainerElement.scrollIntoView({ behavior: 'smooth' });
158
149
  }
150
+ /**
151
+ * @deprecated provided for backward compatibility. set the 'open' property directly on the relevance inspector instead.
152
+ */
159
153
  closeRelevanceInspector() {
160
- this.relevanceInspectorIsOpen = false;
154
+ if (this.relevanceInspector) {
155
+ this.relevanceInspector.open = false;
156
+ }
161
157
  }
162
158
  /**
163
159
  * Initializes the connection with the headless search engine using options for `accessToken` (required), `organizationId` (required), `environment` (defaults to `prod`), and `renewAccessToken`.
@@ -260,6 +256,11 @@ let AtomicSearchInterface = class AtomicSearchInterface extends ChildrenUpdateCo
260
256
  const fields = EcommerceDefaultFieldsToInclude.concat(this.fieldsToInclude);
261
257
  this.store.addFieldsToInclude(fields);
262
258
  }
259
+ updateFieldsToInclude() {
260
+ this.store.state.fieldsToInclude = [];
261
+ this.initFieldsToInclude();
262
+ this.registerFieldsToInclude();
263
+ }
263
264
  registerFieldsToInclude() {
264
265
  this.engine?.dispatch(loadFieldActions(this.engine).registerFieldsToInclude(this.store.state.fieldsToInclude));
265
266
  }
@@ -314,11 +315,6 @@ let AtomicSearchInterface = class AtomicSearchInterface extends ChildrenUpdateCo
314
315
  this.unsubscribeUrlManager = this.urlManager.subscribe(() => this.updateHash());
315
316
  window.addEventListener('hashchange', this.onHashChange);
316
317
  }
317
- initRelevanceInspector() {
318
- if (this.enableRelevanceInspector && !this.disableRelevanceInspector) {
319
- this.addEventListener('dblclick', this.handleRelevanceInspectorDoubleClick);
320
- }
321
- }
322
318
  initSearchStatus() {
323
319
  this.searchStatus = buildSearchStatus(this.engine);
324
320
  this.unsubscribeSearchStatus = this.searchStatus.subscribe(() => {
@@ -363,10 +359,7 @@ let AtomicSearchInterface = class AtomicSearchInterface extends ChildrenUpdateCo
363
359
  return html `
364
360
  ${when(this.bindings?.engine &&
365
361
  this.enableRelevanceInspector &&
366
- !this.disableRelevanceInspector, () => html `<atomic-relevance-inspector
367
- ?open=${this.relevanceInspectorIsOpen}
368
- .bindings=${this.bindings}
369
- ></atomic-relevance-inspector>`)}
362
+ !this.disableRelevanceInspector, () => html `<atomic-relevance-inspector></atomic-relevance-inspector>`)}
370
363
  <slot></slot>
371
364
  `;
372
365
  }
@@ -382,8 +375,8 @@ __decorate([
382
375
  state()
383
376
  ], AtomicSearchInterface.prototype, "error", void 0);
384
377
  __decorate([
385
- state()
386
- ], AtomicSearchInterface.prototype, "relevanceInspectorIsOpen", void 0);
378
+ query('atomic-relevance-inspector')
379
+ ], AtomicSearchInterface.prototype, "relevanceInspector", void 0);
387
380
  __decorate([
388
381
  property({
389
382
  type: Array,
@@ -1,5 +1,8 @@
1
1
  // Auto-generated file
2
+ export { AtomicPager } from './atomic-pager/atomic-pager.js';
2
3
  export { AtomicQuerySummary } from './atomic-query-summary/atomic-query-summary.js';
4
+ export { AtomicRelevanceInspector } from './atomic-relevance-inspector/atomic-relevance-inspector.js';
3
5
  export { AtomicResultsPerPage } from './atomic-results-per-page/atomic-results-per-page.js';
6
+ export { AtomicSearchBoxRecentQueries } from './atomic-search-box-recent-queries/atomic-search-box-recent-queries.js';
4
7
  export { AtomicSearchInterface } from './atomic-search-interface/atomic-search-interface.js';
5
8
  export { AtomicSearchLayout } from './atomic-search-layout/atomic-search-layout.js';
@@ -1,7 +1,10 @@
1
1
  // Auto-generated file
2
2
  export default {
3
+ 'atomic-pager': async () => await import('./atomic-pager/atomic-pager.js'),
3
4
  'atomic-query-summary': async () => await import('./atomic-query-summary/atomic-query-summary.js'),
5
+ 'atomic-relevance-inspector': async () => await import('./atomic-relevance-inspector/atomic-relevance-inspector.js'),
4
6
  'atomic-results-per-page': async () => await import('./atomic-results-per-page/atomic-results-per-page.js'),
7
+ 'atomic-search-box-recent-queries': async () => await import('./atomic-search-box-recent-queries/atomic-search-box-recent-queries.js'),
5
8
  'atomic-search-interface': async () => await import('./atomic-search-interface/atomic-search-interface.js'),
6
9
  'atomic-search-layout': async () => await import('./atomic-search-layout/atomic-search-layout.js'),
7
10
  };
@@ -1,4 +1,4 @@
1
- import { c as containsSections } from './sections2.js';
1
+ import { c as containsSections } from './item-layout-sections.js';
2
2
 
3
3
  function getDisplayClass(display) {
4
4
  switch (display) {
@@ -1 +1 @@
1
- {"file":"display-options.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;cACP,gBAAgB,CAAC,WAAW,CAAC;cAC7B,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,EACnC;YACA,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;SAC/B;QACD,OAAO,OAAO,CAAC;KAChB;;;;;","names":[],"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
+ {"file":"display-options.js","mappings":";;AAWA,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;cACP,gBAAgB,CAAC,WAAW,CAAC;cAC7B,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,EACnC;YACA,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;SAC/B;QACD,OAAO,OAAO,CAAC;KAChB;;;;;","names":[],"sources":["src/components/common/layout/display-options.ts"],"sourcesContent":["import {\n containsSections,\n type ItemSectionTagName,\n} from './item-layout-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}
@@ -3,7 +3,7 @@ function getWindow() {
3
3
  }
4
4
  export function getAtomicEnvironment(headlessVersion) {
5
5
  return {
6
- version: "3.34.0-pre.3832d9ea2f",
6
+ version: "3.34.0-pre.3b5ceb1fe2",
7
7
  headlessVersion,
8
8
  };
9
9
  }