From 35a1e96ca2e0e90a0225e0a7902bb776afc16946 Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Sun, 1 Aug 2021 20:42:11 +0300 Subject: [PATCH] Update update-readme.js --- scripts/update-readme.js | 78 ++++++++++++++++++++++++++-------------- 1 file changed, 52 insertions(+), 26 deletions(-) diff --git a/scripts/update-readme.js b/scripts/update-readme.js index 3f20e0a73..e4a96489c 100644 --- a/scripts/update-readme.js +++ b/scripts/update-readme.js @@ -1,20 +1,25 @@ -const utils = require('./utils') -const db = require('./db') -const parser = require('./parser') - -db.load() - -function main() { - start() +const utils = require('./helpers/utils') +const file = require('./helpers/file') +const log = require('./helpers/log') +const db = require('./helpers/db') + +async function main() { + log.start() + await loadDatabase() generateCategoriesTable() generateCountriesTable() generateLanguagesTable() generateReadme() - finish() + log.finish() +} + +async function loadDatabase() { + log.print('Loading database...\n') + await db.load() } function generateCategoriesTable() { - console.log(`Generating categories table...`) + log.print('Generating categories table...\n') const categories = [] for (const category of [...db.categories.all(), { name: 'Other', id: 'other' }]) { @@ -25,7 +30,7 @@ function generateCategoriesTable() { }) } - const table = utils.generateTable(categories, { + const table = generateTable(categories, { columns: [ { name: 'Category', align: 'left' }, { name: 'Channels', align: 'right' }, @@ -33,11 +38,11 @@ function generateCategoriesTable() { ] }) - utils.createFile('./.readme/_categories.md', table) + file.create('./.readme/_categories.md', table) } function generateCountriesTable() { - console.log(`Generating countries table...`) + log.print('Generating countries table...\n') const countries = [] for (const country of [ @@ -53,7 +58,7 @@ function generateCountriesTable() { }) } - const table = utils.generateTable(countries, { + const table = generateTable(countries, { columns: [ { name: 'Country', align: 'left' }, { name: 'Channels', align: 'right' }, @@ -61,11 +66,11 @@ function generateCountriesTable() { ] }) - utils.createFile('./.readme/_countries.md', table) + file.create('./.readme/_countries.md', table) } function generateLanguagesTable() { - console.log(`Generating languages table...`) + log.print('Generating languages table...\n') const languages = [] for (const language of [ @@ -79,7 +84,7 @@ function generateLanguagesTable() { }) } - const table = utils.generateTable(languages, { + const table = generateTable(languages, { columns: [ { name: 'Language', align: 'left' }, { name: 'Channels', align: 'right' }, @@ -87,20 +92,41 @@ function generateLanguagesTable() { ] }) - utils.createFile('./.readme/_languages.md', table) + file.create('./.readme/_languages.md', table) } -function generateReadme() { - console.log(`Generating README.md...`) - utils.compileMarkdown('../.readme/config.json') -} +function generateTable(data, options) { + let output = '\n' -function start() { - console.log(`Starting...`) + output += '\t\n\t\t' + for (let column of options.columns) { + output += `` + } + output += '\n\t\n' + + output += '\t\n' + for (let item of data) { + output += '\t\t' + let i = 0 + for (let prop in item) { + const column = options.columns[i] + let nowrap = column.nowrap + let align = column.align + output += `` + i++ + } + output += '\n' + } + output += '\t\n' + + output += '
${column.name}
${item[prop]}
' + + return output } -function finish() { - console.log(`Done.`) +function generateReadme() { + log.print('Generating README.md...\n') + file.compileMarkdown('.readme/config.json') } main()