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/. */
10 /* === BEGIN netmonitor.inc.css === */
14 --table-splitter-color: #9C9CFF;
15 --table-zebra-background: rgba(255,159,0,0.1);
18 #requests-menu-empty-notice {
24 #notice-perf-message {
28 #requests-menu-perf-notice-button {
32 list-style-image: url("profiler-stopwatch.svg");
35 #requests-menu-perf-notice-button .button-text {
39 #requests-menu-reload-notice-button {
44 /* Network requests table */
46 #requests-menu-toolbar {
49 #requests-menu-toolbar > .toolbar-box > .toolbar-startcap,
50 #requests-menu-toolbar > .toolbar-box > .toolbar-endcap {
54 .requests-menu-header:first-child {
55 -moz-padding-start: 4px;
56 -moz-margin-start: 4px;
59 .requests-menu-subitem {
63 .requests-menu-header:not(:last-child),
64 .requests-menu-subitem:not(:last-child) {
65 -moz-border-end: 1px solid var(--table-splitter-color);
68 .requests-menu-header:not(:last-child):-moz-locale-dir(rtl),
69 .requests-menu-subitem:not(:last-child):-moz-locale-dir(rtl) {
72 .requests-menu-header-button,
73 #requests-menu-status-button {
74 background-color: transparent;
78 font-weight: inherit !important;
79 transition: background-color 0.1s ease-in-out;
82 .requests-menu-header-button > .button-box,
83 #requests-menu-status-button > .button-box {
85 -moz-padding-start: 0;
90 .requests-menu-header-button:hover {
91 background-color: #FFCF00;
94 .requests-menu-header-button:hover:active {
95 background-color: #FF9F00;
98 .requests-menu-header-button:not(:active)[sorted] {
99 background-color: #008484;
102 .requests-menu-header-button:not(:active)[sorted=ascending] {
103 background-image: radial-gradient(farthest-side at center top, rgba(0,0,0,.7), rgba(0,0,0,0.3));
104 background-size: 100% 1px;
105 background-repeat: no-repeat;
108 .requests-menu-header-button:not(:active)[sorted=descending] {
109 background-image: radial-gradient(farthest-side at center bottom, rgba(0,0,0,.7), rgba(0,0,0,0.3));
110 background-size: 100% 1px;
111 background-repeat: no-repeat;
112 background-position: bottom;
115 #requests-menu-status-button {
119 #requests-menu-status-button > .button-box {
123 /* Network requests table: specific column dimensions */
125 .requests-menu-status-and-method {
129 .requests-menu-status {
135 .requests-menu-method {
140 .requests-menu-icon-and-file {
145 .requests-menu-icon {
147 width: calc(1em + 4px);
148 height: calc(1em + 4px);
150 -moz-margin-end: 4px;
153 .requests-menu-icon {
154 outline: 1px solid var(--table-splitter-color);
157 .requests-menu-file {
161 .requests-menu-security-and-domain {
166 .requests-security-state-icon {
167 -moz-margin-end: 4px;
168 -moz-image-region:rect(0px, 16px, 16px, 0px);
171 .requests-security-state-icon:hover {
172 -moz-image-region: rect(0px, 32px, 16px, 16px);
175 .requests-security-state-icon:active {
176 -moz-image-region: rect(0px, 48px, 16px, 32px);
179 .security-state-insecure {
180 list-style-image: url("chrome://browser/skin/identity-icons-generic.png");
183 .security-state-secure {
185 list-style-image: url("chrome://browser/skin/identity-icons-https.png");
188 .security-state-weak {
190 list-style-image: url("chrome://browser/skin/identity-icons-https-mixed-display.png");
193 .security-state-broken {
195 list-style-image: url("chrome://browser/skin/identity-icons-https-mixed-active.png");
198 .requests-menu-type {
203 .requests-menu-size {
208 .requests-menu-transferred {
213 /* Network requests table: status codes */
215 box.requests-menu-status {
216 background-color: #A09090;
218 -moz-margin-start: 5px;
219 -moz-margin-end: 5px;
221 border: 1px solid #000000;
222 transition: background-color 0.5s ease-in-out;
225 label.requests-menu-status-code {
226 -moz-margin-start: 3px !important;
228 -moz-margin-end: -3em !important;
231 box.requests-menu-status:not([code]) {
232 background-color: var(--theme-content-color2);
235 box.requests-menu-status[code="cached"] {
236 border: 2px solid var(--theme-content-color2);
237 background-color: transparent;
240 box.requests-menu-status[code^="1"] {
241 background-color: var(---theme-highlight-blue);
244 box.requests-menu-status[code^="2"] {
245 background-color: var(--theme-highlight-green);
248 /* 3xx are triangles */
249 box.requests-menu-status[code^="3"] {
250 background-color: transparent;
253 border-left: 5px solid transparent;
254 border-right: 5px solid transparent;
255 border-bottom: 10px solid var(--theme-highlight-lightorange);
259 /* 4xx and 5xx are squares - error codes */
260 box.requests-menu-status[code^="4"] {
261 background-color: var(--theme-highlight-red);
262 border-radius: 0; /* squares */
265 box.requests-menu-status[code^="5"] {
266 background-color: var(--theme-highlight-pink);
268 transform: rotate(45deg);
271 /* Network requests table: waterfall header */
273 #requests-menu-waterfall-label {
274 -moz-padding-start: 8px;
275 -moz-padding-end: 8px;
278 .requests-menu-timings-division {
281 -moz-padding-start: 4px;
282 -moz-border-start: 1px dotted #000000;
284 pointer-events: none;
287 .requests-menu-timings-division:not(:first-child) {
288 -moz-border-start: 1px dotted;
289 -moz-margin-start: -100px !important; /* Don't affect layout. */
292 .requests-menu-timings-division:-moz-locale-dir(ltr) {
293 transform-origin: left center;
296 .requests-menu-timings-division:-moz-locale-dir(rtl) {
297 transform-origin: right center;
300 .requests-menu-timings-division[division-scale=millisecond] {
301 -moz-border-start-color: var(--theme-body-color) !important;
304 .requests-menu-timings-division[division-scale=second] {
305 -moz-border-start-color: var(--theme-body-color) !important;
309 .requests-menu-timings-division[division-scale=minute] {
310 -moz-border-start-color: var(--theme-body-color) !important;
314 /* Network requests table: waterfall items */
316 .requests-menu-subitem.requests-menu-waterfall {
317 -moz-padding-start: 0px;
318 -moz-padding-end: 4px;
319 /* Background created on a <canvas> in js. */
320 /* @see browser/devtools/netmonitor/netmonitor-view.js */
321 background-image: -moz-element(#waterfall-background);
322 background-repeat: repeat-y;
323 background-position: -1px center;
326 .requests-menu-subitem.requests-menu-waterfall:-moz-locale-dir(rtl) {
327 background-position: right center;
330 .requests-menu-timings:-moz-locale-dir(ltr) {
331 transform-origin: left center;
334 .requests-menu-timings:-moz-locale-dir(rtl) {
335 transform-origin: right center;
338 .requests-menu-timings-total:-moz-locale-dir(ltr) {
339 transform-origin: left center;
342 .requests-menu-timings-total:-moz-locale-dir(rtl) {
343 transform-origin: right center;
346 .requests-menu-timings-total {
347 -moz-padding-start: 4px;
352 .requests-menu-timings-box {
356 .requests-menu-timings-box.blocked {
357 background-color: #FF0000; /* red */
360 .requests-menu-timings-box.dns {
361 background-color: #E7ADE7; /* pink */
364 .requests-menu-timings-box.connect {
365 background-color: #FF9F00; /* orange */
368 .requests-menu-timings-box.send {
369 background-color: #FFCF00; /* light blue */
372 .requests-menu-timings-box.wait {
373 background-color: #9C9CFF; /* blue grey */
376 .requests-menu-timings-box.receive {
377 background-color: #A09090; /* green */
382 #network-table .side-menu-widget-empty-text,
383 #network-table .side-menu-widget-container {
384 background-color: var(--theme-body-background);
387 #network-table .side-menu-widget-item {
388 border-top-color: transparent;
389 border-bottom-color: transparent;
392 .side-menu-widget-item-contents {
396 .side-menu-widget-container {
397 box-shadow: none !important;
400 .side-menu-widget-item:not(.selected)[odd] {
401 background-color: var(--table-zebra-background);
404 .side-menu-widget-item:not(.selected):hover {
405 background-color: var(--theme-selection-background-semitransparent);
408 /* Network request details */
410 #details-pane-toggle {
411 list-style-image: url("chrome://browser/skin/devtools/debugger-collapse.png");
412 -moz-image-region: rect(0px,16px,16px,0px);
415 #details-pane-toggle > .toolbarbutton-icon {
420 #details-pane-toggle[pane-collapsed] {
421 list-style-image: url("chrome://browser/skin/devtools/debugger-expand.png");
424 #details-pane-toggle:hover,
425 #details-pane-toggle:hover:active {
426 -moz-image-region: rect(0px,32px,16px,16px);
429 @media (min-resolution: 1.25dppx) {
430 #details-pane-toggle {
431 list-style-image: url("chrome://browser/skin/devtools/debugger-collapse@2x.png");
432 -moz-image-region: rect(0px,32px,32px,0px);
435 #details-pane-toggle[pane-collapsed] {
436 list-style-image: url("chrome://browser/skin/devtools/debugger-expand@2x.png");
439 #details-pane-toggle:active {
440 -moz-image-region: rect(0px,64px,32px,32px);
444 /* Network request details tabpanels */
447 background-color: var(--theme-sidebar-background);
450 .theme-dark .tabpanel-content {
451 color: var(--theme-body-color);
455 background-color: var(--theme-toolbar-background);
458 /* Summary tabpanel */
460 .tabpanel-summary-container {
464 .tabpanel-summary-label {
465 -moz-padding-start: 4px;
466 -moz-padding-end: 3px;
470 .tabpanel-summary-value {
472 -moz-padding-start: 3px;
475 /* Headers tabpanel */
477 #headers-summary-status,
478 #headers-summary-version {
482 #headers-summary-size {
486 #headers-summary-resend {
488 /* min-height: 20px;*/
491 #toggle-raw-headers {
493 -moz-margin-end: 6px;
496 .raw-response-textarea {
500 /* Response tabpanel */
502 #response-content-info-header {
505 background-color: var(--theme-highlight-red);
506 color: var(--theme-selection-color);
509 #response-content-image-box {
511 padding-bottom: 10px;
514 #response-content-image {
516 border: 1px dashed #A09090;
520 /* Preview tabpanel */
531 /* Timings tabpanel */
533 #timings-tabpanel .tabpanel-summary-label {
537 #timings-tabpanel .requests-menu-timings-box {
538 transition: transform 0.2s ease-out;
543 #timings-tabpanel .requests-menu-timings-total {
544 transition: transform 0.2s ease-out;
547 /* Security tabpanel */
549 .security-info-section {
550 -moz-padding-start: 1em;
557 .security-warning-icon {
558 background-image: url("alerticon-warning.png");
559 background-size: 13px 12px;
560 -moz-margin-start: 5px;
566 @media (min-resolution: 1.25dppx) {
567 .security-warning-icon {
568 background-image: url("alerticon-warning@2x.png");
572 /* Custom request form */
575 padding: 0.6em 0.5em;
586 #custom-method-value {
592 #requests-menu-footer {
594 background-color: var(--theme-toolbar-background);
595 border-top: 1px solid var(--table-splitter-color);
598 .requests-menu-footer-button,
599 .requests-menu-footer-label {
602 -moz-margin-end: 3px;
605 /* color: var(--theme-body-color);*/
608 .requests-menu-footer-spacer {
612 .requests-menu-footer-spacer,
613 .requests-menu-footer-button {
616 .requests-menu-footer-button {
619 .requests-menu-footer-button:hover:active {
622 .requests-menu-footer-button:not(:active)[checked] {
625 .requests-menu-footer-label {
629 #requests-menu-filter-freetext-text {
630 transition-property: max-width, -moz-padding-end, -moz-padding-start;
631 transition-duration: 250ms;
632 transition-timing-function: ease;
635 #requests-menu-filter-freetext-text:not([focused]):not([filled]) > .textbox-input-box {
639 #requests-menu-filter-freetext-text:not([focused]):not([filled]) {
640 max-width: 20px !important;
641 -moz-padding-end: 5px;
642 -moz-padding-start: 22px;
643 background-position: 8px center, top left, top left;
646 #requests-menu-filter-freetext-text[focused],
647 #requests-menu-filter-freetext-text[filled] {
648 max-width: 200px !important;
651 /* Performance analysis buttons */
653 #requests-menu-network-summary-button {
654 list-style-image: url("profiler-stopwatch.svg");
659 #requests-menu-network-summary-label {
660 -moz-padding-start: 0;
664 #requests-menu-network-summary-label:hover {
665 text-decoration: underline;
668 /* Performance analysis view */
670 #network-statistics-toolbar {
671 /* Make the toolbar invisible, it only hold the back button */
672 -moz-binding: url("chrome://global/content/bindings/toolbar.xml#toolbar");
673 background-color: #000000;
676 #network-statistics-back-button {
681 #network-statistics-view-splitter {
683 pointer-events: none;
686 #network-statistics-charts {
688 background-color: var(--theme-sidebar-background);
691 #network-statistics-charts .pie-chart-container {
692 -moz-margin-start: 3vw;
693 -moz-margin-end: 1vw;
696 #network-statistics-charts .table-chart-container {
697 -moz-margin-start: 1vw;
698 -moz-margin-end: 3vw;
701 .chart-colored-blob[name=html] {
702 fill: var(--theme-highlight-bluegrey);
703 background: var(--theme-highlight-bluegrey);
706 .chart-colored-blob[name=css] {
707 fill: var(--theme-highlight-blue);
708 background: var(--theme-highlight-blue);
711 .chart-colored-blob[name=js] {
712 fill: var(--theme-highlight-lightorange);
713 background: var(--theme-highlight-lightorange);
716 .chart-colored-blob[name=xhr] {
717 fill: var(--theme-highlight-orange);
718 background: var(--theme-highlight-orange);
721 .chart-colored-blob[name=fonts] {
722 fill: var(--theme-highlight-darkpurple);
723 background: var(--theme-highlight-darkpurple);
726 .chart-colored-blob[name=images] {
727 fill: var(--theme-highlight-pink);
728 background: var(--theme-highlight-pink);
731 .chart-colored-blob[name=media] {
732 fill: var(--theme-highlight-green);
733 background: var(--theme-highlight-green);
736 .chart-colored-blob[name=flash] {
737 fill: var(--theme-highlight-red);
738 background: var(--theme-highlight-red);
741 .table-chart-row-label[name=cached] {
745 .table-chart-row-label[name=count] {
750 .table-chart-row-label[name=label] {
754 .table-chart-row-label[name=size] {
758 .table-chart-row-label[name=time] {
762 /* Responsive sidebar */
763 @media (max-width: 700px) {
764 #requests-menu-toolbar {
768 .requests-menu-header-button {
773 margin: 0 !important;
774 /* To prevent all the margin hacks to hide the sidebar. */
777 .requests-menu-status-and-method {
781 .requests-menu-icon-and-file,
782 .requests-menu-security-and-domain {
786 .requests-menu-type {
790 .requests-menu-size {
792 border-width: 0 !important;
793 box-shadow: none !important;
794 /* The "Timeline" header is not visible anymore, and thus the
795 right border and box-shadow of "Size" column should be hidden. */
799 /* === END netmonitor.inc.css === */