{{ define "main" }}
{{ .Content }} {{/* Define a section to pull recent posts from. For Hugo 0.20 this will default to the section with the most number of pages. */}} {{ $mainSections := .Site.Params.mainSections | default (slice "post") }} {{/* Create a variable with that section to use in multiple places. */}} {{ $section := where .Site.RegularPages "Section" "in" $mainSections }} {{/* Check to see if the section is defined for ranging through it */}} {{ $section_count := len $section }} {{ if ge $section_count 1 }} {{/* Derive the section name */}} {{ $section_name := index (.Site.Params.mainSections) 0 }} {{ if $.Param "all_post_list" }} {{ partial "all-posts-list.html" . }} {{ else }}
{{/* Use $section_name to get the section title. Use "with" to only show it if it exists */}} {{ with .Site.GetPage "section" $section_name }}

{{ if .Site.Params.index_show_recent }} Recent {{ .Title }}: {{ else }} {{ .Title }}: {{ end }}

{{ end }} {{ $n_posts := $.Param "recent_posts_number" | default 3 }}
{{/* Range through the first $n_posts items of the section */}} {{ range (first $n_posts $section) }}
{{ partial "summary-with-image.html" . }}
{{ end }}
{{ if ge $section_count (add $n_posts 1) }}

{{$.Param "index_more_copy" | default "More" }}

{{/* Now, range through the next four after the initial $n_posts items. Nest the requirements, "after" then "first" on the outside */}} {{ range (first 4 (after $n_posts $section)) }}

{{ .Title }}

{{ end }} {{/* As above, Use $section_name to get the section title, and URL. Use "with" to only show it if it exists */}} {{ with .Site.GetPage "section" $section_name }} {{$.Param "index_all_copy" | default "All" }} {{.Title }} {{ end }}
{{ end }}
{{ end }} {{ end }}
{{ end }}