Intro to Git
Build Your Own Website with Github Pages and Cloud9
Women Who Code DC
Front End Hack Night
About Me
Alexandra Ulsh
alexandraulsh.com
@AlexUlsh
Women Who Code DC Front End Hack Night (FEHN) Lead
InfoSec @ Mapbox
data:image/s3,"s3://crabby-images/256e5/256e5170ff7690302f0be572a2eec131740dc0bd" alt=""
data:image/s3,"s3://crabby-images/3c57e/3c57e5d9798a7fe0e85027b84501150a0c858ded" alt=""
Goals
- Learn Git
- Learn GitHub
- Learn GitHub Pages
- Learn a little Bash
- Learn Cloud9
After tonight, you will be able to use Git, Github Pages, and Cloud9 IDE to host your own website!
What is Open Source?
Open = Free, available, public, transparent
Source = software source code
Public software projects on GitHub are open source.
Opposite of commercial proprietary software.
What is Git?
A software program that helps you write software.
Distributed version control for source code
Distributed = more than one copy on more than one computer
Created in 2005 by Linus Torvalds (Linux kernel).
data:image/s3,"s3://crabby-images/55f00/55f0065cde1e6c18558e4e4d8dac1843a5d17d2d" alt=""
Git = a software program
data:image/s3,"s3://crabby-images/6c5e0/6c5e0cc41f663d881d646d4232606f7398c22b87" alt=""
What is GitHub?
A website that hosts public and private Git repositories
Repository = a project or set of files
"Social coding"
Created in 2008
data:image/s3,"s3://crabby-images/15c24/15c249c322d6ba76fa47e4cd3346a6bc36cfffbc" alt=""
GitHub = a website
data:image/s3,"s3://crabby-images/0ac37/0ac3764ac0e843b94c4adf773b1dd19ccaaa64dc" alt=""
Git
+
social media
=
GitHub
tl;dr
What is GitHub Pages?
Public
Uses specially named repositories
User pages = http://username.github.io/
Organization pages = http://organization.github.io/
Project pages = http://username.github.io/my-cool-project
GitHub Pages Limitations
- Only static files
- HTML, CSS, JavaScript, CSV, JSON, GeoJSON
- No PHP, Node.js, Ruby, Django, or server-side frameworks
- This means it is hard to manage pieces of code that repeat on multiple pages - menus, headers, and footers
Unless you use Jekyll!
Jekyll
- Static site generator
- Uses template and configuration files
- GitHub Pages runs on Jekyll
- GitHub the website runs on Ruby on Rails
- Jekyll = a Ruby gem
data:image/s3,"s3://crabby-images/edec8/edec8f638deef5c7a4d40b41e23069ca2d37c3f0" alt=""
data:image/s3,"s3://crabby-images/b51f4/b51f4169bc70392f44a082b87092b9e53a7a56eb" alt=""
Why use GitHub Pages?
- Free!
- Secure
- Easy to use and configure
- Under source control automatically
- Use Jekyll to host your blog
data:image/s3,"s3://crabby-images/0b880/0b8801f7a24acc11cb000397adcd6f4e66f5e6fb" alt=""
What is Cloud9?
Free cloud-based integrated development environment (IDE)
Each workspace is its own Ubuntu Docker container
Support for 40+ programming languages
data:image/s3,"s3://crabby-images/2ced9/2ced94a65ba01727e60278d8b85820d9718e0963" alt=""
Why use Cloud9?
- Hardware agnostic = socioeconomic accessibility
- Saves time - pre-configured
- Amazing productivity features
- Live preview and cross-browser testing
- Collaborative coding - "Google docs style"
- Available from any computer or tablet
Best way to code on a Chromebook
Why have a personal website?
- Great first front
end development project - Complete control of your personal brand
- Shows up when you Google your name
- Career advancement
- Showcase portfolio
Women are encouraged to not self-promote...
Let's change that by building a personal website!
Let's get started!
Create a GitHub Account
https://github.com/
data:image/s3,"s3://crabby-images/6681c/6681c1c0904314ae294fdd337b6a35cc90f034eb" alt=""
data:image/s3,"s3://crabby-images/3ff07/3ff07e3f2756a7275093f7a9bb51d8d7a9667fdf" alt=""
Keep the Free Plan
data:image/s3,"s3://crabby-images/0d742/0d742bf0132f8757ce64bd815ca394489ccfccb0" alt=""
GitHub Welcome Page
Create a New User Pages Repository
data:image/s3,"s3://crabby-images/67884/678840fc407f4d7c5dfc8563a3cfe2e6e13f48ac" alt=""
username.github.io
GitHub Repository
data:image/s3,"s3://crabby-images/31a73/31a7383b9aea17ad8d05ee31ab7bf6bc1b50c72b" alt=""
GitHub User Profile
data:image/s3,"s3://crabby-images/7c926/7c926d0b87046e9198d376ecc36721dcd4e19bea" alt=""
Organization Profile
data:image/s3,"s3://crabby-images/ae94a/ae94a23b8ad68015e49f23e59d16134be72db44b" alt=""
What is README.md?
.md = Markdown
"Text-to-HTML conversion tool"
GitHub Flavored Markdown
You can use Emojis!
data:image/s3,"s3://crabby-images/aecd7/aecd75a62dfa9ec13c7302f0964cec97f4d95711" alt=""
Cloud9 - GitHub Sign In
https://c9.io/
data:image/s3,"s3://crabby-images/45738/4573871fbd33586eccc68f5fd2781020ec32a6f1" alt=""
Authorize application
data:image/s3,"s3://crabby-images/1d607/1d607afc702451bb3e042772b8ecd7ca2ec0e44e" alt=""
data:image/s3,"s3://crabby-images/acaf8/acaf8193b8af30b8a6ade37807fc670ce2bc3ea8" alt=""
Cloud9 Dashboard
Clone Username Repo
data:image/s3,"s3://crabby-images/cec69/cec69258e4f2b42555cdd6b99211aa205b692c5f" alt=""
Create Workspace from Repo
data:image/s3,"s3://crabby-images/a0153/a01531e425a408a36f3aceed7b3c39a201f27359" alt=""
data:image/s3,"s3://crabby-images/5b7d5/5b7d5a8bb35a60db63571b590f8225b0f58eb885" alt=""
Repository Workspace
Git is already installed
data:image/s3,"s3://crabby-images/4ac55/4ac55570c829626e95a1e48f282c741d91967b6e" alt=""
Let's add some files!
data:image/s3,"s3://crabby-images/27d9d/27d9dd90c15016be144e49501909c46df1d4dab0" alt=""
Create with GUI
data:image/s3,"s3://crabby-images/69615/69615899fae65ef7cac329266d1384cfd2a47626" alt=""
GUI = Graphical User Interface
Upload Local Files
data:image/s3,"s3://crabby-images/e9dae/e9dae6ab76a041193844d23f11ca2c81229c6983" alt=""
Create files via Bash
# Create a new file
touch index.html
data:image/s3,"s3://crabby-images/bc859/bc8595a7fd85b6802327c47f8963a373b9759c50" alt=""
Quick Intro to Bash
Why learn bash? Because it saves time
Builds command line interface (CLI) skills
CLIs used in SASS, bower, Node.js, and Ruby
The Terminal
data:image/s3,"s3://crabby-images/f3bea/f3bea267eeb333cc955c6fdea4e94c5c1d95f417" alt=""
Create files via the Terminal
# Create a new file
touch index.html
# Create a new directory (folder)
# mkdir = "Make directory"
mkdir css
# Change the current directory
# cd = "Change directory"
cd css
# Create CSS stylesheet
touch styles.css
Open Files Quickly in Cloud9
# Open file in Cloud9
c9 index.html
data:image/s3,"s3://crabby-images/905d3/905d308e14f8e26fceab2bdbaaedb1d91fbf32ba" alt=""
# Where am I? What's my working directory?
# pwd = "Print working directory"
pwd
# returns /home/ubuntu/workspace/css
# List files in current directory
# ls = "list"
ls
# returns styles.css
# Go back a directory (to the parent)
cd ..
# Go back two directories
cd ../..
# Clear all text in the terminal
clear
Navigating the File System
# Remove a file
# rm = "Remove"
rm styles.css
# Remove a directory containing files
# -r = "Recursive"
rm -r css
# Delete empty directory
# rmdir = "Remove directory"
rmdir js
Deleting Files and Directories
Let's add some code!
data:image/s3,"s3://crabby-images/dfbc3/dfbc32fff96eedb8d566753cf6fc5f9c95ae5bbe" alt=""
index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>My Personal Website</title>
<link href="css/styles.css" rel="stylesheet" type="text/css">
</head>
<body>
<div class="container">
<h1>My Personal Website</h1>
<p>Here's a puppy</p>
<img src="img/Dougie-the-Shih-Tzu.jpg">
</div>
</body>
</html>
Preview index.html
data:image/s3,"s3://crabby-images/c8e97/c8e9703289be1323586bc83eddadd95c9aa80221" alt=""
Side by Side
data:image/s3,"s3://crabby-images/da336/da33649ea548ca815b32b9b451cb45db7dd664fb" alt=""
Live Preview Changes
data:image/s3,"s3://crabby-images/9f0f9/9f0f93b8671deb49bc64ef9d61509c5aa4db838f" alt=""
Preview In Your Browser
data:image/s3,"s3://crabby-images/7ceb4/7ceb47294741e1ab3d06e34c1f1fc601a9f569f3" alt=""
data:image/s3,"s3://crabby-images/b3eee/b3eee1f717de07a3afccea70ae91bffc9cff8588" alt=""
Run with Apache
data:image/s3,"s3://crabby-images/aeaa6/aeaa6d156c78049f77983b0e5876263cb0d1c9bf" alt=""
data:image/s3,"s3://crabby-images/06747/0674795f527d8fda13dff4b44ac7659855ef9740" alt=""
Different URL
Test on Multiple Browsers
data:image/s3,"s3://crabby-images/dfd2d/dfd2d75fcf23a82d09a79ae9b3653fcd58639920" alt=""
Let's Add Our Code to GitHub
data:image/s3,"s3://crabby-images/9b313/9b31314f1cd6fddb59e236eb65bf848a246285dc" alt=""
Checking Git Status
git status
data:image/s3,"s3://crabby-images/b0d17/b0d17973ed6d102e6d007e9c18bf69b37b2dcbfd" alt=""
Adding Untracked Files
# Add one file
git add index.html
# Add all current untracked files
git add --all
data:image/s3,"s3://crabby-images/7cea9/7cea98282468cbe266dd06c5e342bc52c58c619a" alt=""
Commiting Changes
# Commit changes to the local working directory
# -m = "Message"
git commit -m "My first commit"
data:image/s3,"s3://crabby-images/f549e/f549efcb8ed5d6845a0ba6b473f3c5e616d84595" alt=""
I accidentally just did git commit!
git commit
What is this?
data:image/s3,"s3://crabby-images/97e7e/97e7e357b3889dfa5e6df6b5f518a77a288867c3" alt=""
Nano Text Editor
Type your commit message
To save type ctrl + o then enter
data:image/s3,"s3://crabby-images/1bf3d/1bf3d5019cb7e7f6f133e084f0f757d920b0b336" alt=""
After saving, type ctrl + x to exit
OS X - Vim Editor
Type the letter a
Type your commit message
Type esc then :w to save
To exit, type :q
May have to type esc again before
data:image/s3,"s3://crabby-images/85848/858488196ee5c297fc5b7b2f2a8f810c1b5c359b" alt=""
Windows - Vim Editor
Type the letter a
Type your commit message
Type esc then :w to save
To exit, type :q
May have to type esc again before
data:image/s3,"s3://crabby-images/17462/1746273f692b2a419c26de537a69e64fac7e0c3c" alt=""
Push Changes to GitHub
# Push changes to GitHub repository on the master branch
git push origin master
data:image/s3,"s3://crabby-images/7d789/7d7895aea7915952bd6e58200db710f06a7f3248" alt=""
What's "origin"?
# Get information about remote servers
git remote -v
data:image/s3,"s3://crabby-images/39b29/39b29c180a4174419cd84dc4568bbb3ee0434570" alt=""
origin = default name for connection to Github
Github = remote server, or "remote"
repository = https://github.com/techladyulsh/techladyulsh.github.io
Let's check GitHub...
data:image/s3,"s3://crabby-images/19c7c/19c7c3b87f8b36db5b81ff6e97f11b1ffb53bf6d" alt=""
data:image/s3,"s3://crabby-images/2a2c2/2a2c255333735723c2fcef871d86ab0ca7ecc835" alt=""
Hmm... let's wait 5-10 minutes?
Success!
data:image/s3,"s3://crabby-images/9381e/9381e8acbed360c802d9ab1398b6cc200210200e" alt=""
Let's create a branch to test some CSS!
Branches allow us to safely isolate changes or work on multiple features in parallel
# Get a list of branches
git branch
# Create a new branch
git branch css
# Switch to the new branch
git checkout css
# Shortcut - create and switch to new branch
git checkout -b css
data:image/s3,"s3://crabby-images/903e7/903e77af79a71c1dcdcb4553efd9a58d76834301" alt=""
Update styles.css
data:image/s3,"s3://crabby-images/93bea/93bea455a634498b94e2d8112f433a06f3489079" alt=""
Commit and push changes to CSS branch
# Add modified styles.css to tracked files in CSS branch
git add --all
# Commit changes to CSS branch
git commit -m "Set default font family to Sans Serif"
# Push changes to CSS branch on Github
# NOTE we are pushing to "origin css" not "origin master"
git push origin css
data:image/s3,"s3://crabby-images/157e8/157e8acc6280f3fe0dbc08f73b79dd2277999c1d" alt=""
Let's check GitHub...
New CSS branch!
data:image/s3,"s3://crabby-images/b47ad/b47adcd66177646b7f261572bcef163080a9eb51" alt=""
Hmm... my website hasn't changed though?
data:image/s3,"s3://crabby-images/9381e/9381e8acbed360c802d9ab1398b6cc200210200e" alt=""
For user pages, only the master branch is public.
We need to merge our changes in the css branch with the master branch.
Merging Branches
# Check out the master branch
git checkout master
# Merge the CSS branch with the master branch
git merge css
# Push changes from merge back to master branch on Github
git push origin master
data:image/s3,"s3://crabby-images/64adf/64adf3ab1a5d1a146991bd29542d1cab94f33e09" alt=""
Website updated!
data:image/s3,"s3://crabby-images/1a008/1a008af3f260e4efa4027c1104e21197ee4e364a" alt=""
Delete the Old Branch
# Delete the remote branch on Github
git push origin --delete css
# Delete the local branch
# -d = "Delete"
git branch -d css
# View available branches
git branch
data:image/s3,"s3://crabby-images/abeb0/abeb0ab8f0ab9a57babcde0bc172a3d1ad1eba91" alt=""
Troubleshooting Updates
If an update is not showing on your site despite pushing the changes to GitHub, open up your browser's developer tools and disable caching.
Google Chrome Developer Tools
Windows/Linux/Chromebook = Ctrl + Shift + J
Mac OS X = Cmd + Opt + i
Make sure "Disable cache" is checked, then refresh the page.
data:image/s3,"s3://crabby-images/32fee/32feeadea2beb0a0ab1311d5f7c46ee3ef82046f" alt=""
I want to host a portfolio on my website.
Try GitHub Project Pages!
These use the gh-pages branch of any repository, as long as you have already created a User Pages repository.
Project Pages Setup
- Create new repository on GitHub
- Create new workspace in Cloud9 from GitHub repository
- Add files and code to new workspace
- Push code to master branch
- Create a gh-pages branch
- Push gh-pages branch to GitHub
Sample Project
data:image/s3,"s3://crabby-images/5f4a2/5f4a2806c5aeb853ed37d9ccd3a7685ff3c1a7f9" alt=""
Sample Project Repository
data:image/s3,"s3://crabby-images/2eba5/2eba5b56e3142a3552c7fa04aef6624922ed140f" alt=""
Setup the Project Page
# Create the gh-pages branch
git branch gh-pages
# Checkout the gh-pages branch
git checkout gh-pages
# Push the gh-pages branch to GitHub
git push origin gh-pages
data:image/s3,"s3://crabby-images/68161/68161f50783b1154c0cc7a043e5dc3eaff1a2ce0" alt=""
Admire Your Work
http://techladyulsh.github.io/My-Sample-Project
data:image/s3,"s3://crabby-images/d0c88/d0c881ab587033ef67acffb3a9e7d6eb0468cb5e" alt=""
NOTE: Project Pages URLs are case sensitive!
GitHub Extras!
data:image/s3,"s3://crabby-images/89e43/89e437fab304f81ee69d8beab6a35ec68a89368f" alt=""
.gitignore file
Allows certain files, file extensions, and folders to be excluded from your Git repository.
Particularly useful for Node.js applications.
To enable in Cloud9, show hidden files.
data:image/s3,"s3://crabby-images/3fc06/3fc064811b279a29df027a8ea61971f3009a961b" alt=""
Sometimes may have to add the hidden .c9 folder to a .gitignore file.
GitHub Social and Collaboration Features
- Watch a repo
- Star a repo
- Submit an issue
- Pull requests
Watch a repo
data:image/s3,"s3://crabby-images/09d73/09d7313aa7ba33103e6de886f9001976ff3b6a78" alt=""
Get notifications of any new pull requests or issues.
Star a repo
data:image/s3,"s3://crabby-images/123b1/123b170fc69580f2502220a5b3e3817cc53af199" alt=""
- Bookmark interesting repositories
- Show appreciation of good work
- Affects ranking of repository
data:image/s3,"s3://crabby-images/516cd/516cd45d23cd0a5c6fd7e8c4f15dc738f52edb55" alt=""
Log an Issue
data:image/s3,"s3://crabby-images/79a15/79a155846737b4691e4be7a91140fdf89f301d7e" alt=""
Pull Requests
data:image/s3,"s3://crabby-images/d0d0d/d0d0da80c33844f172f623390999f49de0da43ab" alt=""
What if I want my own custom domain name for my website?
Buy your domain name
I used namecheap
data:image/s3,"s3://crabby-images/ab700/ab70091884d6f6829c16a5686d18a6ed5bb6ae5c" alt=""
CNAME = canonical name
DNS (Domain Name System) record
Points an alias (domain name), to another domain name (canonical name).
For example, alexandraulsh.com is the alias for alulsh.github.io.
Add a CNAME file to GitHub Repo
data:image/s3,"s3://crabby-images/dadce/dadcec1a75f2e360c10e5d41ceb1890df8d3a8d0" alt=""
CNAME file does not have a file extension.
Configure DNS with your domain name provider
Domain name needs to point to Github's servers.
data:image/s3,"s3://crabby-images/2f88b/2f88b97962fb93748a12bba856d509bae7a008ab" alt=""
Cloud9 Extras
- Node.js, PHP, Go, C++, Ruby on Rails, Django...
- ALL THE THINGS
- Npm already installed
- Bower already installed
data:image/s3,"s3://crabby-images/1d9ba/1d9ba25db0454e726fd47e6b69a2d42ce72ca256" alt=""
Want more to do for your website?
Check out Search Engine Optimization (SEO), Google Analytics, and Jekyll.
data:image/s3,"s3://crabby-images/43fd9/43fd92752cba1dcf0f4e9ab478182a055613481b" alt=""
Need Inspiration?
Check out some personal websites of awesome women and non-binary people in the DC Tech scene.
Questions?
WWCDC - Build Your Own Website With Cloud9 and GitHub Pages
By Alexandra Ulsh
WWCDC - Build Your Own Website With Cloud9 and GitHub Pages
Presented at Women Who Code DC Front End Hack Night - Intro to Git
- 3,630