-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathhtmlList.js
83 lines (69 loc) · 2.94 KB
/
htmlList.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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
const fs = require("fs");
const Constants = require("./htmlConstants.js");
let newRawData = Constants.rawData;
const writeFile = (lang, langValues, page, defaultHead, metaTags, defaultNav, nav4, defaultFooter) => {
let writeStream = fs.createWriteStream(`${lang}/${page}.html`);
defaultHead.forEach((heads) => {
writeStream.write(heads);
});
metaTags.forEach((tags) => {
writeStream.write(tags);
});
defaultNav.forEach((navs) => {
writeStream.write(navs);
});
writeStream.write(`<h1 class='truncate'>${langValues[page]}</h1>`);
nav4.forEach((navs) => {
writeStream.write(navs);
});
function getNum(value) {
if (lang === "ar") {
// Arabic
value = value.toString().replace(/\./g, "٫");
var id = ["٠", "١", "٢", "٣", "٤", "٥", "٦", "٧", "٨", "٩"];
return value.toString().replace(/[0-9]/g, function (w) {
return id[+w];
});
} else if (lang === "fa") {
// Persian
value = value.toString().replace(/\./g, "٫");
var id = ["۰", "۱", "۲", "۳", "۴", "۵", "۶", "۷", "۸", "۹"];
return value.toString().replace(/[0-9]/g, function (w) {
return id[+w];
});
} else return value;
}
writeStream.write("<div class='content-wrapper'>");
writeStream.write("<div class='container'>");
writeStream.write("<div class='row'>");
writeStream.write("<div id='mainList'>");
writeStream.write("<div class='listButtons'>");
writeStream.write(`<input class='search' id='searchText' placeholder='${langValues.search}' aria-label='${langValues.search}' />`);
writeStream.write(`<button class='sort' data-sort='listNum' onclick='sortByNumber()'>${langValues.sortNumber}<span id='sortNum' /></button>`);
writeStream.write(`<button class='sort' data-sort='listName' onclick='sortByName()'>${langValues.sortName}<span id='sortNm' /></button>`);
writeStream.write(`<button class='sort' data-sort='listSym' onclick='sortBySymbol()'>${langValues.sortSymbol}<span id='sortSym' /></button>`);
writeStream.write("</div>");
writeStream.write("<div class='list text-center listGrid'>");
newRawData.forEach((element) => {
writeStream.write(`<a class='elementList list-content flex' href='element-${element.num}'>`);
writeStream.write(`<div class='listSym'>${element.sym}</div>`);
writeStream.write(`<div class='listName'>${langValues[element.nme]}</div>`);
writeStream.write(`<div class='listNum'><span>${getNum(element.num)}</span></div>`);
writeStream.write("</a>");
});
writeStream.write("</div>");
writeStream.write("</div>");
writeStream.write("</div>");
writeStream.write("</div>");
writeStream.write("</div>");
defaultFooter.forEach((footers) => {
writeStream.write(footers);
});
// the finish event is emitted when all data has been flushed from the stream
writeStream.on("finish", () => {
console.log(`Created ${lang}-${page}`);
});
// close the stream
writeStream.end();
};
exports.writeFile = writeFile;