UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

183 lines (182 loc) • 19.7 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "Nav", { enumerable: true, get: function() { return Nav; } }); 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 _Chevron = /*#__PURE__*/ _interop_require_default(require("../../icons/Chevron")); const _Auth = require("../../utilities/Auth"); const _Config = require("../../utilities/Config"); const _RenderCustomComponent = /*#__PURE__*/ _interop_require_default(require("../../utilities/RenderCustomComponent")); const _Hamburger = require("../Hamburger"); const _Logout = /*#__PURE__*/ _interop_require_default(require("../Logout")); const _NavGroup = /*#__PURE__*/ _interop_require_default(require("../NavGroup")); const _context = require("./context"); 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 = 'nav'; const DefaultNav = ()=>{ const { navOpen, navRef, setNavOpen } = (0, _context.useNav)(); const { permissions, user } = (0, _Auth.useAuth)(); const [groups, setGroups] = (0, _react.useState)([]); const { i18n } = (0, _reacti18next.useTranslation)('general'); const { admin: { components: { afterNavLinks, beforeNavLinks } }, collections, globals, routes: { admin } } = (0, _Config.useConfig)(); (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, permissions, i18n, i18n.language, user ]); return /*#__PURE__*/ _react.default.createElement("aside", { className: [ baseClass, navOpen && `${baseClass}--nav-open` ].filter(Boolean).join(' ') }, /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__scroll`, ref: navRef }, /*#__PURE__*/ _react.default.createElement("nav", { className: `${baseClass}__wrap` }, Array.isArray(beforeNavLinks) && beforeNavLinks.map((Component, i)=>/*#__PURE__*/ _react.default.createElement(Component, { key: i })), groups.map(({ entities, label }, key)=>{ return /*#__PURE__*/ _react.default.createElement(_NavGroup.default, { key, label }, entities.map(({ entity, type }, i)=>{ let entityLabel; let href; let id; if (type === _groupNavItems.EntityType.collection) { href = `${admin}/collections/${entity.slug}`; entityLabel = (0, _getTranslation.getTranslation)(entity.labels.plural, i18n); id = `nav-${entity.slug}`; } if (type === _groupNavItems.EntityType.global) { href = `${admin}/globals/${entity.slug}`; entityLabel = (0, _getTranslation.getTranslation)(entity.label, i18n); id = `nav-global-${entity.slug}`; } return /*#__PURE__*/ _react.default.createElement(_reactrouterdom.NavLink, { activeClassName: "active", className: `${baseClass}__link`, id: id, key: i, tabIndex: !navOpen ? -1 : undefined, to: href }, /*#__PURE__*/ _react.default.createElement("span", { className: `${baseClass}__link-icon` }, /*#__PURE__*/ _react.default.createElement(_Chevron.default, { direction: "right" })), /*#__PURE__*/ _react.default.createElement("span", { className: `${baseClass}__link-label` }, entityLabel)); })); }), Array.isArray(afterNavLinks) && afterNavLinks.map((Component, i)=>/*#__PURE__*/ _react.default.createElement(Component, { key: i })), /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__controls` }, /*#__PURE__*/ _react.default.createElement(_Logout.default, { tabIndex: !navOpen ? -1 : undefined })))), /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__header` }, /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__header-content` }, /*#__PURE__*/ _react.default.createElement("button", { className: `${baseClass}__mobile-close`, onClick: ()=>{ setNavOpen(false); }, tabIndex: !navOpen ? -1 : undefined, type: "button" }, /*#__PURE__*/ _react.default.createElement(_Hamburger.Hamburger, { isActive: true }))))); }; const Nav = ()=>{ const { admin: { components: { Nav: CustomNav } = { Nav: undefined } } = {} } = (0, _Config.useConfig)(); return /*#__PURE__*/ _react.default.createElement(_RenderCustomComponent.default, { CustomComponent: CustomNav, DefaultComponent: DefaultNav }); }; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/Nav/index.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { NavLink } from 'react-router-dom'\n\nimport type { EntityToGroup, Group } from '../../../utilities/groupNavItems'\n\nimport { getTranslation } from '../../../../utilities/getTranslation'\nimport { EntityType, groupNavItems } from '../../../utilities/groupNavItems'\nimport Chevron from '../../icons/Chevron'\nimport { useAuth } from '../../utilities/Auth'\nimport { useConfig } from '../../utilities/Config'\nimport RenderCustomComponent from '../../utilities/RenderCustomComponent'\nimport { Hamburger } from '../Hamburger'\nimport Logout from '../Logout'\nimport NavGroup from '../NavGroup'\nimport { useNav } from './context'\nimport './index.scss'\n\nconst baseClass = 'nav'\n\nconst DefaultNav: React.FC = () => {\n  const { navOpen, navRef, setNavOpen } = useNav()\n  const { permissions, user } = useAuth()\n  const [groups, setGroups] = useState<Group[]>([])\n  const { i18n } = useTranslation('general')\n\n  const {\n    admin: {\n      components: { afterNavLinks, beforeNavLinks },\n    },\n    collections,\n    globals,\n    routes: { admin },\n  } = useConfig()\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, permissions, i18n, i18n.language, user])\n\n  return (\n    <aside className={[baseClass, navOpen && `${baseClass}--nav-open`].filter(Boolean).join(' ')}>\n      <div className={`${baseClass}__scroll`} ref={navRef}>\n        <nav className={`${baseClass}__wrap`}>\n          {Array.isArray(beforeNavLinks) &&\n            beforeNavLinks.map((Component, i) => <Component key={i} />)}\n          {groups.map(({ entities, label }, key) => {\n            return (\n              <NavGroup {...{ key, label }}>\n                {entities.map(({ entity, type }, i) => {\n                  let entityLabel: string\n                  let href: string\n                  let id: string\n\n                  if (type === EntityType.collection) {\n                    href = `${admin}/collections/${entity.slug}`\n                    entityLabel = getTranslation(entity.labels.plural, i18n)\n                    id = `nav-${entity.slug}`\n                  }\n\n                  if (type === EntityType.global) {\n                    href = `${admin}/globals/${entity.slug}`\n                    entityLabel = getTranslation(entity.label, i18n)\n                    id = `nav-global-${entity.slug}`\n                  }\n\n                  return (\n                    <NavLink\n                      activeClassName=\"active\"\n                      className={`${baseClass}__link`}\n                      id={id}\n                      key={i}\n                      tabIndex={!navOpen ? -1 : undefined}\n                      to={href}\n                    >\n                      <span className={`${baseClass}__link-icon`}>\n                        <Chevron direction=\"right\" />\n                      </span>\n                      <span className={`${baseClass}__link-label`}>{entityLabel}</span>\n                    </NavLink>\n                  )\n                })}\n              </NavGroup>\n            )\n          })}\n          {Array.isArray(afterNavLinks) &&\n            afterNavLinks.map((Component, i) => <Component key={i} />)}\n          <div className={`${baseClass}__controls`}>\n            <Logout tabIndex={!navOpen ? -1 : undefined} />\n          </div>\n        </nav>\n      </div>\n      <div className={`${baseClass}__header`}>\n        <div className={`${baseClass}__header-content`}>\n          <button\n            className={`${baseClass}__mobile-close`}\n            onClick={() => {\n              setNavOpen(false)\n            }}\n            tabIndex={!navOpen ? -1 : undefined}\n            type=\"button\"\n          >\n            <Hamburger isActive />\n          </button>\n        </div>\n      </div>\n    </aside>\n  )\n}\n\nexport const Nav: React.FC = () => {\n  const {\n    admin: {\n      components: { Nav: CustomNav } = {\n        Nav: undefined,\n      },\n    } = {},\n  } = useConfig()\n\n  return <RenderCustomComponent CustomComponent={CustomNav} DefaultComponent={DefaultNav} />\n}\n"],"names":["Nav","baseClass","DefaultNav","navOpen","navRef","setNavOpen","useNav","permissions","user","useAuth","groups","setGroups","useState","i18n","useTranslation","admin","components","afterNavLinks","beforeNavLinks","collections","globals","routes","useConfig","useEffect","groupNavItems","filter","hidden","map","collection","entityToGroup","entity","type","EntityType","global","language","aside","className","Boolean","join","div","ref","nav","Array","isArray","Component","i","key","entities","label","NavGroup","entityLabel","href","id","slug","getTranslation","labels","plural","NavLink","activeClassName","tabIndex","undefined","to","span","Chevron","direction","Logout","button","onClick","Hamburger","isActive","CustomNav","RenderCustomComponent","CustomComponent","DefaultComponent"],"mappings":"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"}