aboutsummaryrefslogtreecommitdiffstats
path: root/layouts/archives/single.html
blob: be44c9fe2ad8c7f0813551e8e1365e3c95d2efae (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
{{ define "main" }}
<header>
{{- partial "header.html" . -}}
</header>
<content>
  {{ if .Data.Singular }}
  <h3 style="margin-bottom:0">Filtering for "{{ .Title }}"</h3>
  <small>
    <a href="{{ "blog" | relURL }}">Remove filter</a>
  </small>
  {{ end }}

  {{ if .Site.Params.postSearch }}
  <input id="search-input" type="text" placeholder="Search..." style="margin-top: 16px" />
  <script>
    // 等待 DOM 完全加载后执行
    document.addEventListener('DOMContentLoaded', function () {
      // 缓存 DOM 元素
      const searchInput = document.getElementById('search-input');
      const posts = document.querySelectorAll('.blog-posts li');
      const years = document.querySelectorAll('.blog-posts h3');

      // 更新搜索结果
      function updateSearchResults(searchTerm) {
        let visiblePosts = 0;
        const displayedYears = new Set();
        posts.forEach(function (post) {
          const title = post.querySelector('a').textContent.toLowerCase();
          const year = post.querySelector('time').getAttribute('datetime').split('-')[0];
          if (title.includes(searchTerm)) {
            post.style.display = '';
            visiblePosts++;
            displayedYears.add(year);
          } else {
            post.style.display = 'none';
          }
        });

        {{ if .Site.Params.groupByYear }}
        years.forEach(function (y) {
          const year = y.textContent;
          y.style.display = displayedYears.has(year) ? '' : 'none';
        });
        {{ end }}

        {{ if .Site.Params.showPostCount }}
        const countText = `There ${visiblePosts <= 1 ? `is ${visiblePosts} piece.` : `are ${visiblePosts} pieces.`}`;
        document.getElementById('post-count').innerHTML = countText;
        {{ end }}
      }

      searchInput.addEventListener('input', function () {
        updateSearchResults(this.value.toLowerCase().trim());
      });
    });
  </script>
  {{ end }}

  {{ $allPosts := where .Site.RegularPages "Type" "eq" "posts" }}
  {{ $excludePosts := where $allPosts "Params.categories" "intersect" (slice "1") }}
  {{ $postPages := ($allPosts | complement $excludePosts) }}

  {{ if .Site.Params.showPostCount }}
  <p id="post-count">There {{ if le (len $postPages) 1 }} is {{ len $postPages }} piece. {{ else }} are {{ len $postPages }} pieces. {{ end }}</p>
  {{ end }}

  <ul class="blog-posts">
    {{ $currentYear := 0 }}
    {{ range $postPages }}
      {{ if .Site.Params.groupByYear }}
        {{ $year := .Date.Year }}
        {{ if ne $year $currentYear }}
          <h3>{{ $year }}</h3>
          {{ $currentYear = $year }}
        {{ end }}
      {{ end }}
      <li>
        <span class="{{ if .Site.Params.groupByYear }} grouped {{ else }} ungrouped {{ end }}">
          <i>
            <time datetime='{{ .Date.Format "2006-01-02" }}' pubdate>
              {{ if .Site.Params.groupByYear }}
                {{ .Date.Format (default "2006-01-02" .Site.Params.dateFormat) }}
              {{ else }}
                {{ .Date.Format (default "02 Jan, 2006" .Site.Params.dateFormat) }}
              {{ end }}
            </time>
          </i>
        </span>
        <a href="{{ .Permalink }}">{{ .Title }}</a>
      </li>
    {{ else }}
      <li>No posts yet</li>
    {{ end }}
  </ul>

  {{ if .Data.Singular }}
  {{ else }}
  <small>
    <div>
      {{ range .Site.Taxonomies.tags }}
        <a href="{{ .Page.Permalink }}">#{{ .Page.Title }}</a>&nbsp;
      {{ end }}
    </div>
  </small>
  {{ end }}
</content>
{{ end }}