--- /dev/null
+/* 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/. */
+
+#downloadsRichListBox {
+ /** The default listbox appearance comes with an unwanted margin. **/
+ -moz-appearance: none;
+ margin: 0;
+ border: none;
+}
+
+#downloadsRichListBox > richlistitem.download {
+ height: 6em;
+ padding: 5px 8px;
+}
+
+.downloadTypeIcon {
+ -moz-margin-end: 8px;
+ -moz-margin-start: 8px;
+ /* Prevent flickering when changing states. */
+ min-height: 32px;
+ min-width: 32px;
+}
+
+.blockedIcon {
+ list-style-image: url("chrome://global/skin/icons/alert-error.gif");
+}
+
+.downloadTarget {
+ margin-bottom: 3px;
+ cursor: inherit;
+}
+
+.downloadDetails {
+ opacity: 0.7;
+ font-size: 95%;
+ cursor: inherit;
+}
+
+.downloadButton {
+ background: transparent;
+ min-width: 0;
+ min-height: 0;
+ margin: 3px;
+ border: none;
+ padding: 5px;
+ list-style-image: url("chrome://browser/skin/downloads/buttons.png");
+}
+
+/*** Highlighted list items ***/
+
+richlistitem.download:not([selected]):hover {
+ border-radius: 3px;
+ background-color: #794900;
+ color: #FFCF00;
+ cursor: pointer;
+}
+
+/*** Button icons ***/
+
+.downloadButton.downloadCancel {
+ -moz-image-region: rect(0px, 16px, 16px, 0px);
+}
+
+richlistitem.download:hover > .downloadButton.downloadCancel,
+richlistitem.download:hover > .downloadButton.downloadCancel:hover,
+richlistitem.download:hover > .downloadButton.downloadCancel:active {
+ -moz-image-region: rect(0px, 32px, 16px, 16px);
+}
+
+.downloadButton.downloadShow {
+ -moz-image-region: rect(16px, 16px, 32px, 0px);
+}
+
+richlistitem.download:hover > .downloadButton.downloadShow,
+richlistitem.download:hover > .downloadButton.downloadShow:hover,
+richlistitem.download:hover > .downloadButton.downloadShow:active {
+ -moz-image-region: rect(16px, 32px, 32px, 16px);
+}
+
+.downloadButton.downloadRetry {
+ -moz-image-region: rect(32px, 16px, 48px, 0px);
+}
+
+richlistitem.download:hover > .downloadButton.downloadRetry,
+richlistitem.download:hover > .downloadButton.downloadRetry:hover,
+richlistitem.download:hover > .downloadButton.downloadRetry:active {
+ -moz-image-region: rect(32px, 32px, 48px, 16px);
+}
+
+richlistitem.download[selected] > .downloadButton.downloadCancel,
+richlistitem.download[selected]:hover > .downloadButton.downloadCancel,
+richlistitem.download[selected]:hover > .downloadButton.downloadCancel:hover,
+richlistitem.download[selected]:hover > .downloadButton.downloadCancel:active {
+ -moz-image-region: rect(0px, 32px, 16px, 16px);
+}
+
+richlistitem.download[selected] > .downloadButton.downloadShow,
+richlistitem.download[selected]:hover > .downloadButton.downloadShow,
+richlistitem.download[selected]:hover > .downloadButton.downloadShow:hover,
+richlistitem.download[selected]:hover > .downloadButton.downloadShow:active {
+ -moz-image-region: rect(16px, 32px, 32px, 16px);
+}
+
+richlistitem.download[selected] > .downloadButton.downloadRetry,
+richlistitem.download[selected]:hover > .downloadButton.downloadRetry,
+richlistitem.download[selected]:hover > .downloadButton.downloadRetry:hover,
+richlistitem.download[selected]:hover > .downloadButton.downloadRetry:active {
+ -moz-image-region: rect(32px, 32px, 48px, 16px);
+}
/*** Panel and outer controls ***/
-#downloadsPanel > .panel-arrowcontainer > .panel-arrowcontent {
- /* Avoid that the arrow overlaps the selection on first item */
- padding-top: 5px;
-}
-
#downloadsPanel > .panel-arrowcontainer > .panel-arrowcontent {
padding: 0;
}
}
#downloadsHistory {
- background: transparent;
- color: #9C9CFF;
cursor: pointer;
+ margin: 4px !important;
+}
+
+#downloadsPanel[keyfocus] > #downloadsFooter > #downloadsHistory:focus {
+ outline: 1px #008484 dotted;
+ outline-offset: -1px;
}
#downloadsHistory > .button-box {
- margin: 1em;
+ border: none;
}
/*** Downloads Summary and List items ***/
#downloadsSummary {
padding: 8px 38px 8px 12px;
cursor: pointer;
+ -moz-user-focus: normal;
+}
+
+#downloadsPanel[keyfocus] > #downloadsFooter > #downloadsSummary:focus {
+ outline: 1px #008484 dotted;
+ outline-offset: -5px;
}
#downloadsSummary > .downloadTypeIcon {
- height: 24px;
- width: 24px;
- list-style-image: url("chrome://mozapps/skin/downloads/downloadIcon.png");
+ list-style-image: url("chrome://browser/skin/downloads/download-summary.png");
}
#downloadsSummaryDescription {
- color: -moz-nativehyperlinktext;
+ color: #3333FF;
}
richlistitem[type="download"] {
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 90% 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: 90%;
+}
+
+#downloadsSummaryDescription,
.downloadTarget {
margin-bottom: 6px;
cursor: inherit;
}
+.downloadTarget {
+ font-size: calc(100%/0.9);
+}
+
+#downloadsSummaryDetails,
.downloadDetails {
opacity: 0.6;
- font-size: 90%;
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");
}
.downloadButton > .button-box {
+ border: 1px solid transparent;
padding: 0;
}
+#downloadsPanel[keyfocus] .downloadButton:focus > .button-box {
+ border: 1px dotted #008484;
+}
+
/*** Highlighted list items ***/
-richlistitem[type="download"][state="1"]:hover {
+#downloadsPanel:not([keyfocus]) > #downloadsListBox > richlistitem[type="download"][state="1"]:hover {
+ border-radius: 3px;
background-color: #794900;
color: #FFCF00;
cursor: pointer;
.downloadButton.downloadCancel {
-moz-image-region: rect(0px, 16px, 16px, 0px);
}
-.downloadButton.downloadCancel:hover,
-.downloadButton.downloadCancel:active {
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadCancel,
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadCancel:hover,
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadCancel:active {
-moz-image-region: rect(0px, 32px, 16px, 16px);
}
.downloadButton.downloadShow {
-moz-image-region: rect(16px, 16px, 32px, 0px);
}
-.downloadButton.downloadShow:hover,
-.downloadButton.downloadShow:active {
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadShow,
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadShow:hover,
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadShow:active {
-moz-image-region: rect(16px, 32px, 32px, 16px);
}
.downloadButton.downloadRetry {
-moz-image-region: rect(32px, 16px, 48px, 0px);
}
-.downloadButton.downloadRetry:hover,
-.downloadButton.downloadRetry:active {
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadRetry,
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadRetry:hover,
+richlistitem[type="download"]:hover > stack > .downloadButton.downloadRetry:active {
-moz-image-region: rect(32px, 32px, 48px, 16px);
}
18, 108, 36, 90) center no-repeat;
}
+#downloads-indicator-icon:-moz-lwtheme-brighttext {
+/* background: -moz-image-rect(url("chrome://browser/skin/Toolbar-inverted.png"),
+ 0, 108, 18, 90) center no-repeat;*/
+}
+
#downloads-indicator[attention] > #downloads-indicator-anchor > #downloads-indicator-icon {
background-image: url("chrome://browser/skin/downloads/download-glow.png");
}
+/* In the next few rules, we use :not([counter]) as a shortcut that is
+ equivalent to -moz-any([progress], [paused]). */
+
#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;
18, 108, 36, 90) center no-repeat;
}
-/*** Event notification ***/
+/*** Download notifications ***/
#downloads-indicator-notification {
opacity: 0;
- background: url("chrome://browser/skin/downloads/download-notification.png")
- center no-repeat;
background-size: 16px;
+ background-position: center;
+ background-repeat: no-repeat;
}
-@keyframes downloadsIndicatorNotificationRight {
+@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 downloadsIndicatorNotificationLeft {
+@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-indicator[notification] > #downloads-indicator-anchor > #downloads-indicator-notification {
- animation-name: downloadsIndicatorNotificationRight;
+#downloads-indicator[notification="start"] > #downloads-indicator-anchor > #downloads-indicator-notification {
+ background-image: url("chrome://browser/skin/downloads/download-notification-start.png");
+ animation-name: downloadsIndicatorNotificationStartRight;
animation-duration: 1s;
}
-#downloads-indicator[notification]:-moz-locale-dir(rtl) > #downloads-indicator-anchor > #downloads-indicator-notification {
- animation-name: downloadsIndicatorNotificationLeft;
+#downloads-indicator[notification="start"]:-moz-locale-dir(rtl) > #downloads-indicator-anchor > #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-indicator[notification="finish"] > #downloads-indicator-anchor > #downloads-indicator-notification {
+ background-image: url("chrome://browser/skin/downloads/download-notification-finish.png");
+ animation-name: downloadsIndicatorNotificationFinish;
+ animation-duration: 1s;
}
/*** Progress bar and text ***/
text-align: center;
}
+#downloads-indicator-counter:-moz-lwtheme-brighttext {
+/* 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;
margin-bottom: 2px;
border-radius: 2px;
background-color: #795900;
- /*border: 1px solid #FFCF00;*/
}
#downloads-indicator-progress > .progress-bar {
#downloads-indicator-progress > .progress-remainder {
min-width: 0;
min-height: 0;
- background-color: #000000;
+ background-color: #A09090;
border-radius: 0 2px 2px 0;
}
}
#downloads-indicator[paused] > #downloads-indicator-anchor > #downloads-indicator-progress-area > #downloads-indicator-progress > .progress-remainder {
- background-color: #000000;
+ background-color: #404048;
}