mirror of
https://github.com/strapi/strapi.git
synced 2025-08-05 07:16:02 +00:00
60 lines
1.7 KiB
JavaScript
60 lines
1.7 KiB
JavaScript
![]() |
// These are the pages you can go to.
|
||
|
// They are all wrapped in the App component, which should contain the navbar etc
|
||
|
// See http://blog.mxstbr.com/2016/01/react-apps-with-pages for more information
|
||
|
// about the code splitting business
|
||
|
import { getAsyncInjectors } from './utils/asyncInjectors';
|
||
|
|
||
|
const errorLoading = (err) => {
|
||
|
console.error('Dynamic page loading failed', err); // eslint-disable-line no-console
|
||
|
};
|
||
|
|
||
|
const loadModule = (cb) => (componentModule) => {
|
||
|
cb(null, componentModule.default);
|
||
|
};
|
||
|
|
||
|
export default function createRoutes(store) {
|
||
|
// create reusable async injectors using getAsyncInjectors factory
|
||
|
const { injectReducer, injectSagas } = getAsyncInjectors(store);
|
||
|
|
||
|
return [
|
||
|
{
|
||
|
path: '/',
|
||
|
name: 'home',
|
||
|
getComponent(nextState, cb) {
|
||
|
const importModules = Promise.all([
|
||
|
System.import('containers/HomePage/reducer'),
|
||
|
System.import('containers/HomePage/sagas'),
|
||
|
System.import('containers/HomePage'),
|
||
|
]);
|
||
|
|
||
|
const renderRoute = loadModule(cb);
|
||
|
|
||
|
importModules.then(([reducer, sagas, component]) => {
|
||
|
injectReducer('home', reducer.default);
|
||
|
injectSagas(sagas.default);
|
||
|
|
||
|
renderRoute(component);
|
||
|
});
|
||
|
|
||
|
importModules.catch(errorLoading);
|
||
|
},
|
||
|
}, {
|
||
|
path: '/features',
|
||
|
name: 'features',
|
||
|
getComponent(nextState, cb) {
|
||
|
System.import('containers/FeaturePage')
|
||
|
.then(loadModule(cb))
|
||
|
.catch(errorLoading);
|
||
|
},
|
||
|
}, {
|
||
|
path: '*',
|
||
|
name: 'notfound',
|
||
|
getComponent(nextState, cb) {
|
||
|
System.import('containers/NotFoundPage')
|
||
|
.then(loadModule(cb))
|
||
|
.catch(errorLoading);
|
||
|
},
|
||
|
},
|
||
|
];
|
||
|
}
|