mirror of
https://github.com/strapi/strapi.git
synced 2025-08-02 13:58:18 +00:00
67 lines
1.8 KiB
JavaScript
67 lines
1.8 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); // eslint-disable-line no-unused-vars
|
|
|
|
return [
|
|
{
|
|
path: '/',
|
|
name: 'home',
|
|
getComponent(nextState, cb) {
|
|
const importModules = Promise.all([
|
|
System.import('containers/HomePage'),
|
|
]);
|
|
|
|
const renderRoute = loadModule(cb);
|
|
|
|
importModules.then(([component]) => {
|
|
renderRoute(component);
|
|
});
|
|
|
|
importModules.catch(errorLoading);
|
|
},
|
|
childRoutes: [
|
|
{
|
|
path: '/plugins',
|
|
name: 'plugins',
|
|
getComponent(nextState, cb) {
|
|
const importModules = Promise.all([
|
|
System.import('containers/PluginPage'),
|
|
]);
|
|
|
|
const renderRoute = loadModule(cb);
|
|
|
|
importModules.then(([component]) => {
|
|
renderRoute(component);
|
|
});
|
|
|
|
importModules.catch(errorLoading);
|
|
},
|
|
childRoutes: [],
|
|
},
|
|
],
|
|
}, {
|
|
path: '*',
|
|
name: '404',
|
|
getComponent(nextState, cb) {
|
|
System.import('containers/NotFoundPage')
|
|
.then(loadModule(cb))
|
|
.catch(errorLoading);
|
|
},
|
|
},
|
|
];
|
|
}
|