@coveo/atomic 3.33.8-pre.f82c4ba7d3 → 3.33.8-pre.fb042f4f0e

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 (184) 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 +2 -0
  4. package/dist/atomic/components/_index.js +1 -0
  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-user-actions-toggle.js +2 -2
  14. package/dist/atomic/components/atomic-insight-user-actions-toggle.js.map +1 -1
  15. package/dist/atomic/components/atomic-numeric-facet.js +1 -1
  16. package/dist/atomic/components/atomic-quickview-modal2.js +1 -1
  17. package/dist/atomic/components/atomic-quickview.js +1 -1
  18. package/dist/atomic/components/atomic-result-children.js +1 -1
  19. package/dist/atomic/components/atomic-result-fields-list.js +1 -1
  20. package/dist/atomic/components/atomic-result-link.js +1 -1
  21. package/dist/atomic/components/atomic-result-list.js +1 -1
  22. package/dist/atomic/components/atomic-search-box-query-suggestions2.js +1 -1
  23. package/dist/atomic/components/atomic-search-box-recent-queries.d.ts +11 -0
  24. package/dist/atomic/components/atomic-search-box-recent-queries.js +8 -0
  25. package/dist/atomic/components/atomic-search-box-recent-queries.js.map +1 -0
  26. package/dist/atomic/components/atomic-search-box-recent-queries2.js +183 -0
  27. package/dist/atomic/components/atomic-search-box-recent-queries2.js.map +1 -0
  28. package/dist/atomic/components/atomic-search-box.js +23 -6
  29. package/dist/atomic/components/atomic-search-box.js.map +1 -1
  30. package/dist/atomic/components/atomic-smart-snippet-feedback-modal2.js +2 -2
  31. package/dist/atomic/components/atomic-sort-dropdown.js +2 -2
  32. package/dist/atomic/components/atomic-sort-expression.js +1 -1
  33. package/dist/atomic/components/atomic-tab-manager.js +1 -1
  34. package/dist/atomic/components/clock.js +2 -2
  35. package/dist/atomic/components/components/commerce/atomic-commerce-interface/atomic-commerce-interface.js +49 -7
  36. package/dist/atomic/components/components/commerce/atomic-commerce-query-summary/atomic-commerce-query-summary.js +2 -2
  37. package/dist/atomic/components/components/commerce/atomic-commerce-recommendation-interface/atomic-commerce-recommendation-interface.js +25 -10
  38. package/dist/atomic/components/components/commerce/atomic-commerce-search-box/atomic-commerce-search-box.js +12 -5
  39. package/dist/atomic/components/components/common/atomic-modal/atomic-modal.js +2 -0
  40. package/dist/atomic/components/components/search/index.js +0 -1
  41. package/dist/atomic/components/components/search/lazy-index.js +0 -1
  42. package/dist/atomic/components/global/environment.js +1 -1
  43. package/dist/atomic/components/index.js.map +1 -1
  44. package/dist/atomic/{p-75e00690.entry.js → p-089be992.entry.js} +2 -2
  45. package/dist/atomic/{p-4b3d253b.entry.js → p-09a3a067.entry.js} +2 -2
  46. package/dist/atomic/{p-7b899b57.entry.js → p-1d1f54a5.entry.js} +2 -2
  47. package/dist/atomic/{p-ae98c582.entry.js → p-2ce8220a.entry.js} +2 -2
  48. package/dist/atomic/{p-877d35b1.entry.js → p-3b023e83.entry.js} +2 -2
  49. package/dist/atomic/{p-52ba404c.entry.js → p-49c38b27.entry.js} +2 -2
  50. package/dist/atomic/p-4c2f230f.entry.js +2 -0
  51. package/dist/atomic/p-4c2f230f.entry.js.map +1 -0
  52. package/dist/atomic/{p-299555fb.entry.js → p-4c41abd0.entry.js} +2 -2
  53. package/dist/atomic/{p-88d5e178.entry.js → p-51a4606d.entry.js} +2 -2
  54. package/dist/atomic/{p-0ce38b0d.entry.js → p-5528d006.entry.js} +2 -2
  55. package/dist/atomic/{p-d00a12e9.entry.js → p-5f1fa581.entry.js} +2 -2
  56. package/dist/atomic/{p-ba4bf29f.entry.js → p-6329ff94.entry.js} +2 -2
  57. package/dist/atomic/{p-7383fd32.entry.js → p-6e6d686e.entry.js} +2 -2
  58. package/dist/atomic/p-744da781.entry.js +2 -0
  59. package/dist/atomic/{p-c88a3d2d.entry.js.map → p-744da781.entry.js.map} +1 -1
  60. package/dist/atomic/{p-a760d9f9.entry.js → p-7e2109e9.entry.js} +2 -2
  61. package/dist/atomic/{p-b28011e6.entry.js → p-89085429.entry.js} +2 -2
  62. package/dist/atomic/{p-39e63678.entry.js → p-89ab44de.entry.js} +2 -2
  63. package/dist/atomic/{p-330e6e7c.entry.js → p-9c9b1965.entry.js} +2 -2
  64. package/dist/atomic/{p-78b70622.entry.js → p-a8882a2a.entry.js} +2 -2
  65. package/dist/atomic/{p-f22bcb8c.entry.js → p-b6963bae.entry.js} +2 -2
  66. package/dist/atomic/{p-3c8d109e.entry.js → p-b7063a0d.entry.js} +2 -2
  67. package/dist/atomic/{p-e1cc5150.js → p-c280cd05.js} +1 -1
  68. package/dist/atomic/{p-5bc31a30.js → p-dd761b10.js} +2 -2
  69. package/dist/atomic/{p-7b0b9e9b.entry.js → p-f289269f.entry.js} +2 -2
  70. package/dist/atomic/{p-c49cfa0c.entry.js → p-fda26113.entry.js} +2 -2
  71. package/dist/cjs/_loader.cjs.js +1 -1
  72. package/dist/cjs/{analytics-config-68dbae8e.js → analytics-config-fa9c8790.js} +2 -2
  73. package/dist/cjs/{analytics-config-68dbae8e.js.map → analytics-config-fa9c8790.js.map} +1 -1
  74. package/dist/cjs/atomic-category-facet.cjs.entry.js +1 -1
  75. package/dist/cjs/atomic-facet.cjs.entry.js +1 -1
  76. package/dist/cjs/atomic-format-currency.cjs.entry.js +1 -1
  77. package/dist/cjs/atomic-format-number.cjs.entry.js +1 -1
  78. package/dist/cjs/atomic-format-unit.cjs.entry.js +1 -1
  79. package/dist/cjs/atomic-insight-history-toggle.cjs.entry.js +2 -2
  80. package/dist/cjs/atomic-insight-history-toggle.cjs.entry.js.map +1 -1
  81. package/dist/cjs/atomic-insight-interface.cjs.entry.js +1 -1
  82. package/dist/cjs/atomic-insight-user-actions-toggle.cjs.entry.js +2 -2
  83. package/dist/cjs/atomic-insight-user-actions-toggle.cjs.entry.js.map +1 -1
  84. package/dist/cjs/atomic-numeric-facet.cjs.entry.js +1 -1
  85. package/dist/cjs/atomic-quickview-modal.cjs.entry.js +1 -1
  86. package/dist/cjs/atomic-quickview.cjs.entry.js +1 -1
  87. package/dist/cjs/atomic-recs-interface.cjs.entry.js +1 -1
  88. package/dist/cjs/atomic-result-children.cjs.entry.js +1 -1
  89. package/dist/cjs/atomic-result-fields-list.cjs.entry.js +1 -1
  90. package/dist/cjs/atomic-result-link.cjs.entry.js +1 -1
  91. package/dist/cjs/atomic-result-list.cjs.entry.js +1 -1
  92. package/dist/cjs/atomic-search-box-query-suggestions_2.cjs.entry.js +234 -0
  93. package/dist/cjs/atomic-search-box-query-suggestions_2.cjs.entry.js.map +1 -0
  94. package/dist/cjs/atomic-search-box.cjs.entry.js +15 -4
  95. package/dist/cjs/atomic-search-box.cjs.entry.js.map +1 -1
  96. package/dist/cjs/atomic-search-interface.cjs.entry.js +1 -1
  97. package/dist/cjs/atomic-smart-snippet-feedback-modal.cjs.entry.js +2 -2
  98. package/dist/cjs/atomic-sort-dropdown.cjs.entry.js +2 -2
  99. package/dist/cjs/atomic-sort-expression.cjs.entry.js +1 -1
  100. package/dist/cjs/atomic-tab-manager.cjs.entry.js +1 -1
  101. package/dist/cjs/atomic.cjs.js +1 -1
  102. package/dist/cjs/clock-f03ff827.js +7 -0
  103. package/dist/cjs/clock-f03ff827.js.map +1 -0
  104. package/dist/cjs/index-757bc886.js +2 -2
  105. package/dist/cjs/version.cjs.js +2 -2
  106. package/dist/esm/_loader.js +1 -1
  107. package/dist/esm/{analytics-config-18d42f83.js → analytics-config-c51d0bc9.js} +2 -2
  108. package/dist/esm/{analytics-config-18d42f83.js.map → analytics-config-c51d0bc9.js.map} +1 -1
  109. package/dist/esm/atomic-category-facet.entry.js +1 -1
  110. package/dist/esm/atomic-facet.entry.js +1 -1
  111. package/dist/esm/atomic-format-currency.entry.js +1 -1
  112. package/dist/esm/atomic-format-number.entry.js +1 -1
  113. package/dist/esm/atomic-format-unit.entry.js +1 -1
  114. package/dist/esm/atomic-insight-history-toggle.entry.js +2 -2
  115. package/dist/esm/atomic-insight-history-toggle.entry.js.map +1 -1
  116. package/dist/esm/atomic-insight-interface.entry.js +1 -1
  117. package/dist/esm/atomic-insight-user-actions-toggle.entry.js +2 -2
  118. package/dist/esm/atomic-insight-user-actions-toggle.entry.js.map +1 -1
  119. package/dist/esm/atomic-numeric-facet.entry.js +1 -1
  120. package/dist/esm/atomic-quickview-modal.entry.js +1 -1
  121. package/dist/esm/atomic-quickview.entry.js +1 -1
  122. package/dist/esm/atomic-recs-interface.entry.js +1 -1
  123. package/dist/esm/atomic-result-children.entry.js +1 -1
  124. package/dist/esm/atomic-result-fields-list.entry.js +1 -1
  125. package/dist/esm/atomic-result-link.entry.js +1 -1
  126. package/dist/esm/atomic-result-list.entry.js +1 -1
  127. package/dist/esm/atomic-search-box-query-suggestions_2.entry.js +229 -0
  128. package/dist/esm/atomic-search-box-query-suggestions_2.entry.js.map +1 -0
  129. package/dist/esm/atomic-search-box.entry.js +15 -4
  130. package/dist/esm/atomic-search-box.entry.js.map +1 -1
  131. package/dist/esm/atomic-search-interface.entry.js +1 -1
  132. package/dist/esm/atomic-smart-snippet-feedback-modal.entry.js +2 -2
  133. package/dist/esm/atomic-sort-dropdown.entry.js +2 -2
  134. package/dist/esm/atomic-sort-expression.entry.js +1 -1
  135. package/dist/esm/atomic-tab-manager.entry.js +1 -1
  136. package/dist/esm/atomic.js +1 -1
  137. package/dist/esm/clock-add3e9a5.js +5 -0
  138. package/dist/esm/clock-add3e9a5.js.map +1 -0
  139. package/dist/esm/index-3f35faca.js +2 -2
  140. package/dist/esm/version.js +2 -2
  141. package/dist/types/components/commerce/atomic-commerce-interface/atomic-commerce-interface.d.ts +29 -1
  142. package/dist/types/components/commerce/atomic-commerce-recommendation-interface/atomic-commerce-recommendation-interface.d.ts +1 -0
  143. package/dist/types/components/commerce/atomic-commerce-search-box/atomic-commerce-search-box.d.ts +1 -0
  144. package/dist/types/components/search/atomic-search-box/atomic-search-box.d.ts +1 -0
  145. package/dist/types/components/search/index.d.ts +0 -1
  146. package/dist/types/components/search/{atomic-search-box-recent-queries → search-box-suggestions/atomic-search-box-recent-queries}/atomic-search-box-recent-queries.d.ts +7 -15
  147. package/dist/types/components.d.ts +49 -0
  148. package/docs/atomic-docs.json +98 -1
  149. package/package.json +3 -3
  150. package/dist/atomic/components/components/search/atomic-search-box-recent-queries/atomic-search-box-recent-queries.js +0 -137
  151. package/dist/atomic/p-2e9db4ca.entry.js +0 -2
  152. package/dist/atomic/p-2e9db4ca.entry.js.map +0 -1
  153. package/dist/atomic/p-c88a3d2d.entry.js +0 -2
  154. package/dist/cjs/atomic-search-box-query-suggestions.cjs.entry.js +0 -76
  155. package/dist/cjs/atomic-search-box-query-suggestions.cjs.entry.js.map +0 -1
  156. package/dist/cjs/clock-7aeb19d0.js +0 -7
  157. package/dist/cjs/clock-7aeb19d0.js.map +0 -1
  158. package/dist/esm/atomic-search-box-query-suggestions.entry.js +0 -72
  159. package/dist/esm/atomic-search-box-query-suggestions.entry.js.map +0 -1
  160. package/dist/esm/clock-b1f5d7f7.js +0 -5
  161. package/dist/esm/clock-b1f5d7f7.js.map +0 -1
  162. /package/dist/atomic/{p-75e00690.entry.js.map → p-089be992.entry.js.map} +0 -0
  163. /package/dist/atomic/{p-4b3d253b.entry.js.map → p-09a3a067.entry.js.map} +0 -0
  164. /package/dist/atomic/{p-7b899b57.entry.js.map → p-1d1f54a5.entry.js.map} +0 -0
  165. /package/dist/atomic/{p-ae98c582.entry.js.map → p-2ce8220a.entry.js.map} +0 -0
  166. /package/dist/atomic/{p-877d35b1.entry.js.map → p-3b023e83.entry.js.map} +0 -0
  167. /package/dist/atomic/{p-52ba404c.entry.js.map → p-49c38b27.entry.js.map} +0 -0
  168. /package/dist/atomic/{p-299555fb.entry.js.map → p-4c41abd0.entry.js.map} +0 -0
  169. /package/dist/atomic/{p-88d5e178.entry.js.map → p-51a4606d.entry.js.map} +0 -0
  170. /package/dist/atomic/{p-0ce38b0d.entry.js.map → p-5528d006.entry.js.map} +0 -0
  171. /package/dist/atomic/{p-d00a12e9.entry.js.map → p-5f1fa581.entry.js.map} +0 -0
  172. /package/dist/atomic/{p-ba4bf29f.entry.js.map → p-6329ff94.entry.js.map} +0 -0
  173. /package/dist/atomic/{p-7383fd32.entry.js.map → p-6e6d686e.entry.js.map} +0 -0
  174. /package/dist/atomic/{p-a760d9f9.entry.js.map → p-7e2109e9.entry.js.map} +0 -0
  175. /package/dist/atomic/{p-b28011e6.entry.js.map → p-89085429.entry.js.map} +0 -0
  176. /package/dist/atomic/{p-39e63678.entry.js.map → p-89ab44de.entry.js.map} +0 -0
  177. /package/dist/atomic/{p-330e6e7c.entry.js.map → p-9c9b1965.entry.js.map} +0 -0
  178. /package/dist/atomic/{p-78b70622.entry.js.map → p-a8882a2a.entry.js.map} +0 -0
  179. /package/dist/atomic/{p-f22bcb8c.entry.js.map → p-b6963bae.entry.js.map} +0 -0
  180. /package/dist/atomic/{p-3c8d109e.entry.js.map → p-b7063a0d.entry.js.map} +0 -0
  181. /package/dist/atomic/{p-e1cc5150.js.map → p-c280cd05.js.map} +0 -0
  182. /package/dist/atomic/{p-5bc31a30.js.map → p-dd761b10.js.map} +0 -0
  183. /package/dist/atomic/{p-7b0b9e9b.entry.js.map → p-f289269f.entry.js.map} +0 -0
  184. /package/dist/atomic/{p-c49cfa0c.entry.js.map → p-fda26113.entry.js.map} +0 -0
@@ -481,7 +481,7 @@ const AtomicCategoryFacet = class {
481
481
  }
482
482
  render() {
483
483
  const { bindings: { i18n }, label, facetState: { facetSearch, enabled, valuesAsTrees, selectedValueAncestry }, searchStatusState: { hasError, firstSearchExecuted }, } = this;
484
- return (h(FacetGuard, { key: '560a3287cb2c891940283d5083def6e4fb7d688a', enabled: enabled, firstSearchExecuted: firstSearchExecuted, hasError: hasError, hasResults: valuesAsTrees.length > 0 }, firstSearchExecuted ? (h(FacetContainer, null, this.renderHeader(), !this.isCollapsed && [
484
+ return (h(FacetGuard, { key: '01bc9546504e065411c474121d53c5191d57d2e9', enabled: enabled, firstSearchExecuted: firstSearchExecuted, hasError: hasError, hasResults: valuesAsTrees.length > 0 }, firstSearchExecuted ? (h(FacetContainer, null, this.renderHeader(), !this.isCollapsed && [
485
485
  this.renderSearchInput(),
486
486
  shouldDisplaySearchResults(facetSearch) ? (h(Fragment, null, facetSearch.values.length ? (h(FacetValuesGroup, { i18n: i18n, label: label, query: facetSearch.query }, this.renderSearchResults())) : (h("div", { class: "mt-3" })), this.renderMatches())) : (h(Fragment, null, h(FacetValuesGroup, { i18n: i18n, label: label }, this.hasParents ? (h(CategoryFacetParentAsTreeContainer, { isTopLevel: true, className: "mt-3" }, this.renderValuesTree(selectedValueAncestry, true))) : (h(CategoryFacetChildrenAsTreeContainer, { className: "mt-3" }, this.renderChildren()))), this.renderShowMoreLess())),
487
487
  ])) : (h(FacetPlaceholder, { isCollapsed: this.isCollapsed, numberOfValues: this.numberOfValues }))));
@@ -262,7 +262,7 @@ const AtomicFacet = class {
262
262
  return true;
263
263
  }
264
264
  render() {
265
- return (h(FacetGuard, { key: '7cde9d27287caa0ef530f2155c33c6c9912aa017', enabled: this.facetState.enabled, hasError: this.searchStatusState.hasError, firstSearchExecuted: this.searchStatusState.firstSearchExecuted, hasResults: this.facetState.values.length > 0 }, this.searchStatusState.firstSearchExecuted ? (h(FacetContainer, null, h(FacetHeader, { i18n: this.bindings.i18n, label: this.definedLabel, onClearFilters: () => {
265
+ return (h(FacetGuard, { key: 'b2df11b285b166854e378fb05f48dc5b8b4bd503', enabled: this.facetState.enabled, hasError: this.searchStatusState.hasError, firstSearchExecuted: this.searchStatusState.firstSearchExecuted, hasResults: this.facetState.values.length > 0 }, this.searchStatusState.firstSearchExecuted ? (h(FacetContainer, null, h(FacetHeader, { i18n: this.bindings.i18n, label: this.definedLabel, onClearFilters: () => {
266
266
  this.focusTargets.header.focusAfterSearch();
267
267
  this.facet.deselectAll();
268
268
  }, numberOfActiveValues: this.activeValues.length, isCollapsed: this.isCollapsed, headingLevel: this.headingLevel, onToggleCollapse: () => (this.isCollapsed = !this.isCollapsed), headerRef: (el) => this.focusTargets.header.setTarget(el) }), this.renderBody())) : (h(FacetPlaceholder, { numberOfValues: this.numberOfValues, isCollapsed: this.isCollapsed }))));
@@ -19,7 +19,7 @@ const AtomicFormatCurrency = class {
19
19
  }
20
20
  render() {
21
21
  if (this.error) {
22
- return (h("atomic-component-error", { key: 'b501a8f3abe5b875899b003417aaf058cb275a2a', element: this.host, error: this.error }));
22
+ return (h("atomic-component-error", { key: 'c649c16618fac96b694c3f6cb378e822e2321a0a', element: this.host, error: this.error }));
23
23
  }
24
24
  }
25
25
  get host() { return getElement(this); }
@@ -31,7 +31,7 @@ const AtomicFormatNumber = class {
31
31
  }
32
32
  render() {
33
33
  if (this.error) {
34
- return (h("atomic-component-error", { key: '72fd0700517485e5cc38aa5cb58b4d9a3984dddb', element: this.host, error: this.error }));
34
+ return (h("atomic-component-error", { key: 'b8db0749ee8aed93331c5a6385aa07f732ec03e9', element: this.host, error: this.error }));
35
35
  }
36
36
  }
37
37
  get host() { return getElement(this); }
@@ -34,7 +34,7 @@ const AtomicFormatUnit = class {
34
34
  }
35
35
  render() {
36
36
  if (this.error) {
37
- return (h("atomic-component-error", { key: 'd875c8637c44118c50039cc4c4a369df9820a6de', element: this.host, error: this.error }));
37
+ return (h("atomic-component-error", { key: '5e34407ff07142c4765f234c4b9227727e0ff89a', element: this.host, error: this.error }));
38
38
  }
39
39
  }
40
40
  get host() { return getElement(this); }
@@ -1,5 +1,5 @@
1
1
  import { r as registerInstance, h } from './index-3f35faca.js';
2
- import { C as Clockicon } from './clock-b1f5d7f7.js';
2
+ import { C as Clock } from './clock-add3e9a5.js';
3
3
  import { I as IconButton } from './stencil-iconButton-ba40899c.js';
4
4
  import './stencil-button-1a29a5df.js';
5
5
  import './event-utils-8de63ec3.js';
@@ -17,7 +17,7 @@ const AtomicInsightHistoryToggle = class {
17
17
  this.tooltip = '';
18
18
  }
19
19
  render() {
20
- return (h(IconButton, { key: '83098c524b4d1197222a045b7da60d10ced398bf', partPrefix: "insight-history-toggle", style: "outline-neutral", icon: Clockicon, ariaLabel: "history", onClick: this.clickCallback, title: this.tooltip }));
20
+ return (h(IconButton, { key: '83098c524b4d1197222a045b7da60d10ced398bf', partPrefix: "insight-history-toggle", style: "outline-neutral", icon: Clock, ariaLabel: "history", onClick: this.clickCallback, title: this.tooltip }));
21
21
  }
22
22
  };
23
23
  AtomicInsightHistoryToggle.style = AtomicInsightHistoryToggleStyle0;
@@ -1 +1 @@
1
- {"file":"atomic-insight-history-toggle.entry.js","mappings":";;;;;;;AAAA,MAAM,6BAA6B,GAAG,yqjEAAyqjE,CAAC;AAChtjE,yCAAe,6BAA6B;;MCW/B,0BAA0B;;;QACP,kBAAa,GAAe,SAAQ,CAAC;QAErC,YAAO,GAAG,EAAE,CAAC;6BAFe,SAAQ;uBAE1B,EAAE;;IAEnC,MAAM;QACX,QACE,EAAC,UAAU,qDACT,UAAU,EAAC,wBAAwB,EACnC,KAAK,EAAC,iBAAiB,EACvB,IAAI,EAAE,SAAS,EACf,SAAS,EAAC,SAAS,EACnB,OAAO,EAAE,IAAI,CAAC,aAAa,EAC3B,KAAK,EAAE,IAAI,CAAC,OAAO,GACnB,EACF;KACH;;;;;;","names":[],"sources":["src/components/insight/atomic-insight-history-toggle/atomic-insight-history-toggle.pcss?tag=atomic-insight-history-toggle&encapsulation=shadow","src/components/insight/atomic-insight-history-toggle/atomic-insight-history-toggle.tsx"],"sourcesContent":["@import '../../../global/global.pcss';\n","import {Component, h, Prop} from '@stencil/core';\nimport Clockicon from '../../../images/clock.svg';\nimport {IconButton} from '../../common/stencil-iconButton';\n\n/**\n * @internal\n */\n@Component({\n tag: 'atomic-insight-history-toggle',\n styleUrl: 'atomic-insight-history-toggle.pcss',\n shadow: true,\n})\nexport class AtomicInsightHistoryToggle {\n @Prop({mutable: true}) public clickCallback: () => void = () => {};\n\n @Prop({mutable: true}) public tooltip = '';\n\n public render() {\n return (\n <IconButton\n partPrefix=\"insight-history-toggle\"\n style=\"outline-neutral\"\n icon={Clockicon}\n ariaLabel=\"history\"\n onClick={this.clickCallback}\n title={this.tooltip}\n />\n );\n }\n}\n"],"version":3}
1
+ {"file":"atomic-insight-history-toggle.entry.js","mappings":";;;;;;;AAAA,MAAM,6BAA6B,GAAG,yqjEAAyqjE,CAAC;AAChtjE,yCAAe,6BAA6B;;MCW/B,0BAA0B;;;QACP,kBAAa,GAAe,SAAQ,CAAC;QAErC,YAAO,GAAG,EAAE,CAAC;6BAFe,SAAQ;uBAE1B,EAAE;;IAEnC,MAAM;QACX,QACE,EAAC,UAAU,qDACT,UAAU,EAAC,wBAAwB,EACnC,KAAK,EAAC,iBAAiB,EACvB,IAAI,EAAEA,KAAS,EACf,SAAS,EAAC,SAAS,EACnB,OAAO,EAAE,IAAI,CAAC,aAAa,EAC3B,KAAK,EAAE,IAAI,CAAC,OAAO,GACnB,EACF;KACH;;;;;;","names":["Clockicon"],"sources":["src/components/insight/atomic-insight-history-toggle/atomic-insight-history-toggle.pcss?tag=atomic-insight-history-toggle&encapsulation=shadow","src/components/insight/atomic-insight-history-toggle/atomic-insight-history-toggle.tsx"],"sourcesContent":["@import '../../../global/global.pcss';\n","import {Component, h, Prop} from '@stencil/core';\nimport Clockicon from '../../../images/clock.svg';\nimport {IconButton} from '../../common/stencil-iconButton';\n\n/**\n * @internal\n */\n@Component({\n tag: 'atomic-insight-history-toggle',\n styleUrl: 'atomic-insight-history-toggle.pcss',\n shadow: true,\n})\nexport class AtomicInsightHistoryToggle {\n @Prop({mutable: true}) public clickCallback: () => void = () => {};\n\n @Prop({mutable: true}) public tooltip = '';\n\n public render() {\n return (\n <IconButton\n partPrefix=\"insight-history-toggle\"\n style=\"outline-neutral\"\n icon={Clockicon}\n ariaLabel=\"history\"\n onClick={this.clickCallback}\n title={this.tooltip}\n />\n );\n }\n}\n"],"version":3}
@@ -1,7 +1,7 @@
1
1
  import { r as registerInstance, s as setNonce, h, H as Host, g as getElement } from './index-3f35faca.js';
2
2
  import { m as markParentAsReady } from './init-queue-fbe942c3.js';
3
3
  import { buildResultsPerPage, loadFieldActions, buildInsightEngine } from '@coveo/headless/insight';
4
- import { g as getNextAnalyticsConfig, a as augmentWithExternalMiddleware, b as augmentAnalyticsWithAtomicVersion, C as CommonAtomicInterfaceHelper, i as instance } from './analytics-config-18d42f83.js';
4
+ import { g as getNextAnalyticsConfig, a as augmentWithExternalMiddleware, b as augmentAnalyticsWithAtomicVersion, C as CommonAtomicInterfaceHelper, i as instance } from './analytics-config-c51d0bc9.js';
5
5
  import { A as ArrayProp } from './props-utils-e97ad6bd.js';
6
6
  import { D as DEFAULT_MOBILE_BREAKPOINT } from './replace-breakpoint-utils-7a336631.js';
7
7
  import { u as unsetLoadingFlag, s as setLoadingFlag, r as registerFacet, g as getFacetElements, w as waitUntilAppLoaded, a as createBaseStore } from './store-015afa83.js';
@@ -1,6 +1,6 @@
1
1
  import { r as registerInstance, h, g as getElement } from './index-3f35faca.js';
2
2
  import { buildUserActions } from '@coveo/headless/insight';
3
- import { C as Clockicon } from './clock-b1f5d7f7.js';
3
+ import { C as Clock } from './clock-add3e9a5.js';
4
4
  import { I as InitializeBindings, B as BindStateToController } from './initialization-utils-ffbc4136.js';
5
5
  import { I as IconButton } from './stencil-iconButton-ba40899c.js';
6
6
  import './dom-utils-f6086cd3.js';
@@ -60,7 +60,7 @@ const AtomicInsightUserActionsToggle = class {
60
60
  this.modalRef.excludedCustomActions = this.excludedCustomActions;
61
61
  }
62
62
  render() {
63
- return (h(IconButton, { key: 'e146b9c160034349da8ffc4d416cc37547576bde', partPrefix: "insight-user-actions-toggle", style: "outline-neutral", icon: Clockicon, ariaLabel: this.bindings.i18n.t('user-actions'), onClick: () => {
63
+ return (h(IconButton, { key: 'e146b9c160034349da8ffc4d416cc37547576bde', partPrefix: "insight-user-actions-toggle", style: "outline-neutral", icon: Clock, ariaLabel: this.bindings.i18n.t('user-actions'), onClick: () => {
64
64
  this.enableModal();
65
65
  }, title: this.bindings.i18n.t('user-actions'), buttonRef: (button) => {
66
66
  if (!button) {
@@ -1 +1 @@
1
- {"file":"atomic-insight-user-actions-toggle.entry.js","mappings":";;;;;;;;;;;;AAAA,MAAM,iCAAiC,GAAG,yqjEAAyqjE,CAAC;AACptjE,6CAAe,iCAAiC;;;;;;;;;;;;MCuBnC,8BAA8B;;;;;;QAsB1B,0BAAqB,GAAa,EAAE,CAAC;;;;;qCAAH,EAAE;;IAE5C,UAAU;QACf,IAAI,CAAC,WAAW,GAAGA,gBAAuB,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YAC/D,OAAO,EAAE;gBACP,kBAAkB,EAAE,IAAI,CAAC,sBAAsB;gBAC/C,qBAAqB,EAAE,IAAI,CAAC,qBAAqB;aAClD;SACF,CAAC,CAAC;KACJ;IAKO,WAAW;QACjB,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;QAC/C,IAAI,CAAC,WAAW,CAAC,kBAAkB,EAAE,CAAC;KACvC;IAEO,SAAS;QACf,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO;SACR;QAED,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,mCAAmC,CAAC,CAAC;QAE5E,IAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC9D,IAAI,CAAC,QAAQ,CAAC,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC;QAC1C,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QACnC,IAAI,CAAC,QAAQ,CAAC,sBAAsB,GAAG,IAAI,CAAC,sBAAsB,CAAC;QACnE,IAAI,CAAC,QAAQ,CAAC,qBAAqB,GAAG,IAAI,CAAC,qBAAqB,CAAC;KAClE;IAEM,MAAM;QACX,QACE,EAAC,UAAU,qDACT,UAAU,EAAC,6BAA6B,EACxC,KAAK,EAAC,iBAAiB,EACvB,IAAI,EAAE,SAAS,EACf,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC,EAC/C,OAAO,EAAE;gBACP,IAAI,CAAC,WAAW,EAAE,CAAC;aACpB,EACD,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC,EAC3C,SAAS,EAAE,CAAC,MAA0B;gBACpC,IAAI,CAAC,MAAM,EAAE;oBACX,OAAO;iBACR;gBACD,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC;gBACxB,IAAI,CAAC,SAAS,EAAE,CAAC;aAClB,GACD,EACF;KACH;;;AAvE4B;IAA5B,kBAAkB,EAAE;gEAAmC;AAIjD;IAFN,qBAAqB,CAAC,aAAa,CAAC;wEAEa;;;;;","names":["buildInsightUserActions"],"sources":["src/components/insight/user-actions/atomic-insight-user-actions-toggle/atomic-insight-user-actions-toggle.pcss?tag=atomic-insight-user-actions-toggle&encapsulation=shadow","src/components/insight/user-actions/atomic-insight-user-actions-toggle/atomic-insight-user-actions-toggle.tsx"],"sourcesContent":["@import '../../../../global/global.pcss';\n","import {\n buildUserActions as buildInsightUserActions,\n UserActions as InsightUserActions,\n UserActionsState as InsightUserActionsState,\n} from '@coveo/headless/insight';\nimport {Component, h, Prop, Element, State} from '@stencil/core';\nimport Clockicon from '../../../../images/clock.svg';\nimport {\n BindStateToController,\n InitializableComponent,\n InitializeBindings,\n} from '../../../../utils/initialization-utils';\nimport {IconButton} from '../../../common/stencil-iconButton';\nimport {InsightBindings} from '../../atomic-insight-interface/atomic-insight-interface';\n\n/**\n * Internal component of the atomic-insight-interface\n * The `atomic-insight-user-actions-toggle` component displays a button that opens a modal containing the user actions timeline component.\n */\n@Component({\n tag: 'atomic-insight-user-actions-toggle',\n styleUrl: 'atomic-insight-user-actions-toggle.pcss',\n shadow: true,\n})\nexport class AtomicInsightUserActionsToggle\n implements InitializableComponent<InsightBindings>\n{\n @Element() public host!: HTMLElement;\n @InitializeBindings() public bindings!: InsightBindings;\n public userActions!: InsightUserActions;\n @BindStateToController('userActions')\n @State()\n public userActionsState!: InsightUserActionsState;\n @State() public error!: Error;\n\n /**\n * The ID of the user whose actions are being displayed.\n */\n @Prop() public userId!: string;\n /**\n * The date and time when the case was created. For example \"2024-01-01T00:00:00Z\"\n */\n @Prop() public ticketCreationDateTime!: string;\n /**\n * The names of custom events to exclude.\n */\n @Prop() public excludedCustomActions: string[] = [];\n\n public initialize() {\n this.userActions = buildInsightUserActions(this.bindings.engine, {\n options: {\n ticketCreationDate: this.ticketCreationDateTime,\n excludedCustomActions: this.excludedCustomActions,\n },\n });\n }\n\n private buttonRef?: HTMLButtonElement;\n private modalRef?: HTMLAtomicInsightUserActionsModalElement;\n\n private enableModal() {\n this.modalRef && (this.modalRef.isOpen = true);\n this.userActions.logOpenUserActions();\n }\n\n private loadModal() {\n if (this.modalRef) {\n return;\n }\n\n this.modalRef = document.createElement('atomic-insight-user-actions-modal');\n\n this.host.insertAdjacentElement('beforebegin', this.modalRef);\n this.modalRef.openButton = this.buttonRef;\n this.modalRef.userId = this.userId;\n this.modalRef.ticketCreationDateTime = this.ticketCreationDateTime;\n this.modalRef.excludedCustomActions = this.excludedCustomActions;\n }\n\n public render() {\n return (\n <IconButton\n partPrefix=\"insight-user-actions-toggle\"\n style=\"outline-neutral\"\n icon={Clockicon}\n ariaLabel={this.bindings.i18n.t('user-actions')}\n onClick={() => {\n this.enableModal();\n }}\n title={this.bindings.i18n.t('user-actions')}\n buttonRef={(button?: HTMLButtonElement) => {\n if (!button) {\n return;\n }\n this.buttonRef = button;\n this.loadModal();\n }}\n />\n );\n }\n}\n"],"version":3}
1
+ {"file":"atomic-insight-user-actions-toggle.entry.js","mappings":";;;;;;;;;;;;AAAA,MAAM,iCAAiC,GAAG,yqjEAAyqjE,CAAC;AACptjE,6CAAe,iCAAiC;;;;;;;;;;;;MCuBnC,8BAA8B;;;;;;QAsB1B,0BAAqB,GAAa,EAAE,CAAC;;;;;qCAAH,EAAE;;IAE5C,UAAU;QACf,IAAI,CAAC,WAAW,GAAGA,gBAAuB,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YAC/D,OAAO,EAAE;gBACP,kBAAkB,EAAE,IAAI,CAAC,sBAAsB;gBAC/C,qBAAqB,EAAE,IAAI,CAAC,qBAAqB;aAClD;SACF,CAAC,CAAC;KACJ;IAKO,WAAW;QACjB,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;QAC/C,IAAI,CAAC,WAAW,CAAC,kBAAkB,EAAE,CAAC;KACvC;IAEO,SAAS;QACf,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO;SACR;QAED,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,mCAAmC,CAAC,CAAC;QAE5E,IAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC9D,IAAI,CAAC,QAAQ,CAAC,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC;QAC1C,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QACnC,IAAI,CAAC,QAAQ,CAAC,sBAAsB,GAAG,IAAI,CAAC,sBAAsB,CAAC;QACnE,IAAI,CAAC,QAAQ,CAAC,qBAAqB,GAAG,IAAI,CAAC,qBAAqB,CAAC;KAClE;IAEM,MAAM;QACX,QACE,EAAC,UAAU,qDACT,UAAU,EAAC,6BAA6B,EACxC,KAAK,EAAC,iBAAiB,EACvB,IAAI,EAAEC,KAAS,EACf,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC,EAC/C,OAAO,EAAE;gBACP,IAAI,CAAC,WAAW,EAAE,CAAC;aACpB,EACD,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC,EAC3C,SAAS,EAAE,CAAC,MAA0B;gBACpC,IAAI,CAAC,MAAM,EAAE;oBACX,OAAO;iBACR;gBACD,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC;gBACxB,IAAI,CAAC,SAAS,EAAE,CAAC;aAClB,GACD,EACF;KACH;;;AAvE4B;IAA5B,kBAAkB,EAAE;gEAAmC;AAIjD;IAFN,qBAAqB,CAAC,aAAa,CAAC;wEAEa;;;;;","names":["buildInsightUserActions","Clockicon"],"sources":["src/components/insight/user-actions/atomic-insight-user-actions-toggle/atomic-insight-user-actions-toggle.pcss?tag=atomic-insight-user-actions-toggle&encapsulation=shadow","src/components/insight/user-actions/atomic-insight-user-actions-toggle/atomic-insight-user-actions-toggle.tsx"],"sourcesContent":["@import '../../../../global/global.pcss';\n","import {\n buildUserActions as buildInsightUserActions,\n UserActions as InsightUserActions,\n UserActionsState as InsightUserActionsState,\n} from '@coveo/headless/insight';\nimport {Component, h, Prop, Element, State} from '@stencil/core';\nimport Clockicon from '../../../../images/clock.svg';\nimport {\n BindStateToController,\n InitializableComponent,\n InitializeBindings,\n} from '../../../../utils/initialization-utils';\nimport {IconButton} from '../../../common/stencil-iconButton';\nimport {InsightBindings} from '../../atomic-insight-interface/atomic-insight-interface';\n\n/**\n * Internal component of the atomic-insight-interface\n * The `atomic-insight-user-actions-toggle` component displays a button that opens a modal containing the user actions timeline component.\n */\n@Component({\n tag: 'atomic-insight-user-actions-toggle',\n styleUrl: 'atomic-insight-user-actions-toggle.pcss',\n shadow: true,\n})\nexport class AtomicInsightUserActionsToggle\n implements InitializableComponent<InsightBindings>\n{\n @Element() public host!: HTMLElement;\n @InitializeBindings() public bindings!: InsightBindings;\n public userActions!: InsightUserActions;\n @BindStateToController('userActions')\n @State()\n public userActionsState!: InsightUserActionsState;\n @State() public error!: Error;\n\n /**\n * The ID of the user whose actions are being displayed.\n */\n @Prop() public userId!: string;\n /**\n * The date and time when the case was created. For example \"2024-01-01T00:00:00Z\"\n */\n @Prop() public ticketCreationDateTime!: string;\n /**\n * The names of custom events to exclude.\n */\n @Prop() public excludedCustomActions: string[] = [];\n\n public initialize() {\n this.userActions = buildInsightUserActions(this.bindings.engine, {\n options: {\n ticketCreationDate: this.ticketCreationDateTime,\n excludedCustomActions: this.excludedCustomActions,\n },\n });\n }\n\n private buttonRef?: HTMLButtonElement;\n private modalRef?: HTMLAtomicInsightUserActionsModalElement;\n\n private enableModal() {\n this.modalRef && (this.modalRef.isOpen = true);\n this.userActions.logOpenUserActions();\n }\n\n private loadModal() {\n if (this.modalRef) {\n return;\n }\n\n this.modalRef = document.createElement('atomic-insight-user-actions-modal');\n\n this.host.insertAdjacentElement('beforebegin', this.modalRef);\n this.modalRef.openButton = this.buttonRef;\n this.modalRef.userId = this.userId;\n this.modalRef.ticketCreationDateTime = this.ticketCreationDateTime;\n this.modalRef.excludedCustomActions = this.excludedCustomActions;\n }\n\n public render() {\n return (\n <IconButton\n partPrefix=\"insight-user-actions-toggle\"\n style=\"outline-neutral\"\n icon={Clockicon}\n ariaLabel={this.bindings.i18n.t('user-actions')}\n onClick={() => {\n this.enableModal();\n }}\n title={this.bindings.i18n.t('user-actions')}\n buttonRef={(button?: HTMLButtonElement) => {\n if (!button) {\n return;\n }\n this.buttonRef = button;\n this.loadModal();\n }}\n />\n );\n }\n}\n"],"version":3}
@@ -305,7 +305,7 @@ const AtomicNumericFacet = class {
305
305
  }
306
306
  render() {
307
307
  const { searchStatusState: { firstSearchExecuted, hasError }, bindings: { i18n }, } = this;
308
- return (h(FacetGuard, { key: '481b5d0d304d6e7f6696faa14dc0dbb501f0490d', enabled: this.enabled, firstSearchExecuted: firstSearchExecuted, hasError: hasError, hasResults: this.shouldRenderFacet }, firstSearchExecuted ? (h(FacetContainer, null, h(FacetHeader, { i18n: i18n, label: this.label, onClearFilters: () => {
308
+ return (h(FacetGuard, { key: '4ae7f2c657012459dadc76b6c2f8215a19341e9e', enabled: this.enabled, firstSearchExecuted: firstSearchExecuted, hasError: hasError, hasResults: this.shouldRenderFacet }, firstSearchExecuted ? (h(FacetContainer, null, h(FacetHeader, { i18n: i18n, label: this.label, onClearFilters: () => {
309
309
  this.focusTarget.focusAfterSearch();
310
310
  if (this.filterState?.range) {
311
311
  this.filter?.clear();
@@ -586,7 +586,7 @@ const AtomicQuickviewModal = class {
586
586
  });
587
587
  }
588
588
  render() {
589
- return (h("atomic-modal", { key: '39961d2d82abff5de836cc62847719c3c8e42a8a', fullscreen: this.bindings.store.isMobile(), class: 'atomic-quickview-modal', isOpen: this.isOpen, close: () => this.onClose(), exportparts: ATOMIC_MODAL_EXPORT_PARTS }, this.renderHeader(), this.renderBody(), this.renderFooter()));
589
+ return (h("atomic-modal", { key: '561499630f5da5df55933332f8c9567d57d0e22e', fullscreen: this.bindings.store.isMobile(), class: 'atomic-quickview-modal', isOpen: this.isOpen, close: () => this.onClose(), exportparts: ATOMIC_MODAL_EXPORT_PARTS }, this.renderHeader(), this.renderBody(), this.renderFooter()));
590
590
  }
591
591
  static get watchers() { return {
592
592
  "highlightKeywords": ["watchHighlightKeywords"]
@@ -112,7 +112,7 @@ const AtomicQuickview = class {
112
112
  }
113
113
  render() {
114
114
  if (this.quickviewState.resultHasPreview) {
115
- return (h(Button, { key: 'e764a4103dfec30f0fc15ad4237aaa64a2db267c', part: "button", title: this.bindings.i18n.t('quickview'), style: "outline-primary", class: "p-2", onClick: (event) => this.onClick(event), ref: this.focusTarget.setTarget }, h("atomic-icon", { key: '5df8ef61e0138ba63512897f99364391e5c5be14', part: "icon", class: "flex w-5 justify-center", icon: QuickviewIcon })));
115
+ return (h(Button, { key: '14fe117eb06409f41f2ec124669944fea2b710fc', part: "button", title: this.bindings.i18n.t('quickview'), style: "outline-primary", class: "p-2", onClick: (event) => this.onClick(event), ref: this.focusTarget.setTarget }, h("atomic-icon", { key: '4048bf25642bf6548716557132e62996ac5dda96', part: "icon", class: "flex w-5 justify-center", icon: QuickviewIcon })));
116
116
  }
117
117
  }
118
118
  };
@@ -1,7 +1,7 @@
1
1
  import { r as registerInstance, s as setNonce, h, g as getElement } from './index-3f35faca.js';
2
2
  import { m as markParentAsReady } from './init-queue-fbe942c3.js';
3
3
  import { loadRecommendationActions, loadSearchConfigurationActions, EcommerceDefaultFieldsToInclude, loadFieldActions, buildRecommendationEngine } from '@coveo/headless/recommendation';
4
- import { g as getNextAnalyticsConfig, c as augmentAnalyticsConfigWithDocument, d as augmentAnalyticsConfigWithAtomicVersion, a as augmentWithExternalMiddleware, b as augmentAnalyticsWithAtomicVersion, C as CommonAtomicInterfaceHelper, i as instance, m as mismatchedInterfaceAndEnginePropError } from './analytics-config-18d42f83.js';
4
+ import { g as getNextAnalyticsConfig, c as augmentAnalyticsConfigWithDocument, d as augmentAnalyticsConfigWithAtomicVersion, a as augmentWithExternalMiddleware, b as augmentAnalyticsWithAtomicVersion, C as CommonAtomicInterfaceHelper, i as instance, m as mismatchedInterfaceAndEnginePropError } from './analytics-config-c51d0bc9.js';
5
5
  import { A as ArrayProp } from './props-utils-e97ad6bd.js';
6
6
  import { u as unsetLoadingFlag, s as setLoadingFlag, a as createBaseStore } from './store-015afa83.js';
7
7
  import './dayjs.min-d04628c6.js';
@@ -135,7 +135,7 @@ const AtomicResultChildren = class {
135
135
  return (h(ChildrenWrapper, { hasChildren: children.length > 0 }, children.map((child, i) => this.renderChild(child, i === children.length - 1))));
136
136
  }
137
137
  render() {
138
- return (h(ResultChildrenGuard, { key: '28a209dcfc87da57c297a1a5fe5a06877311eaf7', inheritTemplates: this.inheritTemplates, resultTemplateRegistered: this.resultTemplateRegistered, templateHasError: this.templateHasError }, this.collection ? this.renderCollection() : this.renderFoldedResult()));
138
+ return (h(ResultChildrenGuard, { key: '2150e9417d88508b82af66754c3ae89c000f934a', inheritTemplates: this.inheritTemplates, resultTemplateRegistered: this.resultTemplateRegistered, templateHasError: this.templateHasError }, this.collection ? this.renderCollection() : this.renderFoldedResult()));
139
139
  }
140
140
  get host() { return getElement(this); }
141
141
  };
@@ -100,7 +100,7 @@ const AtomicResultFieldsList = class {
100
100
  }
101
101
  }
102
102
  render() {
103
- return h(Host, { key: '7206c67fd17f812fdf7a5aaf9429af162907677e' });
103
+ return h(Host, { key: 'f4108a4cdb1f7e0bf7d8658268f68bab2b0e4311' });
104
104
  }
105
105
  get host() { return getElement(this); }
106
106
  };
@@ -46,7 +46,7 @@ const AtomicResultLink = class {
46
46
  const href = isUndefined(this.hrefTemplate)
47
47
  ? this.result.clickUri
48
48
  : buildStringTemplateFromResult(this.hrefTemplate, this.result, this.bindings);
49
- return (h(LinkWithItemAnalytics, { key: 'adbdf25dba24847402d7ba4afd254627e6ae833c', href: href, onSelect: () => this.interactiveResult.select(), onBeginDelayedSelect: () => this.interactiveResult.beginDelayedSelect(), onCancelPendingSelect: () => this.interactiveResult.cancelPendingSelect(), attributes: this.linkAttributes, stopPropagation: this.stopPropagation }, this.hasDefaultSlot ? (h("slot", null)) : (h("atomic-result-text", { field: "title", default: "no-title" }))));
49
+ return (h(LinkWithItemAnalytics, { key: 'f8ab6cddf502983ab1563fbff477cb3c3aaa2db2', href: href, onSelect: () => this.interactiveResult.select(), onBeginDelayedSelect: () => this.interactiveResult.beginDelayedSelect(), onCancelPendingSelect: () => this.interactiveResult.cancelPendingSelect(), attributes: this.linkAttributes, stopPropagation: this.stopPropagation }, this.hasDefaultSlot ? (h("slot", null)) : (h("atomic-result-text", { field: "title", default: "no-title" }))));
50
50
  }
51
51
  get host() { return getElement(this); }
52
52
  };
@@ -191,7 +191,7 @@ const AtomicResultList = class {
191
191
  render() {
192
192
  this.resultListCommon.updateBreakpoints();
193
193
  const listClasses = this.computeListDisplayClasses();
194
- return (h(TabGuard, { key: '3300c868d8f38a4f7215288c091db4f60bec918b', tabsIncluded: this.tabsIncluded, tabsExcluded: this.tabsExcluded, activeTab: this.tabManagerState.activeTab }, h(ItemListGuard, { key: '76429f5c16104eed0ff58b83dd2cb94f807e2b62', hasError: this.resultListState.hasError, hasTemplate: this.resultTemplateRegistered, templateHasError: this.itemTemplateProvider.hasError, firstRequestExecuted: this.resultListState.firstSearchExecuted, hasItems: this.resultListState.hasResults }, h(DisplayWrapper, { key: 'f0944363d4bba184e1e76869f507ea03bed2951d', display: this.display, listClasses: listClasses }, h(ResultsPlaceholdersGuard, { key: 'c91a24daf9e86581e73f8ac514eca75275778376', density: this.density, display: this.display, imageSize: this.imageSize, displayPlaceholders: !this.isAppLoaded, numberOfPlaceholders: this.resultsPerPageState.numberOfResults }), h(ItemDisplayGuard, { key: '8266609ac00b5e0c3fb8eb7be5c3485b20c7b3d6', firstRequestExecuted: this.resultListState.firstSearchExecuted, hasItems: this.resultListState.hasResults }, this.display === 'table'
194
+ return (h(TabGuard, { key: '84e905bc447448b3ae9701cc63b6b36ea2d8a0fd', tabsIncluded: this.tabsIncluded, tabsExcluded: this.tabsExcluded, activeTab: this.tabManagerState.activeTab }, h(ItemListGuard, { key: '8a1fe0484e410fceaa0815e61630478fc3a7112a', hasError: this.resultListState.hasError, hasTemplate: this.resultTemplateRegistered, templateHasError: this.itemTemplateProvider.hasError, firstRequestExecuted: this.resultListState.firstSearchExecuted, hasItems: this.resultListState.hasResults }, h(DisplayWrapper, { key: '2c7bd5851175b7414ff588c2c53d9a561e68c33a', display: this.display, listClasses: listClasses }, h(ResultsPlaceholdersGuard, { key: '92540528744f9fb632dadc7d048b817905380440', density: this.density, display: this.display, imageSize: this.imageSize, displayPlaceholders: !this.isAppLoaded, numberOfPlaceholders: this.resultsPerPageState.numberOfResults }), h(ItemDisplayGuard, { key: '246eafcd94c68ff9fe662f8efc2f9faee2cbe8dc', firstRequestExecuted: this.resultListState.firstSearchExecuted, hasItems: this.resultListState.hasResults }, this.display === 'table'
195
195
  ? this.renderAsTable()
196
196
  : this.display === 'grid'
197
197
  ? this.renderAsGrid()
@@ -0,0 +1,229 @@
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: '215a9db1f42f1688a334a727efa99767ecc7cfa1', 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: 'a02dad03f81cece33429bdf45b2f1b8997dfb499', 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
@@ -0,0 +1 @@
1
+ {"file":"atomic-search-box-query-suggestions.atomic-search-box-recent-queries.entry.js","mappings":"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","names":[],"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}
@@ -10,6 +10,7 @@ import { o as once, r as randomID, j as spreadProperties, h as isFocusingOut } f
10
10
  import { a as SearchSlimIcon, b as SearchTextArea, S as SuggestionManager, c as SearchBoxWrapper } from './stencil-suggestion-manager-376f83e8.js';
11
11
  import { B as Button } from './stencil-button-1a29a5df.js';
12
12
  import { a as elementHasQuery } from './suggestions-utils-591559a0.js';
13
+ import { a as getDefaultSlotFromHost } from './slot-utils-dcf4fc27.js';
13
14
  import './dom-utils-f6086cd3.js';
14
15
  import './event-utils-8de63ec3.js';
15
16
  import './init-queue-fbe942c3.js';
@@ -423,6 +424,16 @@ const AtomicSearchBox = class {
423
424
  })
424
425
  : this.bindings.i18n.t('query-suggestions-unavailable');
425
426
  }
427
+ renderSlotContent() {
428
+ const hasDefaultSlot = !!getDefaultSlotFromHost(this.host);
429
+ if (hasDefaultSlot) {
430
+ return h("slot", null);
431
+ }
432
+ return [
433
+ h("atomic-search-box-recent-queries", null),
434
+ h("atomic-search-box-query-suggestions", null),
435
+ ];
436
+ }
426
437
  render() {
427
438
  this.updateBreakpoints();
428
439
  const searchLabel = this.getSearchInputLabel(this.minimumQueryLength);
@@ -430,18 +441,18 @@ const AtomicSearchBox = class {
430
441
  if (!this.suggestionManager.suggestions.length) {
431
442
  this.registerSearchboxSuggestionEvents();
432
443
  }
433
- return (h(Host, { key: 'e3ed5e9633d8f37158974ae3f1b21cedf5f7de01' }, this.renderAbsolutePositionSpacer(), [
434
- h(SearchBoxWrapper, { key: 'b5f0da61b7ac4f1fee156de7027945040dbbf500', disabled: isDisabled, onFocusout: (event) => {
444
+ return (h(Host, { key: '58faa4cda9561d97a09018d88071992175d330d3' }, this.renderAbsolutePositionSpacer(), [
445
+ h(SearchBoxWrapper, { key: '9bb8cd4336c51d4ea2aa3a7f41b55dadaeed2eee', disabled: isDisabled, onFocusout: (event) => {
435
446
  if (!isFocusingOut(event)) {
436
447
  return;
437
448
  }
438
449
  this.suggestionManager.clearSuggestions();
439
450
  this.isExpanded = false;
440
- } }, this.renderTextBox(searchLabel), h(SubmitButton, { key: 'c8c6083671167dac6c211c7b456dcfe87ca1cfaa', bindings: this.bindings, disabled: isDisabled, onClick: () => {
451
+ } }, this.renderTextBox(searchLabel), h(SubmitButton, { key: 'acf07db6d58c8e2341970ca3ea4071e913494aa3', bindings: this.bindings, disabled: isDisabled, onClick: () => {
441
452
  this.searchBox.submit();
442
453
  this.suggestionManager.clearSuggestions();
443
454
  } }), this.renderSuggestions()),
444
- !this.suggestionManager.suggestions.length && (h("slot", { key: 'd6c0f1ff47370f794d0dc81782ced70baa04db91' }, h("atomic-search-box-recent-queries", { key: 'e599e83ae1f15386e310d1e03b8111144d452a8e' }), h("atomic-search-box-query-suggestions", { key: '6d446202f6722a66714ac067ad78afcf853a5dbe' }))),
455
+ this.renderSlotContent(),
445
456
  ]));
446
457
  }
447
458
  get host() { return getElement(this); }