/* * noVNC general input element CSS * Copyright (C) 2022 The noVNC Authors * noVNC is licensed under the MPL 2.0 (see LICENSE.txt) * This file is licensed under the 2-Clause BSD license (see LICENSE.txt). */ input, input::file-selector-button, button, select, textarea { /* Respect standard font settings */ font: inherit; /* Disable default rendering */ appearance: none; background: none; padding: 5px; border: 1px solid rgb(192, 192, 192); border-radius: 5px; color: black; background-image: linear-gradient(to top, rgb(255, 255, 255) 80%, rgb(240, 240, 240)); } input[type=button], input[type=color], input[type=image], input[type=reset], input[type=submit], input::file-selector-button, button, select { border-bottom-width: 2px; /* This avoids it jumping around when :active */ vertical-align: middle; padding-left: 20px; padding-right: 20px; } select { --select-arrow: url('data:image/svg+xml;utf8, \ \ \ '); background-image: var(--select-arrow), linear-gradient(to top, rgb(255, 255, 255), rgb(240, 240, 240)); background-position: calc(100% - 7px), left top; background-repeat: no-repeat; padding-right: calc(2*7px + 8px); padding-left: 7px; } select:active { /* Rotated arrow */ --select-arrow: url('data:image/svg+xml;utf8, \ \ \ '); } option { color: black; background: white; } input[type=checkbox] { position: relative; background-color: white; background-image: unset; border: 1px solid dimgrey; border-radius: 3px; width: 13px; height: 13px; margin-right: 6px; vertical-align: bottom; transition: 0.2s background-color linear; } input[type=checkbox]:checked { background-color: rgb(110, 132, 163); border-color: rgb(110, 132, 163); } input[type=checkbox]:checked::after { content: ""; position: absolute; top: 0; left: 3px; width: 3px; height: 7px; border: 1px solid white; border-width: 0 2px 2px 0; transform: rotate(40deg); } input[type=radio] { border-radius: 50%; border: 1px solid dimgrey; width: 12px; height: 12px; padding: 0; margin-right: 6px; transition: 0.2s border linear; } input[type=radio]:checked { border: 6px solid rgb(110, 132, 163); } input[type=range] { border: unset; border-radius: 3px; height: 20px; padding: 0; background: transparent; } /* -webkit-slider.. & -moz-range.. cant be in selector lists: https://bugs.chromium.org/p/chromium/issues/detail?id=1154623 */ input[type=range]::-webkit-slider-runnable-track { background-color: rgb(110, 132, 163); height: 6px; border-radius: 3px; } input[type=range]::-moz-range-track { background-color: rgb(110, 132, 163); height: 6px; border-radius: 3px; } input[type=range]::-webkit-slider-thumb { appearance: none; width: 18px; height: 20px; border-radius: 5px; background-color: white; border: 1px solid dimgray; margin-top: -7px; } input[type=range]::-moz-range-thumb { appearance: none; width: 18px; height: 20px; border-radius: 5px; background-color: white; border: 1px solid dimgray; margin-top: -7px; } input[type=file] { background-image: none; border: none; } input::file-selector-button { margin-right: 6px; } :root:not(.noVNC_touch) input[type=button]:hover, :root:not(.noVNC_touch) input[type=color]:hover, :root:not(.noVNC_touch) input[type=image]:hover, :root:not(.noVNC_touch) input[type=reset]:hover, :root:not(.noVNC_touch) input[type=submit]:hover, :root:not(.noVNC_touch) input::file-selector-button:hover, :root:not(.noVNC_touch) button:hover { background-image: linear-gradient(to top, rgb(255, 255, 255), rgb(250, 250, 250)); } :root:not(.noVNC_touch) select:hover { background-image: var(--select-arrow), linear-gradient(to top, rgb(255, 255, 255), rgb(250, 250, 250)); background-position: calc(100% - 7px), left top; background-repeat: no-repeat; } input[type=button]:active, input[type=color]:active, input[type=image]:active, input[type=reset]:active, input[type=submit]:active, input::file-selector-button:active, button:active, select:active { border-bottom-width: 1px; margin-top: 1px; } input:focus-visible, input:focus-visible::file-selector-button, button:focus-visible, select:focus-visible, textarea:focus-visible { outline: 2px solid rgb(74, 144, 217); outline-offset: 1px; } input[type=file]:focus-visible { outline: none; /* We outline the button instead of the entire element */ } input:disabled, input:disabled::file-selector-button, button:disabled, select:disabled, textarea:disabled { opacity: 0.4; } :root:not(.noVNC_touch) input[type=button]:disabled, :root:not(.noVNC_touch) input[type=color]:disabled, :root:not(.noVNC_touch) input[type=image]:disabled, :root:not(.noVNC_touch) input[type=reset]:disabled, :root:not(.noVNC_touch) input[type=submit]:disabled, :root:not(.noVNC_touch) input:disabled::file-selector-button, :root:not(.noVNC_touch) button:disabled, :root:not(.noVNC_touch) select:disabled { background-image: linear-gradient(to top, rgb(255, 255, 255), rgb(240, 240, 240)); } input[type=file]:disabled { background-image: none; } :root:not(.noVNC_touch) select:disabled { background-image: var(--select-arrow), linear-gradient(to top, rgb(255, 255, 255), rgb(240, 240, 240)); } input[type=image]:disabled { /* See Firefox bug: https://bugzilla.mozilla.org/show_bug.cgi?id=1798304 */ cursor: default; }