1 Commits

Author SHA1 Message Date
7780ccb376 WIP: use template to generate the individual share buttons 2025-07-30 01:59:40 -05:00
15 changed files with 127 additions and 117 deletions

View File

@@ -158,38 +158,61 @@ pre > code {
/* }}} */ /* }}} */
/* Common distances/sizes {{{ */ /* Basic elements {{{ */
:root { html {
--page-margin: 16px; scroll-behavior: smooth;
} }
/* }}} */ @media screen and (prefers-reduced-motion: reduce) {
html {
scroll-behavior: auto;
}
}
body {
background-color: var(--background-0);
color: var(--text-0);
overflow-wrap: break-word;
margin: 0;
}
/* Common elements {{{ */ .main-container {
margin: 20px auto;
padding: 0 20px;
max-width: 760px; /* 720px + 20px for left & right padding */
}
footer {
margin: 20px 0;
text-align: center;
font-size: smaller;
}
footer p {
margin: 0;
}
img, img,
video { video {
max-width: 100%; max-width: 100%;
} }
figure > .figure-media { .post-media > figure img,
.post-media > figure video {
padding: 5px; padding: 5px;
}
figure > .figure-media.border {
border: 2px solid var(--figure-border);
}
.post-media > figure > .figure-media {
border: 7px solid var(--figure-border); border: 7px solid var(--figure-border);
} }
figure img,
figure video {
padding: 5px;
border: 2px solid var(--figure-border);
}
figure { figure {
display: block; margin: auto;
text-align: center; display: inline-block;
margin: 0;
} }
figcaption { figcaption {
@@ -217,6 +240,14 @@ hr {
border: 1px solid var(--background-3); border: 1px solid var(--background-3);
} }
@media (min-width: 720px) {
.full-width-hr {
/* see also: the related-posts section too */
margin-left: calc(-100vw / 2 + 760px / 2);
margin-right: calc(-100vw / 2 + 760px / 2);
}
}
table.simple { table.simple {
border-collapse: collapse; border-collapse: collapse;
border: 2px solid var(--text-1); border: 2px solid var(--text-1);
@@ -276,40 +307,12 @@ table.simple tbody tr:nth-child(even) {
/* }}} */ /* }}} */
/* Baseof formatting {{{ */ /* Heading formatting (article section titles) {{{ */
html { /* this is also used i.e. in page-title */
scroll-behavior: smooth; .heading-link {
} color: inherit;
font-weight: bold;
@media screen and (prefers-reduced-motion: reduce) {
html {
scroll-behavior: auto;
}
}
body {
background-color: var(--background-0);
color: var(--text-0);
overflow-wrap: break-word;
margin: 0;
}
.main-container {
margin: var(--page-margin) auto;
/* use padding because otherwise there's no way to have margin be both auto, and a minimum value */
padding: 0 var(--page-margin);
max-width: calc(720px + 2 * var(--page-margin)); /* padding is included in the element's width */
}
footer {
margin: var(--page-margin) 0;
text-align: center;
font-size: smaller;
}
footer p {
margin: 0;
} }
/* }}} */ /* }}} */
@@ -322,30 +325,23 @@ footer p {
flex-wrap: wrap; flex-wrap: wrap;
justify-content: space-between; justify-content: space-between;
background-color: var(--background-1); background-color: var(--background-1);
/* padding can't be here because then the first navbar element will be shifted too far over,
* or it will need its hover background to be chopped off on the left */
} }
.header { .header {
flex-grow: 1; flex-grow: 1;
margin: 8px var(--page-margin); margin: 8px 16px;
font-size: 1.25em; font-size: 1.25em;
display: flex; display: flex;
align-items: center; align-items: center;
} }
.header a {
color: inherit;
font-weight: bold;
}
.navbar { .navbar {
display: flex; display: flex;
flex-wrap: wrap; flex-wrap: wrap;
} }
.navbar-item { .navbar-item {
padding: 12px var(--page-margin); padding: 12px 16px;
white-space: nowrap; white-space: nowrap;
} }
@@ -379,7 +375,7 @@ footer p {
/* Breadcrumb navigation {{{ */ /* Breadcrumb navigation {{{ */
.breadcrumb { .breadcrumb {
margin: var(--page-margin) 0; margin: 20px 0;
} }
.breadcrumb ul { .breadcrumb ul {
@@ -487,10 +483,6 @@ footer p {
margin-bottom: 10px; margin-bottom: 10px;
} }
.page-title a {
color: inherit;
}
.page-title h1 { .page-title h1 {
margin: 0; margin: 0;
} }
@@ -641,7 +633,7 @@ footer p {
/* }}} */ /* }}} */
/* Components exclusive to content/single pages {{{ */ /* Content (single) formatting {{{ */
.series-box { .series-box {
background-color: var(--background-1); background-color: var(--background-1);
@@ -881,16 +873,19 @@ aside.quote {
/* }}} */ /* }}} */
/* }}} */
/* Related posts section {{{ */ /* Related posts section {{{ */
/* set the margins on the contents instead of the parent .related-posts .full-width-page-list {
* so that the posts in the list clip off the edge of the screen, /* make left/right 0 margin so it takes up full width */
* which makes a more obvious indicator that it's scrollable margin: 25px 0;
*/ }
.related-posts > hr, .related-posts > hr,
.related-posts > h1 { .related-posts > h1 {
margin: var(--page-margin); margin-left: 20px;
margin-right: 20px;
} }
.related-posts .page { .related-posts .page {
@@ -900,24 +895,21 @@ aside.quote {
} }
.related-posts .page:first-child { .related-posts .page:first-child {
margin-left: var(--page-margin); margin-left: 20px;
} }
.related-posts .page:last-child { .related-posts .page:last-child {
margin-right: var(--page-margin); margin-right: 20px;
} }
.related-posts .page-list { .related-posts .page-list {
display: flex; display: flex;
flex-direction: row; flex-direction: row;
gap: 20px; gap: 20px;
overflow-x: auto; overflow-x: scroll;
margin-bottom: var(--page-margin);
} }
/* }}} */ /* }}} */
/* }}} */
/* @media specializations {{{ */ /* @media specializations {{{ */

View File

@@ -0,0 +1,7 @@
{{ with .Description }}
<p>{{ . | markdownify }}</p>
{{ else }}
{{ with .Summary }}
{{ . }}
{{ end }}
{{ end }}

View File

@@ -3,9 +3,9 @@
* claims that images won't work with JS disabled since it would * claims that images won't work with JS disabled since it would
* make tracking possible, but my experience says otherwise * make tracking possible, but my experience says otherwise
*/}} */}}
<img class="figure-media" src="{{ .Permalink }}" {{ with .Params.alt }}alt="{{ . }}"{{ end }} /> <img src="{{ .Permalink }}" {{ with .Params.alt }}alt="{{ . }}"{{ end }} />
{{ else if eq .ResourceType "video" }} {{ else if eq .ResourceType "video" }}
<video class="figure-media" controls preload="metadata"> <video controls preload="metadata">
{{ with .Params.alt }} {{ with .Params.alt }}
{{ warnf "video does not support alt text, '%s'" . }} {{ warnf "video does not support alt text, '%s'" . }}
{{ end }} {{ end }}

View File

@@ -1,6 +1,6 @@
{{ if gt .Paginator.TotalPages 1 }} {{ if gt .Paginator.TotalPages 1 }}
<nav class="pagination"> <nav class="pagination">
{{/* https://github.com/gohugoio/hugo/blob/a88b488181279befd50e1d127f9f67604f2f9854/tpl/tplimpl/embedded/templates/_partials/pagination.html */}} {{/* https://github.com/gohugoio/hugo/blob/a88b488181279befd50e1d127f9f67604f2f9854/tpl/tplimpl/embedded/templates/_partials/pagination.html */}}
{{ partial "pagination-hugo.html" . }} {{ partial "_internal/pagination.html" . }}
</nav> </nav>
{{ end }} {{ end }}

View File

@@ -1,4 +1,22 @@
{{ define "_partials/share-button.html" }}
<a class="{{ .ShortName }}-share"
target="_blank"
rel="noopener"
aria-label="{{ i18n (printf "aria_share_%s" .ShortName) }}"
onclick="share_event('{{ .ProperName }}');"
href="{{ .URL }}">
{{- partial "icon.html" (or .IconName .ShortName) -}}
</a>
{{ end }}
<div class="share-buttons"> <div class="share-buttons">
{{ $services := dict
"twitter" (dict "ProperName" "Twitter" "URL" (printf "https://twitter.com/intent/tweet?url=%s&text=%s&via=bbaovanc" .Permalink .Title))
}}
{{ range $name, $info := $services }}
{{ $data := merge $info (dict "ShortName" $name) }}
{{ partial "share-button.html" $data }}
{{ end }}
{{ if .Site.Params.shareButtons.twitter }} {{ if .Site.Params.shareButtons.twitter }}
<a class="twitter-share" <a class="twitter-share"
target="_blank" target="_blank"

View File

@@ -1,6 +1,6 @@
<div class="top"> <div class="top">
<header class="header"> <header class="header">
<a href="{{ .Site.Home.Permalink | absLangURL }}"> <a class="heading-link" href="{{ .Site.Home.Permalink | absLangURL }}">
{{ .Site.Title | markdownify }} {{ .Site.Title | markdownify }}
</a> </a>
</header> </header>

View File

@@ -0,0 +1 @@
<hr class="full-width-hr">

View File

@@ -1,15 +1,13 @@
<h2 class="page-title"> <h2 class="page-title">
<a href="{{ .Permalink }}">{{ .Title | markdownify }}</a> <a class="heading-link" href="{{ .Permalink }}">{{ .Title | markdownify }}</a>
{{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }}
</h2> </h2>
{{ partial "page-metadata/author.html" . }} {{ partial "page-metadata/author.html" . }}
{{ with .Summary }} <div class="page-description">
<div class="page-description"> {{ partial "description-or-summary.html" . }}
{{ . }} </div>
</div>
{{ end }}
<div class="readmore"> <div class="readmore">
<a href="{{ .Permalink }}">{{ i18n "read_more" }} &rarr;</a> <a href="{{ .Permalink }}">{{ i18n "read_more" }} &rarr;</a>

View File

@@ -13,28 +13,28 @@
{{ partial "breadcrumb.html" . }} {{ partial "breadcrumb.html" . }}
{{ end }} {{ end }}
<main id="main-content"> <main id="main-content" {{ if .IsPage }}data-pagefind-body{{ end }}>
{{ block "main" . }} {{ block "main" . }}
THIS TEXT SHOULD NOT SHOW. YUZSIQGHE (that string is so I can grep for it) THIS TEXT SHOULD NOT SHOW. YUZSIQGHE (that string is so I can grep for it)
{{ end }} {{ end }}
</main> </main>
{{ if or .Site.Copyright .Site.Params.footer }}
<footer>
{{ with .Site.Copyright }}
{{ . | safeHTML }}
{{ end }}
{{ with .Site.Params.footer }}
{{ . | $.RenderString (dict "display" "block") }}
{{ end }}
</footer>
{{ end }}
</div> </div>
{{ block "post-body" . }} {{ block "post-body" . }}
{{/* currently this is only used for related posts */}} {{/* currently this is only used for related posts */}}
{{ end }} {{ end }}
{{ if or .Site.Copyright .Site.Params.footer }}
<footer>
{{ with .Site.Copyright }}
{{ . | safeHTML }}
{{ end }}
{{ with .Site.Params.footer }}
{{ . | $.RenderString (dict "display" "block") }}
{{ end }}
</footer>
{{ end }}
</body> </body>
</html> </html>

View File

@@ -24,7 +24,7 @@
{{ partial "feature-figure.html" . }} {{ partial "feature-figure.html" . }}
<article class="post-content" data-pagefind-body> <article class="post-content">
{{ .Content }} {{ .Content }}
</article> </article>

View File

@@ -5,10 +5,8 @@
{{ .Title | markdownify }} {{ .Title | markdownify }}
</h2> </h2>
{{ with .Summary }} <div class="section-description">
<div class="section-description"> {{ partial "description-or-summary.html" . }}
{{ . }} </div>
</div>
{{ end }}
</div> </div>
</a> </a>

View File

@@ -1,16 +1,14 @@
<h2 class="page-title"> <h2 class="page-title">
{{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }} {{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }}
<a href="{{ .Permalink }}">{{ .Title | markdownify }}</a> <a class="heading-link" href="{{ .Permalink }}">{{ .Title | markdownify }}</a>
{{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }}
</h2> </h2>
{{ partial "page-metadata/series.html" . }} {{ partial "page-metadata/series.html" . }}
{{ with .Summary }} <div class="page-description">
<div class="page-description"> {{ partial "description-or-summary.html" . }}
{{ . }} </div>
</div>
{{ end }}
<div class="page-list series-inner"> <div class="page-list series-inner">
{{ range .Data.Pages.Reverse }} {{ range .Data.Pages.Reverse }}

View File

@@ -1,6 +1,6 @@
<h2 class="page-title"> <h2 class="page-title">
{{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }} {{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }}
<a href="{{ .Permalink }}">{{ .Title | markdownify }}</a> <a class="heading-link" href="{{ .Permalink }}">{{ .Title | markdownify }}</a>
{{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }}
</h2> </h2>
@@ -8,11 +8,9 @@
{{ partial "feature-figure.html" . }} {{ partial "feature-figure.html" . }}
{{ with .Summary }} <div class="page-description">
<div class="page-description"> {{ partial "description-or-summary.html" . }}
{{ . }} </div>
</div>
{{ end }}
<div class="readmore"> <div class="readmore">
<a href="{{ .Permalink }}">{{ i18n "read_more" }} &rarr;</a> <a href="{{ .Permalink }}">{{ i18n "read_more" }} &rarr;</a>

View File

@@ -28,7 +28,7 @@
</a> </a>
{{ partial "page-metadata/taxonomy.html" . }} {{ partial "page-metadata/taxonomy.html" . }}
</div> </div>
{{ .Summary }} {{ partial "description-or-summary.html" . }}
</article> </article>
{{ end }} {{ end }}
{{ end }} {{ end }}