static-cms/src/bootstrap.js

103 lines
2.4 KiB
JavaScript
Raw Normal View History

import React from 'react';
import { render } from 'react-dom';
import { Provider, connect } from 'react-redux';
2022-09-28 20:04:00 -06:00
import { Router } from 'react-router-dom';
import { I18n } from 'react-polyglot';
2022-09-28 20:04:00 -06:00
import { GlobalStyles } from './ui';
import { store } from './store';
import { history } from './routing/history';
import { loadConfig } from './actions/config';
import { authenticateUser } from './actions/auth';
import { getPhrases } from './lib/phrases';
import { selectLocale } from './reducers/config';
import { ErrorBoundary } from './components/UI';
import App from './components/App/App';
import './components/EditorWidgets';
import './mediaLibrary';
2018-07-06 18:56:28 -04:00
import 'what-input';
const ROOT_ID = 'nc-root';
function TranslatedApp({ locale, config }) {
return (
<I18n locale={locale} messages={getPhrases(locale)}>
<ErrorBoundary showBackup config={config}>
<Router history={history}>
2022-09-28 20:04:00 -06:00
<App />
</Router>
</ErrorBoundary>
</I18n>
);
}
function mapDispatchToProps(state) {
return { locale: selectLocale(state.config), config: state.config };
}
const ConnectedTranslatedApp = connect(mapDispatchToProps)(TranslatedApp);
function bootstrap(opts = {}) {
const { config } = opts;
/**
* Log the version number.
*/
2022-09-30 06:13:47 -06:00
if (typeof SIMPLE_CMS_CORE_VERSION === 'string') {
console.info(`simple-cms-core ${SIMPLE_CMS_CORE_VERSION}`);
}
/**
* Get DOM element where app will mount.
*/
function getRoot() {
/**
* Return existing root if found.
*/
const existingRoot = document.getElementById(ROOT_ID);
if (existingRoot) {
return existingRoot;
}
/**
* If no existing root, create and return a new root.
*/
const newRoot = document.createElement('div');
newRoot.id = ROOT_ID;
document.body.appendChild(newRoot);
return newRoot;
}
/**
* Dispatch config to store if received. This config will be merged into
* config.yml if it exists, and any portion that produces a conflict will be
* overwritten.
*/
store.dispatch(
loadConfig(config, function onLoad() {
store.dispatch(authenticateUser());
}),
);
/**
* Create connected root component.
*/
function Root() {
return (
<>
2022-09-19 21:15:15 -04:00
<GlobalStyles />
<Provider store={store}>
<ConnectedTranslatedApp />
</Provider>
</>
);
}
/**
* Render application root.
*/
render(<Root />, getRoot());
}
export default bootstrap;