react-modal-promise
Version:
Promise wrapper for React components
189 lines (177 loc) • 24.8 kB
JavaScript
import React, { forwardRef, useRef, useState, useCallback, useEffect, useImperativeHandle, useMemo } from 'react';
/*! *****************************************************************************
Copyright (c) Microsoft Corporation.
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */
var __assign = function() {
__assign = Object.assign || function __assign(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
function __rest(s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function")
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
t[p[i]] = s[p[i]];
}
return t;
}
function __spreadArray(to, from) {
for (var i = 0, il = from.length, j = to.length; i < il; i++, j++)
to[j] = from[i];
return to;
}
var hexGen = function (len) {
if (len === void 0) { len = 12; }
var maxlen = 8;
var min = Math.pow(16, Math.min(len, maxlen) - 1);
var max = Math.pow(16, Math.min(len, maxlen)) - 1;
var n = Math.floor(Math.random() * (max - min + 1)) + min;
var r = n.toString(16);
while (r.length < len) {
r = r + hexGen(len - maxlen);
}
return r;
};
var DEFAULT_SCOPE = 'stack';
var SCOPE_KEY = 'factoryStack';
if (typeof window !== 'undefined') {
if (!window[SCOPE_KEY]) {
window[SCOPE_KEY] = {};
}
}
var registerContainer = function (scope, ref) {
window[SCOPE_KEY][scope] = ref;
return ref;
};
var unregisterContainer = function (scope) {
delete window[SCOPE_KEY][scope];
};
var getContainer = function (scope) {
return window[SCOPE_KEY][scope || DEFAULT_SCOPE];
};
var InstanceContainer = function (props, ref) {
var _a = (props || {}).scope, scope = _a === void 0 ? DEFAULT_SCOPE : _a;
var propsRef = useRef(props);
var _b = useState({}), instances = _b[0], setInstances = _b[1];
var _c = useState([]), hashStack = _c[0], setHashStack = _c[1];
var resolve = useCallback(function (hash, v) { var _a; return (_a = instances === null || instances === void 0 ? void 0 : instances[hash]) === null || _a === void 0 ? void 0 : _a.resolve(v); }, [instances]);
var resolveAll = useCallback(function (v) { return Object.values(instances).forEach(function (i) { return i.resolve(v); }); }, [instances]);
var reject = useCallback(function (hash, r) { var _a; return (_a = instances === null || instances === void 0 ? void 0 : instances[hash]) === null || _a === void 0 ? void 0 : _a.reject(r); }, [instances]);
var rejectAll = useCallback(function (r) { return Object.values(instances).forEach(function (i) { return i.reject(r); }); }, [instances]);
var hasInstance = useCallback(function (hash) { return !!hashStack.find(function (id) { return id === hash; }); }, [hashStack]);
var getInstance = useCallback(function (hash) { return instances === null || instances === void 0 ? void 0 : instances[hash]; }, [
instances,
]);
var remove = function (hash, options) {
var _a;
setHashStack(function (stack) { return stack.filter(function (s) { return s !== hash; }); });
setTimeout(function () {
setInstances(function (instances) {
var _a = instances, _b = hash; _a[_b]; var omitHash = __rest(_a, [typeof _b === "symbol" ? _b : _b + ""]);
return omitHash;
});
}, options === null || options === void 0 ? void 0 : options.exitTimeout);
(_a = props.onRemove) === null || _a === void 0 ? void 0 : _a.call(props, hash);
};
var create = function (Component, options, instanceProps) {
if (options === void 0) { options = {}; }
return new Promise(function (res, rej) {
var hash = (instanceProps === null || instanceProps === void 0 ? void 0 : instanceProps.instanceId) || hexGen();
var _a = propsRef.current, enterTimeout = _a.enterTimeout, exitTimeout = _a.exitTimeout, isAppendIntances = _a.isAppendIntances, onResolve = _a.onResolve, onReject = _a.onReject;
var instanceOptions = __assign({ enterTimeout: enterTimeout,
exitTimeout: exitTimeout, instanceId: hash }, options);
var instance = __assign({ Component: Component, props: __assign(__assign({}, options), instanceProps), resolve: function (v) {
removeRef.current(hash, instanceOptions);
res(v);
onResolve === null || onResolve === void 0 ? void 0 : onResolve(v, hash);
}, reject: function (r) {
removeRef.current(hash, instanceOptions);
rej(r);
onReject === null || onReject === void 0 ? void 0 : onReject(r, hash);
} }, instanceOptions);
setInstances(function (instances) {
var _a, _b;
return isAppendIntances
? __assign(__assign({}, instances), (_a = {}, _a[hash] = instance, _a)) : __assign((_b = {}, _b[hash] = instance, _b), instances);
});
setTimeout(function () {
var _a, _b;
setHashStack(function (stack) { return __spreadArray(__spreadArray([], stack), [hash]); });
(_b = (_a = propsRef.current).onOpen) === null || _b === void 0 ? void 0 : _b.call(_a, hash, instance);
}, instanceOptions.enterTimeout);
});
};
var removeRef = useRef(remove);
var createRef = useRef(create);
useEffect(function () {
propsRef.current = props;
removeRef.current = remove;
createRef.current = create;
});
useImperativeHandle(ref, function () { return ({
create: createRef.current,
resolve: resolve,
reject: reject,
resolveAll: resolveAll,
rejectAll: rejectAll,
hasInstance: hasInstance,
getInstance: getInstance,
}); });
useEffect(function () {
registerContainer(scope, {
create: createRef.current,
resolve: resolve,
reject: reject,
resolveAll: resolveAll,
rejectAll: rejectAll,
hasInstance: hasInstance,
getInstance: getInstance,
});
return function () { return unregisterContainer(scope); };
}, [scope]);
var mapKeys = useMemo(function () {
var keys = Object.keys(instances);
return keys.map(function (key) {
var _a = instances[key], Component = _a.Component, props = _a.props, resolve = _a.resolve, reject = _a.reject;
var isOpen = !!hashStack.find(function (h) { return h === key; });
return (React.createElement(Component, __assign({}, props, { key: key, isOpen: isOpen, onReject: reject, onResolve: resolve,
/** @deprecated **/
close: resolve,
/** @deprecated **/
open: isOpen })));
});
}, [instances, hashStack]);
return React.createElement(React.Fragment, null, mapKeys);
};
var Container = forwardRef(InstanceContainer);
Container.defaultProps = {
exitTimeout: 500,
enterTimeout: 50,
};
/** @deprecated */
var createModal = function (Component, options) { return function (props) {
return getContainer(options === null || options === void 0 ? void 0 : options.scope).create(Component, options, props);
}; };
var create = function (Component, options) { return function (props) {
return getContainer(options === null || options === void 0 ? void 0 : options.scope).create(Component, options, props);
}; };
export default Container;
export { Container, DEFAULT_SCOPE, SCOPE_KEY, create, createModal, getContainer, hexGen, registerContainer, unregisterContainer };
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.es.js","sources":["../src/utils/hex-gen.ts","../src/utils/register-scope.ts","../src/Container.tsx","../src/create.tsx"],"sourcesContent":["export type Hex = string\n\nexport const hexGen = (len: number = 12): Hex => {\n  const maxlen = 8\n  const min = Math.pow(16, Math.min(len, maxlen) - 1)\n  const max = Math.pow(16, Math.min(len, maxlen)) - 1\n  const n = Math.floor(Math.random() * (max - min + 1)) + min\n  let r = n.toString(16)\n  while (r.length < len) {\n    r = r + hexGen(len - maxlen)\n  }\n  return r\n}\n","import { Scope, ScopeModel, ContainerRef } from '../types'\n\nexport const DEFAULT_SCOPE = 'stack'\nexport const SCOPE_KEY = 'factoryStack'\ndeclare global {\n  interface Window {\n    [SCOPE_KEY]: ScopeModel\n  }\n}\n\nif (typeof window !== 'undefined') {\n  if (!window[SCOPE_KEY]) {\n    window[SCOPE_KEY] = {}\n  }\n}\n\nexport const registerContainer = (scope: Scope, ref: ContainerRef) => {\n  window[SCOPE_KEY][scope] = ref\n\n  return ref\n}\n\nexport const unregisterContainer = (scope: Scope) => {\n  delete window[SCOPE_KEY][scope]\n}\n\nexport const getContainer = (scope?: Scope) =>\n  window[SCOPE_KEY][scope || DEFAULT_SCOPE]\n","import React, {\n  useRef,\n  useImperativeHandle,\n  forwardRef,\n  useState,\n  useEffect,\n  useMemo,\n  useCallback,\n} from 'react'\n\nimport {\n  hexGen,\n  Hex,\n  registerContainer,\n  unregisterContainer,\n  DEFAULT_SCOPE,\n} from './utils'\n\nimport {\n  ContainerRef,\n  ContainerProps,\n  Instance,\n  InstanceId,\n  InstanceCreator,\n  InstanceOptions,\n} from './types'\n\nconst InstanceContainer: React.ForwardRefRenderFunction<\n  ContainerRef,\n  ContainerProps\n> = (props, ref) => {\n  const { scope = DEFAULT_SCOPE } = props || {}\n\n  const propsRef = useRef(props)\n\n  const [instances, setInstances] = useState<{ [key: string]: Instance }>({})\n  const [hashStack, setHashStack] = useState<Hex[]>([])\n\n  const resolve = useCallback(\n    (hash: InstanceId, v) => instances?.[hash]?.resolve(v),\n    [instances]\n  )\n  const resolveAll = useCallback(\n    v => Object.values(instances).forEach(i => i.resolve(v)),\n    [instances]\n  )\n\n  const reject = useCallback(\n    (hash: InstanceId, r) => instances?.[hash]?.reject(r),\n    [instances]\n  )\n  const rejectAll = useCallback(\n    r => Object.values(instances).forEach(i => i.reject(r)),\n    [instances]\n  )\n  const hasInstance = useCallback(\n    (hash: InstanceId) => !!hashStack.find(id => id === hash),\n    [hashStack]\n  )\n  const getInstance = useCallback((hash: InstanceId) => instances?.[hash], [\n    instances,\n  ])\n\n  const remove = (hash: InstanceId, options: InstanceOptions): void => {\n    setHashStack(stack => stack.filter(s => s !== hash))\n\n    setTimeout(() => {\n      setInstances(instances => {\n        const { [hash]: _, ...omitHash } = instances\n\n        return omitHash\n      })\n    }, options?.exitTimeout)\n\n    props.onRemove?.(hash)\n  }\n\n  const create: InstanceCreator = (Component, options = {}, instanceProps) =>\n    new Promise((res, rej) => {\n      const hash = instanceProps?.instanceId || hexGen()\n\n      const {\n        enterTimeout,\n        exitTimeout,\n        isAppendIntances,\n        onResolve,\n        onReject,\n      } = propsRef.current\n\n      const instanceOptions = {\n        enterTimeout,\n        exitTimeout,\n        instanceId: hash,\n        ...options,\n      }\n\n      const instance: Instance = {\n        Component,\n        props: { ...options, ...instanceProps },\n        resolve: v => {\n          removeRef.current(hash, instanceOptions)\n          res(v)\n          onResolve?.(v, hash)\n        },\n        reject: r => {\n          removeRef.current(hash, instanceOptions)\n          rej(r)\n          onReject?.(r, hash)\n        },\n        ...instanceOptions,\n      }\n\n      setInstances(instances =>\n        isAppendIntances\n          ? {\n              ...instances,\n              [hash]: instance,\n            }\n          : {\n              [hash]: instance,\n              ...instances,\n            }\n      )\n\n      setTimeout(() => {\n        setHashStack(stack => [...stack, hash])\n        propsRef.current.onOpen?.(hash, instance)\n      }, instanceOptions.enterTimeout)\n    })\n\n  const removeRef = useRef(remove)\n  const createRef = useRef(create)\n\n  useEffect(() => {\n    propsRef.current = props\n    removeRef.current = remove\n    createRef.current = create\n  })\n\n  useImperativeHandle(ref, () => ({\n    create: createRef.current,\n    resolve,\n    reject,\n    resolveAll,\n    rejectAll,\n    hasInstance,\n    getInstance,\n  }))\n\n  useEffect(() => {\n    registerContainer(scope, {\n      create: createRef.current,\n      resolve,\n      reject,\n      resolveAll,\n      rejectAll,\n      hasInstance,\n      getInstance,\n    })\n\n    return () => unregisterContainer(scope)\n  }, [scope])\n\n  const mapKeys = useMemo(() => {\n    const keys = Object.keys(instances)\n\n    return keys.map(key => {\n      const { Component, props, resolve, reject } = instances[key]\n\n      const isOpen = !!hashStack.find(h => h === key)\n\n      return (\n        <Component\n          {...props}\n          key={key}\n          isOpen={isOpen}\n          onReject={reject}\n          onResolve={resolve}\n          /** @deprecated **/\n          close={resolve}\n          /** @deprecated **/\n          open={isOpen}\n        />\n      )\n    })\n  }, [instances, hashStack])\n\n  return <>{mapKeys}</>\n}\n\nexport const Container = forwardRef(InstanceContainer)\n\nContainer.defaultProps = {\n  exitTimeout: 500,\n  enterTimeout: 50,\n}\n","import { getContainer } from './utils'\nimport { CreateInstance } from './types'\n\n/** @deprecated */\nexport const createModal: CreateInstance = (Component, options) => props =>\n  getContainer(options?.scope).create(Component, options, props)\n\nexport const create: CreateInstance = (Component, options) => props =>\n  getContainer(options?.scope).create(Component, options, props)\n"],"names":[],"mappings":"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"}