1
0
Fork 0
mirror of https://git.sr.ht/~seirdy/seirdy.one synced 2024-09-20 04:12:09 +00:00

Stylesheet: better print theme, simpler dark theme

- Better print stylesheet, now with a file dedicated just for print
  style improvements.
- Hide extra stuff in print.
- Bring back navbar for print because it also tells users the current
  section and the site name.
- Dark theme: make superscripts bold instead of using a higher-contrast
  color.
This commit is contained in:
Rohan Kumar 2022-04-27 08:41:36 -07:00
parent f964152072
commit 8597e50a59
No known key found for this signature in database
GPG key ID: 1E892DB2A5F84479
4 changed files with 67 additions and 49 deletions

View file

@ -1,13 +1,17 @@
/* The dark stylesheet is the only place we set custom colors besides
* border colors for inline text. Make sure the perceptual contrast
* stays within the ideal APCA ranges, not lower and preferably not
* higher either. */
@media (prefers-color-scheme: dark) { @media (prefers-color-scheme: dark) {
/* I've been told that pure white on black is a bit harsh */
html { html {
color: #e9e9e9; /* Pure white on black causes halation.
} * "background" is short for a bunch of unnecessary CSS rules
html {
/* "background" is short for a bunch of unnecessary CSS rules
* background-color is all I need */ * background-color is all I need */
background-color: #111; background-color: #111;
/* Dimming the default text color is not the same as reducing screen
* brightness, since other colors in this stylesheet have brighter
* red and blue channels than the default text. */
color: #e9e9e9;
} }
/* Only color <a> if it's a link; if href is empty, let it be. */ /* Only color <a> if it's a link; if href is empty, let it be. */
@ -20,20 +24,7 @@
} }
a:visited { a:visited {
color: #ffd6ff; color: #fdf;
}
sup a:link {
color: #f3f0cb;
}
sup a:visited {
color: #ffdfff;
}
:not(pre) > code,
:not(pre) > samp {
border-color: #555;
} }
/* stylelint-disable -- hasn't heard of "prefers-contrast" yet */ /* stylelint-disable -- hasn't heard of "prefers-contrast" yet */

View file

@ -2,9 +2,9 @@
* Nothing here exists purely for aesthetics except the unstyled-list; * Nothing here exists purely for aesthetics except the unstyled-list;
* everything else addresses a specific a11y, compatibility, or critical * everything else addresses a specific a11y, compatibility, or critical
* usability need. * usability need.
* I also don't use any classes besides unstyled-list and pixelated. My * I also don't use any classes besides "unstyled-list" and "pix". My
* HTML contains microformats2 classnames for IndieWeb parsers, but I * HTML contains microformats2 classnames for IndieWeb parsers, but I
* don't actually use those. */ * don't actually use those for styling. */
html { html {
/* Mobile screens benefit from greater line-spacing so links are /* Mobile screens benefit from greater line-spacing so links are
@ -12,18 +12,11 @@ html {
* <100dpi screens: sans-serif is better. Why did browsers settle * <100dpi screens: sans-serif is better. Why did browsers settle
* on serif being the default?? */ * on serif being the default?? */
font: 100%/1.5 sans-serif; font: 100%/1.5 sans-serif;
/* Aligning to the center with space on both sides prevents accidental
* link activation on mobile devices. */
margin: auto;
} }
/* WCAG recommends a max line width. Not everyone can resize the /* This should not take effect on printouts, to save paper. */
* viewport.
* This should not take effect on printouts, to save paper. */
@media screen { @media screen {
/* 45em is the lowest reasonable width for titles, nav, footers, etc */ body {
html {
/* Default font sizes are one-size-fits-all; they're optimized for a /* Default font sizes are one-size-fits-all; they're optimized for a
* wide variety of complex pages. For single-column websites like * wide variety of complex pages. For single-column websites like
* mine, it's ideal to bump it up ever so slightly. This also makes * mine, it's ideal to bump it up ever so slightly. This also makes
@ -33,6 +26,13 @@ html {
* and cost paper + ink. */ * and cost paper + ink. */
font-size: 105%; font-size: 105%;
/* Aligning to the center with space on both sides prevents accidental
* link activation on tablets. */
margin: auto;
/* WCAG recommends a max line width. Not everyone can resize the
* viewport.
* 45em is the lowest reasonable width for titles, nav, footers, etc */
max-width: 45em; max-width: 45em;
padding: 0 2%; padding: 0 2%;
} }
@ -44,6 +44,15 @@ html {
} }
} }
/* Small text is easier to read when slightly bolder.
* This is important in the dark theme where I set my own colors and
* try to maintain good perceptual contrast even for small text, but
* I don't want toggling the theme to impact anything besides color so
* I set the weight here. */
sup {
font-weight: 600;
}
/* narrow screens: reduce margin for blockquotes a lot, using /* narrow screens: reduce margin for blockquotes a lot, using
* a thick left-side border instead. */ * a thick left-side border instead. */
blockquote { blockquote {
@ -68,8 +77,8 @@ dd {
ol ol, ol ol,
ul ul { ul ul {
padding-left: 1em;
hyphens: auto; hyphens: auto;
padding-left: 1em;
} }
/* Narrow screens: allow hyphenating titles /* Narrow screens: allow hyphenating titles
@ -100,15 +109,6 @@ h1 {
} }
} }
/* Print: anchor links and nav are useless in printouts. Hide them. */
@media print {
a[aria-hidden],
header nav,
footer nav {
display: none;
}
}
/* <kbd> should be distinguished from <code> and surrounding text /* <kbd> should be distinguished from <code> and surrounding text
* in a way beyond font-face; at least two visual distinctions needed */ * in a way beyond font-face; at least two visual distinctions needed */
kbd { kbd {
@ -121,7 +121,6 @@ kbd {
* be some extra space. */ * be some extra space. */
figure { figure {
margin: 1.5em 0; margin: 1.5em 0;
page-break-inside: avoid;
} }
/* figcaptions should be distinct from surrounding paragraphs tho */ /* figcaptions should be distinct from surrounding paragraphs tho */
@ -188,14 +187,15 @@ pre,
border: 1px solid; border: 1px solid;
} }
.pix {
image-rendering: pixelated;
}
/* A black border is too harsh. */ /* A black border is too harsh. */
:not(pre) > code, :not(pre) > code,
:not(pre) > samp { :not(pre) > samp {
border-color: #aaa; border-color: #999;
}
/* Some images look blurry when scaled */
.pix {
image-rendering: pixelated;
} }
/* center images that aren't my indieweb icon; same justification as /* center images that aren't my indieweb icon; same justification as
@ -227,14 +227,16 @@ div[role="doc-endnotes"] {
/* For browsers that don't support :focus-visible */ /* For browsers that don't support :focus-visible */
a:focus, a:focus,
[tabindex]:focus { summary:focus,
pre[tabindex]:focus {
outline: 3px solid; outline: 3px solid;
} }
/* Remove :focus styling for browsers that do support :focus-visible */ /* Remove :focus styling for browsers that do support :focus-visible */
@supports selector(:focus-visible) { @supports selector(:focus-visible) {
a:focus:not(:focus-visible), a:focus:not(:focus-visible),
[tabindex]:focus:not(:focus-visible) { summary:focus:not(:focus-visible),
pre[tabindex]:focus:not(:focus-visible) {
outline: none; outline: none;
} }
} }

24
assets/css/print.css Normal file
View file

@ -0,0 +1,24 @@
/* Print stylesheet: hide stuff that we don't need. */
@media print {
/* Currently only used for transcripts */
details,
/* Currently only used for anchors */
span[aria-hidden],
/* You can't navigate in a printout. */
footer nav {
display: none;
}
}
/* Print: don't orphan headings */
h2,
h3,
h4 {
break-after: avoid;
}
figure,
article article,
div[role="doc-endnotes"] ol li {
break-inside: avoid;
}

View file

@ -41,6 +41,7 @@
{{- if not (eq $dark "off") -}} {{- if not (eq $dark "off") -}}
{{ $resources = $resources | append (resources.Get "css/dark.css" | resources.ExecuteAsTemplate "dark.css" .) -}} {{ $resources = $resources | append (resources.Get "css/dark.css" | resources.ExecuteAsTemplate "dark.css" .) -}}
{{- end -}} {{- end -}}
{{ $resources = $resources | append (resources.Get "css/print.css" | resources.ExecuteAsTemplate "print.css" .) -}}
{{- $css := $resources | resources.Concat "css/style.css" | minify -}} {{- $css := $resources | resources.Concat "css/style.css" | minify -}}
<style>{{ $css.Content | safeCSS }}</style> <style>{{ $css.Content | safeCSS }}</style>
<meta property="og:title" content="{{ .Title }}"> <meta property="og:title" content="{{ .Title }}">