Browse Source

Add --harmony option to live JSX compiler page

main
Ben Alpert 11 years ago
parent
commit
1cd3c3e7e9
  1. 5
      _css/react.scss
  2. 33
      _js/jsx-compiler.js
  3. 5
      _js/live_editor.js

5
_css/react.scss

@ -455,6 +455,11 @@ section.black content {
padding-top: 20px; padding-top: 20px;
width: 1220px; width: 1220px;
label.compiler-option {
display: block;
margin-top: 5px;
}
#jsxCompiler { #jsxCompiler {
margin-top: 20px; margin-top: 20px;
} }

33
_js/jsx-compiler.js

@ -13,15 +13,38 @@ var HelloMessage = React.createClass({\n\
React.renderComponent(<HelloMessage name=\"John\" />, mountNode);\ React.renderComponent(<HelloMessage name=\"John\" />, mountNode);\
"; ";
var transformer = function(code) { function transformer(harmony, code) {
return JSXTransformer.transform(code).code; return JSXTransformer.transform(code, {harmony: harmony}).code;
} }
React.renderComponent(
var CompilerPlayground = React.createClass({
getInitialState: function() {
return {harmony: false};
},
handleHarmonyChange: function(e) {
this.setState({harmony: e.target.checked});
},
render: function() {
return (
<div>
<ReactPlayground <ReactPlayground
codeText={HELLO_COMPONENT} codeText={HELLO_COMPONENT}
renderCode={true} renderCode={true}
transformer={transformer} transformer={transformer.bind(null, this.state.harmony)}
showCompiledJSTab={false} showCompiledJSTab={false}
/>, />
<label className="compiler-option">
<input
type="checkbox"
onChange={this.handleHarmonyChange}
checked={this.state.harmony} />{' '}
Enable ES6 transforms (<code>--harmony</code>)
</label>
</div>
);
},
});
React.renderComponent(
<CompilerPlayground />,
document.getElementById('jsxCompiler') document.getElementById('jsxCompiler')
); );

5
_js/live_editor.js

@ -173,10 +173,11 @@ var ReactPlayground = React.createClass({
this.executeCode(); this.executeCode();
}, },
componentWillUpdate: function(nextProps, nextState) { componentDidUpdate: function(prevProps, prevState) {
// execute code only when the state's not being updated by switching tab // execute code only when the state's not being updated by switching tab
// this avoids re-displaying the error, which comes after a certain delay // this avoids re-displaying the error, which comes after a certain delay
if (this.state.code !== nextState.code) { if (this.props.transformer !== prevProps.transformer ||
this.state.code !== prevState.code) {
this.executeCode(); this.executeCode();
} }
}, },

Loading…
Cancel
Save