UNPKG

cspace-ui

Version:
61 lines (48 loc) 1.76 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = AdminNavBar; var _react = _interopRequireDefault(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _reactIntl = require("react-intl"); var _reactRouterDom = require("react-router-dom"); var _AdminNavBar = _interopRequireDefault(require("../../../styles/cspace-ui/AdminNavBar.css")); var _AdminNavItem = _interopRequireDefault(require("../../../styles/cspace-ui/AdminNavItem.css")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } const messages = (0, _reactIntl.defineMessages)({ account: { "id": "adminNavBar.account", "defaultMessage": "Users" }, authrole: { "id": "adminNavBar.authrole", "defaultMessage": "Roles and Permissions" }, vocabulary: { "id": "adminNavBar.vocabulary", "defaultMessage": "Term Lists" } }); const renderLinkItem = (basename, tab) => _react.default.createElement("li", { key: tab }, _react.default.createElement(_reactRouterDom.NavLink, { to: "".concat(basename, "/").concat(tab), className: _AdminNavItem.default.common, activeClassName: _AdminNavItem.default.active }, _react.default.createElement(_reactIntl.FormattedMessage, messages[tab]))); const propTypes = { basename: _propTypes.default.string, tabs: _propTypes.default.arrayOf(_propTypes.default.string) }; function AdminNavBar(props) { const { basename, tabs } = props; const items = tabs.map(tab => renderLinkItem(basename, tab)); return _react.default.createElement("nav", { className: _AdminNavBar.default.common }, _react.default.createElement("ul", null, items)); } AdminNavBar.propTypes = propTypes;