import { HTMLTable, HTMLTableItem, LogParser, LogItem, HTMLTableColumn } from '../core' import { Storage, File } from '@freearhey/storage-js' import { LOGS_DIR, README_DIR } from '../constants' import { Collection } from '@freearhey/core' import * as sdk from '@iptv-org/sdk' import { Table } from './table' import { data } from '../api' export class CategoriesTable implements Table { async create() { const parser = new LogParser() const logsStorage = new Storage(LOGS_DIR) const generatorsLog = await logsStorage.load('generators.log') let items = new Collection() parser .parse(generatorsLog) .filter((logItem: LogItem) => logItem.type === 'category') .forEach((logItem: LogItem) => { if (logItem.filepath.includes('undefined')) { items.add([ 'ZZ', 'Undefined', logItem.count.toString(), `https://iptv-org.github.io/iptv/${logItem.filepath}` ]) return } const file = new File(logItem.filepath) const categoryId = file.name() const category: sdk.Models.Category | undefined = data.categoriesKeyById.get(categoryId) if (!category) return items.add([ category.name, category.name, logItem.count.toString(), `https://iptv-org.github.io/iptv/${logItem.filepath}` ]) }) items = items .sortBy(item => item[0]) .map(item => { item.shift() return item }) const columns = new Collection([ { name: 'Category' }, { name: 'Channels', align: 'right' }, { name: 'Playlist', nowrap: true } ]) const table = new HTMLTable(items, columns) const readmeStorage = new Storage(README_DIR) await readmeStorage.save('_categories.md', table.toString()) } }