Skip to content

Commit

Permalink
fix(Message): flags not being parsed on some edits (#5886)
Browse files Browse the repository at this point in the history
* fix(Message): flags not being parsed on some edits

* refactor(MessageManager): access cache once
  • Loading branch information
monbrey committed Jun 23, 2021
1 parent 1816a93 commit 2d7c12b
Show file tree
Hide file tree
Showing 4 changed files with 29 additions and 11 deletions.
16 changes: 10 additions & 6 deletions src/managers/MessageManager.js
Expand Up @@ -120,16 +120,20 @@ class MessageManager extends BaseManager {
* @returns {Promise<Message>}
*/
async edit(message, options) {
message = this.resolveID(message);
if (!message) throw new TypeError('INVALID_TYPE', 'message', 'MessageResolvable');
const messageID = this.resolveID(message);
if (!messageID) throw new TypeError('INVALID_TYPE', 'message', 'MessageResolvable');

const { data, files } = await (options instanceof APIMessage ? options : APIMessage.create(this, options))
const { data, files } = await (options instanceof APIMessage
? options
: APIMessage.create(message instanceof Message ? message : this, options)
)
.resolveData()
.resolveFiles();
const d = await this.client.api.channels[this.channel.id].messages[message].patch({ data, files });
const d = await this.client.api.channels[this.channel.id].messages[messageID].patch({ data, files });

if (this.cache.has(message)) {
const clone = this.cache.get(message)._clone();
const existing = this.cache.get(messageID);
if (existing) {
const clone = existing._clone();
clone._patch(d);
return clone;
}
Expand Down
17 changes: 14 additions & 3 deletions src/structures/APIMessage.js
Expand Up @@ -74,6 +74,16 @@ class APIMessage {
return this.target instanceof Message;
}

/**
* Wether or not the target is a message manager
* @type {boolean}
* @readonly
*/
get isMessageManager() {
const MessageManager = require('../managers/MessageManager');
return this.target instanceof MessageManager;
}

/**
* Whether or not the target is an interaction
* @type {boolean}
Expand Down Expand Up @@ -156,9 +166,9 @@ class APIMessage {
}

let flags;
if (this.isMessage) {
if (this.isMessage || this.isMessageManager) {
// eslint-disable-next-line eqeqeq
flags = this.options.flags != null ? new MessageFlags(this.options.flags).bitfield : this.target.flags.bitfield;
flags = this.options.flags != null ? new MessageFlags(this.options.flags).bitfield : this.target.flags?.bitfield;
} else if (isInteraction && this.options.ephemeral) {
flags = MessageFlags.FLAGS.EPHEMERAL;
}
Expand Down Expand Up @@ -300,5 +310,6 @@ module.exports = APIMessage;

/**
* A target for a message.
* @typedef {TextChannel|DMChannel|User|GuildMember|Webhook|WebhookClient|Interaction|InteractionWebhook} MessageTarget
* @typedef {TextChannel|DMChannel|User|GuildMember|Webhook|WebhookClient|Interaction|InteractionWebhook|
* Message|MessageManager} MessageTarget
*/
2 changes: 1 addition & 1 deletion src/structures/Message.js
Expand Up @@ -559,7 +559,7 @@ class Message extends Base {
* .catch(console.error);
*/
edit(options) {
return this.channel.messages.edit(this.id, options);
return this.channel.messages.edit(this, options);
}

/**
Expand Down
5 changes: 4 additions & 1 deletion typings/index.d.ts
Expand Up @@ -205,6 +205,7 @@ declare module 'discord.js' {
public readonly isUser: boolean;
public readonly isWebhook: boolean;
public readonly isMessage: boolean;
public readonly isMessageManager: boolean;
public readonly isInteraction: boolean;
public files: unknown[] | null;
public options: MessageOptions | WebhookMessageOptions;
Expand Down Expand Up @@ -3560,7 +3561,9 @@ declare module 'discord.js' {
| User
| GuildMember
| Webhook
| WebhookClient;
| WebhookClient
| Message
| MessageManager;

type MessageType =
| 'DEFAULT'
Expand Down

0 comments on commit 2d7c12b

Please sign in to comment.