forked from webcrawls/discord
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpretty-folders.plugin.js
84 lines (70 loc) · 3.02 KB
/
pretty-folders.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
/**
* @name PrettyFolders
* @author webcrawls
* @description Applies a folder's icon colour to its background when expanded.
* @version 1.2.1
*/
module.exports = class MyPlugin {
start = () => Array.from(document.getElementsByClassName(FOLDER_WRAPPER)).forEach(attachFolder)
stop = () => Array.from(document.getElementsByClassName(FOLDER_WRAPPER)).forEach(detachFolder)
};
// Discord HTML classname constants
const FOLDER_WRAPPER = "wrapper_ed1dea"
const FOLDER_COLLAPSED = "collapsed__0a270"
const FOLDER_ICON_WRAPPER = "expandedFolderIconWrapper__458cf"
const EXPANDED_FOLDER_BACKGROUND = "expandedFolderBackground__1bec6"
// Utility methods to get key elements
// Not exactly happy with how these, but hey, they're one-liners :D
const folderIcon = (el) => "getElementsByClassName" in el ? el.getElementsByClassName(FOLDER_ICON_WRAPPER)[0] : undefined
const folderBackground = (el) => "getElementsByClassName" in el ? el.getElementsByClassName(EXPANDED_FOLDER_BACKGROUND)[0] : undefined
// State. MutationObservers are thrown in here
const observers = {}
// A bit of a hack. "#updateFolder" reads this string when updating a folder.
// If the icon's SVG color is one of these, i.e. "white", which it will be after we make it look better,
// the function will not make any modifications.
const ignoredColors = [
"white"
]
const attachFolder = (folderElement) => {
const observer = new MutationObserver(() => setTimeout(updateFolder.bind(this, folderElement), 1))
observer.observe(folderElement, {childList: true, attributes: true})
observers[folderElement] = observer
updateFolder(folderElement)
}
const detachFolder = (folderElement) => {
observers[folderElement]?.disconnect()
observers[folderElement] = null
}
/**
* Updates a folder's background color with the icon color.
* @param folder the folder wrapper element
*/
const updateFolder = (folder) => {
const background = folderBackground(folder)
if (!background) {
console.warn("could not find background element for", {folder})
return
}
const icon = folderIcon(folder)
const svg = icon?.querySelector("svg")
const folderColor = svg?.style?.color;
if (!folderColor) return;
if (!background.classList.contains(FOLDER_COLLAPSED) && ignoredColors.indexOf(folderColor) === -1) {
background.style.backgroundColor = folderColor;
icon.style.backgroundColor = folderColor
svg.style.color = "white"
svg.style.opacity = 0.7;
background.style.opacity = 0.3;
}
folder.addEventListener("click", () => updateFolder(this))
const observer = new MutationObserver((mutations) => updateFolder(folder))
observer.observe(svg, {attributes: true, attributeFilter: ['style']})
observers[folder] = observer
}
const resetFolder = (folder) => {
const background = folderBackground(folder)
background.style.removeProperty("background-color");
background.style.removeProperty("opacity");
observers[folder]?.disconnect()
folder.removeEventListener("click", () => updateFolder(this))
}