@peculiar/react-components 0.1.4 → 0.1.5
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/Toast/toast_provider.js +64 -47
- package/dist/cjs/Toast/toast_provider.js.map +1 -1
- package/dist/esm/Toast/toast_provider.js +64 -47
- package/dist/esm/Toast/toast_provider.js.map +1 -1
- package/dist/esnext/Toast/toast_provider.js +66 -49
- package/dist/esnext/Toast/toast_provider.js.map +1 -1
- package/package.json +2 -2
|
@@ -51,56 +51,73 @@ var Portal_1 = require("../Portal");
|
|
|
51
51
|
var toast_1 = require("./toast");
|
|
52
52
|
var ToastProvider = function (props) {
|
|
53
53
|
var children = props.children, toastContainerProps = props.toastContainerProps, _a = props.maxToasts, maxToasts = _a === void 0 ? 1 : _a;
|
|
54
|
-
var _b = React.useState(
|
|
55
|
-
|
|
56
|
-
|
|
54
|
+
var _b = React.useState({
|
|
55
|
+
toasts: [],
|
|
56
|
+
queue: [],
|
|
57
|
+
}), state = _b[0], setState = _b[1];
|
|
58
|
+
var addToast = function (options) {
|
|
57
59
|
var id = options.id || "".concat(Date.now()).concat(Math.random());
|
|
58
60
|
var newToast = __assign(__assign({}, options), { id: id, createdAt: Date.now() });
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
61
|
+
setState(function (prevState) {
|
|
62
|
+
var inQueue = prevState.queue.findIndex(function (item) { return item.id === id; });
|
|
63
|
+
if (inQueue > -1) {
|
|
64
|
+
return prevState;
|
|
65
|
+
}
|
|
66
|
+
var inToasts = prevState.toasts.findIndex(function (item) { return item.id === id; });
|
|
67
|
+
if (inToasts > -1) {
|
|
68
|
+
return prevState;
|
|
69
|
+
}
|
|
70
|
+
if (prevState.toasts.length >= maxToasts) {
|
|
71
|
+
return {
|
|
72
|
+
toasts: prevState.toasts,
|
|
73
|
+
queue: __spreadArray(__spreadArray([], prevState.queue, true), [
|
|
74
|
+
newToast,
|
|
75
|
+
], false),
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
return {
|
|
79
|
+
queue: prevState.queue,
|
|
80
|
+
toasts: __spreadArray(__spreadArray([], prevState.toasts, true), [
|
|
81
|
+
newToast,
|
|
82
|
+
], false),
|
|
83
|
+
};
|
|
84
|
+
});
|
|
85
|
+
};
|
|
86
|
+
var removeToast = function (id) {
|
|
87
|
+
setState(function (prevState) {
|
|
88
|
+
var inToasts = prevState.toasts.findIndex(function (item) { return item.id === id; });
|
|
89
|
+
if (inToasts > -1 && prevState.queue.length) {
|
|
90
|
+
var newList = __spreadArray([], prevState.toasts, true);
|
|
91
|
+
newList.splice(inToasts, 1);
|
|
92
|
+
newList.push(prevState.queue[0]);
|
|
93
|
+
return {
|
|
94
|
+
queue: prevState.queue.slice(1, prevState.queue.length),
|
|
95
|
+
toasts: newList,
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
if (inToasts > -1) {
|
|
99
|
+
return {
|
|
100
|
+
queue: prevState.queue,
|
|
101
|
+
toasts: prevState.toasts.filter(function (item) { return item.id !== id; }),
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
var inQueue = prevState.queue.findIndex(function (item) { return item.id === id; });
|
|
105
|
+
if (inQueue > -1) {
|
|
106
|
+
return {
|
|
107
|
+
toasts: prevState.toasts,
|
|
108
|
+
queue: prevState.queue.filter(function (item) { return item.id !== id; }),
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
return prevState;
|
|
112
|
+
});
|
|
113
|
+
};
|
|
99
114
|
var removeAllToasts = function () {
|
|
100
|
-
|
|
101
|
-
|
|
115
|
+
setState({
|
|
116
|
+
toasts: [],
|
|
117
|
+
queue: [],
|
|
118
|
+
});
|
|
102
119
|
};
|
|
103
|
-
var hasToasts = Boolean(toasts.length);
|
|
120
|
+
var hasToasts = Boolean(state.toasts.length);
|
|
104
121
|
return (React.createElement(toast_context_1.ToastContext.Provider, { value: {
|
|
105
122
|
addToast: addToast,
|
|
106
123
|
removeToast: removeToast,
|
|
@@ -108,7 +125,7 @@ var ToastProvider = function (props) {
|
|
|
108
125
|
} },
|
|
109
126
|
children,
|
|
110
127
|
hasToasts && (React.createElement(Portal_1.Portal, null,
|
|
111
|
-
React.createElement(toast_container_1.ToastContainer, __assign({}, toastContainerProps), toasts.map(function (toast) { return (React.createElement(toast_1.Toast, { key: toast.id, id: toast.id, onClose: removeToast, isClosable: toast.isClosable, duration: toast.duration, alertProps: {
|
|
128
|
+
React.createElement(toast_container_1.ToastContainer, __assign({}, toastContainerProps), state.toasts.map(function (toast) { return (React.createElement(toast_1.Toast, { key: toast.id, id: toast.id, onClose: removeToast, isClosable: toast.isClosable, duration: toast.duration, alertProps: {
|
|
112
129
|
disableIcon: toast.disableIcon,
|
|
113
130
|
variant: toast.variant,
|
|
114
131
|
} }, toast.message)); }))))));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"toast_provider.js","sourceRoot":"","sources":["../../../src/Toast/toast_provider.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAA+B;AAC/B,iDAIyB;AACzB,qDAAwE;AACxE,oCAAmC;AACnC,iCAAgC;AAiBzB,IAAM,aAAa,GAAwB,UAAC,KAAK;IAEpD,IAAA,QAAQ,GAGN,KAAK,SAHC,EACR,mBAAmB,GAEjB,KAAK,oBAFY,EACnB,KACE,KAAK,UADM,EAAb,SAAS,mBAAG,CAAC,KAAA,CACL;IACJ,IAAA,
|
|
1
|
+
{"version":3,"file":"toast_provider.js","sourceRoot":"","sources":["../../../src/Toast/toast_provider.tsx"],"names":[],"mappings":"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"}
|
|
@@ -25,56 +25,73 @@ import { Portal } from '../Portal';
|
|
|
25
25
|
import { Toast } from './toast';
|
|
26
26
|
export var ToastProvider = function (props) {
|
|
27
27
|
var children = props.children, toastContainerProps = props.toastContainerProps, _a = props.maxToasts, maxToasts = _a === void 0 ? 1 : _a;
|
|
28
|
-
var _b = React.useState(
|
|
29
|
-
|
|
30
|
-
|
|
28
|
+
var _b = React.useState({
|
|
29
|
+
toasts: [],
|
|
30
|
+
queue: [],
|
|
31
|
+
}), state = _b[0], setState = _b[1];
|
|
32
|
+
var addToast = function (options) {
|
|
31
33
|
var id = options.id || "".concat(Date.now()).concat(Math.random());
|
|
32
34
|
var newToast = __assign(__assign({}, options), { id: id, createdAt: Date.now() });
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
35
|
+
setState(function (prevState) {
|
|
36
|
+
var inQueue = prevState.queue.findIndex(function (item) { return item.id === id; });
|
|
37
|
+
if (inQueue > -1) {
|
|
38
|
+
return prevState;
|
|
39
|
+
}
|
|
40
|
+
var inToasts = prevState.toasts.findIndex(function (item) { return item.id === id; });
|
|
41
|
+
if (inToasts > -1) {
|
|
42
|
+
return prevState;
|
|
43
|
+
}
|
|
44
|
+
if (prevState.toasts.length >= maxToasts) {
|
|
45
|
+
return {
|
|
46
|
+
toasts: prevState.toasts,
|
|
47
|
+
queue: __spreadArray(__spreadArray([], prevState.queue, true), [
|
|
48
|
+
newToast,
|
|
49
|
+
], false),
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
return {
|
|
53
|
+
queue: prevState.queue,
|
|
54
|
+
toasts: __spreadArray(__spreadArray([], prevState.toasts, true), [
|
|
55
|
+
newToast,
|
|
56
|
+
], false),
|
|
57
|
+
};
|
|
58
|
+
});
|
|
59
|
+
};
|
|
60
|
+
var removeToast = function (id) {
|
|
61
|
+
setState(function (prevState) {
|
|
62
|
+
var inToasts = prevState.toasts.findIndex(function (item) { return item.id === id; });
|
|
63
|
+
if (inToasts > -1 && prevState.queue.length) {
|
|
64
|
+
var newList = __spreadArray([], prevState.toasts, true);
|
|
65
|
+
newList.splice(inToasts, 1);
|
|
66
|
+
newList.push(prevState.queue[0]);
|
|
67
|
+
return {
|
|
68
|
+
queue: prevState.queue.slice(1, prevState.queue.length),
|
|
69
|
+
toasts: newList,
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
if (inToasts > -1) {
|
|
73
|
+
return {
|
|
74
|
+
queue: prevState.queue,
|
|
75
|
+
toasts: prevState.toasts.filter(function (item) { return item.id !== id; }),
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
var inQueue = prevState.queue.findIndex(function (item) { return item.id === id; });
|
|
79
|
+
if (inQueue > -1) {
|
|
80
|
+
return {
|
|
81
|
+
toasts: prevState.toasts,
|
|
82
|
+
queue: prevState.queue.filter(function (item) { return item.id !== id; }),
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
return prevState;
|
|
86
|
+
});
|
|
87
|
+
};
|
|
73
88
|
var removeAllToasts = function () {
|
|
74
|
-
|
|
75
|
-
|
|
89
|
+
setState({
|
|
90
|
+
toasts: [],
|
|
91
|
+
queue: [],
|
|
92
|
+
});
|
|
76
93
|
};
|
|
77
|
-
var hasToasts = Boolean(toasts.length);
|
|
94
|
+
var hasToasts = Boolean(state.toasts.length);
|
|
78
95
|
return (React.createElement(ToastContext.Provider, { value: {
|
|
79
96
|
addToast: addToast,
|
|
80
97
|
removeToast: removeToast,
|
|
@@ -82,7 +99,7 @@ export var ToastProvider = function (props) {
|
|
|
82
99
|
} },
|
|
83
100
|
children,
|
|
84
101
|
hasToasts && (React.createElement(Portal, null,
|
|
85
|
-
React.createElement(ToastContainer, __assign({}, toastContainerProps), toasts.map(function (toast) { return (React.createElement(Toast, { key: toast.id, id: toast.id, onClose: removeToast, isClosable: toast.isClosable, duration: toast.duration, alertProps: {
|
|
102
|
+
React.createElement(ToastContainer, __assign({}, toastContainerProps), state.toasts.map(function (toast) { return (React.createElement(Toast, { key: toast.id, id: toast.id, onClose: removeToast, isClosable: toast.isClosable, duration: toast.duration, alertProps: {
|
|
86
103
|
disableIcon: toast.disableIcon,
|
|
87
104
|
variant: toast.variant,
|
|
88
105
|
} }, toast.message)); }))))));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"toast_provider.js","sourceRoot":"","sources":["../../../src/Toast/toast_provider.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EACL,YAAY,GAGb,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,cAAc,EAAuB,MAAM,mBAAmB,CAAC;AACxE,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAiBhC,MAAM,CAAC,IAAM,aAAa,GAAwB,UAAC,KAAK;IAEpD,IAAA,QAAQ,GAGN,KAAK,SAHC,EACR,mBAAmB,GAEjB,KAAK,oBAFY,EACnB,KACE,KAAK,UADM,EAAb,SAAS,mBAAG,CAAC,KAAA,CACL;IACJ,IAAA,
|
|
1
|
+
{"version":3,"file":"toast_provider.js","sourceRoot":"","sources":["../../../src/Toast/toast_provider.tsx"],"names":[],"mappings":"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"}
|
|
@@ -5,62 +5,79 @@ import { Portal } from '../Portal';
|
|
|
5
5
|
import { Toast } from './toast';
|
|
6
6
|
export const ToastProvider = (props) => {
|
|
7
7
|
const { children, toastContainerProps, maxToasts = 1, } = props;
|
|
8
|
-
const [
|
|
9
|
-
|
|
10
|
-
|
|
8
|
+
const [state, setState] = React.useState({
|
|
9
|
+
toasts: [],
|
|
10
|
+
queue: [],
|
|
11
|
+
});
|
|
12
|
+
const addToast = (options) => {
|
|
11
13
|
const id = options.id || `${Date.now()}${Math.random()}`;
|
|
12
14
|
const newToast = {
|
|
13
15
|
...options,
|
|
14
16
|
id,
|
|
15
17
|
createdAt: Date.now(),
|
|
16
18
|
};
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
19
|
+
setState((prevState) => {
|
|
20
|
+
const inQueue = prevState.queue.findIndex((item) => item.id === id);
|
|
21
|
+
if (inQueue > -1) {
|
|
22
|
+
return prevState;
|
|
23
|
+
}
|
|
24
|
+
const inToasts = prevState.toasts.findIndex((item) => item.id === id);
|
|
25
|
+
if (inToasts > -1) {
|
|
26
|
+
return prevState;
|
|
27
|
+
}
|
|
28
|
+
if (prevState.toasts.length >= maxToasts) {
|
|
29
|
+
return {
|
|
30
|
+
toasts: prevState.toasts,
|
|
31
|
+
queue: [
|
|
32
|
+
...prevState.queue,
|
|
33
|
+
newToast,
|
|
34
|
+
],
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
return {
|
|
38
|
+
queue: prevState.queue,
|
|
39
|
+
toasts: [
|
|
40
|
+
...prevState.toasts,
|
|
41
|
+
newToast,
|
|
42
|
+
],
|
|
43
|
+
};
|
|
44
|
+
});
|
|
45
|
+
};
|
|
46
|
+
const removeToast = (id) => {
|
|
47
|
+
setState((prevState) => {
|
|
48
|
+
const inToasts = prevState.toasts.findIndex((item) => item.id === id);
|
|
49
|
+
if (inToasts > -1 && prevState.queue.length) {
|
|
50
|
+
const newList = [...prevState.toasts];
|
|
51
|
+
newList.splice(inToasts, 1);
|
|
52
|
+
newList.push(prevState.queue[0]);
|
|
53
|
+
return {
|
|
54
|
+
queue: prevState.queue.slice(1, prevState.queue.length),
|
|
55
|
+
toasts: newList,
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
if (inToasts > -1) {
|
|
59
|
+
return {
|
|
60
|
+
queue: prevState.queue,
|
|
61
|
+
toasts: prevState.toasts.filter((item) => item.id !== id),
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
const inQueue = prevState.queue.findIndex((item) => item.id === id);
|
|
65
|
+
if (inQueue > -1) {
|
|
66
|
+
return {
|
|
67
|
+
toasts: prevState.toasts,
|
|
68
|
+
queue: prevState.queue.filter((item) => item.id !== id),
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
return prevState;
|
|
72
|
+
});
|
|
73
|
+
};
|
|
59
74
|
const removeAllToasts = () => {
|
|
60
|
-
|
|
61
|
-
|
|
75
|
+
setState({
|
|
76
|
+
toasts: [],
|
|
77
|
+
queue: [],
|
|
78
|
+
});
|
|
62
79
|
};
|
|
63
|
-
const hasToasts = Boolean(toasts.length);
|
|
80
|
+
const hasToasts = Boolean(state.toasts.length);
|
|
64
81
|
return (React.createElement(ToastContext.Provider, { value: {
|
|
65
82
|
addToast,
|
|
66
83
|
removeToast,
|
|
@@ -68,7 +85,7 @@ export const ToastProvider = (props) => {
|
|
|
68
85
|
} },
|
|
69
86
|
children,
|
|
70
87
|
hasToasts && (React.createElement(Portal, null,
|
|
71
|
-
React.createElement(ToastContainer, { ...toastContainerProps }, toasts.map((toast) => (React.createElement(Toast, { key: toast.id, id: toast.id, onClose: removeToast, isClosable: toast.isClosable, duration: toast.duration, alertProps: {
|
|
88
|
+
React.createElement(ToastContainer, { ...toastContainerProps }, state.toasts.map((toast) => (React.createElement(Toast, { key: toast.id, id: toast.id, onClose: removeToast, isClosable: toast.isClosable, duration: toast.duration, alertProps: {
|
|
72
89
|
disableIcon: toast.disableIcon,
|
|
73
90
|
variant: toast.variant,
|
|
74
91
|
} }, toast.message))))))));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"toast_provider.js","sourceRoot":"","sources":["../../../src/Toast/toast_provider.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EACL,YAAY,GAGb,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,cAAc,EAAuB,MAAM,mBAAmB,CAAC;AACxE,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAiBhC,MAAM,CAAC,MAAM,aAAa,GAAwB,CAAC,KAAK,EAAE,EAAE;IAC1D,MAAM,EACJ,QAAQ,EACR,mBAAmB,EACnB,SAAS,GAAG,CAAC,GACd,GAAG,KAAK,CAAC;IACV,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"toast_provider.js","sourceRoot":"","sources":["../../../src/Toast/toast_provider.tsx"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@peculiar/react-components",
|
|
3
3
|
"private": false,
|
|
4
|
-
"version": "0.1.
|
|
4
|
+
"version": "0.1.5",
|
|
5
5
|
"author": "PeculiarVentures Team",
|
|
6
6
|
"description": "A simple and customizable component library to build faster, beautiful, and more accessible React applications.",
|
|
7
7
|
"keywords": [
|
|
@@ -96,5 +96,5 @@
|
|
|
96
96
|
"node": ">=12.x"
|
|
97
97
|
},
|
|
98
98
|
"license": "MIT",
|
|
99
|
-
"gitHead": "
|
|
99
|
+
"gitHead": "13711e2318c5d1ca3aa669bc4adcdf470d93af49"
|
|
100
100
|
}
|