title | summary | date | layout |
---|---|---|---|
Home |
About this page. |
2016-04-13 |
default |
A skeleton-site for a personal academic website, written in Jekyll for hosting with GitHub Pages.
- Minimal, clean design
- CV-specific print-style
- Responsive layout with collapsible sidebar-menu
- Hierarchical menu with deep linking
- Site-wide search-system
- Simple social sharing buttons
- Optional MathJax for displaying mathematical notations
- Register an account with GitHub
- Fork
https://github.com/OleVik/personal-academic-website
- Rename repository to
username.github.io
, whereusername
is your GitHub-username - Set
baseurl
tousername.github.io
in_config.yml
- Edit Markdown-files (
.md
)
Edit the pages using any Markdown-editor (see below) or text-editor, then upload them.
If you want to use a custom domain, ie. not username.github.io
but something like mywebsite.com
, read this guide.
Pages are written Markdown and use FrontMatter. For Markdown, see this cheatsheet or this quick guide. Alternatively, view the default "Hello"-document on StackEdit.
Defines the settings for each page, using this format (minimal requirements for each page):
- Title: Double quote-encapsulated string naming the page
- Summary: Double quote-encapsulated string describing the page
- Date: Date for when the page was written (YYYY-MM-DD)
- Layout: String governing layout to use, either "default" or "cv" (no quotes)
For example:
---
title: "About"
summary: "About this page."
date: 2016-04-02
layout: default
---
More options are available here.
Notes:
- Indentation, if used, must be two spaces (not tabs).
- Colons (
:
) can only be used in strings if enclosed in quotes. - Dashes can be used in strings, but should otherwise also be enclosed in quotes (see this).
- Layout must be "cv" (
layout: cv
) - See
cv.md
for other variables - List-elements are the following:
experience, education, positions
- These consist of nested lists in YAML, for example:
education:
- years: 2013-2015
name: Master’s Degree
location: University
description: Includes qualitative and quantitative methods.
- years: 2010-2013
name: Bachelor’s Degree
location: University
description: Includes statistics and maths.
To add other list-elements, edit _layouts/cv.html
, and duplicate the blocks of code including a for-loop, changing the variable (page.variable
) in:
{% raw %}{% for item in page.experience %}
Various HTML code...
{% endfor %}{% endraw %}
To whatever you name the list.
In order of most recommended for this workflow:
- Prose: "Simple content authoring environment for CMS-free websites", very easy to use for editing GitHub Pages.
- Direct editing, only requires GitHub authorization.
- StackEdit: Elegant interface with live preview and extensive features.
- Can publish to GitHub, saves documents in local browser storage or the cloud.
- DraftIn: Also elegant and easy-to-use interface with extensive features.
- Requires signup (e-mail).
- Handy Chrome extension for editing text on any website.
Or just edit pages directly on GitHub.
PDF-files can be linked to from the GitHub Repository, but it is far easier to upload it to Google Drive and embed it (or any other cloud storage that generates an <iframe>
-embed tag).
Procedure (from here):
- Find the PDF file in Google Drive.
- Preview the PDF file in Google Drive.
- Pop-out the Google Drive preview.
- Use the More actions menu and choose Embed item.
- Copy code provided.
- Paste it on a separate line in the Markdown-file, like this:
Paragraph...
<iframe style="margin: 10px 0 40px 0;" class="pdf-iframe" src="https://drive.google.com/file/d/0B-xXQEsWEjrUUmpBdkhIVS10YjA/preview" width="100%" height="768"></iframe>
Other Markdown and text.
The links in the menu, and their order, are edited through _config.yml
. The format is also nested YAML lists, like the FrontMatter described above. 'baseurl' must be set to your repository (eg. baseurl: username.github.io
), or the build will fail. The name
and description
variable should also be set, as well as mathjax: true
if you need to render MathJax formulas on pages.
The markdown, encoding, locale
variables should not be changed.
To find the right page-link (#somethingonthepage
) you open the page, hover a heading so that the icon-link displays, right-click it and choose "Copy link". Everything after the #
is the link for this specific title on the page.
Note that these links must be encapsulated in quotes in the lists in _config.yml
, or they will be interpreted as code-comments.
Written in Jekyll, structured with Bootstrap v4, styled with plain CSS. The Jekyll-output (in the _site
-folder when generated) can be hosted anywhere (static files). For further development, see Jekyll Tips and GitHub Pages Setup Guide.