// Form control focus state // // Generate a customized focus state and for any input with the specified color, // which defaults to the `$input-focus-border-color` variable. // // We highly encourage you to not customize the default value, but instead use // this to tweak colors on an as-needed basis. This aesthetic change is based on // WebKit's default styles, but applicable to a wider range of browsers. Its // usability and accessibility should be taken into account with any change. // // Example usage: change the default blue border and shadow to white for better // contrast against a dark gray background. @mixin form-control-focus() { &:focus { color: $input-focus-color; background-color: $input-focus-bg; border-color: $input-focus-border-color; outline: 0; // Avoid using mixin so we can pass custom focus shadow properly @if $enable-shadows { box-shadow: $input-box-shadow, $input-focus-box-shadow; } @else { box-shadow: $input-focus-box-shadow; } } } @mixin form-validation-state($state, $color) { .#{$state}-feedback { display: none; margin-top: .25rem; font-size: .875rem; color: $color; } .#{$state}-tooltip { position: absolute; top: 100%; z-index: 5; display: none; width: 250px; padding: .5rem; margin-top: .1rem; font-size: .875rem; line-height: 1; color: #fff; background-color: rgba($color, .8); border-radius: .2rem; } .form-control, .custom-select { .was-validated &:#{$state}, &.is-#{$state} { border-color: $color; &:focus { box-shadow: 0 0 0 $input-focus-width rgba($color, .25); } ~ .#{$state}-feedback, ~ .#{$state}-tooltip { display: block; } } } // TODO: redo check markup lol crap .form-check-input { .was-validated &:#{$state}, &.is-#{$state} { + .form-check-label { color: $color; } } } // custom radios and checks .custom-control-input { .was-validated &:#{$state}, &.is-#{$state} { ~ .custom-control-indicator { background-color: rgba($color, .4); } ~ .custom-control-description { color: $color; } &:focus { ~ .custom-control-indicator { box-shadow: 0 0 0 1px $body-bg, 0 0 0 $input-focus-width rgba($color, .25); } } } } // custom file .custom-file-input { .was-validated &:#{$state}, &.is-#{$state} { ~ .custom-file-control { border-color: $color; &::before { border-color: inherit; } } &:focus { ~ .custom-file-control { box-shadow: 0 0 0 $input-focus-width rgba($color, .25); } } } } }