Personal Portfolio and Blog

Portfolio Homepage

Introductory Note

The website you are currently visiting is my personal portfolio and blog. I consider this site an active, ongoing project of mine because I will be continually updating it with new tool integrations and posts.

The Hugo theme, Wowchemy, is developed by George Cushen. I am using George Cushen’s theme, reformatting the basic templates, and adding new API integration for my personal customizations. The default theme demo can be found here.

Wowchemy is free to use and customize under the MIT License.

This project page will go over my design choices and third-party integrations. Further analyses will be added as I integrate or create new functionalities.


Design

Custom Domain

My custom domain was registered at Google Domains. I generally recommend Google Domains over other domain registrars because Google Domains is:

  • Inexpensive
  • Provides included privacy protection

My domain costs $12 a year with included privacy protection, and I have enough faith in Google that it will not raise prices without notice.

Site Hosting

This site’s source code is hosted on GitHub in a private repository. I update my site by pushing changes to the repository.

Deployment

The site is deployed by Netlify. Netlify has a deploy key which allows it to continually update my site when I push new changes to the repository.

Single vs Multiple Pages

I chose multiple pages over single pages because the amount of technical and project posts would end up increasing the total amount of widgets on the homepage. Furthermore, linking menu items to homepage widgets will persist even after the user changes to different pages. Clicking the back-button will cause the user to jump back to the previous widget it was set to.


Integration

Prodibi

Prodibi is an image platform which allows you to embed high resolution photos to a website. I am using their API to display my travel albums from New Zealand, Australia, Japan, and California.

I wrote a simple Prodibi shortcode for Hugo. Feel free to use the code below.

Prodibi Shortcode

Designed For: George Cushen's Academic Theme

{{ if .Get "style" | eq "grid" }}
	<div data-prodibi='{"type":"grid","settings":{"container":"{{ .Get "containerID" }}","account":"{{ .Get "username" }}"}}'>
		<script>;!function() {if (window.prodibiAsync == null) { var s = document.createElement('script'); s.async = !0; s.src = 'https://max1.prodibicdn.com/libraries/pages/prodibi.embed.2.0.min.js'; document.body.appendChild(s); }window.prodibiAsync = window.prodibiAsync || [];prodibiAsync.push({ type: "settings", settings: { account: "{{ .Get "username" }}" } });}();</script>
	</div>
{{ else if .Get "style" | eq "album" }}
	<canvas data-prodibi='{"type":"thumbnailMediaView","settings":{"cover":{"heightMode":"aspectRatio"},"container":"{{ .Get "containerID" }}","account":"{{ .Get "username" }}"}}'>
		<script>;!function() {if (window.prodibiAsync == null) { var s = document.createElement('script'); s.async = !0; s.src = 'https://max1.prodibicdn.com/libraries/pages/prodibi.embed.2.0.min.js'; document.body.appendChild(s); }window.prodibiAsync = window.prodibiAsync || [];prodibiAsync.push({ type: "settings", settings: { account: "{{ .Get "username" }}" } });}();</script>
	</canvas>
{{ end }}

Usage: {{< prodibi style="grid" containerID="[albumID]" username="[prodibiUserName]" >}}

containerID is the ID of the album found on the website. username is the account name of the Prodibi user.

The shortcode has two style options:

  • grid - Pinterest style gallery option
  • album - Single image per page

If the images do not load/render, then there might be an issue with your Prodibi gallery settings or shortcode usage error.

view raw prodibi.md hosted with ❤ by GitHub

PDF Render

I originally used Google Drive Viewer to render my PDF files, however, I noticed that the viewer had a bug where it would occasionally return an error code. Thus, I decided to embed the PDF file directly instead.

The shortcode I wrote will:

  • Display the PDF file using the browser’s native plugin
  • Link to where the PDF can be found if render is unsuccessful

Embed PDF Shortcode

Designed For: George Cushen's Academic Theme

If the browser is able to render the PDF file, it will do so. If not, the browser will display an error message and link to the address given in the url parameter of the shortcode.

Usage: {{< embedpdf url="pdfURL" >}}

<div class="responsive-wrap">
	<object data="{{ .Get "url" }}" type="application/pdf" style="margin: 0 auto;height: 100vh;width: 100%;">
		<embed src="{{ .Get "url" }}" type="application/pdf "style="margin: 0 auto;height: 100vh;width: 100%;">
			<em>It seems that your browser cannot display the PDF file; Please use this <a href="{{ .Get "url" }}"><strong>link</strong> </a>
			instead. Thanks!</em>
	</object>
</div>
view raw embedpdf.md hosted with ❤ by GitHub

Commenting

The comment system is provided by Commento. Commento is a lightweight, and privacy-oriented comment platform. You can choose to either use a hosted plan or host a server yourself.

Yiping Su
Yiping Su
Software Engineer

I am interested in data, software engineering, and the application of computer science concepts in real-world scenarios.