@searchspring/snap-preact-components 0.51.1 → 0.52.0
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/cjs/components/Atoms/Badge/Badge.d.ts +1 -3
- package/dist/cjs/components/Atoms/Badge/Badge.d.ts.map +1 -1
- package/dist/cjs/components/Atoms/Badge/Badge.js +2 -2
- package/dist/cjs/components/Atoms/Breadcrumbs/Breadcrumbs.d.ts +1 -3
- package/dist/cjs/components/Atoms/Breadcrumbs/Breadcrumbs.d.ts.map +1 -1
- package/dist/cjs/components/Atoms/Breadcrumbs/Breadcrumbs.js +2 -2
- package/dist/cjs/components/Atoms/Button/Button.d.ts +1 -3
- package/dist/cjs/components/Atoms/Button/Button.d.ts.map +1 -1
- package/dist/cjs/components/Atoms/Button/Button.js +2 -2
- package/dist/cjs/components/Atoms/Dropdown/Dropdown.d.ts +1 -3
- package/dist/cjs/components/Atoms/Dropdown/Dropdown.d.ts.map +1 -1
- package/dist/cjs/components/Atoms/Dropdown/Dropdown.js +2 -2
- package/dist/cjs/components/Atoms/Icon/Icon.d.ts +1 -1
- package/dist/cjs/components/Atoms/Icon/Icon.d.ts.map +1 -1
- package/dist/cjs/components/Atoms/Icon/paths.d.ts +1 -1
- package/dist/cjs/components/Atoms/Icon/paths.d.ts.map +1 -1
- package/dist/cjs/components/Atoms/Icon/paths.js +1 -0
- package/dist/cjs/components/Atoms/Price/Price.js +1 -1
- package/dist/cjs/components/Atoms/Skeleton/Skeleton.d.ts +1 -3
- package/dist/cjs/components/Atoms/Skeleton/Skeleton.d.ts.map +1 -1
- package/dist/cjs/components/Atoms/Skeleton/Skeleton.js +2 -2
- package/dist/cjs/components/Molecules/Carousel/Carousel.d.ts +11 -8
- package/dist/cjs/components/Molecules/Carousel/Carousel.d.ts.map +1 -1
- package/dist/cjs/components/Molecules/Carousel/Carousel.js +91 -44
- package/dist/cjs/components/Molecules/Checkbox/Checkbox.d.ts +1 -3
- package/dist/cjs/components/Molecules/Checkbox/Checkbox.d.ts.map +1 -1
- package/dist/cjs/components/Molecules/Checkbox/Checkbox.js +2 -2
- package/dist/cjs/components/Molecules/ErrorHandler/ErrorHandler.d.ts +1 -3
- package/dist/cjs/components/Molecules/ErrorHandler/ErrorHandler.d.ts.map +1 -1
- package/dist/cjs/components/Molecules/ErrorHandler/ErrorHandler.js +2 -2
- package/dist/cjs/components/Molecules/FacetGridOptions/FacetGridOptions.d.ts +1 -3
- package/dist/cjs/components/Molecules/FacetGridOptions/FacetGridOptions.d.ts.map +1 -1
- package/dist/cjs/components/Molecules/FacetGridOptions/FacetGridOptions.js +2 -2
- package/dist/cjs/components/Molecules/FacetHierarchyOptions/FacetHierarchyOptions.d.ts +1 -3
- package/dist/cjs/components/Molecules/FacetHierarchyOptions/FacetHierarchyOptions.d.ts.map +1 -1
- package/dist/cjs/components/Molecules/FacetHierarchyOptions/FacetHierarchyOptions.js +2 -2
- package/dist/cjs/components/Molecules/FacetListOptions/FacetListOptions.d.ts +1 -3
- package/dist/cjs/components/Molecules/FacetListOptions/FacetListOptions.d.ts.map +1 -1
- package/dist/cjs/components/Molecules/FacetListOptions/FacetListOptions.js +2 -2
- package/dist/cjs/components/Molecules/FacetPaletteOptions/FacetPaletteOptions.d.ts +1 -3
- package/dist/cjs/components/Molecules/FacetPaletteOptions/FacetPaletteOptions.d.ts.map +1 -1
- package/dist/cjs/components/Molecules/FacetPaletteOptions/FacetPaletteOptions.js +2 -2
- package/dist/cjs/components/Molecules/FacetSlider/FacetSlider.d.ts +1 -3
- package/dist/cjs/components/Molecules/FacetSlider/FacetSlider.d.ts.map +1 -1
- package/dist/cjs/components/Molecules/FacetSlider/FacetSlider.js +2 -2
- package/dist/cjs/components/Molecules/Filter/Filter.d.ts +1 -3
- package/dist/cjs/components/Molecules/Filter/Filter.d.ts.map +1 -1
- package/dist/cjs/components/Molecules/Filter/Filter.js +2 -2
- package/dist/cjs/components/Molecules/Pagination/Pagination.d.ts +1 -3
- package/dist/cjs/components/Molecules/Pagination/Pagination.d.ts.map +1 -1
- package/dist/cjs/components/Molecules/Pagination/Pagination.js +2 -2
- package/dist/cjs/components/Molecules/Result/Result.d.ts +1 -3
- package/dist/cjs/components/Molecules/Result/Result.d.ts.map +1 -1
- package/dist/cjs/components/Molecules/Result/Result.js +7 -7
- package/dist/cjs/components/Molecules/SearchInput/SearchInput.d.ts +1 -3
- package/dist/cjs/components/Molecules/SearchInput/SearchInput.d.ts.map +1 -1
- package/dist/cjs/components/Molecules/SearchInput/SearchInput.js +2 -2
- package/dist/cjs/components/Molecules/Select/Select.d.ts +2 -4
- package/dist/cjs/components/Molecules/Select/Select.d.ts.map +1 -1
- package/dist/cjs/components/Molecules/Select/Select.js +6 -2
- package/dist/cjs/components/Molecules/Slideout/Slideout.d.ts +1 -1
- package/dist/cjs/components/Molecules/Slideout/Slideout.d.ts.map +1 -1
- package/dist/cjs/components/Organisms/Autocomplete/Autocomplete.d.ts +1 -3
- package/dist/cjs/components/Organisms/Autocomplete/Autocomplete.d.ts.map +1 -1
- package/dist/cjs/components/Organisms/Autocomplete/Autocomplete.js +2 -2
- package/dist/cjs/components/Organisms/Facet/Facet.d.ts +2 -4
- package/dist/cjs/components/Organisms/Facet/Facet.d.ts.map +1 -1
- package/dist/cjs/components/Organisms/Facet/Facet.js +2 -2
- package/dist/cjs/components/Organisms/Facets/Facets.d.ts +2 -4
- package/dist/cjs/components/Organisms/Facets/Facets.d.ts.map +1 -1
- package/dist/cjs/components/Organisms/Facets/Facets.js +2 -2
- package/dist/cjs/components/Organisms/FilterSummary/FilterSummary.d.ts +1 -3
- package/dist/cjs/components/Organisms/FilterSummary/FilterSummary.d.ts.map +1 -1
- package/dist/cjs/components/Organisms/FilterSummary/FilterSummary.js +2 -2
- package/dist/cjs/components/Organisms/Recommendation/Recommendation.d.ts +3 -5
- package/dist/cjs/components/Organisms/Recommendation/Recommendation.d.ts.map +1 -1
- package/dist/cjs/components/Organisms/Recommendation/Recommendation.js +2 -2
- package/dist/cjs/components/Organisms/RecommendationBundle/BundleCTA.d.ts +17 -0
- package/dist/cjs/components/Organisms/RecommendationBundle/BundleCTA.d.ts.map +1 -0
- package/dist/cjs/components/Organisms/RecommendationBundle/BundleCTA.js +48 -0
- package/dist/cjs/components/Organisms/RecommendationBundle/BundleSelector.d.ts +21 -0
- package/dist/cjs/components/Organisms/RecommendationBundle/BundleSelector.d.ts.map +1 -0
- package/dist/cjs/components/Organisms/RecommendationBundle/BundleSelector.js +47 -0
- package/dist/cjs/components/Organisms/RecommendationBundle/RecommendationBundle.d.ts +33 -0
- package/dist/cjs/components/Organisms/RecommendationBundle/RecommendationBundle.d.ts.map +1 -0
- package/dist/cjs/components/Organisms/RecommendationBundle/RecommendationBundle.js +336 -0
- package/dist/cjs/components/Organisms/RecommendationBundle/index.d.ts +2 -0
- package/dist/cjs/components/Organisms/RecommendationBundle/index.d.ts.map +1 -0
- package/dist/cjs/components/Organisms/RecommendationBundle/index.js +17 -0
- package/dist/cjs/components/Organisms/Results/Results.d.ts +1 -3
- package/dist/cjs/components/Organisms/Results/Results.d.ts.map +1 -1
- package/dist/cjs/components/Organisms/Results/Results.js +2 -2
- package/dist/cjs/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.d.ts +1 -3
- package/dist/cjs/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.d.ts.map +1 -1
- package/dist/cjs/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.js +2 -2
- package/dist/cjs/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.d.ts +1 -3
- package/dist/cjs/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.d.ts.map +1 -1
- package/dist/cjs/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.js +2 -2
- package/dist/cjs/index.d.ts +1 -0
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +1 -0
- package/dist/cjs/setupTests.d.ts +1 -0
- package/dist/cjs/setupTests.d.ts.map +1 -1
- package/dist/cjs/setupTests.js +2 -1
- package/dist/cjs/toolbox/createHoverProps/createHoverProps.d.ts +1 -1
- package/dist/cjs/toolbox/createHoverProps/createHoverProps.d.ts.map +1 -1
- package/dist/cjs/types.d.ts +4 -4
- package/dist/cjs/types.d.ts.map +1 -1
- package/dist/cjs/types.js +3 -3
- package/dist/cjs/utilities/defined.d.ts +1 -1
- package/dist/cjs/utilities/defined.d.ts.map +1 -1
- package/dist/cjs/utilities/snapify.js +1 -1
- package/dist/esm/components/Atoms/Badge/Badge.d.ts +1 -3
- package/dist/esm/components/Atoms/Badge/Badge.d.ts.map +1 -1
- package/dist/esm/components/Atoms/Badge/Badge.js +1 -1
- package/dist/esm/components/Atoms/Breadcrumbs/Breadcrumbs.d.ts +1 -3
- package/dist/esm/components/Atoms/Breadcrumbs/Breadcrumbs.d.ts.map +1 -1
- package/dist/esm/components/Atoms/Breadcrumbs/Breadcrumbs.js +1 -1
- package/dist/esm/components/Atoms/Button/Button.d.ts +1 -3
- package/dist/esm/components/Atoms/Button/Button.d.ts.map +1 -1
- package/dist/esm/components/Atoms/Button/Button.js +1 -1
- package/dist/esm/components/Atoms/Dropdown/Dropdown.d.ts +1 -3
- package/dist/esm/components/Atoms/Dropdown/Dropdown.d.ts.map +1 -1
- package/dist/esm/components/Atoms/Dropdown/Dropdown.js +1 -1
- package/dist/esm/components/Atoms/Icon/Icon.d.ts +1 -1
- package/dist/esm/components/Atoms/Icon/Icon.d.ts.map +1 -1
- package/dist/esm/components/Atoms/Icon/paths.d.ts +1 -1
- package/dist/esm/components/Atoms/Icon/paths.d.ts.map +1 -1
- package/dist/esm/components/Atoms/Icon/paths.js +1 -0
- package/dist/esm/components/Atoms/Price/Price.js +1 -1
- package/dist/esm/components/Atoms/Skeleton/Skeleton.d.ts +1 -3
- package/dist/esm/components/Atoms/Skeleton/Skeleton.d.ts.map +1 -1
- package/dist/esm/components/Atoms/Skeleton/Skeleton.js +1 -1
- package/dist/esm/components/Molecules/Carousel/Carousel.d.ts +11 -8
- package/dist/esm/components/Molecules/Carousel/Carousel.d.ts.map +1 -1
- package/dist/esm/components/Molecules/Carousel/Carousel.js +95 -21
- package/dist/esm/components/Molecules/Checkbox/Checkbox.d.ts +1 -3
- package/dist/esm/components/Molecules/Checkbox/Checkbox.d.ts.map +1 -1
- package/dist/esm/components/Molecules/Checkbox/Checkbox.js +1 -1
- package/dist/esm/components/Molecules/ErrorHandler/ErrorHandler.d.ts +1 -3
- package/dist/esm/components/Molecules/ErrorHandler/ErrorHandler.d.ts.map +1 -1
- package/dist/esm/components/Molecules/ErrorHandler/ErrorHandler.js +1 -1
- package/dist/esm/components/Molecules/FacetGridOptions/FacetGridOptions.d.ts +1 -3
- package/dist/esm/components/Molecules/FacetGridOptions/FacetGridOptions.d.ts.map +1 -1
- package/dist/esm/components/Molecules/FacetGridOptions/FacetGridOptions.js +1 -1
- package/dist/esm/components/Molecules/FacetHierarchyOptions/FacetHierarchyOptions.d.ts +1 -3
- package/dist/esm/components/Molecules/FacetHierarchyOptions/FacetHierarchyOptions.d.ts.map +1 -1
- package/dist/esm/components/Molecules/FacetHierarchyOptions/FacetHierarchyOptions.js +1 -1
- package/dist/esm/components/Molecules/FacetListOptions/FacetListOptions.d.ts +1 -3
- package/dist/esm/components/Molecules/FacetListOptions/FacetListOptions.d.ts.map +1 -1
- package/dist/esm/components/Molecules/FacetListOptions/FacetListOptions.js +1 -1
- package/dist/esm/components/Molecules/FacetPaletteOptions/FacetPaletteOptions.d.ts +1 -3
- package/dist/esm/components/Molecules/FacetPaletteOptions/FacetPaletteOptions.d.ts.map +1 -1
- package/dist/esm/components/Molecules/FacetPaletteOptions/FacetPaletteOptions.js +1 -1
- package/dist/esm/components/Molecules/FacetSlider/FacetSlider.d.ts +1 -3
- package/dist/esm/components/Molecules/FacetSlider/FacetSlider.d.ts.map +1 -1
- package/dist/esm/components/Molecules/FacetSlider/FacetSlider.js +1 -1
- package/dist/esm/components/Molecules/Filter/Filter.d.ts +1 -3
- package/dist/esm/components/Molecules/Filter/Filter.d.ts.map +1 -1
- package/dist/esm/components/Molecules/Filter/Filter.js +1 -1
- package/dist/esm/components/Molecules/Pagination/Pagination.d.ts +1 -3
- package/dist/esm/components/Molecules/Pagination/Pagination.d.ts.map +1 -1
- package/dist/esm/components/Molecules/Pagination/Pagination.js +1 -1
- package/dist/esm/components/Molecules/Result/Result.d.ts +1 -3
- package/dist/esm/components/Molecules/Result/Result.d.ts.map +1 -1
- package/dist/esm/components/Molecules/Result/Result.js +2 -2
- package/dist/esm/components/Molecules/SearchInput/SearchInput.d.ts +1 -3
- package/dist/esm/components/Molecules/SearchInput/SearchInput.d.ts.map +1 -1
- package/dist/esm/components/Molecules/SearchInput/SearchInput.js +1 -1
- package/dist/esm/components/Molecules/Select/Select.d.ts +2 -4
- package/dist/esm/components/Molecules/Select/Select.d.ts.map +1 -1
- package/dist/esm/components/Molecules/Select/Select.js +5 -1
- package/dist/esm/components/Molecules/Slideout/Slideout.d.ts +1 -1
- package/dist/esm/components/Molecules/Slideout/Slideout.d.ts.map +1 -1
- package/dist/esm/components/Organisms/Autocomplete/Autocomplete.d.ts +1 -3
- package/dist/esm/components/Organisms/Autocomplete/Autocomplete.d.ts.map +1 -1
- package/dist/esm/components/Organisms/Autocomplete/Autocomplete.js +1 -1
- package/dist/esm/components/Organisms/Facet/Facet.d.ts +2 -4
- package/dist/esm/components/Organisms/Facet/Facet.d.ts.map +1 -1
- package/dist/esm/components/Organisms/Facet/Facet.js +1 -1
- package/dist/esm/components/Organisms/Facets/Facets.d.ts +2 -4
- package/dist/esm/components/Organisms/Facets/Facets.d.ts.map +1 -1
- package/dist/esm/components/Organisms/Facets/Facets.js +1 -1
- package/dist/esm/components/Organisms/FilterSummary/FilterSummary.d.ts +1 -3
- package/dist/esm/components/Organisms/FilterSummary/FilterSummary.d.ts.map +1 -1
- package/dist/esm/components/Organisms/FilterSummary/FilterSummary.js +1 -1
- package/dist/esm/components/Organisms/Recommendation/Recommendation.d.ts +3 -5
- package/dist/esm/components/Organisms/Recommendation/Recommendation.d.ts.map +1 -1
- package/dist/esm/components/Organisms/Recommendation/Recommendation.js +1 -1
- package/dist/esm/components/Organisms/RecommendationBundle/BundleCTA.d.ts +17 -0
- package/dist/esm/components/Organisms/RecommendationBundle/BundleCTA.d.ts.map +1 -0
- package/dist/esm/components/Organisms/RecommendationBundle/BundleCTA.js +42 -0
- package/dist/esm/components/Organisms/RecommendationBundle/BundleSelector.d.ts +21 -0
- package/dist/esm/components/Organisms/RecommendationBundle/BundleSelector.d.ts.map +1 -0
- package/dist/esm/components/Organisms/RecommendationBundle/BundleSelector.js +43 -0
- package/dist/esm/components/Organisms/RecommendationBundle/RecommendationBundle.d.ts +33 -0
- package/dist/esm/components/Organisms/RecommendationBundle/RecommendationBundle.d.ts.map +1 -0
- package/dist/esm/components/Organisms/RecommendationBundle/RecommendationBundle.js +339 -0
- package/dist/esm/components/Organisms/RecommendationBundle/index.d.ts +2 -0
- package/dist/esm/components/Organisms/RecommendationBundle/index.d.ts.map +1 -0
- package/dist/esm/components/Organisms/RecommendationBundle/index.js +1 -0
- package/dist/esm/components/Organisms/Results/Results.d.ts +1 -3
- package/dist/esm/components/Organisms/Results/Results.d.ts.map +1 -1
- package/dist/esm/components/Organisms/Results/Results.js +1 -1
- package/dist/esm/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.d.ts +1 -3
- package/dist/esm/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.d.ts.map +1 -1
- package/dist/esm/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.js +1 -1
- package/dist/esm/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.d.ts +1 -3
- package/dist/esm/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.d.ts.map +1 -1
- package/dist/esm/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.js +1 -1
- package/dist/esm/index.d.ts +1 -0
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +1 -0
- package/dist/esm/setupTests.d.ts +1 -0
- package/dist/esm/setupTests.d.ts.map +1 -1
- package/dist/esm/setupTests.js +1 -2
- package/dist/esm/toolbox/createHoverProps/createHoverProps.d.ts +1 -1
- package/dist/esm/toolbox/createHoverProps/createHoverProps.d.ts.map +1 -1
- package/dist/esm/types.d.ts +4 -4
- package/dist/esm/types.d.ts.map +1 -1
- package/dist/esm/utilities/defined.d.ts +1 -1
- package/dist/esm/utilities/defined.d.ts.map +1 -1
- package/package.json +32 -17
|
@@ -2,11 +2,9 @@
|
|
|
2
2
|
/** @jsx jsx */
|
|
3
3
|
import { ComponentChildren } from 'preact';
|
|
4
4
|
import type { RecommendationController } from '@searchspring/snap-controller';
|
|
5
|
-
import type {
|
|
5
|
+
import type { Product } from '@searchspring/snap-store-mobx';
|
|
6
6
|
import { ComponentProps, BreakpointsProps } from '../../../types';
|
|
7
|
-
export declare const Recommendation: (
|
|
8
|
-
displayName: string;
|
|
9
|
-
};
|
|
7
|
+
export declare const Recommendation: (properties: RecommendationProps) => JSX.Element;
|
|
10
8
|
export interface RecommendationProps extends ComponentProps {
|
|
11
9
|
title?: JSX.Element | string;
|
|
12
10
|
breakpoints?: BreakpointsProps;
|
|
@@ -14,7 +12,7 @@ export interface RecommendationProps extends ComponentProps {
|
|
|
14
12
|
nextButton?: JSX.Element | string;
|
|
15
13
|
hideButtons?: boolean;
|
|
16
14
|
loop?: boolean;
|
|
17
|
-
results?:
|
|
15
|
+
results?: Product[];
|
|
18
16
|
pagination?: boolean;
|
|
19
17
|
controller: RecommendationController;
|
|
20
18
|
children?: ComponentChildren;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Recommendation.d.ts","sourceRoot":"","sources":["../../../../../src/components/Organisms/Recommendation/Recommendation.tsx"],"names":[],"mappings":";AAAA,eAAe;AACf,OAAO,EAAe,iBAAiB,EAAE,MAAM,QAAQ,CAAC;AAMxD,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAC9E,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"Recommendation.d.ts","sourceRoot":"","sources":["../../../../../src/components/Organisms/Recommendation/Recommendation.tsx"],"names":[],"mappings":";AAAA,eAAe;AACf,OAAO,EAAe,iBAAiB,EAAE,MAAM,QAAQ,CAAC;AAMxD,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAC9E,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,+BAA+B,CAAC;AAM7D,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAc,MAAM,gBAAgB,CAAC;AAe9E,eAAO,MAAM,cAAc,eAAyB,mBAAmB,KAAG,WA+HxE,CAAC;AAEH,MAAM,WAAW,mBAAoB,SAAQ,cAAc;IAC1D,KAAK,CAAC,EAAE,GAAG,CAAC,OAAO,GAAG,MAAM,CAAC;IAC7B,WAAW,CAAC,EAAE,gBAAgB,CAAC;IAC/B,UAAU,CAAC,EAAE,GAAG,CAAC,OAAO,GAAG,MAAM,CAAC;IAClC,UAAU,CAAC,EAAE,GAAG,CAAC,OAAO,GAAG,MAAM,CAAC;IAClC,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,OAAO,CAAC,EAAE,OAAO,EAAE,CAAC;IACpB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,UAAU,EAAE,wBAAwB,CAAC;IACrC,QAAQ,CAAC,EAAE,iBAAiB,CAAC;IAC7B,QAAQ,CAAC,EAAE,OAAO,CAAC;CACnB"}
|
|
@@ -30,7 +30,7 @@ exports.Recommendation = void 0;
|
|
|
30
30
|
var preact_1 = require("preact");
|
|
31
31
|
var react_1 = require("@emotion/react");
|
|
32
32
|
var classnames_1 = __importDefault(require("classnames"));
|
|
33
|
-
var
|
|
33
|
+
var mobx_react_1 = require("mobx-react");
|
|
34
34
|
var deepmerge_1 = __importDefault(require("deepmerge"));
|
|
35
35
|
var Carousel_1 = require("../../Molecules/Carousel");
|
|
36
36
|
var Result_1 = require("../../Molecules/Result");
|
|
@@ -50,7 +50,7 @@ var CSS = {
|
|
|
50
50
|
});
|
|
51
51
|
},
|
|
52
52
|
};
|
|
53
|
-
exports.Recommendation = (0,
|
|
53
|
+
exports.Recommendation = (0, mobx_react_1.observer)(function (properties) {
|
|
54
54
|
var _a, _b, _c, _d, _e, _f;
|
|
55
55
|
var globalTheme = (0, providers_1.useTheme)();
|
|
56
56
|
var props = __assign(__assign(__assign({
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { IconProps } from '../../Atoms/Icon';
|
|
3
|
+
import type { ComponentProps } from '../../../types';
|
|
4
|
+
import type { CartStore } from '@searchspring/snap-store-mobx';
|
|
5
|
+
export declare const BundledCTA: (properties: BundledCTAProps) => JSX.Element;
|
|
6
|
+
export interface BundleSelectorSubProps {
|
|
7
|
+
icon: Partial<IconProps>;
|
|
8
|
+
}
|
|
9
|
+
interface BundledCTAProps extends ComponentProps {
|
|
10
|
+
ctaSlot?: JSX.Element;
|
|
11
|
+
cartStore: CartStore;
|
|
12
|
+
icon?: string | Partial<IconProps> | boolean;
|
|
13
|
+
onAddToCartClick: (e: React.MouseEvent<HTMLElement, MouseEvent>) => void;
|
|
14
|
+
addToCartText?: string;
|
|
15
|
+
}
|
|
16
|
+
export {};
|
|
17
|
+
//# sourceMappingURL=BundleCTA.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BundleCTA.d.ts","sourceRoot":"","sources":["../../../../../src/components/Organisms/RecommendationBundle/BundleCTA.tsx"],"names":[],"mappings":";AAQA,OAAO,EAAQ,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AACrD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,+BAA+B,CAAC;AAE/D,eAAO,MAAM,UAAU,eAAyB,eAAe,KAAG,WA2DhE,CAAC;AAEH,MAAM,WAAW,sBAAsB;IACtC,IAAI,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;CACzB;AAED,UAAU,eAAgB,SAAQ,cAAc;IAC/C,OAAO,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC;IACtB,SAAS,EAAE,SAAS,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,GAAG,OAAO,CAAC;IAC7C,gBAAgB,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,UAAU,CAAC,WAAW,EAAE,UAAU,CAAC,KAAK,IAAI,CAAC;IACzE,aAAa,CAAC,EAAE,MAAM,CAAC;CACvB"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
+
exports.BundledCTA = void 0;
|
|
15
|
+
/** @jsx jsx */
|
|
16
|
+
var preact_1 = require("preact");
|
|
17
|
+
var react_1 = require("@emotion/react");
|
|
18
|
+
var mobx_react_1 = require("mobx-react");
|
|
19
|
+
var utilities_1 = require("../../../utilities");
|
|
20
|
+
var Button_1 = require("../../Atoms/Button");
|
|
21
|
+
var Price_1 = require("../../Atoms/Price");
|
|
22
|
+
var providers_1 = require("../../../providers");
|
|
23
|
+
var Icon_1 = require("../../Atoms/Icon");
|
|
24
|
+
exports.BundledCTA = (0, mobx_react_1.observer)(function (properties) {
|
|
25
|
+
var _a;
|
|
26
|
+
var globalTheme = (0, providers_1.useTheme)();
|
|
27
|
+
var props = __assign({}, properties);
|
|
28
|
+
var ctaSlot = props.ctaSlot, icon = props.icon, cartStore = props.cartStore, onAddToCartClick = props.onAddToCartClick, addToCartText = props.addToCartText;
|
|
29
|
+
var subProps = {
|
|
30
|
+
icon: __assign(__assign({
|
|
31
|
+
// default props
|
|
32
|
+
className: 'ss__recommendation-bundle__wrapper__cta__icon', icon: 'bag', size: 50 }, (_a = globalTheme === null || globalTheme === void 0 ? void 0 : globalTheme.components) === null || _a === void 0 ? void 0 : _a.icon), {
|
|
33
|
+
// component theme overrides
|
|
34
|
+
theme: props === null || props === void 0 ? void 0 : props.theme }),
|
|
35
|
+
};
|
|
36
|
+
return ((0, react_1.jsx)("div", { className: "ss__recommendation-bundle__wrapper__cta" }, ctaSlot ? ((0, utilities_1.cloneWithProps)(ctaSlot, props)) : ((0, react_1.jsx)(preact_1.Fragment, null,
|
|
37
|
+
(0, react_1.jsx)("div", { className: "ss__recommendation-bundle__wrapper__cta__subtotal" },
|
|
38
|
+
icon ? ((0, react_1.jsx)("div", { className: "icon" },
|
|
39
|
+
(0, react_1.jsx)(Icon_1.Icon, __assign({}, subProps.icon, (typeof icon == 'string' ? { icon: icon } : icon))))) : ((0, react_1.jsx)(preact_1.Fragment, null)),
|
|
40
|
+
(0, react_1.jsx)("span", { className: "ss__recommendation-bundle__wrapper__cta__subtotal__title" }, "Subtotal for ".concat(cartStore.count, " items")),
|
|
41
|
+
(0, react_1.jsx)("div", { className: "ss__recommendation-bundle__wrapper__cta__subtotal__prices" },
|
|
42
|
+
cartStore.msrp && cartStore.msrp !== cartStore.price ? ((0, react_1.jsx)("label", { className: "ss__recommendation-bundle__wrapper__cta__subtotal__strike" },
|
|
43
|
+
"Was ",
|
|
44
|
+
(0, react_1.jsx)(Price_1.Price, { lineThrough: true, value: cartStore.msrp }))) : ((0, react_1.jsx)(preact_1.Fragment, null)),
|
|
45
|
+
(0, react_1.jsx)("label", { className: "ss__recommendation-bundle__wrapper__cta__subtotal__price" },
|
|
46
|
+
(0, react_1.jsx)(Price_1.Price, { value: cartStore.price })))),
|
|
47
|
+
(0, react_1.jsx)(Button_1.Button, { className: 'ss__recommendation-bundle__wrapper__cta__button', onClick: function (e) { return onAddToCartClick(e); } }, addToCartText)))));
|
|
48
|
+
});
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
/** @jsx jsx */
|
|
3
|
+
import { ComponentChildren } from 'preact';
|
|
4
|
+
import { CheckboxProps } from '../../Molecules/Checkbox';
|
|
5
|
+
import { IconProps } from '../../Atoms/Icon';
|
|
6
|
+
import type { ComponentProps } from '../../../types';
|
|
7
|
+
export declare const BundleSelector: (properties: BundleSelectorProps) => JSX.Element;
|
|
8
|
+
export interface BundleSelectorSubProps {
|
|
9
|
+
icon: Partial<IconProps>;
|
|
10
|
+
checkbox: Partial<CheckboxProps>;
|
|
11
|
+
}
|
|
12
|
+
export interface BundleSelectorProps extends ComponentProps {
|
|
13
|
+
children?: ComponentChildren;
|
|
14
|
+
checked?: boolean;
|
|
15
|
+
seedText?: string;
|
|
16
|
+
seed?: boolean;
|
|
17
|
+
hideCheckboxes?: boolean;
|
|
18
|
+
onCheck?: () => void;
|
|
19
|
+
icon?: string | Partial<IconProps> | boolean;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=BundleSelector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BundleSelector.d.ts","sourceRoot":"","sources":["../../../../../src/components/Organisms/RecommendationBundle/BundleSelector.tsx"],"names":[],"mappings":";AAAA,eAAe;AACf,OAAO,EAAK,iBAAiB,EAAE,MAAM,QAAQ,CAAC;AAK9C,OAAO,EAAY,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAQ,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAErD,eAAO,MAAM,cAAc,eAAyB,mBAAmB,KAAG,WAmDxE,CAAC;AAEH,MAAM,WAAW,sBAAsB;IACtC,IAAI,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;IACzB,QAAQ,EAAE,OAAO,CAAC,aAAa,CAAC,CAAC;CACjC;AAED,MAAM,WAAW,mBAAoB,SAAQ,cAAc;IAC1D,QAAQ,CAAC,EAAE,iBAAiB,CAAC;IAC7B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,GAAG,OAAO,CAAC;CAC7C"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
14
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.BundleSelector = void 0;
|
|
18
|
+
var react_1 = require("@emotion/react");
|
|
19
|
+
var classnames_1 = __importDefault(require("classnames"));
|
|
20
|
+
var mobx_react_1 = require("mobx-react");
|
|
21
|
+
var providers_1 = require("../../../providers");
|
|
22
|
+
var Checkbox_1 = require("../../Molecules/Checkbox");
|
|
23
|
+
var Icon_1 = require("../../Atoms/Icon");
|
|
24
|
+
exports.BundleSelector = (0, mobx_react_1.observer)(function (properties) {
|
|
25
|
+
var _a, _b;
|
|
26
|
+
var globalTheme = (0, providers_1.useTheme)();
|
|
27
|
+
var props = __assign({
|
|
28
|
+
// default props
|
|
29
|
+
hideCheckboxes: false }, properties);
|
|
30
|
+
var className = props.className, children = props.children, checked = props.checked, icon = props.icon, seedText = props.seedText, seed = props.seed, hideCheckboxes = props.hideCheckboxes, onCheck = props.onCheck;
|
|
31
|
+
var subProps = {
|
|
32
|
+
icon: __assign(__assign({
|
|
33
|
+
// default props
|
|
34
|
+
className: 'ss__recommendation-bundle__wrapper__selector__icon', size: 15 }, (_a = globalTheme === null || globalTheme === void 0 ? void 0 : globalTheme.components) === null || _a === void 0 ? void 0 : _a.icon), {
|
|
35
|
+
// component theme overrides
|
|
36
|
+
theme: props === null || props === void 0 ? void 0 : props.theme }),
|
|
37
|
+
checkbox: __assign(__assign({ className: 'ss__recommendation-bundle__wrapper__selector__result-wrapper__checkbox', checked: checked, size: 18, onClick: onCheck }, (_b = globalTheme === null || globalTheme === void 0 ? void 0 : globalTheme.components) === null || _b === void 0 ? void 0 : _b.checkbox), {
|
|
38
|
+
// component theme overrides
|
|
39
|
+
theme: props === null || props === void 0 ? void 0 : props.theme }),
|
|
40
|
+
};
|
|
41
|
+
return ((0, react_1.jsx)("div", { className: (0, classnames_1.default)('ss__recommendation-bundle__wrapper__selector', checked ? 'ss__recommendation-bundle__wrapper__selector--selected' : '', seedText || seed ? 'ss__recommendation-bundle__wrapper__selector--seed' : '', className) },
|
|
42
|
+
(0, react_1.jsx)("div", { className: "ss__recommendation-bundle__wrapper__selector__result-wrapper" },
|
|
43
|
+
!hideCheckboxes && (0, react_1.jsx)(Checkbox_1.Checkbox, __assign({}, subProps.checkbox)),
|
|
44
|
+
seedText && (0, react_1.jsx)("div", { className: 'ss__recommendation-bundle__wrapper__selector__result-wrapper__seed-badge' }, seedText),
|
|
45
|
+
children),
|
|
46
|
+
(0, react_1.jsx)(Icon_1.Icon, __assign({}, subProps.icon, (typeof icon == 'string' ? { icon: icon } : icon)))));
|
|
47
|
+
});
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { CarouselProps as CarouselProps } from '../../Molecules/Carousel';
|
|
3
|
+
import { ComponentProps, BreakpointsProps } from '../../../types';
|
|
4
|
+
import { IconProps } from '../../Atoms/Icon';
|
|
5
|
+
import type { RecommendationController } from '@searchspring/snap-controller';
|
|
6
|
+
import type { Product } from '@searchspring/snap-store-mobx';
|
|
7
|
+
export declare const RecommendationBundle: (properties: RecommendationBundleProps) => JSX.Element;
|
|
8
|
+
type BundleCarouselProps = {
|
|
9
|
+
enabled?: boolean;
|
|
10
|
+
seedInCarousel?: boolean;
|
|
11
|
+
} & Partial<CarouselProps>;
|
|
12
|
+
export interface RecommendationBundleProps extends ComponentProps {
|
|
13
|
+
results?: Product[];
|
|
14
|
+
limit?: number;
|
|
15
|
+
controller: RecommendationController;
|
|
16
|
+
onAddToCart: (items: Product[]) => void;
|
|
17
|
+
title?: JSX.Element | string;
|
|
18
|
+
breakpoints?: BreakpointsProps;
|
|
19
|
+
resultComponent?: JSX.Element;
|
|
20
|
+
preselectedCount?: number;
|
|
21
|
+
hideCheckboxes?: boolean;
|
|
22
|
+
seedText?: string;
|
|
23
|
+
separatorIconSeedOnly?: boolean;
|
|
24
|
+
separatorIcon?: string | Partial<IconProps> | boolean;
|
|
25
|
+
ctaInline?: boolean;
|
|
26
|
+
ctaIcon?: string | Partial<IconProps> | boolean;
|
|
27
|
+
ctaButtonText?: string;
|
|
28
|
+
ctaSlot?: JSX.Element;
|
|
29
|
+
vertical?: boolean;
|
|
30
|
+
carousel?: BundleCarouselProps;
|
|
31
|
+
}
|
|
32
|
+
export {};
|
|
33
|
+
//# sourceMappingURL=RecommendationBundle.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RecommendationBundle.d.ts","sourceRoot":"","sources":["../../../../../src/components/Organisms/RecommendationBundle/RecommendationBundle.tsx"],"names":[],"mappings":";AAOA,OAAO,EAAY,aAAa,IAAI,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAIpF,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAc,MAAM,gBAAgB,CAAC;AAI9E,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAC9E,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,+BAA+B,CAAC;AAyG7D,eAAO,MAAM,oBAAoB,eAAyB,yBAAyB,KAAG,WAicpF,CAAC;AAEH,KAAK,mBAAmB,GAAG;IAC1B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,cAAc,CAAC,EAAE,OAAO,CAAC;CACzB,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;AAE3B,MAAM,WAAW,yBAA0B,SAAQ,cAAc;IAChE,OAAO,CAAC,EAAE,OAAO,EAAE,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,wBAAwB,CAAC;IACrC,WAAW,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,KAAK,IAAI,CAAC;IACxC,KAAK,CAAC,EAAE,GAAG,CAAC,OAAO,GAAG,MAAM,CAAC;IAC7B,WAAW,CAAC,EAAE,gBAAgB,CAAC;IAC/B,eAAe,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC;IAC9B,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,aAAa,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,GAAG,OAAO,CAAC;IACtD,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,GAAG,OAAO,CAAC;IAChD,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,OAAO,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,mBAAmB,CAAC;CAC/B"}
|
|
@@ -0,0 +1,336 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
14
|
+
var t = {};
|
|
15
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
16
|
+
t[p] = s[p];
|
|
17
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
18
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
19
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
20
|
+
t[p[i]] = s[p[i]];
|
|
21
|
+
}
|
|
22
|
+
return t;
|
|
23
|
+
};
|
|
24
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
25
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
26
|
+
};
|
|
27
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
28
|
+
exports.RecommendationBundle = void 0;
|
|
29
|
+
/** @jsx jsx */
|
|
30
|
+
var preact_1 = require("preact");
|
|
31
|
+
var react_1 = require("@emotion/react");
|
|
32
|
+
var classnames_1 = __importDefault(require("classnames"));
|
|
33
|
+
var hooks_1 = require("preact/hooks");
|
|
34
|
+
var mobx_react_1 = require("mobx-react");
|
|
35
|
+
var deepmerge_1 = __importDefault(require("deepmerge"));
|
|
36
|
+
var Carousel_1 = require("../../Molecules/Carousel");
|
|
37
|
+
var Result_1 = require("../../Molecules/Result");
|
|
38
|
+
var utilities_1 = require("../../../utilities");
|
|
39
|
+
var providers_1 = require("../../../providers");
|
|
40
|
+
var useDisplaySettings_1 = require("../../../hooks/useDisplaySettings");
|
|
41
|
+
var ProfileTracker_1 = require("../../Trackers/Recommendation/ProfileTracker");
|
|
42
|
+
var ResultTracker_1 = require("../../Trackers/Recommendation/ResultTracker");
|
|
43
|
+
var BundleSelector_1 = require("./BundleSelector");
|
|
44
|
+
var BundleCTA_1 = require("./BundleCTA");
|
|
45
|
+
var react_2 = require("react");
|
|
46
|
+
var CSS = {
|
|
47
|
+
recommendationBundle: function (_a) {
|
|
48
|
+
var slidesPerView = _a.slidesPerView, spaceBetween = _a.spaceBetween, ctaInline = _a.ctaInline, vertical = _a.vertical, separatorIcon = _a.separatorIcon;
|
|
49
|
+
return (0, react_1.css)({
|
|
50
|
+
'.ss__recommendation-bundle__wrapper': {
|
|
51
|
+
display: 'flex',
|
|
52
|
+
maxWidth: '100%',
|
|
53
|
+
margin: '0',
|
|
54
|
+
padding: '0',
|
|
55
|
+
},
|
|
56
|
+
'.ss__recommendation-bundle__wrapper__selector--seed': {
|
|
57
|
+
width: "".concat(vertical ? '100%' : 'auto'),
|
|
58
|
+
margin: "".concat(!separatorIcon ? 'auto !important' : 'initial'),
|
|
59
|
+
},
|
|
60
|
+
'.ss__recommendation-bundle__wrapper__seed-container': {
|
|
61
|
+
width: vertical ? '100%' : "calc(100% / ".concat(slidesPerView + (!ctaInline ? 0 : 1), ")"),
|
|
62
|
+
},
|
|
63
|
+
'.ss__recommendation-bundle__wrapper__cta': {
|
|
64
|
+
width: vertical ? '100%' : "".concat(!ctaInline ? '100%' : "calc(100% / ".concat(slidesPerView + 1, ")")),
|
|
65
|
+
textAlign: 'center',
|
|
66
|
+
'& .ss__recommendation-bundle__wrapper__cta__subtotal__prices': {
|
|
67
|
+
display: 'block',
|
|
68
|
+
},
|
|
69
|
+
},
|
|
70
|
+
'.ss__recommendation-bundle__wrapper__carousel': {
|
|
71
|
+
boxSizing: 'border-box',
|
|
72
|
+
width: vertical ? '100%' : "calc(calc(100% / ".concat(slidesPerView + (!ctaInline ? 0 : 1), ") * ").concat(slidesPerView - 1, ")"),
|
|
73
|
+
},
|
|
74
|
+
'.ss__recommendation-bundle__wrapper--seed-in-carousel': {
|
|
75
|
+
'.ss__recommendation-bundle__wrapper__cta': {
|
|
76
|
+
width: vertical ? '100%' : "calc(100% / ".concat(slidesPerView + (!ctaInline ? 0 : 1), ")"),
|
|
77
|
+
},
|
|
78
|
+
'.ss__recommendation-bundle__wrapper__carousel': {
|
|
79
|
+
width: vertical ? '100%' : "calc(calc(100% / ".concat(slidesPerView + (!ctaInline ? 0 : 1), ") * ").concat(slidesPerView, ")"),
|
|
80
|
+
padding: '0',
|
|
81
|
+
},
|
|
82
|
+
},
|
|
83
|
+
'.swiper-slide, .swiper-slide-visible.swiper-last-visible-slide': {
|
|
84
|
+
'.ss__recommendation-bundle__wrapper__selector__icon': {
|
|
85
|
+
display: 'none',
|
|
86
|
+
},
|
|
87
|
+
},
|
|
88
|
+
'.swiper-slide-visible': {
|
|
89
|
+
'.ss__recommendation-bundle__wrapper__selector__icon': {
|
|
90
|
+
display: 'block',
|
|
91
|
+
},
|
|
92
|
+
},
|
|
93
|
+
'.ss__recommendation-bundle__wrapper--vertical': {
|
|
94
|
+
flexDirection: 'column',
|
|
95
|
+
},
|
|
96
|
+
'.ss__recommendation-bundle__wrapper__selector': {
|
|
97
|
+
alignItems: 'baseline',
|
|
98
|
+
position: 'relative',
|
|
99
|
+
'&.ss__recommendation-bundle__wrapper__selector--last': {
|
|
100
|
+
'& .ss__recommendation-bundle__wrapper__selector__icon': {
|
|
101
|
+
display: 'none',
|
|
102
|
+
},
|
|
103
|
+
},
|
|
104
|
+
'& .ss__recommendation-bundle__wrapper__selector__result-wrapper__seed-badge': {
|
|
105
|
+
position: 'absolute',
|
|
106
|
+
top: '0',
|
|
107
|
+
left: '0',
|
|
108
|
+
zIndex: '1',
|
|
109
|
+
},
|
|
110
|
+
'& .ss__recommendation-bundle__wrapper__selector__icon': {
|
|
111
|
+
position: 'absolute',
|
|
112
|
+
right: '-1em',
|
|
113
|
+
top: '140px',
|
|
114
|
+
},
|
|
115
|
+
'& .ss__recommendation-bundle__wrapper__selector__result-wrapper': {
|
|
116
|
+
alignItems: 'center',
|
|
117
|
+
position: 'relative',
|
|
118
|
+
margin: "0px ".concat(5 + (spaceBetween || 0), "px"),
|
|
119
|
+
},
|
|
120
|
+
'& .ss__recommendation-bundle__wrapper__selector__result-wrapper__checkbox': {
|
|
121
|
+
position: 'absolute',
|
|
122
|
+
top: '0',
|
|
123
|
+
right: '0',
|
|
124
|
+
zIndex: '1',
|
|
125
|
+
cursor: 'pointer',
|
|
126
|
+
},
|
|
127
|
+
},
|
|
128
|
+
});
|
|
129
|
+
},
|
|
130
|
+
};
|
|
131
|
+
exports.RecommendationBundle = (0, mobx_react_1.observer)(function (properties) {
|
|
132
|
+
var _a, _b, _c, _d, _e, _f, _g, _h;
|
|
133
|
+
var globalTheme = (0, providers_1.useTheme)();
|
|
134
|
+
var defaultCarouselBreakpoints = {
|
|
135
|
+
0: {
|
|
136
|
+
slidesPerView: 2,
|
|
137
|
+
slidesPerGroup: 2,
|
|
138
|
+
spaceBetween: 10,
|
|
139
|
+
ctaInline: false,
|
|
140
|
+
},
|
|
141
|
+
768: {
|
|
142
|
+
slidesPerView: 3,
|
|
143
|
+
slidesPerGroup: 3,
|
|
144
|
+
spaceBetween: 10,
|
|
145
|
+
},
|
|
146
|
+
1200: {
|
|
147
|
+
slidesPerView: 4,
|
|
148
|
+
slidesPerGroup: 4,
|
|
149
|
+
spaceBetween: 10,
|
|
150
|
+
},
|
|
151
|
+
};
|
|
152
|
+
var props = __assign(__assign(__assign({
|
|
153
|
+
// default props
|
|
154
|
+
breakpoints: JSON.parse(JSON.stringify(defaultCarouselBreakpoints)), hideCheckboxes: false, separatorIcon: 'plus-thin', seedText: 'This Product', separatorIconSeedOnly: true, ctaIcon: true, ctaButtonText: 'Add All To Cart', ctaInline: true }, (_a = globalTheme === null || globalTheme === void 0 ? void 0 : globalTheme.components) === null || _a === void 0 ? void 0 : _a.recommendationBundle), properties), (_c = (_b = properties.theme) === null || _b === void 0 ? void 0 : _b.components) === null || _c === void 0 ? void 0 : _c.recommendationBundle);
|
|
155
|
+
var displaySettings = (0, useDisplaySettings_1.useDisplaySettings)(props.breakpoints);
|
|
156
|
+
if (displaySettings && Object.keys(displaySettings).length) {
|
|
157
|
+
var theme = (0, deepmerge_1.default)((props === null || props === void 0 ? void 0 : props.theme) || {}, (displaySettings === null || displaySettings === void 0 ? void 0 : displaySettings.theme) || {}, { arrayMerge: function (destinationArray, sourceArray) { return sourceArray; } });
|
|
158
|
+
props = __assign(__assign(__assign({}, props), displaySettings), { theme: theme });
|
|
159
|
+
}
|
|
160
|
+
var title = props.title, controller = props.controller, breakpoints = props.breakpoints, results = props.results, carousel = props.carousel, preselectedCount = props.preselectedCount, separatorIcon = props.separatorIcon, hideCheckboxes = props.hideCheckboxes, limit = props.limit, seedText = props.seedText, vertical = props.vertical, onAddToCart = props.onAddToCart, separatorIconSeedOnly = props.separatorIconSeedOnly, resultComponent = props.resultComponent, ctaSlot = props.ctaSlot, ctaButtonText = props.ctaButtonText, disableStyles = props.disableStyles, ctaIcon = props.ctaIcon, ctaInline = props.ctaInline, style = props.style, className = props.className, additionalProps = __rest(props, ["title", "controller", "breakpoints", "results", "carousel", "preselectedCount", "separatorIcon", "hideCheckboxes", "limit", "seedText", "vertical", "onAddToCart", "separatorIconSeedOnly", "resultComponent", "ctaSlot", "ctaButtonText", "disableStyles", "ctaIcon", "ctaInline", "style", "className"]);
|
|
161
|
+
var mergedCarouselProps = __assign({ enabled: true, loop: false, spaceBetween: 10 }, carousel);
|
|
162
|
+
var seedInCarousel = mergedCarouselProps.seedInCarousel, prevButton = mergedCarouselProps.prevButton, nextButton = mergedCarouselProps.nextButton, hideButtons = mergedCarouselProps.hideButtons, loop = mergedCarouselProps.loop, spaceBetween = mergedCarouselProps.spaceBetween, pagination = mergedCarouselProps.pagination;
|
|
163
|
+
var carouselEnabled = mergedCarouselProps.enabled;
|
|
164
|
+
if (!controller || controller.type !== 'recommendation') {
|
|
165
|
+
throw new Error("<BundleRecommendation> Component requires 'controller' prop with an instance of RecommendationController");
|
|
166
|
+
}
|
|
167
|
+
var resultsToRender = results || ((_d = controller.store) === null || _d === void 0 ? void 0 : _d.results);
|
|
168
|
+
if (limit) {
|
|
169
|
+
resultsToRender = resultsToRender.slice(0, limit);
|
|
170
|
+
}
|
|
171
|
+
var cartStore = controller.store.cart;
|
|
172
|
+
if (!cartStore) {
|
|
173
|
+
throw new Error("<BundleRecommendation> Component requires 'cartStore' to exist in the recommendation store");
|
|
174
|
+
}
|
|
175
|
+
var seed = results ? results[0] : (_e = controller.store) === null || _e === void 0 ? void 0 : _e.results[0];
|
|
176
|
+
var subProps = {
|
|
177
|
+
carousel: __assign(__assign(__assign({ loop: loop,
|
|
178
|
+
// default props
|
|
179
|
+
className: 'ss__recommendation__carousel' }, (_f = globalTheme === null || globalTheme === void 0 ? void 0 : globalTheme.components) === null || _f === void 0 ? void 0 : _f.carousel), (0, utilities_1.defined)({
|
|
180
|
+
disableStyles: disableStyles,
|
|
181
|
+
})), {
|
|
182
|
+
// component theme overrides
|
|
183
|
+
theme: props === null || props === void 0 ? void 0 : props.theme }),
|
|
184
|
+
result: __assign(__assign(__assign({
|
|
185
|
+
// default props
|
|
186
|
+
className: 'ss__recommendation__result' }, (_g = globalTheme === null || globalTheme === void 0 ? void 0 : globalTheme.components) === null || _g === void 0 ? void 0 : _g.result), (0, utilities_1.defined)({
|
|
187
|
+
disableStyles: disableStyles,
|
|
188
|
+
})), {
|
|
189
|
+
// component theme overrides
|
|
190
|
+
theme: props === null || props === void 0 ? void 0 : props.theme }),
|
|
191
|
+
};
|
|
192
|
+
var slidesPerView = ((_h = props.carousel) === null || _h === void 0 ? void 0 : _h.slidesPerView) || props.slidesPerView;
|
|
193
|
+
if (!slidesPerView) {
|
|
194
|
+
slidesPerView = 2;
|
|
195
|
+
}
|
|
196
|
+
else if (resultsToRender.length < slidesPerView) {
|
|
197
|
+
slidesPerView = resultsToRender.length;
|
|
198
|
+
}
|
|
199
|
+
var styling = {};
|
|
200
|
+
if (!disableStyles) {
|
|
201
|
+
styling.css = [CSS.recommendationBundle({ slidesPerView: slidesPerView, spaceBetween: spaceBetween, ctaInline: ctaInline, vertical: vertical, separatorIcon: separatorIcon }), style];
|
|
202
|
+
}
|
|
203
|
+
else if (style) {
|
|
204
|
+
styling.css = [style];
|
|
205
|
+
}
|
|
206
|
+
var _preSelectedCount = typeof preselectedCount == 'number' ? preselectedCount : carouselEnabled ? slidesPerView : resultsToRender.length;
|
|
207
|
+
//this resets the selected items if the results to render changes
|
|
208
|
+
// so you dont end up with something selected that is no longer rendered
|
|
209
|
+
(0, react_2.useEffect)(function () {
|
|
210
|
+
cartStore.reset();
|
|
211
|
+
if (_preSelectedCount) {
|
|
212
|
+
resultsToRender === null || resultsToRender === void 0 ? void 0 : resultsToRender.forEach(function (result, idx) {
|
|
213
|
+
if (idx < _preSelectedCount) {
|
|
214
|
+
cartStore.addItems([result]);
|
|
215
|
+
}
|
|
216
|
+
});
|
|
217
|
+
}
|
|
218
|
+
}, [resultsToRender.length]);
|
|
219
|
+
var selectedItems = cartStore.items;
|
|
220
|
+
var modifiedBreakpoints = __assign({}, breakpoints);
|
|
221
|
+
if (carouselEnabled) {
|
|
222
|
+
Object.keys(props.breakpoints).forEach(function (breakpoint) {
|
|
223
|
+
var _a, _b;
|
|
224
|
+
var obj = props.breakpoints[breakpoint];
|
|
225
|
+
// fallback in case slides per view/group were not provided in breakpoint...
|
|
226
|
+
var objSlidesPerView = ((_a = obj.carousel) === null || _a === void 0 ? void 0 : _a.slidesPerView) || obj.slidesPerView || 2;
|
|
227
|
+
var objSlidesPerGroup = ((_b = obj.carousel) === null || _b === void 0 ? void 0 : _b.slidesPerGroup) || obj.slidesPerGroup || 2;
|
|
228
|
+
var newSlidesPerView = objSlidesPerView;
|
|
229
|
+
var newSlidesPerGroup = objSlidesPerGroup;
|
|
230
|
+
var resultCount = seedInCarousel ? resultsToRender.length : resultsToRender.length - 1;
|
|
231
|
+
if (resultCount) {
|
|
232
|
+
if (resultCount >= objSlidesPerView) {
|
|
233
|
+
newSlidesPerView = objSlidesPerView - (!seedInCarousel ? 1 : 0);
|
|
234
|
+
if (!seedInCarousel) {
|
|
235
|
+
newSlidesPerGroup = objSlidesPerGroup - 1 || 1;
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
else {
|
|
239
|
+
(newSlidesPerView = resultCount), (newSlidesPerGroup = resultCount);
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
modifiedBreakpoints[breakpoint] = __assign(__assign({}, modifiedBreakpoints[breakpoint]), { slidesPerView: newSlidesPerView, slidesPerGroup: newSlidesPerGroup });
|
|
243
|
+
});
|
|
244
|
+
}
|
|
245
|
+
var onProductSelect = function (product) {
|
|
246
|
+
if (product) {
|
|
247
|
+
var idx = selectedItems.findIndex(function (result) { return result.id == product.id; });
|
|
248
|
+
//is it in the selected items?
|
|
249
|
+
if (idx > -1) {
|
|
250
|
+
//already selected, deselect it now
|
|
251
|
+
cartStore.removeItems([product]);
|
|
252
|
+
if (cartStore.items.length == 0) {
|
|
253
|
+
//we dont call addItems here to prevent tracking
|
|
254
|
+
cartStore.items.push(seed);
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
else {
|
|
258
|
+
//add it to the list;
|
|
259
|
+
cartStore.addItems([product]);
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
};
|
|
263
|
+
var addToCart = function (e) {
|
|
264
|
+
// add to cart tracking
|
|
265
|
+
controller.track.addBundle(e, selectedItems);
|
|
266
|
+
//call the function passed
|
|
267
|
+
onAddToCart && onAddToCart(selectedItems);
|
|
268
|
+
};
|
|
269
|
+
var setSeedwidth = function () {
|
|
270
|
+
var _a, _b;
|
|
271
|
+
if (seedRef.current) {
|
|
272
|
+
// @ts-ignore - todo can this be typed appropriatly?
|
|
273
|
+
var seedElem = (_a = seedRef.current) === null || _a === void 0 ? void 0 : _a.base;
|
|
274
|
+
// @ts-ignore - todo can this be typed appropriatly?
|
|
275
|
+
var carouselElem = (_b = carouselRef.current) === null || _b === void 0 ? void 0 : _b.base;
|
|
276
|
+
var visibleSlide = carouselElem === null || carouselElem === void 0 ? void 0 : carouselElem.querySelector('.swiper-slide-visible .ss__recommendation-bundle__wrapper__selector');
|
|
277
|
+
var width = visibleSlide === null || visibleSlide === void 0 ? void 0 : visibleSlide.offsetWidth;
|
|
278
|
+
if (seedElem) {
|
|
279
|
+
seedElem.style.width = "".concat(width, "px");
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
};
|
|
283
|
+
var seedRef = (0, hooks_1.useRef)();
|
|
284
|
+
var carouselRef = (0, hooks_1.useRef)();
|
|
285
|
+
return (resultsToRender === null || resultsToRender === void 0 ? void 0 : resultsToRender.length) ? ((0, react_1.jsx)(providers_1.CacheProvider, null,
|
|
286
|
+
(0, react_1.jsx)("div", __assign({}, styling, { className: (0, classnames_1.default)('ss__recommendation-bundle', { 'ss__recommendation-bundle--stacked': !ctaInline }, className) }),
|
|
287
|
+
(0, react_1.jsx)(ProfileTracker_1.RecommendationProfileTracker, { controller: controller },
|
|
288
|
+
title && ((0, react_1.jsx)("h3", { className: "ss__recommendation-bundle__title" },
|
|
289
|
+
(0, react_1.jsx)("span", null, title))),
|
|
290
|
+
(0, react_1.jsx)("div", { className: (0, classnames_1.default)('ss__recommendation-bundle__wrapper', {
|
|
291
|
+
'ss__recommendation-bundle__wrapper--seed-in-carousel': seedInCarousel,
|
|
292
|
+
'ss__recommendation-bundle__wrapper--vertical': vertical,
|
|
293
|
+
}) },
|
|
294
|
+
carouselEnabled ? ((0, react_1.jsx)(preact_1.Fragment, null,
|
|
295
|
+
!seedInCarousel && ((0, react_1.jsx)("div", { className: "ss__recommendation-bundle__wrapper__seed-container" },
|
|
296
|
+
(0, react_1.jsx)(ResultTracker_1.RecommendationResultTracker, { controller: controller, result: seed },
|
|
297
|
+
(0, react_1.jsx)(BundleSelector_1.BundleSelector, { seedText: seedText, seed: true, onCheck: function () { return onProductSelect(seed); }, checked: selectedItems.findIndex(function (item) { return item.id == seed.id; }) > -1, icon: separatorIcon, hideCheckboxes: hideCheckboxes, theme: props.theme, ref: seedRef }, resultComponent ? ((0, utilities_1.cloneWithProps)(resultComponent, {
|
|
298
|
+
result: seed,
|
|
299
|
+
seed: true,
|
|
300
|
+
selected: selectedItems.findIndex(function (item) { return item.id == seed.id; }) > -1,
|
|
301
|
+
onProductSelect: onProductSelect,
|
|
302
|
+
})) : ((0, react_1.jsx)(Result_1.Result, __assign({}, subProps.result, { controller: controller, result: seed }))))))),
|
|
303
|
+
(0, react_1.jsx)("div", { className: "ss__recommendation-bundle__wrapper__carousel" },
|
|
304
|
+
(0, react_1.jsx)(Carousel_1.Carousel, __assign({ prevButton: prevButton, nextButton: nextButton, hideButtons: hideButtons, loop: loop, spaceBetween: spaceBetween, pagination: pagination, breakpoints: modifiedBreakpoints, watchSlidesProgress: true, observer: true, vertical: vertical, onResize: function () { return setSeedwidth(); } }, subProps.carousel, additionalProps, displaySettings, { ref: carouselRef }), seedInCarousel
|
|
305
|
+
? resultsToRender.map(function (result, idx) {
|
|
306
|
+
var selected = selectedItems.findIndex(function (item) { return item.id == result.id; }) > -1;
|
|
307
|
+
if (idx == 0) {
|
|
308
|
+
return ((0, react_1.jsx)(ResultTracker_1.RecommendationResultTracker, { controller: controller, result: result },
|
|
309
|
+
(0, react_1.jsx)(BundleSelector_1.BundleSelector, { seedText: seedText, seed: true, icon: separatorIcon, onCheck: function () { return onProductSelect(result); }, checked: selected, hideCheckboxes: hideCheckboxes, theme: props.theme }, resultComponent ? ((0, utilities_1.cloneWithProps)(resultComponent, { result: result, seed: true, selected: selected, onProductSelect: onProductSelect })) : ((0, react_1.jsx)(Result_1.Result, __assign({}, subProps.result, { controller: controller, result: result }))))));
|
|
310
|
+
}
|
|
311
|
+
else {
|
|
312
|
+
return ((0, react_1.jsx)(ResultTracker_1.RecommendationResultTracker, { controller: controller, result: result },
|
|
313
|
+
(0, react_1.jsx)(BundleSelector_1.BundleSelector, { icon: separatorIconSeedOnly ? false : separatorIcon, onCheck: function () { return onProductSelect(result); }, checked: selected, hideCheckboxes: hideCheckboxes, theme: props.theme, className: idx + 1 == resultsToRender.length ? 'ss__recommendation-bundle__wrapper__selector--last' : '' }, resultComponent ? ((0, utilities_1.cloneWithProps)(resultComponent, { result: result, seed: false, selected: selected, onProductSelect: onProductSelect })) : ((0, react_1.jsx)(Result_1.Result, __assign({}, subProps.result, { controller: controller, result: result }))))));
|
|
314
|
+
}
|
|
315
|
+
})
|
|
316
|
+
: resultsToRender
|
|
317
|
+
.filter(function (result, idx) { return idx !== 0; })
|
|
318
|
+
.map(function (result, idx, results) {
|
|
319
|
+
var selected = selectedItems.findIndex(function (item) { return item.id == result.id; }) > -1;
|
|
320
|
+
return ((0, react_1.jsx)(ResultTracker_1.RecommendationResultTracker, { controller: controller, result: result },
|
|
321
|
+
(0, react_1.jsx)(BundleSelector_1.BundleSelector, { icon: separatorIconSeedOnly ? false : separatorIcon, onCheck: function () { return onProductSelect(result); }, checked: selected, hideCheckboxes: hideCheckboxes, theme: props.theme, className: idx + 1 == results.length ? 'ss__recommendation-bundle__wrapper__selector--last' : '' }, resultComponent ? ((0, utilities_1.cloneWithProps)(resultComponent, { result: result, seed: false, selected: selected, onProductSelect: onProductSelect })) : ((0, react_1.jsx)(Result_1.Result, __assign({}, subProps.result, { controller: controller, result: result }))))));
|
|
322
|
+
}))))) : (resultsToRender.map(function (result, idx) {
|
|
323
|
+
var selected = selectedItems.findIndex(function (item) { return item.id == result.id; }) > -1;
|
|
324
|
+
if (idx == 0) {
|
|
325
|
+
return ((0, react_1.jsx)(ResultTracker_1.RecommendationResultTracker, { controller: controller, result: result },
|
|
326
|
+
(0, react_1.jsx)(BundleSelector_1.BundleSelector, { seedText: seedText, seed: true, icon: separatorIcon, onCheck: function () { return onProductSelect(result); }, checked: selected, hideCheckboxes: hideCheckboxes, theme: props.theme }, resultComponent ? ((0, utilities_1.cloneWithProps)(resultComponent, { result: result, seed: true, selected: selected, onProductSelect: onProductSelect })) : ((0, react_1.jsx)(Result_1.Result, __assign({}, subProps.result, { controller: controller, result: result }))))));
|
|
327
|
+
}
|
|
328
|
+
else {
|
|
329
|
+
return ((0, react_1.jsx)(ResultTracker_1.RecommendationResultTracker, { controller: controller, result: result },
|
|
330
|
+
(0, react_1.jsx)(BundleSelector_1.BundleSelector, { icon: separatorIconSeedOnly ? false : separatorIcon, onCheck: function () { return onProductSelect(result); }, checked: selected, hideCheckboxes: hideCheckboxes, theme: props.theme, className: idx + 1 == resultsToRender.length ? 'ss__recommendation-bundle__wrapper__selector--last' : '' }, resultComponent ? ((0, utilities_1.cloneWithProps)(resultComponent, { result: result, seed: false, selected: selected, onProductSelect: onProductSelect })) : ((0, react_1.jsx)(Result_1.Result, __assign({}, subProps.result, { controller: controller, result: result }))))));
|
|
331
|
+
}
|
|
332
|
+
})),
|
|
333
|
+
ctaInline && ((0, react_1.jsx)(BundleCTA_1.BundledCTA, { ctaSlot: ctaSlot, cartStore: cartStore, onAddToCartClick: function (e) { return addToCart(e); }, addToCartText: ctaButtonText, icon: ctaIcon }))),
|
|
334
|
+
!ctaInline && ((0, react_1.jsx)(BundleCTA_1.BundledCTA, { ctaSlot: ctaSlot, cartStore: cartStore, onAddToCartClick: function (e) { return addToCart(e); }, addToCartText: ctaButtonText, icon: ctaIcon })))))) : ((0, react_1.jsx)(preact_1.Fragment, null));
|
|
335
|
+
return (0, react_1.jsx)(preact_1.Fragment, null);
|
|
336
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/Organisms/RecommendationBundle/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./RecommendationBundle"), exports);
|
|
@@ -2,9 +2,7 @@
|
|
|
2
2
|
import type { SearchController, AutocompleteController, RecommendationController } from '@searchspring/snap-controller';
|
|
3
3
|
import type { SearchResultStore } from '@searchspring/snap-store-mobx';
|
|
4
4
|
import { ComponentProps, LayoutType, BreakpointsProps } from '../../../types';
|
|
5
|
-
export declare const Results: (
|
|
6
|
-
displayName: string;
|
|
7
|
-
};
|
|
5
|
+
export declare const Results: (properties: ResultsProp) => JSX.Element;
|
|
8
6
|
export interface ResultsProp extends ComponentProps {
|
|
9
7
|
results?: SearchResultStore;
|
|
10
8
|
columns?: number;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Results.d.ts","sourceRoot":"","sources":["../../../../../src/components/Organisms/Results/Results.tsx"],"names":[],"mappings":";AAQA,OAAO,KAAK,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AACxH,OAAO,KAAK,EAAE,iBAAiB,EAAmB,MAAM,+BAA+B,CAAC;AAIxF,OAAO,EAAE,cAAc,EAAU,UAAU,EAAE,gBAAgB,EAAc,MAAM,gBAAgB,CAAC;AAuClG,eAAO,MAAM,OAAO,
|
|
1
|
+
{"version":3,"file":"Results.d.ts","sourceRoot":"","sources":["../../../../../src/components/Organisms/Results/Results.tsx"],"names":[],"mappings":";AAQA,OAAO,KAAK,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AACxH,OAAO,KAAK,EAAE,iBAAiB,EAAmB,MAAM,+BAA+B,CAAC;AAIxF,OAAO,EAAE,cAAc,EAAU,UAAU,EAAE,gBAAgB,EAAc,MAAM,gBAAgB,CAAC;AAuClG,eAAO,MAAM,OAAO,eAAyB,WAAW,KAAG,WA4GzD,CAAC;AAEH,MAAM,WAAW,WAAY,SAAQ,cAAc;IAClD,OAAO,CAAC,EAAE,iBAAiB,CAAC;IAC5B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,UAAU,CAAC;IACpB,WAAW,CAAC,EAAE,gBAAgB,CAAC;IAC/B,UAAU,CAAC,EAAE,gBAAgB,GAAG,sBAAsB,GAAG,wBAAwB,CAAC;CAClF"}
|