footer.html 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. {{/* variables for enabling/disabling parts of the footer */}}
  2. {{ $footerEnabled := site.Params.footer.enable | default true }}
  3. {{ $navigationEnabled := site.Params.footer.navigation.enable | default true }}
  4. {{ $customMenusEnabled := site.Params.footer.navigation.customMenus | default true }}
  5. {{ $contactMeEnabled := site.Params.footer.contactMe.enable | default true }}
  6. {{ $newsletterEnabled := site.Params.footer.newsletter.enable | default true }}
  7. {{ $credentialsEnabled := site.Params.footer.credentials.enable | default true }}
  8. {{ $disclaimerEnabled := site.Params.footer.disclaimer.enable | default false }}
  9. {{/* Keep backward compatibility for the newsletter function */}}
  10. {{ if site.Params.newsletter }}
  11. {{ if site.Params.newsletter.enable }}
  12. {{ $newsletterEnabled = true }}
  13. {{ else }}
  14. {{ $newsletterEnabled = false }}
  15. {{ end }}
  16. {{ end }}
  17. {{ if $footerEnabled }}
  18. {{ $author:= site.Data.author }}
  19. {{ if (index site.Data site.Language.Lang).author }}
  20. {{ $author = (index site.Data site.Language.Lang).author }}
  21. {{ end }}
  22. {{ $sections:= site.Data.sections }}
  23. {{ if (index site.Data site.Language.Lang).sections }}
  24. {{ $sections = (index site.Data site.Language.Lang).sections }}
  25. {{ end }}
  26. {{ $customMenus := site.Params.customMenus }}
  27. {{ if (index site.Data site.Language.Lang).site.customMenus }}
  28. {{ $customMenus = (index site.Data site.Language.Lang).site.customMenus }}
  29. {{ end }}
  30. {{ $copyrightNotice := now.Format "2006" | printf "© %s Copyright."}}
  31. {{ if (index site.Data site.Language.Lang).site }}
  32. {{ $siteConfig := (index site.Data site.Language.Lang).site }}
  33. {{ if $siteConfig.copyright }}
  34. {{ $copyrightNotice = $siteConfig.copyright }}
  35. {{ end }}
  36. {{ end }}
  37. {{ $disclaimer := "" }}
  38. {{ $siteConfig := (index site.Data site.Language.Lang).site }}
  39. {{ if $siteConfig.disclaimer }}
  40. {{ $disclaimer = $siteConfig.disclaimer }}
  41. {{ end }}
  42. {{/* footer logos */}}
  43. {{ $themeLogo := "/images/theme-logo.png" }}
  44. {{ $hugoLogo := "/images/hugo-logo.svg" }}
  45. {{/* resize the logos. don't resize svg because it is not supported */}}
  46. {{ $themeLogo:= resources.Get $themeLogo}}
  47. {{ if and $themeLogo (ne $themeLogo.MediaType.SubType "svg") }}
  48. {{ $themeLogo = $themeLogo.Resize "32x" }}
  49. {{ end }}
  50. {{ $themeLogo = $themeLogo.RelPermalink}}
  51. {{ $hugoLogo:= resources.Get $hugoLogo}}
  52. {{ if and $hugoLogo (ne $hugoLogo.MediaType.SubType "svg")}}
  53. {{ $hugoLogo = $hugoLogo.Resize "32x" }}
  54. {{ end }}
  55. {{ $hugoLogo = $hugoLogo.RelPermalink}}
  56. <footer id="footer" class="container-fluid text-center align-content-center footer pb-2">
  57. <div class="container pt-5">
  58. <div class="row text-left">
  59. {{ if $navigationEnabled }}
  60. <div class="col-md-4 col-sm-12">
  61. <h5>{{ i18n "navigation" }}</h5>
  62. {{ if $sections }}
  63. <ul>
  64. {{- range sort $sections "section.weight" }}
  65. {{ if and (.section.enable) (.section.showOnNavbar)}}
  66. {{ $sectionID := replace (lower .section.name) " " "-" }}
  67. {{ if .section.id }}
  68. {{ $sectionID = .section.id }}
  69. {{ end }}
  70. <li class="nav-item">
  71. <a class="smooth-scroll" href="{{ "" | absLangURL }}#{{ $sectionID }}">{{ .section.name }}</a>
  72. </li>
  73. {{ end }}
  74. {{- end }}
  75. {{ if $customMenusEnabled }}
  76. {{ range $customMenus }}
  77. {{ if .showOnFooter }}
  78. <li class="nav-item">
  79. <a class="smooth-scroll" href="{{ .url }}">{{ .name }}</a>
  80. </li>
  81. {{ end }}
  82. {{ end }}
  83. {{ end }}
  84. </ul>
  85. {{ end }}
  86. </div>
  87. {{ end }}
  88. {{ if (and $contactMeEnabled $author) }}
  89. <div class="col-md-4 col-sm-12">
  90. <h5>{{ i18n "contact_me" }}</h5>
  91. <ul>
  92. {{ range $key,$value:= $author.contactInfo }}
  93. {{ if (eq $key "email") }}
  94. <li><a href={{ printf "mailto:%s" $value }} target="_blank" rel="noopener">
  95. <span><i class="fas fa-envelope"></i></span> <span>{{ $value }}</span>
  96. </a></li>
  97. {{ else if (eq $key "phone") }}
  98. <li><span><i class="fas fa-phone-alt"></i></span> <span>{{ $value }}</span></li>
  99. {{ else if (eq $key "linkedin") }}
  100. <li><a href={{ printf "https://www.linkedin.com/in/%s" $value }} target="_blank" rel="noopener">
  101. <span><i class="fab fa-linkedin"></i></span> <span>{{ $author.name }}</span>
  102. </a></li>
  103. {{ else if (eq $key "github") }}
  104. <li><a href={{ printf "https://github.com/%s" $value }} target="_blank" rel="noopener">
  105. <span><i class="fab fa-github"></i></span> <span>{{ $value }}</span>
  106. </a></li>
  107. {{ else if reflect.IsMap $value }}
  108. <li>
  109. {{ if (and (isset $value "url") (isset $value "icon"))}}
  110. <a href={{ $value.url }} target="_blank" rel="noopener">
  111. <span><i class={{ printf "fab fa-%s" $value.icon }}></i></span> <span>{{ $value.text }}</span>
  112. </a>
  113. {{ else if isset $value "icon" }}
  114. <span><i class={{ printf "fab fa-%s" $value.icon }}></i></span> <span>{{ $value.text }}</span>
  115. {{ else }}
  116. <a href={{ $value.url }} target="_blank" rel="noopener">
  117. <span>{{ title $key }}: </span> <span>{{ $value.text }}</span>
  118. </a>
  119. {{ end }}
  120. </li>
  121. {{ else }}
  122. <li><span>{{ title $key }}: </span> <span>{{ $value }}</span></li>
  123. {{ end }}
  124. {{ end }}
  125. </ul>
  126. </div>
  127. {{ end }}
  128. <!-------------- Newsletter --------------->
  129. {{ if $newsletterEnabled }}
  130. {{ $provider := site.Params.footer.newsletter.provider }}
  131. <div class="col-md-4 col-sm-12">
  132. <p>{{ i18n "newsletter_text" }}</p>
  133. {{ if and (eq $provider "mailchimp") site.Params.footer.newsletter.mailchimpURL }} <!-- mailchimp -->
  134. <form
  135. action="{{ site.Params.footer.newsletter.mailchimpURL }}"
  136. method="post"
  137. id="mc-embedded-subscribe-form"
  138. name="mc-embedded-subscribe-form"
  139. class="validate"
  140. target="_blank"
  141. novalidate >
  142. <div class="form-group">
  143. <input
  144. type="email"
  145. class="form-control"
  146. id="mce-EMAIL"
  147. name="EMAIL"
  148. aria-describedby="emailHelp"
  149. placeholder="{{ i18n "newsletter_input_placeholder" }}"
  150. />
  151. <small id="emailHelp" class="form-text text-muted"
  152. >{{ i18n "newsletter_warning" }}</small
  153. >
  154. </div>
  155. <button type="submit" class="btn btn-info">{{ i18n "submit" }}</button>
  156. </form>
  157. {{ else }}
  158. <form method='post' action='https://blogtrottr.com'>
  159. <div class="form-group">
  160. <input type='email' class="form-control" name='btr_email' placeholder="{{ i18n "newsletter_input_placeholder" }}"/><br />
  161. <input type='hidden' name='btr_url' value='{{ "" | absLangURL }}index.xml' />
  162. <input type='hidden' name='schedule_type' value='1' />
  163. <small id="emailHelp" class="form-text text-muted">{{ i18n "newsletter_warning" }}</small>
  164. <button type="submit" class="btn btn-info"> {{ i18n "submit" }} </button>
  165. </div>
  166. </form>
  167. {{ end }}
  168. </div>
  169. {{ end }}
  170. </div>
  171. </div>
  172. {{ if and $disclaimerEnabled $disclaimer}}
  173. <hr />
  174. <div class="container">
  175. <p id="disclaimer"><strong>{{ i18n "disclaimer_text" }}:</strong> {{ $disclaimer | markdownify }}</p>
  176. </div>
  177. {{ end }}
  178. {{ if $credentialsEnabled }}
  179. <hr />
  180. <div class="container">
  181. <div class="row text-left">
  182. <div class="col-md-4">
  183. <a id="theme" href="https://github.com/hugo-toha/toha" target="_blank" rel="noopener">
  184. <img src="{{ $themeLogo }}" alt="Toha Theme Logo">
  185. Toha
  186. </a>
  187. </div>
  188. <div class="col-md-4 text-center">{{ $copyrightNotice | markdownify }}</div>
  189. <div class="col-md-4 text-right">
  190. <a id="hugo" href="https://gohugo.io/" target="_blank" rel="noopener">{{ i18n "hugoAttributionText" }}
  191. <img
  192. src="{{ $hugoLogo }}"
  193. alt="Hugo Logo"
  194. height="18"
  195. />
  196. </a>
  197. </div>
  198. </div>
  199. </div>
  200. {{ end }}
  201. </footer>
  202. {{end}}