UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

169 lines (168 loc) • 18.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return _default; } }); const _react = /*#__PURE__*/ _interop_require_wildcard(require("react")); const _reacti18next = require("react-i18next"); const _reactrouterdom = require("react-router-dom"); const _getTranslation = require("../../../../utilities/getTranslation"); const _groupNavItems = require("../../../utilities/groupNavItems"); const _Button = /*#__PURE__*/ _interop_require_default(require("../../elements/Button")); const _Card = /*#__PURE__*/ _interop_require_default(require("../../elements/Card")); const _Gutter = require("../../elements/Gutter"); const _Config = require("../../utilities/Config"); 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 = 'dashboard'; const Dashboard = (props)=>{ const { collections, globals, permissions, user } = props; const { push } = (0, _reactrouterdom.useHistory)(); const { i18n, t } = (0, _reacti18next.useTranslation)('general'); const { admin: { components: { afterDashboard, beforeDashboard } }, routes: { admin } } = (0, _Config.useConfig)(); const [groups, setGroups] = (0, _react.useState)([]); (0, _react.useEffect)(()=>{ setGroups((0, _groupNavItems.groupNavItems)([ ...collections.filter(({ admin: { hidden } })=>!(typeof hidden === 'function' ? hidden({ user }) : hidden)).map((collection)=>{ const entityToGroup = { entity: collection, type: _groupNavItems.EntityType.collection }; return entityToGroup; }), ...globals.filter(({ admin: { hidden } })=>!(typeof hidden === 'function' ? hidden({ user }) : hidden)).map((global)=>{ const entityToGroup = { entity: global, type: _groupNavItems.EntityType.global }; return entityToGroup; }) ], permissions, i18n)); }, [ collections, globals, i18n, permissions, user ]); return /*#__PURE__*/ _react.default.createElement("div", { className: baseClass }, /*#__PURE__*/ _react.default.createElement(_Gutter.Gutter, { className: `${baseClass}__wrap` }, Array.isArray(beforeDashboard) && beforeDashboard.map((Component, i)=>/*#__PURE__*/ _react.default.createElement(Component, { key: i })), groups.map(({ entities, label }, groupIndex)=>{ return /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__group`, key: groupIndex }, /*#__PURE__*/ _react.default.createElement("h2", { className: `${baseClass}__label` }, label), /*#__PURE__*/ _react.default.createElement("ul", { className: `${baseClass}__card-list` }, entities.map(({ entity, type }, entityIndex)=>{ let title; let buttonAriaLabel; let createHREF; let onClick; let hasCreatePermission; if (type === _groupNavItems.EntityType.collection) { title = (0, _getTranslation.getTranslation)(entity.labels.plural, i18n); buttonAriaLabel = t('showAllLabel', { label: title }); onClick = ()=>push({ pathname: `${admin}/collections/${entity.slug}` }); createHREF = `${admin}/collections/${entity.slug}/create`; hasCreatePermission = permissions?.collections?.[entity.slug]?.create?.permission; } if (type === _groupNavItems.EntityType.global) { title = (0, _getTranslation.getTranslation)(entity.label, i18n); buttonAriaLabel = t('editLabel', { label: (0, _getTranslation.getTranslation)(entity.label, i18n) }); onClick = ()=>push({ pathname: `${admin}/globals/${entity.slug}` }); } return /*#__PURE__*/ _react.default.createElement("li", { key: entityIndex }, /*#__PURE__*/ _react.default.createElement(_Card.default, { actions: hasCreatePermission && type === _groupNavItems.EntityType.collection ? /*#__PURE__*/ _react.default.createElement(_Button.default, { "aria-label": t('createNewLabel', { label: (0, _getTranslation.getTranslation)(entity.labels.singular, i18n) }), buttonStyle: "icon-label", el: "link", icon: "plus", iconStyle: "with-border", round: true, to: createHREF }) : undefined, buttonAriaLabel: buttonAriaLabel, id: `card-${entity.slug}`, onClick: onClick, title: title, titleAs: "h3" })); }))); }), Array.isArray(afterDashboard) && afterDashboard.map((Component, i)=>/*#__PURE__*/ _react.default.createElement(Component, { key: i })))); }; const _default = Dashboard; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/views/Dashboard/Default.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useHistory } from 'react-router-dom'\n\nimport type { EntityToGroup, Group } from '../../../utilities/groupNavItems'\nimport type { Props } from './types'\n\nimport { getTranslation } from '../../../../utilities/getTranslation'\nimport { EntityType, groupNavItems } from '../../../utilities/groupNavItems'\nimport Button from '../../elements/Button'\nimport Card from '../../elements/Card'\nimport { Gutter } from '../../elements/Gutter'\nimport { useConfig } from '../../utilities/Config'\nimport './index.scss'\n\nconst baseClass = 'dashboard'\n\nconst Dashboard: React.FC<Props> = (props) => {\n  const { collections, globals, permissions, user } = props\n\n  const { push } = useHistory()\n  const { i18n, t } = useTranslation('general')\n\n  const {\n    admin: {\n      components: { afterDashboard, beforeDashboard },\n    },\n    routes: { admin },\n  } = useConfig()\n\n  const [groups, setGroups] = useState<Group[]>([])\n\n  useEffect(() => {\n    setGroups(\n      groupNavItems(\n        [\n          ...collections\n            .filter(\n              ({ admin: { hidden } }) =>\n                !(typeof hidden === 'function' ? hidden({ user }) : hidden),\n            )\n            .map((collection) => {\n              const entityToGroup: EntityToGroup = {\n                entity: collection,\n                type: EntityType.collection,\n              }\n\n              return entityToGroup\n            }),\n          ...globals\n            .filter(\n              ({ admin: { hidden } }) =>\n                !(typeof hidden === 'function' ? hidden({ user }) : hidden),\n            )\n            .map((global) => {\n              const entityToGroup: EntityToGroup = {\n                entity: global,\n                type: EntityType.global,\n              }\n\n              return entityToGroup\n            }),\n        ],\n        permissions,\n        i18n,\n      ),\n    )\n  }, [collections, globals, i18n, permissions, user])\n\n  return (\n    <div className={baseClass}>\n      <Gutter className={`${baseClass}__wrap`}>\n        {Array.isArray(beforeDashboard) &&\n          beforeDashboard.map((Component, i) => <Component key={i} />)}\n        {groups.map(({ entities, label }, groupIndex) => {\n          return (\n            <div className={`${baseClass}__group`} key={groupIndex}>\n              <h2 className={`${baseClass}__label`}>{label}</h2>\n              <ul className={`${baseClass}__card-list`}>\n                {entities.map(({ entity, type }, entityIndex) => {\n                  let title: string\n                  let buttonAriaLabel: string\n                  let createHREF: string\n                  let onClick: () => void\n                  let hasCreatePermission: boolean\n\n                  if (type === EntityType.collection) {\n                    title = getTranslation(entity.labels.plural, i18n)\n                    buttonAriaLabel = t('showAllLabel', { label: title })\n                    onClick = () => push({ pathname: `${admin}/collections/${entity.slug}` })\n                    createHREF = `${admin}/collections/${entity.slug}/create`\n                    hasCreatePermission =\n                      permissions?.collections?.[entity.slug]?.create?.permission\n                  }\n\n                  if (type === EntityType.global) {\n                    title = getTranslation(entity.label, i18n)\n                    buttonAriaLabel = t('editLabel', { label: getTranslation(entity.label, i18n) })\n                    onClick = () => push({ pathname: `${admin}/globals/${entity.slug}` })\n                  }\n\n                  return (\n                    <li key={entityIndex}>\n                      <Card\n                        actions={\n                          hasCreatePermission && type === EntityType.collection ? (\n                            <Button\n                              aria-label={t('createNewLabel', {\n                                label: getTranslation(entity.labels.singular, i18n),\n                              })}\n                              buttonStyle=\"icon-label\"\n                              el=\"link\"\n                              icon=\"plus\"\n                              iconStyle=\"with-border\"\n                              round\n                              to={createHREF}\n                            />\n                          ) : undefined\n                        }\n                        buttonAriaLabel={buttonAriaLabel}\n                        id={`card-${entity.slug}`}\n                        onClick={onClick}\n                        title={title}\n                        titleAs=\"h3\"\n                      />\n                    </li>\n                  )\n                })}\n              </ul>\n            </div>\n          )\n        })}\n        {Array.isArray(afterDashboard) &&\n          afterDashboard.map((Component, i) => <Component key={i} />)}\n      </Gutter>\n    </div>\n  )\n}\n\nexport default Dashboard\n"],"names":["baseClass","Dashboard","props","collections","globals","permissions","user","push","useHistory","i18n","t","useTranslation","admin","components","afterDashboard","beforeDashboard","routes","useConfig","groups","setGroups","useState","useEffect","groupNavItems","filter","hidden","map","collection","entityToGroup","entity","type","EntityType","global","div","className","Gutter","Array","isArray","Component","i","key","entities","label","groupIndex","h2","ul","entityIndex","title","buttonAriaLabel","createHREF","onClick","hasCreatePermission","getTranslation","labels","plural","pathname","slug","create","permission","li","Card","actions","Button","aria-label","singular","buttonStyle","el","icon","iconStyle","round","to","undefined","id","titleAs"],"mappings":"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"}