computer-scienceangular-roadmapbackend-roadmapblockchain-roadmapdba-roadmapdeveloper-roadmapdevops-roadmapfrontend-roadmapgo-roadmaphactoberfestjava-roadmapjavascript-roadmapnodejs-roadmappython-roadmapqa-roadmapreact-roadmaproadmapstudy-planvue-roadmapweb3-roadmap
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
105 lines
2.5 KiB
105 lines
2.5 KiB
const path = require('path'); |
|
const glob = require('glob'); |
|
const fs = require('fs'); |
|
|
|
const roadmaps = require('../storage/roadmaps.json'); |
|
const guides = require('../storage/guides.json'); |
|
|
|
const PAGES_PATH = path.join(__dirname, '../pages'); |
|
const ROADMAPS_PATH = path.join(__dirname, '../storage/roadmaps'); |
|
|
|
/** |
|
* Generate the page routes from the page files inside `/pages` |
|
* directory. Gives the format understood by next |
|
* { |
|
* '/slug': { page: '/path/to-file' } |
|
* } |
|
*/ |
|
const getPageRoutes = () => { |
|
const files = glob.sync(`${PAGES_PATH}/**/*.js`, { |
|
ignore: [ |
|
'**/_*.js', // private non-page files e.g. _document.js |
|
'**/[[]*[]].js', // Ignore dynamic pages i.e. `page/[something].js` files |
|
'**/[[]*[]]/*.js', // Ignore files inside dynamic pages i.e. `[something]/abc.js` |
|
], |
|
}); |
|
|
|
const pageRoutes = {}; |
|
files.forEach(file => { |
|
const pageName = file.replace(PAGES_PATH, '').replace('.js', ''); |
|
const pagePath = pageName.replace('/index', '') || '/'; |
|
|
|
pageRoutes[pagePath] = { page: `${pageName}` } |
|
}); |
|
|
|
return pageRoutes; |
|
}; |
|
|
|
/** |
|
* Generates routes for guide pages |
|
* @returns {*} |
|
*/ |
|
const getGuideRoutes = () => { |
|
return guides.reduce((acc, guide) => { |
|
const [, , slug] = guide.url.split('/'); |
|
return { |
|
...acc, |
|
[guide.url]: { |
|
page: '/guides/[guide]', |
|
query: slug, |
|
}, |
|
}; |
|
}, {}); |
|
}; |
|
|
|
/** |
|
* Generates routes for each of the roadmap and it's respective versions |
|
* @returns {*} |
|
*/ |
|
const getRoadmapRoutes = () => { |
|
return roadmaps.reduce((roadmapRoutes, roadmap) => { |
|
const pages = Object.values(roadmap.sidebar || {}) |
|
.reduce((acc, menuPages) => { |
|
return [ |
|
...acc, |
|
...menuPages |
|
] |
|
}, []); |
|
|
|
return { |
|
...roadmapRoutes, |
|
// Default roadmap path i.e. `{ '/frontend': { page: '/[roadmap]', query: 'frontend' }` |
|
[roadmap.url]: { |
|
page: '/[roadmap]', |
|
query: roadmap.url.replace(/\/+/, ''), |
|
}, |
|
// Routes for all the pages inside this directory |
|
...pages.reduce((pageRoutes, page) => { |
|
return { |
|
...pageRoutes, |
|
[page.url]: { |
|
page: '/[roadmap]/[page]', |
|
query: page.url.replace(/^\//, '') |
|
} |
|
}; |
|
}, {}) |
|
}; |
|
}, {}); |
|
}; |
|
|
|
/** |
|
* Generates the path-map understood by next.js |
|
* @returns {{}} |
|
*/ |
|
const getPathMap = () => () => ({ |
|
...getPageRoutes(), |
|
...getGuideRoutes(), |
|
...getRoadmapRoutes(), |
|
}); |
|
|
|
module.exports = { |
|
getPageRoutes, |
|
getGuideRoutes, |
|
getRoadmapRoutes, |
|
getPathMap, |
|
};
|
|
|