Compare commits

..

1 Commits

Author SHA1 Message Date
Jacob Nguyen
62ff8e9d69 fix: autocomplete sdt.module not present 2025-03-03 21:43:02 -06:00
6 changed files with 196 additions and 1121 deletions

View File

@@ -1,33 +1,5 @@
# Changelog # Changelog
## [4.2.6](https://github.com/sern-handler/handler/compare/v4.2.5...v4.2.6) (2025-09-22)
### Miscellaneous Chores
* release 4.2.6 ([#402](https://github.com/sern-handler/handler/issues/402)) ([0eecb08](https://github.com/sern-handler/handler/commit/0eecb08e87e26102030ccf6ef38ddd81051ec373))
## [4.2.5](https://github.com/sern-handler/handler/compare/v4.2.4...v4.2.5) (2025-08-31)
### Bug Fixes
* make message module warn rather than throwing ([#399](https://github.com/sern-handler/handler/issues/399)) ([797442e](https://github.com/sern-handler/handler/commit/797442ece3999bf2cb6b5ba0688ce0177e72a22f))
## [4.2.4](https://github.com/sern-handler/handler/compare/v4.2.3...v4.2.4) (2025-03-06)
### Bug Fixes
* flat autocomplete ([#395](https://github.com/sern-handler/handler/issues/395)) ([89d7409](https://github.com/sern-handler/handler/commit/89d74095363befddc3222b9e5c89c35e7c6457b9))
## [4.2.3](https://github.com/sern-handler/handler/compare/v4.2.2...v4.2.3) (2025-03-04)
### Bug Fixes
* autocomplete sdt.module not present ([#393](https://github.com/sern-handler/handler/issues/393)) ([2414992](https://github.com/sern-handler/handler/commit/2414992b73a40065464b20f2d53826c78fcd3a5f))
## [4.2.2](https://github.com/sern-handler/handler/compare/v4.2.1...v4.2.2) (2025-02-03) ## [4.2.2](https://github.com/sern-handler/handler/compare/v4.2.1...v4.2.2) (2025-02-03)

1191
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@@ -1,7 +1,7 @@
{ {
"name": "@sern/handler", "name": "@sern/handler",
"packageManager": "yarn@3.5.0", "packageManager": "yarn@3.5.0",
"version": "4.2.6", "version": "4.2.2",
"description": "A complete, customizable, typesafe, & reactive framework for discord bots.", "description": "A complete, customizable, typesafe, & reactive framework for discord bots.",
"main": "./dist/index.js", "main": "./dist/index.js",
"module": "./dist/index.js", "module": "./dist/index.js",
@@ -47,7 +47,7 @@
"@types/node-cron": "^3.0.11", "@types/node-cron": "^3.0.11",
"@typescript-eslint/eslint-plugin": "5.58.0", "@typescript-eslint/eslint-plugin": "5.58.0",
"@typescript-eslint/parser": "5.59.1", "@typescript-eslint/parser": "5.59.1",
"discord.js": "^14.22.1", "discord.js": "^14.14.1",
"eslint": "8.39.0", "eslint": "8.39.0",
"typescript": "5.0.2", "typescript": "5.0.2",
"vitest": "^1.6.0" "vitest": "^1.6.0"

View File

@@ -33,8 +33,8 @@ export function interactionHandler(deps: UnpackedDependencies, defaultPrefix?: s
// handles autocomplete // handles autocomplete
if(isAutocomplete(event)) { if(isAutocomplete(event)) {
const lookupTable = module.locals['@sern/lookup-table'] as Map<string, SernAutocompleteData> const lookupTable = module.locals['@sern/lookup-table'] as Map<string, SernAutocompleteData>
const subCommandGroup = event.options.getSubcommandGroup(false) ?? "", const subCommandGroup = event.options.getSubcommandGroup() ?? "",
subCommand = event.options.getSubcommand(false) ?? "", subCommand = event.options.getSubcommand() ?? "",
option = event.options.getFocused(true), option = event.options.getFocused(true),
fullPath = path.posix.join("<parent>", subCommandGroup, subCommand, option.name) fullPath = path.posix.join("<parent>", subCommandGroup, subCommand, option.name)

View File

@@ -36,7 +36,7 @@ export function messageHandler (deps: UnpackedDependencies, defaultPrefix?: stri
const [prefix] = fmt(message.content, defaultPrefix); const [prefix] = fmt(message.content, defaultPrefix);
let module = mg.get(`${prefix}_T`) ?? mg.get(`${prefix}_B`) as Module; let module = mg.get(`${prefix}_T`) ?? mg.get(`${prefix}_B`) as Module;
if(!module) { if(!module) {
log?.warning({ message: 'Possibly undefined behavior: could not find a static id to resolve' }); throw Error('Possibly undefined behavior: could not find a static id to resolve')
} }
const payload = { module, args: [Context.wrap(message, defaultPrefix), createSDT(module, deps, undefined)] } const payload = { module, args: [Context.wrap(message, defaultPrefix), createSDT(module, deps, undefined)] }
const result = await callPlugins(payload) const result = await callPlugins(payload)

View File

@@ -1,58 +1,44 @@
import * as Files from "../core/module-loading"; import * as Files from '../core/module-loading'
import { once } from "node:events"; import { once } from 'node:events';
import { createLookupTable, resultPayload } from "../core/functions"; import { createLookupTable, resultPayload } from '../core/functions';
import { CommandType } from "../core/structures/enums"; import { CommandType } from '../core/structures/enums';
import { Module, SernOptionsData } from "../types/core-modules"; import { Module, SernOptionsData } from '../types/core-modules';
import type { UnpackedDependencies, Wrapper } from "../types/utility"; import type { UnpackedDependencies, Wrapper } from '../types/utility';
import { callInitPlugins } from "./event-utils"; import { callInitPlugins } from './event-utils';
import { SernAutocompleteData } from ".."; import { SernAutocompleteData } from '..';
import { Events } from "discord.js";
export default async function ( export default async function(dirs: string | string[], deps : UnpackedDependencies) {
dirs: string | string[], const { '@sern/client': client,
deps: UnpackedDependencies, '@sern/logger': log,
) { '@sern/emitter': sEmitter,
const { '@sern/modules': commands } = deps;
"@sern/client": client, log?.info({ message: "Waiting on discord client to be ready..." })
"@sern/logger": log, await once(client, "ready");
"@sern/emitter": sEmitter, log?.info({ message: "Client signaled ready, registering modules" });
"@sern/modules": commands,
} = deps;
log?.info({ message: "Waiting on discord client to be ready..." });
await once(client, Events.ClientReady);
log?.info({ message: "Client signaled ready, registering modules" });
// https://observablehq.com/@ehouais/multiple-promises-as-an-async-generator // https://observablehq.com/@ehouais/multiple-promises-as-an-async-generator
// possibly optimize to concurrently import modules // possibly optimize to concurrently import modules
const directories = Array.isArray(dirs) ? dirs : [dirs]; const directories = Array.isArray(dirs) ? dirs : [dirs];
for (const dir of directories) { for (const dir of directories) {
for await (const path of Files.readRecursive(dir)) { for await (const path of Files.readRecursive(dir)) {
const { module } = await Files.importModule<Module>(path); let { module } = await Files.importModule<Module>(path);
const validType = const validType = module.type >= CommandType.Text && module.type <= CommandType.ChannelSelect;
module.type >= CommandType.Text && if(!validType) {
module.type <= CommandType.ChannelSelect; throw Error(`Found ${module.name} at ${module.meta.absPath}, which has incorrect \`type\``);
if (!validType) { }
throw Error( const resultModule = await callInitPlugins(module, deps, true);
`Found ${module.name} at ${module.meta.absPath}, which has incorrect \`type\``,
);
}
const resultModule = await callInitPlugins(module, deps, true);
if ( if(module.type === CommandType.Both || module.type === CommandType.Slash) {
module.type === CommandType.Both || const options = (Reflect.get(module, 'options') ?? []) as SernOptionsData[];
module.type === CommandType.Slash const lookupTable = createLookupTable(options)
) { module.locals['@sern/lookup-table'] = lookupTable;
const options = (Reflect.get(module, "options") ?? }
[]) as SernOptionsData[]; // FREEZE! no more writing!!
const lookupTable = createLookupTable(options); commands.set(resultModule.meta.id, Object.freeze(resultModule));
module.locals["@sern/lookup-table"] = lookupTable; sEmitter.emit('module.register', resultPayload('success', resultModule));
} }
// FREEZE! no more writing!!
commands.set(resultModule.meta.id, Object.freeze(resultModule));
sEmitter.emit("module.register", resultPayload("success", resultModule));
} }
} sEmitter.emit('modulesLoaded');
sEmitter.emit("modulesLoaded");
} }