openOutpaint/css/ui/generic.css

448 lines
7.3 KiB
CSS
Raw Normal View History

/* UI Floating Windows */
.floating-window {
position: fixed;
width: 250px;
height: auto;
z-index: 999;
}
.floating-window-title {
display: flex;
align-items: center;
justify-content: center;
cursor: move;
background-color: rgba(104, 104, 104, 0.75);
user-select: none;
padding: 5px;
padding-left: 10px;
margin-bottom: auto;
font-size: 1.5em;
color: black;
text-align: center;
border-top-left-radius: 10px;
border-top-right-radius: 10px;
border: solid;
border-bottom: none;
border-color: black;
}
.draggable {
cursor: move;
}
/* Slider Input */
div.slider-wrapper {
margin: 5px;
margin-left: 0;
margin-right: 0;
}
div.slider-wrapper {
position: relative;
height: 20px;
border-radius: 5px;
overflow-y: visible;
}
div.slider-wrapper * {
height: 20px;
border-radius: 5px;
margin: 0;
}
div.slider-wrapper > * {
position: absolute;
padding: inherit;
width: 100%;
left: 0;
right: 0;
top: 0;
bottom: 0;
overflow: hidden;
}
div.slider-wrapper > div.under {
display: flex;
background-color: var(--c-primary-accent);
}
div.slider-wrapper > div.under > div:first-child {
background-color: var(--c-primary);
border-top-right-radius: 0;
border-bottom-right-radius: 0;
}
div.slider-wrapper > div.under > div:last-child {
flex: 1;
border-top-left-radius: 0;
border-bottom-left-radius: 0;
}
div.slider-wrapper > div.under > * {
height: 100%;
}
div.slider-wrapper > div.over {
cursor: pointer;
}
div.slider-wrapper > input.text {
color: var(--c-text);
flex: 1;
appearance: textfield;
border: 0px;
height: 100%;
text-align: center;
background-color: transparent;
}
/* Checkbox Input */
div.checkbox-array {
display: flex;
margin-top: 5px;
margin-bottom: 5px;
}
input.oo-checkbox[type="checkbox"] {
/* Hide original checkbox */
-webkit-appearance: none;
appearance: none;
flex: 1;
margin: 0;
min-width: 28px;
height: 28px;
background-color: var(--c-primary);
cursor: pointer;
}
input.oo-checkbox[type="checkbox"]:disabled {
background-color: #666 !important;
cursor: default !important;
}
input.oo-checkbox[type="checkbox"]:disabled:hover {
filter: none !important;
}
input.oo-checkbox[type="checkbox"]:checked::after {
background-color: #66f;
}
input.oo-checkbox[type="checkbox"]:hover {
background-color: var(--c-hover);
}
input.oo-checkbox[type="checkbox"]:active {
filter: brightness(120%);
}
input.oo-checkbox[type="checkbox"]:first-child {
border-top-left-radius: 5px;
border-bottom-left-radius: 5px;
}
input.oo-checkbox[type="checkbox"]:last-child {
border-top-right-radius: 5px;
border-bottom-right-radius: 5px;
}
/* Mask Inversion Checkbox */
input.oo-checkbox[type="checkbox"].invert-mask-checkbox::after {
background-color: var(--c-text);
}
input.oo-checkbox[type="checkbox"].invert-mask-checkbox:hover {
filter: brightness(120%);
}
input.oo-checkbox[type="checkbox"].invert-mask-checkbox:active {
filter: brightness(140%);
}
input.oo-checkbox[type="checkbox"].invert-mask-checkbox {
background-color: #922;
}
input.oo-checkbox[type="checkbox"].invert-mask-checkbox:checked {
background-color: #229;
}
/* Bare Select */
.bareselector {
border-radius: 5px;
background-color: white;
overflow-y: auto;
margin-top: 0;
margin-left: 0;
max-height: 200px;
min-width: 100%;
max-width: 800px;
width: fit-content;
z-index: 200;
}
/* Autocomplete Select */
div.autocomplete {
border-radius: 5px;
}
div.autocomplete > .autocomplete-text {
box-sizing: border-box;
border-radius: 5px;
width: 100%;
}
div.autocomplete > .autocomplete-list {
position: absolute;
background-color: white;
overflow-y: auto;
margin-top: 0;
margin-left: 0;
max-height: 200px;
min-width: 100%;
max-width: 800px;
width: fit-content;
z-index: 200;
}
div.autocomplete > .autocomplete-list > .autocomplete-option {
position: relative;
cursor: pointer;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
padding: 3px;
}
div.autocomplete > .autocomplete-list > .autocomplete-option:hover {
background-color: #dddf;
}
div.autocomplete > .autocomplete-list > .autocomplete-option.selected::after {
content: "";
position: absolute;
right: 5px;
top: 0;
height: 100%;
aspect-ratio: 1;
background-color: darkgreen;
2022-12-18 17:50:40 -06:00
-webkit-mask-image: url("../../res/icons/check.svg");
-webkit-mask-size: contain;
2022-12-18 17:50:40 -06:00
mask-image: url("../../res/icons/check.svg");
mask-size: contain;
}
/* Select Input */
select > option:checked::after {
content: "";
position: absolute;
right: 5px;
top: 0;
height: 100%;
aspect-ratio: 1;
background-color: darkgreen;
2022-12-18 17:50:40 -06:00
-webkit-mask-image: url("../../res/icons/check.svg");
-webkit-mask-size: contain;
2022-12-18 17:50:40 -06:00
mask-image: url("../../res/icons/check.svg");
mask-size: contain;
}
/*************/
/* UI styles */
/*************/
/* The separator */
.ui.separator {
width: 80%;
margin: auto;
align-self: center;
border-top: 1px var(--c-hover) solid;
}
/* Icon button */
.ui.square {
aspect-ratio: 1;
}
.ui.button {
cursor: pointer;
padding: 0;
margin: 0;
border: 0;
color: var(--c-text);
background-color: var(--c-primary);
transition-duration: 50ms;
}
.ui.button:hover {
background-color: var(--c-hover);
}
.ui.button:active {
background-color: var(--c-hover);
filter: brightness(120%);
}
.ui.button.icon {
display: flex;
align-items: stretch;
}
.ui.button.icon > *:first-child {
flex: 1;
margin: 3px;
-webkit-mask-position: center;
mask-position: center;
-webkit-mask-size: contain;
mask-size: contain;
-webkit-mask-repeat: no-repeat;
mask-repeat: no-repeat;
background-color: var(--c-text);
}
/**
* Generic list
*/
.list {
height: 200px;
overflow-y: auto;
background-color: var(--c-primary);
border-top-left-radius: 5px;
border-top-right-radius: 5px;
}
.list > *:first-child {
border-top-left-radius: 5px;
border-top-right-radius: 5px;
}
.list .list-item {
display: flex;
align-items: center;
justify-content: space-between;
height: 25px;
padding-left: 5px;
padding-right: 5px;
cursor: pointer;
color: var(--c-text);
transition-duration: 50ms;
}
.list .list-item.active {
background-color: var(--c-active);
}
.list .list-item.active:hover,
.list .list-item:hover {
background-color: var(--c-hover);
}
.list .list-item.active:active,
.list .list-item:active {
background-color: var(--c-hover);
filter: brightness(120%);
}
.list .list-item > .title {
flex: 1;
text-overflow: ellipsis;
overflow: hidden;
white-space: nowrap;
background-color: transparent;
border: 0;
color: var(--c-text);
}
.list .list-item > .actions {
display: flex;
align-self: stretch;
}
.list .actions > button {
display: flex;
align-items: stretch;
padding: 0;
width: 25px;
aspect-ratio: 1;
background-color: transparent;
border: 0;
cursor: pointer;
}
.list .list-item > .actions > *:hover > * {
margin: 2px;
}
.list .actions > button > *:first-child {
flex: 1;
margin: 3px;
-webkit-mask-size: contain;
mask-size: contain;
background-color: var(--c-text);
}
/* Generic buttons */
.list .actions > .delete-btn > *:first-child {
2022-12-18 17:50:40 -06:00
-webkit-mask-image: url("../../res/icons/trash.svg");
mask-image: url("../../res/icons/trash.svg");
}
.list .actions > .rename-btn > *:first-child {
2022-12-18 17:50:40 -06:00
-webkit-mask-image: url("../../res/icons/edit.svg");
mask-image: url("../../res/icons/edit.svg");
}
.list .actions > .download-btn > *:first-child {
2022-12-18 17:50:40 -06:00
-webkit-mask-image: url("../../res/icons/download.svg");
mask-image: url("../../res/icons/download.svg");
}