Source code
Revision control
Copy as Markdown
Other Tools
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
:root {
--breakpoint-active-color: rgba(44,187,15,.2);
--breakpoint-active-color-hover: rgba(44,187,15,.5);
}
.theme-dark:root {
--breakpoint-active-color: rgba(0,255,175,.4);
--breakpoint-active-color-hover: rgba(0,255,175,.7);
}
/* We don't want the focus style to be displayed on the CodeMirror scrollbars.
*/
.CodeMirror-vscrollbar, .CodeMirror-hscrollbar {
outline: none !important;
}
.CodeMirror .errors {
width: 16px;
}
.CodeMirror .error {
display: inline-block;
margin-left: 5px;
width: 12px;
height: 12px;
background-repeat: no-repeat;
background-position: center;
background-size: contain;
opacity: 0.75;
}
.CodeMirror .hit-counts {
width: 6px;
}
.CodeMirror .hit-count {
display: inline-block;
height: 12px;
border: solid rgba(0,0,0,0.2);
border-width: 1px 1px 1px 0;
border-radius: 0 3px 3px 0;
padding: 0 3px;
font-size: 10px;
pointer-events: none;
}
.CodeMirror-linenumber:before {
content: " ";
display: block;
width: calc(100% - 3px);
position: absolute;
top: 1px;
left: 0;
height: 12px;
z-index: -1;
background-size: calc(100% - 2px) 12px;
background-repeat: no-repeat;
background-position: right center;
padding-inline-end: 9px;
}
.breakpoint .CodeMirror-linenumber {
color: var(--theme-body-background);
}
.debug-line .CodeMirror-linenumber {
background-color: var(--breakpoint-active-color);
}
.theme-dark .debug-line .CodeMirror-linenumber {
color: #c0c0c0;
}
.debug-line .CodeMirror-line {
background-color: var(--breakpoint-active-color) !important;
}
/* Don't display the highlight color since the debug line
is already highlighted */
.debug-line .CodeMirror-activeline-background {
display: none;
}
.CodeMirror {
cursor: text;
height: 100%;
}
.CodeMirror-gutters {
cursor: default;
}
.cm-trailingspace {
background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAQAAAACCAYAAAB/qH1jAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH3QUXCToH00Y1UgAAACFJREFUCNdjPMDBUc/AwNDAAAFMTAwMDA0OP34wQgX/AQBYgwYEx4f9lQAAAABJRU5ErkJggg==");
opacity: 0.75;
background-position: left bottom;
background-repeat: repeat-x;
}
/* Search highlight style
* cm-searching is used in Style Editor, and cm-highlight in Debugger */
.cm-searching,
.cm-highlight {
border-bottom: 1px solid var(--theme-contrast-border);
/* Use the translucent yellow background, because we want the text selection
background (CodeMirror-selected) to show through this. */
background-color: var(--theme-contrast-background-alpha);
}
/* CodeMirror dialogs styling */
.CodeMirror-dialog {
padding: 4px 3px;
}
.CodeMirror-dialog,
.CodeMirror-dialog input {
font: message-box;
}
/* Fold addon */
.CodeMirror-foldmarker {
display: inline-block;
font-family: sans-serif;
line-height: 10px;
margin: 0 1px;
padding: 0 2px;
border-radius: 3px;
border: solid 1px var(--theme-splitter-color);
color: var(--theme-body-color);
background-color: var(--theme-sidebar-background);
cursor: pointer;
}
.CodeMirror-foldgutter {
width: 16px; /* Same as breakpoints gutter above */
}
.CodeMirror-foldgutter-open,
.CodeMirror-foldgutter-folded {
height: 14px;
margin-top: 1px;
background-image: url("chrome://devtools/skin/images/arrow.svg");
background-position: center;
background-repeat: no-repeat;
-moz-context-properties: fill;
fill: var(--theme-icon-dimmed-color);
/* make the icons smaller than regular twistys (10->8px) */
background-size: 8px;
cursor: pointer;
}
.CodeMirror-foldgutter-folded {
transform: rotate(-90deg);
}
.CodeMirror-hints {
position: absolute;
z-index: 10;
overflow: hidden;
list-style: none;
margin: 0;
padding: 2px;
border-radius: 3px;
font-size: 90%;
max-height: 20em;
overflow-y: auto;
}
.CodeMirror-hint {
margin: 0;
padding: 0 4px;
border-radius: 2px;
max-width: 19em;
overflow: hidden;
white-space: pre;
cursor: pointer;
}
.CodeMirror-Tern-completion {
padding-inline-start: 22px;
position: relative;
line-height: 18px;
}
.CodeMirror-Tern-completion:before {
position: absolute;
left: 2px;
bottom: 2px;
border-radius: 50%;
font-size: 12px;
font-weight: bold;
height: 15px;
width: 15px;
line-height: 16px;
text-align: center;
color: #ffffff;
box-sizing: border-box;
}
.CodeMirror-Tern-completion-unknown:before {
content: "?";
}
.CodeMirror-Tern-completion-object:before {
content: "O";
}
.CodeMirror-Tern-completion-fn:before {
content: "F";
}
.CodeMirror-Tern-completion-array:before {
content: "A";
}
.CodeMirror-Tern-completion-number:before {
content: "N";
}
.CodeMirror-Tern-completion-string:before {
content: "S";
}
.CodeMirror-Tern-completion-bool:before {
content: "B";
}
.CodeMirror-Tern-completion-guess {
color: #999;
}
.CodeMirror-Tern-tooltip {
border-radius: 3px;
padding: 2px 5px;
white-space: pre-wrap;
max-width: 40em;
position: absolute;
z-index: 10;
}
.CodeMirror-Tern-hint-doc {
max-width: 25em;
}
.CodeMirror-Tern-farg-current {
text-decoration: underline;
}
.CodeMirror-Tern-fhint-guess {
opacity: .7;
}
/* Override the background-color: white applied to filler elements in codemirror.css */
.CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {
appearance: auto;
-moz-default-appearance: scrollcorner;
}
/* Markup view and Event tooltip styles */
.CodeMirror.cm-s-markup-view pre {
font-size: var(--theme-code-font-size);
line-height: var(--theme-code-line-height);
min-height: 15px;
}
/* Make our own cursor-blink animation */
@keyframes cursor-blink {
0% {}
50% { opacity: 0; }
100% {}
}
.CodeMirror-focused .CodeMirror-cursor {
/*
* We're using the --caret-blink-time custom property for the animation duration.
* It is set in editor.js when we setup the CodeMirror instance, and will map either
* to the value of the ui.caretBlinkTime preference, or to CodeMirror's default for
*/
/*
* The animation should only be set when the editor is focused, otherwise the
* animation will continue even when devtools is in a background tab.
* This happens because the cursor is hidden using visiblity: hidden rather than
*/
animation: cursor-blink calc(var(--caret-blink-time, 0.53s) * 2) steps(1) infinite;
}
/*
* Always align CodeMirror lines to the left.
*/
.CodeMirror-lines {
text-align: left;
}
/* CodeMirror matchhighlight styling */
.cm-matchhighlight, .cm-selectionMatch {
outline: 1px solid var(--theme-contrast-border);
border-radius: 2px;
/* Override cm6 inline */
background-color: transparent !important;
}
.cm-non-printable-char {
color: var(--theme-comment);
font-size: 0.9em;
border-radius: 2px;
outline: 1px solid currentColor;
margin-inline: 2px;
padding-inline: 2px;
}
/* matching brackets highlight */
.cm-s-mozilla .CodeMirror-matchingbracket,
/* Codemirror 6 */
.cm-editor .cm-matchingBracket {
text-decoration: 1px underline solid currentColor;
text-decoration-skip-ink: none;
text-underline-offset: 3px;
}
.cm-s-mozilla.CodeMirror-focused .CodeMirror-selected { /* selected text (focused) */
background: var(--theme-text-selection-background);
}
.cm-s-mozilla .CodeMirror-selected { /* selected text (unfocused) */
background: var(--theme-text-selection-unfocused-background);
}
/* cm5 High Contrast Mode override */
:root[forced-colors-active] {
.CodeMirror-selectedtext {
/* Set the color on the actual span elements */
color: var(--theme-text-selection-color);
/* We also need to set the background color to avoid the backplating and keep it readable */
background-color: var(--theme-text-selection-background);
/* Set the background for the "active match" (i.e. when double clicking a word) */
&.cm-matchhighlight {
forced-color-adjust: auto;
background-color: var(--theme-text-selection-background) !important;
color: var(--theme-text-selection-color);
}
}
/* Matching brackets */
div.CodeMirror span.CodeMirror-matchingbracket {
background-color: Mark;
color: MarkText;
}
}
/****************************************/
/***** CodeMirror 6 specific styles *****/
/****************************************/
.cm-editor {
max-height: 100%;
height: 100%;
}
.cm-editor .cm-selectionBackground {
background: var(--theme-text-selection-background) !important;
}
.cm-editor .cm-content ::selection {
/* We don't want forced colors on selection so we can adjust the colors as we want.
This especially helps for the unfocused selected text */
forced-color-adjust: none;
}
.cm-editor .cm-line ::selection {
color: inherit;
}
:root[forced-colors-active] .cm-editor .cm-line ::selection,
:root[forced-colors-active] .cm-editor .cm-line::selection {
background-color: var(--theme-text-selection-background) !important;
color: var(--theme-text-selection-color) !important;
}
.cm6-dt-foldgutter__toggle-button {
height: 20px;
width: 20px;
padding-inline: 3px;
/* By default, the icon is a bit too low */
translate: 0px -4px;
background-image: url("chrome://devtools/skin/images/arrow.svg");
background-position: center;
background-repeat: no-repeat;
background-color: transparent;
border: none;
outline-offset: -2px;
-moz-context-properties: fill;
fill: var(--theme-icon-dimmed-color);
/* make the icons smaller than regular twistys (10->8px) */
background-size: 8px;
cursor: pointer;
&[aria-expanded=false] {
transform: rotate(-90deg);
}
}
.cm-editor .cm-gutter.cm-lineNumbers {
user-select: none;
}
.cm-editor .cm-foldPlaceholder {
font-family: sans-serif;
padding: 0 2px;
border-radius: 3px;
border: solid 1px var(--theme-splitter-color);
color: var(--theme-body-color);
background-color: var(--theme-sidebar-background);
vertical-align: middle;
}
.cm-editor .cm-matchingBracket {
/* Removing the default background color */
background-color: unset !important;
/* Applying the same color that was set in cm5. Set the color on the parent so the
underline set on the parent has the correct color */
color: #0b0;
:root[forced-colors-active] & {
background: Mark;
color: MarkText;
}
.tok-punctuation {
color: currentColor;
}
}