sprint-asia-custom-component 0.1.181 → 0.1.182
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/index.js
CHANGED
|
@@ -29092,50 +29092,60 @@
|
|
|
29092
29092
|
|
|
29093
29093
|
var img$7 = "";
|
|
29094
29094
|
|
|
29095
|
-
const
|
|
29096
|
-
|
|
29097
|
-
|
|
29098
|
-
|
|
29099
|
-
|
|
29100
|
-
|
|
29101
|
-
|
|
29102
|
-
|
|
29103
|
-
|
|
29104
|
-
|
|
29105
|
-
|
|
29106
|
-
|
|
29107
|
-
|
|
29108
|
-
|
|
29095
|
+
const Modal = ({
|
|
29096
|
+
open,
|
|
29097
|
+
onClose = () => {},
|
|
29098
|
+
children
|
|
29099
|
+
}) => {
|
|
29100
|
+
const [visible, setVisible] = React.useState(open);
|
|
29101
|
+
const [animate, setAnimate] = React.useState(false);
|
|
29102
|
+
React.useEffect(() => {
|
|
29103
|
+
if (open) {
|
|
29104
|
+
setVisible(true);
|
|
29105
|
+
requestAnimationFrame(() => setAnimate(true));
|
|
29106
|
+
document.body.style.overflow = "hidden";
|
|
29107
|
+
} else {
|
|
29108
|
+
setAnimate(false);
|
|
29109
|
+
const t = setTimeout(() => setVisible(false), 200);
|
|
29110
|
+
document.body.style.overflow = "";
|
|
29111
|
+
return () => clearTimeout(t);
|
|
29112
|
+
}
|
|
29113
|
+
}, [open]);
|
|
29114
|
+
if (!visible) return null;
|
|
29115
|
+
const modalRoot = document.getElementById("modal-root");
|
|
29116
|
+
if (!modalRoot) return null;
|
|
29117
|
+
return /*#__PURE__*/reactDomExports.createPortal( /*#__PURE__*/React__default["default"].createElement("div", {
|
|
29118
|
+
className: "fixed inset-0",
|
|
29109
29119
|
style: {
|
|
29110
29120
|
zIndex: 1001
|
|
29111
|
-
}
|
|
29112
|
-
|
|
29113
|
-
as: React.Fragment,
|
|
29114
|
-
enter: "ease-out duration-300",
|
|
29115
|
-
enterFrom: "opacity-0",
|
|
29116
|
-
enterTo: "opacity-100",
|
|
29117
|
-
leave: "ease-in duration-200",
|
|
29118
|
-
leaveFrom: "opacity-100",
|
|
29119
|
-
leaveTo: "opacity-0"
|
|
29121
|
+
},
|
|
29122
|
+
onClick: onClose
|
|
29120
29123
|
}, /*#__PURE__*/React__default["default"].createElement("div", {
|
|
29121
|
-
className:
|
|
29122
|
-
onClick:
|
|
29123
|
-
})
|
|
29124
|
-
className: "
|
|
29124
|
+
className: `absolute inset-0 bg-black transition-opacity duration-200 ${animate ? "opacity-40" : "opacity-0"}`,
|
|
29125
|
+
onClick: onClose
|
|
29126
|
+
}), /*#__PURE__*/React__default["default"].createElement("div", {
|
|
29127
|
+
className: "relative z-10 h-full overflow-y-auto"
|
|
29128
|
+
}, /*#__PURE__*/React__default["default"].createElement("div", {
|
|
29129
|
+
className: "min-h-full flex items-center justify-center p-4 sm:p-8"
|
|
29130
|
+
}, /*#__PURE__*/React__default["default"].createElement("div", {
|
|
29131
|
+
className: `
|
|
29132
|
+
inline-block
|
|
29133
|
+
bg-white rounded-lg shadow-xl
|
|
29134
|
+
transform transition-all duration-200
|
|
29135
|
+
${animate ? "opacity-100 scale-100" : "opacity-0 scale-95"}
|
|
29136
|
+
`,
|
|
29137
|
+
onClick: e => e.stopPropagation()
|
|
29138
|
+
}, children)))), modalRoot);
|
|
29139
|
+
};
|
|
29140
|
+
|
|
29141
|
+
const ModalResult = props => {
|
|
29142
|
+
return /*#__PURE__*/React__default["default"].createElement(Modal, {
|
|
29143
|
+
open: props.isOpen,
|
|
29144
|
+
onClose: props.onClose
|
|
29125
29145
|
}, /*#__PURE__*/React__default["default"].createElement("div", {
|
|
29126
|
-
className: "flex min-h-full items-center justify-center p-4 text-center sm:items-center sm:p-0"
|
|
29127
|
-
}, /*#__PURE__*/React__default["default"].createElement(qe.Child, {
|
|
29128
|
-
as: React.Fragment,
|
|
29129
|
-
enter: "ease-out duration-300",
|
|
29130
|
-
enterFrom: "opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95",
|
|
29131
|
-
enterTo: "opacity-100 translate-y-0 sm:scale-100",
|
|
29132
|
-
leave: "ease-in duration-200",
|
|
29133
|
-
leaveFrom: "opacity-100 translate-y-0 sm:scale-100",
|
|
29134
|
-
leaveTo: "opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95"
|
|
29135
|
-
}, /*#__PURE__*/React__default["default"].createElement(_t.Panel, {
|
|
29136
29146
|
className: "relative transform overflow-hidden rounded-lg bg-white text-left shadow-xl transition-all w-80"
|
|
29137
29147
|
}, /*#__PURE__*/React__default["default"].createElement("div", {
|
|
29138
|
-
className: "bg-white px-4 pb-4 pt-
|
|
29148
|
+
className: "bg-white px-4 pb-4 pt-4 sm:p-4 text-center"
|
|
29139
29149
|
}, /*#__PURE__*/React__default["default"].createElement("div", {
|
|
29140
29150
|
className: "flex justify-center items-center my-3"
|
|
29141
29151
|
}, props.type == "success" ? /*#__PURE__*/React__default["default"].createElement("img", {
|
|
@@ -29148,7 +29158,7 @@
|
|
|
29148
29158
|
className: "text-xl text-black font-semibold mt-2"
|
|
29149
29159
|
}, props.type == "success" ? "Success" : "Failed"), /*#__PURE__*/React__default["default"].createElement("p", {
|
|
29150
29160
|
className: "text-sm text-black mb-2"
|
|
29151
|
-
}, props.subtitle))))
|
|
29161
|
+
}, props.subtitle))));
|
|
29152
29162
|
};
|
|
29153
29163
|
|
|
29154
29164
|
const formatNumber = val => {
|
package/package.json
CHANGED
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import React, { useEffect, useState } from "react";
|
|
2
|
+
import { createPortal } from "react-dom";
|
|
3
|
+
|
|
4
|
+
const Modal = ({ open, onClose = () => {}, children }) => {
|
|
5
|
+
const [visible, setVisible] = useState(open);
|
|
6
|
+
const [animate, setAnimate] = useState(false);
|
|
7
|
+
|
|
8
|
+
useEffect(() => {
|
|
9
|
+
if (open) {
|
|
10
|
+
setVisible(true);
|
|
11
|
+
requestAnimationFrame(() => setAnimate(true));
|
|
12
|
+
document.body.style.overflow = "hidden";
|
|
13
|
+
} else {
|
|
14
|
+
setAnimate(false);
|
|
15
|
+
const t = setTimeout(() => setVisible(false), 200);
|
|
16
|
+
document.body.style.overflow = "";
|
|
17
|
+
return () => clearTimeout(t);
|
|
18
|
+
}
|
|
19
|
+
}, [open]);
|
|
20
|
+
|
|
21
|
+
if (!visible) return null;
|
|
22
|
+
|
|
23
|
+
const modalRoot = document.getElementById("modal-root");
|
|
24
|
+
if (!modalRoot) return null;
|
|
25
|
+
|
|
26
|
+
return createPortal(
|
|
27
|
+
<div className="fixed inset-0" style={{ zIndex: 1001 }} onClick={onClose}>
|
|
28
|
+
{/* Backdrop */}
|
|
29
|
+
<div
|
|
30
|
+
className={`absolute inset-0 bg-black transition-opacity duration-200 ${animate ? "opacity-40" : "opacity-0"}`}
|
|
31
|
+
onClick={onClose}
|
|
32
|
+
/>
|
|
33
|
+
|
|
34
|
+
{/* Scroll container (THIS scrolls) */}
|
|
35
|
+
<div className="relative z-10 h-full overflow-y-auto">
|
|
36
|
+
{/* Centering wrapper */}
|
|
37
|
+
<div className="min-h-full flex items-center justify-center p-4 sm:p-8">
|
|
38
|
+
{/* Modal panel */}
|
|
39
|
+
<div
|
|
40
|
+
className={`
|
|
41
|
+
inline-block
|
|
42
|
+
bg-white rounded-lg shadow-xl
|
|
43
|
+
transform transition-all duration-200
|
|
44
|
+
${animate ? "opacity-100 scale-100" : "opacity-0 scale-95"}
|
|
45
|
+
`}
|
|
46
|
+
onClick={(e) => e.stopPropagation()}
|
|
47
|
+
>
|
|
48
|
+
{children}
|
|
49
|
+
</div>
|
|
50
|
+
</div>
|
|
51
|
+
</div>
|
|
52
|
+
</div>,
|
|
53
|
+
modalRoot
|
|
54
|
+
);
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
export default Modal;
|
|
@@ -1,70 +1,26 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
-
import { Fragment, useRef } from "react";
|
|
3
|
-
import { Dialog, Transition } from "@headlessui/react";
|
|
4
2
|
import LogoSuccess from "../../../assets/images/logo_success.png";
|
|
5
3
|
import LogoFailed from "../../../assets/images/logo_failed.png";
|
|
4
|
+
import Modal from "../modal";
|
|
6
5
|
|
|
7
6
|
const ModalResult = (props) => {
|
|
8
|
-
const cancelButtonRef = useRef(null);
|
|
9
|
-
|
|
10
|
-
function handleBackgroundClick(e) {
|
|
11
|
-
e.stopPropagation();
|
|
12
|
-
}
|
|
13
|
-
|
|
14
7
|
return (
|
|
15
|
-
<
|
|
16
|
-
<
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
<Transition.Child
|
|
25
|
-
as={Fragment}
|
|
26
|
-
enter="ease-out duration-300"
|
|
27
|
-
enterFrom="opacity-0"
|
|
28
|
-
enterTo="opacity-100"
|
|
29
|
-
leave="ease-in duration-200"
|
|
30
|
-
leaveFrom="opacity-100"
|
|
31
|
-
leaveTo="opacity-0"
|
|
32
|
-
>
|
|
33
|
-
<div className="fixed inset-0 bg-black bg-opacity-25 transition-opacity" onClick={handleBackgroundClick} />
|
|
34
|
-
</Transition.Child>
|
|
35
|
-
|
|
36
|
-
<div className="fixed inset-0 z-10 w-screen overflow-y-auto">
|
|
37
|
-
<div className="flex min-h-full items-center justify-center p-4 text-center sm:items-center sm:p-0">
|
|
38
|
-
<Transition.Child
|
|
39
|
-
as={Fragment}
|
|
40
|
-
enter="ease-out duration-300"
|
|
41
|
-
enterFrom="opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95"
|
|
42
|
-
enterTo="opacity-100 translate-y-0 sm:scale-100"
|
|
43
|
-
leave="ease-in duration-200"
|
|
44
|
-
leaveFrom="opacity-100 translate-y-0 sm:scale-100"
|
|
45
|
-
leaveTo="opacity-0 translate-y-4 sm:translate-y-0 sm:scale-95"
|
|
46
|
-
>
|
|
47
|
-
<Dialog.Panel className="relative transform overflow-hidden rounded-lg bg-white text-left shadow-xl transition-all w-80">
|
|
48
|
-
<div className="bg-white px-4 pb-4 pt-5 sm:p-4 text-center">
|
|
49
|
-
<div className="flex justify-center items-center my-3">
|
|
50
|
-
{props.type == "success" ? (
|
|
51
|
-
<img src={LogoSuccess} className="w-14 h-14" />
|
|
52
|
-
) : (
|
|
53
|
-
<img src={LogoFailed} className="w-14 h-14" />
|
|
54
|
-
)}
|
|
55
|
-
</div>
|
|
56
|
-
<p className="text-xl text-black font-semibold mt-2">
|
|
57
|
-
{props.type == "success" ? "Success" : "Failed"}
|
|
58
|
-
</p>
|
|
59
|
-
<p className="text-sm text-black mb-2">{props.subtitle}</p>
|
|
60
|
-
</div>
|
|
61
|
-
</Dialog.Panel>
|
|
62
|
-
</Transition.Child>
|
|
8
|
+
<Modal open={props.isOpen} onClose={props.onClose}>
|
|
9
|
+
<div className="relative transform overflow-hidden rounded-lg bg-white text-left shadow-xl transition-all w-80">
|
|
10
|
+
<div className="bg-white px-4 pb-4 pt-4 sm:p-4 text-center">
|
|
11
|
+
<div className="flex justify-center items-center my-3">
|
|
12
|
+
{props.type == "success" ? (
|
|
13
|
+
<img src={LogoSuccess} className="w-14 h-14" />
|
|
14
|
+
) : (
|
|
15
|
+
<img src={LogoFailed} className="w-14 h-14" />
|
|
16
|
+
)}
|
|
63
17
|
</div>
|
|
18
|
+
<p className="text-xl text-black font-semibold mt-2">{props.type == "success" ? "Success" : "Failed"}</p>
|
|
19
|
+
<p className="text-sm text-black mb-2">{props.subtitle}</p>
|
|
64
20
|
</div>
|
|
65
|
-
</
|
|
66
|
-
</
|
|
21
|
+
</div>
|
|
22
|
+
</Modal>
|
|
67
23
|
);
|
|
68
24
|
};
|
|
69
25
|
|
|
70
|
-
export default ModalResult;
|
|
26
|
+
export default ModalResult;
|