"use strict"; class trdom_servermanager extends EventTarget { #logcb; #log(loglevel, msg) { if (this.#logcb !== null) { this.#logcb('trdom_servermanager', loglevel, msg); } } #servers = {}; getServers() { return this.#servers; } #elements = { menuentry: document.createElement('div'), serverlist: { shade: document.createElement('div'), form: document.createElement('div'), header: { container: document.createElement('div'), addbutton: document.createElement('div') }, list: document.createElement('div') } }; get menuentry() { return this.#elements.menuentry; } #registerServer(name, initdata) { let server = new trserver(name, initdata, this.#logcb); this.#servers[name] = server; this.#elements.serverlist.list.appendChild(server.element); let button = document.createElement('div'); server.addServerListButton('deleteserver', button); button.setAttributeNS('trweb', 'servermanagerbutton', 'delete'); button.setAttribute('server', name); button.appendChild(document.createTextNode('[Delete]')); button.addEventListener('click', this); //server.addEventListener('torrent-updated', this); server.addEventListener('torrent-initialize', this); let e = new CustomEvent('torrentserver-added', { detail: { serverName: name, serverObject: server } }); this.dispatchEvent(e); server.refreshTorrentList(); } addServer(name, url, user, pass) { this.#registerServer(name, {'rpcurl': url, 'auth': `Basic ${btoa(`${user}:${pass}`)}`}); this.#saveServers(); } deleteServer(name) { delete this.#servers[name]; this.saveServers(); window.location.reload(); } #loadcb; #loadServers() { let serverjson = this.#loadcb('servers'); this.#servers = {}; if (serverjson == null) { this.#log(4, 'No saved server data found'); } else { let serverdata = JSON.parse(serverjson); for (const [key, value] of Object.entries(serverdata)) { this.#registerServer(key, value); } this.#log(5, `Loaded ${Object.keys(this.#servers).length} servers`); } } loadServers() { this.#loadServers(); } #savecb; #saveServers() { let serverdata = {}; for (const [key, value] of Object.entries(this.#servers)) { serverdata[key] = value.getInstanceData(); } this.#log(5, `Saving ${Object.keys(serverdata).length} servers`); this.#savecb('servers', JSON.stringify(serverdata)); } saveServers() { this.#saveServers(); } constructor (loadcb = null, savecb = null, logcb = null) { super(); this.#loadcb = loadcb; this.#savecb = savecb; this.#logcb = logcb this.menuentry.appendChild(document.createTextNode('[Servers]')); this.menuentry.setAttributeNS('trweb', 'servermanagerbutton', 'manager'); this.menuentry.addEventListener('click', this); this.#elements.serverlist.shade.classList.add('trweb_formshade', 'd-flex', 'justify-content-center', 'align-items-center'); this.#elements.serverlist.shade.setAttributeNS('trweb', 'servermanagerbutton', 'hide'); this.#elements.serverlist.shade.addEventListener('click', this); this.#elements.serverlist.shade.appendChild(this.#elements.serverlist.form); this.#elements.serverlist.form.classList.add('trweb_form', 'd-flex', 'flex-column'); this.#elements.serverlist.form.setAttributeNS('trweb', 'servermanagerbutton', 'block'); this.#elements.serverlist.form.addEventListener('click', this); this.#elements.serverlist.form.style.backgroundColor = 'cyan'; this.#elements.serverlist.form.appendChild(this.#elements.serverlist.header.container); this.#elements.serverlist.form.appendChild(this.#elements.serverlist.list); this.#elements.serverlist.header.container.classList.add('d-flex', 'flex-row'); this.#elements.serverlist.header.container.appendChild(this.#elements.serverlist.header.addbutton); this.#elements.serverlist.header.addbutton.appendChild(document.createTextNode('[Add server]')); this.#elements.serverlist.header.addbutton.setAttributeNS('trweb', 'servermanagerbutton', 'add'); this.#elements.serverlist.header.addbutton.addEventListener('click', this); this.#elements.serverlist.list.classList.add('d-flex', 'flex-column'); } handleEvent(e) { this.#log(6, `Handling event of type ${e.type}`); switch (e.type) { case 'click': if (e.currentTarget.hasAttributeNS('trweb', 'servermanagerbutton')) { switch (e.currentTarget.getAttributeNS('trweb', 'servermanagerbutton')) { case 'add': e.stopPropagation(); window.alert('Server add form isn\'t implemented'); break; case 'block': e.stopPropagation(); break; case 'delete': e.stopPropagation(); let deleteSrv = e.currentTarget.getAttribute('server'); if (window.confirm(`Are you sure you want to delete server ${deleteSrv}?`)) { this.deleteServer(deleteSrv); } break; case 'hide': e.stopPropagation(); document.body.removeChild(this.#elements.serverlist.shade); break; case 'manager': e.stopPropagation(); document.body.appendChild(this.#elements.serverlist.shade); break; } } break; case 'torrent-initialize': let initControls = {}; let initHash = e.detail.torrentHash; for (const [srv, server] of Object.entries(this.#servers)) { let control = server == e.detail.serverObject ? e.detail.torrentControl : new trdom_torrentcontrol(initHash, server, {magnetLink: e.detail.torrentControl.magnet}, this.#logcb); //server.addControl(control); initControls[srv] = control; } let initEvent = new CustomEvent('torrent-created', { detail: { torrentHash: initHash, torrentControls: initControls, torrentName: e.detail.torrentControl.name, magnetLink: e.detail.torrentControl.magnet } }); this.dispatchEvent(initEvent); break; default: this.#log(5, `Event type ${e.type} not supported`); break; } } }