@faststore/components 3.42.0 → 3.45.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/UIProvider.d.ts +10 -1
- package/dist/cjs/hooks/UIProvider.js +24 -0
- package/dist/cjs/hooks/UIProvider.js.map +1 -1
- package/dist/cjs/hooks/index.d.ts +2 -1
- package/dist/cjs/hooks/index.js +5 -3
- package/dist/cjs/hooks/index.js.map +1 -1
- package/dist/cjs/hooks/useOnClickOutside.d.ts +4 -0
- package/dist/cjs/hooks/useOnClickOutside.js +33 -0
- package/dist/cjs/hooks/useOnClickOutside.js.map +1 -0
- package/dist/cjs/index.d.ts +2 -0
- package/dist/cjs/index.js +4 -2
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/molecules/Accordion/AccordionButton.js +1 -1
- package/dist/cjs/molecules/Accordion/AccordionButton.js.map +1 -1
- package/dist/cjs/molecules/Modal/Modal.d.ts +14 -6
- package/dist/cjs/molecules/Modal/Modal.js +13 -4
- package/dist/cjs/molecules/Modal/Modal.js.map +1 -1
- package/dist/cjs/molecules/Popover/Popover.d.ts +67 -0
- package/dist/cjs/molecules/Popover/Popover.js +65 -0
- package/dist/cjs/molecules/Popover/Popover.js.map +1 -0
- package/dist/cjs/molecules/Popover/index.d.ts +2 -0
- package/dist/cjs/molecules/Popover/index.js +9 -0
- package/dist/cjs/molecules/Popover/index.js.map +1 -0
- package/dist/cjs/molecules/RegionBar/RegionBar.d.ts +13 -4
- package/dist/cjs/molecules/RegionBar/RegionBar.js +5 -3
- package/dist/cjs/molecules/RegionBar/RegionBar.js.map +1 -1
- package/dist/cjs/organisms/RegionModal/RegionModal.d.ts +10 -1
- package/dist/cjs/organisms/RegionModal/RegionModal.js +15 -8
- package/dist/cjs/organisms/RegionModal/RegionModal.js.map +1 -1
- package/dist/cjs/organisms/ShippingSimulation/ShippingSimulation.d.ts +2 -2
- package/dist/cjs/organisms/SlideOver/SlideOverHeader.d.ts +1 -1
- package/dist/esm/hooks/UIProvider.d.ts +10 -1
- package/dist/esm/hooks/UIProvider.js +24 -0
- package/dist/esm/hooks/UIProvider.js.map +1 -1
- package/dist/esm/hooks/index.d.ts +2 -1
- package/dist/esm/hooks/index.js +2 -1
- package/dist/esm/hooks/index.js.map +1 -1
- package/dist/esm/hooks/useOnClickOutside.d.ts +4 -0
- package/dist/esm/hooks/useOnClickOutside.js +29 -0
- package/dist/esm/hooks/useOnClickOutside.js.map +1 -0
- package/dist/esm/index.d.ts +2 -0
- package/dist/esm/index.js +1 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/molecules/Accordion/AccordionButton.js +1 -1
- package/dist/esm/molecules/Accordion/AccordionButton.js.map +1 -1
- package/dist/esm/molecules/Modal/Modal.d.ts +14 -6
- package/dist/esm/molecules/Modal/Modal.js +13 -4
- package/dist/esm/molecules/Modal/Modal.js.map +1 -1
- package/dist/esm/molecules/Popover/Popover.d.ts +67 -0
- package/dist/esm/molecules/Popover/Popover.js +62 -0
- package/dist/esm/molecules/Popover/Popover.js.map +1 -0
- package/dist/esm/molecules/Popover/index.d.ts +2 -0
- package/dist/esm/molecules/Popover/index.js +2 -0
- package/dist/esm/molecules/Popover/index.js.map +1 -0
- package/dist/esm/molecules/RegionBar/RegionBar.d.ts +13 -4
- package/dist/esm/molecules/RegionBar/RegionBar.js +5 -3
- package/dist/esm/molecules/RegionBar/RegionBar.js.map +1 -1
- package/dist/esm/organisms/RegionModal/RegionModal.d.ts +10 -1
- package/dist/esm/organisms/RegionModal/RegionModal.js +15 -8
- package/dist/esm/organisms/RegionModal/RegionModal.js.map +1 -1
- package/dist/esm/organisms/ShippingSimulation/ShippingSimulation.d.ts +2 -2
- package/dist/esm/organisms/SlideOver/SlideOverHeader.d.ts +1 -1
- package/package.json +2 -2
- package/src/hooks/UIProvider.tsx +48 -1
- package/src/hooks/index.ts +2 -1
- package/src/hooks/useOnClickOutside.ts +40 -0
- package/src/index.ts +2 -0
- package/src/molecules/Accordion/AccordionButton.tsx +1 -1
- package/src/molecules/Modal/Modal.tsx +29 -8
- package/src/molecules/Popover/Popover.tsx +209 -0
- package/src/molecules/Popover/index.tsx +2 -0
- package/src/molecules/RegionBar/RegionBar.tsx +21 -5
- package/src/organisms/RegionModal/RegionModal.tsx +29 -7
- package/src/organisms/ShippingSimulation/ShippingSimulation.tsx +2 -2
- package/src/organisms/SlideOver/SlideOverHeader.tsx +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { PropsWithChildren, ReactNode } from 'react';
|
|
1
|
+
import type { PropsWithChildren, ReactNode, RefObject } from 'react';
|
|
2
2
|
import React from 'react';
|
|
3
3
|
export interface Toast {
|
|
4
4
|
message: string;
|
|
@@ -6,6 +6,10 @@ export interface Toast {
|
|
|
6
6
|
title?: string;
|
|
7
7
|
icon?: ReactNode;
|
|
8
8
|
}
|
|
9
|
+
export interface Popover {
|
|
10
|
+
isOpen: boolean;
|
|
11
|
+
triggerRef?: RefObject<HTMLElement>;
|
|
12
|
+
}
|
|
9
13
|
interface State {
|
|
10
14
|
/** Cart sidebar */
|
|
11
15
|
cart: boolean;
|
|
@@ -15,7 +19,10 @@ interface State {
|
|
|
15
19
|
navbar: boolean;
|
|
16
20
|
/** Search page filter slider */
|
|
17
21
|
filter: boolean;
|
|
22
|
+
/** Toast notifications */
|
|
18
23
|
toasts: Toast[];
|
|
24
|
+
/** Region Popover */
|
|
25
|
+
popover: Popover;
|
|
19
26
|
}
|
|
20
27
|
interface Context extends State {
|
|
21
28
|
closeNavbar: () => void;
|
|
@@ -28,6 +35,8 @@ interface Context extends State {
|
|
|
28
35
|
closeModal: () => void;
|
|
29
36
|
pushToast: (data: Toast) => void;
|
|
30
37
|
popToast: () => void;
|
|
38
|
+
openPopover: (popover: Popover) => void;
|
|
39
|
+
closePopover: () => void;
|
|
31
40
|
}
|
|
32
41
|
declare function UIProvider({ children }: PropsWithChildren<unknown>): React.JSX.Element;
|
|
33
42
|
export declare function useUI(): Context;
|
|
@@ -39,6 +39,24 @@ const reducer = (state, action) => {
|
|
|
39
39
|
toasts: state.toasts.slice(1),
|
|
40
40
|
};
|
|
41
41
|
}
|
|
42
|
+
case 'openPopover': {
|
|
43
|
+
return {
|
|
44
|
+
...state,
|
|
45
|
+
popover: {
|
|
46
|
+
isOpen: true,
|
|
47
|
+
triggerRef: action.payload.triggerRef,
|
|
48
|
+
},
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
case 'closePopover': {
|
|
52
|
+
return {
|
|
53
|
+
...state,
|
|
54
|
+
popover: {
|
|
55
|
+
isOpen: false,
|
|
56
|
+
triggerRef: undefined,
|
|
57
|
+
},
|
|
58
|
+
};
|
|
59
|
+
}
|
|
42
60
|
default:
|
|
43
61
|
throw new Error(`Action ${type} not implemented`);
|
|
44
62
|
}
|
|
@@ -49,6 +67,10 @@ const initializer = () => ({
|
|
|
49
67
|
navbar: false,
|
|
50
68
|
filter: false,
|
|
51
69
|
toasts: [],
|
|
70
|
+
popover: {
|
|
71
|
+
isOpen: false,
|
|
72
|
+
triggerRef: undefined,
|
|
73
|
+
},
|
|
52
74
|
});
|
|
53
75
|
const UIContext = (0, react_1.createContext)(undefined);
|
|
54
76
|
function UIProvider({ children }) {
|
|
@@ -64,6 +86,8 @@ function UIProvider({ children }) {
|
|
|
64
86
|
closeModal: () => dispatch({ type: 'close', payload: 'modal' }),
|
|
65
87
|
pushToast: (toast) => dispatch({ type: 'pushToast', payload: toast }),
|
|
66
88
|
popToast: () => dispatch({ type: 'popToast' }),
|
|
89
|
+
openPopover: (popover) => dispatch({ type: 'openPopover', payload: popover }),
|
|
90
|
+
closePopover: () => dispatch({ type: 'closePopover' }),
|
|
67
91
|
}), []);
|
|
68
92
|
const value = (0, react_1.useMemo)(() => ({
|
|
69
93
|
...ui,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UIProvider.js","sourceRoot":"","sources":["../../../src/hooks/UIProvider.tsx"],"names":[],"mappings":";;;;AACA,uDAA6E;
|
|
1
|
+
{"version":3,"file":"UIProvider.js","sourceRoot":"","sources":["../../../src/hooks/UIProvider.tsx"],"names":[],"mappings":";;;;AACA,uDAA6E;AA0D7E,MAAM,OAAO,GAAG,CAAC,KAAY,EAAE,MAAc,EAAS,EAAE;IACtD,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,CAAA;IAEvB,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,MAAM,CAAC,CAAC,CAAC;YACZ,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,CAAA;YAE1B,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,WAAW,CAAC,CAAA;YAExC,OAAO;gBACL,GAAG,KAAK;gBACR,CAAC,OAAO,CAAC,EAAE,IAAI;aAChB,CAAA;QACH,CAAC;QAED,KAAK,OAAO,CAAC,CAAC,CAAC;YACb,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,CAAA;YAE1B,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC,CAAA;YAE3C,OAAO;gBACL,GAAG,KAAK;gBACR,CAAC,OAAO,CAAC,EAAE,KAAK;aACjB,CAAA;QACH,CAAC;QAED,KAAK,WAAW,CAAC,CAAC,CAAC;YACjB,MAAM,WAAW,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CACnC,CAAC,aAAa,EAAE,EAAE,CAChB,aAAa,CAAC,OAAO,KAAK,MAAM,CAAC,OAAO,CAAC,OAAO;gBAChD,aAAa,CAAC,MAAM,KAAK,MAAM,CAAC,OAAO,CAAC,MAAM,CACjD,CAAA;YAED,IAAI,WAAW,EAAE,CAAC;gBAChB,OAAO,KAAK,CAAA;YACd,CAAC;YAED,OAAO;gBACL,GAAG,KAAK;gBACR,MAAM,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,OAAO,CAAC;aAC1C,CAAA;QACH,CAAC;QAED,KAAK,UAAU,CAAC,CAAC,CAAC;YAChB,OAAO;gBACL,GAAG,KAAK;gBACR,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;aAC9B,CAAA;QACH,CAAC;QAED,KAAK,aAAa,CAAC,CAAC,CAAC;YACnB,OAAO;gBACL,GAAG,KAAK;gBACR,OAAO,EAAE;oBACP,MAAM,EAAE,IAAI;oBACZ,UAAU,EAAE,MAAM,CAAC,OAAO,CAAC,UAAU;iBACtC;aACF,CAAA;QACH,CAAC;QAED,KAAK,cAAc,CAAC,CAAC,CAAC;YACpB,OAAO;gBACL,GAAG,KAAK;gBACR,OAAO,EAAE;oBACP,MAAM,EAAE,KAAK;oBACb,UAAU,EAAE,SAAS;iBACtB;aACF,CAAA;QACH,CAAC;QAED;YACE,MAAM,IAAI,KAAK,CAAC,UAAU,IAAI,kBAAkB,CAAC,CAAA;IACrD,CAAC;AACH,CAAC,CAAA;AAED,MAAM,WAAW,GAAG,GAAU,EAAE,CAAC,CAAC;IAChC,IAAI,EAAE,KAAK;IACX,KAAK,EAAE,KAAK;IACZ,MAAM,EAAE,KAAK;IACb,MAAM,EAAE,KAAK;IACb,MAAM,EAAE,EAAE;IACV,OAAO,EAAE;QACP,MAAM,EAAE,KAAK;QACb,UAAU,EAAE,SAAS;KACtB;CACF,CAAC,CAAA;AAiBF,MAAM,SAAS,GAAG,IAAA,qBAAa,EAAsB,SAAS,CAAC,CAAA;AAE/D,SAAS,UAAU,CAAC,EAAE,QAAQ,EAA8B;IAC1D,MAAM,CAAC,EAAE,EAAE,QAAQ,CAAC,GAAG,IAAA,kBAAU,EAAC,OAAO,EAAE,SAAS,EAAE,WAAW,CAAC,CAAA;IAElE,MAAM,SAAS,GAAG,IAAA,eAAO,EACvB,GAAG,EAAE,CAAC,CAAC;QACL,UAAU,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC;QAC/D,WAAW,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC;QACjE,UAAU,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC;QAC/D,WAAW,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC;QACjE,QAAQ,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;QAC3D,SAAS,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;QAC7D,SAAS,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;QAC7D,UAAU,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;QAC/D,SAAS,EAAE,CAAC,KAAY,EAAE,EAAE,CAC1B,QAAQ,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;QACjD,QAAQ,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;QAC9C,WAAW,EAAE,CAAC,OAAgB,EAAE,EAAE,CAChC,QAAQ,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;QACrD,YAAY,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,cAAc,EAAE,CAAC;KACvD,CAAC,EACF,EAAE,CACH,CAAA;IAED,MAAM,KAAK,GAAG,IAAA,eAAO,EACnB,GAAG,EAAE,CAAC,CAAC;QACL,GAAG,EAAE;QACL,GAAG,SAAS;KACb,CAAC,EACF,CAAC,SAAS,EAAE,EAAE,CAAC,CAChB,CAAA;IAED,OAAO,8BAAC,SAAS,CAAC,QAAQ,IAAC,KAAK,EAAE,KAAK,IAAG,QAAQ,CAAsB,CAAA;AAC1E,CAAC;AAED,SAAgB,KAAK;IACnB,MAAM,OAAO,GAAG,IAAA,kBAAU,EAAC,SAAS,CAAC,CAAA;IAErC,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;QAC1B,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAA;IACrD,CAAC;IAED,OAAO,OAAO,CAAA;AAChB,CAAC;AARD,sBAQC;AAED,kBAAe,UAAU,CAAA"}
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
export { default as UIProvider, Toast as ToastProps, useUI } from './UIProvider';
|
|
2
2
|
export { useFadeEffect } from './useFadeEffect';
|
|
3
|
-
export {
|
|
3
|
+
export { useOnClickOutside } from './useOnClickOutside';
|
|
4
4
|
export { useSearch } from './useSearch';
|
|
5
5
|
export { useSKUMatrix } from './useSKUMatrix';
|
|
6
6
|
export { useScrollDirection } from './useScrollDirection';
|
|
7
7
|
export { useSlider } from './useSlider';
|
|
8
8
|
export type { UseSliderArgs, SliderState, SliderDispatch, SlideDirection, } from './useSlider';
|
|
9
9
|
export { useSlideVisibility } from './useSlideVisibility';
|
|
10
|
+
export { useTrapFocus } from './useTrapFocus';
|
package/dist/cjs/hooks/index.js
CHANGED
|
@@ -3,14 +3,14 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.useSlideVisibility = exports.useSlider = exports.useScrollDirection = exports.useSKUMatrix = exports.useSearch = exports.
|
|
6
|
+
exports.useTrapFocus = exports.useSlideVisibility = exports.useSlider = exports.useScrollDirection = exports.useSKUMatrix = exports.useSearch = exports.useOnClickOutside = exports.useFadeEffect = exports.useUI = exports.UIProvider = void 0;
|
|
7
7
|
var UIProvider_1 = require("./UIProvider");
|
|
8
8
|
Object.defineProperty(exports, "UIProvider", { enumerable: true, get: function () { return __importDefault(UIProvider_1).default; } });
|
|
9
9
|
Object.defineProperty(exports, "useUI", { enumerable: true, get: function () { return UIProvider_1.useUI; } });
|
|
10
10
|
var useFadeEffect_1 = require("./useFadeEffect");
|
|
11
11
|
Object.defineProperty(exports, "useFadeEffect", { enumerable: true, get: function () { return useFadeEffect_1.useFadeEffect; } });
|
|
12
|
-
var
|
|
13
|
-
Object.defineProperty(exports, "
|
|
12
|
+
var useOnClickOutside_1 = require("./useOnClickOutside");
|
|
13
|
+
Object.defineProperty(exports, "useOnClickOutside", { enumerable: true, get: function () { return useOnClickOutside_1.useOnClickOutside; } });
|
|
14
14
|
var useSearch_1 = require("./useSearch");
|
|
15
15
|
Object.defineProperty(exports, "useSearch", { enumerable: true, get: function () { return useSearch_1.useSearch; } });
|
|
16
16
|
var useSKUMatrix_1 = require("./useSKUMatrix");
|
|
@@ -21,4 +21,6 @@ var useSlider_1 = require("./useSlider");
|
|
|
21
21
|
Object.defineProperty(exports, "useSlider", { enumerable: true, get: function () { return useSlider_1.useSlider; } });
|
|
22
22
|
var useSlideVisibility_1 = require("./useSlideVisibility");
|
|
23
23
|
Object.defineProperty(exports, "useSlideVisibility", { enumerable: true, get: function () { return useSlideVisibility_1.useSlideVisibility; } });
|
|
24
|
+
var useTrapFocus_1 = require("./useTrapFocus");
|
|
25
|
+
Object.defineProperty(exports, "useTrapFocus", { enumerable: true, get: function () { return useTrapFocus_1.useTrapFocus; } });
|
|
24
26
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/hooks/index.ts"],"names":[],"mappings":";;;;;;AAAA,2CAAgF;AAAvE,yHAAA,OAAO,OAAc;AAAuB,mGAAA,KAAK,OAAA;AAC1D,iDAA+C;AAAtC,8GAAA,aAAa,OAAA;AACtB
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/hooks/index.ts"],"names":[],"mappings":";;;;;;AAAA,2CAAgF;AAAvE,yHAAA,OAAO,OAAc;AAAuB,mGAAA,KAAK,OAAA;AAC1D,iDAA+C;AAAtC,8GAAA,aAAa,OAAA;AACtB,yDAAuD;AAA9C,sHAAA,iBAAiB,OAAA;AAC1B,yCAAuC;AAA9B,sGAAA,SAAS,OAAA;AAClB,+CAA6C;AAApC,4GAAA,YAAY,OAAA;AACrB,2DAAyD;AAAhD,wHAAA,kBAAkB,OAAA;AAC3B,yCAAuC;AAA9B,sGAAA,SAAS,OAAA;AAOlB,2DAAyD;AAAhD,wHAAA,kBAAkB,OAAA;AAC3B,+CAA6C;AAApC,4GAAA,YAAY,OAAA"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.useOnClickOutside = void 0;
|
|
4
|
+
const react_1 = require("react");
|
|
5
|
+
function useOnClickOutside(ref, handler) {
|
|
6
|
+
(0, react_1.useEffect)(() => {
|
|
7
|
+
if (!ref?.current)
|
|
8
|
+
return;
|
|
9
|
+
const listener = (event) => {
|
|
10
|
+
if (!ref?.current || ref.current.contains(event.target)) {
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
handler(event);
|
|
14
|
+
};
|
|
15
|
+
document.addEventListener('mousedown', listener);
|
|
16
|
+
document.addEventListener('touchstart', listener);
|
|
17
|
+
return () => {
|
|
18
|
+
document.removeEventListener('mousedown', listener);
|
|
19
|
+
document.removeEventListener('touchstart', listener);
|
|
20
|
+
};
|
|
21
|
+
},
|
|
22
|
+
/**
|
|
23
|
+
* Add ref and handler to effect dependencies.
|
|
24
|
+
* It's worth noting that because passed in handler is a new
|
|
25
|
+
* function on every render that will cause this effect
|
|
26
|
+
* callback/cleanup to run every render. It's not a big deal
|
|
27
|
+
* but to optimize you can wrap handler in useCallback before
|
|
28
|
+
* passing it into this hook.
|
|
29
|
+
*/
|
|
30
|
+
[ref, handler]);
|
|
31
|
+
}
|
|
32
|
+
exports.useOnClickOutside = useOnClickOutside;
|
|
33
|
+
//# sourceMappingURL=useOnClickOutside.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useOnClickOutside.js","sourceRoot":"","sources":["../../../src/hooks/useOnClickOutside.ts"],"names":[],"mappings":";;;AACA,iCAAiC;AAIjC,SAAgB,iBAAiB,CAC/B,GAA6B,EAC7B,OAAgB;IAEhB,IAAA,iBAAS,EACP,GAAG,EAAE;QACH,IAAI,CAAC,GAAG,EAAE,OAAO;YAAE,OAAM;QAEzB,MAAM,QAAQ,GAAY,CAAC,KAAK,EAAE,EAAE;YAClC,IAAI,CAAC,GAAG,EAAE,OAAO,IAAI,GAAG,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC;gBACxD,OAAM;YACR,CAAC;YAED,OAAO,CAAC,KAAK,CAAC,CAAA;QAChB,CAAC,CAAA;QAED,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAA;QAChD,QAAQ,CAAC,gBAAgB,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAA;QAEjD,OAAO,GAAG,EAAE;YACV,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAA;YACnD,QAAQ,CAAC,mBAAmB,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAA;QACtD,CAAC,CAAA;IACH,CAAC;IACD;;;;;;;OAOG;IACH,CAAC,GAAG,EAAE,OAAO,CAAC,CACf,CAAA;AACH,CAAC;AAlCD,8CAkCC"}
|
package/dist/cjs/index.d.ts
CHANGED
|
@@ -67,6 +67,8 @@ export { default as NavbarLinks, NavbarLinksList, NavbarLinksListItem, } from '.
|
|
|
67
67
|
export type { NavbarLinksProps, NavbarLinksListProps, NavbarLinksListItemProps, } from './molecules/NavbarLinks';
|
|
68
68
|
export { default as OrderSummary } from './molecules/OrderSummary';
|
|
69
69
|
export type { OrderSummaryProps } from './molecules/OrderSummary';
|
|
70
|
+
export { default as Popover } from './molecules/Popover';
|
|
71
|
+
export type { PopoverProps } from './molecules/Popover';
|
|
70
72
|
export { default as ProductCard, ProductCardImage, ProductCardContent, } from './molecules/ProductCard';
|
|
71
73
|
export type { ProductCardProps, ProductCardImageProps, ProductCardContentProps, } from './molecules/ProductCard';
|
|
72
74
|
export { default as ProductPrice } from './molecules/ProductPrice';
|
package/dist/cjs/index.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.NavbarLinks = exports.ModalFooter = exports.ModalBody = exports.ModalHeader = exports.Modal = exports.LinkButton = exports.TextareaField = exports.InputField = exports.GiftImage = exports.GiftContent = exports.Gift = exports.DropdownMenu = exports.DropdownItem = exports.DropdownButton = exports.Dropdown = exports.DiscountBadge = exports.IconButton = exports.CheckboxField = exports.CartItemSummary = exports.CartItemImage = exports.CartItem = exports.Card = exports.CarouselBullets = exports.CarouselItem = exports.Carousel = exports.BuyButton = exports.Breadcrumb = exports.BreadcrumbPure = exports.Alert = exports.AccordionPanel = exports.AccordionButton = exports.AccordionItem = exports.Accordion = exports.SROnly = exports.Slider = exports.Select = exports.Skeleton = exports.Radio = exports.Price = exports.Overlay = exports.List = exports.Loader = exports.Link = exports.Label = exports.Textarea = exports.Input = exports.Icon = exports.Checkbox = exports.Button = exports.Badge = void 0;
|
|
4
|
-
exports.
|
|
5
|
-
exports.SKUMatrixSidebar = exports.SKUMatrixTrigger = exports.SKUMatrix = exports.SlideOverHeader = exports.SlideOver = exports.ShippingSimulation = exports.SearchInput = exports.RegionModal = exports.ProductShelfItem = exports.ProductShelfItems = exports.ProductShelf = exports.ProductGridItem = exports.ProductGrid = exports.PriceRange = exports.PaymentMethods = exports.OutOfStock = exports.NewsletterHeader = exports.NewsletterForm = exports.NewsletterContent = exports.NewsletterAddendum = exports.Newsletter = exports.NavbarSliderFooter = exports.NavbarSliderContent = exports.NavbarSliderHeader = exports.NavbarSlider = exports.NavbarButtons = exports.NavbarRow = exports.NavbarHeader = exports.Navbar = exports.ImageGalleryViewer = exports.ImageGallerySelector = exports.ImageGallery = exports.HeroHeader = exports.HeroImage = exports.Hero = exports.FilterSlider = exports.FilterFacets = exports.FilterFacetRange = void 0;
|
|
4
|
+
exports.FilterFacetBoolean = exports.Filter = exports.EmptyState = exports.CartSidebarFooter = exports.CartSidebarList = exports.CartSidebar = exports.BannerTextContent = exports.BannerText = exports.QuantitySelector = exports.ToggleField = exports.Toggle = exports.Toast = exports.Tag = exports.TableRow = exports.TableHead = exports.TableFooter = exports.TableCell = exports.TableBody = exports.Table = exports.SkuSelector = exports.SelectField = exports.SearchTopTerm = exports.SearchTop = exports.SearchProductItemContent = exports.SearchProductItemImage = exports.SearchProductItem = exports.SearchProducts = exports.SearchHistoryTerm = exports.SearchHistory = exports.SearchDropdown = exports.SearchAutoCompleteTerm = exports.SearchAutoComplete = exports.SearchInputField = exports.SearchProvider = exports.Tooltip = exports.RegionBar = exports.RatingField = exports.Rating = exports.RadioOption = exports.RadioGroup = exports.RadioField = exports.ProductTitle = exports.ProductPrice = exports.ProductCardContent = exports.ProductCardImage = exports.ProductCard = exports.Popover = exports.OrderSummary = exports.NavbarLinksListItem = exports.NavbarLinksList = void 0;
|
|
5
|
+
exports.SKUMatrixSidebar = exports.SKUMatrixTrigger = exports.SKUMatrix = exports.SlideOverHeader = exports.SlideOver = exports.ShippingSimulation = exports.SearchInput = exports.RegionModal = exports.ProductShelfItem = exports.ProductShelfItems = exports.ProductShelf = exports.ProductGridItem = exports.ProductGrid = exports.PriceRange = exports.PaymentMethods = exports.OutOfStock = exports.NewsletterHeader = exports.NewsletterForm = exports.NewsletterContent = exports.NewsletterAddendum = exports.Newsletter = exports.NavbarSliderFooter = exports.NavbarSliderContent = exports.NavbarSliderHeader = exports.NavbarSlider = exports.NavbarButtons = exports.NavbarRow = exports.NavbarHeader = exports.Navbar = exports.ImageGalleryViewer = exports.ImageGallerySelector = exports.ImageGallery = exports.HeroHeader = exports.HeroImage = exports.Hero = exports.FilterSlider = exports.FilterFacets = exports.FilterFacetRange = exports.FilterFacetBooleanItem = void 0;
|
|
6
6
|
const tslib_1 = require("tslib");
|
|
7
7
|
// Hooks
|
|
8
8
|
tslib_1.__exportStar(require("./hooks"), exports);
|
|
@@ -96,6 +96,8 @@ Object.defineProperty(exports, "NavbarLinksList", { enumerable: true, get: funct
|
|
|
96
96
|
Object.defineProperty(exports, "NavbarLinksListItem", { enumerable: true, get: function () { return NavbarLinks_1.NavbarLinksListItem; } });
|
|
97
97
|
var OrderSummary_1 = require("./molecules/OrderSummary");
|
|
98
98
|
Object.defineProperty(exports, "OrderSummary", { enumerable: true, get: function () { return tslib_1.__importDefault(OrderSummary_1).default; } });
|
|
99
|
+
var Popover_1 = require("./molecules/Popover");
|
|
100
|
+
Object.defineProperty(exports, "Popover", { enumerable: true, get: function () { return tslib_1.__importDefault(Popover_1).default; } });
|
|
99
101
|
var ProductCard_1 = require("./molecules/ProductCard");
|
|
100
102
|
Object.defineProperty(exports, "ProductCard", { enumerable: true, get: function () { return tslib_1.__importDefault(ProductCard_1).default; } });
|
|
101
103
|
Object.defineProperty(exports, "ProductCardImage", { enumerable: true, get: function () { return ProductCard_1.ProductCardImage; } });
|
package/dist/cjs/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -32,7 +32,7 @@ const AccordionButton = (0, react_1.forwardRef)(function AccordionButton({ testI
|
|
|
32
32
|
default:
|
|
33
33
|
}
|
|
34
34
|
};
|
|
35
|
-
return (react_1.default.createElement(__1.Button, { ref: ref, id: button, variant: "tertiary", "data-fs-accordion-button":
|
|
35
|
+
return (react_1.default.createElement(__1.Button, { ref: ref, id: button, variant: "tertiary", "data-fs-accordion-button": indices.has(index) ? 'expanded' : 'collapsed', "aria-expanded": indices.has(index), icon: indices.has(index) ? expandedIcon : collapsedIcon, iconPosition: "right", "aria-controls": panel, onKeyDown: onKeyDown, onClick: () => {
|
|
36
36
|
onChange(index);
|
|
37
37
|
}, "data-testid": testId, ...otherProps }, children));
|
|
38
38
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AccordionButton.js","sourceRoot":"","sources":["../../../../src/molecules/Accordion/AccordionButton.tsx"],"names":[],"mappings":";;;AACA,uDAAyC;AAEzC,2CAA0C;AAC1C,mDAAkD;AAGlD,6BAAoC;AAiBpC,MAAM,eAAe,GAAG,IAAA,kBAAU,EAChC,SAAS,eAAe,CACtB,EACE,MAAM,GAAG,qBAAqB,EAC9B,YAAY,GAAG,8BAAC,QAAI,IAAC,IAAI,EAAC,aAAa,eAAW,UAAU,GAAG,EAC/D,aAAa,GAAG,8BAAC,QAAI,IAAC,IAAI,EAAC,YAAY,eAAW,WAAW,GAAG,EAChE,QAAQ,EACR,GAAG,UAAU,EACd,EACD,GAAG;IAEH,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,GAAG,IAAA,wBAAY,GAAE,CAAA;IAC3D,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAA,gCAAgB,GAAE,CAAA;IAE7D,MAAM,SAAS,GAAG,CAAC,KAA0B,EAAE,EAAE;QAC/C,IAAI,CAAC,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;YAClD,OAAM;QACR,CAAC;QAED,MAAM,OAAO,GAAG,GAAG,EAAE;YACnB,MAAM,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YAExE,OAAO,QAAQ,CAAC,cAAc,CAC5B,GAAG,QAAQ,IAAI,GAAG,QAAQ,GAAG,WAAW,IAAI,EAAE,CAC/C,CAAA;QACH,CAAC,CAAA;QAED,MAAM,WAAW,GAAG,GAAG,EAAE;YACvB,MAAM,QAAQ,GACZ,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YAE/D,OAAO,QAAQ,CAAC,cAAc,CAC5B,GAAG,QAAQ,IAAI,GAAG,QAAQ,GAAG,WAAW,QAAQ,EAAE,CACnD,CAAA;QACH,CAAC,CAAA;QAED,QAAQ,KAAK,CAAC,GAAG,EAAE,CAAC;YAClB,KAAK,WAAW;gBACd,KAAK,CAAC,cAAc,EAAE,CAAA;gBACtB,OAAO,EAAE,EAAE,KAAK,EAAE,CAAA;gBAClB,MAAK;YAEP,KAAK,SAAS;gBACZ,KAAK,CAAC,cAAc,EAAE,CAAA;gBACtB,WAAW,EAAE,EAAE,KAAK,EAAE,CAAA;gBACtB,MAAK;YAEP,QAAQ;QACV,CAAC;IACH,CAAC,CAAA;IAED,OAAO,CACL,8BAAC,UAAM,IACL,GAAG,EAAE,GAAG,EACR,EAAE,EAAE,MAAM,EACV,OAAO,EAAC,UAAU,
|
|
1
|
+
{"version":3,"file":"AccordionButton.js","sourceRoot":"","sources":["../../../../src/molecules/Accordion/AccordionButton.tsx"],"names":[],"mappings":";;;AACA,uDAAyC;AAEzC,2CAA0C;AAC1C,mDAAkD;AAGlD,6BAAoC;AAiBpC,MAAM,eAAe,GAAG,IAAA,kBAAU,EAChC,SAAS,eAAe,CACtB,EACE,MAAM,GAAG,qBAAqB,EAC9B,YAAY,GAAG,8BAAC,QAAI,IAAC,IAAI,EAAC,aAAa,eAAW,UAAU,GAAG,EAC/D,aAAa,GAAG,8BAAC,QAAI,IAAC,IAAI,EAAC,YAAY,eAAW,WAAW,GAAG,EAChE,QAAQ,EACR,GAAG,UAAU,EACd,EACD,GAAG;IAEH,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,GAAG,IAAA,wBAAY,GAAE,CAAA;IAC3D,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAA,gCAAgB,GAAE,CAAA;IAE7D,MAAM,SAAS,GAAG,CAAC,KAA0B,EAAE,EAAE;QAC/C,IAAI,CAAC,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;YAClD,OAAM;QACR,CAAC;QAED,MAAM,OAAO,GAAG,GAAG,EAAE;YACnB,MAAM,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YAExE,OAAO,QAAQ,CAAC,cAAc,CAC5B,GAAG,QAAQ,IAAI,GAAG,QAAQ,GAAG,WAAW,IAAI,EAAE,CAC/C,CAAA;QACH,CAAC,CAAA;QAED,MAAM,WAAW,GAAG,GAAG,EAAE;YACvB,MAAM,QAAQ,GACZ,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YAE/D,OAAO,QAAQ,CAAC,cAAc,CAC5B,GAAG,QAAQ,IAAI,GAAG,QAAQ,GAAG,WAAW,QAAQ,EAAE,CACnD,CAAA;QACH,CAAC,CAAA;QAED,QAAQ,KAAK,CAAC,GAAG,EAAE,CAAC;YAClB,KAAK,WAAW;gBACd,KAAK,CAAC,cAAc,EAAE,CAAA;gBACtB,OAAO,EAAE,EAAE,KAAK,EAAE,CAAA;gBAClB,MAAK;YAEP,KAAK,SAAS;gBACZ,KAAK,CAAC,cAAc,EAAE,CAAA;gBACtB,WAAW,EAAE,EAAE,KAAK,EAAE,CAAA;gBACtB,MAAK;YAEP,QAAQ;QACV,CAAC;IACH,CAAC,CAAA;IAED,OAAO,CACL,8BAAC,UAAM,IACL,GAAG,EAAE,GAAG,EACR,EAAE,EAAE,MAAM,EACV,OAAO,EAAC,UAAU,8BACQ,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,WAAW,mBACxD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,EACjC,IAAI,EAAE,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,aAAa,EACvD,YAAY,EAAC,OAAO,mBACL,KAAK,EACpB,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,GAAG,EAAE;YACZ,QAAQ,CAAC,KAAK,CAAC,CAAA;QACjB,CAAC,iBACY,MAAM,KACf,UAAU,IAEb,QAAQ,CACF,CACV,CAAA;AACH,CAAC,CACF,CAAA;AAED,kBAAe,eAAe,CAAA"}
|
|
@@ -8,7 +8,7 @@ export type ModalChildrenProps = {
|
|
|
8
8
|
fadeIn: () => void;
|
|
9
9
|
};
|
|
10
10
|
type ModalChildrenFunction = (props: ModalChildrenProps) => ReactNode;
|
|
11
|
-
export interface ModalProps extends Omit<ModalContentProps, 'children'> {
|
|
11
|
+
export interface ModalProps extends Omit<ModalContentProps, 'children' | 'onEntered'> {
|
|
12
12
|
/**
|
|
13
13
|
* ID to find this component in testing tools (e.g.: cypress, testing library, and jest).
|
|
14
14
|
*/
|
|
@@ -19,21 +19,29 @@ export interface ModalProps extends Omit<ModalContentProps, 'children'> {
|
|
|
19
19
|
*/
|
|
20
20
|
'aria-labelledby'?: AriaAttributes['aria-label'];
|
|
21
21
|
/**
|
|
22
|
-
* A boolean value that represents the state of the Modal
|
|
22
|
+
* A boolean value that represents the state of the Modal.
|
|
23
23
|
*/
|
|
24
24
|
isOpen?: boolean;
|
|
25
25
|
/**
|
|
26
|
-
* Event emitted when the modal is closed
|
|
26
|
+
* Event emitted when the modal is closed.
|
|
27
27
|
*/
|
|
28
28
|
onDismiss?: () => void;
|
|
29
29
|
/**
|
|
30
|
-
*
|
|
30
|
+
* Callback function when the modal is opened.
|
|
31
|
+
*/
|
|
32
|
+
onEntered?: () => void;
|
|
33
|
+
/**
|
|
34
|
+
* Props forwarded to the `Overlay` component.
|
|
31
35
|
*/
|
|
32
36
|
overlayProps?: OverlayProps;
|
|
33
37
|
/**
|
|
34
|
-
* Children or function as a children
|
|
38
|
+
* Children or function as a children.
|
|
35
39
|
*/
|
|
36
40
|
children: ModalChildrenFunction | ReactNode;
|
|
41
|
+
/**
|
|
42
|
+
* Disable being closed using the Escape key.
|
|
43
|
+
*/
|
|
44
|
+
disableEscapeKeyDown?: boolean;
|
|
37
45
|
}
|
|
38
|
-
declare const Modal: ({ children, testId, isOpen, onDismiss, overlayProps, ...otherProps }: ModalProps) => React.ReactPortal | null;
|
|
46
|
+
declare const Modal: ({ children, testId, isOpen, onDismiss, overlayProps, disableEscapeKeyDown, onEntered, ...otherProps }: ModalProps) => React.ReactPortal | null;
|
|
39
47
|
export default Modal;
|
|
@@ -11,11 +11,11 @@ const ModalContent_1 = tslib_1.__importDefault(require("./ModalContent"));
|
|
|
11
11
|
* https://github.com/reach/reach-ui/blob/main/packages/dialog/src/index.tsx
|
|
12
12
|
* https://reach.tech/dialog
|
|
13
13
|
*/
|
|
14
|
-
const Modal = ({ children, testId = 'fs-modal', isOpen = true, onDismiss, overlayProps, ...otherProps }) => {
|
|
14
|
+
const Modal = ({ children, testId = 'fs-modal', isOpen = true, onDismiss, overlayProps, disableEscapeKeyDown = false, onEntered, ...otherProps }) => {
|
|
15
15
|
const { closeModal } = (0, hooks_1.useUI)();
|
|
16
16
|
const { fade, fadeOut, fadeIn } = (0, hooks_1.useFadeEffect)();
|
|
17
17
|
const handleBackdropClick = (event) => {
|
|
18
|
-
if (event.defaultPrevented) {
|
|
18
|
+
if (disableEscapeKeyDown || event.defaultPrevented) {
|
|
19
19
|
return;
|
|
20
20
|
}
|
|
21
21
|
event.stopPropagation();
|
|
@@ -23,7 +23,9 @@ const Modal = ({ children, testId = 'fs-modal', isOpen = true, onDismiss, overla
|
|
|
23
23
|
onDismiss?.();
|
|
24
24
|
};
|
|
25
25
|
const handleBackdropKeyDown = (event) => {
|
|
26
|
-
if (
|
|
26
|
+
if (disableEscapeKeyDown ||
|
|
27
|
+
event.key !== 'Escape' ||
|
|
28
|
+
event.defaultPrevented) {
|
|
27
29
|
return;
|
|
28
30
|
}
|
|
29
31
|
event.stopPropagation();
|
|
@@ -32,7 +34,14 @@ const Modal = ({ children, testId = 'fs-modal', isOpen = true, onDismiss, overla
|
|
|
32
34
|
};
|
|
33
35
|
return isOpen
|
|
34
36
|
? (0, react_dom_1.createPortal)(react_1.default.createElement(__1.Overlay, { onClick: handleBackdropClick, onKeyDown: handleBackdropKeyDown, ...overlayProps },
|
|
35
|
-
react_1.default.createElement(ModalContent_1.default, { onTransitionEnd: () =>
|
|
37
|
+
react_1.default.createElement(ModalContent_1.default, { onTransitionEnd: () => {
|
|
38
|
+
if (fade === 'out') {
|
|
39
|
+
closeModal();
|
|
40
|
+
}
|
|
41
|
+
else if (fade === 'in' && onEntered) {
|
|
42
|
+
onEntered();
|
|
43
|
+
}
|
|
44
|
+
}, "data-fs-modal": true, "data-fs-modal-state": fade, testId: testId, ...otherProps }, typeof children === 'function'
|
|
36
45
|
? children({ fade, fadeOut, fadeIn })
|
|
37
46
|
: children)), document.body)
|
|
38
47
|
: null;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Modal.js","sourceRoot":"","sources":["../../../../src/molecules/Modal/Modal.tsx"],"names":[],"mappings":";;;AAMA,0DAAyB;AACzB,yCAAwC;AAExC,6BAAkD;AAClD,uCAAkD;AAElD,0EAAyC;
|
|
1
|
+
{"version":3,"file":"Modal.js","sourceRoot":"","sources":["../../../../src/molecules/Modal/Modal.tsx"],"names":[],"mappings":";;;AAMA,0DAAyB;AACzB,yCAAwC;AAExC,6BAAkD;AAClD,uCAAkD;AAElD,0EAAyC;AA+CzC;;;;GAIG;AAEH,MAAM,KAAK,GAAG,CAAC,EACb,QAAQ,EACR,MAAM,GAAG,UAAU,EACnB,MAAM,GAAG,IAAI,EACb,SAAS,EACT,YAAY,EACZ,oBAAoB,GAAG,KAAK,EAC5B,SAAS,EACT,GAAG,UAAU,EACF,EAAE,EAAE;IACf,MAAM,EAAE,UAAU,EAAE,GAAG,IAAA,aAAK,GAAE,CAAA;IAC9B,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,IAAA,qBAAa,GAAE,CAAA;IAEjD,MAAM,mBAAmB,GAAG,CAAC,KAAiB,EAAE,EAAE;QAChD,IAAI,oBAAoB,IAAI,KAAK,CAAC,gBAAgB,EAAE,CAAC;YACnD,OAAM;QACR,CAAC;QAED,KAAK,CAAC,eAAe,EAAE,CAAA;QACvB,OAAO,EAAE,EAAE,CAAA;QACX,SAAS,EAAE,EAAE,CAAA;IACf,CAAC,CAAA;IAED,MAAM,qBAAqB,GAAG,CAAC,KAAoB,EAAE,EAAE;QACrD,IACE,oBAAoB;YACpB,KAAK,CAAC,GAAG,KAAK,QAAQ;YACtB,KAAK,CAAC,gBAAgB,EACtB,CAAC;YACD,OAAM;QACR,CAAC;QAED,KAAK,CAAC,eAAe,EAAE,CAAA;QACvB,OAAO,EAAE,EAAE,CAAA;QACX,SAAS,EAAE,EAAE,CAAA;IACf,CAAC,CAAA;IAED,OAAO,MAAM;QACX,CAAC,CAAC,IAAA,wBAAY,EACV,8BAAC,WAAO,IACN,OAAO,EAAE,mBAAmB,EAC5B,SAAS,EAAE,qBAAqB,KAC5B,YAAY;YAEhB,8BAAC,sBAAY,IACX,eAAe,EAAE,GAAG,EAAE;oBACpB,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;wBACnB,UAAU,EAAE,CAAA;oBACd,CAAC;yBAAM,IAAI,IAAI,KAAK,IAAI,IAAI,SAAS,EAAE,CAAC;wBACtC,SAAS,EAAE,CAAA;oBACb,CAAC;gBACH,CAAC,gDAEoB,IAAI,EACzB,MAAM,EAAE,MAAM,KACV,UAAU,IAEb,OAAO,QAAQ,KAAK,UAAU;gBAC7B,CAAC,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;gBACrC,CAAC,CAAC,QAAQ,CACC,CACP,EACV,QAAQ,CAAC,IAAI,CACd;QACH,CAAC,CAAC,IAAI,CAAA;AACV,CAAC,CAAA;AAED,kBAAe,KAAK,CAAA"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import React, { type HTMLAttributes, type ReactNode, type RefObject } from 'react';
|
|
2
|
+
/**
|
|
3
|
+
* Specifies Popover position.
|
|
4
|
+
*/
|
|
5
|
+
export type Side = 'bottom' | 'top';
|
|
6
|
+
/**
|
|
7
|
+
* Specifies tooltip alignment.
|
|
8
|
+
*/
|
|
9
|
+
export type Alignment = 'start' | 'center' | 'end';
|
|
10
|
+
/**
|
|
11
|
+
* Combines side + alignment (e.g., "top-start").
|
|
12
|
+
*/
|
|
13
|
+
export type Placement = `${Side}-${Alignment}`;
|
|
14
|
+
export interface PopoverProps extends Omit<HTMLAttributes<HTMLDivElement>, 'content'> {
|
|
15
|
+
/**
|
|
16
|
+
* The Popover header's title.
|
|
17
|
+
*/
|
|
18
|
+
title?: string;
|
|
19
|
+
/**
|
|
20
|
+
* Content of the Popover.
|
|
21
|
+
*/
|
|
22
|
+
content: ReactNode;
|
|
23
|
+
/**
|
|
24
|
+
* Defines the side or side-alignment (e.g., "bottom-start", "bottom-center") of the Popover.
|
|
25
|
+
*/
|
|
26
|
+
placement?: Placement;
|
|
27
|
+
/**
|
|
28
|
+
* If the Popover can be closed by a button.
|
|
29
|
+
*/
|
|
30
|
+
dismissible?: boolean;
|
|
31
|
+
/**
|
|
32
|
+
* Called when the Popover is dismissed.
|
|
33
|
+
*/
|
|
34
|
+
onDismiss?: () => void;
|
|
35
|
+
/**
|
|
36
|
+
* Callback when the Popover is fully rendered and positioned.
|
|
37
|
+
*/
|
|
38
|
+
onEntered?: () => void;
|
|
39
|
+
/**
|
|
40
|
+
* Close button aria-label.
|
|
41
|
+
*/
|
|
42
|
+
closeButtonAriaLabel?: string;
|
|
43
|
+
/**
|
|
44
|
+
* Controls whether the Popover is open.
|
|
45
|
+
*/
|
|
46
|
+
isOpen: boolean;
|
|
47
|
+
/**
|
|
48
|
+
* ID to find this component in testing tools (e.g.: cypress, testing library, and jest).
|
|
49
|
+
*/
|
|
50
|
+
testId?: string;
|
|
51
|
+
/**
|
|
52
|
+
* Offset value for top position (e.g.: 12).
|
|
53
|
+
* @default '8'
|
|
54
|
+
*/
|
|
55
|
+
offsetTop?: number;
|
|
56
|
+
/**
|
|
57
|
+
* Offset value for left position (e.g.: 12).
|
|
58
|
+
* @default '0'
|
|
59
|
+
*/
|
|
60
|
+
offsetLeft?: number;
|
|
61
|
+
/**
|
|
62
|
+
* Reference to the trigger element that opens the Popover.
|
|
63
|
+
*/
|
|
64
|
+
triggerRef?: RefObject<HTMLElement>;
|
|
65
|
+
}
|
|
66
|
+
declare const Popover: React.ForwardRefExoticComponent<PopoverProps & React.RefAttributes<HTMLDivElement>>;
|
|
67
|
+
export default Popover;
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
const react_1 = tslib_1.__importStar(require("react"));
|
|
5
|
+
const Icon_1 = tslib_1.__importDefault(require("../../atoms/Icon"));
|
|
6
|
+
const IconButton_1 = tslib_1.__importDefault(require("../IconButton"));
|
|
7
|
+
const hooks_1 = require("../../hooks");
|
|
8
|
+
const calculatePosition = (rect, placement, offsetTop, offsetLeft) => {
|
|
9
|
+
const { top, left, height } = rect;
|
|
10
|
+
switch (true) {
|
|
11
|
+
case placement.startsWith('top'):
|
|
12
|
+
return {
|
|
13
|
+
top: top + height + window.scrollY - offsetTop,
|
|
14
|
+
left: left + window.scrollX + offsetLeft,
|
|
15
|
+
};
|
|
16
|
+
case placement.startsWith('bottom'):
|
|
17
|
+
return {
|
|
18
|
+
top: top + height + window.scrollY + offsetTop,
|
|
19
|
+
left: left + window.scrollX + offsetLeft,
|
|
20
|
+
};
|
|
21
|
+
default:
|
|
22
|
+
return { top: 0, left: 0 };
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
const Popover = (0, react_1.forwardRef)(function Popover({ title, content, placement = 'bottom-start', dismissible = false, onDismiss, isOpen, triggerRef: propTriggerRef, offsetTop = 8, offsetLeft = 0, closeButtonAriaLabel = 'Close Popover', testId = 'fs-popover', style, onEntered, ...otherProps }, ref) {
|
|
26
|
+
// Use forwarded ref or internal ref for fallback
|
|
27
|
+
const popoverRef = ref || (0, react_1.useRef)(null);
|
|
28
|
+
const [popoverPosition, setPopoverPosition] = (0, react_1.useState)({ top: 0, left: 0 });
|
|
29
|
+
const { popover, closePopover } = (0, hooks_1.useUI)();
|
|
30
|
+
const contextTriggerRef = popover.triggerRef;
|
|
31
|
+
// Use the propTriggerRef if provided, otherwise fallback to contextTriggerRef
|
|
32
|
+
const triggerRef = propTriggerRef || contextTriggerRef;
|
|
33
|
+
(0, react_1.useEffect)(() => {
|
|
34
|
+
if (!isOpen || !triggerRef?.current)
|
|
35
|
+
return;
|
|
36
|
+
// Set the position according to the trigger element and placement
|
|
37
|
+
const rect = triggerRef.current.getBoundingClientRect();
|
|
38
|
+
setPopoverPosition(calculatePosition(rect, placement, offsetTop, offsetLeft));
|
|
39
|
+
// Trigger the onEntered callback after positioning
|
|
40
|
+
if (onEntered) {
|
|
41
|
+
onEntered();
|
|
42
|
+
}
|
|
43
|
+
}, [isOpen, triggerRef, offsetTop, offsetLeft, placement]);
|
|
44
|
+
const handleDismiss = (0, react_1.useCallback)(() => {
|
|
45
|
+
closePopover();
|
|
46
|
+
onDismiss?.();
|
|
47
|
+
}, [closePopover, onDismiss]);
|
|
48
|
+
(0, hooks_1.useOnClickOutside)(isOpen ? popoverRef : undefined, handleDismiss);
|
|
49
|
+
const handleKeyDown = (0, react_1.useCallback)((event) => {
|
|
50
|
+
if (event.key === 'Escape') {
|
|
51
|
+
handleDismiss();
|
|
52
|
+
}
|
|
53
|
+
}, [handleDismiss]);
|
|
54
|
+
if (!isOpen) {
|
|
55
|
+
return null;
|
|
56
|
+
}
|
|
57
|
+
return (react_1.default.createElement("div", { "data-fs-popover": true, role: "dialog", ref: popoverRef, "data-fs-popover-placement": placement, onKeyDown: handleKeyDown, "data-testid": testId, style: { position: 'absolute', ...popoverPosition, ...style }, ...otherProps },
|
|
58
|
+
react_1.default.createElement("header", { "data-fs-popover-header": true },
|
|
59
|
+
title && react_1.default.createElement("h3", { "data-fs-popover-header-title": true }, title),
|
|
60
|
+
dismissible && (react_1.default.createElement(IconButton_1.default, { "data-fs-popover-header-dismiss-button": true, size: "small", variant: "tertiary", icon: react_1.default.createElement(Icon_1.default, { name: "X", width: 20, height: 20 }), "aria-label": closeButtonAriaLabel, onClick: handleDismiss }))),
|
|
61
|
+
react_1.default.createElement("div", { "data-fs-popover-content": true }, content),
|
|
62
|
+
react_1.default.createElement("span", { "data-fs-popover-indicator": true, "aria-hidden": "true" })));
|
|
63
|
+
});
|
|
64
|
+
exports.default = Popover;
|
|
65
|
+
//# sourceMappingURL=Popover.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Popover.js","sourceRoot":"","sources":["../../../../src/molecules/Popover/Popover.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var Popover_1 = require("./Popover");
|
|
8
|
+
Object.defineProperty(exports, "default", { enumerable: true, get: function () { return __importDefault(Popover_1).default; } });
|
|
9
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/molecules/Popover/index.tsx"],"names":[],"mappings":";;;;;;AAAA,qCAAmC;AAA1B,mHAAA,OAAO,OAAA"}
|
|
@@ -1,8 +1,12 @@
|
|
|
1
|
-
import type { HTMLAttributes, ReactNode } from 'react';
|
|
1
|
+
import type { HTMLAttributes, ReactNode, RefAttributes } from 'react';
|
|
2
2
|
import React from 'react';
|
|
3
|
-
export interface RegionBarProps extends HTMLAttributes<HTMLDivElement> {
|
|
3
|
+
export interface RegionBarProps extends HTMLAttributes<HTMLDivElement>, RefAttributes<HTMLDivElement> {
|
|
4
4
|
/**
|
|
5
|
-
*
|
|
5
|
+
* City to be displayed in the component.
|
|
6
|
+
*/
|
|
7
|
+
city?: string;
|
|
8
|
+
/**
|
|
9
|
+
* Postal code string to be display in the component.
|
|
6
10
|
*/
|
|
7
11
|
postalCode?: string;
|
|
8
12
|
/**
|
|
@@ -25,6 +29,11 @@ export interface RegionBarProps extends HTMLAttributes<HTMLDivElement> {
|
|
|
25
29
|
* A React component that will be rendered as an icon.
|
|
26
30
|
*/
|
|
27
31
|
buttonIcon?: ReactNode;
|
|
32
|
+
/**
|
|
33
|
+
* Boolean to control whether postal code should be visible or not.
|
|
34
|
+
* @default true
|
|
35
|
+
*/
|
|
36
|
+
shouldDisplayPostalCode?: boolean;
|
|
28
37
|
}
|
|
29
|
-
declare const RegionBar: React.ForwardRefExoticComponent<RegionBarProps &
|
|
38
|
+
declare const RegionBar: React.ForwardRefExoticComponent<Omit<RegionBarProps, "ref"> & RefAttributes<HTMLDivElement>>;
|
|
30
39
|
export default RegionBar;
|
|
@@ -3,12 +3,14 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
const tslib_1 = require("tslib");
|
|
4
4
|
const react_1 = tslib_1.__importStar(require("react"));
|
|
5
5
|
const __1 = require("../../");
|
|
6
|
-
const RegionBar = (0, react_1.forwardRef)(function RegionBar({ postalCode, icon, label, editLabel, buttonIcon, onButtonClick, ...otherProps }, ref) {
|
|
6
|
+
const RegionBar = (0, react_1.forwardRef)(function RegionBar({ city, postalCode, icon, label, editLabel, buttonIcon, onButtonClick, shouldDisplayPostalCode = true, ...otherProps }, ref) {
|
|
7
7
|
return (react_1.default.createElement("div", { ref: ref, "data-fs-region-bar": true, ...otherProps },
|
|
8
8
|
react_1.default.createElement(__1.Button, { variant: "tertiary", iconPosition: "right", onClick: onButtonClick, icon: buttonIcon },
|
|
9
9
|
!!icon && icon,
|
|
10
|
-
postalCode ? (react_1.default.createElement(react_1.default.Fragment, null,
|
|
11
|
-
react_1.default.createElement("span", { "data-fs-region-bar-postal-code": true },
|
|
10
|
+
city && postalCode ? (react_1.default.createElement(react_1.default.Fragment, null,
|
|
11
|
+
react_1.default.createElement("span", { "data-fs-region-bar-postal-code": true },
|
|
12
|
+
city,
|
|
13
|
+
shouldDisplayPostalCode && `, ${postalCode}`),
|
|
12
14
|
!!editLabel && react_1.default.createElement("span", { "data-fs-region-bar-cta": true }, editLabel))) : (react_1.default.createElement("span", { "data-fs-region-bar-message": true }, label)))));
|
|
13
15
|
});
|
|
14
16
|
exports.default = RegionBar;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RegionBar.js","sourceRoot":"","sources":["../../../../src/molecules/RegionBar/RegionBar.tsx"],"names":[],"mappings":";;;AACA,uDAAyC;AAEzC,8BAA+B;
|
|
1
|
+
{"version":3,"file":"RegionBar.js","sourceRoot":"","sources":["../../../../src/molecules/RegionBar/RegionBar.tsx"],"names":[],"mappings":";;;AACA,uDAAyC;AAEzC,8BAA+B;AAwC/B,MAAM,SAAS,GAAG,IAAA,kBAAU,EAAiC,SAAS,SAAS,CAC7E,EACE,IAAI,EACJ,UAAU,EACV,IAAI,EACJ,KAAK,EACL,SAAS,EACT,UAAU,EACV,aAAa,EACb,uBAAuB,GAAG,IAAI,EAC9B,GAAG,UAAU,EACd,EACD,GAAG;IAEH,OAAO,CACL,uCAAK,GAAG,EAAE,GAAG,iCAAyB,UAAU;QAC9C,8BAAC,UAAM,IACL,OAAO,EAAC,UAAU,EAClB,YAAY,EAAC,OAAO,EACpB,OAAO,EAAE,aAAa,EACtB,IAAI,EAAE,UAAU;YAEf,CAAC,CAAC,IAAI,IAAI,IAAI;YACd,IAAI,IAAI,UAAU,CAAC,CAAC,CAAC,CACpB;gBACE;oBACG,IAAI;oBACJ,uBAAuB,IAAI,KAAK,UAAU,EAAE,CACxC;gBACN,CAAC,CAAC,SAAS,IAAI,0EAA8B,SAAS,CAAQ,CAC9D,CACJ,CAAC,CAAC,CAAC,CACF,8EAAkC,KAAK,CAAQ,CAChD,CACM,CACL,CACP,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,kBAAe,SAAS,CAAA"}
|
|
@@ -43,6 +43,10 @@ export interface RegionModalProps extends Omit<ModalProps, 'children'> {
|
|
|
43
43
|
* Postal code input's label.
|
|
44
44
|
*/
|
|
45
45
|
inputLabel?: string;
|
|
46
|
+
/**
|
|
47
|
+
* The text displayed on the InputField Button. Suggestion: maximum 9 characters.
|
|
48
|
+
*/
|
|
49
|
+
inputButtonActionText?: string;
|
|
46
50
|
/**
|
|
47
51
|
* Enables fadeOut effect on modal after onSubmit function
|
|
48
52
|
*/
|
|
@@ -67,6 +71,11 @@ export interface RegionModalProps extends Omit<ModalProps, 'children'> {
|
|
|
67
71
|
* Callback function when the input clear button is clicked.
|
|
68
72
|
*/
|
|
69
73
|
onClear?: () => void;
|
|
74
|
+
/**
|
|
75
|
+
* Determines if the modal can be dismissed using the close button or the Escape key.
|
|
76
|
+
* @default true
|
|
77
|
+
*/
|
|
78
|
+
dismissible?: boolean;
|
|
70
79
|
}
|
|
71
|
-
declare function RegionModal({ testId, title, description, closeButtonAriaLabel, idkPostalCodeLinkProps, errorMessage, inputRef, inputValue, inputLabel, fadeOutOnSubmit, overlayProps, onClose, onInput, onSubmit, onClear, ...otherProps }: RegionModalProps): React.JSX.Element;
|
|
80
|
+
declare function RegionModal({ testId, title, description, closeButtonAriaLabel, idkPostalCodeLinkProps, errorMessage, inputRef, inputValue, inputLabel, inputButtonActionText, fadeOutOnSubmit, overlayProps, onClose, onInput, onSubmit, onClear, dismissible, ...otherProps }: RegionModalProps): React.JSX.Element;
|
|
72
81
|
export default RegionModal;
|