@faststore/components 3.70.2 → 3.78.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 (89) hide show
  1. package/dist/cjs/hooks/index.d.ts +1 -0
  2. package/dist/cjs/hooks/index.d.ts.map +1 -1
  3. package/dist/cjs/hooks/index.js +3 -1
  4. package/dist/cjs/hooks/index.js.map +1 -1
  5. package/dist/cjs/hooks/useProductComparison.d.ts +2 -0
  6. package/dist/cjs/hooks/useProductComparison.d.ts.map +1 -0
  7. package/dist/cjs/hooks/useProductComparison.js +14 -0
  8. package/dist/cjs/hooks/useProductComparison.js.map +1 -0
  9. package/dist/cjs/index.d.ts +2 -0
  10. package/dist/cjs/index.d.ts.map +1 -1
  11. package/dist/cjs/index.js +6 -1
  12. package/dist/cjs/index.js.map +1 -1
  13. package/dist/cjs/molecules/ToggleField/ToggleField.d.ts +2 -1
  14. package/dist/cjs/molecules/ToggleField/ToggleField.d.ts.map +1 -1
  15. package/dist/cjs/molecules/ToggleField/ToggleField.js.map +1 -1
  16. package/dist/cjs/organisms/ProductComparison/ProductComparison.d.ts +7 -0
  17. package/dist/cjs/organisms/ProductComparison/ProductComparison.d.ts.map +1 -0
  18. package/dist/cjs/organisms/ProductComparison/ProductComparison.js +11 -0
  19. package/dist/cjs/organisms/ProductComparison/ProductComparison.js.map +1 -0
  20. package/dist/cjs/organisms/ProductComparison/ProductComparisonSidebar.d.ts +79 -0
  21. package/dist/cjs/organisms/ProductComparison/ProductComparisonSidebar.d.ts.map +1 -0
  22. package/dist/cjs/organisms/ProductComparison/ProductComparisonSidebar.js +135 -0
  23. package/dist/cjs/organisms/ProductComparison/ProductComparisonSidebar.js.map +1 -0
  24. package/dist/cjs/organisms/ProductComparison/ProductComparisonToolbar.d.ts +9 -0
  25. package/dist/cjs/organisms/ProductComparison/ProductComparisonToolbar.d.ts.map +1 -0
  26. package/dist/cjs/organisms/ProductComparison/ProductComparisonToolbar.js +25 -0
  27. package/dist/cjs/organisms/ProductComparison/ProductComparisonToolbar.js.map +1 -0
  28. package/dist/cjs/organisms/ProductComparison/ProductComparisonTrigger.d.ts +11 -0
  29. package/dist/cjs/organisms/ProductComparison/ProductComparisonTrigger.d.ts.map +1 -0
  30. package/dist/cjs/organisms/ProductComparison/ProductComparisonTrigger.js +18 -0
  31. package/dist/cjs/organisms/ProductComparison/ProductComparisonTrigger.js.map +1 -0
  32. package/dist/cjs/organisms/ProductComparison/index.d.ts +11 -0
  33. package/dist/cjs/organisms/ProductComparison/index.d.ts.map +1 -0
  34. package/dist/cjs/organisms/ProductComparison/index.js +17 -0
  35. package/dist/cjs/organisms/ProductComparison/index.js.map +1 -0
  36. package/dist/cjs/organisms/ProductComparison/provider/ProductComparisonProvider.d.ts +75 -0
  37. package/dist/cjs/organisms/ProductComparison/provider/ProductComparisonProvider.d.ts.map +1 -0
  38. package/dist/cjs/organisms/ProductComparison/provider/ProductComparisonProvider.js +50 -0
  39. package/dist/cjs/organisms/ProductComparison/provider/ProductComparisonProvider.js.map +1 -0
  40. package/dist/esm/hooks/index.d.ts +1 -0
  41. package/dist/esm/hooks/index.d.ts.map +1 -1
  42. package/dist/esm/hooks/index.js +1 -0
  43. package/dist/esm/hooks/index.js.map +1 -1
  44. package/dist/esm/hooks/useProductComparison.d.ts +2 -0
  45. package/dist/esm/hooks/useProductComparison.d.ts.map +1 -0
  46. package/dist/esm/hooks/useProductComparison.js +10 -0
  47. package/dist/esm/hooks/useProductComparison.js.map +1 -0
  48. package/dist/esm/index.d.ts +2 -0
  49. package/dist/esm/index.d.ts.map +1 -1
  50. package/dist/esm/index.js +1 -0
  51. package/dist/esm/index.js.map +1 -1
  52. package/dist/esm/molecules/ToggleField/ToggleField.d.ts +2 -1
  53. package/dist/esm/molecules/ToggleField/ToggleField.d.ts.map +1 -1
  54. package/dist/esm/molecules/ToggleField/ToggleField.js.map +1 -1
  55. package/dist/esm/organisms/ProductComparison/ProductComparison.d.ts +7 -0
  56. package/dist/esm/organisms/ProductComparison/ProductComparison.d.ts.map +1 -0
  57. package/dist/esm/organisms/ProductComparison/ProductComparison.js +8 -0
  58. package/dist/esm/organisms/ProductComparison/ProductComparison.js.map +1 -0
  59. package/dist/esm/organisms/ProductComparison/ProductComparisonSidebar.d.ts +79 -0
  60. package/dist/esm/organisms/ProductComparison/ProductComparisonSidebar.d.ts.map +1 -0
  61. package/dist/esm/organisms/ProductComparison/ProductComparisonSidebar.js +132 -0
  62. package/dist/esm/organisms/ProductComparison/ProductComparisonSidebar.js.map +1 -0
  63. package/dist/esm/organisms/ProductComparison/ProductComparisonToolbar.d.ts +9 -0
  64. package/dist/esm/organisms/ProductComparison/ProductComparisonToolbar.d.ts.map +1 -0
  65. package/dist/esm/organisms/ProductComparison/ProductComparisonToolbar.js +22 -0
  66. package/dist/esm/organisms/ProductComparison/ProductComparisonToolbar.js.map +1 -0
  67. package/dist/esm/organisms/ProductComparison/ProductComparisonTrigger.d.ts +11 -0
  68. package/dist/esm/organisms/ProductComparison/ProductComparisonTrigger.d.ts.map +1 -0
  69. package/dist/esm/organisms/ProductComparison/ProductComparisonTrigger.js +15 -0
  70. package/dist/esm/organisms/ProductComparison/ProductComparisonTrigger.js.map +1 -0
  71. package/dist/esm/organisms/ProductComparison/index.d.ts +11 -0
  72. package/dist/esm/organisms/ProductComparison/index.d.ts.map +1 -0
  73. package/dist/esm/organisms/ProductComparison/index.js +6 -0
  74. package/dist/esm/organisms/ProductComparison/index.js.map +1 -0
  75. package/dist/esm/organisms/ProductComparison/provider/ProductComparisonProvider.d.ts +75 -0
  76. package/dist/esm/organisms/ProductComparison/provider/ProductComparisonProvider.d.ts.map +1 -0
  77. package/dist/esm/organisms/ProductComparison/provider/ProductComparisonProvider.js +46 -0
  78. package/dist/esm/organisms/ProductComparison/provider/ProductComparisonProvider.js.map +1 -0
  79. package/package.json +2 -2
  80. package/src/hooks/index.ts +1 -0
  81. package/src/hooks/useProductComparison.ts +15 -0
  82. package/src/index.ts +14 -0
  83. package/src/molecules/ToggleField/ToggleField.tsx +2 -2
  84. package/src/organisms/ProductComparison/ProductComparison.tsx +24 -0
  85. package/src/organisms/ProductComparison/ProductComparisonSidebar.tsx +452 -0
  86. package/src/organisms/ProductComparison/ProductComparisonToolbar.tsx +78 -0
  87. package/src/organisms/ProductComparison/ProductComparisonTrigger.tsx +49 -0
  88. package/src/organisms/ProductComparison/index.ts +14 -0
  89. package/src/organisms/ProductComparison/provider/ProductComparisonProvider.tsx +144 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProductComparisonToolbar.js","sourceRoot":"","sources":["../../../../src/organisms/ProductComparison/ProductComparisonToolbar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,OAAO,CAAA;AACrC,OAAO,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAA;AAkBvE,MAAM,cAAc,GAAuB,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,UAAU,EAAE,EAAE,EAAE,CAAC,CAC1E,6BAAK,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,KAAM,UAAU,GAAI,CAC5C,CAAA;AAED,SAAS,wBAAwB,CAAC,EAChC,yBAAyB,EACzB,kBAAkB,EAClB,qBAAqB,GACS;IAC9B,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,aAAa,EAAE,GAAG,oBAAoB,EAAE,CAAA;IAE7E,MAAM,uBAAuB,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;IAEpD,IAAI,CAAC,QAAQ,CAAC,MAAM,IAAI,MAAM;QAAE,OAAO,IAAI,CAAA;IAE3C,OAAO,CACL;QACE;YACG,uBAAuB,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CACxC,oBAAC,cAAc,IACb,GAAG,EAAE,OAAO,CAAC,EAAE,EACf,GAAG,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,EACzB,GAAG,EAAE,OAAO,CAAC,IAAI,EACjB,KAAK,EAAE,EAAE,EACT,MAAM,EAAE,EAAE,GACV,CACH,CAAC;YAED,QAAQ,CAAC,MAAM,GAAG,CAAC,IAAI,CACtB;gBACE,+BAAI,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAK,CAC9B,CACP;YAEA,QAAQ,CAAC,MAAM,KAAK,CAAC,IAAI,CACxB,oBAAC,KAAK,kEACH,qBAAqB,CAChB,CACT,CACG;QAEN,oBAAC,MAAM,IAAC,OAAO,EAAC,UAAU,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,EAAE,IACtD,yBAAyB,CACnB;QACT,oBAAC,MAAM,IACL,OAAO,EAAC,SAAS,EACjB,QAAQ,EAAE,QAAQ,CAAC,MAAM,GAAG,CAAC,EAC7B,OAAO,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,IAE7B,QAAQ,CAAC,MAAM,GAAG,CAAC;YAClB,CAAC,CAAC,GAAG,kBAAkB,IAAI,QAAQ,CAAC,MAAM,EAAE;YAC5C,CAAC,CAAC,kBAAkB,CACf,CACF,CACV,CAAA;AACH,CAAC;AAED,eAAe,wBAAwB,CAAA"}
@@ -0,0 +1,11 @@
1
+ import React from 'react';
2
+ import type { IProductComparison } from '.';
3
+ import { type CheckboxFieldProps } from '../../molecules/CheckboxField';
4
+ export type ProductComparisonTriggerProps = CheckboxFieldProps & {
5
+ product: IProductComparison;
6
+ };
7
+ declare const ProductComparisonTrigger: React.ForwardRefExoticComponent<CheckboxFieldProps & {
8
+ product: IProductComparison;
9
+ } & React.RefAttributes<HTMLInputElement>>;
10
+ export default ProductComparisonTrigger;
11
+ //# sourceMappingURL=ProductComparisonTrigger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProductComparisonTrigger.d.ts","sourceRoot":"","sources":["../../../../src/organisms/ProductComparison/ProductComparisonTrigger.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqB,MAAM,OAAO,CAAA;AACzC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,GAAG,CAAA;AAC3C,OAAsB,EACpB,KAAK,kBAAkB,EACxB,MAAM,+BAA+B,CAAA;AAGtC,MAAM,MAAM,6BAA6B,GAAG,kBAAkB,GAAG;IAI/D,OAAO,EAAE,kBAAkB,CAAA;CAC5B,CAAA;AAED,QAAA,MAAM,wBAAwB;aAHnB,kBAAkB;0CAmC3B,CAAA;AAEF,eAAe,wBAAwB,CAAA"}
@@ -0,0 +1,15 @@
1
+ import React, { forwardRef } from 'react';
2
+ import CheckboxField from '../../molecules/CheckboxField';
3
+ import { useProductComparison } from '../../hooks/useProductComparison';
4
+ const ProductComparisonTrigger = forwardRef(function ProductComparisonTrigger({ id, label, onChange, product, ...otherProps }, ref) {
5
+ const { productIds, handleProductsIds } = useProductComparison();
6
+ const isSelected = productIds.some((productId) => productId === product.id);
7
+ return (React.createElement("div", { "data-fs-product-comparison-trigger": true }, product.hasSpecifications && (React.createElement(CheckboxField, { "data-fs-product-comparison-trigger-checkbox-field": true, ref: ref, id: `product-comparison-trigger-${id}`, label: label, checked: isSelected, onClick: (event) => {
8
+ event.stopPropagation();
9
+ }, onChange: (event) => {
10
+ onChange?.(event);
11
+ handleProductsIds(product);
12
+ }, ...otherProps }))));
13
+ });
14
+ export default ProductComparisonTrigger;
15
+ //# sourceMappingURL=ProductComparisonTrigger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProductComparisonTrigger.js","sourceRoot":"","sources":["../../../../src/organisms/ProductComparison/ProductComparisonTrigger.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAEzC,OAAO,aAEN,MAAM,+BAA+B,CAAA;AACtC,OAAO,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAA;AASvE,MAAM,wBAAwB,GAAG,UAAU,CAGzC,SAAS,wBAAwB,CACjC,EAAE,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,UAAU,EAAE,EAC/C,GAAG;IAEH,MAAM,EAAE,UAAU,EAAE,iBAAiB,EAAE,GAAG,oBAAoB,EAAE,CAAA;IAEhE,MAAM,UAAU,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,KAAK,OAAO,CAAC,EAAE,CAAC,CAAA;IAE3E,OAAO,CACL,2EACG,OAAO,CAAC,iBAAiB,IAAI,CAC5B,oBAAC,aAAa,+DAEZ,GAAG,EAAE,GAAG,EACR,EAAE,EAAE,8BAA8B,EAAE,EAAE,EACtC,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,UAAU,EACnB,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;YACjB,KAAK,CAAC,eAAe,EAAE,CAAA;QACzB,CAAC,EACD,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE;YAClB,QAAQ,EAAE,CAAC,KAAK,CAAC,CAAA;YACjB,iBAAiB,CAAC,OAAO,CAAC,CAAA;QAC5B,CAAC,KACG,UAAU,GACd,CACH,CACG,CACP,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,wBAAwB,CAAA"}
@@ -0,0 +1,11 @@
1
+ export { default } from './ProductComparison';
2
+ export type { ProductComparisonProps } from './ProductComparison';
3
+ export { default as ProductComparisonSidebar } from './ProductComparisonSidebar';
4
+ export type { ProductComparisonSidebarProps } from './ProductComparisonSidebar';
5
+ export { default as ProductComparisonToolbar } from './ProductComparisonToolbar';
6
+ export type { ProductComparisonToolbarProps } from './ProductComparisonToolbar';
7
+ export { default as ProductComparisonTrigger } from './ProductComparisonTrigger';
8
+ export type { ProductComparisonTriggerProps } from './ProductComparisonTrigger';
9
+ export { default as ProductComparisonProvider } from './provider/ProductComparisonProvider';
10
+ export type { IProductComparison } from './provider/ProductComparisonProvider';
11
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/organisms/ProductComparison/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAA;AAC7C,YAAY,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAA;AAEjE,OAAO,EAAE,OAAO,IAAI,wBAAwB,EAAE,MAAM,4BAA4B,CAAA;AAChF,YAAY,EAAE,6BAA6B,EAAE,MAAM,4BAA4B,CAAA;AAE/E,OAAO,EAAE,OAAO,IAAI,wBAAwB,EAAE,MAAM,4BAA4B,CAAA;AAChF,YAAY,EAAE,6BAA6B,EAAE,MAAM,4BAA4B,CAAA;AAE/E,OAAO,EAAE,OAAO,IAAI,wBAAwB,EAAE,MAAM,4BAA4B,CAAA;AAChF,YAAY,EAAE,6BAA6B,EAAE,MAAM,4BAA4B,CAAA;AAE/E,OAAO,EAAE,OAAO,IAAI,yBAAyB,EAAE,MAAM,sCAAsC,CAAA;AAC3F,YAAY,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAA"}
@@ -0,0 +1,6 @@
1
+ export { default } from './ProductComparison';
2
+ export { default as ProductComparisonSidebar } from './ProductComparisonSidebar';
3
+ export { default as ProductComparisonToolbar } from './ProductComparisonToolbar';
4
+ export { default as ProductComparisonTrigger } from './ProductComparisonTrigger';
5
+ export { default as ProductComparisonProvider } from './provider/ProductComparisonProvider';
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/organisms/ProductComparison/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAA;AAG7C,OAAO,EAAE,OAAO,IAAI,wBAAwB,EAAE,MAAM,4BAA4B,CAAA;AAGhF,OAAO,EAAE,OAAO,IAAI,wBAAwB,EAAE,MAAM,4BAA4B,CAAA;AAGhF,OAAO,EAAE,OAAO,IAAI,wBAAwB,EAAE,MAAM,4BAA4B,CAAA;AAGhF,OAAO,EAAE,OAAO,IAAI,yBAAyB,EAAE,MAAM,sCAAsC,CAAA"}
@@ -0,0 +1,75 @@
1
+ import React, { type ReactNode } from 'react';
2
+ export interface IProductComparison {
3
+ slug: string;
4
+ sku: string;
5
+ name: string;
6
+ gtin: string;
7
+ id: string;
8
+ unitMultiplier: number;
9
+ brand: {
10
+ name: string;
11
+ brandName: string;
12
+ };
13
+ isVariantOf: {
14
+ productGroupID: string;
15
+ name: string;
16
+ skuVariants: {
17
+ activeVariations: any | null;
18
+ slugsMap: any | null;
19
+ availableVariations: any | null;
20
+ allVariantProducts: Array<{
21
+ name: string;
22
+ productID: string;
23
+ }> | null;
24
+ };
25
+ };
26
+ image: Array<{
27
+ url: string;
28
+ alternateName: string;
29
+ }>;
30
+ offers: {
31
+ lowPrice: number;
32
+ lowPriceWithTaxes: number;
33
+ offers: Array<{
34
+ availability: string;
35
+ price: number;
36
+ listPrice: number;
37
+ listPriceWithTaxes: number;
38
+ priceWithTaxes: number;
39
+ quantity: number;
40
+ seller: {
41
+ identifier: string;
42
+ };
43
+ }>;
44
+ };
45
+ additionalProperty: Array<{
46
+ propertyID: string;
47
+ name: string;
48
+ value: any;
49
+ valueReference: any;
50
+ }>;
51
+ advertisement: {
52
+ adId: string;
53
+ adResponseId: string;
54
+ } | null;
55
+ hasSpecifications?: boolean;
56
+ skuSpecifications?: Array<{
57
+ field: string;
58
+ values: string[];
59
+ }>;
60
+ }
61
+ export interface ProductComparisonProviderContextValue {
62
+ isOpen: boolean;
63
+ setIsOpen: (isOpen: boolean) => void;
64
+ productIds: string[];
65
+ products: IProductComparison[];
66
+ handleProductsIds: (product: IProductComparison) => void;
67
+ handleProductsComparison: (products: IProductComparison[]) => void;
68
+ clearProducts: () => void;
69
+ }
70
+ export declare const ProductComparisonContext: React.Context<ProductComparisonProviderContextValue | undefined>;
71
+ declare function ProductComparisonProvider({ children }: {
72
+ children: ReactNode;
73
+ }): React.JSX.Element;
74
+ export default ProductComparisonProvider;
75
+ //# sourceMappingURL=ProductComparisonProvider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProductComparisonProvider.d.ts","sourceRoot":"","sources":["../../../../../src/organisms/ProductComparison/provider/ProductComparisonProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAEZ,KAAK,SAAS,EAGf,MAAM,OAAO,CAAA;AAEd,MAAM,WAAW,kBAAkB;IACjC,IAAI,EAAE,MAAM,CAAA;IACZ,GAAG,EAAE,MAAM,CAAA;IACX,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,EAAE,MAAM,CAAA;IACZ,EAAE,EAAE,MAAM,CAAA;IACV,cAAc,EAAE,MAAM,CAAA;IACtB,KAAK,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE,CAAA;IAC1C,WAAW,EAAE;QACX,cAAc,EAAE,MAAM,CAAA;QACtB,IAAI,EAAE,MAAM,CAAA;QACZ,WAAW,EAAE;YACX,gBAAgB,EAAE,GAAG,GAAG,IAAI,CAAA;YAC5B,QAAQ,EAAE,GAAG,GAAG,IAAI,CAAA;YACpB,mBAAmB,EAAE,GAAG,GAAG,IAAI,CAAA;YAC/B,kBAAkB,EAAE,KAAK,CAAC;gBACxB,IAAI,EAAE,MAAM,CAAA;gBACZ,SAAS,EAAE,MAAM,CAAA;aAClB,CAAC,GAAG,IAAI,CAAA;SACV,CAAA;KACF,CAAA;IACD,KAAK,EAAE,KAAK,CAAC;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,aAAa,EAAE,MAAM,CAAA;KAAE,CAAC,CAAA;IACpD,MAAM,EAAE;QACN,QAAQ,EAAE,MAAM,CAAA;QAChB,iBAAiB,EAAE,MAAM,CAAA;QACzB,MAAM,EAAE,KAAK,CAAC;YACZ,YAAY,EAAE,MAAM,CAAA;YACpB,KAAK,EAAE,MAAM,CAAA;YACb,SAAS,EAAE,MAAM,CAAA;YACjB,kBAAkB,EAAE,MAAM,CAAA;YAC1B,cAAc,EAAE,MAAM,CAAA;YACtB,QAAQ,EAAE,MAAM,CAAA;YAChB,MAAM,EAAE;gBAAE,UAAU,EAAE,MAAM,CAAA;aAAE,CAAA;SAC/B,CAAC,CAAA;KACH,CAAA;IACD,kBAAkB,EAAE,KAAK,CAAC;QACxB,UAAU,EAAE,MAAM,CAAA;QAClB,IAAI,EAAE,MAAM,CAAA;QACZ,KAAK,EAAE,GAAG,CAAA;QACV,cAAc,EAAE,GAAG,CAAA;KACpB,CAAC,CAAA;IACF,aAAa,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAA;IAC5D,iBAAiB,CAAC,EAAE,OAAO,CAAA;IAC3B,iBAAiB,CAAC,EAAE,KAAK,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,EAAE,CAAA;KAAE,CAAC,CAAA;CAC/D;AAED,MAAM,WAAW,qCAAqC;IAIpD,MAAM,EAAE,OAAO,CAAA;IAIf,SAAS,EAAE,CAAC,MAAM,EAAE,OAAO,KAAK,IAAI,CAAA;IAIpC,UAAU,EAAE,MAAM,EAAE,CAAA;IAIpB,QAAQ,EAAE,kBAAkB,EAAE,CAAA;IAI9B,iBAAiB,EAAE,CAAC,OAAO,EAAE,kBAAkB,KAAK,IAAI,CAAA;IAIxD,wBAAwB,EAAE,CAAC,QAAQ,EAAE,kBAAkB,EAAE,KAAK,IAAI,CAAA;IAIlE,aAAa,EAAE,MAAM,IAAI,CAAA;CAC1B;AAED,eAAO,MAAM,wBAAwB,kEAEzB,CAAA;AAEZ,iBAAS,yBAAyB,CAAC,EAAE,QAAQ,EAAE,EAAE;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,qBAqDvE;AAED,eAAe,yBAAyB,CAAA"}
@@ -0,0 +1,46 @@
1
+ import React, { createContext, useCallback, useState, } from 'react';
2
+ export const ProductComparisonContext = createContext(undefined);
3
+ function ProductComparisonProvider({ children }) {
4
+ const [productIds, setProductIds] = useState([]);
5
+ const [products, setProducts] = useState([]);
6
+ const [isOpen, setIsOpen] = useState(false);
7
+ const handleProductsIds = useCallback((product) => {
8
+ setProductIds((prev) => {
9
+ if (prev.includes(product?.id)) {
10
+ return prev.filter((id) => id !== product.id);
11
+ }
12
+ return [...prev, product.id];
13
+ });
14
+ setProducts((prev) => {
15
+ if (prev.some((p) => p.id === product.id)) {
16
+ return prev.filter((p) => p.id !== product.id);
17
+ }
18
+ return [...prev, product];
19
+ });
20
+ }, []);
21
+ function handleProductsComparison(products) {
22
+ const productSelectedWithFullData = products.map((product) => {
23
+ const productAlreadySelected = products.find((p) => p.id === product.id);
24
+ return {
25
+ ...product,
26
+ ...productAlreadySelected,
27
+ };
28
+ });
29
+ setProducts(productSelectedWithFullData);
30
+ }
31
+ function clearProducts() {
32
+ setProductIds([]);
33
+ setProducts([]);
34
+ }
35
+ return (React.createElement(ProductComparisonContext.Provider, { value: {
36
+ isOpen,
37
+ setIsOpen,
38
+ productIds,
39
+ products,
40
+ handleProductsIds,
41
+ handleProductsComparison,
42
+ clearProducts,
43
+ } }, children));
44
+ }
45
+ export default ProductComparisonProvider;
46
+ //# sourceMappingURL=ProductComparisonProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProductComparisonProvider.js","sourceRoot":"","sources":["../../../../../src/organisms/ProductComparison/provider/ProductComparisonProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EACZ,aAAa,EAEb,WAAW,EACX,QAAQ,GACT,MAAM,OAAO,CAAA;AA+Ed,MAAM,CAAC,MAAM,wBAAwB,GAAG,aAAa,CAEnD,SAAS,CAAC,CAAA;AAEZ,SAAS,yBAAyB,CAAC,EAAE,QAAQ,EAA2B;IACtE,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAW,EAAE,CAAC,CAAA;IAC1D,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAuB,EAAE,CAAC,CAAA;IAClE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAE3C,MAAM,iBAAiB,GAAG,WAAW,CAAC,CAAC,OAA2B,EAAE,EAAE;QACpE,aAAa,CAAC,CAAC,IAAI,EAAE,EAAE;YACrB,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,CAAC;gBAC/B,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,OAAO,CAAC,EAAE,CAAC,CAAA;YAC/C,CAAC;YACD,OAAO,CAAC,GAAG,IAAI,EAAE,OAAO,CAAC,EAAE,CAAC,CAAA;QAC9B,CAAC,CAAC,CAAA;QAEF,WAAW,CAAC,CAAC,IAAI,EAAE,EAAE;YACnB,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC1C,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC,EAAE,CAAC,CAAA;YAChD,CAAC;YACD,OAAO,CAAC,GAAG,IAAI,EAAE,OAAO,CAAC,CAAA;QAC3B,CAAC,CAAC,CAAA;IACJ,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,SAAS,wBAAwB,CAAC,QAA8B;QAC9D,MAAM,2BAA2B,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YAC3D,MAAM,sBAAsB,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC,EAAE,CAAC,CAAA;YACxE,OAAO;gBACL,GAAG,OAAO;gBACV,GAAG,sBAAsB;aAC1B,CAAA;QACH,CAAC,CAAC,CAAA;QAEF,WAAW,CAAC,2BAA2B,CAAC,CAAA;IAC1C,CAAC;IAED,SAAS,aAAa;QACpB,aAAa,CAAC,EAAE,CAAC,CAAA;QACjB,WAAW,CAAC,EAAE,CAAC,CAAA;IACjB,CAAC;IAED,OAAO,CACL,oBAAC,wBAAwB,CAAC,QAAQ,IAChC,KAAK,EAAE;YACL,MAAM;YACN,SAAS;YACT,UAAU;YACV,QAAQ;YACR,iBAAiB;YACjB,wBAAwB;YACxB,aAAa;SACd,IAEA,QAAQ,CACyB,CACrC,CAAA;AACH,CAAC;AAED,eAAe,yBAAyB,CAAA"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@faststore/components",
3
- "version": "3.70.2",
3
+ "version": "3.78.0",
4
4
  "main": "dist/cjs/index.js",
5
5
  "module": "dist/esm/index.js",
6
6
  "typings": "dist/esm/index.d.ts",
@@ -56,5 +56,5 @@
56
56
  "volta": {
57
57
  "extends": "../../package.json"
58
58
  },
59
- "gitHead": "9388d1dd171b76fa3ccb77ec3a5327b2ca9a01fc"
59
+ "gitHead": "e4853a8c962f5ba4527694ea4b60984fa21e1208"
60
60
  }
@@ -18,3 +18,4 @@ export type {
18
18
  } from './useSlider'
19
19
  export { useSlideVisibility } from './useSlideVisibility'
20
20
  export { useTrapFocus } from './useTrapFocus'
21
+ export { useProductComparison } from './useProductComparison'
@@ -0,0 +1,15 @@
1
+ import { useContext } from 'react'
2
+
3
+ import { ProductComparisonContext } from '../organisms/ProductComparison/provider/ProductComparisonProvider'
4
+
5
+ export function useProductComparison() {
6
+ const context = useContext(ProductComparisonContext)
7
+
8
+ if (context === undefined) {
9
+ throw new Error(
10
+ 'useProductComparison must be used within a ProductComparisonProvider'
11
+ )
12
+ }
13
+
14
+ return context
15
+ }
package/src/index.ts CHANGED
@@ -337,6 +337,20 @@ export type { PaymentMethodsProps } from './organisms/PaymentMethods'
337
337
  export { default as PriceRange } from './organisms/PriceRange'
338
338
  export type { PriceRangeProps } from './organisms/PriceRange'
339
339
 
340
+ export {
341
+ default as ProductComparison,
342
+ ProductComparisonTrigger,
343
+ ProductComparisonToolbar,
344
+ ProductComparisonSidebar,
345
+ } from './organisms/ProductComparison'
346
+ export type {
347
+ IProductComparison,
348
+ ProductComparisonProps,
349
+ ProductComparisonTriggerProps,
350
+ ProductComparisonToolbarProps,
351
+ ProductComparisonSidebarProps,
352
+ } from './organisms/ProductComparison'
353
+
340
354
  export {
341
355
  default as ProductGrid,
342
356
  ProductGridItem,
@@ -1,7 +1,7 @@
1
1
  import React, { forwardRef } from 'react'
2
- import { Label, SROnly, Toggle } from './../../'
2
+ import { Label, SROnly, Toggle, type ToggleProps } from './../../'
3
3
 
4
- export interface ToggleFieldProps {
4
+ export interface ToggleFieldProps extends ToggleProps {
5
5
  /**
6
6
  * ID to find this component in testing tools (e.g.: cypress, testing library, and jest).
7
7
  */
@@ -0,0 +1,24 @@
1
+ import React, { forwardRef, type HTMLAttributes } from 'react'
2
+ import { ProductComparisonProvider } from '.'
3
+
4
+ export interface ProductComparisonProps extends HTMLAttributes<HTMLDivElement> {
5
+ /*
6
+ * ID to find this component in testing tools (e.g.: cypress, testing library, and jest).
7
+ */
8
+ testId?: string
9
+ }
10
+
11
+ const ProductComparison = forwardRef<HTMLDivElement, ProductComparisonProps>(
12
+ function ProductComparison(
13
+ { testId = 'fs-product-comparison', children, ...otherProps },
14
+ ref
15
+ ) {
16
+ return (
17
+ <div ref={ref} data-testid={testId} {...otherProps}>
18
+ <ProductComparisonProvider>{children}</ProductComparisonProvider>
19
+ </div>
20
+ )
21
+ }
22
+ )
23
+
24
+ export default ProductComparison