@searchspring/snap-preact-components 0.51.2 → 0.52.1
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 +19 -0
- package/dist/cjs/components/Organisms/RecommendationBundle/BundleCTA.d.ts.map +1 -0
- package/dist/cjs/components/Organisms/RecommendationBundle/BundleCTA.js +62 -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 +35 -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 +19 -0
- package/dist/esm/components/Organisms/RecommendationBundle/BundleCTA.d.ts.map +1 -0
- package/dist/esm/components/Organisms/RecommendationBundle/BundleCTA.js +53 -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 +35 -0
- package/dist/esm/components/Organisms/RecommendationBundle/RecommendationBundle.d.ts.map +1 -0
- package/dist/esm/components/Organisms/RecommendationBundle/RecommendationBundle.js +341 -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 +34 -18
|
@@ -0,0 +1,341 @@
|
|
|
1
|
+
/** @jsx jsx */
|
|
2
|
+
import { Fragment } from 'preact';
|
|
3
|
+
import { jsx, css } from '@emotion/react';
|
|
4
|
+
import classnames from 'classnames';
|
|
5
|
+
import { useRef } from 'preact/hooks';
|
|
6
|
+
import { observer } from 'mobx-react';
|
|
7
|
+
import deepmerge from 'deepmerge';
|
|
8
|
+
import { Carousel } from '../../Molecules/Carousel';
|
|
9
|
+
import { Result } from '../../Molecules/Result';
|
|
10
|
+
import { cloneWithProps, defined } from '../../../utilities';
|
|
11
|
+
import { useTheme, CacheProvider } from '../../../providers';
|
|
12
|
+
import { useDisplaySettings } from '../../../hooks/useDisplaySettings';
|
|
13
|
+
import { RecommendationProfileTracker } from '../../Trackers/Recommendation/ProfileTracker';
|
|
14
|
+
import { RecommendationResultTracker } from '../../Trackers/Recommendation/ResultTracker';
|
|
15
|
+
import { BundleSelector } from './BundleSelector';
|
|
16
|
+
import { BundledCTA } from './BundleCTA';
|
|
17
|
+
import { useEffect } from 'react';
|
|
18
|
+
const CSS = {
|
|
19
|
+
recommendationBundle: ({ slidesPerView, spaceBetween, ctaInline, vertical, separatorIcon }) => css({
|
|
20
|
+
'.ss__recommendation-bundle__wrapper': {
|
|
21
|
+
display: 'flex',
|
|
22
|
+
maxWidth: '100%',
|
|
23
|
+
margin: '0',
|
|
24
|
+
padding: '0',
|
|
25
|
+
},
|
|
26
|
+
'.ss__recommendation-bundle__wrapper__selector--seed': {
|
|
27
|
+
width: `${vertical ? '100%' : 'auto'}`,
|
|
28
|
+
margin: `${!separatorIcon ? 'auto !important' : 'initial'}`,
|
|
29
|
+
},
|
|
30
|
+
'.ss__recommendation-bundle__wrapper__seed-container': {
|
|
31
|
+
width: vertical ? '100%' : `calc(100% / ${slidesPerView + (!ctaInline ? 0 : 1)})`,
|
|
32
|
+
},
|
|
33
|
+
'.ss__recommendation-bundle__wrapper__cta': {
|
|
34
|
+
width: vertical ? '100%' : `${!ctaInline ? '100%' : `calc(100% / ${slidesPerView + 1})`}`,
|
|
35
|
+
textAlign: 'center',
|
|
36
|
+
'& .ss__recommendation-bundle__wrapper__cta__subtotal__prices': {
|
|
37
|
+
display: 'block',
|
|
38
|
+
},
|
|
39
|
+
},
|
|
40
|
+
'.ss__recommendation-bundle__wrapper__carousel': {
|
|
41
|
+
boxSizing: 'border-box',
|
|
42
|
+
width: vertical ? '100%' : `calc(calc(100% / ${slidesPerView + (!ctaInline ? 0 : 1)}) * ${slidesPerView - 1})`,
|
|
43
|
+
},
|
|
44
|
+
'.ss__recommendation-bundle__wrapper--seed-in-carousel': {
|
|
45
|
+
'.ss__recommendation-bundle__wrapper__cta': {
|
|
46
|
+
width: vertical ? '100%' : `calc(100% / ${slidesPerView + (!ctaInline ? 0 : 1)})`,
|
|
47
|
+
},
|
|
48
|
+
'.ss__recommendation-bundle__wrapper__carousel': {
|
|
49
|
+
width: vertical ? '100%' : `calc(calc(100% / ${slidesPerView + (!ctaInline ? 0 : 1)}) * ${slidesPerView})`,
|
|
50
|
+
padding: '0',
|
|
51
|
+
},
|
|
52
|
+
},
|
|
53
|
+
'.swiper-slide, .swiper-slide-visible.swiper-last-visible-slide': {
|
|
54
|
+
'.ss__recommendation-bundle__wrapper__selector__icon': {
|
|
55
|
+
display: 'none',
|
|
56
|
+
},
|
|
57
|
+
},
|
|
58
|
+
'.swiper-slide-visible': {
|
|
59
|
+
'.ss__recommendation-bundle__wrapper__selector__icon': {
|
|
60
|
+
display: 'block',
|
|
61
|
+
},
|
|
62
|
+
},
|
|
63
|
+
'.ss__recommendation-bundle__wrapper--vertical': {
|
|
64
|
+
flexDirection: 'column',
|
|
65
|
+
},
|
|
66
|
+
'.ss__recommendation-bundle__wrapper__selector': {
|
|
67
|
+
alignItems: 'baseline',
|
|
68
|
+
position: 'relative',
|
|
69
|
+
'&.ss__recommendation-bundle__wrapper__selector--last': {
|
|
70
|
+
'& .ss__recommendation-bundle__wrapper__selector__icon': {
|
|
71
|
+
display: 'none',
|
|
72
|
+
},
|
|
73
|
+
},
|
|
74
|
+
'& .ss__recommendation-bundle__wrapper__selector__result-wrapper__seed-badge': {
|
|
75
|
+
position: 'absolute',
|
|
76
|
+
top: '0',
|
|
77
|
+
left: '0',
|
|
78
|
+
zIndex: '1',
|
|
79
|
+
},
|
|
80
|
+
'& .ss__recommendation-bundle__wrapper__selector__icon': {
|
|
81
|
+
position: 'absolute',
|
|
82
|
+
right: '-1em',
|
|
83
|
+
top: '140px',
|
|
84
|
+
},
|
|
85
|
+
'& .ss__recommendation-bundle__wrapper__selector__result-wrapper': {
|
|
86
|
+
alignItems: 'center',
|
|
87
|
+
position: 'relative',
|
|
88
|
+
margin: `0px ${5 + (spaceBetween || 0)}px`,
|
|
89
|
+
},
|
|
90
|
+
'& .ss__recommendation-bundle__wrapper__selector__result-wrapper__checkbox': {
|
|
91
|
+
position: 'absolute',
|
|
92
|
+
top: '0',
|
|
93
|
+
right: '0',
|
|
94
|
+
zIndex: '1',
|
|
95
|
+
cursor: 'pointer',
|
|
96
|
+
},
|
|
97
|
+
},
|
|
98
|
+
}),
|
|
99
|
+
};
|
|
100
|
+
export const RecommendationBundle = observer((properties) => {
|
|
101
|
+
const globalTheme = useTheme();
|
|
102
|
+
const defaultCarouselBreakpoints = {
|
|
103
|
+
0: {
|
|
104
|
+
slidesPerView: 2,
|
|
105
|
+
slidesPerGroup: 2,
|
|
106
|
+
spaceBetween: 10,
|
|
107
|
+
ctaInline: false,
|
|
108
|
+
},
|
|
109
|
+
768: {
|
|
110
|
+
slidesPerView: 3,
|
|
111
|
+
slidesPerGroup: 3,
|
|
112
|
+
spaceBetween: 10,
|
|
113
|
+
},
|
|
114
|
+
1200: {
|
|
115
|
+
slidesPerView: 4,
|
|
116
|
+
slidesPerGroup: 4,
|
|
117
|
+
spaceBetween: 10,
|
|
118
|
+
},
|
|
119
|
+
};
|
|
120
|
+
let props = {
|
|
121
|
+
// default props
|
|
122
|
+
breakpoints: JSON.parse(JSON.stringify(defaultCarouselBreakpoints)),
|
|
123
|
+
hideCheckboxes: false,
|
|
124
|
+
separatorIcon: 'plus-thin',
|
|
125
|
+
seedText: 'This Product',
|
|
126
|
+
separatorIconSeedOnly: true,
|
|
127
|
+
ctaIcon: true,
|
|
128
|
+
ctaButtonText: 'Add All To Cart',
|
|
129
|
+
ctaButtonSuccessText: 'Bundle Added!',
|
|
130
|
+
ctaButtonSuccessTimeout: 2000,
|
|
131
|
+
ctaInline: true,
|
|
132
|
+
// global theme
|
|
133
|
+
...globalTheme?.components?.recommendationBundle,
|
|
134
|
+
...properties,
|
|
135
|
+
// props
|
|
136
|
+
...properties.theme?.components?.recommendationBundle,
|
|
137
|
+
};
|
|
138
|
+
const displaySettings = useDisplaySettings(props.breakpoints);
|
|
139
|
+
if (displaySettings && Object.keys(displaySettings).length) {
|
|
140
|
+
const theme = deepmerge(props?.theme || {}, displaySettings?.theme || {}, { arrayMerge: (destinationArray, sourceArray) => sourceArray });
|
|
141
|
+
props = {
|
|
142
|
+
...props,
|
|
143
|
+
...displaySettings,
|
|
144
|
+
theme,
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
const { title, controller, breakpoints, results, carousel, preselectedCount, separatorIcon, hideCheckboxes, limit, seedText, vertical, onAddToCart, separatorIconSeedOnly, resultComponent, ctaSlot, ctaButtonText, ctaButtonSuccessText, ctaButtonSuccessTimeout, disableStyles, ctaIcon, ctaInline, style, className, ...additionalProps } = props;
|
|
148
|
+
const mergedCarouselProps = {
|
|
149
|
+
enabled: true,
|
|
150
|
+
loop: false,
|
|
151
|
+
spaceBetween: 10,
|
|
152
|
+
...carousel,
|
|
153
|
+
};
|
|
154
|
+
const { seedInCarousel, prevButton, nextButton, hideButtons, loop, spaceBetween, pagination } = mergedCarouselProps;
|
|
155
|
+
const carouselEnabled = mergedCarouselProps.enabled;
|
|
156
|
+
if (!controller || controller.type !== 'recommendation') {
|
|
157
|
+
throw new Error(`<BundleRecommendation> Component requires 'controller' prop with an instance of RecommendationController`);
|
|
158
|
+
}
|
|
159
|
+
let resultsToRender = results || controller.store?.results;
|
|
160
|
+
if (limit) {
|
|
161
|
+
resultsToRender = resultsToRender.slice(0, limit);
|
|
162
|
+
}
|
|
163
|
+
const cartStore = controller.store.cart;
|
|
164
|
+
if (!cartStore) {
|
|
165
|
+
throw new Error(`<BundleRecommendation> Component requires 'cartStore' to exist in the recommendation store`);
|
|
166
|
+
}
|
|
167
|
+
const seed = results ? results[0] : controller.store?.results[0];
|
|
168
|
+
const subProps = {
|
|
169
|
+
carousel: {
|
|
170
|
+
loop: loop,
|
|
171
|
+
// default props
|
|
172
|
+
className: 'ss__recommendation__carousel',
|
|
173
|
+
// global theme
|
|
174
|
+
...globalTheme?.components?.carousel,
|
|
175
|
+
// inherited props
|
|
176
|
+
...defined({
|
|
177
|
+
disableStyles,
|
|
178
|
+
}),
|
|
179
|
+
// component theme overrides
|
|
180
|
+
theme: props?.theme,
|
|
181
|
+
},
|
|
182
|
+
result: {
|
|
183
|
+
// default props
|
|
184
|
+
className: 'ss__recommendation__result',
|
|
185
|
+
// global theme
|
|
186
|
+
...globalTheme?.components?.result,
|
|
187
|
+
// inherited props
|
|
188
|
+
...defined({
|
|
189
|
+
disableStyles,
|
|
190
|
+
}),
|
|
191
|
+
// component theme overrides
|
|
192
|
+
theme: props?.theme,
|
|
193
|
+
},
|
|
194
|
+
};
|
|
195
|
+
let slidesPerView = props.carousel?.slidesPerView || props.slidesPerView;
|
|
196
|
+
if (!slidesPerView) {
|
|
197
|
+
slidesPerView = 2;
|
|
198
|
+
}
|
|
199
|
+
else if (resultsToRender.length < slidesPerView) {
|
|
200
|
+
slidesPerView = resultsToRender.length;
|
|
201
|
+
}
|
|
202
|
+
const styling = {};
|
|
203
|
+
if (!disableStyles) {
|
|
204
|
+
styling.css = [CSS.recommendationBundle({ slidesPerView, spaceBetween, ctaInline, vertical, separatorIcon }), style];
|
|
205
|
+
}
|
|
206
|
+
else if (style) {
|
|
207
|
+
styling.css = [style];
|
|
208
|
+
}
|
|
209
|
+
const _preSelectedCount = typeof preselectedCount == 'number' ? preselectedCount : carouselEnabled ? slidesPerView : resultsToRender.length;
|
|
210
|
+
//this resets the selected items if the results to render changes
|
|
211
|
+
// so you dont end up with something selected that is no longer rendered
|
|
212
|
+
useEffect(() => {
|
|
213
|
+
cartStore.reset();
|
|
214
|
+
if (_preSelectedCount) {
|
|
215
|
+
resultsToRender?.forEach((result, idx) => {
|
|
216
|
+
if (idx < _preSelectedCount) {
|
|
217
|
+
cartStore.addItems([result]);
|
|
218
|
+
}
|
|
219
|
+
});
|
|
220
|
+
}
|
|
221
|
+
}, [resultsToRender.length]);
|
|
222
|
+
const selectedItems = cartStore.items;
|
|
223
|
+
const modifiedBreakpoints = { ...breakpoints };
|
|
224
|
+
if (carouselEnabled) {
|
|
225
|
+
Object.keys(props.breakpoints).forEach((breakpoint) => {
|
|
226
|
+
const obj = props.breakpoints[breakpoint];
|
|
227
|
+
// fallback in case slides per view/group were not provided in breakpoint...
|
|
228
|
+
const objSlidesPerView = obj.carousel?.slidesPerView || obj.slidesPerView || 2;
|
|
229
|
+
const objSlidesPerGroup = obj.carousel?.slidesPerGroup || obj.slidesPerGroup || 2;
|
|
230
|
+
let newSlidesPerView = objSlidesPerView;
|
|
231
|
+
let newSlidesPerGroup = objSlidesPerGroup;
|
|
232
|
+
const resultCount = seedInCarousel ? resultsToRender.length : resultsToRender.length - 1;
|
|
233
|
+
if (resultCount) {
|
|
234
|
+
if (resultCount >= objSlidesPerView) {
|
|
235
|
+
newSlidesPerView = objSlidesPerView - (!seedInCarousel ? 1 : 0);
|
|
236
|
+
if (!seedInCarousel) {
|
|
237
|
+
newSlidesPerGroup = objSlidesPerGroup - 1 || 1;
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
else {
|
|
241
|
+
(newSlidesPerView = resultCount), (newSlidesPerGroup = resultCount);
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
modifiedBreakpoints[breakpoint] = {
|
|
245
|
+
...modifiedBreakpoints[breakpoint],
|
|
246
|
+
slidesPerView: newSlidesPerView,
|
|
247
|
+
slidesPerGroup: newSlidesPerGroup,
|
|
248
|
+
};
|
|
249
|
+
});
|
|
250
|
+
}
|
|
251
|
+
const onProductSelect = (product) => {
|
|
252
|
+
if (product) {
|
|
253
|
+
const idx = selectedItems.findIndex((result) => result.id == product.id);
|
|
254
|
+
//is it in the selected items?
|
|
255
|
+
if (idx > -1) {
|
|
256
|
+
//already selected, deselect it now
|
|
257
|
+
cartStore.removeItems([product]);
|
|
258
|
+
if (cartStore.items.length == 0) {
|
|
259
|
+
//we dont call addItems here to prevent tracking
|
|
260
|
+
cartStore.items.push(seed);
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
else {
|
|
264
|
+
//add it to the list;
|
|
265
|
+
cartStore.addItems([product]);
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
};
|
|
269
|
+
const addToCart = (e) => {
|
|
270
|
+
// add to cart tracking
|
|
271
|
+
controller.track.addBundle(e, selectedItems);
|
|
272
|
+
//call the function passed
|
|
273
|
+
onAddToCart && onAddToCart(e, selectedItems);
|
|
274
|
+
};
|
|
275
|
+
const setSeedwidth = () => {
|
|
276
|
+
if (seedRef.current) {
|
|
277
|
+
// @ts-ignore - todo can this be typed appropriatly?
|
|
278
|
+
const seedElem = seedRef.current?.base;
|
|
279
|
+
// @ts-ignore - todo can this be typed appropriatly?
|
|
280
|
+
const carouselElem = carouselRef.current?.base;
|
|
281
|
+
const visibleSlide = carouselElem?.querySelector('.swiper-slide-visible .ss__recommendation-bundle__wrapper__selector');
|
|
282
|
+
const width = visibleSlide?.offsetWidth;
|
|
283
|
+
if (seedElem) {
|
|
284
|
+
seedElem.style.width = `${width}px`;
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
};
|
|
288
|
+
const seedRef = useRef();
|
|
289
|
+
const carouselRef = useRef();
|
|
290
|
+
return resultsToRender?.length ? (jsx(CacheProvider, null,
|
|
291
|
+
jsx("div", { ...styling, className: classnames('ss__recommendation-bundle', { 'ss__recommendation-bundle--stacked': !ctaInline }, className) },
|
|
292
|
+
jsx(RecommendationProfileTracker, { controller: controller },
|
|
293
|
+
title && (jsx("h3", { className: "ss__recommendation-bundle__title" },
|
|
294
|
+
jsx("span", null, title))),
|
|
295
|
+
jsx("div", { className: classnames('ss__recommendation-bundle__wrapper', {
|
|
296
|
+
'ss__recommendation-bundle__wrapper--seed-in-carousel': seedInCarousel,
|
|
297
|
+
'ss__recommendation-bundle__wrapper--vertical': vertical,
|
|
298
|
+
}) },
|
|
299
|
+
carouselEnabled ? (jsx(Fragment, null,
|
|
300
|
+
!seedInCarousel && (jsx("div", { className: "ss__recommendation-bundle__wrapper__seed-container" },
|
|
301
|
+
jsx(RecommendationResultTracker, { controller: controller, result: seed },
|
|
302
|
+
jsx(BundleSelector, { seedText: seedText, seed: true, onCheck: () => onProductSelect(seed), checked: selectedItems.findIndex((item) => item.id == seed.id) > -1, icon: separatorIcon, hideCheckboxes: hideCheckboxes, theme: props.theme, ref: seedRef }, resultComponent ? (cloneWithProps(resultComponent, {
|
|
303
|
+
result: seed,
|
|
304
|
+
seed: true,
|
|
305
|
+
selected: selectedItems.findIndex((item) => item.id == seed.id) > -1,
|
|
306
|
+
onProductSelect,
|
|
307
|
+
})) : (jsx(Result, { ...subProps.result, controller: controller, result: seed })))))),
|
|
308
|
+
jsx("div", { className: "ss__recommendation-bundle__wrapper__carousel" },
|
|
309
|
+
jsx(Carousel, { prevButton: prevButton, nextButton: nextButton, hideButtons: hideButtons, loop: loop, spaceBetween: spaceBetween, pagination: pagination, breakpoints: modifiedBreakpoints, watchSlidesProgress: true, observer: true, vertical: vertical, onResize: () => setSeedwidth(), ...subProps.carousel, ...additionalProps, ...displaySettings, ref: carouselRef }, seedInCarousel
|
|
310
|
+
? resultsToRender.map((result, idx) => {
|
|
311
|
+
const selected = selectedItems.findIndex((item) => item.id == result.id) > -1;
|
|
312
|
+
if (idx == 0) {
|
|
313
|
+
return (jsx(RecommendationResultTracker, { controller: controller, result: result },
|
|
314
|
+
jsx(BundleSelector, { seedText: seedText, seed: true, icon: separatorIcon, onCheck: () => onProductSelect(result), checked: selected, hideCheckboxes: hideCheckboxes, theme: props.theme }, resultComponent ? (cloneWithProps(resultComponent, { result: result, seed: true, selected, onProductSelect })) : (jsx(Result, { ...subProps.result, controller: controller, result: result })))));
|
|
315
|
+
}
|
|
316
|
+
else {
|
|
317
|
+
return (jsx(RecommendationResultTracker, { controller: controller, result: result },
|
|
318
|
+
jsx(BundleSelector, { icon: separatorIconSeedOnly ? false : separatorIcon, onCheck: () => onProductSelect(result), checked: selected, hideCheckboxes: hideCheckboxes, theme: props.theme, className: idx + 1 == resultsToRender.length ? 'ss__recommendation-bundle__wrapper__selector--last' : '' }, resultComponent ? (cloneWithProps(resultComponent, { result: result, seed: false, selected, onProductSelect })) : (jsx(Result, { ...subProps.result, controller: controller, result: result })))));
|
|
319
|
+
}
|
|
320
|
+
})
|
|
321
|
+
: resultsToRender
|
|
322
|
+
.filter((result, idx) => idx !== 0)
|
|
323
|
+
.map((result, idx, results) => {
|
|
324
|
+
const selected = selectedItems.findIndex((item) => item.id == result.id) > -1;
|
|
325
|
+
return (jsx(RecommendationResultTracker, { controller: controller, result: result },
|
|
326
|
+
jsx(BundleSelector, { icon: separatorIconSeedOnly ? false : separatorIcon, onCheck: () => onProductSelect(result), checked: selected, hideCheckboxes: hideCheckboxes, theme: props.theme, className: idx + 1 == results.length ? 'ss__recommendation-bundle__wrapper__selector--last' : '' }, resultComponent ? (cloneWithProps(resultComponent, { result: result, seed: false, selected, onProductSelect })) : (jsx(Result, { ...subProps.result, controller: controller, result: result })))));
|
|
327
|
+
}))))) : (resultsToRender.map((result, idx) => {
|
|
328
|
+
const selected = selectedItems.findIndex((item) => item.id == result.id) > -1;
|
|
329
|
+
if (idx == 0) {
|
|
330
|
+
return (jsx(RecommendationResultTracker, { controller: controller, result: result },
|
|
331
|
+
jsx(BundleSelector, { seedText: seedText, seed: true, icon: separatorIcon, onCheck: () => onProductSelect(result), checked: selected, hideCheckboxes: hideCheckboxes, theme: props.theme }, resultComponent ? (cloneWithProps(resultComponent, { result: result, seed: true, selected, onProductSelect })) : (jsx(Result, { ...subProps.result, controller: controller, result: result })))));
|
|
332
|
+
}
|
|
333
|
+
else {
|
|
334
|
+
return (jsx(RecommendationResultTracker, { controller: controller, result: result },
|
|
335
|
+
jsx(BundleSelector, { icon: separatorIconSeedOnly ? false : separatorIcon, onCheck: () => onProductSelect(result), checked: selected, hideCheckboxes: hideCheckboxes, theme: props.theme, className: idx + 1 == resultsToRender.length ? 'ss__recommendation-bundle__wrapper__selector--last' : '' }, resultComponent ? (cloneWithProps(resultComponent, { result: result, seed: false, selected, onProductSelect })) : (jsx(Result, { ...subProps.result, controller: controller, result: result })))));
|
|
336
|
+
}
|
|
337
|
+
})),
|
|
338
|
+
ctaInline && (jsx(BundledCTA, { ctaSlot: ctaSlot, cartStore: cartStore, onAddToCart: (e) => addToCart(e), ctaButtonText: ctaButtonText, ctaButtonSuccessText: ctaButtonSuccessText, ctaButtonSuccessTimeout: ctaButtonSuccessTimeout, ctaIcon: ctaIcon }))),
|
|
339
|
+
!ctaInline && (jsx(BundledCTA, { ctaSlot: ctaSlot, cartStore: cartStore, onAddToCart: (e) => addToCart(e), ctaButtonText: ctaButtonText, ctaButtonSuccessText: ctaButtonSuccessText, ctaButtonSuccessTimeout: ctaButtonSuccessTimeout, ctaIcon: ctaIcon })))))) : (jsx(Fragment, null));
|
|
340
|
+
return jsx(Fragment, null);
|
|
341
|
+
});
|
|
@@ -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 @@
|
|
|
1
|
+
export * from './RecommendationBundle';
|
|
@@ -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"}
|
package/dist/esm/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.d.ts
CHANGED
|
@@ -1,9 +1,7 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import type { RecommendationController } from '@searchspring/snap-controller';
|
|
3
3
|
import { ComponentProps } from '../../../../types';
|
|
4
|
-
export declare const RecommendationProfileTracker: (
|
|
5
|
-
displayName: string;
|
|
6
|
-
};
|
|
4
|
+
export declare const RecommendationProfileTracker: (properties: RecommendationProfileTrackerProps) => JSX.Element;
|
|
7
5
|
export interface RecommendationProfileTrackerProps extends ComponentProps {
|
|
8
6
|
children: any;
|
|
9
7
|
controller: RecommendationController;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RecommendationProfileTracker.d.ts","sourceRoot":"","sources":["../../../../../../src/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.tsx"],"names":[],"mappings":";AAOA,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAc,MAAM,mBAAmB,CAAC;AAO/D,eAAO,MAAM,4BAA4B,
|
|
1
|
+
{"version":3,"file":"RecommendationProfileTracker.d.ts","sourceRoot":"","sources":["../../../../../../src/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.tsx"],"names":[],"mappings":";AAOA,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAc,MAAM,mBAAmB,CAAC;AAO/D,eAAO,MAAM,4BAA4B,eAAyB,iCAAiC,KAAG,WA+CpG,CAAC;AAEH,MAAM,WAAW,iCAAkC,SAAQ,cAAc;IACxE,QAAQ,EAAE,GAAG,CAAC;IACd,UAAU,EAAE,wBAAwB,CAAC;CACrC"}
|
package/dist/esm/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.js
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import { Fragment, toChildArray } from 'preact';
|
|
3
3
|
import { jsx, css } from '@emotion/react';
|
|
4
4
|
import { useRef } from 'preact/hooks';
|
|
5
|
-
import { observer } from 'mobx-react
|
|
5
|
+
import { observer } from 'mobx-react';
|
|
6
6
|
import { useTheme } from '../../../../providers';
|
|
7
7
|
import { useIntersection } from '../../../../hooks';
|
|
8
8
|
import classnames from 'classnames';
|
package/dist/esm/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.d.ts
CHANGED
|
@@ -2,9 +2,7 @@
|
|
|
2
2
|
import type { RecommendationController } from '@searchspring/snap-controller';
|
|
3
3
|
import { ComponentProps } from '../../../../types';
|
|
4
4
|
import type { Product } from '@searchspring/snap-store-mobx';
|
|
5
|
-
export declare const RecommendationResultTracker: (
|
|
6
|
-
displayName: string;
|
|
7
|
-
};
|
|
5
|
+
export declare const RecommendationResultTracker: (properties: RecommendationResultTrackerProps) => JSX.Element;
|
|
8
6
|
export interface RecommendationResultTrackerProps extends ComponentProps {
|
|
9
7
|
children: any;
|
|
10
8
|
result: Product;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RecommendationResultTracker.d.ts","sourceRoot":"","sources":["../../../../../../src/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.tsx"],"names":[],"mappings":";AAOA,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAc,MAAM,mBAAmB,CAAC;AAC/D,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,+BAA+B,CAAC;AAO7D,eAAO,MAAM,2BAA2B,
|
|
1
|
+
{"version":3,"file":"RecommendationResultTracker.d.ts","sourceRoot":"","sources":["../../../../../../src/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.tsx"],"names":[],"mappings":";AAOA,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAc,MAAM,mBAAmB,CAAC;AAC/D,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,+BAA+B,CAAC;AAO7D,eAAO,MAAM,2BAA2B,eAAyB,gCAAgC,KAAG,WAiDlG,CAAC;AAEH,MAAM,WAAW,gCAAiC,SAAQ,cAAc;IACvE,QAAQ,EAAE,GAAG,CAAC;IACd,MAAM,EAAE,OAAO,CAAC;IAChB,UAAU,EAAE,wBAAwB,CAAC;CACrC"}
|
package/dist/esm/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { jsx, css } from '@emotion/react';
|
|
2
2
|
import { useRef } from 'preact/hooks';
|
|
3
|
-
import { observer } from 'mobx-react
|
|
3
|
+
import { observer } from 'mobx-react';
|
|
4
4
|
import { useTheme } from '../../../../providers';
|
|
5
5
|
import { useIntersection } from '../../../../hooks';
|
|
6
6
|
import classnames from 'classnames';
|
package/dist/esm/index.d.ts
CHANGED
|
@@ -31,6 +31,7 @@ export * from './components/Organisms/Facet';
|
|
|
31
31
|
export * from './components/Organisms/Facets';
|
|
32
32
|
export * from './components/Organisms/FilterSummary';
|
|
33
33
|
export * from './components/Organisms/Recommendation';
|
|
34
|
+
export * from './components/Organisms/RecommendationBundle';
|
|
34
35
|
export * from './components/Organisms/Results';
|
|
35
36
|
export * from './hooks';
|
|
36
37
|
export * from './providers';
|
package/dist/esm/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AACA,cAAc,0BAA0B,CAAC;AACzC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,oCAAoC,CAAC;AACnD,cAAc,yBAAyB,CAAC;AACxC,cAAc,0BAA0B,CAAC;AACzC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,kCAAkC,CAAC;AACjD,cAAc,4BAA4B,CAAC;AAC3C,cAAc,0BAA0B,CAAC;AACzC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,oDAAoD,CAAC;AACnE,cAAc,qDAAqD,CAAC;AAGpE,cAAc,iCAAiC,CAAC;AAChD,cAAc,iCAAiC,CAAC;AAChD,cAAc,qCAAqC,CAAC;AACpD,cAAc,yCAAyC,CAAC;AACxD,cAAc,8CAA8C,CAAC;AAC7D,cAAc,yCAAyC,CAAC;AACxD,cAAc,4CAA4C,CAAC;AAC3D,cAAc,+BAA+B,CAAC;AAC9C,cAAc,mCAAmC,CAAC;AAClD,cAAc,+BAA+B,CAAC;AAC9C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,iCAAiC,CAAC;AAChD,cAAc,oCAAoC,CAAC;AAGnD,cAAc,qCAAqC,CAAC;AACpD,cAAc,uCAAuC,CAAC;AACtD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,sCAAsC,CAAC;AACrD,cAAc,uCAAuC,CAAC;AACtD,cAAc,gCAAgC,CAAC;AAG/C,cAAc,SAAS,CAAC;AAGxB,cAAc,aAAa,CAAC;AAG5B,cAAc,WAAW,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AACA,cAAc,0BAA0B,CAAC;AACzC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,oCAAoC,CAAC;AACnD,cAAc,yBAAyB,CAAC;AACxC,cAAc,0BAA0B,CAAC;AACzC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,kCAAkC,CAAC;AACjD,cAAc,4BAA4B,CAAC;AAC3C,cAAc,0BAA0B,CAAC;AACzC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,oDAAoD,CAAC;AACnE,cAAc,qDAAqD,CAAC;AAGpE,cAAc,iCAAiC,CAAC;AAChD,cAAc,iCAAiC,CAAC;AAChD,cAAc,qCAAqC,CAAC;AACpD,cAAc,yCAAyC,CAAC;AACxD,cAAc,8CAA8C,CAAC;AAC7D,cAAc,yCAAyC,CAAC;AACxD,cAAc,4CAA4C,CAAC;AAC3D,cAAc,+BAA+B,CAAC;AAC9C,cAAc,mCAAmC,CAAC;AAClD,cAAc,+BAA+B,CAAC;AAC9C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,iCAAiC,CAAC;AAChD,cAAc,oCAAoC,CAAC;AAGnD,cAAc,qCAAqC,CAAC;AACpD,cAAc,uCAAuC,CAAC;AACtD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,sCAAsC,CAAC;AACrD,cAAc,uCAAuC,CAAC;AACtD,cAAc,6CAA6C,CAAC;AAC5D,cAAc,gCAAgC,CAAC;AAG/C,cAAc,SAAS,CAAC;AAGxB,cAAc,aAAa,CAAC;AAG5B,cAAc,WAAW,CAAC"}
|
package/dist/esm/index.js
CHANGED
|
@@ -34,6 +34,7 @@ export * from './components/Organisms/Facet';
|
|
|
34
34
|
export * from './components/Organisms/Facets';
|
|
35
35
|
export * from './components/Organisms/FilterSummary';
|
|
36
36
|
export * from './components/Organisms/Recommendation';
|
|
37
|
+
export * from './components/Organisms/RecommendationBundle';
|
|
37
38
|
export * from './components/Organisms/Results';
|
|
38
39
|
// HOOKS
|
|
39
40
|
export * from './hooks';
|
package/dist/esm/setupTests.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setupTests.d.ts","sourceRoot":"","sources":["../../src/setupTests.ts"],"names":[],"mappings":""}
|
|
1
|
+
{"version":3,"file":"setupTests.d.ts","sourceRoot":"","sources":["../../src/setupTests.ts"],"names":[],"mappings":"AAAA,OAAO,2BAA2B,CAAC"}
|
package/dist/esm/setupTests.js
CHANGED
|
@@ -1,2 +1 @@
|
|
|
1
|
-
|
|
2
|
-
require('@testing-library/jest-dom/extend-expect');
|
|
1
|
+
import '@testing-library/jest-dom';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createHoverProps.d.ts","sourceRoot":"","sources":["../../../../src/toolbox/createHoverProps/createHoverProps.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,gBAAgB,
|
|
1
|
+
{"version":3,"file":"createHoverProps.d.ts","sourceRoot":"","sources":["../../../../src/toolbox/createHoverProps/createHoverProps.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,gBAAgB,cAAe,MAAM,IAAI,YAAW;IAAE,KAAK,CAAC,EAAE,MAAM,CAAC;IAAC,SAAS,CAAC,EAAE,OAAO,CAAA;CAAE;sBAIpF,gBAAgB,CAAC,WAAW,CAAC;;CAWhD,CAAC"}
|
package/dist/esm/types.d.ts
CHANGED
|
@@ -11,7 +11,7 @@ export declare enum Layout {
|
|
|
11
11
|
GRID = "grid",
|
|
12
12
|
LIST = "list"
|
|
13
13
|
}
|
|
14
|
-
export
|
|
14
|
+
export type LayoutType = Layout.GRID | Layout.LIST;
|
|
15
15
|
export declare enum FacetType {
|
|
16
16
|
VALUE = "value",
|
|
17
17
|
RANGE = "range",
|
|
@@ -24,11 +24,11 @@ export declare enum FacetDisplay {
|
|
|
24
24
|
SLIDER = "slider",
|
|
25
25
|
HIERARCHY = "hierarchy"
|
|
26
26
|
}
|
|
27
|
-
export
|
|
27
|
+
export type BreakpointsProps = {
|
|
28
28
|
[key: number]: BreakpointsEntry;
|
|
29
29
|
};
|
|
30
|
-
export
|
|
30
|
+
export type BreakpointsEntry = {
|
|
31
31
|
[property: string]: any;
|
|
32
32
|
};
|
|
33
|
-
export
|
|
33
|
+
export type StylingCSS = Array<SerializedStyles | string | Record<string, string> | undefined>;
|
|
34
34
|
//# sourceMappingURL=types.d.ts.map
|
package/dist/esm/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AACzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAE1C,MAAM,WAAW,cAAe,SAAQ,eAAe,CAAC,GAAG,CAAC;IAC3D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACrC,KAAK,CAAC,EAAE,KAAK,CAAC;CACd;AAED,oBAAY,MAAM;IACjB,IAAI,SAAS;IACb,IAAI,SAAS;CACb;AAED,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AACzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAE1C,MAAM,WAAW,cAAe,SAAQ,eAAe,CAAC,GAAG,CAAC;IAC3D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACrC,KAAK,CAAC,EAAE,KAAK,CAAC;CACd;AAED,oBAAY,MAAM;IACjB,IAAI,SAAS;IACb,IAAI,SAAS;CACb;AAED,MAAM,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;AAGnD,oBAAY,SAAS;IACpB,KAAK,UAAU;IACf,KAAK,UAAU;IACf,aAAa,kBAAkB;CAC/B;AAGD,oBAAY,YAAY;IACvB,IAAI,SAAS;IACb,OAAO,YAAY;IACnB,IAAI,SAAS;IACb,MAAM,WAAW;IACjB,SAAS,cAAc;CACvB;AAED,MAAM,MAAM,gBAAgB,GAAG;IAC9B,CAAC,GAAG,EAAE,MAAM,GAAG,gBAAgB,CAAC;CAChC,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC9B,CAAC,QAAQ,EAAE,MAAM,GAAG,GAAG,CAAC;CACxB,CAAC;AAEF,MAAM,MAAM,UAAU,GAAG,KAAK,CAAC,gBAAgB,GAAG,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,SAAS,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"defined.d.ts","sourceRoot":"","sources":["../../../src/utilities/defined.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"defined.d.ts","sourceRoot":"","sources":["../../../src/utilities/defined.ts"],"names":[],"mappings":"AAAA,KAAK,YAAY,GAAG;IACnB,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;CACnB,CAAC;AAEF,wBAAgB,OAAO,CAAC,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,YAAY,CAUrE"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@searchspring/snap-preact-components",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.52.1",
|
|
4
4
|
"description": "Snap Preact Component Library",
|
|
5
5
|
"author": "Searchspring",
|
|
6
6
|
"license": "MIT",
|
|
@@ -21,31 +21,45 @@
|
|
|
21
21
|
"format": "prettier --write 'src/**/*.{js,jsx,ts,tsx}'",
|
|
22
22
|
"lint": "eslint 'src/components/**/*.{js,jsx,ts,tsx}'",
|
|
23
23
|
"storybook": "start-storybook -p 6006",
|
|
24
|
-
"
|
|
24
|
+
"cypress": "cypress open --project tests",
|
|
25
|
+
"cypress:headless": "cypress run --component --project tests",
|
|
26
|
+
"test": "jest; npm run cypress:headless",
|
|
25
27
|
"test:watch": "jest --watch"
|
|
26
28
|
},
|
|
27
29
|
"dependencies": {
|
|
30
|
+
"@cypress/react": "^8.0.0",
|
|
28
31
|
"@emotion/react": "11.9.0",
|
|
29
|
-
"@searchspring/snap-toolbox": "^0.
|
|
32
|
+
"@searchspring/snap-toolbox": "^0.52.1",
|
|
30
33
|
"classnames": "^2.3.2",
|
|
34
|
+
"cypress": "^12.15.0",
|
|
35
|
+
"cypress-wait-until": "^1.7.2",
|
|
31
36
|
"deepmerge": "4.3.1",
|
|
32
37
|
"dequal": "2.0.3",
|
|
33
|
-
"mobx-react
|
|
38
|
+
"mobx-react": "7.6.0",
|
|
34
39
|
"react-ranger": "2.1.0",
|
|
35
|
-
"swiper": "
|
|
40
|
+
"swiper": "11.0.7"
|
|
36
41
|
},
|
|
37
42
|
"peerDependencies": {
|
|
43
|
+
"mobx": "6.9.0",
|
|
38
44
|
"preact": "10.9.0"
|
|
39
45
|
},
|
|
40
46
|
"devDependencies": {
|
|
41
|
-
"@
|
|
42
|
-
"@
|
|
43
|
-
"@
|
|
44
|
-
"@
|
|
45
|
-
"@
|
|
46
|
-
"@
|
|
47
|
-
"@
|
|
48
|
-
"@
|
|
47
|
+
"@babel/core": "^7.21.4",
|
|
48
|
+
"@babel/plugin-proposal-class-properties": "^7.18.6",
|
|
49
|
+
"@babel/plugin-proposal-decorators": "^7.21.0",
|
|
50
|
+
"@babel/plugin-transform-react-jsx": "^7.21.0",
|
|
51
|
+
"@babel/plugin-transform-runtime": "^7.21.4",
|
|
52
|
+
"@babel/preset-env": "^7.21.4",
|
|
53
|
+
"@babel/preset-react": "^7.18.6",
|
|
54
|
+
"@babel/runtime": "^7.21.0",
|
|
55
|
+
"@searchspring/snap-client": "^0.52.1",
|
|
56
|
+
"@searchspring/snap-controller": "^0.52.1",
|
|
57
|
+
"@searchspring/snap-event-manager": "^0.52.1",
|
|
58
|
+
"@searchspring/snap-logger": "^0.52.1",
|
|
59
|
+
"@searchspring/snap-profiler": "^0.52.1",
|
|
60
|
+
"@searchspring/snap-store-mobx": "^0.52.1",
|
|
61
|
+
"@searchspring/snap-tracker": "^0.52.1",
|
|
62
|
+
"@searchspring/snap-url-manager": "^0.52.1",
|
|
49
63
|
"@storybook/addon-actions": "6.4.22",
|
|
50
64
|
"@storybook/addon-controls": "6.4.22",
|
|
51
65
|
"@storybook/addon-docs": "6.4.22",
|
|
@@ -55,17 +69,19 @@
|
|
|
55
69
|
"@storybook/manager-webpack5": "6.4.22",
|
|
56
70
|
"@storybook/preact": "6.4.22",
|
|
57
71
|
"@storybook/theming": "6.4.22",
|
|
58
|
-
"@testing-library/
|
|
59
|
-
"@testing-library/preact": "2.0.1",
|
|
72
|
+
"@testing-library/preact": "3.2.3",
|
|
60
73
|
"@testing-library/user-event": "13.5.0",
|
|
61
74
|
"@types/react": "16.14.28",
|
|
62
75
|
"@types/react-ranger": "2.0.1",
|
|
63
|
-
"
|
|
76
|
+
"babel-jest": "^29.7.0",
|
|
64
77
|
"preact": "10.9.0",
|
|
65
78
|
"react": "16.14.0",
|
|
66
79
|
"react-dom": "16.14.0",
|
|
67
|
-
"ts-loader": "9.
|
|
80
|
+
"ts-loader": "9.4.2",
|
|
81
|
+
"webpack": "^5.77.0",
|
|
82
|
+
"webpack-cli": "^5.0.1",
|
|
83
|
+
"webpack-merge": "^5.8.0"
|
|
68
84
|
},
|
|
69
85
|
"sideEffects": false,
|
|
70
|
-
"gitHead": "
|
|
86
|
+
"gitHead": "c9651b79b78d8105b0f17234528ab6ba8eaa3cab"
|
|
71
87
|
}
|