mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-17 20:13:30 +01:00
voice: patch in default VoiceStateUpdate in case on doesn't exist, cache member
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
const AbstractHandler = require('./AbstractHandler');
|
const AbstractHandler = require('./AbstractHandler');
|
||||||
|
|
||||||
const { Events } = require('../../../../util/Constants');
|
const { Events } = require('../../../../util/Constants');
|
||||||
|
const VoiceState = require('../../../../structures/VoiceState');
|
||||||
|
|
||||||
class VoiceStateUpdateHandler extends AbstractHandler {
|
class VoiceStateUpdateHandler extends AbstractHandler {
|
||||||
handle(packet) {
|
handle(packet) {
|
||||||
@@ -10,14 +11,23 @@ class VoiceStateUpdateHandler extends AbstractHandler {
|
|||||||
const guild = client.guilds.get(data.guild_id);
|
const guild = client.guilds.get(data.guild_id);
|
||||||
if (guild) {
|
if (guild) {
|
||||||
// Update the state
|
// Update the state
|
||||||
let oldState = guild.voiceStates.get(data.user_id);
|
const oldState = guild.voiceStates.has(data.user_id) ?
|
||||||
if (oldState) oldState = oldState._clone();
|
guild.voiceStates.get(data.user_id)._clone() :
|
||||||
|
new VoiceState(guild, { user_id: data.user_id });
|
||||||
|
|
||||||
const newState = guild.voiceStates.add(data);
|
const newState = guild.voiceStates.add(data);
|
||||||
const member = guild.members.get(data.user_id);
|
|
||||||
|
// Get the member
|
||||||
|
let member = guild.members.get(data.user_id);
|
||||||
|
if (member && data.member) {
|
||||||
|
member._patch(data.member);
|
||||||
|
} else if (data.member && data.member.user && data.member.joined_at) {
|
||||||
|
member = guild.members.add(data.member);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Emit event
|
||||||
if (member) {
|
if (member) {
|
||||||
if (member.user.id === client.user.id && data.channel_id) {
|
if (member.user.id === client.user.id && data.channel_id) client.emit('self.voiceStateUpdate', data);
|
||||||
client.emit('self.voiceStateUpdate', data);
|
|
||||||
}
|
|
||||||
client.emit(Events.VOICE_STATE_UPDATE, oldState, newState);
|
client.emit(Events.VOICE_STATE_UPDATE, oldState, newState);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -27,7 +37,7 @@ class VoiceStateUpdateHandler extends AbstractHandler {
|
|||||||
/**
|
/**
|
||||||
* Emitted whenever a member changes voice state - e.g. joins/leaves a channel, mutes/unmutes.
|
* Emitted whenever a member changes voice state - e.g. joins/leaves a channel, mutes/unmutes.
|
||||||
* @event Client#voiceStateUpdate
|
* @event Client#voiceStateUpdate
|
||||||
* @param {?VoiceState} oldState The voice state before the update
|
* @param {VoiceState} oldState The voice state before the update
|
||||||
* @param {VoiceState} newState The voice state after the update
|
* @param {VoiceState} newState The voice state after the update
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user