Polymer docs are mostly in Markdown with some HTML. Jekyll is used to generate the static HTML for the site. The output is generated into a folder called _site
and served from Google App Engine.
We use Jekyll 1.0+ and Grunt to generate the documentation. You'll need to install the requirements before working on the docs (these instructions assume NPM is already installed):
sudo gem install jekyll
sudo npm install -g grunt-cli
npm install
You'll also need the App Engine dev server to preview the docs locally. Download the SDK.
This repo (polymer/docs
) is where the documentation source files live. To make a change:
- Checkout this repo (using
git clone https://github.com/Polymer/docs.git --recursive
) and make your edits. - To build the docs, run
grunt
in base of the docs diretory you checked out. This starts up jekyll and watches for changes as you make edits. You may need to runnpm install
in your docs directory if it's a new checkout. - Lastly, fire up the App Engine dev server in this folder (
dev_appserver.py .
) to preview the docs.
Jekyll generates the static site in a folder named _site
. Note: If you're not running jekyll to rebuild the site, you won't see your changes in the dev server.
Once your changes look good, git commit
them and push.
Note: only project owners can publish the documentation.
Make sure your docs/polymer
submodule is up to date
(this should only be necessary when polymer
merges the master -> stable branch):
git submodule update --recursive
Generate the docs using:
grunt docs
Last step is to push the docs to App Engine. In your Polymer/docs
directory, run:
appcfg.py --oauth2 update .
(The --oauth2
is not required, but makes it easier to upload if you use second factor authentication.)