1 /* vim:set ts=2 sw=2 sts=2 et: */
2 /* This Source Code Form is subject to the terms of the Mozilla Public
3 * License, v. 2.0. If a copy of the MPL was not distributed with this
4 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
6 /* === BEGIN widgets.inc.css === */
8 /* Generic pane helpers */
10 .generic-toggled-side-pane {
11 -moz-margin-start: 0px !important;
12 /* Unfortunately, transitions don't work properly with locale-aware properties,
13 so both the left and right margins are set via js, while the start margin
14 is always overridden here. */
17 .generic-toggled-side-pane[animated] {
18 transition: margin 0.25s ease-in-out;
21 /* Responsive container */
23 .devtools-responsive-container {
24 -moz-box-orient: horizontal;
27 .devtools-main-content {
31 .devtools-main-content,
32 .devtools-sidebar-tabs {
33 /* Prevent some children that should be hidden from remaining visible as this is shrunk (Bug 971959) */
37 @media (max-width: 700px) {
38 .devtools-responsive-container {
39 -moz-box-orient: vertical;
42 .devtools-responsive-container > .devtools-side-splitter {
43 /* This is a normally vertical splitter, but we have turned it horizontal
44 due to the smaller resolution */
51 /* Reset the vertical splitter styles */
55 /* In some edge case the cursor is not changed to n-resize */
59 .devtools-responsive-container > .devtools-sidebar-tabs {
65 /* BreacrumbsWidget */
67 .breadcrumbs-widget-container {
68 -moz-margin-start: 2px;
69 -moz-margin-start: 2px;
70 max-height: 24px; /* Set max-height for proper sizing on linux */
71 height: 24px; /* Set height to prevent starting small waiting for content */
76 background: transparent;
91 .scrollbutton-up > .toolbarbutton-icon,
92 .scrollbutton-down > .toolbarbutton-icon {
96 .scrollbutton-up:not([disabled]):active:hover > .toolbarbutton-icon,
97 .scrollbutton-down:not([disabled]):active:hover > .toolbarbutton-icon {
100 .scrollbutton-up[disabled] > .toolbarbutton-icon,
101 .scrollbutton-down[disabled] > .toolbarbutton-icon {
104 .scrollbutton-up:-moz-locale-dir(ltr) {
105 border-top-right-radius: 0;
106 border-bottom-right-radius: 0;
109 .scrollbutton-down:-moz-locale-dir(ltr) {
110 border-top-left-radius: 0;
111 border-bottom-left-radius: 0;
114 .scrollbutton-up:-moz-locale-dir(rtl) {
115 border-top-left-radius: 0;
116 border-bottom-left-radius: 0;
119 .scrollbutton-down:-moz-locale-dir(rtl) {
120 border-top-right-radius: 0;
121 border-bottom-right-radius: 0;
124 /* Draw shadows to indicate there is more content 'behind' scrollbuttons. */
126 .scrollbutton-up:-moz-locale-dir(ltr),
127 .scrollbutton-down:-moz-locale-dir(rtl) {
128 border-right: solid 1px rgba(255, 255, 255, .1);
129 border-left: solid 1px transparent;
130 box-shadow: 3px 0px 3px -3px var(--theme-sidebar-background);
133 .scrollbutton-down:-moz-locale-dir(ltr),
134 .scrollbutton-up:-moz-locale-dir(rtl) {
135 border-right: solid 1px transparent;
136 border-left: solid 1px rgba(255, 255, 255, .1);
137 box-shadow: -3px 0px 3px -3px var(--theme-sidebar-background);
140 .scrollbutton-up[disabled],
141 .scrollbutton-down[disabled] {
143 border-color: transparent;
147 .scrollbutton-up > .toolbarbutton-icon:-moz-locale-dir(rtl),
148 .scrollbutton-down > .toolbarbutton-icon:-moz-locale-dir(ltr) {
149 /* transform: scaleX(-1); */
152 /* The breadcrumb separator elements are used as background images with
153 * -moz-element, so we position them offscreen since we don't care about
154 * seeing the original elements.
156 .breadcrumb-separator-container {
162 #breadcrumb-separator-before,
163 #breadcrumb-separator-after,
164 #breadcrumb-separator-normal {
170 #breadcrumb-separator-before,
171 #breadcrumb-separator-after:after {
172 background: var(--theme-selection-background);
175 #breadcrumb-separator-after,
176 #breadcrumb-separator-before:after {
177 background: var(--theme-toolbar-background);
180 /* This chevron arrow cannot be replicated easily in CSS, so we are using
181 * a background image for it (still keeping it in a separate element so
182 * we can handle RTL support with a CSS transform).
184 #breadcrumb-separator-normal {
185 background: url("breadcrumbs-divider@2x.png") no-repeat center right;
186 background-size: 12px 24px;
189 /* Fake a triangle by rotating a rectangle inside the elements */
190 #breadcrumb-separator-before:after,
191 #breadcrumb-separator-after:after {
196 transform: translateX(-18px) rotate(45deg);
197 box-sizing: border-box;
200 .breadcrumbs-widget-item {
201 background-color: var(--theme-toolbar-background);
205 padding: 0 8px 0 20px;
209 color: var(--theme-content-color1);
212 .breadcrumbs-widget-item:hover {
213 background-color: var(--theme-hover-background);
214 color: var(--theme-hover-color);
217 .breadcrumbs-widget-item[checked]:not(:hover) {
218 background-color: var(--theme-selection-background);
219 color: var(--theme-selection-color);
222 .breadcrumbs-widget-item[siblings-menu-open],
223 .breadcrumbs-widget-item:active {
224 background-color: #FF9F00;
228 .breadcrumbs-widget-item > .button-box {
234 .breadcrumbs-widget-item:not([checked]) {
235 background-image: -moz-element(#breadcrumb-separator-normal);
236 background-repeat: no-repeat;
237 background-position: center left;
240 .breadcrumbs-widget-item[checked] + .breadcrumbs-widget-item {
241 background-image: -moz-element(#breadcrumb-separator-after);
242 background-repeat: no-repeat;
243 background-position: 0 0;
246 .breadcrumbs-widget-item[checked] {
247 background-image: -moz-element(#breadcrumb-separator-before);
248 background-repeat: no-repeat;
249 background-position: 0 0;
250 background-color: #008484; /* Select Highlight Blue */
253 .breadcrumbs-widget-item:first-child {
254 background-image: none;
257 /* RTL support: move the images that were on the left to the right,
258 * and move images that were on the right to the left.
260 .breadcrumbs-widget-item:-moz-locale-dir(rtl) {
261 padding: 0 20px 0 8px;
264 .breadcrumbs-widget-item:-moz-locale-dir(rtl),
265 .breadcrumbs-widget-item[checked] + .breadcrumbs-widget-item:-moz-locale-dir(rtl) {
266 background-position: center right;
269 #breadcrumb-separator-before:-moz-locale-dir(rtl),
270 #breadcrumb-separator-after:-moz-locale-dir(rtl),
271 #breadcrumb-separator-normal:-moz-locale-dir(rtl) {
272 transform: scaleX(-1);
275 #breadcrumb-separator-before:-moz-locale-dir(rtl):after,
276 #breadcrumb-separator-after:-moz-locale-dir(rtl):after {
277 transform: translateX(-5px) rotate(45deg);
280 .breadcrumbs-widget-item[checked] .breadcrumbs-widget-item-id,
281 .breadcrumbs-widget-item[checked] .breadcrumbs-widget-item-tag,
282 .breadcrumbs-widget-item[checked] .breadcrumbs-widget-item-pseudo-classes,
283 .breadcrumbs-widget-item[checked] .breadcrumbs-widget-item-classes {
284 color: var(--theme-highlight-lightorange);
287 .breadcrumbs-widget-item:not([checked]):hover .breadcrumbs-widget-item-id,
288 .breadcrumbs-widget-item:not([checked]):hover .breadcrumbs-widget-item-tag,
289 .breadcrumbs-widget-item:not([checked]):hover .breadcrumbs-widget-item-pseudo-classes,
290 .breadcrumbs-widget-item:not([checked]):hover .breadcrumbs-widget-item-classes {
291 color: var(--theme-hover-color) !important;
294 .breadcrumbs-widget-item {
295 color: var(--theme-highlight-lightorange);
298 .breadcrumbs-widget-item-id {
299 color: var(--theme-body-color-alt);
302 .breadcrumbs-widget-item-classes {
303 color: var(--theme-content-color1);
306 .breadcrumbs-widget-item-pseudo-classes {
307 color: var(--theme-highlight-lightorange);
310 /* SimpleListWidget */
312 .simple-list-widget-container {
313 /* Hack: force hardware acceleration */
314 transform: translateZ(1px);
317 .simple-list-widget-item.selected {
318 background-color: var(--theme-selection-background);
319 color: var(--theme-selection-color);
322 .simple-list-widget-item:not(.selected):hover {
323 background-color: var(--theme-hover-background);
324 color: var(--theme-hover-color);
327 .simple-list-widget-perma-text,
328 .simple-list-widget-empty-text {
329 color: var(--theme-body-color-alt);
335 .fast-list-widget-container {
336 /* Hack: force hardware acceleration */
337 transform: translateZ(1px);
340 /* dark/light theme */
341 .fast-list-widget-empty-text {
344 color: var(--theme-body-color-alt);
349 /* SideMenuWidget container */
351 .side-menu-widget-container {
352 /* Hack: force hardware acceleration */
353 transform: translateZ(1px);
356 .side-menu-widget-container:-moz-locale-dir(ltr),
357 .side-menu-widget-empty-text:-moz-locale-dir(ltr) {
360 .side-menu-widget-container:-moz-locale-dir(rtl),
361 .side-menu-widget-empty-text:-moz-locale-dir(rtl)[with-arrows=true]:-moz-locale-dir(rtl) {
364 .side-menu-widget-group {
365 /* To allow visibility of the dark margin shadow. */
366 /* -moz-margin-end: 1px; */
369 .side-menu-widget-container[with-arrows=true] .side-menu-widget-item {
370 /* To compensate for the arrow image's dark margin. */
371 /* -moz-margin-end: -1px; */
374 /* SideMenuWidget groups */
376 .side-menu-widget-group-title {
378 background-color: var(--theme-contrastsidebar-background);
379 color: var(--theme-contrastsidebar-color);
382 /* SideMenuWidget items */
384 .side-menu-widget-item {
385 border-top: 1px solid #9C9CFF;
386 /* To compensate for the top and bottom borders */
389 background-clip: padding-box;
392 .side-menu-widget-item:last-of-type {
393 border-bottom: 1px solid #9C9CFF;
396 .side-menu-widget-item.selected {
397 background-color: var(--theme-selection-background);
398 color: var(--theme-selection-color);
401 .side-menu-widget-item-arrow {
402 -moz-margin-start: -7px;
403 width: 7px; /* The image's width is 7 pixels */
404 /* Cover the border of the side-menu-widget-item */
409 .side-menu-widget-item.selected > .side-menu-widget-item-arrow {
410 background-size: auto, 1px 100%;
411 background-repeat: no-repeat;
414 .side-menu-widget-item.selected > .side-menu-widget-item-arrow:-moz-locale-dir(ltr) {
415 background-position: center right;
418 .side-menu-widget-item.selected > .side-menu-widget-item-arrow:-moz-locale-dir(rtl) {
419 background-position: center left;
422 .side-menu-widget-item.selected > .side-menu-widget-item-arrow:-moz-locale-dir(ltr) {
423 background-image: url("itemArrow-ltr.svg");
426 .side-menu-widget-item.selected > .side-menu-widget-item-arrow:-moz-locale-dir(rtl) {
427 background-image: url("itemArrow-rtl.svg");
430 /* SideMenuWidget items contents */
432 .side-menu-widget-item-contents {
434 /* To avoid having content overlapping the arrow image. */
435 -moz-padding-end: 8px;
438 .side-menu-widget-item-other {
439 /* To avoid having content overlapping the arrow image. */
440 -moz-padding-end: 8px;
441 /* To compensate for the .side-menu-widget-item-contents padding. */
442 -moz-margin-start: -4px;
443 -moz-margin-end: -8px;
444 color: var(--theme-selection-color);
447 .side-menu-widget-item-other.selected {
448 background-color: var(--theme-selection-background);
449 color: var(--theme-selection-color);
452 .side-menu-widget-item-other:first-of-type {
454 /* border-top-left-radius: 4px; */
457 .side-menu-widget-item-other:last-of-type {
461 .side-menu-widget-item-other:not(.selected) > label {
465 /* SideMenuWidget checkboxes */
467 .side-menu-widget-group-checkbox {
469 -moz-margin-end: 4px;
472 .side-menu-widget-item-checkbox {
474 -moz-margin-start: 4px;
475 -moz-margin-end: -4px;
478 /* SideMenuWidget misc */
480 .theme-dark .side-menu-widget-container,
481 .theme-dark .side-menu-widget-empty-text {
482 background-color: var(--theme-toolbar-background);
485 .side-menu-widget-empty-text {
491 .variables-view-container:not([empty]) {
492 /* Hack: force hardware acceleration */
493 transform: translateZ(1px);
496 .variables-view-empty-notice {
497 color: var(--theme-body-color-alt);
501 .variables-view-scope:focus > .title,
502 .theme-dark .variable-or-property:focus > .title {
503 background-color: var(--theme-selection-background);
504 color: var(--theme-selection-color);
507 .variables-view-scope > .title {
508 background-color: #A09090;
512 /* Generic variables traits */
514 .variables-view-variable:not(:last-child) {
515 border-bottom: 1px solid #A09090;
518 .variables-view-variable > .title > .name {
522 /* Generic variables *and* properties traits */
524 .variable-or-property:focus > .title > label {
525 color: inherit !important;
528 .variables-view-container .theme-twisty {
532 .variable-or-property > .title > .theme-twisty {
533 -moz-margin-start: 5px;
536 .variable-or-property:not([untitled]) > .variables-view-element-details {
537 -moz-margin-start: 7px;
540 /* Traits applied when variables or properties are changed or overridden */
542 .variable-or-property:not([overridden]) {
543 transition: background 1s ease-in-out, color 1s ease-in-out;
546 .variable-or-property:not([overridden])[changed] {
548 transition-duration: .4s;
551 .variable-or-property[overridden] {
552 background: rgba(160,144,144,0.0.5);
555 .variable-or-property[overridden] .title > label {
556 /* Cross out the title for this variable and all child properties. */
558 text-decoration: line-through;
559 border-bottom: none !important;
564 /* Traits applied when variables or properties are editable */
566 .variable-or-property[editable] > .title > .value {
570 .variable-or-property[overridden] .title > .value {
571 /* Disallow editing this variable and all child properties. */
572 pointer-events: none;
575 /* Custom configurable/enumerable/writable or frozen/sealed/extensible
576 * variables and properties */
578 .variable-or-property[non-enumerable]:not([self]):not([pseudo-item]) > .title > .name {
582 .variable-or-property-non-writable-icon {
583 background: url("chrome://browser/skin/devtools/vview-lock.png") no-repeat;
584 background-size: cover;
590 @media (min-resolution: 2dppx) {
591 .variable-or-property-non-writable-icon > .title:after {
592 background-image: url("chrome://browser/skin/devtools/vview-lock@2x.png");
596 .variable-or-property-frozen-label,
597 .variable-or-property-sealed-label,
598 .variable-or-property-non-extensible-label {
600 -moz-padding-end: 4px;
603 .variable-or-property:not(:focus) > .title > .variable-or-property-frozen-label,
604 .variable-or-property:not(:focus) > .title > .variable-or-property-sealed-label,
605 .variable-or-property:not(:focus) > .title > .variable-or-property-non-extensible-label {
611 .variables-view-container[aligned-values] .title > .separator {
615 .variables-view-container[aligned-values] .title > .value {
620 .variables-view-container[aligned-values] .title > .element-value-input {
621 width: calc(70vw - 10px);
626 .variables-view-open-inspector {
627 -moz-box-ordinal-group: 1;
630 .variables-view-edit,
631 .variables-view-add-property {
632 -moz-box-ordinal-group: 2;
635 .variable-or-property-frozen-label,
636 .variable-or-property-sealed-label,
637 .variable-or-property-non-extensible-label,
638 .variable-or-property-non-writable-icon {
639 -moz-box-ordinal-group: 3;
642 .variables-view-delete {
643 -moz-box-ordinal-group: 4;
646 .variables-view-container[actions-first] .variables-view-delete,
647 .variables-view-container[actions-first] .variables-view-add-property,
648 .variables-view-container[actions-first] .variables-view-open-inspector {
649 -moz-box-ordinal-group: 0;
652 .variables-view-container[actions-first] [invisible] {
656 /* Variables and properties tooltips */
658 .variable-or-property > tooltip > label {
662 .variable-or-property[non-enumerable] > tooltip > label.enumerable,
663 .variable-or-property[non-configurable] > tooltip > label.configurable,
664 .variable-or-property[non-writable] > tooltip > label.writable
665 .variable-or-property[non-extensible] > tooltip > label.extensible {
667 text-decoration: line-through;
670 .variable-or-property[overridden] > tooltip > label.overridden {
671 -moz-padding-start: 4px;
672 -moz-border-start: 1px dotted #9C9CFF;
675 .variable-or-property[safe-getter] > tooltip > label.WebIDL {
676 -moz-padding-start: 4px;
677 -moz-border-start: 1px dotted #9C9CFF;
681 /* Variables and properties editing */
683 .variables-view-delete {
684 background: url("chrome://browser/skin/devtools/vview-delete.png");
685 background-size: cover;
690 @media (min-resolution: 2dppx) {
691 .variables-view-delete {
692 background-image: url("chrome://browser/skin/devtools/vview-delete@2x.png");
696 .variables-view-delete:hover {
697 background-position: 32px;
700 .variables-view-delete:active {
701 background-position: 16px;
704 .variable-or-property:focus > .title > .variables-view-delete {
705 /* background-position: 0px; */
708 .variables-view-edit {
709 background: url("chrome://browser/skin/devtools/vview-edit.png");
710 background-size: cover;
716 @media (min-resolution: 2dppx) {
717 .variables-view-edit {
718 background-image: url("chrome://browser/skin/devtools/vview-edit@2x.png");
722 .variables-view-edit:hover {
723 background-position: 32px;
726 .variables-view-edit:active {
727 background-position: 16px;
730 .variable-or-property:focus > .title > .variables-view-edit {
731 /* background-position: 0px; */
734 .variables-view-open-inspector {
735 background: url("chrome://browser/skin/devtools/vview-open-inspector.png");
736 background-size: cover;
742 .variables-view-open-inspector:hover {
743 background-position: 32px;
746 .variables-view-open-inspector:active {
747 background-position: 16px;
750 .variable-or-property:focus > .title > .variables-view-open-inspector {
751 /* background-position: 0px; */
754 /* Variables and properties input boxes */
756 .variable-or-property > .title > .separator + .element-value-input {
757 -moz-margin-start: -2px !important;
758 -moz-margin-end: 2px !important;
761 .variable-or-property > .title > .separator[hidden=true] + .element-value-input {
762 -moz-margin-start: 4px !important;
763 -moz-margin-end: 2px !important;
766 .element-name-input {
767 -moz-margin-start: -2px !important;
768 -moz-margin-end: 2px !important;
772 .element-value-input,
773 .element-name-input {
774 border: 1px solid #008484 !important;
778 /* Variables and properties searching */
780 .variable-or-property[unmatched] {
787 .graph-widget-container {
791 .graph-widget-canvas {
796 .graph-widget-canvas[input=hovering-background] {
800 .graph-widget-canvas[input=hovering-region] {
804 .graph-widget-canvas[input=hovering-selection-start-boundary],
805 .graph-widget-canvas[input=hovering-selection-end-boundary],
806 .graph-widget-canvas[input=adjusting-selection-boundary] {
810 .graph-widget-canvas[input=hovering-selection-contents] {
814 .graph-widget-canvas[input=dragging-selection-contents] {
818 /* Line graph widget */
820 .line-graph-widget-gutter {
827 border-right: 1px solid #9C9CFF;
828 pointer-events: none;
831 .line-graph-widget-gutter-line {
834 border-top: 1px solid;
837 .line-graph-widget-gutter-line[type=maximum] {
838 border-color: #008484;
841 .line-graph-widget-gutter-line[type=minimum] {
842 border-color: #FF0000;
845 .line-graph-widget-gutter-line[type=average] {
846 border-color: #FF9F00;
849 .line-graph-widget-tooltip {
854 -moz-padding-start: 6px;
855 -moz-padding-end: 6px;
856 transform: translateY(-50%);
859 pointer-events: none;
862 .line-graph-widget-tooltip[with-arrows=true]::before {
865 border-top: 3px solid transparent;
866 border-bottom: 3px solid transparent;
867 top: calc(50% - 3px);
870 .line-graph-widget-tooltip[arrow=start][with-arrows=true]::before {
871 -moz-border-end: 3px solid #9C9CFF;
875 .line-graph-widget-tooltip[arrow=end][with-arrows=true]::before {
876 -moz-border-start: 3px solid #9C9CFF;
880 .line-graph-widget-tooltip[type=maximum] {
884 .line-graph-widget-tooltip[type=minimum] {
888 .line-graph-widget-tooltip[type=average] {
892 .line-graph-widget-tooltip[type=maximum][with-arrows=true] {
896 .line-graph-widget-tooltip[type=minimum][with-arrows=true] {
900 .line-graph-widget-tooltip[type=average][with-arrows=true] {
904 .line-graph-widget-tooltip > [text=info] {
908 .line-graph-widget-tooltip > [text=value] {
909 -moz-margin-start: 3px;
912 .line-graph-widget-tooltip > [text=metric] {
913 -moz-margin-start: 1px;
917 .line-graph-widget-tooltip > [text=value],
918 .line-graph-widget-tooltip > [text=metric] {
919 /* text-shadow: 1px 0px rgba(255,255,255,0.6),
920 -1px 0px rgba(255,255,255,0.6),
921 0px -1px rgba(255,255,255,0.6),
922 0px 1px rgba(255,255,255,0.6);*/
925 .line-graph-widget-tooltip[type=maximum] > [text=value] {
929 .line-graph-widget-tooltip[type=minimum] > [text=value] {
933 .line-graph-widget-tooltip[type=average] > [text=value] {
937 /* Bar graph widget */
939 .bar-graph-widget-canvas {
943 .bar-graph-widget-legend {
949 pointer-events: none;
952 .bar-graph-widget-legend-item {
954 -moz-margin-end: 8px;
957 .bar-graph-widget-legend-item > [view="color"],
958 .bar-graph-widget-legend-item > [view="label"] {
959 vertical-align: middle;
962 .bar-graph-widget-legend-item > [view="color"] {
963 display: inline-block;
966 border: 1px solid #9C9CFF;
968 -moz-margin-end: 4px;
969 pointer-events: none;
972 .bar-graph-widget-legend-item > [view="label"] {
973 /* text-shadow: 1px 0px rgba(255,255,255,0.8),
974 -1px 0px rgba(255,255,255,0.8),
975 0px -1px rgba(255,255,255,0.8),
976 0px 1px rgba(255,255,255,0.8);*/
981 .generic-chart-container {
982 /* Hack: force hardware acceleration */
983 transform: translateZ(1px);
986 .generic-chart-container {
987 color: var(--theme-body-color-alt);
990 .chart-colored-blob {
991 fill: var(--theme-highlight-blue);
992 background: var(--theme-highlight-blue);
1006 .pie-chart-slice[largest] {
1012 text-anchor: middle;
1013 dominant-baseline: middle;
1014 pointer-events: none;
1021 .pie-chart-container[slices="1"] > .pie-chart-slice {
1027 transition: all 0.1s ease-out;
1030 .pie-chart-slice:not(:hover):not([focused]),
1031 .pie-chart-slice:not(:hover):not([focused]) + .pie-chart-label {
1032 transform: none !important;
1037 .table-chart-title {
1038 padding-bottom: 10px;
1048 .table-chart-grid:hover > .table-chart-row {
1049 transition: opacity 0.1s ease-in-out;
1052 .table-chart-grid:not(:hover) > .table-chart-row {
1053 transition: opacity 0.2s ease-in-out;
1056 .generic-chart-container:hover > .table-chart-grid:hover > .table-chart-row:not(:hover),
1057 .generic-chart-container:hover ~ .table-chart-container > .table-chart-grid > .table-chart-row:not([focused]) {
1061 .table-chart-row-box {
1064 -moz-margin-end: 10px;
1067 .table-chart-row-label {
1069 -moz-padding-end: 6px;
1073 .table-chart-totals {
1078 .table-chart-totals {
1079 border-top: 1px solid var(--theme-body-color-alt); /* Grey foreground text */
1082 .table-chart-summary-label {
1087 .table-chart-summary-label {
1088 color: var(--theme-content-color2);
1095 .table-widget-body > .devtools-side-splitter {
1099 .table-widget-body {
1102 background: var(--theme-sidebar-background);
1105 .table-widget-body:-moz-locale-dir(ltr) {
1106 /* box-shadow: inset -1px 0 0 @smw_marginDark@;*/
1109 .table-widget-body:-moz-locale-dir(rtl) {
1110 /* box-shadow: inset 1px 0 0 @smw_marginDark@;*/
1113 .table-widget-body:-moz-locale-dir(ltr) {
1114 /* box-shadow: inset -1px 0 0 @smw_marginLight@;*/
1117 .table-widget-body:-moz-locale-dir(rtl) {
1118 /* box-shadow: inset 1px 0 0 @smw_marginLight@;*/
1121 /* Column Headers */
1123 .table-widget-column-header,
1124 .table-widget-cell {
1125 -moz-border-end: 1px solid #A09090;
1128 /* Table widget column header colors are taken from netmonitor.inc.css to match
1129 the look of both the tables. This needs to be updated along with netmonitor
1130 header colors in bug 951714 */
1132 .table-widget-column-header {
1133 background: rgba(0,0,0,0);
1139 padding: 8px 0 0 !important;
1142 font-weight: inherit !important;
1143 transition: background-color 0.1s ease-in-out;
1146 .table-widget-column-header:hover {
1147 background: #FFCF00;
1150 .table-widget-column-header:hover:active {
1151 background: #FF9F00;
1154 .table-widget-column-header:not(:active)[sorted] {
1155 background: #008484;
1158 .table-widget-column-header:not(:active)[sorted=ascending] {
1159 background-image: radial-gradient(farthest-side at center top, hsla(0,0%,0%,.7), hsla(0,0%,0%,0.3));
1160 background-size: 100% 1px;
1161 background-repeat: no-repeat;
1164 .table-widget-column-header:not(:active)[sorted=descending] {
1165 background-image: radial-gradient(farthest-side at center bottom, hsla(0,0%,0%,.7), hsla(0,0%,0%,0.3));
1166 background-size: 100% 1px;
1167 background-repeat: no-repeat;
1168 background-position: bottom;
1173 .table-widget-cell {
1175 margin: -1px 0 !important;
1177 background-clip: padding-box;
1179 -moz-user-focus: normal;
1182 .table-widget-cell {
1183 border-top: 1px solid #A09090;
1184 border-bottom: 1px solid #A09090;
1185 color: var(--theme-body-color);
1188 .theme-dark:not(.filtering) .table-widget-cell:nth-child(odd):not(.theme-selected),
1189 .theme-light:not(.filtering) .table-widget-cell:nth-child(odd):not(.theme-selected),
1190 .table-widget-cell:not(.theme-selected)[odd] {
1191 background: #404000;
1194 .table-widget-cell:last-of-type {
1195 /* box-shadow: inset 0 -1px 0 @smw_itemDarkTopBorder@;*/
1198 .table-widget-cell.flash-out {
1199 animation: flash-out 0.5s ease-in;
1202 @keyframes flash-out {
1204 background: var(--theme-contrast-background2);
1208 /* Empty text and initial text */
1210 .table-widget-empty-text {
1214 margin-top: -20px !important;
1217 .table-widget-body:empty + .table-widget-empty-text:not([value=""]),
1218 .table-widget-body[empty] + .table-widget-empty-text:not([value=""]) {
1224 .tree-widget-container {
1231 -moz-margin-end: 40px;
1234 .tree-widget-container:-moz-focusring,
1235 .tree-widget-container *:-moz-focusring {
1236 outline-style: none;
1239 .tree-widget-empty-text {
1242 background: transparent;
1243 pointer-events: none;
1248 .tree-widget-container .tree-widget-item {
1249 padding: 2px 0px 4px;
1250 /* OSX has line-height 14px by default, which causes weird alignment issues
1251 * because of 20px high icons. thus making line-height consistent with that of
1254 line-height: 17px !important;
1255 display: inline-block;
1257 word-break: keep-all; /* To prevent long urls like http://foo.com/bar from
1258 breaking in multiple lines */
1261 .tree-widget-container .tree-widget-children {
1267 .tree-widget-item[level="1"] {
1272 .tree-widget-item:before {
1277 margin: 3px 2px -3px;
1278 background-repeat: no-repeat;
1279 background-image: url("chrome://browser/skin/devtools/controls.png");
1280 background-size: 56px 28px;
1282 background-position: -28px -14px;
1285 .tree-widget-item:-moz-locale-dir(rtl):before {
1287 transform: scaleX(-1);
1290 .theme-light .tree-widget-item:before {
1291 background-position: 0 -14px;
1294 .tree-widget-item[empty]:before {
1295 background: transparent;
1298 .tree-widget-item[expanded]:before {
1299 background-position: -42px -14px;
1302 .theme-light .tree-widget-item[expanded]:before {
1303 background-position: -14px -14px;
1306 .tree-widget-item + ul {
1308 animation: collapse-tree-item 0.2s;
1312 .tree-widget-item[expanded] + ul {
1313 animation: expand-tree-item 0.3s;
1317 @keyframes collapse-tree-item {
1326 @keyframes expand-tree-item {
1335 @media (min-resolution: 2dppx) {
1336 .tree-widget-item:before {
1337 background-image: url("chrome://browser/skin/devtools/controls@2x.png");
1341 /* Indentation of child items in the tree */
1344 .tree-widget-item[level] + ul > li > .tree-widget-item {
1345 -moz-padding-start: 98px;
1349 .tree-widget-item[level="1"] + ul > li > .tree-widget-item {
1350 -moz-padding-start: 14px;
1354 .tree-widget-item[level="2"] + ul > li > .tree-widget-item {
1355 -moz-padding-start: 28px;
1359 .tree-widget-item[level="3"] + ul > li > .tree-widget-item {
1360 -moz-padding-start: 42px;
1364 .tree-widget-item[level="4"] + ul > li > .tree-widget-item {
1365 -moz-padding-start: 56px;
1369 .tree-widget-item[level="5"] + ul > li > .tree-widget-item {
1370 -moz-padding-start: 70px;
1374 .tree-widget-item[level="6"] + ul > li > .tree-widget-item {
1375 -moz-padding-start: 84px;
1378 /* Custom icons for certain tree items indicating the type of the item */
1380 .tree-widget-item[type]:after {
1385 -moz-margin-end: 4px;
1386 background-repeat: no-repeat;
1387 background-size: 20px auto;
1388 filter: url('filters.svg#invert');
1389 background-position: 0 0;
1390 background-size: auto 20px;
1393 .tree-widget-item:-moz-locale-dir(rtl):after {
1397 .theme-dark .tree-widget-item[type]:after {
1398 filter: url('filters.svg#invert-white');
1401 .tree-widget-item[type="dir"]:after {
1402 background-image: url("chrome://browser/skin/devtools/filetype-dir-close.svg");
1403 background-position: 2px 0;
1404 background-size: auto 16px;
1408 .tree-widget-item[type="dir"][expanded]:not([empty]):after {
1409 background-image: url("chrome://browser/skin/devtools/filetype-dir-open.svg");
1412 .tree-widget-item[type="url"]:after {
1413 background-image: url("chrome://browser/skin/devtools/filetype-globe.svg");
1414 background-size: auto 18px;
1418 /* === BEGIN manifest-editor.inc.css === */
1420 /* Manifest Editor overrides */
1422 .variables-view-container.manifest-editor {
1423 background-color: #000000;
1427 .manifest-editor .variable-or-property:focus > .title {
1428 /* background-color: #EDEDED;
1433 .manifest-editor .variables-view-property > .title > .name {
1434 /* color: #27406A; */
1437 .manifest-editor .variable-or-property > .title > label,
1438 .manifest-editor textbox {
1439 font-family: monospace;
1442 .manifest-editor .variable-or-property > .title > .token-string {
1443 /* color: #54BC6A; */
1447 .manifest-editor .variable-or-property > .title > .token-boolean,
1448 .manifest-editor .variable-or-property > .title > .token-number {
1449 /* color: #009BD4; */
1453 .manifest-editor .variable-or-property > .title > .token-undefined {
1457 .manifest-editor .variable-or-property > .title > .token-null {
1461 .manifest-editor .variable-or-property > .title > .token-other {
1465 .manifest-editor .variables-view-variable {
1466 border-bottom: none;
1469 .manifest-editor .variables-view-delete,
1470 .manifest-editor .variables-view-delete:hover,
1471 .manifest-editor .variables-view-delete:active,
1472 .manifest-editor .variable-or-property:focus .variables-view-delete,
1473 .manifest-editor .variables-view-add-property,
1474 .manifest-editor .variables-view-add-property:hover,
1475 .manifest-editor .variables-view-add-property:active,
1476 .manifest-editor .variable-or-property:focus .variables-view-add-property {
1477 list-style-image: none;
1478 -moz-image-region: initial;
1481 .manifest-editor .variables-view-delete::before,
1482 .manifest-editor .variables-view-add-property::before {
1486 display: inline-block;
1487 background-size: 11px auto;
1490 .manifest-editor .variables-view-delete::before {
1491 background-image: url("app-manager/remove.svg");
1492 background-size: 12px auto;
1495 .manifest-editor .variables-view-add-property::before {
1496 background-image: url("app-manager/add.svg");
1497 -moz-margin-end: 2px;
1500 /* === END manifest-editor.inc.css === */
1502 /* === END widgets.inc.css === */