You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
Julen Ruiz Aizpuru 9da4c206dc Docs: renamed input's state to `message` 11 years ago
_css Update Bourbon files (4.0.2) 11 years ago
_data Autogenerate acknowledgements 11 years ago
_includes Put nav data in "_data" 11 years ago
_js Add --harmony option to live JSX compiler page 11 years ago
_layouts [Docs] Make retina react logo work 11 years ago
_plugins Make doc headers clickable again 11 years ago
_posts Default to layout: post for posts 11 years ago
blog 2 docs fixes. 11 years ago
css [Docs] Make retina react logo work 11 years ago
docs Docs: renamed input's state to `message` 11 years ago
downloads v0.11.1 release materials, update to 0.11.0 release materials 11 years ago
img [Docs] Make retina react logo work 11 years ago
js Normalize line endings 11 years ago
tips Add example to if else in JSX. 11 years ago
404.md Simple custom 404 page. 11 years ago
Gemfile Use jekyll-redirect-from instead of our other redirect method 11 years ago
Gemfile.lock Use jekyll-redirect-from instead of our other redirect method 11 years ago
README.md Update README to use bundle exec * 11 years ago
Rakefile Autogenerate acknowledgements 11 years ago
_config.yml Use jekyll-redirect-from instead of our other redirect method 11 years ago
acknowledgements.md Autogenerate acknowledgements 11 years ago
downloads.md Remove mention of envify since it is listed in package.json 11 years ago
extractCode.js Initial public release 12 years ago
favicon.ico Initial public release 12 years ago
feed.xml [docs] RSS: Pass title through xml_escape 12 years ago
html-jsx.md Simple HTML to JSX converter, built during Hackathon 40 at Facebook. 11 years ago
index.md Update homepage for new JSX/JS editor 11 years ago
jsx-compiler.md Fix docs typo 11 years ago
support.md Don't use <center> for twitter embeds 11 years ago

README.md

React Documentation & Website

We use Jekyll to build the site using (mostly) Markdown, and we host it by pushing HTML to GitHub Pages.

Installation

If you are working on the site, you will want to install and run a local copy of it.

Dependencies

In order to use Jekyll, you will need to have Ruby installed.

Mac OS X comes pre-installed with Ruby, but you may need to update RubyGems (via gem update --system). Otherwise, RVM and rbenv are popular ways to install Ruby. Once you have RubyGems and installed Bundler (via gem install bundler), use it to install the dependencies:

$ cd react/docs
$ bundle install # Might need sudo.
$ npm install # Might need sudo.

Instructions

The site requires React, so first make sure you've built the project (via grunt).

Use Jekyll to serve the website locally (by default, at http://localhost:4000):

$ cd react/docs
$ bundle exec rake
$ bundle exec jekyll serve -w
$ open http://localhost:4000/react/

We use SASS (with Bourbon) for our CSS, and we use JSX to transform some of our JS. If you only want to modify the HTML or Markdown, you do not have to do anything because we package pre-compiled copies of the CSS and JS. If you want to modify the CSS or JS, use Rake to compile them:

$ cd react/docs
$ bundle exec rake watch # Automatically compiles as needed.
# bundle exec rake         Manually compile CSS and JS.
# bundle exec rake js      Manually compile JS, only.

Afterthoughts

Updating facebook.github.io/react

The easiest way to do this is to have a separate clone of this repository, checked out to the gh-pages branch. We have a build step that expects this to be in a directory named react-gh-pages at the same depth as react. Then it's just a matter of running grunt docs, which will compile the site and copy it out to this repository. From there you can check it in.

Note: This should only be done for new releases. You should create a tag corresponding to the release tag in the main repository.

We also have a rake task that does the same thing (without creating commits). It expects the directory structure mentioned above.

$ bundle exec rake release

Removing the Jekyll / Ruby Dependency

In an ideal world, we would not be adding a Ruby dependency on part of our project. We would like to move towards a point where we are using React to render the website.