Implement EventListener instead of func juggling

This commit is contained in:
2025-10-09 11:35:35 +02:00
parent 46e7f7540b
commit 10a19717ad
4 changed files with 18 additions and 17 deletions

View File

@@ -19,7 +19,7 @@ class trdom_torrentcontrol {
//TODO: remove //TODO: remove
#getKnownTorrents; #getKnownTorrents;
#handler = function(e) { handleEvent(e) {
switch (e.type) { switch (e.type) {
case 'click': case 'click':
if (e.currentTarget.hasAttributeNS('trweb', 'torrentlistfield')) { if (e.currentTarget.hasAttributeNS('trweb', 'torrentlistfield')) {
@@ -55,7 +55,7 @@ class trdom_torrentcontrol {
} }
} }
} }
}.bind(this); }
constructor(hash, server, logcb, getKnownTorrents) { constructor(hash, server, logcb, getKnownTorrents) {
this.#hash = hash; this.#hash = hash;
@@ -81,7 +81,7 @@ class trdom_torrentcontrol {
element_start.setAttributeNS('trweb', 'torrent', this.#hash); element_start.setAttributeNS('trweb', 'torrent', this.#hash);
element_start.setAttributeNS('trweb', 'torrentlistfield', 'start'); element_start.setAttributeNS('trweb', 'torrentlistfield', 'start');
element_start.appendChild(document.createTextNode("Start")); element_start.appendChild(document.createTextNode("Start"));
element_start.addEventListener("click", this.#handler); element_start.addEventListener("click", this);
let element_pause = document.createElement('div'); let element_pause = document.createElement('div');
element_pause.classList.add('trweb_torrentlistcontrol', 'col-4'); element_pause.classList.add('trweb_torrentlistcontrol', 'col-4');
@@ -89,7 +89,7 @@ class trdom_torrentcontrol {
element_pause.setAttributeNS('trweb', 'torrent', this.#hash); element_pause.setAttributeNS('trweb', 'torrent', this.#hash);
element_pause.setAttributeNS('trweb', 'torrentlistfield', 'pause'); element_pause.setAttributeNS('trweb', 'torrentlistfield', 'pause');
element_pause.appendChild(document.createTextNode("Pause")); element_pause.appendChild(document.createTextNode("Pause"));
element_pause.addEventListener("click", this.#handler); element_pause.addEventListener("click", this);
// Download by magnet // Download by magnet
let element_magnet = document.createElement('div'); let element_magnet = document.createElement('div');
@@ -98,7 +98,7 @@ class trdom_torrentcontrol {
element_magnet.setAttributeNS('trweb', 'torrent', this.#hash); element_magnet.setAttributeNS('trweb', 'torrent', this.#hash);
element_magnet.setAttributeNS('trweb', 'torrentlistfield', 'magnet'); element_magnet.setAttributeNS('trweb', 'torrentlistfield', 'magnet');
element_magnet.appendChild(document.createTextNode(`[${srv}] Magnet`)); element_magnet.appendChild(document.createTextNode(`[${srv}] Magnet`));
element_magnet.addEventListener("click", this.#handler); element_magnet.addEventListener("click", this);
// Download by torrent file // Download by torrent file
let element_download = document.createElement('div'); let element_download = document.createElement('div');
@@ -107,7 +107,7 @@ class trdom_torrentcontrol {
element_download.setAttributeNS('trweb', 'torrent', this.#hash); element_download.setAttributeNS('trweb', 'torrent', this.#hash);
element_download.setAttributeNS('trweb', 'torrentlistfield', 'download'); element_download.setAttributeNS('trweb', 'torrentlistfield', 'download');
element_download.appendChild(document.createTextNode(`[${srv}] Get torrent`)); element_download.appendChild(document.createTextNode(`[${srv}] Get torrent`));
element_download.addEventListener("click", this.#handler); element_download.addEventListener("click", this);
// row container // row container
let element_serverrow = document.createElement('div'); let element_serverrow = document.createElement('div');

View File

@@ -47,9 +47,9 @@ class trserver {
rpc.setRequestHeader('X-Transmission-Session-Id', this.#sessionHeader); rpc.setRequestHeader('X-Transmission-Session-Id', this.#sessionHeader);
} }
rpc.setRequestHeader('content-type', 'application/json'); rpc.setRequestHeader('content-type', 'application/json');
rpc.addEventListener('readystatechange', this.#handler.bind(this)); rpc.addEventListener('readystatechange', this);
rpc.addEventListener('timeout', this.#handler.bind(this)); rpc.addEventListener('timeout', this);
rpc.addEventListener('error', this.#handler.bind(this)); rpc.addEventListener('error', this);
rpc.timeout = 10000; rpc.timeout = 10000;
try { try {
rpc.send(JSON.stringify(request.payload)); rpc.send(JSON.stringify(request.payload));
@@ -65,7 +65,7 @@ class trserver {
this.#rpccall(tag); this.#rpccall(tag);
} }
#handler(e) { handleEvent(e) {
switch (e.type) { switch (e.type) {
case 'readystatechange': case 'readystatechange':
if (e.target.readyState == 4) { if (e.target.readyState == 4) {

View File

@@ -26,7 +26,7 @@ class trtorrent {
this.#servers[srv] = status; this.#servers[srv] = status;
} }
#handler = function(e) { handleEvent(e) {
switch (e.type) { switch (e.type) {
case 'click': case 'click':
if (e.currentTarget.hasAttributeNS('trweb', 'torrentlistfield')) { if (e.currentTarget.hasAttributeNS('trweb', 'torrentlistfield')) {
@@ -39,7 +39,7 @@ class trtorrent {
} }
break; break;
} }
}.bind(this); }
constructor(hash) { constructor(hash) {
this.#hash = hash; this.#hash = hash;
@@ -52,7 +52,7 @@ class trtorrent {
this.#element.torrent = this; this.#element.torrent = this;
this.#element.classList.add('trweb_torrentlistentry', 'trweb_hide_buttons', 'row'); this.#element.classList.add('trweb_torrentlistentry', 'trweb_hide_buttons', 'row');
this.#element.setAttributeNS('trweb', 'torrentlistfield', 'entry'); this.#element.setAttributeNS('trweb', 'torrentlistfield', 'entry');
this.#element.addEventListener('click', this.#handler); this.#element.addEventListener('click', this);
this.#element.element_name = element_name; this.#element.element_name = element_name;
this.#element.appendChild(element_name); this.#element.appendChild(element_name);
} }

View File

@@ -37,11 +37,12 @@ class trweb {
if (document.readyState === 'complete' || document.readyState === 'interactive') { if (document.readyState === 'complete' || document.readyState === 'interactive') {
this.#logger('Document already loaded, jumpstarting'); this.#logger('Document already loaded, jumpstarting');
this.#handler({'type': 'DOMContentLoaded'}); // we don't want to re-trigger every listener, so call handler directly instead of dispatching an event
this.handleEvent({'type': 'DOMContentLoaded'});
} }
else { else {
this.#logger('Waiting for document to load'); this.#logger('Waiting for document to load');
document.addEventListener('DOMContentLoaded', this.#handler); document.addEventListener('DOMContentLoaded', this);
} }
} }
@@ -162,7 +163,7 @@ class trweb {
} }
} }
#handler = function(e) { handleEvent(e) {
switch (e.type) { switch (e.type) {
case 'DOMContentLoaded': case 'DOMContentLoaded':
this.#logger('Activating TRWEB instance'); this.#logger('Activating TRWEB instance');
@@ -178,7 +179,7 @@ class trweb {
this.setTimer(); this.setTimer();
break; break;
} }
}.bind(this); }
refresh() { refresh() {
for (const [key, value] of Object.entries(this.#dom_servermanager.getServers())) { for (const [key, value] of Object.entries(this.#dom_servermanager.getServers())) {