forked from Public/pics
Introduce new menu classes and navigation templates
This commit is contained in:
@@ -1,38 +0,0 @@
|
||||
<?php
|
||||
/*****************************************************************************
|
||||
* AdminBar.php
|
||||
* Defines the AdminBar class.
|
||||
*
|
||||
* Kabuki CMS (C) 2013-2015, Aaron van Geffen
|
||||
*****************************************************************************/
|
||||
|
||||
class AdminBar extends Template
|
||||
{
|
||||
private $extra_items = [];
|
||||
|
||||
public function html_main()
|
||||
{
|
||||
echo '
|
||||
<div id="admin_bar">
|
||||
<ul>
|
||||
<li><a href="', BASEURL, '/managealbums/">Albums</a></li>
|
||||
<li><a href="', BASEURL, '/manageassets/">Assets</a></li>
|
||||
<li><a href="', BASEURL, '/managetags/">Tags</a></li>
|
||||
<li><a href="', BASEURL, '/manageusers/">Users</a></li>
|
||||
<li><a href="', BASEURL, '/manageerrors/">Errors [', ErrorLog::getCount(), ']</a></li>';
|
||||
|
||||
foreach ($this->extra_items as $item)
|
||||
echo '
|
||||
<li><a href="', $item[0], '">', $item[1], '</a></li>';
|
||||
|
||||
echo '
|
||||
<li><a href="', BASEURL, '/logout/">Log out [', Registry::get('user')->getFullName(), ']</a></li>
|
||||
</ul>
|
||||
</div>';
|
||||
}
|
||||
|
||||
public function appendItem($url, $caption)
|
||||
{
|
||||
$this->extra_items[] = [$url, $caption];
|
||||
}
|
||||
}
|
||||
51
templates/MainNavBar.php
Normal file
51
templates/MainNavBar.php
Normal file
@@ -0,0 +1,51 @@
|
||||
<?php
|
||||
/*****************************************************************************
|
||||
* MainNavBar.php
|
||||
* Contains the primary navigational menu template.
|
||||
*
|
||||
* Global Data Lab code (C) Radboud University Nijmegen
|
||||
* Programming (C) Aaron van Geffen, 2015-2022
|
||||
*****************************************************************************/
|
||||
|
||||
class MainNavBar extends NavBar
|
||||
{
|
||||
protected $outerMenuId = 'mainNav';
|
||||
protected $innerMenuId = 'mainNavigation';
|
||||
protected $ariaLabel = 'Main navigation';
|
||||
protected $navBarClasses = 'navbar-dark bg-dark sticky-top mb-4';
|
||||
protected $primaryBadgeClasses = 'bg-light text-dark';
|
||||
protected $secondaryBadgeClasses = 'bg-dark text-light';
|
||||
|
||||
public function html_main()
|
||||
{
|
||||
echo '
|
||||
<nav id="', $this->outerMenuId, '" class="navbar navbar-expand-lg ', $this->navBarClasses, '" aria-label="', $this->ariaLabel, '">
|
||||
<div class="container">
|
||||
<a class="navbar-brand flex-grow-1" href="', BASEURL, '/">
|
||||
HashRU Pics
|
||||
</a>
|
||||
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#', $this->innerMenuId, '" aria-controls="', $this->innerMenuId, '" aria-expanded="false" aria-label="Toggle navigation">
|
||||
<span class="navbar-toggler-icon"></span>
|
||||
</button>
|
||||
<div class="collapse navbar-collapse justify-content-end" id="', $this->innerMenuId, '">
|
||||
<ul class="navbar-nav mb-2 mb-lg-0">';
|
||||
|
||||
$mainMenu = new MainMenu();
|
||||
$this->renderMenuItems($mainMenu->getItems());
|
||||
|
||||
echo '
|
||||
<li class="nav-divider d-none d-lg-inline"></li>';
|
||||
|
||||
$adminMenu = new AdminMenu();
|
||||
$this->renderMenuItems($adminMenu->getItems());
|
||||
|
||||
$userMenu = new UserMenu();
|
||||
$this->renderMenuItems($userMenu->getItems());
|
||||
|
||||
echo '
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
</nav>';
|
||||
}
|
||||
}
|
||||
@@ -43,15 +43,12 @@ class MainTemplate extends Template
|
||||
, $this->header_html, '
|
||||
</head>
|
||||
<body', !empty($this->classes) ? ' class="' . implode(' ', $this->classes) . '"' : '', '>
|
||||
<header>
|
||||
<a href="', BASEURL, '/">
|
||||
<h1 id="logo">#pics</h1>
|
||||
</a>
|
||||
<ul id="nav">
|
||||
<li><a href="', BASEURL, '/">albums</a></li>
|
||||
<li><a href="', BASEURL, '/people/">people</a></li>
|
||||
<li><a href="', BASEURL, '/timeline/">timeline</a></li>
|
||||
</ul>
|
||||
<header>';
|
||||
|
||||
$bar = new MainNavBar();
|
||||
$bar->html_main();
|
||||
|
||||
echo '
|
||||
</header>
|
||||
<div id="wrapper">';
|
||||
|
||||
@@ -88,6 +85,7 @@ class MainTemplate extends Template
|
||||
echo '<pre>', strtr($query, "\t", " "), '</pre>';
|
||||
|
||||
echo '
|
||||
<script type="text/javascript" src="', BASEURL, '/vendor/twbs/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||
</body>
|
||||
</html>';
|
||||
}
|
||||
|
||||
62
templates/NavBar.php
Normal file
62
templates/NavBar.php
Normal file
@@ -0,0 +1,62 @@
|
||||
<?php
|
||||
/*****************************************************************************
|
||||
* NavBar.php
|
||||
* Contains the navigational menu template.
|
||||
*
|
||||
* Global Data Lab code (C) Radboud University Nijmegen
|
||||
* Programming (C) Aaron van Geffen, 2015-2022
|
||||
*****************************************************************************/
|
||||
|
||||
abstract class NavBar extends Template
|
||||
{
|
||||
protected $primaryBadgeClasses = 'bg-dark text-light';
|
||||
protected $secondaryBadgeClasses = 'bg-light text-dark';
|
||||
|
||||
public function renderMenu(array $items, $navBarClasses = '')
|
||||
{
|
||||
echo '
|
||||
<ul class="navbar-nav ', $navBarClasses, '">';
|
||||
|
||||
$this->renderMenuItems($items, $navBarClasses);
|
||||
|
||||
echo '
|
||||
</ul>';
|
||||
}
|
||||
|
||||
public function renderMenuItems(array $items)
|
||||
{
|
||||
foreach ($items as $menuId => $item)
|
||||
{
|
||||
if (isset($item['icon']))
|
||||
$item['label'] = '<i class="bi bi-' . $item['icon'] . '"></i> ' . $item['label'];
|
||||
|
||||
if (isset($item['badge']))
|
||||
$item['label'] .= ' <span class="badge ' . $this->primaryBadgeClasses . '">' . $item['badge'] . '</span>';
|
||||
|
||||
if (empty($item['subs']))
|
||||
{
|
||||
echo '
|
||||
<li class="nav-item"><a class="nav-link" href="', $item['url'], '">', $item['label'], '</a></li>';
|
||||
continue;
|
||||
}
|
||||
|
||||
echo '
|
||||
<li class="nav-item dropdown">
|
||||
<a class="nav-link dropdown-toggle" href="#" id="menu', $menuId, '" data-bs-toggle="dropdown" aria-expanded="false">', $item['label'], '</a>
|
||||
<ul class="dropdown-menu" aria-labelledby="menu', $menuId, '">';
|
||||
|
||||
foreach ($item['subs'] as $subitem)
|
||||
{
|
||||
if (isset($subitem['badge']))
|
||||
$subitem['label'] .= ' <span class="badge ' . $this->secondaryBadgeClasses . '">' . $subitem['badge'] . '</span>';
|
||||
|
||||
echo '
|
||||
<li><a class="dropdown-item" href="', $subitem['url'], '">', $subitem['label'], '</a></li>';
|
||||
}
|
||||
|
||||
echo '
|
||||
</ul>
|
||||
</li>';
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user