docusaurus/lib/version.js
Joel Marcey 1388e13795
Don't throw if a doc hasn't been versioned yet (#455)
Instead of throwing, return `null` because that means we have a
new doc in our versioning sequence

(Also, cleaned up a bit of code as I researched this)

Partial Fix To #450
2018-02-16 19:16:38 -08:00

139 lines
3.6 KiB
JavaScript
Executable file

#!/usr/bin/env node
/**
* Copyright (c) 2017-present, Facebook, Inc.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
const glob = require('glob');
const fs = require('fs-extra');
const path = require('path');
const mkdirp = require('mkdirp');
const chalk = require('chalk');
const readMetadata = require('./server/readMetadata.js');
const versionFallback = require('./server/versionFallback.js');
const CWD = process.cwd();
let versions;
if (fs.existsSync(CWD + '/versions.json')) {
versions = require(CWD + '/versions.json');
} else {
versions = [];
}
let version;
const program = require('commander');
program
.arguments('<version>')
.action(ver => {
version = ver;
})
.parse(process.argv);
if (typeof version === 'undefined') {
console.error(
`${chalk.yellow(
'No version number specified!'
)}\nPass the version you wish to create as an argument.\nEx: 1.0.0`
);
process.exit(1);
}
if (versions.includes(version)) {
console.error(
`${chalk.yellow(
'This version already exists!'
)}\nSpecify a new version to create that does not already exist.`
);
process.exit(1);
}
function makeHeader(metadata) {
let header = '---\n';
Object.keys(metadata).forEach(key => {
header += key + ': ' + metadata[key] + '\n';
});
header += '---\n';
return header;
}
const versionFolder = CWD + '/versioned_docs/version-' + version;
mkdirp.sync(versionFolder);
// copy necessary files to new version, changing some of its metadata to reflect the versioning
let files = glob.sync(CWD + '/../' + readMetadata.getDocsPath() + '/*');
files.forEach(file => {
const ext = path.extname(file);
if (ext !== '.md' && ext !== '.markdown') {
return;
}
const res = readMetadata.extractMetadata(fs.readFileSync(file, 'utf8'));
let metadata = res.metadata;
// Don't version any docs without any metadata whatsoever.
if (Object.keys(metadata).length === 0) {
return;
}
let rawContent = res.rawContent;
if (!metadata.id) {
metadata.id = path.basename(file, path.extname(file));
}
if (metadata.id.includes('/')) {
throw new Error('Document id cannot include "/".');
}
if (!metadata.title) {
metadata.title = metadata.id;
}
if (!versionFallback.diffLatestDoc(file, metadata.id)) {
return;
}
metadata.original_id = metadata.id;
metadata.id = 'version-' + version + '-' + metadata.id;
const targetFile = versionFolder + '/' + path.basename(file);
fs.writeFileSync(targetFile, makeHeader(metadata) + rawContent, 'utf8');
});
// copy sidebar if necessary
if (versionFallback.diffLatestSidebar()) {
mkdirp(CWD + '/versioned_sidebars');
const sidebar = JSON.parse(fs.readFileSync(CWD + '/sidebars.json', 'utf8'));
const versioned = {};
Object.keys(sidebar).forEach(sb => {
const version_sb = 'version-' + version + '-' + sb;
versioned[version_sb] = {};
const categories = sidebar[sb];
Object.keys(categories).forEach(category => {
versioned[version_sb][category] = [];
const ids = categories[category];
ids.forEach((id, index) => {
versioned[version_sb][category].push('version-' + version + '-' + id);
});
});
});
fs.writeFileSync(
CWD + '/versioned_sidebars/version-' + version + '-sidebars.json',
JSON.stringify(versioned, null, 2) + '\n',
'utf8'
);
}
// update versions.json file
versions.unshift(version);
fs.writeFileSync(
CWD + '/versions.json',
JSON.stringify(versions, null, 2) + '\n'
);
console.log(`${chalk.green('Version ' + version + ' created!\n')}`);