// Embedded icons from Open Iconic. // Released under MIT and copyright 2014 Waybury. // https://useiconic.com/open // Checkboxes and radios // // Base class takes care of all the key behavioral aspects. .custom-control { position: relative; display: -webkit-inline-flex; display: -moz-inline-flex; display: -ms-inline-flexbox; display: inline-flex; min-height: (1rem * $line-height-base); padding-#{$left}: $custom-control-gutter; margin-#{$right}: $custom-control-spacer-x; } .custom-control-input { position: absolute; z-index: -1; // Put the input behind the label so it doesn't overlay text opacity: 0; &:checked ~ .custom-control-indicator { color: $custom-control-indicator-checked-color; @include gradient-bg($custom-control-indicator-checked-bg); @include box-shadow($custom-control-indicator-checked-box-shadow); } &:focus ~ .custom-control-indicator { // the mixin is not used here to make sure there is feedback box-shadow: $custom-control-indicator-focus-box-shadow; } &:active ~ .custom-control-indicator { color: $custom-control-indicator-active-color; @include gradient-bg($custom-control-indicator-active-bg); @include box-shadow($custom-control-indicator-active-box-shadow); } &:disabled { ~ .custom-control-indicator { background-color: $custom-control-indicator-disabled-bg; } ~ .custom-control-description { color: $custom-control-description-disabled-color; } } } // Custom indicator // // Generates a shadow element to create our makeshift checkbox/radio background. .custom-control-indicator { position: absolute; top: (($line-height-base - $custom-control-indicator-size) / 2); #{$left}: 0; display: block; width: $custom-control-indicator-size; height: $custom-control-indicator-size; pointer-events: none; user-select: none; background-color: $custom-control-indicator-bg; background-repeat: no-repeat; background-position: center center; background-size: $custom-control-indicator-bg-size; @include box-shadow($custom-control-indicator-box-shadow); } // Checkboxes // // Tweak just a few things for checkboxes. .custom-checkbox { .custom-control-indicator { @include border-radius($custom-checkbox-indicator-border-radius); } .custom-control-input:checked ~ .custom-control-indicator { background-image: $custom-checkbox-indicator-icon-checked; } .custom-control-input:indeterminate ~ .custom-control-indicator { background-color: $custom-checkbox-indicator-indeterminate-bg; background-image: $custom-checkbox-indicator-icon-indeterminate; @include box-shadow($custom-checkbox-indicator-indeterminate-box-shadow); } } // Radios // // Tweak just a few things for radios. .custom-radio { .custom-control-indicator { border-radius: $custom-radio-indicator-border-radius; } .custom-control-input:checked ~ .custom-control-indicator { background-image: $custom-radio-indicator-icon-checked; } } // Layout options // // By default radios and checkboxes are `inline-block` with no additional spacing // set. Use these optional classes to tweak the layout. .custom-controls-stacked { display: -webkit-flex; display: -moz-flex; display: -ms-flexbox; display: flex; -webkit-flex-direction: column; -moz-flex-direction: column; flex-direction: column; -ms-flex-direction: column; .custom-control { margin-bottom: $custom-control-spacer-y; + .custom-control { margin-#{$left}: 0; } } } // Select // // Replaces the browser default select with a custom one, mostly pulled from // http://primercss.io. // .custom-select { display: inline-block; max-width: 100%; height: $input-height; padding: side-values($custom-select-padding-y ($custom-select-padding-x + $custom-select-indicator-padding) $custom-select-padding-y $custom-select-padding-x); line-height: $custom-select-line-height; color: $custom-select-color; vertical-align: middle; background: $custom-select-bg $custom-select-indicator no-repeat $right $custom-select-padding-x center; background-size: $custom-select-bg-size; border: $custom-select-border-width solid $custom-select-border-color; @if $enable-rounded { border-radius: $custom-select-border-radius; } @else { border-radius: 0; } appearance: none; &:focus { border-color: $custom-select-focus-border-color; outline: none; @include box-shadow($custom-select-focus-box-shadow); &::-ms-value { // For visual consistency with other platforms/browsers, // supress the default white text on blue background highlight given to // the selected option text when the (still closed)