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