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

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 (225) 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 -2
  4. package/dist/atomic/components/_index.js +1 -1
  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/atomic/components/atomic-numeric-facet.js +1 -1
  18. package/dist/atomic/components/atomic-query-error.js +1 -1
  19. package/dist/atomic/components/atomic-quickview-modal2.js +1 -1
  20. package/dist/atomic/components/atomic-quickview.js +1 -1
  21. package/dist/atomic/components/atomic-refine-modal2.js +1 -1
  22. package/dist/atomic/components/atomic-refine-toggle.js +1 -1
  23. package/dist/atomic/components/atomic-relevance-inspector2.js +2 -2
  24. package/dist/atomic/components/atomic-result-children.js +1 -1
  25. package/dist/atomic/components/atomic-result-fields-list.js +1 -1
  26. package/dist/atomic/components/atomic-result-link.js +1 -1
  27. package/dist/atomic/components/atomic-result-list.js +1 -1
  28. package/dist/atomic/components/atomic-result-table-placeholder2.js +1 -1
  29. package/dist/atomic/components/atomic-search-box-query-suggestions2.js +1 -1
  30. package/dist/atomic/components/atomic-search-box-recent-queries.d.ts +11 -0
  31. package/dist/atomic/components/atomic-search-box-recent-queries.js +8 -0
  32. package/dist/atomic/components/atomic-search-box-recent-queries.js.map +1 -0
  33. package/dist/atomic/components/atomic-search-box-recent-queries2.js +183 -0
  34. package/dist/atomic/components/atomic-search-box-recent-queries2.js.map +1 -0
  35. package/dist/atomic/components/atomic-search-box.js +12 -6
  36. package/dist/atomic/components/atomic-search-box.js.map +1 -1
  37. package/dist/atomic/components/atomic-smart-snippet-feedback-modal2.js +2 -2
  38. package/dist/atomic/components/atomic-sort-dropdown.js +2 -2
  39. package/dist/atomic/components/atomic-sort-expression.js +1 -1
  40. package/dist/atomic/components/atomic-tab-manager.js +1 -1
  41. package/dist/atomic/components/clock.js +2 -2
  42. package/dist/atomic/components/components/search/atomic-pager/atomic-pager.js +175 -0
  43. package/dist/atomic/components/components/search/index.js +1 -1
  44. package/dist/atomic/components/components/search/lazy-index.js +1 -1
  45. package/dist/atomic/components/global/environment.js +1 -1
  46. package/dist/atomic/{p-ae060711.entry.js → p-00e5bb15.entry.js} +2 -2
  47. package/dist/atomic/{p-5bc31a30.js → p-031670fe.js} +2 -2
  48. package/dist/atomic/{p-330e6e7c.entry.js → p-3af5c567.entry.js} +2 -2
  49. package/dist/atomic/{p-88d5e178.entry.js → p-43c16eeb.entry.js} +2 -2
  50. package/dist/atomic/{p-75e00690.entry.js → p-45c4685e.entry.js} +2 -2
  51. package/dist/atomic/{p-0ce38b0d.entry.js → p-470f88ed.entry.js} +2 -2
  52. package/dist/atomic/{p-ae98c582.entry.js → p-4915faeb.entry.js} +2 -2
  53. package/dist/atomic/{p-52ba404c.entry.js → p-4c30ca3e.entry.js} +2 -2
  54. package/dist/atomic/{p-39e63678.entry.js → p-4e9d1f9e.entry.js} +2 -2
  55. package/dist/atomic/p-516b8165.entry.js +2 -0
  56. package/dist/atomic/p-516b8165.entry.js.map +1 -0
  57. package/dist/atomic/p-593903ec.entry.js +2 -0
  58. package/dist/atomic/p-593903ec.entry.js.map +1 -0
  59. package/dist/atomic/{p-877d35b1.entry.js → p-5adbf098.entry.js} +2 -2
  60. package/dist/atomic/{p-ba4bf29f.entry.js → p-6329ff94.entry.js} +2 -2
  61. package/dist/atomic/{p-4b3d253b.entry.js → p-65373475.entry.js} +2 -2
  62. package/dist/atomic/{p-7383fd32.entry.js → p-6e6d686e.entry.js} +2 -2
  63. package/dist/atomic/{p-3c8d109e.entry.js → p-6f988841.entry.js} +2 -2
  64. package/dist/atomic/{p-b28011e6.entry.js → p-71bb8125.entry.js} +2 -2
  65. package/dist/atomic/{p-de066001.entry.js → p-757de797.entry.js} +2 -2
  66. package/dist/atomic/{p-78b70622.entry.js → p-8acb1466.entry.js} +2 -2
  67. package/dist/atomic/{p-93e29b24.entry.js → p-9883415e.entry.js} +2 -2
  68. package/dist/atomic/{p-7b899b57.entry.js → p-a02b1209.entry.js} +2 -2
  69. package/dist/atomic/{p-d00a12e9.entry.js → p-b4ad3036.entry.js} +2 -2
  70. package/dist/atomic/{p-a760d9f9.entry.js → p-be1b98a6.entry.js} +2 -2
  71. package/dist/atomic/{p-7dfcd6af.entry.js → p-bf50b64d.entry.js} +2 -2
  72. package/dist/atomic/{p-e1cc5150.js → p-c280cd05.js} +1 -1
  73. package/dist/atomic/{p-c49cfa0c.entry.js → p-d11b2b24.entry.js} +2 -2
  74. package/dist/atomic/{p-f22bcb8c.entry.js → p-d2d22ab2.entry.js} +2 -2
  75. package/dist/atomic/{p-299555fb.entry.js → p-e1865f9f.entry.js} +2 -2
  76. package/dist/atomic/{p-021f01d6.entry.js → p-e8d5e852.entry.js} +2 -2
  77. package/dist/atomic/{p-7b0b9e9b.entry.js → p-f073a78d.entry.js} +2 -2
  78. package/dist/atomic/{p-c88a3d2d.entry.js → p-fb7ad34b.entry.js} +2 -2
  79. package/dist/cjs/_loader.cjs.js +1 -1
  80. package/dist/cjs/{analytics-config-68dbae8e.js → analytics-config-e3890e2c.js} +2 -2
  81. package/dist/cjs/{analytics-config-68dbae8e.js.map → analytics-config-e3890e2c.js.map} +1 -1
  82. package/dist/cjs/atomic-category-facet.cjs.entry.js +1 -1
  83. package/dist/cjs/atomic-facet.cjs.entry.js +1 -1
  84. package/dist/cjs/atomic-format-currency.cjs.entry.js +1 -1
  85. package/dist/cjs/atomic-format-number.cjs.entry.js +1 -1
  86. package/dist/cjs/atomic-format-unit.cjs.entry.js +1 -1
  87. package/dist/cjs/atomic-insight-history-toggle.cjs.entry.js +2 -2
  88. package/dist/cjs/atomic-insight-history-toggle.cjs.entry.js.map +1 -1
  89. package/dist/cjs/atomic-insight-interface.cjs.entry.js +1 -1
  90. package/dist/cjs/atomic-insight-pager.cjs.entry.js +41 -7
  91. package/dist/cjs/atomic-insight-pager.cjs.entry.js.map +1 -1
  92. package/dist/cjs/atomic-insight-user-actions-toggle.cjs.entry.js +2 -2
  93. package/dist/cjs/atomic-insight-user-actions-toggle.cjs.entry.js.map +1 -1
  94. package/dist/cjs/atomic-numeric-facet.cjs.entry.js +1 -1
  95. package/dist/cjs/atomic-query-error.cjs.entry.js +1 -1
  96. package/dist/cjs/atomic-quickview-modal.cjs.entry.js +1 -1
  97. package/dist/cjs/atomic-quickview.cjs.entry.js +1 -1
  98. package/dist/cjs/atomic-recs-interface.cjs.entry.js +1 -1
  99. package/dist/cjs/atomic-refine-modal.cjs.entry.js +1 -1
  100. package/dist/cjs/atomic-refine-toggle.cjs.entry.js +1 -1
  101. package/dist/cjs/atomic-relevance-inspector.cjs.entry.js +2 -2
  102. package/dist/cjs/atomic-result-children.cjs.entry.js +1 -1
  103. package/dist/cjs/atomic-result-fields-list.cjs.entry.js +1 -1
  104. package/dist/cjs/atomic-result-link.cjs.entry.js +1 -1
  105. package/dist/cjs/atomic-result-list.cjs.entry.js +1 -1
  106. package/dist/cjs/atomic-result-placeholder_8.cjs.entry.js +1 -1
  107. package/dist/cjs/atomic-search-box-query-suggestions_2.cjs.entry.js +234 -0
  108. package/dist/cjs/atomic-search-box-query-suggestions_2.cjs.entry.js.map +1 -0
  109. package/dist/cjs/atomic-search-box.cjs.entry.js +4 -4
  110. package/dist/cjs/atomic-search-interface.cjs.entry.js +1 -1
  111. package/dist/cjs/atomic-smart-snippet-feedback-modal.cjs.entry.js +2 -2
  112. package/dist/cjs/atomic-sort-dropdown.cjs.entry.js +2 -2
  113. package/dist/cjs/atomic-sort-expression.cjs.entry.js +1 -1
  114. package/dist/cjs/atomic-tab-manager.cjs.entry.js +1 -1
  115. package/dist/cjs/atomic.cjs.js +1 -1
  116. package/dist/cjs/clock-f03ff827.js +7 -0
  117. package/dist/cjs/clock-f03ff827.js.map +1 -0
  118. package/dist/cjs/index-757bc886.js +2 -6
  119. package/dist/cjs/version.cjs.js +2 -2
  120. package/dist/esm/_loader.js +1 -1
  121. package/dist/esm/{analytics-config-18d42f83.js → analytics-config-76f4b38f.js} +2 -2
  122. package/dist/esm/{analytics-config-18d42f83.js.map → analytics-config-76f4b38f.js.map} +1 -1
  123. package/dist/esm/atomic-category-facet.entry.js +1 -1
  124. package/dist/esm/atomic-facet.entry.js +1 -1
  125. package/dist/esm/atomic-format-currency.entry.js +1 -1
  126. package/dist/esm/atomic-format-number.entry.js +1 -1
  127. package/dist/esm/atomic-format-unit.entry.js +1 -1
  128. package/dist/esm/atomic-insight-history-toggle.entry.js +2 -2
  129. package/dist/esm/atomic-insight-history-toggle.entry.js.map +1 -1
  130. package/dist/esm/atomic-insight-interface.entry.js +1 -1
  131. package/dist/esm/atomic-insight-pager.entry.js +38 -4
  132. package/dist/esm/atomic-insight-pager.entry.js.map +1 -1
  133. package/dist/esm/atomic-insight-user-actions-toggle.entry.js +2 -2
  134. package/dist/esm/atomic-insight-user-actions-toggle.entry.js.map +1 -1
  135. package/dist/esm/atomic-numeric-facet.entry.js +1 -1
  136. package/dist/esm/atomic-query-error.entry.js +1 -1
  137. package/dist/esm/atomic-quickview-modal.entry.js +1 -1
  138. package/dist/esm/atomic-quickview.entry.js +1 -1
  139. package/dist/esm/atomic-recs-interface.entry.js +1 -1
  140. package/dist/esm/atomic-refine-modal.entry.js +1 -1
  141. package/dist/esm/atomic-refine-toggle.entry.js +1 -1
  142. package/dist/esm/atomic-relevance-inspector.entry.js +2 -2
  143. package/dist/esm/atomic-result-children.entry.js +1 -1
  144. package/dist/esm/atomic-result-fields-list.entry.js +1 -1
  145. package/dist/esm/atomic-result-link.entry.js +1 -1
  146. package/dist/esm/atomic-result-list.entry.js +1 -1
  147. package/dist/esm/atomic-result-placeholder_8.entry.js +1 -1
  148. package/dist/esm/atomic-search-box-query-suggestions_2.entry.js +229 -0
  149. package/dist/esm/atomic-search-box-query-suggestions_2.entry.js.map +1 -0
  150. package/dist/esm/atomic-search-box.entry.js +4 -4
  151. package/dist/esm/atomic-search-interface.entry.js +1 -1
  152. package/dist/esm/atomic-smart-snippet-feedback-modal.entry.js +2 -2
  153. package/dist/esm/atomic-sort-dropdown.entry.js +2 -2
  154. package/dist/esm/atomic-sort-expression.entry.js +1 -1
  155. package/dist/esm/atomic-tab-manager.entry.js +1 -1
  156. package/dist/esm/atomic.js +1 -1
  157. package/dist/esm/clock-add3e9a5.js +5 -0
  158. package/dist/esm/clock-add3e9a5.js.map +1 -0
  159. package/dist/esm/index-3f35faca.js +2 -6
  160. package/dist/esm/version.js +2 -2
  161. package/dist/types/components/search/atomic-pager/atomic-pager.d.ts +26 -16
  162. package/dist/types/components/search/index.d.ts +1 -1
  163. 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
  164. package/dist/types/components.d.ts +49 -65
  165. package/docs/atomic-docs.json +98 -167
  166. package/package.json +3 -3
  167. package/dist/atomic/components/atomic-pager.d.ts +0 -11
  168. package/dist/atomic/components/atomic-pager.js +0 -134
  169. package/dist/atomic/components/atomic-pager.js.map +0 -1
  170. package/dist/atomic/components/components/search/atomic-search-box-recent-queries/atomic-search-box-recent-queries.js +0 -137
  171. package/dist/atomic/components/stencil-pager-navigation.js +0 -42
  172. package/dist/atomic/components/stencil-pager-navigation.js.map +0 -1
  173. package/dist/atomic/p-211d7d6a.js +0 -2
  174. package/dist/atomic/p-211d7d6a.js.map +0 -1
  175. package/dist/atomic/p-2e9db4ca.entry.js +0 -2
  176. package/dist/atomic/p-2e9db4ca.entry.js.map +0 -1
  177. package/dist/atomic/p-fa8b7c4c.entry.js +0 -2
  178. package/dist/atomic/p-fa8b7c4c.entry.js.map +0 -1
  179. package/dist/atomic/p-fcf3f7d7.entry.js +0 -2
  180. package/dist/atomic/p-fcf3f7d7.entry.js.map +0 -1
  181. package/dist/cjs/atomic-pager.cjs.entry.js +0 -121
  182. package/dist/cjs/atomic-pager.cjs.entry.js.map +0 -1
  183. package/dist/cjs/atomic-search-box-query-suggestions.cjs.entry.js +0 -76
  184. package/dist/cjs/atomic-search-box-query-suggestions.cjs.entry.js.map +0 -1
  185. package/dist/cjs/clock-7aeb19d0.js +0 -7
  186. package/dist/cjs/clock-7aeb19d0.js.map +0 -1
  187. package/dist/cjs/stencil-pager-navigation-c20b8a95.js +0 -48
  188. package/dist/cjs/stencil-pager-navigation-c20b8a95.js.map +0 -1
  189. package/dist/esm/atomic-pager.entry.js +0 -117
  190. package/dist/esm/atomic-pager.entry.js.map +0 -1
  191. package/dist/esm/atomic-search-box-query-suggestions.entry.js +0 -72
  192. package/dist/esm/atomic-search-box-query-suggestions.entry.js.map +0 -1
  193. package/dist/esm/clock-b1f5d7f7.js +0 -5
  194. package/dist/esm/clock-b1f5d7f7.js.map +0 -1
  195. package/dist/esm/stencil-pager-navigation-7261a834.js +0 -42
  196. package/dist/esm/stencil-pager-navigation-7261a834.js.map +0 -1
  197. /package/dist/atomic/{p-ae060711.entry.js.map → p-00e5bb15.entry.js.map} +0 -0
  198. /package/dist/atomic/{p-5bc31a30.js.map → p-031670fe.js.map} +0 -0
  199. /package/dist/atomic/{p-330e6e7c.entry.js.map → p-3af5c567.entry.js.map} +0 -0
  200. /package/dist/atomic/{p-88d5e178.entry.js.map → p-43c16eeb.entry.js.map} +0 -0
  201. /package/dist/atomic/{p-75e00690.entry.js.map → p-45c4685e.entry.js.map} +0 -0
  202. /package/dist/atomic/{p-0ce38b0d.entry.js.map → p-470f88ed.entry.js.map} +0 -0
  203. /package/dist/atomic/{p-ae98c582.entry.js.map → p-4915faeb.entry.js.map} +0 -0
  204. /package/dist/atomic/{p-52ba404c.entry.js.map → p-4c30ca3e.entry.js.map} +0 -0
  205. /package/dist/atomic/{p-39e63678.entry.js.map → p-4e9d1f9e.entry.js.map} +0 -0
  206. /package/dist/atomic/{p-877d35b1.entry.js.map → p-5adbf098.entry.js.map} +0 -0
  207. /package/dist/atomic/{p-ba4bf29f.entry.js.map → p-6329ff94.entry.js.map} +0 -0
  208. /package/dist/atomic/{p-4b3d253b.entry.js.map → p-65373475.entry.js.map} +0 -0
  209. /package/dist/atomic/{p-7383fd32.entry.js.map → p-6e6d686e.entry.js.map} +0 -0
  210. /package/dist/atomic/{p-3c8d109e.entry.js.map → p-6f988841.entry.js.map} +0 -0
  211. /package/dist/atomic/{p-b28011e6.entry.js.map → p-71bb8125.entry.js.map} +0 -0
  212. /package/dist/atomic/{p-de066001.entry.js.map → p-757de797.entry.js.map} +0 -0
  213. /package/dist/atomic/{p-78b70622.entry.js.map → p-8acb1466.entry.js.map} +0 -0
  214. /package/dist/atomic/{p-93e29b24.entry.js.map → p-9883415e.entry.js.map} +0 -0
  215. /package/dist/atomic/{p-7b899b57.entry.js.map → p-a02b1209.entry.js.map} +0 -0
  216. /package/dist/atomic/{p-d00a12e9.entry.js.map → p-b4ad3036.entry.js.map} +0 -0
  217. /package/dist/atomic/{p-a760d9f9.entry.js.map → p-be1b98a6.entry.js.map} +0 -0
  218. /package/dist/atomic/{p-7dfcd6af.entry.js.map → p-bf50b64d.entry.js.map} +0 -0
  219. /package/dist/atomic/{p-e1cc5150.js.map → p-c280cd05.js.map} +0 -0
  220. /package/dist/atomic/{p-c49cfa0c.entry.js.map → p-d11b2b24.entry.js.map} +0 -0
  221. /package/dist/atomic/{p-f22bcb8c.entry.js.map → p-d2d22ab2.entry.js.map} +0 -0
  222. /package/dist/atomic/{p-299555fb.entry.js.map → p-e1865f9f.entry.js.map} +0 -0
  223. /package/dist/atomic/{p-021f01d6.entry.js.map → p-e8d5e852.entry.js.map} +0 -0
  224. /package/dist/atomic/{p-7b0b9e9b.entry.js.map → p-f073a78d.entry.js.map} +0 -0
  225. /package/dist/atomic/{p-c88a3d2d.entry.js.map → p-fb7ad34b.entry.js.map} +0 -0
@@ -0,0 +1,234 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-757bc886.js');
6
+ const headless = require('@coveo/headless');
7
+ const search = require('./search-a4774f02.js');
8
+ const stencilQuerySuggestions = require('./stencil-query-suggestions-03268ecc.js');
9
+ const suggestionsEvents = require('./suggestions-events-63dd0640.js');
10
+ const clock = require('./clock-f03ff827.js');
11
+ const localStorageUtils = require('./local-storage-utils-380ce22b.js');
12
+ const utils = require('./utils-7153ae6b.js');
13
+ const stringUtils = require('./string-utils-bdf08f8c.js');
14
+ require('./dom-utils-d4790328.js');
15
+ require('./event-utils-9bfcf3c5.js');
16
+ require('./purify-85b542e2.js');
17
+ require('./_commonjsHelpers-b3309d7b.js');
18
+
19
+ const AtomicSearchBoxQuerySuggestions = class {
20
+ constructor(hostRef) {
21
+ index.registerInstance(this, hostRef);
22
+ this.error = undefined;
23
+ this.icon = undefined;
24
+ this.maxWithQuery = undefined;
25
+ this.maxWithoutQuery = undefined;
26
+ }
27
+ componentWillLoad() {
28
+ try {
29
+ suggestionsEvents.dispatchSearchBoxSuggestionsEvent((bindings) => {
30
+ this.bindings = bindings;
31
+ return this.initialize();
32
+ }, this.host, ['atomic-search-box']);
33
+ }
34
+ catch (error) {
35
+ this.error = error;
36
+ }
37
+ }
38
+ initialize() {
39
+ const engine = this.bindings.engine;
40
+ const { registerQuerySuggest, fetchQuerySuggestions } = headless.loadQuerySuggestActions(engine);
41
+ engine.dispatch(registerQuerySuggest({
42
+ id: this.bindings.id,
43
+ count: this.bindings.numberOfQueries,
44
+ }));
45
+ return {
46
+ position: Array.from(this.host.parentNode.children).indexOf(this.host),
47
+ onInput: () => engine.dispatch(fetchQuerySuggestions({
48
+ id: this.bindings.id,
49
+ })),
50
+ renderItems: () => this.renderItems(),
51
+ };
52
+ }
53
+ renderItems() {
54
+ const hasQuery = this.bindings.searchBoxController.state.value !== '';
55
+ const max = hasQuery ? this.maxWithQuery : this.maxWithoutQuery;
56
+ return this.bindings.searchBoxController.state.suggestions
57
+ .slice(0, max)
58
+ .map((suggestion) => this.renderItem(suggestion));
59
+ }
60
+ renderItem(suggestion) {
61
+ const hasQuery = this.bindings.searchBoxController.state.value !== '';
62
+ const partialItem = stencilQuerySuggestions.getPartialSearchBoxSuggestionElement(suggestion, this.bindings.i18n);
63
+ return {
64
+ ...partialItem,
65
+ content: (index.h(stencilQuerySuggestions.QuerySuggestionContainer, null, index.h(stencilQuerySuggestions.QuerySuggestionIcon, { icon: this.icon || search.SearchIcon, hasSuggestion: this.bindings.getSuggestions().length > 1 }), index.h(stencilQuerySuggestions.QuerySuggestionText, { suggestion: suggestion, hasQuery: hasQuery }))),
66
+ onSelect: () => {
67
+ this.bindings.searchBoxController.selectSuggestion(suggestion.rawValue);
68
+ },
69
+ };
70
+ }
71
+ render() {
72
+ if (this.error) {
73
+ return (index.h("atomic-component-error", { key: 'ee518dd01ee68d5ac1e13c37335888acf7089beb', element: this.host, error: this.error }));
74
+ }
75
+ }
76
+ get host() { return index.getElement(this); }
77
+ };
78
+
79
+ const getPartialRecentQueryElement = (value, i18n) => {
80
+ return {
81
+ part: 'recent-query-item',
82
+ query: value,
83
+ key: `recent-${stringUtils.encodeForDomAttribute(value)}`,
84
+ ariaLabel: i18n.t('recent-query-suggestion-label', {
85
+ query: value,
86
+ interpolation: { escapeValue: false },
87
+ }),
88
+ };
89
+ };
90
+ const getPartialRecentQueryClearElement = (i18n) => {
91
+ return {
92
+ key: 'recent-query-clear',
93
+ ariaLabel: i18n.t('clear-recent-searches', {
94
+ interpolation: { escapeValue: false },
95
+ }),
96
+ part: 'recent-query-title-item suggestion-divider',
97
+ hideIfLast: true,
98
+ };
99
+ };
100
+ const RecentQueriesContainer = (_, children) => {
101
+ return (index.h("div", { part: "recent-query-content", class: "flex items-center text-left break-all" }, children));
102
+ };
103
+ const RecentQueryIcon = ({ icon, }) => {
104
+ return (index.h("atomic-icon", { part: "recent-query-icon", icon: icon, class: "mr-2 h-4 w-4 shrink-0" }));
105
+ };
106
+ const RecentQueryText = ({ query, value, }) => {
107
+ if (query === '') {
108
+ return (index.h("span", { part: "recent-query-text", class: "line-clamp-2 break-all" }, value));
109
+ }
110
+ return (index.h("span", { part: "recent-query-text", class: "line-clamp-2 break-all", innerHTML: headless.HighlightUtils.highlightString({
111
+ content: value,
112
+ openingDelimiter: '<span part="recent-query-text-highlight" class="font-bold">',
113
+ closingDelimiter: '</span>',
114
+ highlights: [
115
+ {
116
+ offset: query.length,
117
+ length: value.length - query.length,
118
+ },
119
+ ],
120
+ }) }));
121
+ };
122
+ const RecentQueryClear = ({ i18n, }) => {
123
+ return (index.h("div", { part: "recent-query-title-content", class: "flex w-full justify-between" },
124
+ index.h("span", { class: "font-bold", part: "recent-query-title" }, i18n.t('recent-searches')),
125
+ index.h("span", { part: "recent-query-clear" }, i18n.t('clear'))));
126
+ };
127
+
128
+ const AtomicSearchBoxRecentQueries = class {
129
+ constructor(hostRef) {
130
+ index.registerInstance(this, hostRef);
131
+ /**
132
+ * The maximum number of suggestions that will be displayed if the user has typed something into the input field.
133
+ */
134
+ this.maxWithQuery = 3;
135
+ this.warnUser = utils.once(() => this.bindings.engine.logger.warn('Because analytics are disabled, the recent queries feature is deactivated.'));
136
+ this.error = undefined;
137
+ this.icon = undefined;
138
+ this.maxWithQuery = 3;
139
+ this.maxWithoutQuery = undefined;
140
+ }
141
+ componentWillLoad() {
142
+ try {
143
+ suggestionsEvents.dispatchSearchBoxSuggestionsEvent((bindings) => {
144
+ this.bindings = bindings;
145
+ return this.initialize();
146
+ }, this.host, ['atomic-search-box']);
147
+ }
148
+ catch (error) {
149
+ this.error = error;
150
+ }
151
+ }
152
+ renderIcon() {
153
+ return this.icon || clock.Clock;
154
+ }
155
+ initialize() {
156
+ this.storage = new localStorageUtils.SafeStorage();
157
+ this.recentQueriesList = headless.buildRecentQueriesList(this.bindings.engine, {
158
+ initialState: { queries: this.retrieveLocalStorage() },
159
+ options: { maxLength: 1000, clearFilters: this.bindings.clearFilters },
160
+ });
161
+ this.recentQueriesList.subscribe(() => this.updateLocalStorage());
162
+ return {
163
+ position: Array.from(this.host.parentNode.children).indexOf(this.host),
164
+ renderItems: () => this.renderItems(),
165
+ };
166
+ }
167
+ retrieveLocalStorage() {
168
+ return this.storage.getParsedJSON(localStorageUtils.StorageItems.RECENT_QUERIES, []);
169
+ }
170
+ updateLocalStorage() {
171
+ if (!this.recentQueriesList.state.analyticsEnabled) {
172
+ return this.disableFeature();
173
+ }
174
+ return this.storage.setJSON(localStorageUtils.StorageItems.RECENT_QUERIES, this.recentQueriesList.state.queries);
175
+ }
176
+ disableFeature() {
177
+ this.warnUser();
178
+ this.storage.removeItem(localStorageUtils.StorageItems.RECENT_QUERIES);
179
+ }
180
+ renderItems() {
181
+ if (!this.recentQueriesList.state.analyticsEnabled) {
182
+ return [];
183
+ }
184
+ const query = this.bindings.searchBoxController.state.value;
185
+ const hasQuery = query !== '';
186
+ const max = hasQuery ? this.maxWithQuery : this.maxWithoutQuery;
187
+ const filteredQueries = this.recentQueriesList.state.queries
188
+ .filter((recentQuery) => recentQuery.toLowerCase().startsWith(query.toLowerCase()))
189
+ .slice(0, max);
190
+ const suggestionElements = filteredQueries.map((value) => this.renderItem(value));
191
+ if (suggestionElements.length) {
192
+ suggestionElements.unshift(this.renderClear());
193
+ }
194
+ return suggestionElements;
195
+ }
196
+ renderClear() {
197
+ const partialItem = getPartialRecentQueryClearElement(this.bindings.i18n);
198
+ return {
199
+ ...partialItem,
200
+ content: index.h(RecentQueryClear, { i18n: this.bindings.i18n }),
201
+ onSelect: () => {
202
+ this.recentQueriesList.clear();
203
+ this.bindings.triggerSuggestions();
204
+ },
205
+ };
206
+ }
207
+ renderItem(value) {
208
+ const query = this.bindings.searchBoxController.state.value;
209
+ const partialItem = getPartialRecentQueryElement(value, this.bindings.i18n);
210
+ return {
211
+ ...partialItem,
212
+ content: (index.h(RecentQueriesContainer, null, index.h(RecentQueryIcon, { icon: this.renderIcon() }), index.h(RecentQueryText, { query: query, value: value }))),
213
+ onSelect: () => {
214
+ if (this.bindings.isStandalone) {
215
+ this.bindings.searchBoxController.updateText(value);
216
+ this.bindings.searchBoxController.submit();
217
+ return;
218
+ }
219
+ this.recentQueriesList.executeRecentQuery(this.recentQueriesList.state.queries.indexOf(value));
220
+ },
221
+ };
222
+ }
223
+ render() {
224
+ if (this.error) {
225
+ return (index.h("atomic-component-error", { key: '577129c08c073b99dbb6b86b77e2ffa7c2ff7f69', element: this.host, error: this.error }));
226
+ }
227
+ }
228
+ get host() { return index.getElement(this); }
229
+ };
230
+
231
+ exports.atomic_search_box_query_suggestions = AtomicSearchBoxQuerySuggestions;
232
+ exports.atomic_search_box_recent_queries = AtomicSearchBoxRecentQueries;
233
+
234
+ //# sourceMappingURL=atomic-search-box-query-suggestions_2.cjs.entry.js.map
@@ -0,0 +1 @@
1
+ {"file":"atomic-search-box-query-suggestions.atomic-search-box-recent-queries.entry.cjs.js","mappings":";;;;;;;;;;;;;;;;;;MA8Ba,+BAA+B;;;;;;;;IAwB1C,iBAAiB;QACf,IAAI;YACFA,mDAAiC,CAC/B,CAAC,QAAQ;gBACP,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;gBACzB,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC;aAC1B,EACD,IAAI,CAAC,IAAI,EACT,CAAC,mBAAmB,CAAC,CACtB,CAAC;SACH;QAAC,OAAO,KAAK,EAAE;YACd,IAAI,CAAC,KAAK,GAAG,KAAc,CAAC;SAC7B;KACF;IAEO,UAAU;QAChB,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,MAG3B,CAAC;QACH,MAAM,EAAC,oBAAoB,EAAE,qBAAqB,EAAC,GACjDC,gCAAuB,CAAC,MAAM,CAAC,CAAC;QAElC,MAAM,CAAC,QAAQ,CACb,oBAAoB,CAAC;YACnB,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE;YACpB,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,eAAe;SACrC,CAAC,CACH,CAAC;QAEF,OAAO;YACL,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAW,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC;YACvE,OAAO,EAAE,MACP,MAAM,CAAC,QAAQ,CACb,qBAAqB,CAAC;gBACpB,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE;aACrB,CAAC,CACH;YACH,WAAW,EAAE,MAAM,IAAI,CAAC,WAAW,EAAE;SACtC,CAAC;KACH;IAEO,WAAW;QACjB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,KAAK,CAAC,KAAK,KAAK,EAAE,CAAC;QACtE,MAAM,GAAG,GAAG,QAAQ,GAAG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC;QAChE,OAAO,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,KAAK,CAAC,WAAW;aACvD,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC;aACb,GAAG,CAAC,CAAC,UAAU,KAAK,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC;KACrD;IAEO,UAAU,CAAC,UAAsB;QACvC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,KAAK,CAAC,KAAK,KAAK,EAAE,CAAC;QACtE,MAAM,WAAW,GAAGC,4DAAoC,CACtD,UAAU,EACV,IAAI,CAAC,QAAQ,CAAC,IAAI,CACnB,CAAC;QAEF,OAAO;YACL,GAAG,WAAW;YACd,OAAO,GACLC,QAACC,gDAAwB,QACvBD,QAACE,2CAAmB,IAClB,IAAI,EAAE,IAAI,CAAC,IAAI,IAAIC,iBAAU,EAC7B,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,cAAc,EAAE,CAAC,MAAM,GAAG,CAAC,GACxD,EAEFH,QAACI,2CAAmB,IAAC,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,GAAI,CAC1C,CAC5B;YACD,QAAQ,EAAE;gBACR,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,gBAAgB,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;aACzE;SACF,CAAC;KACH;IAEM,MAAM;QACX,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,QACEJ,qFACE,OAAO,EAAE,IAAI,CAAC,IAAI,EAClB,KAAK,EAAE,IAAI,CAAC,KAAK,GACO,EAC1B;SACH;KACF;;;;ACpII,MAAM,4BAA4B,GAAG,CAC1C,KAAa,EACb,IAAU;IAEV,OAAO;QACL,IAAI,EAAE,mBAAmB;QACzB,KAAK,EAAE,KAAK;QACZ,GAAG,EAAE,UAAUK,iCAAqB,CAAC,KAAK,CAAC,EAAE;QAC7C,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,+BAA+B,EAAE;YACjD,KAAK,EAAE,KAAK;YACZ,aAAa,EAAE,EAAC,WAAW,EAAE,KAAK,EAAC;SACpC,CAAC;KACH,CAAC;AACJ,CAAC,CAAC;AAEK,MAAM,iCAAiC,GAAG,CAC/C,IAAU;IAKV,OAAO;QACL,GAAG,EAAE,oBAAoB;QACzB,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,uBAAuB,EAAE;YACzC,aAAa,EAAE,EAAC,WAAW,EAAE,KAAK,EAAC;SACpC,CAAC;QACF,IAAI,EAAE,4CAA4C;QAClD,UAAU,EAAE,IAAI;KACjB,CAAC;AACJ,CAAC,CAAC;AAEK,MAAM,sBAAsB,GAAwB,CAAC,CAAC,EAAE,QAAQ;IACrE,QACEL,iBACE,IAAI,EAAC,sBAAsB,EAC3B,KAAK,EAAC,uCAAuC,IAE5C,QAAQ,CACL,EACN;AACJ,CAAC,CAAC;AAMK,MAAM,eAAe,GAA8C,CAAC,EACzE,IAAI,GACL;IACC,QACEA,yBACE,IAAI,EAAC,mBAAmB,EACxB,IAAI,EAAE,IAAI,EACV,KAAK,EAAC,uBAAuB,GAChB,EACf;AACJ,CAAC,CAAC;AAOK,MAAM,eAAe,GAA8C,CAAC,EACzE,KAAK,EACL,KAAK,GACN;IACC,IAAI,KAAK,KAAK,EAAE,EAAE;QAChB,QACEA,kBAAM,IAAI,EAAC,mBAAmB,EAAC,KAAK,EAAC,wBAAwB,IAC1D,KAAK,CACD,EACP;KACH;IACD,QACEA,kBACE,IAAI,EAAC,mBAAmB,EACxB,KAAK,EAAC,wBAAwB,EAC9B,SAAS,EAAEM,uBAAc,CAAC,eAAe,CAAC;YACxC,OAAO,EAAE,KAAK;YACd,gBAAgB,EACd,6DAA6D;YAC/D,gBAAgB,EAAE,SAAS;YAC3B,UAAU,EAAE;gBACV;oBACE,MAAM,EAAE,KAAK,CAAC,MAAM;oBACpB,MAAM,EAAE,KAAK,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM;iBACpC;aACF;SACF,CAAC,GACI,EACR;AACJ,CAAC,CAAC;AAMK,MAAM,gBAAgB,GAA+C,CAAC,EAC3E,IAAI,GACL;IACC,QACEN,iBAAK,IAAI,EAAC,4BAA4B,EAAC,KAAK,EAAC,6BAA6B;QACxEA,kBAAM,KAAK,EAAC,WAAW,EAAC,IAAI,EAAC,oBAAoB,IAC9C,IAAI,CAAC,CAAC,CAAC,iBAAiB,CAAC,CACrB;QACPA,kBAAM,IAAI,EAAC,oBAAoB,IAAE,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAQ,CACpD,EACN;AACJ,CAAC;;MCjFY,4BAA4B;;;;;;QAqBT,iBAAY,GAAG,CAAC,CAAC;QAuDvC,aAAQ,GAAGO,UAAI,CAAC,MACtB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAC9B,4EAA4E,CAC7E,CACF,CAAC;;;4BA3D2C,CAAC;;;IAM9C,iBAAiB;QACf,IAAI;YACFV,mDAAiC,CAC/B,CAAC,QAAQ;gBACP,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;gBACzB,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC;aAC1B,EACD,IAAI,CAAC,IAAI,EACT,CAAC,mBAAmB,CAAC,CACtB,CAAC;SACH;QAAC,OAAO,KAAK,EAAE;YACd,IAAI,CAAC,KAAK,GAAG,KAAc,CAAC;SAC7B;KACF;IAEO,UAAU;QAChB,OAAO,IAAI,CAAC,IAAI,IAAIW,WAAK,CAAC;KAC3B;IAEO,UAAU;QAChB,IAAI,CAAC,OAAO,GAAG,IAAIC,6BAAW,EAAE,CAAC;QACjC,IAAI,CAAC,iBAAiB,GAAGC,+BAAsB,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpE,YAAY,EAAE,EAAC,OAAO,EAAE,IAAI,CAAC,oBAAoB,EAAE,EAAC;YACpD,OAAO,EAAE,EAAC,SAAS,EAAE,IAAI,EAAE,YAAY,EAAE,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAC;SACrE,CAAC,CAAC;QAEH,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC;QAElE,OAAO;YACL,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAW,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC;YACvE,WAAW,EAAE,MAAM,IAAI,CAAC,WAAW,EAAE;SACtC,CAAC;KACH;IAEO,oBAAoB;QAC1B,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,CAACC,8BAAY,CAAC,cAAc,EAAE,EAAE,CAAC,CAAC;KACpE;IAEO,kBAAkB;QACxB,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,gBAAgB,EAAE;YAClD,OAAO,IAAI,CAAC,cAAc,EAAE,CAAC;SAC9B;QAED,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,CACzBA,8BAAY,CAAC,cAAc,EAC3B,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,OAAO,CACrC,CAAC;KACH;IAQO,cAAc;QACpB,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,OAAO,CAAC,UAAU,CAACA,8BAAY,CAAC,cAAc,CAAC,CAAC;KACtD;IAEO,WAAW;QACjB,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,gBAAgB,EAAE;YAClD,OAAO,EAAE,CAAC;SACX;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,KAAK,CAAC,KAAK,CAAC;QAC5D,MAAM,QAAQ,GAAG,KAAK,KAAK,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,QAAQ,GAAG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC;QAChE,MAAM,eAAe,GAAG,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,OAAO;aACzD,MAAM,CAAC,CAAC,WAAW,KAClB,WAAW,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,CAC1D;aACA,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QAEjB,MAAM,kBAAkB,GACtB,eAAe,CAAC,GAAG,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;QACzD,IAAI,kBAAkB,CAAC,MAAM,EAAE;YAC7B,kBAAkB,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;SAChD;QAED,OAAO,kBAAkB,CAAC;KAC3B;IAEO,WAAW;QACjB,MAAM,WAAW,GAAG,iCAAiC,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAE1E,OAAO;YACL,GAAG,WAAW;YACd,OAAO,EAAEX,QAAC,gBAAgB,IAAC,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAI;YACvD,QAAQ,EAAE;gBACR,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC;gBAC/B,IAAI,CAAC,QAAQ,CAAC,kBAAkB,EAAE,CAAC;aACpC;SACF,CAAC;KACH;IAEO,UAAU,CAAC,KAAa;QAC9B,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,KAAK,CAAC,KAAK,CAAC;QAC5D,MAAM,WAAW,GAAG,4BAA4B,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC5E,OAAO;YACL,GAAG,WAAW;YACd,OAAO,GACLA,QAAC,sBAAsB,QACrBA,QAAC,eAAe,IAAC,IAAI,EAAE,IAAI,CAAC,UAAU,EAAE,GAAI,EAC5CA,QAAC,eAAe,IAAC,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,GAAI,CACxB,CAC1B;YAED,QAAQ,EAAE;gBACR,IAAI,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE;oBAC9B,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;oBACpD,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,MAAM,EAAE,CAAC;oBAC3C,OAAO;iBACR;gBAED,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CACvC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CACpD,CAAC;aACH;SACF,CAAC;KACH;IAEM,MAAM;QACX,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,QACEA,qFACE,OAAO,EAAE,IAAI,CAAC,IAAI,EAClB,KAAK,EAAE,IAAI,CAAC,KAAK,GACO,EAC1B;SACH;KACF;;;;;;;","names":["dispatchSearchBoxSuggestionsEvent","loadQuerySuggestActions","getPartialSearchBoxSuggestionElement","h","QuerySuggestionContainer","QuerySuggestionIcon","SearchIcon","QuerySuggestionText","encodeForDomAttribute","HighlightUtils","once","Clock","SafeStorage","buildRecentQueriesList","StorageItems"],"sources":["src/components/search/search-box-suggestions/atomic-search-box-query-suggestions/atomic-search-box-query-suggestions.tsx","src/components/common/suggestions/stencil-recent-queries.tsx","src/components/search/search-box-suggestions/atomic-search-box-recent-queries/atomic-search-box-recent-queries.tsx"],"sourcesContent":["import {\n loadQuerySuggestActions,\n SearchBox,\n SearchEngine,\n Suggestion,\n} from '@coveo/headless';\nimport {Component, Element, Prop, State, h} from '@stencil/core';\nimport SearchIcon from '../../../../images/search.svg';\nimport {\n getPartialSearchBoxSuggestionElement,\n QuerySuggestionContainer,\n QuerySuggestionIcon,\n QuerySuggestionText,\n} from '../../../common/suggestions/stencil-query-suggestions';\nimport {\n dispatchSearchBoxSuggestionsEvent,\n} from '../../../common/suggestions/suggestions-events';\nimport type {\n SearchBoxSuggestionElement,\n SearchBoxSuggestions,\n SearchBoxSuggestionsBindings,\n} from '../../../common/suggestions/suggestions-types';\n\n/**\n * The `atomic-search-box-query-suggestions` component can be added as a child of an `atomic-search-box` component, allowing for the configuration of query suggestion behavior.\n */\n@Component({\n tag: 'atomic-search-box-query-suggestions',\n shadow: true,\n})\nexport class AtomicSearchBoxQuerySuggestions {\n private bindings!: SearchBoxSuggestionsBindings<SearchBox>;\n @Element() private host!: HTMLElement;\n\n @State() public error!: Error;\n\n /**\n * The SVG icon to display.\n *\n * - Use a value that starts with `http://`, `https://`, `./`, or `../`, to fetch and display an icon from a given location.\n * - Use a value that starts with `assets://`, to display an icon from the Atomic package.\n * - Use a stringified SVG to display it directly.\n */\n @Prop() public icon?: string;\n\n /**\n * The maximum number of suggestions that will be displayed if the user has typed something into the input field.\n */\n @Prop({reflect: true}) public maxWithQuery?: number;\n /**\n * The maximum number of suggestions that will be displayed initially when the input field is empty.\n */\n @Prop({reflect: true}) public maxWithoutQuery?: number;\n\n componentWillLoad() {\n try {\n dispatchSearchBoxSuggestionsEvent<SearchBox>(\n (bindings) => {\n this.bindings = bindings;\n return this.initialize();\n },\n this.host,\n ['atomic-search-box']\n );\n } catch (error) {\n this.error = error as Error;\n }\n }\n\n private initialize(): SearchBoxSuggestions {\n const engine = this.bindings.engine as SearchEngine<{\n querySet: string;\n querySuggest: string;\n }>;\n const {registerQuerySuggest, fetchQuerySuggestions} =\n loadQuerySuggestActions(engine);\n\n engine.dispatch(\n registerQuerySuggest({\n id: this.bindings.id,\n count: this.bindings.numberOfQueries,\n })\n );\n\n return {\n position: Array.from(this.host.parentNode!.children).indexOf(this.host),\n onInput: () =>\n engine.dispatch(\n fetchQuerySuggestions({\n id: this.bindings.id,\n })\n ),\n renderItems: () => this.renderItems(),\n };\n }\n\n private renderItems(): SearchBoxSuggestionElement[] {\n const hasQuery = this.bindings.searchBoxController.state.value !== '';\n const max = hasQuery ? this.maxWithQuery : this.maxWithoutQuery;\n return this.bindings.searchBoxController.state.suggestions\n .slice(0, max)\n .map((suggestion) => this.renderItem(suggestion));\n }\n\n private renderItem(suggestion: Suggestion) {\n const hasQuery = this.bindings.searchBoxController.state.value !== '';\n const partialItem = getPartialSearchBoxSuggestionElement(\n suggestion,\n this.bindings.i18n\n );\n\n return {\n ...partialItem,\n content: (\n <QuerySuggestionContainer>\n <QuerySuggestionIcon\n icon={this.icon || SearchIcon}\n hasSuggestion={this.bindings.getSuggestions().length > 1}\n />\n\n <QuerySuggestionText suggestion={suggestion} hasQuery={hasQuery} />\n </QuerySuggestionContainer>\n ),\n onSelect: () => {\n this.bindings.searchBoxController.selectSuggestion(suggestion.rawValue);\n },\n };\n }\n\n public render() {\n if (this.error) {\n return (\n <atomic-component-error\n element={this.host}\n error={this.error}\n ></atomic-component-error>\n );\n }\n }\n}\n","import {HighlightUtils} from '@coveo/headless';\nimport {FunctionalComponent, h} from '@stencil/core';\nimport {i18n} from 'i18next';\nimport {encodeForDomAttribute} from '../../../utils/string-utils';\nimport {SearchBoxSuggestionElement} from './suggestions-types';\n\nexport const getPartialRecentQueryElement = (\n value: string,\n i18n: i18n\n): Pick<SearchBoxSuggestionElement, 'ariaLabel' | 'key' | 'query' | 'part'> => {\n return {\n part: 'recent-query-item',\n query: value,\n key: `recent-${encodeForDomAttribute(value)}`,\n ariaLabel: i18n.t('recent-query-suggestion-label', {\n query: value,\n interpolation: {escapeValue: false},\n }),\n };\n};\n\nexport const getPartialRecentQueryClearElement = (\n i18n: i18n\n): Pick<\n SearchBoxSuggestionElement,\n 'ariaLabel' | 'key' | 'part' | 'hideIfLast'\n> => {\n return {\n key: 'recent-query-clear',\n ariaLabel: i18n.t('clear-recent-searches', {\n interpolation: {escapeValue: false},\n }),\n part: 'recent-query-title-item suggestion-divider',\n hideIfLast: true,\n };\n};\n\nexport const RecentQueriesContainer: FunctionalComponent = (_, children) => {\n return (\n <div\n part=\"recent-query-content\"\n class=\"flex items-center text-left break-all\"\n >\n {children}\n </div>\n );\n};\n\ninterface RecentQueryIconProps {\n icon: string;\n}\n\nexport const RecentQueryIcon: FunctionalComponent<RecentQueryIconProps> = ({\n icon,\n}) => {\n return (\n <atomic-icon\n part=\"recent-query-icon\"\n icon={icon}\n class=\"mr-2 h-4 w-4 shrink-0\"\n ></atomic-icon>\n );\n};\n\ninterface RecentQueryTextProps {\n query: string;\n value: string;\n}\n\nexport const RecentQueryText: FunctionalComponent<RecentQueryTextProps> = ({\n query,\n value,\n}) => {\n if (query === '') {\n return (\n <span part=\"recent-query-text\" class=\"line-clamp-2 break-all\">\n {value}\n </span>\n );\n }\n return (\n <span\n part=\"recent-query-text\"\n class=\"line-clamp-2 break-all\"\n innerHTML={HighlightUtils.highlightString({\n content: value,\n openingDelimiter:\n '<span part=\"recent-query-text-highlight\" class=\"font-bold\">',\n closingDelimiter: '</span>',\n highlights: [\n {\n offset: query.length,\n length: value.length - query.length,\n },\n ],\n })}\n ></span>\n );\n};\n\ninterface RecentQueryClearProps {\n i18n: i18n;\n}\n\nexport const RecentQueryClear: FunctionalComponent<RecentQueryClearProps> = ({\n i18n,\n}) => {\n return (\n <div part=\"recent-query-title-content\" class=\"flex w-full justify-between\">\n <span class=\"font-bold\" part=\"recent-query-title\">\n {i18n.t('recent-searches')}\n </span>\n <span part=\"recent-query-clear\">{i18n.t('clear')}</span>\n </div>\n );\n};\n","import {\n buildRecentQueriesList,\n RecentQueriesList,\n SearchBox,\n} from '@coveo/headless';\nimport {Component, Element, Prop, State, h} from '@stencil/core';\nimport Clock from '../../../../images/clock.svg';\nimport {SafeStorage, StorageItems} from '../../../../utils/local-storage-utils';\nimport {once} from '../../../../utils/utils';\nimport {\n getPartialRecentQueryClearElement,\n getPartialRecentQueryElement,\n RecentQueriesContainer,\n RecentQueryClear,\n RecentQueryIcon,\n RecentQueryText,\n} from '../../../common/suggestions/stencil-recent-queries';\nimport {\n dispatchSearchBoxSuggestionsEvent,\n} from '../../../common/suggestions/suggestions-events';\nimport type {\n SearchBoxSuggestionElement,\n SearchBoxSuggestions,\n SearchBoxSuggestionsBindings,\n} from '../../../common/suggestions/suggestions-types';\nimport {Bindings} from '../../atomic-search-interface/atomic-search-interface';\n\n/**\n * The `atomic-search-box-recent-queries` component can be added as a child of an `atomic-search-box` component, allowing for the configuration of recent query suggestions.\n */\n@Component({\n tag: 'atomic-search-box-recent-queries',\n shadow: true,\n})\nexport class AtomicSearchBoxRecentQueries {\n private bindings!: SearchBoxSuggestionsBindings<SearchBox, Bindings>;\n private recentQueriesList!: RecentQueriesList;\n private storage!: SafeStorage;\n\n @Element() private host!: HTMLElement;\n\n @State() public error!: Error;\n\n /**\n * The SVG icon to display.\n *\n * - Use a value that starts with `http://`, `https://`, `./`, or `../`, to fetch and display an icon from a given location.\n * - Use a value that starts with `assets://`, to display an icon from the Atomic package.\n * - Use a stringified SVG to display it directly.\n */\n @Prop() public icon?: string;\n\n /**\n * The maximum number of suggestions that will be displayed if the user has typed something into the input field.\n */\n @Prop({reflect: true}) public maxWithQuery = 3;\n /**\n * The maximum number of suggestions that will be displayed initially when the input field is empty.\n */\n @Prop({reflect: true}) public maxWithoutQuery?: number;\n\n componentWillLoad() {\n try {\n dispatchSearchBoxSuggestionsEvent<SearchBox, Bindings>(\n (bindings) => {\n this.bindings = bindings;\n return this.initialize();\n },\n this.host,\n ['atomic-search-box']\n );\n } catch (error) {\n this.error = error as Error;\n }\n }\n\n private renderIcon() {\n return this.icon || Clock;\n }\n\n private initialize(): SearchBoxSuggestions {\n this.storage = new SafeStorage();\n this.recentQueriesList = buildRecentQueriesList(this.bindings.engine, {\n initialState: {queries: this.retrieveLocalStorage()},\n options: {maxLength: 1000, clearFilters: this.bindings.clearFilters},\n });\n\n this.recentQueriesList.subscribe(() => this.updateLocalStorage());\n\n return {\n position: Array.from(this.host.parentNode!.children).indexOf(this.host),\n renderItems: () => this.renderItems(),\n };\n }\n\n private retrieveLocalStorage() {\n return this.storage.getParsedJSON(StorageItems.RECENT_QUERIES, []);\n }\n\n private updateLocalStorage() {\n if (!this.recentQueriesList.state.analyticsEnabled) {\n return this.disableFeature();\n }\n\n return this.storage.setJSON(\n StorageItems.RECENT_QUERIES,\n this.recentQueriesList.state.queries\n );\n }\n\n private warnUser = once(() =>\n this.bindings.engine.logger.warn(\n 'Because analytics are disabled, the recent queries feature is deactivated.'\n )\n );\n\n private disableFeature() {\n this.warnUser();\n this.storage.removeItem(StorageItems.RECENT_QUERIES);\n }\n\n private renderItems(): SearchBoxSuggestionElement[] {\n if (!this.recentQueriesList.state.analyticsEnabled) {\n return [];\n }\n\n const query = this.bindings.searchBoxController.state.value;\n const hasQuery = query !== '';\n const max = hasQuery ? this.maxWithQuery : this.maxWithoutQuery;\n const filteredQueries = this.recentQueriesList.state.queries\n .filter((recentQuery) =>\n recentQuery.toLowerCase().startsWith(query.toLowerCase())\n )\n .slice(0, max);\n\n const suggestionElements: SearchBoxSuggestionElement[] =\n filteredQueries.map((value) => this.renderItem(value));\n if (suggestionElements.length) {\n suggestionElements.unshift(this.renderClear());\n }\n\n return suggestionElements;\n }\n\n private renderClear(): SearchBoxSuggestionElement {\n const partialItem = getPartialRecentQueryClearElement(this.bindings.i18n);\n\n return {\n ...partialItem,\n content: <RecentQueryClear i18n={this.bindings.i18n} />,\n onSelect: () => {\n this.recentQueriesList.clear();\n this.bindings.triggerSuggestions();\n },\n };\n }\n\n private renderItem(value: string): SearchBoxSuggestionElement {\n const query = this.bindings.searchBoxController.state.value;\n const partialItem = getPartialRecentQueryElement(value, this.bindings.i18n);\n return {\n ...partialItem,\n content: (\n <RecentQueriesContainer>\n <RecentQueryIcon icon={this.renderIcon()} />\n <RecentQueryText query={query} value={value} />\n </RecentQueriesContainer>\n ),\n\n onSelect: () => {\n if (this.bindings.isStandalone) {\n this.bindings.searchBoxController.updateText(value);\n this.bindings.searchBoxController.submit();\n return;\n }\n\n this.recentQueriesList.executeRecentQuery(\n this.recentQueriesList.state.queries.indexOf(value)\n );\n },\n };\n }\n\n public render() {\n if (this.error) {\n return (\n <atomic-component-error\n element={this.host}\n error={this.error}\n ></atomic-component-error>\n );\n }\n }\n}\n"],"version":3}
@@ -434,18 +434,18 @@ const AtomicSearchBox = class {
434
434
  if (!this.suggestionManager.suggestions.length) {
435
435
  this.registerSearchboxSuggestionEvents();
436
436
  }
437
- return (index.h(index.Host, { key: 'e3ed5e9633d8f37158974ae3f1b21cedf5f7de01' }, this.renderAbsolutePositionSpacer(), [
438
- index.h(stencilSuggestionManager.SearchBoxWrapper, { key: 'b5f0da61b7ac4f1fee156de7027945040dbbf500', disabled: isDisabled, onFocusout: (event) => {
437
+ return (index.h(index.Host, { key: 'c6057e947ead5556e40b2cedcf06781a7e9927f0' }, this.renderAbsolutePositionSpacer(), [
438
+ index.h(stencilSuggestionManager.SearchBoxWrapper, { key: '628b8bcabcf9612cba7970163b8c2a2f7747de9d', disabled: isDisabled, onFocusout: (event) => {
439
439
  if (!utils.isFocusingOut(event)) {
440
440
  return;
441
441
  }
442
442
  this.suggestionManager.clearSuggestions();
443
443
  this.isExpanded = false;
444
- } }, this.renderTextBox(searchLabel), index.h(SubmitButton, { key: 'c8c6083671167dac6c211c7b456dcfe87ca1cfaa', bindings: this.bindings, disabled: isDisabled, onClick: () => {
444
+ } }, this.renderTextBox(searchLabel), index.h(SubmitButton, { key: '82b2a7e72b27405c8ea129dee66901dc95ea7510', bindings: this.bindings, disabled: isDisabled, onClick: () => {
445
445
  this.searchBox.submit();
446
446
  this.suggestionManager.clearSuggestions();
447
447
  } }), this.renderSuggestions()),
448
- !this.suggestionManager.suggestions.length && (index.h("slot", { key: 'd6c0f1ff47370f794d0dc81782ced70baa04db91' }, index.h("atomic-search-box-recent-queries", { key: 'e599e83ae1f15386e310d1e03b8111144d452a8e' }), index.h("atomic-search-box-query-suggestions", { key: '6d446202f6722a66714ac067ad78afcf853a5dbe' }))),
448
+ !this.suggestionManager.suggestions.length && (index.h("slot", { key: '5d3bfbd30545b9d50afde0ea178121f2157618ae' }, index.h("atomic-search-box-recent-queries", { key: '0c04feaf3b136bc45532a1a134d0e307bc64131d' }), index.h("atomic-search-box-query-suggestions", { key: '65c916e94811e1e1a0fae8a6082e8122f34be471' }))),
449
449
  ]));
450
450
  }
451
451
  get host() { return index.getElement(this); }
@@ -5,7 +5,7 @@ Object.defineProperty(exports, '__esModule', { value: true });
5
5
  const index = require('./index-757bc886.js');
6
6
  const initQueue = require('./init-queue-a18aa323.js');
7
7
  const headless = require('@coveo/headless');
8
- const analyticsConfig = require('./analytics-config-68dbae8e.js');
8
+ const analyticsConfig = require('./analytics-config-e3890e2c.js');
9
9
  const localStorageUtils = require('./local-storage-utils-380ce22b.js');
10
10
  const propsUtils = require('./props-utils-1e4ba1b0.js');
11
11
  const replaceBreakpointUtils = require('./replace-breakpoint-utils-7a084f54.js');
@@ -53,9 +53,9 @@ const AtomicSmartSnippetFeedbackModal = class {
53
53
  }
54
54
  render() {
55
55
  replaceBreakpointUtils.updateBreakpoints(this.host);
56
- return (index.h("atomic-modal", { key: '4e420c4844f6ba7d674002bfb73048cfe34d6aaf', fullscreen: false, source: this.source, container: this.host, isOpen: this.isOpen, close: () => this.close(), exportparts: exportParts.ATOMIC_MODAL_EXPORT_PARTS }, index.h(smartSnippetFeedbackModalCommon.SmartSnippetFeedbackModalHeader, { key: '6a72e3297ed7126cf69563911d85aab6c27ff091', i18n: this.bindings.i18n }), index.h(smartSnippetFeedbackModalCommon.SmartSnippetFeedbackModalBody, { key: '89a48d8530720bd17b5f642dea7725078cf214c3', formId: this.formId, onSubmit: (e) => this.sendFeedback(e) }, index.h(smartSnippetFeedbackModalCommon.SmartSnippetFeebackModalOptions, { key: 'b3d59af560b6bb32592f246f8430e5b63361bfd2', i18n: this.bindings.i18n }, smartSnippetFeedbackModalCommon.smartSnippetFeedbackOptions.map(({ id, localeKey, correspondingAnswer }) => (index.h(smartSnippetFeedbackModalCommon.SmartSnippetFeedbackModalOption, { correspondingAnswer: correspondingAnswer, currentAnswer: this.currentAnswer, i18n: this.bindings.i18n, id: id, localeKey: localeKey, onChange: () => {
56
+ return (index.h("atomic-modal", { key: '9915bc71b6329068bc8a3731971a793946762f39', fullscreen: false, source: this.source, container: this.host, isOpen: this.isOpen, close: () => this.close(), exportparts: exportParts.ATOMIC_MODAL_EXPORT_PARTS }, index.h(smartSnippetFeedbackModalCommon.SmartSnippetFeedbackModalHeader, { key: '385350607264cd3a0dce273b18eec02909220384', i18n: this.bindings.i18n }), index.h(smartSnippetFeedbackModalCommon.SmartSnippetFeedbackModalBody, { key: 'e1a01e0df35dbaf9da6891c825ad5e5e1e6bc534', formId: this.formId, onSubmit: (e) => this.sendFeedback(e) }, index.h(smartSnippetFeedbackModalCommon.SmartSnippetFeebackModalOptions, { key: 'd92a6395c26802cfafbcbd50fb1b2cd86bb907de', i18n: this.bindings.i18n }, smartSnippetFeedbackModalCommon.smartSnippetFeedbackOptions.map(({ id, localeKey, correspondingAnswer }) => (index.h(smartSnippetFeedbackModalCommon.SmartSnippetFeedbackModalOption, { correspondingAnswer: correspondingAnswer, currentAnswer: this.currentAnswer, i18n: this.bindings.i18n, id: id, localeKey: localeKey, onChange: () => {
57
57
  this.currentAnswer = correspondingAnswer;
58
- } })))), index.h(smartSnippetFeedbackModalCommon.SmartSnippetFeedbackModalDetails, { key: '33e65c38e5cf9fcf64e29391ad532d455ddbdc03', currentAnswer: this.currentAnswer, i18n: this.bindings.i18n, setDetailsInputRef: (ref) => (this.detailsInputRef = ref) })), index.h(smartSnippetFeedbackModalCommon.SmartSnippetFeedbackModalFooter, { key: 'c1e92161506d150cc1c1edbb2594281a706a6143', formId: this.formId, i18n: this.bindings.i18n, onClick: () => this.close() })));
58
+ } })))), index.h(smartSnippetFeedbackModalCommon.SmartSnippetFeedbackModalDetails, { key: '6dfe87c931bc44d202d78c5a800936aa733b89de', currentAnswer: this.currentAnswer, i18n: this.bindings.i18n, setDetailsInputRef: (ref) => (this.detailsInputRef = ref) })), index.h(smartSnippetFeedbackModalCommon.SmartSnippetFeedbackModalFooter, { key: '86f51c71ade3a7e360ce5c000e45939e8744ade4', formId: this.formId, i18n: this.bindings.i18n, onClick: () => this.close() })));
59
59
  }
60
60
  close() {
61
61
  this.isOpen = false;
@@ -125,8 +125,8 @@ const AtomicSortDropdown = class {
125
125
  const { hasError, hasResults, firstSearchExecuted } = this.searchStatusState;
126
126
  const { bindings: { i18n }, id, } = this;
127
127
  return [
128
- index.h(SortGuard, { key: 'de3cefc2f8ba7dacb299dd569ca97d4d93a54249', firstSearchExecuted: firstSearchExecuted, hasError: hasError, hasResults: hasResults }, index.h(SortContainer, { key: '5a7296ed5a7f379509399ef260a344210c17ff34' }, index.h(SortLabel, { key: '1448eb9996a0b6a2df55f9ce880cd54c3312640d', i18n: i18n, id: id }), index.h(SortSelect, { key: '273f27873cfb73092eb7d98ef742536f3bb5fac5', i18n: i18n, id: id, onSelect: (evt) => this.select(evt) }, this.options.map(({ label, criteria, expression }) => (index.h(SortOption, { i18n: i18n, label: label, selected: this.sort.isSortedBy(criteria), value: expression })))))),
129
- index.h("slot", { key: 'd1058cd5f4e28bca8816e6987ec2f3a72b2d4825' }),
128
+ index.h(SortGuard, { key: '0669c3a8c7067eef9ba5c178a5f4d12752f8b085', firstSearchExecuted: firstSearchExecuted, hasError: hasError, hasResults: hasResults }, index.h(SortContainer, { key: '6eb9cc11bb18013dfd384b809e6e72d2177cbe60' }, index.h(SortLabel, { key: '4573530fcd7c614b7ed1d3dbb8f4ad5617477ee3', i18n: i18n, id: id }), index.h(SortSelect, { key: 'a5ee4b55058679c63fb628337c33d1db192cf481', i18n: i18n, id: id, onSelect: (evt) => this.select(evt) }, this.options.map(({ label, criteria, expression }) => (index.h(SortOption, { i18n: i18n, label: label, selected: this.sort.isSortedBy(criteria), value: expression })))))),
129
+ index.h("slot", { key: '39a0d6e53adfe877b5f677d4cf9b0ff9177f84e8' }),
130
130
  ];
131
131
  }
132
132
  get host() { return index.getElement(this); }
@@ -54,7 +54,7 @@ const AtomicSortExpression = class {
54
54
  const dropdownComponent = 'atomic-sort-dropdown';
55
55
  if (!this.host.closest(dropdownComponent)) {
56
56
  const error = new Error(`The "${this.host.nodeName.toLowerCase()}" component has to be used inside an ${dropdownComponent} element.`);
57
- return (index.h("atomic-component-error", { key: 'c0181fed2562ac8d51cba8d9a2395ab3fc431295', element: this.host, error: error }));
57
+ return (index.h("atomic-component-error", { key: '4e946fe770ef49fc6346f0bc247db856fd38ba68', element: this.host, error: error }));
58
58
  }
59
59
  }
60
60
  get host() { return index.getElement(this); }
@@ -62,7 +62,7 @@ const AtomicTabManager = class {
62
62
  });
63
63
  }
64
64
  render() {
65
- return (index.h(index.Host, { key: '6e72dfdd25eae1cd7fac4e91535654c8659e96a2' }, index.h("atomic-tab-bar", { key: '2afb27ff6773d7e31100aff97594f06c55264844' }, index.h("div", { key: 'bcd422b9454a9dfe3480c8cc4e09535dae266f10', role: "list", "aria-label": "tab-area", part: "tab-area", class: "border-neutral mb-2 flex w-full flex-row border-b" }, this.tabs.map((tab) => (index.h("atomic-tab-button", { active: this.tabManagerState.activeTab === tab.name, label: this.bindings.i18n.t(tab.label, {
65
+ return (index.h(index.Host, { key: 'ea60f4179a268319ba97570f95d6881c379c8b18' }, index.h("atomic-tab-bar", { key: 'ea83347d794b2f83b70706bdfc4240286c27d71e' }, index.h("div", { key: '9d9e588d7a4b7012f43419f3edae786b177498cc', role: "list", "aria-label": "tab-area", part: "tab-area", class: "border-neutral mb-2 flex w-full flex-row border-b" }, this.tabs.map((tab) => (index.h("atomic-tab-button", { active: this.tabManagerState.activeTab === tab.name, label: this.bindings.i18n.t(tab.label, {
66
66
  defaultValue: tab.label,
67
67
  }), select: () => {
68
68
  if (!tab.tabController.state.isActive) {