diff --git a/.github/ISSUE_TEMPLATE/bug.md b/.github/ISSUE_TEMPLATE/bug.md
index ae56f184..44ddaf93 100644
--- a/.github/ISSUE_TEMPLATE/bug.md
+++ b/.github/ISSUE_TEMPLATE/bug.md
@@ -33,6 +33,9 @@ Steps to reproduce:
**Expected behavior**
**Environment (include versions). Did this work in previous versions?**
diff --git a/README.md b/README.md
index 0a95a9ed..ff607ed3 100644
--- a/README.md
+++ b/README.md
@@ -25,7 +25,7 @@ using Node.js.
Who is using React Native in production web apps?
[Twitter](https://mobile.twitter.com), [Major League
Soccer](https://matchcenter.mlssoccer.com),
-[Flipkart](https://www.flipkart.com/), Playstation, Uber, [The
+[Flipkart](https://www.flipkart.com/), Uber, [The
Times](https://github.com/newsuk/times-components).
Browser support: Chrome, Firefox, Edge, Safari 7+, IE 10+.
@@ -38,34 +38,56 @@ The easiest way to get started is to edit this
anything to try it out.
For installation and configuration details please read the [getting
-started](https://github.com/necolas/react-native-web/blob/master/packages/website/guides/getting-started.md)
+started](https://github.com/necolas/react-native-web/blob/master/docs/guides/getting-started.md)
guide.
## Documentation
-You can find the API documentation [on the website][website-url].
-
-Please refer to the [React Native documentation][react-native-url] for more
-design details, and for information about the [Gesture Responder
+Please refer to the [React Native documentation][react-native-url] for the
+overall API, design details, and information about the [Gesture Responder
system](https://facebook.github.io/react-native/docs/gesture-responder-system.html)
and [animations](https://facebook.github.io/react-native/docs/animations.html).
+Some components and APIs are extended with additional features for the web. And
+in a few cases, features present for Android or iOS are missing on the web.
+These differences are documented [on the website][website-url].
+
### Guides
-* [Getting started](https://github.com/necolas/react-native-web/blob/master/packages/website/guides/getting-started.md)
-* [Style](https://github.com/necolas/react-native-web/blob/master/packages/website/guides/style.md)
-* [Accessibility](https://github.com/necolas/react-native-web/blob/master/packages/website/guides/accessibility.md)
-* [Internationalization](https://github.com/necolas/react-native-web/blob/master/packages/website/guides/internationalization.md)
-* [Direct manipulation](https://github.com/necolas/react-native-web/blob/master/packages/website/guides/direct-manipulation.md)
-* [Experimental / unstable use](https://github.com/necolas/react-native-web/blob/master/packages/website/guides/advanced.md)
+These guides provide a detailed look at using React Native to create accessible
+web experiences. Certain web-specific patterns are documented in the "web
+recipes" guide.
+
+* [Getting started](https://github.com/necolas/react-native-web/blob/master/docs/guides/getting-started.md)
+* [Client-side rendering](https://github.com/necolas/react-native-web/blob/master/docs/guides/client-side-rendering.md)
+* [Server-side rendering](https://github.com/necolas/react-native-web/blob/master/docs/guides/server-side-rendering.md)
+* [Style](https://github.com/necolas/react-native-web/blob/master/docs/guides/style.md)
+* [Accessibility](https://github.com/necolas/react-native-web/blob/master/docs/guides/accessibility.md)
+* [Internationalization](https://github.com/necolas/react-native-web/blob/master/docs/guides/internationalization.md)
+* [Direct manipulation](https://github.com/necolas/react-native-web/blob/master/docs/guides/direct-manipulation.md)
+* [Web recipes](https://github.com/necolas/react-native-web/blob/master/docs/guides/web-recipes.md)
+* [Multi-platform apps](https://github.com/necolas/react-native-web/blob/master/docs/guides/multi-platform-apps.md)
+* [Experimental / unstable use](https://github.com/necolas/react-native-web/blob/master/docs/guides/advanced.md)
+
+## Integrations
+
+Examples of using React Native for Web with other web tools:
+
+* [Docz](https://github.com/pedronauck/docz/tree/master/examples/react-native-flow)
+* [Gatsby](https://github.com/gatsbyjs/gatsby/tree/master/examples/using-react-native-web)
+* [Next.js](https://github.com/zeit/next.js/tree/master/examples/with-react-native-web)
+* [Phenomic](https://github.com/phenomic/phenomic/tree/master/examples/react-native-web-app)
+* [Razzle](https://github.com/jaredpalmer/razzle/tree/master/examples/with-react-native-web)
+* [Storybook](https://github.com/necolas/react-native-web/tree/master/packages/website/storybook/.storybook)
+* [Styleguidist](https://github.com/styleguidist/react-styleguidist/tree/master/examples/react-native)
## Examples
-There are examples [on the website][website-url] ([source
-code](https://github.com/necolas/react-native-web/blob/master/packages/website).
-And all the [React Native examples][examples-url] ([source
-code](https://github.com/necolas/react-native-web/blob/master/packages/examples))
-are also available. Here is an example to get you started:
+Check out all the [React Native examples][examples-url] ([source
+code](https://github.com/necolas/react-native-web/blob/master/packages/examples)).
+There are more examples [on the website][website-url] ([source
+code](https://github.com/necolas/react-native-web/blob/master/packages/website)).
+And here is a simple example to get you started:
```js
import React from 'react';
@@ -96,104 +118,87 @@ You'll notice that there is no reference to `react-dom`; the `App` component is
defined using the platform-agnostic APIs and Components introduced by React
Native. This allows the app to be rendered to web and native platforms.
-## Integrations
-
-Examples of using React Native for Web with other web tools:
-
-* [Gatsby](https://github.com/gatsbyjs/gatsby/tree/master/examples/using-react-native-web)
-* [Next.js](https://github.com/zeit/next.js/tree/master/examples/with-react-native-web)
-* [Phenomic](https://github.com/phenomic/phenomic/tree/master/examples/react-native-web-app)
-* [Razzle](https://github.com/jaredpalmer/razzle/tree/master/examples/with-react-native-web)
-* [Storybook](https://github.com/necolas/react-native-web/tree/master/packages/website/storybook/.storybook)
-* [Styleguidist](https://github.com/styleguidist/react-styleguidist/tree/master/examples/react-native)
-
-Example recipes for web-specific UI patterns:
-
-* [Links](https://codesandbox.io/s/53r88k5opx)
-* [Hover styles](https://codesandbox.io/s/o9q8vy70l5)
-* [Root element styles](https://codesandbox.io/s/52x1871vjl)
-
## Compatibility with React Native
React Native v0.55
### Components
-| Name | Status | Notes |
-| :----------------------- | :------------------ | :---- |
-| ActivityIndicator | Available | |
-| ART | Available | |
-| Button | Available | |
-| CheckBox | Available | |
-| FlatList | Available | |
-| Image | Available (partial) | Missing multiple sources and HTTP headers. |
-| ImageBackground | Available | |
-| KeyboardAvoidingView | Available (mock) | |
-| ListView | Available | |
-| Modal | Not started | |
-| Picker | Available | |
-| RefreshControl | Not started | |
-| SafeAreaView | Available | |
-| ScrollView | Available (partial) | Missing momentum scroll events. |
-| SectionList | Available | |
-| Slider | Not started | |
-| StatusBar | Mock | |
-| SwipeableFlatList | Available | |
-| SwipeableListView | Available | |
-| Switch | Available | |
-| Text | Available (partial) | Missing `onLongPress` support. |
-| TextInput | Available (partial) | Missing rich text features and auto-expanding behaviour. |
-| Touchable | Available | Includes additional support for mouse and keyboard interactions. |
-| TouchableHighlight | Available | |
-| TouchableNativeFeedback | Not started | |
-| TouchableOpacity | Available | |
-| TouchableWithoutFeedback | Available | |
-| View | Available | |
-| VirtualizedList | Available | |
-| WebView | Not started | |
-| YellowBox | Mock | |
+| Name | Status | Notes |
+| :----------------------- | :----- | :---- |
+| ActivityIndicator | ✓ | |
+| ART | ✓ | |
+| Button | ✓ | |
+| CheckBox | ✓ | |
+| FlatList | ✓ | |
+| Image | ✓ | Missing multiple sources ([#515](https://github.com/necolas/react-native-web/issues/515)) and HTTP headers ([#1019](https://github.com/necolas/react-native-web/issues/1019)). |
+| ImageBackground | ✓ | |
+| KeyboardAvoidingView | (✓) | Mock. No equivalent web APIs. |
+| ListView | ✓ | |
+| Modal | ✘ | Not started ([#1020](https://github.com/necolas/react-native-web/issues/1020)). |
+| Picker | ✓ | |
+| RefreshControl | ✘ | Not started ([#1027](https://github.com/necolas/react-native-web/issues/1027)). |
+| SafeAreaView | ✓ | |
+| ScrollView | ✓ | Missing momentum scroll events ([#1021](https://github.com/necolas/react-native-web/issues/1021)) and `pagingEnabled` ([#1057](https://github.com/necolas/react-native-web/issues/1057)). |
+| SectionList | ✓ | |
+| Slider | ✘ | Not started ([#1022](https://github.com/necolas/react-native-web/issues/1022)). |
+| StatusBar | (✓) | Mock. No equivalent web APIs. |
+| SwipeableFlatList | ✓ | |
+| SwipeableListView | ✓ | |
+| Switch | ✓ | |
+| Text | ✓ | Missing `onLongPress` ([#1011](https://github.com/necolas/react-native-web/issues/1011)) and `numberOfLines` ([#13](https://github.com/necolas/react-native-web/issues/13)) support. |
+| TextInput | ✓ | Missing `onContentSizeChange` ([#793](https://github.com/necolas/react-native-web/issues/793)), rich text features ([#1023](https://github.com/necolas/react-native-web/issues/1023)), and auto-expanding behaviour ([#795](https://github.com/necolas/react-native-web/issues/795)). |
+| Touchable | ✓ | Includes additional support for mouse and keyboard interactions. |
+| TouchableHighlight | ✓ | |
+| TouchableNativeFeedback | ✘ | Not started ([#1024](https://github.com/necolas/react-native-web/issues/1024)). |
+| TouchableOpacity | ✓ | |
+| TouchableWithoutFeedback | ✓ | |
+| View | ✓ | |
+| VirtualizedList | ✓ | |
+| WebView | ✘ | Not started ([1025](https://github.com/necolas/react-native-web/issues/1025)). |
+| YellowBox | (✓) | Mock. No YellowBox functionality. |
### Modules
-| Name | Status | Notes |
-| :----------------------- | :------------------ | :---- |
-| AccessibilityInfo | Mock | No equivalent web APIs. |
-| Alert | Not started | |
-| Animated | Available | Missing `useNativeDriver` support. |
-| AppRegistry | Available | Includes additional support for SSR with `getApplication`. |
-| AppState | Available | |
-| AsyncStorage | Available | |
-| BackHandler | Mock | No equivalent web APIs. |
-| CameraRoll | Not started | No equivalent web APIs. |
-| Clipboard | Available | |
-| ColorPropType | Available | |
-| DeviceInfo | Available (partial) | |
-| Dimensions | Available | |
-| Easing | Available | |
-| EdgeInsetsPropType | Available | |
-| Geolocation | Available | |
-| I18nManager | Available | Includes additional support for runtime switch to RTL. |
-| ImageEditor | Not started | No equivalent web APIs. |
-| ImageStore | Not started | No equivalent web APIs. |
-| InteractionManager | Available (partial) | |
-| Keyboard | Mock | |
-| LayoutAnimation | Available (partial) | Missing transform to web animation. |
-| Linking | Available | |
-| NativeEventEmitter | Available | |
-| NativeMethodsMixin | Available | |
-| NativeModules | Available (partial) | Mocked. Missing ability to load native modules. |
-| NetInfo | Available (partial) | Missing functionality to detect extensive connections. |
-| PanResponder | Available | |
-| PixelRatio | Available | |
-| Platform | Available | |
-| PointPropType | Available | |
-| Settings | Not started | |
-| Share | Available | Only available over HTTPS. Read about the [Web Share API](https://wicg.github.io/web-share/). |
-| StyleSheet | Available | |
-| TextPropTypes | Available | |
-| UIManager | Available | |
-| Vibration | Available | |
-| ViewPropTypes | Available | |
+| Name | Status | Notes |
+| :----------------------- | :----- | :---- |
+| AccessibilityInfo | (✓) | Mock. No equivalent web APIs. |
+| Alert | ✘ | Not started ([#1026](https://github.com/necolas/react-native-web/issues/1026)). |
+| Animated | ✓ | Missing `useNativeDriver` support. |
+| AppRegistry | ✓ | Includes additional support for server rendering with `getApplication`. |
+| AppState | ✓ | |
+| AsyncStorage | ✓ | |
+| BackHandler | (✓) | Mock. No equivalent web APIs. |
+| CameraRoll | ✘ | No equivalent web APIs. |
+| Clipboard | ✓ | |
+| ColorPropType | ✓ | |
+| DeviceInfo | (✓) | Limited information. |
+| Dimensions | ✓ | |
+| Easing | ✓ | |
+| EdgeInsetsPropType | ✓ | |
+| Geolocation | ✓ | |
+| I18nManager | ✓ | Includes additional support for runtime switch to RTL. |
+| ImageEditor | ✘ | No equivalent web APIs. |
+| ImageStore | ✘ | No equivalent web APIs. |
+| InteractionManager | (✓) | |
+| Keyboard | (✓) | Mock. |
+| LayoutAnimation | (✓) | Missing translation to web animations. |
+| Linking | ✓ | |
+| NativeEventEmitter | ✓ | |
+| NativeMethodsMixin | ✓ | |
+| NativeModules | (✓) | Mocked. Missing ability to load native modules. |
+| NetInfo | ✓ | Missing functionality to detect expensive connections as there are no equivalent web APIs. |
+| PanResponder | ✓ | |
+| PixelRatio | ✓ | |
+| Platform | ✓ | |
+| PointPropType | ✓ | |
+| Settings | ✘ | No equivalent web APIs. |
+| Share | ✓ | Only available over HTTPS. Read about the [Web Share API](https://wicg.github.io/web-share/). |
+| StyleSheet | ✓ | |
+| TextPropTypes | ✓ | |
+| UIManager | ✓ | |
+| Vibration | ✓ | |
+| ViewPropTypes | ✓ | |
## Contributing
diff --git a/packages/website/guides/accessibility.md b/docs/guides/accessibility.md
similarity index 100%
rename from packages/website/guides/accessibility.md
rename to docs/guides/accessibility.md
diff --git a/packages/website/guides/advanced.md b/docs/guides/advanced.md
similarity index 100%
rename from packages/website/guides/advanced.md
rename to docs/guides/advanced.md
diff --git a/docs/guides/client-side-rendering.md b/docs/guides/client-side-rendering.md
new file mode 100644
index 00000000..e2c47df1
--- /dev/null
+++ b/docs/guides/client-side-rendering.md
@@ -0,0 +1,42 @@
+# Client-side rendering
+
+Render apps using `AppRegistry`:
+
+```js
+// index.web.js
+
+import App from './src/App';
+import React from 'react';
+import { AppRegistry } from 'react-native';
+
+// register the app
+AppRegistry.registerComponent('App', () => App);
+
+AppRegistry.runApplication('App', {
+ initialProps: {},
+ rootTag: document.getElementById('react-app')
+});
+```
+
+Or render individual components:
+
+```js
+import AppHeader from './src/AppHeader';
+import React from 'react';
+import { render } from 'react-native';
+
+render(