0
Fork 0
mirror of https://github.com/verdaccio/verdaccio.git synced 2025-01-20 22:52:46 -05:00
verdaccio/website/gatsby-node.js

83 lines
2.1 KiB
JavaScript
Raw Normal View History

/**
* Fix: react-🔥-dom patch is not detected.
* https://github.com/gatsbyjs/gatsby/issues/11934
*/
exports.onCreateWebpackConfig = ({ stage, actions }) => {
if (stage.startsWith('develop')) {
actions.setWebpackConfig({
resolve: {
alias: {
'react-dom': '@hot-loader/react-dom',
},
},
});
}
};
// You can delete this file if you're not using it
const path = require('path');
2020-08-31 22:21:38 +02:00
const docPageTemplate = path.resolve('src/templates/docPage.tsx');
const frontPageTemplate = path.resolve('src/templates/frontpage.tsx');
const sideBar = require('./config/sidebar.json');
2020-08-31 22:21:38 +02:00
exports.createPages = async ({ graphql, actions }) => {
const { createPage } = actions;
2020-08-31 22:21:38 +02:00
const result = await graphql(`
query {
allMarkdownRemark {
edges {
node {
id
frontmatter {
title
id
}
2020-08-31 22:21:38 +02:00
html
fileAbsolutePath
}
2020-08-31 22:21:38 +02:00
}
}
}
`);
const posts = result.data.allMarkdownRemark.edges;
const idTitleMap = {};
const languages = [];
// create documentation pages
2020-08-31 22:21:38 +02:00
posts.forEach(({ node }) => {
console.log('-node.fileAbsolutePath-', node.frontmatter);
2020-08-31 22:21:38 +02:00
const parsedPath = path.parse(node.fileAbsolutePath);
const id = node.id;
const markDownId = node.frontmatter.id;
2020-08-31 22:21:38 +02:00
const name = parsedPath.name;
const title = node.frontmatter.title;
2020-08-31 22:21:38 +02:00
const lng = parsedPath.dir.match('translated_docs') ? parsedPath.dir.split('/').pop() : 'en';
if (!languages.includes(lng)) {
languages.push(lng);
}
if (!idTitleMap[lng]) {
idTitleMap[lng] = {};
}
idTitleMap[lng][markDownId] = title;
2020-08-31 22:21:38 +02:00
createPage({
path: `docs/${lng}/${name}.html`,
component: docPageTemplate,
context: { id, lng, sideBar, title, idTitleMap, markDownId },
2020-08-31 22:21:38 +02:00
});
});
// create index pages
languages.map((language) => {
createPage({
path: language === 'en' ? '/' : `/${language}/index.html`,
component: frontPageTemplate,
context: { id: '', lng: language, sideBar, title: '', idTitleMap, markDownId: '/' },
});
});
};