@4i/modal-manager 1.0.14 → 1.0.30
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/package.json +1 -1
- package/readme.md +8 -5
- package/src/components/modal-provider.d.ts +5 -1
- package/src/components/modal-provider.js +7 -1
- package/src/components/modal-provider.tsx +12 -0
- package/src/utils/ModalManager.d.ts +2 -0
- package/src/utils/ModalManager.js +10 -0
- package/src/utils/ModalManager.ts +8 -0
package/package.json
CHANGED
package/readme.md
CHANGED
@@ -31,6 +31,8 @@ create table with methods
|
|
31
31
|
| |
|
32
32
|
| close() | Close last modals. (default) |
|
33
33
|
| |
|
34
|
+
| haveOpenModal | (getter) Is there at least one window open now |
|
35
|
+
| |
|
34
36
|
| addEventListener(event, callback) | Add an event listener to the modal manager. |
|
35
37
|
| |
|
36
38
|
| removeEventListener(event, callback) | Remove an event listener from the modal manager. |
|
@@ -38,11 +40,12 @@ create table with methods
|
|
38
40
|
|
39
41
|
#### ModalProvider props
|
40
42
|
|
41
|
-
| Prop
|
42
|
-
|
|
43
|
-
| modalList
|
44
|
-
| className
|
45
|
-
| isOverflow
|
43
|
+
| Prop | Type | Description |
|
44
|
+
| ------------------ | -------- | -------------------------------------------------------------------------- |
|
45
|
+
| modalList | Object | An object containing modal actions as keys and modal components as values. |
|
46
|
+
| className | string | |
|
47
|
+
| isOverflow | boolean | Set "overflow: hidden" on body |
|
48
|
+
| onModalStateChange | function | Callback function that is called when modal state changes. |
|
46
49
|
|
47
50
|
#### Define Modal Actions:
|
48
51
|
|
@@ -6,6 +6,10 @@ interface ModalProviderProps {
|
|
6
6
|
modalList: any;
|
7
7
|
isOverflow?: boolean;
|
8
8
|
className?: string;
|
9
|
+
onModalStateChange?: (modalState: boolean, data: TData[], names: string[]) => void;
|
9
10
|
}
|
10
|
-
|
11
|
+
type TData = {
|
12
|
+
[key: string]: any;
|
13
|
+
};
|
14
|
+
declare const ModalProvider: ({ modalList, isOverflow, className, onModalStateChange, }: ModalProviderProps) => false | React.JSX.Element[];
|
11
15
|
export default ModalProvider;
|
@@ -50,10 +50,16 @@ var react_1 = __importStar(require("react"));
|
|
50
50
|
var ModalManager_1 = __importDefault(require("../utils/ModalManager"));
|
51
51
|
var ModalManager_2 = __importDefault(require("../utils/ModalManager"));
|
52
52
|
var ModalProvider = function (_a) {
|
53
|
-
var modalList = _a.modalList, isOverflow = _a.isOverflow, className = _a.className;
|
53
|
+
var modalList = _a.modalList, isOverflow = _a.isOverflow, className = _a.className, onModalStateChange = _a.onModalStateChange;
|
54
54
|
var _b = (0, react_1.useState)([]), data = _b[0], setData = _b[1];
|
55
55
|
var _c = (0, react_1.useState)([]), names = _c[0], setNames = _c[1];
|
56
56
|
var modalRef = (0, react_1.useRef)([]);
|
57
|
+
(0, react_1.useEffect)(function () {
|
58
|
+
if (!onModalStateChange)
|
59
|
+
return;
|
60
|
+
var modalState = data.length !== 0;
|
61
|
+
onModalStateChange(modalState, data, names);
|
62
|
+
}, [data, names]);
|
57
63
|
(0, react_1.useEffect)(function () {
|
58
64
|
var handleOpenModal = function (name, data) {
|
59
65
|
setData(function (prev) { return __spreadArray(__spreadArray([], prev, true), [data], false); });
|
@@ -8,6 +8,11 @@ interface ModalProviderProps {
|
|
8
8
|
modalList: any;
|
9
9
|
isOverflow?: boolean;
|
10
10
|
className?: string;
|
11
|
+
onModalStateChange?: (
|
12
|
+
modalState: boolean,
|
13
|
+
data: TData[],
|
14
|
+
names: string[]
|
15
|
+
) => void;
|
11
16
|
}
|
12
17
|
|
13
18
|
type TData = { [key: string]: any };
|
@@ -16,11 +21,18 @@ const ModalProvider = ({
|
|
16
21
|
modalList,
|
17
22
|
isOverflow,
|
18
23
|
className,
|
24
|
+
onModalStateChange,
|
19
25
|
}: ModalProviderProps) => {
|
20
26
|
const [data, setData] = useState<TData[]>([]);
|
21
27
|
const [names, setNames] = useState<string[]>([]);
|
22
28
|
const modalRef = useRef<any[]>([]);
|
23
29
|
|
30
|
+
useEffect(() => {
|
31
|
+
if (!onModalStateChange) return;
|
32
|
+
const modalState = data.length !== 0;
|
33
|
+
onModalStateChange(modalState, data, names);
|
34
|
+
}, [data, names]);
|
35
|
+
|
24
36
|
useEffect(() => {
|
25
37
|
const handleOpenModal = (name: string, data: TData) => {
|
26
38
|
setData((prev: TData[]) => [...prev, data]);
|
@@ -1,5 +1,6 @@
|
|
1
1
|
import Manager from "./Manager";
|
2
2
|
declare class ModalManager extends Manager {
|
3
|
+
queue: string[];
|
3
4
|
constructor();
|
4
5
|
create<T>(name: string, payload: {
|
5
6
|
modalId: number;
|
@@ -7,6 +8,7 @@ declare class ModalManager extends Manager {
|
|
7
8
|
}): void;
|
8
9
|
call<T>(name: string, data?: T): void;
|
9
10
|
close<T>(position?: T): void;
|
11
|
+
get haveOpenModal(): boolean;
|
10
12
|
}
|
11
13
|
declare const modal: ModalManager;
|
12
14
|
export default modal;
|
@@ -30,6 +30,7 @@ var ModalManager = /** @class */ (function (_super) {
|
|
30
30
|
__extends(ModalManager, _super);
|
31
31
|
function ModalManager() {
|
32
32
|
var _this = _super.call(this) || this;
|
33
|
+
_this.queue = [];
|
33
34
|
_this.create = _this.create.bind(_this);
|
34
35
|
_this.call = _this.call.bind(_this);
|
35
36
|
_this.close = _this.close.bind(_this);
|
@@ -42,10 +43,19 @@ var ModalManager = /** @class */ (function (_super) {
|
|
42
43
|
};
|
43
44
|
ModalManager.prototype.call = function (name, data) {
|
44
45
|
this.create(name, { modalId: uniqueID(), data: data });
|
46
|
+
this.queue.push(name);
|
45
47
|
};
|
46
48
|
ModalManager.prototype.close = function (position) {
|
47
49
|
this.emitter.emit(constants.CLOSE, position);
|
50
|
+
this.queue.pop();
|
48
51
|
};
|
52
|
+
Object.defineProperty(ModalManager.prototype, "haveOpenModal", {
|
53
|
+
get: function () {
|
54
|
+
return this.queue.length > 0;
|
55
|
+
},
|
56
|
+
enumerable: false,
|
57
|
+
configurable: true
|
58
|
+
});
|
49
59
|
return ModalManager;
|
50
60
|
}(Manager_1.default));
|
51
61
|
var modal = new ModalManager();
|
@@ -10,6 +10,8 @@ const constants = {
|
|
10
10
|
};
|
11
11
|
|
12
12
|
class ModalManager extends Manager {
|
13
|
+
queue: string[] = [];
|
14
|
+
|
13
15
|
constructor() {
|
14
16
|
super();
|
15
17
|
this.create = this.create.bind(this);
|
@@ -25,10 +27,16 @@ class ModalManager extends Manager {
|
|
25
27
|
|
26
28
|
call<T>(name: string, data?: T) {
|
27
29
|
this.create<T>(name, { modalId: uniqueID(), data });
|
30
|
+
this.queue.push(name);
|
28
31
|
}
|
29
32
|
|
30
33
|
close<T>(position?: T) {
|
31
34
|
this.emitter.emit(constants.CLOSE, position);
|
35
|
+
this.queue.pop();
|
36
|
+
}
|
37
|
+
|
38
|
+
get haveOpenModal() {
|
39
|
+
return this.queue.length > 0;
|
32
40
|
}
|
33
41
|
}
|
34
42
|
|