index.html 2.0KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. {{ define "main" }}
  2. <main class="cf ph3 ph5-l pv3 pv4-l f4 tc-l center measure-wide lh-copy mid-gray">
  3. {{ .Content }}
  4. </main>
  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. {{ if $section }}
  11. {{/* Derive the section name */}}
  12. {{ $section_name := index (.Site.Params.mainSections) 0 }}
  13. <div class="pa3 pa4-ns w-100 w-70-ns center">
  14. {{/* Use $section_name to get the section title. Use "with" to only show it if it exists */}}
  15. {{ with .Site.GetPage "section" $section_name }}
  16. <h1 class="flex-none">
  17. Recent {{ .Title }}
  18. </h1>
  19. {{ end }}
  20. <section class="w-100 mw8">
  21. {{/* Range through the first three items of the section */}}
  22. {{ range (first 3 $section) }}
  23. <div class="relative w-100 mb4">
  24. {{ partial "summary-with-image.html" . }}
  25. </div>
  26. {{ end }}
  27. </section>
  28. <section class="w-100">
  29. <h1 class="f3">More</h1>
  30. {{/* Now, range through the next four after the initial 3 items. Nest the requirements, "after" then "first" on the outside */}}
  31. {{ range (first 4 (after 3 $section)) }}
  32. <h2 class="f5 fw4 mb4 dib mr3">
  33. <a href="{{ .URL }}" class="link black dim">
  34. {{ .Title }}
  35. </a>
  36. </h2>
  37. {{ end }}
  38. {{/* As above, Use $section_name to get the section title, and URL. Use "with" to only show it if it exists */}}
  39. {{ with .Site.GetPage "section" $section_name }}
  40. <a href="{{ .URL }}" class="link db f6 pa2 br3 bg-mid-gray white dim w4 tc">All {{.Title }}</a>
  41. {{ end }}
  42. </section>
  43. </div>
  44. {{ end }}
  45. {{ end }}