Skip to content

Latest commit

 

History

History
121 lines (74 loc) · 8.71 KB

README.md

File metadata and controls

121 lines (74 loc) · 8.71 KB

En example of a site running using this repo

DSA Chapter In a Box Website Runbook

Smaller Chapters and Organizing Committees of the Democratic Socialists of America (refered herein as "Chapters" for shorthand), or Chapters without a dedicated internal Tech committee, may lack a web presence outside of Corporate owned Social Media. To assist with this, the National Tech Committee (NTC) has created this runbook to help quickly get Chapter webpages up and running with DSA branding.

An example webpage can be viewed at peninsula.dsachapters.org (source code). The tools used to create it consist of:

You can also opt-in to self-host your site if your Chapter has a webserver, this is however out of scope of this document.

Expectations and Limitations

This project's function is for the NTC to provide the means for smaller DSA Chapters to establish a Jekyll based website quickly and at no cost. The ownership (e.g. updates to content, updates to theme, customization) is expected to fall on the individual Chapter with minimal support from the NTC outside of onboarding. There is no requirement the website must be hosted on GitHub Pages, use this Jekyll theme, or use this project.

Jekyll, the base code for this website and this project, is a static website generator, meaning some "dynamic" functionality like a comments section, dynamic chapter calendars for tracking events, or some embedded media, are not supported. The Jekyll documentation can help further explain what will and won't work if implemented on your website. See this helpful comparison between static and dynamic webpages that further explains the difference.

Installation

You will need a GitHub account and a GitHub organization for your Chapter. While GitHub Pages can be created both on personal and group accounts, it's recommended to make this a Chapter based account to provide additional access if needed.

  1. Create a new organization on GitHub. Select the "Create a free organization" option.

Screenshot of GitHub's "Pick a plan" page when creating a new organization

  1. Fill out the basic information. Feel free to add organization members now or at a later point. As you proceed past the optional survey, you will be redirected to your organization's page at https://github.com/organization-name.

Screenshot of the organization setup page

  1. Click the "Create new repository" button in the right-hand sidebar, under "Repositories". Name your repository organization-name.github.io. All letters in the repository name will need to be lowercase.

Organization page after it's first created, with the button labeled "Create new repository" highlighted

  1. You will need to make your repostory public in order for GitHub page to work, unless you're using a paid plan. You can leave the rest of the options as they are and click the "Create repository" button at the bottom of the page.

Screenshot of the repo configuration page before the repo is created

  1. Use the "Import code" button to copy the starter website.

A view of a new repo page after the repo is created, with the "Import code" button highlighted

  1. Use https://github.com/dsa-chapter-website/dsa-chapter-website.github.io as "Your old repository's clone URL" and click "Begin import".

The next step in the code import process, with an input field prompting for the imported repo URL and a "Begin import" button both highlighted

  1. Once the import is finished, click your repository link. You will see a link to your new site next to the repository's name on top of the page. Your site's URL will have the format of https://organization-name.github.io/.

Screenshot of the imported starter website repo

Customizing Your Website

A handful of files need to be updated to better customize your Chapter's webpage. This can be done directly through GitHub's interface.

  • _config.yml Basic information about your Chapter's website. You can start with these:
    • title
    • url
  • There are more settings in _config.yml that will improve the Search Engine Optimization tags Jekyll generates for your pages, but it's okay to leave blank the ones you don't understand.
  • _data/copy.yaml Update this file with the name and description of your Chapter.
  • _data/blog.yml Basic information about the blog authors, in most cases this is the name and social media links of the Chapter.
  • _data/nav.yml This file contains both the header and footer bars on the webpage, and will be added to every post or page made in the above section. Example values are provided from DSA National.

See the Peninsula DSA's GitHub repo for an example website.

Adding and Editing Content

All pages for this new website are contained in the _pages directory. There are several pages created as examples, here are the main ones:

  • 404.md -- Example 404 page which Jekyll will direct any page to if it doesn't otherwise exist, you can customize this further to your Chapter's content.
  • about.md -- A quick about summary of your Chapter, why the Chapter was formed, how it ties in to the history of your area. blog.md -- Placeholder for a Chapter blog or statements page (which can be renamed and updated as per your Chapter's preference). An example of a blog post / Chapter - statement (contained in _posts/2021-09-20-ice-statement.md) is provided to further illustrate how this page can be used to automatically group statements/blogs
  • calendar.md -- A page where you can embed or provide a calendar around events and actions your Chapter is participating in
  • get-involved.md -- A page where you can provide additional instructions for potential memebers to join your Chapter.

To learn more about adding content to your site, please review the GitHub documentation.

After you commit your changes, you can check your site's Actions page at https://github.com/organization-name/organization-name.github.io/actions to see the deployment process status.

Domain Name

TBD, needs to be agreed on but proposed to use chapter.dsausa.org as the backbone for these websites. GitHub supports custom domain names.

For Developers

See the Jekyll documentation on how to set up a Jekyll site for local development.

Once Jekyll is installed, you can run the site locally with:

bundle exec jekyll serve --livereload

If the site is not automatically updating after content is changed, try:

bundle exec jekyll serve --livereload --force-polling

If you're missing any of the dependencies, run:

bundle install

Updating the Theme

See Jekyll Themes documentation on working with Jekyll themes.

  • _sass/bootswatch/dist/united/_variables.scss This controls the variables for colors and font for the webpage, currently defaults are kept and minor changes were made to align to the DSA style guide

TODO

  • Instructions on how to maintain and update pages with GitHub Editor vs Desktop
  • Project website DNS name
  • Remove duplicated data like social media account info
  • Trim _config.yml