For this part, we’re going to be setting up the basic page used for our post and make sure that it can be reached from the index page. We’re going to be switching between different files to show the iterative process that I went through in order to see results quickly.
We’re going to edit the single.html
to show the content by using the {{ .Content }}
tag from Hugo. We also add the {{ .Title }}
to the header and link it using the {{ .Permalink }}
tag to get the following.
<article class="h-entry">
<header>
<h1><a href="{{ .Permalink }}">{{ .Title }}</a></h1>
</header>
<section class="e-content post-body">
{{ .Content }}
</section>
It renders to the following:
data:image/s3,"s3://crabby-images/61b1d/61b1dd813a90c80d9e2b6fd2e311f10c47a519b3" alt="This is the first pass on the header. Simple article header with title"
Let’s go back to our index.html
to make it link to our post and show it on the main page.
|
|
The first line in the above code instructs hugo to iterate over all pages marked for the post type. On our local system, this isthe post
directory and is in a database when using Micro.blog. The Permalink
points to the individual post.
data:image/s3,"s3://crabby-images/382c0/382c0fa2f78b60b782976023dacd17ed37a2979b" alt="The index points to the different posts. Links between index and post"
We can test this by adding more content in the post
folder to see what it looks like.
data:image/s3,"s3://crabby-images/7e54e/7e54e9d26bec145214c811c795ba2adcdb06d1cc" alt="The current view of index page. Multiple posts on index"
But this highlights, we’re currently writing code in two places: the index.html
and the single.html
to render our content.
Note the forth line of the code which makes the assumption that we’re using a title for this post.
This is how I envision a post’s composition.
data:image/s3,"s3://crabby-images/4a857/4a857f42ca2e55f523ce36b47416a90e28f99892" alt="My wife hates it when I make diagrams! Mental model of post composition"
We’d check if a post has a title and from there show a header or not before displaying the content and ultimately the footer.
Abstracting the article from the page
Let’s create partials/article.html
and we’ll put all the content that we placed in _default/single.html
in it.
<article class="h-entry">
<header>
<h1><a href="{{ .Permalink }}">{{ .Title }}</a></h1>
</header>
<section class="e-content post-body">
{{ .Content }}
</section>
<footer>
<p>Category: <a href="#">Some Category</a><br/>
Tags: One Two Three</p>
<p>Published: Some Time</p>
</footer>
</article>
Then we replace the contents of default/single.html
with the following.
{{ define "main" }}
{{ partial "article.html" . }}
{{ end }}
When we render the page and there shouldn’t be any errors at this point.
Let’s add the conditional for the header of the article.
{{ if .Title }}
<header>
<h1><a href="{{ .Permalink }}">{{ .Title }}</a></h1>
</header>
{{ end }}
Then let’s make a post without a header to test out that this is working without an error in our logs.
data:image/s3,"s3://crabby-images/28cef/28cef592cd39e051404333d3d6bb7fce62c3be2d" alt="Sometimes coming up with a title is the hardest part about writing. Simple article without a header"
Next, we can work on the article footer which I’ll make into a separate component in the next installment.