4 Commits

Author SHA1 Message Date
f9481a6e7f WIP 2025-08-24 02:35:25 -05:00
8083b1a299 WIP 2025-08-24 02:25:12 -05:00
314b533698 WIP 2025-08-22 19:51:15 -05:00
00a0f64be4 WIP body-module and smarter usage of container divs 2025-08-22 12:11:24 -05:00
30 changed files with 489 additions and 448 deletions

View File

@@ -174,6 +174,30 @@ 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;
@@ -271,20 +295,40 @@ body {
margin: 0; margin: 0;
} }
.main-container { /* body-module types:
margin: var(--page-margin) auto; *
/* use padding because otherwise there's no way to have margin be both auto, and a minimum value */ * full-width: no max-width, no margin from the sides of the page
padding: 0 var(--page-margin); * full-padded: no max-width, but has margin from the left/right page edges
max-width: calc(720px + 2 * var(--page-margin)); /* padding is included in the element's width */ * center: max-width 720px, centered when too large, padded when screen is narrow
*/
.body-module--full-width,
.body-module--full-padded,
.body-module--center-wide {
margin-block: var(--page-margin);
} }
.site-footer { .body-module--full-width {
margin: var(--page-margin) 0; margin-inline: 0;
}
.body-module-full-padded {
margin-inline: var(--page-margin);
}
.body-module--center {
margin-inline: auto;
/* add the minimum margin here because we are using auto for its centering */
padding-inline: var(--page-margin);
/* account for the padding being included in the element's calculated width */
max-width: calc(720px + 2 * var(--page-margin));
}
footer {
margin-bottom: var(--page-margin);
text-align: center; text-align: center;
font-size: smaller; font-size: smaller;
} }
.site-footer p { footer p {
margin: 0; margin: 0;
} }
@@ -316,7 +360,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 */
} }
.top-brand { .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;
@@ -324,27 +368,27 @@ body {
align-items: center; align-items: center;
} }
.top-brand > a { .brand a {
color: inherit; color: inherit;
font-weight: bold; font-weight: bold;
} }
.top-navbar { .navbar {
display: flex; display: flex;
flex-wrap: wrap; flex-wrap: wrap;
} }
.top-navbar-item { .navbar-item {
padding: 12px var(--page-margin); padding: 12px var(--page-margin);
white-space: nowrap; white-space: nowrap;
} }
.top-navbar-item:hover { .navbar-item:hover {
background-color: var(--background-2); background-color: var(--background-2);
text-decoration: none; text-decoration: none;
} }
.top-navbar-item--active { .navbar-item.active {
font-weight: bold; font-weight: bold;
} }
@@ -352,10 +396,6 @@ body {
/* Breadcrumb navigation {{{ */ /* Breadcrumb navigation {{{ */
.breadcrumb {
margin: var(--page-margin) 0;
}
.breadcrumb ul { .breadcrumb ul {
margin: 0; margin: 0;
padding: 0; padding: 0;
@@ -420,26 +460,33 @@ body {
/* }}} */ /* }}} */
/* Summary card formatting {{{ */ /* List layout {{{ */
.summary-card { /* flexbox container for sections and main page list */
.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);
} }
.summary-card-title { .page > .page-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
@@ -450,6 +497,18 @@ 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;
} }
@@ -471,74 +530,20 @@ body {
content: ","; content: ",";
} }
/* for formatting of the featured image/media, see the .featured-media class */ .post-media {
margin-top: 15px;
}
.summary-card-description { .page-description {
margin-top: 10px; margin-top: 10px;
} }
.summary-card-readmore { .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,
@@ -589,11 +594,17 @@ figcaption {
/* 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;
@@ -602,7 +613,7 @@ figcaption {
padding: 8px; padding: 8px;
border-radius: 16px; border-radius: 16px;
} }
.page-list--series-inner > .summary-card { .page-list.series-inner > .page {
flex: 1; flex: 1;
min-width: 49%; min-width: 49%;
} }
@@ -612,53 +623,39 @@ figcaption {
/* 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;
} }
.section-card { .section {
background-color: var(--background-1); background-color: var(--background-1);
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-card:hover { .section:hover {
background-color: var(--background-2); background-color: var(--background-2);
color: var(--text-2); color: var(--text-2);
} }
.section-card-title { .section-title {
margin: 10px 0; margin: 10px 0;
} }
.section-card-anchor { .section-anchor {
color: inherit; color: inherit;
} }
.section-card-anchor:hover { .section-anchor:hover {
text-decoration: none; text-decoration: none;
} }
.section-card-description { .section-description {
margin-bottom: 5px; margin-bottom: 5px;
} }
.section-card-arrow {
margin-block: auto;
max-height: fit-content;
float: right;
}
.section-card-arrow > .icon {
height: 48px;
width: 48px;
}
/* }}} */ /* }}} */
@@ -784,20 +781,20 @@ figcaption {
*/ */
.related-posts > hr, .related-posts > hr,
.related-posts > h2 { .related-posts > h1 {
margin: var(--page-margin); margin: var(--page-margin);
} }
.related-posts .summary-card { .related-posts .page {
min-width: 300px; min-width: 300px;
max-width: 300px; max-width: 300px;
} }
.related-posts .summary-card:first-child { .related-posts .page:first-child {
margin-left: var(--page-margin); margin-left: var(--page-margin);
} }
.related-posts .summary-card:last-child { .related-posts .page:last-child {
margin-right: var(--page-margin); margin-right: var(--page-margin);
} }
@@ -823,7 +820,7 @@ figcaption {
background-color: var(--background-1); background-color: var(--background-1);
border-radius: 8px; border-radius: 8px;
} }
.code-block-header { .code-block > .code-header {
display: flex; display: flex;
flex-direction: row; flex-direction: row;
justify-content: space-between; justify-content: space-between;
@@ -833,17 +830,17 @@ figcaption {
border-top-right-radius: 8px; border-top-right-radius: 8px;
height: 2em; height: 2em;
} }
.code-block-header > * { .code-block > .code-header > * {
margin: auto 0; margin: auto 0;
} }
.code-block-type { .code-block > .code-header > .code-type {
border-top-left-radius: 8px; border-top-left-radius: 8px;
} }
/* TODO: make the code copy button prettier */ /* TODO: make the code copy button prettier */
.code-block-copy-button { .code-block > .code-header > .code-copy-button {
color: var(--link-1); color: var(--link-1);
} }
.code-block-copy-button:hover { .code-block > .code-header > .code-copy-button:hover {
cursor: pointer; cursor: pointer;
} }
.code-block > .highlight { .code-block > .highlight {
@@ -877,7 +874,7 @@ figcaption {
overflow-wrap: break-word; overflow-wrap: break-word;
} }
.code-block-type, .code-block > .code-header > .code-type,
code { code {
border-radius: 5px; border-radius: 5px;
} }
@@ -960,7 +957,7 @@ aside.quote {
/* Print compatibility {{{ */ /* Print compatibility {{{ */
@media print { @media print {
.top-navbar, .top > .navbar,
.content-heading-link, .content-heading-link,
.post-meta-edit-history, .post-meta-edit-history,
.post-meta-view-markdown, .post-meta-view-markdown,
@@ -979,7 +976,7 @@ aside.quote {
.top { .top {
background-color: unset; background-color: unset;
} }
.top-brand { .top > .header {
margin-left: 0; margin-left: 0;
margin-right: 0; margin-right: 0;
} }

View File

@@ -1,14 +1,15 @@
/* tango style */
@media print, (prefers-color-scheme: light) { @media print, (prefers-color-scheme: light) {
.chroma { .chroma {
color: black; color: black;
} }
/* Generated using: hugo gen chromastyles --style tango */
/* Background */ .bg { background-color: #f8f8f8; } /* Background */ .bg { background-color: #f8f8f8; }
/* PreWrapper */ .chroma { background-color: #f8f8f8; } /* PreWrapper */ .chroma { background-color: #f8f8f8; }
/* Other */ .chroma .x { color:#000 } /* Other */ .chroma .x { color: #000000 }
/* Error */ .chroma .err { color: #a40000 } /* Error */ .chroma .err { color: #a40000 }
/* CodeLine */ .chroma .cl { }
/* LineLink */ .chroma .lnlinks { outline: none; text-decoration: none; color: inherit } /* LineLink */ .chroma .lnlinks { outline: none; text-decoration: none; color: inherit }
/* LineTableTD */ .chroma .lntd { vertical-align: top; padding: 0; margin: 0; border: 0; } /* LineTableTD */ .chroma .lntd { vertical-align: top; padding: 0; margin: 0; border: 0; }
/* LineTable */ .chroma .lntable { border-spacing: 0; padding: 0; margin: 0; border: 0; } /* LineTable */ .chroma .lntable { border-spacing: 0; padding: 0; margin: 0; border: 0; }
@@ -23,29 +24,29 @@
/* KeywordPseudo */ .chroma .kp { color: #204a87; font-weight: bold } /* KeywordPseudo */ .chroma .kp { color: #204a87; font-weight: bold }
/* KeywordReserved */ .chroma .kr { color: #204a87; font-weight: bold } /* KeywordReserved */ .chroma .kr { color: #204a87; font-weight: bold }
/* KeywordType */ .chroma .kt { color: #204a87; font-weight: bold } /* KeywordType */ .chroma .kt { color: #204a87; font-weight: bold }
/* Name */ .chroma .n { color:#000 } /* Name */ .chroma .n { color: #000000 }
/* NameAttribute */ .chroma .na { color: #c4a000 } /* NameAttribute */ .chroma .na { color: #c4a000 }
/* NameClass */ .chroma .nc { color:#000 }
/* NameConstant */ .chroma .no { color:#000 }
/* NameDecorator */ .chroma .nd { color:#5c35cc;font-weight:bold }
/* NameEntity */ .chroma .ni { color:#ce5c00 }
/* NameException */ .chroma .ne { color:#c00;font-weight:bold }
/* NameLabel */ .chroma .nl { color:#f57900 }
/* NameNamespace */ .chroma .nn { color:#000 }
/* NameOther */ .chroma .nx { color:#000 }
/* NameProperty */ .chroma .py { color:#000 }
/* NameTag */ .chroma .nt { color:#204a87;font-weight:bold }
/* NameBuiltin */ .chroma .nb { color: #204a87 } /* NameBuiltin */ .chroma .nb { color: #204a87 }
/* NameBuiltinPseudo */ .chroma .bp { color: #3465a4 } /* NameBuiltinPseudo */ .chroma .bp { color: #3465a4 }
/* NameVariable */ .chroma .nv { color:#000 } /* NameClass */ .chroma .nc { color: #000000 }
/* NameVariableClass */ .chroma .vc { color:#000 } /* NameConstant */ .chroma .no { color: #000000 }
/* NameVariableGlobal */ .chroma .vg { color:#000 } /* NameDecorator */ .chroma .nd { color: #5c35cc; font-weight: bold }
/* NameVariableInstance */ .chroma .vi { color:#000 } /* NameEntity */ .chroma .ni { color: #ce5c00 }
/* NameVariableMagic */ .chroma .vm { color:#000 } /* NameException */ .chroma .ne { color: #cc0000; font-weight: bold }
/* NameFunction */ .chroma .nf { color:#000 } /* NameFunction */ .chroma .nf { color: #000000 }
/* NameFunctionMagic */ .chroma .fm { color:#000 } /* NameFunctionMagic */ .chroma .fm { color: #000000 }
/* Literal */ .chroma .l { color:#000 } /* NameLabel */ .chroma .nl { color: #f57900 }
/* LiteralDate */ .chroma .ld { color:#000 } /* NameNamespace */ .chroma .nn { color: #000000 }
/* NameOther */ .chroma .nx { color: #000000 }
/* NameProperty */ .chroma .py { color: #000000 }
/* NameTag */ .chroma .nt { color: #204a87; font-weight: bold }
/* NameVariable */ .chroma .nv { color: #000000 }
/* NameVariableClass */ .chroma .vc { color: #000000 }
/* NameVariableGlobal */ .chroma .vg { color: #000000 }
/* NameVariableInstance */ .chroma .vi { color: #000000 }
/* NameVariableMagic */ .chroma .vm { color: #000000 }
/* Literal */ .chroma .l { color: #000000 }
/* LiteralDate */ .chroma .ld { color: #000000 }
/* LiteralString */ .chroma .s { color: #4e9a06 } /* LiteralString */ .chroma .s { color: #4e9a06 }
/* LiteralStringAffix */ .chroma .sa { color: #4e9a06 } /* LiteralStringAffix */ .chroma .sa { color: #4e9a06 }
/* LiteralStringBacktick */ .chroma .sb { color: #4e9a06 } /* LiteralStringBacktick */ .chroma .sb { color: #4e9a06 }
@@ -69,7 +70,7 @@
/* LiteralNumberOct */ .chroma .mo { color: #0000cf; font-weight: bold } /* LiteralNumberOct */ .chroma .mo { color: #0000cf; font-weight: bold }
/* Operator */ .chroma .o { color: #ce5c00; font-weight: bold } /* Operator */ .chroma .o { color: #ce5c00; font-weight: bold }
/* OperatorWord */ .chroma .ow { color: #204a87; font-weight: bold } /* OperatorWord */ .chroma .ow { color: #204a87; font-weight: bold }
/* Punctuation */ .chroma .p { color:#000;font-weight:bold } /* Punctuation */ .chroma .p { color: #000000; font-weight: bold }
/* Comment */ .chroma .c { color: #8f5902; font-style: italic } /* Comment */ .chroma .c { color: #8f5902; font-style: italic }
/* CommentHashbang */ .chroma .ch { color: #8f5902; font-style: italic } /* CommentHashbang */ .chroma .ch { color: #8f5902; font-style: italic }
/* CommentMultiline */ .chroma .cm { color: #8f5902; font-style: italic } /* CommentMultiline */ .chroma .cm { color: #8f5902; font-style: italic }
@@ -77,19 +78,19 @@
/* CommentSpecial */ .chroma .cs { color: #8f5902; font-style: italic } /* CommentSpecial */ .chroma .cs { color: #8f5902; font-style: italic }
/* CommentPreproc */ .chroma .cp { color: #8f5902; font-style: italic } /* CommentPreproc */ .chroma .cp { color: #8f5902; font-style: italic }
/* CommentPreprocFile */ .chroma .cpf { color: #8f5902; font-style: italic } /* CommentPreprocFile */ .chroma .cpf { color: #8f5902; font-style: italic }
/* Generic */ .chroma .g { color:#000 } /* Generic */ .chroma .g { color: #000000 }
/* GenericDeleted */ .chroma .gd { color: #a40000 } /* GenericDeleted */ .chroma .gd { color: #a40000 }
/* GenericEmph */ .chroma .ge { color:#000;font-style:italic } /* GenericEmph */ .chroma .ge { color: #000000; font-style: italic }
/* GenericError */ .chroma .gr { color: #ef2929 } /* GenericError */ .chroma .gr { color: #ef2929 }
/* GenericHeading */ .chroma .gh { color: #000080; font-weight: bold } /* GenericHeading */ .chroma .gh { color: #000080; font-weight: bold }
/* GenericInserted */ .chroma .gi { color: #00a000 } /* GenericInserted */ .chroma .gi { color: #00a000 }
/* GenericOutput */ .chroma .go { color:#000;font-style:italic } /* GenericOutput */ .chroma .go { color: #000000; font-style: italic }
/* GenericPrompt */ .chroma .gp { color: #8f5902 } /* GenericPrompt */ .chroma .gp { color: #8f5902 }
/* GenericStrong */ .chroma .gs { color:#000;font-weight:bold } /* GenericStrong */ .chroma .gs { color: #000000; font-weight: bold }
/* GenericSubheading */ .chroma .gu { color: #800080; font-weight: bold } /* GenericSubheading */ .chroma .gu { color: #800080; font-weight: bold }
/* GenericTraceback */ .chroma .gt { color: #a40000; font-weight: bold } /* GenericTraceback */ .chroma .gt { color: #a40000; font-weight: bold }
/* GenericUnderline */ .chroma .gl { color:#000;text-decoration:underline } /* GenericUnderline */ .chroma .gl { color: #000000; text-decoration: underline }
/* TextWhitespace */ .chroma .w { color:#f8f8f8 } /* TextWhitespace */ .chroma .w { color: #f8f8f8; text-decoration: underline }
} }

View File

@@ -1,8 +1,10 @@
/* Generated using: hugo gen chromastyles --style native */ /* native style */
/* Background */ .bg { color: #d0d0d0; background-color: #202020; } /* Background */ .bg { color: #d0d0d0; background-color: #202020; }
/* PreWrapper */ .chroma { color: #d0d0d0; background-color: #202020; } /* PreWrapper */ .chroma { color: #d0d0d0; background-color: #202020; }
/* Other */ .chroma .x { }
/* Error */ .chroma .err { color: #a61717; background-color: #e3d2d2 } /* Error */ .chroma .err { color: #a61717; background-color: #e3d2d2 }
/* CodeLine */ .chroma .cl { }
/* LineLink */ .chroma .lnlinks { outline: none; text-decoration: none; color: inherit } /* LineLink */ .chroma .lnlinks { outline: none; text-decoration: none; color: inherit }
/* LineTableTD */ .chroma .lntd { vertical-align: top; padding: 0; margin: 0; border: 0; } /* LineTableTD */ .chroma .lntd { vertical-align: top; padding: 0; margin: 0; border: 0; }
/* LineTable */ .chroma .lntable { border-spacing: 0; padding: 0; margin: 0; border: 0; } /* LineTable */ .chroma .lntable { border-spacing: 0; padding: 0; margin: 0; border: 0; }
@@ -17,22 +19,29 @@
/* KeywordPseudo */ .chroma .kp { color: #6ab825 } /* KeywordPseudo */ .chroma .kp { color: #6ab825 }
/* KeywordReserved */ .chroma .kr { color: #6ab825; font-weight: bold } /* KeywordReserved */ .chroma .kr { color: #6ab825; font-weight: bold }
/* KeywordType */ .chroma .kt { color: #6ab825; font-weight: bold } /* KeywordType */ .chroma .kt { color: #6ab825; font-weight: bold }
/* NameAttribute */ .chroma .na { color:#bbb } /* Name */ .chroma .n { }
/* NameAttribute */ .chroma .na { color: #bbbbbb }
/* NameBuiltin */ .chroma .nb { color: #24909d }
/* NameBuiltinPseudo */ .chroma .bp { }
/* NameClass */ .chroma .nc { color: #447fcf; text-decoration: underline } /* NameClass */ .chroma .nc { color: #447fcf; text-decoration: underline }
/* NameConstant */ .chroma .no { color: #40ffff } /* NameConstant */ .chroma .no { color: #40ffff }
/* NameDecorator */ .chroma .nd { color: #ffa500 } /* NameDecorator */ .chroma .nd { color: #ffa500 }
/* NameException */ .chroma .ne { color:#bbb } /* NameEntity */ .chroma .ni { }
/* NameNamespace */ .chroma .nn { color:#447fcf;text-decoration:underline } /* NameException */ .chroma .ne { color: #bbbbbb }
/* NameTag */ .chroma .nt { color:#6ab825;font-weight:bold }
/* NameBuiltin */ .chroma .nb { color:#24909d }
/* NameBuiltinPseudo */ .chroma .bp { color:#24909d }
/* NameVariable */ .chroma .nv { color:#40ffff }
/* NameVariableClass */ .chroma .vc { color:#40ffff }
/* NameVariableGlobal */ .chroma .vg { color:#40ffff }
/* NameVariableInstance */ .chroma .vi { color:#40ffff }
/* NameVariableMagic */ .chroma .vm { color:#40ffff }
/* NameFunction */ .chroma .nf { color: #447fcf } /* NameFunction */ .chroma .nf { color: #447fcf }
/* NameFunctionMagic */ .chroma .fm { color:#447fcf } /* NameFunctionMagic */ .chroma .fm { }
/* NameLabel */ .chroma .nl { }
/* NameNamespace */ .chroma .nn { color: #447fcf; text-decoration: underline }
/* NameOther */ .chroma .nx { }
/* NameProperty */ .chroma .py { }
/* NameTag */ .chroma .nt { color: #6ab825; font-weight: bold }
/* NameVariable */ .chroma .nv { color: #40ffff }
/* NameVariableClass */ .chroma .vc { }
/* NameVariableGlobal */ .chroma .vg { }
/* NameVariableInstance */ .chroma .vi { }
/* NameVariableMagic */ .chroma .vm { }
/* Literal */ .chroma .l { }
/* LiteralDate */ .chroma .ld { }
/* LiteralString */ .chroma .s { color: #ed9d13 } /* LiteralString */ .chroma .s { color: #ed9d13 }
/* LiteralStringAffix */ .chroma .sa { color: #ed9d13 } /* LiteralStringAffix */ .chroma .sa { color: #ed9d13 }
/* LiteralStringBacktick */ .chroma .sb { color: #ed9d13 } /* LiteralStringBacktick */ .chroma .sb { color: #ed9d13 }
@@ -54,23 +63,26 @@
/* LiteralNumberInteger */ .chroma .mi { color: #3677a9 } /* LiteralNumberInteger */ .chroma .mi { color: #3677a9 }
/* LiteralNumberIntegerLong */ .chroma .il { color: #3677a9 } /* LiteralNumberIntegerLong */ .chroma .il { color: #3677a9 }
/* LiteralNumberOct */ .chroma .mo { color: #3677a9 } /* LiteralNumberOct */ .chroma .mo { color: #3677a9 }
/* Operator */ .chroma .o { }
/* OperatorWord */ .chroma .ow { color: #6ab825; font-weight: bold } /* OperatorWord */ .chroma .ow { color: #6ab825; font-weight: bold }
/* Comment */ .chroma .c { color:#999;font-style:italic } /* Punctuation */ .chroma .p { }
/* CommentHashbang */ .chroma .ch { color:#999;font-style:italic } /* Comment */ .chroma .c { color: #999999; font-style: italic }
/* CommentMultiline */ .chroma .cm { color:#999;font-style:italic } /* CommentHashbang */ .chroma .ch { color: #999999; font-style: italic }
/* CommentSingle */ .chroma .c1 { color:#999;font-style:italic } /* CommentMultiline */ .chroma .cm { color: #999999; font-style: italic }
/* CommentSingle */ .chroma .c1 { color: #999999; font-style: italic }
/* CommentSpecial */ .chroma .cs { color: #e50808; background-color: #520000; font-weight: bold } /* CommentSpecial */ .chroma .cs { color: #e50808; background-color: #520000; font-weight: bold }
/* CommentPreproc */ .chroma .cp { color: #cd2828; font-weight: bold } /* CommentPreproc */ .chroma .cp { color: #cd2828; font-weight: bold }
/* CommentPreprocFile */ .chroma .cpf { color: #cd2828; font-weight: bold } /* CommentPreprocFile */ .chroma .cpf { color: #cd2828; font-weight: bold }
/* Generic */ .chroma .g { }
/* GenericDeleted */ .chroma .gd { color: #d22323 } /* GenericDeleted */ .chroma .gd { color: #d22323 }
/* GenericEmph */ .chroma .ge { font-style: italic } /* GenericEmph */ .chroma .ge { font-style: italic }
/* GenericError */ .chroma .gr { color: #d22323 } /* GenericError */ .chroma .gr { color: #d22323 }
/* GenericHeading */ .chroma .gh { color:#fff;font-weight:bold } /* GenericHeading */ .chroma .gh { color: #ffffff; font-weight: bold }
/* GenericInserted */ .chroma .gi { color: #589819 } /* GenericInserted */ .chroma .gi { color: #589819 }
/* GenericOutput */ .chroma .go { color:#ccc } /* GenericOutput */ .chroma .go { color: #cccccc }
/* GenericPrompt */ .chroma .gp { color:#aaa } /* GenericPrompt */ .chroma .gp { color: #aaaaaa }
/* GenericStrong */ .chroma .gs { font-weight: bold } /* GenericStrong */ .chroma .gs { font-weight: bold }
/* GenericSubheading */ .chroma .gu { color:#fff;text-decoration:underline } /* GenericSubheading */ .chroma .gu { color: #ffffff; text-decoration: underline }
/* GenericTraceback */ .chroma .gt { color: #d22323 } /* GenericTraceback */ .chroma .gt { color: #d22323 }
/* GenericUnderline */ .chroma .gl { text-decoration: underline } /* GenericUnderline */ .chroma .gl { text-decoration: underline }
/* TextWhitespace */ .chroma .w { color:#666 } /* TextWhitespace */ .chroma .w { color: #666666 }

View File

@@ -21,6 +21,11 @@ taxonomies:
outputs: outputs:
page: page:
- html - html
- markdown
outputFormats:
markdown:
ugly: true
privacy: privacy:
googleAnalytics: googleAnalytics:

View File

@@ -32,6 +32,9 @@ readingtime:
edit_history: edit_history:
other: "Edit history" other: "Edit history"
view_markdown:
other: "View raw"
# Post count # Post count
no_posts: no_posts:
@@ -45,8 +48,6 @@ 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"
@@ -71,6 +72,9 @@ aria_rss_link:
aria_post_meta_edit_history: aria_post_meta_edit_history:
other: "link to page edit history" other: "link to page edit history"
aria_post_meta_view_markdown:
other: "link to view raw markdown code of page"
aria_post_meta_categories: aria_post_meta_categories:
other: "categories" other: "categories"

View File

@@ -3,9 +3,9 @@
{{ $type = . }} {{ $type = . }}
{{ end }} {{ end }}
<div class="code-block"> <div class="code-block">
<div class="code-block-header"> <div class="code-header">
<pre class="code-block-type">{{ $type }}</pre> <pre class="code-type">{{ $type }}</pre>
<a href="javascript:void(0)" class="code-block-copy-button"> <a href="javascript:void(0)" class="code-copy-button">
{{ i18n "copy_to_clipboard" }} {{ i18n "copy_to_clipboard" }}
</a> </a>
</div> </div>

View File

@@ -0,0 +1,4 @@
{{/*
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,4 +1,4 @@
<nav class="breadcrumb" aria-label="{{ i18n "aria_breadcrumbnav" }}"> <nav class="body-module--center breadcrumb" aria-label="{{ i18n "aria_breadcrumbnav" }}">
<ul> <ul>
{{ template "breadcrumbnav" (dict "p1" . "p2" .) }} {{ template "breadcrumbnav" (dict "p1" . "p2" .) }}
</ul> </ul>

View File

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

View File

@@ -1 +1 @@
{{ partialCached "icon_impl.html" . . }} {{ partialCached "icon_code.html" . . }}

View File

@@ -1,7 +1,9 @@
<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

@@ -0,0 +1,8 @@
{{ with .OutputFormats.Get "markdown" }}
<span class="page-metadata-item post-meta-view-markdown" aria-label="{{ i18n "aria_post_meta_view_markdown" }}">
{{ partial "icon.html" "code" }}
<a href="{{ .Permalink }}" target="_blank">
{{- i18n "view_markdown" -}}
</a>
</span>
{{ end }}

View File

@@ -1,5 +1,5 @@
{{ if or .Date .Params.authors .Site.Params.readingtime .Site.Params.gitFileURL }} {{ if or .Date .Params.authors .Site.Params.readingtime .Site.Params.gitFileURL }}
<section class="page-metadata" aria-label="{{ i18n "aria_post_metadata" }}"> <div class="page-metadata" aria-label="{{ i18n "aria_post_metadata" }}">
{{ if .Date }} {{ if .Date }}
<span class="page-metadata-item" aria-label="{{ i18n "aria_post_meta_date" }}"> <span class="page-metadata-item" aria-label="{{ i18n "aria_post_meta_date" }}">
{{ partial "icon.html" "calendar" }} {{ partial "icon.html" "calendar" }}
@@ -20,10 +20,11 @@
{{ partial "page-metadata/item/authors.html" . }} {{ partial "page-metadata/item/authors.html" . }}
{{ partial "page-metadata/item/readingtime.html" . }} {{ partial "page-metadata/item/readingtime.html" . }}
{{ partial "page-metadata/item/edithistory.html" . }} {{ partial "page-metadata/item/edithistory.html" . }}
{{ partial "page-metadata/item/viewraw.html" . }}
{{ partial "page-metadata/item/comments-counter.html" . }} {{ partial "page-metadata/item/comments-counter.html" . }}
{{ partial "page-metadata/item/categories.html" . }} {{ partial "page-metadata/item/categories.html" . }}
{{ partial "page-metadata/item/tags.html" . }} {{ partial "page-metadata/item/tags.html" . }}
</section> </div>
{{ end }} {{ end }}

View File

@@ -1,5 +1,5 @@
{{ if or .Date .Params.authors .Site.Params.readingtime }} {{ if or .Date .Params.authors .Site.Params.readingtime }}
<section class="page-metadata" aria-label="{{ i18n "aria_post_metadata" }}"> <div class="page-metadata" aria-label="{{ i18n "aria_post_metadata" }}">
{{ if .Date }} {{ if .Date }}
<span class="page-metadata-item" aria-label="date"> <span class="page-metadata-item" aria-label="date">
{{ partial "icon.html" "calendar" }} {{ partial "icon.html" "calendar" }}
@@ -14,5 +14,5 @@
{{ partial "page-metadata/item/series.html" . }} {{ partial "page-metadata/item/series.html" . }}
{{ partial "page-metadata/item/categories.html" . }} {{ partial "page-metadata/item/categories.html" . }}
{{ partial "page-metadata/item/tags.html" . }} {{ partial "page-metadata/item/tags.html" . }}
</section> </div>
{{ end }} {{ end }}

View File

@@ -1,4 +1,4 @@
<section class="share-buttons"> <div class="share-buttons">
{{ if .Site.Params.shareButtons.twitter }} {{ if .Site.Params.shareButtons.twitter }}
<a class="twitter-share" <a class="twitter-share"
target="_blank" target="_blank"
@@ -66,4 +66,4 @@
{{- partial "icon.html" "printer" -}} {{- partial "icon.html" "printer" -}}
</a> </a>
{{ end }} {{ end }}
</section> </div>

View File

@@ -1,13 +1,13 @@
<header class="top"> <header class="top">
<div class="top-brand"> <div class="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="top-navbar" aria-label="{{ i18n "aria_navbar" }}"> <nav class="navbar" aria-label="{{ i18n "aria_navbar" }}">
{{ with .Site.Home }} {{ with .Site.Home }}
<a class="top-navbar-item{{ if $.IsHome }} top-navbar-item--active{{ end }}" href="{{ .Permalink | absLangURL }}">{{ .Title | markdownify }}</a> <a class="navbar-item{{ if $.IsHome }} 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="top-navbar-item{{ if $isActive }} top-navbar-item--active{{ end }}" <a class="navbar-item{{ if $isActive }} 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 }}

26
layouts/authors/list.html Normal file
View File

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

View File

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

View File

@@ -8,19 +8,22 @@
{{ partial "top.html" . }} {{ partial "top.html" . }}
<div class="main-container">
{{ if not .IsHome }} {{ if not .IsHome }}
{{ partial "breadcrumb.html" . }} {{ partial "breadcrumb.html" . }}
{{ end }} {{ end }}
{{ block "pre-body" . }}{{ end }}
<main id="main-content"> <main id="main-content">
{{ 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>
{{ block "post-body" . }}{{ end }}
{{ if or .Site.Copyright .Site.Params.footer }} {{ if or .Site.Copyright .Site.Params.footer }}
<footer class="site-footer"> <footer class="body-module--center">
{{ with .Site.Copyright }} {{ with .Site.Copyright }}
{{ . | safeHTML }} {{ . | safeHTML }}
{{ end }} {{ end }}
@@ -30,11 +33,6 @@
{{ end }} {{ end }}
</footer> </footer>
{{ end }} {{ end }}
</div>
{{ block "post-body" . }}
{{/* currently this is only used for related posts */}}
{{ end }}
</body> </body>
</html> </html>

View File

@@ -1,13 +1,15 @@
{{ define "main" }} {{ define "main" }}
{{ with .Content }} {{ with .Content }}
<article class="homepage-content"> <article class="body-module--center">
{{ . }} {{ . }}
</article> </article>
<hr class="body-module--center">
{{ end }}
{{ end }} {{ end }}
{{ define "post-body" }}
{{ if .Site.Params.homepageLatestPosts }} {{ if .Site.Params.homepageLatestPosts }}
<hr> <div class="body-module--center">
<section class="homepage-latest-posts">
<h1> <h1>
{{ i18n "latest_posts" }} {{ i18n "latest_posts" }}
{{ partial "rss-link.html" . }} {{ partial "rss-link.html" . }}
@@ -16,6 +18,6 @@
{{ partial "page-list.html" (.Paginate .Site.RegularPages).Pages }} {{ partial "page-list.html" (.Paginate .Site.RegularPages).Pages }}
{{ partial "pagination.html" . }} {{ partial "pagination.html" . }}
</section> </div>
{{ end }} {{ end }}
{{ end }} {{ end }}

View File

@@ -1,5 +1,5 @@
{{ define "main" }} {{ define "main" }}
<article> <article class="body-module--center">
<div class="page-title"> <div class="page-title">
<h1> <h1>
{{ .Title | markdownify }} {{ .Title | markdownify }}
@@ -11,28 +11,28 @@
{{ partial "series-box.html" . }} {{ partial "series-box.html" . }}
{{ if .Params.Toc }} {{ if .Params.Toc }}
<section class="table-of-contents" aria-label="{{ i18n "aria_table_of_contents" }}"> <div class="table-of-contents" aria-label="{{ i18n "aria_table_of_contents" }}">
<details> <details>
<summary>{{ i18n "table_of_contents" }}</summary> <summary>{{ i18n "table_of_contents" }}</summary>
{{ .TableOfContents }} {{ .TableOfContents }}
</details> </details>
</section> </div>
<div class="table-of-contents print"> <div class="table-of-contents print">
{{ i18n "table_of_contents" }} {{ i18n "table_of_contents" }}
{{ .TableOfContents }} {{ .TableOfContents }}
</div> </div>
{{ end }} {{ end }}
{{ partial "featured-media.html" . }} {{ partial "feature-figure.html" . }}
<div class="post-content" data-pagefind-body> <article class="post-content" data-pagefind-body>
{{ .Content }} {{ .Content }}
</div> </article>
{{ partial "series-box.html" . }} {{ partial "series-box.html" . }}
{{ if or .NextInSection .PrevInSection }} {{ if or .NextInSection .PrevInSection }}
<nav class="prevnext"> <div class="prevnext">
{{ with .NextInSection }} {{ with .NextInSection }}
<a class="prev" href="{{ .Permalink }}"> <a class="prev" href="{{ .Permalink }}">
<div class="prev-caption"> <div class="prev-caption">
@@ -58,7 +58,7 @@
{{ else }} {{ else }}
<div class="next"></div> <div class="next"></div>
{{ end }} {{ end }}
</nav> </div>
{{ end }} {{ end }}
{{ if .Site.Params.shareButtons }} {{ if .Site.Params.shareButtons }}
@@ -66,9 +66,9 @@
{{ end }} {{ end }}
{{ if .Params.comments }} {{ if .Params.comments }}
<section class="comments"> <div class="comments">
{{ partial "comments.html" . }} {{ partial "comments.html" . }}
</section> </div>
{{ end }} {{ end }}
</article> </article>
{{ end }} {{ end }}
@@ -77,9 +77,9 @@
{{ define "post-body" }} {{ define "post-body" }}
{{ $related := .Site.RegularPages.Related . | first 10 }} {{ $related := .Site.RegularPages.Related . | first 10 }}
{{ with $related }} {{ with $related }}
<div class="related-posts"> <div class="body-module--full-width related-posts">
<hr> <hr>
<h2>{{ i18n "related_posts" }}</h2> <h1>{{ i18n "related_posts" }}</h1>
{{ partial "page-list.html" . }} {{ partial "page-list.html" . }}
</div> </div>
{{ end }} {{ end }}

9
layouts/page.markdown.md Normal file
View File

@@ -0,0 +1,9 @@
{{ with .File -}}
{{ with (.Path | readFile) -}}
{{ . -}}
{{ else -}}
{{ errorf "file not found: %s" .Path -}}
{{ end -}}
{{ else -}}
{{ errorf "no file available for markdown template?" -}}
{{ end -}}

View File

@@ -1,4 +1,6 @@
User-Agent: * User-Agent: *
Allow: /
Sitemap: {{ "sitemap.xml" | absLangURL }} Sitemap: {{ "sitemap.xml" | absLangURL }}
{{/* It complains about the raw markdown output having no title tag */ -}}
User-Agent: Bingbot
Disallow: /blog/*.md$

View File

@@ -9,6 +9,7 @@
{{ . }} {{ . }}
{{ end }} {{ end }}
<div class="list-page-container">
{{ with .Sections }} {{ with .Sections }}
<div class="sections"> <div class="sections">
{{ range . }} {{ range . }}
@@ -18,6 +19,7 @@
{{ end }} {{ end }}
{{ partial "page-list.html" .Paginator.Pages }} {{ partial "page-list.html" .Paginator.Pages }}
</div>
{{ partial "pagination.html" . }} {{ partial "pagination.html" . }}
{{ end }} {{ end }}

View File

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

View File

@@ -1,6 +1,6 @@
{{ define "main" }} {{ define "main" }}
<h1> <h1>
{{ partial "icon.html" "user-circle" }} {{ partial "icon.html" "files" }}
{{ .Title | markdownify }} {{ .Title | markdownify }}
</h1> </h1>
@@ -8,10 +8,12 @@
{{ . }} {{ . }}
{{ end }} {{ end }}
<div class="page-list"> <div class="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,5 +1,4 @@
<article class="summary-card"> <h2 class="page-title">
<h2 class="summary-card-title">
{{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }} {{ with .Parent.Params.icon }}{{ partial "icon.html" . }}{{ end }}
<a href="{{ .Permalink }}">{{ .Title | markdownify }}</a> <a href="{{ .Permalink }}">{{ .Title | markdownify }}</a>
{{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }} {{ if .Draft }}{{ partial "icon.html" "write" }}{{ end }}
@@ -8,14 +7,15 @@
{{ partial "page-metadata/series.html" . }} {{ partial "page-metadata/series.html" . }}
{{ with .Summary }} {{ with .Summary }}
<div class="summary-card-description"> <div class="page-description">
{{ . }} {{ . }}
</div> </div>
{{ end }} {{ end }}
<div class="page-list page-list--series-inner"> <div class="page-list series-inner">
{{ range .Data.Pages.Reverse }} {{ range .Data.Pages.Reverse }}
<article class="page">
{{ .Render "summary" }} {{ .Render "summary" }}
</article>
{{ end }} {{ end }}
</div> </div>
</article>

View File

@@ -1,24 +0,0 @@
{{ define "main" }}
<div class="page-title">
<h1>
{{ partial "icon.html" "files" }}
{{ .Title | markdownify }}
</h1>
</div>
{{ with .Content }}
{{ . }}
{{ end }}
<div class="page-list page-list--series">
{{ with .Paginator.Pages }}
{{ range . }}
{{ .Render "summary" }}
{{ end }}
{{ else }}
<div>
{{ i18n "no_posts" }}
</div>
{{ end }}
</div>
{{ end }}

View File

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