diff --git a/.all-contributorsrc b/.all-contributorsrc
index 8ceeb9ca..33f404b0 100644
--- a/.all-contributorsrc
+++ b/.all-contributorsrc
@@ -1004,6 +1004,15 @@
"contributions": [
"doc"
]
+ },
+ {
+ "login": "cdschroeder",
+ "name": "Casey Schroeder",
+ "avatar_url": "https://avatars3.githubusercontent.com/u/31967674?v=4",
+ "profile": "https://github.com/cdschroeder",
+ "contributions": [
+ "doc"
+ ]
}
],
"repoType": "github"
diff --git a/README.md b/README.md
index 6d365f3d..c405e2d8 100644
--- a/README.md
+++ b/README.md
@@ -1,5 +1,5 @@
# Netlify CMS
-[![All Contributors](https://img.shields.io/badge/all_contributors-114-orange.svg)](#contributors)
+[![All Contributors](https://img.shields.io/badge/all_contributors-115-orange.svg)](#contributors)
[![Open Source Helpers](https://www.codetriage.com/netlify/netlify-cms/badges/users.svg)](https://www.codetriage.com/netlify/netlify-cms)
[![](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/netlify/netlifycms)
@@ -78,7 +78,7 @@ These wonderful folks are responsible for developing and maintaining Netlify CMS
| [ David Ko](https://github.com/daveyko) [π»](https://github.com/netlify/netlify-cms/commits?author=daveyko "Code") | [ IΓ±aki GarcΓa](http://www.txorua.com) [π¨](#design-igarbla "Design") | [ Sam](https://github.com/gazebosx3) [π»](https://github.com/netlify/netlify-cms/commits?author=gazebosx3 "Code") | [ Josh Dzielak](https://dzello.com) [π](https://github.com/netlify/netlify-cms/commits?author=dzello "Documentation") | [ Jeremy Bise](http://thosegeeks.com) [π](https://github.com/netlify/netlify-cms/commits?author=jeremybise "Documentation") | [ terrierscript](https://terrierscript.com) [π»](https://github.com/netlify/netlify-cms/commits?author=terrierscript "Code") | [ Christopher Geary](https://twitter.com/crgeary) [π](#plugin-crgeary "Plugin/utility libraries") |
| [ Brian Macdonald](https://github.com/brianlmacdonald) [π»](https://github.com/netlify/netlify-cms/commits?author=brianlmacdonald "Code") | [ John Vandenberg](https://jayvdb.github.io/) [π](https://github.com/netlify/netlify-cms/commits?author=jayvdb "Documentation") | [ MarkZither](https://github.com/MarkZither) [π](https://github.com/netlify/netlify-cms/commits?author=MarkZither "Documentation") | [ Rob Phoenix](https://www.robphoenix.com) [π](https://github.com/netlify/netlify-cms/commits?author=robphoenix "Documentation") | [ Steve Lathrop](https://www.SteLa.io) [π»](https://github.com/netlify/netlify-cms/commits?author=slathrop "Code") [π](https://github.com/netlify/netlify-cms/commits?author=slathrop "Documentation") [π‘](#example-slathrop "Examples") | [ Maciej Matuszewski](https://github.com/maciejmatu) [π»](https://github.com/netlify/netlify-cms/commits?author=maciejmatu "Code") | [ Eko Eryanto](https://github.com/ekoeryanto) [π](#plugin-ekoeryanto "Plugin/utility libraries") |
| [ Taylor D. Edmiston](http://blog.tedmiston.com/) [π](https://github.com/netlify/netlify-cms/commits?author=tedmiston "Documentation") | [ Daniel Mahon](https://www.mahonstudios.com) [π»](https://github.com/netlify/netlify-cms/commits?author=danielmahon "Code") | [ Evan Hennessy](https://www.hennessyevan.com) [π](#plugin-hennessyevan "Plugin/utility libraries") | [ Hasan Azizul Haque](https://hasanavi.me) [π»](https://github.com/netlify/netlify-cms/commits?author=hasanavi "Code") [π](https://github.com/netlify/netlify-cms/commits?author=hasanavi "Documentation") [π€](#ideas-hasanavi "Ideas, Planning, & Feedback") | [ Robert Karlsson](https://github.com/robertkarlsson) [π](https://github.com/netlify/netlify-cms/issues?q=author%3Arobertkarlsson "Bug reports") | [ Gil Greenberg](http://gilgreenberg.com) [π»](https://github.com/netlify/netlify-cms/commits?author=gil-- "Code") | [ Tyler Ipson](http://loremipson.com) [π](https://github.com/netlify/netlify-cms/commits?author=loremipson "Documentation") |
-| [ Jake Rayson](https://www.growdigital.org/) [π»](https://github.com/netlify/netlify-cms/commits?author=growdigital "Code") [π](#blog-growdigital "Blogposts") [π‘](#example-growdigital "Examples") | [ Kurt collins](https://github.com/kurtgcollins) [π](https://github.com/netlify/netlify-cms/commits?author=kurtgcollins "Documentation") |
+| [ Jake Rayson](https://www.growdigital.org/) [π»](https://github.com/netlify/netlify-cms/commits?author=growdigital "Code") [π](#blog-growdigital "Blogposts") [π‘](#example-growdigital "Examples") | [ Kurt collins](https://github.com/kurtgcollins) [π](https://github.com/netlify/netlify-cms/commits?author=kurtgcollins "Documentation") | [ Casey Schroeder](https://github.com/cdschroeder) [π](https://github.com/netlify/netlify-cms/commits?author=cdschroeder "Documentation") |
This project follows the [all-contributors](https://github.com/kentcdodds/all-contributors) specification. Contributions of any kind welcome!
diff --git a/website/content/docs/architecture.md b/website/content/docs/architecture.md
index c0cea65a..b1fa23f2 100755
--- a/website/content/docs/architecture.md
+++ b/website/content/docs/architecture.md
@@ -10,7 +10,7 @@ The core abstractions for content editing are `collections`, `entries` and `widg
Each `collection` represents a collection of entries. This can either be a collection of similar entries with the same structure, or a set of entries where each has its own structure.
-The structure of an entry is defined as a series of fields, each with a `name`, a `label`, and a `widget` .
+The structure of an entry is defined as a series of fields, each with a `name`, a `label`, and a `widget`.
The `widget` determines the UI widget that the content editor will use when editing this field of an entry, as well as how the content of the field is presented in the editing preview.
@@ -21,7 +21,7 @@ Entries are loaded and persisted through a `backend` that will typically represe
**Config:** Holds the environment configuration (backend type, available collections and fields).
-**Collections** List of available collections, their fields and metadata information.
+**Collections:** List of available collections, their fields and metadata information.
**Entries:** Entries for each field.
@@ -37,7 +37,7 @@ Selectors are functions defined within reducers used to compute derived data fro
**getAsset:** Selects a single AssetProxy object for the given URI.
## Value Objects
-**AssetProxy:** AssetProxy is a Value Object that holds information regarding an asset file (such as an image, for example), whether it's persisted online or held locally in cache.
+**AssetProxy:** AssetProxy is a Value Object that holds information regarding an asset file (for example, an image), whether it's persisted online or held locally in cache.
For a file persisted online, the AssetProxy only keeps information about its URI. For local files, the AssetProxy will keep a reference to the actual File object while generating the expected final URIs and on-demand blobs for local preview.
@@ -72,6 +72,6 @@ Furthermore, all editorial workflow state is managed in Redux - there's an `acti
### About metadata
-Netlify CMS embraces the idea of Git-as-backend for storing metadata. The first time it runs with the editorial_workflow setup, it creates a new ref called `meta/_netlify_cms`, pointing to an empty, orphan tree.
+Netlify CMS embraces the idea of Git-as-backend for storing metadata. The first time it runs with the `editorial_workflow` setup, it creates a new ref called `meta/_netlify_cms`, pointing to an empty, orphan tree.
Actual data are stored in individual `json` files committed to this tree.
diff --git a/website/content/docs/beta-features.md b/website/content/docs/beta-features.md
index 8b276448..e19932b7 100644
--- a/website/content/docs/beta-features.md
+++ b/website/content/docs/beta-features.md
@@ -9,20 +9,16 @@ We run new functionality in an open beta format from time to time. That means th
**Use these features at your own risk.**
## Custom Mount Element
-Netlify CMS always creates it's own DOM element for mounting the application, which means it always
-takes over the entire page, and is generally inflexible if you're trying to do something creative,
-like injecting it into a shared context.
+Netlify CMS always creates its own DOM element for mounting the application, which means it always takes over the entire page, and is generally inflexible if you're trying to do something creative, like injecting it into a shared context.
-You can now provide your own element for Netlify CMS to mount in by setting the target element's ID
-as `nc-root`. If Netlify CMS finds an element with this ID during initialization, it will mount
-within that element instead of creating it's own.
+You can now provide your own element for Netlify CMS to mount in by setting the target element's ID as `nc-root`. If Netlify CMS finds an element with this ID during initialization, it will mount within that element instead of creating its own.
## Manual Initialization
Netlify CMS can now be manually initialized, rather than automatically loading up the moment you import it. The whole point of this at the moment is to inject configuration into Netlify CMS before it loads, bypassing need for an actual Netlify CMS `config.yml`. This is important, for example, when creating tight integrations with static site generators.
Injecting config is technically already possible by setting `window.CMS_CONFIG` before importing/requiring/running Netlify CMS, but most projects are modular and don't want to use globals, plus `window.CMS_CONFIG` is an internal, not technically supported, and provides no validation.
-Assuming you have the netlify-cms package installed to your project, manual initialization works like so:
+Assuming you have the netlify-cms package installed to your project, manual initialization works like this:
```js
// This global flag enables manual initialization.
@@ -48,7 +44,7 @@ init()
* not concatenated.
*
* For example, the code below contains an incomplete config, but using it,
- * your `config.yml` can be missing it's backend property, allowing you
+ * your `config.yml` can be missing its backend property, allowing you
* to set this property at runtime.
*/
@@ -65,7 +61,7 @@ CMS.registerPreviewTemplate(...);
```
## Raw CSS in `registerPreviewStyle`
-`registerPreviewStyle` can now accept a CSS string, in addition to accepting a url. The feature is activated by passing in an object as the second argument, with `raw` set to a truthy value.This is critical for integrating with modern build tooling. Here's an example using webpack:
+`registerPreviewStyle` can now accept a CSS string, in addition to accepting a url. The feature is activated by passing in an object as the second argument, with `raw` set to a truthy value. This is critical for integrating with modern build tooling. Here's an example using webpack:
```js
/**
@@ -79,7 +75,7 @@ CMS.registerPreviewStyle(styles.toString(), { raw: true })
```
## Squash merge GitHub pull requests
-When using the [Editorial Workflow](/docs/configuration-options/#publish-mode) with the `github` or GitHub-connected `git-gateway` backends, Netlify CMS creates a pull request for each unpublished entry. Every time the unpublished entry is changed and saved, a new commit is added to the pull request. When the entry is published, the pull request is merged, and all of those commits are added to your project commit history in a merge commit.
+When using the [Editorial Workflow](../configuration-options/#publish-mode) with the `github` or GitHub-connected `git-gateway` backends, Netlify CMS creates a pull request for each unpublished entry. Every time the unpublished entry is changed and saved, a new commit is added to the pull request. When the entry is published, the pull request is merged, and all of those commits are added to your project commit history in a merge commit.
The squash merge option causes all commits to be "squashed" into a single commit when the pull request is merged, and the resulting commit is rebased onto the target branch, avoiding the merge commit altogether.
diff --git a/website/content/docs/configuration-options.md b/website/content/docs/configuration-options.md
index 0d68a610..23963709 100644
--- a/website/content/docs/configuration-options.md
+++ b/website/content/docs/configuration-options.md
@@ -14,7 +14,7 @@ Alternatively, you can specify a custom config file using a link tag:
```
-To see working configuration examples, you can [start from a template](https://www.netlifycms.org/docs/start-with-a-template) or check out the [CMS demo site](https://cms-demo.netlify.com). (No login required: click the login button and the CMS will open.) You can refer to the demo [configuration code](https://github.com/netlify/netlify-cms/blob/master/example/config.yml) to see how each option was configured.
+To see working configuration examples, you can [start from a template](../start-with-a-template) or check out the [CMS demo site](https://cms-demo.netlify.com). (No login required: click the login button and the CMS will open.) You can refer to the demo [configuration code](https://github.com/netlify/netlify-cms/blob/master/example/config.yml) to see how each option was configured.
You can find details about all configuration options below. Note that [YAML syntax](https://en.wikipedia.org/wiki/YAML#Basic_components) allows lists and objects to be written in block or inline style, and the code samples below include a mix of both.
@@ -23,7 +23,7 @@ You can find details about all configuration options below. Note that [YAML synt
*This setting is required.*
-The `backend` option specifies how to access the content for your site, including authentication. Full details and code samples can be found in [Authentication & Backends](https://www.netlifycms.org/docs/authentication-backends).
+The `backend` option specifies how to access the content for your site, including authentication. Full details and code samples can be found in [Authentication & Backends](../authentication-backends).
**Note**: no matter where you access Netlify CMS β whether running locally, in a staging environment, or in your published site β it will always fetch and commit files in your hosted repository (for example, on GitHub), on the branch you configured in your Netlify CMS config.yml file. This means that content fetched in the admin UI will match the content in the repository, which may be different from your locally running site. It also means that content saved using the admin UI will save directly to the hosted repository, even if you're running the UI locally or in staging.
@@ -107,11 +107,11 @@ The `collections` setting is the heart of your Netlify CMS configuration, as it
`collections` accepts a list of collection objects, each with the following options:
-- `name` (required): unique identifier for the collection, used as the key when referenced in other contexts (like the [relation widget](https://www.netlifycms.org/docs/widgets/#relation))
+- `name` (required): unique identifier for the collection, used as the key when referenced in other contexts (like the [relation widget](../widgets/#relation))
- `Label`: label for the collection in the editor UI; defaults to the value of `name`
- `label_singular`: singular label for certain elements in the editor; defaults to the value of `label`
-- `file` or `folder` (requires one of these): specifies the collection type and location; details in [Collection Types](https://www.netlifycms.org/docs/collection-types)
-- `filter`: optional filter for `folder` collections; details in [Collection Types](https://www.netlifycms.org/docs/collection-types)
+- `file` or `folder` (requires one of these): specifies the collection type and location; details in [Collection Types](../collection-types)
+- `filter`: optional filter for `folder` collections; details in [Collection Types](../collection-types)
- `create`: for `folder` collections only; `true` allows users to create new items in the collection; defaults to `false`
- `delete`: `false` prevents users from deleting items in a collection; defaults to `true`
- `extension`: see detailed description below
@@ -170,12 +170,12 @@ The `fields` option maps editor UI widgets to field-value pairs in the saved fil
`fields` accepts a list of collection objects, each with the following options:
-- `name` (required): unique identifier for the field, used as the key when referenced in other contexts (like the [relation widget](https://www.netlifycms.org/docs/widgets/#relation))
+- `name` (required): unique identifier for the field, used as the key when referenced in other contexts (like the [relation widget](../widgets/#relation))
- `label`: label for the field in the editor UI; defaults to the value of `name`
-- `widget`: defines editor UI and inputs and file field data types; details in [Widgets](https://www.netlifycms.org/docs/widgets)
-- `default`: specify a default value for a field; available for most widget types (see [Widgets](https://www.netlifycms.org/docs/widgets) for details on each widget type)
+- `widget`: defines editor UI and inputs and file field data types; details in [Widgets](../widgets)
+- `default`: specify a default value for a field; available for most widget types (see [Widgets](../widgets) for details on each widget type)
- `required`: specify as `false` to make a field optional; defaults to `true`
-- `pattern`: add field validation by specifying a list with a regex pattern and an error message; more extensive validation can be achieved with [custom widgets](https://www.netlifycms.org/docs/custom-widgets/#advanced-field-validation)
+- `pattern`: add field validation by specifying a list with a regex pattern and an error message; more extensive validation can be achieved with [custom widgets](../custom-widgets/#advanced-field-validation)
In files with frontmatter, one field should be named `body`. This special field represents the section of the document (usually markdown) that comes after the frontmatter.
diff --git a/website/content/docs/custom-widgets.md b/website/content/docs/custom-widgets.md
index b13ebeea..89b6f95f 100644
--- a/website/content/docs/custom-widgets.md
+++ b/website/content/docs/custom-widgets.md
@@ -6,8 +6,8 @@ group: guides
The NetlifyCMS exposes a `window.CMS` global object that you can use to register custom widgets, previews, and editor plugins. The same object is also the default export if you import Netify CMS as an npm module. The available widget extension methods are:
-* **registerWidget:** lets you register a custom widget.
-* **registerEditorComponent:** lets you add a block component to the Markdown editor.
+* **registerWidget:** registers a custom widget.
+* **registerEditorComponent:** adds a block component to the Markdown editor.
### Writing React Components inline
@@ -125,7 +125,7 @@ CMS.registerEditorComponent({
## Advanced field validation
-All widget fields, including those for built-in widgets, [include basic validation](https://www.netlifycms.org/docs/widgets/#common-widget-options) capability using the `required` and `pattern` options.
+All widget fields, including those for built-in widgets, [include basic validation](../widgets/#common-widget-options) capability using the `required` and `pattern` options.
With custom widgets, the widget control can also optionally implement an `isValid` method to perform custom validations, in addition to presence and pattern. The `isValid` method will be automatically called, and it can return either a boolean value, an object with an error message or a promise. Examples:
@@ -167,4 +167,4 @@ You can also return a promise from `isValid`. While the promise is pending, the
};
```
-Note: Do not create a promise inside `isValid` - `isValid` is called right before trying to persist. This means that even if a previous promise was already resolved, when the user hits 'save', `isValid` will be called again. If it returns a new promise, it will be immediately marked as "in error" until the new promise resolves.
+**Note:** Do not create a promise inside `isValid` - `isValid` is called right before trying to persist. This means that even if a previous promise was already resolved, when the user hits 'save', `isValid` will be called again. If it returns a new promise, it will be immediately marked as "in error" until the new promise resolves.
diff --git a/website/content/docs/customization.md b/website/content/docs/customization.md
index 0d7a1176..c195100f 100644
--- a/website/content/docs/customization.md
+++ b/website/content/docs/customization.md
@@ -88,13 +88,8 @@ Registers a template for a collection.
```
### Lists and Objects
- The API for accessing the individual fields of list- and object-type entries is similar to the API
- for accessing fields in standard entries, but there are a few key differences. Access to these
- nested fields is facilitated through the `widgetsFor` function, which is passed to the preview
- template component during render.
- **Note**: as is often the case with the NetlifyCMS API, arrays and objects are created with
- Immutable.js. If some of the methods that we use are unfamiliar, such as `getIn`, check out
- [their docs](https://facebook.github.io/immutable-js/docs/#/) to get a better understanding.
+ The API for accessing the individual fields of list- and object-type entries is similar to the API for accessing fields in standard entries, but there are a few key differences. Access to these nested fields is facilitated through the `widgetsFor` function, which is passed to the preview template component during render.
+ **Note**: as is often the case with the NetlifyCMS API, arrays and objects are created with Immutable.js. If some of the methods that we use are unfamiliar, such as `getIn`, check out [their docs](https://facebook.github.io/immutable-js/docs/#/) to get a better understanding.
**List Example:**
```html
```
### Accessing Metadata
- Preview Components also receive an additional prop: `fieldsMetaData`. It contains aditional information (besides the plain plain textual value of each field) that can be useful for preview purposes.
- For example, the Relation widget passes the whole selected relation data in `fieldsMetaData`.
+ Preview Components also receive an additional prop: `fieldsMetaData`. It contains aditional information (besides the plain plain textual value of each field) that can be useful for preview purposes. For example, the Relation widget passes the whole selected relation data in `fieldsMetaData`.
```js
export default class ArticlePreview extends React.Component {
render() {
diff --git a/website/content/docs/widgets/index.md b/website/content/docs/widgets/index.md
index f40b1641..62b1df02 100644
--- a/website/content/docs/widgets/index.md
+++ b/website/content/docs/widgets/index.md
@@ -4,7 +4,7 @@ weight: 30
group: reference
---
-Widgets define the data type and interface for entry fields. Netlify CMS comes with several built-in widgets. Click the widget names in the sidebar to jump to specific widget details. Weβre always adding new widgets, and you can also [create your own](https://www.netlifycms.org/docs/custom-widgets)!
+Widgets define the data type and interface for entry fields. Netlify CMS comes with several built-in widgets. Click the widget names in the sidebar to jump to specific widget details. Weβre always adding new widgets, and you can also [create your own](../custom-widgets)!
Widgets are specified as collection fields in the Netlify CMS `config.yml` file. Note that [YAML syntax](https://en.wikipedia.org/wiki/YAML#Basic_components) allows lists and objects to be written in block or inline style, and the code samples below include a mix of both.
@@ -17,7 +17,7 @@ The following options are available on all fields:
- `required`: specify as `false` to make a field optional; defaults to `true`
- `hint`: optionally add helper text directly below a widget. Useful for including instructions.
-- `pattern`: add field validation by specifying a list with a [regex pattern](https://regexr.com/) and an error message; more extensive validation can be achieved with [custom widgets](https://www.netlifycms.org/docs/custom-widgets/#advanced-field-validation)
+- `pattern`: add field validation by specifying a list with a [regex pattern](https://regexr.com/) and an error message; more extensive validation can be achieved with [custom widgets](../custom-widgets/#advanced-field-validation)
- **Example:**
```yaml
- label: "Title"
diff --git a/website/content/docs/widgets/markdown.md b/website/content/docs/widgets/markdown.md
index 23692b02..1bd2155c 100644
--- a/website/content/docs/widgets/markdown.md
+++ b/website/content/docs/widgets/markdown.md
@@ -5,7 +5,7 @@ target: markdown
The markdown widget provides a full fledged text editor - which is based on [slate](https://github.com/ianstormtaylor/slate) - that allows users to format text with features such as headings and blockquotes. Users are also allowed to write in markdown by simply flipping a switch.
-*Please note:* in case you want to use your markdown editor to fill a markdown's file content after the frontmatter, you'll have name the field as `body` so then the CMS can recognize it and save the file accordingly.
+*Please note:* in case you want to use your markdown editor to fill a markdown's file content after the frontmatter, you'll have name the field as `body` so that the CMS can recognize it and save the file accordingly.
- **Name:** `markdown`
- **UI:** full text editor