UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

196 lines (195 loc) • 27.6 kB
"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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"}