| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451 | //// Component: Forms//.form-group {  &.has-icon {    position: relative;    .form-control {      padding-right: 35px;    }    .form-icon {      background-color: transparent;      border: 0;      cursor: pointer;      font-size: 1rem;      // margin-top: -3px;      padding: $input-btn-padding-y $input-btn-padding-x;      position: absolute;      right: 3px;      top: 0;    }  }}// Button groups.btn-group-vertical {  .btn {    &.btn-flat:first-of-type,    &.btn-flat:last-of-type {      @include border-radius(0);    }  }}// Support icons in form-control.form-control-feedback {  &.fa,  &.fas,  &.far,  &.fab,  &.fal,  &.fad,  &.svg-inline--fa,  &.ion {    line-height: $input-height;  }}.input-lg + .form-control-feedback,.input-group-lg + .form-control-feedback {  &.fa,  &.fas,  &.far,  &.fab,  &.fal,  &.fad,  &.svg-inline--fa,  &.ion {    line-height: $input-height-lg;  }}.form-group-lg {  .form-control + .form-control-feedback {    &.fa,    &.fas,    &.far,    &.fab,    &.fal,    &.fad,    &.svg-inline--fa,    &.ion {      line-height: $input-height-lg;    }  }}.input-sm + .form-control-feedback,.input-group-sm + .form-control-feedback {  &.fa,  &.fas,  &.far,  &.fab,  &.fal,  &.fad,  &.svg-inline--fa,  &.ion {    line-height: $input-height-sm;  }}.form-group-sm {  .form-control + .form-control-feedback {    &.fa,    &.fas,    &.far,    &.fab,    &.fal,    &.fad,    &.svg-inline--fa,    &.ion {      line-height: $input-height-sm;    }  }}label:not(.form-check-label):not(.custom-file-label) {  font-weight: $font-weight-bold;}.warning-feedback {  @include font-size($form-feedback-font-size);  color: theme-color("warning");  display: none;  margin-top: $form-feedback-margin-top;  width: 100%;}.warning-tooltip {  @include border-radius($form-feedback-tooltip-border-radius);  @include font-size($form-feedback-tooltip-font-size);  background-color: rgba(theme-color("warning"), $form-feedback-tooltip-opacity);  color: color-yiq(theme-color("warning"));  display: none;  line-height: $form-feedback-tooltip-line-height;  margin-top: .1rem;  max-width: 100%; // Contain to parent when possible  padding: $form-feedback-tooltip-padding-y $form-feedback-tooltip-padding-x;  position: absolute;  top: 100%;  z-index: 5;}.form-control {  &.is-warning {    border-color: theme-color("warning");    @if $enable-validation-icons {      // padding-right: $input-height-inner;      // background-image: none;      // background-repeat: no-repeat;      // background-position: center right $input-height-inner-quarter;      // background-size: $input-height-inner-half $input-height-inner-half;    }    &:focus {      border-color: theme-color("warning");      box-shadow: 0 0 0 $input-focus-width rgba(theme-color("warning"), .25);    }    ~ .warning-feedback,    ~ .warning-tooltip {      display: block;    }  }}// stylelint-disable-next-line selector-no-qualifying-typetextarea.form-control {  &.is-warning {    @if $enable-validation-icons {      padding-right: $input-height-inner;      background-position: top $input-height-inner-quarter right $input-height-inner-quarter;    }  }}.custom-select {  &.is-warning {    border-color: theme-color("warning");    @if $enable-validation-icons {      // padding-right: $custom-select-feedback-icon-padding-right;      // background: $custom-select-background, none $custom-select-bg no-repeat $custom-select-feedback-icon-position / $custom-select-feedback-icon-size;    }    &:focus {      border-color: theme-color("warning");      box-shadow: 0 0 0 $input-focus-width rgba(theme-color("warning"), .25);    }    ~ .warning-feedback,    ~ .warning-tooltip {      display: block;    }  }}.form-control-file {  &.is-warning {    ~ .warning-feedback,    ~ .warning-tooltip {      display: block;    }  }}.form-check-input {  &.is-warning {    ~ .form-check-label {      color: theme-color("warning");    }    ~ .warning-feedback,    ~ .warning-tooltip {      display: block;    }  }}.custom-control-input.is-warning {  ~ .custom-control-label {    color: theme-color("warning");    &::before {      border-color: theme-color("warning");    }  }  ~ .warning-feedback,  ~ .warning-tooltip {    display: block;  }  &:checked {    ~ .custom-control-label::before {      @include gradient-bg(lighten(theme-color("warning"), 10%));      border-color: lighten(theme-color("warning"), 10%);    }  }  &:focus {    ~ .custom-control-label::before {      box-shadow: 0 0 0 $input-focus-width rgba(theme-color("warning"), .25);    }    &:not(:checked) ~ .custom-control-label::before {      border-color: theme-color("warning");    }  }}// custom file.custom-file-input {  &.is-warning {    ~ .custom-file-label {      border-color: theme-color("warning");    }    ~ .warning-feedback,    ~ .warning-tooltip {      display: block;    }    &:focus {      ~ .custom-file-label {        border-color: theme-color("warning");        box-shadow: 0 0 0 $input-focus-width rgba(theme-color("warning"), .25);      }    }  }}// body.text-sm supportbody.text-sm {  .input-group-text {    font-size: $font-size-sm;  }}// custom .form-control styles.form-control,.custom-select {  &.form-control-border {    border-top: 0;    border-left: 0;    border-right: 0;    border-radius: 0;    box-shadow: inherit;    &.border-width-2 {      border-bottom-width: 2px;    }    &.border-width-3 {      border-bottom-width: 3px;    }  }}// custom switch color variations.custom-switch {  @each $name, $color in $theme-colors {    @include custom-switch-variant($name, $color);  }  @each $name, $color in $colors {    @include custom-switch-variant($name, $color);  }}// custom range color variations.custom-range {  @each $name, $color in $theme-colors {    @include custom-range-variant($name, $color);  }  @each $name, $color in $colors {    @include custom-range-variant($name, $color);  }}// custom control input variations@each $name, $color in $theme-colors {  @include custom-control-input-variant($name, $color);}@each $name, $color in $colors {  @include custom-control-input-variant($name, $color);}.custom-control-input-outline {  ~ .custom-control-label::before {    background-color: transparent !important;    box-shadow: none;  }  &:checked ~ .custom-control-label::before {    @include gradient-bg(transparent);  }}.navbar-dark {  .btn-navbar,  .form-control-navbar {    background-color: lighten($sidebar-dark-bg, 5%);    border: 1px solid lighten($sidebar-dark-bg, 15%);    color: lighten(color-yiq(lighten($sidebar-dark-bg, 5%)), 15%);  }  .btn-navbar {    &:hover {      background-color: lighten($sidebar-dark-bg, 7.5%);    }    &:focus {      background-color: lighten($sidebar-dark-bg, 10%);    }  }  .form-control-navbar + .input-group-prepend,  .form-control-navbar + .input-group-append {    > .btn-navbar {      background-color: lighten($sidebar-dark-bg, 5%);      color: $white;      border: 1px solid lighten($sidebar-dark-bg, 15%);      border-left: none;    }  }}@include dark-mode () {  .form-control:not(.form-control-navbar):not(.form-control-sidebar),  .custom-select,  .custom-file-label,  .custom-file-label::after,  .custom-control-label::before,  .input-group-text {    background-color: $dark;    color: $white;  }  .form-control:not(.form-control-navbar):not(.form-control-sidebar):not(.is-invalid):not(:focus),  .custom-file-label,  .custom-file-label::after {    border-color: $gray-600;  }  select {    background-color: $dark;    color: $white;    border-color: $gray-600;  }  .custom-select {    background: $dark $custom-select-dark-background;    &[multiple]{      background: $dark;    }  }  .input-group-text {    border-color: $gray-600;  }  .custom-control-input:disabled ~ .custom-control-label::before,  .custom-control-input[disabled] ~ .custom-control-label::before {    background-color: lighten($dark, 5%);    border-color: $gray-600;    color: $white;  }  input:-webkit-autofill,  input:-webkit-autofill:hover,  input:-webkit-autofill:focus,  textarea:-webkit-autofill,  textarea:-webkit-autofill:hover,  textarea:-webkit-autofill:focus,  select:-webkit-autofill,  select:-webkit-autofill:hover,  select:-webkit-autofill:focus {    -webkit-text-fill-color: $white;  }  .custom-range {    &::-webkit-slider-runnable-track {      background-color: lighten($dark, 7.5%);    }    &::-moz-range-track {      background-color: lighten($dark, 7.5%);    }    &::-ms-track {      background-color: lighten($dark, 7.5%);    }    @each $name, $color in $theme-colors-alt {      @include custom-range-variant($name, $color);    }    @each $name, $color in $colors-alt {      @include custom-range-variant($name, $color);    }  }  // custom switch color variations  .custom-switch {    @each $name, $color in $theme-colors-alt {      @include custom-switch-variant($name, $color);    }    @each $name, $color in $colors-alt {      @include custom-switch-variant($name, $color);    }  }  @each $name, $color in $theme-colors-alt {    @include custom-control-input-variant($name, $color);  }  @each $name, $color in $colors-alt {    @include custom-control-input-variant($name, $color);  }}
 |