File: progressmeter.css

package info (click to toggle)
firefox 141.0.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,550,588 kB
  • sloc: cpp: 7,426,506; javascript: 6,367,238; ansic: 3,707,351; python: 1,369,002; xml: 623,983; asm: 426,918; java: 184,324; sh: 64,488; makefile: 19,203; objc: 13,059; perl: 12,955; yacc: 4,583; cs: 3,846; pascal: 3,352; lex: 1,720; ruby: 1,071; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10
file content (84 lines) | stat: -rw-r--r-- 2,707 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/* 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/. */

/*** Common-styled progressmeter ***/

:root {
  --download-progress-fill-color: var(--toolbarbutton-icon-fill-attention);
  --download-progress-paused-color: GrayText;
  --download-progress-flare-color: rgba(255, 255, 255, 0.75);
}

@media (prefers-color-scheme: dark) {
  #contentAreaDownloadsView {
    --download-progress-fill-color: var(--in-content-item-selected);
  }
}

/*
 * Styling "html:progress" is limited by the fact that a number of properties
 * are intentionally locked at the UA stylesheet level. We have to use a border
 * instead of an outline because the latter would be drawn over the progress
 * bar and we cannot change its z-index. This means we have to use a negative
 * margin, except when the value is zero, and adjust the width calculation for
 * the indeterminate state.
 */

.downloadProgress {
  appearance: none;
  display: flex;
  margin-block: 5px 1px;
  /* This value is kinda odd, it's used to align with the edge of the badge,
   * if shown, which is inside the edge of the image (the image gets 16px
   * margin). */
  margin-inline-end: 18px;
  border: none;
  height: 4px;
  border-radius: 2px;
  background-color: color-mix(in srgb, currentColor 15%, transparent);
}

/* Ensure we have contrast in selected download items */
#downloadsListBox.allDownloadsListBox richlistitem[selected] .downloadProgress::-moz-progress-bar {
  --download-progress-fill-color: currentColor;
  --download-progress-flare-color: AccentColor;
}

.downloadProgress::-moz-progress-bar {
  appearance: none;
  background-color: var(--download-progress-fill-color);
  border-radius: 2px;
}

.downloadProgress[paused]::-moz-progress-bar {
  background-color: var(--download-progress-paused-color);
}

.downloadProgress:indeterminate::-moz-progress-bar {
  width: calc(100% + 2px);
  /* Make a white reflecting animation.
     Create a gradient with 2 identical patterns, and enlarge the size to 200%.
     This allows us to animate background-position with percentage. */
  background-color: var(--download-progress-fill-color);
  background-image: linear-gradient(
    90deg,
    transparent 0%,
    var(--download-progress-flare-color) 25%,
    transparent 50%,
    var(--download-progress-flare-color) 75%,
    transparent 100%
  );
  background-blend-mode: normal;
  background-size: 200% 100%;
  animation: downloadProgressSlideX 1.5s linear infinite;
}

@keyframes downloadProgressSlideX {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -100% 0;
  }
}