diff --git a/docs/react-style-guide.md b/docs/react-style-guide.md
index 280641a66d..745b45d3f1 100644
--- a/docs/react-style-guide.md
+++ b/docs/react-style-guide.md
@@ -6,21 +6,21 @@
### Table of Contents
-* [Separate folder per UI component](#separate-folder-per-ui-component)
-* [Prefer using functional components](#prefer-using-functional-components)
-* [Use CSS Modules](#use-css-modules)
-* [Use higher-order components](#use-higher-order-components)
+- [Separate folder per UI component](#separate-folder-per-ui-component)
+- [Prefer using functional components](#prefer-using-functional-components)
+- [Use CSS Modules](#use-css-modules)
+- [Use higher-order components](#use-higher-order-components)
### Separate folder per UI component
-* Place each major UI component along with its resources in a separate folder\
+- Place each major UI component along with its resources in a separate folder\
This will make it easier to find related resources for any particular UI element
(CSS, images, unit tests, localization files etc.). Removing such components during
refactorings should also be easy.
-* Avoid having CSS, images and other resource files shared between multiple
+- Avoid having CSS, images and other resource files shared between multiple
components.\
This will make your code more maintainable, easy to refactor.
-* Add `package.json` file into each component's folder.\
+- Add `package.json` file into each component's folder.\
This will allow to easily reference such components from other places in your code.\
Use `import Nav from '../Navigation'` instead of `import Nav from '../Navigation/Navigation.js'`
@@ -46,7 +46,7 @@ For more information google for
### Prefer using functional components
-* Prefer using stateless functional components whenever possible.\
+- Prefer using stateless functional components whenever possible.\
Components that don't use state are better to be written as simple pure functions.
```jsx
@@ -69,16 +69,16 @@ Navigation.propTypes = { items: PropTypes.array.isRequired };
### Use CSS Modules
-* Use CSS Modules\
+- Use CSS Modules\
This will allow using short CSS class names and at the same time avoid conflicts.
-* Keep CSS simple and declarative. Avoid loops, mixins etc.
-* Feel free to use variables in CSS via
+- Keep CSS simple and declarative. Avoid loops, mixins etc.
+- Feel free to use variables in CSS via
[precss](https://github.com/jonathantneal/precss) plugin for
[PostCSS](https://github.com/postcss/postcss)
-* Prefer CSS class selectors instead of element and `id` selectors (see
+- Prefer CSS class selectors instead of element and `id` selectors (see
[BEM](https://bem.info/))
-* Avoid nested CSS selectors (see [BEM](https://bem.info/))
-* When in doubt, use `.root { }` class name for the root elements of your
+- Avoid nested CSS selectors (see [BEM](https://bem.info/))
+- When in doubt, use `.root { }` class name for the root elements of your
components
```scss
@@ -127,7 +127,7 @@ Navigation.propTypes = { items: PropTypes.array.isRequired };
// Navigation.js
import React from 'react';
import PropTypes from 'prop-types';
-import withStyles from 'isomorphic-style-loader/lib/withStyles';
+import withStyles from 'isomorphic-style-loader/withStyles';
import s from './Navigation.scss';
function Navigation() {
@@ -156,7 +156,7 @@ export default withStyles(Navigation, s);
### Use higher-order components
-* Use higher-order components (HOC) to extend existing React components.\
+- Use higher-order components (HOC) to extend existing React components.\
Here is an example:
```js
diff --git a/src/client.js b/src/client.js
index a6234d95d7..4b0a7b6fba 100644
--- a/src/client.js
+++ b/src/client.js
@@ -19,18 +19,19 @@ import history from './history';
import { updateMeta } from './DOMUtils';
import router from './router';
+// Enables critical path CSS rendering
+// https://github.com/kriasoft/isomorphic-style-loader
+const insertCss = (...styles) => {
+ // eslint-disable-next-line no-underscore-dangle
+ const removeCss = styles.map(x => x._insertCss());
+ return () => {
+ removeCss.forEach(f => f());
+ };
+};
+
// Global (context) variables that can be easily accessed from any React component
// https://facebook.github.io/react/docs/context.html
const context = {
- // Enables critical path CSS rendering
- // https://github.com/kriasoft/isomorphic-style-loader
- insertCss: (...styles) => {
- // eslint-disable-next-line no-underscore-dangle
- const removeCss = styles.map(x => x._insertCss());
- return () => {
- removeCss.forEach(f => f());
- };
- },
// Universal HTTP client
fetch: createFetch(fetch, {
baseUrl: window.App.apiUrl,
@@ -78,7 +79,9 @@ async function onLocationChange(location, action) {
const renderReactApp = isInitialRender ? ReactDOM.hydrate : ReactDOM.render;
appInstance = renderReactApp(
- {route.component},
+
+ {route.component}
+ ,
container,
() => {
if (isInitialRender) {
diff --git a/src/components/App.js b/src/components/App.js
index f20711f262..651438ed7e 100644
--- a/src/components/App.js
+++ b/src/components/App.js
@@ -10,10 +10,10 @@
import React from 'react';
import PropTypes from 'prop-types';
+import StyleContext from 'isomorphic-style-loader/StyleContext';
+import ApplicationContext from './ApplicationContext';
+
const ContextType = {
- // Enables critical path CSS rendering
- // https://github.com/kriasoft/isomorphic-style-loader
- insertCss: PropTypes.func.isRequired,
// Universal HTTP client
fetch: PropTypes.func.isRequired,
pathname: PropTypes.string.isRequired,
@@ -44,20 +44,25 @@ const ContextType = {
*/
class App extends React.PureComponent {
static propTypes = {
+ // Enables critical path CSS rendering
+ // https://github.com/kriasoft/isomorphic-style-loader
+ insertCss: PropTypes.func.isRequired,
context: PropTypes.shape(ContextType).isRequired,
children: PropTypes.element.isRequired,
};
- static childContextTypes = ContextType;
-
- getChildContext() {
- return this.props.context;
- }
-
render() {
+ const { context, insertCss } = this.props;
+
// NOTE: If you need to add or modify header, footer etc. of the app,
// please do that inside the Layout component.
- return React.Children.only(this.props.children);
+ return (
+
+
+ {React.Children.only(this.props.children)}
+
+
+ );
}
}
diff --git a/src/components/ApplicationContext.js b/src/components/ApplicationContext.js
new file mode 100644
index 0000000000..beb4844f5a
--- /dev/null
+++ b/src/components/ApplicationContext.js
@@ -0,0 +1,9 @@
+import React from 'react';
+
+const ApplicationContext = React.createContext({
+ fetch: () => {
+ throw new Error('Fetch method not initialized.');
+ },
+});
+
+export default ApplicationContext;
diff --git a/src/components/Feedback/Feedback.js b/src/components/Feedback/Feedback.js
index 6c9712493a..c22042aaca 100644
--- a/src/components/Feedback/Feedback.js
+++ b/src/components/Feedback/Feedback.js
@@ -8,7 +8,7 @@
*/
import React from 'react';
-import withStyles from 'isomorphic-style-loader/lib/withStyles';
+import withStyles from 'isomorphic-style-loader/withStyles';
import s from './Feedback.css';
class Feedback extends React.Component {
diff --git a/src/components/Footer/Footer.js b/src/components/Footer/Footer.js
index 5b6cc5de9c..b861410c73 100644
--- a/src/components/Footer/Footer.js
+++ b/src/components/Footer/Footer.js
@@ -8,7 +8,7 @@
*/
import React from 'react';
-import withStyles from 'isomorphic-style-loader/lib/withStyles';
+import withStyles from 'isomorphic-style-loader/withStyles';
import s from './Footer.css';
import Link from '../Link';
diff --git a/src/components/Header/Header.js b/src/components/Header/Header.js
index 13a48096d9..cfcb83745a 100644
--- a/src/components/Header/Header.js
+++ b/src/components/Header/Header.js
@@ -8,7 +8,7 @@
*/
import React from 'react';
-import withStyles from 'isomorphic-style-loader/lib/withStyles';
+import withStyles from 'isomorphic-style-loader/withStyles';
import s from './Header.css';
import Link from '../Link';
import Navigation from '../Navigation';
diff --git a/src/components/Layout/Layout.js b/src/components/Layout/Layout.js
index 6c88b352ea..05b8d957e1 100644
--- a/src/components/Layout/Layout.js
+++ b/src/components/Layout/Layout.js
@@ -9,7 +9,7 @@
import React from 'react';
import PropTypes from 'prop-types';
-import withStyles from 'isomorphic-style-loader/lib/withStyles';
+import withStyles from 'isomorphic-style-loader/withStyles';
// external-global styles must be imported in your JS.
import normalizeCss from 'normalize.css';
diff --git a/src/components/Navigation/Navigation.js b/src/components/Navigation/Navigation.js
index 56a1a78255..97fd0f7d38 100644
--- a/src/components/Navigation/Navigation.js
+++ b/src/components/Navigation/Navigation.js
@@ -9,7 +9,7 @@
import React from 'react';
import cx from 'classnames';
-import withStyles from 'isomorphic-style-loader/lib/withStyles';
+import withStyles from 'isomorphic-style-loader/withStyles';
import s from './Navigation.css';
import Link from '../Link';
diff --git a/src/components/Page/Page.js b/src/components/Page/Page.js
index 291cfbffda..55ab20c9a5 100644
--- a/src/components/Page/Page.js
+++ b/src/components/Page/Page.js
@@ -9,7 +9,7 @@
import React from 'react';
import PropTypes from 'prop-types';
-import withStyles from 'isomorphic-style-loader/lib/withStyles';
+import withStyles from 'isomorphic-style-loader/withStyles';
import s from './Page.css';
class Page extends React.Component {
diff --git a/src/routes/admin/Admin.js b/src/routes/admin/Admin.js
index c297754294..1328838339 100644
--- a/src/routes/admin/Admin.js
+++ b/src/routes/admin/Admin.js
@@ -9,7 +9,7 @@
import React from 'react';
import PropTypes from 'prop-types';
-import withStyles from 'isomorphic-style-loader/lib/withStyles';
+import withStyles from 'isomorphic-style-loader/withStyles';
import s from './Admin.css';
class Admin extends React.Component {
diff --git a/src/routes/contact/Contact.js b/src/routes/contact/Contact.js
index 5c8f398ab4..923749a54f 100644
--- a/src/routes/contact/Contact.js
+++ b/src/routes/contact/Contact.js
@@ -9,7 +9,7 @@
import React from 'react';
import PropTypes from 'prop-types';
-import withStyles from 'isomorphic-style-loader/lib/withStyles';
+import withStyles from 'isomorphic-style-loader/withStyles';
import s from './Contact.css';
class Contact extends React.Component {
diff --git a/src/routes/error/ErrorPage.js b/src/routes/error/ErrorPage.js
index aff9d07947..59bca0f41d 100644
--- a/src/routes/error/ErrorPage.js
+++ b/src/routes/error/ErrorPage.js
@@ -9,7 +9,7 @@
import React from 'react';
import PropTypes from 'prop-types';
-import withStyles from 'isomorphic-style-loader/lib/withStyles';
+import withStyles from 'isomorphic-style-loader/withStyles';
import s from './ErrorPage.css';
class ErrorPage extends React.Component {
diff --git a/src/routes/home/Home.js b/src/routes/home/Home.js
index c4e4b8f605..7c89ffaa6e 100644
--- a/src/routes/home/Home.js
+++ b/src/routes/home/Home.js
@@ -9,7 +9,7 @@
import React from 'react';
import PropTypes from 'prop-types';
-import withStyles from 'isomorphic-style-loader/lib/withStyles';
+import withStyles from 'isomorphic-style-loader/withStyles';
import s from './Home.css';
class Home extends React.Component {
diff --git a/src/routes/login/Login.js b/src/routes/login/Login.js
index 852919ce4f..5991f44ae5 100644
--- a/src/routes/login/Login.js
+++ b/src/routes/login/Login.js
@@ -9,7 +9,7 @@
import React from 'react';
import PropTypes from 'prop-types';
-import withStyles from 'isomorphic-style-loader/lib/withStyles';
+import withStyles from 'isomorphic-style-loader/withStyles';
import s from './Login.css';
class Login extends React.Component {
diff --git a/src/routes/not-found/NotFound.js b/src/routes/not-found/NotFound.js
index 437b2ba00c..e6bbf2ec72 100644
--- a/src/routes/not-found/NotFound.js
+++ b/src/routes/not-found/NotFound.js
@@ -9,7 +9,7 @@
import React from 'react';
import PropTypes from 'prop-types';
-import withStyles from 'isomorphic-style-loader/lib/withStyles';
+import withStyles from 'isomorphic-style-loader/withStyles';
import s from './NotFound.css';
class NotFound extends React.Component {
diff --git a/src/routes/register/Register.js b/src/routes/register/Register.js
index 3a5a618099..0a7fc257a7 100644
--- a/src/routes/register/Register.js
+++ b/src/routes/register/Register.js
@@ -9,7 +9,7 @@
import React from 'react';
import PropTypes from 'prop-types';
-import withStyles from 'isomorphic-style-loader/lib/withStyles';
+import withStyles from 'isomorphic-style-loader/withStyles';
import s from './Register.css';
class Register extends React.Component {
diff --git a/src/server.js b/src/server.js
index 2bad532b53..f8143028b0 100644
--- a/src/server.js
+++ b/src/server.js
@@ -143,7 +143,6 @@ app.get('*', async (req, res, next) => {
// Global (context) variables that can be easily accessed from any React component
// https://facebook.github.io/react/docs/context.html
const context = {
- insertCss,
fetch,
// The twins below are wild, be careful!
pathname: req.path,
@@ -159,7 +158,9 @@ app.get('*', async (req, res, next) => {
const data = { ...route };
data.children = ReactDOM.renderToString(
- {route.component},
+
+ {route.component}
+ ,
);
data.styles = [{ id: 'css', cssText: [...css].join('') }];