@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.
- package/dist/cjs/hooks/index.d.ts +1 -0
- package/dist/cjs/hooks/index.d.ts.map +1 -1
- package/dist/cjs/hooks/index.js +3 -1
- package/dist/cjs/hooks/index.js.map +1 -1
- package/dist/cjs/hooks/useProductComparison.d.ts +2 -0
- package/dist/cjs/hooks/useProductComparison.d.ts.map +1 -0
- package/dist/cjs/hooks/useProductComparison.js +14 -0
- package/dist/cjs/hooks/useProductComparison.js.map +1 -0
- package/dist/cjs/index.d.ts +2 -0
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +6 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/molecules/ToggleField/ToggleField.d.ts +2 -1
- package/dist/cjs/molecules/ToggleField/ToggleField.d.ts.map +1 -1
- package/dist/cjs/molecules/ToggleField/ToggleField.js.map +1 -1
- package/dist/cjs/organisms/ProductComparison/ProductComparison.d.ts +7 -0
- package/dist/cjs/organisms/ProductComparison/ProductComparison.d.ts.map +1 -0
- package/dist/cjs/organisms/ProductComparison/ProductComparison.js +11 -0
- package/dist/cjs/organisms/ProductComparison/ProductComparison.js.map +1 -0
- package/dist/cjs/organisms/ProductComparison/ProductComparisonSidebar.d.ts +79 -0
- package/dist/cjs/organisms/ProductComparison/ProductComparisonSidebar.d.ts.map +1 -0
- package/dist/cjs/organisms/ProductComparison/ProductComparisonSidebar.js +135 -0
- package/dist/cjs/organisms/ProductComparison/ProductComparisonSidebar.js.map +1 -0
- package/dist/cjs/organisms/ProductComparison/ProductComparisonToolbar.d.ts +9 -0
- package/dist/cjs/organisms/ProductComparison/ProductComparisonToolbar.d.ts.map +1 -0
- package/dist/cjs/organisms/ProductComparison/ProductComparisonToolbar.js +25 -0
- package/dist/cjs/organisms/ProductComparison/ProductComparisonToolbar.js.map +1 -0
- package/dist/cjs/organisms/ProductComparison/ProductComparisonTrigger.d.ts +11 -0
- package/dist/cjs/organisms/ProductComparison/ProductComparisonTrigger.d.ts.map +1 -0
- package/dist/cjs/organisms/ProductComparison/ProductComparisonTrigger.js +18 -0
- package/dist/cjs/organisms/ProductComparison/ProductComparisonTrigger.js.map +1 -0
- package/dist/cjs/organisms/ProductComparison/index.d.ts +11 -0
- package/dist/cjs/organisms/ProductComparison/index.d.ts.map +1 -0
- package/dist/cjs/organisms/ProductComparison/index.js +17 -0
- package/dist/cjs/organisms/ProductComparison/index.js.map +1 -0
- package/dist/cjs/organisms/ProductComparison/provider/ProductComparisonProvider.d.ts +75 -0
- package/dist/cjs/organisms/ProductComparison/provider/ProductComparisonProvider.d.ts.map +1 -0
- package/dist/cjs/organisms/ProductComparison/provider/ProductComparisonProvider.js +50 -0
- package/dist/cjs/organisms/ProductComparison/provider/ProductComparisonProvider.js.map +1 -0
- package/dist/esm/hooks/index.d.ts +1 -0
- package/dist/esm/hooks/index.d.ts.map +1 -1
- package/dist/esm/hooks/index.js +1 -0
- package/dist/esm/hooks/index.js.map +1 -1
- package/dist/esm/hooks/useProductComparison.d.ts +2 -0
- package/dist/esm/hooks/useProductComparison.d.ts.map +1 -0
- package/dist/esm/hooks/useProductComparison.js +10 -0
- package/dist/esm/hooks/useProductComparison.js.map +1 -0
- package/dist/esm/index.d.ts +2 -0
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +1 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/molecules/ToggleField/ToggleField.d.ts +2 -1
- package/dist/esm/molecules/ToggleField/ToggleField.d.ts.map +1 -1
- package/dist/esm/molecules/ToggleField/ToggleField.js.map +1 -1
- package/dist/esm/organisms/ProductComparison/ProductComparison.d.ts +7 -0
- package/dist/esm/organisms/ProductComparison/ProductComparison.d.ts.map +1 -0
- package/dist/esm/organisms/ProductComparison/ProductComparison.js +8 -0
- package/dist/esm/organisms/ProductComparison/ProductComparison.js.map +1 -0
- package/dist/esm/organisms/ProductComparison/ProductComparisonSidebar.d.ts +79 -0
- package/dist/esm/organisms/ProductComparison/ProductComparisonSidebar.d.ts.map +1 -0
- package/dist/esm/organisms/ProductComparison/ProductComparisonSidebar.js +132 -0
- package/dist/esm/organisms/ProductComparison/ProductComparisonSidebar.js.map +1 -0
- package/dist/esm/organisms/ProductComparison/ProductComparisonToolbar.d.ts +9 -0
- package/dist/esm/organisms/ProductComparison/ProductComparisonToolbar.d.ts.map +1 -0
- package/dist/esm/organisms/ProductComparison/ProductComparisonToolbar.js +22 -0
- package/dist/esm/organisms/ProductComparison/ProductComparisonToolbar.js.map +1 -0
- package/dist/esm/organisms/ProductComparison/ProductComparisonTrigger.d.ts +11 -0
- package/dist/esm/organisms/ProductComparison/ProductComparisonTrigger.d.ts.map +1 -0
- package/dist/esm/organisms/ProductComparison/ProductComparisonTrigger.js +15 -0
- package/dist/esm/organisms/ProductComparison/ProductComparisonTrigger.js.map +1 -0
- package/dist/esm/organisms/ProductComparison/index.d.ts +11 -0
- package/dist/esm/organisms/ProductComparison/index.d.ts.map +1 -0
- package/dist/esm/organisms/ProductComparison/index.js +6 -0
- package/dist/esm/organisms/ProductComparison/index.js.map +1 -0
- package/dist/esm/organisms/ProductComparison/provider/ProductComparisonProvider.d.ts +75 -0
- package/dist/esm/organisms/ProductComparison/provider/ProductComparisonProvider.d.ts.map +1 -0
- package/dist/esm/organisms/ProductComparison/provider/ProductComparisonProvider.js +46 -0
- package/dist/esm/organisms/ProductComparison/provider/ProductComparisonProvider.js.map +1 -0
- package/package.json +2 -2
- package/src/hooks/index.ts +1 -0
- package/src/hooks/useProductComparison.ts +15 -0
- package/src/index.ts +14 -0
- package/src/molecules/ToggleField/ToggleField.tsx +2 -2
- package/src/organisms/ProductComparison/ProductComparison.tsx +24 -0
- package/src/organisms/ProductComparison/ProductComparisonSidebar.tsx +452 -0
- package/src/organisms/ProductComparison/ProductComparisonToolbar.tsx +78 -0
- package/src/organisms/ProductComparison/ProductComparisonTrigger.tsx +49 -0
- package/src/organisms/ProductComparison/index.ts +14 -0
- 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.
|
|
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": "
|
|
59
|
+
"gitHead": "e4853a8c962f5ba4527694ea4b60984fa21e1208"
|
|
60
60
|
}
|
package/src/hooks/index.ts
CHANGED
|
@@ -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
|