Browse Source

render simple placeholder while Babel loads

main
renanpvaz 7 years ago
parent
commit
36e1185fde
  1. 1
      src/components/CodeEditor/CodeEditor.js
  2. 2
      src/layouts/index.js
  3. 2
      src/site-constants.js
  4. 25
      src/templates/home.js

1
src/components/CodeEditor/CodeEditor.js

@ -134,7 +134,6 @@ class CodeEditor extends Component {
marginBottom: '0 !important', marginBottom: '0 !important',
}, },
'& pre.prism-code[contenteditable]': { '& pre.prism-code[contenteditable]': {
outline: 0, outline: 0,
overflow: 'auto', overflow: 'auto',

2
src/layouts/index.js

@ -19,8 +19,6 @@ import Flex from 'components/Flex';
import Footer from 'components/LayoutFooter'; import Footer from 'components/LayoutFooter';
import Header from 'components/LayoutHeader'; import Header from 'components/LayoutHeader';
import {media} from 'theme'; import {media} from 'theme';
import loadScript from 'utils/loadScript';
import {algoliaURL} from 'site-constants';
// Import global styles // Import global styles
import '../prism-styles'; import '../prism-styles';

2
src/site-constants.js

@ -16,4 +16,4 @@ const urlRoot = 'https://reactjs.org';
const version = '16.0.0'; const version = '16.0.0';
const babelURL = '//unpkg.com/babel-standalone@6.26.0/babel.min.js'; const babelURL = '//unpkg.com/babel-standalone@6.26.0/babel.min.js';
export {urlRoot, version, babelURL,}; export {urlRoot, version, babelURL};

25
src/templates/home.js

@ -20,9 +20,15 @@ import {colors, media, sharedStyles} from 'theme';
import createOgUrl from 'utils/createOgUrl'; import createOgUrl from 'utils/createOgUrl';
import loadScript from 'utils/loadScript'; import loadScript from 'utils/loadScript';
import {babelURL} from 'site-constants'; import {babelURL} from 'site-constants';
import ReactDOM from 'react-dom';
class Home extends Component { class Home extends Component {
componentDidMount() { componentDidMount() {
this.renderExamplePlaceholder('helloExample');
this.renderExamplePlaceholder('timerExample');
this.renderExamplePlaceholder('todoExample');
this.renderExamplePlaceholder('markdownExample');
loadScript(babelURL).then(() => { loadScript(babelURL).then(() => {
mountCodeExample('helloExample', HELLO_COMPONENT); mountCodeExample('helloExample', HELLO_COMPONENT);
mountCodeExample('timerExample', TIMER_COMPONENT); mountCodeExample('timerExample', TIMER_COMPONENT);
@ -31,6 +37,25 @@ class Home extends Component {
}); });
} }
renderExamplePlaceholder(containerId) {
ReactDOM.render(
<strong
css={{
transform: 'translate(65%, -5em)',
display: 'block',
[media.lessThan('xlarge')]: {
transform: 'none',
marginTop: 15,
textAlign: 'center',
},
}}>
Loading code example...
</strong>,
document.getElementById(containerId),
);
}
render() { render() {
const {data} = this.props; const {data} = this.props;
const title = 'React - A JavaScript library for building user interfaces'; const title = 'React - A JavaScript library for building user interfaces';

Loading…
Cancel
Save