linkmore-design
Version:
π πlmη»δ»ΆεΊγπ
86 lines (82 loc) β’ 2.85 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = useModal;
var React = _interopRequireWildcard(require("react"));
var _usePatchElement = _interopRequireDefault(require("../../_util/hooks/usePatchElement"));
var _confirm = require("../confirm");
var _HookModal = _interopRequireDefault(require("./HookModal"));
let uuid = 0;
const ElementsHolder = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef((_props, ref) => {
const [elements, patchElement] = (0, _usePatchElement.default)();
React.useImperativeHandle(ref, () => ({
patchElement
}), []);
// eslint-disable-next-line react/jsx-no-useless-fragment
return /*#__PURE__*/React.createElement(React.Fragment, null, elements);
}));
function useModal() {
const holderRef = React.useRef(null);
// ========================== Effect ==========================
const [actionQueue, setActionQueue] = React.useState([]);
React.useEffect(() => {
if (actionQueue.length) {
const cloneQueue = [...actionQueue];
cloneQueue.forEach(action => {
action();
});
setActionQueue([]);
}
}, [actionQueue]);
// =========================== Hook ===========================
const getConfirmFunc = React.useCallback(withFunc => function hookConfirm(config) {
uuid += 1;
const modalRef = /*#__PURE__*/React.createRef();
let closeFunc;
const modal = /*#__PURE__*/React.createElement(_HookModal.default, {
key: `modal-${uuid}`,
config: withFunc(config),
ref: modalRef,
afterClose: () => {
closeFunc?.();
}
});
closeFunc = holderRef.current?.patchElement(modal);
return {
destroy: () => {
function destroyAction() {
modalRef.current?.destroy();
}
if (modalRef.current) {
destroyAction();
} else {
setActionQueue(prev => [...prev, destroyAction]);
}
},
update: newConfig => {
function updateAction() {
modalRef.current?.update(newConfig);
}
if (modalRef.current) {
updateAction();
} else {
setActionQueue(prev => [...prev, updateAction]);
}
}
};
}, []);
const fns = React.useMemo(() => ({
info: getConfirmFunc(_confirm.withInfo),
success: getConfirmFunc(_confirm.withSuccess),
error: getConfirmFunc(_confirm.withError),
warning: getConfirmFunc(_confirm.withWarn),
confirm: getConfirmFunc(_confirm.withConfirm)
}), []);
// eslint-disable-next-line react/jsx-key
return [fns, /*#__PURE__*/React.createElement(ElementsHolder, {
ref: holderRef
})];
}