mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-13 10:03:31 +01:00
fix(PresenceUpdateAction): emit presences again (#3214)
* fix(PresenceUpdateAction): emit presences again * update typings
This commit is contained in:
@@ -5,40 +5,38 @@ const { Events } = require('../../util/Constants');
|
||||
|
||||
class PresenceUpdateAction extends Action {
|
||||
handle(data) {
|
||||
let cached = this.client.users.get(data.user.id);
|
||||
if (!cached && data.user.username) cached = this.client.users.add(data.user);
|
||||
if (!cached) return;
|
||||
let user = this.client.users.get(data.user.id);
|
||||
if (!user && data.user.username) user = this.client.users.add(data.user);
|
||||
if (!user) return;
|
||||
|
||||
if (data.user && data.user.username) {
|
||||
if (!cached.equals(data.user)) this.client.actions.UserUpdate.handle(data.user);
|
||||
if (!user.equals(data.user)) this.client.actions.UserUpdate.handle(data.user);
|
||||
}
|
||||
|
||||
const guild = this.client.guilds.get(data.guild_id);
|
||||
if (!guild) return;
|
||||
|
||||
let member = guild.members.get(cached.id);
|
||||
let oldPresence = guild.presences.get(user.id);
|
||||
if (oldPresence) oldPresence = oldPresence._clone();
|
||||
let member = guild.members.get(user.id);
|
||||
if (!member && data.status !== 'offline') {
|
||||
member = guild.members.add({ user: cached, roles: data.roles, deaf: false, mute: false });
|
||||
member = guild.members.add({
|
||||
user,
|
||||
roles: data.roles,
|
||||
deaf: false,
|
||||
mute: false,
|
||||
});
|
||||
this.client.emit(Events.GUILD_MEMBER_AVAILABLE, member);
|
||||
}
|
||||
|
||||
if (member) {
|
||||
if (this.client.listenerCount(Events.PRESENCE_UPDATE) === 0) {
|
||||
guild.presences.add(data);
|
||||
return;
|
||||
}
|
||||
const old = member._clone();
|
||||
if (member.presence) old.frozenPresence = member.presence._clone();
|
||||
guild.presences.add(data);
|
||||
guild.presences.add(Object.assign(data, { guild }));
|
||||
if (member && this.client.listenerCount(Events.PRESENCE_UPDATE)) {
|
||||
/**
|
||||
* Emitted whenever a guild member's presence changes, or they change one of their details.
|
||||
* Emitted whenever a guild member's presence (e.g. status, activity) is changed.
|
||||
* @event Client#presenceUpdate
|
||||
* @param {GuildMember} oldMember The member before the presence update
|
||||
* @param {GuildMember} newMember The member after the presence update
|
||||
* @param {?Presence} oldPresence The presence before the update, if one at all
|
||||
* @param {Presence} newPresence The presence after the update
|
||||
*/
|
||||
this.client.emit(Events.PRESENCE_UPDATE, old, member);
|
||||
} else {
|
||||
guild.presences.add(data);
|
||||
this.client.emit(Events.PRESENCE_UPDATE, oldPresence, member.presence);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user