UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

328 lines (327 loc) • 39.4 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "ListDrawerContent", { enumerable: true, get: function() { return ListDrawerContent; } }); const _modal = require("@faceless-ui/modal"); const _react = /*#__PURE__*/ _interop_require_wildcard(require("react")); const _reacti18next = require("react-i18next"); const _ = require("."); const _getTranslation = require("../../../../utilities/getTranslation"); const _usePayloadAPI = /*#__PURE__*/ _interop_require_default(require("../../../hooks/usePayloadAPI")); const _useUseAsTitle = require("../../../hooks/useUseAsTitle"); const _Label = /*#__PURE__*/ _interop_require_default(require("../../forms/Label")); const _X = /*#__PURE__*/ _interop_require_default(require("../../icons/X")); const _Auth = require("../../utilities/Auth"); const _Config = require("../../utilities/Config"); const _DocumentInfo = require("../../utilities/DocumentInfo"); const _Preferences = require("../../utilities/Preferences"); const _RenderCustomComponent = /*#__PURE__*/ _interop_require_default(require("../../utilities/RenderCustomComponent")); const _Default = /*#__PURE__*/ _interop_require_default(require("../../views/collections/List/Default")); const _formatFields = /*#__PURE__*/ _interop_require_default(require("../../views/collections/List/formatFields")); const _DocumentDrawer = require("../DocumentDrawer"); const _Pill = /*#__PURE__*/ _interop_require_default(require("../Pill")); const _ReactSelect = /*#__PURE__*/ _interop_require_default(require("../ReactSelect")); const _TableColumns = require("../TableColumns"); const _ViewDescription = /*#__PURE__*/ _interop_require_default(require("../ViewDescription")); 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 hoistQueryParamsToAnd = (where, queryParams)=>{ if ('and' in where) { where.and.push(queryParams); } else if ('or' in where) { where = { and: [ where, queryParams ] }; } else { where = { and: [ where, queryParams ] }; } return where; }; const ListDrawerContent = ({ collectionSlugs, customHeader, drawerSlug, filterOptions, onSelect, selectedCollection })=>{ const { i18n, t } = (0, _reacti18next.useTranslation)([ 'upload', 'general' ]); const { permissions } = (0, _Auth.useAuth)(); const { setPreference } = (0, _Preferences.usePreferences)(); const { closeModal, isModalOpen } = (0, _modal.useModal)(); const [limit, setLimit] = (0, _react.useState)(); const [sort, setSort] = (0, _react.useState)(null); const [page, setPage] = (0, _react.useState)(1); const [where, setWhere] = (0, _react.useState)(null); const [search, setSearch] = (0, _react.useState)(''); const { collections, routes: { api }, serverURL } = (0, _Config.useConfig)(); const enabledCollectionConfigs = collections.filter(({ slug })=>{ return collectionSlugs.includes(slug); }); const [selectedCollectionConfig, setSelectedCollectionConfig] = (0, _react.useState)(()=>{ return enabledCollectionConfigs.find(({ slug })=>slug === selectedCollection) || enabledCollectionConfigs?.[0]; }); const [selectedOption, setSelectedOption] = (0, _react.useState)(()=>selectedCollectionConfig ? { label: (0, _getTranslation.getTranslation)(selectedCollectionConfig.labels.singular, i18n), value: selectedCollectionConfig.slug } : undefined); const [fields, setFields] = (0, _react.useState)(()=>(0, _formatFields.default)(selectedCollectionConfig)); const titleField = (0, _useUseAsTitle.useUseTitleField)(selectedCollectionConfig); (0, _react.useEffect)(()=>{ setFields((0, _formatFields.default)(selectedCollectionConfig)); }, [ selectedCollectionConfig ]); // allow external control of selected collection, same as the initial state logic above (0, _react.useEffect)(()=>{ if (selectedCollection) { // if passed a selection, find it and check if it's enabled const selectedConfig = enabledCollectionConfigs.find(({ slug })=>slug === selectedCollection) || enabledCollectionConfigs?.[0]; setSelectedCollectionConfig(selectedConfig); } }, [ selectedCollection, enabledCollectionConfigs, onSelect, t ]); const preferenceKey = `${selectedCollectionConfig.slug}-list`; // this is the 'create new' drawer const [DocumentDrawer, DocumentDrawerToggler, { drawerSlug: documentDrawerSlug }] = (0, _DocumentDrawer.useDocumentDrawer)({ collectionSlug: selectedCollectionConfig.slug }); (0, _react.useEffect)(()=>{ if (selectedOption) { setSelectedCollectionConfig(enabledCollectionConfigs.find(({ slug })=>selectedOption.value === slug)); } }, [ selectedOption, enabledCollectionConfigs ]); const collectionPermissions = permissions?.collections?.[selectedCollectionConfig?.slug]; const hasCreatePermission = collectionPermissions?.create?.permission; // If modal is open, get active page of upload gallery const isOpen = isModalOpen(drawerSlug); const apiURL = isOpen ? `${serverURL}${api}/${selectedCollectionConfig.slug}` : null; const [cacheBust, dispatchCacheBust] = (0, _react.useReducer)((state)=>state + 1, 0) // used to force a re-fetch even when apiURL is unchanged ; const [{ data, isError }, { setParams }] = (0, _usePayloadAPI.default)(apiURL, {}); const moreThanOneAvailableCollection = enabledCollectionConfigs.length > 1; (0, _react.useEffect)(()=>{ const { slug, admin: { listSearchableFields } = {}, versions } = selectedCollectionConfig; const params = {}; let copyOfWhere = { ...where || {} }; const filterOption = filterOptions?.[slug]; if (filterOptions && typeof filterOption !== 'boolean') { copyOfWhere = hoistQueryParamsToAnd(copyOfWhere, filterOption); } if (search) { const searchAsConditions = (listSearchableFields || [ titleField?.name ]).map((fieldName)=>{ return { [fieldName]: { like: search } }; }, []); if (searchAsConditions.length > 0) { const searchFilter = { or: [ ...searchAsConditions ] }; copyOfWhere = hoistQueryParamsToAnd(copyOfWhere, searchFilter); } } if (page) params.page = page; if (sort) params.sort = sort; if (cacheBust) params.cacheBust = cacheBust; if (copyOfWhere) params.where = copyOfWhere; if (versions?.drafts) params.draft = 'true'; setParams(params); }, [ page, sort, where, search, cacheBust, filterOptions, selectedCollectionConfig, t, setParams, titleField?.name ]); (0, _react.useEffect)(()=>{ const newPreferences = { limit, sort }; setPreference(preferenceKey, newPreferences, true); }, [ sort, limit, setPreference, preferenceKey ]); const onCreateNew = (0, _react.useCallback)(({ doc })=>{ if (typeof onSelect === 'function') { onSelect({ collectionConfig: selectedCollectionConfig, docID: doc.id }); } dispatchCacheBust(); closeModal(documentDrawerSlug); closeModal(drawerSlug); }, [ closeModal, documentDrawerSlug, drawerSlug, onSelect, selectedCollectionConfig ]); if (!selectedCollectionConfig || isError) { return null; } const listComponent = selectedCollectionConfig?.admin?.components?.views?.List; let ListToRender = null; if (listComponent && typeof listComponent === 'function') { ListToRender = listComponent; } else if (typeof listComponent === 'object' && typeof listComponent.Component === 'function') { ListToRender = listComponent.Component; } return /*#__PURE__*/ _react.default.createElement(_TableColumns.TableColumnsProvider, { cellProps: [ { className: `${_.baseClass}__first-cell`, link: false, onClick: ({ collection: rowColl, rowData })=>{ if (typeof onSelect === 'function') { onSelect({ collectionConfig: rowColl, docID: rowData.id }); } } } ], collection: selectedCollectionConfig }, /*#__PURE__*/ _react.default.createElement(_DocumentInfo.DocumentInfoProvider, { collection: selectedCollectionConfig }, /*#__PURE__*/ _react.default.createElement(_RenderCustomComponent.default, { CustomComponent: ListToRender, DefaultComponent: _Default.default, componentProps: { collection: { ...selectedCollectionConfig, fields }, customHeader: /*#__PURE__*/ _react.default.createElement("header", { className: `${_.baseClass}__header` }, /*#__PURE__*/ _react.default.createElement("div", { className: `${_.baseClass}__header-wrap` }, /*#__PURE__*/ _react.default.createElement("div", { className: `${_.baseClass}__header-content` }, /*#__PURE__*/ _react.default.createElement("h2", { className: `${_.baseClass}__header-text` }, !customHeader ? (0, _getTranslation.getTranslation)(selectedCollectionConfig?.labels?.plural, i18n) : customHeader), hasCreatePermission && /*#__PURE__*/ _react.default.createElement(DocumentDrawerToggler, { className: `${_.baseClass}__create-new-button` }, /*#__PURE__*/ _react.default.createElement(_Pill.default, null, t('general:createNew')))), /*#__PURE__*/ _react.default.createElement("button", { className: `${_.baseClass}__header-close`, onClick: ()=>{ closeModal(drawerSlug); }, type: "button" }, /*#__PURE__*/ _react.default.createElement(_X.default, null))), selectedCollectionConfig?.admin?.description && /*#__PURE__*/ _react.default.createElement("div", { className: `${_.baseClass}__sub-header` }, /*#__PURE__*/ _react.default.createElement(_ViewDescription.default, { description: selectedCollectionConfig.admin.description })), moreThanOneAvailableCollection && /*#__PURE__*/ _react.default.createElement("div", { className: `${_.baseClass}__select-collection-wrap` }, /*#__PURE__*/ _react.default.createElement(_Label.default, { label: t('selectCollectionToBrowse') }), /*#__PURE__*/ _react.default.createElement(_ReactSelect.default, { className: `${_.baseClass}__select-collection`, onChange: setSelectedOption, options: enabledCollectionConfigs.map((coll)=>({ label: (0, _getTranslation.getTranslation)(coll.labels.singular, i18n), value: coll.slug })), value: selectedOption }))), data, handlePageChange: setPage, handlePerPageChange: setLimit, handleSearchChange: setSearch, handleSortChange: setSort, handleWhereChange: setWhere, hasCreatePermission, limit: limit || selectedCollectionConfig?.admin?.pagination?.defaultLimit, modifySearchParams: false, newDocumentURL: null, setLimit, setSort, titleField } })), /*#__PURE__*/ _react.default.createElement(DocumentDrawer, { onSave: onCreateNew })); }; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/ListDrawer/DrawerContent.tsx"],"sourcesContent":["import { useModal } from '@faceless-ui/modal'\nimport React, { useCallback, useEffect, useReducer, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport type { SanitizedCollectionConfig } from '../../../../collections/config/types'\nimport type { Where } from '../../../../exports/types'\nimport type { Field } from '../../../../fields/config/types'\nimport type { ListDrawerProps } from './types'\n\nimport { baseClass } from '.'\nimport { getTranslation } from '../../../../utilities/getTranslation'\nimport usePayloadAPI from '../../../hooks/usePayloadAPI'\nimport { useUseTitleField } from '../../../hooks/useUseAsTitle'\nimport Label from '../../forms/Label'\nimport X from '../../icons/X'\nimport { useAuth } from '../../utilities/Auth'\nimport { useConfig } from '../../utilities/Config'\nimport { DocumentInfoProvider } from '../../utilities/DocumentInfo'\nimport { usePreferences } from '../../utilities/Preferences'\nimport RenderCustomComponent from '../../utilities/RenderCustomComponent'\nimport DefaultList from '../../views/collections/List/Default'\nimport formatFields from '../../views/collections/List/formatFields'\nimport { useDocumentDrawer } from '../DocumentDrawer'\nimport Pill from '../Pill'\nimport ReactSelect from '../ReactSelect'\nimport { TableColumnsProvider } from '../TableColumns'\nimport ViewDescription from '../ViewDescription'\n\nconst hoistQueryParamsToAnd = (where: Where, queryParams: Where) => {\n  if ('and' in where) {\n    where.and.push(queryParams)\n  } else if ('or' in where) {\n    where = {\n      and: [where, queryParams],\n    }\n  } else {\n    where = {\n      and: [where, queryParams],\n    }\n  }\n\n  return where\n}\n\nexport const ListDrawerContent: React.FC<ListDrawerProps> = ({\n  collectionSlugs,\n  customHeader,\n  drawerSlug,\n  filterOptions,\n  onSelect,\n  selectedCollection,\n}) => {\n  const { i18n, t } = useTranslation(['upload', 'general'])\n  const { permissions } = useAuth()\n  const { setPreference } = usePreferences()\n  const { closeModal, isModalOpen } = useModal()\n  const [limit, setLimit] = useState<number>()\n  const [sort, setSort] = useState(null)\n  const [page, setPage] = useState(1)\n  const [where, setWhere] = useState(null)\n  const [search, setSearch] = useState('')\n\n  const {\n    collections,\n    routes: { api },\n    serverURL,\n  } = useConfig()\n\n  const enabledCollectionConfigs = collections.filter(({ slug }) => {\n    return collectionSlugs.includes(slug)\n  })\n\n  const [selectedCollectionConfig, setSelectedCollectionConfig] =\n    useState<SanitizedCollectionConfig>(() => {\n      return (\n        enabledCollectionConfigs.find(({ slug }) => slug === selectedCollection) ||\n        enabledCollectionConfigs?.[0]\n      )\n    })\n\n  const [selectedOption, setSelectedOption] = useState<{ label: string; value: string }>(() =>\n    selectedCollectionConfig\n      ? {\n          label: getTranslation(selectedCollectionConfig.labels.singular, i18n),\n          value: selectedCollectionConfig.slug,\n        }\n      : undefined,\n  )\n\n  const [fields, setFields] = useState<Field[]>(() => formatFields(selectedCollectionConfig))\n\n  const titleField = useUseTitleField(selectedCollectionConfig)\n\n  useEffect(() => {\n    setFields(formatFields(selectedCollectionConfig))\n  }, [selectedCollectionConfig])\n\n  // allow external control of selected collection, same as the initial state logic above\n  useEffect(() => {\n    if (selectedCollection) {\n      // if passed a selection, find it and check if it's enabled\n      const selectedConfig =\n        enabledCollectionConfigs.find(({ slug }) => slug === selectedCollection) ||\n        enabledCollectionConfigs?.[0]\n      setSelectedCollectionConfig(selectedConfig)\n    }\n  }, [selectedCollection, enabledCollectionConfigs, onSelect, t])\n\n  const preferenceKey = `${selectedCollectionConfig.slug}-list`\n\n  // this is the 'create new' drawer\n  const [DocumentDrawer, DocumentDrawerToggler, { drawerSlug: documentDrawerSlug }] =\n    useDocumentDrawer({\n      collectionSlug: selectedCollectionConfig.slug,\n    })\n\n  useEffect(() => {\n    if (selectedOption) {\n      setSelectedCollectionConfig(\n        enabledCollectionConfigs.find(({ slug }) => selectedOption.value === slug),\n      )\n    }\n  }, [selectedOption, enabledCollectionConfigs])\n\n  const collectionPermissions = permissions?.collections?.[selectedCollectionConfig?.slug]\n  const hasCreatePermission = collectionPermissions?.create?.permission\n\n  // If modal is open, get active page of upload gallery\n  const isOpen = isModalOpen(drawerSlug)\n  const apiURL = isOpen ? `${serverURL}${api}/${selectedCollectionConfig.slug}` : null\n  const [cacheBust, dispatchCacheBust] = useReducer((state) => state + 1, 0) // used to force a re-fetch even when apiURL is unchanged\n  const [{ data, isError }, { setParams }] = usePayloadAPI(apiURL, {})\n  const moreThanOneAvailableCollection = enabledCollectionConfigs.length > 1\n\n  useEffect(() => {\n    const { slug, admin: { listSearchableFields } = {}, versions } = selectedCollectionConfig\n    const params: {\n      cacheBust?: number\n      draft?: string\n      limit?: number\n      page?: number\n      search?: string\n      sort?: string\n      where?: unknown\n    } = {}\n\n    let copyOfWhere = { ...(where || {}) }\n    const filterOption = filterOptions?.[slug]\n\n    if (filterOptions && typeof filterOption !== 'boolean') {\n      copyOfWhere = hoistQueryParamsToAnd(copyOfWhere, filterOption)\n    }\n\n    if (search) {\n      const searchAsConditions = (listSearchableFields || [titleField?.name]).map((fieldName) => {\n        return {\n          [fieldName]: {\n            like: search,\n          },\n        }\n      }, [])\n\n      if (searchAsConditions.length > 0) {\n        const searchFilter: Where = {\n          or: [...searchAsConditions],\n        }\n\n        copyOfWhere = hoistQueryParamsToAnd(copyOfWhere, searchFilter)\n      }\n    }\n\n    if (page) params.page = page\n    if (sort) params.sort = sort\n    if (cacheBust) params.cacheBust = cacheBust\n    if (copyOfWhere) params.where = copyOfWhere\n    if (versions?.drafts) params.draft = 'true'\n\n    setParams(params)\n  }, [\n    page,\n    sort,\n    where,\n    search,\n    cacheBust,\n    filterOptions,\n    selectedCollectionConfig,\n    t,\n    setParams,\n    titleField?.name,\n  ])\n\n  useEffect(() => {\n    const newPreferences = {\n      limit,\n      sort,\n    }\n\n    setPreference(preferenceKey, newPreferences, true)\n  }, [sort, limit, setPreference, preferenceKey])\n\n  const onCreateNew = useCallback(\n    ({ doc }) => {\n      if (typeof onSelect === 'function') {\n        onSelect({\n          collectionConfig: selectedCollectionConfig,\n          docID: doc.id,\n        })\n      }\n      dispatchCacheBust()\n      closeModal(documentDrawerSlug)\n      closeModal(drawerSlug)\n    },\n    [closeModal, documentDrawerSlug, drawerSlug, onSelect, selectedCollectionConfig],\n  )\n\n  if (!selectedCollectionConfig || isError) {\n    return null\n  }\n\n  const listComponent = selectedCollectionConfig?.admin?.components?.views?.List\n  let ListToRender = null\n\n  if (listComponent && typeof listComponent === 'function') {\n    ListToRender = listComponent\n  } else if (typeof listComponent === 'object' && typeof listComponent.Component === 'function') {\n    ListToRender = listComponent.Component\n  }\n\n  return (\n    <TableColumnsProvider\n      cellProps={[\n        {\n          className: `${baseClass}__first-cell`,\n          link: false,\n          onClick: ({ collection: rowColl, rowData }) => {\n            if (typeof onSelect === 'function') {\n              onSelect({\n                collectionConfig: rowColl,\n                docID: rowData.id,\n              })\n            }\n          },\n        },\n      ]}\n      collection={selectedCollectionConfig}\n    >\n      <DocumentInfoProvider collection={selectedCollectionConfig}>\n        <RenderCustomComponent\n          CustomComponent={ListToRender}\n          DefaultComponent={DefaultList}\n          componentProps={{\n            collection: {\n              ...selectedCollectionConfig,\n              fields,\n            },\n            customHeader: (\n              <header className={`${baseClass}__header`}>\n                <div className={`${baseClass}__header-wrap`}>\n                  <div className={`${baseClass}__header-content`}>\n                    <h2 className={`${baseClass}__header-text`}>\n                      {!customHeader\n                        ? getTranslation(selectedCollectionConfig?.labels?.plural, i18n)\n                        : customHeader}\n                    </h2>\n                    {hasCreatePermission && (\n                      <DocumentDrawerToggler className={`${baseClass}__create-new-button`}>\n                        <Pill>{t('general:createNew')}</Pill>\n                      </DocumentDrawerToggler>\n                    )}\n                  </div>\n                  <button\n                    className={`${baseClass}__header-close`}\n                    onClick={() => {\n                      closeModal(drawerSlug)\n                    }}\n                    type=\"button\"\n                  >\n                    <X />\n                  </button>\n                </div>\n                {selectedCollectionConfig?.admin?.description && (\n                  <div className={`${baseClass}__sub-header`}>\n                    <ViewDescription description={selectedCollectionConfig.admin.description} />\n                  </div>\n                )}\n                {moreThanOneAvailableCollection && (\n                  <div className={`${baseClass}__select-collection-wrap`}>\n                    <Label label={t('selectCollectionToBrowse')} />\n                    <ReactSelect\n                      className={`${baseClass}__select-collection`}\n                      onChange={setSelectedOption} // this is only changing the options which is not rerunning my effect\n                      options={enabledCollectionConfigs.map((coll) => ({\n                        label: getTranslation(coll.labels.singular, i18n),\n                        value: coll.slug,\n                      }))}\n                      value={selectedOption}\n                    />\n                  </div>\n                )}\n              </header>\n            ),\n            data,\n            handlePageChange: setPage,\n            handlePerPageChange: setLimit,\n            handleSearchChange: setSearch,\n            handleSortChange: setSort,\n            handleWhereChange: setWhere,\n            hasCreatePermission,\n            limit: limit || selectedCollectionConfig?.admin?.pagination?.defaultLimit,\n            modifySearchParams: false,\n            newDocumentURL: null,\n            setLimit,\n            setSort,\n            titleField,\n          }}\n        />\n      </DocumentInfoProvider>\n      <DocumentDrawer onSave={onCreateNew} />\n    </TableColumnsProvider>\n  )\n}\n"],"names":["ListDrawerContent","hoistQueryParamsToAnd","where","queryParams","and","push","collectionSlugs","customHeader","drawerSlug","filterOptions","onSelect","selectedCollection","i18n","t","useTranslation","permissions","useAuth","setPreference","usePreferences","closeModal","isModalOpen","useModal","limit","setLimit","useState","sort","setSort","page","setPage","setWhere","search","setSearch","collections","routes","api","serverURL","useConfig","enabledCollectionConfigs","filter","slug","includes","selectedCollectionConfig","setSelectedCollectionConfig","find","selectedOption","setSelectedOption","label","getTranslation","labels","singular","value","undefined","fields","setFields","formatFields","titleField","useUseTitleField","useEffect","selectedConfig","preferenceKey","DocumentDrawer","DocumentDrawerToggler","documentDrawerSlug","useDocumentDrawer","collectionSlug","collectionPermissions","hasCreatePermission","create","permission","isOpen","apiURL","cacheBust","dispatchCacheBust","useReducer","state","data","isError","setParams","usePayloadAPI","moreThanOneAvailableCollection","length","admin","listSearchableFields","versions","params","copyOfWhere","filterOption","searchAsConditions","name","map","fieldName","like","searchFilter","or","drafts","draft","newPreferences","onCreateNew","useCallback","doc","collectionConfig","docID","id","listComponent","components","views","List","ListToRender","Component","TableColumnsProvider","cellProps","className","baseClass","link","onClick","collection","rowColl","rowData","DocumentInfoProvider","RenderCustomComponent","CustomComponent","DefaultComponent","DefaultList","componentProps","header","div","h2","plural","Pill","button","type","X","description","ViewDescription","Label","ReactSelect","onChange","options","coll","handlePageChange","handlePerPageChange","handleSearchChange","handleSortChange","handleWhereChange","pagination","defaultLimit","modifySearchParams","newDocumentURL","onSave"],"mappings":"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"}