Hi! I'm excited that you're interested in contributing to this project! Contributing should be enjoyable and productive for everyone, so please be kind to others and reach out if you have any questions or concerns (this project follows a Code of Conduct).
All contributions are welcome, including opening and commenting on issues and pull requests, adding or updating the docs, bug fixes, and suggestions for new features. Since this project is mostly written in TypeScript any improvements around TypeScript are also appreciated.
Changes to themes need to evaluated in more detail (e.g. if they would be breaking). The time to review a pull request depends on the complexity involved, so please be patient if a particular feature takes longer to review than others. Especially since this project is currently only maintained by me, LekoArts.
This repository uses Yarn Workspaces and changesets to develop multiple packages together as a monorepo. Be sure to install Yarn before setting up the development environment.
Clone the repository:
git clone [email protected]:LekoArts/gatsby-themes.git
Install the dependencies:
yarn
After yarn has linked packages and installed the dependencies in the repo, you can inspect the locally available workspaces with:
yarn workspaces info
As all themes are set up with a respective example page (to view the theme/changes), you could for example run the "gatsby-theme-emilia" workspace with the example "emilia" like:
yarn workspace emilia develop
Unit tests are run with Vitest, and are included where appropriate (mostly for utils/helper functions). Feel free to improve the code base with additional tests!
Running tests:
yarn test:ci
Running tests in watch mode:
yarn test:watch
Most of the themes' functionality is tested with Cypress as it allows real-world testing which is most important for me when developing themes. Run the following script for development:
bash ./scripts/e2e-dev.sh "example-name"
In the case of examples/emma
the "example-name" would be "emma".
The script starts starts start-server-and-test
with Gatsby's development server and Cypress. Once the Cypress GUI opens select the fitting test (the others won't work, only the respective test).
You can use the e2e-build.sh
script to test the headless mode that is run in GitHub Actions.
You can skip the e2e tests if you use docs
or www
in your branch name, e.g. docs/improve-readme
or www/add-new-entry
.
When opening a pull request, please be sure to update any relevant documentation in the READMEs or write some additional Vitest/Cypress tests to ensure functionality. Also include a high-level list of changes.
This repository uses changesets to do versioning. What that means for contributors is that you need to add a changeset by running yarn changeset
which contains what packages should be bumped, their associated semver bump types, and some markdown which will be inserted into changelogs.