payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
160 lines (159 loc) • 14.5 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
function _export(target, all) {
for(var name in all)Object.defineProperty(target, name, {
enumerable: true,
get: all[name]
});
}
_export(exports, {
Drawer: function() {
return Drawer;
},
DrawerToggler: function() {
return DrawerToggler;
},
formatDrawerSlug: function() {
return formatDrawerSlug;
}
});
const _modal = require("@faceless-ui/modal");
const _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
const _reacti18next = require("react-i18next");
const _X = /*#__PURE__*/ _interop_require_default(require("../../icons/X"));
const _EditDepth = require("../../utilities/EditDepth");
const _Gutter = require("../Gutter");
require("./index.scss");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
function _getRequireWildcardCache(nodeInterop) {
if (typeof WeakMap !== "function") return null;
var cacheBabelInterop = new WeakMap();
var cacheNodeInterop = new WeakMap();
return (_getRequireWildcardCache = function(nodeInterop) {
return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
})(nodeInterop);
}
function _interop_require_wildcard(obj, nodeInterop) {
if (!nodeInterop && obj && obj.__esModule) {
return obj;
}
if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
return {
default: obj
};
}
var cache = _getRequireWildcardCache(nodeInterop);
if (cache && cache.has(obj)) {
return cache.get(obj);
}
var newObj = {
__proto__: null
};
var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
for(var key in obj){
if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
if (desc && (desc.get || desc.set)) {
Object.defineProperty(newObj, key, desc);
} else {
newObj[key] = obj[key];
}
}
}
newObj.default = obj;
if (cache) {
cache.set(obj, newObj);
}
return newObj;
}
const baseClass = 'drawer';
const zBase = 100;
const formatDrawerSlug = ({ depth, slug })=>`drawer_${depth}_${slug}`;
const DrawerToggler = ({ children, className, disabled, onClick, slug, ...rest })=>{
const { openModal } = (0, _modal.useModal)();
const handleClick = (0, _react.useCallback)((e)=>{
openModal(slug);
if (typeof onClick === 'function') onClick(e);
}, [
openModal,
slug,
onClick
]);
return /*#__PURE__*/ _react.default.createElement("button", {
className: className,
disabled: disabled,
onClick: handleClick,
type: "button",
...rest
}, children);
};
const Drawer = ({ children, className, gutter = true, header, hoverTitle, slug, title })=>{
const { t } = (0, _reacti18next.useTranslation)('general');
const { closeModal, modalState } = (0, _modal.useModal)();
const drawerDepth = (0, _EditDepth.useEditDepth)();
const [isOpen, setIsOpen] = (0, _react.useState)(false);
const [animateIn, setAnimateIn] = (0, _react.useState)(false);
(0, _react.useEffect)(()=>{
setIsOpen(modalState[slug]?.isOpen);
}, [
slug,
modalState
]);
(0, _react.useEffect)(()=>{
setAnimateIn(isOpen);
}, [
isOpen
]);
if (isOpen) {
// IMPORTANT: do not render the drawer until it is explicitly open, this is to avoid large html trees especially when nesting drawers
return /*#__PURE__*/ _react.default.createElement(_modal.Modal, {
className: [
className,
baseClass,
animateIn && `${baseClass}--is-open`,
drawerDepth > 1 && `${baseClass}--nested`
].filter(Boolean).join(' '),
slug: slug,
style: {
zIndex: zBase + drawerDepth
}
}, (!drawerDepth || drawerDepth === 1) && /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__blur-bg`
}), /*#__PURE__*/ _react.default.createElement("button", {
"aria-label": t('close'),
className: `${baseClass}__close`,
id: `close-drawer__${slug}`,
onClick: ()=>closeModal(slug),
type: "button"
}), /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__content`
}, /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__blur-bg-content`
}), /*#__PURE__*/ _react.default.createElement(_Gutter.Gutter, {
className: `${baseClass}__content-children`,
left: gutter,
right: gutter
}, /*#__PURE__*/ _react.default.createElement(_EditDepth.EditDepthContext.Provider, {
value: drawerDepth + 1
}, header && header, header === undefined && /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__header`
}, /*#__PURE__*/ _react.default.createElement("h2", {
className: `${baseClass}__header__title`,
title: hoverTitle ? title : null
}, title), /*#__PURE__*/ _react.default.createElement("button", {
"aria-label": t('close'),
className: `${baseClass}__header__close`,
id: `close-drawer__${slug}`,
onClick: ()=>closeModal(slug),
type: "button"
}, /*#__PURE__*/ _react.default.createElement(_X.default, null))), children))));
}
return null;
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/Drawer/index.tsx"],"sourcesContent":["import { Modal, useModal } from '@faceless-ui/modal'\nimport React, { useCallback, useEffect, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport type { Props, TogglerProps } from './types'\n\nimport X from '../../icons/X'\nimport { EditDepthContext, useEditDepth } from '../../utilities/EditDepth'\nimport { Gutter } from '../Gutter'\nimport './index.scss'\n\nconst baseClass = 'drawer'\nconst zBase = 100\n\nexport const formatDrawerSlug = ({ depth, slug }: { depth: number; slug: string }): string =>\n  `drawer_${depth}_${slug}`\n\nexport const DrawerToggler: React.FC<TogglerProps> = ({\n  children,\n  className,\n  disabled,\n  onClick,\n  slug,\n  ...rest\n}) => {\n  const { openModal } = useModal()\n\n  const handleClick = useCallback(\n    (e) => {\n      openModal(slug)\n      if (typeof onClick === 'function') onClick(e)\n    },\n    [openModal, slug, onClick],\n  )\n\n  return (\n    <button className={className} disabled={disabled} onClick={handleClick} type=\"button\" {...rest}>\n      {children}\n    </button>\n  )\n}\n\nexport const Drawer: React.FC<Props> = ({\n  children,\n  className,\n  gutter = true,\n  header,\n  hoverTitle,\n  slug,\n  title,\n}) => {\n  const { t } = useTranslation('general')\n  const { closeModal, modalState } = useModal()\n  const drawerDepth = useEditDepth()\n  const [isOpen, setIsOpen] = useState(false)\n  const [animateIn, setAnimateIn] = useState(false)\n\n  useEffect(() => {\n    setIsOpen(modalState[slug]?.isOpen)\n  }, [slug, modalState])\n\n  useEffect(() => {\n    setAnimateIn(isOpen)\n  }, [isOpen])\n\n  if (isOpen) {\n    // IMPORTANT: do not render the drawer until it is explicitly open, this is to avoid large html trees especially when nesting drawers\n\n    return (\n      <Modal\n        className={[\n          className,\n          baseClass,\n          animateIn && `${baseClass}--is-open`,\n          drawerDepth > 1 && `${baseClass}--nested`,\n        ]\n          .filter(Boolean)\n          .join(' ')}\n        slug={slug}\n        style={{\n          zIndex: zBase + drawerDepth,\n        }}\n      >\n        {(!drawerDepth || drawerDepth === 1) && <div className={`${baseClass}__blur-bg`} />}\n        <button\n          aria-label={t('close')}\n          className={`${baseClass}__close`}\n          id={`close-drawer__${slug}`}\n          onClick={() => closeModal(slug)}\n          type=\"button\"\n        />\n        <div className={`${baseClass}__content`}>\n          <div className={`${baseClass}__blur-bg-content`} />\n          <Gutter className={`${baseClass}__content-children`} left={gutter} right={gutter}>\n            <EditDepthContext.Provider value={drawerDepth + 1}>\n              {header && header}\n              {header === undefined && (\n                <div className={`${baseClass}__header`}>\n                  <h2 className={`${baseClass}__header__title`} title={hoverTitle ? title : null}>\n                    {title}\n                  </h2>\n                  <button\n                    aria-label={t('close')}\n                    className={`${baseClass}__header__close`}\n                    id={`close-drawer__${slug}`}\n                    onClick={() => closeModal(slug)}\n                    type=\"button\"\n                  >\n                    <X />\n                  </button>\n                </div>\n              )}\n              {children}\n            </EditDepthContext.Provider>\n          </Gutter>\n        </div>\n      </Modal>\n    )\n  }\n\n  return null\n}\n"],"names":["Drawer","DrawerToggler","formatDrawerSlug","baseClass","zBase","depth","slug","children","className","disabled","onClick","rest","openModal","useModal","handleClick","useCallback","e","button","type","gutter","header","hoverTitle","title","t","useTranslation","closeModal","modalState","drawerDepth","useEditDepth","isOpen","setIsOpen","useState","animateIn","setAnimateIn","useEffect","Modal","filter","Boolean","join","style","zIndex","div","aria-label","id","Gutter","left","right","EditDepthContext","Provider","value","undefined","h2","X"],"mappings":"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"}