Simplify usage of CSS background-image
This commit is contained in:
parent
64c9903660
commit
6fe09722ea
9 changed files with 57 additions and 24 deletions
|
@ -126,16 +126,13 @@ impl Context<'_> {
|
|||
emit: &[EmitType],
|
||||
) -> Result<(), Error> {
|
||||
let tmp;
|
||||
let contents =
|
||||
contents.replace("data-url(minus-17x17.png)", static_files::MINUS_PNG_DATAURL);
|
||||
let contents = contents.replace("data-url(plus-17x17.png)", static_files::PLUS_PNG_DATAURL);
|
||||
let contents = if minify {
|
||||
tmp = if resource.extension() == Some(&OsStr::new("css")) {
|
||||
minifier::css::minify(&contents).map_err(|e| {
|
||||
minifier::css::minify(contents).map_err(|e| {
|
||||
Error::new(format!("failed to minify CSS file: {}", e), resource.path(self))
|
||||
})?
|
||||
} else {
|
||||
minifier::js::minify(&contents)
|
||||
minifier::js::minify(contents)
|
||||
};
|
||||
tmp.as_bytes()
|
||||
} else {
|
||||
|
@ -178,9 +175,45 @@ pub(super) fn write_shared(
|
|||
cx.write_shared(SharedResource::InvocationSpecific { basename: p }, content, &options.emit)
|
||||
};
|
||||
|
||||
fn add_background_image_to_css(
|
||||
cx: &Context<'_>,
|
||||
css: &mut String,
|
||||
rule: &str,
|
||||
file: &'static str,
|
||||
) {
|
||||
css.push_str(&format!(
|
||||
"{} {{ background-image: url({}); }}",
|
||||
rule,
|
||||
SharedResource::ToolchainSpecific { basename: file }
|
||||
.path(cx)
|
||||
.file_name()
|
||||
.unwrap()
|
||||
.to_str()
|
||||
.unwrap()
|
||||
))
|
||||
}
|
||||
|
||||
// Add all the static files. These may already exist, but we just
|
||||
// overwrite them anyway to make sure that they're fresh and up-to-date.
|
||||
let mut rustdoc_css = static_files::RUSTDOC_CSS.to_owned();
|
||||
add_background_image_to_css(
|
||||
cx,
|
||||
&mut rustdoc_css,
|
||||
"details.undocumented[open] > summary::before, \
|
||||
details.rustdoc-toggle[open] > summary::before, \
|
||||
details.rustdoc-toggle[open] > summary.hideme::before",
|
||||
"toggle-minus.svg",
|
||||
);
|
||||
add_background_image_to_css(
|
||||
cx,
|
||||
&mut rustdoc_css,
|
||||
"details.undocumented > summary::before, details.rustdoc-toggle > summary::before",
|
||||
"toggle-plus.svg",
|
||||
);
|
||||
write_minify("rustdoc.css", &rustdoc_css)?;
|
||||
|
||||
// Add all the static files. These may already exist, but we just
|
||||
// overwrite them anyway to make sure that they're fresh and up-to-date.
|
||||
write_minify("rustdoc.css", static_files::RUSTDOC_CSS)?;
|
||||
write_minify("settings.css", static_files::SETTINGS_CSS)?;
|
||||
write_minify("noscript.css", static_files::NOSCRIPT_CSS)?;
|
||||
|
||||
|
@ -220,6 +253,8 @@ pub(super) fn write_shared(
|
|||
write_toolchain("wheel.svg", static_files::WHEEL_SVG)?;
|
||||
write_toolchain("clipboard.svg", static_files::CLIPBOARD_SVG)?;
|
||||
write_toolchain("down-arrow.svg", static_files::DOWN_ARROW_SVG)?;
|
||||
write_toolchain("toggle-minus.svg", static_files::TOGGLE_MINUS_PNG)?;
|
||||
write_toolchain("toggle-plus.svg", static_files::TOGGLE_PLUS_PNG)?;
|
||||
|
||||
let mut themes: Vec<&String> = themes.iter().collect();
|
||||
themes.sort();
|
||||
|
|
|
@ -1512,7 +1512,8 @@ details.rustdoc-toggle > summary::before {
|
|||
cursor: pointer;
|
||||
width: 17px;
|
||||
height: max(17px, 1.1em);
|
||||
background: data-url(plus-17x17.png) no-repeat top left;
|
||||
background-repeat: no-repeat;
|
||||
background-position: top left;
|
||||
display: inline-block;
|
||||
vertical-align: middle;
|
||||
opacity: .5;
|
||||
|
@ -1533,10 +1534,6 @@ details.rustdoc-toggle > summary.hideme::after {
|
|||
content: "";
|
||||
}
|
||||
|
||||
details.rustdoc-toggle > summary:focus::before {
|
||||
outline: dotted 1px;
|
||||
}
|
||||
|
||||
details.rustdoc-toggle > summary:focus::before,
|
||||
details.rustdoc-toggle > summary:hover::before {
|
||||
opacity: 1;
|
||||
|
@ -1591,7 +1588,8 @@ details.rustdoc-toggle[open] > summary::before,
|
|||
details.rustdoc-toggle[open] > summary.hideme::before {
|
||||
width: 17px;
|
||||
height: max(17px, 1.1em);
|
||||
background: data-url(minus-17x17.png) no-repeat top left;
|
||||
background-repeat: no-repeat;
|
||||
background-position: top left;
|
||||
display: inline-block;
|
||||
content: "";
|
||||
}
|
||||
|
@ -1604,7 +1602,8 @@ details.rustdoc-toggle[open] > summary.hideme::after {
|
|||
details.undocumented > summary::before {
|
||||
padding-left: 17px;
|
||||
height: max(17px, 1.1em);
|
||||
background: data-url(plus-17x17.png) no-repeat top left;
|
||||
background-repeat: no-repeat;
|
||||
background-position: top left;
|
||||
content: "Show hidden undocumented items";
|
||||
cursor: pointer;
|
||||
font-size: 16px;
|
||||
|
@ -1612,10 +1611,6 @@ details.undocumented > summary::before {
|
|||
opacity: .5;
|
||||
}
|
||||
|
||||
details.undocumented > summary:focus::before {
|
||||
outline: dotted 1px;
|
||||
}
|
||||
|
||||
details.undocumented > summary:focus::before,
|
||||
details.undocumented > summary:hover::before {
|
||||
opacity: 1;
|
||||
|
@ -1624,7 +1619,8 @@ details.undocumented > summary:hover::before {
|
|||
details.undocumented[open] > summary::before {
|
||||
padding-left: 17px;
|
||||
height: max(17px, 1.1em);
|
||||
background: data-url(minus-17x17.png) no-repeat top left;
|
||||
background-repeat: no-repeat
|
||||
background-position: top left;
|
||||
content: "Hide undocumented items";
|
||||
}
|
||||
|
||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 3.1 KiB |
|
@ -1 +0,0 @@
|
|||
url()
|
Binary file not shown.
Before Width: | Height: | Size: 3.3 KiB |
|
@ -1 +0,0 @@
|
|||
url()
|
1
src/librustdoc/html/static/images/toggle-minus.svg
Normal file
1
src/librustdoc/html/static/images/toggle-minus.svg
Normal file
|
@ -0,0 +1 @@
|
|||
<svg width="17" height="17" shape-rendering="crispEdges" stroke="#000" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M5 2.5H2.5v12H5m7-12h2.5v12H12M5 8.5h7"/></svg>
|
After Width: | Height: | Size: 174 B |
1
src/librustdoc/html/static/images/toggle-plus.svg
Normal file
1
src/librustdoc/html/static/images/toggle-plus.svg
Normal file
|
@ -0,0 +1 @@
|
|||
<svg width="17" height="17" shape-rendering="crispEdges" stroke="#000" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M5 2.5H2.5v12H5m7-12h2.5v12H12M5 8.5h7M8.5 12V8.625v0V5"/></svg>
|
After Width: | Height: | Size: 191 B |
|
@ -47,6 +47,12 @@ crate static CLIPBOARD_SVG: &[u8] = include_bytes!("static/images/clipboard.svg"
|
|||
/// The file contents of `down-arrow.svg`, the icon used for the crate choice combobox.
|
||||
crate static DOWN_ARROW_SVG: &[u8] = include_bytes!("static/images/down-arrow.svg");
|
||||
|
||||
/// The file contents of `toggle-minus.svg`, the icon used for opened toggles.
|
||||
crate static TOGGLE_MINUS_PNG: &[u8] = include_bytes!("static/images/toggle-minus.svg");
|
||||
|
||||
/// The file contents of `toggle-plus.svg`, the icon used for closed toggles.
|
||||
crate static TOGGLE_PLUS_PNG: &[u8] = include_bytes!("static/images/toggle-plus.svg");
|
||||
|
||||
/// The contents of `COPYRIGHT.txt`, the license listing for files distributed with documentation
|
||||
/// output.
|
||||
crate static COPYRIGHT: &[u8] = include_bytes!("static/COPYRIGHT.txt");
|
||||
|
@ -64,10 +70,6 @@ crate static RUST_FAVICON_SVG: &[u8] = include_bytes!("static/images/favicon.svg
|
|||
crate static RUST_FAVICON_PNG_16: &[u8] = include_bytes!("static/images/favicon-16x16.png");
|
||||
crate static RUST_FAVICON_PNG_32: &[u8] = include_bytes!("static/images/favicon-32x32.png");
|
||||
|
||||
/// The pixel art buttons
|
||||
crate static MINUS_PNG_DATAURL: &str = include_str!("static/images/minus-17x17.png.url");
|
||||
crate static PLUS_PNG_DATAURL: &str = include_str!("static/images/plus-17x17.png.url");
|
||||
|
||||
crate static PAGE: &str = include_str!("templates/page.html");
|
||||
|
||||
/// The built-in themes given to every documentation site.
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue