payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
196 lines (195 loc) • 27.6 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return _default;
}
});
const _windowinfo = require("@faceless-ui/window-info");
const _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
const _reacti18next = require("react-i18next");
const _formatFilesize = /*#__PURE__*/ _interop_require_default(require("../../../../../uploads/formatFilesize"));
const _getTranslation = require("../../../../../utilities/getTranslation");
const _Button = /*#__PURE__*/ _interop_require_default(require("../../../elements/Button"));
const _DeleteMany = /*#__PURE__*/ _interop_require_default(require("../../../elements/DeleteMany"));
const _EditMany = /*#__PURE__*/ _interop_require_default(require("../../../elements/EditMany"));
const _Gutter = require("../../../elements/Gutter");
const _ListControls = require("../../../elements/ListControls");
const _ListSelection = /*#__PURE__*/ _interop_require_default(require("../../../elements/ListSelection"));
const _Paginator = /*#__PURE__*/ _interop_require_default(require("../../../elements/Paginator"));
const _PerPage = /*#__PURE__*/ _interop_require_default(require("../../../elements/PerPage"));
const _Pill = /*#__PURE__*/ _interop_require_default(require("../../../elements/Pill"));
const _PublishMany = /*#__PURE__*/ _interop_require_default(require("../../../elements/PublishMany"));
const _ShimmerEffect = require("../../../elements/ShimmerEffect");
const _Table = require("../../../elements/Table");
const _UnpublishMany = /*#__PURE__*/ _interop_require_default(require("../../../elements/UnpublishMany"));
const _ViewDescription = /*#__PURE__*/ _interop_require_default(require("../../../elements/ViewDescription"));
const _Meta = /*#__PURE__*/ _interop_require_default(require("../../../utilities/Meta"));
const _RelationshipProvider = require("./RelationshipProvider");
const _SelectionProvider = require("./SelectionProvider");
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 = 'collection-list';
const DefaultList = (props)=>{
const { collection: { admin: { components: { AfterList, AfterListTable, BeforeList, BeforeListTable } = {}, description } = {}, labels: { plural: pluralLabel, singular: singularLabel } }, collection, customHeader, data, handlePageChange, handlePerPageChange, handleSearchChange, handleSortChange, handleWhereChange, hasCreatePermission, limit, modifySearchParams, newDocumentURL, resetParams, titleField } = props;
const { breakpoints: { s: smallBreak } } = (0, _windowinfo.useWindowInfo)();
const { i18n, t } = (0, _reacti18next.useTranslation)('general');
let formattedDocs = data.docs || [];
if (collection.upload) {
formattedDocs = formattedDocs?.map((doc)=>{
return {
...doc,
filesize: (0, _formatFilesize.default)(doc.filesize)
};
});
}
return /*#__PURE__*/ _react.default.createElement("div", {
className: baseClass
}, Array.isArray(BeforeList) && BeforeList.map((Component, i)=>/*#__PURE__*/ _react.default.createElement(Component, {
key: i,
...props
})), /*#__PURE__*/ _react.default.createElement(_Meta.default, {
title: (0, _getTranslation.getTranslation)(collection.labels.plural, i18n)
}), /*#__PURE__*/ _react.default.createElement(_SelectionProvider.SelectionProvider, {
docs: data.docs,
totalDocs: data.totalDocs
}, /*#__PURE__*/ _react.default.createElement(_Gutter.Gutter, {
className: `${baseClass}__wrap`
}, /*#__PURE__*/ _react.default.createElement("header", {
className: `${baseClass}__header`
}, customHeader && customHeader, !customHeader && /*#__PURE__*/ _react.default.createElement(_react.Fragment, null, /*#__PURE__*/ _react.default.createElement("h1", null, (0, _getTranslation.getTranslation)(pluralLabel, i18n)), hasCreatePermission && /*#__PURE__*/ _react.default.createElement(_Pill.default, {
"aria-label": t('createNewLabel', {
label: (0, _getTranslation.getTranslation)(singularLabel, i18n)
}),
to: newDocumentURL
}, t('createNew')), !smallBreak && /*#__PURE__*/ _react.default.createElement(_ListSelection.default, {
label: (0, _getTranslation.getTranslation)(collection.labels.plural, i18n)
}), description && /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__sub-header`
}, /*#__PURE__*/ _react.default.createElement(_ViewDescription.default, {
description: description
})))), /*#__PURE__*/ _react.default.createElement(_ListControls.ListControls, {
collection: collection,
handleSearchChange: handleSearchChange,
handleSortChange: handleSortChange,
handleWhereChange: handleWhereChange,
modifySearchQuery: modifySearchParams,
resetParams: resetParams,
titleField: titleField
}), Array.isArray(BeforeListTable) && BeforeListTable.map((Component, i)=>/*#__PURE__*/ _react.default.createElement(Component, {
key: i,
...props
})), !data.docs && /*#__PURE__*/ _react.default.createElement(_ShimmerEffect.StaggeredShimmers, {
className: [
`${baseClass}__shimmer`,
`${baseClass}__shimmer--rows`
].join(' '),
count: 6
}), data.docs && data.docs.length > 0 && /*#__PURE__*/ _react.default.createElement(_RelationshipProvider.RelationshipProvider, null, /*#__PURE__*/ _react.default.createElement(_Table.Table, {
data: formattedDocs
})), data.docs && data.docs.length === 0 && /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__no-results`
}, /*#__PURE__*/ _react.default.createElement("p", null, t('noResults', {
label: (0, _getTranslation.getTranslation)(pluralLabel, i18n)
})), hasCreatePermission && newDocumentURL && /*#__PURE__*/ _react.default.createElement(_Button.default, {
el: "link",
to: newDocumentURL
}, t('createNewLabel', {
label: (0, _getTranslation.getTranslation)(singularLabel, i18n)
}))), Array.isArray(AfterListTable) && AfterListTable.map((Component, i)=>/*#__PURE__*/ _react.default.createElement(Component, {
key: i,
...props
})), data.docs && data.docs.length > 0 && /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__page-controls`
}, /*#__PURE__*/ _react.default.createElement(_Paginator.default, {
disableHistoryChange: modifySearchParams === false,
hasNextPage: data.hasNextPage,
hasPrevPage: data.hasPrevPage,
limit: data.limit,
nextPage: data.nextPage,
numberOfNeighbors: 1,
onChange: handlePageChange,
page: data.page,
prevPage: data.prevPage,
totalPages: data.totalPages
}), data?.totalDocs > 0 && /*#__PURE__*/ _react.default.createElement(_react.Fragment, null, /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__page-info`
}, data.page * data.limit - (data.limit - 1), "-", data.totalPages > 1 && data.totalPages !== data.page ? data.limit * data.page : data.totalDocs, ' ', t('of'), " ", data.totalDocs), /*#__PURE__*/ _react.default.createElement(_PerPage.default, {
handleChange: handlePerPageChange,
limit: limit,
limits: collection?.admin?.pagination?.limits,
modifySearchParams: modifySearchParams,
resetPage: data.totalDocs <= data.pagingCounter
}), smallBreak && /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__list-selection`
}, /*#__PURE__*/ _react.default.createElement(_react.Fragment, null, /*#__PURE__*/ _react.default.createElement(_ListSelection.default, {
label: (0, _getTranslation.getTranslation)(collection.labels.plural, i18n)
}), /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__list-selection-actions`
}, /*#__PURE__*/ _react.default.createElement(_EditMany.default, {
collection: collection,
resetParams: resetParams
}), /*#__PURE__*/ _react.default.createElement(_PublishMany.default, {
collection: collection,
resetParams: resetParams
}), /*#__PURE__*/ _react.default.createElement(_UnpublishMany.default, {
collection: collection,
resetParams: resetParams
}), /*#__PURE__*/ _react.default.createElement(_DeleteMany.default, {
collection: collection,
resetParams: resetParams
})))))))), Array.isArray(AfterList) && AfterList.map((Component, i)=>/*#__PURE__*/ _react.default.createElement(Component, {
key: i,
...props
})));
};
const _default = DefaultList;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/admin/components/views/collections/List/Default.tsx"],"sourcesContent":["import { useWindowInfo } from '@faceless-ui/window-info'\nimport React, { Fragment } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport type { Props } from './types'\n\nimport formatFilesize from '../../../../../uploads/formatFilesize'\nimport { getTranslation } from '../../../../../utilities/getTranslation'\nimport Button from '../../../elements/Button'\nimport DeleteMany from '../../../elements/DeleteMany'\nimport EditMany from '../../../elements/EditMany'\nimport { Gutter } from '../../../elements/Gutter'\nimport { ListControls } from '../../../elements/ListControls'\nimport ListSelection from '../../../elements/ListSelection'\nimport Paginator from '../../../elements/Paginator'\nimport PerPage from '../../../elements/PerPage'\nimport Pill from '../../../elements/Pill'\nimport PublishMany from '../../../elements/PublishMany'\nimport { StaggeredShimmers } from '../../../elements/ShimmerEffect'\nimport { Table } from '../../../elements/Table'\nimport UnpublishMany from '../../../elements/UnpublishMany'\nimport ViewDescription from '../../../elements/ViewDescription'\nimport Meta from '../../../utilities/Meta'\nimport { RelationshipProvider } from './RelationshipProvider'\nimport { SelectionProvider } from './SelectionProvider'\nimport './index.scss'\n\nconst baseClass = 'collection-list'\n\nconst DefaultList: React.FC<Props> = (props) => {\n  const {\n    collection: {\n      admin: {\n        components: { AfterList, AfterListTable, BeforeList, BeforeListTable } = {},\n        description,\n      } = {},\n      labels: { plural: pluralLabel, singular: singularLabel },\n    },\n    collection,\n    customHeader,\n    data,\n    handlePageChange,\n    handlePerPageChange,\n    handleSearchChange,\n    handleSortChange,\n    handleWhereChange,\n    hasCreatePermission,\n    limit,\n    modifySearchParams,\n    newDocumentURL,\n    resetParams,\n    titleField,\n  } = props\n\n  const {\n    breakpoints: { s: smallBreak },\n  } = useWindowInfo()\n  const { i18n, t } = useTranslation('general')\n  let formattedDocs = data.docs || []\n\n  if (collection.upload) {\n    formattedDocs = formattedDocs?.map((doc) => {\n      return {\n        ...doc,\n        filesize: formatFilesize(doc.filesize),\n      }\n    })\n  }\n\n  return (\n    <div className={baseClass}>\n      {Array.isArray(BeforeList) &&\n        BeforeList.map((Component, i) => <Component key={i} {...props} />)}\n\n      <Meta title={getTranslation(collection.labels.plural, i18n)} />\n      <SelectionProvider docs={data.docs} totalDocs={data.totalDocs}>\n        <Gutter className={`${baseClass}__wrap`}>\n          <header className={`${baseClass}__header`}>\n            {customHeader && customHeader}\n            {!customHeader && (\n              <Fragment>\n                <h1>{getTranslation(pluralLabel, i18n)}</h1>\n                {hasCreatePermission && (\n                  <Pill\n                    aria-label={t('createNewLabel', { label: getTranslation(singularLabel, i18n) })}\n                    to={newDocumentURL}\n                  >\n                    {t('createNew')}\n                  </Pill>\n                )}\n                {!smallBreak && (\n                  <ListSelection label={getTranslation(collection.labels.plural, i18n)} />\n                )}\n                {description && (\n                  <div className={`${baseClass}__sub-header`}>\n                    <ViewDescription description={description} />\n                  </div>\n                )}\n              </Fragment>\n            )}\n          </header>\n          <ListControls\n            collection={collection}\n            handleSearchChange={handleSearchChange}\n            handleSortChange={handleSortChange}\n            handleWhereChange={handleWhereChange}\n            modifySearchQuery={modifySearchParams}\n            resetParams={resetParams}\n            titleField={titleField}\n          />\n          {Array.isArray(BeforeListTable) &&\n            BeforeListTable.map((Component, i) => <Component key={i} {...props} />)}\n          {!data.docs && (\n            <StaggeredShimmers\n              className={[`${baseClass}__shimmer`, `${baseClass}__shimmer--rows`].join(' ')}\n              count={6}\n            />\n          )}\n          {data.docs && data.docs.length > 0 && (\n            <RelationshipProvider>\n              <Table data={formattedDocs} />\n            </RelationshipProvider>\n          )}\n          {data.docs && data.docs.length === 0 && (\n            <div className={`${baseClass}__no-results`}>\n              <p>{t('noResults', { label: getTranslation(pluralLabel, i18n) })}</p>\n              {hasCreatePermission && newDocumentURL && (\n                <Button el=\"link\" to={newDocumentURL}>\n                  {t('createNewLabel', { label: getTranslation(singularLabel, i18n) })}\n                </Button>\n              )}\n            </div>\n          )}\n          {Array.isArray(AfterListTable) &&\n            AfterListTable.map((Component, i) => <Component key={i} {...props} />)}\n          {data.docs && data.docs.length > 0 && (\n            <div className={`${baseClass}__page-controls`}>\n              <Paginator\n                disableHistoryChange={modifySearchParams === false}\n                hasNextPage={data.hasNextPage}\n                hasPrevPage={data.hasPrevPage}\n                limit={data.limit}\n                nextPage={data.nextPage}\n                numberOfNeighbors={1}\n                onChange={handlePageChange}\n                page={data.page}\n                prevPage={data.prevPage}\n                totalPages={data.totalPages}\n              />\n              {data?.totalDocs > 0 && (\n                <Fragment>\n                  <div className={`${baseClass}__page-info`}>\n                    {data.page * data.limit - (data.limit - 1)}-\n                    {data.totalPages > 1 && data.totalPages !== data.page\n                      ? data.limit * data.page\n                      : data.totalDocs}{' '}\n                    {t('of')} {data.totalDocs}\n                  </div>\n                  <PerPage\n                    handleChange={handlePerPageChange}\n                    limit={limit}\n                    limits={collection?.admin?.pagination?.limits}\n                    modifySearchParams={modifySearchParams}\n                    resetPage={data.totalDocs <= data.pagingCounter}\n                  />\n                  {smallBreak && (\n                    <div className={`${baseClass}__list-selection`}>\n                      <Fragment>\n                        <ListSelection label={getTranslation(collection.labels.plural, i18n)} />\n                        <div className={`${baseClass}__list-selection-actions`}>\n                          <EditMany collection={collection} resetParams={resetParams} />\n                          <PublishMany collection={collection} resetParams={resetParams} />\n                          <UnpublishMany collection={collection} resetParams={resetParams} />\n                          <DeleteMany collection={collection} resetParams={resetParams} />\n                        </div>\n                      </Fragment>\n                    </div>\n                  )}\n                </Fragment>\n              )}\n            </div>\n          )}\n        </Gutter>\n      </SelectionProvider>\n      {Array.isArray(AfterList) &&\n        AfterList.map((Component, i) => <Component key={i} {...props} />)}\n    </div>\n  )\n}\n\nexport default DefaultList\n"],"names":["baseClass","DefaultList","props","collection","admin","components","AfterList","AfterListTable","BeforeList","BeforeListTable","description","labels","plural","pluralLabel","singular","singularLabel","customHeader","data","handlePageChange","handlePerPageChange","handleSearchChange","handleSortChange","handleWhereChange","hasCreatePermission","limit","modifySearchParams","newDocumentURL","resetParams","titleField","breakpoints","s","smallBreak","useWindowInfo","i18n","t","useTranslation","formattedDocs","docs","upload","map","doc","filesize","formatFilesize","div","className","Array","isArray","Component","i","key","Meta","title","getTranslation","SelectionProvider","totalDocs","Gutter","header","Fragment","h1","Pill","aria-label","label","to","ListSelection","ViewDescription","ListControls","modifySearchQuery","StaggeredShimmers","join","count","length","RelationshipProvider","Table","p","Button","el","Paginator","disableHistoryChange","hasNextPage","hasPrevPage","nextPage","numberOfNeighbors","onChange","page","prevPage","totalPages","PerPage","handleChange","limits","pagination","resetPage","pagingCounter","EditMany","PublishMany","UnpublishMany","DeleteMany"],"mappings":"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"}