373 lines
10 KiB
CSS
373 lines
10 KiB
CSS
/*
|
|
* Copyright (C) 2020 Yomichan Authors
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
/* Variables */
|
|
:root {
|
|
--padding: 10px;
|
|
--main-content-size: 700px;
|
|
--main-content-padding: 10px;
|
|
--shadow-color: rgba(0, 0, 0, 0.185);
|
|
--shadow-vertical: 0 1px 4px 0 var(--shadow-color), 0 2px 2px 0 var(--shadow-color);
|
|
|
|
--font-size-default: 14px;
|
|
--line-height-default: calc(20 / 14);
|
|
--thin-border-size: 1px;
|
|
--toggle-size: 16px;
|
|
|
|
--textarea-line-height: 1.25em;
|
|
--textarea-padding: 0.5em;
|
|
|
|
--animation-duration: 0s;
|
|
--animation-duration2: calc(var(--animation-duration) * 2);
|
|
|
|
--material-arrow-dimension1: 5px;
|
|
--material-arrow-dimension2: 10px;
|
|
--input-height: 32px;
|
|
--input-width-large: 200px;
|
|
|
|
--text-color-default: #222222;
|
|
--background-color: #ffffff;
|
|
--background-color-light: #ffffff;
|
|
--input-background-color: #f2f2f2;
|
|
--input-background-color-dark: #dddddd;
|
|
--input-background-color-darker: #cccccc;
|
|
--separator-color1: #cccccc;
|
|
--button-icon-color: #333333;
|
|
--toggle-track-color: #cccccc;
|
|
--toggle-knob-color: #ffffff;
|
|
--selectable-indicator-color: rgba(160, 160, 160, 0.25);
|
|
--disabled-color: #aaaaaa;
|
|
--disabled-color-light: #dddddd;
|
|
--disabled-color-lighter: #eeeeee;
|
|
--accent-color: #1a73e8;
|
|
--accent-color-lighter: #8db9f4;
|
|
--accent-color-transparent25: rgba(28, 116, 233, 0.25);
|
|
}
|
|
:root[data-loaded=true] {
|
|
--animation-duration: 0.125s;
|
|
}
|
|
:root[data-yomichan-theme=dark] {
|
|
--text-color-default: #d8d8d8;
|
|
--background-color: #1e1e1e;
|
|
--shadow-color: rgba(255, 255, 255, 0.185);
|
|
--separator-color1: #cccccc;
|
|
--input-background-color: #2f2f2f;
|
|
--input-background-color-dark: #383838;
|
|
--input-background-color-darker: #484848;
|
|
--selectable-indicator-color: rgba(100, 100, 100, 0.25);
|
|
--button-icon-color: #cccccc;
|
|
--disabled-color: #444444;
|
|
--disabled-color-light: #585858;
|
|
--disabled-color-lighter: #777777;
|
|
}
|
|
|
|
/* Common styles */
|
|
:root {
|
|
height: 100%;
|
|
}
|
|
body {
|
|
background-color: var(--background-color);
|
|
margin: 0;
|
|
padding: 0;
|
|
margin: 0;
|
|
font-size: var(--font-size-default);
|
|
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
|
|
color: var(--text-color-default);
|
|
line-height: var(--line-height-default);
|
|
height: 100%;
|
|
overflow: hidden;
|
|
}
|
|
h1 {
|
|
font-size: 2em;
|
|
line-height: 1.5em;
|
|
margin: 0;
|
|
padding: 0.25em 0 0;
|
|
font-weight: normal;
|
|
box-sizing: border-box;
|
|
border-bottom: var(--thin-border-size) solid var(--separator-color1);
|
|
}
|
|
|
|
/* Material design select */
|
|
select {
|
|
width: var(--input-width-large);
|
|
height: var(--input-height);
|
|
line-height: var(--input-height);
|
|
border: 0;
|
|
border-radius: 0;
|
|
box-sizing: border-box;
|
|
padding: 0 0.5em;
|
|
-webkit-appearance: none;
|
|
-moz-appearance: none;
|
|
appearance: none;
|
|
background-image: url(/mixed/img/material-down-arrow.svg);
|
|
background-repeat: no-repeat;
|
|
background-position: right var(--padding) center;
|
|
background-color: var(--input-background-color);
|
|
background-size: var(--material-arrow-dimension2) var(--material-arrow-dimension1);
|
|
cursor: pointer;
|
|
outline: 0;
|
|
}
|
|
select::-ms-expand {
|
|
display: none;
|
|
}
|
|
|
|
/* Material design toggle switch */
|
|
label.toggle {
|
|
cursor: default;
|
|
}
|
|
.toggle {
|
|
font-size: var(--toggle-size);
|
|
display: inline-block;
|
|
}
|
|
.toggle>input[type=checkbox] {
|
|
opacity: 0;
|
|
width: 0;
|
|
height: 0;
|
|
display: block;
|
|
margin: 0;
|
|
padding: 0;
|
|
border: none;
|
|
appearance: none;
|
|
-moz-appearance: none;
|
|
}
|
|
.toggle-body {
|
|
display: block;
|
|
cursor: pointer;
|
|
width: 2em;
|
|
height: 1em;
|
|
position: relative;
|
|
}
|
|
.toggle-track {
|
|
display: block;
|
|
position: absolute;
|
|
left: 0.125em;
|
|
right: 0.125em;
|
|
top: 0.125em;
|
|
bottom: 0.125em;
|
|
background-color: var(--toggle-track-color);
|
|
border-radius: 0.4375em;
|
|
transition: background-color var(--animation-duration) ease-in-out;
|
|
}
|
|
.toggle-knob {
|
|
display: block;
|
|
position: absolute;
|
|
left: 0;
|
|
top: 0;
|
|
width: 1em;
|
|
height: 1em;
|
|
background-color: var(--toggle-knob-color);
|
|
border-radius: 0.5em;
|
|
box-shadow: var(--shadow-vertical);
|
|
transition: transform var(--animation-duration) ease-in-out,
|
|
background-color var(--animation-duration) ease-in-out;
|
|
}
|
|
.toggle-body>.toggle-knob::after {
|
|
position: absolute;
|
|
display: block;
|
|
content: "";
|
|
left: -0.75em;
|
|
top: -0.75em;
|
|
right: -0.75em;
|
|
bottom: -0.75em;
|
|
border-radius: 2.5em;
|
|
background-color: var(--selectable-indicator-color);
|
|
pointer-events: none;
|
|
transform: scale(0);
|
|
opacity: 0;
|
|
visibility: hidden;
|
|
transition: transform 0s ease-in-out var(--animation-duration2),
|
|
background-color var(--animation-duration2) ease-in-out,
|
|
opacity var(--animation-duration2) ease-in-out,
|
|
visibility 0s ease-in-out var(--animation-duration2);
|
|
}
|
|
.toggle>input[type=checkbox]:focus:not(:disabled)+.toggle-body>.toggle-knob::after,
|
|
.toggle:active>input[type=checkbox]:not(:disabled)+.toggle-body>.toggle-knob::after {
|
|
transform: scale(1);
|
|
opacity: 1;
|
|
visibility: visible;
|
|
transition: transform var(--animation-duration2) ease-in-out,
|
|
background-color var(--animation-duration2) ease-in-out,
|
|
opacity var(--animation-duration2) ease-in-out,
|
|
visibility var(--animation-duration2) ease-in-out;
|
|
}
|
|
.toggle>input[type=checkbox]:focus+.toggle-body>.toggle-knob::after {
|
|
opacity: 0.5;
|
|
}
|
|
.toggle:active>input[type=checkbox]:focus+.toggle-body>.toggle-knob::after {
|
|
opacity: 1;
|
|
}
|
|
.toggle>input[type=checkbox]:checked+.toggle-body>.toggle-knob {
|
|
transform: translateX(1em);
|
|
}
|
|
.toggle>input[type=checkbox]:checked:not(:disabled)+.toggle-body>.toggle-track {
|
|
background-color: var(--accent-color-lighter);
|
|
}
|
|
.toggle>input[type=checkbox]:checked:not(:disabled)+.toggle-body>.toggle-knob {
|
|
background-color: var(--accent-color);
|
|
}
|
|
.toggle>input[type=checkbox]:focus:checked:not(:disabled)+.toggle-body>.toggle-knob::after,
|
|
.toggle:active>input[type=checkbox]:checked:not(:disabled)+.toggle-body>.toggle-knob::after {
|
|
background-color: var(--accent-color-transparent25);
|
|
}
|
|
.toggle>input[type=checkbox]:disabled+.toggle-body {
|
|
cursor: default;
|
|
}
|
|
.toggle>input[type=checkbox]:disabled+.toggle-body>.toggle-track {
|
|
background-color: var(--disabled-color-light);
|
|
}
|
|
.toggle>input[type=checkbox]:disabled+.toggle-body>.toggle-knob {
|
|
background-color: var(--disabled-color-lighter);
|
|
}
|
|
|
|
/* Content layout */
|
|
.content {
|
|
flex: 1 0 auto;
|
|
flex-flow: row nowrap;
|
|
width: 100%;
|
|
display: flex;
|
|
position: relative;
|
|
align-items: stretch;
|
|
justify-content: center;
|
|
}
|
|
.content-center {
|
|
flex: 1 1 auto;
|
|
width: var(--main-content-size);
|
|
padding: 0 var(--main-content-padding);
|
|
max-width: var(--main-content-size);
|
|
box-sizing: border-box;
|
|
}
|
|
|
|
/* Search bar */
|
|
.search-textbox-container {
|
|
display: flex;
|
|
flex-flow: row nowrap;
|
|
width: 100%;
|
|
align-items: stretch;
|
|
margin: 0;
|
|
padding: 0;
|
|
border: 0;
|
|
}
|
|
#search-textbox {
|
|
color: var(--text-color-default);
|
|
flex: 1 1 auto;
|
|
box-sizing: border-box;
|
|
padding: var(--textarea-padding);
|
|
font-family: 'Courier New', Courier, monospace;
|
|
background-color: var(--input-background-color);
|
|
border-radius: 0;
|
|
line-height: var(--textarea-line-height);
|
|
border: 0;
|
|
outline: none;
|
|
width: 100%;
|
|
height: calc(var(--textarea-line-height) + var(--textarea-padding) * 2);
|
|
min-height: calc(var(--textarea-line-height) + var(--textarea-padding) * 2);
|
|
max-height: calc(var(--textarea-line-height) * 10 + var(--textarea-padding) * 2);
|
|
resize: vertical;
|
|
font-size: var(--font-size-default);
|
|
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
|
|
color: var(--text-color-default);
|
|
white-space: pre-wrap;
|
|
}
|
|
#search-button {
|
|
flex: 0 0 auto;
|
|
position: relative;
|
|
width: 2.5em;
|
|
background-color: var(--input-background-color);
|
|
border: 0;
|
|
padding: 0;
|
|
margin: 0;
|
|
cursor: pointer;
|
|
outline: none;
|
|
transition: background-color var(--animation-duration) ease-in-out;
|
|
}
|
|
#search-button:hover,
|
|
#search-button:focus {
|
|
background-color: var(--input-background-color-dark);
|
|
}
|
|
#search-button:active {
|
|
background-color: var(--input-background-color-darker);
|
|
}
|
|
|
|
.icon-button-icon {
|
|
display: block;
|
|
position: absolute;
|
|
left: 0;
|
|
top: 0;
|
|
right: 0;
|
|
bottom: 0;
|
|
background-color: var(--button-icon-color);
|
|
mask-repeat: no-repeat;
|
|
mask-position: center center;
|
|
mask-mode: alpha;
|
|
-webkit-mask-repeat: no-repeat;
|
|
-webkit-mask-position: center center;
|
|
-webkit-mask-mode: alpha;
|
|
}
|
|
.icon-button-icon[data-icon=magnifying-glass] {
|
|
mask-image: url(/mixed/img/magnifying-glass.svg);
|
|
-webkit-mask-image: url(/mixed/img/magnifying-glass.svg);
|
|
mask-size: 16px 16px;
|
|
-webkit-mask-size: 16px 16px;
|
|
}
|
|
|
|
/* Search options */
|
|
.search-options {
|
|
display: flex;
|
|
flex-flow: row wrap;
|
|
margin: 0.5em -1em;
|
|
align-items: center;
|
|
}
|
|
.search-option {
|
|
flex: 0 1 auto;
|
|
margin: 0.5em 1em;
|
|
align-items: center;
|
|
cursor: pointer;
|
|
}
|
|
.search-option:not([hidden]) {
|
|
display: flex;
|
|
}
|
|
.search-option-label {
|
|
padding-left: 0.5em;
|
|
}
|
|
.search-option-pre-label {
|
|
padding-right: 0.5em;
|
|
}
|
|
#query-parser-mode-container {
|
|
flex: 1 1 auto;
|
|
}
|
|
#query-parser-mode-container:not([hidden]) {
|
|
display: flex;
|
|
}
|
|
#query-parser-mode-select {
|
|
flex: 1 1 auto;
|
|
max-width: 220px;
|
|
min-width: 100px;
|
|
}
|
|
|
|
/* Search styles */
|
|
#intro {
|
|
overflow: hidden;
|
|
}
|
|
#intro>p {
|
|
margin: 0;
|
|
}
|
|
|
|
#query-parser-content:not(:empty) {
|
|
border-bottom: var(--thin-border-size) solid var(--separator-color1);
|
|
padding-bottom: 0.5em;
|
|
}
|