index.html 2.3KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  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. <div class="pa3 pa4-ns w-100 w-70-ns center">
  15. {{/* Use $section_name to get the section title. Use "with" to only show it if it exists */}}
  16. {{ with .Site.GetPage "section" $section_name }}
  17. <h1 class="flex-none">
  18. {{ $.Param "recent_copy" | default (i18n "recentTitle" .) }}
  19. </h1>
  20. {{ end }}
  21. {{ $n_posts := $.Param "recent_posts_number" | default 3 }}
  22. <section class="w-100 mw8">
  23. {{/* Range through the first $n_posts items of the section */}}
  24. {{ range (first $n_posts $section) }}
  25. <div class="relative w-100 mb4">
  26. {{ partial "summary-with-image.html" . }}
  27. </div>
  28. {{ end }}
  29. </section>
  30. {{ if ge $section_count (add $n_posts 1) }}
  31. <section class="w-100">
  32. <h1 class="f3">{{ i18n "more" }}</h1>
  33. {{/* Now, range through the next four after the initial $n_posts items. Nest the requirements, "after" then "first" on the outside */}}
  34. {{ range (first 4 (after $n_posts $section)) }}
  35. <h2 class="f5 fw4 mb4 dib mr3">
  36. <a href="{{ .Permalink }}" class="link black dim">
  37. {{ .Title }}
  38. </a>
  39. </h2>
  40. {{ end }}
  41. {{/* As above, Use $section_name to get the section title, and URL. Use "with" to only show it if it exists */}}
  42. {{ with .Site.GetPage "section" $section_name }}
  43. <a href="{{ .Permalink }}" class="link db f6 pa2 br3 bg-mid-gray white dim w4 tc">{{ i18n "allTitle" . }}</a>
  44. {{ end }}
  45. </section>
  46. {{ end }}
  47. </div>
  48. {{ end }}
  49. {{ end }}