mirror of
https://github.com/BBaoVanC/bobatheme.git
synced 2025-06-14 02:17:29 -05:00
Compare commits
1 Commits
master
...
wip-print-
Author | SHA1 | Date | |
---|---|---|---|
fa1fb5d0ba
|
2
.gitmodules
vendored
2
.gitmodules
vendored
@ -1,4 +1,4 @@
|
|||||||
[submodule "assets/jam"]
|
[submodule "assets/jam"]
|
||||||
path = assets/jam
|
path = assets/jam
|
||||||
url = https://github.com/BBaoVanC/jam.git
|
url = https://github.com/michaelampr/jam.git
|
||||||
branch = master
|
branch = master
|
||||||
|
@ -248,31 +248,31 @@ hr {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
table.simple {
|
table.markdown {
|
||||||
border-collapse: collapse;
|
border-collapse: collapse;
|
||||||
border: 2px solid var(--text-1);
|
border: 2px solid var(--text-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
table.simple thead {
|
table.markdown thead {
|
||||||
background-color: var(--background-2);
|
background-color: var(--background-2);
|
||||||
color: var(--text-2);
|
color: var(--text-2);
|
||||||
border-bottom: 2px solid var(--text-1);
|
border-bottom: 2px solid var(--text-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
table.simple th,
|
table.markdown th,
|
||||||
table.simple td {
|
table.markdown td {
|
||||||
padding: 8px;
|
padding: 8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
table.simple :is(th, td) + :is(th, td) {
|
table.markdown :is(th, td) + :is(th, td) {
|
||||||
border-left: 2px solid var(--text-1);
|
border-left: 2px solid var(--text-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
table.simple tbody tr:nth-child(odd) {
|
table.markdown tbody tr:nth-child(odd) {
|
||||||
background-color: var(--background-0);
|
background-color: var(--background-0);
|
||||||
color: var(--text-0);
|
color: var(--text-0);
|
||||||
}
|
}
|
||||||
table.simple tbody tr:nth-child(even) {
|
table.markdown tbody tr:nth-child(even) {
|
||||||
background-color: var(--background-1);
|
background-color: var(--background-1);
|
||||||
color: var(--text-1);
|
color: var(--text-1);
|
||||||
}
|
}
|
||||||
@ -641,7 +641,7 @@ h1 svg.icon {
|
|||||||
/* Content (single) formatting {{{ */
|
/* Content (single) formatting {{{ */
|
||||||
|
|
||||||
.series-box {
|
.series-box {
|
||||||
background-color: var(--background-1);
|
background-color: var(--background-1); /* remember to update print styling */
|
||||||
color: var(--text-1);
|
color: var(--text-1);
|
||||||
padding: 8px 16px;
|
padding: 8px 16px;
|
||||||
border-radius: 8px;
|
border-radius: 8px;
|
||||||
@ -649,7 +649,7 @@ h1 svg.icon {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.table-of-contents {
|
.table-of-contents {
|
||||||
background-color: var(--background-1);
|
background-color: var(--background-1); /* remember to update print styling */
|
||||||
color: var(--text-1);
|
color: var(--text-1);
|
||||||
padding: 8px 20px;
|
padding: 8px 20px;
|
||||||
border-radius: 8px;
|
border-radius: 8px;
|
||||||
@ -704,7 +704,7 @@ h1 svg.icon {
|
|||||||
|
|
||||||
/* See also formating */
|
/* See also formating */
|
||||||
.see-also {
|
.see-also {
|
||||||
background-color: var(--background-1);
|
background-color: var(--background-1); /* remember to update print styling */
|
||||||
color: var(--text-1);
|
color: var(--text-1);
|
||||||
padding: 8px 12px;
|
padding: 8px 12px;
|
||||||
border-radius: 8px;
|
border-radius: 8px;
|
||||||
@ -770,14 +770,14 @@ h1 svg.icon {
|
|||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
margin: 16px 0;
|
margin: 16px 0;
|
||||||
background-color: var(--background-1);
|
background-color: var(--background-1); /* remember to update print styling */
|
||||||
border-radius: 8px;
|
border-radius: 8px;
|
||||||
}
|
}
|
||||||
.code-block > .code-header {
|
.code-block > .code-header {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
justify-content: space-between;
|
justify-content: space-between;
|
||||||
background-color: var(--background-2);
|
background-color: var(--background-2); /* remember to update print styling */
|
||||||
padding: 4px 8px;
|
padding: 4px 8px;
|
||||||
border-top-left-radius: 8px;
|
border-top-left-radius: 8px;
|
||||||
border-top-right-radius: 8px;
|
border-top-right-radius: 8px;
|
||||||
@ -857,6 +857,7 @@ aside {
|
|||||||
margin-bottom: 0;
|
margin-bottom: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* remember to update print styling for all the following asides */
|
||||||
aside.note {
|
aside.note {
|
||||||
background-color: var(--background-blue-1);
|
background-color: var(--background-blue-1);
|
||||||
}
|
}
|
||||||
@ -972,6 +973,19 @@ aside.quote {
|
|||||||
.table-of-contents.print {
|
.table-of-contents.print {
|
||||||
display: block;
|
display: block;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* replace background colors with borders {{{ */
|
||||||
|
.series-box {
|
||||||
|
}
|
||||||
|
.table-of-contents {
|
||||||
|
}
|
||||||
|
.see-also {
|
||||||
|
}
|
||||||
|
.code-block {
|
||||||
|
}
|
||||||
|
.code-block > .code-header {
|
||||||
|
}
|
||||||
|
/* all the asides */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* }}} */
|
/* }}} */
|
||||||
|
60
exampleSite/hugo.yaml
Normal file
60
exampleSite/hugo.yaml
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
baseURL: https://example.com
|
||||||
|
theme: bobatheme
|
||||||
|
defaultContentLanguage: en
|
||||||
|
copyright: '© 2021 bbaovanc <a rel="license" href="http://creativecommons.org/licenses/by-sa/4.0/">CC BY-SA 4.0</a>'
|
||||||
|
sectionPagesMenu: main
|
||||||
|
enableRobotsTXT: true
|
||||||
|
paginate: 5
|
||||||
|
enableGitInfo: true
|
||||||
|
|
||||||
|
taxonomies:
|
||||||
|
_merge: deep
|
||||||
|
|
||||||
|
markup: # this just keeps the bobatheme markup styling
|
||||||
|
_merge: deep
|
||||||
|
|
||||||
|
params:
|
||||||
|
author:
|
||||||
|
name: bbaovanc
|
||||||
|
|
||||||
|
# these are for the OpenGraph/Twitter embeds in Hugo
|
||||||
|
description: Example website for bobatheme
|
||||||
|
|
||||||
|
# these are for favicons in bobatheme (disabled by default)
|
||||||
|
# faviconSVG: favicon.svg
|
||||||
|
# appleTouchPNG: apple-touch-icon.png
|
||||||
|
|
||||||
|
# show reading time (enabled by default)
|
||||||
|
# readingtime: true
|
||||||
|
|
||||||
|
# used for "View source" (unset by default)
|
||||||
|
# gitFileURL: https://github.com/BBaoVanC/bobatheme/blob/master
|
||||||
|
# gitFileIcon: github-circle
|
||||||
|
# gitHistoryURL: https://github.com/BBaoVanC/bobatheme/commits/master
|
||||||
|
|
||||||
|
# social media share icons
|
||||||
|
# shareButtons:
|
||||||
|
# twitter: true
|
||||||
|
# facebook: true
|
||||||
|
# linkedin: true
|
||||||
|
# reddit: true
|
||||||
|
# telegram: true
|
||||||
|
# print: true
|
||||||
|
|
||||||
|
# show "Latest Posts" section at bottom of content pages
|
||||||
|
# latestPostsOnContent: true
|
||||||
|
|
||||||
|
# footer: >-
|
||||||
|
# Some example text for the footer.
|
||||||
|
|
||||||
|
|
||||||
|
# see https://gohugo.io/about/hugo-and-gdpr/#all-privacy-settings
|
||||||
|
# you probably want to keep this default
|
||||||
|
privacy:
|
||||||
|
_merge: deep
|
||||||
|
|
||||||
|
languages:
|
||||||
|
en:
|
||||||
|
languageName: English
|
||||||
|
title: Example Website
|
||||||
|
weight: 1
|
17
hugo.yaml
17
hugo.yaml
@ -2,12 +2,6 @@ markup:
|
|||||||
highlight:
|
highlight:
|
||||||
noClasses: false
|
noClasses: false
|
||||||
lineNos: true
|
lineNos: true
|
||||||
goldmark:
|
|
||||||
parser:
|
|
||||||
attribute:
|
|
||||||
block: true
|
|
||||||
# this is enabled by default already
|
|
||||||
#title: true
|
|
||||||
|
|
||||||
params:
|
params:
|
||||||
readingtime: true
|
readingtime: true
|
||||||
@ -18,20 +12,11 @@ taxonomies:
|
|||||||
author: authors
|
author: authors
|
||||||
series: series
|
series: series
|
||||||
|
|
||||||
outputs:
|
|
||||||
page:
|
|
||||||
- html
|
|
||||||
- markdown
|
|
||||||
|
|
||||||
outputFormats:
|
|
||||||
markdown:
|
|
||||||
ugly: true
|
|
||||||
|
|
||||||
privacy:
|
privacy:
|
||||||
googleAnalytics:
|
googleAnalytics:
|
||||||
disable: true
|
disable: true
|
||||||
|
|
||||||
x:
|
twitter:
|
||||||
enableDNT: true
|
enableDNT: true
|
||||||
|
|
||||||
vimeo:
|
vimeo:
|
||||||
|
@ -30,9 +30,6 @@ readingtime:
|
|||||||
edit_history:
|
edit_history:
|
||||||
other: "Edit history"
|
other: "Edit history"
|
||||||
|
|
||||||
view_markdown:
|
|
||||||
other: "View raw"
|
|
||||||
|
|
||||||
|
|
||||||
# Post count
|
# Post count
|
||||||
no_posts:
|
no_posts:
|
||||||
@ -70,9 +67,6 @@ 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"
|
||||||
|
|
||||||
|
@ -1,9 +0,0 @@
|
|||||||
{{ with .File -}}
|
|
||||||
{{ with (.Path | readFile) -}}
|
|
||||||
{{ . -}}
|
|
||||||
{{ else -}}
|
|
||||||
{{ errorf "file not found: %s" .Path -}}
|
|
||||||
{{ end -}}
|
|
||||||
{{ else -}}
|
|
||||||
{{ errorf "no file available for markdown template?" -}}
|
|
||||||
{{ end -}}
|
|
@ -1,154 +0,0 @@
|
|||||||
{{- $validFormats := slice "default" "terse" }}
|
|
||||||
|
|
||||||
{{- $msg1 := "When passing a map to the internal pagination template, one of the elements must be named 'page', and it must be set to the context of the current page." }}
|
|
||||||
{{- $msg2 := "The 'format' specified in the map passed to the internal pagination template is invalid. Valid choices are: %s." }}
|
|
||||||
|
|
||||||
{{- $page := . }}
|
|
||||||
{{- $format := "default" }}
|
|
||||||
|
|
||||||
{{- if reflect.IsMap . }}
|
|
||||||
{{- with .page }}
|
|
||||||
{{- $page = . }}
|
|
||||||
{{- else }}
|
|
||||||
{{- errorf $msg1 }}
|
|
||||||
{{- end }}
|
|
||||||
{{- with .format }}
|
|
||||||
{{- $format = lower . }}
|
|
||||||
{{- end }}
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
{{- if in $validFormats $format }}
|
|
||||||
{{- if gt $page.Paginator.TotalPages 1 }}
|
|
||||||
<ul class="pagination pagination-{{ $format }}">
|
|
||||||
{{- partial (printf "inline/pagination/%s.html" $format) $page }}
|
|
||||||
</ul>
|
|
||||||
{{- end }}
|
|
||||||
{{- else }}
|
|
||||||
{{- errorf $msg2 (delimit $validFormats ", ") }}
|
|
||||||
{{- end -}}
|
|
||||||
|
|
||||||
{{/* Format: default
|
|
||||||
{{/* --------------------------------------------------------------------- */}}
|
|
||||||
{{- define "_partials/inline/pagination/default.html" }}
|
|
||||||
{{- with .Paginator }}
|
|
||||||
{{- $currentPageNumber := .PageNumber }}
|
|
||||||
|
|
||||||
{{- with .First }}
|
|
||||||
{{- if ne $currentPageNumber .PageNumber }}
|
|
||||||
<li class="page-item">
|
|
||||||
<a href="{{ .URL }}" aria-label="First" class="page-link" role="button"><span aria-hidden="true">««</span></a>
|
|
||||||
</li>
|
|
||||||
{{- else }}
|
|
||||||
<li class="page-item disabled">
|
|
||||||
<a aria-disabled="true" aria-label="First" class="page-link" role="button" tabindex="-1"><span aria-hidden="true">««</span></a>
|
|
||||||
</li>
|
|
||||||
{{- end }}
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
{{- with .Prev }}
|
|
||||||
<li class="page-item">
|
|
||||||
<a href="{{ .URL }}" aria-label="Previous" class="page-link" role="button"><span aria-hidden="true">«</span></a>
|
|
||||||
</li>
|
|
||||||
{{- else }}
|
|
||||||
<li class="page-item disabled">
|
|
||||||
<a aria-disabled="true" aria-label="Previous" class="page-link" role="button" tabindex="-1"><span aria-hidden="true">«</span></a>
|
|
||||||
</li>
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
{{- $slots := 5 }}
|
|
||||||
{{- $start := math.Max 1 (sub .PageNumber (math.Floor (div $slots 2))) }}
|
|
||||||
{{- $end := math.Min .TotalPages (sub (add $start $slots) 1) }}
|
|
||||||
{{- if lt (add (sub $end $start) 1) $slots }}
|
|
||||||
{{- $start = math.Max 1 (add (sub $end $slots) 1) }}
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
{{- range $k := seq $start $end }}
|
|
||||||
{{- if eq $.Paginator.PageNumber $k }}
|
|
||||||
<li class="page-item active">
|
|
||||||
<a aria-current="page" aria-label="Page {{ $k }}" class="page-link" role="button">{{ $k }}</a>
|
|
||||||
</li>
|
|
||||||
{{- else }}
|
|
||||||
<li class="page-item">
|
|
||||||
<a href="{{ (index $.Paginator.Pagers (sub $k 1)).URL }}" aria-label="Page {{ $k }}" class="page-link" role="button">{{ $k }}</a>
|
|
||||||
</li>
|
|
||||||
{{- end }}
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
{{- with .Next }}
|
|
||||||
<li class="page-item">
|
|
||||||
<a href="{{ .URL }}" aria-label="Next" class="page-link" role="button"><span aria-hidden="true">»</span></a>
|
|
||||||
</li>
|
|
||||||
{{- else }}
|
|
||||||
<li class="page-item disabled">
|
|
||||||
<a aria-disabled="true" aria-label="Next" class="page-link" role="button" tabindex="-1"><span aria-hidden="true">»</span></a>
|
|
||||||
</li>
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
{{- with .Last }}
|
|
||||||
{{- if ne $currentPageNumber .PageNumber }}
|
|
||||||
<li class="page-item">
|
|
||||||
<a href="{{ .URL }}" aria-label="Last" class="page-link" role="button"><span aria-hidden="true">»»</span></a>
|
|
||||||
</li>
|
|
||||||
{{- else }}
|
|
||||||
<li class="page-item disabled">
|
|
||||||
<a aria-disabled="true" aria-label="Last" class="page-link" role="button" tabindex="-1"><span aria-hidden="true">»»</span></a>
|
|
||||||
</li>
|
|
||||||
{{- end }}
|
|
||||||
{{- end }}
|
|
||||||
{{- end }}
|
|
||||||
{{- end -}}
|
|
||||||
|
|
||||||
{{/* Format: terse
|
|
||||||
{{/* --------------------------------------------------------------------- */}}
|
|
||||||
{{- define "_partials/inline/pagination/terse.html" }}
|
|
||||||
{{- with .Paginator }}
|
|
||||||
{{- $currentPageNumber := .PageNumber }}
|
|
||||||
|
|
||||||
{{- with .First }}
|
|
||||||
{{- if ne $currentPageNumber .PageNumber }}
|
|
||||||
<li class="page-item">
|
|
||||||
<a href="{{ .URL }}" aria-label="First" class="page-link" role="button"><span aria-hidden="true">««</span></a>
|
|
||||||
</li>
|
|
||||||
{{- end }}
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
{{- with .Prev }}
|
|
||||||
<li class="page-item">
|
|
||||||
<a href="{{ .URL }}" aria-label="Previous" class="page-link" role="button"><span aria-hidden="true">«</span></a>
|
|
||||||
</li>
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
{{- $slots := 3 }}
|
|
||||||
{{- $start := math.Max 1 (sub .PageNumber (math.Floor (div $slots 2))) }}
|
|
||||||
{{- $end := math.Min .TotalPages (sub (add $start $slots) 1) }}
|
|
||||||
{{- if lt (add (sub $end $start) 1) $slots }}
|
|
||||||
{{- $start = math.Max 1 (add (sub $end $slots) 1) }}
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
{{- range $k := seq $start $end }}
|
|
||||||
{{- if eq $.Paginator.PageNumber $k }}
|
|
||||||
<li class="page-item active">
|
|
||||||
<a aria-current="page" aria-label="Page {{ $k }}" class="page-link" role="button">{{ $k }}</a>
|
|
||||||
</li>
|
|
||||||
{{- else }}
|
|
||||||
<li class="page-item">
|
|
||||||
<a href="{{ (index $.Paginator.Pagers (sub $k 1)).URL }}" aria-label="Page {{ $k }}" class="page-link" role="button">{{ $k }}</a>
|
|
||||||
</li>
|
|
||||||
{{- end }}
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
{{- with .Next }}
|
|
||||||
<li class="page-item">
|
|
||||||
<a href="{{ .URL }}" aria-label="Next" class="page-link" role="button"><span aria-hidden="true">»</span></a>
|
|
||||||
</li>
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
{{- with .Last }}
|
|
||||||
{{- if ne $currentPageNumber .PageNumber }}
|
|
||||||
<li class="page-item">
|
|
||||||
<a href="{{ .URL }}" aria-label="Last" class="page-link" role="button"><span aria-hidden="true">»»</span></a>
|
|
||||||
</li>
|
|
||||||
{{- end }}
|
|
||||||
{{- end }}
|
|
||||||
{{- end }}
|
|
||||||
{{- end -}}
|
|
@ -1,8 +0,0 @@
|
|||||||
{{ 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 }}
|
|
@ -20,10 +20,7 @@
|
|||||||
{{ 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/categories.html" . }}
|
{{ partial "page-metadata/item/categories.html" . }}
|
||||||
|
|
||||||
{{ partial "page-metadata/item/tags.html" . }}
|
{{ partial "page-metadata/item/tags.html" . }}
|
||||||
</div>
|
</div>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
{{ 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 */}}
|
{{ template "_internal/pagination.html" . }}
|
||||||
{{ partial "_internal/pagination.html" . }}
|
|
||||||
</nav>
|
</nav>
|
||||||
{{ end }}
|
{{ end }}
|
||||||
|
@ -24,6 +24,6 @@
|
|||||||
<meta name="twitter:title" content="{{ .Title | plainify }}">
|
<meta name="twitter:title" content="{{ .Title | plainify }}">
|
||||||
<meta name="twitter:description" content="{{ (partial "seo-description.html" .) | plainify }}">
|
<meta name="twitter:description" content="{{ (partial "seo-description.html" .) | plainify }}">
|
||||||
|
|
||||||
{{ with .Site.Params.social.twitter }}
|
{{ with .Site.Social.twitter }}
|
||||||
<meta name="twitter:site" content="@{{ . }}">
|
<meta name="twitter:site" content="@{{ . }}">
|
||||||
{{ end }}
|
{{ end }}
|
||||||
|
10
layouts/shortcodes/table.html
Normal file
10
layouts/shortcodes/table.html
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
{{/* See https://willschenk.com/articles/2020/styling_tables_with_hugo/ */}}
|
||||||
|
|
||||||
|
{{ $class := "markdown" }}
|
||||||
|
{{ with .Get "class" }}
|
||||||
|
{{ $class = delimit (slice $class .) " " }}
|
||||||
|
{{ end }}
|
||||||
|
|
||||||
|
{{ $htmlTable := .Inner | .Page.RenderString (dict "display" "block") }}
|
||||||
|
{{ $new := printf `<table class="%s">` $class }}
|
||||||
|
{{ (replace $htmlTable "<table>" $new) | safeHTML }}
|
Reference in New Issue
Block a user