/* 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/. */ /*** Status and progress indicator ***/ #downloads-animation-container { min-height: 1px; min-width: 1px; height: 1px; margin-bottom: -1px; /* Makes the outermost animation container 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; /* The selected tab may overlap #downloads-indicator-notification */ z-index: 5; } /*** Main indicator icon ***/ @media not all and (min-resolution: 1.1dppx) { #downloads-button { --downloads-indicator-icon: -moz-image-rect(url("chrome://browser/skin/Toolbar.png"), 0, 198, 18, 180); --downloads-indicator-icon-attention: -moz-image-rect(url("chrome://browser/skin/Toolbar.png"), 18, 198, 36, 180); --downloads-indicator-icon-inverted: -moz-image-rect(url("chrome://browser/skin/Toolbar-inverted.png"), 0, 198, 18, 180); --downloads-indicator-icon-attention-inverted: -moz-image-rect(url("chrome://browser/skin/Toolbar-inverted.png"), 18, 198, 36, 180); } } @media (min-resolution: 1.1dppx) { #downloads-button { --downloads-indicator-icon: -moz-image-rect(url("chrome://browser/skin/Toolbar@2x.png"), 0, 396, 36, 360); --downloads-indicator-icon-attention: -moz-image-rect(url("chrome://browser/skin/Toolbar@2x.png"), 36, 396, 72, 360); --downloads-indicator-icon-inverted: -moz-image-rect(url("chrome://browser/skin/Toolbar-inverted@2x.png"), 0, 396, 36, 360); --downloads-indicator-icon-attention-inverted: -moz-image-rect(url("chrome://browser/skin/Toolbar-inverted@2x.png"), 36, 396, 72, 360); } } #downloads-indicator-icon { background: var(--downloads-indicator-icon) center no-repeat; width: 18px; height: 18px; background-size: 18px; } toolbar[brighttext] #downloads-button:not([attention="success"]) > #downloads-indicator-anchor > #downloads-indicator-icon { background-image: var(--downloads-indicator-icon-inverted); } #downloads-button[attention="warning"] > .toolbarbutton-badge-stack > .toolbarbutton-badge, #downloads-button[attention="severe"] > .toolbarbutton-badge-stack > .toolbarbutton-badge { display: -moz-box; height: 8px; width: 8px; min-width: 0; border-radius: 50%; /* "!important" is necessary to override the rule in toolbarbutton.css */ margin-top: -1px !important; margin-right: -2px !important; } #downloads-button[cui-areatype="toolbar"] > .toolbarbutton-badge-stack > .toolbarbutton-badge { height: 7px; width: 7px; } #downloads-button[attention="severe"] > .toolbarbutton-badge-stack > .toolbarbutton-badge { background: #D90000; } #downloads-button[attention="warning"] > .toolbarbutton-badge-stack > .toolbarbutton-badge { background: #FFBF00; } #downloads-button[attention="severe"] > .toolbarbutton-badge-stack > .toolbarbutton-badge:-moz-window-inactive, #downloads-button[attention="warning"] > .toolbarbutton-badge-stack > .toolbarbutton-badge:-moz-window-inactive { filter: none; } #downloads-button[attention="success"] > #downloads-indicator-anchor > #downloads-indicator-icon { background-image: var(--downloads-indicator-icon-attention); } toolbar[brighttext] #downloads-button[attention="success"] > #downloads-indicator-anchor > #downloads-indicator-icon { background-image: var(--downloads-indicator-icon-attention-inverted); } #downloads-button[cui-areatype="menu-panel"][attention="success"] { list-style-image: url("chrome://browser/skin/downloads/download-glow-menuPanel.png"); -moz-image-region: auto; } /* In the next few rules, we use :not([counter]) as a shortcut that is equivalent to -moz-any([progress], [paused]). */ #downloads-button:not([counter]) > #downloads-indicator-anchor > #downloads-indicator-progress-area > #downloads-indicator-counter { background: var(--downloads-indicator-icon) center no-repeat; background-size: 12px; } toolbar[brighttext] #downloads-button:not([counter]):not([attention="success"]) > #downloads-indicator-anchor > #downloads-button-progress-area > #downloads-indicator-counter { background-image: var(--downloads-indicator-icon-inverted); } #downloads-button:not([counter])[attention="success"] > #downloads-indicator-anchor > #downloads-indicator-progress-area > #downloads-indicator-counter { background-image: var(--downloads-indicator-icon-attention); } toolbar[brighttext] #downloads-button:not([counter])[attention="success"] > #downloads-indicator-anchor > #downloads-indicator-progress-area > #downloads-indicator-counter { background-image: var(--downloads-indicator-icon-attention-inverted); } /*** Download notifications ***/ #downloads-indicator-notification { opacity: 0; background-size: 16px; background-position: center; background-repeat: no-repeat; width: 16px; height: 16px; } @keyframes downloadsIndicatorNotificationStartRight { 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); } } @keyframes downloadsIndicatorNotificationStartLeft { 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); } } #downloads-notification-anchor[notification="start"] > #downloads-indicator-notification { background-image: url("chrome://browser/skin/downloads/download-notification-start.png"); animation-name: downloadsIndicatorNotificationStartRight; animation-duration: 1s; } #downloads-notification-anchor[notification="start"]:-moz-locale-dir(rtl) > #downloads-indicator-notification { animation-name: downloadsIndicatorNotificationStartLeft; } @keyframes downloadsIndicatorNotificationFinish { from { opacity: 0; transform: scale(1); } 20% { opacity: .65; animation-timing-function: ease-in; } to { opacity: 0; transform: scale(8); } } #downloads-notification-anchor[notification="finish"] > #downloads-indicator-notification { background-image: url("chrome://browser/skin/downloads/download-notification-finish.png"); animation-name: downloadsIndicatorNotificationFinish; animation-duration: 1s; } /*** Progress bar and text ***/ #downloads-indicator-counter { height: 9px; margin: -3px 0px 0px 0px; color: hsl(0,0%,30%); text-shadow: hsla(0,0%,100%,.5) 0 1px; font-size: 9px; line-height: 9px; text-align: center; /* Bug 812345 added this... */ margin-bottom: -1px; } toolbar[brighttext] #downloads-indicator-counter { color: white; text-shadow: 0 0 1px rgba(0,0,0,.7), 0 1px 1.5px rgba(0,0,0,.5); } #downloads-indicator-progress { width: 16px; height: 5px; min-width: 0; min-height: 0; margin-top: 1px; margin-bottom: 2px; border-radius: 2px; box-shadow: 0 1px 0 hsla(0,0%,100%,.4); } #downloads-indicator-progress > .progress-bar { -moz-appearance: none; min-width: 0; min-height: 0; /* The background-clip: border-box; and background-image: none; are there to expand the background-color behind the border */ background-clip: padding-box, border-box; background-color: rgb(90, 201, 66); background-image: linear-gradient(transparent 1px, rgba(255, 255, 255, 0.4) 1px, rgba(255, 255, 255, 0.4) 2px, transparent 2px), none; border: 1px solid; border-color: rgba(0,43,86,.6) rgba(0,43,86,.4) rgba(0,43,86,.4); border-radius: 2px 0 0 2px; } #downloads-indicator-progress > .progress-remainder { -moz-appearance: none; min-width: 0; min-height: 0; background-image: linear-gradient(#505050, #575757); border: 1px solid; border-color: hsla(0,0%,0%,.6) hsla(0,0%,0%,.4) hsla(0,0%,0%,.4); border-inline-start: none; border-radius: 0 2px 2px 0; } #downloads-button[paused] > #downloads-indicator-anchor > #downloads-indicator-progress-area > #downloads-indicator-progress > .progress-bar { background-color: rgb(220, 230, 81); } #downloads-button[paused] > #downloads-indicator-anchor > #downloads-indicator-progress-area > #downloads-indicator-progress > .progress-remainder { background-image: linear-gradient(#4b5000, #515700); }