collapsible aside navigation

This commit is contained in:
Felix Hamann 2018-03-17 16:24:55 +01:00
parent be383f84b8
commit d480195b2d
6 changed files with 128 additions and 50 deletions

View File

@ -1,11 +1,9 @@
<!-- navigation --> <!-- navigation -->
<div .navbar-container> ^{navbar}
^{navbar}
<div .main> <div .main>
<aside .main__aside> ^{asidenav}
^{asidenav}
<div .main__content> <div .main__content>
<!-- breadcrumbs --> <!-- breadcrumbs -->

View File

@ -46,9 +46,6 @@
--header-height-collapsed: 50px; --header-height-collapsed: 50px;
} }
* { * {
box-sizing: border-box; box-sizing: border-box;
padding: 0; padding: 0;
@ -126,19 +123,6 @@ th {
min-height: calc(100vh - var(--header-height)); min-height: calc(100vh - var(--header-height));
} }
.main__aside {
width: 300px;
flex-shrink: 0;
padding-right: 20px;
padding-left: 4vw;
background-color: var(--darkbase);
/*background: -moz-linear-gradient(right, var(--darkbase) 0%, #395069 100%); /* FF3.6-15 */*/
/*background: -webkit-linear-gradient(right, var(--darkbase) 0%, #395069 100%); /* Chrome10-25,Safari5.1-6 */*/
/*background: linear-gradient(to left, var(--darkbase) 0%, #395069 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */*/
box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
z-index: 1;
}
.main__content { .main__content {
background-color: white; background-color: white;
padding: 20px 40px; padding: 20px 40px;

View File

@ -1,17 +1,18 @@
<div .asidenav> <aside .main__aside>
<div .asidenav__box> <div .asidenav>
<ul .asidenav__list> <div .asidenav__box--dont-hide>
$forall menuType <- menuTypes <ul .asidenav__list>
$case menuType $forall menuType <- menuTypes
$of NavbarLeft (MenuItem label route _) $case menuType
<li .asidenav__list-item :Just route == mcurrentRoute:.asidenav__list-item--active> $of NavbarLeft (MenuItem label icon route _)
<a .asidenav__link href=@{route}>#{label} <li .asidenav__list-item :Just route == mcurrentRoute:.asidenav__list-item--active>
$of _ <a .asidenav__link.asidenav__icon--#{icon} href=@{route}>#{label}
$of _
<div .asidenav__box> <div .asidenav__box>
<h3 .asidenav__box-title>WiSe 17/18 <h3 .asidenav__box-title>WiSe 17/18
<ul .asidenav__list> <ul .asidenav__list>
<li>CD <li>CD
<li>IxD <li>IxD
<li>Funktionale Programmierung <li>Funktionale Programmierung
<li>Programmierung und Modellierung <li>Programmierung und Modellierung

View File

@ -0,0 +1,55 @@
(function() {
'use strict';
window.utils = window.utils || {};
window.utils.aside = function(el) {
var asideEl = el;
var collapsed = false;
var collClass = 'main__aside--collapsed';
var animClass = 'main__aside--transitioning';
init();
function init() {
var collLS = window.localStorage.getItem('asidenavCollapsed') === 'true';
if (document.body.getBoundingClientRect().width < 999 || collLS) {
asideEl.classList.add(collClass);
collapsed = true;
}
}
function check() {
if (collapsed && !hasClass() || !collapsed && hasClass()) {
asideEl.classList.add(animClass);
asideEl.classList.toggle(collClass, collapsed);
window.localStorage.setItem('asidenavCollapsed', collapsed);
}
}
function hasClass() {
return asideEl.classList.contains(collClass);
}
asideEl.addEventListener('click', function(event) {
if (event.target === asideEl) {
collapsed = !collapsed;
check();
}
});
asideEl.addEventListener('transitionend', function(event) {
if (event.propertyName === 'opacity') {
asideEl.classList.remove(animClass);
}
});
window.addEventListener('resize', function() {
collapsed = document.body.getBoundingClientRect().width < 999;
check();
});
};
})();
document.addEventListener('DOMContentLoaded', function() {
utils.aside(document.querySelector('.main__aside'));
});

View File

@ -1,21 +1,60 @@
.main__aside {
flex-shrink: 0;
background-color: var(--darkbase);
box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
z-index: 1;
width: 300px;
overflow: hidden;
}
.main__aside--transitioning {
transition: width .2s ease;
}
.main__aside--transitioning .asidenav__box{
transition: opacity .2s ease;
}
.main__aside--collapsed {
width: 50px;
}
.main__aside--collapsed .asidenav__box {
opacity: 0;
}
.main__aside--collapsed .asidenav__box--dont-hide {
opacity: 1;
}
.main__aside--collapsed:not(.main__aside--transitioning) .asidenav__box {
visibility: hidden;
pointer-events: none;
z-index: -10;
height: 0;
padding: 0;
margin: 0;
}
.asidenav { .asidenav {
width: 300px;
margin-top: 20px; margin-top: 20px;
color: white; color: white;
} }
.asidenav__box { .asidenav__box {
margin: 10px 0; margin: 10px 0;
padding: 10px; padding: 10px 0;
border-bottom: 4px solid var(--whitebase); border-bottom: 4px solid var(--whitebase);
} }
.asidenav__box-title { .asidenav__box-title {
margin-left: -10px; margin-left: -10px;
} }
.asidenav .asidenav__link { .asidenav .asidenav__link {
position: relative;
display: block; display: block;
padding: 4px 7px; padding: 4px 7px;
border-radius: 2px; line-height: 40px;
margin: 4px 0; margin: 4px 0;
padding-left: 60px;
color: var(--darkbase); color: var(--darkbase);
background-color: white; background-color: white;
} }

View File

@ -1,14 +1,15 @@
<nav .navbar.js-sticky-navbar> <div .navbar-container>
<nav .navbar.js-sticky-navbar>
<ul .navbar__list.list--inline> <ul .navbar__list.list--inline>
$forall menuType <- menuTypes $forall menuType <- menuTypes
$case menuType $case menuType
$of NavbarRight (MenuItem label route _) $of NavbarRight (MenuItem label icon route _)
<li .navbar__list-item :Just route == mcurrentRoute:.navbar__list-item--active> <li .navbar__list-item :Just route == mcurrentRoute:.navbar__list-item--active>
<a .navbar__link href=@{route}>#{label} <a .navbar__link href=@{route}>#{label}
$of NavbarSecondary (MenuItem label route _) $of NavbarSecondary (MenuItem label icon route _)
<li .navbar__list-item.navbar__list-item--secondary :Just route == mcurrentRoute:.navbar__list-item--active> <li .navbar__list-item.navbar__list-item--secondary :Just route == mcurrentRoute:.navbar__list-item--active>
<a .navbar__link href=@{route}>#{label} <a .navbar__link href=@{route}>#{label}
$of _ $of _
<div .navbar__pushdown> <div .navbar__pushdown>