First, thank you for contributing! Here’s some basics about our codebase.
- Clone the repository and enter it
git clone https://github.com/hackclub/site.git
cd site
```sh
2. Update submodules (this may take a little while)
```sh
git submodule init && git submodule update
- Install packages & run
yarn && yarn run dev
- It should now be running, open localhost:8000 to view
The Git submodule to hackclub/hackclub is for including the Workshop source files.
This site is a standard Gatsby site, so:
- Pages are in
src/pages/
. They use unnamed default exports (e.g.export default () => ()
). - Components are in
src/components/
. They use named default exports (e.g.class Hello extends Component {}
+export default Hello
).
In all prose (form labels, text blocks, etc), use rich quotes.
For code formatting, we use Prettier with options.
Before committing, run yarn run fmt
and you’re good to go.
This site uses the Hack Club Design System for all UI primitives (Text, Buttons, etc).
- Use
styled-components
to add any custom styling to DS components. - Whenever style utility props (whitespace, color, etc) might be used, make use of DS’s components.
- If style utility props aren’t needed, use JSX tags or
styled.tag
for performance.
Before adding images (in static/
), resize them to a logical size and run
Guetzli on them for optimization.
Improvements to image serving are planned but not yet in place.