diff --git a/src/bot.ts b/src/bot.ts index 61c0271..1b8f8dd 100644 --- a/src/bot.ts +++ b/src/bot.ts @@ -96,7 +96,7 @@ export default class { }); this.client.on('ready', async () => { - console.log(`Ready! Invite the bot with https://discordapp.com/oauth2/authorize?client_id=${this.clientId}&scope=bot&permissions=36760640`); + console.log(`Ready! Invite the bot with https://discordapp.com/oauth2/authorize?client_id=${this.clientId}&scope=bot&permissions=36752448`); }); this.client.on('error', console.error); diff --git a/src/utils/loading-message.ts b/src/utils/loading-message.ts index a5a2fa1..53a2aed 100644 --- a/src/utils/loading-message.ts +++ b/src/utils/loading-message.ts @@ -43,7 +43,7 @@ export default class { if (reactionToRemove) { // eslint-disable-next-line no-await-in-loop - await reactionToRemove.remove(); + await reactionToRemove.users.remove(this.msg.client.user!.id); } else { isRemoving = false; } @@ -64,15 +64,17 @@ export default class { this.isStopped = true; - if (str) { - if (wasAlreadyStopped) { - await this.msg.edit(str); - } else { - await Promise.all([this.msg.reactions.removeAll(), this.msg.edit(str)]); - } - } else { - await this.msg.reactions.removeAll(); - } + const editPromise = str ? this.msg.edit(str) : null; + const reactPromise = str && !wasAlreadyStopped ? (async () => { + await this.msg.fetch(); + await Promise.all(this.msg.reactions.cache.map(async react => { + if (react.me) { + await react.users.remove(this.msg.client.user!.id); + } + })); + })() : null; + + await Promise.all([editPromise, reactPromise]); return this.msg; }