Skip to content
This repository has been archived by the owner on Oct 10, 2024. It is now read-only.

Latest commit

 

History

History
174 lines (127 loc) · 5.51 KB

README.md

File metadata and controls

174 lines (127 loc) · 5.51 KB

CCM Website GitHub CI Status Netlify Status

This is the repo for Christ Church Mayfair's website.

Report a problem

If you see something that doesn't look right, text British Transport Police on 61016 create an issue or email Tom Duckering.

Contributing

The website is built using Gatsby, a static site generator built on React. We use TypeScript, GraphQL and Sass.

We coordinate and discuss tasks on the #website channel of our Slack workspace - email Tom Duckering if you don't already have an account here and want to join.

Prerequisites

  • A basic knowledge of git.
  • Yarn - follow the instructions for your operating system. You may need to install Node.js separately if you are running Windows.

Getting started

Clone this repo and then inside the folder:

Install Yarn modules

yarn install

Run the develop script

yarn develop

A local version of the website should now be running on port 8000. Open http://localhost:8000 on your browser.

Coding guidelines

Please follow all conventions already established in the code. We try to write and structure our code in a way which is as modern and idiomatic as possible, for example:

  • const and let - no vars
  • React hooks wherever possible and required
  • prefer functional-style Javascript
  • optional chaining wherever possible and required.

We use ESLint for linting and Prettier for formatting. We recommend that you install the plugins for these two tools on your editor of choice.

# Run the TypeScript type checker
yarn type-check

# Run the lint checker
yarn lint

# Run the formatting checker
yarn prettier-check

Tests

You should write unit tests for any code which performs significant logic. Test files live in a folder named __tests__ in the same directory as the file to be tested, and should have the .spec.ts or .spec.tsx extension. For example, if we wanted to write tests for a function in the numbers.ts file:

mathsUtils/
    isOdd.ts
    isThirteen.ts
    numbers.ts
    __tests__/
        isOdd.spec.ts
        numbers.spec.ts  # tests should be written in here

We write tests using the Jest framework.

# Run all tests
yarn test

# Run tests in files whose name contains "filters"
yarn test filters

Repo structure overview

Some highlights:

.
├── src/
│   ├── assets/             # fontfaces, icons etc.
│   ├── components/         # shared, reusable React components
│   │   ├── foo.module.scss
│   │   └── foo.tsx
│   ├── content/            # Markdown content
│   ├── mixins/             # Sass mixins
│   ├── pages/              # React components for pages
│   ├── templates/          # Page templates
│   └── utils/              # Common utility functions
└── static/                 # Static files - downloads
    └── _redirects          # christchurchmayfair.org/* redirects

Styling (aka. CSS)

We uses Sass modules to style each component. Style sheets should be named component-name.module.scss. We use BEM naming rules, but without elements since CSS modules are namespaced (elements follow the same conventions as blocks).

An example React component extract:

// music-player.tsx
<div className={styles.musicPlayer}>
    <div className={styles.songName}>{songName}</div>
    <div className={styles.buttons}>
        <button
            onClick={onPlay}
            className={classnames(styles.playButton, {
                [styles["playButton--active"]]: isPlaying,
            })}
        >
            Play
        </button>
        <button
            onClick={onPause}
            className={classnames(styles.pauseButton, {
                [styles["pauseButton--active"]]: isPaused,
            })}
        >
            Pause
        </button>
    </div>
</div>

...and its accompanying Sass stylesheet:

/* music-player.module.scss */
.musicPlayer {
    /* ... */

    @media only screen and (max-width: 968px) {
        /* ... */
    }
}

.songName {
    /* ... */
}

.playButton {
    /* ... */

    &--active {
        /* ... */
    }
}

.pauseButton {
    /* ... */

    &--active {
        /* ... */
    }
}

Global styles should be written in or referenced from src/assets/css/global.scss.

GraphQL

Gatsby uses GraphQL to fetch data from Markdown content files. We also use it to fetch some data at runtime from Sanity CMS.

You can use the GraphiQL Explorer to test out Gatsby queries - you can access it at http://localhost:8000/___graphql after running yarn develop. Gatsby's website has a guide to using GraphQL.