stuff
This commit is contained in:
parent
e82cfabd6f
commit
20656ca095
|
@ -14,12 +14,12 @@ module.exports = (_ => {
|
||||||
"info": {
|
"info": {
|
||||||
"name": "ChatFilter",
|
"name": "ChatFilter",
|
||||||
"author": "DevilBro",
|
"author": "DevilBro",
|
||||||
"version": "3.4.7",
|
"version": "3.4.8",
|
||||||
"description": "Allow the user to censor words or block complete messages based on words in the chatwindow"
|
"description": "Allows the user to censor Words or block complete Messages/Statuses"
|
||||||
},
|
},
|
||||||
"changeLog": {
|
"changeLog": {
|
||||||
"added": {
|
"improved": {
|
||||||
"Segment Option": "You can now enable the Segment option for censored Words to only replace Segments of Words"
|
"Status Option": "Plugin now also checks custom statuses, can be disabled"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -81,14 +81,21 @@ module.exports = (_ => {
|
||||||
censored: {value: "$!%&%!&", description: "Default Replacement Word for censored Messages: "}
|
censored: {value: "$!%&%!&", description: "Default Replacement Word for censored Messages: "}
|
||||||
},
|
},
|
||||||
settings: {
|
settings: {
|
||||||
addContextMenu: {value: true, description: "Add a Context Menu Entry to faster add new blocked/censored Words: "}
|
addContextMenu: {value: true, description: "Add a Context Menu Entry to faster add new blocked/censored Words"},
|
||||||
|
targetMessages: {value: true, description: "Check Messages for blocked/censored Words"},
|
||||||
|
targetStatuses: {value: true, description: "Check Custom Statuses for blocked/censored Words"}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
this.patchedModules = {
|
this.patchedModules = {
|
||||||
before: {
|
before: {
|
||||||
Message: "default",
|
Message: "default",
|
||||||
MessageContent: "type"
|
MessageContent: "type",
|
||||||
|
UserPopout: "render",
|
||||||
|
UserProfile: "render",
|
||||||
|
UserInfo: "default",
|
||||||
|
MemberListItem: "render",
|
||||||
|
PrivateChannel: "render"
|
||||||
},
|
},
|
||||||
after: {
|
after: {
|
||||||
Messages: "type",
|
Messages: "type",
|
||||||
|
@ -296,14 +303,16 @@ module.exports = (_ => {
|
||||||
}
|
}
|
||||||
|
|
||||||
processMessages (e) {
|
processMessages (e) {
|
||||||
e.returnvalue.props.children.props.channelStream = [].concat(e.returnvalue.props.children.props.channelStream);
|
if (settings.targetMessages) {
|
||||||
for (let i in e.returnvalue.props.children.props.channelStream) {
|
e.returnvalue.props.children.props.channelStream = [].concat(e.returnvalue.props.children.props.channelStream);
|
||||||
let message = e.returnvalue.props.children.props.channelStream[i].content;
|
for (let i in e.returnvalue.props.children.props.channelStream) {
|
||||||
if (message) {
|
let message = e.returnvalue.props.children.props.channelStream[i].content;
|
||||||
if (BDFDB.ArrayUtils.is(message.attachments)) this.checkMessage(e.returnvalue.props.children.props.channelStream[i], message);
|
if (message) {
|
||||||
else if (BDFDB.ArrayUtils.is(message)) for (let j in message) {
|
if (BDFDB.ArrayUtils.is(message.attachments)) this.checkMessage(e.returnvalue.props.children.props.channelStream[i], message);
|
||||||
let childMessage = message[j].content;
|
else if (BDFDB.ArrayUtils.is(message)) for (let j in message) {
|
||||||
if (childMessage && BDFDB.ArrayUtils.is(childMessage.attachments)) this.checkMessage(message[j], childMessage);
|
let childMessage = message[j].content;
|
||||||
|
if (childMessage && BDFDB.ArrayUtils.is(childMessage.attachments)) this.checkMessage(message[j], childMessage);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -328,15 +337,17 @@ module.exports = (_ => {
|
||||||
}
|
}
|
||||||
|
|
||||||
processMessage (e) {
|
processMessage (e) {
|
||||||
let repliedMessage = e.instance.props.childrenRepliedMessage;
|
if (settings.targetMessages) {
|
||||||
if (repliedMessage && repliedMessage.props && repliedMessage.props.children && repliedMessage.props.children.props && repliedMessage.props.children.props.referencedMessage && repliedMessage.props.children.props.referencedMessage.message && (oldBlockedMessages[repliedMessage.props.children.props.referencedMessage.message.id] || oldCensoredMessages[repliedMessage.props.children.props.referencedMessage.message.id])) {
|
let repliedMessage = e.instance.props.childrenRepliedMessage;
|
||||||
let {blocked, censored, content, embeds} = this.parseMessage(repliedMessage.props.children.props.referencedMessage.message);
|
if (repliedMessage && repliedMessage.props && repliedMessage.props.children && repliedMessage.props.children.props && repliedMessage.props.children.props.referencedMessage && repliedMessage.props.children.props.referencedMessage.message && (oldBlockedMessages[repliedMessage.props.children.props.referencedMessage.message.id] || oldCensoredMessages[repliedMessage.props.children.props.referencedMessage.message.id])) {
|
||||||
repliedMessage.props.children.props.referencedMessage.message = new BDFDB.DiscordObjects.Message(Object.assign({}, repliedMessage.props.children.props.referencedMessage.message, {content, embeds}));
|
let {blocked, censored, content, embeds} = this.parseMessage(repliedMessage.props.children.props.referencedMessage.message);
|
||||||
|
repliedMessage.props.children.props.referencedMessage.message = new BDFDB.DiscordObjects.Message(Object.assign({}, repliedMessage.props.children.props.referencedMessage.message, {content, embeds}));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
processMessageContent (e) {
|
processMessageContent (e) {
|
||||||
if (e.instance.props.message) {
|
if (e.instance.props.message && settings.targetMessages) {
|
||||||
if (!e.returnvalue) {
|
if (!e.returnvalue) {
|
||||||
if (oldBlockedMessages[e.instance.props.message.id]) e.instance.props.className = BDFDB.DOMUtils.formatClassName(e.instance.props.className, BDFDB.disCN._chatfilterblocked);
|
if (oldBlockedMessages[e.instance.props.message.id]) e.instance.props.className = BDFDB.DOMUtils.formatClassName(e.instance.props.className, BDFDB.disCN._chatfilterblocked);
|
||||||
if (oldCensoredMessages[e.instance.props.message.id] && e.instance.props.message.content != oldCensoredMessages[e.instance.props.message.id].content) e.instance.props.className = BDFDB.DOMUtils.formatClassName(e.instance.props.className, BDFDB.disCN._chatfiltercensored);
|
if (oldCensoredMessages[e.instance.props.message.id] && e.instance.props.message.content != oldCensoredMessages[e.instance.props.message.id].content) e.instance.props.className = BDFDB.DOMUtils.formatClassName(e.instance.props.className, BDFDB.disCN._chatfiltercensored);
|
||||||
|
@ -351,7 +362,52 @@ module.exports = (_ => {
|
||||||
processEmbed (e) {
|
processEmbed (e) {
|
||||||
if (e.instance.props.embed && e.instance.props.embed.censored && oldCensoredMessages[e.instance.props.embed.message_id]) {
|
if (e.instance.props.embed && e.instance.props.embed.censored && oldCensoredMessages[e.instance.props.embed.message_id]) {
|
||||||
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {props: [["className", BDFDB.disCN.embeddescription]]});
|
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {props: [["className", BDFDB.disCN.embeddescription]]});
|
||||||
if (index > -1) children[index].props.children.push(this.createStamp(oldCensoredMessages[e.instance.props.embed.message_id].embeds[e.instance.props.embed.index].rawDescription, "censored"));
|
if (index > -1) children[index].props.children = [
|
||||||
|
children[index].props.children,
|
||||||
|
this.createStamp(oldCensoredMessages[e.instance.props.embed.message_id].embeds[e.instance.props.embed.index].rawDescription, "censored")
|
||||||
|
].flat(10).filter(n => n);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
processUserPopout (e) {
|
||||||
|
this.checkStatus(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
processUserProfile (e) {
|
||||||
|
this.checkStatus(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
processUserInfo (e) {
|
||||||
|
this.checkActivities(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
processMemberListItem (e) {
|
||||||
|
this.checkActivities(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
processPrivateChannel (e) {
|
||||||
|
this.checkActivities(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
checkStatus (e) {
|
||||||
|
if (settings.targetStatuses && e.instance.props.customStatusActivity) {
|
||||||
|
let {content} = this.parseMessage({content: e.instance.props.customStatusActivity.state, embeds: [], id: "status"});
|
||||||
|
if (content) e.instance.props.customStatusActivity = Object.assign({}, e.instance.props.customStatusActivity, {state: content});
|
||||||
|
else if (!e.instance.props.customStatusActivity.emoji) delete e.instance.props.customStatusActivity;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
checkActivities (e) {
|
||||||
|
if (settings.targetStatuses && e.instance.props.activities && e.instance.props.activities.length) {
|
||||||
|
let index = e.instance.props.activities.findIndex(n => n && n.type == BDFDB.DiscordConstants.ActivityTypes.CUSTOM_STATUS);
|
||||||
|
if (index > -1 && e.instance.props.activities[index].state) {
|
||||||
|
let {content} = this.parseMessage({content: e.instance.props.activities[index].state, embeds: [], id: "status"});
|
||||||
|
if (content) e.instance.props.activities[index] = Object.assign({}, e.instance.props.activities[index], {state: content});
|
||||||
|
else if (!e.instance.props.activities[index].emoji) {
|
||||||
|
e.instance.props.activities = [].concat(e.instance.props.activities);
|
||||||
|
e.instance.props.activities.splice(index, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -9,5 +9,5 @@
|
||||||
[patreon-badge]: https://img.shields.io/badge/Patreon-Support!-%23F96854.svg?logo=patreon&style=flat
|
[patreon-badge]: https://img.shields.io/badge/Patreon-Support!-%23F96854.svg?logo=patreon&style=flat
|
||||||
[patreon-link]: https://patreon.com/MircoWittrien
|
[patreon-link]: https://patreon.com/MircoWittrien
|
||||||
|
|
||||||
Allow the user to censor words or block complete messages based on words in the chatwindow. Blocked in this case means, that a message that contains one of the words will be completely blocked in your chat window. Censored means you will still be able to read the message but the censored words will be unreadable. You can also completely hide blocked messages and enable the option to see the original message while hovering over a censored/blocked message
|
Allows the user to censor Words or block complete Messages/Statuses. Blocked in this case means, that a message that contains one of the words will be completely blocked in your chat window. Censored means you will still be able to read the message but the censored words will be unreadable. You can also completely hide blocked messages and enable the option to see the original message while hovering over a censored/blocked message
|
||||||
Support Regular Expressions
|
Support Regular Expressions
|
||||||
|
|
|
@ -12,7 +12,7 @@
|
||||||
- [Better Search Page](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/BetterSearchPage) - Add some extra controls to the search results page
|
- [Better Search Page](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/BetterSearchPage) - Add some extra controls to the search results page
|
||||||
- [Char Counter](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/CharCounter) - Add a character counter to the chat
|
- [Char Counter](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/CharCounter) - Add a character counter to the chat
|
||||||
- [Chat Aliases](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/ChatAliases) - Allow the user to configure their own chat-aliases which will automatically be replaced before the message is being sent
|
- [Chat Aliases](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/ChatAliases) - Allow the user to configure their own chat-aliases which will automatically be replaced before the message is being sent
|
||||||
- [Chat Filter](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/ChatFilter) - Allow the user to censor words or block complete messages based on words in the chatwindow
|
- [Chat Filter](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/ChatFilter) - Allows the user to censor Words or block complete Messages/Statuses
|
||||||
- [Complete Timestamps](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/CompleteTimestamps) - Replace all timestamps with complete timestamps
|
- [Complete Timestamps](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/CompleteTimestamps) - Replace all timestamps with complete timestamps
|
||||||
- [Copy Raw Message](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/CopyRawMessage) - Add a entry in the contextmenu when you right click a message that allows you to copy the raw contents of a message
|
- [Copy Raw Message](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/CopyRawMessage) - Add a entry in the contextmenu when you right click a message that allows you to copy the raw contents of a message
|
||||||
- [Creation Date](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/CreationDate) - Display the Creation Date of an Account in the UserPopout and UserModal
|
- [Creation Date](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/CreationDate) - Display the Creation Date of an Account in the UserPopout and UserModal
|
||||||
|
|
Loading…
Reference in New Issue