You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

140 lines
3.4 KiB

// Name: Iconnav
// Description: Component to create icon navigations
//
// Component: `uk-iconnav`
//
// Modifier: `uk-iconnav-vertical`
//
// States: `uk-active`
//
// ========================================================================
// Variables
// ========================================================================
$iconnav-margin-horizontal: $global-small-margin !default;
$iconnav-margin-vertical: $iconnav-margin-horizontal !default;
$iconnav-item-color: $global-muted-color !default;
$iconnav-item-hover-color: $global-color !default;
$iconnav-item-active-color: $global-color !default;
/* ========================================================================
Component: Iconnav
========================================================================== */
/*
* 1. Allow items to wrap into the next line
* 2. Reset list
* 3. Gutter
*/
.uk-iconnav {
display: flex;
/* 1 */
flex-wrap: wrap;
/* 2 */
margin: 0;
padding: 0;
list-style: none;
/* 3 */
margin-left: (-$iconnav-margin-horizontal);
@if(mixin-exists(hook-iconnav)) {@include hook-iconnav();}
}
/*
* 1. Space is allocated solely based on content dimensions: 0 0 auto
* 2. Gutter
*/
.uk-iconnav > * {
/* 1 */
flex: none;
/* 2 */
padding-left: $iconnav-margin-horizontal;
}
/* Items
========================================================================== */
/*
* Items must target `a` elements to exclude other elements (e.g. dropdowns)
* 1. Prevent gap if child element is `inline-block`, e.g. an icon
* 2. Style
*/
.uk-iconnav > * > a {
/* 1 */
display: block;
/* 2 */
color: $iconnav-item-color;
@if(mixin-exists(hook-iconnav-item)) {@include hook-iconnav-item();}
}
/* Hover + Focus */
.uk-iconnav > * > a:hover,
.uk-iconnav > * > a:focus {
color: $iconnav-item-hover-color;
outline: none;
@if(mixin-exists(hook-iconnav-item-hover)) {@include hook-iconnav-item-hover();}
}
/* Active */
.uk-iconnav > .uk-active > a {
color: $iconnav-item-active-color;
@if(mixin-exists(hook-iconnav-item-active)) {@include hook-iconnav-item-active();}
}
/* Modifier: 'uk-iconnav-vertical'
========================================================================== */
/*
* 1. Change direction
* 2. Gutter
*/
.uk-iconnav-vertical {
/* 1 */
flex-direction: column;
/* 2 */
margin-left: 0;
margin-top: (-$iconnav-margin-vertical);
}
/* 2 */
.uk-iconnav-vertical > * {
padding-left: 0;
padding-top: $iconnav-margin-vertical;
}
// Hooks
// ========================================================================
@if(mixin-exists(hook-iconnav-misc)) {@include hook-iconnav-misc();}
// @mixin hook-iconnav(){}
// @mixin hook-iconnav-item(){}
// @mixin hook-iconnav-item-hover(){}
// @mixin hook-iconnav-item-active(){}
// @mixin hook-iconnav-misc(){}
// Inverse
// ========================================================================
$inverse-iconnav-item-color: $inverse-global-muted-color !default;
$inverse-iconnav-item-hover-color: $inverse-global-color !default;
$inverse-iconnav-item-active-color: $inverse-global-color !default;
// @mixin hook-inverse-iconnav-item(){}
// @mixin hook-inverse-iconnav-item-hover(){}
// @mixin hook-inverse-iconnav-item-active(){}