* 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/. */
-/*** Panel and outer controls ***/
-
-#downloadsHistory,
-#downloadsHistory:-moz-focusring > .button-box {
- border-bottom-left-radius: 6px;
- border-bottom-right-radius: 6px;
-}
+/* === BEGIN downloads.inc.css === */
-#downloadsPanel:not([hasdownloads]) > #downloadsHistory,
-#downloadsPanel:not([hasdownloads]) > #downloadsHistory:-moz-focusring > .button-box {
- border-top-left-radius: 6px;
- border-top-right-radius: 6px;
-}
+/*** Panel and outer controls ***/
#downloadsPanel > .panel-arrowcontainer > .panel-arrowcontent {
- /* Avoid that the arrow overlaps the selection on first item */
- padding-top: 5px;
+ overflow: hidden;
+ display: block;
}
-#downloadsPanel > .panel-arrowcontainer > .panel-arrowcontent {
+#downloadsPanel > .panel-arrowcontainer > .panel-arrowcontent,
+#downloadsPanel-multiView > .panel-viewcontainer > .panel-viewstack > .panel-subviews {
padding: 0;
}
background-color: transparent;
padding: 4px;
color: inherit;
+ margin: 0;
+ border: none;
+}
+
+#emptyDownloads {
+ padding: 16px 25px;
+ margin: 0;
+ /* The panel can be wider than this description after the blocked subview is
+ shown, so center the text. */
+ text-align: center;
+}
+
+.downloadsPanelFooter {
+/* background-color: var(--arrowpanel-dimmed);
+ border-top: 1px solid var(--panel-separator-color);*/
+}
+
+.downloadsPanelFooter toolbarseparator {
+ margin: 0;
+ border: 0;
+ min-width: 0;
+/* border-left: 1px solid var(--panel-separator-color);
+ -moz-appearance: none;*/
+}
+
+.downloadsPanelFooterButton {
+ margin: 0;
+ padding: 0;
+ min-width: 0;
+/* min-height: 40px;*/
+ border: none;
+}
+
+.downloadsPanelFooterButton:hover {
+}
+
+.downloadsPanelFooterButton:hover:active,
+.downloadsPanelFooterButton[open="true"] {
+}
+
+.downloadsPanelFooterButton[default] {
+}
+
+.downloadsPanelFooterButton[default]:hover {
+}
+
+.downloadsPanelFooterButton[default]:hover:active {
+}
+
+.downloadsPanelFooterButton > .button-box {
+ padding: 0;
+ margin: 0;
+ border: none;
}
#downloadsHistory {
- background: transparent;
- color: #9C9CFF;
+ padding-inline-start: 10px;
+ padding-inline-end: 10px;
+}
+
+#downloadsPanel[hasdownloads] #downloadsFooterButtons:not(.downloadsHideDropmarker) > #downloadsHistory {
+ padding-inline-start: 68px;
+}
+
+toolbarseparator.downloadsDropmarkerSplitter {
+ margin: 7px 0;
+}
+
+#downloadsFooter:hover toolbarseparator.downloadsDropmarkerSplitter,
+#downloadsFooter[showingdropdown] toolbarseparator {
+ margin: 0;
+}
+
+.downloadsDropmarker {
+ padding: 0 21px;
+}
+
+.downloadsDropmarker > .button-box > hbox {
+ display: none;
+}
+
+.downloadsDropmarker > .button-box > .button-menu-dropmarker {
+ display: -moz-box;
+ padding: 0;
+ margin: 0;
+}
+
+.downloadsDropmarker > .button-box > .button-menu-dropmarker > .dropmarker-icon {
+ width: 16px;
+ height: 16px;
+/* list-style-image: url("chrome://browser/skin/downloads/menubutton-dropmarker.svg");
+ filter: url("chrome://browser/skin/filters.svg#fill");
+ fill: currentColor;*/
+}
+
+/* Override default icon size which is too small for this dropdown */
+.downloadsDropmarker > .button-box > .button-menu-dropmarker {
+ width: 16px;
+ height: 16px;
+}
+
+#downloadsSummary {
+ padding: 0 12px;
cursor: pointer;
+ -moz-user-focus: normal;
}
-#downloadsHistory > .button-box {
- margin: 1em;
+#downloadsSummary > .downloadTypeIcon {
+ list-style-image: url("chrome://browser/skin/downloads/download-summary.svg");
}
-/*** List items ***/
+#downloadsSummaryDescription {
+ color: #3333FF;
+}
+
+/*** List items and similar elements in the summary ***/
+
+#downloadsSummary,
+richlistitem[type="download"] {
+ height: var(--downloads-item-height);
+ padding-inline-end: 0;
+ color: inherit;
+}
richlistitem[type="download"] {
- height: 7em;
margin: 0;
- border-bottom: 1px dotted #9C9CFF;
+ /*border-top: 1px solid var(--downloads-item-border-top-color);*/
+ border-bottom: 1px solid var(--downloads-item-border-bottom-color);
background: transparent;
padding: 8px;
- -moz-padding-end: 0;
- color: inherit;
}
richlistitem[type="download"]:first-child {
/* border-top: 1px solid transparent;*/
}
-#downloadsListBox:-moz-focusring > richlistitem[type="download"][selected] {
- outline: 1px #008484 dotted;
- outline-offset: -1px;
- -moz-outline-radius: 3px;
+.downloadTypeIcon {
+ margin-top: 8px;
+ margin-inline-end: 12px;
+ margin-bottom: 8px;
+ margin-inline-start: 0;
+ width: 32px;
+ height: 32px;
}
-.downloadTypeIcon {
- -moz-margin-end: 8px;
- /* Prevent flickering when changing states. */
- min-height: 32px;
- min-width: 32px;
+.downloadBlockedBadge {
+ margin: 0 4px;
+ background: url("chrome://browser/skin/downloads/download-blocked.svg") top right / 16px no-repeat;
+}
+
+downloadBlockedBadge:-moz-locale-dir(rtl) {
+ background-position-x: left;
+}
+
+richlistitem[type="download"][verdict="PotentiallyUnwanted"] .downloadBlockedBadge {
+ background-image: url("chrome://browser/skin/warning.svg");
+}
+
+richlistitem[type="download"][verdict="Uncommon"] .downloadBlockedBadge {
+ background-image: url("chrome://browser/skin/info.svg");
}
-.blockedIcon {
- list-style-image: url("chrome://global/skin/icons/alert-error.gif");
+/* We hold .downloadTarget, .downloadProgress and .downloadDetails inside of
+ a vbox with class .downloadContainer. We set the font-size of the entire
+ container to --downloads-item-font-size-factor because:
+
+ 1) This is the size that we want .downloadDetails to be
+ 2) The container's width is set by localizers by &downloadDetails.width;,
+ which is a ch unit. Since this is the value that should control the
+ panel width, we apply it to the outer container to constrain
+ .downloadTarget and .downloadProgress.
+
+ Finally, since we want .downloadTarget's font-size to be at 100% of the
+ font-size of .downloadContainer's parent, we use calc to go from the
+ smaller font-size back to the original font-size.
+ */
+#downloadsSummaryDetails,
+.downloadContainer {
+ font-size: calc(100% * var(--downloads-item-font-size-factor));
}
+#downloadsSummaryDescription,
.downloadTarget {
- margin-bottom: 6px;
+ margin-bottom: var(--downloads-item-target-margin-bottom);
cursor: inherit;
}
+.downloadTarget {
+ font-size: calc(100% / var(--downloads-item-font-size-factor));
+}
+
+#downloadsSummaryDetails,
.downloadDetails {
- opacity: 0.6;
- font-size: 90%;
+ margin-top: var(--downloads-item-details-margin-top);
+ opacity: var(--downloads-item-details-opacity);
cursor: inherit;
}
.downloadButton {
- -moz-appearance: none;
min-width: 0;
min-height: 0;
- margin: 6px;
- border: none;
+ margin: 3px;
+/* border: none; */
background: transparent;
padding: 5px;
list-style-image: url("chrome://browser/skin/downloads/buttons.png");
padding: 0;
}
-/*** Highlighted list items ***/
+/*** Blocked subview ***/
-richlistitem[type="download"][state="1"]:hover {
- background-color: #794900;
- color: #FFCF00;
- cursor: pointer;
+#downloadsPanel-multiView > .panel-viewcontainer > .panel-viewstack[viewtype=main] > .panel-subviews {
+ /* When the main view is showing, the shadow on the left edge of the subview is
+ barely visible on the right edge of the main view, so set it to none. */
+ box-shadow: none;
}
-/*** Button icons ***/
-
-.downloadButton.downloadCancel {
- -moz-image-region: rect(0px, 16px, 16px, 0px);
-}
-.downloadButton.downloadCancel:hover,
-.downloadButton.downloadCancel:active {
- -moz-image-region: rect(0px, 32px, 16px, 16px);
+/* When the subview is showing, turn the download button into an arrow pointing
+ back to the main view. */
+#downloadsPanel-multiView > .panel-viewcontainer > .panel-viewstack[viewtype="subview"] .download-state[showingsubview] .downloadButton {
+ list-style-image: url("chrome://browser/skin/customizableui/subView-arrow-back-inverted.png");
}
-.downloadButton.downloadShow {
- -moz-image-region: rect(16px, 16px, 32px, 0px);
+#downloadsPanel-multiView > .panel-viewcontainer > .panel-viewstack[viewtype="subview"] .download-state[showingsubview] .downloadButton:-moz-locale-dir(rtl) {
+ list-style-image: url("chrome://browser/skin/customizableui/subView-arrow-back-inverted-rtl.png");
}
-.downloadButton.downloadShow:hover,
-.downloadButton.downloadShow:active {
- -moz-image-region: rect(16px, 32px, 32px, 16px);
+
+#downloadsPanel-blockedSubview {
+ background-image: url("chrome://browser/skin/warning.svg");
+ background-size: 32px 32px;
+ background-position: 16px 16px;
+ background-repeat: no-repeat;
}
-.downloadButton.downloadRetry {
- -moz-image-region: rect(32px, 16px, 48px, 0px);
+#downloadsPanel-blockedSubview:-moz-locale-dir(rtl) {
+ background-position: calc(100% - 16px) 16px;
}
-.downloadButton.downloadRetry:hover,
-.downloadButton.downloadRetry:active {
- -moz-image-region: rect(32px, 32px, 48px, 16px);
+
+#downloadsPanel-blockedSubview[verdict=Malware] {
+ background-image: url("chrome://browser/skin/downloads/download-blocked.svg");
}
-/*** Status and progress indicator ***/
+#downloadsPanel-blockedSubview-title {
+ margin-top: 16px;
+ margin-bottom: 16px;
+ font-size: calc(100% / var(--downloads-item-font-size-factor));
+}
-#downloads-indicator {
- width: 35px;
+#downloadsPanel-blockedSubview-details1,
+#downloadsPanel-blockedSubview-details2 {
+ font-size: calc(100% * var(--downloads-item-font-size-factor));
+ margin-bottom: 16px;
+ opacity: var(--downloads-item-details-opacity);
}
-#downloads-indicator-anchor {
- min-width: 18px;
- min-height: 18px;
- /* Makes the outermost stack element positioned, so that its contents are
- rendered over the main browser window in the Z order. This is required by
- the animated event notification. */
- position: relative;
+#downloadsPanel-blockedSubview-title,
+#downloadsPanel-blockedSubview-details1,
+#downloadsPanel-blockedSubview-details2 {
+ -moz-margin-start: 64px;
+ -moz-margin-end: 16px;
}
-/*** Main indicator icon ***/
+/* === END downloads.inc.css === */
-#downloads-indicator-icon {
- background: -moz-image-rect(url("chrome://browser/skin/Toolbar.png"),
- 0, 108, 18, 90) center no-repeat;
+/*** Panel and outer controls ***/
+
+#downloadsSummary {
}
-#downloads-indicator:hover > #downloads-indicator-anchor > #downloads-indicator-icon,
-#downloads-indicator[attention]:hover > #downloads-indicator-anchor > #downloads-indicator-icon {
- background: -moz-image-rect(url("chrome://browser/skin/Toolbar.png"),
- 18, 108, 36, 90) center no-repeat;
+#downloadsSummary:hover {
}
-#downloads-indicator[attention] > #downloads-indicator-anchor > #downloads-indicator-icon {
- background: -moz-image-rect(url("chrome://browser/skin/downloads/download-glow.png"),
- 15, 33, 33, 15) center no-repeat;
+#downloadsSummary:hover:active {
}
-#downloads-indicator:not([counter]) > #downloads-indicator-anchor > #downloads-indicator-progress-area > #downloads-indicator-counter {
- background: -moz-image-rect(url("chrome://browser/skin/Toolbar.png"),
- 0, 108, 18, 90) center no-repeat;
- background-size: 12px;
+#downloadsPanel[keyfocus] #downloadsSummary:focus,
+#downloadsPanel[keyfocus] .downloadsPanelFooterButton:focus {
+ outline: 1px #008484 dotted;
+ outline-offset: -1px;
}
-#downloads-indicator:not([counter])[attention] > #downloads-indicator-anchor > #downloads-indicator-progress-area > #downloads-indicator-counter {
- background-image: -moz-image-rect(url("chrome://browser/skin/downloads/download-glow.png"),
- 16, 32, 32, 16);
+#downloadsPanel[keyfocus] #downloadsSummary:focus {
+ outline-offset: -5px;
}
-#downloads-indicator:not([counter]):hover > #downloads-indicator-anchor > #downloads-indicator-progress-area > #downloads-indicator-counter,
-#downloads-indicator:not([counter])[attention]:hover > #downloads-indicator-anchor > #downloads-indicator-progress-area > #downloads-indicator-counter {
- background: -moz-image-rect(url("chrome://browser/skin/Toolbar.png"),
- 18, 108, 36, 90) center no-repeat;
+richlistitem[type="download"][showingsubview] {
+ background-color: Highlight;
+ color: HighlightText;
+ transition: background-color var(--panelui-subview-transition-duration),
+ color var(--panelui-subview-transition-duration);
}
-/*** Event notification ***/
+#downloadsPanel:not([keyfocus]) richlistitem[type="download"][state="1"][exists][verdict="Malware"]:hover,
+#downloadsPanel:not([keyfocus]) richlistitem[type="download"][state="1"][exists][verdict="Malware"]:hover:active,
+richlistitem[type="download"][showingsubview][verdict="Malware"] {
+ background-color: hsl(4, 82%, 47%);
+ color: white;
+}
-#downloads-indicator-notification {
- opacity: 0;
- background: url("chrome://browser/skin/downloads/download-notification.png")
- center no-repeat;
- background-size: 16px;
+
+/*** List items and similar elements in the summary ***/
+
+:root {
+ --downloads-item-height: 7em;
+ /*--downloads-item-border-top-color: hsla(0,0%,100%,.3);*/
+ --downloads-item-border-bottom-color: #9C9CFF;
+ --downloads-item-font-size-factor: 0.9;
+ --downloads-item-target-margin-bottom: 6px;
+ --downloads-item-details-margin-top: 0;
+ --downloads-item-details-opacity: 0.6;
}
-@keyframes downloadsIndicatorNotificationRight {
- from { opacity: 0; transform: translate(-128px, 128px) scale(8); }
- 20% { opacity: .85; animation-timing-function: ease-out; }
- to { opacity: 0; transform: translate(0) scale(1); }
+.downloadButton > .button-box {
+ border: 1px solid transparent;
}
-@keyframes downloadsIndicatorNotificationLeft {
- from { opacity: 0; transform: translate(128px, 128px) scale(8); }
- 20% { opacity: .85; animation-timing-function: ease-out; }
- to { opacity: 0; transform: translate(0) scale(1); }
+#downloadsPanel[keyfocus] .downloadButton:focus > .button-box {
+ border: 1px dotted #008484;
}
-#downloads-indicator[notification] > #downloads-indicator-anchor > #downloads-indicator-notification {
- animation-name: downloadsIndicatorNotificationRight;
- animation-duration: 1s;
+richlistitem[type="download"][verdict="PotentiallyUnwanted"] .blockedIcon {
+ list-style-image: url("chrome://global/skin/icons/warning.svg");
}
-#downloads-indicator[notification]:-moz-locale-dir(rtl) > #downloads-indicator-anchor > #downloads-indicator-notification {
- animation-name: downloadsIndicatorNotificationLeft;
+richlistitem[type="download"][verdict="Uncommon"] .blockedIcon {
+ list-style-image: url("chrome://global/skin/icons/information-32.png");
}
-/*** Progress bar and text ***/
+/*** Highlighted list items ***/
-#downloads-indicator-counter {
- height: 10px;
- margin: 0;
+#downloadsListBox:-moz-focusring > richlistitem[type="download"][selected] {
+ outline: 1px #008484 dotted;
+ outline-offset: -1px;
+ /*-moz-outline-radius: 3px;*/
+}
+
+/* #downloadsPanel:not([keyfocus]) > #downloadsListBox > richlistitem[type="download"][state="1"][exists]:hover { */
+#downloadsPanel:not([keyfocus]) > #downloadsListBox > richlistitem[type="download"]:hover {
+ border-radius: 3px;
+ background-color: #794900;
color: #FFCF00;
- font-size: 10px;
- line-height: 10px;
- text-align: center;
+ cursor: pointer;
}
-#downloads-indicator-progress {
- width: 16px;
- height: 6px;
- min-width: 0;
- min-height: 0;
- margin-top: 1px;
- margin-bottom: 2px;
- border-radius: 2px;
- background-color: #795900;
- /*border: 1px solid #FFCF00;*/
+#downloadsPanel:not([keyfocus]) > #downloadsListBox > richlistitem[type="download"][state="1"][exists]:hover:active {
}
-#downloads-indicator-progress > .progress-bar {
- -moz-appearance: none;
- min-width: 0;
- min-height: 0;
- background-color: #008484;
- border-radius: 2px 0 0 2px;
+/*** Button icons ***/
+
+.downloadButton.downloadIconCancel {
+ -moz-image-region: rect(0px, 16px, 16px, 0px);
+}
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadIconCancel,
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadIconCancel:hover,
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadIconCancel:active {
+ -moz-image-region: rect(0px, 32px, 16px, 16px);
}
-#downloads-indicator-progress > .progress-remainder {
- min-width: 0;
- min-height: 0;
- background-color: #000000;
- border-radius: 0 2px 2px 0;
+.downloadButton.downloadIconShow {
+ -moz-image-region: rect(16px, 16px, 32px, 0px);
+}
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadIconShow,
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadIconShow:hover,
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadIconShow:active {
+ -moz-image-region: rect(16px, 32px, 32px, 16px);
+}
+
+.downloadButton.downloadIconRetry {
+ -moz-image-region: rect(32px, 16px, 48px, 0px);
+}
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadIconRetry,
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadIconRetry:hover,
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadIconRetry:active {
+ -moz-image-region: rect(32px, 32px, 48px, 16px);
}
-#downloads-indicator[paused] > #downloads-indicator-anchor > #downloads-indicator-progress-area > #downloads-indicator-progress > .progress-bar {
- background-color: #8050B0;
+.downloadButton.downloadShowBlockedInfo {
+ -moz-image-region: rect(48px, 16px, 64px, 0px);
+}
+richlistitem[type="download"]:hover .downloadButton.downloadShowBlockedInfo,
+richlistitem[type="download"]:hover .downloadButton.downloadShowBlockedInfo:hover,
+richlistitem[type="download"]:hover .downloadButton.downloadShowBlockedInfo:active {
+/* -moz-image-region: rect(48px, 32px, 64px, 16px);*/
}
-#downloads-indicator[paused] > #downloads-indicator-anchor > #downloads-indicator-progress-area > #downloads-indicator-progress > .progress-remainder {
- background-color: #000000;
+.downloadButton.downloadShowBlockedInfo:-moz-locale-dir(rtl) {
+ -moz-image-region: rect(64px, 16px, 80px, 0px);
+}
+richlistitem[type="download"]:hover .downloadButton.downloadShowBlockedInfo:-moz-locale-dir(rtl),
+richlistitem[type="download"]:hover .downloadButton.downloadShowBlockedInfo:hover:-moz-locale-dir(rtl),
+richlistitem[type="download"]:hover .downloadButton.downloadShowBlockedInfo:active:-moz-locale-dir(rtl) {
+/* -moz-image-region: rect(64px, 32px, 80px, 16px);*/
}