payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
328 lines (327 loc) • 39.4 kB
JavaScript
;
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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"}