blockbench/css/general.css
JannisX11 46261d2a40 Fix style of search bar in menus
Change default align of long searchable menus
Prioritize menu over dialog when using confirm/cancel keys
2023-02-04 19:48:32 +01:00

747 lines
15 KiB
CSS

/*Defaults*/
div.tool.wide {
width: 72px;
padding: 1px 0;
}
.hidden, .tooltip_shift, .custom_select ul, .mobile_only, .m_disp {
display: none;
}
div.selection_only {
visibility: hidden;
}
a.open-in-browser {
cursor: pointer;
}
.f_left {
float: left;
}
.f_right {
float: right !important;
}
.i_b {
display: inline-block;
}
label.inline_label {
padding-left: 8px;
padding-right: 8px;
padding-top: 2px;
}
.progress_bar {
background-color: var(--color-back);
height: 20px;
margin-top: 12px;
}
.progress_bar_inner {
background-color: var(--color-accent);
height: 100%;
width: 0px;
}
.accent_color {
color: var(--color-accent);
font-weight: normal;
}
.slash {
color: var(--color-light);
padding-left: 3px;
padding-right: 3px;
font-weight: normal;
display: inline-block;
}
.code {
font-family: var(--font-code);
font-size: 16px;
}
.small_text {
font-size: 0.94em;
}
.subtle {
color: var(--color-subtle_text);
}
.color_x {
color: var(--color-axis-x);
}
.color_y {
color: var(--color-axis-y);
}
.color_z {
color: var(--color-axis-z);
}
.button {
display: inline-block;
width: 30px;
text-align: center;
cursor: default;
}
.dark_bordered {
height: 30px;
padding-left: 4px;
padding-top: 1px;
background-color: var(--color-back);
border: 1px solid var(--color-border);
}
.input_wide {
width: 100%;
padding: 8px;
height: 40px;
padding-bottom: 5px;
}
input.medium_width {
width: 64px;
}
.prism-editor-wrapper {
padding-left: 4px;
padding-top: 1px;
background-color: var(--color-back);
border: 1px solid var(--color-border);
}
.prism-editor__autocomplete {
background-color: var(--color-back);
border: 1px solid var(--color-accent);
z-index: 30;
}
.prism-editor__autocomplete li:hover {
color: var(--color-light);
}
.prism-editor__autocomplete li.selected {
background-color: var(--color-accent);
color: var(--color-accent_text);
}
.checkerboard, .checkerboard_trigger .checkerboard_target {
--color-checker_offset: rgba(0, 0, 0, 0.16);
background-color: var(--color-checkerboard) !important;
background-image: linear-gradient(45deg, var(--color-checkerboard) 25%, transparent 25%),
linear-gradient(-45deg, var(--color-checkerboard) 25%, transparent 25%),
linear-gradient(45deg, transparent 75%, var(--color-checkerboard) 75%),
linear-gradient(-45deg, var(--color-checker_offset) 75%, var(--color-checkerboard) 75%);
background-size: 30px 30px;
background-position: 0 0, 0 15px, 15px -15px, -15px 0px;
}
body[mode=start] div#center.checkerboard {
background-image: none;
background-color: var(--color-dark) !important;
}
/*UI Elements*/
div.preview {
height: 100%;
width: 100%;
position: relative;
cursor: inherit;
}
.preview > canvas {
background-repeat: no-repeat;
}
.preview .preview_menu {
position: absolute;
right: -1px;
top: 0;
background-color: var(--color-dark);
display: flex;
}
.checkerboard .preview_menu {
background-color: var(--color-checkerboard);
}
.preview .preview_menu .tool {
width: 32px;
}
.preview .preview_menu .preview_main_menu > i {
width: 20px;
}
.preview .preview_background_menu {
background-size: cover;
width: 30px;
}
.text_padding {
margin-left: 5px;
margin-right: 5px;
}
.toolbar_label {
padding: 2px;
margin-left: 4px;
}
.bar {
height: 30px;
}
.bar > * {
float: left;
}
.bar.flex {
display: flex;
}
.bar.flex > * {
float: none;
}
.bar.flex > label {
flex-grow: 0;
}
.scroll_horizontal {
overflow-x: scroll;
overflow-y: hidden;
height: 100%;
scrollbar-width: none;
}
.scroll_horizontal ::-webkit-scrollbar {
height: 0px;
}
.list {
background-color: var(--color-back);
width: 100%;
overflow-y: scroll;
flex-grow: 1;
}
.list::-webkit-scrollbar-track {
background: var(--color-back);
}
ul.list_style li {
list-style: initial;
margin-left: 20px;
}
#quick_message_box {
position: absolute;
margin-left: auto;
margin-right: auto;
left: 0;
right: 0;
top: 420px;
z-index: 100;
min-width: 150px;
max-width: 250px;
width: fit-content;
padding: 0 12px;
background-color: var(--color-bright_ui);
color: var(--color-bright_ui_text);
box-shadow: 0 0 2px rgba(0, 0, 0, 0.5);;
text-align: center;
overflow-wrap: break-word;
cursor: default;
pointer-events: none;
}
@media (max-device-width: 640px) {
#quick_message_box {
bottom: 26px;
top: unset;
padding: 6px;
}
}
.uv_message_box {
position: absolute;
margin-left: auto;
margin-right: auto;
z-index: 101;
min-width: 100px;
max-width: 200px;
background-color: var(--color-bright_ui);
color: var(--color-bright_ui_text);
box-shadow: 0 0 2px rgba(0, 0, 0, 0.5);;
text-align: center;
cursor: default;
top: 40px;
right: 0px;
left: 0px;
pointer-events: none;
}
.selection_rectangle {
position: absolute;
display: block;
border: 1px solid var(--color-accent);
background-color: rgba(40,50,60,0.5);
pointer-events: none;
}
.annotation {
min-width: 40px;
max-width: 100%;
width: max-content;
position: absolute;
text-align: center;
background-color: var(--color-bright_ui);
color: var(--color-bright_ui_text);
padding: 3px 8px;
pointer-events: none;
}
.annotation.transparent {
background: transparent;
font-weight: normal;
font-size: 1.2em;
padding: 0;
margin: -4px;
min-width: 15px;
color: var(--color-light);
text-shadow: 0 0 5px black;
}
.light_on_hover:hover {
color: var(--color-light);
}
.spinning {
-webkit-animation: spin 2s linear infinite;
-moz-animation: spin 2s linear infinite;
animation: spin 2s linear infinite;
}
@-moz-keyframes spin { 100% { -moz-transform: rotate(360deg); } }
@-webkit-keyframes spin { 100% { -webkit-transform: rotate(360deg); } }
@keyframes spin { 100% { -webkit-transform: rotate(360deg); transform:rotate(360deg); } }
/*Markdown*/
.markdown li {
list-style: initial;
cursor: inherit;
}
.markdown ul {
padding-left: 24px;
}
.markdown ol {
padding-left: 24px;
}
.markdown ol li {
list-style: auto;
}
.markdown a {
cursor: pointer;
}
/*Actions*/
.toolbar {
width: 100%;
overflow: hidden;
flex-shrink: 0;
}
.toolbar > .content {
display: flex;
flex-wrap: wrap;
}
div.toolbar_wrapper {
float: none;
}
.toolbar.narrow, .toolbar_wrapper.narrow > .toolbar {
width: fit-content;
display: flex;
flex-flow: row-reverse;
height: 100%;
}
.toolbar.narrow, .toolbar_wrapper.narrow > .toolbar > .content {
height: 100%;
overflow-x: hidden;
overflow-y: auto;
flex-grow: 1;
}
.toolbar_wrapper > .toolbar.vertical {
width: 40px;
flex-direction: column-reverse;
}
.toolbar_wrapper > .toolbar.vertical .tool {
height: 36px;
width: 40px;
padding: 2px;
}
.toolbar > .tool.toolbar_menu {
float: right;
width: 12px;
color: var(--color-subtle_text);
}
.toolbar.vertical .toolbar_menu {
height: 24px;
padding: 0;
}
.toolbar > .tool.toolbar_menu > i {
width: 16px;
margin-left: -5px;
font-size: 20px;
}
.toolbar.vertical > .tool.toolbar_menu > i {
width: auto;
margin-right: auto;
margin-left: auto;
}
.tool {
height: 30px;
width: 36px;
margin-left: 1px;
margin-right: 1px;
background: transparent;
display: inline-block;
text-align: center;
vertical-align: middle;
cursor: default;
float: left;
color: var(--color-text);
}
.tool i {
display: block;
margin: 4px auto;
}
.tool:active .icon {
padding-top: 1px;
}
.tool:active .icon.fa_big {
padding-top: 2px;
}
img.icon {
height: 26px;
image-rendering: pixelated;
}
.tool.enabled {
border-bottom: 3px solid var(--color-accent);
}
.tool.widget {
width: auto;
padding: 0;
}
.tool.widget.bar_text {
padding: 3px;
}
.tool.has_label {
width: auto;
}
.tool:hover {
color: var(--color-light);
}
.tool.right_tool {
position: relative;
}
.placeholder {
width: 20px;
height: 10px;
float: left;
}
.toolbar .toolbar_separator.border {
width: 2px;
height: 24px;
float: left;
background-color: var(--color-border);
margin: 4px;
margin-bottom: 0;
}
.toolbar .toolbar_separator.spacer {
background: transparent;
flex-grow: 1;
}
.toolbar .toolbar_separator.linebreak {
display: block;
float: left;
width: 100%;
height: 0;
margin: 0;
}
.text_button:hover {
color: var(--color-light);
}
.bar_select_wrapper {
position: relative;
}
.bar_select:hover {
color: var(--color-light);
}
.bar_select select {
padding-right: 24px;
width: 100%;
}
.bar_select .bar_select_wrapper::before {
content: "\f0d7";
font-family: 'Font Awesome 6 Free';
font-weight: 900;
display: block;
position: absolute;
height: 12px;
width: 16px;
pointer-events: none;
right: 6px;
top: 3px;
}
.half {
display: inline-block;
width: calc(50% - 4px);
}
.tooltip {
position: absolute;
height: 28px;
width: fit-content;
padding-left: 5px;
padding-right: 5px;
padding-top: 2px;
background: var(--color-bright_ui);
color: var(--color-bright_ui_text);
margin-top: 30px;
white-space: nowrap;
z-index: 20;
box-shadow: 0 0.4px 3.5px rgba(0, 0, 0, 0.6);
pointer-events: none;
visibility: hidden;
}
.tool:hover > .tooltip {
visibility: visible;
}
.tooltip_shift {
display: none;
}
.tooltip_description {
position: absolute;
background-color: var(--color-ui);
color: var(--color-text);
border: 1px solid var(--color-bright_ui);
padding: 2px 6px;
margin-top: 1px;
font-size: 0.84em;
margin-left: -5px;
opacity: 0;
}
.tool:hover > .tooltip .tooltip_description {
transition-property: opacity;
transition-duration: 200ms;
transition-delay: 600ms;
opacity: 1;
}
.tool.bar_select.icon_mode {
padding: 0 4px;
background-color: var(--color-button);
}
.tool.bar_select .select_option {
float: left;
width: 28px;
height: 100%;
color: var(--color-text);
}
.tool.bar_select .select_option:hover {
color: var(--color-light);
}
.tool.bar_select .select_option.selected {
background: var(--color-accent);
color: var(--color-accent_text);
}
.tool.bar_select .select_option .icon {
transform: scale(0.86);
}
.tool.bar_select .select_option[key=vertex] .icon {
transform: scale(0.6);
}
.tool.side_menu_tool {
width: 48px;
}
.tool.side_menu_tool i.icon {
display: block;
margin-left: 6px;
float: left;
}
.tool.side_menu_tool i.icon.action_more_options {
display: inline-block;
width: 19px;
color: var(--color-text);
margin-left: 0;
}
.tool.side_menu_tool i.icon.action_more_options:hover {
color: inherit;
}
.toolbar.vertical .tool.side_menu_tool {
height: 54px;
}
.toolbar.vertical .tool.side_menu_tool > .action_more_options {
max-width: 48px;
text-align: center;
width: 100%;
margin-top: 0px;
}
/*(Context-)Menu*/
.contextMenu {
position: absolute;
display: block;
height: auto;
width: fit-content;
min-width: 110px;
background-color: var(--color-bright_ui);
color: var(--color-bright_ui_text);
z-index: 30;
box-shadow: 0.4px 0.4px 4px rgba(0, 0, 0, 0.7);
cursor: default;
white-space: nowrap;
}
.contextMenu.sub {
display: none;
margin-top: -4px;
}
.contextMenu li {
display: flex;
height: 30px;
padding: 4px;
padding-left: 34px;
padding-right: 8px;
}
.contextMenu li.parent {
padding-right: 20px;
}
.contextMenu li.parent::after {
content: "\f105";
display: block;
font-family: 'Font Awesome 6 Free';
font-weight: 900;
font-size: inherit;
text-rendering: auto;
-webkit-font-smoothing: antialiased;
margin-right: -12px;
margin-left: 6px;
margin-top: -1px;
pointer-events: none;
}
.contextMenu li.enabled {
padding-left: 29px;
border-left: 5px solid var(--color-accent);
}
.contextMenu li.focused,
.contextMenu li.parent.opened {
background-color: var(--color-accent);
color: var(--color-accent_text);
}
.contextMenu li.hybrid_parent.opened {
background-color: transparent;
}
.contextMenu li > i {
margin-top: 1px;
margin-right: 4px;
margin-left: -28px;
pointer-events: none;
}
.contextMenu li > img {
cursor: default;
height: 20px;
width: 20px;
color: var(--color-text);
white-space: nowrap;
margin-bottom: -3px;
margin-left: -27px;
margin-right: 5px;
margin-top: 1px;
}
.contextMenu li > span {
pointer-events: none;
flex: 1 0 auto;
}
.contextMenu li.parent.focused > .contextMenu.sub {
display: block;
}
.contextMenu li.hybrid_parent.opened > .contextMenu.sub {
display: block;
}
.contextMenu li.opened > .contextMenu.sub {
display: block;
}
.contextMenu .menu_more_button {
width: 28px;
margin: -4px -8px -4px 2px;
padding: 4px 0;
text-align: center;
}
.contextMenu .menu_more_button:hover,
.hybrid_parent.opened .menu_more_button {
background-color: var(--color-accent);
color: var(--color-accent_text);
}
li.menu_separator {
height: 2px;
width: 100%;
padding: 0;
background-color: var(--color-menu_separator);
}
.contextMenu li.highlighted {
animation: menu_item_highlight 1s infinite ease-in-out;
}
@keyframes menu_item_highlight {
0% {
background-color: transparent;
}
50% {
background-color: var(--color-accent);
}
100% {
background-color: transparent;
}
}
.contextMenu .menu_search_bar {
padding: 0;
display: flex;
}
.menu_search_bar > input {
color: inherit;
padding: 6px;
flex-grow: 1;
height: auto;
}
.menu_search_bar > div {
width: 30px;
text-align: center;
padding-top: 2px;
}
.menu_search_bar > div > * {
pointer-events: none;
vertical-align: middle;
}
.keybinding_label {
pointer-events: none;
font-size: 0.84em;
padding: 2px 0 2px 8px;
opacity: 0.6;
flex-grow: 0;
flex-shrink: 0;
}
/* Theme Borders */
body.theme_borders .contextMenu,
body.theme_borders dialog,
body.theme_borders .dialog_close_button,
body.theme_borders #start_screen > content,
body.theme_borders #quick_message_box,
body.theme_borders action_selector > #action_selector_list
{
border: 1px solid var(--color-border);
}
body.theme_borders #start_screen section {
border-bottom: 1px solid var(--color-border);
}
body.theme_borders .panel {
margin-top: -1px;
border-top: 01px solid var(--color-border);
}
body.theme_borders #right_bar {
border-left: 1px solid var(--color-border);
}
body.theme_borders #left_bar {
border-right: 1px solid var(--color-border);
}
body.theme_borders .preview .preview_menu {
right: 0;
}
body.theme_borders .dialog_sidebar {
border-right: 1px solid var(--color-border);
}
body.theme_borders .dialog_handle {
border-bottom: 1px solid var(--color-border);
}
body.theme_borders .dialog_close_button {
right: -1px;
top: -1px;
height: 31px;
}
body.theme_borders li.animation_file {
border-top: 1px solid var(--color-border);
}
body.theme_borders #main_toolbar, body.theme_borders #tab_bar {
border-bottom: 1px solid var(--color-border);
}
body.theme_borders #status_bar {
border-top: 1px solid var(--color-border);
}
body.theme_borders .contextMenu li.menu_separator {
background-color: var(--color-border);
height: 1px;
padding: 0;
opacity: 1;
}
body.theme_borders #animation_controllers_wrapper .controller_state {
border-color: var(--color-border);
}