/* 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 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ :root { --breakpoint-active-color: light-dark(rgba(44,187,15,.2), rgba(0,255,175,.4)); --breakpoint-active-color-hover: light-dark(rgba(44,187,15,.5), rgba(0,255,175,.7);); --gutter-background-color: var(--theme-sidebar-background); --gutter-border-color: light-dark(var(--theme-splitter-color), var(--theme-toolbar-background)); &[forced-colors-active] { /* overriding variable in HCM so the border is actually visible (see Bug 1953376) */ --gutter-border-color: var(--theme-splitter-color); } } /* We don't want the focus style to be displayed on the CodeMirror scrollbars. * See Bug 1590707. */ .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-s-mozilla .CodeMirror-gutters, .cm-editor .cm-gutters { /* vertical line next to line numbers */ border-right-color: var(--gutter-border-color); background-color: var(--gutter-background-color); } .cm-trailingspace { background-image: url(""); 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); :root[forced-colors-active] & { border-bottom-width: 2px; color: var(--theme-contrast-color); } } /* CodeMirror 5 search addon input */ .cm5-search-container { display: flex; padding: 4px 2px; .CodeMirror-dialog:has(> &) { background-color: var(--theme-body-background); /* remove padding on the dialog so it's easier to style the focus indicator */ padding: 0; } .cm5-search-input { margin-inline: 1em; flex-grow: 1; } &:focus-within { outline: var(--theme-focus-outline); outline-offset: -2px; } } .cm5-search-replace-input { width: 10em; &:focus { outline: var(--theme-focus-outline) !important; } } .cm5-search-replace-hint { color: var(--theme-text-color-alt); margin-inline-start: 8px; } /* CodeMirror 5 vim addon prompt/input */ .cm5-vim-prompt { font-family: monospace; white-space: pre; /* When there's a label, add some space before the input */ & label input { margin-inline-start: 8px; } & input:focus { outline: var(--theme-focus-outline) !important; } } .cm5-vim-prompt-description { color: var(--theme-text-color-alt); margin-inline-start: 8px; } .cm5-vim-notification-error { color: var(--theme-text-color-error); } /* 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 * cursorBlinkRate. (See Bug 1609567 for more information on why this is needed). */ /* * 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 * display: none in codemirror.css. See bug 1661054 for details. */ animation: cursor-blink calc(var(--caret-blink-time, 0.53s) * 2) steps(1) infinite; } /* * Always align CodeMirror lines to the left. * See Bug 1651443 for more information. */ .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; } /* Make the outline a bit more visible in High Contrast Mode */ :root[forced-colors-active] .cm-matchhighlight { outline-width: 2px; outline-offset: 2px; } .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%; } /* This makes sure we use the font-family set for devtools */ .cm-editor .cm-scroller { font-family: unset; } .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; } /* Repeat .cm-matchingBracket to get a higher specificity than the default codemirror rule */ .cm-editor .cm-matchingBracket.cm-matchingBracket { /* Removing the default background color */ background-color: unset; /* 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-color: Mark; color: MarkText; } .tok-punctuation { color: currentColor; } }