payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
197 lines (196 loc) • 15.4 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, {
ListDrawer: function() {
return ListDrawer;
},
ListDrawerToggler: function() {
return ListDrawerToggler;
},
baseClass: function() {
return baseClass;
},
formatListDrawerSlug: function() {
return formatListDrawerSlug;
},
useListDrawer: function() {
return useListDrawer;
}
});
const _modal = require("@faceless-ui/modal");
const _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
const _Config = require("../../utilities/Config");
const _EditDepth = require("../../utilities/EditDepth");
const _Drawer = require("../Drawer");
const _DrawerContent = require("./DrawerContent");
require("./index.scss");
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 = 'list-drawer';
const formatListDrawerSlug = ({ depth, uuid })=>`list-drawer_${depth}_${uuid}`;
const ListDrawerToggler = ({ children, className, disabled, drawerSlug, ...rest })=>{
return /*#__PURE__*/ _react.default.createElement(_Drawer.DrawerToggler, {
className: [
className,
`${baseClass}__toggler`
].filter(Boolean).join(' '),
disabled: disabled,
slug: drawerSlug,
...rest
}, children);
};
const ListDrawer = (props)=>{
const { drawerSlug } = props;
return /*#__PURE__*/ _react.default.createElement(_Drawer.Drawer, {
className: baseClass,
gutter: false,
header: false,
slug: drawerSlug
}, /*#__PURE__*/ _react.default.createElement(_DrawerContent.ListDrawerContent, props));
};
const useListDrawer = ({ collectionSlugs: collectionSlugsFromProps, filterOptions, selectedCollection, uploads })=>{
const { collections } = (0, _Config.useConfig)();
const drawerDepth = (0, _EditDepth.useEditDepth)();
const uuid = (0, _react.useId)();
const { closeModal, modalState, openModal, toggleModal } = (0, _modal.useModal)();
const [isOpen, setIsOpen] = (0, _react.useState)(false);
const [collectionSlugs, setCollectionSlugs] = (0, _react.useState)(collectionSlugsFromProps);
const drawerSlug = formatListDrawerSlug({
depth: drawerDepth,
uuid
});
(0, _react.useEffect)(()=>{
setIsOpen(Boolean(modalState[drawerSlug]?.isOpen));
}, [
modalState,
drawerSlug
]);
(0, _react.useEffect)(()=>{
if (!collectionSlugs || collectionSlugs.length === 0) {
const filteredCollectionSlugs = collections.filter(({ upload })=>{
if (uploads) {
return Boolean(upload) === true;
}
return true;
});
setCollectionSlugs(filteredCollectionSlugs.map(({ slug })=>slug));
}
}, [
collectionSlugs,
uploads,
collections
]);
const toggleDrawer = (0, _react.useCallback)(()=>{
toggleModal(drawerSlug);
}, [
toggleModal,
drawerSlug
]);
const closeDrawer = (0, _react.useCallback)(()=>{
closeModal(drawerSlug);
}, [
drawerSlug,
closeModal
]);
const openDrawer = (0, _react.useCallback)(()=>{
openModal(drawerSlug);
}, [
drawerSlug,
openModal
]);
const MemoizedDrawer = (0, _react.useMemo)(()=>{
return (props)=>/*#__PURE__*/ _react.default.createElement(ListDrawer, {
...props,
closeDrawer: closeDrawer,
collectionSlugs: collectionSlugs,
drawerSlug: drawerSlug,
filterOptions: filterOptions,
key: drawerSlug,
selectedCollection: selectedCollection,
uploads: uploads
});
}, [
drawerSlug,
collectionSlugs,
uploads,
closeDrawer,
selectedCollection,
filterOptions
]);
const MemoizedDrawerToggler = (0, _react.useMemo)(()=>{
return (props)=>/*#__PURE__*/ _react.default.createElement(ListDrawerToggler, {
...props,
drawerSlug: drawerSlug
});
}, [
drawerSlug
]);
const MemoizedDrawerState = (0, _react.useMemo)(()=>({
closeDrawer,
drawerDepth,
drawerSlug,
isDrawerOpen: isOpen,
openDrawer,
toggleDrawer
}), [
drawerDepth,
drawerSlug,
isOpen,
toggleDrawer,
closeDrawer,
openDrawer
]);
return [
MemoizedDrawer,
MemoizedDrawerToggler,
MemoizedDrawerState
];
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/ListDrawer/index.tsx"],"sourcesContent":["import { useModal } from '@faceless-ui/modal'\nimport React, { useCallback, useEffect, useId, useMemo, useState } from 'react'\n\nimport type { ListDrawerProps, ListTogglerProps, UseListDrawer } from './types'\n\nimport { useConfig } from '../../utilities/Config'\nimport { useEditDepth } from '../../utilities/EditDepth'\nimport { Drawer, DrawerToggler } from '../Drawer'\nimport { ListDrawerContent } from './DrawerContent'\nimport './index.scss'\n\nexport const baseClass = 'list-drawer'\n\nexport const formatListDrawerSlug = ({\n  depth,\n  uuid,\n}: {\n  depth: number\n  uuid: string // supply when creating a new document and no id is available\n}) => `list-drawer_${depth}_${uuid}`\n\nexport const ListDrawerToggler: React.FC<ListTogglerProps> = ({\n  children,\n  className,\n  disabled,\n  drawerSlug,\n  ...rest\n}) => {\n  return (\n    <DrawerToggler\n      className={[className, `${baseClass}__toggler`].filter(Boolean).join(' ')}\n      disabled={disabled}\n      slug={drawerSlug}\n      {...rest}\n    >\n      {children}\n    </DrawerToggler>\n  )\n}\n\nexport const ListDrawer: React.FC<ListDrawerProps> = (props) => {\n  const { drawerSlug } = props\n\n  return (\n    <Drawer className={baseClass} gutter={false} header={false} slug={drawerSlug}>\n      <ListDrawerContent {...props} />\n    </Drawer>\n  )\n}\n\nexport const useListDrawer: UseListDrawer = ({\n  collectionSlugs: collectionSlugsFromProps,\n  filterOptions,\n  selectedCollection,\n  uploads,\n}) => {\n  const { collections } = useConfig()\n  const drawerDepth = useEditDepth()\n  const uuid = useId()\n  const { closeModal, modalState, openModal, toggleModal } = useModal()\n  const [isOpen, setIsOpen] = useState(false)\n  const [collectionSlugs, setCollectionSlugs] = useState(collectionSlugsFromProps)\n\n  const drawerSlug = formatListDrawerSlug({\n    depth: drawerDepth,\n    uuid,\n  })\n\n  useEffect(() => {\n    setIsOpen(Boolean(modalState[drawerSlug]?.isOpen))\n  }, [modalState, drawerSlug])\n\n  useEffect(() => {\n    if (!collectionSlugs || collectionSlugs.length === 0) {\n      const filteredCollectionSlugs = collections.filter(({ upload }) => {\n        if (uploads) {\n          return Boolean(upload) === true\n        }\n        return true\n      })\n\n      setCollectionSlugs(filteredCollectionSlugs.map(({ slug }) => slug))\n    }\n  }, [collectionSlugs, uploads, collections])\n  const toggleDrawer = useCallback(() => {\n    toggleModal(drawerSlug)\n  }, [toggleModal, drawerSlug])\n\n  const closeDrawer = useCallback(() => {\n    closeModal(drawerSlug)\n  }, [drawerSlug, closeModal])\n\n  const openDrawer = useCallback(() => {\n    openModal(drawerSlug)\n  }, [drawerSlug, openModal])\n\n  const MemoizedDrawer = useMemo(() => {\n    return (props) => (\n      <ListDrawer\n        {...props}\n        closeDrawer={closeDrawer}\n        collectionSlugs={collectionSlugs}\n        drawerSlug={drawerSlug}\n        filterOptions={filterOptions}\n        key={drawerSlug}\n        selectedCollection={selectedCollection}\n        uploads={uploads}\n      />\n    )\n  }, [drawerSlug, collectionSlugs, uploads, closeDrawer, selectedCollection, filterOptions])\n\n  const MemoizedDrawerToggler = useMemo(() => {\n    return (props) => <ListDrawerToggler {...props} drawerSlug={drawerSlug} />\n  }, [drawerSlug])\n\n  const MemoizedDrawerState = useMemo(\n    () => ({\n      closeDrawer,\n      drawerDepth,\n      drawerSlug,\n      isDrawerOpen: isOpen,\n      openDrawer,\n      toggleDrawer,\n    }),\n    [drawerDepth, drawerSlug, isOpen, toggleDrawer, closeDrawer, openDrawer],\n  )\n\n  return [MemoizedDrawer, MemoizedDrawerToggler, MemoizedDrawerState]\n}\n"],"names":["ListDrawer","ListDrawerToggler","baseClass","formatListDrawerSlug","useListDrawer","depth","uuid","children","className","disabled","drawerSlug","rest","DrawerToggler","filter","Boolean","join","slug","props","Drawer","gutter","header","ListDrawerContent","collectionSlugs","collectionSlugsFromProps","filterOptions","selectedCollection","uploads","collections","useConfig","drawerDepth","useEditDepth","useId","closeModal","modalState","openModal","toggleModal","useModal","isOpen","setIsOpen","useState","setCollectionSlugs","useEffect","length","filteredCollectionSlugs","upload","map","toggleDrawer","useCallback","closeDrawer","openDrawer","MemoizedDrawer","useMemo","key","MemoizedDrawerToggler","MemoizedDrawerState","isDrawerOpen"],"mappings":"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"}