// Material Design Switch // -------------------------------------------------- $switch-md-active-color: color(primary) !default; $switch-md-track-width: 36px !default; $switch-md-track-height: 14px !default; $switch-md-track-off-bg-color: $item-md-border-color !default; $switch-md-track-on-bg-color: lighten($switch-md-active-color, 25%) !default; $switch-md-handle-width: 20px !default; $switch-md-handle-height: 20px !default; $switch-md-handle-off-bg-color: $background-color !default; $switch-md-handle-on-bg-color: $switch-md-active-color !default; $switch-md-handle-box-shadow: 0 2px 2px 0 rgba(0,0,0,.14), 0 3px 1px -2px rgba(0,0,0,.2), 0 1px 5px 0 rgba(0,0,0,.12) !default; $switch-md-transition-duration: 300ms !default; .switch { .item-media { margin: 0; padding: 6px ($item-md-padding-right / 2) 6px $item-md-padding-left; } // Switch Background Track // ----------------------------------------- .switch-icon { // bg track, when not checked position: relative; width: $switch-md-track-width; height: $switch-md-track-height; pointer-events: none; border-radius: $switch-md-track-height; background-color: $switch-md-track-off-bg-color; will-change: background-color; transition: background-color $switch-md-transition-duration } &[aria-checked=true] .switch-icon { // bg track, when not checked background-color: $switch-md-track-on-bg-color; } // Switch Knob // ----------------------------------------- .switch-icon:after { // knob, when not checked content: ''; position: absolute; top: ($switch-md-handle-height - $switch-md-track-height) / -2; left: 0; width: $switch-md-handle-width; height: $switch-md-handle-height; border-radius: 50%; box-shadow: $switch-md-handle-box-shadow; background-color: $switch-md-handle-off-bg-color; will-change: transform, background-color; transition-property: transform, background-color; transition-duration: $switch-md-transition-duration; } &[aria-checked=true] .switch-icon:after { // knob, when not checked background-color: $switch-md-handle-on-bg-color; transform: translate3d($switch-md-track-width - $switch-md-handle-width, 0, 0); } } // Material Design Color Mixin // -------------------------------------------------- @mixin switch-theme-md($color-name, $bg-on) { .switch[#{$color-name}] { &[aria-checked=true] .switch-icon { background-color: lighten($bg-on, 25%); } &[aria-checked=true] .switch-icon:after { background-color: $bg-on; } } } // Generate Material Design Switch Auxiliary Colors // -------------------------------------------------- @each $color-name, $value in auxiliary-colors() { @include switch-theme-md($color-name, $value); }