gabrielgio.me @ 4b494b189fc1d1dcf9dc7cf6ab6f0275729c63ce

 1{{ define "main" }}
 2  <article class="cf ph3 ph5-l pv3 pv4-l f4 tc-l center measure-wide lh-copy mid-gray">
 3    {{ .Content }}
 4  </article>
 5  {{/* Define a section to pull recent posts from. For Hugo 0.20 this will default to the section with the most number of pages. */}}
 6  {{ $mainSections := .Site.Params.mainSections | default (slice "post") }}
 7  {{/* Create a variable with that section to use in multiple places. */}}
 8  {{ $section := where .Site.RegularPages "Section" "in" $mainSections }}
 9  {{/* Check to see if the section is defined for ranging through it */}}
10  {{ $section_count := len $section }}
11  {{ if ge $section_count 1 }}
12    {{/* Derive the section name  */}}
13    {{ $section_name := index (.Site.Params.mainSections) 0 }}
14
15    <div class="pa3 pa4-ns w-100 w-70-ns center">
16      {{/* Use $section_name to get the section title. Use "with" to only show it if it exists */}}
17       {{ with .Site.GetPage "section" $section_name }}
18          <h1 class="flex-none">
19            {{ $.Param "recent_copy" | default (i18n "recentTitle" .) }}
20          </h1>
21        {{ end }}
22
23      {{ $n_posts := $.Param "recent_posts_number" | default 3 }}
24
25      <section class="w-100 mw8">
26        {{/* Range through the first $n_posts items of the section */}}
27        {{ range (first $n_posts $section) }}
28          <div class="relative w-100 mb4">
29            {{ partial "summary-with-image.html" . }}
30          </div>
31        {{ end }}
32      </section>
33
34      {{ if ge $section_count (add $n_posts 1) }}
35      <section class="w-100">
36        <h1 class="f3">{{ i18n "more" }}</h1>
37        {{/* Now, range through the next four after the initial $n_posts items. Nest the requirements, "after" then "first" on the outside */}}
38        {{ range (first 4 (after $n_posts $section))  }}
39          <h2 class="f5 fw4 mb4 dib mr3">
40            <a href="{{ .Permalink }}" class="link black dim">
41              {{ .Title }}
42            </a>
43          </h2>
44        {{ end }}
45
46        {{/* As above, Use $section_name to get the section title, and URL. Use "with" to only show it if it exists */}}
47        {{ with .Site.GetPage "section" $section_name }}
48          <a href="{{ .Permalink }}" class="link db f6 pa2 br3 bg-mid-gray white dim w4 tc">{{ i18n "allTitle" . }}</a>
49        {{ end }}
50        </section>
51      {{ end }}
52
53      </div>
54  {{ end }}
55{{ end }}