/* ------------------------------------------------------------------------------ * * # Bootstrap multiselect * * Styles for multiselect.js - custom multiple select plugin * * Version: 1.0 * Latest update: May 25, 2015 * * ---------------------------------------------------------------------------- */ // Core // ------------------------------ .multiselect { width: 100%; min-width: 100%; text-align: left; padding-left: @padding-base-horizontal; padding-right: ((@padding-base-horizontal * 2) + 5); text-overflow: ellipsis; overflow: hidden; // Default button overrides &.btn-default { &, &.disabled { background-color: @input-bg; border-color: @input-border; } &:active, .btn-group.open & { border-color: @input-border; } } // Caret .caret { position: absolute; top: 50%; right: @padding-base-horizontal; margin-top: -(@icon-font-size / 2); width: @icon-font-size; text-align: right; } // // Make it as an input instead of button // // Large &.btn-lg { padding-left: @padding-large-horizontal; padding-right: (@padding-large-horizontal * 2); .caret { right: @padding-large-horizontal; } } // Small &.btn-sm { padding-left: @padding-small-horizontal; padding-right: (@padding-small-horizontal * 2); .caret { right: @padding-small-horizontal; } } // Mini &.btn-xs { padding-left: @padding-xs-horizontal; padding-right: (@padding-xs-horizontal * 2); .caret { right: @padding-xs-horizontal; } } } // Container // ------------------------------ .multiselect-container { min-width: 180px; max-height: 250px; overflow-y: auto; > li { padding: 0; // Links > a { padding: 0; // Label > label { margin: 0; height: 100%; cursor: pointer; padding: (@padding-base-vertical + 1) @padding-base-horizontal; padding-left: (@padding-base-horizontal + @checkbox-size + 10); // Inside navbar form .navbar-form & { display: block; } } // Checkboxes and radios .checker, .choice { top: 50%; margin-top: -(@checkbox-size / 2); left: @padding-base-horizontal; } // Select all link &.multiselect-all label { font-weight: 500; } } // Disabled item &.disabled > a { background-color: transparent; > label { cursor: @cursor-disabled; } } // Optgroup title &.multiselect-group { > label, &.active > label { margin: 0; padding: (@padding-base-vertical + 1) @content-padding-base; font-size: @font-size-mini; line-height: @line-height-mini; color: @text-muted; text-transform: uppercase; margin-top: (@list-spacing * 2); background-color: transparent; cursor: default; } // Disabled color &.disabled { color: @text-muted; } // First item &:first-child { > label, &.active > label { margin-top: @list-spacing; } } // Clickable group &.multiselect-group-clickable > label { cursor: pointer; } // Disabled group &.disabled { &, &:hover, &:focus { label { background-color: transparent; cursor: @cursor-disabled; } } } } } } // Width sizing // ------------------------------ // Full width .multi-select-full > .btn-group { width: 100%; .multiselect-container { width: inherit; } } // Fixed width .multi-select-fixed > .btn-group > .btn { width: 250px; } // Auto width .multi-select-auto > .btn-group > .btn { width: auto; } // Misc // ------------------------------ // Border color div[class*=border-] > .btn-group { border-color: inherit; > .multiselect { border-color: inherit; } } // Filter li.multiselect-filter { position: relative; padding: (@padding-base-horizontal - @list-spacing) @padding-base-horizontal; margin-bottom: (@padding-base-horizontal - @list-spacing); // Center icon vertically i { font-size: @font-size-small; position: absolute; left: (@padding-base-horizontal * 2); top: 50%; margin-top: -(@font-size-small / 2); .opacity(0.5); } // Input horizontal padding .form-control { padding-left: (@padding-base-horizontal * 3); } } // Remove left rounded corners .input-group-btn, .input-group-addon { & + .multi-select-full, & + .multi-select-auto, & + .multi-select-fixed, & + .btn-group { .multiselect:first-child { .border-left-radius(0); } } } // Button group styles .btn-group-multiselect { width: 100%; .btn { float: none; } .multiselect { min-width: 0; } } .btn-group > .btn-group:nth-child(2) > .multiselect.btn { .border-left-radius(@border-radius-small); }