Initial coomit for AAI-UI(sparky-fe)
[aai/sparky-fe.git] / resources / scss / bootstrap / _navbar.scss
diff --git a/resources/scss/bootstrap/_navbar.scss b/resources/scss/bootstrap/_navbar.scss
new file mode 100644 (file)
index 0000000..af38fd9
--- /dev/null
@@ -0,0 +1,650 @@
+//
+// Navbars
+// --------------------------------------------------
+
+// Wrapper and base class
+//
+// Provide a static navbar from which we expand to create full-width, fixed, and
+// other navbar variations.
+
+.navbar {
+  position: relative;
+  min-height: $navbar-height; // Ensure a navbar always shows (e.g., without a .navbar-brand in collapsed mode)
+  margin-bottom: $navbar-margin-bottom;
+  border: 1px solid transparent;
+
+  // Prevent floats from breaking the navbar
+  @include clearfix;
+
+  @media (min-width: $grid-float-breakpoint) {
+       border-radius: $navbar-border-radius;
+  }
+}
+
+// Navbar heading
+//
+// Groups `.navbar-brand` and `.navbar-toggle` into a single component for easy
+// styling of responsive aspects.
+
+.navbar-header {
+  @include clearfix;
+
+  @media (min-width: $grid-float-breakpoint) {
+       float: left;
+  }
+}
+
+// Navbar collapse (body)
+//
+// Group your navbar content into this for easy collapsing and expanding across
+// various device sizes. By default, this content is collapsed when <768px, but
+// will expand past that for a horizontal display.
+//
+// To start (on mobile devices) the navbar links, forms, and buttons are stacked
+// vertically and include a `max-height` to overflow in case you have too much
+// content for the user's viewport.
+
+.navbar-collapse {
+  overflow-x: visible;
+  padding-right: $navbar-padding-horizontal;
+  padding-left: $navbar-padding-horizontal;
+  border-top: 1px solid transparent;
+  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .1);
+  @include clearfix;
+  -webkit-overflow-scrolling: touch;
+
+  &.in {
+       overflow-y: auto;
+  }
+
+  @media (min-width: $grid-float-breakpoint) {
+       width: auto;
+       border-top: 0;
+       box-shadow: none;
+
+       &.collapse {
+         display: block !important;
+         height: auto !important;
+         padding-bottom: 0; // Override default setting
+         overflow: visible !important;
+       }
+
+       &.in {
+         overflow-y: visible;
+       }
+
+       // Undo the collapse side padding for navbars with containers to ensure
+       // alignment of right-aligned contents.
+       .navbar-fixed-top &,
+       .navbar-static-top &,
+       .navbar-fixed-bottom & {
+         padding-left: 0;
+         padding-right: 0;
+       }
+  }
+}
+
+.navbar-fixed-top,
+.navbar-fixed-bottom {
+  .navbar-collapse {
+       max-height: $navbar-collapse-max-height;
+
+       @media (max-device-width: $screen-xs-min) and (orientation: landscape) {
+         max-height: 200px;
+       }
+  }
+}
+
+// Both navbar header and collapse
+//
+// When a container is present, change the behavior of the header and collapse.
+
+.container,
+.container-fluid {
+  > .navbar-header,
+  > .navbar-collapse {
+       margin-right: -$navbar-padding-horizontal;
+       margin-left: -$navbar-padding-horizontal;
+
+       @media (min-width: $grid-float-breakpoint) {
+         margin-right: 0;
+         margin-left: 0;
+       }
+  }
+}
+
+//
+// Navbar alignment options
+//
+// Display the navbar across the entirety of the page or fixed it to the top or
+// bottom of the page.
+
+// Static top (unfixed, but 100% wide) navbar
+.navbar-static-top {
+  z-index: $zindex-navbar;
+  border-width: 0 0 1px;
+
+  @media (min-width: $grid-float-breakpoint) {
+       border-radius: 0;
+  }
+}
+
+// Fix the top/bottom navbars when screen real estate supports it
+.navbar-fixed-top,
+.navbar-fixed-bottom {
+  position: fixed;
+  right: 0;
+  left: 0;
+  z-index: $zindex-navbar-fixed;
+
+  // Undo the rounded corners
+  @media (min-width: $grid-float-breakpoint) {
+       border-radius: 0;
+  }
+}
+
+.navbar-fixed-top {
+  top: 0;
+  border-width: 0 0 1px;
+}
+
+.navbar-fixed-bottom {
+  bottom: 0;
+  margin-bottom: 0; // override .navbar defaults
+  border-width: 1px 0 0;
+}
+
+// Brand/project name
+
+.navbar-brand {
+  float: left;
+  padding: $navbar-padding-vertical $navbar-padding-horizontal;
+  font-size: $font-size-large;
+  line-height: $line-height-computed;
+  height: $navbar-height;
+
+  &:hover,
+  &:focus {
+       text-decoration: none;
+  }
+
+  > img {
+       display: block;
+  }
+
+  @media (min-width: $grid-float-breakpoint) {
+       .navbar > .container &,
+       .navbar > .container-fluid & {
+         margin-left: -$navbar-padding-horizontal;
+       }
+  }
+}
+
+// Navbar toggle
+//
+// Custom button for toggling the `.navbar-collapse`, powered by the collapse
+// JavaScript plugin.
+
+.navbar-toggle {
+  position: relative;
+  float: right;
+  margin-right: $navbar-padding-horizontal;
+  padding: 9px 10px;
+  @include navbar-vertical-align(34px);
+  background-color: transparent;
+  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214
+  border: 1px solid transparent;
+  border-radius: $border-radius-base;
+
+  // We remove the `outline` here, but later compensate by attaching `:hover`
+  // styles to `:focus`.
+  &:focus {
+       outline: 0;
+  }
+
+  // Bars
+  .icon-bar {
+       display: block;
+       width: 22px;
+       height: 2px;
+       border-radius: 1px;
+  }
+  .icon-bar + .icon-bar {
+       margin-top: 4px;
+  }
+
+  @media (min-width: $grid-float-breakpoint) {
+       display: none;
+  }
+}
+
+// Navbar nav links
+//
+// Builds on top of the `.nav` components with its own modifier class to make
+// the nav the full height of the horizontal nav (above 768px).
+
+.navbar-nav {
+  margin: ($navbar-padding-vertical / 2) (-$navbar-padding-horizontal);
+
+  > li > a {
+       padding-top: 10px;
+       padding-bottom: 10px;
+       line-height: $line-height-computed;
+  }
+
+  @media (max-width: $grid-float-breakpoint-max) {
+       // Dropdowns get custom display when collapsed
+       .open .dropdown-menu {
+         position: static;
+         float: none;
+         width: auto;
+         margin-top: 0;
+         background-color: transparent;
+         border: 0;
+         box-shadow: none;
+         > li > a,
+         .dropdown-header {
+               padding: 5px 15px 5px 25px;
+         }
+         > li > a {
+               line-height: $line-height-computed;
+               &:hover,
+               &:focus {
+                 background-image: none;
+               }
+         }
+       }
+  }
+
+  // Uncollapse the nav
+  @media (min-width: $grid-float-breakpoint) {
+       float: left;
+       margin: 0;
+
+       > li {
+         float: left;
+         > a {
+               padding-top: $navbar-padding-vertical;
+               padding-bottom: $navbar-padding-vertical;
+         }
+       }
+  }
+}
+
+// Navbar form
+//
+// Extension of the `.form-inline` with some extra flavor for optimum display in
+// our navbars.
+
+.navbar-form {
+  margin-left: -$navbar-padding-horizontal;
+  margin-right: -$navbar-padding-horizontal;
+  padding: 10px $navbar-padding-horizontal;
+  border-top: 1px solid transparent;
+  border-bottom: 1px solid transparent;
+  $shadow: inset 0 1px 0 rgba(255, 255, 255, .1), 0 1px 0 rgba(255, 255, 255, .1);
+  @include box-shadow($shadow);
+
+  // Mixin behavior for optimum display
+  @include form-inline;
+
+  .form-group {
+       @media (max-width: $grid-float-breakpoint-max) {
+         margin-bottom: 5px;
+
+         &:last-child {
+               margin-bottom: 0;
+         }
+       }
+  }
+
+  // Vertically center in expanded, horizontal navbar
+  @include navbar-vertical-align($input-height-base);
+
+  // Undo 100% width for pull classes
+  @media (min-width: $grid-float-breakpoint) {
+       width: auto;
+       border: 0;
+       margin-left: 0;
+       margin-right: 0;
+       padding-top: 0;
+       padding-bottom: 0;
+       @include box-shadow(none);
+  }
+}
+
+// Dropdown menus
+
+// Menu position and menu carets
+.navbar-nav > li > .dropdown-menu {
+  margin-top: 0;
+  @include border-top-radius(0);
+}
+
+// Menu position and menu caret support for dropups via extra dropup class
+.navbar-fixed-bottom .navbar-nav > li > .dropdown-menu {
+  margin-bottom: 0;
+  @include border-top-radius($navbar-border-radius);
+  @include border-bottom-radius(0);
+}
+
+// Buttons in navbars
+//
+// Vertically center a button within a navbar (when *not* in a form).
+
+.navbar-btn {
+  @include navbar-vertical-align($input-height-base);
+
+  &.btn-sm {
+       @include navbar-vertical-align($input-height-small);
+  }
+  &.btn-xs {
+       @include navbar-vertical-align(22);
+  }
+}
+
+// Text in navbars
+//
+// Add a class to make any element properly align itself vertically within the navbars.
+
+.navbar-text {
+  @include navbar-vertical-align($line-height-computed);
+
+  @media (min-width: $grid-float-breakpoint) {
+       float: left;
+       margin-left: $navbar-padding-horizontal;
+       margin-right: $navbar-padding-horizontal;
+  }
+}
+
+// Component alignment
+//
+// Repurpose the pull utilities as their own navbar utilities to avoid specificity
+// issues with parents and chaining. Only do this when the navbar is uncollapsed
+// though so that navbar contents properly stack and align in mobile.
+//
+// Declared after the navbar components to ensure more specificity on the margins.
+
+@media (min-width: $grid-float-breakpoint) {
+  .navbar-left {
+       float: left !important;
+  }
+  .navbar-right {
+       float: right !important;
+       margin-right: -$navbar-padding-horizontal;
+
+       ~ .navbar-right {
+         margin-right: 0;
+       }
+  }
+}
+
+// Alternate navbars
+// --------------------------------------------------
+
+// Default navbar
+.navbar-default {
+  background-color: $navbar-default-bg;
+  border-color: $navbar-default-border;
+
+  .navbar-brand {
+       color: $navbar-default-brand-color;
+       &:hover,
+       &:focus {
+         color: $navbar-default-brand-hover-color;
+         background-color: $navbar-default-brand-hover-bg;
+       }
+  }
+
+  .navbar-text {
+       color: $navbar-default-color;
+  }
+
+  .navbar-nav {
+       > li > a {
+         color: $navbar-default-link-color;
+
+         &:hover,
+         &:focus {
+               color: $navbar-default-link-hover-color;
+               background-color: $navbar-default-link-hover-bg;
+         }
+       }
+       > .active > a {
+         &,
+         &:hover,
+         &:focus {
+               color: $navbar-default-link-active-color;
+               background-color: $navbar-default-link-active-bg;
+         }
+       }
+       > .disabled > a {
+         &,
+         &:hover,
+         &:focus {
+               color: $navbar-default-link-disabled-color;
+               background-color: $navbar-default-link-disabled-bg;
+         }
+       }
+  }
+
+  .navbar-toggle {
+       border-color: $navbar-default-toggle-border-color;
+       &:hover,
+       &:focus {
+         background-color: $navbar-default-toggle-hover-bg;
+       }
+       .icon-bar {
+         background-color: $navbar-default-toggle-icon-bar-bg;
+       }
+  }
+
+  .navbar-collapse,
+  .navbar-form {
+       border-color: $navbar-default-border;
+  }
+
+  // Dropdown menu items
+  .navbar-nav {
+       // Remove background color from open dropdown
+       > .open > a {
+         &,
+         &:hover,
+         &:focus {
+               background-color: $navbar-default-link-active-bg;
+               color: $navbar-default-link-active-color;
+         }
+       }
+
+       @media (max-width: $grid-float-breakpoint-max) {
+         // Dropdowns get custom display when collapsed
+         .open .dropdown-menu {
+               > li > a {
+                 color: $navbar-default-link-color;
+                 &:hover,
+                 &:focus {
+                       color: $navbar-default-link-hover-color;
+                       background-color: $navbar-default-link-hover-bg;
+                 }
+               }
+               > .active > a {
+                 &,
+                 &:hover,
+                 &:focus {
+                       color: $navbar-default-link-active-color;
+                       background-color: $navbar-default-link-active-bg;
+                 }
+               }
+               > .disabled > a {
+                 &,
+                 &:hover,
+                 &:focus {
+                       color: $navbar-default-link-disabled-color;
+                       background-color: $navbar-default-link-disabled-bg;
+                 }
+               }
+         }
+       }
+  }
+
+  // Links in navbars
+  //
+  // Add a class to ensure links outside the navbar nav are colored correctly.
+
+  .navbar-link {
+       color: $navbar-default-link-color;
+       &:hover {
+         color: $navbar-default-link-hover-color;
+       }
+  }
+
+  .btn-link {
+       color: $navbar-default-link-color;
+       &:hover,
+       &:focus {
+         color: $navbar-default-link-hover-color;
+       }
+       &[disabled],
+       fieldset[disabled] & {
+         &:hover,
+         &:focus {
+               color: $navbar-default-link-disabled-color;
+         }
+       }
+  }
+}
+
+// Inverse navbar
+
+.navbar-inverse {
+  background-color: $navbar-inverse-bg;
+  border-color: $navbar-inverse-border;
+
+  .navbar-brand {
+       color: $navbar-inverse-brand-color;
+       &:hover,
+       &:focus {
+         color: $navbar-inverse-brand-hover-color;
+         background-color: $navbar-inverse-brand-hover-bg;
+       }
+  }
+
+  .navbar-text {
+       color: $navbar-inverse-color;
+  }
+
+  .navbar-nav {
+       > li > a {
+         color: $navbar-inverse-link-color;
+
+         &:hover,
+         &:focus {
+               color: $navbar-inverse-link-hover-color;
+               background-color: $navbar-inverse-link-hover-bg;
+         }
+       }
+       > .active > a {
+         &,
+         &:hover,
+         &:focus {
+               color: $navbar-inverse-link-active-color;
+               background-color: $navbar-inverse-link-active-bg;
+         }
+       }
+       > .disabled > a {
+         &,
+         &:hover,
+         &:focus {
+               color: $navbar-inverse-link-disabled-color;
+               background-color: $navbar-inverse-link-disabled-bg;
+         }
+       }
+  }
+
+  // Darken the responsive nav toggle
+  .navbar-toggle {
+       border-color: $navbar-inverse-toggle-border-color;
+       &:hover,
+       &:focus {
+         background-color: $navbar-inverse-toggle-hover-bg;
+       }
+       .icon-bar {
+         background-color: $navbar-inverse-toggle-icon-bar-bg;
+       }
+  }
+
+  .navbar-collapse,
+  .navbar-form {
+       border-color: darken($navbar-inverse-bg, 7%);
+  }
+
+  // Dropdowns
+  .navbar-nav {
+       > .open > a {
+         &,
+         &:hover,
+         &:focus {
+               background-color: $navbar-inverse-link-active-bg;
+               color: $navbar-inverse-link-active-color;
+         }
+       }
+
+       @media (max-width: $grid-float-breakpoint-max) {
+         // Dropdowns get custom display
+         .open .dropdown-menu {
+               > .dropdown-header {
+                 border-color: $navbar-inverse-border;
+               }
+               .divider {
+                 background-color: $navbar-inverse-border;
+               }
+               > li > a {
+                 color: $navbar-inverse-link-color;
+                 &:hover,
+                 &:focus {
+                       color: $navbar-inverse-link-hover-color;
+                       background-color: $navbar-inverse-link-hover-bg;
+                 }
+               }
+               > .active > a {
+                 &,
+                 &:hover,
+                 &:focus {
+                       color: $navbar-inverse-link-active-color;
+                       background-color: $navbar-inverse-link-active-bg;
+                 }
+               }
+               > .disabled > a {
+                 &,
+                 &:hover,
+                 &:focus {
+                       color: $navbar-inverse-link-disabled-color;
+                       background-color: $navbar-inverse-link-disabled-bg;
+                 }
+               }
+         }
+       }
+  }
+
+  .navbar-link {
+       color: $navbar-inverse-link-color;
+       &:hover {
+         color: $navbar-inverse-link-hover-color;
+       }
+  }
+
+  .btn-link {
+       color: $navbar-inverse-link-color;
+       &:hover,
+       &:focus {
+         color: $navbar-inverse-link-hover-color;
+       }
+       &[disabled],
+       fieldset[disabled] & {
+         &:hover,
+         &:focus {
+               color: $navbar-inverse-link-disabled-color;
+         }
+       }
+  }
+}