mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-12 20:14:12 +00:00
bf6a122e38
* 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%
77 lines
1.8 KiB
SCSS
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;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|