@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.
Files changed (223) hide show
  1. package/dist/cjs/components/Atoms/Badge/Badge.d.ts +1 -3
  2. package/dist/cjs/components/Atoms/Badge/Badge.d.ts.map +1 -1
  3. package/dist/cjs/components/Atoms/Badge/Badge.js +2 -2
  4. package/dist/cjs/components/Atoms/Breadcrumbs/Breadcrumbs.d.ts +1 -3
  5. package/dist/cjs/components/Atoms/Breadcrumbs/Breadcrumbs.d.ts.map +1 -1
  6. package/dist/cjs/components/Atoms/Breadcrumbs/Breadcrumbs.js +2 -2
  7. package/dist/cjs/components/Atoms/Button/Button.d.ts +1 -3
  8. package/dist/cjs/components/Atoms/Button/Button.d.ts.map +1 -1
  9. package/dist/cjs/components/Atoms/Button/Button.js +2 -2
  10. package/dist/cjs/components/Atoms/Dropdown/Dropdown.d.ts +1 -3
  11. package/dist/cjs/components/Atoms/Dropdown/Dropdown.d.ts.map +1 -1
  12. package/dist/cjs/components/Atoms/Dropdown/Dropdown.js +2 -2
  13. package/dist/cjs/components/Atoms/Icon/Icon.d.ts +1 -1
  14. package/dist/cjs/components/Atoms/Icon/Icon.d.ts.map +1 -1
  15. package/dist/cjs/components/Atoms/Icon/paths.d.ts +1 -1
  16. package/dist/cjs/components/Atoms/Icon/paths.d.ts.map +1 -1
  17. package/dist/cjs/components/Atoms/Icon/paths.js +1 -0
  18. package/dist/cjs/components/Atoms/Price/Price.js +1 -1
  19. package/dist/cjs/components/Atoms/Skeleton/Skeleton.d.ts +1 -3
  20. package/dist/cjs/components/Atoms/Skeleton/Skeleton.d.ts.map +1 -1
  21. package/dist/cjs/components/Atoms/Skeleton/Skeleton.js +2 -2
  22. package/dist/cjs/components/Molecules/Carousel/Carousel.d.ts +11 -8
  23. package/dist/cjs/components/Molecules/Carousel/Carousel.d.ts.map +1 -1
  24. package/dist/cjs/components/Molecules/Carousel/Carousel.js +91 -44
  25. package/dist/cjs/components/Molecules/Checkbox/Checkbox.d.ts +1 -3
  26. package/dist/cjs/components/Molecules/Checkbox/Checkbox.d.ts.map +1 -1
  27. package/dist/cjs/components/Molecules/Checkbox/Checkbox.js +2 -2
  28. package/dist/cjs/components/Molecules/ErrorHandler/ErrorHandler.d.ts +1 -3
  29. package/dist/cjs/components/Molecules/ErrorHandler/ErrorHandler.d.ts.map +1 -1
  30. package/dist/cjs/components/Molecules/ErrorHandler/ErrorHandler.js +2 -2
  31. package/dist/cjs/components/Molecules/FacetGridOptions/FacetGridOptions.d.ts +1 -3
  32. package/dist/cjs/components/Molecules/FacetGridOptions/FacetGridOptions.d.ts.map +1 -1
  33. package/dist/cjs/components/Molecules/FacetGridOptions/FacetGridOptions.js +2 -2
  34. package/dist/cjs/components/Molecules/FacetHierarchyOptions/FacetHierarchyOptions.d.ts +1 -3
  35. package/dist/cjs/components/Molecules/FacetHierarchyOptions/FacetHierarchyOptions.d.ts.map +1 -1
  36. package/dist/cjs/components/Molecules/FacetHierarchyOptions/FacetHierarchyOptions.js +2 -2
  37. package/dist/cjs/components/Molecules/FacetListOptions/FacetListOptions.d.ts +1 -3
  38. package/dist/cjs/components/Molecules/FacetListOptions/FacetListOptions.d.ts.map +1 -1
  39. package/dist/cjs/components/Molecules/FacetListOptions/FacetListOptions.js +2 -2
  40. package/dist/cjs/components/Molecules/FacetPaletteOptions/FacetPaletteOptions.d.ts +1 -3
  41. package/dist/cjs/components/Molecules/FacetPaletteOptions/FacetPaletteOptions.d.ts.map +1 -1
  42. package/dist/cjs/components/Molecules/FacetPaletteOptions/FacetPaletteOptions.js +2 -2
  43. package/dist/cjs/components/Molecules/FacetSlider/FacetSlider.d.ts +1 -3
  44. package/dist/cjs/components/Molecules/FacetSlider/FacetSlider.d.ts.map +1 -1
  45. package/dist/cjs/components/Molecules/FacetSlider/FacetSlider.js +2 -2
  46. package/dist/cjs/components/Molecules/Filter/Filter.d.ts +1 -3
  47. package/dist/cjs/components/Molecules/Filter/Filter.d.ts.map +1 -1
  48. package/dist/cjs/components/Molecules/Filter/Filter.js +2 -2
  49. package/dist/cjs/components/Molecules/Pagination/Pagination.d.ts +1 -3
  50. package/dist/cjs/components/Molecules/Pagination/Pagination.d.ts.map +1 -1
  51. package/dist/cjs/components/Molecules/Pagination/Pagination.js +2 -2
  52. package/dist/cjs/components/Molecules/Result/Result.d.ts +1 -3
  53. package/dist/cjs/components/Molecules/Result/Result.d.ts.map +1 -1
  54. package/dist/cjs/components/Molecules/Result/Result.js +7 -7
  55. package/dist/cjs/components/Molecules/SearchInput/SearchInput.d.ts +1 -3
  56. package/dist/cjs/components/Molecules/SearchInput/SearchInput.d.ts.map +1 -1
  57. package/dist/cjs/components/Molecules/SearchInput/SearchInput.js +2 -2
  58. package/dist/cjs/components/Molecules/Select/Select.d.ts +2 -4
  59. package/dist/cjs/components/Molecules/Select/Select.d.ts.map +1 -1
  60. package/dist/cjs/components/Molecules/Select/Select.js +6 -2
  61. package/dist/cjs/components/Molecules/Slideout/Slideout.d.ts +1 -1
  62. package/dist/cjs/components/Molecules/Slideout/Slideout.d.ts.map +1 -1
  63. package/dist/cjs/components/Organisms/Autocomplete/Autocomplete.d.ts +1 -3
  64. package/dist/cjs/components/Organisms/Autocomplete/Autocomplete.d.ts.map +1 -1
  65. package/dist/cjs/components/Organisms/Autocomplete/Autocomplete.js +2 -2
  66. package/dist/cjs/components/Organisms/Facet/Facet.d.ts +2 -4
  67. package/dist/cjs/components/Organisms/Facet/Facet.d.ts.map +1 -1
  68. package/dist/cjs/components/Organisms/Facet/Facet.js +2 -2
  69. package/dist/cjs/components/Organisms/Facets/Facets.d.ts +2 -4
  70. package/dist/cjs/components/Organisms/Facets/Facets.d.ts.map +1 -1
  71. package/dist/cjs/components/Organisms/Facets/Facets.js +2 -2
  72. package/dist/cjs/components/Organisms/FilterSummary/FilterSummary.d.ts +1 -3
  73. package/dist/cjs/components/Organisms/FilterSummary/FilterSummary.d.ts.map +1 -1
  74. package/dist/cjs/components/Organisms/FilterSummary/FilterSummary.js +2 -2
  75. package/dist/cjs/components/Organisms/Recommendation/Recommendation.d.ts +3 -5
  76. package/dist/cjs/components/Organisms/Recommendation/Recommendation.d.ts.map +1 -1
  77. package/dist/cjs/components/Organisms/Recommendation/Recommendation.js +2 -2
  78. package/dist/cjs/components/Organisms/RecommendationBundle/BundleCTA.d.ts +17 -0
  79. package/dist/cjs/components/Organisms/RecommendationBundle/BundleCTA.d.ts.map +1 -0
  80. package/dist/cjs/components/Organisms/RecommendationBundle/BundleCTA.js +48 -0
  81. package/dist/cjs/components/Organisms/RecommendationBundle/BundleSelector.d.ts +21 -0
  82. package/dist/cjs/components/Organisms/RecommendationBundle/BundleSelector.d.ts.map +1 -0
  83. package/dist/cjs/components/Organisms/RecommendationBundle/BundleSelector.js +47 -0
  84. package/dist/cjs/components/Organisms/RecommendationBundle/RecommendationBundle.d.ts +33 -0
  85. package/dist/cjs/components/Organisms/RecommendationBundle/RecommendationBundle.d.ts.map +1 -0
  86. package/dist/cjs/components/Organisms/RecommendationBundle/RecommendationBundle.js +336 -0
  87. package/dist/cjs/components/Organisms/RecommendationBundle/index.d.ts +2 -0
  88. package/dist/cjs/components/Organisms/RecommendationBundle/index.d.ts.map +1 -0
  89. package/dist/cjs/components/Organisms/RecommendationBundle/index.js +17 -0
  90. package/dist/cjs/components/Organisms/Results/Results.d.ts +1 -3
  91. package/dist/cjs/components/Organisms/Results/Results.d.ts.map +1 -1
  92. package/dist/cjs/components/Organisms/Results/Results.js +2 -2
  93. package/dist/cjs/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.d.ts +1 -3
  94. package/dist/cjs/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.d.ts.map +1 -1
  95. package/dist/cjs/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.js +2 -2
  96. package/dist/cjs/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.d.ts +1 -3
  97. package/dist/cjs/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.d.ts.map +1 -1
  98. package/dist/cjs/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.js +2 -2
  99. package/dist/cjs/index.d.ts +1 -0
  100. package/dist/cjs/index.d.ts.map +1 -1
  101. package/dist/cjs/index.js +1 -0
  102. package/dist/cjs/setupTests.d.ts +1 -0
  103. package/dist/cjs/setupTests.d.ts.map +1 -1
  104. package/dist/cjs/setupTests.js +2 -1
  105. package/dist/cjs/toolbox/createHoverProps/createHoverProps.d.ts +1 -1
  106. package/dist/cjs/toolbox/createHoverProps/createHoverProps.d.ts.map +1 -1
  107. package/dist/cjs/types.d.ts +4 -4
  108. package/dist/cjs/types.d.ts.map +1 -1
  109. package/dist/cjs/types.js +3 -3
  110. package/dist/cjs/utilities/defined.d.ts +1 -1
  111. package/dist/cjs/utilities/defined.d.ts.map +1 -1
  112. package/dist/cjs/utilities/snapify.js +1 -1
  113. package/dist/esm/components/Atoms/Badge/Badge.d.ts +1 -3
  114. package/dist/esm/components/Atoms/Badge/Badge.d.ts.map +1 -1
  115. package/dist/esm/components/Atoms/Badge/Badge.js +1 -1
  116. package/dist/esm/components/Atoms/Breadcrumbs/Breadcrumbs.d.ts +1 -3
  117. package/dist/esm/components/Atoms/Breadcrumbs/Breadcrumbs.d.ts.map +1 -1
  118. package/dist/esm/components/Atoms/Breadcrumbs/Breadcrumbs.js +1 -1
  119. package/dist/esm/components/Atoms/Button/Button.d.ts +1 -3
  120. package/dist/esm/components/Atoms/Button/Button.d.ts.map +1 -1
  121. package/dist/esm/components/Atoms/Button/Button.js +1 -1
  122. package/dist/esm/components/Atoms/Dropdown/Dropdown.d.ts +1 -3
  123. package/dist/esm/components/Atoms/Dropdown/Dropdown.d.ts.map +1 -1
  124. package/dist/esm/components/Atoms/Dropdown/Dropdown.js +1 -1
  125. package/dist/esm/components/Atoms/Icon/Icon.d.ts +1 -1
  126. package/dist/esm/components/Atoms/Icon/Icon.d.ts.map +1 -1
  127. package/dist/esm/components/Atoms/Icon/paths.d.ts +1 -1
  128. package/dist/esm/components/Atoms/Icon/paths.d.ts.map +1 -1
  129. package/dist/esm/components/Atoms/Icon/paths.js +1 -0
  130. package/dist/esm/components/Atoms/Price/Price.js +1 -1
  131. package/dist/esm/components/Atoms/Skeleton/Skeleton.d.ts +1 -3
  132. package/dist/esm/components/Atoms/Skeleton/Skeleton.d.ts.map +1 -1
  133. package/dist/esm/components/Atoms/Skeleton/Skeleton.js +1 -1
  134. package/dist/esm/components/Molecules/Carousel/Carousel.d.ts +11 -8
  135. package/dist/esm/components/Molecules/Carousel/Carousel.d.ts.map +1 -1
  136. package/dist/esm/components/Molecules/Carousel/Carousel.js +95 -21
  137. package/dist/esm/components/Molecules/Checkbox/Checkbox.d.ts +1 -3
  138. package/dist/esm/components/Molecules/Checkbox/Checkbox.d.ts.map +1 -1
  139. package/dist/esm/components/Molecules/Checkbox/Checkbox.js +1 -1
  140. package/dist/esm/components/Molecules/ErrorHandler/ErrorHandler.d.ts +1 -3
  141. package/dist/esm/components/Molecules/ErrorHandler/ErrorHandler.d.ts.map +1 -1
  142. package/dist/esm/components/Molecules/ErrorHandler/ErrorHandler.js +1 -1
  143. package/dist/esm/components/Molecules/FacetGridOptions/FacetGridOptions.d.ts +1 -3
  144. package/dist/esm/components/Molecules/FacetGridOptions/FacetGridOptions.d.ts.map +1 -1
  145. package/dist/esm/components/Molecules/FacetGridOptions/FacetGridOptions.js +1 -1
  146. package/dist/esm/components/Molecules/FacetHierarchyOptions/FacetHierarchyOptions.d.ts +1 -3
  147. package/dist/esm/components/Molecules/FacetHierarchyOptions/FacetHierarchyOptions.d.ts.map +1 -1
  148. package/dist/esm/components/Molecules/FacetHierarchyOptions/FacetHierarchyOptions.js +1 -1
  149. package/dist/esm/components/Molecules/FacetListOptions/FacetListOptions.d.ts +1 -3
  150. package/dist/esm/components/Molecules/FacetListOptions/FacetListOptions.d.ts.map +1 -1
  151. package/dist/esm/components/Molecules/FacetListOptions/FacetListOptions.js +1 -1
  152. package/dist/esm/components/Molecules/FacetPaletteOptions/FacetPaletteOptions.d.ts +1 -3
  153. package/dist/esm/components/Molecules/FacetPaletteOptions/FacetPaletteOptions.d.ts.map +1 -1
  154. package/dist/esm/components/Molecules/FacetPaletteOptions/FacetPaletteOptions.js +1 -1
  155. package/dist/esm/components/Molecules/FacetSlider/FacetSlider.d.ts +1 -3
  156. package/dist/esm/components/Molecules/FacetSlider/FacetSlider.d.ts.map +1 -1
  157. package/dist/esm/components/Molecules/FacetSlider/FacetSlider.js +1 -1
  158. package/dist/esm/components/Molecules/Filter/Filter.d.ts +1 -3
  159. package/dist/esm/components/Molecules/Filter/Filter.d.ts.map +1 -1
  160. package/dist/esm/components/Molecules/Filter/Filter.js +1 -1
  161. package/dist/esm/components/Molecules/Pagination/Pagination.d.ts +1 -3
  162. package/dist/esm/components/Molecules/Pagination/Pagination.d.ts.map +1 -1
  163. package/dist/esm/components/Molecules/Pagination/Pagination.js +1 -1
  164. package/dist/esm/components/Molecules/Result/Result.d.ts +1 -3
  165. package/dist/esm/components/Molecules/Result/Result.d.ts.map +1 -1
  166. package/dist/esm/components/Molecules/Result/Result.js +2 -2
  167. package/dist/esm/components/Molecules/SearchInput/SearchInput.d.ts +1 -3
  168. package/dist/esm/components/Molecules/SearchInput/SearchInput.d.ts.map +1 -1
  169. package/dist/esm/components/Molecules/SearchInput/SearchInput.js +1 -1
  170. package/dist/esm/components/Molecules/Select/Select.d.ts +2 -4
  171. package/dist/esm/components/Molecules/Select/Select.d.ts.map +1 -1
  172. package/dist/esm/components/Molecules/Select/Select.js +5 -1
  173. package/dist/esm/components/Molecules/Slideout/Slideout.d.ts +1 -1
  174. package/dist/esm/components/Molecules/Slideout/Slideout.d.ts.map +1 -1
  175. package/dist/esm/components/Organisms/Autocomplete/Autocomplete.d.ts +1 -3
  176. package/dist/esm/components/Organisms/Autocomplete/Autocomplete.d.ts.map +1 -1
  177. package/dist/esm/components/Organisms/Autocomplete/Autocomplete.js +1 -1
  178. package/dist/esm/components/Organisms/Facet/Facet.d.ts +2 -4
  179. package/dist/esm/components/Organisms/Facet/Facet.d.ts.map +1 -1
  180. package/dist/esm/components/Organisms/Facet/Facet.js +1 -1
  181. package/dist/esm/components/Organisms/Facets/Facets.d.ts +2 -4
  182. package/dist/esm/components/Organisms/Facets/Facets.d.ts.map +1 -1
  183. package/dist/esm/components/Organisms/Facets/Facets.js +1 -1
  184. package/dist/esm/components/Organisms/FilterSummary/FilterSummary.d.ts +1 -3
  185. package/dist/esm/components/Organisms/FilterSummary/FilterSummary.d.ts.map +1 -1
  186. package/dist/esm/components/Organisms/FilterSummary/FilterSummary.js +1 -1
  187. package/dist/esm/components/Organisms/Recommendation/Recommendation.d.ts +3 -5
  188. package/dist/esm/components/Organisms/Recommendation/Recommendation.d.ts.map +1 -1
  189. package/dist/esm/components/Organisms/Recommendation/Recommendation.js +1 -1
  190. package/dist/esm/components/Organisms/RecommendationBundle/BundleCTA.d.ts +17 -0
  191. package/dist/esm/components/Organisms/RecommendationBundle/BundleCTA.d.ts.map +1 -0
  192. package/dist/esm/components/Organisms/RecommendationBundle/BundleCTA.js +42 -0
  193. package/dist/esm/components/Organisms/RecommendationBundle/BundleSelector.d.ts +21 -0
  194. package/dist/esm/components/Organisms/RecommendationBundle/BundleSelector.d.ts.map +1 -0
  195. package/dist/esm/components/Organisms/RecommendationBundle/BundleSelector.js +43 -0
  196. package/dist/esm/components/Organisms/RecommendationBundle/RecommendationBundle.d.ts +33 -0
  197. package/dist/esm/components/Organisms/RecommendationBundle/RecommendationBundle.d.ts.map +1 -0
  198. package/dist/esm/components/Organisms/RecommendationBundle/RecommendationBundle.js +339 -0
  199. package/dist/esm/components/Organisms/RecommendationBundle/index.d.ts +2 -0
  200. package/dist/esm/components/Organisms/RecommendationBundle/index.d.ts.map +1 -0
  201. package/dist/esm/components/Organisms/RecommendationBundle/index.js +1 -0
  202. package/dist/esm/components/Organisms/Results/Results.d.ts +1 -3
  203. package/dist/esm/components/Organisms/Results/Results.d.ts.map +1 -1
  204. package/dist/esm/components/Organisms/Results/Results.js +1 -1
  205. package/dist/esm/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.d.ts +1 -3
  206. package/dist/esm/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.d.ts.map +1 -1
  207. package/dist/esm/components/Trackers/Recommendation/ProfileTracker/RecommendationProfileTracker.js +1 -1
  208. package/dist/esm/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.d.ts +1 -3
  209. package/dist/esm/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.d.ts.map +1 -1
  210. package/dist/esm/components/Trackers/Recommendation/ResultTracker/RecommendationResultTracker.js +1 -1
  211. package/dist/esm/index.d.ts +1 -0
  212. package/dist/esm/index.d.ts.map +1 -1
  213. package/dist/esm/index.js +1 -0
  214. package/dist/esm/setupTests.d.ts +1 -0
  215. package/dist/esm/setupTests.d.ts.map +1 -1
  216. package/dist/esm/setupTests.js +1 -2
  217. package/dist/esm/toolbox/createHoverProps/createHoverProps.d.ts +1 -1
  218. package/dist/esm/toolbox/createHoverProps/createHoverProps.d.ts.map +1 -1
  219. package/dist/esm/types.d.ts +4 -4
  220. package/dist/esm/types.d.ts.map +1 -1
  221. package/dist/esm/utilities/defined.d.ts +1 -1
  222. package/dist/esm/utilities/defined.d.ts.map +1 -1
  223. 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 { SearchResultStore } from '@searchspring/snap-store-mobx';
5
+ import type { Product } from '@searchspring/snap-store-mobx';
6
6
  import { ComponentProps, BreakpointsProps } from '../../../types';
7
- export declare const Recommendation: ((properties: RecommendationProps) => JSX.Element) & {
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?: SearchResultStore;
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,iBAAiB,EAAW,MAAM,+BAA+B,CAAC;AAMhF,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAc,MAAM,gBAAgB,CAAC;AAe9E,eAAO,MAAM,cAAc,gBAAyB,mBAAmB,KAAG,WAAW;;CA+HnF,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,iBAAiB,CAAC;IAC5B,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,UAAU,EAAE,wBAAwB,CAAC;IACrC,QAAQ,CAAC,EAAE,iBAAiB,CAAC;IAC7B,QAAQ,CAAC,EAAE,OAAO,CAAC;CACnB"}
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 mobx_react_lite_1 = require("mobx-react-lite");
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, mobx_react_lite_1.observer)(function (properties) {
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,2 @@
1
+ export * from './RecommendationBundle';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -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: ((properties: ResultsProp) => JSX.Element) & {
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,gBAAyB,WAAW,KAAG,WAAW;;CA4GpE,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"}
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"}