Remove default embeds option..

This commit is contained in:
John Marlo 2022-04-01 15:54:01 +08:00 committed by GitHub
parent 44db21c06f
commit 2d3e6ec271
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -2,7 +2,7 @@
const { Buffer } = require('node:buffer'); const { Buffer } = require('node:buffer');
const BaseMessageComponent = require('./BaseMessageComponent'); const BaseMessageComponent = require('./BaseMessageComponent');
const MessageEmbed = require('./MessageEmbed'); const WebEmbed = require('./WebEmbed');
const { RangeError } = require('../errors'); const { RangeError } = require('../errors');
const DataResolver = require('../util/DataResolver'); const DataResolver = require('../util/DataResolver');
const MessageFlags = require('../util/MessageFlags'); const MessageFlags = require('../util/MessageFlags');
@ -188,11 +188,29 @@ class MessagePayload {
this.options.attachments = attachments; this.options.attachments = attachments;
} }
if (this.options.embeds) {
//check if embeds is an array
if (!Array.isArray(this.options.embeds)) {
this.options.embeds = [this.options.embeds];
}
//check if the embeds is an array of WebEmbed
if (!this.options.embeds.every(e => e instanceof WebEmbed)) {
throw new TypeError('WEB_EMBEDS_TYPE');
}
//while loop to make sure all embeds will be added to the content
while (this.options.embeds.length) {
const embed = this.options.embeds.shift();
const data = await embed.toMessage(true, true); //set to true hidden, shorten...
content +=`\n${data}`
}
}
this.data = { this.data = {
content, content,
tts, tts,
nonce, nonce,
embeds: this.options.embeds?.map(embed => new MessageEmbed(embed).toJSON()),
components, components,
username, username,
avatar_url: avatarURL, avatar_url: avatarURL,