diff --git a/website/core/Marked.js b/website/core/Marked.js index 7d3fa4626..d123b874b 100644 --- a/website/core/Marked.js +++ b/website/core/Marked.js @@ -8,6 +8,7 @@ var React = require('React'); var Prism = require('Prism'); +var WebPlayer = require('WebPlayer'); var Header = require('Header'); /** @@ -827,7 +828,16 @@ Parser.prototype.tok = function() { ); } case 'code': { - return {this.token.text}; + var lang = this.token.lang + , text = this.token.text; + + if (lang && lang.indexOf('ReactNativeWebPlayer') === 0) { + return ( + {text} + ); + } + + return {text}; } case 'table': { var table = [] diff --git a/website/core/WebPlayer.js b/website/core/WebPlayer.js new file mode 100644 index 000000000..2e985388b --- /dev/null +++ b/website/core/WebPlayer.js @@ -0,0 +1,68 @@ +/** + * Copyright (c) 2015-present, Facebook, Inc. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. An additional grant + * of patent rights can be found in the PATENTS file in the same directory. + * + * @providesModule WebPlayer + */ + +var React = require('React'); +var Prism = require('Prism'); + +/** + * Use the WebPlayer by including a ```ReactNativeWebPlayer``` block in markdown. + * + * Optionally, include url parameters directly after the block's language. For + * the complete list of url parameters, see: https://github.com/dabbott/react-native-web-player + * + * E.g. + * ```ReactNativeWebPlayer?platform=android + * import React from 'react'; + * import { AppRegistry, Text } from 'react-native'; + * + * const App = () => Hello World!; + * + * AppRegistry.registerComponent('MyApp', () => App); + * ``` + */ +var WebPlayer = React.createClass({ + parseParams: function(paramString) { + var params = {}; + + if (paramString) { + var pairs = paramString.split('&'); + for (var i = 0; i < pairs.length; i++) { + var pair = pairs[i].split('='); + params[pair[0]] = pair[1]; + } + } + + return params; + }, + + render: function() { + var hash = `#code=${encodeURIComponent(this.props.children)}&runApp=AwesomeProject`; + + if (this.props.params) { + hash += `&${this.props.params}`; + } + + return ( +
+ {this.props.children} +