trivious 1.3.20 → 1.3.22
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +1445 -67
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +973 -3
- package/dist/index.d.ts +973 -3
- package/dist/index.js +1434 -10
- package/dist/index.js.map +1 -1
- package/package.json +3 -2
- package/dist/core/client/trivious.client.cjs +0 -90
- package/dist/core/client/trivious.client.cjs.map +0 -1
- package/dist/core/client/trivious.client.d.cts +0 -3
- package/dist/core/client/trivious.client.d.ts +0 -3
- package/dist/core/client/trivious.client.js +0 -88
- package/dist/core/client/trivious.client.js.map +0 -1
- package/dist/core/commands/command.base.cjs +0 -224
- package/dist/core/commands/command.base.cjs.map +0 -1
- package/dist/core/commands/command.base.d.cts +0 -3
- package/dist/core/commands/command.base.d.ts +0 -3
- package/dist/core/commands/command.base.js +0 -214
- package/dist/core/commands/command.base.js.map +0 -1
- package/dist/core/commands/contextcommand.base.cjs +0 -98
- package/dist/core/commands/contextcommand.base.cjs.map +0 -1
- package/dist/core/commands/contextcommand.base.d.cts +0 -3
- package/dist/core/commands/contextcommand.base.d.ts +0 -3
- package/dist/core/commands/contextcommand.base.js +0 -93
- package/dist/core/commands/contextcommand.base.js.map +0 -1
- package/dist/core/commands/subcommand.base.cjs +0 -96
- package/dist/core/commands/subcommand.base.cjs.map +0 -1
- package/dist/core/commands/subcommand.base.d.cts +0 -3
- package/dist/core/commands/subcommand.base.d.ts +0 -3
- package/dist/core/commands/subcommand.base.js +0 -91
- package/dist/core/commands/subcommand.base.js.map +0 -1
- package/dist/core/components/component.base.cjs +0 -111
- package/dist/core/components/component.base.cjs.map +0 -1
- package/dist/core/components/component.base.d.cts +0 -3
- package/dist/core/components/component.base.d.ts +0 -3
- package/dist/core/components/component.base.js +0 -106
- package/dist/core/components/component.base.js.map +0 -1
- package/dist/core/events/interactionCreate.cjs +0 -68
- package/dist/core/events/interactionCreate.cjs.map +0 -1
- package/dist/core/events/interactionCreate.d.cts +0 -10
- package/dist/core/events/interactionCreate.d.ts +0 -10
- package/dist/core/events/interactionCreate.js +0 -66
- package/dist/core/events/interactionCreate.js.map +0 -1
- package/dist/core/registry/command.registry.cjs +0 -56
- package/dist/core/registry/command.registry.cjs.map +0 -1
- package/dist/core/registry/command.registry.d.cts +0 -3
- package/dist/core/registry/command.registry.d.ts +0 -3
- package/dist/core/registry/command.registry.js +0 -54
- package/dist/core/registry/command.registry.js.map +0 -1
- package/dist/core/registry/component.registry.cjs +0 -42
- package/dist/core/registry/component.registry.cjs.map +0 -1
- package/dist/core/registry/component.registry.d.cts +0 -3
- package/dist/core/registry/component.registry.d.ts +0 -3
- package/dist/core/registry/component.registry.js +0 -40
- package/dist/core/registry/component.registry.js.map +0 -1
- package/dist/core/registry/event.registry.cjs +0 -57
- package/dist/core/registry/event.registry.cjs.map +0 -1
- package/dist/core/registry/event.registry.d.cts +0 -3
- package/dist/core/registry/event.registry.d.ts +0 -3
- package/dist/core/registry/event.registry.js +0 -51
- package/dist/core/registry/event.registry.js.map +0 -1
- package/dist/core/registry/index.cjs +0 -49
- package/dist/core/registry/index.cjs.map +0 -1
- package/dist/core/registry/index.d.cts +0 -19
- package/dist/core/registry/index.d.ts +0 -19
- package/dist/core/registry/index.js +0 -39
- package/dist/core/registry/index.js.map +0 -1
- package/dist/core/registry/module.registry.cjs +0 -57
- package/dist/core/registry/module.registry.cjs.map +0 -1
- package/dist/core/registry/module.registry.d.cts +0 -3
- package/dist/core/registry/module.registry.d.ts +0 -3
- package/dist/core/registry/module.registry.js +0 -55
- package/dist/core/registry/module.registry.js.map +0 -1
- package/dist/index-BPaYmWRO.d.ts +0 -927
- package/dist/index-CU2Xl9Xo.d.cts +0 -927
- package/dist/shared/typings/client.cjs +0 -4
- package/dist/shared/typings/client.cjs.map +0 -1
- package/dist/shared/typings/client.d.cts +0 -3
- package/dist/shared/typings/client.d.ts +0 -3
- package/dist/shared/typings/client.js +0 -3
- package/dist/shared/typings/client.js.map +0 -1
- package/dist/shared/typings/commands.cjs +0 -4
- package/dist/shared/typings/commands.cjs.map +0 -1
- package/dist/shared/typings/commands.d.cts +0 -3
- package/dist/shared/typings/commands.d.ts +0 -3
- package/dist/shared/typings/commands.js +0 -3
- package/dist/shared/typings/commands.js.map +0 -1
- package/dist/shared/typings/components.cjs +0 -22
- package/dist/shared/typings/components.cjs.map +0 -1
- package/dist/shared/typings/components.d.cts +0 -3
- package/dist/shared/typings/components.d.ts +0 -3
- package/dist/shared/typings/components.js +0 -19
- package/dist/shared/typings/components.js.map +0 -1
- package/dist/shared/typings/events.cjs +0 -4
- package/dist/shared/typings/events.cjs.map +0 -1
- package/dist/shared/typings/events.d.cts +0 -3
- package/dist/shared/typings/events.d.ts +0 -3
- package/dist/shared/typings/events.js +0 -3
- package/dist/shared/typings/events.js.map +0 -1
- package/dist/shared/typings/index.cjs +0 -56
- package/dist/shared/typings/index.cjs.map +0 -1
- package/dist/shared/typings/index.d.cts +0 -3
- package/dist/shared/typings/index.d.ts +0 -3
- package/dist/shared/typings/index.js +0 -9
- package/dist/shared/typings/index.js.map +0 -1
- package/dist/shared/typings/module.cjs +0 -4
- package/dist/shared/typings/module.cjs.map +0 -1
- package/dist/shared/typings/module.d.cts +0 -3
- package/dist/shared/typings/module.d.ts +0 -3
- package/dist/shared/typings/module.js +0 -3
- package/dist/shared/typings/module.js.map +0 -1
- package/dist/shared/typings/permissions.cjs +0 -22
- package/dist/shared/typings/permissions.cjs.map +0 -1
- package/dist/shared/typings/permissions.d.cts +0 -3
- package/dist/shared/typings/permissions.d.ts +0 -3
- package/dist/shared/typings/permissions.js +0 -19
- package/dist/shared/typings/permissions.js.map +0 -1
- package/dist/shared/typings/registry.cjs +0 -63
- package/dist/shared/typings/registry.cjs.map +0 -1
- package/dist/shared/typings/registry.d.cts +0 -51
- package/dist/shared/typings/registry.d.ts +0 -51
- package/dist/shared/typings/registry.js +0 -61
- package/dist/shared/typings/registry.js.map +0 -1
- package/dist/shared/utility/functions.cjs +0 -81
- package/dist/shared/utility/functions.cjs.map +0 -1
- package/dist/shared/utility/functions.d.cts +0 -56
- package/dist/shared/utility/functions.d.ts +0 -56
- package/dist/shared/utility/functions.js +0 -74
- package/dist/shared/utility/functions.js.map +0 -1
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import { resolveUserPath } from '../../shared/utility/functions.js';
|
|
2
|
-
import CommandRegistry from './command.registry.js';
|
|
3
|
-
import ComponentRegistry from './component.registry.js';
|
|
4
|
-
import EventRegistry from './event.registry.js';
|
|
5
|
-
import ModuleRegistry from './module.registry.js';
|
|
6
|
-
import path from 'node:path';
|
|
7
|
-
|
|
8
|
-
const registries = () => ({
|
|
9
|
-
commands: new CommandRegistry(),
|
|
10
|
-
components: new ComponentRegistry(),
|
|
11
|
-
events: new EventRegistry(),
|
|
12
|
-
modules: new ModuleRegistry(),
|
|
13
|
-
async loadAll(options) {
|
|
14
|
-
const corePaths = options.corePaths;
|
|
15
|
-
const corePath = options.corePath;
|
|
16
|
-
await Promise.all([
|
|
17
|
-
this.commands.load(
|
|
18
|
-
corePath ? resolveUserPath(path.join(corePath, "commands")) : corePaths?.commandsPath ? resolveUserPath(corePaths.commandsPath) : void 0
|
|
19
|
-
),
|
|
20
|
-
this.components.load(
|
|
21
|
-
corePath ? resolveUserPath(path.join(corePath, "components")) : corePaths?.componentsPath ? resolveUserPath(corePaths.componentsPath) : void 0
|
|
22
|
-
),
|
|
23
|
-
this.events.load(
|
|
24
|
-
corePath ? resolveUserPath(path.join(corePath, "events")) : corePaths?.eventsPath ? resolveUserPath(corePaths.eventsPath) : void 0
|
|
25
|
-
),
|
|
26
|
-
this.modules.load(
|
|
27
|
-
corePath ? resolveUserPath(path.join(corePath, "modules")) : corePaths?.modulesPath ? resolveUserPath(corePaths.modulesPath) : void 0
|
|
28
|
-
)
|
|
29
|
-
]);
|
|
30
|
-
},
|
|
31
|
-
bind(client) {
|
|
32
|
-
this.events.bind(client);
|
|
33
|
-
this.modules.bind(client);
|
|
34
|
-
}
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
export { registries };
|
|
38
|
-
//# sourceMappingURL=index.js.map
|
|
39
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/core/registry/index.ts"],"names":[],"mappings":";;;;;;;AAcO,MAAM,aAAa,OAAO;AAAA,EAChC,QAAA,EAAU,IAAI,eAAA,EAAgB;AAAA,EAC9B,UAAA,EAAY,IAAI,iBAAA,EAAkB;AAAA,EAClC,MAAA,EAAQ,IAAI,aAAA,EAAc;AAAA,EAC1B,OAAA,EAAS,IAAI,cAAA,EAAe;AAAA,EAE5B,MAAM,QAAQ,OAAA,EAAgC;AAC7C,IAAA,MAAM,YAAY,OAAA,CAAQ,SAAA;AAC1B,IAAA,MAAM,WAAW,OAAA,CAAQ,QAAA;AAEzB,IAAA,MAAM,QAAQ,GAAA,CAAI;AAAA,MACjB,KAAK,QAAA,CAAS,IAAA;AAAA,QACb,QAAA,GACG,eAAA,CAAgB,IAAA,CAAK,IAAA,CAAK,QAAA,EAAU,UAAU,CAAC,CAAA,GAC/C,SAAA,EAAW,YAAA,GACV,eAAA,CAAgB,SAAA,CAAU,YAAY,CAAA,GACtC;AAAA,OACL;AAAA,MACA,KAAK,UAAA,CAAW,IAAA;AAAA,QACf,QAAA,GACG,eAAA,CAAgB,IAAA,CAAK,IAAA,CAAK,QAAA,EAAU,YAAY,CAAC,CAAA,GACjD,SAAA,EAAW,cAAA,GACV,eAAA,CAAgB,SAAA,CAAU,cAAc,CAAA,GACxC;AAAA,OACL;AAAA,MACA,KAAK,MAAA,CAAO,IAAA;AAAA,QACX,QAAA,GACG,eAAA,CAAgB,IAAA,CAAK,IAAA,CAAK,QAAA,EAAU,QAAQ,CAAC,CAAA,GAC7C,SAAA,EAAW,UAAA,GACV,eAAA,CAAgB,SAAA,CAAU,UAAU,CAAA,GACpC;AAAA,OACL;AAAA,MACA,KAAK,OAAA,CAAQ,IAAA;AAAA,QACZ,QAAA,GACG,eAAA,CAAgB,IAAA,CAAK,IAAA,CAAK,QAAA,EAAU,SAAS,CAAC,CAAA,GAC9C,SAAA,EAAW,WAAA,GACV,eAAA,CAAgB,SAAA,CAAU,WAAW,CAAA,GACrC;AAAA;AACL,KACA,CAAA;AAAA,EACF,CAAA;AAAA,EAEA,KAAK,MAAA,EAAwB;AAC5B,IAAA,IAAA,CAAK,MAAA,CAAO,KAAK,MAAM,CAAA;AACvB,IAAA,IAAA,CAAK,OAAA,CAAQ,KAAK,MAAM,CAAA;AAAA,EACzB;AACD,CAAA","file":"index.js","sourcesContent":["import { TriviousClientOptions } from \"../../shared/typings/client.js\";\nimport { resolveUserPath } from \"../../shared/utility/functions.js\";\nimport TriviousClient from \"../client/trivious.client.js\";\nimport CommandRegistry from \"./command.registry.js\";\nimport ComponentRegistry from \"./component.registry.js\";\nimport EventRegistry from \"./event.registry.js\";\nimport ModuleRegistry from \"./module.registry.js\";\nimport path from \"node:path\";\n\n/**\n * Create new registries.\n *\n * @returns {{ commands: CommandRegistry; components: ComponentRegistry; events: EventRegistry; modules: any; loadAll(options: TriviousClientOptions): any; bind(client: TriviousClient): void; }}\n */\nexport const registries = () => ({\n\tcommands: new CommandRegistry(),\n\tcomponents: new ComponentRegistry(),\n\tevents: new EventRegistry(),\n\tmodules: new ModuleRegistry(),\n\n\tasync loadAll(options: TriviousClientOptions) {\n\t\tconst corePaths = options.corePaths;\n\t\tconst corePath = options.corePath;\n\n\t\tawait Promise.all([\n\t\t\tthis.commands.load(\n\t\t\t\tcorePath\n\t\t\t\t\t? resolveUserPath(path.join(corePath, \"commands\"))\n\t\t\t\t\t: corePaths?.commandsPath\n\t\t\t\t\t\t? resolveUserPath(corePaths.commandsPath)\n\t\t\t\t\t\t: undefined\n\t\t\t),\n\t\t\tthis.components.load(\n\t\t\t\tcorePath\n\t\t\t\t\t? resolveUserPath(path.join(corePath, \"components\"))\n\t\t\t\t\t: corePaths?.componentsPath\n\t\t\t\t\t\t? resolveUserPath(corePaths.componentsPath)\n\t\t\t\t\t\t: undefined\n\t\t\t),\n\t\t\tthis.events.load(\n\t\t\t\tcorePath\n\t\t\t\t\t? resolveUserPath(path.join(corePath, \"events\"))\n\t\t\t\t\t: corePaths?.eventsPath\n\t\t\t\t\t\t? resolveUserPath(corePaths.eventsPath)\n\t\t\t\t\t\t: undefined\n\t\t\t),\n\t\t\tthis.modules.load(\n\t\t\t\tcorePath\n\t\t\t\t\t? resolveUserPath(path.join(corePath, \"modules\"))\n\t\t\t\t\t: corePaths?.modulesPath\n\t\t\t\t\t\t? resolveUserPath(corePaths.modulesPath)\n\t\t\t\t\t\t: undefined\n\t\t\t),\n\t\t]);\n\t},\n\n\tbind(client: TriviousClient) {\n\t\tthis.events.bind(client);\n\t\tthis.modules.bind(client);\n\t},\n});\n"]}
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var discord_js = require('discord.js');
|
|
4
|
-
var functions_js = require('../../shared/utility/functions.js');
|
|
5
|
-
var index_js = require('../../shared/typings/index.js');
|
|
6
|
-
var fs = require('fs');
|
|
7
|
-
var node_path = require('node:path');
|
|
8
|
-
|
|
9
|
-
class ModuleRegistry extends index_js.BaseRegistry {
|
|
10
|
-
items = new discord_js.Collection();
|
|
11
|
-
/**
|
|
12
|
-
* Load all modules.
|
|
13
|
-
*
|
|
14
|
-
* @async
|
|
15
|
-
* @param {string} [directory=getCorePath({ coreDirectory: "module" })]
|
|
16
|
-
* @returns {Promise<this>}
|
|
17
|
-
*/
|
|
18
|
-
async load(directory = functions_js.getCorePath({ coreDirectory: "module" })) {
|
|
19
|
-
if (!await functions_js.exists(directory)) {
|
|
20
|
-
return this;
|
|
21
|
-
}
|
|
22
|
-
const entries = await fs.promises.readdir(directory, { withFileTypes: true });
|
|
23
|
-
for (const entry of entries) {
|
|
24
|
-
const fullPath = node_path.join(directory, entry.name);
|
|
25
|
-
if (!entry.isDirectory()) continue;
|
|
26
|
-
const moduleFiles = (await fs.promises.readdir(fullPath)).filter(
|
|
27
|
-
(file) => (file.endsWith(".ts") || file.endsWith(".js")) && !file.startsWith("index.") && !file.endsWith(".d.ts")
|
|
28
|
-
);
|
|
29
|
-
for (const file of moduleFiles) {
|
|
30
|
-
const moduleEvent = await this.importFile(node_path.join(fullPath, file));
|
|
31
|
-
if (!moduleEvent || !moduleEvent.events) continue;
|
|
32
|
-
this.items.set(moduleEvent.name, moduleEvent);
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
return this;
|
|
36
|
-
}
|
|
37
|
-
/**
|
|
38
|
-
* Bind all loaded modules to their client event respectively.
|
|
39
|
-
*
|
|
40
|
-
* @param {TriviousClient} client
|
|
41
|
-
*/
|
|
42
|
-
bind(client) {
|
|
43
|
-
for (const mod of this.items.values()) {
|
|
44
|
-
for (const [eventName, handler] of Object.entries(mod.events)) {
|
|
45
|
-
if (typeof handler !== "function") continue;
|
|
46
|
-
const listener = (...args) => {
|
|
47
|
-
void handler(client, ...args);
|
|
48
|
-
};
|
|
49
|
-
client.on(eventName, listener);
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
module.exports = ModuleRegistry;
|
|
56
|
-
//# sourceMappingURL=module.registry.cjs.map
|
|
57
|
-
//# sourceMappingURL=module.registry.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/core/registry/module.registry.ts"],"names":["BaseRegistry","Collection","getCorePath","exists","fs","join"],"mappings":";;;;;;;;AAeA,MAAO,uBAAqCA,qBAAA,CAAqB;AAAA,EACtD,KAAA,GAAQ,IAAIC,qBAAA,EAA2B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASjD,MAAM,KAAK,SAAA,GAAoBC,wBAAA,CAAY,EAAE,aAAA,EAAe,QAAA,EAAU,CAAA,EAAkB;AACvF,IAAA,IAAI,CAAE,MAAMC,mBAAA,CAAO,SAAS,CAAA,EAAI;AAC/B,MAAA,OAAO,IAAA;AAAA,IACR;AAEA,IAAA,MAAM,OAAA,GAAU,MAAMC,WAAA,CAAG,OAAA,CAAQ,WAAW,EAAE,aAAA,EAAe,MAAM,CAAA;AAEnE,IAAA,KAAA,MAAW,SAAS,OAAA,EAAS;AAC5B,MAAA,MAAM,QAAA,GAAWC,cAAA,CAAK,SAAA,EAAW,KAAA,CAAM,IAAI,CAAA;AAC3C,MAAA,IAAI,CAAC,KAAA,CAAM,WAAA,EAAY,EAAG;AAE1B,MAAA,MAAM,WAAA,GAAA,CAAe,MAAMD,WAAA,CAAG,OAAA,CAAQ,QAAQ,CAAA,EAAG,MAAA;AAAA,QAChD,WACE,IAAA,CAAK,QAAA,CAAS,KAAK,CAAA,IAAK,KAAK,QAAA,CAAS,KAAK,CAAA,KAC5C,CAAC,KAAK,UAAA,CAAW,QAAQ,KACzB,CAAC,IAAA,CAAK,SAAS,OAAO;AAAA,OACxB;AAEA,MAAA,KAAA,MAAW,QAAQ,WAAA,EAAa;AAC/B,QAAA,MAAM,cAAc,MAAM,IAAA,CAAK,WAAmBC,cAAA,CAAK,QAAA,EAAU,IAAI,CAAC,CAAA;AACtE,QAAA,IAAI,CAAC,WAAA,IAAe,CAAC,WAAA,CAAY,MAAA,EAAQ;AAEzC,QAAA,IAAA,CAAK,KAAA,CAAM,GAAA,CAAI,WAAA,CAAY,IAAA,EAAM,WAAW,CAAA;AAAA,MAC7C;AAAA,IACD;AAEA,IAAA,OAAO,IAAA;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,KAAK,MAAA,EAAwB;AAC5B,IAAA,KAAA,MAAW,GAAA,IAAO,IAAA,CAAK,KAAA,CAAM,MAAA,EAAO,EAAG;AACtC,MAAA,KAAA,MAAW,CAAC,WAAW,OAAO,CAAA,IAAK,OAAO,OAAA,CAAQ,GAAA,CAAI,MAAO,CAAA,EAAG;AAC/D,QAAA,IAAI,OAAO,YAAY,UAAA,EAAY;AAEnC,QAAA,MAAM,QAAA,GAAW,IAAI,IAAA,KAAoB;AACxC,UAAA,KAAM,OAAA,CAAgE,MAAA,EAAQ,GAAG,IAAI,CAAA;AAAA,QACtF,CAAA;AAEA,QAAC,MAAA,CAAO,EAAA,CAAW,SAAA,EAAW,QAAQ,CAAA;AAAA,MACvC;AAAA,IACD;AAAA,EACD;AACD","file":"module.registry.cjs","sourcesContent":["import { Collection } from \"discord.js\";\nimport { exists, getCorePath } from \"../../shared/utility/functions.js\";\nimport { BaseRegistry, Module } from \"../../shared/typings/index.js\";\nimport { promises as fs } from \"fs\";\nimport { join } from \"node:path\";\nimport TriviousClient from \"../client/trivious.client.js\";\n\n/**\n * Registry to load, get and bind modules.\n *\n * @export\n * @class ModuleRegistry\n * @typedef {ModuleRegistry}\n * @extends {BaseRegistry<Module>}\n */\nexport default class ModuleRegistry extends BaseRegistry<Module> {\n\tprotected items = new Collection<string, Module>();\n\n\t/**\n\t * Load all modules.\n\t *\n\t * @async\n\t * @param {string} [directory=getCorePath({ coreDirectory: \"module\" })]\n\t * @returns {Promise<this>}\n\t */\n\tasync load(directory: string = getCorePath({ coreDirectory: \"module\" })): Promise<this> {\n\t\tif (!(await exists(directory))) {\n\t\t\treturn this;\n\t\t}\n\n\t\tconst entries = await fs.readdir(directory, { withFileTypes: true });\n\n\t\tfor (const entry of entries) {\n\t\t\tconst fullPath = join(directory, entry.name);\n\t\t\tif (!entry.isDirectory()) continue;\n\n\t\t\tconst moduleFiles = (await fs.readdir(fullPath)).filter(\n\t\t\t\tfile =>\n\t\t\t\t\t(file.endsWith(\".ts\") || file.endsWith(\".js\")) &&\n\t\t\t\t\t!file.startsWith(\"index.\") &&\n\t\t\t\t\t!file.endsWith(\".d.ts\")\n\t\t\t);\n\n\t\t\tfor (const file of moduleFiles) {\n\t\t\t\tconst moduleEvent = await this.importFile<Module>(join(fullPath, file));\n\t\t\t\tif (!moduleEvent || !moduleEvent.events) continue;\n\n\t\t\t\tthis.items.set(moduleEvent.name, moduleEvent);\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Bind all loaded modules to their client event respectively.\n\t *\n\t * @param {TriviousClient} client\n\t */\n\tbind(client: TriviousClient) {\n\t\tfor (const mod of this.items.values()) {\n\t\t\tfor (const [eventName, handler] of Object.entries(mod.events!)) {\n\t\t\t\tif (typeof handler !== \"function\") continue;\n\n\t\t\t\tconst listener = (...args: unknown[]) => {\n\t\t\t\t\tvoid (handler as (client: TriviousClient, ...args: unknown[]) => any)(client, ...args);\n\t\t\t\t};\n\n\t\t\t\t(client.on as any)(eventName, listener);\n\t\t\t}\n\t\t}\n\t}\n}\n"]}
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
import { Collection } from 'discord.js';
|
|
2
|
-
import { getCorePath, exists } from '../../shared/utility/functions.js';
|
|
3
|
-
import { BaseRegistry } from '../../shared/typings/index.js';
|
|
4
|
-
import { promises } from 'fs';
|
|
5
|
-
import { join } from 'node:path';
|
|
6
|
-
|
|
7
|
-
class ModuleRegistry extends BaseRegistry {
|
|
8
|
-
items = new Collection();
|
|
9
|
-
/**
|
|
10
|
-
* Load all modules.
|
|
11
|
-
*
|
|
12
|
-
* @async
|
|
13
|
-
* @param {string} [directory=getCorePath({ coreDirectory: "module" })]
|
|
14
|
-
* @returns {Promise<this>}
|
|
15
|
-
*/
|
|
16
|
-
async load(directory = getCorePath({ coreDirectory: "module" })) {
|
|
17
|
-
if (!await exists(directory)) {
|
|
18
|
-
return this;
|
|
19
|
-
}
|
|
20
|
-
const entries = await promises.readdir(directory, { withFileTypes: true });
|
|
21
|
-
for (const entry of entries) {
|
|
22
|
-
const fullPath = join(directory, entry.name);
|
|
23
|
-
if (!entry.isDirectory()) continue;
|
|
24
|
-
const moduleFiles = (await promises.readdir(fullPath)).filter(
|
|
25
|
-
(file) => (file.endsWith(".ts") || file.endsWith(".js")) && !file.startsWith("index.") && !file.endsWith(".d.ts")
|
|
26
|
-
);
|
|
27
|
-
for (const file of moduleFiles) {
|
|
28
|
-
const moduleEvent = await this.importFile(join(fullPath, file));
|
|
29
|
-
if (!moduleEvent || !moduleEvent.events) continue;
|
|
30
|
-
this.items.set(moduleEvent.name, moduleEvent);
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
return this;
|
|
34
|
-
}
|
|
35
|
-
/**
|
|
36
|
-
* Bind all loaded modules to their client event respectively.
|
|
37
|
-
*
|
|
38
|
-
* @param {TriviousClient} client
|
|
39
|
-
*/
|
|
40
|
-
bind(client) {
|
|
41
|
-
for (const mod of this.items.values()) {
|
|
42
|
-
for (const [eventName, handler] of Object.entries(mod.events)) {
|
|
43
|
-
if (typeof handler !== "function") continue;
|
|
44
|
-
const listener = (...args) => {
|
|
45
|
-
void handler(client, ...args);
|
|
46
|
-
};
|
|
47
|
-
client.on(eventName, listener);
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
export { ModuleRegistry as default };
|
|
54
|
-
//# sourceMappingURL=module.registry.js.map
|
|
55
|
-
//# sourceMappingURL=module.registry.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/core/registry/module.registry.ts"],"names":["fs"],"mappings":";;;;;;AAeA,MAAO,uBAAqC,YAAA,CAAqB;AAAA,EACtD,KAAA,GAAQ,IAAI,UAAA,EAA2B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASjD,MAAM,KAAK,SAAA,GAAoB,WAAA,CAAY,EAAE,aAAA,EAAe,QAAA,EAAU,CAAA,EAAkB;AACvF,IAAA,IAAI,CAAE,MAAM,MAAA,CAAO,SAAS,CAAA,EAAI;AAC/B,MAAA,OAAO,IAAA;AAAA,IACR;AAEA,IAAA,MAAM,OAAA,GAAU,MAAMA,QAAA,CAAG,OAAA,CAAQ,WAAW,EAAE,aAAA,EAAe,MAAM,CAAA;AAEnE,IAAA,KAAA,MAAW,SAAS,OAAA,EAAS;AAC5B,MAAA,MAAM,QAAA,GAAW,IAAA,CAAK,SAAA,EAAW,KAAA,CAAM,IAAI,CAAA;AAC3C,MAAA,IAAI,CAAC,KAAA,CAAM,WAAA,EAAY,EAAG;AAE1B,MAAA,MAAM,WAAA,GAAA,CAAe,MAAMA,QAAA,CAAG,OAAA,CAAQ,QAAQ,CAAA,EAAG,MAAA;AAAA,QAChD,WACE,IAAA,CAAK,QAAA,CAAS,KAAK,CAAA,IAAK,KAAK,QAAA,CAAS,KAAK,CAAA,KAC5C,CAAC,KAAK,UAAA,CAAW,QAAQ,KACzB,CAAC,IAAA,CAAK,SAAS,OAAO;AAAA,OACxB;AAEA,MAAA,KAAA,MAAW,QAAQ,WAAA,EAAa;AAC/B,QAAA,MAAM,cAAc,MAAM,IAAA,CAAK,WAAmB,IAAA,CAAK,QAAA,EAAU,IAAI,CAAC,CAAA;AACtE,QAAA,IAAI,CAAC,WAAA,IAAe,CAAC,WAAA,CAAY,MAAA,EAAQ;AAEzC,QAAA,IAAA,CAAK,KAAA,CAAM,GAAA,CAAI,WAAA,CAAY,IAAA,EAAM,WAAW,CAAA;AAAA,MAC7C;AAAA,IACD;AAEA,IAAA,OAAO,IAAA;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,KAAK,MAAA,EAAwB;AAC5B,IAAA,KAAA,MAAW,GAAA,IAAO,IAAA,CAAK,KAAA,CAAM,MAAA,EAAO,EAAG;AACtC,MAAA,KAAA,MAAW,CAAC,WAAW,OAAO,CAAA,IAAK,OAAO,OAAA,CAAQ,GAAA,CAAI,MAAO,CAAA,EAAG;AAC/D,QAAA,IAAI,OAAO,YAAY,UAAA,EAAY;AAEnC,QAAA,MAAM,QAAA,GAAW,IAAI,IAAA,KAAoB;AACxC,UAAA,KAAM,OAAA,CAAgE,MAAA,EAAQ,GAAG,IAAI,CAAA;AAAA,QACtF,CAAA;AAEA,QAAC,MAAA,CAAO,EAAA,CAAW,SAAA,EAAW,QAAQ,CAAA;AAAA,MACvC;AAAA,IACD;AAAA,EACD;AACD","file":"module.registry.js","sourcesContent":["import { Collection } from \"discord.js\";\nimport { exists, getCorePath } from \"../../shared/utility/functions.js\";\nimport { BaseRegistry, Module } from \"../../shared/typings/index.js\";\nimport { promises as fs } from \"fs\";\nimport { join } from \"node:path\";\nimport TriviousClient from \"../client/trivious.client.js\";\n\n/**\n * Registry to load, get and bind modules.\n *\n * @export\n * @class ModuleRegistry\n * @typedef {ModuleRegistry}\n * @extends {BaseRegistry<Module>}\n */\nexport default class ModuleRegistry extends BaseRegistry<Module> {\n\tprotected items = new Collection<string, Module>();\n\n\t/**\n\t * Load all modules.\n\t *\n\t * @async\n\t * @param {string} [directory=getCorePath({ coreDirectory: \"module\" })]\n\t * @returns {Promise<this>}\n\t */\n\tasync load(directory: string = getCorePath({ coreDirectory: \"module\" })): Promise<this> {\n\t\tif (!(await exists(directory))) {\n\t\t\treturn this;\n\t\t}\n\n\t\tconst entries = await fs.readdir(directory, { withFileTypes: true });\n\n\t\tfor (const entry of entries) {\n\t\t\tconst fullPath = join(directory, entry.name);\n\t\t\tif (!entry.isDirectory()) continue;\n\n\t\t\tconst moduleFiles = (await fs.readdir(fullPath)).filter(\n\t\t\t\tfile =>\n\t\t\t\t\t(file.endsWith(\".ts\") || file.endsWith(\".js\")) &&\n\t\t\t\t\t!file.startsWith(\"index.\") &&\n\t\t\t\t\t!file.endsWith(\".d.ts\")\n\t\t\t);\n\n\t\t\tfor (const file of moduleFiles) {\n\t\t\t\tconst moduleEvent = await this.importFile<Module>(join(fullPath, file));\n\t\t\t\tif (!moduleEvent || !moduleEvent.events) continue;\n\n\t\t\t\tthis.items.set(moduleEvent.name, moduleEvent);\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Bind all loaded modules to their client event respectively.\n\t *\n\t * @param {TriviousClient} client\n\t */\n\tbind(client: TriviousClient) {\n\t\tfor (const mod of this.items.values()) {\n\t\t\tfor (const [eventName, handler] of Object.entries(mod.events!)) {\n\t\t\t\tif (typeof handler !== \"function\") continue;\n\n\t\t\t\tconst listener = (...args: unknown[]) => {\n\t\t\t\t\tvoid (handler as (client: TriviousClient, ...args: unknown[]) => any)(client, ...args);\n\t\t\t\t};\n\n\t\t\t\t(client.on as any)(eventName, listener);\n\t\t\t}\n\t\t}\n\t}\n}\n"]}
|