Skip to content

Latest commit

 

History

History
425 lines (307 loc) · 19.2 KB

README.md

File metadata and controls

425 lines (307 loc) · 19.2 KB

NYC DOE CS Education (CS4All) Blueprint

CS4All Blueprint V2.0 using GatsbyJS

By @nycdoe-cs4all

Updated version of CS4All Blueprint V1.0

About Gatsby and React

Gatsby is a remix of the popular framework React. React makes it easy to create web apps using components. Gatsby makes it easy to create websites with a light front-end framework and little to no backend. It can easily connect to data sources (such as WordPress), and is configured to work well with headless servers. Gatsby statically renders the site and the data shown/stored on it, which means it's super easy to publish anywhere online and makes for a very fast web app.

Table of Contents

This README ended up being longer than intended, so here are quick links to where you may want to go

TO DO

  • Port Blueprint 1.0 to GatsbyJS
  • Squash bugs so Blueprint 2.0 looks and functions identical to Blueprint 1.0
  • Organize folder structure
  • Improve code comments
  • Update Educator Resource layouts and structure
  • Improve look of curriculum page(s)
  • Include references to NYSED standards, 3rd party curriculum, and CS Leads resources
  • Update README
  • Create process for adding new Educator Resources via WordPress
  • Launch Blueprint 2.0
  • (IN PROGRESS) Improve site accessibility (i.e. translation, page structure, alt text, etc. Will require sub tasks)
  • (OPTIONAL) (IN PROGRESS) Improve stylesheets (i.e only import styles for pages that need them)
  • (OPTIONAL) Make site more modular (i.e make components for items that are used often)
  • (OPTIONAL) Change video hosting
  • (OPTIONAL) Change site hosting

File Structure

  • public
    • This is where all of the files gofor the built site that will go live
  • src
    • This is where the main code of this website lives
    • src/assets
      • This is where images, videos, etc. are stored
      • When adding assets, make sure they are placed in the appropriate subfolder
    • src/components
      • Where components that will be reused are stored (eg. layout and SEO)
      • The temporary home for stylesheets (until site is made more modular)
    • src/pages
      • Where every page of the site is stored
      • The structure for each component is written out in src/pages/boilerplate.js

Setting Up Your Development Environment

Installing Apps

For more information, check out the Gatsby Tutorial

  1. Install Node.js using an installer or package manager
  2. Install Git
  3. Install Gatsby
    • In your terminal, run the following command: npm install -g gatsby-cli
  • OPTIONAL - Additional recommended installs:
    • Install GitHub Desktop
      • A GUI to more easily use Git on your machine
    • Install Atom
      • A text editor designed specifically for (and by) GitHub
    • Install Prettier
      • A plugin for various text editors that helps format code to avoid errors

Preparing Git(Hub)

For more information, check out GitHub Help

  1. Clone the repository:
  2. Navigate to the project in your terminal:
    • If using your terminal, run the following command: cd C:\...\cs4all-blueprint-gatsby
      • Replace the URL above with the directory you cloned the repository into
    • If using GitHub Desktop, just hit CTRL + ~
  3. Install dependencies:
    • In your terminal, run the following command: npm install

Developing and Building the Site

Running Site Locally

For more information, check out the Gatsby Tutorial

  1. Navigate to the project in your terminal:
    • If using your terminal, run the following command: cd C:\...\cs4all-blueprint-gatsby
      • Replace the URL above with the directory you cloned the repository into
    • If using GitHub Desktop, just hit CTRL + ~
  2. Run the development server:
    • In your terminal, run the following command: gatsby develop
    • If you receive the ERROR message The path passed to gatsby-source-filesystem does not exist on your file system: ~ /cs4all-blueprint-gatsby/src/assets/videos:
    • Create a videos dir in\src\assets and try running the development server again.
  3. Open up a browser tab and navigate to http://localhost:8000
    • You can also access the site's GraphQL data by going to http://localhost:8000/___graphql

Building Site Locally

For more information, check out the Gatsby Tutorial

  1. Stop the development server (if running)
  2. Navigate to the project in your terminal:
    • If using your terminal, run the following command: cd C:\...\cs4all-blueprint-gatsby
      • Replace the URL above with the directory you cloned the repository into
    • If using GitHub Desktop, just hit CTRL + ~
  3. Build the project:
    • In your terminal, run the following command: gatsby build
  • OPTIONAL - Viewing the production site locally:
    • In your terminal, run the following command: gatsby serve
    • Open up a browser tab and navigate to http://localhost:9000

Updating Live Site

  1. Access the site's Digital Ocean droplet using SSH
    • To SSH into the server, run ssh <username>@<ip-address> then enter your password
    • If you do not have a username and password or know the IP address, contact the webmaster
  2. Navigate to the proper folder cd /home/cs4all/cs4all-blueprint-gatsby
  3. Run sudo gatsby build
    • You may need to sudo git pull first

Adding Educator Resources via WordPress

  1. Access the site's WordPress backend:
  2. Determine which layout the resource will take:
  3. Navigate to the Posts section in WordPress
  4. Click Add New in the top left
  5. Type in the content using the following guidelines:
    • NOTE: Use the examples in step 2 as references
    • Each paragraph should be its own block
    • Headings should start at H3 and work down
    • H4 should be in all caps
    • Links to external sites should be marked to open in a new tab
    • Images should have a width of approximately 613px and have alt text
  6. Change the following in the right menu (Settings):
    • NOTE: If the settings menu isn't visible, click on the gear next to the Publish button
    • The author should be nycdoecs4all
    • Update the URL slug to something that makes sense (see other posts for examples)
    • Check of appropriate categories (used for filtering)
    • Summarize the page in the excerpt (for the main Educator Resources page)
  7. Click the Preview button to make sure the page displays correctly
  8. Click the Publish button
    • The page will go live during the next deployment

Changelog

11/16/21

From Dan

  • Updated links on curricular pages

10/7/21

From Dan

  • Some changes
  • Writing about the launch (launch happened about a month ago, but forgot to write it earlier)
  • Note: Need to be better about listing changes...

7/2/21

From Dan

  • Site prepared for live deployment
  • Some tweaks to code to accommodate changes in needs

4/7/21

From Dan

  • Added code to account for variables being undefined or the incorrect type

3/5/21

From Dan

  • Updated README to make it easier to follow
  • Added process for adding Educator Resources via WordPress
  • Added project To-do list

3/1/21

From Dan

  • Used prettier to make code easier to read

2/24/21

From Dan

  • Fixed caret in Navbar
  • Updated page scrolling for internal links
  • Added draft looks of potential changes to the following pages:
    • Educator resources
    • Curriculum Catalog
    • Student outcomes
    • Integrated Units Curriculum

2/16/21

From various

  • Blueprint 2.0 bugs squashed, site looks and functions exactly like 1.0 with some minor differences
  • Code roughly commented and organized for easier viewing and parsing

10/27/20

From Dylan

  • Finished wordpress pagination
  • Merged wordpress branch with master

10/22/20

From Dan

  • Missed several updates from prior...
  • Updated About page so the read more/collapse text buttons work and text opens gradually
  • Removed data var from layout.js, unsure if it broke anything, but everything still seems to work
  • Added an Accordion component that allows sections to open gradually
    • Added accordion to the concepts, practices, and perspective pages
  • Fixed links in practices page, but the sections it links to do not automatically open
  • Show me how button on index page now gradually scrolls to the proper section of the page
  • CS4All logo in navbar links to index, but there is now a border around the logo
  • Noticed issue where previous coder stylized anchors to be used as buttons, but that is improper use for accessibility
    • To fix we will have to deep dive into the stylesheet

9/22/20

From Dan

  • Fixed various warnings from running 'gatsby develop'
    • Ex: img alt text, 'Link' not being used, a elements
    • layout.js still has 1 warning that might be hardere to fix
  • Removed all links to the old units page
  • Restructured pages so all of the curriculum and unused pages are in their own folders
  • Made sure most non-internal links open in a new tab

9/21/20

From Dylan

  • Began looking into independent routing with Gatsby's createPages API

8/31/20

From Dylan

  • Pushed stable wordpress version to master
    • Next up: fix internal router so each educator resource article has its own page
    • Will keep looking into reach router

8/12/20

From Dylan

  • Cleaned up pages/resources.js
  • Worked on pages/educator-resources.js -- a component that will be re-used to display each article
  • Looked into how we can clean up some of the code

7/29/20

From Dylan

  • pages/resources.js shows all posts
  • Trying to get demo server working, but taking a while because of WordPress issues

7/17/20

From Dylan

  • Fixed all runtime bugs from component conversion
  • Connected to local Wordpress
  • Created Resource component, which just returns all of the WordPress posts as JSON
  • Added "How to locally run WordPress" in README

7/15/20

From Dylan

  • Created resources component and fixed some bugs

7/8/20

From Dylan

  • Added Wordpress-Gatsby plugin to the project
  • Created wordpress branch
  • Created a blank Wordpress site for testing
  • Paused further development to check in with Dan
    • All of the components are fully coded out, and if we used WordPress, we would have to re-convert them to plain text and sort out how we want to replicate all of the icons
      • Could also keep the code for key sites and then create a base layout for every component page(this would be the only solution that would involve Wordpress, basically)

6/25/2020

From Dan

  • Cleaned up the code of all the pages that were converted to components
  • Started adding comments to the Computational Media Innovator page

6/22/20

From Dylan

  • Converted the remaining pages into components
  • Moved some files to src/for_later
    • Code that can't be added back to the code base until we choose and implement a back end
    • Mostly database code, or code that is used to interact with database content(eg. registering a new user, logging out, etc.)]
  • Began toying around with WordPress

6/19/2020

From Dan

  • Converted src/pages/creative-computing.js to a component
  • Converted src/pages/creative-web.js to a component
  • Converted src/pages/critical-computing.js to a component
  • Converted src/pages/cs-a.js to a component
  • Converted src/pages/cs-principles.js to a component
  • Cleaned up the code of various other pages that were already converted to components

6/18/2020

From Dan

  • Converted src/pages/bootstrap-data-science.js to a component
  • Converted src/pages/codeorg-cs-principles.js to a component
  • Converted src/pages/computational-media-creator.js to a component
  • Converted src/pages/computational-media-explorer.js to a component
  • Converted src/pages/computational-media-innovator.js to a component

6/17/20

From Dylan

  • Fixed inline @media query issue in src/pages/ican.js

6/16/20

From Dylan

  • Converted and fixed:
    • The three components Dan converted earlier today(I had to make a small fix to the boilerplate, so I made a very minor edit to the three components that was my own fault)
    • src/pages/boilerplate.js
      • Changed a very small typo in the naming of the components that was causing an error
    • src/pages/units-k2-computer-science-and-me.js
    • src/pages/units-68-innovative-programming.js
    • src/pages/units-35-creating-from-scratch.js
    • src/pages/tangible-interfaces.js
    • src/pages/software-engineering-program.js
    • src/pages/software-engineering-program-jr.js
    • src/pages/practices.js

6/16/2020

From Dan

  • Converted src/pages/bjc-cs-principles.js to a component
  • Converted src/pages/uteach-cs-principles.js to a component
  • Converted src/pages/ican.js to a component

6/10/2020

From Dylan

  • Wrote guide on how to convert the blueprint site's template pages to Gatsby
  • Changed file extensions from .html to .js for all files in pages/ activities, registration, resources, and users.
  • Converted src/pages/what_is_cs.js to a component
  • Added installation instructions

6/9/2020

From Dylan

  • Imported all HTML pages from original blueprint repo and changed all extensions from .html to .js
  • Created src/pages/boilerplate.js as an example for the core structure of a page
  • Finished converting src/pages/index.js and src/pages/about.js to Gatsby/React
    • Cleaned up some of the code
    • Changed certain syntax to match React
      • eg. In React, class becomes className because it follows camel case for DOM attributes(class, style, id, etc.)
  • Created navbar component

For Posterity

Converting CS4All Blueprint V1.0 pages into V2.0 Gatsby components

Quick Note 1: You may not have to follow every single step for each component. It is possible that, for example, some files won't include comments or inline styling in the original HTML. In that case, move on to the next step. Quick Note 2: If, after following these steps, the page still does not work, use other pages as a reference or flag the file in some way for additional eyes.

  1. Add the V1.0 page into src/pages and change the extension to .js.
  2. Copy the contents of src/pages/boilerplate.js into the top of the file you're working in, and un-comment the code.
  3. Change the title of the <SEO /> component to the name of the page. eg. if the file is called cs-and-the-city.js, name it CS and the City.
  4. Delete every line in the old HTML code that contains {% %}, such as: {% extends "base.html" %} {% load i18n %} {% block content %}
  5. Find every instance of class= and replace it with className= -- because React supports camel case, and lower case "class" means something different in the React DOM.
  6. Find every xlink:href= and replace it with xlinkHref=.
  7. Turn every inline HTML comment into a React comment. Replace the <!-- at the beginning of every comment with {/* and replace the --> at the end of every comment with */}. For example, <!-- end of section --> should be: {/* end of section */}.
  8. Turn every inline style into a React inline style. In React, inline styling is done with nested objects, where every property is written in camel-case and every value is written in quotations. For example, <h1 style="background-color: blue;"> Hi </h1> becomes <h1 style={{backgroundColor: 'blue'}}> Hi </h1>. Instead of putting a semicolon between every property, put a comma.
  9. Cut/copy all of the HTML code from the original site that you've just edited and paste it where the comment at the top of the file(the code you copied from the boilerplate) says "children -- the HTML code for the site".
  10. Rename the component from Boilerplate to the name of the site, written in camelcase. For example, if the file is called cs-and-the-city.js, turn const Boilerplate into const CSAndTheCity.