|
@ -14,14 +14,13 @@ 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 {highlight, languages} from 'prismjs/components/prism-core'; |
|
|
import 'prismjs/components/prism-javascript' |
|
|
import 'prismjs/components/prism-javascript'; |
|
|
|
|
|
|
|
|
const compile = code => |
|
|
const compile = code => |
|
|
Babel.transform(code, {presets: ['es2015', 'react']}).code; // eslint-disable-line no-undef
|
|
|
Babel.transform(code, {presets: ['es2015', 'react']}).code; // eslint-disable-line no-undef
|
|
|
|
|
|
|
|
|
const compileJsxToJS = code => |
|
|
const compileJsxToJS = code => Babel.transform(code, {presets: ['react']}).code; // eslint-disable-line no-undef
|
|
|
Babel.transform(code, {presets: ['react']}).code; // eslint-disable-line no-undef
|
|
|
|
|
|
|
|
|
|
|
|
const prism = code => highlight(code, languages.javascript); |
|
|
const prism = code => highlight(code, languages.javascript); |
|
|
|
|
|
|
|
@ -119,13 +118,23 @@ class CodeEditor extends Component { |
|
|
background: colors.darker, |
|
|
background: colors.darker, |
|
|
color: colors.white, |
|
|
color: colors.white, |
|
|
}}> |
|
|
}}> |
|
|
<MetaTitle onDark={true}>Live JSX Editor |
|
|
<MetaTitle onDark={true}> |
|
|
|
|
|
Live JSX Editor |
|
|
{!showCompiledJsx && ( |
|
|
{!showCompiledJsx && ( |
|
|
<a css={{cursor: 'pointer'}} onClick={this._showCompiledJsxPreview.bind(this)}> |
|
|
<a |
|
|
View Compiled JSX</a> |
|
|
role="button" |
|
|
|
|
|
tabIndex="0" |
|
|
|
|
|
css={{cursor: 'pointer'}} |
|
|
|
|
|
onClick={this._showCompiledJsxPreview.bind(this)}> |
|
|
|
|
|
View Compiled JSX |
|
|
|
|
|
</a> |
|
|
)} |
|
|
)} |
|
|
{showCompiledJsx && ( |
|
|
{showCompiledJsx && ( |
|
|
<a css={{cursor: 'pointer'}} onClick={this._hideCompiledJsxPreview.bind(this)}> |
|
|
<a |
|
|
|
|
|
css={{cursor: 'pointer'}} |
|
|
|
|
|
role="button" |
|
|
|
|
|
tabIndex="0" |
|
|
|
|
|
onClick={this._hideCompiledJsxPreview.bind(this)}> |
|
|
Back to JSX Editor |
|
|
Back to JSX Editor |
|
|
</a> |
|
|
</a> |
|
|
)} |
|
|
)} |
|
@ -156,12 +165,13 @@ class CodeEditor extends Component { |
|
|
}, |
|
|
}, |
|
|
}} |
|
|
}} |
|
|
className="gatsby-highlight"> |
|
|
className="gatsby-highlight"> |
|
|
{!showCompiledJsx && ( |
|
|
{!showCompiledJsx && <LiveEditor onChange={this._onChange} />} |
|
|
<LiveEditor onChange={this._onChange} /> |
|
|
|
|
|
)} |
|
|
|
|
|
{showCompiledJsx && ( |
|
|
{showCompiledJsx && ( |
|
|
<pre className="prism-code" spellCheck="false" dangerouslySetInnerHTML={{__html: prism(compiledJsx)}}> |
|
|
<pre |
|
|
</pre> |
|
|
className="prism-code" |
|
|
|
|
|
spellCheck="false" |
|
|
|
|
|
dangerouslySetInnerHTML={{__html: prism(compiledJsx)}} |
|
|
|
|
|
/> |
|
|
)} |
|
|
)} |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|