Skip to content

Commit

Permalink
chore: Compile static html for bootstrapping styleguidist
Browse files Browse the repository at this point in the history
  • Loading branch information
kwltrs committed Feb 19, 2018
1 parent 9da258e commit c35f706
Show file tree
Hide file tree
Showing 4 changed files with 59 additions and 26 deletions.
70 changes: 47 additions & 23 deletions bin/build-content.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,35 +6,38 @@ const marked = require('marked');
const Handlebars = require('handlebars');

const settings = require('../styleguide.content.js');
const styleguidistSettings = require('../styleguide.config.js');

const promisedMap = (arr, cb) => Promise.all(arr.map(cb));

const resolveDir = dir => path.normalize(path.join(__dirname, '..', dir));

require(resolveDir(settings.helpers));

const mkdir = dir => promisify(mkdirp)(resolveDir(dir));

const readFile = promisify(fs.readFile);
const writeFile = promisify(fs.writeFile);

const createReader = relDir => {
const absDir = resolveDir(relDir);
return fname => readFile(path.join(absDir, fname), 'utf8');
};
const dataFromFileInDirReader = dir => fname =>
readFile(path.join(dir, fname), 'utf8');

const createReader = dir => dataFromFileInDirReader(resolveDir(dir));

const dataToFileWriter = file => data =>
writeFile(file, data).then(() => console.log(`Wrote ${file}.`));

const dataToFileInDirWriter = dir => fname =>
dataToFileWriter(path.join(dir, fname));

const createWriter = relDir => dataToFileInDirWriter(resolveDir(relDir));

const createWriter = relDir => {
const absDir = resolveDir(relDir);
return fname => {
const file = path.join(absDir, fname);
return data =>
writeFile(file, data).then(() => console.log(`Wrote ${file}.`));
};
};

const readFromBaseDir = createReader('.');

const readFromContentDir = createReader(settings.contentDir);
const writeToOutputDir = createWriter(settings.outputDir);

const mkDir = dir => promisify(mkdirp)(resolveDir(dir));
const writeToOutputDir = createWriter(settings.outputDir);

const prerenderSections = sectionsDef => {
const getTarget = source =>
Expand Down Expand Up @@ -62,6 +65,16 @@ const getTemplateCompiler = fname =>
.then(template => Handlebars.compile(template))
.then(compile => opts => Promise.resolve(compile(opts)));

const getStyleguidistCompiler = (source, destination) => {
return readFile(resolveDir(source), 'utf8')
.then(template => Handlebars.compile(template))
.then(compile => opts =>
Promise.resolve(compile(opts)).then(
dataToFileWriter(resolveDir(destination)),
),
);
};

const registerPartials = partialsDef =>
promisedMap(Object.entries(partialsDef), ([key, fname]) =>
readFromBaseDir(fname).then(partial =>
Expand All @@ -70,18 +83,29 @@ const registerPartials = partialsDef =>
);

Promise.all([
prerenderSections(settings.sections),
getTemplateCompiler(settings.template),
prerenderSections(settings.sections),
getTemplateCompiler(
settings.template
),
getStyleguidistCompiler(
settings.styleguidistTemplate,
styleguidistSettings.template
),
registerPartials(settings.partials),
mkDir(settings.outputDir),
mkdir(settings.outputDir),
])
.then(([sections, compile]) =>
promisedMap(sections, section =>
compile({
.then(([sections, compile, compileStyleguidist]) =>
Promise.all([
promisedMap(sections, section => compile({
...settings.context,
sections,
section,
}).then(writeToOutputDir(`${section.target}.html`))
),
compileStyleguidist({
...settings.context,
sections,
section,
}).then(writeToOutputDir(`${section.target}.html`)),
),
}),
])
)
.catch(err => console.error(err));
12 changes: 10 additions & 2 deletions src/templates/index.hbs → src/templates/styleguidist.hbs
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,16 @@
<meta name="viewport" content="width=device-width, initial-scale=1.0">
</head>
<body>
{{ header }}
<nav>
<ul>
{{#each sections}}
<li>
<a href="{{this.target}}.html">{{this.name}}</a>
</li>
{{/each}}
</ul>
</nav>

<div id="app"></div>
</body>
</html>
</html>
2 changes: 1 addition & 1 deletion styleguide.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ module.exports = {
],
},
},
template: 'src/templates/index.hbs',
template: 'src/styleguidist.html',
sections: [
{
name: 'Komponenter',
Expand Down
1 change: 1 addition & 0 deletions styleguide.content.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ module.exports = {
section: 'src/templates/section.hbs',
sectionsToc: 'src/templates/sectionsToc.hbs',
},
styleguidistTemplate: 'src/templates/styleguidist.hbs',
context: {
title: 'FFE',
},
Expand Down

0 comments on commit c35f706

Please sign in to comment.