ReadAllNotificationsButton now uses patching instead of observing
This commit is contained in:
parent
8b034a36e4
commit
c21f315a24
|
@ -2,6 +2,11 @@
|
||||||
|
|
||||||
class ReadAllNotificationsButton {
|
class ReadAllNotificationsButton {
|
||||||
initConstructor () {
|
initConstructor () {
|
||||||
|
this.patchModules = {
|
||||||
|
"Guilds":"componentDidMount",
|
||||||
|
"RecentMentions":"componentDidMount"
|
||||||
|
};
|
||||||
|
|
||||||
this.RANbuttonMarkup =
|
this.RANbuttonMarkup =
|
||||||
`<div class="${BDFDB.disCN.guild} RANbutton-frame" id="bd-pub-li" style="height: 20px; margin-bottom: 10px;">
|
`<div class="${BDFDB.disCN.guild} RANbutton-frame" id="bd-pub-li" style="height: 20px; margin-bottom: 10px;">
|
||||||
<div class="${BDFDB.disCN.guildinner}" style="height: 20px; border-radius: 4px;">
|
<div class="${BDFDB.disCN.guildinner}" style="height: 20px; border-radius: 4px;">
|
||||||
|
@ -12,7 +17,7 @@ class ReadAllNotificationsButton {
|
||||||
</div>`;
|
</div>`;
|
||||||
|
|
||||||
this.RAMbuttonMarkup =
|
this.RAMbuttonMarkup =
|
||||||
`<button type="button" id="RAMbutton" class="${BDFDB.disCNS.flexchild + BDFDB.disCNS.button + BDFDB.disCNS.buttonlookfilled + BDFDB.disCNS.buttoncolorbrand + BDFDB.disCNS.buttonsizemin + BDFDB.disCN.buttongrow}" style="flex: 0 0 auto; margin-left: 25px; height: 25px;">
|
`<button type="button" class="${BDFDB.disCNS.flexchild + BDFDB.disCNS.button + BDFDB.disCNS.buttonlookfilled + BDFDB.disCNS.buttoncolorbrand + BDFDB.disCNS.buttonsizemin + BDFDB.disCN.buttongrow} RAMbutton" style="flex: 0 0 auto; margin-left: 25px; height: 25px;">
|
||||||
<div class="${BDFDB.disCN.buttoncontents}">Clear Mentions</div>
|
<div class="${BDFDB.disCN.buttoncontents}">Clear Mentions</div>
|
||||||
</button>`;
|
</button>`;
|
||||||
|
|
||||||
|
@ -27,7 +32,7 @@ class ReadAllNotificationsButton {
|
||||||
|
|
||||||
getDescription () {return "Adds a button to clear all notifications.";}
|
getDescription () {return "Adds a button to clear all notifications.";}
|
||||||
|
|
||||||
getVersion () {return "1.3.6";}
|
getVersion () {return "1.3.7";}
|
||||||
|
|
||||||
getAuthor () {return "DevilBro";}
|
getAuthor () {return "DevilBro";}
|
||||||
|
|
||||||
|
@ -71,47 +76,7 @@ class ReadAllNotificationsButton {
|
||||||
if (typeof BDFDB === "object") {
|
if (typeof BDFDB === "object") {
|
||||||
BDFDB.loadMessage(this);
|
BDFDB.loadMessage(this);
|
||||||
|
|
||||||
var observer = null;
|
BDFDB.WebModules.forceAllUpdates(this);
|
||||||
|
|
||||||
observer = new MutationObserver((changes, _) => {
|
|
||||||
changes.forEach(
|
|
||||||
(change, i) => {
|
|
||||||
if (change.addedNodes) {
|
|
||||||
change.addedNodes.forEach((node) => {
|
|
||||||
var mentionspopout = null;
|
|
||||||
if (node.tagName && (mentionspopout = node.querySelector(BDFDB.dotCN.recentmentionspopout)) != null && node.querySelector(BDFDB.dotCN.recentmentionsmentionfilter)) {
|
|
||||||
$(this.RAMbuttonMarkup).appendTo(BDFDB.dotCN.recentmentionstitle, mentionspopout)
|
|
||||||
.on("click", () => {
|
|
||||||
var loadinterval = setInterval(() => {
|
|
||||||
if (!mentionspopout || !mentionspopout.parentElement) clearInterval(loadinterval);
|
|
||||||
var loadbutton = mentionspopout.querySelector(BDFDB.dotCNS.messagespopouthasmore + "button");
|
|
||||||
var closebuttons = mentionspopout.querySelectorAll(BDFDB.dotCN.messagespopoutclosebutton);
|
|
||||||
if (!loadbutton) {
|
|
||||||
closebuttons.forEach((btn) => {btn.click();});
|
|
||||||
clearInterval(loadinterval);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
closebuttons.forEach((btn,i) => {if (closebuttons.length-1 > i) btn.click();});
|
|
||||||
loadbutton.click();
|
|
||||||
}
|
|
||||||
},2000);
|
|
||||||
});
|
|
||||||
mentionspopout.classList.add("RAM-added");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
});
|
|
||||||
BDFDB.addObserver(this, BDFDB.dotCN.popouts, {name:"mentionsPopoutObserver",instance:observer}, {childList: true});
|
|
||||||
|
|
||||||
$(this.RANbuttonMarkup).insertBefore(document.querySelector(BDFDB.dotCN.guildseparator))
|
|
||||||
.on("click", ".RANbutton", () => {
|
|
||||||
let servers = BDFDB.getData("includeMuted", this, "settings") ? BDFDB.readServerList() : BDFDB.readUnreadServerList();
|
|
||||||
BDFDB.clearReadNotifications(servers);
|
|
||||||
});
|
|
||||||
|
|
||||||
$(BDFDB.dotCN.guilds).addClass("RAN-added");
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
console.error(this.getName() + ": Fatal Error: Could not load BD functions!");
|
console.error(this.getName() + ": Fatal Error: Could not load BD functions!");
|
||||||
|
@ -120,11 +85,8 @@ class ReadAllNotificationsButton {
|
||||||
|
|
||||||
stop () {
|
stop () {
|
||||||
if (typeof BDFDB === "object") {
|
if (typeof BDFDB === "object") {
|
||||||
$(".RANbutton-frame, .RAMbutton").remove();
|
BDFDB.removeEles(".RANbutton-frame", ".RAMbutton");
|
||||||
|
BDFDB.removeClasses("RAN-added", "RAM-added");
|
||||||
$(".RAN-added").removeClass("RAN-added");
|
|
||||||
$(".RAM-added").removeClass("RAM-added");
|
|
||||||
|
|
||||||
BDFDB.unloadMessage(this);
|
BDFDB.unloadMessage(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -139,4 +101,30 @@ class ReadAllNotificationsButton {
|
||||||
}
|
}
|
||||||
BDFDB.saveAllData(settings, this, "settings");
|
BDFDB.saveAllData(settings, this, "settings");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
processGuilds (instance, wrapper) {
|
||||||
|
$(this.RANbuttonMarkup).insertBefore(wrapper.querySelector(BDFDB.dotCN.guildseparator))
|
||||||
|
.on("click", ".RANbutton", () => {
|
||||||
|
BDFDB.clearReadNotifications(BDFDB.getData("includeMuted", this, "settings") ? BDFDB.readServerList() : BDFDB.readUnreadServerList());
|
||||||
|
});
|
||||||
|
wrapper.classList.add("RAN-added");
|
||||||
|
}
|
||||||
|
|
||||||
|
processRecentMentions (instance, wrapper) {
|
||||||
|
BDFDB.removeEles(".RAMbutton");
|
||||||
|
if (instance.props && instance.props.popoutName == "RECENT_MENTIONS_POPOUT") {
|
||||||
|
wrapper.classList.add("RAM-added");
|
||||||
|
$(this.RAMbuttonMarkup).appendTo(wrapper.querySelector(BDFDB.dotCN.recentmentionstitle))
|
||||||
|
.on("click", () => {this.clearMentions(instance, wrapper);});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
clearMentions (instance, wrapper) {
|
||||||
|
let closebuttons = wrapper.querySelectorAll(BDFDB.dotCN.messagespopoutclosebutton);
|
||||||
|
for (let btn of wrapper.querySelectorAll(BDFDB.dotCN.messagespopoutclosebutton)) btn.click();
|
||||||
|
if (closebuttons.length) {
|
||||||
|
instance.loadMore();
|
||||||
|
setTimeout(() => {this.clearMentions(instance, wrapper);},3000);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue