Update FriendNotifications.plugin.js

This commit is contained in:
Mirco Wittrien 2021-04-14 14:37:19 +02:00
parent 09276a836d
commit 5c60465d59
1 changed files with 11 additions and 8 deletions

View File

@ -2,7 +2,7 @@
* @name FriendNotifications * @name FriendNotifications
* @author DevilBro * @author DevilBro
* @authorId 278543574059057154 * @authorId 278543574059057154
* @version 1.6.6 * @version 1.6.7
* @description Shows a Notification when a Friend or a User, you choose to observe, changes their Status * @description Shows a Notification when a Friend or a User, you choose to observe, changes their Status
* @invite Jx3TjNS * @invite Jx3TjNS
* @donate https://www.paypal.me/MircoWittrien * @donate https://www.paypal.me/MircoWittrien
@ -17,10 +17,13 @@ module.exports = (_ => {
"info": { "info": {
"name": "FriendNotifications", "name": "FriendNotifications",
"author": "DevilBro", "author": "DevilBro",
"version": "1.6.6", "version": "1.6.7",
"description": "Shows a Notification when a Friend or a User, you choose to observe, changes their Status" "description": "Shows a Notification when a Friend or a User, you choose to observe, changes their Status"
}, },
"changeLog": { "changeLog": {
"fixed": {
"Custom Status": "Fixed Issue where the notification wouldn't show that a user changed their custom status, if they previously had not custom status set. This could lead to what looked like double entries in the login/out timelog, since custom statuses appeared like normal status changes"
},
"added": { "added": {
"Status Indicator": "Added the Status Indicator to the Notifications" "Status Indicator": "Added the Status Indicator to the Notifications"
}, },
@ -724,7 +727,7 @@ module.exports = (_ => {
return statusName; return statusName;
} }
compareActivity (id, status) { activityIsSame (id, status) {
return BDFDB.equals(BDFDB.ObjectUtils.extract(userStatusStore[id].activity, "name", "details", "state", "emoji"), status && BDFDB.ObjectUtils.extract(status.activity, "name", "details", "state", "emoji")); return BDFDB.equals(BDFDB.ObjectUtils.extract(userStatusStore[id].activity, "name", "details", "state", "emoji"), status && BDFDB.ObjectUtils.extract(status.activity, "name", "details", "state", "emoji"));
} }
@ -756,13 +759,13 @@ module.exports = (_ => {
let status = this.getStatusWithMobileAndActivity(id, observedUsers[id], clientStatuses); let status = this.getStatusWithMobileAndActivity(id, observedUsers[id], clientStatuses);
let customChanged = false; let customChanged = false;
if (user && observedUsers[id][status.name] && ( if (user && observedUsers[id][status.name] && (
userStatusStore[id].name != status.name ||
observedUsers[id].mobile && userStatusStore[id].mobile != status.mobile ||
observedUsers[id].custom && ( observedUsers[id].custom && (
userStatusStore[id].custom != status.custom || userStatusStore[id].custom != status.custom && ((customChanged = status.custom) || true) ||
(customChanged = status.custom && !this.compareActivity(id, status)) (customChanged = status.custom && !this.activityIsSame(id, status))
) || ) ||
statuses[status.name].checkActivity && !this.compareActivity(id, status) observedUsers[id].mobile && userStatusStore[id].mobile != status.mobile ||
statuses[status.name].checkActivity && !this.activityIsSame(id, status) ||
userStatusStore[id].name != status.name
)) { )) {
let EUdata = BDFDB.BDUtils.isPluginEnabled("EditUsers") && BDFDB.DataUtils.load("EditUsers", "users", user.id) || {}; let EUdata = BDFDB.BDUtils.isPluginEnabled("EditUsers") && BDFDB.DataUtils.load("EditUsers", "users", user.id) || {};
let name = EUdata.name || user.username; let name = EUdata.name || user.username;