We'd love for you to contribute and make Material Components for the web even better than it is today! Here are the guidelines we'd like you to follow:
- General Contributing Guidelines
- Finding an Issue to Work On
- Development Process
- "What's the core team up to?"
The Material Components contributing policies and procedures can be found in the main Material Components documentation repository’s contributing page.
Material Components Web uses GitHub to file and track issues. To find an issue you'd like to work on, filter the issues list by the help wanted label. If you have found a bug, or would like to request a feature not represented in the list of GitHub issues, please refer to the documentation for Contributing
We strive to make developing Material Components Web as frictionless as possible, both for ourselves and for our community. This section should get you up and running working on the MDC-Web codebase. Before beginning development, you may want to read through our brief developer guide to get a better understanding of our overall architecture.
You'll need a recent version of nodejs to work on MDC-Web. We test our builds using both the latest and LTS node versions, so use of one of those is recommended. You can use nvm to easily install and manage different versions of node on your system.
Once node is installed, simply clone our repo (or your fork of it) and run npm install
git clone [email protected]:material-components/material-components-web.git # or a path to your fork
cd material-components-web && npm i
Each component requires the following items in order to be complete:
-
An Engineering Outline Document, which should be linked to in a comment on the GitHub issue where we're tracking the component. This way, the core team can review and sign off on the outline doc. Outline docs should be signed off on before submitting a PR. Please copy this google doc template in order to make your outline.
We have found that enforcing an eng outline doc has allowed us to speed up development by offering more informed feedback on component implementations. This results in components that take into account all of the concepts MDC Web components should account for (RTL, a11y, etc.) before they even reach the PR stage, meaning faster review and merge times 😄.
-
A foundation class which is integrated into actual components
-
A component class using vanilla JS + SCSS
-
A README.md in its subdir which contains developer documentation on the component, including usage.
-
A set of unit tests within
test/unit/
with adequate coverage (which we enforce automatically). -
A demo page within
demos/
that shows example usage of the component.
You can find much more information with respect to building components within our authoring components guide
npm run dev
open http://localhost:8080
npm run dev
runs a webpack-dev-server instance that uses demos/
as its content base. This should aid you in initial development of a component. It's served on port 8080.
npm run build # Builds an unminified version of MDC-Web within build/
npm run build:min # Same as above, but enables minification
npm run dist # Cleans out build/ and runs both of the above commands sequentially
npm run lint:js # Lints javascript using eslint
npm run lint:css # Lints (S)CSS using stylelint
npm run lint # Runs both of the above commands in parallel
npm run fix:js # Runs eslint with the --fix option enabled
npm run fix:css # Runs stylefmt, which helps fix simple stylelint errors
npm run fix # Runs both of the above commands in parallel
npm run test:watch # Runs karma on Chrome, re-running when source files change
npm test # Lints all files, runs karma, runs closure tests, and then runs coverage enforcement checks.
npm run test:unit # Only runs the karma tests
npm run test:closure # Runs closure build tests against all closurized files
If you're making big changes or developing new components, we encourage you to be a good citizen and test your changes across browsers! A super simple way to do this is to use sauce labs, which is how we tests our collaborator PRs on TravisCI:
- Sign up for a sauce labs account (choose "Open Sauce" as your selected plan; it's free!)
- Download sauce connect for your OS and make sure that the
bin
folder in the downloaded zip is somewhere on your$PATH
. - Navigate to your dashboard, scroll down to where it says "Access Key", and click "Show"
- Enter your password when prompted
- Copy your access key
- Run
SAUCE_USERNAME=<your-saucelabs-username> SAUCE_ACCESS_KEY=<your-saucelabs-access-key> npm test
This will have karma run our unit tests across all browsers we support, and ensure your changes will not introduce regressions.
Alternatively, you can run npm run test:watch
and manually open browsers / use VMs / use emulators to test your changes.
Our entire coding style is enforced automatically through the use of linters. Check out our eslint config (heavily influenced by Google's Javascript Styleguide) as well as our stylelint config (heavily annotated, with justifications for each rule) for further details.
When submitting PRs, make sure you're following our commit message conventions (which are the same as angular's); our commit-msg
hook should automatically enforce this. We also support commitizen, which you can
use to auto-format commit messages for you.
When submitting PRs for large changes, be sure to include an adequate background in the description so that reviewers of the PR know what the changes entail at a high-level, the motivations for making these changes, and what they affect.
If you've done some experimental work on your branch/fork and committed these via git commit --no-verify
, you can rebase them into one correctly-formatted commit before submitting.
Finally, it helps to make sure that your branch/fork is up to date with what's currently on master. You can ensure this by running git pull --rebase origin master
on your branch.
NOTE: Please do not merge master into your branch. Always
pull --rebase
instead. This ensures a linear history by always putting the work you've done after the work that's already on master, regardless of the date in which those commits were made.
NOTE: This section is for collaborators only. Contributors without repo write access can ignore this section.
Before releasing MDC-Web, ensure that you have the following:
- Write access to the material-components-web repo
- Correct credentials for npm
- The Google Cloud SDK installed. Please run
gcloud init
command to login to your Google Cloud account and choosematerial-components-web
if this is your first time working with the SDK. - Access to the
material-components-web
Google Cloud project
You should ping a core team member regarding any/all of these items if you're unsure whether or not they are all set up.
To release MDC-Web, you perform the following steps.
- Ensure you are on master, and you have the latest changes: run
git fetch && git fetch --tags && git pull
to be sure. - Run
./scripts/pre-release.sh
. This will runnpm test
, build MDC-Web, copy the built assets over to each module'sdist/
folder, and then print out a summary of all of the new versions that should be used for changed components. The summary is printed out to both the console, as well as a.new-versions.log
file in the repo root. This information should be used within the following steps. - From the root directory of the repo, run
$(npm bin)/lerna publish -m "chore: Publish"
. When prompted for versions for each component, you should use the version info output above. In some cases, e.g. repo-wide refactors that cause all component versions to be updated, you can ignore this info. However, it is strongly recommended to adhere to those specified versions in order to minimize human error. - Run
./scripts/post-release.sh
. This will update ourCHANGELOG.md
with information for the current release of the overarchingmaterial-components-web
library, and commit those changes. It will also generate avX.Y.Z
semver tag for the entire repo, and commit the tag as such. - Run
git push && git push --tags
to push the changelog changes and semver tag to master. - Run
MDC_ENV=development npm run build && gcloud app deploy
. This will deploy demo pages to our App Engine demo site. - Call it a day! 🎉 🚀 📦
Sometimes, things go wrong 🙃. A stale repo, misconfigured environment, or
dependency update may cause something in the release pipeline to fail. This will almost always
happen while running lerna's publish
command. If that does happen, you probably need to reset your
repo to a clean state in order to be able to re-run the command.
If you make a mistake while inputting new component versions into the lerna prompt:
Simply Ctrl+C
/ abort the lerna command. No changes should have been made locally.
If something goes wrong while lerna is creating its publish commit:
- After the lerna command fails, run
git reset HEAD
- Run
git co -- .
. This will restore the repo to its state before lerna attempted to bump versions and commit. - Re-run the publish command. Note that the new component versions are saved to
.new-versions.log
in the repo's root directory, which you can use to re-enter the new versions.
If something goes wrong while lerna is publishing to npm:
Ctrl+C
/ abort the lerna command. Your repo now has a newly created commit and tags that you have to get rid of in order to re-run the lerna command successfully.- Remove the publish commit by running
git reset --hard HEAD~1
. - Re-sync all of the local tags in your repo to only reflect the tags on GitHub by running
git tag | xargs -n1 git tag -d && git fetch --tags
(taken from this StackOverflow response) - Re-run the publish command. Note that the new component versions are saved to
.new-versions.log
in the repo's root directory, which you can use to re-enter the new versions.
If something goes wrong while lerna is pushing the published changes / tags to GitHub:
Ctrl+C
/ abort the lerna command.- Run
git push && git push --tags
. This does the equivalent of what lerna would have done.
The core team maintains a public Pivotal Tracker (tracker for short) which details all the items we're working on within our current two-week iteration. This tracker mirrors in what's in our GH issues. It is used purely for planning and prioritization purposes, not for discussions or community issue filing. That being said, it's a great place to look at the overall state of our project as well as some the big ticket issues we're working on.
Each tracker story contains a link to its corresponding GH issue within its description. Each GH issue present in tracker is tagged with an in-tracker
label. This will hopefully make it easy to move between the two if so desired.