@faststore/components 3.4.4 → 3.7.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 (62) hide show
  1. package/dist/cjs/hooks/index.d.ts +1 -0
  2. package/dist/cjs/hooks/index.js +3 -1
  3. package/dist/cjs/hooks/index.js.map +1 -1
  4. package/dist/cjs/hooks/useSKUMatrix.d.ts +1 -0
  5. package/dist/cjs/hooks/useSKUMatrix.js +14 -0
  6. package/dist/cjs/hooks/useSKUMatrix.js.map +1 -0
  7. package/dist/cjs/index.d.ts +2 -0
  8. package/dist/cjs/index.js +5 -1
  9. package/dist/cjs/index.js.map +1 -1
  10. package/dist/cjs/molecules/Breadcrumb/BreadcrumbBase.js +9 -4
  11. package/dist/cjs/molecules/Breadcrumb/BreadcrumbBase.js.map +1 -1
  12. package/dist/cjs/organisms/SKUMatrix/SKUMatrix.d.ts +9 -0
  13. package/dist/cjs/organisms/SKUMatrix/SKUMatrix.js +11 -0
  14. package/dist/cjs/organisms/SKUMatrix/SKUMatrix.js.map +1 -0
  15. package/dist/cjs/organisms/SKUMatrix/SKUMatrixSidebar.d.ts +45 -0
  16. package/dist/cjs/organisms/SKUMatrix/SKUMatrixSidebar.js +93 -0
  17. package/dist/cjs/organisms/SKUMatrix/SKUMatrixSidebar.js.map +1 -0
  18. package/dist/cjs/organisms/SKUMatrix/SKUMatrixTrigger.d.ts +5 -0
  19. package/dist/cjs/organisms/SKUMatrix/SKUMatrixTrigger.js +15 -0
  20. package/dist/cjs/organisms/SKUMatrix/SKUMatrixTrigger.js.map +1 -0
  21. package/dist/cjs/organisms/SKUMatrix/index.d.ts +6 -0
  22. package/dist/cjs/organisms/SKUMatrix/index.js +13 -0
  23. package/dist/cjs/organisms/SKUMatrix/index.js.map +1 -0
  24. package/dist/cjs/organisms/SKUMatrix/provider/SKUMatrixProvider.d.ts +49 -0
  25. package/dist/cjs/organisms/SKUMatrix/provider/SKUMatrixProvider.js +28 -0
  26. package/dist/cjs/organisms/SKUMatrix/provider/SKUMatrixProvider.js.map +1 -0
  27. package/dist/esm/hooks/index.d.ts +1 -0
  28. package/dist/esm/hooks/index.js +1 -0
  29. package/dist/esm/hooks/index.js.map +1 -1
  30. package/dist/esm/hooks/useSKUMatrix.d.ts +1 -0
  31. package/dist/esm/hooks/useSKUMatrix.js +10 -0
  32. package/dist/esm/hooks/useSKUMatrix.js.map +1 -0
  33. package/dist/esm/index.d.ts +2 -0
  34. package/dist/esm/index.js +1 -0
  35. package/dist/esm/index.js.map +1 -1
  36. package/dist/esm/molecules/Breadcrumb/BreadcrumbBase.js +10 -5
  37. package/dist/esm/molecules/Breadcrumb/BreadcrumbBase.js.map +1 -1
  38. package/dist/esm/organisms/SKUMatrix/SKUMatrix.d.ts +9 -0
  39. package/dist/esm/organisms/SKUMatrix/SKUMatrix.js +8 -0
  40. package/dist/esm/organisms/SKUMatrix/SKUMatrix.js.map +1 -0
  41. package/dist/esm/organisms/SKUMatrix/SKUMatrixSidebar.d.ts +45 -0
  42. package/dist/esm/organisms/SKUMatrix/SKUMatrixSidebar.js +90 -0
  43. package/dist/esm/organisms/SKUMatrix/SKUMatrixSidebar.js.map +1 -0
  44. package/dist/esm/organisms/SKUMatrix/SKUMatrixTrigger.d.ts +5 -0
  45. package/dist/esm/organisms/SKUMatrix/SKUMatrixTrigger.js +12 -0
  46. package/dist/esm/organisms/SKUMatrix/SKUMatrixTrigger.js.map +1 -0
  47. package/dist/esm/organisms/SKUMatrix/index.d.ts +6 -0
  48. package/dist/esm/organisms/SKUMatrix/index.js +4 -0
  49. package/dist/esm/organisms/SKUMatrix/index.js.map +1 -0
  50. package/dist/esm/organisms/SKUMatrix/provider/SKUMatrixProvider.d.ts +49 -0
  51. package/dist/esm/organisms/SKUMatrix/provider/SKUMatrixProvider.js +24 -0
  52. package/dist/esm/organisms/SKUMatrix/provider/SKUMatrixProvider.js.map +1 -0
  53. package/package.json +4 -4
  54. package/src/hooks/index.ts +1 -2
  55. package/src/hooks/useSKUMatrix.ts +15 -0
  56. package/src/index.ts +11 -0
  57. package/src/molecules/Breadcrumb/BreadcrumbBase.tsx +52 -24
  58. package/src/organisms/SKUMatrix/SKUMatrix.tsx +22 -0
  59. package/src/organisms/SKUMatrix/SKUMatrixSidebar.tsx +297 -0
  60. package/src/organisms/SKUMatrix/SKUMatrixTrigger.tsx +31 -0
  61. package/src/organisms/SKUMatrix/index.ts +8 -0
  62. package/src/organisms/SKUMatrix/provider/SKUMatrixProvider.tsx +104 -0
@@ -1 +1 @@
1
- {"version":3,"file":"BreadcrumbBase.js","sourceRoot":"","sources":["../../../../src/molecules/Breadcrumb/BreadcrumbBase.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"BreadcrumbBase.js","sourceRoot":"","sources":["../../../../src/molecules/Breadcrumb/BreadcrumbBase.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EACZ,YAAY,EAEZ,UAAU,EACV,IAAI,EAIJ,QAAQ,EACR,WAAW,GACZ,MAAM,OAAO,CAAA;AACd,OAAO,IAAI,MAAM,kBAAkB,CAAA;AACnC,OAAO,IAAI,MAAM,kBAAkB,CAAA;AAOnC,OAAO,cAAuC,MAAM,kBAAkB,CAAA;AAEtE,MAAM,QAAQ,GAAG,IAAI,CACnB,GAAG,EAAE,CAAC,MAAM,CAAC,kCAAkC,CAAC,sBAAsB,CAAC,CACxE,CAAA;AAED,MAAM,cAAc,GAAG,IAAI,CACzB,GAAG,EAAE,CACH,MAAM;AACJ,wCAAwC,CAAC,4BAA4B,CACtE,CACJ,CAAA;AAED,MAAM,YAAY,GAAG,IAAI,CACvB,GAAG,EAAE,CACH,MAAM,CAAC,sCAAsC,CAAC,0BAA0B,CAAC,CAC5E,CAAA;AAED,MAAM,YAAY,GAAG,IAAI,CACvB,GAAG,EAAE,CACH,MAAM,CAAC,sCAAsC,CAAC,0BAA0B,CAAC,CAC5E,CAAA;AAgDD,MAAM,cAAc,GAAG,UAAU,CAC/B,SAAS,cAAc,CACrB,EACE,QAAQ,EACR,OAAO,EAAE,UAAU,GAAG,EAAE,EACxB,MAAM,GAAG,eAAe,EACxB,cAAc,EACd,SAAS,GAAG,KAAK,EACjB,UAAU,EACV,QAAQ,EACR,kBAAkB,GAAG,oBAAC,IAAI,IAAC,IAAI,EAAC,WAAW,GAAG,EAC9C,kBAAkB,GAAG,CACnB,oBAAC,IAAI,wCAA4B,IAAI,EAAC,qBAAqB,GAAG,CAC/D,EACD,GAAG,UAAU,EACd,EACD,GAAG;IAEH,MAAM,SAAS,GAAG,SAAS,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;IACtD,MAAM,WAAW,GAAG,SAAS;QAC3B,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC7B,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;IAE/B,MAAM,SAAS,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAA;IAE1C,MAAM,kBAAkB,GAAG,cAAc,CAAC,MAAM,GAAG,CAAC,CAAA;IAEpD,MAAM,cAAc,GAAG,WAAW,CAChC,CAAC,eAAgC,EAAE,EAAE;QACnC,MAAM,cAAc,GAAG,UAAU,EAAE,CAAC,eAAe,CAAC,CAAA;QACpD,MAAM,SAAS,GAAG,eAAe,CAAC,SAAS;YACzC,CAAC,CAAC;gBACE,kCAAkC,EAAE,IAAI;aACzC;YACH,CAAC,CAAC;gBACE,yBAAyB,EAAE,IAAI;aAChC,CAAA;QACL,OAAO,cAAc,CAAC,CAAC,CAAC,CACtB,YAAY,CAAC,cAAc,EAAE;YAC3B,GAAG,SAAS;YACZ,GAAG,EAAE,eAAe,CAAC,SAAS,CAAC,QAAQ;SACxC,CAAC,CACH,CAAC,CAAC,CAAC,CACF,oBAAC,IAAI,OACC,SAAS,EACb,IAAI,EAAE,eAAe,CAAC,SAAS,CAAC,IAAI,EACpC,GAAG,EAAE,eAAe,CAAC,SAAS,CAAC,QAAQ,IAEtC,eAAe,CAAC,SAAS,CAAC,IAAI,CAC1B,CACR,CAAA;IACH,CAAC,EACD,CAAC,UAAU,CAAC,CACb,CAAA;IAED,OAAO,CACL,oBAAC,cAAc,IACb,GAAG,EAAE,GAAG,mCACuB,SAAS,KACpC,UAAU;QAEb,QAAQ;QAER,CAAC,kBAAkB;YAClB,cAAc,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;gBACjC,OAAO,cAAc,CAAC,MAAM,KAAK,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAC3C,8BAAM,GAAG,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAG,IAAI,CAAC,IAAI,CAAQ,CACrD,CAAC,CAAC,CAAC,CACF,cAAc,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CACtD,CAAA;YACH,CAAC,CAAC;QAEH,kBAAkB;YACjB,SAAS;YACT,cAAc,CAAC,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;QAE3D,kBAAkB,IAAI,CACrB,oBAAC,QAAQ;YACP,oBAAC,QAAQ;gBACP,oBAAC,cAAc,kBACF,WAAW,8CAEtB,IAAI,EAAC,OAAO,IAEX,kBAAkB,CACJ;gBACjB,oBAAC,YAAY,gDACV,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CACzB,oBAAC,YAAY,8CAEX,GAAG,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,EAC1B,IAAI,EAAE,kBAAkB,IAEvB,cAAc,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CACxC,CAChB,CAAC,CACW,CACN,CACF,CACZ;QAEA,kBAAkB;YACjB,SAAS,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;gBAC5B,OAAO,SAAS,CAAC,MAAM,KAAK,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CACtC,8BAAM,GAAG,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAG,IAAI,CAAC,IAAI,CAAQ,CACrD,CAAC,CAAC,CAAC,CACF,cAAc,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CACtD,CAAA;YACH,CAAC,CAAC,CACW,CAClB,CAAA;AACH,CAAC,CACF,CAAA;AAED,eAAe,cAAc,CAAA"}
@@ -0,0 +1,9 @@
1
+ import React, { HTMLAttributes } from 'react';
2
+ export interface SKUMatrixProps extends HTMLAttributes<HTMLDivElement> {
3
+ /**
4
+ * ID to find this component in testing tools (e.g.: cypress, testing library, and jest).
5
+ */
6
+ testId?: string;
7
+ }
8
+ declare const SKUMatrix: React.ForwardRefExoticComponent<SKUMatrixProps & React.RefAttributes<HTMLDivElement>>;
9
+ export default SKUMatrix;
@@ -0,0 +1,8 @@
1
+ import React, { forwardRef } from 'react';
2
+ import SKUMatrixProvider from './provider/SKUMatrixProvider';
3
+ const SKUMatrix = forwardRef(function SKUMatrix({ testId = 'fs-sku-matrix', children, ...otherProps }, ref) {
4
+ return (React.createElement("div", { ref: ref, "data-fs-sku-matrix": true, "data-testid": testId, ...otherProps },
5
+ React.createElement(SKUMatrixProvider, null, children)));
6
+ });
7
+ export default SKUMatrix;
8
+ //# sourceMappingURL=SKUMatrix.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SKUMatrix.js","sourceRoot":"","sources":["../../../../src/organisms/SKUMatrix/SKUMatrix.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAkB,MAAM,OAAO,CAAA;AACzD,OAAO,iBAAiB,MAAM,8BAA8B,CAAA;AAS5D,MAAM,SAAS,GAAG,UAAU,CAAiC,SAAS,SAAS,CAC7E,EAAE,MAAM,GAAG,eAAe,EAAE,QAAQ,EAAE,GAAG,UAAU,EAAE,EACrD,GAAG;IAEH,OAAO,CACL,6BAAK,GAAG,EAAE,GAAG,6CAAkC,MAAM,KAAM,UAAU;QACnE,oBAAC,iBAAiB,QAAE,QAAQ,CAAqB,CAC7C,CACP,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,SAAS,CAAA"}
@@ -0,0 +1,45 @@
1
+ import React from 'react';
2
+ import { PriceFormatter } from '../../atoms/Price';
3
+ import { SlideOverProps } from '../SlideOver';
4
+ interface VariationProductColumn {
5
+ name: string;
6
+ additionalColumns: Array<{
7
+ label: string;
8
+ value: string;
9
+ }>;
10
+ availability: {
11
+ label: string;
12
+ stockDisplaySettings: 'showStockQuantity' | 'showAvailability';
13
+ };
14
+ price: number;
15
+ quantitySelector: number;
16
+ }
17
+ export interface SKUMatrixSidebarProps extends Omit<SlideOverProps, 'isOpen' | 'setIsOpen' | "fade"> {
18
+ /**
19
+ * Title for the SKUMatrixSidebar component.
20
+ */
21
+ title?: string;
22
+ /**
23
+ * Represents the variations products to building the table.
24
+ */
25
+ columns: VariationProductColumn;
26
+ /**
27
+ * Properties related to the 'add to cart' button
28
+ */
29
+ buyProps: {
30
+ 'data-testid': string;
31
+ 'data-sku': string;
32
+ 'data-seller': string;
33
+ onClick(e: React.MouseEvent<HTMLButtonElement>): void;
34
+ };
35
+ /**
36
+ * Formatter function that transforms the raw price value and render the result.
37
+ */
38
+ formatter?: PriceFormatter;
39
+ /**
40
+ * Check if some result is still loading before render the result.
41
+ */
42
+ loading?: boolean;
43
+ }
44
+ declare function SKUMatrixSidebar({ direction, title, overlayProps, size, children, columns, buyProps: { onClick: buyButtonOnClick, ...buyProps }, loading, formatter, ...otherProps }: SKUMatrixSidebarProps): React.JSX.Element;
45
+ export default SKUMatrixSidebar;
@@ -0,0 +1,90 @@
1
+ import Image from 'next/image';
2
+ import React, { useMemo } from 'react';
3
+ import { Badge, Button, QuantitySelector, Skeleton } from '../..';
4
+ import Price from '../../atoms/Price';
5
+ import Icon from '../../atoms/Icon';
6
+ import { useFadeEffect, useSKUMatrix, useUI } from '../../hooks';
7
+ import { Table, TableBody, TableCell, TableHead, TableRow, } from '../../molecules/Table';
8
+ import SlideOver, { SlideOverHeader } from '../SlideOver';
9
+ function SKUMatrixSidebar({ direction = 'rightSide', title, overlayProps, size = 'partial', children, columns, buyProps: { onClick: buyButtonOnClick, ...buyProps }, loading, formatter, ...otherProps }) {
10
+ const { isOpen, setIsOpen, setAllVariantProducts, allVariantProducts, onChangeQuantityItem, } = useSKUMatrix();
11
+ const { pushToast } = useUI();
12
+ const { fade } = useFadeEffect();
13
+ const cartDetails = useMemo(() => {
14
+ return allVariantProducts.reduce((acc, product) => ({
15
+ amount: acc.amount + product.selectedCount,
16
+ subtotal: acc.subtotal + product.selectedCount * product.price,
17
+ }), { amount: 0, subtotal: 0 });
18
+ }, [allVariantProducts]);
19
+ function resetQuantityItems() {
20
+ setAllVariantProducts((prev) => prev.map((item) => ({ ...item, quantity: 0 })));
21
+ }
22
+ function onClose() {
23
+ resetQuantityItems();
24
+ setIsOpen(false);
25
+ }
26
+ function handleAddToCart(e) {
27
+ buyButtonOnClick(e);
28
+ onClose();
29
+ }
30
+ const totalColumnsSkeletonLength = Object.keys(columns).filter((v) => v !== 'additionalColumns').length +
31
+ (columns.additionalColumns?.length ?? 0);
32
+ return (React.createElement(SlideOver, { "data-fs-sku-matrix-sidebar": true, size: size, direction: direction, overlayProps: overlayProps, isOpen: isOpen, fade: fade, ...otherProps },
33
+ React.createElement(SlideOverHeader, { onClose: onClose },
34
+ React.createElement("h2", { "data-fs-sku-matrix-sidebar-title": true }, title)),
35
+ children,
36
+ React.createElement(Table, { variant: "bordered" },
37
+ React.createElement(TableHead, null,
38
+ React.createElement(TableRow, null,
39
+ React.createElement(TableCell, { align: "left", variant: "header", scope: "col" }, columns.name),
40
+ columns.additionalColumns?.map(({ label, value }) => (React.createElement(TableCell, { key: value, align: "left", variant: "header", scope: "col" }, label))),
41
+ React.createElement(TableCell, { align: "left", variant: "header", scope: "col" }, columns.availability.label),
42
+ React.createElement(TableCell, { align: "right", variant: "header", scope: "col" }, columns.price),
43
+ React.createElement(TableCell, { align: "left", variant: "header", scope: "col" }, columns.quantitySelector))),
44
+ React.createElement(TableBody, null, loading ? (React.createElement(React.Fragment, null, Array.from({ length: 5 }).map((_, index) => {
45
+ return (React.createElement(TableRow, { key: `table-row-${index}` }, Array.from({
46
+ length: totalColumnsSkeletonLength,
47
+ }).map((_, index) => {
48
+ return (React.createElement(TableCell, { key: `table-cell-${index}` },
49
+ React.createElement("span", null,
50
+ React.createElement(Skeleton, { key: index, size: { width: '100%', height: '30px' } }))));
51
+ })));
52
+ }))) : (React.createElement(React.Fragment, null, allVariantProducts.map((variantProduct) => (React.createElement(TableRow, { key: `${variantProduct.name}-${variantProduct.id}` },
53
+ React.createElement(TableCell, { "data-fs-sku-matrix-sidebar-cell-image": true, align: "left" },
54
+ React.createElement(Image, { src: variantProduct.image.url, alt: variantProduct.image.alternateName, width: 48, height: 48 }),
55
+ variantProduct.name),
56
+ columns.additionalColumns?.map(({ value }) => (React.createElement(TableCell, { key: `${variantProduct.name}-${variantProduct.id}-${value}`, align: "left" }, variantProduct.specifications[value.toLowerCase()]))),
57
+ React.createElement(TableCell, { align: "left" },
58
+ columns.availability.stockDisplaySettings ===
59
+ 'showAvailability' && (React.createElement(Badge, { variant: variantProduct.availability === 'outOfStock'
60
+ ? 'warning'
61
+ : 'success' }, variantProduct.availability === 'outOfStock'
62
+ ? 'Out of stock'
63
+ : 'Available')),
64
+ columns.availability.stockDisplaySettings ===
65
+ 'showStockQuantity' && variantProduct.inventory),
66
+ React.createElement(TableCell, { align: "right" },
67
+ React.createElement("div", { "data-fs-sku-matrix-sidebar-table-price": true },
68
+ React.createElement(Price, { value: variantProduct.price, variant: "spot", formatter: formatter }))),
69
+ React.createElement(TableCell, { align: "right", "data-fs-sku-matrix-sidebar-table-cell-quantity-selector": true },
70
+ React.createElement("div", { "data-fs-sku-matrix-sidebar-table-action": true },
71
+ React.createElement(QuantitySelector, { min: 0, max: variantProduct.inventory, disabled: !variantProduct.inventory ||
72
+ variantProduct.availability === 'outOfStock', initial: variantProduct.selectedCount, onChange: (value) => onChangeQuantityItem(variantProduct.id, value), onValidateBlur: (min, maxValue, quantity) => {
73
+ pushToast({
74
+ title: 'Invalid quantity!',
75
+ message: `The quantity you entered is outside the range of ${min} to ${maxValue}. The quantity was set to ${quantity}.`,
76
+ status: 'INFO',
77
+ icon: (React.createElement(Icon, { name: "CircleWavyWarning", width: 30, height: 30 })),
78
+ });
79
+ } })))))))))),
80
+ React.createElement("footer", { "data-fs-sku-matrix-sidebar-footer": true },
81
+ React.createElement("div", null,
82
+ React.createElement("p", null,
83
+ cartDetails.amount,
84
+ " ",
85
+ cartDetails.amount !== 1 ? 'Items' : 'Item'),
86
+ React.createElement(Price, { value: cartDetails.subtotal, variant: "spot", formatter: formatter })),
87
+ React.createElement(Button, { variant: "primary", disabled: !cartDetails.amount, onClick: handleAddToCart, ...buyProps }, "Add to Cart"))));
88
+ }
89
+ export default SKUMatrixSidebar;
90
+ //# sourceMappingURL=SKUMatrixSidebar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SKUMatrixSidebar.js","sourceRoot":"","sources":["../../../../src/organisms/SKUMatrix/SKUMatrixSidebar.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ import type { ButtonProps } from '../../atoms/Button';
3
+ export type SKUMatrixTriggerProps = ButtonProps;
4
+ declare const SKUMatrixTrigger: React.ForwardRefExoticComponent<ButtonProps & React.RefAttributes<HTMLButtonElement>>;
5
+ export default SKUMatrixTrigger;
@@ -0,0 +1,12 @@
1
+ import React, { forwardRef } from 'react';
2
+ import Button from '../../atoms/Button';
3
+ import { useSKUMatrix } from '../../hooks';
4
+ const SKUMatrixTrigger = forwardRef(function SKUMatrixTrigger({ children, variant = 'secondary', onClick, ...otherProps }, ref) {
5
+ const { setIsOpen } = useSKUMatrix();
6
+ return (React.createElement(Button, { ref: ref, variant: variant, onClick: (event) => {
7
+ setIsOpen(true);
8
+ onClick?.(event);
9
+ }, ...otherProps }, children));
10
+ });
11
+ export default SKUMatrixTrigger;
12
+ //# sourceMappingURL=SKUMatrixTrigger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SKUMatrixTrigger.js","sourceRoot":"","sources":["../../../../src/organisms/SKUMatrix/SKUMatrixTrigger.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AACzC,OAAO,MAAM,MAAM,oBAAoB,CAAA;AAEvC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAI1C,MAAM,gBAAgB,GAAG,UAAU,CACjC,SAAS,gBAAgB,CACvB,EAAE,QAAQ,EAAE,OAAO,GAAG,WAAW,EAAE,OAAO,EAAE,GAAG,UAAU,EAAE,EAC3D,GAAG;IAEH,MAAM,EAAE,SAAS,EAAE,GAAG,YAAY,EAAE,CAAA;IAEpC,OAAO,CACL,oBAAC,MAAM,IACL,GAAG,EAAE,GAAG,EACR,OAAO,EAAE,OAAO,EAChB,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;YACjB,SAAS,CAAC,IAAI,CAAC,CAAA;YACf,OAAO,EAAE,CAAC,KAAK,CAAC,CAAA;QAClB,CAAC,KACG,UAAU,IAEb,QAAQ,CACF,CACV,CAAA;AACH,CAAC,CACF,CAAA;AAED,eAAe,gBAAgB,CAAA"}
@@ -0,0 +1,6 @@
1
+ export { default } from './SKUMatrix';
2
+ export type { SKUMatrixProps } from './SKUMatrix';
3
+ export { default as SKUMatrixTrigger } from './SKUMatrixTrigger';
4
+ export type { SKUMatrixTriggerProps } from './SKUMatrixTrigger';
5
+ export { default as SKUMatrixSidebar } from './SKUMatrixSidebar';
6
+ export type { SKUMatrixSidebarProps } from './SKUMatrixSidebar';
@@ -0,0 +1,4 @@
1
+ export { default } from './SKUMatrix';
2
+ export { default as SKUMatrixTrigger } from './SKUMatrixTrigger';
3
+ export { default as SKUMatrixSidebar } from './SKUMatrixSidebar';
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/organisms/SKUMatrix/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAGrC,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AAGhE,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAA"}
@@ -0,0 +1,49 @@
1
+ import React, { SetStateAction } from 'react';
2
+ import type { ReactNode } from 'react';
3
+ interface IAllVariantProducts {
4
+ id: string;
5
+ name: string;
6
+ image: {
7
+ url: string;
8
+ alternateName: string;
9
+ };
10
+ inventory: number;
11
+ availability: string;
12
+ price: number;
13
+ listPrice: number;
14
+ priceWithTaxes: number;
15
+ listPriceWithTaxes: number;
16
+ specifications: Record<string, string>;
17
+ selectedCount: number;
18
+ offers: {
19
+ highPrice: number;
20
+ lowPrice: number;
21
+ lowPriceWithTaxes: number;
22
+ offerCount: number;
23
+ priceCurrency: string;
24
+ offers: Array<{
25
+ listPrice: number;
26
+ listPriceWithTaxes: number;
27
+ sellingPrice: number;
28
+ priceCurrency: string;
29
+ price: number;
30
+ priceWithTaxes: number;
31
+ priceValidUntil: string;
32
+ itemCondition: string;
33
+ availability: string;
34
+ quantity: number;
35
+ }>;
36
+ };
37
+ }
38
+ export interface SKUMatrixProviderContextValue {
39
+ isOpen: boolean;
40
+ allVariantProducts: IAllVariantProducts[];
41
+ setAllVariantProducts(items: SetStateAction<IAllVariantProducts[]>): void;
42
+ onChangeQuantityItem(id: string, value: number): IAllVariantProducts[];
43
+ setIsOpen(value: boolean): void;
44
+ }
45
+ export declare const SKUMatrixContext: React.Context<SKUMatrixProviderContextValue | null>;
46
+ declare function SKUMatrixProvider({ children }: {
47
+ children: ReactNode;
48
+ }): React.JSX.Element;
49
+ export default SKUMatrixProvider;
@@ -0,0 +1,24 @@
1
+ import React, { createContext, useCallback, useState } from 'react';
2
+ export const SKUMatrixContext = createContext(null);
3
+ function SKUMatrixProvider({ children }) {
4
+ const [isOpen, setIsOpen] = useState(false);
5
+ const [allVariantProducts, setAllVariantProducts] = useState([]);
6
+ const onChangeQuantityItem = useCallback((id, value) => {
7
+ const data = [...allVariantProducts];
8
+ const matchedSKU = data.find((item) => item.id === id);
9
+ if (matchedSKU) {
10
+ matchedSKU.selectedCount = value;
11
+ }
12
+ setAllVariantProducts(data);
13
+ return data;
14
+ }, [allVariantProducts]);
15
+ return (React.createElement(SKUMatrixContext.Provider, { value: {
16
+ isOpen,
17
+ allVariantProducts,
18
+ setAllVariantProducts,
19
+ onChangeQuantityItem,
20
+ setIsOpen,
21
+ } }, children));
22
+ }
23
+ export default SKUMatrixProvider;
24
+ //# sourceMappingURL=SKUMatrixProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SKUMatrixProvider.js","sourceRoot":"","sources":["../../../../../src/organisms/SKUMatrix/provider/SKUMatrixProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,aAAa,EAAE,WAAW,EAAE,QAAQ,EAAmB,MAAM,OAAO,CAAA;AA+DpF,MAAM,CAAC,MAAM,gBAAgB,GAC3B,aAAa,CAAuC,IAAI,CAAC,CAAA;AAE3D,SAAS,iBAAiB,CAAC,EAAE,QAAQ,EAA2B;IAC9D,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAU,KAAK,CAAC,CAAA;IACpD,MAAM,CAAC,kBAAkB,EAAE,qBAAqB,CAAC,GAAG,QAAQ,CAE1D,EAAE,CAAC,CAAA;IAEL,MAAM,oBAAoB,GAAG,WAAW,CACtC,CAAC,EAAU,EAAE,KAAa,EAAE,EAAE;QAC5B,MAAM,IAAI,GAAG,CAAC,GAAG,kBAAkB,CAAC,CAAA;QACpC,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,CAAC,CAAA;QAEtD,IAAG,UAAU,EAAE;YACb,UAAU,CAAC,aAAa,GAAG,KAAK,CAAA;SACjC;QAED,qBAAqB,CAAC,IAAI,CAAC,CAAA;QAE3B,OAAO,IAAI,CAAA;IACb,CAAC,EACD,CAAC,kBAAkB,CAAC,CACrB,CAAA;IAED,OAAO,CACL,oBAAC,gBAAgB,CAAC,QAAQ,IACxB,KAAK,EAAE;YACL,MAAM;YACN,kBAAkB;YAClB,qBAAqB;YACrB,oBAAoB;YACpB,SAAS;SACV,IAEA,QAAQ,CACiB,CAC7B,CAAA;AACH,CAAC;AAED,eAAe,iBAAiB,CAAA"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@faststore/components",
3
- "version": "3.4.4",
3
+ "version": "3.7.0",
4
4
  "main": "dist/cjs/index.js",
5
5
  "module": "dist/esm/index.js",
6
6
  "typings": "dist/esm/index.d.ts",
@@ -35,8 +35,8 @@
35
35
  "react-dom": "^18.2.0"
36
36
  },
37
37
  "devDependencies": {
38
- "@faststore/eslint-config": "^3.4.4",
39
- "@faststore/shared": "^3.4.4",
38
+ "@faststore/eslint-config": "^3.5.0",
39
+ "@faststore/shared": "^3.5.0",
40
40
  "@testing-library/jest-dom": "^6.5.0",
41
41
  "@testing-library/react": "^14.3.0",
42
42
  "@types/jest-axe": "^3.5.9",
@@ -52,5 +52,5 @@
52
52
  "volta": {
53
53
  "extends": "../../package.json"
54
54
  },
55
- "gitHead": "7e548f73d188d00ea1883b1bdecc625ba719b75f"
55
+ "gitHead": "b692b179d39c24f590083cc0a1fdaaa779aa6dd9"
56
56
  }
@@ -2,6 +2,7 @@ export { default as UIProvider, Toast as ToastProps, useUI } from './UIProvider'
2
2
  export { useFadeEffect } from './useFadeEffect'
3
3
  export { useTrapFocus } from './useTrapFocus'
4
4
  export { useSearch } from './useSearch'
5
+ export { useSKUMatrix } from './useSKUMatrix'
5
6
  export { useScrollDirection } from './useScrollDirection'
6
7
  export { useSlider } from './useSlider'
7
8
  export type {
@@ -11,5 +12,3 @@ export type {
11
12
  SlideDirection,
12
13
  } from './useSlider'
13
14
  export { useSlideVisibility } from './useSlideVisibility'
14
-
15
-
@@ -0,0 +1,15 @@
1
+ import { useContext } from 'react'
2
+
3
+ import { SKUMatrixContext } from '../organisms/SKUMatrix/provider/SKUMatrixProvider'
4
+
5
+ export function useSKUMatrix() {
6
+ const context = useContext(SKUMatrixContext)
7
+
8
+ if (!context) {
9
+ throw new Error(
10
+ 'Do not use SKUMatrix components outside the SKUMatrix context.'
11
+ )
12
+ }
13
+
14
+ return context
15
+ }
package/src/index.ts CHANGED
@@ -360,3 +360,14 @@ export type {
360
360
  SlideOverProps,
361
361
  SlideOverHeaderProps,
362
362
  } from './organisms/SlideOver'
363
+
364
+ export {
365
+ default as SKUMatrix,
366
+ SKUMatrixTrigger,
367
+ SKUMatrixSidebar,
368
+ } from './organisms/SKUMatrix'
369
+ export type {
370
+ SKUMatrixProps,
371
+ SKUMatrixTriggerProps,
372
+ SKUMatrixSidebarProps
373
+ } from './organisms/SKUMatrix'
@@ -1,19 +1,45 @@
1
1
  import React, {
2
2
  cloneElement,
3
+ ComponentType,
3
4
  forwardRef,
5
+ lazy,
6
+ PropsWithChildren,
4
7
  ReactElement,
5
8
  ReactNode,
9
+ Suspense,
6
10
  useCallback,
7
11
  } from 'react'
8
12
  import Icon from '../../atoms/Icon'
9
13
  import Link from '../../atoms/Link'
10
- import Dropdown, {
11
- DropdownButton,
12
- DropdownItem,
13
- DropdownMenu,
14
+ import type {
15
+ DropdownButtonProps,
16
+ DropdownItemProps,
17
+ DropdownMenuProps,
18
+ DropdownProps,
14
19
  } from '../Dropdown'
15
20
  import BreadcrumbPure, { BreadcrumbPureProps } from './BreadcrumbPure'
16
21
 
22
+ const Dropdown = lazy<ComponentType<PropsWithChildren<DropdownProps>>>(
23
+ () => import(/* webpackChunkName: "Dropdown" */ '../Dropdown/Dropdown')
24
+ )
25
+
26
+ const DropdownButton = lazy<ComponentType<DropdownButtonProps>>(
27
+ () =>
28
+ import(
29
+ /* webpackChunkName: "DropdownButton" */ '../Dropdown/DropdownButton'
30
+ )
31
+ )
32
+
33
+ const DropdownMenu = lazy<ComponentType<DropdownMenuProps>>(
34
+ () =>
35
+ import(/* webpackChunkName: "DropdownMenu" */ '../Dropdown/DropdownMenu')
36
+ )
37
+
38
+ const DropdownItem = lazy<ComponentType<DropdownItemProps>>(
39
+ () =>
40
+ import(/* webpackChunkName: "DropdownItem" */ '../Dropdown/DropdownItem')
41
+ )
42
+
17
43
  type ItemElement = {
18
44
  item: string
19
45
  name: string
@@ -137,26 +163,28 @@ const BreadcrumbBase = forwardRef<HTMLDivElement, BreadcrumbBaseProps>(
137
163
  breadcrumbLink({ itemProps: firstItem, collapsed: false })}
138
164
 
139
165
  {collapseBreadcrumb && (
140
- <Dropdown>
141
- <DropdownButton
142
- aria-label="View More"
143
- data-fs-breadcrumb-dropdown-button
144
- size="small"
145
- >
146
- {dropdownButtonIcon}
147
- </DropdownButton>
148
- <DropdownMenu data-fs-breadcrumb-dropdown-menu>
149
- {mediumItems.map((item) => (
150
- <DropdownItem
151
- data-fs-breadcrumb-dropdown-item
152
- key={String(item.position)}
153
- icon={collapsedItemsIcon}
154
- >
155
- {breadcrumbLink({ itemProps: item, collapsed: true })}
156
- </DropdownItem>
157
- ))}
158
- </DropdownMenu>
159
- </Dropdown>
166
+ <Suspense>
167
+ <Dropdown>
168
+ <DropdownButton
169
+ aria-label="View More"
170
+ data-fs-breadcrumb-dropdown-button
171
+ size="small"
172
+ >
173
+ {dropdownButtonIcon}
174
+ </DropdownButton>
175
+ <DropdownMenu data-fs-breadcrumb-dropdown-menu>
176
+ {mediumItems.map((item) => (
177
+ <DropdownItem
178
+ data-fs-breadcrumb-dropdown-item
179
+ key={String(item.position)}
180
+ icon={collapsedItemsIcon}
181
+ >
182
+ {breadcrumbLink({ itemProps: item, collapsed: true })}
183
+ </DropdownItem>
184
+ ))}
185
+ </DropdownMenu>
186
+ </Dropdown>
187
+ </Suspense>
160
188
  )}
161
189
 
162
190
  {collapseBreadcrumb &&
@@ -0,0 +1,22 @@
1
+ import React, { forwardRef, HTMLAttributes } from 'react'
2
+ import SKUMatrixProvider from './provider/SKUMatrixProvider'
3
+
4
+ export interface SKUMatrixProps 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 SKUMatrix = forwardRef<HTMLDivElement, SKUMatrixProps>(function SKUMatrix(
12
+ { testId = 'fs-sku-matrix', children, ...otherProps },
13
+ ref
14
+ ) {
15
+ return (
16
+ <div ref={ref} data-fs-sku-matrix data-testid={testId} {...otherProps}>
17
+ <SKUMatrixProvider>{children}</SKUMatrixProvider>
18
+ </div>
19
+ )
20
+ })
21
+
22
+ export default SKUMatrix