Skip to main content

Building an Academic Portfolio

Over Thanksgiving, my sister had an idea brewing. ā€œI have enough publications and projects out there, Iā€™d like to put everything together on a website.ā€ Sheā€™s quite tech savvy and talented with design. I encouraged her to go for it and let her know I would be here to support her if she wanted.

A couple weeks later, she texted: could we build this together? Heck yes! We successfully launched her website just after Christmas.

The stack

Real quick, to cover the basics: my sister and I started our collaboration with a shared Google Drive, drafting the content structure, and looking at aspirational websites to understand what she envisioned.

The specifics Iā€™ll put to a table:

TechnologyPurposeRating
HugoStatic site generator (SSG) in Go programming languagešŸ’Æ
WowchemyPre-built theme for Hugo (Academic ResumĆ©) with lots of batteries includedšŸŽ‰
NetlifyBuild-deploy cloud platformšŸ’Æ
GitDistributed version control systemšŸ’Æ
GitLabDevOps platform, hosts Git repositoryšŸ’Æ
ForestryContent management system (CMS), an editor compatible with many popular SSGs (incl Hugo) that sits atop your hosted source code (incl GitLab)šŸ˜•
Google DomainsDomain registrar, custom domainsšŸ’Æ
GoatCounterAnalytics for site trafficā²1
ffmpegA bit of light media file processingšŸ’Æ

And a hastily drawn diagram shows how the pieces fit together:

system diagram showing my local Hugo server and git commit setup, my sister editing online with Forestry, and GitLab, Netlify, and Google Domains making the published content available online

Decisions and tradeoffs

The action Iā€™m most proud of was listening, hearing what was important to her. Two priorities guided our decisions:

  1. speed to launch
  2. customizing the site design

When speed is critical, play to your strengths. Iā€™ve spent the past year building my personal site with Hugo because itā€™s fantastic for making websites with static content. Hugo was a solid choice.

Though on my personal site Iā€™ve forked and developed a theme, I did not build a custom theme for my sister. Why? My theme is a work in progress, and one that Iā€™ve tinkered with to suite my interests, my problems. It is incomplete. Trying to build and release a custom theme while at the same time building the site would have been a distraction and would likely have delayed launch.

The academic portfolio is about my sister and her content, so when we searched Hugo themes and found one that specialized in academic content, it ended up being a great fit! Because I donā€™t live in the academic world, there were all sorts of features she recognized and immediately found useful that I wouldnā€™t have thought of, for example iconography for links to Google Scholar or a url_doi field. Though I didnā€™t build a custom theme, the time I spent tinkering educated me on Hugoā€™s core concepts: lookup order, front matter, configuration, convention and structure. The theme publisher had great documentation, and my experience gave me context to search more effectively and ask better questions.

I had a third priority: ease of content editing for my sister, and I missed the mark. Forestry was a gamble, I knew better: gamble on new services and technology on your own time, not with clients. Being well-equipped to customize and modify the site was a key reason for choosing Hugo over Wordpress. Forestry and platforms like it make it possible for non-coders to manage and add content to their sites without coding, and it supports several popular generators. However, the following gaps were a problem:

  1. No preview server, outdated versions of Hugo : On time of writing, the latest Hugo version is 0.91. The pre-built theme used version 0.84, the latest available by Forestry 0.81. This meant my sister could see edits in a WYSIWYG editor but couldnā€™t preview them as part of the site before publish.

  2. Limited abstraction of Hugoā€™s full capabilities : Hugo can support either a single post file (this-post-is-great.md) or a directory which is especially useful for organizing related media (this-post-is-useful/index.md). Forestry could interpret either structure but my sister couldnā€™t upload a featured image into a directory. To flip the problem, the pre-built theme might have used front matter instead of convention to support a featured image just like it does to support alt text and captions. šŸ¤·šŸ¼ā€ā™€ļø Oh well, itā€™s still one of a few missing capabilities for managing a Hugo site:

    • can only upload media to one static directory
    • adding a post to a directory, no option to rename the file to index.md
    • cannot edit Hugo configuration or theme configuration files (maybe a limitation of the outdated Hugo version?)
  3. No viewing or managing version history from the editor : It comforted me knowing ā€œitā€™s all Gitā€. Nearly any mistake could be fixed with a quick git revertā€”but not in the editor. Thereā€™s a Site Activity icon by the logo but no way to see commit hashes to a file or revert to a change like you might in GitHub or GitLab.

  4. So many commits : Each save is a commit, and more commits is more build minutes. Over the week I jumped over 100 minutes of 300 minutes available (normally I average 5-10 minutes per month).

    Sidenote: I realized I want something like a branch feature so not every change needs to be draft-or-live: you can save changes to a ā€œreleaseā€, and publishing your changes is like merging your branch into the main development branch. Iā€™m sure this is challenging (rebasing branches, for one) but itā€™s an idea.

Summary

What Iā€™m curious about next

Footnotes

  1. I use GoatCounter for basic analytics. Once the site has traffic, weā€™ll assess if it meets her needs. ā†©