feat(command): improve command events args

This commit is contained in:
DjDeveloperr 2020-11-15 13:08:18 +05:30
parent 7835162fd5
commit 18efd1efcc

View file

@ -150,10 +150,21 @@ export class CommandClient extends Client implements CommandClientOptions {
guild: msg.guild guild: msg.guild
} }
if (command.guildOnly === true && msg.guild === undefined) return this.emit('commandGuildOnly', { ctx, command }) if (command.guildOnly === true && msg.guild === undefined) return this.emit('commandGuildOnly', ctx, command)
if (command.dmOnly === true && msg.guild !== undefined) return this.emit('commandDmOnly', { ctx, command }) if (command.dmOnly === true && msg.guild !== undefined) return this.emit('commandDmOnly', ctx, command)
if (command.ownerOnly === true && !this.owners.includes(msg.author.id)) return this.emit('commandOwnerOnly', { ctx, command }) if (command.ownerOnly === true && !this.owners.includes(msg.author.id)) return this.emit('commandOwnerOnly', ctx, command)
if (command.botPermissions !== undefined && msg.guild !== undefined) {
const me = await msg.guild.me()
const missing: string[] = []
for (const perm of command.botPermissions) {
if (me.permissions.has(perm) === false) missing.push(perm)
}
if (missing.length !== 0) return this.emit('commandBotMissingPermissions', ctx, command, missing)
}
if (command.permissions !== undefined && msg.guild !== undefined) { if (command.permissions !== undefined && msg.guild !== undefined) {
const missing: string[] = [] const missing: string[] = []
let perms: string[] = [] let perms: string[] = []
@ -163,11 +174,11 @@ export class CommandClient extends Client implements CommandClientOptions {
const has = msg.member?.permissions.has(perm) const has = msg.member?.permissions.has(perm)
if (has !== true) missing.push(perm) if (has !== true) missing.push(perm)
} }
if (missing.length !== 0) return this.emit('commandMissingPermissions', { command, missing, ctx }) if (missing.length !== 0) return this.emit('commandMissingPermissions', command, missing, ctx)
} }
try { try {
this.emit('commandUsed', { context: ctx }) this.emit('commandUsed', ctx, command)
const beforeExecute = await awaitSync(command.beforeExecute(ctx)) const beforeExecute = await awaitSync(command.beforeExecute(ctx))
if (beforeExecute === false) return if (beforeExecute === false) return
@ -175,7 +186,7 @@ export class CommandClient extends Client implements CommandClientOptions {
const result = await awaitSync(command.execute(ctx)) const result = await awaitSync(command.execute(ctx))
command.afterExecute(ctx, result) command.afterExecute(ctx, result)
} catch (e) { } catch (e) {
this.emit('commandError', { command, parsed, error: e, ctx }) this.emit('commandError', command, ctx, e)
} }
} }
} }