|
|
|
const fm = require('gray-matter');
|
|
|
|
const path = require('path');
|
|
|
|
|
|
|
|
// Makes mdx in next.js suck less by injecting necessary exports so that
|
|
|
|
// the docs are still readable on github.
|
|
|
|
//
|
|
|
|
// Layout component for a .mdx or .md page can be specfied in the frontmatter.
|
|
|
|
// This plugin assumes that the layout file and named export are the same. This
|
|
|
|
// easily changed by modifying the string below.
|
|
|
|
//
|
|
|
|
// All metadata can be written in yaml front matter. It will be passed to the
|
|
|
|
// layout component as `meta` prop.
|
|
|
|
//
|
|
|
|
// (Shamelessly stolen from Expo.io docs)
|
|
|
|
// @see https://github.com/expo/expo/blob/master/docs/common/md-loader.js
|
|
|
|
module.exports = async function (src) {
|
|
|
|
const callback = this.async();
|
|
|
|
const {content, data} = fm(src);
|
|
|
|
const pageParentDir = path
|
|
|
|
.dirname(path.relative('./src/pages', this.resourcePath))
|
|
|
|
.split(path.sep)
|
|
|
|
.shift();
|
|
|
|
const layoutMap = {
|
|
|
|
blog: 'Post',
|
|
|
|
learn: 'Learn',
|
|
|
|
apis: 'API',
|
|
|
|
};
|
|
|
|
const layout = layoutMap[pageParentDir] || 'Home';
|
|
|
|
const code =
|
|
|
|
`import withLayout from 'components/Layout/Layout${layout}';
|
|
|
|
|
|
|
|
export default withLayout(${JSON.stringify(data)})
|
|
|
|
|
|
|
|
|
|
|
|
` + content;
|
|
|
|
|
|
|
|
return callback(null, code);
|
|
|
|
};
|