12 Commits

Author SHA1 Message Date
94bfef19a1 Merge branch 'page-list-and-summary-css-cleanup' 2025-09-01 02:51:40 -05:00
9b2509c0d5 Change "Read more" to "See posts" on author summary card
I never noticed this; you can read more of an article, but it doesn't
really make any sense to "Read more" on an author.
2025-09-01 02:45:12 -05:00
c02ceb2dc4 Reorganize series page list and series summary card class names
- Use namespaced class names to prevent accidental name collisions in
  the future
- Clean up whatever the hell I was doing with the flex config on the
  outer series list. I have no clue why it's set up as a wrapping row,
  or what the border radius is for. It seems to look the same if I just
  make it a page-list that gets its gap overridden.
- Remove page.series wrapper around the summary card render which was
  accidentally left in after 8eb343132c6b57f692f87a72a5aca1bc9c563d1b.
2025-09-01 02:45:12 -05:00
8e22007bfd Rename feature-figure.html to featured-media and combine CSS with figures
- Rename feature-figure.html and its class from post-media to
  featured-media
- Move all <figure> formatting to a separate section
- Put the .featured-media CSS next to the rest of the figure formatting
  as it's sorta a special case of regular figure
2025-09-01 02:45:12 -05:00
1ee8d314c0 Rename summary card classes from .page to .summary-card 2025-09-01 02:44:57 -05:00
22fdeadf78 Move summary card CSS to a new fold section 2025-09-01 00:57:41 -05:00
6251b033d5 Move article.page wrapping to summary.html instead of at list template
I am trying to make various templates and partials act more like
self-contained components.

This is in preparation for #113.
2025-09-01 00:50:54 -05:00
37dbdc53af Use section tag for homepage latest posts section
This improves semantic HTML compliance.
2025-08-30 22:25:05 -05:00
ef91527ed6 Remove leftover additional-head partial
This was removed from use in d50a4dc6bd,
but the actual file was left in on accident.
2025-08-30 22:00:09 -05:00
4bc8184593 Add arrow in the right side of list page section buttons
This makes it more obvious that you can click this to view a different
area.
2025-08-27 11:38:29 -05:00
22e7ad4b77 Remove nested list-page-container to simplify layout CSS on section page
Originally I was using gap on a flexbox to separate the .sections
container from the rest of the page list. But it's simpler if I just use
block layout and a bottom margin, then I don't need an extra layer of
div.
2025-08-27 11:13:48 -05:00
c2b10a6c99 Use hierarchical naming on top and its elements
Any element that can't stand on its own as a self-contained component
should have its naming nested under whatever parent it's supposed to
have.

Fixes #109
2025-08-27 10:50:52 -05:00
14 changed files with 206 additions and 195 deletions

View File

@@ -174,30 +174,6 @@ video {
max-width: 100%; max-width: 100%;
} }
figure > .figure-media {
padding: 5px;
}
figure > .figure-media.border {
border: 2px solid var(--figure-border);
}
.post-media > figure > .figure-media {
border: 7px solid var(--figure-border);
}
figure {
display: block;
text-align: center;
margin: 0;
}
figcaption {
font-style: italic;
font-size: small;
text-align: center;
}
a { a {
color: var(--link-0); color: var(--link-0);
text-decoration: inherit; text-decoration: inherit;
@@ -340,7 +316,7 @@ body {
* or it will need its hover background to be chopped off on the left */ * or it will need its hover background to be chopped off on the left */
} }
.brand { .top-brand {
flex-grow: 1; flex-grow: 1;
margin: 8px var(--page-margin); margin: 8px var(--page-margin);
font-size: 1.25em; font-size: 1.25em;
@@ -348,27 +324,27 @@ body {
align-items: center; align-items: center;
} }
.brand a { .top-brand > a {
color: inherit; color: inherit;
font-weight: bold; font-weight: bold;
} }
.navbar { .top-navbar {
display: flex; display: flex;
flex-wrap: wrap; flex-wrap: wrap;
} }
.navbar-item { .top-navbar-item {
padding: 12px var(--page-margin); padding: 12px var(--page-margin);
white-space: nowrap; white-space: nowrap;
} }
.navbar-item:hover { .top-navbar-item:hover {
background-color: var(--background-2); background-color: var(--background-2);
text-decoration: none; text-decoration: none;
} }
.navbar-item.active { .top-navbar-item--active {
font-weight: bold; font-weight: bold;
} }
@@ -444,33 +420,26 @@ body {
/* }}} */ /* }}} */
/* List layout {{{ */ /* Summary card formatting {{{ */
/* flexbox container for sections and main page list */ .summary-card {
.list-page-container {
display: flex;
flex-direction: column;
gap: 40px;
}
.page-list {
display: flex;
flex-direction: column;
list-style: none;
padding: 0;
gap: 40px;
margin-top: 16px;
}
.page-list > .page {
padding: 24px; padding: 24px;
border-radius: 12px; border-radius: 12px;
background-color: var(--background-1); background-color: var(--background-1);
color: var(--text-1); color: var(--text-1);
} }
.page > .page-title { .summary-card-title {
margin-top: 0; margin-top: 0;
margin-bottom: 10px;
}
.summary-card-title a {
color: inherit;
}
.summary-card-title h1 {
margin: 0;
} }
/* hugo just can't handle this feature /* hugo just can't handle this feature
@@ -481,18 +450,6 @@ body {
} }
*/ */
.page-title {
margin-bottom: 10px;
}
.page-title a {
color: inherit;
}
.page-title h1 {
margin: 0;
}
.page-metadata { .page-metadata {
margin-bottom: 24px; margin-bottom: 24px;
} }
@@ -514,20 +471,74 @@ body {
content: ","; content: ",";
} }
.post-media { /* for formatting of the featured image/media, see the .featured-media class */
margin-top: 15px;
}
.page-description { .summary-card-description {
margin-top: 10px; margin-top: 10px;
} }
.readmore { .summary-card-readmore {
margin-top: 5px; margin-top: 5px;
} }
/* }}} */ /* }}} */
/* Figures, and featured media component (used in page.html and summary-card) {{{ */
figure > .figure-media {
padding: 5px;
}
figure > .figure-media.border {
border: 2px solid var(--figure-border);
}
figure {
display: block;
text-align: center;
margin: 0;
}
figcaption {
font-style: italic;
font-size: small;
text-align: center;
}
.featured-media {
margin-top: 15px;
}
.featured-media > figure > .figure-media {
border: 7px solid var(--figure-border);
}
/* }}} */
/* List layout {{{ */
.page-list {
display: flex;
flex-direction: column;
list-style: none;
padding: 0;
gap: 40px;
margin-top: 16px;
}
.page-title {
margin-bottom: 10px;
}
.page-title a {
color: inherit;
}
.page-title h1 {
margin: 0;
}
/* }}} */
/* Taxonomy list layout {{{ */ /* Taxonomy list layout {{{ */
.taxonomy-list a, .taxonomy-list a,
@@ -578,17 +589,11 @@ body {
/* Series list layout {{{ */ /* Series list layout {{{ */
.page-list.series { .page-list--series {
display: flex;
gap: 80px; gap: 80px;
flex-flow: row wrap;
list-style: none;
color: var(--text-0);
padding: 8px;
border-radius: 16px;
} }
.page-list.series-inner { .page-list--series-inner {
gap: 10px; gap: 10px;
flex-direction: row; flex-direction: row;
flex-flow: row wrap; flex-flow: row wrap;
@@ -597,7 +602,7 @@ body {
padding: 8px; padding: 8px;
border-radius: 16px; border-radius: 16px;
} }
.page-list.series-inner > .page { .page-list--series-inner > .summary-card {
flex: 1; flex: 1;
min-width: 49%; min-width: 49%;
} }
@@ -607,6 +612,7 @@ body {
/* Subsections on list pages {{{ */ /* Subsections on list pages {{{ */
.sections { .sections {
margin-bottom: 60px;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: 10px; gap: 10px;
@@ -617,6 +623,9 @@ body {
color: var(--text-1); color: var(--text-1);
border-radius: 12px; border-radius: 12px;
padding: 1px 25px; padding: 1px 25px;
display: flex;
flex-direction: row;
justify-content: space-between;
} }
.section:hover { .section:hover {
@@ -640,6 +649,16 @@ body {
margin-bottom: 5px; margin-bottom: 5px;
} }
.section-arrow {
margin-block: auto;
max-height: fit-content;
float: right;
}
.section-arrow > .icon {
height: 48px;
width: 48px;
}
/* }}} */ /* }}} */
@@ -769,16 +788,16 @@ body {
margin: var(--page-margin); margin: var(--page-margin);
} }
.related-posts .page { .related-posts .summary-card {
min-width: 300px; min-width: 300px;
max-width: 300px; max-width: 300px;
} }
.related-posts .page:first-child { .related-posts .summary-card:first-child {
margin-left: var(--page-margin); margin-left: var(--page-margin);
} }
.related-posts .page:last-child { .related-posts .summary-card:last-child {
margin-right: var(--page-margin); margin-right: var(--page-margin);
} }

View File

@@ -48,6 +48,8 @@ post_count:
# Navigation # Navigation
read_more: read_more:
other: "Read more" other: "Read more"
see_posts:
other: "See posts"
related_posts: related_posts:
other: "Related Posts" other: "Related Posts"

View File

@@ -1,4 +0,0 @@
{{/*
Create a file named `layouts/partials/additional-head.html` at your site root to
add extra tags into <head>. Page variables are passed.
*/}}

View File

@@ -1,5 +1,5 @@
{{ with .Resources.Get "feature" }} {{ with .Resources.Get "feature" }}
<div class="post-media"> <div class="featured-media">
<figure> <figure>
{{ partial "embed-resource.html" . }} {{ partial "embed-resource.html" . }}
{{ with .Title }} {{ with .Title }}

View File

@@ -1,9 +1,7 @@
<div class="page-list"> <div class="page-list">
{{ with . }} {{ with . }}
{{ range . }} {{ range . }}
<article class="page"> {{ .Render "summary" }}
{{ .Render "summary" }}
</article>
{{ end }} {{ end }}
{{ else }} {{ else }}
<div> <div>

View File

@@ -1,13 +1,13 @@
<header class="top"> <header class="top">
<div class="brand"> <div class="top-brand">
<a href="{{ .Site.Home.Permalink | absLangURL }}"> <a href="{{ .Site.Home.Permalink | absLangURL }}">
{{ .Site.Title | markdownify }} {{ .Site.Title | markdownify }}
</a> </a>
</div> </div>
<nav class="navbar" aria-label="{{ i18n "aria_navbar" }}"> <nav class="top-navbar" aria-label="{{ i18n "aria_navbar" }}">
{{ with .Site.Home }} {{ with .Site.Home }}
<a class="navbar-item{{ if $.IsHome }} active{{ end }}" href="{{ .Permalink | absLangURL }}">{{ .Title | markdownify }}</a> <a class="top-navbar-item{{ if $.IsHome }} top-navbar-item--active{{ end }}" href="{{ .Permalink | absLangURL }}">{{ .Title | markdownify }}</a>
{{ end }} {{ end }}
{{ range .Site.Menus.main }} {{ range .Site.Menus.main }}
@@ -16,7 +16,7 @@
{{ if or ($.HasMenuCurrent .Menu .) (eq .Page $) }} {{ if or ($.HasMenuCurrent .Menu .) (eq .Page $) }}
{{ $isActive = true }} {{ $isActive = true }}
{{ end }} {{ end }}
<a class="navbar-item{{ if $isActive }} active{{ end }}" <a class="top-navbar-item{{ if $isActive }} top-navbar-item--active{{ end }}"
{{ if strings.HasPrefix .URL "http" }}target="_blank" rel="noopener"{{ end }} {{ if strings.HasPrefix .URL "http" }}target="_blank" rel="noopener"{{ end }}
href="{{ .URL }}">{{ .Name }}</a> href="{{ .URL }}">{{ .Name }}</a>
{{ end }} {{ end }}

View File

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

View File

@@ -1,30 +1,22 @@
{{ define "main" }} {{ define "main" }}
<section> <h1>
{{ if .Content }}<article>{{ end }} {{ partial "icon.html" "user-circle" }}
{{ .Title | markdownify }}
</h1>
<h1> {{ with .Content }}
{{ partial "icon.html" "user-circle" }} {{ . }}
{{ .Title | markdownify }} {{ end }}
</h1>
{{ with .Content }} <div class="page-list">
{{ . }} {{ with .Paginator.Pages }}
{{ end }} {{ range . }}
{{ .Render "summary" }}
{{ if .Content }}</article>{{ end }}
<section class="page-list">
{{ with .Paginator.Pages }}
{{ range . }}
<article class="page">
{{ .Render "summary" }}
</article>
{{ end }}
{{ else }}
<div>
{{ i18n "no_posts" }}
</div>
{{ end }} {{ end }}
</section> {{ else }}
</section> <div>
{{ i18n "no_posts" }}
</div>
{{ end }}
</div>
{{ end }} {{ end }}

View File

@@ -23,7 +23,7 @@
</div> </div>
{{ end }} {{ end }}
{{ partial "feature-figure.html" . }} {{ partial "featured-media.html" . }}
<div class="post-content" data-pagefind-body> <div class="post-content" data-pagefind-body>
{{ .Content }} {{ .Content }}

View File

@@ -1,27 +1,23 @@
{{ define "main" }} {{ define "main" }}
<section> <h1>
<h1> {{ with .Params.icon }}{{ partial "icon.html" . }}{{ end }}
{{ with .Params.icon }}{{ partial "icon.html" . }}{{ end }} {{ .Title | markdownify }}
{{ .Title | markdownify }} {{ partial "rss-link.html" . }}
{{ partial "rss-link.html" . }} </h1>
</h1>
{{ with .Content }} {{ with .Content }}
{{ . }} {{ . }}
{{ end }} {{ end }}
<div class="list-page-container"> {{ with .Sections }}
{{ with .Sections }} <div class="sections">
<div class="sections"> {{ range . }}
{{ range . }} {{ .Render "summary" }}
{{ .Render "summary" }}
{{ end }}
</div>
{{ end }} {{ end }}
{{ partial "page-list.html" .Paginator.Pages }}
</div> </div>
{{ end }}
{{ partial "pagination.html" . }} {{ partial "page-list.html" .Paginator.Pages }}
</section>
{{ partial "pagination.html" . }}
{{ end }} {{ end }}

View File

@@ -1,14 +1,20 @@
<a class="section-anchor" href="{{ .Permalink }}"> <a class="section-anchor" href="{{ .Permalink }}">
<div class="section"> <div class="section">
<h2 class="section-title"> <div>
{{ with .Params.icon }}{{ partial "icon.html" . }}{{ end }} <h2 class="section-title">
{{ .Title | markdownify }} {{ with .Params.icon }}{{ partial "icon.html" . }}{{ end }}
</h2> {{ .Title | markdownify }}
</h2>
{{ with .Summary }} {{ with .Summary }}
<div class="section-description"> <div class="section-description">
{{ . }} {{ . }}
</div> </div>
{{ end }} {{ end }}
</div>
<div class="section-arrow">
{{ partial "icon.html" "arrow-right" }}
</div>
</div> </div>
</a> </a>

View File

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

View File

@@ -10,12 +10,10 @@
{{ . }} {{ . }}
{{ end }} {{ end }}
<div class="page-list series"> <div class="page-list page-list--series">
{{ with .Paginator.Pages }} {{ with .Paginator.Pages }}
{{ range . }} {{ range . }}
<div class="page series"> {{ .Render "summary" }}
{{ .Render "summary" }}
</div>
{{ end }} {{ end }}
{{ else }} {{ else }}
<div> <div>

View File

@@ -1,19 +1,21 @@
<h2 class="page-title"> <article class="summary-card">
{{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }} <h2 class="summary-card-title">
<a href="{{ .Permalink }}">{{ .Title | markdownify }}</a> {{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }}
{{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} <a href="{{ .Permalink }}">{{ .Title | markdownify }}</a>
</h2> {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }}
</h2>
{{ partial "page-metadata/post-short.html" . }} {{ partial "page-metadata/post-short.html" . }}
{{ partial "feature-figure.html" . }} {{ partial "featured-media.html" . }}
{{ with .Summary }} {{ with .Summary }}
<div class="page-description"> <div class="summary-card-description">
{{ . }} {{ . }}
</div>
{{ end }}
<div class="summary-card-readmore">
<a href="{{ .Permalink }}">{{ i18n "read_more" }} &rarr;</a>
</div> </div>
{{ end }} </article>
<div class="readmore">
<a href="{{ .Permalink }}">{{ i18n "read_more" }} &rarr;</a>
</div>