Files
30-seconds-of-code/scripts/glossary/library.js
2018-11-10 14:55:31 +02:00

60 lines
1.8 KiB
JavaScript

/*
This is the "librarian" script that generates the glossary/README file.
Run using `npm run glossary:librarian`.
*/
const fs = require('fs-extra');
const chalk = require('chalk');
const util = require('../util');
const glossaryFiles = util.getFilesInDir('./glossary', true, ['keyword_database', 'README.md']);
const fileTitles = [];
const getGlossaryTermMarkdownBlock = fileName => {
let fileContent = fs.readFileSync(fileName, 'utf8');
let title = fileContent
.match(/###[^\n]*/)[0]
.replace('### ', '')
.trim();
// let description = fileContent.replace(title, '').trim();
fileTitles.push(title);
return fileContent.trim() + '\n';
};
const glossaryFilesContentReducer = (accumulator, currentFilename) => {
// handle first array item
if (accumulator === glossaryFiles[0]) {
return (
getGlossaryTermMarkdownBlock(accumulator) +
'\n' +
getGlossaryTermMarkdownBlock(currentFilename)
);
}
return accumulator + '\n' + getGlossaryTermMarkdownBlock(currentFilename);
};
const getTermLinkMarkdownBlock = termTitle => {
let anchor = util.getMarkDownAnchor(termTitle);
return `* [\`${termTitle}\`](#${anchor})` + '\n';
};
const glossaryTableOfContentsReducer = (accumulator, currentFile) => {
if (accumulator === fileTitles[0])
return getTermLinkMarkdownBlock(accumulator) + getTermLinkMarkdownBlock(currentFile);
return accumulator + getTermLinkMarkdownBlock(currentFile);
};
try {
const fileContents = glossaryFiles.reduce(glossaryFilesContentReducer);
const TOC = '## Table of Contents\n\n' + fileTitles.reduce(glossaryTableOfContentsReducer);
const README = '# 30-seconds-of-code JavaScript Glossary\n\n' + TOC + '\n\n' + fileContents;
fs.writeFileSync('glossary/README.md', README);
} catch (err) {
console.log(`${chalk.red('ERROR!')} During glossary README generation: ${err}`);
process.exit(1);
}