forked from w3f/polkadot-wiki
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmirror.js
47 lines (42 loc) · 1.57 KB
/
mirror.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
/**
* The wiki hosts both the Polkadot Wiki and the Kusama User Guide. This means
* that we can "mirror" the same document between the two. However, due to
* a peculiarity in Docusaurus, when we put the same document into both sub-wikis
* in `website/sidebars.json` only the most recent entry is read.
*
* To solve this, we create an explicit mirror of the document. The process for
* adding content to both wikis is as follows:
*
* 1) Create the source document and put it under the relevant sidebar in the
* Polkadot wiki configuration in `sidebars.json`.
* 2) Add the source document's name to the `mirrored` array below.
* 3) Run `node mirror.js`.
* 4) Add `mirror-DOCUMENT_NAME` to the sidebar for Kusama in `sidebars.json`.
*
*/
const fs = require('fs');
// List of mirrored files that should be in both the Polkadot wiki and the Kusama
// user guide.
const mirrored = [
'build-build-with-polkadot',
'learn-identity',
'learn-governance',
'maintain-guides-how-to-nominate-kusama',
'maintain-guides-how-to-validate-kusama',
];
for (const file of mirrored) {
const doc = 'docs/' + file + '.md';
const mirror = 'docs/mirror-' + file + '.md';
if (!fs.existsSync(doc)) {
throw new Error(`${doc} doesn't exist!`);
}
const content = fs.readFileSync(doc, { encoding: 'utf-8' });
const mirroredContent = content.split('\n').map((line) => {
if (line.startsWith('id:')) {
const [before, after] = line.split(' ');
return before + ' mirror-' + after;
}
else return line;
}).join('\n');
fs.writeFileSync(mirror, mirroredContent);
}