@faststore/components 2.0.53-alpha.0 → 2.0.56-alpha.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/atoms/Slider/Slider.d.ts +71 -0
- package/dist/atoms/Slider/Slider.js +57 -0
- package/dist/atoms/Slider/Slider.js.map +1 -0
- package/dist/atoms/Slider/index.d.ts +2 -0
- package/dist/atoms/Slider/index.js +2 -0
- package/dist/atoms/Slider/index.js.map +1 -0
- package/dist/hooks/UIProvider.d.ts +33 -0
- package/dist/hooks/UIProvider.js +74 -0
- package/dist/hooks/UIProvider.js.map +1 -0
- package/dist/hooks/index.d.ts +3 -0
- package/dist/hooks/index.js +4 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/useFadeEffect.d.ts +5 -0
- package/dist/hooks/useFadeEffect.js +18 -0
- package/dist/hooks/useFadeEffect.js.map +1 -0
- package/dist/hooks/useTrapFocus.d.ts +8 -0
- package/dist/hooks/useTrapFocus.js +75 -0
- package/dist/hooks/useTrapFocus.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -1
- package/dist/molecules/Modal/Modal.d.ts +34 -0
- package/dist/molecules/Modal/Modal.js +38 -0
- package/dist/molecules/Modal/Modal.js.map +1 -0
- package/dist/molecules/Modal/ModalBody.d.ts +6 -0
- package/dist/molecules/Modal/ModalBody.js +4 -0
- package/dist/molecules/Modal/ModalBody.js.map +1 -0
- package/dist/molecules/Modal/ModalContent.d.ts +10 -0
- package/dist/molecules/Modal/ModalContent.js +23 -0
- package/dist/molecules/Modal/ModalContent.js.map +1 -0
- package/dist/molecules/Modal/ModalHeader.d.ts +19 -0
- package/dist/molecules/Modal/ModalHeader.js +11 -0
- package/dist/molecules/Modal/ModalHeader.js.map +1 -0
- package/dist/molecules/Modal/index.d.ts +5 -0
- package/dist/molecules/Modal/index.js +4 -0
- package/dist/molecules/Modal/index.js.map +1 -0
- package/dist/molecules/Table/Table.d.ts +1 -1
- package/dist/organisms/PriceRange/PriceRange.d.ts +38 -0
- package/dist/organisms/PriceRange/PriceRange.js +75 -0
- package/dist/organisms/PriceRange/PriceRange.js.map +1 -0
- package/dist/organisms/PriceRange/index.d.ts +2 -0
- package/dist/organisms/PriceRange/index.js +2 -0
- package/dist/organisms/PriceRange/index.js.map +1 -0
- package/package.json +2 -2
- package/src/atoms/Slider/Slider.tsx +220 -0
- package/src/atoms/Slider/index.ts +2 -0
- package/src/hooks/UIProvider.tsx +152 -0
- package/src/hooks/index.ts +3 -0
- package/src/hooks/useFadeEffect.ts +21 -0
- package/src/hooks/useTrapFocus.ts +108 -0
- package/src/index.ts +10 -0
- package/src/molecules/Modal/Modal.tsx +106 -0
- package/src/molecules/Modal/ModalBody.tsx +13 -0
- package/src/molecules/Modal/ModalContent.tsx +90 -0
- package/src/molecules/Modal/ModalHeader.tsx +47 -0
- package/src/molecules/Modal/index.tsx +5 -0
- package/src/organisms/PriceRange/PriceRange.tsx +188 -0
- package/src/organisms/PriceRange/index.ts +2 -0
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This code is inspired by the work of [sandra-lewis](https://codesandbox.io/u/sandra-lewis)
|
|
3
|
+
*/
|
|
4
|
+
import React from 'react';
|
|
5
|
+
import type { ReactNode } from 'react';
|
|
6
|
+
interface Range {
|
|
7
|
+
absolute: number;
|
|
8
|
+
selected: number;
|
|
9
|
+
}
|
|
10
|
+
interface RangeLabel {
|
|
11
|
+
min: string | ReactNode;
|
|
12
|
+
max: string | ReactNode;
|
|
13
|
+
}
|
|
14
|
+
export type SliderProps = {
|
|
15
|
+
/**
|
|
16
|
+
* ID to find this component in testing tools (e.g.: cypress, testing library, and jest).
|
|
17
|
+
*
|
|
18
|
+
* @default 'fs-slider'
|
|
19
|
+
*/
|
|
20
|
+
testId?: string;
|
|
21
|
+
/**
|
|
22
|
+
* The minimum value of the slider.
|
|
23
|
+
*/
|
|
24
|
+
min: Range;
|
|
25
|
+
/**
|
|
26
|
+
* The maximum value of the slider.
|
|
27
|
+
*/
|
|
28
|
+
max: Range;
|
|
29
|
+
/**
|
|
30
|
+
* Specifies the number interval to be used in the inputs.
|
|
31
|
+
*/
|
|
32
|
+
step?: number;
|
|
33
|
+
/**
|
|
34
|
+
* Specifies the absolute values labels.
|
|
35
|
+
*/
|
|
36
|
+
absoluteValuesLabel: RangeLabel;
|
|
37
|
+
/**
|
|
38
|
+
* Callback that fires when the slider value changes.
|
|
39
|
+
*/
|
|
40
|
+
onChange?: (value: {
|
|
41
|
+
min: number;
|
|
42
|
+
max: number;
|
|
43
|
+
}) => void;
|
|
44
|
+
/**
|
|
45
|
+
* Callback that fires when the slider value ends changing.
|
|
46
|
+
*/
|
|
47
|
+
onEnd?: (value: {
|
|
48
|
+
min: number;
|
|
49
|
+
max: number;
|
|
50
|
+
}) => void;
|
|
51
|
+
/**
|
|
52
|
+
* A function used to set a human-readable value text based on the slider's current value.
|
|
53
|
+
*/
|
|
54
|
+
getAriaValueText?(value: number, thumb?: 'min' | 'max'): string;
|
|
55
|
+
/**
|
|
56
|
+
* Component that renders min value label above the left thumb.
|
|
57
|
+
*/
|
|
58
|
+
minValueLabelComponent?: (minValue: number) => ReactNode;
|
|
59
|
+
/**
|
|
60
|
+
* Component that renders max value label above the right thumb.
|
|
61
|
+
*/
|
|
62
|
+
maxValueLabelComponent?: (maxValue: number) => ReactNode;
|
|
63
|
+
};
|
|
64
|
+
type SliderRefType = {
|
|
65
|
+
setSliderValues: (values: {
|
|
66
|
+
min: number;
|
|
67
|
+
max: number;
|
|
68
|
+
}) => void;
|
|
69
|
+
};
|
|
70
|
+
declare const Slider: React.ForwardRefExoticComponent<SliderProps & React.RefAttributes<SliderRefType | undefined>>;
|
|
71
|
+
export default Slider;
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This code is inspired by the work of [sandra-lewis](https://codesandbox.io/u/sandra-lewis)
|
|
3
|
+
*/
|
|
4
|
+
import React, { useState, useMemo, useImperativeHandle, forwardRef, } from 'react';
|
|
5
|
+
const percent = (value, min, max) => Math.round(((value - min) / (max - min)) * 100);
|
|
6
|
+
const Slider = forwardRef(function Slider({ min, max, absoluteValuesLabel, onChange, onEnd, testId = 'fs-slider', getAriaValueText, step, minValueLabelComponent, maxValueLabelComponent, ...otherProps }, ref) {
|
|
7
|
+
const widthPercent = useMemo(() => (max.absolute - min.absolute) / 100, [max.absolute, min.absolute]);
|
|
8
|
+
const [minPercent, setMinPercent] = useState(() => percent(min.selected, min.absolute, max.absolute));
|
|
9
|
+
const [maxPercent, setMaxPercent] = useState(() => percent(max.selected, min.absolute, max.absolute));
|
|
10
|
+
const [minVal, setMinVal] = useState(() => Math.floor(min.absolute + minPercent * widthPercent));
|
|
11
|
+
const [maxVal, setMaxVal] = useState(() => Math.round(min.absolute + maxPercent * widthPercent));
|
|
12
|
+
const percentage = (value) => (value / max.absolute) * 100;
|
|
13
|
+
useImperativeHandle(ref, () => ({
|
|
14
|
+
setSliderValues: (values) => {
|
|
15
|
+
const sliderMinValue = Math.min(Number(values.min), maxVal);
|
|
16
|
+
setMinVal(sliderMinValue);
|
|
17
|
+
setMinPercent(percent(sliderMinValue, min.absolute, max.absolute));
|
|
18
|
+
if (values.max > max.absolute) {
|
|
19
|
+
setMaxVal(max.absolute);
|
|
20
|
+
setMaxPercent(percent(max.absolute, min.absolute, max.absolute));
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
const sliderMaxValue = Math.max(Number(values.max), minVal);
|
|
24
|
+
setMaxVal(sliderMaxValue);
|
|
25
|
+
setMaxPercent(percent(sliderMaxValue, min.absolute, max.absolute));
|
|
26
|
+
},
|
|
27
|
+
}));
|
|
28
|
+
return (React.createElement("div", { "data-fs-slider": true, "data-testid": testId },
|
|
29
|
+
React.createElement("div", { "data-fs-slider-absolute-values": true },
|
|
30
|
+
React.createElement("span", null, absoluteValuesLabel.min),
|
|
31
|
+
React.createElement("span", null, absoluteValuesLabel.max)),
|
|
32
|
+
React.createElement("div", { "data-fs-slider-wrapper": true },
|
|
33
|
+
React.createElement("div", { "data-fs-slider-range": true, style: {
|
|
34
|
+
left: `${minPercent}%`,
|
|
35
|
+
width: `${maxPercent - minPercent}%`,
|
|
36
|
+
} }),
|
|
37
|
+
React.createElement("input", { type: "range", min: Math.floor(min.absolute), max: Math.round(max.absolute), value: minVal, step: step, onMouseUp: () => onEnd?.({ min: minVal, max: maxVal }), onTouchEnd: () => onEnd?.({ min: minVal, max: maxVal }), onChange: (event) => {
|
|
38
|
+
const minValue = Math.min(Number(event.target.value), maxVal);
|
|
39
|
+
setMinVal(minValue);
|
|
40
|
+
setMinPercent(percent(minValue, min.absolute, max.absolute));
|
|
41
|
+
onChange?.({ min: minValue, max: maxVal });
|
|
42
|
+
}, "data-fs-slider-thumb": "left", "aria-valuemin": min.absolute, "aria-valuemax": max.absolute, "aria-valuenow": minVal, "aria-label": String(minVal), "aria-labelledby": getAriaValueText?.(minVal, 'min'), ...otherProps }),
|
|
43
|
+
minValueLabelComponent && (React.createElement("span", { "data-fs-slider-value-label": "min", style: {
|
|
44
|
+
left: `calc(${percentage(minVal)}% + (${8 - percentage(minVal) * 0.2}px))`,
|
|
45
|
+
} }, minValueLabelComponent(minVal))),
|
|
46
|
+
React.createElement("input", { type: "range", min: Math.floor(min.absolute), max: Math.round(max.absolute), value: maxVal, step: step, onMouseUp: () => onEnd?.({ min: minVal, max: maxVal }), onTouchEnd: () => onEnd?.({ min: minVal, max: maxVal }), onChange: (event) => {
|
|
47
|
+
const maxValue = Math.max(Number(event.target.value), minVal);
|
|
48
|
+
setMaxVal(maxValue);
|
|
49
|
+
setMaxPercent(percent(maxValue, min.absolute, max.absolute));
|
|
50
|
+
onChange?.({ min: minVal, max: maxValue });
|
|
51
|
+
}, "data-fs-slider-thumb": "right", "aria-valuemin": min.absolute, "aria-valuemax": max.absolute, "aria-valuenow": maxVal, "aria-label": String(maxVal), "aria-labelledby": getAriaValueText?.(maxVal, 'max') }),
|
|
52
|
+
maxValueLabelComponent && (React.createElement("span", { "data-fs-slider-value-label": "max", style: {
|
|
53
|
+
left: `calc(${percentage(maxVal)}% + (${8 - percentage(maxVal) * 0.2}px))`,
|
|
54
|
+
} }, maxValueLabelComponent(maxVal))))));
|
|
55
|
+
});
|
|
56
|
+
export default Slider;
|
|
57
|
+
//# sourceMappingURL=Slider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Slider.js","sourceRoot":"","sources":["../../../src/atoms/Slider/Slider.tsx"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,KAAK,EAAE,EACZ,QAAQ,EACR,OAAO,EACP,mBAAmB,EACnB,UAAU,GACX,MAAM,OAAO,CAAA;AA8Dd,MAAM,OAAO,GAAG,CAAC,KAAa,EAAE,GAAW,EAAE,GAAW,EAAE,EAAE,CAC1D,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAA;AAEjD,MAAM,MAAM,GAAG,UAAU,CACvB,SAAS,MAAM,CACb,EACE,GAAG,EACH,GAAG,EACH,mBAAmB,EACnB,QAAQ,EACR,KAAK,EACL,MAAM,GAAG,WAAW,EACpB,gBAAgB,EAChB,IAAI,EACJ,sBAAsB,EACtB,sBAAsB,EACtB,GAAG,UAAU,EACd,EACD,GAAG;IAEH,MAAM,YAAY,GAAG,OAAO,CAC1B,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,QAAQ,GAAG,GAAG,CAAC,QAAQ,CAAC,GAAG,GAAG,EACzC,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,QAAQ,CAAC,CAC7B,CAAA;IACD,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,GAAG,EAAE,CAChD,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,QAAQ,CAAC,CAClD,CAAA;IAED,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,GAAG,EAAE,CAChD,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,QAAQ,CAAC,CAClD,CAAA;IAED,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,GAAG,EAAE,CACxC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,GAAG,UAAU,GAAG,YAAY,CAAC,CACrD,CAAA;IACD,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,GAAG,EAAE,CACxC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,GAAG,UAAU,GAAG,YAAY,CAAC,CACrD,CAAA;IAED,MAAM,UAAU,GAAG,CAAC,KAAa,EAAE,EAAE,CAAC,CAAC,KAAK,GAAG,GAAG,CAAC,QAAQ,CAAC,GAAG,GAAG,CAAA;IAElE,mBAAmB,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;QAC9B,eAAe,EAAE,CAAC,MAAoC,EAAE,EAAE;YACxD,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,MAAM,CAAC,CAAA;YAC3D,SAAS,CAAC,cAAc,CAAC,CAAA;YACzB,aAAa,CAAC,OAAO,CAAC,cAAc,EAAE,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAA;YAElE,IAAI,MAAM,CAAC,GAAG,GAAG,GAAG,CAAC,QAAQ,EAAE;gBAC7B,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;gBACvB,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAA;gBAChE,OAAM;aACP;YAED,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,MAAM,CAAC,CAAA;YAC3D,SAAS,CAAC,cAAc,CAAC,CAAA;YACzB,aAAa,CAAC,OAAO,CAAC,cAAc,EAAE,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAA;QACpE,CAAC;KACF,CAAC,CAAC,CAAA;IAEH,OAAO,CACL,oEAAiC,MAAM;QACrC;YACE,kCAAO,mBAAmB,CAAC,GAAG,CAAQ;YACtC,kCAAO,mBAAmB,CAAC,GAAG,CAAQ,CAClC;QACN;YACE,2DAEE,KAAK,EAAE;oBACL,IAAI,EAAE,GAAG,UAAU,GAAG;oBACtB,KAAK,EAAE,GAAG,UAAU,GAAG,UAAU,GAAG;iBACrC,GACD;YACF,+BACE,IAAI,EAAC,OAAO,EACZ,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAC7B,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAC7B,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,IAAI,EACV,SAAS,EAAE,GAAG,EAAE,CAAC,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC,EACtD,UAAU,EAAE,GAAG,EAAE,CAAC,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC,EACvD,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE;oBAClB,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC,CAAA;oBAE7D,SAAS,CAAC,QAAQ,CAAC,CAAA;oBACnB,aAAa,CAAC,OAAO,CAAC,QAAQ,EAAE,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAA;oBAC5D,QAAQ,EAAE,CAAC,EAAE,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC,CAAA;gBAC5C,CAAC,0BACoB,MAAM,mBACZ,GAAG,CAAC,QAAQ,mBACZ,GAAG,CAAC,QAAQ,mBACZ,MAAM,gBACT,MAAM,CAAC,MAAM,CAAC,qBACT,gBAAgB,EAAE,CAAC,MAAM,EAAE,KAAK,CAAC,KAC9C,UAAU,GACd;YACD,sBAAsB,IAAI,CACzB,4DAC6B,KAAK,EAChC,KAAK,EAAE;oBACL,IAAI,EAAE,QAAQ,UAAU,CAAC,MAAM,CAAC,QAC9B,CAAC,GAAG,UAAU,CAAC,MAAM,CAAC,GAAG,GAC3B,MAAM;iBACP,IAEA,sBAAsB,CAAC,MAAM,CAAC,CAC1B,CACR;YAED,+BACE,IAAI,EAAC,OAAO,EACZ,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAC7B,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAC7B,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,IAAI,EACV,SAAS,EAAE,GAAG,EAAE,CAAC,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC,EACtD,UAAU,EAAE,GAAG,EAAE,CAAC,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC,EACvD,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE;oBAClB,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC,CAAA;oBAE7D,SAAS,CAAC,QAAQ,CAAC,CAAA;oBACnB,aAAa,CAAC,OAAO,CAAC,QAAQ,EAAE,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAA;oBAC5D,QAAQ,EAAE,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,CAAC,CAAA;gBAC5C,CAAC,0BACoB,OAAO,mBACb,GAAG,CAAC,QAAQ,mBACZ,GAAG,CAAC,QAAQ,mBACZ,MAAM,gBACT,MAAM,CAAC,MAAM,CAAC,qBACT,gBAAgB,EAAE,CAAC,MAAM,EAAE,KAAK,CAAC,GAClD;YACD,sBAAsB,IAAI,CACzB,4DAC6B,KAAK,EAChC,KAAK,EAAE;oBACL,IAAI,EAAE,QAAQ,UAAU,CAAC,MAAM,CAAC,QAC9B,CAAC,GAAG,UAAU,CAAC,MAAM,CAAC,GAAG,GAC3B,MAAM;iBACP,IAEA,sBAAsB,CAAC,MAAM,CAAC,CAC1B,CACR,CACG,CACF,CACP,CAAA;AACH,CAAC,CACF,CAAA;AAED,eAAe,MAAM,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/atoms/Slider/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAA"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import type { PropsWithChildren } from 'react';
|
|
2
|
+
interface Toast {
|
|
3
|
+
message: string;
|
|
4
|
+
status: 'ERROR' | 'WARNING' | 'INFO';
|
|
5
|
+
title?: string;
|
|
6
|
+
icon?: string;
|
|
7
|
+
}
|
|
8
|
+
interface State {
|
|
9
|
+
/** Cart sidebar */
|
|
10
|
+
cart: boolean;
|
|
11
|
+
/** Region modal */
|
|
12
|
+
modal: boolean;
|
|
13
|
+
/** Menu slider */
|
|
14
|
+
navbar: boolean;
|
|
15
|
+
/** Search page filter slider */
|
|
16
|
+
filter: boolean;
|
|
17
|
+
toasts: Toast[];
|
|
18
|
+
}
|
|
19
|
+
interface Context extends State {
|
|
20
|
+
closeNavbar: () => void;
|
|
21
|
+
openNavbar: () => void;
|
|
22
|
+
closeFilter: () => void;
|
|
23
|
+
openFilter: () => void;
|
|
24
|
+
openCart: () => void;
|
|
25
|
+
closeCart: () => void;
|
|
26
|
+
openModal: () => void;
|
|
27
|
+
closeModal: () => void;
|
|
28
|
+
pushToast: (data: Toast) => void;
|
|
29
|
+
popToast: () => void;
|
|
30
|
+
}
|
|
31
|
+
declare function UIProvider({ children }: PropsWithChildren): JSX.Element;
|
|
32
|
+
export declare function useUI(): Context;
|
|
33
|
+
export default UIProvider;
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { createContext, useContext, useMemo, useReducer } from 'react';
|
|
3
|
+
const reducer = (state, action) => {
|
|
4
|
+
const { type } = action;
|
|
5
|
+
switch (type) {
|
|
6
|
+
case 'open': {
|
|
7
|
+
const { payload } = action;
|
|
8
|
+
document.body.classList.add('no-scroll');
|
|
9
|
+
return {
|
|
10
|
+
...state,
|
|
11
|
+
[payload]: true,
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
case 'close': {
|
|
15
|
+
const { payload } = action;
|
|
16
|
+
document.body.classList.remove('no-scroll');
|
|
17
|
+
return {
|
|
18
|
+
...state,
|
|
19
|
+
[payload]: false,
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
case 'pushToast': {
|
|
23
|
+
return {
|
|
24
|
+
...state,
|
|
25
|
+
toasts: [...state.toasts, action.payload],
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
case 'popToast': {
|
|
29
|
+
return {
|
|
30
|
+
...state,
|
|
31
|
+
toasts: state.toasts.slice(1),
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
default:
|
|
35
|
+
throw new Error(`Action ${type} not implemented`);
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
const initializer = () => ({
|
|
39
|
+
cart: false,
|
|
40
|
+
modal: false,
|
|
41
|
+
navbar: false,
|
|
42
|
+
filter: false,
|
|
43
|
+
toasts: [],
|
|
44
|
+
});
|
|
45
|
+
const UIContext = createContext(undefined);
|
|
46
|
+
function UIProvider({ children }) {
|
|
47
|
+
const [ui, dispatch] = useReducer(reducer, undefined, initializer);
|
|
48
|
+
const callbacks = useMemo(() => ({
|
|
49
|
+
openFilter: () => dispatch({ type: 'open', payload: 'filter' }),
|
|
50
|
+
closeFilter: () => dispatch({ type: 'close', payload: 'filter' }),
|
|
51
|
+
openNavbar: () => dispatch({ type: 'open', payload: 'navbar' }),
|
|
52
|
+
closeNavbar: () => dispatch({ type: 'close', payload: 'navbar' }),
|
|
53
|
+
openCart: () => dispatch({ type: 'open', payload: 'cart' }),
|
|
54
|
+
closeCart: () => dispatch({ type: 'close', payload: 'cart' }),
|
|
55
|
+
openModal: () => dispatch({ type: 'open', payload: 'modal' }),
|
|
56
|
+
closeModal: () => dispatch({ type: 'close', payload: 'modal' }),
|
|
57
|
+
pushToast: (toast) => dispatch({ type: 'pushToast', payload: toast }),
|
|
58
|
+
popToast: () => dispatch({ type: 'popToast' }),
|
|
59
|
+
}), []);
|
|
60
|
+
const value = useMemo(() => ({
|
|
61
|
+
...ui,
|
|
62
|
+
...callbacks,
|
|
63
|
+
}), [callbacks, ui]);
|
|
64
|
+
return React.createElement(UIContext.Provider, { value: value }, children);
|
|
65
|
+
}
|
|
66
|
+
export function useUI() {
|
|
67
|
+
const context = useContext(UIContext);
|
|
68
|
+
if (context === undefined) {
|
|
69
|
+
throw new Error('Missing UI context on React tree');
|
|
70
|
+
}
|
|
71
|
+
return context;
|
|
72
|
+
}
|
|
73
|
+
export default UIProvider;
|
|
74
|
+
//# sourceMappingURL=UIProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UIProvider.js","sourceRoot":"","sources":["../../src/hooks/UIProvider.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,KAAK,EAAE,MAAM,cAAc,CAAA;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { useState, useCallback, useEffect } from 'react';
|
|
2
|
+
export const useFadeEffect = () => {
|
|
3
|
+
const [fade, setFade] = useState('out');
|
|
4
|
+
const fadeOut = useCallback(() => setFade('out'), []);
|
|
5
|
+
const fadeIn = useCallback(() => setFade('in'), []);
|
|
6
|
+
useEffect(() => {
|
|
7
|
+
fadeIn();
|
|
8
|
+
return () => {
|
|
9
|
+
fadeOut();
|
|
10
|
+
};
|
|
11
|
+
}, [fadeIn, fadeOut]);
|
|
12
|
+
return {
|
|
13
|
+
fade,
|
|
14
|
+
fadeIn,
|
|
15
|
+
fadeOut,
|
|
16
|
+
};
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=useFadeEffect.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useFadeEffect.js","sourceRoot":"","sources":["../../src/hooks/useFadeEffect.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAExD,MAAM,CAAC,MAAM,aAAa,GAAG,GAAG,EAAE;IAChC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAe,KAAK,CAAC,CAAA;IACrD,MAAM,OAAO,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAA;IACrD,MAAM,MAAM,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,CAAA;IAEnD,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,EAAE,CAAA;QAER,OAAO,GAAG,EAAE;YACV,OAAO,EAAE,CAAA;QACX,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAA;IAErB,OAAO;QACL,IAAI;QACJ,MAAM;QACN,OAAO;KACR,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { RefObject } from 'react';
|
|
2
|
+
interface TrapFocusParams {
|
|
3
|
+
beforeElementRef: RefObject<HTMLElement>;
|
|
4
|
+
trapFocusRef: RefObject<HTMLElement>;
|
|
5
|
+
afterElementRef: RefObject<HTMLElement>;
|
|
6
|
+
}
|
|
7
|
+
export declare const useTrapFocus: ({ trapFocusRef, beforeElementRef, afterElementRef, }: TrapFocusParams) => void;
|
|
8
|
+
export {};
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { useEffect, useRef } from 'react';
|
|
2
|
+
import { tabbable } from 'tabbable';
|
|
3
|
+
/*
|
|
4
|
+
* Element that will maintain the focus inside trapFocusRef, focus the first element,
|
|
5
|
+
* and focus back on the element that was in focus when useTrapFocus was triggered.
|
|
6
|
+
*
|
|
7
|
+
* Inspired by Reakit useTrapFocus https://github.com/reakit/reakit/blob/a211d94da9f3b683182568a56479b91afb1b85ae/packages/reakit/src/Dialog/__utils/useFocusTrap.ts
|
|
8
|
+
*/
|
|
9
|
+
export const useTrapFocus = ({ trapFocusRef, beforeElementRef, afterElementRef, }) => {
|
|
10
|
+
const tabbableNodesRef = useRef();
|
|
11
|
+
const nodeToRestoreRef = useRef(document.hasFocus() ? document.activeElement : null);
|
|
12
|
+
// Focus back on the element that was focused when useTrapFocus is triggered.
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
const nodeToRestore = nodeToRestoreRef.current;
|
|
15
|
+
return () => {
|
|
16
|
+
nodeToRestore?.focus();
|
|
17
|
+
};
|
|
18
|
+
}, [nodeToRestoreRef]);
|
|
19
|
+
// Set focus on first tabbable element
|
|
20
|
+
useEffect(() => {
|
|
21
|
+
if (!trapFocusRef.current) {
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
if (!tabbableNodesRef.current) {
|
|
25
|
+
tabbableNodesRef.current = tabbable(trapFocusRef.current);
|
|
26
|
+
}
|
|
27
|
+
const [firstTabbable] = tabbableNodesRef.current;
|
|
28
|
+
if (!firstTabbable) {
|
|
29
|
+
trapFocusRef.current.focus();
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
firstTabbable.focus();
|
|
33
|
+
}, [trapFocusRef]);
|
|
34
|
+
// Handle loop focus. Set keydown and focusin event listeners
|
|
35
|
+
useEffect(() => {
|
|
36
|
+
if (!trapFocusRef.current ||
|
|
37
|
+
!beforeElementRef.current ||
|
|
38
|
+
!afterElementRef.current) {
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
const beforeElement = beforeElementRef.current;
|
|
42
|
+
const afterElement = afterElementRef.current;
|
|
43
|
+
const trapFocus = trapFocusRef.current;
|
|
44
|
+
const handleLoopFocus = (nativeEvent) => {
|
|
45
|
+
if (!document.hasFocus()) {
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
tabbableNodesRef.current = tabbable(trapFocusRef.current);
|
|
49
|
+
if (!tabbableNodesRef.current.length) {
|
|
50
|
+
trapFocus.focus();
|
|
51
|
+
}
|
|
52
|
+
/*
|
|
53
|
+
* Handle loop focus from beforeElementRef. This node can only be focused if the user press shift tab.
|
|
54
|
+
* It will focus the last element of the trapFocusRef.
|
|
55
|
+
*/
|
|
56
|
+
if (nativeEvent.target === beforeElement) {
|
|
57
|
+
tabbableNodesRef.current[tabbableNodesRef.current.length - 1]?.focus();
|
|
58
|
+
}
|
|
59
|
+
/*
|
|
60
|
+
* Handle loop focus from afterElementRef. This node can only be focused if the user press tab.
|
|
61
|
+
* It will focus the first element of the trapFocusRef.
|
|
62
|
+
*/
|
|
63
|
+
if (nativeEvent.target === afterElement) {
|
|
64
|
+
tabbableNodesRef.current[0]?.focus();
|
|
65
|
+
}
|
|
66
|
+
};
|
|
67
|
+
beforeElement?.addEventListener('focusin', handleLoopFocus);
|
|
68
|
+
afterElement?.addEventListener('focusin', handleLoopFocus);
|
|
69
|
+
return () => {
|
|
70
|
+
beforeElement?.removeEventListener('focusin', handleLoopFocus);
|
|
71
|
+
afterElement?.removeEventListener('focusin', handleLoopFocus);
|
|
72
|
+
};
|
|
73
|
+
}, [tabbableNodesRef, afterElementRef, beforeElementRef, trapFocusRef]);
|
|
74
|
+
};
|
|
75
|
+
//# sourceMappingURL=useTrapFocus.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useTrapFocus.js","sourceRoot":"","sources":["../../src/hooks/useTrapFocus.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export * from './assets';
|
|
2
|
+
export * from './hooks';
|
|
2
3
|
export { default as Badge } from './atoms/Badge';
|
|
3
4
|
export type { BadgeProps } from './atoms/Badge';
|
|
4
5
|
export { default as Button } from './atoms/Button';
|
|
@@ -25,6 +26,8 @@ export { default as Radio } from './atoms/Radio';
|
|
|
25
26
|
export type { RadioProps } from './atoms/Radio';
|
|
26
27
|
export { default as Select } from './atoms/Select';
|
|
27
28
|
export type { SelectProps } from './atoms/Select';
|
|
29
|
+
export { default as Slider } from './atoms/Slider';
|
|
30
|
+
export type { SliderProps } from './atoms/Slider';
|
|
28
31
|
export { default as SROnly } from './atoms/SROnly';
|
|
29
32
|
export { default as Accordion, AccordionItem, AccordionButton, AccordionPanel, } from './molecules/Accordion';
|
|
30
33
|
export type { AccordionProps, AccordionItemProps, AccordionButtonProps, AccordionPanelProps, } from './molecules/Accordion';
|
|
@@ -45,6 +48,8 @@ export { default as InputField } from './molecules/InputField';
|
|
|
45
48
|
export type { InputFieldProps } from './molecules/InputField';
|
|
46
49
|
export { default as LinkButton } from './molecules/LinkButton';
|
|
47
50
|
export type { LinkButtonProps } from './molecules/LinkButton';
|
|
51
|
+
export { default as Modal, ModalHeader, ModalBody } from './molecules/Modal';
|
|
52
|
+
export type { ModalProps, ModalHeaderProps } from './molecules/Modal';
|
|
48
53
|
export { default as RadioField } from './molecules/RadioField';
|
|
49
54
|
export type { RadioFieldProps } from './molecules/RadioField';
|
|
50
55
|
export { default as RadioGroup, RadioOption, } from './molecules/RadioGroup';
|
|
@@ -65,3 +70,5 @@ export { default as QuantitySelector } from './molecules/QuantitySelector';
|
|
|
65
70
|
export type { QuantitySelectorProps } from './molecules/QuantitySelector';
|
|
66
71
|
export { default as Hero, HeroImage, HeroHeading } from './organisms/Hero';
|
|
67
72
|
export type { HeroProps, HeroImageProps, HeroHeadingProps, } from './organisms/Hero';
|
|
73
|
+
export { default as PriceRange } from './organisms/PriceRange';
|
|
74
|
+
export type { PriceRangeProps } from './organisms/PriceRange';
|
package/dist/index.js
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
// Assets
|
|
2
2
|
export * from './assets';
|
|
3
|
+
// Hooks
|
|
4
|
+
export * from './hooks';
|
|
3
5
|
// Atoms
|
|
4
6
|
export { default as Badge } from './atoms/Badge';
|
|
5
7
|
export { default as Button } from './atoms/Button';
|
|
@@ -14,6 +16,7 @@ export { default as Overlay } from './atoms/Overlay';
|
|
|
14
16
|
export { default as Price } from './atoms/Price';
|
|
15
17
|
export { default as Radio } from './atoms/Radio';
|
|
16
18
|
export { default as Select } from './atoms/Select';
|
|
19
|
+
export { default as Slider } from './atoms/Slider';
|
|
17
20
|
export { default as SROnly } from './atoms/SROnly';
|
|
18
21
|
// Molecules
|
|
19
22
|
export { default as Accordion, AccordionItem, AccordionButton, AccordionPanel, } from './molecules/Accordion';
|
|
@@ -26,6 +29,7 @@ export { default as Dropdown, DropdownButton, DropdownItem, DropdownMenu, } from
|
|
|
26
29
|
export { default as Gift, GiftContent, GiftImage, } from './molecules/Gift';
|
|
27
30
|
export { default as InputField } from './molecules/InputField';
|
|
28
31
|
export { default as LinkButton } from './molecules/LinkButton';
|
|
32
|
+
export { default as Modal, ModalHeader, ModalBody } from './molecules/Modal';
|
|
29
33
|
export { default as RadioField } from './molecules/RadioField';
|
|
30
34
|
export { default as RadioGroup, RadioOption, } from './molecules/RadioGroup';
|
|
31
35
|
export { default as Rating } from './molecules/Rating';
|
|
@@ -37,4 +41,5 @@ export { default as ToggleField } from './molecules/ToggleField';
|
|
|
37
41
|
export { default as QuantitySelector } from './molecules/QuantitySelector';
|
|
38
42
|
// Organisms
|
|
39
43
|
export { default as Hero, HeroImage, HeroHeading } from './organisms/Hero';
|
|
44
|
+
export { default as PriceRange } from './organisms/PriceRange';
|
|
40
45
|
//# sourceMappingURL=index.js.map
|
package/dist/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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"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type { AriaAttributes, ReactNode } from 'react';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import type { ModalContentProps } from './ModalContent';
|
|
4
|
+
export type ModalChildrenProps = {
|
|
5
|
+
fade: 'in' | 'out';
|
|
6
|
+
fadeOut: () => void;
|
|
7
|
+
fadeIn: () => void;
|
|
8
|
+
};
|
|
9
|
+
type ModalChildrenFunction = (props: ModalChildrenProps) => ReactNode;
|
|
10
|
+
export interface ModalProps extends Omit<ModalContentProps, 'children'> {
|
|
11
|
+
/**
|
|
12
|
+
* ID to find this component in testing tools (e.g.: cypress, testing library, and jest).
|
|
13
|
+
*/
|
|
14
|
+
testId?: string;
|
|
15
|
+
/**
|
|
16
|
+
* Identifies the element (or elements) that labels the current element.
|
|
17
|
+
* @see aria-labelledby https://www.w3.org/TR/wai-aria-1.1/#aria-labelledby
|
|
18
|
+
*/
|
|
19
|
+
'aria-labelledby'?: AriaAttributes['aria-label'];
|
|
20
|
+
/**
|
|
21
|
+
* A boolean value that represents the state of the Modal
|
|
22
|
+
*/
|
|
23
|
+
isOpen?: boolean;
|
|
24
|
+
/**
|
|
25
|
+
* Event emitted when the modal is closed
|
|
26
|
+
*/
|
|
27
|
+
onDismiss?: () => void;
|
|
28
|
+
/**
|
|
29
|
+
* Children or function as a children
|
|
30
|
+
*/
|
|
31
|
+
children: ModalChildrenFunction | ReactNode;
|
|
32
|
+
}
|
|
33
|
+
declare const Modal: ({ children, testId, isOpen, onDismiss, ...otherProps }: ModalProps) => React.ReactPortal | null;
|
|
34
|
+
export default Modal;
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { createPortal } from 'react-dom';
|
|
3
|
+
import { Overlay } from '../..';
|
|
4
|
+
import { useFadeEffect, useUI } from '../../hooks';
|
|
5
|
+
import ModalContent from './ModalContent';
|
|
6
|
+
/*
|
|
7
|
+
* This component is based on @reach/dialog.
|
|
8
|
+
* https://github.com/reach/reach-ui/blob/main/packages/dialog/src/index.tsx
|
|
9
|
+
* https://reach.tech/dialog
|
|
10
|
+
*/
|
|
11
|
+
const Modal = ({ children, testId = 'fs-modal', isOpen = true, onDismiss, ...otherProps }) => {
|
|
12
|
+
const { closeModal } = useUI();
|
|
13
|
+
const { fade, fadeOut, fadeIn } = useFadeEffect();
|
|
14
|
+
const handleBackdropClick = (event) => {
|
|
15
|
+
if (event.defaultPrevented) {
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
event.stopPropagation();
|
|
19
|
+
fadeOut?.();
|
|
20
|
+
onDismiss?.();
|
|
21
|
+
};
|
|
22
|
+
const handleBackdropKeyDown = (event) => {
|
|
23
|
+
if (event.key !== 'Escape' || event.defaultPrevented) {
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
event.stopPropagation();
|
|
27
|
+
fadeOut?.();
|
|
28
|
+
onDismiss?.();
|
|
29
|
+
};
|
|
30
|
+
return isOpen
|
|
31
|
+
? createPortal(React.createElement(Overlay, { onClick: handleBackdropClick, onKeyDown: handleBackdropKeyDown },
|
|
32
|
+
React.createElement(ModalContent, { onTransitionEnd: () => fade === 'out' && closeModal(), "data-fs-modal": true, "data-fs-modal-state": fade, testId: testId, ...otherProps }, typeof children === 'function'
|
|
33
|
+
? children({ fade, fadeOut, fadeIn })
|
|
34
|
+
: children)), document.body)
|
|
35
|
+
: null;
|
|
36
|
+
};
|
|
37
|
+
export default Modal;
|
|
38
|
+
//# sourceMappingURL=Modal.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Modal.js","sourceRoot":"","sources":["../../../src/molecules/Modal/Modal.tsx"],"names":[],"mappings":"AAMA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAA;AAExC,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAA;AAC/B,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,aAAa,CAAA;AAElD,OAAO,YAAY,MAAM,gBAAgB,CAAA;AAkCzC;;;;GAIG;AAEH,MAAM,KAAK,GAAG,CAAC,EACb,QAAQ,EACR,MAAM,GAAG,UAAU,EACnB,MAAM,GAAG,IAAI,EACb,SAAS,EACT,GAAG,UAAU,EACF,EAAE,EAAE;IACf,MAAM,EAAE,UAAU,EAAE,GAAG,KAAK,EAAE,CAAA;IAC9B,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,aAAa,EAAE,CAAA;IAEjD,MAAM,mBAAmB,GAAG,CAAC,KAAiB,EAAE,EAAE;QAChD,IAAI,KAAK,CAAC,gBAAgB,EAAE;YAC1B,OAAM;SACP;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,IAAI,KAAK,CAAC,GAAG,KAAK,QAAQ,IAAI,KAAK,CAAC,gBAAgB,EAAE;YACpD,OAAM;SACP;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,YAAY,CACV,oBAAC,OAAO,IACN,OAAO,EAAE,mBAAmB,EAC5B,SAAS,EAAE,qBAAqB;YAEhC,oBAAC,YAAY,IACX,eAAe,EAAE,GAAG,EAAE,CAAC,IAAI,KAAK,KAAK,IAAI,UAAU,EAAE,gDAEhC,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,eAAe,KAAK,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ModalBody.js","sourceRoot":"","sources":["../../../src/molecules/Modal/ModalBody.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAoC,MAAM,OAAO,CAAA;AAMxD,MAAM,SAAS,GAAG,CAAC,EAAE,QAAQ,EAAE,GAAG,UAAU,EAAkB,EAAE,EAAE,CAAC,CACjE,4DAA4B,UAAU,IACnC,QAAQ,CACL,CACP,CAAA;AAED,eAAe,SAAS,CAAA"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { DetailedHTMLProps, HTMLAttributes, RefObject } from 'react';
|
|
2
|
+
interface ModalContentPureProps extends Omit<DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement>, 'ref'> {
|
|
3
|
+
beforeElementRef: RefObject<HTMLDivElement>;
|
|
4
|
+
trapFocusRef: RefObject<HTMLDivElement>;
|
|
5
|
+
afterElementRef: RefObject<HTMLDivElement>;
|
|
6
|
+
testId?: string;
|
|
7
|
+
}
|
|
8
|
+
export type ModalContentProps = Omit<ModalContentPureProps, 'trapFocusRef' | 'onClick' | 'beforeElementRef' | 'afterElementRef'>;
|
|
9
|
+
declare const ModalContent: ({ children, ...otherProps }: ModalContentProps) => JSX.Element;
|
|
10
|
+
export default ModalContent;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import React, { useRef } from 'react';
|
|
2
|
+
import { useTrapFocus } from '../../hooks';
|
|
3
|
+
const ModalContentPure = ({ beforeElementRef, trapFocusRef, afterElementRef, testId = 'store-modal-content', children, ...otherProps }) => {
|
|
4
|
+
return (React.createElement(React.Fragment, null,
|
|
5
|
+
React.createElement("div", { ref: beforeElementRef, "data-testid": "beforeElement", tabIndex: 0, "aria-hidden": "true" }),
|
|
6
|
+
React.createElement("div", { "data-fs-modal-content": true, "data-testid": testId, ref: trapFocusRef, "aria-modal": "true", role: "dialog", tabIndex: -1, ...otherProps }, children),
|
|
7
|
+
React.createElement("div", { ref: afterElementRef, "data-testid": "afterElement", tabIndex: 0, "aria-hidden": "true" })));
|
|
8
|
+
};
|
|
9
|
+
const ModalContent = ({ children, ...otherProps }) => {
|
|
10
|
+
const trapFocusRef = useRef(null);
|
|
11
|
+
const beforeElementRef = useRef(null);
|
|
12
|
+
const afterElementRef = useRef(null);
|
|
13
|
+
useTrapFocus({
|
|
14
|
+
beforeElementRef,
|
|
15
|
+
trapFocusRef,
|
|
16
|
+
afterElementRef,
|
|
17
|
+
});
|
|
18
|
+
return (React.createElement(ModalContentPure, { ...otherProps, trapFocusRef: trapFocusRef, beforeElementRef: beforeElementRef, afterElementRef: afterElementRef, onClick: (event) => {
|
|
19
|
+
event.stopPropagation();
|
|
20
|
+
} }, children));
|
|
21
|
+
};
|
|
22
|
+
export default ModalContent;
|
|
23
|
+
//# sourceMappingURL=ModalContent.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ModalContent.js","sourceRoot":"","sources":["../../../src/molecules/Modal/ModalContent.tsx"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,EAAE,MAAM,EAAE,MAAM,OAAO,CAAA;AAErC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAa1C,MAAM,gBAAgB,GAAG,CAAC,EACxB,gBAAgB,EAChB,YAAY,EACZ,eAAe,EACf,MAAM,GAAG,qBAAqB,EAC9B,QAAQ,EACR,GAAG,UAAU,EACS,EAAE,EAAE;IAC1B,OAAO,CACL;QACE,6BACE,GAAG,EAAE,gBAAgB,iBACT,eAAe,EAC3B,QAAQ,EAAE,CAAC,iBACC,MAAM,GAClB;QACF,2EAEe,MAAM,EACnB,GAAG,EAAE,YAAY,gBACN,MAAM,EACjB,IAAI,EAAC,QAAQ,EACb,QAAQ,EAAE,CAAC,CAAC,KACR,UAAU,IAEb,QAAQ,CACL;QACN,6BACE,GAAG,EAAE,eAAe,iBACR,cAAc,EAC1B,QAAQ,EAAE,CAAC,iBACC,MAAM,GAClB,CACD,CACJ,CAAA;AACH,CAAC,CAAA;AAOD,MAAM,YAAY,GAAG,CAAC,EAAE,QAAQ,EAAE,GAAG,UAAU,EAAqB,EAAE,EAAE;IACtE,MAAM,YAAY,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAA;IACjD,MAAM,gBAAgB,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAA;IACrD,MAAM,eAAe,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAA;IAEpD,YAAY,CAAC;QACX,gBAAgB;QAChB,YAAY;QACZ,eAAe;KAChB,CAAC,CAAA;IAEF,OAAO,CACL,oBAAC,gBAAgB,OACX,UAAU,EACd,YAAY,EAAE,YAAY,EAC1B,gBAAgB,EAAE,gBAAgB,EAClC,eAAe,EAAE,eAAe,EAChC,OAAO,EAAE,CAAC,KAAiB,EAAE,EAAE;YAC7B,KAAK,CAAC,eAAe,EAAE,CAAA;QACzB,CAAC,IAEA,QAAQ,CACQ,CACpB,CAAA;AACH,CAAC,CAAA;AAED,eAAe,YAAY,CAAA"}
|