Browse Source

99 replace button with checkbox and apply proposed changes

main
Admir Sabanovic 7 years ago
parent
commit
9876647f26
  1. 91
      src/components/CodeEditor/CodeEditor.js

91
src/components/CodeEditor/CodeEditor.js

@ -14,21 +14,20 @@ import Remarkable from 'remarkable';
import {LiveEditor, LiveProvider} from '@gaearon/react-live'; import {LiveEditor, LiveProvider} from '@gaearon/react-live';
import {colors, media} from 'theme'; import {colors, media} from 'theme';
import MetaTitle from 'templates/components/MetaTitle'; import MetaTitle from 'templates/components/MetaTitle';
import {highlight, languages} from 'prismjs/components/prism-core';
import 'prismjs/components/prism-javascript';
const compile = code => const compileES5 = (
Babel.transform(code, {presets: ['es2015', 'react']}).code; // eslint-disable-line no-undef code, // eslint-disable-next-line no-undef
) => Babel.transform(code, {presets: ['es2015', 'react']}).code;
const compileJsxToJS = code => Babel.transform(code, {presets: ['react']}).code; // eslint-disable-line no-undef // eslint-disable-next-line no-undef
const compileES6 = code => Babel.transform(code, {presets: ['react']}).code;
const prism = code => highlight(code, languages.javascript);
class CodeEditor extends Component { class CodeEditor extends Component {
constructor(props, context) { constructor(props, context) {
super(props, context); super(props, context);
this.state = this._updateState(props.code); this.state = this._updateState(props.code);
this.state.showJSX = true;
} }
componentDidMount() { componentDidMount() {
@ -45,10 +44,10 @@ class CodeEditor extends Component {
render() { render() {
const {children} = this.props; const {children} = this.props;
const {error, code, showCompiledJsx, compiledJsx} = this.state; const {compiledES6, code, error, showJSX} = this.state;
return ( return (
<LiveProvider code={code} mountStylesheet={false}> <LiveProvider code={showJSX ? code : compiledES6} mountStylesheet={false}>
<div <div
css={{ css={{
[media.greaterThan('xlarge')]: { [media.greaterThan('xlarge')]: {
@ -120,24 +119,20 @@ class CodeEditor extends Component {
}}> }}>
<MetaTitle onDark={true}> <MetaTitle onDark={true}>
Live JSX Editor Live JSX Editor
{!showCompiledJsx && ( <label
<a css={{
role="button" fontSize: 14,
tabIndex="0" float: 'right',
css={{cursor: 'pointer'}} cursor: 'pointer',
onClick={this._showCompiledJsxPreview.bind(this)}> }}>
View Compiled JSX <input
</a> checked={this.state.showJSX}
)} onChange={event =>
{showCompiledJsx && ( this.setState({showJSX: event.target.checked})}
<a type="checkbox"
css={{cursor: 'pointer'}} />{' '}
role="button" JSX?
tabIndex="0" </label>
onClick={this._hideCompiledJsxPreview.bind(this)}>
Back to JSX Editor
</a>
)}
</MetaTitle> </MetaTitle>
</div> </div>
<div <div
@ -165,14 +160,7 @@ class CodeEditor extends Component {
}, },
}} }}
className="gatsby-highlight"> className="gatsby-highlight">
{!showCompiledJsx && <LiveEditor onChange={this._onChange} />} <LiveEditor onChange={this._onChange} />
{showCompiledJsx && (
<pre
className="prism-code"
spellCheck="false"
dangerouslySetInnerHTML={{__html: prism(compiledJsx)}}
/>
)}
</div> </div>
</div> </div>
{error && ( {error && (
@ -298,14 +286,21 @@ class CodeEditor extends Component {
this._mountNode = ref; this._mountNode = ref;
}; };
_updateState(code) { _updateState(code, showJSX = true) {
try { try {
return { let newState = {
compiled: compile(code), compiled: compileES5(code),
compiledJsx: compileJsxToJS(code),
code: code,
error: null, error: null,
}; };
if (showJSX) {
newState.code = code;
newState.compiledES6 = compileES6(code);
} else {
newState.compiledES6 = code;
}
return newState;
} catch (error) { } catch (error) {
console.error(error); console.error(error);
@ -317,21 +312,7 @@ class CodeEditor extends Component {
} }
_onChange = code => { _onChange = code => {
this.setState(this._updateState(code)); this.setState(this._updateState(code, this.state.showJSX));
};
_showCompiledJsxPreview = () => {
this.setState({
...this.state,
showCompiledJsx: true,
});
};
_hideCompiledJsxPreview = () => {
this.setState({
...this.state,
showCompiledJsx: false,
});
}; };
} }

Loading…
Cancel
Save