Anatomy of GitHub Pages
Learn the Files and development work flow of GitHub Pages. This includes working with you home page, theme, markdown, and more.
Overview of GitHub Pages files
Discuss how to develop a home page, code, run local server test, and then sync to deploy to GitHub Pages.
- Review tools setup and make in README.md to support this lesson.
Files and Directories in this Project
Here are some defintion to key files and directories in this project
-
README.md
: This file contains instructions and background information about the project. It is a standard file present in all properly set up GitHub projects. -
index.md
: This is the source file for the home page of the project. It is a standard file for all GitHub Pages projects. Note that Markdown (.md) files are converted to HTML by the Jekyll build process. HTML files are the only file type that is rendered on a website. -
_notebooks
: This directory contains Jupyter Notebook (.ipynb) files. These files are converted to Markdown (.md) files by the Makefile rules in the build process. The Markdown files are then converted to HTML by the Jekyll build process. -
_posts
: This directory contains Markdown (.md) files that will be part of the website. These files are formatted similarly to index.md and include frontmatter (metadata coded in YAML) and Markdown, HTML, JavaScript, and CSS source code. You will also find Liquid code in these files, which is used to generate Markdown, HTML, JavaScript, and CSS. -
_data
: This directory is the standard location for storing data files that support the _posts or _notebooks directories. -
images
: This directory is the standard location for storing image files (JPEG, PNG, etc.) that support the _posts or _notebooks directories. -
_config.yml
: This file contains YAML definitions (key-value properties) used to build the Jekyll website. -
.gitignore
: This file specifies elements to be excluded from version control. Files are excluded when they are derived from the original source and not considered part of the project’s source code. In the VSCode Explorer, you may notice some files appearing dimmed, indicating that they are purposely excluded by the rules in .gitignore.
Please note that there are many other key files and directories in a GitHub Pages project, but we will highlight those as the development progresses.
Changing the Theme
Google “github pages themes” or this theme link. The purpose of this section is to help you change your Theme options.
_config.yml
contains commented out alternatives to themes (see ‘# theme requirements’ cell below). Try these themes by commenting out midnight them with # at front and remove comment # from the front of theme of choice. After changing theme you will need to do amake clean
followed by amake
to test._includes/head.html
this file contains code to ensure page loads the proper JavaScript. This is a partial effort at support. You will need to follow README.md instruction of theme provider to finish convertion. FYI, th head.html is included from_layouts/default.html
Go to Themes click on Theme and scroll down to README.md and review requirements. Look their _layouts.html to understand requirements for integration.- Reading README.md should become common practice when using a repository. You should make sure your README has instructions. Also, in the Theme case, the best way to understand and make your own customizations is to understand how Theme providers customized theirs. Review these diligently if you want to become proficient and customizing your page.
# theme requirements
remote_theme: pages-themes/midnight@v0.2.0
# remote_theme: pages-themes/dinky@v0.2.0
# remote_theme: pages-themes/minimal@v0.2.0
# remote_theme: pages-themes/hacker@v0.2.0
# remote_theme: pages-themes/cayman@v0.2.0
# remote_theme: pages-themes/time-machine@v0.2.0
plugins:
- jekyll-remote-theme
Hacks
Perform customization to your ‘student’. This is an opportunity to learn a few concepts from ‘teacher’ repository and then customize your own page to your course needs and personal interests.
Customize Home Page
The home page to other pages is a common first step in building a project. To start you will need to form your index.md
in your project, which behind the scenes is generated into an index.html
by the GitHub Pages build process.
Change Title
Every page should have a title
. Here is frontmatter sample…
---
layout: default
title: My Title
---
GitHub Page, GitHub, GitHub Raw; Broken Links
Home Page usually is an information page describing the project. This often contains nice visuals and links to further content. Review the index.md
of the teacher repository.
GitHub displays information in three forms.
- GitHub Pages, Fully rendered link. This is the link we share with friends or community.
- GitHub, Partial rendered link. This is the link developer typically uses to discover a file in a project, GitHub tries to present markdown in a pretty form by default.
- GitHub raw, Source link. The raw link is in the project, but requires a 2nd click after discovery in GitHub. This contains the source the developer creates when building the pages.
Learn to add /game
when referening files in project to avoid broken links. File locations on localhost and on github.io can be different, this makes sure they are always found.
![csse](/game/images/ccr.png)
Making a Submenu
This is made from markdown and references images from the
image
foler.
index.md
is the file that contains markdown for this page_includes/nav_home.html
contains code for submenu, it is included in every page in this dialog/game
refers to baseurl defined in _config.yml, this is the localtion of all files in WebSite. Note, this changes as you run on localhost and deployed; make sure you remember to use this for locations of files in site.
<table>
<tr>
<td><img src="/game//images/logo.png" height="60" title="Frontend" alt=""></td>
<td><a href="/game/index">Course</a></td>
<td><a href="/game/home/table">Table</a></td>
<td><a href="/game/home/about">About</a></td>
</tr>
</table>
Style Hack
The Style submenu is using a Calculator as an example.
/assets/css/style.css
contains import of style customization per rules defined by GitHub Pages themse. Read the description on how Stye customization are handled by midnight in the README.md. This is a way to use there repo of customization, but also add individual spice. This is much faster than trying to do this by yourself./_posts/<date>Example-calculator.md
contains code for Calculator in the project. Only the top output is generating completely custom style, the remainder comes from adjusting style.css.- A Calculator is a great way to learn customizations of things like buttons, which are common elements in a Theme. Also, it is great way to learn Math operations. Suggested Hacks are inside this file.
- As you view the content of this file you will see CSS, HTML, and JavaScipt. To enhance this you would need to start to learn the basic structures and use a Cheat Sheet for reference. Also, putting this code into ChatGPT and aking for overview is a great way to understand line by line.