diff options
Diffstat (limited to '')
-rw-r--r-- | devtools/client/themes/webconsole.css | 1022 |
1 files changed, 1022 insertions, 0 deletions
diff --git a/devtools/client/themes/webconsole.css b/devtools/client/themes/webconsole.css new file mode 100644 index 0000000000..87a40226e5 --- /dev/null +++ b/devtools/client/themes/webconsole.css @@ -0,0 +1,1022 @@ +/* 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/. */ + +/* Webconsole specific theme variables */ +:root { + /* Minimum height of a message (excluding borders) */ + --console-row-height: 20px; + /* We need a unitless line-height to render formatted messages correctly. + * Target line-height computed value is 14px, for a 11px font-size. */ + --console-output-line-height: calc(14 / 11); + --console-output-vertical-padding: 3px; + /* Additional vertical padding used on the JSTerm and EagerEvaluation + * containers. Set to 0 to make the messages and input seamless. */ + --console-input-extra-padding: 2px; + /* Width of the left gutter where icons appear */ + --console-inline-start-gutter: 32px; + /* Icons perfectly centered in the left gutter "feel" closer to the window + * edge than to message text. This value pushes them slightly to the right. */ + --console-icon-horizontal-offset: 1px; + --console-warning-background: var(--theme-warning-background); + --console-warning-border: var(--theme-warning-border); + --console-warning-color: var(--theme-warning-color); +} + +.theme-dark { + --console-input-background: var(--theme-tab-toolbar-background); + --console-message-background: var(--theme-body-background); + --console-message-border: var(--theme-splitter-color); + --console-message-color: var(--theme-text-color-strong); + --console-error-background: hsl(345, 23%, 24%); + --console-error-border: hsl(345, 30%, 35%); + --console-error-color: var(--red-20); + --console-navigation-color: var(--theme-highlight-blue); + --console-navigation-border: var(--blue-60); + --console-indent-border-color: var(--theme-highlight-blue); + --console-repeat-bubble-background: var(--blue-60); + + /* TODO in bug 1549195: colors used in shared components (e.g. Reps) should + be renamed and/or moved to variables.css so they work everywhere */ + --error-color: var(--red-20); + --console-output-color: white; +} + +.theme-light { + --console-input-background: var(--theme-body-background); + --console-message-background: var(--theme-body-background); + --console-message-border: #f2f2f4; /* between Grey 10 and Grey 20 */ + --console-message-color: var(--theme-text-color-strong); + --console-error-background: hsl(344, 73%, 97%); + --console-error-border: rgba(215, 0, 34, 0.12); /* Red 60 + opacity */ + --console-error-color: var(--red-70); + --console-navigation-color: var(--theme-highlight-blue); + --console-navigation-border: var(--blue-30); + --console-indent-border-color: var(--theme-highlight-blue); + --console-repeat-bubble-background: var(--theme-highlight-blue); + + /* TODO in bug 1549195: colors used in shared components (e.g. Reps) should + be renamed and/or moved to variables.css so they work everywhere */ + --error-color: var(--red-70); + --console-output-color: var(--grey-90); +} + +/* General output styles */ + +* { + box-sizing: border-box; +} + +/* + * Stack messages on the z axis so that we can make their borders overlap + * and show color borders on top: + * + * ----------------- <-- Red + * Error message + * ----------------- <-- Red + * Normal message + * ----------------- <-- Grey + * + * and: + * + * ----------------- <-- Grey + * Normal message + * ----------------- <-- Red + * Error message + * ----------------- <-- Red + * + * The exact stacking order is: + * + * - z-index: 3 = Navigation + * - z-index: 2 = Errors and warnings + * - z-index: 1 = Other (console.log, console.info, requests, etc.) + */ +.message { + position: relative; + z-index: 1; + display: flex; + width: 100%; + /* Make the top border cover the previous message's bottom border */ + margin-top: -1px; + /* Min height is the target row height plus borders */ + min-height: calc(var(--console-row-height) + 2px); + border-top: 1px solid var(--console-message-border); + border-bottom: 1px solid var(--console-message-border); + /* Avoid vertical padding, so that we can draw full-height items (e.g. indent guides). + * Use vertical margins of --console-output-vertical-padding on children instead. */ + padding-block: 0; + /* Layout of the 32px-wide left gutter: + * | 4px message padding | 24px icon container | 4px icon margin | + * Note: on hover we show a 3px pseudo-border on top of the left padding. */ + padding-inline-start: 4px; + padding-inline-end: 8px; + font-size: var(--theme-code-font-size); + line-height: var(--console-output-line-height); + color: var(--console-message-color); + background-color: var(--console-message-background); +} + +@media (min-width: 1000px) { + .message { + padding-inline-end: 12px; + } +} + +/* Always hide the border of the first message, but keep its spacing */ +.message:first-child { + border-top-color: transparent !important; +} + +/* We already paint a top border on jsterm-input-container (and we need to keep + * it when scrolling console content), so remove the last item's border. (NOTE: + * the last element is actually the second-to-last element when the output is + * scrolled all the way down, because we include an empty buffer div which + * grows to simulate the height of unrendered content.) */ + .webconsole-app:not(.jsterm-editor) .message:nth-last-child(2) { + border-bottom-width: 0; + /* Adjust the min-height since we now only have a single border. */ + min-height: calc(var(--console-row-height) + 1px); +} + +/* + * By default, prevent any element in message to overflow. + * We exclude network messages as it may cause issues in the network detail panel. + * This makes console reflows faster (See Bug 1487457). + */ +.message:not(.network) * { + overflow: hidden; +} + +.message.disabled { + z-index: 2; + opacity: 0.6; +} + +.message.error { + z-index: 2; + color: var(--console-error-color); + border-color: var(--console-error-border); + background-color: var(--console-error-background); +} + +.message.warn { + z-index: 2; + color: var(--console-warning-color); + border-color: var(--console-warning-border); + background-color: var(--console-warning-background); +} + +.message.navigationMarker { + z-index: 3; + color: var(--console-navigation-color); + border-color: var(--console-navigation-border); +} + +.message.startGroup, +.message.startGroupCollapsed { + --console-indent-border-color: transparent; +} + +/* Hide border between a command and its result */ +.message.command + .result.log { + border-top-width: 0; +} + +.message > .prefix, +.message > .timestamp { + flex: none; + color: var(--theme-comment); + margin: var(--console-output-vertical-padding) 4px; +} + +/* Use a container query as the inline-size of the output might vary when the console is in editor mode */ +@container console-output (width < 500px) { + /* + * When we export messages, we mount the app as a sibling of the #app-wrapper element, + * in a 0-width section which would cause the timestamp to be hidden, so only hide + * the timestamp in the "visible" element. + */ + #app-wrapper .message > .timestamp { + display: none; + } + + /** + * This element might have: + * - the message body + * - the repeat bubble + * - the location + * + * What we want here is to display the location one its own line, at the bottom of the + * element: + * +----------------------------+ + * | Message body | [repeat] | + * +----------------------------+ + * | location | + * +----------------------------+ + */ + .message:not(.message-did-catch) .message-flex-body:not(.error-note) { + display: grid; + grid-template-columns: 1fr auto; + row-gap: 8px; + } + + .message-flex-body .message-location { + max-width: 100%; + grid-column: 1 / -1; + grid-row: 2; + justify-self: end; + } +} + +.message > .indent { + flex: none; + display: inline-block; + /* Display indent borders above the message's top and bottom border. + * This avoids interrupted indent lines (looking like dashes). */ + margin-block: -1px; + margin-inline-start: 12px; + border-inline-end: solid 1px var(--console-indent-border-color); +} + +.message > .indent.warning-indent { + border-inline-end-color: var(--console-warning-color); + /* Align the border of the message in warning groups with the toggle icon */ + margin-inline-start: 15px; +} + +/* Center first level indent within the left gutter */ +.message[data-indent="1"]:not(.startGroup, .startGroupCollapsed) > .indent, +.warning-indent { + margin-inline-start: calc(1px + var(--console-icon-horizontal-offset)); + margin-inline-end: calc(11px - var(--console-icon-horizontal-offset)); +} + +.message > .icon { + flex: none; + align-self: flex-start; + /* Width and height must be a multiples of 2px to avoid blurry images. + * Height should match the text's line-height for optimal vertical alignment */ + width: 14px; + height: 14px; + margin: var(--console-output-vertical-padding) 4px; + background-image: none; + background-position: center; + background-repeat: no-repeat; + background-size: 12px; + -moz-context-properties: fill; + fill: currentColor; +} + +/* Icon on unindented row should be centered within the left gutter */ +.message[data-indent="0"] + .icon { + width: 24px; + margin-inline-start: var(--console-icon-horizontal-offset); + margin-inline-end: calc(4px - var(--console-icon-horizontal-offset)); +} + +.message.command > .icon { + color: var(--theme-icon-color); + background-image: url(chrome://devtools/skin/images/webconsole/input.svg); +} + +.message.result > .icon { + color: var(--theme-icon-dimmed-color); + background-image: url(chrome://devtools/skin/images/webconsole/return.svg); +} + +.message.info > .icon { + color: var(--theme-icon-color); + background-image: url(chrome://devtools/skin/images/info-small.svg); +} + +.message.disabled > .icon { + color: var(--theme-icon-color); + background-image: url(chrome://devtools/skin/images/info-small.svg); +} + +.message.error > .icon { + color: var(--theme-icon-error-color); + background-image: url(chrome://devtools/skin/images/error-small.svg); +} + +.message.warn > .icon { + color: var(--theme-icon-warning-color); + background-image: url(chrome://devtools/skin/images/alert-small.svg); +} + +.message.navigationMarker > .icon { + color: var(--console-navigation-color); + background-image: url(chrome://devtools/skin/images/webconsole/navigation.svg); +} + +.message > .icon.logpoint { + background-image: url(chrome://devtools/content/debugger/images/webconsole-logpoint.svg); + -moz-context-properties: fill, stroke; + fill: var(--theme-graphs-purple); + stroke: var(--theme-graphs-purple); +} + +.message > .icon.logtrace { + background-image: url(chrome://devtools/content/debugger/images/trace.svg); + -moz-context-properties: fill, stroke; + fill: var(--theme-icon-checked-color); +} + +.message.network-message-blocked > .icon { + color: var(--theme-icon-error-color); + background-image: url(chrome://devtools/skin/images/blocked.svg); +} + +.message > .message-body-wrapper { + flex: auto; + min-width: 0px; + margin: var(--console-output-vertical-padding) 0; +} + +.message-body-wrapper .elements-label { + color: var(--location-color); + margin: calc(var(--console-output-vertical-padding) * 2) 0; +} + +/* The bubble that shows the number of times a message is repeated */ +.message-repeats, +.warning-group-badge { + display: inline-block; + flex-shrink: 0; + margin: 2px 5px 0 5px; + padding: 0 6px; + height: 1.25em; + border-radius: 40px; + font: message-box; + font-size: 0.8em; + font-weight: normal; +} + +.message-repeats { + color: white; + background-color: var(--console-repeat-bubble-background); +} + +.warning-group-badge { + color: var(--console-warning-background); + background-color: var(--console-warning-color); +} + +.message-location { + max-width: 40%; + flex-shrink: 0; + color: var(--frame-link-source); + margin-left: 1ch; + /* Makes the file name truncated (and ellipsis shown) on the left side */ + direction: rtl; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + text-align: end; +} + +.message-location:empty { + display: none; +} + +.message-location .frame-link-source { + font-style: normal !important; + /* Enforce LTR direction for the file name - fixes bug 1290056 */ + direction: ltr; + unicode-bidi: embed; +} + +.message-location .frame-link-source:visited { + color: currentColor; +} + +.message-flex-body { + display: flex; +} + +.message-body { + white-space: pre-wrap; + word-wrap: break-word; +} + +.message-flex-body > .message-body { + display: block; + flex: 1; +} + +/* Network styles */ +.webconsole-app .message.network.network-message-blocked .method, +.webconsole-app .message.network.network-message-blocked .message-flex-body .message-body .url, +.webconsole-app .message.network.network-message-blocked .status { + color: var(--timing-blocked-color); +} + +.webconsole-app .message.network .method { + flex: none; + margin-inline-end: 1ch; +} + +.webconsole-app .message.network .xhr { + background-color: var(--theme-comment); + color: white; + border-radius: 2px; + font-size: 10px; + padding: 1px 2px; + margin-inline-start: 0; + margin-inline-end: 1ex; +} + +.webconsole-app .message.network .message-flex-body .message-body .url { + color: var(--theme-comment); + font-style: inherit; +} + +.webconsole-app .message.network .status { + color: var(--theme-highlight-blue); + font-style: inherit; +} + +.webconsole-app .message.network .network-monitor .empty-notice { + font-size: 16px; +} + +/* For 4XX and 5XX requests, display the text in the "error" color */ +.webconsole-app .message.network.error .message-flex-body .message-body .url, +.webconsole-app .message.network.error .message-flex-body .message-body .status { + color: currentColor; +} + +.network.message .network-info { + display: none; + margin-block: 6px 2px; + border: solid 1px var(--theme-splitter-color); +} + +.network.message.open .network-info { + display: block; +} + +:root:dir(rtl) .network.message.open .network-info { + direction: rtl; +} + +.network.message .network-info .panels { + min-height: 250px; +} +/* Response panel needs an absolute height size as the + * sizing of its content depends on it, it also needs override + * the inline height set on the panels */ +.network.message .network-info #response-panel { + height: 250px !important; +} + +.network.message .network-info .accordion-item:last-child .accordion-content { + position: static; +} + +.network .message-flex-body > .message-body { + display: flex; + flex-wrap: wrap; + align-items: baseline; +} + +.message.network > .message-body { + display: flex; + flex-wrap: wrap; +} + +.message.network .url { + flex: 1 1 auto; + /* Make sure the URL is very small initially, let flex change width as needed. */ + width: 100px; + min-width: 5em; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + cursor: default; +} + +.message.network .message-body .status { + flex: none; + margin-left: 1ch; + cursor: default; +} + +.message.network.mixed-content .url { + color: var(--theme-highlight-red); + cursor: default; +} + +.message .learn-more-link { + user-select: none; + color: var(--theme-highlight-blue); + margin: 0 1ch; +} + +/* Hide the headers panel toolbar buttons in the console */ +.message.network .headers-panel-container :is(#block-button, #edit-resend-button, .devtools-separator) { + display: none; +} + +/* Override the `postion:absolute` set on the `.panel-container`, this is only needed in the +netmonitor to enable the use of top, right, bottom etc to support content scrolling. +See https://searchfox.org/mozilla-central/rev/7bafa9b9c2156018ec1d410194f9bf4b5b23e77f +/devtools/client/netmonitor/src/assets/styles/HeadersPanel.css#17-24. +The webconsole does not need that as the `.webconsole-output` is already scrollable */ +.message.network .headers-panel-container .panel-container { + position: static; +} + +/* JSTerm Styles */ +html #webconsole-notificationbox { + flex: 0; + width: 100%; +} + +.webconsole-output:empty ~ .notificationbox .notification { + border-top-width: 0; + border-bottom-width: 1px; +} + +.jsterm-input-container { + position: relative; + max-width: 100%; + background-color: var(--console-input-background); + font-family: var(--monospace-font-family); + font-size: var(--theme-code-font-size); + line-height: var(--console-output-line-height); +} + +/* CodeMirror-powered JsTerm */ +.jsterm-input-container > .CodeMirror { + /* aim for a 32px left space (a descendent has 4px padding) */ + padding-inline-start: calc(var(--console-inline-start-gutter) - 4px); + /* Create a new stacking context */ + position: relative; + z-index: 0; /* Keep below column resizers */ + /* input icon */ + background-image: url(chrome://devtools/skin/images/webconsole/input.svg); + background-position-x: calc(10px + var(--console-icon-horizontal-offset)); + background-position-y: 4px; + background-repeat: no-repeat; + background-size: 12px 12px; + -moz-context-properties: fill; + fill: var(--theme-icon-dimmed-color); +} + +.jsterm-input-container > .CodeMirror-focused { + fill: var(--theme-icon-checked-color); +} + +.jsterm-input-container .CodeMirror-lines { + padding-block: var(--console-output-vertical-padding); +} + +.webconsole-app .cm-auto-complete-shadow-text::after { + content: attr(data-completion); + color: var(--theme-comment); + /* This is important for the completion text not to move while the user is typing */ + /* See Bugs 1491776 & 1558248 */ + position: absolute; +} + +.jsterm-input-container .CodeMirror-hscrollbar { + /* We never want to see the horizontal scrollbar */ + display: none !important; +} + +.stacktrace { + display: none; + overflow-y: auto; + margin-block-start: 5px; + margin-block-end: var(--attachment-margin-block-end); + padding-inline-start: 16px; +} + +.message.open .stacktrace:not(:empty) { + display: block; +} + +.objectBox-stackTrace .frames { + padding-inline-start: 16px; +} + +.cm-s-mozilla a[class] { + font-style: italic; + text-decoration: underline; + text-decoration-skip-ink: none; +} + +a.learn-more-link.webconsole-learn-more-link { + font-style: normal; +} + +/* + This element contains the different toolbars in the console + - primary, containing the clear messages button and the text search input, and a + checkbox (Persist logs or Show Content Messages). + It can expand as much as it needs. + - close button, close the split console panel. This button will always be displayed on + righ-top of the toolbar. + - secondary, containing the filter buttons (Error, Warning, …). It's placed inside the + primary toolbar if there's enought space. + + We have 2 different layout: + + Narrow: + + -------------------------------------------------------------- + | 🗑 - Filter Input | ✕ | + -------------------------------------------------------------- + | Error - Warning - Log - Info - Debug - CSS - Network - XHR | + -------------------------------------------------------------- + + And wide: + + -------------------------------------------------------------------------------------- + | 🗑 - Filter Input | Error - Warning - Log - Info - Debug - CSS - Network - XHR | ✕ | + -------------------------------------------------------------------------------------- +*/ +.webconsole-filteringbar-wrapper { + display: grid; + grid-template-columns: 1fr auto; + --primary-toolbar-height: 29px; +} + +.webconsole-filteringbar-wrapper .devtools-toolbar { + background-color: var(--theme-body-background); +} + +.webconsole-filterbar-primary { + display: flex; + /* We want the toolbar (which contain the text search input) to fit + the content, we don't allow to shrink/overlap it */ + flex: 100 0 -moz-fit-content; + align-items: center; + min-height: var(--primary-toolbar-height); +} + +.devtools-toolbar.webconsole-filterbar-secondary { + display: flex; + align-items: center; + align-self: stretch; + user-select: none; + grid-column: 1 / -1; + min-height: var(--primary-toolbar-height); +} + +.devtools-toolbar.webconsole-filterbar-secondary .devtools-separator { + margin-inline: 5px; +} + +.webconsole-filterbar-primary .devtools-togglebutton { + font-variant-numeric: tabular-nums; +} + +.split-console-close-button-wrapper { + min-height: var(--primary-toolbar-height); + /* We will need to display the close button in the right-top always. */ + grid-column: -1 / -2; + grid-row: 1 / 2; + padding-inline-end: 0; +} + +/* On OSX the cursor turns into a window-resizing cursor at the edges of the + * window, so bring the end of the close button in. */ +:root[platform="mac"] .split-console-close-button-wrapper, +:root[platform="mac"] .webconsole-sidebar-toolbar { + padding-inline-end: 2px; +} + +#split-console-close-button { + height: 100%; + margin: 0; +} + +#split-console-close-button::before { + background-image: url(chrome://devtools/skin/images/close.svg); +} + +.webconsole-filterbar-primary .devtools-searchbox { + align-self: stretch; + /* Prevent the filter height from devtools-searchbox */ + height: unset; + flex: 1 1 100%; + margin-inline-start: 1px; + /* It's important to keep this in px as it's used in JS to control the display mode + * of the filter toolbar. */ + min-width: 150px; +} + +.webconsole-filterbar-primary .filter-checkbox { + flex-shrink: 0; + margin: 0 3px; + display: flex; + align-items: center; + user-select: none; +} + +.webconsole-filterbar-filtered-messages { + /* Needed so the bar takes the whole horizontal space when it is wrapped */ + flex-grow: 1; + justify-content: flex-end; + color: var(--theme-comment); + text-align: end; + align-items: center; + min-height: var(--primary-toolbar-height); + line-height: var(--primary-toolbar-height); +} + +@media (max-width: 965px) { + /* This media query will make filtered message element to be displayed in new + line. This width is based on greek localized size since it is longer than + other localized strings. */ + .webconsole-filterbar-filtered-messages { + grid-row: 2 / 3; + grid-column: 1 / -1; + justify-self: stretch; + } +} + +.webconsole-filterbar-filtered-messages .filter-message-text { + font-style: italic; + user-select: none; +} + +.webconsole-filterbar-filtered-messages .reset-filters-button { + margin-inline-start: 0.5em; +} + +/* Special casing String reps, and warning/error string colors + * so they are legible */ +.message .message-body > .objectBox-string, +.message.error .objectBox-string, +.message.warn .objectBox-string { + color: inherit; +} + +/* Special casing dark-theme error and warning ObjectInspector colors */ +.theme-dark .message.error .tree.object-inspector .object-label, +.theme-dark .message.error .tree.object-inspector .object-label *, +.theme-dark .message.warn .tree.object-inspector .object-label, +.theme-dark .message.warn .tree.object-inspector .object-label *, +.theme-dark .message.error .objectLeftBrace, +.theme-dark .message.error .objectRightBrace, +.theme-dark .message.error .arrayLeftBracket, +.theme-dark .message.error .arrayRightBracket, +.theme-dark .message.warn .objectLeftBrace, +.theme-dark .message.warn .objectRightBrace, +.theme-dark .message.warn .arrayLeftBracket, +.theme-dark .message.warn .arrayRightBracket { + color: var(--theme-body-color); +} +.theme-dark .message.error .tree.object-inspector, +.theme-dark .message.warn .tree.object-inspector { + --console-indent-border-color: var(--theme-body-color); +} + +.webconsole-app .message-flex-body > .message-body { + overflow: hidden; +} + +.webconsole-app .message-body > * { + flex-shrink: 0; + vertical-align: top; +} + +.message.startGroup .message-body > .objectBox-string, +.message.startGroupCollapsed .message-body > .objectBox-string { + color: var(--theme-body-color); + font-weight: bold; +} + +/* Prefix text that can be set by ConsoleAPI option */ +.webconsole-app .console-message-prefix { + color: var(--theme-comment); +} + + +/* console.table() */ +.message .consoletable-wrapper { + --consoletable-border: var(--theme-splitter-color); + + max-height: 250px; + overflow: auto; + position: relative; + border-width: 1px 0 0 1px; + padding: 0; + margin-block-end: var(--attachment-margin-block-end); + border: 1px solid var(--consoletable-border); +} + +.message .consoletable { + width: 100%; + margin: 0; + color: var(--theme-body-color); + border-spacing: 0; +} + +.consoletable :is(th, td) { + border: 0 solid var(--consoletable-border); + text-overflow: ellipsis; +} + +.consoletable :is(th, td) + :is(th, td) { + border-inline-start-width: 1px; +} + +.consoletable th { + position: sticky; + top: 0; + background-color: var(--theme-toolbar-background); + color: var(--theme-body-color); + border-block-end-width: 1px; + margin: 0; + padding: 5px 4px; + font-weight: inherit; +} + +.consoletable td { + background-color: var(--theme-body-background); + color: var(--theme-body-color); + padding: 3px 4px; + font-variant-numeric: tabular-nums; +} + + +.consoletable tr:nth-child(even) td { + background-color: var(--table-zebra-background); +} + +/* Simple Table */ +.message .simple-table { + width: 100%; + border-collapse: collapse; + --simpletable-border: var(--theme-splitter-color); + margin-block-end: var(--attachment-margin-block-end); + color: var(--theme-body-color); + text-align: left; + max-height: 250px; + overflow-y: auto; + border: 1px solid var(--simpletable-border); + table-layout: fixed; + margin-top: 3px; +} + +.simple-table-header { + background-color: var(--theme-toolbar-background); + text-overflow: ellipsis; + border-bottom: 1px solid var(--simpletable-border); +} + +.simple-table-header > th { + padding: 5px 4px; + font-weight: inherit; +} + +.simple-table-header > th:nth-child(odd) { + width: 10%; +} + +.simple-table td { + padding: 3px 4px; + text-overflow: ellipsis; + border-left: 1px solid var(--simpletable-border); +} + +.simple-table td:nth-child(2n) span { + color: var(--theme-body-color); +} + +.simple-table tr:nth-child(even) { + background-color: var(--table-zebra-background); +} + +/* Object Inspector */ +.webconsole-app .object-inspector.tree { + display: inline-block; + max-width: 100%; +} + +.webconsole-app .object-inspector.tree .tree-indent { + border-inline-start-color: var(--console-indent-border-color); +} + +.webconsole-app .object-inspector.tree .tree-node:hover:not(.focused) { + background-color: var(--object-inspector-hover-background); +} + +/* + * Make console.group, exception and XHR message's arrow look the same as the arrow + * used in the ObjectInspector (same background-image, width, transition). + * Properties were copied from devtools/client/shared/components/reps/reps.css. + */ +.collapse-button { + flex: none; + align-self: flex-start; + margin-block-start: calc(var(--console-output-vertical-padding) - 1px); + margin-inline-start: -4px; + padding: 3px; + border: none; + color: var(--theme-icon-dimmed-color); + background: transparent; +} + +.collapse-button::before { + content: ""; + display: block; + width: 10px; + height: 10px; + background: url("chrome://devtools/skin/images/arrow.svg") no-repeat center; + background-size: 10px; + transform: rotate(-90deg); + transition: transform 125ms ease; + -moz-context-properties: fill; + fill: currentColor; +} + +/* Align console.group messages with the border they create for their "children" messages */ +.indent ~ .collapse-button { + margin-inline-start: 3px; +} + +.collapse-button[aria-expanded="true"]::before { + transform: rotate(0); +} + +.collapse-button::-moz-focus-inner { + border: none; +} + +/* Hide the icon, so that we can use the collapse-button in its place */ +.message.network:not(:where(.network-message-blocked, .disabled)) > .icon, +.message.startGroup > .icon, +.message.startGroupCollapsed > .icon { + display: none; +} + +/* Center the collapse button in the left gutter (first-level only) */ +.message.network > .collapse-button, +.message:is(.startGroup,.startGroupCollapsed)[data-indent="0"] > .collapse-button { + width: 24px; + margin-inline-start: var(--console-icon-horizontal-offset); + margin-inline-end: calc(4px - var(--console-icon-horizontal-offset)); +} + +/* Use a bigger arrow that is visually similar to other icons (10px) */ +.message.network > .collapse-button::before, +.message:is(.startGroup,.startGroupCollapsed)[data-indent="0"] > .collapse-button::before { + width: 100%; + background-image: url("chrome://devtools/skin/images/arrow-big.svg"); + fill: var(--theme-icon-dimmed-color); +} + +/* Apply a style similar to collapse-button for the object tree arrows */ +.webconsole-app .tree .arrow, +.webconsole-app .object-inspector .tree-node .arrow { + width: 10px; + height: 10px; + background: url("chrome://devtools/skin/images/arrow.svg") no-repeat center; + background-size: 10px; + transform: rotate(-90deg); + /* Needed for alignment */ + margin-top: -1px; + -moz-context-properties: fill; + fill: var(--theme-icon-dimmed-color); +} + +/* In RTL the tree arrows should usually point to the left, but in + this context it should point to the right. + This overrides the rule from other stylesheets that does the opposite. */ +.webconsole-app .tree .arrow:dir(rtl), +.webconsole-app .object-inspector .tree-node .arrow:dir(rtl) { + transform: rotate(-90deg); +} + +.webconsole-app .tree .arrow.expanded, +.webconsole-app .object-inspector .tree-node .arrow.expanded { + transform: rotate(0deg); +} + +.webconsole-app .tree.focused .arrow, +.webconsole-app .object-inspector .tree-node.focused .arrow { + fill: currentColor; +} + +/** Utils **/ +.clipboard-only { + position: absolute; + left: -9999px; + width: 0; + height: 0; +} + +.lazy-message-list-top, +.lazy-message-list-bottom { + overflow-anchor: none; + pointer-events: none; + user-select: none; + padding: 0; + margin: 0; + border: none; +} |