summaryrefslogtreecommitdiffstats
path: root/devtools/client/themes/rules.css
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
commit26a029d407be480d791972afb5975cf62c9360a6 (patch)
treef435a8308119effd964b339f76abb83a57c29483 /devtools/client/themes/rules.css
parentInitial commit. (diff)
downloadfirefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz
firefox-26a029d407be480d791972afb5975cf62c9360a6.zip
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'devtools/client/themes/rules.css')
-rw-r--r--devtools/client/themes/rules.css974
1 files changed, 974 insertions, 0 deletions
diff --git a/devtools/client/themes/rules.css b/devtools/client/themes/rules.css
new file mode 100644
index 0000000000..363556732d
--- /dev/null
+++ b/devtools/client/themes/rules.css
@@ -0,0 +1,974 @@
+/* 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/. */
+
+/* CSS Variables specific to this panel that aren't defined by the themes */
+:root {
+ --rule-highlight-background-color: var(--theme-highlight-yellow);
+ --rule-highlight-propertyname: var(--blue-60);
+ --rule-highlight-propertyvalue: var(--magenta-70);
+ --rule-highlight-unmatched-unused-color: var(--grey-55);
+ --rule-header-background-color: var(--theme-toolbar-background);
+ --rule-computed-margin-inline-start: 35px;
+ --rule-enableproperty-size: 12px;
+ --rule-enableproperty-margin-inline-start: 3px;
+ --rule-enableproperty-margin-inline-end: 9px;
+
+ &:is([platform="win"], [platform="linux"]) {
+ --rule-enableproperty-size: 14px;
+ /* it's important to keep the px unit here as this is used in a `calc()` */
+ --rule-enableproperty-margin-inline-start: 0px;
+ --rule-enableproperty-margin-inline-end: 10px;
+ }
+}
+
+:root.theme-dark {
+ --rule-highlight-background-color: #521C76;
+ --rule-highlight-propertyname: var(--theme-highlight-blue);
+ --rule-highlight-propertyvalue: var(--theme-highlight-red);
+ --rule-highlight-unmatched-unused-color: var(--grey-40);
+ --rule-header-background-color: #222225;
+}
+
+/* Rule View Tabpanel */
+
+#sidebar-panel-ruleview {
+ margin: 0;
+ display: flex;
+ flex-direction: column;
+ width: 100%;
+ height: 100%;
+
+ /* Override the min-width from .inspector-tabpanel, as the rule panel can support small
+ widths */
+ min-width: 100px;
+}
+
+/* Rule View Toolbar */
+
+#ruleview-toolbar-container {
+ line-height: var(--theme-toolbar-height);
+}
+
+#ruleview-toolbar {
+ flex-wrap: wrap;
+ height: auto;
+}
+
+#ruleview-toolbar .devtools-searchbox {
+ flex-basis: 7em;
+ height: var(--theme-toolbar-height);
+}
+
+#ruleview-command-toolbar {
+ display: flex;
+}
+
+.ruleview-reveal-panel {
+ border-bottom: 1px solid var(--theme-splitter-color);
+ display: flex;
+ overflow: hidden;
+ flex-wrap: wrap;
+ margin: 2px;
+}
+
+.ruleview-reveal-panel[hidden] {
+ display: none;
+}
+
+.ruleview-reveal-panel .add-class {
+ height: var(--theme-toolbar-height);
+ line-height: normal;
+}
+
+.ruleview-reveal-panel label {
+ user-select: none;
+ display: flex;
+ align-items: center;
+}
+
+#pseudo-class-panel,
+#ruleview-class-panel .classes {
+ padding: 0 3px;
+}
+
+/* Pseudo Class toggle panel */
+
+#pseudo-class-panel {
+ grid-template-columns: repeat(auto-fit, minmax(100px, max-content));
+}
+
+#pseudo-class-panel:not([hidden]) {
+ display: grid;
+}
+
+/* Class toggle panel */
+
+#ruleview-class-panel {
+ flex-direction: column;
+}
+
+#ruleview-class-panel .classes {
+ border-top: 1px solid var(--theme-splitter-color);
+ display: flex;
+ flex-direction: row;
+ flex-wrap: wrap;
+ max-height: 100px;
+ overflow-y: auto;
+}
+
+#ruleview-class-panel .classes label {
+ flex: 0 0;
+ max-width: 50%;
+ min-width: 100px;
+}
+
+#ruleview-class-panel .classes label span {
+ white-space: nowrap;
+ text-overflow: ellipsis;
+ overflow: hidden;
+}
+
+#ruleview-class-panel .no-classes {
+ flex: 1;
+ color: var(--theme-text-color-inactive);
+ margin: 0;
+ text-align: center;
+}
+
+/* Rule View Container */
+
+#ruleview-container {
+ user-select: text;
+ overflow: auto;
+ flex: auto;
+ height: 100%;
+ /* Adjust outline so it's visible */
+ outline-offset: -2px;
+}
+
+/* This extra wrapper only serves as a way to get the content of the view focusable.
+ So that when the user reaches it either via keyboard or mouse, we know that the view
+ is focused and therefore can handle shortcuts.
+ However, for accessibility reasons, tabindex is set to -1 to avoid having to tab
+ through it, and the outline is hidden. */
+#ruleview-container-focusable {
+ height: 100%;
+ outline: none;
+}
+
+#ruleview-container.non-interactive {
+ pointer-events: none;
+ visibility: collapse;
+ transition: visibility 0.25s;
+}
+
+#ruleview-container .accordion ._content {
+ padding: 0;
+}
+
+.ruleview-property:not(:hover) > .ruleview-enableproperty {
+ pointer-events: none;
+}
+
+.ruleview-expandable-container {
+ display: block;
+}
+
+.ruleview-namecontainer {
+ cursor: text;
+}
+
+.ruleview-computed {
+ margin-inline-start: var(--rule-computed-margin-inline-start);
+ /* Add a small indent for wrapping lines */
+ text-indent: 1em hanging;
+}
+
+.ruleview-computed > .ruleview-namecontainer {
+ margin: 0;
+}
+
+.ruleview-propertyvaluecontainer {
+ cursor: text;
+ padding-right: 5px;
+}
+
+.ruleview-propertyvaluecontainer a {
+ color: var(--theme-highlight-purple);
+ cursor: pointer;
+}
+
+.ruleview-computedlist,
+.ruleview-expandable-container[hidden],
+.ruleview-overridden-items[hidden],
+.ruleview-overridden-rule-filter[hidden],
+.ruleview-warning[hidden],
+.ruleview-unused-warning[hidden],
+.ruleview-compatibility-warning[hidden],
+.ruleview-used[hidden],
+.ruleview-overridden .ruleview-grid {
+ display: none;
+}
+
+.ruleview-computedlist[user-open],
+.ruleview-computedlist[filter-open],
+.ruleview-overridden-items {
+ display: block;
+}
+
+.ruleview-rule-source {
+ text-align: end;
+ float: right;
+ max-width: 100%;
+
+ /* Force RTL direction to crop the source link at the beginning. */
+ direction: rtl;
+ overflow: hidden;
+ text-overflow: ellipsis;
+
+ user-select: none;
+ margin-bottom: 2px;
+ margin-left: 1ch;
+}
+
+.ruleview-rule-source-label {
+ white-space: nowrap;
+ margin: 0;
+ cursor: pointer;
+
+ /* Create an LTR embed to avoid special characters being shifted to the start due to the
+ parent node direction: rtl; */
+ direction: ltr;
+ unicode-bidi: embed
+}
+
+.ruleview-rule-source.disabled > .ruleview-rule-source-label,
+.ruleview-rule-source[unselectable] > .ruleview-rule-source-label {
+ cursor: default;
+}
+
+.ruleview-rule-source:not([unselectable]) {
+ text-decoration: underline;
+ text-decoration-skip-ink: none;
+}
+
+.ruleview-header {
+ --ruleview-header-padding: 4px;
+ background: var(--rule-header-background-color);
+ border-bottom: 1px solid var(--theme-splitter-color);
+ color: var(--theme-toolbar-color);
+ font-size: 12px;
+ line-height: 16px;
+ padding: var(--ruleview-header-padding);
+ width: 100%;
+ align-items: center;
+ display: flex;
+ user-select: none;
+}
+
+.ruleview-expandable-header {
+ cursor: pointer;
+ /* Reset padding set on ruleview-header since we're going to put it on the button instead */
+ padding: 0;
+
+ &:hover {
+ background-color: var(--theme-accordion-header-hover);
+ }
+
+ & button[aria-expanded] {
+ display: flex;
+ /* Space between arrow and label */
+ gap: 2px;
+ width: 100%;
+ padding: var(--ruleview-header-padding);
+ /* Reset button-specific styles */
+ background-color: transparent;
+ border: none;
+ text-align: start;
+ /* Apply same font-size as set on ruleview-header */
+ font-size: 1em;
+ outline-offset: -2px;
+
+ &[aria-expanded="true"] .theme-twisty {
+ rotate: 90deg;
+ }
+ }
+}
+
+.ruleview-rule-pseudo-element {
+ padding-left: 20px;
+ border-left: solid 10px;
+}
+
+.ruleview-rule {
+ border-bottom: 1px solid var(--theme-splitter-color);
+ padding: 2px 4px;
+ direction: ltr;
+}
+
+#ruleview-container-focusable > .ruleview-rule:last-child {
+ border-bottom: none;
+}
+
+/**
+ * Display rules that don't match the current selected element and uneditable
+ * user agent styles differently
+ */
+.ruleview-rule.unmatched,
+.ruleview-rule.uneditable,
+.ruleview-rule[unmatched=true],
+.ruleview-rule[uneditable=true] {
+ background: var(--theme-tab-toolbar-background);
+}
+
+.ruleview-rule.unmatched,
+.ruleview-rule[unmatched=true] {
+ opacity: 0.5;
+}
+
+.ruleview-rule.uneditable :focus,
+.ruleview-rule[uneditable=true] :focus {
+ outline: none;
+}
+
+.ruleview-rule.uneditable .theme-link,
+.ruleview-rule[uneditable=true] .theme-link {
+ color: var(--theme-highlight-bluegrey);
+}
+
+.ruleview-rule.uneditable .ruleview-enableproperty,
+.ruleview-rule[uneditable=true] .ruleview-enableproperty {
+ visibility: hidden;
+}
+
+.ruleview-rule.uneditable .ruleview-swatch,
+.ruleview-rule[uneditable=true] .ruleview-swatch {
+ cursor: default;
+}
+
+.ruleview-rule.uneditable .ruleview-namecontainer > .ruleview-propertyname,
+.ruleview-rule.uneditable .ruleview-propertyvaluecontainer >
+.ruleview-propertyvalue,
+.ruleview-rule[uneditable=true] .ruleview-namecontainer > .ruleview-propertyname,
+.ruleview-rule[uneditable=true] .ruleview-propertyvaluecontainer >
+.ruleview-propertyvalue {
+ border-bottom-color: transparent;
+}
+
+.ruleview-overridden-rule-filter {
+ display: inline-block;
+ width: 14px;
+ height: 14px;
+ margin-inline-start: 3px;
+ background-image: url(chrome://devtools/skin/images/filter-small.svg);
+ background-position: center;
+ background-repeat: no-repeat;
+ background-size: 12px;
+ -moz-context-properties: fill;
+ fill: var(--theme-icon-dimmed-color);
+ background-color: transparent;
+ border: none;
+
+ &:is(:hover, :focus-visible) {
+ fill: var(--theme-icon-color);
+ }
+}
+
+.ruleview-ruleopen {
+ padding-inline-end: 5px;
+}
+
+.ruleview-ruleclose {
+ clear: both;
+ cursor: text;
+ padding-right: 20px;
+}
+
+.ruleview-ancestor-ruleopen,
+.ruleview-ancestor-ruleclose {
+ color: var(--theme-comment);
+}
+
+.ruleview-rule-indent, .ruleview-ancestor-ruleclose {
+ white-space: pre;
+ /*
+ * We do want to keep the underlying chars for the indent for user to copy/paste,
+ * but we can reduce the inline space it takes.
+ * Tweaking word-spacing instead of using font-size as the latter could be odd when
+ * the text is selected.
+ * Avoid using letter-spacing as this can cause visual glitches on low-dpi screen (see Bug 1845517).
+ */
+ word-spacing: -0.5ch;
+}
+
+.ruleview-rule-indent.clipboard-only {
+ position: absolute;
+ left: -9999px;
+ overflow: hidden;
+ width: 0;
+ height: 0;
+ padding: 0;
+ border: 0;
+ margin: 0;
+}
+
+.ruleview-propertylist {
+ list-style: none;
+ padding: 0;
+ margin: 0;
+}
+
+.ruleview-expandable-container.registered-properties .ruleview-propertylist {
+ /* Since we don't have a toggle checkbox for registered property definitions, we set
+ a padding so they have the same indent as properties in regular rules */
+ padding-inline-start: 28px;
+}
+
+.ruleview-enableproperty {
+ position: relative;
+ margin-top: 0;
+ margin-bottom: 0;
+}
+
+.ruleview-enableproperty {
+ box-sizing: border-box;
+ margin-inline-start: var(--rule-enableproperty-margin-inline-start);
+ margin-inline-end: var(--rule-enableproperty-margin-inline-end);
+ width: var(--rule-enableproperty-size);
+ height: var(--rule-enableproperty-size);
+
+ /* The SVG checkbox on Windows and Linux */
+ :root:is([platform="win"], [platform="linux"]) & {
+ appearance: none;
+ float: left;
+ box-sizing: content-box;
+ display: inline-block;
+ border: 0;
+ padding: 0;
+ background: url("chrome://devtools/skin/images/checkbox.svg") center no-repeat content-box;
+ /* Using fill to paint the border, and stroke for the tick */
+ -moz-context-properties: fill, stroke;
+ fill: rgba(0,0,0,.3);
+ stroke: transparent;
+ }
+
+ :root[platform="mac"] & {
+ appearance: auto;
+ -moz-default-appearance: checkbox;
+ }
+}
+
+:root[platform="win"].theme-dark .ruleview-enableproperty,
+:root[platform="linux"].theme-dark .ruleview-enableproperty {
+ fill: rgba(255,255,255,.4);
+}
+
+:root[platform="win"] .ruleview-enableproperty:checked,
+:root[platform="linux"] .ruleview-enableproperty:checked {
+ stroke: rgba(0,0,0,.6);
+}
+
+:root[platform="win"].theme-dark .ruleview-enableproperty:checked,
+:root[platform="linux"].theme-dark .ruleview-enableproperty:checked {
+ stroke: rgba(255,255,255,.8);
+}
+
+.ruleview-warning,
+.ruleview-unused-warning,
+.ruleview-compatibility-warning {
+ display: inline-block;
+ width: 12px;
+ height: 12px;
+ background-size: 12px;
+ background-repeat: no-repeat;
+ -moz-context-properties: fill;
+}
+
+.ruleview-warning {
+ background-image: url(chrome://devtools/skin/images/alert-small.svg);
+ fill: var(--yellow-60);
+}
+
+.ruleview-unused-warning {
+ background-image: url(chrome://devtools/skin/images/info-small.svg);
+ background-color: var(--theme-sidebar-background);
+ fill: var(--theme-icon-dimmed-color);
+}
+
+.ruleview-compatibility-warning {
+ background-image: url(chrome://devtools/skin/images/report.svg);
+ background-color: var(--theme-sidebar-background);
+ fill: var(--theme-icon-dimmed-color);
+}
+
+.ruleview-unused-warning:hover,
+.ruleview-compatibility-warning:hover {
+ fill: var(--theme-icon-color);
+ stroke: var(--theme-icon-color);
+}
+
+.ruleview-rule:not(:hover, :focus-within) .ruleview-enableproperty {
+ /* Use opacity to hide the checkbox instead of visibility:hidden,
+ so that it's possible to focus it with the keyboard. */
+ opacity: 0;
+}
+
+.ruleview-expander {
+ vertical-align: middle;
+}
+
+.ruleview-propertycontainer .ruleview-expander {
+ margin-left: -6px;
+}
+
+.ruleview-propertycontainer .ruleview-expander:dir(rtl):not([open]) {
+ /* for preventing .theme-twisty's wrong direction in rtl; Bug 1296648 */
+ transform: rotate(-90deg);
+}
+
+.ruleview-newproperty {
+ /* As we don't have the checkbox displayed before the input, we need to align it
+ with the property name above it. */
+ margin-inline-start: calc(
+ var(--rule-enableproperty-size) +
+ var(--rule-enableproperty-margin-inline-start) +
+ var(--rule-enableproperty-margin-inline-end)
+ );
+}
+
+.ruleview-namecontainer,
+.ruleview-propertyvaluecontainer,
+.ruleview-propertyname,
+.ruleview-propertyvalue {
+ text-decoration: inherit;
+}
+
+.ruleview-computedlist {
+ list-style: none;
+ padding: 0;
+}
+
+.ruleview-overridden-items {
+ margin-block: 0;
+ list-style: none;
+ line-height: 1.5em;
+}
+
+.ruleview-overridden-item {
+ position: relative;
+}
+
+.ruleview-overridden-item::before,
+.ruleview-overridden-item::after {
+ content: "";
+ position: absolute;
+ display: block;
+ border: 0 solid var(--theme-text-color-alt);
+}
+
+.ruleview-overridden-item::before {
+ top: 0;
+ left: -15px;
+ height: 0.8em;
+ width: 10px;
+ border-left-width: 0.5px;
+ border-bottom-width: 0.5px;
+}
+
+.ruleview-overridden-item::after {
+ left: -15px;
+ bottom: -7px;
+ height: 100%;
+ border-left-width: 0.5px;
+}
+
+.ruleview-overridden-item:last-child::after {
+ display: none;
+}
+
+.ruleview-overridden-item .ruleview-namecontainer {
+ margin-left: 0;
+}
+
+/* All swatches */
+
+.ruleview-flex,
+.ruleview-grid,
+.ruleview-shapeswatch,
+.ruleview-swatch {
+ cursor: pointer;
+ width: 1em;
+ height: 1em;
+ vertical-align: middle;
+
+ /* align the swatch with its value */
+ margin-top: -1px;
+ margin-inline-end: 5px;
+ display: inline-block;
+ position: relative;
+}
+
+/* Icon swatches not using the .ruleview-swatch class (flex, grid, shape) */
+
+.ruleview-flex,
+.ruleview-grid,
+.ruleview-shapeswatch {
+ -moz-context-properties: stroke;
+ stroke: var(--theme-icon-color);
+}
+
+.ruleview-flex.active,
+.ruleview-grid.active,
+.ruleview-shapeswatch.active {
+ stroke: var(--theme-icon-checked-color);
+}
+
+.ruleview-flex {
+ background-image: url("chrome://devtools/skin/images/flexbox-swatch.svg");
+ background-size: 13px 11px;
+ width: 13px;
+ height: 11px;
+}
+
+.ruleview-grid {
+ background-image: url("chrome://devtools/skin/images/grid.svg");
+}
+
+.ruleview-grid[disabled] {
+ cursor: default;
+ opacity: 0.5;
+}
+
+.ruleview-shapeswatch {
+ background-image: url("chrome://devtools/skin/images/shape-swatch.svg");
+ background-size: 110%;
+ width: 1.45em;
+ height: 1.45em;
+}
+
+.ruleview-shape-point.active,
+.ruleview-shapeswatch.active + .ruleview-shape > .ruleview-shape-point:hover {
+ background-color: var(--rule-highlight-background-color);
+}
+
+/* Round swatches using the .ruleview-swatch class (color, bezier, filter and angle) */
+
+.ruleview-swatch {
+ background-size: 1em;
+ border-radius: 50%;
+}
+
+.ruleview-colorswatch::before {
+ content: '';
+ background-color: #eee;
+ background-image: linear-gradient(45deg, #ccc 25%, transparent 25%, transparent 75%, #ccc 75%, #ccc),
+ linear-gradient(45deg, #ccc 25%, transparent 25%, transparent 75%, #ccc 75%, #ccc);
+ background-size: 12px 12px;
+ background-position: 0 0, 6px 6px;
+ position: absolute;
+ border-radius: 50%;
+ top: 0;
+ left: 0;
+ right: 0;
+ bottom: 0;
+ z-index: -1;
+}
+
+.ruleview-swatch.ruleview-colorswatch {
+ border: none;
+ padding: 0;
+ /* Adjust outline so it doesn't conflate with the color swatch, which could have a similar background
+ color as the outline */
+ outline-offset: 2px;
+}
+
+.ruleview-bezierswatch {
+ background-image: url("chrome://devtools/skin/images/cubic-bezier-swatch.svg");
+}
+
+.ruleview-filterswatch {
+ background-image: url("chrome://devtools/skin/images/filter-swatch.svg");
+}
+
+.ruleview-angleswatch {
+ background-image: url("chrome://devtools/skin/images/angle-swatch.svg");
+}
+
+.ruleview-lineareasingswatch {
+ background-image: url("chrome://devtools/skin/images/linear-easing-swatch.svg");
+}
+
+.ruleview-overridden {
+ text-decoration: line-through solid var(--theme-text-color-alt);
+}
+
+/**
+ * Hide swatches (tool icons) from properties that are overwritten by higher specificity * rules.
+ * .ruleview-swatch is a base class for many tool swatches (shapes, color, bezier curves)
+ * .ruleview-flex and .ruleview-grid are custom
+ */
+.ruleview-overridden .ruleview-flex,
+.ruleview-overridden .ruleview-grid,
+.ruleview-overridden .ruleview-shapeswatch,
+.ruleview-overridden .ruleview-swatch {
+ display: none;
+}
+
+.ruleview-font-family.used-font {
+ text-decoration: underline;
+}
+
+.styleinspector-propertyeditor {
+ padding: 0;
+ margin-block: -1px;
+ border: none;
+ outline-offset: 1px;
+ &:focus-visible {
+ /* Unset the outline box shadow to prevent overlapping previous/next properties.
+ This is safe since those input won't be this part of the UI won't get */
+ --theme-outline-box-shadow: initial;
+ }
+}
+
+.ruleview-property {
+ border-left: 3px solid transparent;
+ clear: both;
+ overflow-wrap: break-word;
+ /* When the text of the property wraps, we want the wrapping lines to have an indent so
+ they don't go under the checkbox */
+ text-indent: var(--rule-computed-margin-inline-start) hanging;
+}
+
+.ruleview-propertycontainer > * {
+ vertical-align: middle;
+}
+
+.ruleview-property.ruleview-changed,
+.ruleview-property[dirty] {
+ border-left-color: var(--theme-highlight-green);
+}
+
+.ruleview-highlight {
+ /*
+ * If we'd rely solely on background color change for highlighted element, we would need
+ * to pick a color that would bring at least 3:1 ratio (see 1.4.11 Non-text Contrast).
+ * As this would be too disturbing for the user, we need to indicate impacted element
+ * with another graphical mean.
+ * So here we'll use a bottom box-shadow (not a border to avoid impacting the layout)
+ * which will match the style we have in Debugger for search results.
+ */
+ background-color: var(--rule-highlight-background-color);
+ /* Put the box-shadow inside the element so it's still visible when sibling elements are highlighted */
+ box-shadow: inset 0px -1px 0px 0px var(--theme-contrast-border);
+
+
+ /* property name and value and unmatched/inactive colors need to be adjusted
+ in order to have enough contrast against the highlighted background */
+ & .ruleview-propertyname {
+ color: var(--rule-highlight-propertyname);
+ }
+
+ & .ruleview-propertyvalue {
+ color: var(--rule-highlight-propertyvalue);
+ }
+
+ &.ruleview-selector.unmatched,
+ & .ruleview-unmatched-variable,
+ .ruleview-property:is(.unused, .ruleview-overridden) & :is(.ruleview-propertyname, .ruleview-propertyvalue) {
+ color: var(--rule-highlight-unmatched-unused-color);
+ }
+}
+
+.ruleview-namecontainer > .ruleview-propertyname,
+.ruleview-propertyvaluecontainer > .ruleview-propertyvalue {
+ border-bottom: 1px dashed transparent;
+}
+
+.ruleview-namecontainer:hover > .ruleview-propertyname,
+.ruleview-propertyvaluecontainer:hover > .ruleview-propertyvalue {
+ border-bottom-color: hsl(0,0%,50%);
+}
+
+/* ancestor rules info element (parent at-rules, parent of nested rules, …) */
+.ruleview-rule-ancestor-data {
+ max-width: 100%;
+ display: inline-block;
+ list-style: none;
+ padding: 0;
+ margin: 0;
+}
+
+.ruleview-rule-ancestor-data [role="listitem"] {
+ /* When there's a search and this element is highlighted, this prevents the background
+ color to be applied to the whole width of the parent ul block */
+ max-width: max-content;
+}
+
+.ruleview-rule-ancestor-data [role="listitem"].has-tooltip:hover .container-query-declaration {
+ text-decoration: underline;
+ text-decoration-color: var(--theme-highlight-blue);
+ text-decoration-style: dotted;
+ text-decoration-skip-ink: none;
+ text-decoration-thickness: 2px;
+ text-underline-offset: 2px;
+}
+
+.ruleview-rule-ancestor-data [role="listitem"] :is(button,[role="button"]).open-inspector {
+ /* There's a space character after the button, so add a 1ch margin-inline-start to be consistent */
+ margin-inline: 1ch 0;
+}
+
+.ruleview-selectors-container,
+.ruleview-registered-property-name {
+ word-wrap: break-word;
+ cursor: text;
+}
+
+.ruleview-selector-separator,
+.ruleview-selector.unmatched,
+.ruleview-unmatched-variable,
+.ruleview-property:is(.unused, .ruleview-overridden) :is(.ruleview-propertyname,.ruleview-propertyvalue) {
+ color: var(--theme-text-color-alt);
+}
+
+/* We use a dimmer color for those unmatching element, but we can't convey state change
+ only with colors, so let's add a line-through line */
+:is(
+ .ruleview-selector.unmatched,
+ .ruleview-unmatched-variable
+):not(
+ /* don't show the strike through when the element is hovered so it's more legible */
+ :hover
+) {
+ text-decoration: line-through solid currentColor;
+}
+
+.ruleview-selector.matched > .ruleview-selector-attribute {
+ /* TODO: Bug 1178535 Awaiting UX feedback on highlight colors */
+}
+
+.ruleview-selector.matched > .ruleview-selector-pseudo-class {
+ /* TODO: Bug 1178535 Awaiting UX feedback on highlight colors */
+}
+
+.ruleview-selector.matched > .ruleview-selector-pseudo-class-lock {
+ color: var(--pseudo-class-text-color);
+}
+
+.ruleview-selector-warnings {
+ display: inline-block;
+ width: 16px;
+ height: 12px;
+ margin-inline-start: 2px;
+ vertical-align: text-top;
+ border-radius: 2px;
+
+ border: 1px solid var(--theme-warning-border);
+ background-color: var(--theme-warning-background);
+ background-repeat: no-repeat;
+ background-position: center;
+ fill: var(--theme-warning-color);
+ -moz-context-properties: fill;
+
+ /* Default warning icon */
+ background-image: url(chrome://devtools/skin/images/alert-small.svg);
+ background-size: 10px;
+
+ &.slow {
+ background-image: url(chrome://devtools/content/netmonitor/src/assets/icons/turtle.svg);
+ background-size: 12px;
+ }
+}
+
+/* When hovering the selector warnings icon, highlight the selector it applies to */
+.ruleview-selector:has(.ruleview-selector-warnings:hover) {
+ background-color: var(--theme-warning-background);
+ /* We're not using --theme-warning-border to make it more visible */
+ outline: 1px solid var(--theme-warning-color);
+
+ & .ruleview-selector-warnings {
+ /* In such case, hide the icon border to make it cleaner */
+ border-color: transparent;
+ }
+}
+
+.ruleview-selectorhighlighter {
+ display: inline-block;
+ border: none;
+ vertical-align: top;
+ width: 15px;
+ height: 15px;
+ margin-left: 5px;
+ background: url("chrome://devtools/skin/images/highlight-selector.svg") no-repeat 0 0;
+ background-size: contain;
+ cursor: pointer;
+ -moz-context-properties: fill;
+ fill: var(--theme-icon-dimmed-color);
+ /* Prevent line break when copy/pasting an entire rule */
+ user-select: auto;
+}
+
+.ruleview-selectorhighlighter:hover {
+ fill: var(--theme-icon-color);
+}
+
+.ruleview-selectorhighlighter:active,
+.ruleview-selectorhighlighter.highlighted {
+ fill: var(--theme-icon-checked-color);
+ /* Since the icon is quite thin, it can be hard to differentiate it
+ from its regular state. Adding some background helps make it pop a bit */
+ background-color: var(--dimmed-highlighter-box-content-color);
+}
+
+#ruleview-add-rule-button::before {
+ background-image: url("chrome://devtools/skin/images/add.svg");
+ background-size: 14px;
+}
+
+#pseudo-class-panel-toggle::before {
+ content: ":hov";
+}
+
+#class-panel-toggle::before {
+ content: ".cls";
+}
+
+#pseudo-class-panel-toggle::before,
+#class-panel-toggle::before {
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ font-weight: 600;
+ direction: ltr;
+}
+
+#print-simulation-toggle::before {
+ background-image: url("chrome://devtools/skin/images/rules-view-print-simulation.svg");
+}
+
+#color-scheme-simulation-light-toggle::before {
+ background-image: url("chrome://devtools/skin/images/rules-view-light-mode-simulation.svg");
+ -moz-context-properties: fill, stroke;
+ stroke: currentColor;
+}
+
+#color-scheme-simulation-dark-toggle::before {
+ background-image: url("chrome://devtools/skin/images/rules-view-dark-mode-simulation.svg");
+}
+
+.flash-out {
+ transition: background 1s;
+}
+
+.ruleview-propertyvalue-draggable {
+ cursor: col-resize;
+}
+
+.ruleview-propertyvalue-dragging {
+ user-select: none;
+}
+
+.ruleview-propertyvalue-break-spaces {
+ white-space: break-spaces;
+}