blob: 90104effe3e785ce09cf902d6c6ee5ae1ade0854 [file] [log] [blame]
/* Copyright 2018 The Chromium Authors. All rights reserved. */
/* Use of this source code is governed by a BSD-style license that can be */
/* found in the LICENSE file. */
/* All color values that need to be customized depending on whether a light */
/* or dark theme is used must be specified with CSS variables. */
/* TODO(jacobr): the current list of variables is a bit redundant and should */
/* be refactored to eliminate cases where very similar colors are used with */
/* no clear reason to diverge. */
/* If you add a CSS variable here, be sure to also add it to styles_dart.css */
:root {
--border-color: #eee;
--button-selected-color: #eaeff4;
--chart-bar-color: #4078c0;
--counter-color: #666;
--link-color: #2188ff;
--dark-shadow-color: #666;
--default-background-rgb: 255, 255, 255;
--default-background: rgba(var(--default-background-rgb), 1);
--default-button-text-color: #24292e;
--default-color-thumb: #888;
--default-color: #000;
--disabled-background: #ddd;
--error-background: #f97c7c;
--error-summary-color: #F44336;
--inspector-info-color: #24292e;
--even-row-background: #f7f7f7;
--footer-color: #7a7a7a;
--footer-link-hover: #0366d6;
--footer-strong: #333;
--form-select-background: #f9fbfc;
--header-background: #f3f3f3;
--header-color: #586069;
--header-item-rgb: 255, 255, 255;
--header-item: rgba(var(--header-item-rgb), 1);
--hint-background: #fffbdd;
--inspector-hint-color: #000;
--light-background: #ccc;
--light-text-color: #f5f5dc;
--list-background: #fff;
--match-color: #fff;
--masthead-background: #4078c0;
--menu-item-border: #e1e4e8;
--popup-border-color: #d1d5da;
--row-hover-background: #f2f4fa;
--selected-background: #4078c0;
--selected-border: #a2a2a2;
--selected-line: #c4daf7;
--shadow-color: #ddd;
--shaded-background-lighter: #fdfdfd;
--shaded-background-darker: #f6f6f6;
--subtle: #777;
--subtle-selected: var(--light-background);
--table-border: #dfe2e5;
--title: #555;
--toast-background: #f9f9f9;
--toast-border: #d8dee2;
}
/*
* Variables used in media queries (not themes) to handle different screen
* sizes better
*/
:root {
--page-outer-padding: 30px;
}
@media all and (max-width: 600px) {
:root {
--page-outer-padding: 20px;
}
}
.lead, .page-title + .markdown-body > p:first-child {
margin-bottom: 30px;
font-size: 20px;
font-weight: normal;
color: var(--title);
}
body {
overflow: hidden;
font-size: 14px;
background-color: var(--default-background);
}
.container {
width: initial;
margin-right: var(--page-outer-padding);
margin-left: var(--page-outer-padding);
}
.masthead {
padding: 16px var(--page-outer-padding);
margin-bottom: 20px;
text-align: center;
background-color: var(--masthead-background);
}
.masthead .masthead-logo {
display: inline-block;
font-size: 1.5rem;
color: var(--header-item);
float: left;
}
.masthead-nav {
margin-top: .5rem;
white-space: nowrap;
display: inline-flex;
}
.masthead-nav a:not(:last-child) {
margin-right: 15px;
}
.masthead .mega-octicon {
font-size: 1.5rem;
}
@media all and (max-width: 550px) {
/* At 550px we hide "Dart DevTools" from the title, so we can reduce spacing
* around the icons */
.masthead {
padding: 8px var(--page-outer-padding);
}
.masthead-nav {
margin-top: 0;
}
}
.small-octicon {
font-size: 13px;
}
#icon-nav a {
padding-bottom: 5px;
padding-left: 3px;
color: var(--header-item) !important;
}
.masthead a,
.masthead .masthead-item {
color: rgba(var(--header-item-rgb), 0.5) !important;
font-size: 1rem;
text-decoration: none;
}
.masthead a.disabled {
cursor: default;
opacity: 0.5;
}
.masthead a:hover:not([disabled]) {
color: var(--header-item) !important;
}
.masthead-nav .active {
color: var(--header-item) !important;
}
h2 {
font-size: 18px;
font-weight: bold;
border-bottom: 1px solid var(--border-color);
margin-bottom: 8px;
padding-bottom: 0;
}
td.left,
th.left {
text-align: left;
}
td.right,
th.right {
text-align: right;
}
.pre {
white-space: pre;
}
.pre-wrap {
white-space: pre-wrap;
}
.monospace {
font-family: monospace;
}
span.label {
background-color: #616161;
}
span.label.stderr {
background-color: #F44336;
}
span.label.stdout {
background-color: #78909C;
}
span.label.flutter {
background-color: #0091ea;
}
span.label.gc {
background-color: #424242;
}
.sticky-top {
position: sticky;
top: 0;
}
.table-virtual {
position: relative;
overflow-anchor: none;
}
.table-virtual td {
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
cursor: pointer;
}
.table-virtual.overflow-y td {
max-width: 500px; /* required for text-overflow to work? */
}
table thead {
background-color: var(--header-background);
border-bottom: 1px solid var(--table-border);
}
table tbody {
vertical-align: top;
}
tbody.selectable tr {
cursor: default;
}
table th {
font-weight: bold;
color: var(--header-color);
background-color: var(--header-background);
white-space: nowrap;
}
table th.wide {
width: 80%;
}
.allocation {
float: right;
}
.allocation-abstract {
text-decoration: line-through;
color: var(--dark-shadow-color);
}
.li-allocation-abstract {
font-style: italic;
}
.alloc-image {
background-image: url('icons/memory/alloc_icon.png');
width: 11px;
height: 12px;
margin-top: 5px;
margin-bottom: 4px;
}
.allocation:hover {
background-color: var(--selected-background);
cursor: pointer;
}
.allocation-hover {
background-color: var(--selected-background);
cursor: pointer;
float: right;
}
.allocation-hover-card {
display: none;
height: 25%;
position: absolute;
background-color: var(--default-background);
color: var(--title);
border: 4px solid var(--popup-border-color);
overflow-y: scroll;
width: 30em;
z-index: 101; /* Keep hover top-most. */
}
.allocation-hover-card ul {
list-style-type: square;
list-style-position: outside;
list-style-image: none;
}
.allocation-hover-card ul li {
padding: 5px;
}
.allocation-li-title {
background-color: var(--header-background);
color: var(--header-color);
}
.allocation-li {
background-color: var(--default-background);
color: var(--default-color)
}
.allocation-li:hover {
background-color: var(--row-hover-background);
cursor: default;
}
.allocated-by-class-title {
float: left;
font-weight: bold;
}
.ref-by-title {
float: right;
font-weight: bold;
}
.allocated-by-class { float: left; }
.ref-by { float: right; }
.memory-buttons {
text-align: right;
}
.history-navigation {
display: block;
}
.history-separator {
color: gray;
padding-left: 1em;
padding-right: .5em;
}
.history-link {
text-decoration: underline;
color: var(--link-color);
cursor: pointer;
}
.history-link-last {
text-decoration: underline;
color: var(--link-color);
font-weight: bold;
cursor: pointer;
}
table td,
table th {
padding: 4px 8px;
/*border: 1px solid var(--table-border);*/
}
tr th.right span.sortable:before {
content: "â–¼ ";
visibility: hidden;
}
tr th.left span.sortable:after {
content: " â–¼";
visibility: hidden;
}
tr th.right span.sortable.down:before {
content: "â–¼ ";
visibility: visible;
}
tr th.right span.sortable.up:before {
content: "â–² ";
visibility: visible;
}
tr th.left span.sortable.down:after {
content: " â–¼";
visibility: visible;
}
tr th.left span.sortable.up:after {
content: " â–²";
visibility: visible;
}
table tr:nth-child(2n) {
background-color: var(--even-row-background);
}
table tr:hover {
background-color: var(--row-hover-background);
}
table tr.selected {
color: var(--light-text-color);
background-color: var(--selected-background);
}
.table-border {
border: 1px solid var(--table-border);
border-radius: 3px;
}
.gutter {
background-color: var(--default-background);
background-repeat: no-repeat;
background-position: 50%;
margin-left: 0;
margin-right: 0;
flex-shrink: 0;
}
.gutter.gutter-horizontal {
background-image: url('');
cursor: col-resize;
height: 100%;
}
.gutter.gutter-vertical {
background-image: url('');
cursor: row-resize;
width: 100%;
}
.flutter-icon {
box-sizing: content-box;
margin: 2px 3px 2px 2px;
background-size: contain;
background-repeat: no-repeat;
background-position: center;
display: inline-block;
vertical-align: text-bottom;
}
input:disabled+label {
opacity: 0.5;
}
.frame-bar {
background: var(--chart-bar-color);
height: 12px;
display: inline-block;
border-radius: 1px;
}
tr.selected .frame-bar {
background: var(--default-background);
}
.frame-bar.over-budget {
background: var(--error-background);
}
form[horizontal] {
align-items: baseline;
}
.nowrap {
white-space: nowrap;
}
.scroll-table {
max-height: 190px;
overflow-x: auto;
}
.overflow-auto {
overflow: auto;
}
.overflow-y {
overflow-y: auto;
overflow-x: hidden;
}
.full-width {
width: 100%;
}
.full-size {
width: 100%;
height: 100%;
}
.footer {
padding: 10px var(--page-outer-padding);
margin-top: 20px;
color: var(--footer-color);
border-top: 1px solid var(--border-color);
}
.footer a {
color: var(--footer-color);
}
.footer a:hover {
color: var(--footer-link-hover);
text-decoration: none;
}
.footer .separator {
margin-left: 20px;
margin-right: 20px;
}
[text-center] {
text-align: center;
}
[horiz-padding] {
padding-left: 15px;
padding-right: 15px;
}
.footer-status {
display: inline-block;
min-width: 100px;
}
.interactable {
cursor: pointer;
user-select: none;
}
.footer strong {
color: var(--footer-strong);
}
.section + .section {
margin-top: 10px;
}
form + form {
margin-top: 10px;
}
.section .title {
padding-top: 0.3em;
margin-bottom: 0.2em;
font-size: 1.2em;
font-weight: bold;
border-bottom: 1px solid var(--border-color);
}
.fill-section {
position: absolute;
top: 0;
left: 0;
height: 100%;
width: 100%;
}
.form-checkbox {
user-select: none;
}
.margin-left {
margin-left: 8px;
}
.margin-right {
margin-right: 20px;
}
span.function-kind {
background: #888;
color: #fff;
border-radius: 2px;
padding: 0 2px 1px 2px;
}
span.function-kind.Stub {
background: #888;
}
span.function-kind.Native {
background-color: #d73a3a;
}
span.function-kind.Tag {
background-color: cornflowerblue;
}
.flash {
margin-bottom: 20px;
}
a[disabled] {
cursor: default;
}
.masthead a[disabled]:hover {
color: var(--default-background);
opacity: 0.5;
}
.progress-element {
width: 200px;
height: 16px;
background: var(--light-background);
border-radius: 1px;
position: relative;
display: inline-block;
}
.progress-element .complete {
background: var(--selected-background);
display: inline-block;
position: absolute;
top: 0;
left: 0;
bottom: 0;
}
form.align-items-center,
footer.align-items-center {
align-items: center;
}
div.tabnav {
margin-bottom: 0;
}
.search-text {
visibility: hidden;
vertical-align: top;
height: 2.1em;
background-color: var(--default-background);
color: var(--default-color);
width: 20em; /* Matches width of popup-view, see below. */
}
.popup-view {
z-index: 100;
position: absolute;
height: calc(30%);
color: var(--header-color);
background-color: var(--list-background);
list-style: none;
border: 1px solid var(--popup-border-color);
padding-left: 4px;
margin-bottom: 2px;
cursor: pointer;
overflow-y: scroll;
display: none;
width: 20em; /* Matches width of search-text class, see above. */
}
.popup-items-list {
cursor: pointer;
}
.popup-list-item {
white-space: nowrap;
list-style-type: none;
}
.memory-table {
/* Just width doesn't work? */
max-width: 500px;
min-width: 500px;
}
.memory-table table:focus {
outline: none;
}
.memory-inspector {
padding: 3px;
box-sizing: border-box;
font-weight: bold;
color: var(--header-color);
background-color: var(--header-background);
white-space: nowrap;
font-size: 14px;
border: 1px solid var(--table-border);
border-radius: 3px;
}
.memory-inspector-items-list {
background-color: var(--shaded-background-lighter);
}
.memory-instance-data-list-item {
background-color: var(--shaded-background-lighter);
color: var(--default-color);
padding-top: 6px;
padding-left: 6px;
white-space: nowrap;
}
.memory-instance-data-list-item .subtle {
color: var(--header-color);
}
.settings-box {
border-bottom-style: solid;
border-bottom-width: 2px;
border-bottom-color: var(--border-color);
}
.settings-title {
margin-bottom: 10px;
padding: 5px 5px;
}
.settings-area {
padding-left: 5px;
padding-bottom: 10px;
}
.settings-left {
margin-left: 2em;
}
.settings-libraries {
overflow-y: auto;
overflow-x: hidden;
height: 100px;
width: 300px;
border-style: solid;
border-width: 2px;
border-color: var(--border-color);
}
.settings-libraries-checkbox {
vertical-align: text-bottom;
margin: 3px 8px 5px 8px;
}
.settings-libraries-label {
vertical-align: text-bottom;
margin-top: 2px;
font-weight: normal;
}
.filter-pattern-area {
margin-bottom: 1em;
}
.filter-class {
vertical-align: middle;
height: 2.1em;
background-color: var(--default-background);
color: var(--default-color);
width: 20em; /* Matches width of popup-view, see below. */
}
.setttings-options {
margin-left: 2em;
font-size: 10pt;
}
.setttings-options-2 {
border-left: solid lightgray 1px;
padding-left: 2em;
margin-left: 2em;
font-size: 10pt;
}
.settings-checkbox-option {
vertical-align: text-bottom;
}
.settings-checkbox-label-option {
margin-left: .5em;
font-weight: normal;
}
.settings-buttons {
margin-top: auto;
}
div.tabnav-tab {
cursor: pointer;
}
[hidden] {
visibility: hidden;
}
.btn-group .btn:first-child:not(:last-child) {
border-top-right-radius: 0;
border-bottom-right-radius: 0;
border-right-width: 0;
}
.btn-group .btn:not(:first-child):not(:last-child) {
border-radius: 0;
}
.btn-group .btn+.btn {
margin-left: -1px;
}
.btn-group .btn:last-child:not(:first-child) {
border-top-left-radius: 0;
border-bottom-left-radius: 0;
}
.form-select {
cursor: pointer;
}
.form-select.button-bar-dropdown {
background-color: var(--button-background);
color: var(--default-button-text-color);
display: inline-flex;
align-items: center;
height: 30px;
}
.form-select[disabled], .form-select[disabled]:hover {
color: rgba(36,41,46,0.4);
background-color: #eff3f6;
cursor: default;
}
.form-select:hover {
background-color: var(--button-selected-color);
}
input[type='checkbox'] {
cursor: pointer;
}
/* To truly center an object in its parent, give the object a negative top margin of half its height.
* See [centered-single-line-message] as an example (where the height of the single line is ~20px). */
.center-in-parent, .centered-single-line-message {
width: 100%;
text-align: center;
position: absolute;
top: 50%;
left: 0;
}
.centered-single-line-message {
margin-top: -10px;
}
.spinner.centered {
position: absolute;
margin-top: -16px;
margin-left: -16px;
top: 50%;
left: 50%;
}
.spinner {
display: inline-block;
width: 32px;
height: 32px;
}
.spinner:after {
content: " ";
display: block;
width: 23px;
height: 23px;
margin: 1px;
border-radius: 50%;
border: 3px solid var(--selected-background);
border-color: var(--selected-background) transparent var(--selected-background) transparent;
animation: spin 1.2s linear infinite;
}
@keyframes spin {
0% {
transform: rotate(0deg);
}
100% {
transform: rotate(360deg);
}
}
nav.menu {
margin-bottom: 0;
}
.counter {
display: inline-block;
padding: 2px 5px;
font-size: 11px;
font-weight: bold;
color: var(--counter-color);
background-color: var(--border-color);
border-radius: 10px;
}
.menu-item .counter {
float: right;
margin-left: 5px;
}
nav.menu .menu-item {
user-select: none;
cursor: pointer;
}
nav.menu li {
cursor: pointer;
padding: 4px 10px;
}
.menu-item-bottom-border {
border-bottom: 1px solid var(--menu-item-border);
}
.list-item {
white-space: nowrap;
}
.strong-match {
color: var(--default-color);
}
.list-item.subtle {
color: var(--subtle);
}
.list-item .subtle {
font-size: 90%;
color: var(--subtle);
}
.list-item.selected {
color: var(--light-text-color);
background-color: var(--selected-background);
}
.list-item.selected .subtle {
color: var(--subtle-selected);
}
.list-item.selected .strong-match {
color: var(--match-color);
}
.tree-list {
padding-left: 25px;
list-style: none;
}
tr.selected .tree-toggle {
color: var(--header-background);
}
.tree-toggle {
width: 14px;
font-size: 14px;
display: inline-block;
padding-bottom: 1px;
color: var(--subtle);
user-select: none;
align-self: center;
}
.tree-toggle.octicon-triangle-right {
padding-left: 2px;
}
/* We have to do something with the scrollbars as they flicker due to DOM
manipulation in our table and ViewportCanvas code.
Currently we overwrite the default to keep the scrollbars always visible
but a more subtle solution would be better. */
.custom-scrollbar ::-webkit-scrollbar {
-webkit-appearance: none;
width: 9px;
height: 9px;
}
.custom-scrollbar ::-webkit-scrollbar-thumb {
border-radius: 4px;
background-color: var(--default-color-thumb);
box-shadow: 0 0 1px var(--default-background);
opacity: 0.5;
}
::-webkit-scrollbar-corner {
background: var(--default-background);
}
/* Make sure content inside buttons is vertically centered. */
.btn {
display: inline-flex;
align-items: center;
height: 30px; /* Force height to 22px even when there's no text (2x3px padding + 2x1px margin) */
}
/* Increase line height so standard sized icons look ok in buttons. */
.btn-sm {
line-height: 22px;
}
.btn-outline:hover .flutter-icon {
filter: brightness(0) invert(1);
}
.toast {
border: 1px solid var(--toast-border);
border-radius: 3px;
background: var(--toast-background);
padding: 10px;
box-shadow: 1px 1px 2px 0px var(--shadow-color);
transition-property: left;
transition-duration: 0.5s;
position: relative;
left: 400px;
}
.toast + .toast {
margin-top: 10px;
}
#toast-container {
width: 360px;
position: fixed;
right: 30px;
bottom: 30px;
z-index: 10;
}
@font-face {
font-family: 'Material Icons';
font-style: normal;
font-weight: normal;
src: local('Material Icons'),
local('MaterialIcons-Regular'),
url(packages/devtools/src/ui/MaterialIcons-Regular.woff2) format('woff2');
}
.material-icons {
font-family: 'Material Icons';
font-weight: normal;
font-style: normal;
font-size: 24px; /* Preferred icon size */
display: inline-block;
line-height: 1;
text-transform: none;
letter-spacing: normal;
word-wrap: normal;
white-space: nowrap;
direction: ltr;
/* Support for all WebKit browsers. */
-webkit-font-smoothing: antialiased;
/* Support for Safari and Chrome. */
text-rendering: optimizeLegibility;
/* Support for Firefox. */
-moz-osx-font-smoothing: grayscale;
/* Support for IE. */
font-feature-settings: 'liga';
}
html [full] {
height: 100%;
overflow: hidden;
}
.flash div {
margin-left: auto;
margin-right: auto;
}
.flash-close {
line-height: 1.5;
}
#messages-container div+div {
margin-top: 1em;
}
.action-button {
border-radius: 50%;
height: 28px;
width: 28px;
color: white;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
}
.action-button:hover {
box-shadow: 0 2px 2px 0 var(--dark-shadow-color);
background-color: rgba(var(--default-background-rgb), 0.1);
}
.action-button:active {
box-shadow: 0 2px 2px 0 var(--dark-shadow-color);
background-color: rgba(var(--default-background-rgb), 0.3);
}
.action-button[disabled] {
box-shadow: none;
background-color: rgba(var(--default-background-rgb), 0);
opacity: 0.5;
}
.action-button .flutter-icon {
margin: 2px;
}
.btn[disabled] .flutter-icon {
opacity: 0.5;
}
.action-button+.action-button {
margin-left: 8px;
}
#ga-dialog {
background-color: var(--default-background);
color: var(--default-color);
padding-bottom: 10px;
border-bottom: 1px solid var(--border-color);
margin-bottom: 20px;
}
#connect-dialog {
display: none;
padding-bottom: 10px;
border-bottom: 1px solid var(--border-color);
margin-bottom: 20px;
}
#connect-dialog #uri-field {
/* Override the max-width to take the button into account */
max-width: calc(100% - 100px);
}
.masthead-item .octicon {
top: 1px;
position: relative;
font-weight: bold;
}
span.strong {
font-weight: bold;
}
/*
* Support tagging elements with collapsible that can have children tagged
* with optional-text to be hidden when the page is below a certain threshold.
*
* Also support optional directly on elements to be hidden.
*/
@media all and (max-width: 550px) { .optional-550 { display: none; } }
@media all and (max-width: 700px) { .optional-700 { display: none; } }
@media all and (max-width: 1000px) { .optional-1000 { display: none; } }
@media all and (max-width: 1060px) { .optional-1060 { display: none; } }
/*
* Support tagging btn-groups with collapsible that can have children tagged
* with optional-text to be hidden when the page is below a certain threshold.
*/
@media all and (max-width: 685px) {
.btn-group.collapsible-685 .optional-text span:not(.octicon) {
display: none;
}
.btn-group.collapsible-685 .btn .flutter-icon {
margin-right: 0;
box-sizing: content-box;
}
}
@media all and (max-width: 750px) {
.btn-group.collapsible-750 .optional-text span:not(.octicon) {
display: none;
}
.btn-group.collapsible-750 .btn .flutter-icon {
margin-right: 0;
box-sizing: content-box;
}
}
@media all and (max-width: 785px) {
.btn-group.collapsible-785 .optional-text span:not(.octicon) {
display: none;
}
.btn-group.collapsible-785 .btn .flutter-icon {
margin-right: 0;
box-sizing: content-box;
}
}
@media all and (max-width: 800px) {
.btn-group.collapsible-800 .optional-text span:not(.octicon) {
display: none;
}
.btn-group.collapsible-800 .btn .flutter-icon {
margin-right: 0;
box-sizing: content-box;
}
}
@media all and (max-width: 885px) {
.btn-group.collapsible-885 .optional-text span:not(.octicon) {
display: none;
}
.btn-group.collapsible-885 .btn .flutter-icon {
margin-right: 0;
box-sizing: content-box;
}
}
@media all and (max-width: 1000px) {
.btn-group.collapsible-1000 .optional-text span:not(.octicon) {
display: none;
}
.btn-group.collapsible-1000 .btn .flutter-icon {
margin-right: 0;
box-sizing: content-box;
}
}
@media all and (max-width: 1200px) {
.btn-group.collapsible-1200 .optional-text span:not(.octicon) {
display: none;
}
.btn-group.collapsible-1200 .btn .flutter-icon {
margin-right: 0;
box-sizing: content-box;
}
}
@media all and (max-width: 1400px) {
.btn-group.collapsible-1400 .optional-text span:not(.octicon) {
display: none;
}
.btn-group.collapsible-1400 .btn .flutter-icon {
margin-right: 0;
box-sizing: content-box;
}
}
/* Bidirectional splitters that change direction when window is wider/taller */
.bidirectional {
height: 100%;
width: 100%;
display: flex;
flex-direction: column;
}
@media (min-aspect-ratio: 1/1) {
.bidirectional {
flex-direction: row;
}
}
.recording-instruction-container {
margin-top: -22px; /* Negative top margin of half of the container height. */
}
.recording-instruction-message {
justify-content: center;
}
.recording-status-message {
margin-top: -34px; /* Full height of the text field plus padding for the spinner. */
}
.recording-spinner {
margin-top: 0 !important;
}
.checkbox-container {
justify-content: flex-end;
align-items: center;
margin-right: 6px;
}
.checkbox {
margin-left: 6px;
margin-right: 6px;
}
.checkbox-text {
margin-bottom: 1px;
}
.inspector-tree-html {
font: 14px arial;
line-height: 22px;
}