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