scratch-www/src/lib/render.jsx

62 lines
1.9 KiB
React
Raw Normal View History

2018-01-19 14:06:26 -05:00
const redux = require('redux');
const thunk = require('redux-thunk').default;
// JSX syntax transforms to React.createElement
2018-01-19 14:06:26 -05:00
const React = require('react'); // eslint-disable-line
const ReactDOM = require('react-dom');
const StoreProvider = require('react-redux').Provider;
2018-01-19 14:06:26 -05:00
const IntlProvider = require('./intl.jsx').IntlProvider;
const permissionsActions = require('../redux/permissions.js');
const sessionActions = require('../redux/session.js');
const reducer = require('../redux/reducer.js');
require('../main.scss');
2018-01-19 14:06:26 -05:00
/**
* Function to render views into a full page
* @param {object} jsx jsx component of the view
* @param {object} element html element to render to on the template
* @param {array} reducers list of view-specific reducers
*/
const render = (jsx, element, reducers) => {
// Get locale and messages from global namespace (see "init.js")
2018-01-19 14:06:26 -05:00
let locale = window._locale || 'en';
let messages = {};
if (typeof window._messages !== 'undefined') {
if (typeof window._messages[locale] === 'undefined') {
// Fall back on the split
locale = locale.split('-')[0];
}
if (typeof window._messages[locale] === 'undefined') {
// Language appears to not be supported fall back to 'en'
locale = 'en';
}
messages = window._messages[locale];
}
2018-01-19 14:06:26 -05:00
const allReducers = reducer(reducers);
const store = redux.createStore(
allReducers,
redux.applyMiddleware(thunk)
);
// Render view component
ReactDOM.render(
2016-03-18 11:51:22 -04:00
<StoreProvider store={store}>
2018-01-19 14:06:26 -05:00
<IntlProvider
locale={locale}
messages={messages}
>
2016-03-18 11:51:22 -04:00
{jsx}
</IntlProvider>
</StoreProvider>,
element
);
// Get initial session & permissions
store.dispatch(permissionsActions.getPermissions());
store.dispatch(sessionActions.refreshSession());
};
2015-10-16 15:10:17 -04:00
module.exports = render;