Export List of Seeding Torrents

Export list of your currently seeding torrents from TorrentBD.

// ==UserScript==
// @name         Export List of Seeding Torrents
// @namespace    dunno what to put here :|
// @version      1.0
// @description  Export list of your currently seeding torrents from TorrentBD.
// @author       K4K4SH1
// @match        https://*.torrentbd.com/seedbonus-breakdown.php
// @match        https://*.torrentbd.net/seedbonus-breakdown.php
// @match        https://*.torrentbd.me/seedbonus-breakdown.php
// @match        https://*.torrentbd.com/activities.php
// @match        https://*.torrentbd.net/activities.php
// @match        https://*.torrentbd.me/activities.php
// @icon         
// @run-at       document-end
// @license		 MIT
// @grant        none
// ==/UserScript==

(function() {
    'use strict'

    const seedingList = document.querySelector('.simple-data-table tbody')

    // Classes
    class seedingListExporter {
        constructor (table, includeHeaders = true) {
            this.table = table
            this.rows = Array.from(table.querySelectorAll('tr'))

            if (!includeHeaders && this.rows[0].querySelectorAll('th').length) {
                this.rows.shift()
            }
        }

        convertToCSV() {
            const lines = []
            const numCols = this._findLongestRowLength()

            for (const row of this.rows) {
                let line = ''

                for (let i = 0; i < numCols; i++) {
                    if (row.children[i] !== undefined) {
                        line += seedingListExporter.parserCell(row.children[i])
                    }

                    line += (i !== (numCols - 1)) ? ',' : ''
                }

                lines.push(line)
            }
            
            return lines.join('\n')
        }

        _findLongestRowLength() { 
            return this.rows.reduce((l, row) => row.childElementCount > 1 ? row.childElementCount : l, 0)
        }

        static parserCell(tableCell) {
            let parsedValue = tableCell.textContent

            // Replace all the double quotes with dwo double quotes
            parsedValue = parsedValue.replace(/"/g, `""`)

            // If value contains comma, new-line or double-quotes, enclose in the doulbe quotes
            parsedValue = /[",\n]/.test(parsedValue) ? `"${parsedValue}"` : parsedValue
            
            parsedValue = parsedValue.replace(/\s+/g,' ').trim();
            // console.log(parsedValue)

            return parsedValue
        }
    }

    // Get day, month, year
    let date = new Date();
    let month = date.getMonth() + 1;
    let day = date.getDate();
    let year = date.getFullYear();

    let currentDate = `${day}-${month}-${year}`


    // Create a download button
    const exportCSVButton = document.createElement('a')
    const exportCSVButtonText = document.createTextNode('Export List as CSV')
    exportCSVButton.classList.add('btn', 'waves-effect', 'waves-light', 'center-align')
    exportCSVButton.appendChild(exportCSVButtonText)
    exportCSVButton.style.margin = '10px 0px'

    seedingList.parentElement.insertBefore(exportCSVButton, seedingList)

    exportCSVButton.addEventListener('click', () => {
        const exporter = new seedingListExporter(seedingList)
        const csvOutput = exporter.convertToCSV()
        const csvBlob = new Blob([csvOutput], {type: 'text/csv'})
        const blobURL = URL.createObjectURL(csvBlob)
        
        exportCSVButton.href = blobURL
        exportCSVButton.download = `Seeding-List-${currentDate}`

        setTimeout(() => {
            URL.revokeObjectURL(blobURL)
        }, 500)
    })
})();