-
Notifications
You must be signed in to change notification settings - Fork 529
/
Copy pathchannelHistory.plugin.js
115 lines (101 loc) · 3.5 KB
/
channelHistory.plugin.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
//META{"name":"channelHistory"}*//
var channelHistory = (function(listener, bw, wc, backdrop, buttons, buttonsClone, buttonsForward, buttonsBackward, attach, attachClone, css){
class channelHistory {
getName(){ return "Channel History" }
getDescription(){ return "Allows you to switch channels using mouse 4 & 5 or the added GUI buttons." }
getVersion(){ return "1.2.5" }
getAuthor(){ return "square" }
start(){
bw = require("electron").remote.getCurrentWindow();
wc = bw.webContents;
bw.on("app-command", listener);
BdApi.injectCSS("css-channelHistory", css);
attach();
this.onSwitch();
}
stop(){
bw.removeListener("app-command", listener);
buttons.remove();
buttonsClone.remove();
BdApi.clearCSS("css-channelHistory");
}
load(){}
onSwitch(can){
attachClone();
can = wc.canGoBack();
buttonsBackward.forEach(button => button.classList.toggle("cant", !can));
can = wc.canGoForward();
buttonsForward.forEach(button => button.classList.toggle("cant", !can));
}
}
listener = (ev, cmd) => {
if (cmd !== 'browser-backward' && cmd !== 'browser-forward')
return;
if (backdrop = document.querySelector(".backdrop-1ocfXc"))
backdrop.click();
else if (cmd === 'browser-backward' && wc.canGoBack())
wc.goBack();
else if (cmd === 'browser-forward' && wc.canGoForward())
wc.goForward();
backdrop = void 0;
};
buttons = document.createElement("div");
buttons.className = "channelHistoryButtons";
buttons.innerHTML = `<div class="btn back"><</div><div class="btn forward">></div>`;
buttonsClone = buttons.cloneNode(true);
buttonsClone.classList.add("clone");
buttonsBackward = [buttons.firstChild, buttonsClone.firstChild]
buttonsForward = [buttons.lastChild, buttonsClone.lastChild]
buttonsBackward.forEach(button => button.onclick = () => listener(null, "browser-backward"));
buttonsForward.forEach(button => button.onclick = () => listener(null, "browser-forward"));
attach = (branding, titlebar) => {
try {
if (branding = document.querySelector(".wordmark-2iDDfm")) {
// windows
branding.parentElement.insertBefore(buttons, branding.nextElementSibling);
} else if (titlebar = document.querySelector(".titleBar-AC4pGV")) {
// osx
titlebar.insertBefore(buttons, titlebar.firstChild);
}
} catch (err) { console.warn(err); }
}
attachClone = (channelName, after) => {
try {
channelNameWrapper = document.querySelector(".children-19S4PO") || (after = document.querySelector(".search-36MZv-"));
channelNameWrapper.parentElement.insertBefore(buttonsClone, after ? null : channelNameWrapper);
} catch (err) { console.warn(err); }
}
css = `
.channelHistoryButtons {
color: #999;
font-weight: bold;
position: absolute;
left: 71px;
}
.channelHistoryButtons.clone {
display: none;
flex: 0 0 28px;
position: relative;
left: unset;
order: 0;
}
.hidden-by-OTB + * .channelHistoryButtons.clone,
.platform-linux .channelHistoryButtons.clone {
display: inline-block;
}
.channelHistoryButtons .btn {
display: inline-block;
pointer-events: all;
-webkit-app-region: no-drag;
cursor: pointer;
padding: 0 2px;
}
.channelHistoryButtons .btn:hover:not(.cant) {
color: #ddd;
}
.channelHistoryButtons .cant {
opacity: 0.5;
}
`;
return channelHistory;
})()