UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

160 lines (159 loc) • 14.5 kB
"use strict"; 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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"}