heti/_site/scss/components/_panel-list.scss
2020-05-18 00:49:59 +08:00

201 lines
7.2 KiB
SCSS

// Author: Sivan [sun.sivan@gmail.com]
// Description: panel list.
@mixin lightmode {
--bg-color: hsl(240, 100%, 100%);
--bg-tap-color: hsl(300, 3%, 94%);
--border-color: hsla(0, 0%, 76%, 0.88);
--border-inline-start-color: hsl(0, 0%, 76%);
--border-inline-end-color: hsl(0, 0%, 76%);
--border-block-start-color: hsl(0, 0%, 79%);
--border-block-end-color: hsl(0, 0%, 65%);
--text-color: hsl(60, 1%, 16%);
--box-shadow-color: hsla(0, 0%, 86%, 0.54);
--bg-highlight-color-start: hsl(216, 87%, 70%);
--bg-highlight-color-end: hsl(215, 93%, 52%);
--bg-highlight-tap-color-start: hsl(216, 92%, 65%);
--bg-highlight-tap-color-end: hsl(215, 95%, 44%);
--border-highlight-color: hsla(216, 90%, 57%, 0.88);
--border-highlight-tap-color: hsla(216, 85%, 52%, 0.88);
--border-inline-start-highlight-color: hsl(216, 90%, 57%);
--border-inline-end-highlight-color: hsl(216, 90%, 57%);
--border-inline-start-highlight-tap-color: hsl(216, 85%, 52%);
--border-inline-end-highlight-tap-color: hsl(216, 85%, 52%);
--border-block-start-highlight-color: hsl(216, 87%, 63%);
--border-block-end-highlight-color: hsl(215, 99%, 49%);
--border-block-start-highlight-tap-color: hsl(216, 93%, 57%);
--border-block-end-highlight-tap-color: hsl(216, 100%, 42%);
--text-highlight-color: hsl(0, 0%, 100%);
&--gray {
--bg-color: hsl(180, 100%, 100%);
--bg-tap-color: hsl(0, 0%, 94%);
--border-color: hsla(0, 0%, 72%, 0.88);
--border-inline-start-color: hsl(0, 0%, 76%);
--border-inline-end-color: hsl(0, 0%, 76%);
--border-block-start-color: hsl(0, 0%, 79%);
--border-block-end-color: hsl(0, 0%, 65%);
--text-color: hsl(0, 0%, 16%);
--box-shadow-color: hsla(0, 0%, 86%, 0.54);
--bg-highlight-color-start: hsl(225, 3%, 70%);
--bg-highlight-color-end: hsl(228, 2%, 58%);
--bg-highlight-tap-color-start: hsl(228, 2%, 58%);
--bg-highlight-tap-color-end: hsl(240, 3%, 35%);
--border-highlight-color: hsla(225, 2%, 64%, 0.88);
--border-highlight-tap-color: hsla(228, 2%, 47%, 0.88);
--border-inline-start-highlight-color: hsl(240, 3%, 59%);
--border-inline-end-highlight-color: hsl(228, 2%, 54%);
--border-inline-start-highlight-tap-color: hsl(240, 3%, 39%);
--border-inline-end-highlight-tap-color: hsl(228, 3%, 39%);
--border-block-start-highlight-color: hsl(240, 3%, 66%);
--border-block-end-highlight-color: hsl(228, 2%, 50%);
--border-block-start-highlight-tap-color: hsl(228, 2%, 51%);
--border-block-end-highlight-tap-color: hsl(228, 4%, 26%);
--text-highlight-color: hsl(0, 0%, 92%);
}
}
@mixin darkmode {
--bg-color: hsl(225, 2%, 40%);
--bg-tap-color: hsl(210, 2%, 49%);
--border-color: hsla(210, 2%, 33%, 0.88);
--border-inline-start-color: hsl(210, 2%, 33%);
--border-inline-end-color: hsl(210, 2%, 33%);
--border-block-start-color: hsl(225, 2%, 45%);
--border-block-end-color: hsl(210, 2%, 40%);
--text-color: hsl(0, 0%, 91%);
--box-shadow-color: hsla(225, 4%, 21%, 0.54);
--bg-highlight-color-start: hsl(216, 77%, 49%);
--bg-highlight-color-end: hsl(216, 76%, 45%);
--bg-highlight-tap-color-start: hsl(214, 83%, 55%);
--bg-highlight-tap-color-end: hsl(215, 74%, 51%);
--border-highlight-color: hsla(215, 77%, 47%, 0.88);
--border-highlight-tap-color: hsla(215, 79%, 54%, 0.88);
--border-inline-start-highlight-color: hsl(215, 77%, 47%);
--border-inline-end-highlight-color: hsl(215, 77%, 47%);
--border-inline-start-highlight-tap-color: hsl(215, 79%, 54%);
--border-inline-end-highlight-tap-color: hsl(215, 79%, 54%);
--border-block-start-highlight-color: hsl(216, 76%, 55%);
--border-block-end-highlight-color: hsl(216, 76%, 44%);
--border-block-start-highlight-tap-color: hsl(215, 84%, 60%);
--border-block-end-highlight-tap-color: hsl(215, 74%, 51%);
--text-highlight-color: hsl(0, 0%, 100%);
&--gray {
--bg-color: hsl(0, 0%, 40%);
--bg-tap-color: hsl(0, 0%, 49%);
--border-color: hsla(120, 1%, 34%, 0.88);
--border-inline-start-color: hsl(0, 0%, 40%);
--border-inline-end-color: hsl(360, 0%, 40%);
--border-block-start-color: hsl(0, 0%, 46%);
--border-block-end-color: hsl(120, 0%, 40%);
--text-color: hsl(0, 0%, 91%);
--box-shadow-color: hsla(0, 0%, 17%, 0.54);
--bg-highlight-color-start: hsl(0, 0%, 60%);
--bg-highlight-color-end: hsl(0, 0%, 60%);
--bg-highlight-tap-color-start: hsl(0, 0%, 69%);
--bg-highlight-tap-color-end: hsl(0, 0%, 69%);
--border-highlight-color: hsla(0, 0%, 60%, 0.88);
--border-highlight-tap-color: hsla(0, 0%, 69%, 0.88);
--border-inline-start-highlight-color: hsl(0, 0%, 60%);
--border-inline-end-highlight-color: hsl(0, 0%, 60%);
--border-inline-start-highlight-tap-color: hsl(0, 0%, 69%);
--border-inline-end-highlight-tap-color: hsl(0, 0%, 69%);
--border-block-start-highlight-color: hsl(0, 0%, 64%);
--border-block-end-highlight-color: hsl(0, 0%, 60%);
--border-block-start-highlight-tap-color: hsl(0, 0%, 73%);
--border-block-end-highlight-tap-color: hsl(0, 0%, 69%);
--text-highlight-color: hsl(0, 0%, 15%);
}
}
.panel-list {
display: inline-flex;
margin: 0;
padding: 0;
list-style-type: none;
@include lightmode;
[data-darkmode="dark"] & {
@include darkmode;
}
@media (prefers-color-scheme: dark) {
[data-darkmode="auto"] & {
@include darkmode;
}
}
& + & {
margin-inline-start: 12px;
}
label {
position: relative;
display: block;
box-sizing: border-box;
height: 20px;
padding: 0;
padding-inline-start: 12px;
padding-inline-end: 12px;
border: 1px solid;
font-size: 12px;
line-height: 18px;
text-align: center;
user-select: none;
background-color: var(--bg-color);
border-color: var(--border-color);
border-block-start-color: var(--border-block-start-color);
border-block-end-color: var(--border-block-end-color);
color: var(--text-color);
box-shadow: 0 1px 0 var(--box-shadow-color);
&:active {
background-color: var(--bg-tap-color);
}
}
li {
margin-inline-end: -1px;
&:first-child label {
border-top-left-radius: 4px;
border-bottom-left-radius: 4px;
border-inline-start-color: var(--border-inline-start-color);
}
&:last-child label {
border-top-right-radius: 4px;
border-bottom-right-radius: 4px;
border-inline-end-color: var(--border-inline-end-color);
}
}
input {
display: none;
&:checked + label {
z-index: 1;
background-image: linear-gradient(to bottom, var(--bg-highlight-color-start), var(--bg-highlight-color-end));
border-color: var(--border-highlight-color);
border-block-start-color: var(--border-block-start-highlight-color);
border-block-end-color: var(--border-block-end-highlight-color);
color: var(--text-highlight-color);
&:active {
background-image: linear-gradient(to bottom, var(--bg-highlight-tap-color-start), var(--bg-highlight-tap-color-end));
border-color: var(--border-highlight-tap-color);
border-block-start-color: var(--border-block-start-highlight-tap-color);
border-block-end-color: var(--border-block-end-highlight-tap-color);
}
}
}
&--icon {
label {
width: 30px;
padding-inline-start: 8px;
padding-inline-end: 8px;
}
}
}