190 lines
4.8 KiB
Markdown
190 lines
4.8 KiB
Markdown
# CONTRIBUTING
|
|
|
|
Contributions are always welcome, no matter how large or small. Before contributing,
|
|
please read the [code of conduct](CODE_OF_CONDUCT.md).
|
|
|
|
For details on contributing to documentation, see [Website Directory Readme](https://github.com/netlify/netlify-cms/blob/master/website/README.md).
|
|
|
|
## Setup
|
|
|
|
> Install [Node.js (LTS)](https://nodejs.org/) and [yarn](https://yarnpkg.com/en/docs/install) on your system.
|
|
|
|
### Install dependencies
|
|
|
|
> Only required on the first run, subsequent runs can use `yarn start` to both bootstrap and run the development server.
|
|
|
|
```sh
|
|
git clone https://github.com/netlify/netlify-cms
|
|
cd netlify-cms
|
|
yarn
|
|
yarn bootstrap
|
|
```
|
|
|
|
### Run locally
|
|
|
|
```sh
|
|
yarn start
|
|
```
|
|
|
|
## Available scripts
|
|
|
|
### bootstrap
|
|
|
|
Bootstraps the monorepo.
|
|
|
|
```sh
|
|
yarn bootstrap
|
|
```
|
|
|
|
### watch
|
|
|
|
Watches all CMS packages and transpiles them on change.
|
|
|
|
```sh
|
|
yarn watch
|
|
```
|
|
|
|
### start
|
|
|
|
Starts the development server. This task runs both the `bootstrap` and `watch` scripts.
|
|
|
|
```sh
|
|
yarn start
|
|
```
|
|
|
|
### clean
|
|
|
|
Removes all of the CMS package `dist` directories.
|
|
|
|
```sh
|
|
yarn clean
|
|
```
|
|
|
|
### reset
|
|
|
|
Runs the `clean` script and removes all the `node_modules` from the CMS packages.
|
|
|
|
```sh
|
|
yarn reset
|
|
```
|
|
|
|
### build
|
|
|
|
Runs the `clean` script and builds the CMS packages.
|
|
|
|
```sh
|
|
yarn build
|
|
```
|
|
|
|
### build-preview
|
|
|
|
Runs the `build` and `build-preview` scripts in each package and serves the resulting build locally.
|
|
|
|
```sh
|
|
yarn build-preview
|
|
```
|
|
|
|
### test
|
|
|
|
Runs linting and Jest tests.
|
|
|
|
```sh
|
|
yarn test
|
|
```
|
|
|
|
### test:all
|
|
|
|
Runs linting, Jest, and Cypress tests.
|
|
|
|
```sh
|
|
yarn test:all
|
|
```
|
|
|
|
### test:e2e
|
|
|
|
Runs Cypress e2e tests.
|
|
|
|
```sh
|
|
yarn test:e2e
|
|
```
|
|
|
|
### test:e2e:dev
|
|
|
|
Runs Cypress e2e tests on watch mode with an open instance of Chrome.
|
|
|
|
```sh
|
|
yarn test:e2e:dev
|
|
```
|
|
|
|
### format
|
|
|
|
Formats code and docs according to our style guidelines.
|
|
|
|
```sh
|
|
yarn format
|
|
```
|
|
|
|
## Pull Requests
|
|
|
|
We actively welcome your pull requests!
|
|
|
|
If you need help with Git or our workflow, please ask in our [community chat](https://netlifycms.org/chat). We want your contributions even if you're just learning Git. Our maintainers are happy to help!
|
|
|
|
Netlify CMS uses the [Forking Workflow](https://www.atlassian.com/git/tutorials/comparing-workflows/forking-workflow) + [Feature Branches](https://www.atlassian.com/git/tutorials/comparing-workflows/feature-branch-workflow). Additionally, PR's should be [rebased](https://www.atlassian.com/git/tutorials/merging-vs-rebasing) on master when opened, and again before merging.
|
|
|
|
1. Fork the repo.
|
|
2. Create a branch from `master`. If you're addressing a specific issue, prefix your branch name with the issue number.
|
|
3. If you've added code that should be tested, add tests.
|
|
4. If you've changed APIs, update the documentation.
|
|
5. Run `yarn test` and ensure the test suite passes.
|
|
6. Use `yarn format` to format and lint your code.
|
|
7. PR's must be rebased before merge (feel free to ask for help).
|
|
8. PR should be reviewed by two maintainers prior to merging.
|
|
|
|
## Debugging
|
|
|
|
`yarn start` spawns a development server and uses `dev-test/config.yml` and `dev-test/index.html` to serve the CMS.
|
|
In order to debug a specific issue follow the next steps:
|
|
|
|
1. Replace `dev-test/config.yml` with the relevant `config.yml`
|
|
|
|
2. Change the content of `dev-test/index.html` to:
|
|
|
|
```html
|
|
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<meta charset="utf-8" />
|
|
<title>Netlify CMS</title>
|
|
</head>
|
|
<body>
|
|
<script src="dist/netlify-cms.js"></script>
|
|
<!-- <script>
|
|
// this is the place to add CMS customizations if you need to, e.g.
|
|
CMS.registerPreviewTemplate('posts', PostPreview);
|
|
</script> -->
|
|
</body>
|
|
</html>
|
|
```
|
|
|
|
3. Run `yarn start`
|
|
4. Open `http://localhost:8080/` in the browser and you should have access to the CMS
|
|
|
|
### Debugging Git Gateway
|
|
|
|
When debugging the CMS with Git Gateway you must:
|
|
|
|
1. Have a Netlify site with [Git Gateway](https://docs.netlify.com/visitor-access/git-gateway/) and [Netlify Identity](https://docs.netlify.com/visitor-access/identity/) enabled. An easy way to create such a site is to use a [template](https://www.netlifycms.org/docs/start-with-a-template/), for example the [Gatsby template](https://app.netlify.com/start/deploy?repository=https://github.com/AustinGreen/gatsby-starter-netlify-cms&stack=cms)
|
|
2. Tell the CMS the URL of your Netlify site using a local storage item. To do so:
|
|
|
|
1. Open `http://localhost:8080/` in the browser
|
|
2. Write the below command and press enter: `localStorage.setItem('netlifySiteURL', 'https://yourwebsiteurl.netlify.app/')`
|
|
3. To be sure, you can run this command as well: `localStorage.getItem('netlifySiteURL')`
|
|
4. Refresh the page
|
|
5. You should be able to log in via your Netlify Identity email/password
|
|
|
|
## License
|
|
|
|
By contributing to Netlify CMS, you agree that your contributions will be licensed
|
|
under its [MIT license](LICENSE).
|