UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

197 lines (196 loc) • 15.4 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, { 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":";;;;;;;;;;;IAwCaA,UAAU;eAAVA;;IAnBAC,iBAAiB;eAAjBA;;IAVAC,SAAS;eAATA;;IAEAC,oBAAoB;eAApBA;;IAqCAC,aAAa;eAAbA;;;uBAlDY;+DAC+C;wBAI9C;2BACG;wBACS;+BACJ;QAC3B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,MAAMF,YAAY;AAElB,MAAMC,uBAAuB,CAAC,EACnCE,KAAK,EACLC,IAAI,EAIL,GAAK,CAAC,YAAY,EAAED,MAAM,CAAC,EAAEC,KAAK,CAAC;AAE7B,MAAML,oBAAgD,CAAC,EAC5DM,QAAQ,EACRC,SAAS,EACTC,QAAQ,EACRC,UAAU,EACV,GAAGC,MACJ;IACC,qBACE,6BAACC,qBAAa;QACZJ,WAAW;YAACA;YAAW,CAAC,EAAEN,UAAU,SAAS,CAAC;SAAC,CAACW,MAAM,CAACC,SAASC,IAAI,CAAC;QACrEN,UAAUA;QACVO,MAAMN;QACL,GAAGC,IAAI;OAEPJ;AAGP;AAEO,MAAMP,aAAwC,CAACiB;IACpD,MAAM,EAAEP,UAAU,EAAE,GAAGO;IAEvB,qBACE,6BAACC,cAAM;QAACV,WAAWN;QAAWiB,QAAQ;QAAOC,QAAQ;QAAOJ,MAAMN;qBAChE,6BAACW,gCAAiB,EAAKJ;AAG7B;AAEO,MAAMb,gBAA+B,CAAC,EAC3CkB,iBAAiBC,wBAAwB,EACzCC,aAAa,EACbC,kBAAkB,EAClBC,OAAO,EACR;IACC,MAAM,EAAEC,WAAW,EAAE,GAAGC,IAAAA,iBAAS;IACjC,MAAMC,cAAcC,IAAAA,uBAAY;IAChC,MAAMxB,OAAOyB,IAAAA,YAAK;IAClB,MAAM,EAAEC,UAAU,EAAEC,UAAU,EAAEC,SAAS,EAAEC,WAAW,EAAE,GAAGC,IAAAA,eAAQ;IACnE,MAAM,CAACC,QAAQC,UAAU,GAAGC,IAAAA,eAAQ,EAAC;IACrC,MAAM,CAACjB,iBAAiBkB,mBAAmB,GAAGD,IAAAA,eAAQ,EAAChB;IAEvD,MAAMb,aAAaP,qBAAqB;QACtCE,OAAOwB;QACPvB;IACF;IAEAmC,IAAAA,gBAAS,EAAC;QACRH,UAAUxB,QAAQmB,UAAU,CAACvB,WAAW,EAAE2B;IAC5C,GAAG;QAACJ;QAAYvB;KAAW;IAE3B+B,IAAAA,gBAAS,EAAC;QACR,IAAI,CAACnB,mBAAmBA,gBAAgBoB,MAAM,KAAK,GAAG;YACpD,MAAMC,0BAA0BhB,YAAYd,MAAM,CAAC,CAAC,EAAE+B,MAAM,EAAE;gBAC5D,IAAIlB,SAAS;oBACX,OAAOZ,QAAQ8B,YAAY;gBAC7B;gBACA,OAAO;YACT;YAEAJ,mBAAmBG,wBAAwBE,GAAG,CAAC,CAAC,EAAE7B,IAAI,EAAE,GAAKA;QAC/D;IACF,GAAG;QAACM;QAAiBI;QAASC;KAAY;IAC1C,MAAMmB,eAAeC,IAAAA,kBAAW,EAAC;QAC/BZ,YAAYzB;IACd,GAAG;QAACyB;QAAazB;KAAW;IAE5B,MAAMsC,cAAcD,IAAAA,kBAAW,EAAC;QAC9Bf,WAAWtB;IACb,GAAG;QAACA;QAAYsB;KAAW;IAE3B,MAAMiB,aAAaF,IAAAA,kBAAW,EAAC;QAC7Bb,UAAUxB;IACZ,GAAG;QAACA;QAAYwB;KAAU;IAE1B,MAAMgB,iBAAiBC,IAAAA,cAAO,EAAC;QAC7B,OAAO,CAAClC,sBACN,6BAACjB;gBACE,GAAGiB,KAAK;gBACT+B,aAAaA;gBACb1B,iBAAiBA;gBACjBZ,YAAYA;gBACZc,eAAeA;gBACf4B,KAAK1C;gBACLe,oBAAoBA;gBACpBC,SAASA;;IAGf,GAAG;QAAChB;QAAYY;QAAiBI;QAASsB;QAAavB;QAAoBD;KAAc;IAEzF,MAAM6B,wBAAwBF,IAAAA,cAAO,EAAC;QACpC,OAAO,CAAClC,sBAAU,6BAAChB;gBAAmB,GAAGgB,KAAK;gBAAEP,YAAYA;;IAC9D,GAAG;QAACA;KAAW;IAEf,MAAM4C,sBAAsBH,IAAAA,cAAO,EACjC,IAAO,CAAA;YACLH;YACAnB;YACAnB;YACA6C,cAAclB;YACdY;YACAH;QACF,CAAA,GACA;QAACjB;QAAanB;QAAY2B;QAAQS;QAAcE;QAAaC;KAAW;IAG1E,OAAO;QAACC;QAAgBG;QAAuBC;KAAoB;AACrE"}