|
|
@@ -1,46 +1,49 @@
|
|
|
import React from 'react';
|
|
|
import PropTypes from 'prop-types';
|
|
|
import { withTranslation } from 'react-i18next';
|
|
|
+import urljoin from 'url-join';
|
|
|
|
|
|
const AdminNavigation = (props) => {
|
|
|
const { t } = props;
|
|
|
|
|
|
- const pathname = window.location.pathname;
|
|
|
- const activeMenu = pathname.split('/')[2];
|
|
|
+ const isActiveMenu = (path) => {
|
|
|
+ const pathname = window.location.pathname;
|
|
|
+ return (pathname.startsWith(urljoin('/admin', path)));
|
|
|
+ };
|
|
|
|
|
|
return (
|
|
|
<ul className="nav nav-pills nav-stacked">
|
|
|
- <li className={`${activeMenu === 'index' && 'active'}`}>
|
|
|
+ <li className={`${isActiveMenu('/') && 'active'}`}>
|
|
|
<a href="/admin"><i className="icon-fw icon-home"></i> { t('Management Wiki Home') }</a>
|
|
|
</li>
|
|
|
- <li className={`${activeMenu === 'app' && 'active'}`}>
|
|
|
+ <li className={`${isActiveMenu('/app') && 'active'}`}>
|
|
|
<a href="/admin/app"><i className="icon-fw icon-settings"></i> { t('App Settings') }</a>
|
|
|
</li>
|
|
|
- <li className={`${activeMenu === 'security' && 'active'}`}>
|
|
|
+ <li className={`${isActiveMenu('/security') && 'active'}`}>
|
|
|
<a href="/admin/security"><i className="icon-fw icon-shield"></i> { t('security_settings') }</a>
|
|
|
</li>
|
|
|
- <li className={`${activeMenu === 'markdown' && 'active'}`}>
|
|
|
+ <li className={`${isActiveMenu('/markdown') && 'active'}`}>
|
|
|
<a href="/admin/markdown"><i className="icon-fw icon-note"></i> { t('Markdown Settings') }</a>
|
|
|
</li>
|
|
|
- <li className={`${activeMenu === 'customize' && 'active'}`}>
|
|
|
+ <li className={`${isActiveMenu('/customize') && 'active'}`}>
|
|
|
<a href="/admin/customize"><i className="icon-fw icon-wrench"></i> { t('Customize') }</a>
|
|
|
</li>
|
|
|
- <li className={`${activeMenu === 'importer' && 'active'}`}>
|
|
|
+ <li className={`${isActiveMenu('/importer') && 'active'}`}>
|
|
|
<a href="/admin/importer"><i className="icon-fw icon-cloud-upload"></i> { t('Import Data') }</a>
|
|
|
</li>
|
|
|
- <li className={`${activeMenu === 'export' && 'active'}`}>
|
|
|
+ <li className={`${isActiveMenu('/export') && 'active'}`}>
|
|
|
<a href="/admin/export"><i className="icon-fw icon-cloud-download"></i> { t('Export Archive Data') }</a>
|
|
|
</li>
|
|
|
- <li className={`${activeMenu === 'notification' && 'active'}`}>
|
|
|
+ <li className={`${isActiveMenu('/notification') && 'active'}`}>
|
|
|
<a href="/admin/notification"><i className="icon-fw icon-bell"></i> { t('Notification Settings') }</a>
|
|
|
</li>
|
|
|
- <li className={`${(activeMenu === 'user' || activeMenu === 'externalaccount') && 'active'}`}>
|
|
|
+ <li className={`${(isActiveMenu('/user')) && 'active'}`}>
|
|
|
<a href="/admin/users"><i className="icon-fw icon-user"></i> { t('User_Management') }</a>
|
|
|
</li>
|
|
|
- <li className={`${activeMenu === 'user-group' && 'active'}`}>
|
|
|
+ <li className={`${isActiveMenu('/user-group') && 'active'}`}>
|
|
|
<a href="/admin/user-groups"><i className="icon-fw icon-people"></i> { t('UserGroup Management') }</a>
|
|
|
</li>
|
|
|
- <li className={`${activeMenu === 'search' && 'active'}`}>
|
|
|
+ <li className={`${isActiveMenu('/search') && 'active'}`}>
|
|
|
<a href="/admin/search"><i className="icon-fw icon-magnifier"></i> { t('Full Text Search Management') }</a>
|
|
|
</li>
|
|
|
</ul>
|