A basic starting point for web projects that uses parcel as a Build System.
This is the result of a build system research and experimentation.
For the previous version of project-seed, that used browserify see tag v4.0.0.
Steps to follow as soon as you download this structure to start a project:
- Update
package.js
with data about the project (name, repo, license...) - If the license is known update
LICENSE
- Check
index.html
for bootstrap information that can be changed or removed. - Update the application title and description in
.env
- Remove unneeded images from the
graphics
folder and replace the favicon with a project related one. - Update the modules to the most recent version.
- Delete this
README.md
and rename_README.md
. Fill in the needed data. This is the most important task. Others need to be able to know what the project is about and how to work with it. This can't be stressed enough.
It's better to do this straight away so no traces of project-seed are ever pushed to github and just looks more professional. The values that are not immediately know should be left blank and filled ASAP.
Parcel is used to bundle all the needed assets for the application, but there are some edge cases in some projects that parcel can't handle very well. Anything that must happen outside the final bundle, parcel can't deal with properly. For example, parcel's static file plugin will just copy the files to the dist folder, without watching them for changes.
To solve this problem, Gulp is used to orchestrate tasks. With it, tasks can be setup to do all that is needed, and then parcel is executed to bundle the app.
Unless you have a use case that needs data processing you shouldn't have to touch the gulpfile. For an example of extra tasks see the research repo.
There are two commands, both run via yarn
.
yarn build
- clean & build everything and put it into dist folderyarn serve
- serve the pages and utilize live reload on changes to fonts, images, scripts and HTML.
At times, it may be necessary to include options/variables specific to production
, staging
or local
in the code. To handle this, there you can use .env
files.
See Parcel documentation on env variables.
Testing and deployment is taken care of by Github Actions. It is set up to:
- run checks (test & lint) on every non-draft Pull Request
- build and deploy the application on pushes to the
main
branch
To make sure that the site deploys with passing checks, branch protection should be set up for the main
branch (Require status checks to pass before merging
).
Deploy is not set up by default, but the project contains sample workflows that can be used to set it up.
Our ESLint rules are based on eslint:recommended
rules, with some custom options. To check linting errors run:
yarn lint
File .editorconfig defines basic code styling rules, like indent sizes.
Prettier is the recommended code formatter. Atom and VSCode have extensions supporting Prettier-ESLint integration, which will help maintain style consistency while following linting rules.
Path alias allow you to define aliases for commonly used folders and avoid having very long file paths like ../../../component
. This also allows you to more easily move files around without worrying the imports will break.
Paths are defined in the package.json under alias
. They start with a $
and point to a folder.
The following paths are predefined, but feel free to change them to whatever is convenient to your project needs.
"alias": {
"$components": "~/app/scripts/components",
"$styles": "~/app/scripts/styles",
"$utils": "~/app/scripts/utils",
"$test": "~/test"
}
For example, to import a component from a file called page-header
in the "~/app/scripts/components"
folder, you'd just need to do import Component from '$components/page-header'
.
Project seed comes with pull request templates to simplify and standardize the pull requests in the project. This issue on the how repo provides some context to how this works.
To add more templates create them in the .github/PULL_REQUEST_TEMPLATE
folder and link them in the PULL_REQUEST_TEMPLATE.md file.