MyCrypto/common/components/Footer/ThemeToggle.scss
William O'Beirne bf6a122e38 Night Mode Theme (#1896)
* Initial changes to define theme maps, color function, and convert all global styles.

* More global styles.

* All styles converted, colors uncertain.

* Fix tabs, temporary theme toggle button.

* Color refinements

* Color network selector, introduce shade function

* Make palette page

* Add theme button and minor styling to nav

* Blueify dark theme

* A bunch of color adjustments to work better with dark theme

* Fix tables

* Fix wallet decrypt colors

* More misc fixes

* Fix up electron colors

* Convert web theme to redux state / action

* Theme toggle in app, prevent rerenders

* Get rid of all variables, fix selects

* Fix conf modal, modal close styles

* Fix test

* Adjust swap colors

* Check in breaking out component, changing icons

* Check in progress

* Theme toggle in footer. New icons

* Prevent rerender on theme change

* Fix up outstanding merge conflicts

* Fix generate colors to be dark mode friendly

* Reduce swap color intensity

* Make disabled buttons darker in dark mode

* Reduce button size by 25%
2018-06-26 23:51:42 -05:00

77 lines
1.8 KiB
SCSS

@import 'common/sass/variables';
@import 'common/sass/mixins';
@mixin theme-icon-showing {
transform: translate(-50%, -50%);
transition-delay: 100ms;
}
$toggle-height: 30px;
$toggle-width: 60px;
$toggle-control-gutter: 3px;
$toggle-control-size: $toggle-height - $toggle-control-gutter * 2;
.ThemeToggle {
position: relative;
height: $toggle-height;
width: $toggle-width;
border-radius: $toggle-height / 2;
border: 1px solid shade-light(0.4);
background: shade-dark(0.2);
opacity: 0.6;
transition: opacity 100ms ease;
&:hover {
opacity: 1;
}
&-control {
position: absolute;
top: 50%;
left: $toggle-control-gutter;
height: $toggle-control-size;
width: $toggle-control-size;
border-radius: 100%;
background: color(control-bg);
transform: translateY(-50%);
overflow: hidden;
transition: transform 300ms ease;
@include theme('dark') {
transform: translateY(-50%) translateX(-100%) translateX($toggle-width)
translateX($toggle-control-gutter * -3);
}
&-icon {
position: absolute;
top: 50%;
left: 50%;
width: 13px;
height: 13px;
transform: translate(-50%, -50%) translateY(30px);
fill: color(text-color);
transition: transform 200ms ease;
background-size: 100%;
background-position: center;
background-repeat: no-repeat;
&.is-light {
background-image: url('~assets/images/icon-theme-light.svg');
opacity: 0.9;
@include theme('light') {
@include theme-icon-showing;
}
}
&.is-dark {
background-image: url('~assets/images/icon-theme-dark.svg');
opacity: 0.85;
filter: invert(1);
@include theme('dark') {
@include theme-icon-showing;
}
}
}
}
}