2019-08-23 02:01:22 +08:00
|
|
|
{{ define "title" }}{{ .Title }} | {{ .Site.Title }}{{ end }}
|
2019-08-04 21:53:35 +08:00
|
|
|
|
|
|
|
{{ define "content" }}
|
|
|
|
{{ $publish_date := .PublishDate.Format (.Site.Params.dateFormatToUse | default "2006-01-02") }}
|
2019-08-17 03:40:34 +08:00
|
|
|
{{ $author := .Site.Author.name }}
|
2019-08-04 21:53:35 +08:00
|
|
|
{{ if isset .Params "author" }}
|
2019-08-17 03:40:34 +08:00
|
|
|
{{ $author = .Site.Author.name }}
|
2019-08-04 21:53:35 +08:00
|
|
|
{{ end }}
|
|
|
|
|
|
|
|
<article class="post-warp">
|
|
|
|
<header class="post-header">
|
|
|
|
<h1 class="post-title">{{ .Title }}</h1>
|
2019-08-17 03:40:34 +08:00
|
|
|
</header>
|
|
|
|
|
|
|
|
<div class="post-meta">
|
|
|
|
<div class="post-meta-main">
|
2019-08-19 01:36:52 +08:00
|
|
|
<a class="author" href="{{.Site.BaseURL }}" rel="author"><i class="fas fa-user-circle"></i> {{ $author }} </a>
|
2019-08-04 21:53:35 +08:00
|
|
|
{{ with .Params.categories -}}
|
|
|
|
<span class="post-category">
|
2019-08-19 01:36:52 +08:00
|
|
|
{{ T "included" }}
|
2019-08-04 21:53:35 +08:00
|
|
|
{{ range . }}
|
|
|
|
{{- $name := . -}}
|
|
|
|
{{- with $.Site.GetPage "taxonomy" (printf "categories/%s" $name) | default ($.Site.GetPage "taxonomy" (printf "categories/%s" ($name | urlize))) -}}
|
2019-08-19 01:36:52 +08:00
|
|
|
<i class="far fa-folder"></i> <a href="{{ .Permalink }}">{{ $name }}</a>
|
2019-08-04 21:53:35 +08:00
|
|
|
{{ end -}}
|
|
|
|
{{ end }}
|
|
|
|
</span>
|
|
|
|
{{- end }}
|
|
|
|
</div>
|
2019-08-17 03:40:34 +08:00
|
|
|
<div class="post-meta-other">
|
2019-08-17 23:16:09 +08:00
|
|
|
<span class="post-time"><i class="far fa-calendar-alt"></i> <time datetime={{ $publish_date }}>{{ $publish_date }}</time> </span>
|
|
|
|
<i class="fas fa-pencil-alt"></i> {{ T "wordCount" .WordCount }}
|
|
|
|
<i class="far fa-clock"></i> {{ T "readingTime" .ReadingTime }}
|
2019-08-23 02:01:22 +08:00
|
|
|
{{- if eq (getenv "HUGO_ENV") "production" | and .Site.Params.valine.enable | and .Site.Params.valine.visitor -}}
|
2019-08-17 23:16:09 +08:00
|
|
|
<span id="{{ .RelPermalink | relURL }}" class="leancloud_visitors" data-flag-title="{{ .Title }}">
|
|
|
|
<i class="far fa-eye"></i> {{ T "pageviews" | safeHTML }}
|
|
|
|
</span>
|
|
|
|
{{- end -}}
|
2019-08-17 03:40:34 +08:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2019-08-20 03:01:15 +08:00
|
|
|
{{ with .Params.featured_image }}
|
2019-08-23 02:01:22 +08:00
|
|
|
<div class="post-featured-image">
|
|
|
|
<img src=/images/loading.svg data-sizes=auto data-src={{ . }} alt="featured image" class="featured_image lazyload">
|
|
|
|
</div>
|
2019-08-20 03:01:15 +08:00
|
|
|
{{ end }}
|
|
|
|
|
2019-08-17 23:16:09 +08:00
|
|
|
{{ if or .Params.toc (and .Site.Params.toc (ne .Params.toc false)) -}}
|
|
|
|
<div class="post-toc" id="post-toc">
|
|
|
|
<h2 class="post-toc-title">{{ T "toc" }}</h2>
|
|
|
|
{{- $globalAutoCollapseToc := .Site.Params.autoCollapseToc | default true }}
|
2019-08-19 01:36:52 +08:00
|
|
|
<div class="post-toc-content{{ if not (and $globalAutoCollapseToc (ne .Params.autoCollapseToc false)) }} always-active{{ end }}">
|
|
|
|
{{ .TableOfContents }}
|
2019-08-17 23:16:09 +08:00
|
|
|
</div>
|
|
|
|
</div>
|
2019-08-20 03:01:15 +08:00
|
|
|
<div class="post-toc-mobile" id="post-toc-mobile">
|
|
|
|
<details>
|
2019-08-20 03:39:40 +08:00
|
|
|
<summary><div class="post-toc-title"><span>{{ T "toc" }}</span><span><i class="details icon fas fa-angle-down"></i></span></div></summary>
|
2019-08-20 03:01:15 +08:00
|
|
|
<div class="post-toc-content">
|
2019-08-20 03:08:25 +08:00
|
|
|
{{ $toc := .TableOfContents }}
|
|
|
|
{{ $toc = replaceRE `id="TableOfContents"` `id="TableOfContentsMobile"` $toc }}
|
|
|
|
{{ $toc | safeHTML }}
|
2019-08-20 03:01:15 +08:00
|
|
|
</div>
|
|
|
|
</details>
|
|
|
|
</div>
|
2019-08-17 23:16:09 +08:00
|
|
|
{{- end }}
|
|
|
|
|
2019-08-19 01:36:52 +08:00
|
|
|
<div class="post-content">
|
|
|
|
{{ $content := .Content }}
|
|
|
|
{{ $REin := `<img src="([^"]+)" alt="([^"]+)?" />` }}
|
|
|
|
{{ $REout := "<figure><img src=/images/loading.svg data-sizes=auto data-src=$1 alt=$2 class=lazyload><figcaption class=image-caption>$2</figcaption></figure>" }}
|
|
|
|
{{ $content = replaceRE $REin $REout $content }}
|
|
|
|
{{ $REin = `<img src="([^"]+)" alt="([^"]+)?" title="([^"]+)?" />` }}
|
|
|
|
{{ $REout = "<figure><img src=/images/loading.svg data-src=$1 data-sizes=auto alt=$2 title=$3 class=lazyload><figcaption class=image-caption>$2</figcaption></figure>" }}
|
|
|
|
{{ $content = replaceRE $REin $REout $content }}
|
|
|
|
{{ $REin = `:\(([\w- ]+?)\):` }}
|
|
|
|
{{ $REout = `<i class="inline-icon $1"></i>` }}
|
|
|
|
{{ $content = replaceRE $REin $REout $content }}
|
2019-08-19 13:26:39 +08:00
|
|
|
{{ $REin = `\[(.+?)\]\^\((.+?)\)` }}
|
|
|
|
{{ $REout = `<strong><ruby>$1<rt>$2</rt></ruby></strong>` }}
|
|
|
|
{{ $content = replaceRE $REin $REout $content }}
|
2019-08-20 12:15:40 +08:00
|
|
|
{{ $REin = `<(h[23456]) (id=".+?")>` }}
|
|
|
|
{{ $REout = `<a class="post-title-target" $2></a><$1>` }}
|
|
|
|
{{ $content = replaceRE $REin $REout $content }}
|
2019-08-19 01:36:52 +08:00
|
|
|
{{ $content | safeHTML }}
|
2019-08-04 21:53:35 +08:00
|
|
|
</div>
|
|
|
|
|
2019-08-19 01:36:52 +08:00
|
|
|
{{ partial "post/footer.html" . }}
|
2019-08-04 21:53:35 +08:00
|
|
|
|
|
|
|
<div class="post-comment">
|
2019-08-19 01:36:52 +08:00
|
|
|
{{ if ( .Params.comment | default true ) }}
|
2019-08-05 21:15:01 +08:00
|
|
|
{{ partial "comments.html" . }}
|
2019-08-04 21:53:35 +08:00
|
|
|
{{ end }}
|
|
|
|
</div>
|
|
|
|
</article>
|
2019-08-19 01:36:52 +08:00
|
|
|
{{- end }}
|