From f67e846a7064835dad2e99102cf797f750818837 Mon Sep 17 00:00:00 2001 From: Assayyaad Date: Wed, 4 Sep 2024 19:10:32 +0800 Subject: [PATCH] =?UTF-8?q?refactor:=20=D8=AA=D8=AD=D8=B3=D9=8A=D9=86=20?= =?UTF-8?q?=D8=A8=D8=B9=D8=B6=20=D8=A7=D9=84=D8=AC=D8=B2=D8=A6=D9=8A=D8=A7?= =?UTF-8?q?=D8=AA=20=D9=81=D9=8A=20=D8=A7=D9=84=D9=83=D9=88=D8=AF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/class/bot.js | 34 ++++++++++++--------------------- src/events/interactionCreate.js | 2 +- src/exports.js | 2 +- 3 files changed, 14 insertions(+), 24 deletions(-) diff --git a/src/class/bot.js b/src/class/bot.js index 4103193..f307fad 100644 --- a/src/class/bot.js +++ b/src/class/bot.js @@ -29,7 +29,7 @@ export class Bot extends Client { channel: {} }, brand: { - name: 'HalfBot', + name: 'Bot', color: 0xffffff, logoUrl: 'https://cdn.discordapp.com/embed/avatars/0.png' } @@ -62,27 +62,23 @@ export class Bot extends Client { * @returns {Promise} * @private */ - async run(options) { - if (!options.directories) options.directories = {} - - await Promise.all([ - storeFolderPaths([options.directories.root || 'bot'], { deepSearch: true }), - this.storeData(options.directories.data || 'data') - ]) + async run({ directories, token }) { + const folders = Object.assign({ root: 'bot', data: 'data' }, directories) + await Promise.all([storeFolderPaths([folders.root], { deepSearch: true }), this.storeData(folders.data)]) await this.registerAllModules() this.listenToEvents() - await this.login(options.token) + await this.login(token) } /** * Inject data from the workspace files. - * @param {string} directory - The path to the directory the json data files. + * @param {string} folder - The path to the directory the json data files. * @returns {Promise} */ - async storeData(directory) { - const files = await readFolderPaths(resolve(directory), { deepSearch: false }) + async storeData(folder) { + const files = await readFolderPaths(resolve(folder), { deepSearch: false }) if (files.length === 0) return for (let i = 0; i < files.length; i++) { @@ -183,18 +179,15 @@ export class Bot extends Client { * @param {BotEvent} event - The bot event module. * @returns {SuccessRecord} */ - registerEvent(event) { + registerEvent({ data, execute }) { /** @type {SuccessRecord} */ const record = { name: '', - type: event.data.module, + type: data.module, deployment: 'global' } - if (event.data.module === 'event') { - /** @type {ClientEvent} */ // @ts-expect-error - const e = event - const { data, execute } = e + if (data.module === 'event') { /** @type {ClientEventFunction} */ const func = (args) => execute(this, args) @@ -202,10 +195,7 @@ export class Bot extends Client { else this.on(data.name, func) record.name = data.name - } else if (event.data.module === 'event-repeat') { - /** @type {RepeatingEvent} */ // @ts-expect-error - const e = event - const { data, execute } = e + } else if (data.module === 'event-repeat') { /** @type {RepeatingEventFunction} */ const func = async () => { let first = true diff --git a/src/events/interactionCreate.js b/src/events/interactionCreate.js index af69dfc..e3f6dde 100644 --- a/src/events/interactionCreate.js +++ b/src/events/interactionCreate.js @@ -24,7 +24,7 @@ export async function interactionCreate(interaction) { let reply = await command.execute(interaction) if (!reply) { - quickReply('Done', brand) + quickReply(':)👍', brand) return } diff --git a/src/exports.js b/src/exports.js index 1c3e4b3..f218af2 100644 --- a/src/exports.js +++ b/src/exports.js @@ -1,4 +1,4 @@ +export * from './options.js' export { Bot } from './class/bot.js' export { asNumber, asString } from './func/color.js' export { asEmbed, applyStyle } from './func/style.js' -export * from './options.js'