commandkit 0.1.11-dev.20250216074741 → 0.1.11-dev.20250216081126

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.d.mts CHANGED
@@ -294,7 +294,7 @@ interface CommandHandlerOptions {
294
294
  /**
295
295
  * Path to the user's commands.
296
296
  */
297
- commandsPath: string;
297
+ commandsPath?: string;
298
298
  /**
299
299
  * An array of developer guild IDs.
300
300
  */
@@ -342,7 +342,7 @@ declare class CommandHandler {
342
342
  */
343
343
  interface EventHandlerOptions {
344
344
  client: Client;
345
- eventsPath: string;
345
+ eventsPath?: string;
346
346
  commandKitInstance: CommandKit;
347
347
  }
348
348
 
package/dist/index.d.ts CHANGED
@@ -294,7 +294,7 @@ interface CommandHandlerOptions {
294
294
  /**
295
295
  * Path to the user's commands.
296
296
  */
297
- commandsPath: string;
297
+ commandsPath?: string;
298
298
  /**
299
299
  * An array of developer guild IDs.
300
300
  */
@@ -342,7 +342,7 @@ declare class CommandHandler {
342
342
  */
343
343
  interface EventHandlerOptions {
344
344
  client: Client;
345
- eventsPath: string;
345
+ eventsPath?: string;
346
346
  commandKitInstance: CommandKit;
347
347
  }
348
348
 
package/dist/index.js CHANGED
@@ -31,11 +31,11 @@ export const chatInput: SlashCommand = async (ctx) => {
31
31
  export const message: MessageCommand = async (ctx) => {
32
32
  await ctx.message.reply('Hello from ${name}!');
33
33
  };
34
- `.trim();await(0,import_promises7.writeFile)((0,import_path3.join)(cmdPath,"command.ts"),commandFile),console.log(colors_default.green(`Command ${colors_default.magenta(name)} created at ${colors_default.blue(cmdPath)}/command.ts`))}async function generateEvent(name,customPath){let eventPath=(0,import_path3.join)(customPath||EVENTS_DIR,name);import_fs.existsSync||await(0,import_promises7.mkdir)(eventPath,{recursive:!0});let filename="event.ts";if((0,import_fs.existsSync)((0,import_path3.join)(eventPath,filename))){let count=(await(0,import_promises7.readdir)(eventPath)).length;filename=`${String(count).padStart(2,"0")}_${filename}.ts`}let eventFile=`
34
+ `.trim();await(0,import_promises7.writeFile)((0,import_path3.join)(cmdPath,"command.ts"),commandFile),console.log(colors_default.green(`Command ${colors_default.magenta(name)} created at ${colors_default.blue(formatPath(cmdPath))}/command.ts`))}async function generateEvent(name,customPath){let eventPath=(0,import_path3.join)(customPath||EVENTS_DIR,name);(0,import_fs.existsSync)(eventPath)||await(0,import_promises7.mkdir)(eventPath,{recursive:!0});let filename="event.ts";if((0,import_fs.existsSync)((0,import_path3.join)(eventPath,filename))){let count=(await(0,import_promises7.readdir)(eventPath)).length;filename=`${String(count).padStart(2,"0")}_${filename}`}let eventFile=`
35
35
  export default async function on${name[0].toUpperCase()+name.slice(1)}() {
36
36
  console.log('${name} event fired!');
37
37
  };
38
- `.trim();await(0,import_promises7.writeFile)((0,import_path3.join)(eventPath,filename),eventFile),console.log(colors_default.green(`Event ${colors_default.magenta(name)} created at ${colors_default.blue(eventPath)}/${colors_default.magenta(filename)}`))}async function generateLocale(locale,commandName,customPath){(!import_discord13.Locale[locale]||/^\d+$/.test(locale))&&panic(`Invalid locale: ${locale}`),commandName||panic("Command name is required.");let localePath=(0,import_path3.join)(customPath||LOCALES_DIR,locale);(0,import_fs.existsSync)(localePath)||await(0,import_promises7.mkdir)(localePath,{recursive:!0}),(0,import_fs.existsSync)((0,import_path3.join)(localePath,`${commandName}.json`))&&panic(`Locale file for ${commandName} already exists.`);let localeFile={command:{name:`${commandName}`,description:`${commandName} command`},translations:{}};await(0,import_promises7.writeFile)((0,import_path3.join)(localePath,`${commandName}.json`),JSON.stringify(localeFile,null,2)),console.log(colors_default.green(`Locale file for ${colors_default.magenta(commandName)} created at ${colors_default.blue(localePath)}/${colors_default.magenta(`${commandName}.json`)}`))}var import_promises7,import_path3,import_discord13,import_fs,BASE_PATH,COMMANDS_DIR,EVENTS_DIR,LOCALES_DIR,init_generators=__esm({"src/cli/generators.ts"(){"use strict";init_cjs_shims();import_promises7=require("fs/promises"),import_path3=require("path"),import_discord13=require("discord.js");init_common();import_fs=require("fs");init_colors();BASE_PATH=process.cwd(),COMMANDS_DIR=(0,import_path3.join)(BASE_PATH,"src/app/commands"),EVENTS_DIR=(0,import_path3.join)(BASE_PATH,"src/app/events"),LOCALES_DIR=(0,import_path3.join)(BASE_PATH,"src/app/locales");__name(generateCommand,"generateCommand");__name(generateEvent,"generateEvent");__name(generateLocale,"generateLocale")}});var index_exports={};__export(index_exports,{ActionRow:()=>ActionRow,AppCommandHandler:()=>AppCommandHandler,Button:()=>Button,ButtonKit:()=>ButtonKit,CacheProvider:()=>CacheProvider,CommandExecutionMode:()=>CommandExecutionMode,CommandKit:()=>CommandKit,CommandKitEnvironment:()=>CommandKitEnvironment,CommandKitEnvironmentType:()=>CommandKitEnvironmentType,CommandsRouter:()=>CommandsRouter,Context:()=>Context,DefaultLocalizationStrategy:()=>DefaultLocalizationStrategy,DefaultLogger:()=>DefaultLogger,ElementType:()=>ElementType,EventInterceptor:()=>EventInterceptor,EventsRouter:()=>EventsRouter,Fragment:()=>Fragment,Localization:()=>Localization,Logger:()=>Logger,MemoryCache:()=>MemoryCache,MessageCommandOptions:()=>MessageCommandOptions,MessageCommandParser:()=>MessageCommandParser,MiddlewareContext:()=>MiddlewareContext,Modal:()=>Modal,ModalKit:()=>ModalKit,ParagraphInput:()=>ParagraphInput,ShortInput:()=>ShortInput,TextInput:()=>TextInput,afterCommand:()=>afterCommand,bootstrapCommandkitCLI:()=>bootstrapCommandkitCLI,cache:()=>cache,cacheLife:()=>cacheLife,cacheTag:()=>cacheTag,cancelAfterCommand:()=>cancelAfterCommand,createElement:()=>createElement,createLogger:()=>createLogger,default:()=>index_default,defineConfig:()=>defineConfig,dmOnly:()=>dmOnly,exitContext:()=>exitContext,exitMiddleware:()=>exitMiddleware,getCommandKit:()=>getCommandKit,getConfig:()=>getConfig,getContext:()=>getContext,getElement:()=>getElement,guildOnly:()=>guildOnly,invalidate:()=>invalidate,isCachedFunction:()=>isCachedFunction,isCommandKitElement:()=>isCommandKitElement,makeContextAwareFunction:()=>makeContextAwareFunction,redirect:()=>redirect,rethrow:()=>rethrow,revalidate:()=>revalidate,super_duper_secret_internal_for_use_cache_directive_of_commandkit_cli_do_not_use_it_directly_or_you_will_be_fired_from_your_job_kthxbai:()=>useCache,useEnvironment:()=>useEnvironment,version:()=>version});module.exports=__toCommonJS(index_exports);init_cjs_shims();init_cjs_shims();var import_node_events=__toESM(require("events"));init_cjs_shims();init_cjs_shims();var import_discord4=require("discord.js");init_cjs_shims();var import_rfdc=__toESM(require("rfdc")),clone=(0,import_rfdc.default)();init_colors();init_cjs_shims();var import_path=__toESM(require("path")),import_promises=__toESM(require("fs/promises"));async function getFilePaths(directory,nesting){let filePaths=[];if(!directory)return filePaths;let files=await import_promises.default.readdir(directory,{withFileTypes:!0});for(let file of files){let filePath=import_path.default.join(directory,file.name);file.isFile()&&filePaths.push(filePath),nesting&&file.isDirectory()&&(filePaths=[...filePaths,...await getFilePaths(filePath,!0)])}return filePaths}__name(getFilePaths,"getFilePaths");async function getFolderPaths(directory,nesting){let folderPaths=[];if(!directory)return folderPaths;let folders=await import_promises.default.readdir(directory,{withFileTypes:!0});for(let folder of folders){let folderPath=import_path.default.join(directory,folder.name);folder.isDirectory()&&(folderPaths.push(folderPath),nesting&&(folderPaths=[...folderPaths,...await getFolderPaths(folderPath,!0)]))}return folderPaths}__name(getFolderPaths,"getFolderPaths");init_cjs_shims();var import_path2=__toESM(require("path"));function toFileURL(filePath){return"file://"+import_path2.default.resolve(filePath).replace(/\\\\|\\/g,"/")}__name(toFileURL,"toFileURL");init_cjs_shims();init_colors();init_cjs_shims();init_cjs_shims();init_cjs_shims();var import_node_async_hooks=require("async_hooks");init_cjs_shims();var CommandKitErrorCodes={GuildOnlyException:Symbol("kGuildOnlyException"),DMOnlyException:Symbol("kDMOnlyException"),ExitMiddleware:Symbol("kExitMiddleware"),ForwardedCommand:Symbol("kForwardedCommand"),InvalidCommandPrefix:Symbol("kInvalidCommandPrefix")};function createCommandKitError(code){let error=new Error;return Reflect.set(error,"code",code),error}__name(createCommandKitError,"createCommandKitError");function isCommandKitError(error){if(!(error instanceof Error))return!1;let code=Reflect.get(error,"code");for(let key in CommandKitErrorCodes)if(CommandKitErrorCodes[key]===code)return!0;return!1}__name(isCommandKitError,"isCommandKitError");function isErrorType(error,code){if(!isCommandKitError(error))return!1;let errorCode=Reflect.get(error,"code");return errorCode?Array.isArray(code)?code.includes(errorCode):errorCode===code:!1}__name(isErrorType,"isErrorType");var import_discord=require("discord.js");var context=new import_node_async_hooks.AsyncLocalStorage;function exitContext(fn){return context.exit(fn)}__name(exitContext,"exitContext");function makeContextAwareFunction(env,fn,finalizer){return __name((...args)=>context.run(env,async()=>{try{return await fn(...args)}catch(e){if(isCommandKitError(e)){let code=Reflect.get(e,"code"),interaction=env.variables.get("interaction");if(!interaction)return;switch(code){case CommandKitErrorCodes.GuildOnlyException:{interaction.isRepliable()&&await interaction.reply({content:"This command is only available in guilds.",flags:import_discord.MessageFlags.Ephemeral});return}case CommandKitErrorCodes.DMOnlyException:{interaction.isRepliable()&&await interaction.reply({content:"This command is only available in DMs.",flags:import_discord.MessageFlags.Ephemeral});return}}return}env.setExecutionError(e)}finally{if(typeof finalizer=="function")try{await finalizer(...args)}catch{}}}),"_fn")}__name(makeContextAwareFunction,"makeContextAwareFunction");function getCommandKit(strict=!1){var _a;let kit=((_a=context.getStore())==null?void 0:_a.commandkit)??CommandKit.instance;if(!kit&&strict)throw new Error("CommandKit instance not found.");return kit}__name(getCommandKit,"getCommandKit");function getContext(){return context.getStore()}__name(getContext,"getContext");function useEnvironment(){let ctx=context.getStore();if(!ctx)throw new Error("No commandkit environment found. Please make sure you are inside commandkit handler.");return ctx}__name(useEnvironment,"useEnvironment");function guildOnly(){let interaction=useEnvironment().variables.get("interaction");if(!interaction)throw new Error("No interaction found in environment.");if(!interaction.guild){let error=new Error("This command is only available in guilds.");throw Reflect.set(error,"code",CommandKitErrorCodes.GuildOnlyException),error}}__name(guildOnly,"guildOnly");function dmOnly(){let interaction=useEnvironment().variables.get("interaction");if(!interaction)throw new Error("No interaction found in environment.");if(interaction.guild){let error=new Error("This command is only available in DMs.");throw Reflect.set(error,"code",CommandKitErrorCodes.DMOnlyException),error}}__name(dmOnly,"dmOnly");init_colors();var execHandlerKind={autocomplete:"Autocomplete",messageContextMenu:"MessageContextMenu",userContextMenu:"UserContextMenu",chatInput:"SlashCommand",message:"Message"},TextColorMap={0:colors_default.blue,1:colors_default.green,2:colors_default.yellow,3:colors_default.red,4:colors_default.white},TextBgColorMap={0:colors_default.bgBlue,1:colors_default.bgGreen,2:colors_default.bgYellow,3:colors_default.bgRed,4:colors_default.bgWhite},BoxChars={vertical:"\u2502",horizontalDown:"\u252C",horizontalUp:"\u2534",verticalRight:"\u251C",corner:"\u2514"},_DefaultLogger=class _DefaultLogger{constructor(stdout=process.stdout,stderr=process.stderr){this.stdout=stdout;this.stderr=stderr;this.logger=new console.Console(this.stdout,this.stderr)}logger;_formatTime(date){let hours=date.getHours().toString().padStart(2,"0"),minutes=date.getMinutes().toString().padStart(2,"0"),seconds=date.getSeconds().toString().padStart(2,"0"),millis=date.getMilliseconds().toString().padStart(3,"0");return`${hours}:${minutes}:${seconds}.${millis}`}_getContext(){let ctx=getContext();if(!ctx)return"";let kind=ctx.variables.get("execHandlerKind"),commandHandler=ctx.variables.get("commandHandlerType"),command=ctx.variables.get("currentCommandName");if(!kind&&!commandHandler)return"";let h=execHandlerKind[kind];if(!h&&!commandHandler)return"";let t2=commandHandler==="app"?"(app \u2728) ":"",cmdText=command?colors_default.magenta(`/${command}`)+" ":"";return colors_default.dim(`${BoxChars.vertical} `)+colors_default.cyanBright(`${t2}${cmdText}${h?colors_default.gray(`[${h}]`):""}`.trim())}_getLevelLabel(level){let label;switch(level){case 0:label="[DEBUG]";break;case 1:label="[INFO]";break;case 2:label="[WARN]";break;case 3:label="[ERROR]";break;default:label="[LOG]"}return`${TextBgColorMap[level](colors_default.whiteBright(` ${label} `))} `}_getPrefix(level){let timestamp=this._formatTime(new Date);return`${this._getLevelLabel(level)}${colors_default.dim(BoxChars.vertical)} ${colors_default.dim(timestamp)}`}_log(level,...args){let prefix=this._getPrefix(level),context2=this._getContext(),colorFn=TextColorMap[level];context2?this.logger.log(`${prefix}
38
+ `.trim();await(0,import_promises7.writeFile)((0,import_path3.join)(eventPath,filename),eventFile),console.log(colors_default.green(`Event ${colors_default.magenta(name)} created at ${colors_default.blue(formatPath(eventPath))}/${colors_default.magenta(filename)}`))}async function generateLocale(locale,commandName,customPath){Object.fromEntries(Object.entries(import_discord13.Locale).map(([k,v])=>[v,k]))[locale]||panic(`Invalid locale: ${locale}`),commandName||panic("Command name is required.");let localePath=(0,import_path3.join)(customPath||LOCALES_DIR,locale);(0,import_fs.existsSync)(localePath)||await(0,import_promises7.mkdir)(localePath,{recursive:!0}),(0,import_fs.existsSync)((0,import_path3.join)(localePath,`${commandName}.json`))&&panic(`Locale file for ${commandName} already exists.`);let localeFile={command:{name:`${commandName}`,description:`${commandName} command`},translations:{}};await(0,import_promises7.writeFile)((0,import_path3.join)(localePath,`${commandName}.json`),JSON.stringify(localeFile,null,2)),console.log(colors_default.green(`Locale file for ${colors_default.magenta(commandName)} created at ${colors_default.blue(formatPath(localePath))}/${colors_default.magenta(`${commandName}.json`)}`))}var import_promises7,import_path3,import_discord13,import_fs,BASE_PATH,COMMANDS_DIR,EVENTS_DIR,LOCALES_DIR,formatPath,init_generators=__esm({"src/cli/generators.ts"(){"use strict";init_cjs_shims();import_promises7=require("fs/promises"),import_path3=require("path"),import_discord13=require("discord.js");init_common();import_fs=require("fs");init_colors();BASE_PATH=process.cwd(),COMMANDS_DIR=(0,import_path3.join)(BASE_PATH,"src/app/commands"),EVENTS_DIR=(0,import_path3.join)(BASE_PATH,"src/app/events"),LOCALES_DIR=(0,import_path3.join)(BASE_PATH,"src/app/locales"),formatPath=__name(path4=>path4.replace(process.cwd(),".").replace(/\\/g,"/"),"formatPath");__name(generateCommand,"generateCommand");__name(generateEvent,"generateEvent");__name(generateLocale,"generateLocale")}});var index_exports={};__export(index_exports,{ActionRow:()=>ActionRow,AppCommandHandler:()=>AppCommandHandler,Button:()=>Button,ButtonKit:()=>ButtonKit,CacheProvider:()=>CacheProvider,CommandExecutionMode:()=>CommandExecutionMode,CommandKit:()=>CommandKit,CommandKitEnvironment:()=>CommandKitEnvironment,CommandKitEnvironmentType:()=>CommandKitEnvironmentType,CommandsRouter:()=>CommandsRouter,Context:()=>Context,DefaultLocalizationStrategy:()=>DefaultLocalizationStrategy,DefaultLogger:()=>DefaultLogger,ElementType:()=>ElementType,EventInterceptor:()=>EventInterceptor,EventsRouter:()=>EventsRouter,Fragment:()=>Fragment,Localization:()=>Localization,Logger:()=>Logger,MemoryCache:()=>MemoryCache,MessageCommandOptions:()=>MessageCommandOptions,MessageCommandParser:()=>MessageCommandParser,MiddlewareContext:()=>MiddlewareContext,Modal:()=>Modal,ModalKit:()=>ModalKit,ParagraphInput:()=>ParagraphInput,ShortInput:()=>ShortInput,TextInput:()=>TextInput,afterCommand:()=>afterCommand,bootstrapCommandkitCLI:()=>bootstrapCommandkitCLI,cache:()=>cache,cacheLife:()=>cacheLife,cacheTag:()=>cacheTag,cancelAfterCommand:()=>cancelAfterCommand,createElement:()=>createElement,createLogger:()=>createLogger,default:()=>index_default,defineConfig:()=>defineConfig,dmOnly:()=>dmOnly,exitContext:()=>exitContext,exitMiddleware:()=>exitMiddleware,getCommandKit:()=>getCommandKit,getConfig:()=>getConfig,getContext:()=>getContext,getElement:()=>getElement,guildOnly:()=>guildOnly,invalidate:()=>invalidate,isCachedFunction:()=>isCachedFunction,isCommandKitElement:()=>isCommandKitElement,makeContextAwareFunction:()=>makeContextAwareFunction,redirect:()=>redirect,rethrow:()=>rethrow,revalidate:()=>revalidate,super_duper_secret_internal_for_use_cache_directive_of_commandkit_cli_do_not_use_it_directly_or_you_will_be_fired_from_your_job_kthxbai:()=>useCache,useEnvironment:()=>useEnvironment,version:()=>version});module.exports=__toCommonJS(index_exports);init_cjs_shims();init_cjs_shims();var import_node_events=__toESM(require("events"));init_cjs_shims();init_cjs_shims();var import_discord4=require("discord.js");init_cjs_shims();var import_rfdc=__toESM(require("rfdc")),clone=(0,import_rfdc.default)();init_colors();init_cjs_shims();var import_path=__toESM(require("path")),import_promises=__toESM(require("fs/promises"));async function getFilePaths(directory,nesting){let filePaths=[];if(!directory)return filePaths;let files=await import_promises.default.readdir(directory,{withFileTypes:!0});for(let file of files){let filePath=import_path.default.join(directory,file.name);file.isFile()&&filePaths.push(filePath),nesting&&file.isDirectory()&&(filePaths=[...filePaths,...await getFilePaths(filePath,!0)])}return filePaths}__name(getFilePaths,"getFilePaths");async function getFolderPaths(directory,nesting){let folderPaths=[];if(!directory)return folderPaths;let folders=await import_promises.default.readdir(directory,{withFileTypes:!0});for(let folder of folders){let folderPath=import_path.default.join(directory,folder.name);folder.isDirectory()&&(folderPaths.push(folderPath),nesting&&(folderPaths=[...folderPaths,...await getFolderPaths(folderPath,!0)]))}return folderPaths}__name(getFolderPaths,"getFolderPaths");init_cjs_shims();var import_path2=__toESM(require("path"));function toFileURL(filePath){return"file://"+import_path2.default.resolve(filePath).replace(/\\\\|\\/g,"/")}__name(toFileURL,"toFileURL");init_cjs_shims();init_colors();init_cjs_shims();init_cjs_shims();init_cjs_shims();var import_node_async_hooks=require("async_hooks");init_cjs_shims();var CommandKitErrorCodes={GuildOnlyException:Symbol("kGuildOnlyException"),DMOnlyException:Symbol("kDMOnlyException"),ExitMiddleware:Symbol("kExitMiddleware"),ForwardedCommand:Symbol("kForwardedCommand"),InvalidCommandPrefix:Symbol("kInvalidCommandPrefix")};function createCommandKitError(code){let error=new Error;return Reflect.set(error,"code",code),error}__name(createCommandKitError,"createCommandKitError");function isCommandKitError(error){if(!(error instanceof Error))return!1;let code=Reflect.get(error,"code");for(let key in CommandKitErrorCodes)if(CommandKitErrorCodes[key]===code)return!0;return!1}__name(isCommandKitError,"isCommandKitError");function isErrorType(error,code){if(!isCommandKitError(error))return!1;let errorCode=Reflect.get(error,"code");return errorCode?Array.isArray(code)?code.includes(errorCode):errorCode===code:!1}__name(isErrorType,"isErrorType");var import_discord=require("discord.js");var context=new import_node_async_hooks.AsyncLocalStorage;function exitContext(fn){return context.exit(fn)}__name(exitContext,"exitContext");function makeContextAwareFunction(env,fn,finalizer){return __name((...args)=>context.run(env,async()=>{try{return await fn(...args)}catch(e){if(isCommandKitError(e)){let code=Reflect.get(e,"code"),interaction=env.variables.get("interaction");if(!interaction)return;switch(code){case CommandKitErrorCodes.GuildOnlyException:{interaction.isRepliable()&&await interaction.reply({content:"This command is only available in guilds.",flags:import_discord.MessageFlags.Ephemeral});return}case CommandKitErrorCodes.DMOnlyException:{interaction.isRepliable()&&await interaction.reply({content:"This command is only available in DMs.",flags:import_discord.MessageFlags.Ephemeral});return}}return}env.setExecutionError(e)}finally{if(typeof finalizer=="function")try{await finalizer(...args)}catch{}}}),"_fn")}__name(makeContextAwareFunction,"makeContextAwareFunction");function getCommandKit(strict=!1){var _a;let kit=((_a=context.getStore())==null?void 0:_a.commandkit)??CommandKit.instance;if(!kit&&strict)throw new Error("CommandKit instance not found.");return kit}__name(getCommandKit,"getCommandKit");function getContext(){return context.getStore()}__name(getContext,"getContext");function useEnvironment(){let ctx=context.getStore();if(!ctx)throw new Error("No commandkit environment found. Please make sure you are inside commandkit handler.");return ctx}__name(useEnvironment,"useEnvironment");function guildOnly(){let interaction=useEnvironment().variables.get("interaction");if(!interaction)throw new Error("No interaction found in environment.");if(!interaction.guild){let error=new Error("This command is only available in guilds.");throw Reflect.set(error,"code",CommandKitErrorCodes.GuildOnlyException),error}}__name(guildOnly,"guildOnly");function dmOnly(){let interaction=useEnvironment().variables.get("interaction");if(!interaction)throw new Error("No interaction found in environment.");if(interaction.guild){let error=new Error("This command is only available in DMs.");throw Reflect.set(error,"code",CommandKitErrorCodes.DMOnlyException),error}}__name(dmOnly,"dmOnly");init_colors();var execHandlerKind={autocomplete:"Autocomplete",messageContextMenu:"MessageContextMenu",userContextMenu:"UserContextMenu",chatInput:"SlashCommand",message:"Message"},TextColorMap={0:colors_default.blue,1:colors_default.green,2:colors_default.yellow,3:colors_default.red,4:colors_default.white},TextBgColorMap={0:colors_default.bgBlue,1:colors_default.bgGreen,2:colors_default.bgYellow,3:colors_default.bgRed,4:colors_default.bgWhite},BoxChars={vertical:"\u2502",horizontalDown:"\u252C",horizontalUp:"\u2534",verticalRight:"\u251C",corner:"\u2514"},_DefaultLogger=class _DefaultLogger{constructor(stdout=process.stdout,stderr=process.stderr){this.stdout=stdout;this.stderr=stderr;this.logger=new console.Console(this.stdout,this.stderr)}logger;_formatTime(date){let hours=date.getHours().toString().padStart(2,"0"),minutes=date.getMinutes().toString().padStart(2,"0"),seconds=date.getSeconds().toString().padStart(2,"0"),millis=date.getMilliseconds().toString().padStart(3,"0");return`${hours}:${minutes}:${seconds}.${millis}`}_getContext(){let ctx=getContext();if(!ctx)return"";let kind=ctx.variables.get("execHandlerKind"),commandHandler=ctx.variables.get("commandHandlerType"),command=ctx.variables.get("currentCommandName");if(!kind&&!commandHandler)return"";let h=execHandlerKind[kind];if(!h&&!commandHandler)return"";let t2=commandHandler==="app"?"(app \u2728) ":"",cmdText=command?colors_default.magenta(`/${command}`)+" ":"";return colors_default.dim(`${BoxChars.vertical} `)+colors_default.cyanBright(`${t2}${cmdText}${h?colors_default.gray(`[${h}]`):""}`.trim())}_getLevelLabel(level){let label;switch(level){case 0:label="[DEBUG]";break;case 1:label="[INFO]";break;case 2:label="[WARN]";break;case 3:label="[ERROR]";break;default:label="[LOG]"}return`${TextBgColorMap[level](colors_default.whiteBright(` ${label} `))} `}_getPrefix(level){let timestamp=this._formatTime(new Date);return`${this._getLevelLabel(level)}${colors_default.dim(BoxChars.vertical)} ${colors_default.dim(timestamp)}`}_log(level,...args){let prefix=this._getPrefix(level),context2=this._getContext(),colorFn=TextColorMap[level];context2?this.logger.log(`${prefix}
39
39
  ${context2} ${colors_default.dim(BoxChars.corner)}`,...args.map(arg=>colorFn(arg))):this.logger.log(`${prefix} ${colors_default.dim(BoxChars.corner)}`,...args.map(arg=>colorFn(arg)))}debug(...args){this._log(0,...args)}error(...args){this._log(3,...args)}log(...args){this._log(4,...args)}info(...args){this._log(1,...args)}warn(...args){this._log(2,...args)}};__name(_DefaultLogger,"DefaultLogger");var DefaultLogger=_DefaultLogger;function createLogger(options){let opt=options;if(!(opt!=null&&opt.provider))throw new Error("A logger provider must be provided.");let methods=["log","error","warn","info","debug"],impl={configure(options2){opt=options2}};for(let method of methods)impl[method]=(...args)=>{opt.provider[method](...args)};return impl}__name(createLogger,"createLogger");var Logger=createLogger({provider:new DefaultLogger});async function loadCommandsWithRest(props){if(props.reloading)if(props.client.isReady())await handleLoading(props.client,props.commands,props.devGuildIds,props.reloading,props.type);else throw new Error(colors_default.red("Cannot reload commands when client is not ready."));else props.client.once("ready",async c=>{await handleLoading(c,props.commands,props.devGuildIds,props.reloading,props.type)})}__name(loadCommandsWithRest,"loadCommandsWithRest");async function handleLoading(client,commands,devGuildIds,reloading,type){commands=commands.filter(cmd=>{var _a;return!((_a=cmd.options)!=null&&_a.deleted)});let devOnlyCommands=commands.filter(cmd=>{var _a;return(_a=cmd.options)==null?void 0:_a.devOnly}),globalCommands=commands.filter(cmd=>{var _a;return!((_a=cmd.options)!=null&&_a.devOnly)});type==="dev"?await loadDevCommands(client,devOnlyCommands,devGuildIds,reloading):type==="global"?await loadGlobalCommands(client,globalCommands,reloading):(await loadDevCommands(client,devOnlyCommands,devGuildIds,reloading),await loadGlobalCommands(client,globalCommands,reloading))}__name(handleLoading,"handleLoading");async function loadGlobalCommands(client,commands,reloading){let requestBody=commands.map(cmd=>cmd.data);await client.application.commands.set(requestBody).catch(error=>{throw new Error(colors_default.red(`Error ${reloading?"reloading":"loading"} global application commands.
40
40
  `),error)}),Logger.log(colors_default.green(`${reloading?"Reloaded":"Loaded"} ${requestBody.length} global commands.`))}__name(loadGlobalCommands,"loadGlobalCommands");async function loadDevCommands(client,commands,guildIds,reloading){let requestBody=commands.map(cmd=>cmd.data);for(let guildId of guildIds){let targetGuild=client.guilds.cache.get(guildId)||await client.guilds.fetch(guildId);if(!targetGuild){process.emitWarning(`Cannot ${reloading?"reload":"load"} commands in guild "${guildId}" - guild doesn't exist or client isn't part of the guild.`);continue}await targetGuild.commands.set(requestBody).catch(error=>{throw new Error(colors_default.red(`Error ${reloading?"reloading":"loading"} developer application commands in guild "${(targetGuild==null?void 0:targetGuild.name)||guildId}".
41
41
  `),error)}),Logger.log(colors_default.green(`${reloading?"Reloaded":"Loaded"} ${requestBody.length} developer commands in guild "${targetGuild.name}".`))}}__name(loadDevCommands,"loadDevCommands");init_cjs_shims();init_cjs_shims();function compareLocalizations(first,second){if(!first&&!second)return!0;if(!first||!second)return!1;let keys1=Object.keys(first),keys2=Object.keys(second);return keys1.length!==keys2.length?!1:keys1.every(key=>first[key]===second[key])}__name(compareLocalizations,"compareLocalizations");function compareArrays(arr1,arr2){return!arr1&&!arr2?!0:!arr1||!arr2||arr1.length!==arr2.length?!1:arr1.every((item,index)=>{let item2=arr2[index];return Object.keys(item).every(key=>Array.isArray(item[key])?compareArrays(item[key],item2[key]):key.endsWith("_localizations")?compareLocalizations(item[key],item2[key]):item[key]===item2[key])})}__name(compareArrays,"compareArrays");function areSlashCommandsDifferent(appCommand,localCommand){var _a,_b;return appCommand.options||(appCommand.options=[]),localCommand.options||(localCommand.options=[]),appCommand.description||(appCommand.description=""),localCommand.description||(localCommand.description=""),localCommand.description!==appCommand.description||((_a=localCommand.options)==null?void 0:_a.length)!==((_b=appCommand.options)==null?void 0:_b.length)||!compareLocalizations(localCommand.name_localizations,appCommand.name_localizations)||!compareLocalizations(localCommand.description_localizations,appCommand.description_localizations)?!0:!compareArrays(localCommand.options,appCommand.options)}__name(areSlashCommandsDifferent,"areSlashCommandsDifferent");init_colors();init_cjs_shims();var COMMANDKIT_CACHE_TAG=Symbol("kCommandKitCacheTag"),COMMANDKIT_IS_DEV=!!process.env.COMMANDKIT_DEV,COMMANDKIT_IS_TEST=process.env.COMMANDKIT_TEST==="true";async function registerCommands(props){if(!COMMANDKIT_IS_TEST)if(props.reloading)if(props.client.isReady())await handleRegistration(props.client,props.commands,props.devGuildIds,props.type);else throw new Error(colors_default.red("Cannot reload commands when client is not ready."));else props.client.once("ready",async c=>{await handleRegistration(c,props.commands,props.devGuildIds,props.type)})}__name(registerCommands,"registerCommands");async function handleRegistration(client,commands,devGuildIds,type){let devOnlyCommands=commands.filter(cmd=>{var _a;return(_a=cmd.options)==null?void 0:_a.devOnly}),globalCommands=commands.filter(cmd=>{var _a;return!((_a=cmd.options)!=null&&_a.devOnly)});type==="dev"?await registerDevCommands(client,devOnlyCommands,devGuildIds):type==="global"?await registerGlobalCommands(client,globalCommands):(await registerDevCommands(client,devOnlyCommands,devGuildIds),await registerGlobalCommands(client,globalCommands))}__name(handleRegistration,"handleRegistration");async function registerGlobalCommands(client,commands){var _a;let appCommandsManager=client.application.commands;await appCommandsManager.fetch();for(let command of commands){let targetCommand=appCommandsManager.cache.find(cmd=>cmd.name===command.data.name);if((_a=command.options)!=null&&_a.deleted){targetCommand?(await targetCommand.delete().catch(error=>{throw new Error(colors_default.red(`Failed to delete command "${command.data.name}" globally.
@@ -45,5 +45,5 @@ ${context2} ${colors_default.dim(BoxChars.corner)}`,...args.map(arg=>colorFn(arg
45
45
  `),error)}),Logger.log(colors_default.green(`Edited command "${command.data.name}" in ${guildCommands.guild.name}.`));continue}targetCommand||(await guildCommands.create(command.data).catch(error=>{throw new Error(colors_default.red(`Failed to register command "${command.data.name}" in ${guildCommands.guild.name}.
46
46
  `),error)}),Logger.log(colors_default.green(`Registered command "${command.data.name}" in ${guildCommands.guild.name}.`)))}}__name(registerDevCommands,"registerDevCommands");init_cjs_shims();init_cjs_shims();var import_discord2=require("discord.js");function devOnly_default({interaction,targetCommand,handlerData}){var _a,_b;if(!interaction.isAutocomplete()&&(_a=targetCommand.options)!=null&&_a.devOnly){if(interaction.inGuild()&&!handlerData.devGuildIds.includes(interaction.guildId))return interaction.reply({content:"\u274C This command can only be used inside development servers.",flags:import_discord2.MessageFlags.Ephemeral}),!0;let guildMember=(_b=interaction.guild)==null?void 0:_b.members.cache.get(interaction.user.id),memberRoles=guildMember==null?void 0:guildMember.roles.cache,hasDevRole=!1;if(memberRoles==null||memberRoles.forEach(role=>{handlerData.devRoleIds.includes(role.id)&&(hasDevRole=!0)}),!(handlerData.devUserIds.includes(interaction.user.id)||hasDevRole))return interaction.reply({content:"\u274C This command can only be used by developers.",flags:import_discord2.MessageFlags.Ephemeral}),!0}}__name(devOnly_default,"default");init_cjs_shims();var import_discord3=require("discord.js");function permissions_default({interaction,targetCommand}){var _a,_b,_c,_d;if(interaction.isAutocomplete())return;let userPermissions=interaction.memberPermissions,userPermissionsRequired=(_a=targetCommand.options)==null?void 0:_a.userPermissions,missingUserPermissions=[];typeof userPermissionsRequired=="string"&&(userPermissionsRequired=[userPermissionsRequired]);let botPermissions=(_c=(_b=interaction.guild)==null?void 0:_b.members.me)==null?void 0:_c.permissions,botPermissionsRequired=(_d=targetCommand.options)==null?void 0:_d.botPermissions,missingBotPermissions=[];if(typeof botPermissionsRequired=="string"&&(botPermissionsRequired=[botPermissionsRequired]),!(userPermissionsRequired!=null&&userPermissionsRequired.length)&&!(botPermissionsRequired!=null&&botPermissionsRequired.length))return;if(userPermissions&&userPermissionsRequired)for(let permission of userPermissionsRequired)userPermissions.has(permission)||missingUserPermissions.push(permission);if(botPermissions&&botPermissionsRequired)for(let permission of botPermissionsRequired)botPermissions.has(permission)||missingBotPermissions.push(permission);if(!missingUserPermissions.length&&!missingBotPermissions.length)return;let pattern=/([a-z])([A-Z])|([A-Z]+)([A-Z][a-z])/g;missingUserPermissions=missingUserPermissions.map(str=>str.replace(pattern,"$1$3 $2$4")),missingBotPermissions=missingBotPermissions.map(str=>str.replace(pattern,"$1$3 $2$4"));let embedDescription="",formatter=new Intl.ListFormat("en",{style:"long",type:"conjunction"}),getPermissionWord=__name(permissions=>permissions.length===1?"permission":"permissions","getPermissionWord");if(missingUserPermissions.length){let formattedPermissions=missingUserPermissions.map(p=>`\`${p}\``),permissionsString=formatter.format(formattedPermissions);embedDescription+=`- You must have the ${permissionsString} ${getPermissionWord(missingUserPermissions)} to be able to run this command.
47
47
  `}if(missingBotPermissions.length){let formattedPermissions=missingBotPermissions.map(p=>`\`${p}\``),permissionsString=formatter.format(formattedPermissions);embedDescription+=`- I must have the ${permissionsString} ${getPermissionWord(missingBotPermissions)} to be able to execute this command.
48
- `}let embed=new import_discord3.EmbedBuilder().setTitle(":x: Missing permissions!").setDescription(embedDescription).setColor("Red");return interaction.reply({embeds:[embed],flags:import_discord3.MessageFlags.Ephemeral}),!0}__name(permissions_default,"default");var validations_default=[devOnly_default,permissions_default];init_cjs_shims();var import_node_crypto=require("crypto");var _data,_CommandKitEnvironment=class _CommandKitEnvironment{constructor(commandkit){this.commandkit=commandkit;__privateAdd(this,_data,{executionError:null,type:null,variables:new Map,deferredFunctions:new Map,marker:"",markStart:0,markEnd:0})}getExecutionError(){return __privateGet(this,_data).executionError}setExecutionError(error){if(__privateGet(this,_data).executionError)throw new Error("Execution error already set.");__privateGet(this,_data).executionError=error}getType(){let type=__privateGet(this,_data).type;if(!type)throw new Error("Environment type not set.");return type}setType(type){__privateGet(this,_data).type=type}get variables(){return __privateGet(this,_data).variables}registerDeferredFunction(fn){let id=(0,import_node_crypto.randomUUID)();return __privateGet(this,_data).deferredFunctions.set(id,fn),id}clearDeferredFunction(id){__privateGet(this,_data).deferredFunctions.delete(id)}async runDeferredFunctions(){for(let[id,fn]of __privateGet(this,_data).deferredFunctions)try{await fn(this)}catch(e){this.commandkit.emit("unhandledDeferredFunctionRejection",e)}finally{this.clearDeferredFunction(id)}}clearAllDeferredFunctions(){__privateGet(this,_data).deferredFunctions.clear()}markStart(marker){__privateGet(this,_data).marker=marker,__privateGet(this,_data).markStart=performance.now()}markEnd(){__privateGet(this,_data).markEnd||(__privateGet(this,_data).markEnd=performance.now())}getMarker(){return __privateGet(this,_data).marker}getExecutionTime(){return Math.abs(__privateGet(this,_data).markEnd-__privateGet(this,_data).markStart)}};_data=new WeakMap,__name(_CommandKitEnvironment,"CommandKitEnvironment");var CommandKitEnvironment=_CommandKitEnvironment,CommandKitEnvironmentType=(CommandKitEnvironmentType2=>(CommandKitEnvironmentType2.CommandHandler="COMMAND_HANDLER",CommandKitEnvironmentType2))(CommandKitEnvironmentType||{});function afterCommand(fn){let env=getContext();if(!env)throw new Error("after must be called inside commandkit handler.");return env.registerDeferredFunction(fn)}__name(afterCommand,"afterCommand");function cancelAfterCommand(id){let env=getContext();if(!env)throw new Error("cancelAfter must be called inside commandkit handler.");env.clearDeferredFunction(id)}__name(cancelAfterCommand,"cancelAfterCommand");init_cjs_shims();init_cjs_shims();var _Localization=class _Localization{constructor(commandkit,config){this.commandkit=commandkit;this.config=config;let strategy=this.commandkit.config.localizationStrategy,{locale,target}=this.config;this.t=(translatable,args)=>strategy.translate({args,key:translatable,locale,scope:target})}t;getStrategy(){return this.commandkit.config.localizationStrategy}getDefaultLocale(){return this.commandkit.config.defaultLocale}getLocale(){return this.config.locale}getTarget(){return this.config.target}};__name(_Localization,"Localization");var Localization=_Localization;init_cjs_shims();function exitMiddleware(){throw createCommandKitError(CommandKitErrorCodes.ExitMiddleware)}__name(exitMiddleware,"exitMiddleware");function rethrow(error){if(isCommandKitError(error))throw error}__name(rethrow,"rethrow");function redirect(){throw createCommandKitError(CommandKitErrorCodes.ForwardedCommand)}__name(redirect,"redirect");init_cjs_shims();init_cjs_shims();var _CacheProvider=class _CacheProvider{};__name(_CacheProvider,"CacheProvider");var CacheProvider=_CacheProvider;init_cjs_shims();var _cache,_MemoryCache=class _MemoryCache extends CacheProvider{constructor(){super(...arguments);__privateAdd(this,_cache,new Map)}async get(key){let entry=__privateGet(this,_cache).get(key);if(entry){if(entry.ttl&&Date.now()>entry.ttl){__privateGet(this,_cache).delete(key);return}return entry}}async set(key,value,ttl){let entry={value,ttl:ttl!=null?Date.now()+ttl:void 0};__privateGet(this,_cache).set(key,entry)}async exists(key){return __privateGet(this,_cache).has(key)}async delete(key){__privateGet(this,_cache).delete(key)}async clear(){__privateGet(this,_cache).clear()}async expire(key,ttl){let entry=__privateGet(this,_cache).get(key);if(!entry)return;let _ttl=Date.now()+ttl;if(_ttl<Date.now()){__privateGet(this,_cache).delete(key);return}entry.ttl=_ttl}};_cache=new WeakMap,__name(_MemoryCache,"MemoryCache");var MemoryCache=_MemoryCache;init_cjs_shims();var import_node_async_hooks2=require("async_hooks");var import_node_crypto2=require("crypto"),import_ms=__toESM(require("ms"));var cacheContext=new import_node_async_hooks2.AsyncLocalStorage,fnStore=new Map,DEFAULT_TTL=(0,import_ms.default)("15m"),CACHE_FN_ID=`__cache_fn_id_${Date.now()}__${Math.random()}__`,CACHED_FN_SYMBOL=Symbol("commandkit.cache.sentinel");function md5(data){return(0,import_node_crypto2.createHash)("md5").update(data).digest("hex")}__name(md5,"md5");function getCacheProvider(){let provider=getCommandKit(!0).getCacheProvider();if(!provider)throw new Error("Cache provider was not found, please provide a cache provider to commandkit.");return provider}__name(getCacheProvider,"getCacheProvider");function useCache(fn,id,params){let isLocal=id===CACHE_FN_ID;if(id&&!isLocal)throw new Error("Illegal use of cache function.");let fnId=(0,import_node_crypto2.randomUUID)(),memo=__name((...args)=>{let keyHash=(isLocal?params==null?void 0:params.name:null)??md5(args.length?`${fnId}:${args.join(":")}`:fnId),resolvedTTL=isLocal&&(params==null?void 0:params.ttl)!=null?typeof params.ttl=="string"?(0,import_ms.default)(params.ttl):params.ttl:null;return cacheContext.run({params:{name:keyHash,ttl:resolvedTTL??DEFAULT_TTL}},async()=>{let provider=getCacheProvider(),context2=cacheContext.getStore();if(!context2)throw new Error("Cache context was not found.");let storedFn=fnStore.get(keyHash),effectiveKey=(storedFn==null?void 0:storedFn.key)??context2.params.name,cached=await provider.get(effectiveKey);if(cached&&cached.value!=null)return cached.value;let result=await fn(...args);if(result!=null){let finalKey=context2.params.name,ttl=context2.params.ttl??DEFAULT_TTL;await provider.set(finalKey,result,ttl),fnStore.set(keyHash,{key:finalKey,hash:keyHash,ttl,original:fn,memo})}return result})},"memo");return Object.prototype.hasOwnProperty.call(fn,CACHED_FN_SYMBOL)||Object.defineProperty(memo,CACHED_FN_SYMBOL,{get(){return!0},configurable:!1,enumerable:!1}),memo}__name(useCache,"useCache");function cache(fn,params){return useCache(fn,CACHE_FN_ID,params)}__name(cache,"cache");function cacheTag(tag){let context2=cacheContext.getStore();if(!context2)throw new Error("cacheTag() must be called inside a cached function.");if(!tag)throw new Error("cacheTag() must be called with a tag name.");context2.params.name=tag}__name(cacheTag,"cacheTag");function cacheLife(ttl){let context2=cacheContext.getStore();if(!context2)throw new Error("cacheLife() must be called inside a cached function.");if(ttl==null||!["string","number"].includes(typeof ttl))throw new Error("cacheLife() must be called with a ttl.");context2.params.ttl=typeof ttl=="string"?(0,import_ms.default)(ttl):ttl}__name(cacheLife,"cacheLife");async function invalidate(tag){let provider=getCacheProvider(),entry=Array.from(fnStore.values()).find(v=>v.key===tag||v.hash===tag);entry&&await provider.delete(entry.key)}__name(invalidate,"invalidate");async function revalidate(tag,...args){let provider=getCacheProvider(),entry=Array.from(fnStore.values()).find(v=>v.key===tag||v.hash===tag);if(entry)return await provider.delete(entry.key),entry.memo(...args)}__name(revalidate,"revalidate");function isCachedFunction(fn){return Object.prototype.hasOwnProperty.call(fn,CACHED_FN_SYMBOL)}__name(isCachedFunction,"isCachedFunction");var CommandExecutionMode={SlashCommand:"chatInput",MessageContextMenu:"messageContextMenu",UserContextMenu:"userContextMenu",Autocomplete:"autocomplete",Message:"message"},_store,_Context=class _Context{constructor(commandkit,config){this.commandkit=commandkit;this.config=config;__publicField(this,"interaction");__publicField(this,"message");__publicField(this,"client");__privateAdd(this,_store);__publicField(this,"_locale",null);this.interaction=config.interaction,this.message=config.message,this.client=commandkit.client,__privateSet(this,_store,config.store??new Map)}get store(){return __privateGet(this,_store)}get commandName(){return this.isInteraction()?this.interaction.commandName:this.config.messageCommandParser.getCommand()}get options(){return this.isMessage()?this.config.messageCommandParser.options:this.interaction.options}get forwarded(){return this.config.forwarded??!1}async forwardCommand(command){let target=await this.commandkit.appCommandsHandler.prepareCommandRun(this.isInteraction()?this.interaction:this.message);if(!target)throw new Error(`Command ${command} not found! If you are trying to forward to a legacy command, ctx.forwardCommand is not compatible with legacy commands.`);let env=this.config.environment??getContext();if(!env)throw new Error("No commandkit environment found.");let handlers={chatInput:target.command.data.chatInput,autocomplete:target.command.data.autocomplete,message:target.command.data.message,messageContextMenu:target.command.data.messageContextMenu,userContextMenu:target.command.data.userContextMenu},handlerKind=env.variables.get("execHandlerKind");if(!handlerKind)throw new Error("No execution handler kind found.");let handler=handlers[handlerKind];if(!handler)throw new Error(`No handler found for ${handlerKind}`);await handler(this.clone({forwarded:!0})),redirect()}get executionMode(){return this.config.executionMode}isInteraction(){return this.executionMode===CommandExecutionMode.SlashCommand||this.executionMode===CommandExecutionMode.Autocomplete||this.executionMode===CommandExecutionMode.MessageContextMenu||this.executionMode===CommandExecutionMode.UserContextMenu}isSlashCommand(){return this.executionMode===CommandExecutionMode.SlashCommand}isAutocomplete(){return this.executionMode===CommandExecutionMode.Autocomplete}isMessageContextMenu(){return this.executionMode===CommandExecutionMode.MessageContextMenu}isUserContextMenu(){return this.executionMode===CommandExecutionMode.UserContextMenu}isMessage(){return this.executionMode===CommandExecutionMode.Message}getCommandIdentifier(){return this.isInteraction()?this.interaction.commandName:this.message.content.split(" ")[0].slice(1)}getGuildLocale(){var _a;return this.isInteraction()?this.interaction.guildLocale:((_a=this.message.guild)==null?void 0:_a.preferredLocale)??null}getUserLocale(){return this.isInteraction()?this.interaction.locale:null}getLocale(preferUser=!1){if(this._locale)return this._locale;let locale=preferUser?this.getUserLocale():this.getGuildLocale();return locale||this.commandkit.config.defaultLocale}setLocale(locale){this._locale=locale}locale(locale){let selectedLocale=locale??this.getLocale();return new Localization(this.commandkit,{locale:selectedLocale,target:this.getCommandIdentifier()})}clone(config){return config?new _Context(this.commandkit,{...this.config,...config,store:__privateGet(this,_store)}):new _Context(this.commandkit,this.config)}isMiddleware(){return this instanceof MiddlewareContext}args(){return this.isMessage()?this.config.messageCommandParser.getArgs():[]}exit(){exitMiddleware()}defer(fn){return afterCommand(fn)}cancelDeferred(id){cancelAfterCommand(id)}isCached(fn){return isCachedFunction(fn)}};_store=new WeakMap,__name(_Context,"Context");var Context=_Context,_cancel,_MiddlewareContext=class _MiddlewareContext extends Context{constructor(){super(...arguments);__privateAdd(this,_cancel,!1)}get cancelled(){return __privateGet(this,_cancel)}cancel(){__privateSet(this,_cancel,!0)}};_cancel=new WeakMap,__name(_MiddlewareContext,"MiddlewareContext");var MiddlewareContext=_MiddlewareContext;var _data2,_CommandHandler_instances,buildCommands_fn,buildBuiltInValidations_fn,commandFinalizer_fn,requestExternalHandler_fn,interactionHandler_fn,_CommandHandler=class _CommandHandler{constructor({...options}){__privateAdd(this,_CommandHandler_instances);__privateAdd(this,_data2);__privateSet(this,_data2,{...options,builtInValidations:[],commands:[]})}async init(){await __privateMethod(this,_CommandHandler_instances,buildCommands_fn).call(this),__privateMethod(this,_CommandHandler_instances,buildBuiltInValidations_fn).call(this);let devOnlyCommands=__privateGet(this,_data2).commands.filter(cmd=>{var _a;return(_a=cmd.options)==null?void 0:_a.devOnly});devOnlyCommands.length&&!__privateGet(this,_data2).devGuildIds.length&&process.emitWarning(colors_default.yellow('You have commands marked as "devOnly", but "devGuildIds" have not been set.')),devOnlyCommands.length&&!__privateGet(this,_data2).devUserIds.length&&!__privateGet(this,_data2).devRoleIds.length&&process.emitWarning(colors_default.yellow('You have commands marked as "devOnly", but "devUserIds" or "devRoleIds" have not been set.')),__privateGet(this,_data2).bulkRegister?await loadCommandsWithRest({client:__privateGet(this,_data2).client,devGuildIds:__privateGet(this,_data2).devGuildIds,commands:__privateGet(this,_data2).commands}):await registerCommands({client:__privateGet(this,_data2).client,devGuildIds:__privateGet(this,_data2).devGuildIds,commands:__privateGet(this,_data2).commands}),this.handleCommands()}handleCommands(){__privateGet(this,_data2).client.on(import_discord4.Events.InteractionCreate,interaction=>{let env=new CommandKitEnvironment(__privateGet(this,_data2).commandkitInstance);return env.setType("COMMAND_HANDLER"),makeContextAwareFunction(env,__privateMethod(this,_CommandHandler_instances,interactionHandler_fn).bind(this),__privateMethod(this,_CommandHandler_instances,commandFinalizer_fn).bind(this))(interaction)}),__privateGet(this,_data2).client.on(import_discord4.Events.MessageCreate,message=>{let env=new CommandKitEnvironment(__privateGet(this,_data2).commandkitInstance);return env.setType("COMMAND_HANDLER"),makeContextAwareFunction(env,__privateMethod(this,_CommandHandler_instances,requestExternalHandler_fn).bind(this),__privateMethod(this,_CommandHandler_instances,commandFinalizer_fn).bind(this))(message)})}get commands(){return __privateGet(this,_data2).commands}async reloadCommands(type){if(!__privateGet(this,_data2).commandsPath)throw new Error(colors_default.red('Cannot reload commands as "commandsPath" was not provided when instantiating CommandKit.'));__privateGet(this,_data2).commands=[],await __privateMethod(this,_CommandHandler_instances,buildCommands_fn).call(this),__privateGet(this,_data2).bulkRegister?await loadCommandsWithRest({client:__privateGet(this,_data2).client,devGuildIds:__privateGet(this,_data2).devGuildIds,commands:__privateGet(this,_data2).commands,reloading:!0,type}):await registerCommands({client:__privateGet(this,_data2).client,devGuildIds:__privateGet(this,_data2).devGuildIds,commands:__privateGet(this,_data2).commands,reloading:!0,type})}};_data2=new WeakMap,_CommandHandler_instances=new WeakSet,buildCommands_fn=__name(async function(){var _a;let allowedExtensions=/\.(js|mjs|cjs|ts)$/i,commandFilePaths=(await getFilePaths(__privateGet(this,_data2).commandsPath,!0)).filter(path4=>allowedExtensions.test(path4));for(let commandFilePath of commandFilePaths){let importedObj=await import(`${toFileURL(commandFilePath)}?t=${Date.now()}`),commandObj=clone(importedObj);typeof module<"u"&&typeof require<"u"&&delete require.cache[require.resolve(commandFilePath)];let compactFilePath=commandFilePath.split(process.cwd())[1]||commandFilePath;if(commandObj.default&&(commandObj=commandObj.default),importedObj.default?commandObj.data=importedObj.default.data:commandObj.data=importedObj.data,!commandObj.data){process.emitWarning(colors_default.yellow(`Ignoring: Command file ${compactFilePath} does not export "data".`));continue}if(!commandObj.data.name){process.emitWarning(colors_default.yellow(`Ignoring: Command file ${compactFilePath} does not export "data.name".`));continue}if(!commandObj.run){process.emitWarning(colors_default.yellow(`Ignoring: Command file ${commandObj.data.name} does not export "run".`));continue}if(typeof commandObj.run!="function"){process.emitWarning(colors_default.yellow(`Ignoring: Command file ${commandObj.data.name} does not export "run" as a function.`));continue}commandObj.filePath=commandFilePath;let commandCategory=((_a=commandFilePath.split(__privateGet(this,_data2).commandsPath)[1])==null?void 0:_a.replace(/\\\\|\\/g,"/").split("/")[1])||null;commandCategory&&allowedExtensions.test(commandCategory)?commandObj.category=null:commandObj.category=commandCategory,__privateGet(this,_data2).commands.push(commandObj)}if(__privateGet(this,_data2).commandkitInstance.appCommandsHandler){let commands=__privateGet(this,_data2).commandkitInstance.appCommandsHandler.getCommandsArray();for(let cmd of commands){let idx=__privateGet(this,_data2).commands.findIndex(c=>c.data.name===cmd.name);idx!==-1?__privateGet(this,_data2).commands[idx]={data:cmd}:__privateGet(this,_data2).commands.push({data:cmd})}}},"#buildCommands"),buildBuiltInValidations_fn=__name(function(){for(let builtInValidationFunction of validations_default)__privateGet(this,_data2).builtInValidations.push(builtInValidationFunction)},"#buildBuiltInValidations"),commandFinalizer_fn=__name(async function(){let env=useEnvironment();await env.runDeferredFunctions(),env.clearAllDeferredFunctions()},"#commandFinalizer"),requestExternalHandler_fn=__name(async function(interaction){let handler=__privateGet(this,_data2).commandkitInstance.appCommandsHandler;if(!handler||!(interaction instanceof import_discord4.Message)&&!(interaction.isCommand()||interaction.isAutocomplete()))return 0;let targetCommand=await handler.prepareCommandRun(interaction);if(!targetCommand)return 0;let environment=useEnvironment();environment.variables.set("commandHandlerType","app");let{command,middlewares,messageCommandParser}=targetCommand,context2=new MiddlewareContext(__privateGet(this,_data2).commandkitInstance,{executionMode:interaction instanceof import_discord4.Message?CommandExecutionMode.Message:interaction.isChatInputCommand()?CommandExecutionMode.SlashCommand:interaction.isUserContextMenuCommand()?CommandExecutionMode.UserContextMenu:interaction.isMessageContextMenuCommand()?CommandExecutionMode.MessageContextMenu:interaction.isAutocomplete()?CommandExecutionMode.Autocomplete:null,interaction:interaction instanceof import_discord4.Message?null:interaction,message:interaction instanceof import_discord4.Message?interaction:null,messageCommandParser});environment.variables.set("currentCommandName",context2.commandName);let exec=__name(async()=>{var _a,_b,_c,_d,_e,_f,_g,_h,_i,_j;if(middlewares.length>0)for(let middleware of middlewares){if(context2.cancelled)return 1;try{await middleware.data.beforeExecute(context2)}catch(e){if(isErrorType(e,CommandKitErrorCodes.ExitMiddleware))break;if(isErrorType(e,[CommandKitErrorCodes.DMOnlyException,CommandKitErrorCodes.GuildOnlyException,CommandKitErrorCodes.ForwardedCommand]))return;throw e}}if(context2.cancelled)return 1;let postStageRunner=!0;try{let commandContext=context2.clone({environment});if(interaction instanceof import_discord4.Message)environment.variables.set("execHandlerKind","message"),await((_b=(_a=command.data).message)==null?void 0:_b.call(_a,commandContext));else switch(!0){case interaction.isChatInputCommand():environment.variables.set("execHandlerKind","chatInput"),await((_d=(_c=command.data).chatInput)==null?void 0:_d.call(_c,commandContext));break;case interaction.isUserContextMenuCommand():environment.variables.set("execHandlerKind","userContextMenu"),await((_f=(_e=command.data).userContextMenu)==null?void 0:_f.call(_e,commandContext));break;case interaction.isMessageContextMenuCommand():environment.variables.set("execHandlerKind","messageContextMenu"),await((_h=(_g=command.data).messageContextMenu)==null?void 0:_h.call(_g,commandContext));break;case interaction.isAutocomplete():environment.variables.set("execHandlerKind","autocomplete"),await((_j=(_i=command.data).autocomplete)==null?void 0:_j.call(_i,commandContext));break;default:break}}catch(e){if(Logger.error(e),isErrorType(e,CommandKitErrorCodes.ExitMiddleware))postStageRunner=!1;else{if(isErrorType(e,[CommandKitErrorCodes.DMOnlyException,CommandKitErrorCodes.GuildOnlyException,CommandKitErrorCodes.ForwardedCommand]))return;throw e}}if(postStageRunner&&middlewares.length>0)for(let middleware of middlewares)try{await middleware.data.afterExecute(context2)}catch(e){if(isErrorType(e,CommandKitErrorCodes.ExitMiddleware))break;if(isErrorType(e,[CommandKitErrorCodes.DMOnlyException,CommandKitErrorCodes.GuildOnlyException,CommandKitErrorCodes.ForwardedCommand]))return;throw e}},"exec");if(!__privateGet(this,_data2).commandkitInstance.isDebuggingCommands())return await exec(),1;afterCommand(env=>{let error=env.getExecutionError(),marker=env.getMarker(),time=`${env.getExecutionTime().toFixed(2)}ms`;if(error){Logger.error(colors_default.red(`[${marker} - ${time}] Error executing command: ${error.stack||error}`));return}Logger.log(colors_default.green(`[${marker} - ${time}] Command executed successfully`))});try{return environment.markStart(`${command.data.command.name}`),await exec(),1}finally{environment.markEnd()}},"#requestExternalHandler"),interactionHandler_fn=__name(async function(interaction){try{if(await __privateMethod(this,_CommandHandler_instances,requestExternalHandler_fn).call(this,interaction)===1)return}catch(e){console.error(e);return}if(!interaction.isChatInputCommand()&&!interaction.isContextMenuCommand()&&!interaction.isAutocomplete())return;let isAutocomplete=interaction.isAutocomplete(),targetCommand=__privateGet(this,_data2).commands.find(cmd=>cmd.data.name===interaction.commandName);if(!targetCommand)return;let env=useEnvironment();env.variables.set("currentCommandName",interaction.commandName),env.variables.set("commandHandlerType","legacy"),env.variables.set("interaction",interaction),env.variables.set("execHandlerKind",isAutocomplete?"autocomplete":"chatInput");let{data,options,run,autocomplete,...rest}=targetCommand;return isAutocomplete&&!autocomplete?void 0:__name(async()=>{let commandObj={data:targetCommand.data,options:targetCommand.options,...rest};if(__privateGet(this,_data2).validationHandler){let canRun2=!0;for(let validationFunction of __privateGet(this,_data2).validationHandler.validations)if(await validationFunction({interaction,commandObj,client:__privateGet(this,_data2).client,handler:__privateGet(this,_data2).commandkitInstance})){canRun2=!1;break}if(!canRun2)return}let canRun=!0;if(!__privateGet(this,_data2).skipBuiltInValidations){for(let validation of __privateGet(this,_data2).builtInValidations)if(validation({targetCommand,interaction,handlerData:__privateGet(this,_data2)})){canRun=!1;break}}if(!canRun)return;let command=targetCommand[isAutocomplete?"autocomplete":"run"];if(!command)return;let context2={interaction,client:__privateGet(this,_data2).client,handler:__privateGet(this,_data2).commandkitInstance};if(!__privateGet(this,_data2).commandkitInstance.isDebuggingCommands())return command(context2);afterCommand(env2=>{let error=env2.getExecutionError(),marker=env2.getMarker(),time=`${env2.getExecutionTime().toFixed(2)}ms`;if(error){Logger.error(colors_default.red(`[${marker} - ${time}] Error executing command: ${error.stack||error}`));return}Logger.log(colors_default.green(`[${marker} - ${time}] Command executed successfully`))});try{return env.markStart(interaction.commandName),await command(context2)}finally{env.markEnd()}},"executor")()},"#interactionHandler"),__name(_CommandHandler,"CommandHandler");var CommandHandler=_CommandHandler;init_cjs_shims();init_colors();var _data3,_listening,_EventHandler_instances,buildEvents_fn,registerEvents_fn,_EventHandler=class _EventHandler{constructor({...options}){__privateAdd(this,_EventHandler_instances);__privateAdd(this,_data3);__privateAdd(this,_listening,new Set);__privateSet(this,_data3,{...options,events:[]})}async init(){await __privateMethod(this,_EventHandler_instances,buildEvents_fn).call(this),__privateMethod(this,_EventHandler_instances,registerEvents_fn).call(this)}async registerExternal(entry){let{event,listeners}=entry,functions=await Promise.all(listeners.map(async l=>import(`${toFileURL(l)}?t=${Date.now()}`).then(m=>m.default))),existing=__privateGet(this,_data3).events.find(e=>e.name===event);existing?existing.functions.unshift(...functions):__privateGet(this,_data3).events.unshift({name:event,functions})}resyncListeners(){let client=__privateGet(this,_data3).client,handler=__privateGet(this,_data3).commandKitInstance;for(let eventObj of __privateGet(this,_data3).events)__privateGet(this,_listening).has(eventObj.name)||(client.on(eventObj.name,async(...params)=>{for(let eventFunction of eventObj.functions)if(await eventFunction(...params,client,handler))break}),__privateGet(this,_listening).add(eventObj.name))}get events(){return __privateGet(this,_data3).events}async reloadEvents(commandHandler){if(!__privateGet(this,_data3).eventsPath)throw new Error(colors_default.red('Cannot reload events as "eventsPath" was not provided when instantiating CommandKit.'));__privateGet(this,_data3).events=[],await __privateMethod(this,_EventHandler_instances,buildEvents_fn).call(this),__privateGet(this,_listening).clear(),__privateGet(this,_data3).client.removeAllListeners(),__privateMethod(this,_EventHandler_instances,registerEvents_fn).call(this),commandHandler==null||commandHandler.handleCommands()}};_data3=new WeakMap,_listening=new WeakMap,_EventHandler_instances=new WeakSet,buildEvents_fn=__name(async function(){let eventFolderPaths=await getFolderPaths(__privateGet(this,_data3).eventsPath);for(let eventFolderPath of eventFolderPaths){let eventName=eventFolderPath.replace(/\\\\|\\/g,"/").split("/").pop(),allowedExtensions=/\.(js|mjs|cjs|ts)$/i,eventFilePaths=(await getFilePaths(eventFolderPath,!0)).filter(path4=>allowedExtensions.test(path4)),eventObj=__privateGet(this,_data3).events.find(e=>e.name===eventName);eventObj||(eventObj={name:eventName,functions:[]},__privateGet(this,_data3).events.push(eventObj));for(let eventFilePath of eventFilePaths){let importedFunction=(await import(`${toFileURL(eventFilePath)}?t=${Date.now()}`)).default,eventFunction=clone(importedFunction);typeof module<"u"&&typeof require<"u"&&delete require.cache[require.resolve(eventFilePath)],eventFunction!=null&&eventFunction.default&&(eventFunction=eventFunction.default);let compactFilePath=eventFilePath.split(process.cwd())[1]||eventFilePath;if(typeof eventFunction!="function"){process.emitWarning(colors_default.yellow(`Ignoring: Event file ${compactFilePath} does not export a function.`));continue}eventObj.functions.push(eventFunction)}}},"#buildEvents"),registerEvents_fn=__name(function(){let client=__privateGet(this,_data3).client,handler=__privateGet(this,_data3).commandKitInstance;for(let eventObj of __privateGet(this,_data3).events)client.on(eventObj.name,async(...params)=>{for(let eventFunction of eventObj.functions)if(await eventFunction(...params,client,handler))break}),__privateGet(this,_listening).add(eventObj.name)},"#registerEvents"),__name(_EventHandler,"EventHandler");var EventHandler=_EventHandler;init_cjs_shims();init_colors();var _data4,_ValidationHandler_instances,buildValidations_fn,_ValidationHandler=class _ValidationHandler{constructor({...options}){__privateAdd(this,_ValidationHandler_instances);__privateAdd(this,_data4);__privateSet(this,_data4,{...options,validations:[]})}async init(){__privateGet(this,_data4).validations=await __privateMethod(this,_ValidationHandler_instances,buildValidations_fn).call(this)}get validations(){return __privateGet(this,_data4).validations}async reloadValidations(){if(!__privateGet(this,_data4).validationsPath)throw new Error(colors_default.red('Cannot reload validations as "validationsPath" was not provided when instantiating CommandKit.'));let newValidations=await __privateMethod(this,_ValidationHandler_instances,buildValidations_fn).call(this);__privateGet(this,_data4).validations=newValidations}};_data4=new WeakMap,_ValidationHandler_instances=new WeakSet,buildValidations_fn=__name(async function(){let allowedExtensions=/\.(js|mjs|cjs|ts)$/i,validationFilePaths=(await getFilePaths(__privateGet(this,_data4).validationsPath,!0)).filter(path4=>allowedExtensions.test(path4)),validationFunctions=[];for(let validationFilePath of validationFilePaths){let importedFunction=(await import(`${toFileURL(validationFilePath)}?t=${Date.now()}`)).default,validationFunction=clone(importedFunction);typeof module<"u"&&typeof require<"u"&&delete require.cache[require.resolve(validationFilePath)],validationFunction!=null&&validationFunction.default&&(validationFunction=validationFunction.default);let compactFilePath=validationFilePath.split(process.cwd())[1]||validationFilePath;if(typeof validationFunction!="function"){process.emitWarning(colors_default.yellow(`Ignoring: Validation file ${compactFilePath} does not export a function.`));continue}validationFunctions.push(validationFunction)}return validationFunctions},"#buildValidations"),__name(_ValidationHandler,"ValidationHandler");var ValidationHandler=_ValidationHandler;init_colors();init_cjs_shims();init_cjs_shims();var import_discord5=require("discord.js");function ActionRow(props){let row=new import_discord5.ActionRowBuilder;return Array.isArray(props.children)?row.setComponents(...props.children):props.children&&row.setComponents(props.children),row}__name(ActionRow,"ActionRow");init_cjs_shims();var import_discord6=require("discord.js");var _onClickHandler,_contextData,_unsub,_ButtonKit_instances,getEventInterceptor_fn,setupInteractionCollector_fn,destroyCollector_fn,_ButtonKit=class _ButtonKit extends import_discord6.ButtonBuilder{constructor(){super(...arguments);__privateAdd(this,_ButtonKit_instances);__privateAdd(this,_onClickHandler,null);__privateAdd(this,_contextData,{autoReset:!0,time:5*60*1e3,once:!1});__privateAdd(this,_unsub,null)}onClick(handler,data){var _a,_b,_c,_d;if(this.data.style===import_discord6.ButtonStyle.Link)throw new TypeError('Cannot setup "onClick" handler on link buttons.');if(!handler)throw new TypeError('Cannot setup "onClick" without a handler function parameter.');return __privateGet(this,_onClickHandler)&&__privateMethod(this,_ButtonKit_instances,destroyCollector_fn).call(this),__privateSet(this,_onClickHandler,handler),data&&__privateSet(this,_contextData,{autoReset:data.autoReset??((_a=__privateGet(this,_contextData))==null?void 0:_a.autoReset)??!0,time:data.time??((_b=__privateGet(this,_contextData))==null?void 0:_b.time)??5*60*1e3,filter:data.filter??((_c=__privateGet(this,_contextData))==null?void 0:_c.filter),onEnd:data.onEnd??((_d=__privateGet(this,_contextData))==null?void 0:_d.onEnd)}),__privateMethod(this,_ButtonKit_instances,setupInteractionCollector_fn).call(this),this}onEnd(handler){if(this.data.style===import_discord6.ButtonStyle.Link)throw new TypeError('Cannot setup "onEnd" handler on link buttons.');if(!handler)throw new TypeError('Cannot setup "onEnd" without a handler function parameter.');return __privateGet(this,_contextData)??__privateSet(this,_contextData,{}),__privateGet(this,_contextData).onEnd=handler,this}onError(handler){if(!handler)throw new TypeError('Cannot setup "onError" without a handler function parameter.');return __privateGet(this,_contextData)??__privateSet(this,_contextData,{}),__privateGet(this,_contextData).onError=handler,this}filter(predicate){return __privateGet(this,_contextData)??__privateSet(this,_contextData,{autoReset:!0,time:5*60*1e3}),__privateGet(this,_contextData).filter=predicate,this}get customId(){return this.data.custom_id??this.data.customId}dispose(){return __privateMethod(this,_ButtonKit_instances,destroyCollector_fn).call(this),this}};_onClickHandler=new WeakMap,_contextData=new WeakMap,_unsub=new WeakMap,_ButtonKit_instances=new WeakSet,getEventInterceptor_fn=__name(function(){let ctx=getContext();return ctx?exitContext(()=>ctx.commandkit.eventInterceptor):getCommandKit(!0).eventInterceptor},"#getEventInterceptor"),setupInteractionCollector_fn=__name(function(){if(this.data.style===import_discord6.ButtonStyle.Link||!__privateGet(this,_contextData)||!__privateGet(this,_onClickHandler))return;if((this.customId??null)===null)throw new TypeError('Cannot setup "onClick" handler on a button without a custom id.');let interceptor=__privateMethod(this,_ButtonKit_instances,getEventInterceptor_fn).call(this);__privateSet(this,_unsub,interceptor.subscribe(import_discord6.Events.InteractionCreate,async interaction=>{var _a,_b;if(!interaction.isButton())return;let myCustomId2=this.customId??null,interactionCustomId=interaction.customId;if(myCustomId2&&interactionCustomId!==myCustomId2)return;let filter=(_a=__privateGet(this,_contextData))==null?void 0:_a.filter;if(filter&&!await filter(interaction))return;let handler=__privateGet(this,_onClickHandler);return handler?handler(interaction,this):(_b=__privateGet(this,_unsub))==null?void 0:_b.call(this)},__privateGet(this,_contextData)))},"#setupInteractionCollector"),destroyCollector_fn=__name(function(){var _a;(_a=__privateGet(this,_unsub))==null||_a.call(this),__privateSet(this,_unsub,null),__privateSet(this,_contextData,null),__privateSet(this,_onClickHandler,null)},"#destroyCollector"),__name(_ButtonKit,"ButtonKit");var ButtonKit=_ButtonKit;init_cjs_shims();var import_discord7=require("discord.js");function Button(props){let button=new ButtonKit;props.style??=import_discord7.ButtonStyle.Primary,props.onClick&&(props.customId??=`buttonkit::${crypto.randomUUID()}`),props.customId&&button.setCustomId(props.customId),props.onClick&&button.onClick(props.onClick,props.options),props.disabled&&button.setDisabled(props.disabled),props.emoji&&button.setEmoji(props.emoji),props.skuId&&button.setSKUId(props.skuId),props.url&&button.setURL(props.url),props.style&&button.setStyle(props.style);let label=props.label||props.children;return label&&button.setLabel(Array.isArray(label)?label.join(" "):typeof label=="string"?label:String(label)),props.onEnd&&button.onEnd(props.onEnd),props.onError&&button.onError(props.onError),button}__name(Button,"Button");init_cjs_shims();var import_discord8=require("discord.js");var _onSubmitHandler,_contextData2,_unsub2,_ModalKit_instances,getEventInterceptor_fn2,setupCollector_fn,destroyCollector_fn2,_ModalKit=class _ModalKit extends import_discord8.ModalBuilder{constructor(){super(...arguments);__privateAdd(this,_ModalKit_instances);__privateAdd(this,_onSubmitHandler,null);__privateAdd(this,_contextData2,{autoReset:!1,time:5*60*1e3,once:!0});__privateAdd(this,_unsub2,null)}onSubmit(handler,data){var _a,_b,_c,_d;if(!handler)throw new TypeError('Cannot setup "onClick" without a handler function parameter.');return __privateGet(this,_onSubmitHandler)&&__privateMethod(this,_ModalKit_instances,destroyCollector_fn2).call(this),__privateSet(this,_onSubmitHandler,handler),data&&__privateSet(this,_contextData2,{autoReset:data.autoReset??((_a=__privateGet(this,_contextData2))==null?void 0:_a.autoReset)??!0,time:data.time??((_b=__privateGet(this,_contextData2))==null?void 0:_b.time)??5*60*1e3,filter:data.filter??((_c=__privateGet(this,_contextData2))==null?void 0:_c.filter),onEnd:data.onEnd??((_d=__privateGet(this,_contextData2))==null?void 0:_d.onEnd)}),__privateMethod(this,_ModalKit_instances,setupCollector_fn).call(this),this}onEnd(handler){if(!handler)throw new TypeError('Cannot setup "onEnd" without a handler function parameter.');return __privateGet(this,_contextData2)??__privateSet(this,_contextData2,{}),__privateGet(this,_contextData2).onEnd=handler,this}onError(handler){if(!handler)throw new TypeError('Cannot setup "onError" without a handler function parameter.');return __privateGet(this,_contextData2)??__privateSet(this,_contextData2,{}),__privateGet(this,_contextData2).onError=handler,this}filter(predicate){return __privateGet(this,_contextData2)??__privateSet(this,_contextData2,{autoReset:!0,time:5*60*1e3}),__privateGet(this,_contextData2).filter=predicate,this}get customId(){return this.data.custom_id??this.data.customId}dispose(){return __privateMethod(this,_ModalKit_instances,destroyCollector_fn2).call(this),this}};_onSubmitHandler=new WeakMap,_contextData2=new WeakMap,_unsub2=new WeakMap,_ModalKit_instances=new WeakSet,getEventInterceptor_fn2=__name(function(){let ctx=getContext();return ctx?exitContext(()=>ctx.commandkit.eventInterceptor):getCommandKit(!0).eventInterceptor},"#getEventInterceptor"),setupCollector_fn=__name(function(){if(!__privateGet(this,_contextData2))return;if(!this.customId)throw new TypeError("Cannot setup an modal collector without a custom ID.");let interceptor=__privateMethod(this,_ModalKit_instances,getEventInterceptor_fn2).call(this);interceptor&&__privateSet(this,_unsub2,interceptor.subscribe(import_discord8.Events.InteractionCreate,async interaction=>{var _a,_b;if(!interaction.isModalSubmit())return;let myCustomId=this.customId??null,interactionCustomId=interaction.customId;if(myCustomId&&interactionCustomId!==myCustomId)return;let filter=(_a=__privateGet(this,_contextData2))==null?void 0:_a.filter;if(filter&&!await filter(interaction))return;let handler=__privateGet(this,_onSubmitHandler);return handler?handler(interaction,this):(_b=__privateGet(this,_unsub2))==null?void 0:_b.call(this)},__privateGet(this,_contextData2)))},"#setupCollector"),destroyCollector_fn2=__name(function(){var _a;(_a=__privateGet(this,_unsub2))==null||_a.call(this),__privateSet(this,_unsub2,null),__privateSet(this,_onSubmitHandler,null),__privateSet(this,_contextData2,null)},"#destroyCollector"),__name(_ModalKit,"ModalKit");var ModalKit=_ModalKit;init_cjs_shims();var import_discord9=require("discord.js");function Modal(props){let modal=new ModalKit;if(props.title&&modal.setTitle(props.title),props.onSubmit&&(props.customId??=`modalkit::${crypto.randomUUID()}`),props.customId&&modal.setCustomId(props.customId),props.onSubmit&&modal.onSubmit(props.onSubmit,props.options),props.children){let childs=(Array.isArray(props.children)?props.children:[props.children]).map(c=>{if(c instanceof import_discord9.ActionRowBuilder)return c;if(c instanceof import_discord9.TextInputBuilder)return new import_discord9.ActionRowBuilder().addComponents(c)}).filter(c=>c!=null);modal.addComponents(childs)}return props.onEnd&&modal.onEnd(props.onEnd),props.onError&&modal.onError(props.onError),modal}__name(Modal,"Modal");function TextInput(props){let input=new import_discord9.TextInputBuilder().setStyle(props.style);return props.customId&&input.setCustomId(props.customId),props.label&&input.setLabel(props.label),props.placeholder&&input.setPlaceholder(props.placeholder),props.maxLength&&input.setMaxLength(props.maxLength),props.minLength&&input.setMinLength(props.minLength),props.value&&input.setValue(props.value),props.required&&input.setRequired(props.required),input}__name(TextInput,"TextInput");function ShortInput(props){return TextInput({...props,style:import_discord9.TextInputStyle.Short})}__name(ShortInput,"ShortInput");function ParagraphInput(props){return TextInput({...props,style:import_discord9.TextInputStyle.Paragraph})}__name(ParagraphInput,"ParagraphInput");init_cjs_shims();init_cjs_shims();var WARNED_KEYS=new Set;function emitWarning(message,code="CommandKitWarning"){process.emitWarning(message,{code})}__name(emitWarning,"emitWarning");function warnUnstable(name){WARNED_KEYS.has(name)||(WARNED_KEYS.add(name),emitWarning(`${name} is unstable and may change in future versions.`,"CommandKitUnstableWarning"))}__name(warnUnstable,"warnUnstable");var ElementType={ActionRow:"action-row",Button:"button-kit",Modal:"modal",TextInput:"text-input"};function isCommandKitElement(element){return!(typeof element!="object"||element===null||!Reflect.has(element,"type")||!Reflect.has(element,"data"))}__name(isCommandKitElement,"isCommandKitElement");function getElement(element){return element.data}__name(getElement,"getElement");function Fragment(props){return warnUnstable("CommandKit JSX"),Array.isArray(props.children)?props.children.flat():props.children}__name(Fragment,"Fragment");function createElement(type,props,...children){return warnUnstable("CommandKit JSX"),type({...props,children})}__name(createElement,"createElement");init_cjs_shims();init_cjs_shims();var _EventInterceptor_instances,cleanupLoop_fn,_EventInterceptor=class _EventInterceptor{constructor(client){this.client=client;__privateAdd(this,_EventInterceptor_instances);__publicField(this,"subscribers",new Map);__publicField(this,"globalHandlers",new Map);__publicField(this,"cleanupTimer",null);__privateMethod(this,_EventInterceptor_instances,cleanupLoop_fn).call(this)}destroy(){this.cleanupTimer&&(clearInterval(this.cleanupTimer),this.cleanupTimer=null);for(let[event,handlers]of this.subscribers)for(let handler of handlers)this.unsubscribe(event,handler,"destroy");this.subscribers.clear(),this.globalHandlers.clear()}hasSubscribers(event){return this.subscribers.has(event)}getSubscriberCount(event){let handlers=this.subscribers.get(event);return(handlers==null?void 0:handlers.size)??0}hasGlobalHandlers(){return this.globalHandlers.size>0}getGlobalHandlersCount(){return this.subscribers.size}subscribe(event,listener,options){return this.subscribers.has(event)||(this.subscribers.set(event,new Set),this.client.on(event,this.createGlobalHandler(event)),this.client.setMaxListeners(this.client.getMaxListeners()+1)),options??={},options.registeredAt=Date.now(),Reflect.set(listener,"options",options),this.subscribers.get(event).add(listener),()=>{this.unsubscribe(event,listener)}}unsubscribe(event,listener,reason){var _a,_b;let handlers=this.subscribers.get(event);handlers&&(handlers.delete(listener),handlers.size<1&&(this.subscribers.delete(event),this.client.removeListener(event,this.globalHandlers.get(event)),this.globalHandlers.delete(event),this.client.setMaxListeners(Math.max(this.client.getMaxListeners()-1,0))),(_b=(_a=Reflect.get(listener,"options")).onEnd)==null||_b.call(_a,reason??"unsubscribe"))}createGlobalHandler(event){if(this.globalHandlers.has(event))return this.globalHandlers.get(event);let handler=__name(async(...args)=>{let subscribers=this.subscribers.get(event);if(subscribers&&subscribers.size>0)for(let subscriber of subscribers){let options=Reflect.get(subscriber,"options");if(options.time&&Date.now()-options.registeredAt>options.time){this.unsubscribe(event,subscriber,"time");continue}if(options.autoReset&&(options.registeredAt=Date.now()),!(options.filter&&!await options.filter(...args)))try{await subscriber(...args)}catch(e){if(options.onError)await options.onError(e);else throw e}finally{options.once&&this.unsubscribe(event,subscriber,"once")}}},"handler");return this.globalHandlers.set(event,handler),handler}};_EventInterceptor_instances=new WeakSet,cleanupLoop_fn=__name(function(){this.cleanupTimer&&clearInterval(this.cleanupTimer),this.cleanupTimer=setInterval(()=>{for(let[event,handlers]of this.subscribers)for(let handler of handlers){let options=Reflect.get(handler,"options");options.time&&Date.now()-options.registeredAt>options.time&&this.unsubscribe(event,handler,"time")}},6e4).unref()},"#cleanupLoop"),__name(_EventInterceptor,"EventInterceptor");var EventInterceptor=_EventInterceptor;var import_discord12=require("discord.js");init_cjs_shims();var import_promises2=require("fs/promises"),import_node_path=require("path");var _DefaultLocalizationStrategy=class _DefaultLocalizationStrategy{constructor(commandkit){this.commandkit=commandkit}translations=new Map;async locateTranslation(scope,locale){let localesPath=this.commandkit.getPath("locales");if(!localesPath)return null;let path4=(0,import_node_path.join)(localesPath,locale,`${scope}.json`);try{let data=await(0,import_promises2.readFile)(path4,"utf-8");return JSON.parse(data)}catch{return null}}async getTranslationStrict(scope,locale){let key=`${scope}:${locale}`;if(!this.translations.has(key)){let translation=await this.locateTranslation(scope,locale);if(!translation)throw new Error(`Translation not found for ${key}`);return this.translations.set(key,translation),translation}return this.translations.get(key)}async getTranslation(scope,locale){try{return this.getTranslationStrict(scope,locale)}catch{return null}}async translate(request){let{scope,key,args,locale}=request,translation=await this.getTranslation(scope,locale);if(!translation)return`${scope}.${key}`;let value=translation.translations[key];return this.applyTranslation(value,args)||`${scope}.${key}`}applyTranslation(translation,args){return!translation||!args?translation:translation.replace(/{([^}]+)}/g,(_,key)=>String(args[key]??`{${key}}`))}};__name(_DefaultLocalizationStrategy,"DefaultLocalizationStrategy");var DefaultLocalizationStrategy=_DefaultLocalizationStrategy;init_cjs_shims();var import_node_fs=require("fs"),import_node_path2=require("path");var appDir=null;function findAppDirectory(){if(appDir)return appDir;let root=(0,import_node_path2.join)(process.cwd(),COMMANDKIT_IS_DEV?".commandkit":"dist");(0,import_node_fs.existsSync)(root)||(root=process.cwd());let dirs=["src/app"].map(dir=>(0,import_node_path2.join)(root,dir));for(let dir of dirs)if((0,import_node_fs.existsSync)(dir))return appDir=dir,dir;return null}__name(findAppDirectory,"findAppDirectory");var import_node_path5=require("path");init_cjs_shims();var import_discord11=require("discord.js");init_cjs_shims();var import_discord10=require("discord.js");var _parsed,_options,_args,_MessageCommandParser=class _MessageCommandParser{constructor(message,prefix,schema){this.message=message;this.prefix=prefix;this.schema=schema;__privateAdd(this,_parsed,null);__privateAdd(this,_options,null);__privateAdd(this,_args,[])}getArgs(){return this.parse(),__privateGet(this,_args)}get options(){return __privateGet(this,_options)||__privateSet(this,_options,new MessageCommandOptions(this)),__privateGet(this,_options)}getOption(name){var _a;return(_a=this.parse().options.find(o=>o.name===name))==null?void 0:_a.value}getCommand(){return this.parse().command}getSubcommand(){return this.parse().subcommand}getSubcommandGroup(){return this.parse().subcommandGroup}getPrefix(){for(let p of this.prefix)if(this.message.content.startsWith(p))return p}getFullCommand(){return[this.getCommand(),this.getSubcommandGroup(),this.getSubcommand()].filter(v=>v).join(" ")}parse(){if(__privateGet(this,_parsed))return __privateGet(this,_parsed);let content=this.message.content,prefix=this.getPrefix();if(!prefix)throw createCommandKitError(CommandKitErrorCodes.InvalidCommandPrefix);let parts=content.slice(prefix.length).trim().split(" "),command=parts.shift();__privateSet(this,_args,parts);let subcommandGroup,subcommand;if(command!=null&&command.includes(":")){let[,group,cmd]=command.split(":");!cmd&&group?subcommand=group:cmd&&group&&(subcommandGroup=group,subcommand=cmd)}let schema=this.schema([command,subcommandGroup,subcommand].filter(Boolean).join(" ").trim()),options=parts.map(part=>{try{let[name,value]=part.split(":");if(!(name in schema))return null;switch(schema[name]){case import_discord10.ApplicationCommandOptionType.Boolean:return{name,value:value==="true"};case import_discord10.ApplicationCommandOptionType.Integer:return{name,value:parseInt(value,10)};case import_discord10.ApplicationCommandOptionType.Number:return{name,value:parseFloat(value)};case import_discord10.ApplicationCommandOptionType.String:return{name,value};case import_discord10.ApplicationCommandOptionType.User:return{name,value:this.message.mentions.users.find(u=>u.id===value.replace(/[<@!>]/g,""))};case import_discord10.ApplicationCommandOptionType.Channel:return{name,value:this.message.mentions.channels.find(c=>c.id===value.replace(/[<#>]/g,""))};case import_discord10.ApplicationCommandOptionType.Role:return{name,value:this.message.mentions.roles.find(r=>r.id===value.replace(/[<@&>]/g,""))};case import_discord10.ApplicationCommandOptionType.Attachment:return{name,value:this.message.attachments.find(a=>a.name===value)};default:return null}}catch{return null}}).filter(v=>v!==null);return __privateSet(this,_parsed,{command,options,subcommand,subcommandGroup}),__privateGet(this,_parsed)}};_parsed=new WeakMap,_options=new WeakMap,_args=new WeakMap,__name(_MessageCommandParser,"MessageCommandParser");var MessageCommandParser=_MessageCommandParser,_MessageCommandOptions=class _MessageCommandOptions{constructor(parser2){this.parser=parser2}assertOption(name,required=!1){let option=this.parser.getOption(name);if(required&&option===void 0)throw new Error(`Option "${name}" is required.`);return option??null}getMember(name,required=!1){var _a;let user=this.assertOption(name,required),member=(_a=this.parser.message.guild)==null?void 0:_a.members.cache.get(user==null?void 0:user.id);if(required&&!member)throw new Error(`Member "${name}" is required.`);return member??null}getAttachment(name,required=!1){return this.assertOption(name,required)}getBoolean(name,required=!1){return this.assertOption(name,required)}getNumber(name,required=!1){return this.assertOption(name,required)}getString(name,required=!1){return this.assertOption(name,required)}getInteger(name,required=!1){return this.assertOption(name,required)}getUser(name,required=!1){return this.assertOption(name,required)}getChannel(name,required=!1){return this.assertOption(name,required)}getRole(name,required=!1){return this.assertOption(name,required)}getMentionable(name,required=!1){let target=this.assertOption(name,required);if(target instanceof import_discord10.GuildMember||target instanceof import_discord10.User||target instanceof import_discord10.Role)return target;if(required)throw new Error(`Mentionable "${name}" is required.`);return null}getSubcommand(required=!1){let sub=this.parser.getSubcommand();if(required&&sub===void 0)throw new Error("Subcommand is required.");return sub??null}getSubcommandGroup(required=!1){let sub=this.parser.getSubcommandGroup();if(required&&sub===void 0)throw new Error("Subcommand group is required.");return sub??null}};__name(_MessageCommandOptions,"MessageCommandOptions");var MessageCommandOptions=_MessageCommandOptions;var commandDataSchema={command:__name(c=>c instanceof import_discord11.SlashCommandBuilder||c instanceof import_discord11.ContextMenuCommandBuilder||c&&typeof c=="object","command"),chatInput:__name(c=>typeof c=="function","chatInput"),autocomplete:__name(c=>typeof c=="function","autocomplete"),message:__name(c=>typeof c=="function","message"),messageContextMenu:__name(c=>typeof c=="function","messageContextMenu"),userContextMenu:__name(c=>typeof c=="function","userContextMenu")},middlewareDataSchema={beforeExecute:__name(c=>typeof c=="function","beforeExecute"),afterExecute:__name(c=>typeof c=="function","afterExecute")},_AppCommandHandler=class _AppCommandHandler{constructor(commandkit){this.commandkit=commandkit}loadedCommands=new import_discord11.Collection;loadedMiddlewares=new import_discord11.Collection;getCommandsArray(){return Array.from(this.loadedCommands.values()).map(v=>"toJSON"in v&&typeof v.toJSON=="function"?v.toJSON():v.data.command)}async prepareCommandRun(source){let cmd,parser2;if(source instanceof import_discord11.Message){if(source.author.bot)return null;let prefix=await this.commandkit.config.getMessageCommandPrefix(source);parser2=new MessageCommandParser(source,Array.isArray(prefix)?prefix:[prefix],command=>{var _a;let loadedCommand2=this.loadedCommands.find(c=>c.data.command.name===command);return loadedCommand2?((_a=("toJSON"in loadedCommand2.data.command?loadedCommand2.data.command.toJSON():loadedCommand2.data.command).options)==null?void 0:_a.reduce((acc,opt)=>(acc[opt.name]=opt.type,acc),{}))??{}:null});try{cmd=parser2.getFullCommand()}catch(e){return isErrorType(e,CommandKitErrorCodes.InvalidCommandPrefix)||console.error(e),null}}else{if(!source.isCommand())return null;if(cmd=source.commandName,source.isChatInputCommand()){let subcommandGroup=source.options.getSubcommandGroup(!1),subcommand=source.options.getSubcommand(!1);subcommandGroup&&(cmd+=` ${subcommandGroup}`),subcommand&&(cmd+=` ${subcommand}`)}}let loadedCommand=this.loadedCommands.find(c=>c.data.command.name===cmd);return loadedCommand?{command:loadedCommand,middlewares:loadedCommand.command.middlewares.map(m=>this.loadedMiddlewares.get(m)).filter(m=>!!m),messageCommandParser:parser2}:null}async loadCommands(){let commandsRouter=this.commandkit.commandsRouter;if(!commandsRouter)throw new Error("Commands router has not yet initialized");let{commands,middleware}=commandsRouter.getData();for(let[id,md]of middleware){let data=await import(`${toFileURL(md.fullPath)}?t=${Date.now()}`),handlerCount=0;for(let[key,validator]of Object.entries(middlewareDataSchema)){if(data[key]&&!await validator(data[key]))throw new Error(`Invalid export for middleware ${id}: ${key} does not match expected value`);data[key]&&handlerCount++}if(handlerCount===0)throw new Error(`Invalid export for middleware ${id}: at least one handler function must be provided`);this.loadedMiddlewares.set(id,{middleware:md,data})}for(let[name,command]of commands){let data=await import(`${toFileURL(command.fullPath)}?t=${Date.now()}`);if(!data.command)throw new Error(`Invalid export for command ${name}: no command definition found`);let handlerCount=0;for(let[key,validator]of Object.entries(commandDataSchema))if(key!=="command"&&data[key]&&handlerCount++,data[key]&&!await validator(data[key]))throw new Error(`Invalid export for command ${name}: ${key} does not match expected value`);if(handlerCount===0)throw new Error(`Invalid export for command ${name}: at least one handler function must be provided`);let localizedCommand=await this.applyLocalizations({...data.command});this.loadedCommands.set(name,{command,data:{...data,command:localizedCommand}})}}async applyLocalizations(command){var _a,_b,_c,_d,_e;let localization=this.commandkit.config.localizationStrategy,validLocales=Object.values(import_discord11.Locale).filter(v=>typeof v=="string");for(let locale of validLocales){let translation=await localization.locateTranslation(command.name,locale);if(translation!=null&&translation.command)if(command instanceof import_discord11.SlashCommandBuilder){translation.command.name&&command.setNameLocalization(locale,translation.command.name),translation.command.description&&command.setDescriptionLocalization(locale,translation.command.description);let raw=command.toJSON();if((_a=raw.options)!=null&&_a.length&&((_b=translation.command.options)!=null&&_b.length)){let opt=translation.command.options.slice(),o;for(;o=opt.shift();)(_c=raw.options)==null||_c.forEach(option=>{option.name===o.ref&&(option.name&&(option.name_localizations??={},option.name_localizations[locale]=o.name),option.description&&(option.description_localizations??={},option.description_localizations[locale]=o.description))})}}else{if(command instanceof import_discord11.ContextMenuCommandBuilder)return translation.command.name&&command.setNameLocalization(locale,translation.command.name),command.toJSON();if(command.name_localizations??={},command.name_localizations[locale]=translation.command.name,command.description&&(command.description_localizations??={},command.description_localizations[locale]=translation.command.description),(_d=command.options)!=null&&_d.length&&((_e=translation.command.options)!=null&&_e.length)){let opt=translation.command.options.slice(),o;for(;o=opt.shift();)command.options.forEach(option=>{option.name===o.ref&&(option.name&&(option.name_localizations??={},option.name_localizations[locale]=o.name),option.description&&(option.description_localizations??={},option.description_localizations[locale]=o.description))})}}}return command}};__name(_AppCommandHandler,"AppCommandHandler");var AppCommandHandler=_AppCommandHandler;init_cjs_shims();init_cjs_shims();var import_node_fs2=require("fs"),import_promises3=require("fs/promises"),import_node_path3=__toESM(require("path"));var _CommandsRouter=class _CommandsRouter{constructor(options){this.options=options;if(!options.entrypoint)throw new Error("Entrypoint directory must be provided");options.matcher??={},options.matcher.command??=/command\.(m|c)?(j|t)sx?$/,options.matcher.middleware??=/middleware\.(m|c)?(j|t)sx?$/}commands=new Map;middlewares=new Map;get entrypoint(){return this.options.entrypoint}get matchers(){return this.options.matcher}getData(){return{commands:this.commands,middleware:this.middlewares}}isValidPath(){return(0,import_node_fs2.existsSync)(this.entrypoint)}execMatcher(matcher,path4){return typeof matcher=="string"?path4.endsWith(matcher):matcher instanceof RegExp?matcher.test(path4):matcher(path4)}resolveRelativePath(path4){let regex=new RegExp(`^${this.entrypoint}`);return path4.replace(regex,"")}match(commandOrSegment){if(!(commandOrSegment!=null&&commandOrSegment.length))return null;if(Array.isArray(commandOrSegment)&&commandOrSegment.length===1&&(commandOrSegment=commandOrSegment[0]),!Array.isArray(commandOrSegment)&&!commandOrSegment.includes(" ")){let command2=this.commands.get(commandOrSegment);if(!command2)return null;let middlewares2=command2.middlewares.map(id=>this.middlewares.get(id)).filter(m=>!!m);return{command:command2,middlewares:middlewares2}}let segments=Array.isArray(commandOrSegment)?commandOrSegment:commandOrSegment.split(" "),command=Array.from(this.commands.values()).find(cmd=>{let commandSegments=cmd.parentSegments;return commandSegments.length!==segments.length?!1:commandSegments.every((segment,index)=>segment==="[name]"?!0:segment===segments[index])});if(!command)return null;let middlewares=command.middlewares.map(id=>this.middlewares.get(id)).filter(m=>!!m);return{command,middlewares}}async reload(){return this.clear(),this.scan()}clear(){this.commands.clear(),this.middlewares.clear()}async scan(){let files=await this.scanDirectory(this.entrypoint,[]);for(let file of files){if(this.execMatcher(this.matchers.command,file)){let location=this.resolveRelativePath(file),parts=location.split(import_node_path3.default.sep),parentSegments=[];parts.forEach((part,index,arr)=>{index!==arr.length-1&&(/\(.+\)/.test(part)||parentSegments.push(part.trim()))});let parent=parentSegments.join(" "),name=parts[parts.length-1].replace(/\.(m|c)?(j|t)sx?$/,""),command={name,middlewares:[],parent:parent||null,path:location,fullPath:file,parentSegments};this.commands.set(name,command)}if(this.execMatcher(this.matchers.middleware,file)){let location=this.resolveRelativePath(file),name=location.replace(/\.(m|c)?(j|t)sx?$/,""),middlewareDir=import_node_path3.default.dirname(location),command=Array.from(this.commands.values()).filter(command2=>{let commandDir=import_node_path3.default.dirname(command2.path);return commandDir===middlewareDir||commandDir.startsWith(middlewareDir)}),id=crypto.randomUUID(),middleware={id,name,path:location,fullPath:file};this.middlewares.set(id,middleware),command.forEach(cmd=>{cmd.middlewares.push(id)})}}return this.toJSON()}toJSON(){return{commands:Object.fromEntries(this.commands),middleware:Object.fromEntries(this.middlewares)}}async scanDirectory(dir,entries){let files=await(0,import_promises3.readdir)(dir,{withFileTypes:!0});for(let file of files)if(!(file.name==="node_modules"||file.parentPath.includes("node_modules"))){if(file.isDirectory()){let next=(0,import_node_path3.join)(dir,file.name);await this.scanDirectory(next,entries);continue}entries.push((0,import_node_path3.join)(dir,file.name))}return entries}};__name(_CommandsRouter,"CommandsRouter");var CommandsRouter=_CommandsRouter;init_cjs_shims();var import_node_fs3=require("fs"),import_promises4=require("fs/promises"),import_node_path4=require("path");var _EventsRouter=class _EventsRouter{constructor(options){this.options=options;if(!options.entrypoint)throw new Error("Entrypoint directory must be provided")}events=new Map;match(event){return this.events.get(event)??null}get entrypoint(){return this.options.entrypoint}isValidPath(){return(0,import_node_fs3.existsSync)(this.entrypoint)}clear(){this.events.clear()}async reload(){return this.clear(),this.scan()}async scan(){let dirs=await(0,import_promises4.readdir)(this.entrypoint,{withFileTypes:!0});for(let dir of dirs)if(dir.isDirectory()){let path4=(0,import_node_path4.join)(this.entrypoint,dir.name),event=await this.scanEvent(dir.name,path4);this.events.set(event.event,event)}return Object.fromEntries(this.events)}toJSON(){return Object.fromEntries(this.events)}async scanEvent(event,path4,listeners=[]){let files=await(0,import_promises4.readdir)(path4,{withFileTypes:!0});for(let file of files)if(!/node_modules/.test(file.name)){if(file.isDirectory()){let nextPath=(0,import_node_path4.join)(path4,file.name);await this.scanEvent(event,nextPath,listeners);continue}file.isFile()&&/\.(m|c)?(j|t)sx?$/.test(file.name)&&listeners.push((0,import_node_path4.join)(file.parentPath,file.name))}return{event,path:path4,listeners}}};__name(_EventsRouter,"EventsRouter");var EventsRouter=_EventsRouter;var _data5,_started,_CommandKit_instances,init_fn,initApp_fn,initCommands_fn,initEvents_fn,_CommandKit=class _CommandKit extends import_node_events.default{constructor(options){if(_CommandKit.instance&&process.emitWarning("CommandKit instance already exists. Having multiple instance in same project is discouraged and it may lead to unexpected behavior.",{code:"MultiInstanceWarning"}),!options.client)throw new Error(colors_default.red('"client" is required when instantiating CommandKit.'));if(options.validationsPath&&!options.commandsPath)throw new Error(colors_default.red('"commandsPath" is required when "validationsPath" is set.'));super();__privateAdd(this,_CommandKit_instances);__privateAdd(this,_data5);__privateAdd(this,_started,!1);__publicField(this,"eventInterceptor");__publicField(this,"config",{defaultLocale:import_discord12.Locale.EnglishUS,localizationStrategy:new DefaultLocalizationStrategy(this),getMessageCommandPrefix:__name(()=>"!","getMessageCommandPrefix")});__publicField(this,"commandsRouter");__publicField(this,"eventsRouter");__publicField(this,"appCommandsHandler",new AppCommandHandler(this));options.debugCommands??=process.env.NODE_ENV!=="production",options.cacheProvider!==null&&(!options.cacheProvider||!(options.cacheProvider instanceof CacheProvider))&&(options.cacheProvider=new MemoryCache),this.eventInterceptor=new EventInterceptor(options.client),__privateSet(this,_data5,options),_CommandKit.instance||(_CommandKit.instance=this)}async start(token){__privateGet(this,_started)||(await __privateMethod(this,_CommandKit_instances,init_fn).call(this),this.incrementClientListenersCount(),token!==!1&&!__privateGet(this,_data5).client.isReady()&&await __privateGet(this,_data5).client.login(token??process.env.TOKEN??process.env.DISCORD_TOKEN),__privateSet(this,_started,!0))}get started(){return __privateGet(this,_started)}setPrefixResolver(resolver){return this.config.getMessageCommandPrefix=resolver,this}setDefaultLocale(locale){return this.config.defaultLocale=locale,this}setLocalizationStrategy(strategy){return this.config.localizationStrategy=strategy,this}getCacheProvider(){return __privateGet(this,_data5).cacheProvider??null}isDebuggingCommands(){return __privateGet(this,_data5).debugCommands||!1}get client(){return __privateGet(this,_data5).client}get commandHandler(){return __privateGet(this,_data5).commandHandler}async reloadCommands(type){__privateGet(this,_data5).commandHandler&&await __privateGet(this,_data5).commandHandler.reloadCommands(type)}async reloadEvents(){__privateGet(this,_data5).eventHandler&&await __privateGet(this,_data5).eventHandler.reloadEvents(__privateGet(this,_data5).commandHandler)}async reloadValidations(){__privateGet(this,_data5).validationHandler&&await __privateGet(this,_data5).validationHandler.reloadValidations()}get commands(){return __privateGet(this,_data5).commandHandler?__privateGet(this,_data5).commandHandler.commands.map(cmd=>{let{run,autocomplete,...command}=cmd;return command}):[]}get commandsPath(){return __privateGet(this,_data5).commandsPath}get eventsPath(){return __privateGet(this,_data5).eventsPath}get validationsPath(){return __privateGet(this,_data5).validationsPath}get devUserIds(){return __privateGet(this,_data5).devUserIds||[]}get devGuildIds(){return __privateGet(this,_data5).devGuildIds||[]}get devRoleIds(){return __privateGet(this,_data5).devRoleIds||[]}incrementClientListenersCount(){__privateGet(this,_data5).client.setMaxListeners(__privateGet(this,_data5).client.getMaxListeners()+1)}decrementClientListenersCount(){__privateGet(this,_data5).client.setMaxListeners(__privateGet(this,_data5).client.getMaxListeners()-1)}getAppDirectory(){return findAppDirectory()}getPath(to){let appDir2=this.getAppDirectory();if(!appDir2)return null;switch(to){case"locales":return(0,import_node_path5.join)(appDir2,"locales");case"commands":return(0,import_node_path5.join)(appDir2,"commands");case"events":return(0,import_node_path5.join)(appDir2,"events");default:return to}}};_data5=new WeakMap,_started=new WeakMap,_CommandKit_instances=new WeakSet,init_fn=__name(async function(){if(__privateGet(this,_data5).eventsPath){let eventHandler=new EventHandler({client:__privateGet(this,_data5).client,eventsPath:__privateGet(this,_data5).eventsPath,commandKitInstance:this});await eventHandler.init(),__privateGet(this,_data5).eventHandler=eventHandler}if(__privateGet(this,_data5).validationsPath){let validationHandler=new ValidationHandler({validationsPath:__privateGet(this,_data5).validationsPath});await validationHandler.init(),__privateGet(this,_data5).validationHandler=validationHandler}if(__privateGet(this,_data5).commandsPath){let commandHandler=new CommandHandler({client:__privateGet(this,_data5).client,commandsPath:__privateGet(this,_data5).commandsPath,devGuildIds:__privateGet(this,_data5).devGuildIds||[],devUserIds:__privateGet(this,_data5).devUserIds||[],devRoleIds:__privateGet(this,_data5).devRoleIds||[],validationHandler:__privateGet(this,_data5).validationHandler,skipBuiltInValidations:__privateGet(this,_data5).skipBuiltInValidations||!1,commandkitInstance:this,bulkRegister:__privateGet(this,_data5).bulkRegister||!1});__privateGet(this,_data5).commandHandler=commandHandler,await __privateMethod(this,_CommandKit_instances,initApp_fn).call(this),await commandHandler.init()}},"#init"),initApp_fn=__name(async function(){if(!this.getAppDirectory())return;let commandsPath=this.getPath("commands"),events=this.getPath("events");this.commandsRouter=new CommandsRouter({entrypoint:commandsPath}),this.eventsRouter=new EventsRouter({entrypoint:events}),await __privateMethod(this,_CommandKit_instances,initEvents_fn).call(this),await __privateMethod(this,_CommandKit_instances,initCommands_fn).call(this)},"#initApp"),initCommands_fn=__name(async function(){this.commandsRouter.isValidPath()&&await this.commandsRouter.scan(),await this.appCommandsHandler.loadCommands()},"#initCommands"),initEvents_fn=__name(async function(){if(this.eventsRouter.isValidPath()&&await this.eventsRouter.scan(),!!__privateGet(this,_data5).eventHandler){for(let event of Object.values(this.eventsRouter.toJSON()))__privateGet(this,_data5).eventHandler.registerExternal(event);__privateGet(this,_data5).eventHandler.resyncListeners()}},"#initEvents"),__name(_CommandKit,"CommandKit"),__publicField(_CommandKit,"createElement",createElement),__publicField(_CommandKit,"Fragment",Fragment),__publicField(_CommandKit,"instance");var CommandKit=_CommandKit;init_cjs_shims();var defaultConfig={outDir:"dist",watch:!0,envExtra:!0,nodeOptions:[],clearRestartLogs:!0,minify:!1,sourcemap:!1,antiCrash:!0,requirePolyfill:!0};function getConfig(){return defaultConfig}__name(getConfig,"getConfig");function defineConfig(config){return{...defaultConfig,...config}}__name(defineConfig,"defineConfig");init_cjs_shims();init_cjs_shims();init_cjs_shims();init_cjs_shims();init_cjs_shims();async function bootstrapCommandkitCLI(argv,options){let{Command}=await import("commander"),{bootstrapDevelopmentServer:bootstrapDevelopmentServer2}=await Promise.resolve().then(()=>(init_development(),development_exports)),{bootstrapProductionServer:bootstrapProductionServer2}=await Promise.resolve().then(()=>(init_production(),production_exports)),{bootstrapProductionBuild:bootstrapProductionBuild2}=await Promise.resolve().then(()=>(init_build(),build_exports)),{generateCommand:generateCommand2,generateEvent:generateEvent2,generateLocale:generateLocale2}=await Promise.resolve().then(()=>(init_generators(),generators_exports)),program=new Command("commandkit");program.command("dev").description("Start your bot in development mode.").option("-c, --config <path>","Path to your commandkit config file.","./commandkit.js").action(()=>{let options2=program.opts();bootstrapDevelopmentServer2(options2)}),program.command("start").description("Start your bot in production mode after running the build command.").option("-c, --config <path>","Path to your commandkit.json file.","./commandkit.js").action(()=>{let options2=program.opts();bootstrapProductionServer2(options2.config)}),program.command("build").description("Build your project for production usage.").option("-c, --config <path>","Path to your commandkit.json file.","./commandkit.json").action(()=>{let options2=program.opts();bootstrapProductionBuild2(options2.config)}),program.command("create").description("Create new commands, events, or locale files").option("-c, --command <name>","Create a new command").option("-e, --event <name>","Create a new event").option("-l, --locale <locale> <command>","Create a new locale file for the given command").action(async options2=>{if(options2.command)await generateCommand2(options2.command);else if(options2.event)await generateEvent2(options2.event);else if(options2.locale){let[locale,command]=options2.locale;await generateLocale2(locale,command)}else console.error("Please specify what to create: --command, --event, or --locale")}),await program.parseAsync(argv,options)}__name(bootstrapCommandkitCLI,"bootstrapCommandkitCLI");var index_default=CommandKit,version="0.1.11-dev.20250216074741";0&&(module.exports={ActionRow,AppCommandHandler,Button,ButtonKit,CacheProvider,CommandExecutionMode,CommandKit,CommandKitEnvironment,CommandKitEnvironmentType,CommandsRouter,Context,DefaultLocalizationStrategy,DefaultLogger,ElementType,EventInterceptor,EventsRouter,Fragment,Localization,Logger,MemoryCache,MessageCommandOptions,MessageCommandParser,MiddlewareContext,Modal,ModalKit,ParagraphInput,ShortInput,TextInput,afterCommand,bootstrapCommandkitCLI,cache,cacheLife,cacheTag,cancelAfterCommand,createElement,createLogger,defineConfig,dmOnly,exitContext,exitMiddleware,getCommandKit,getConfig,getContext,getElement,guildOnly,invalidate,isCachedFunction,isCommandKitElement,makeContextAwareFunction,redirect,rethrow,revalidate,super_duper_secret_internal_for_use_cache_directive_of_commandkit_cli_do_not_use_it_directly_or_you_will_be_fired_from_your_job_kthxbai,useEnvironment,version});
48
+ `}let embed=new import_discord3.EmbedBuilder().setTitle(":x: Missing permissions!").setDescription(embedDescription).setColor("Red");return interaction.reply({embeds:[embed],flags:import_discord3.MessageFlags.Ephemeral}),!0}__name(permissions_default,"default");var validations_default=[devOnly_default,permissions_default];init_cjs_shims();var import_node_crypto=require("crypto");var _data,_CommandKitEnvironment=class _CommandKitEnvironment{constructor(commandkit){this.commandkit=commandkit;__privateAdd(this,_data,{executionError:null,type:null,variables:new Map,deferredFunctions:new Map,marker:"",markStart:0,markEnd:0})}getExecutionError(){return __privateGet(this,_data).executionError}setExecutionError(error){if(__privateGet(this,_data).executionError)throw new Error("Execution error already set.");__privateGet(this,_data).executionError=error}getType(){let type=__privateGet(this,_data).type;if(!type)throw new Error("Environment type not set.");return type}setType(type){__privateGet(this,_data).type=type}get variables(){return __privateGet(this,_data).variables}registerDeferredFunction(fn){let id=(0,import_node_crypto.randomUUID)();return __privateGet(this,_data).deferredFunctions.set(id,fn),id}clearDeferredFunction(id){__privateGet(this,_data).deferredFunctions.delete(id)}async runDeferredFunctions(){for(let[id,fn]of __privateGet(this,_data).deferredFunctions)try{await fn(this)}catch(e){this.commandkit.emit("unhandledDeferredFunctionRejection",e)}finally{this.clearDeferredFunction(id)}}clearAllDeferredFunctions(){__privateGet(this,_data).deferredFunctions.clear()}markStart(marker){__privateGet(this,_data).marker=marker,__privateGet(this,_data).markStart=performance.now()}markEnd(){__privateGet(this,_data).markEnd||(__privateGet(this,_data).markEnd=performance.now())}getMarker(){return __privateGet(this,_data).marker}getExecutionTime(){return Math.abs(__privateGet(this,_data).markEnd-__privateGet(this,_data).markStart)}};_data=new WeakMap,__name(_CommandKitEnvironment,"CommandKitEnvironment");var CommandKitEnvironment=_CommandKitEnvironment,CommandKitEnvironmentType=(CommandKitEnvironmentType2=>(CommandKitEnvironmentType2.CommandHandler="COMMAND_HANDLER",CommandKitEnvironmentType2))(CommandKitEnvironmentType||{});function afterCommand(fn){let env=getContext();if(!env)throw new Error("after must be called inside commandkit handler.");return env.registerDeferredFunction(fn)}__name(afterCommand,"afterCommand");function cancelAfterCommand(id){let env=getContext();if(!env)throw new Error("cancelAfter must be called inside commandkit handler.");env.clearDeferredFunction(id)}__name(cancelAfterCommand,"cancelAfterCommand");init_cjs_shims();init_cjs_shims();var _Localization=class _Localization{constructor(commandkit,config){this.commandkit=commandkit;this.config=config;let strategy=this.commandkit.config.localizationStrategy,{locale,target}=this.config;this.t=(translatable,args)=>strategy.translate({args,key:translatable,locale,scope:target})}t;getStrategy(){return this.commandkit.config.localizationStrategy}getDefaultLocale(){return this.commandkit.config.defaultLocale}getLocale(){return this.config.locale}getTarget(){return this.config.target}};__name(_Localization,"Localization");var Localization=_Localization;init_cjs_shims();function exitMiddleware(){throw createCommandKitError(CommandKitErrorCodes.ExitMiddleware)}__name(exitMiddleware,"exitMiddleware");function rethrow(error){if(isCommandKitError(error))throw error}__name(rethrow,"rethrow");function redirect(){throw createCommandKitError(CommandKitErrorCodes.ForwardedCommand)}__name(redirect,"redirect");init_cjs_shims();init_cjs_shims();var _CacheProvider=class _CacheProvider{};__name(_CacheProvider,"CacheProvider");var CacheProvider=_CacheProvider;init_cjs_shims();var _cache,_MemoryCache=class _MemoryCache extends CacheProvider{constructor(){super(...arguments);__privateAdd(this,_cache,new Map)}async get(key){let entry=__privateGet(this,_cache).get(key);if(entry){if(entry.ttl&&Date.now()>entry.ttl){__privateGet(this,_cache).delete(key);return}return entry}}async set(key,value,ttl){let entry={value,ttl:ttl!=null?Date.now()+ttl:void 0};__privateGet(this,_cache).set(key,entry)}async exists(key){return __privateGet(this,_cache).has(key)}async delete(key){__privateGet(this,_cache).delete(key)}async clear(){__privateGet(this,_cache).clear()}async expire(key,ttl){let entry=__privateGet(this,_cache).get(key);if(!entry)return;let _ttl=Date.now()+ttl;if(_ttl<Date.now()){__privateGet(this,_cache).delete(key);return}entry.ttl=_ttl}};_cache=new WeakMap,__name(_MemoryCache,"MemoryCache");var MemoryCache=_MemoryCache;init_cjs_shims();var import_node_async_hooks2=require("async_hooks");var import_node_crypto2=require("crypto"),import_ms=__toESM(require("ms"));var cacheContext=new import_node_async_hooks2.AsyncLocalStorage,fnStore=new Map,DEFAULT_TTL=(0,import_ms.default)("15m"),CACHE_FN_ID=`__cache_fn_id_${Date.now()}__${Math.random()}__`,CACHED_FN_SYMBOL=Symbol("commandkit.cache.sentinel");function md5(data){return(0,import_node_crypto2.createHash)("md5").update(data).digest("hex")}__name(md5,"md5");function getCacheProvider(){let provider=getCommandKit(!0).getCacheProvider();if(!provider)throw new Error("Cache provider was not found, please provide a cache provider to commandkit.");return provider}__name(getCacheProvider,"getCacheProvider");function useCache(fn,id,params){let isLocal=id===CACHE_FN_ID;if(id&&!isLocal)throw new Error("Illegal use of cache function.");let fnId=(0,import_node_crypto2.randomUUID)(),memo=__name((...args)=>{let keyHash=(isLocal?params==null?void 0:params.name:null)??md5(args.length?`${fnId}:${args.join(":")}`:fnId),resolvedTTL=isLocal&&(params==null?void 0:params.ttl)!=null?typeof params.ttl=="string"?(0,import_ms.default)(params.ttl):params.ttl:null;return cacheContext.run({params:{name:keyHash,ttl:resolvedTTL??DEFAULT_TTL}},async()=>{let provider=getCacheProvider(),context2=cacheContext.getStore();if(!context2)throw new Error("Cache context was not found.");let storedFn=fnStore.get(keyHash),effectiveKey=(storedFn==null?void 0:storedFn.key)??context2.params.name,cached=await provider.get(effectiveKey);if(cached&&cached.value!=null)return cached.value;let result=await fn(...args);if(result!=null){let finalKey=context2.params.name,ttl=context2.params.ttl??DEFAULT_TTL;await provider.set(finalKey,result,ttl),fnStore.set(keyHash,{key:finalKey,hash:keyHash,ttl,original:fn,memo})}return result})},"memo");return Object.prototype.hasOwnProperty.call(fn,CACHED_FN_SYMBOL)||Object.defineProperty(memo,CACHED_FN_SYMBOL,{get(){return!0},configurable:!1,enumerable:!1}),memo}__name(useCache,"useCache");function cache(fn,params){return useCache(fn,CACHE_FN_ID,params)}__name(cache,"cache");function cacheTag(tag){let context2=cacheContext.getStore();if(!context2)throw new Error("cacheTag() must be called inside a cached function.");if(!tag)throw new Error("cacheTag() must be called with a tag name.");context2.params.name=tag}__name(cacheTag,"cacheTag");function cacheLife(ttl){let context2=cacheContext.getStore();if(!context2)throw new Error("cacheLife() must be called inside a cached function.");if(ttl==null||!["string","number"].includes(typeof ttl))throw new Error("cacheLife() must be called with a ttl.");context2.params.ttl=typeof ttl=="string"?(0,import_ms.default)(ttl):ttl}__name(cacheLife,"cacheLife");async function invalidate(tag){let provider=getCacheProvider(),entry=Array.from(fnStore.values()).find(v=>v.key===tag||v.hash===tag);entry&&await provider.delete(entry.key)}__name(invalidate,"invalidate");async function revalidate(tag,...args){let provider=getCacheProvider(),entry=Array.from(fnStore.values()).find(v=>v.key===tag||v.hash===tag);if(entry)return await provider.delete(entry.key),entry.memo(...args)}__name(revalidate,"revalidate");function isCachedFunction(fn){return Object.prototype.hasOwnProperty.call(fn,CACHED_FN_SYMBOL)}__name(isCachedFunction,"isCachedFunction");var CommandExecutionMode={SlashCommand:"chatInput",MessageContextMenu:"messageContextMenu",UserContextMenu:"userContextMenu",Autocomplete:"autocomplete",Message:"message"},_store,_Context=class _Context{constructor(commandkit,config){this.commandkit=commandkit;this.config=config;__publicField(this,"interaction");__publicField(this,"message");__publicField(this,"client");__privateAdd(this,_store);__publicField(this,"_locale",null);this.interaction=config.interaction,this.message=config.message,this.client=commandkit.client,__privateSet(this,_store,config.store??new Map)}get store(){return __privateGet(this,_store)}get commandName(){return this.isInteraction()?this.interaction.commandName:this.config.messageCommandParser.getCommand()}get options(){return this.isMessage()?this.config.messageCommandParser.options:this.interaction.options}get forwarded(){return this.config.forwarded??!1}async forwardCommand(command){let target=await this.commandkit.appCommandsHandler.prepareCommandRun(this.isInteraction()?this.interaction:this.message);if(!target)throw new Error(`Command ${command} not found! If you are trying to forward to a legacy command, ctx.forwardCommand is not compatible with legacy commands.`);let env=this.config.environment??getContext();if(!env)throw new Error("No commandkit environment found.");let handlers={chatInput:target.command.data.chatInput,autocomplete:target.command.data.autocomplete,message:target.command.data.message,messageContextMenu:target.command.data.messageContextMenu,userContextMenu:target.command.data.userContextMenu},handlerKind=env.variables.get("execHandlerKind");if(!handlerKind)throw new Error("No execution handler kind found.");let handler=handlers[handlerKind];if(!handler)throw new Error(`No handler found for ${handlerKind}`);await handler(this.clone({forwarded:!0})),redirect()}get executionMode(){return this.config.executionMode}isInteraction(){return this.executionMode===CommandExecutionMode.SlashCommand||this.executionMode===CommandExecutionMode.Autocomplete||this.executionMode===CommandExecutionMode.MessageContextMenu||this.executionMode===CommandExecutionMode.UserContextMenu}isSlashCommand(){return this.executionMode===CommandExecutionMode.SlashCommand}isAutocomplete(){return this.executionMode===CommandExecutionMode.Autocomplete}isMessageContextMenu(){return this.executionMode===CommandExecutionMode.MessageContextMenu}isUserContextMenu(){return this.executionMode===CommandExecutionMode.UserContextMenu}isMessage(){return this.executionMode===CommandExecutionMode.Message}getCommandIdentifier(){return this.isInteraction()?this.interaction.commandName:this.message.content.split(" ")[0].slice(1)}getGuildLocale(){var _a;return this.isInteraction()?this.interaction.guildLocale:((_a=this.message.guild)==null?void 0:_a.preferredLocale)??null}getUserLocale(){return this.isInteraction()?this.interaction.locale:null}getLocale(preferUser=!1){if(this._locale)return this._locale;let locale=preferUser?this.getUserLocale():this.getGuildLocale();return locale||this.commandkit.config.defaultLocale}setLocale(locale){this._locale=locale}locale(locale){let selectedLocale=locale??this.getLocale();return new Localization(this.commandkit,{locale:selectedLocale,target:this.getCommandIdentifier()})}clone(config){return config?new _Context(this.commandkit,{...this.config,...config,store:__privateGet(this,_store)}):new _Context(this.commandkit,this.config)}isMiddleware(){return this instanceof MiddlewareContext}args(){return this.isMessage()?this.config.messageCommandParser.getArgs():[]}exit(){exitMiddleware()}defer(fn){return afterCommand(fn)}cancelDeferred(id){cancelAfterCommand(id)}isCached(fn){return isCachedFunction(fn)}};_store=new WeakMap,__name(_Context,"Context");var Context=_Context,_cancel,_MiddlewareContext=class _MiddlewareContext extends Context{constructor(){super(...arguments);__privateAdd(this,_cancel,!1)}get cancelled(){return __privateGet(this,_cancel)}cancel(){__privateSet(this,_cancel,!0)}};_cancel=new WeakMap,__name(_MiddlewareContext,"MiddlewareContext");var MiddlewareContext=_MiddlewareContext;var _data2,_CommandHandler_instances,buildCommands_fn,buildBuiltInValidations_fn,commandFinalizer_fn,requestExternalHandler_fn,interactionHandler_fn,_CommandHandler=class _CommandHandler{constructor({...options}){__privateAdd(this,_CommandHandler_instances);__privateAdd(this,_data2);__privateSet(this,_data2,{...options,builtInValidations:[],commands:[]})}async init(){await __privateMethod(this,_CommandHandler_instances,buildCommands_fn).call(this),__privateMethod(this,_CommandHandler_instances,buildBuiltInValidations_fn).call(this);let devOnlyCommands=__privateGet(this,_data2).commands.filter(cmd=>{var _a;return(_a=cmd.options)==null?void 0:_a.devOnly});devOnlyCommands.length&&!__privateGet(this,_data2).devGuildIds.length&&process.emitWarning(colors_default.yellow('You have commands marked as "devOnly", but "devGuildIds" have not been set.')),devOnlyCommands.length&&!__privateGet(this,_data2).devUserIds.length&&!__privateGet(this,_data2).devRoleIds.length&&process.emitWarning(colors_default.yellow('You have commands marked as "devOnly", but "devUserIds" or "devRoleIds" have not been set.')),__privateGet(this,_data2).bulkRegister?await loadCommandsWithRest({client:__privateGet(this,_data2).client,devGuildIds:__privateGet(this,_data2).devGuildIds,commands:__privateGet(this,_data2).commands}):await registerCommands({client:__privateGet(this,_data2).client,devGuildIds:__privateGet(this,_data2).devGuildIds,commands:__privateGet(this,_data2).commands}),this.handleCommands()}handleCommands(){__privateGet(this,_data2).client.on(import_discord4.Events.InteractionCreate,interaction=>{let env=new CommandKitEnvironment(__privateGet(this,_data2).commandkitInstance);return env.setType("COMMAND_HANDLER"),makeContextAwareFunction(env,__privateMethod(this,_CommandHandler_instances,interactionHandler_fn).bind(this),__privateMethod(this,_CommandHandler_instances,commandFinalizer_fn).bind(this))(interaction)}),__privateGet(this,_data2).client.on(import_discord4.Events.MessageCreate,message=>{let env=new CommandKitEnvironment(__privateGet(this,_data2).commandkitInstance);return env.setType("COMMAND_HANDLER"),makeContextAwareFunction(env,__privateMethod(this,_CommandHandler_instances,requestExternalHandler_fn).bind(this),__privateMethod(this,_CommandHandler_instances,commandFinalizer_fn).bind(this))(message)})}get commands(){return __privateGet(this,_data2).commands}async reloadCommands(type){if(!__privateGet(this,_data2).commandsPath)throw new Error(colors_default.red('Cannot reload commands as "commandsPath" was not provided when instantiating CommandKit.'));__privateGet(this,_data2).commands=[],await __privateMethod(this,_CommandHandler_instances,buildCommands_fn).call(this),__privateGet(this,_data2).bulkRegister?await loadCommandsWithRest({client:__privateGet(this,_data2).client,devGuildIds:__privateGet(this,_data2).devGuildIds,commands:__privateGet(this,_data2).commands,reloading:!0,type}):await registerCommands({client:__privateGet(this,_data2).client,devGuildIds:__privateGet(this,_data2).devGuildIds,commands:__privateGet(this,_data2).commands,reloading:!0,type})}};_data2=new WeakMap,_CommandHandler_instances=new WeakSet,buildCommands_fn=__name(async function(){var _a;if(!__privateGet(this,_data2).commandsPath)return;let allowedExtensions=/\.(c|m)?(j|t)sx?$/i,commandFilePaths=(await getFilePaths(__privateGet(this,_data2).commandsPath,!0)).filter(path4=>allowedExtensions.test(path4));for(let commandFilePath of commandFilePaths){let importedObj=await import(`${toFileURL(commandFilePath)}?t=${Date.now()}`),commandObj=clone(importedObj);typeof module<"u"&&typeof require<"u"&&delete require.cache[require.resolve(commandFilePath)];let compactFilePath=commandFilePath.split(process.cwd())[1]||commandFilePath;if(commandObj.default&&(commandObj=commandObj.default),importedObj.default?commandObj.data=importedObj.default.data:commandObj.data=importedObj.data,!commandObj.data){process.emitWarning(colors_default.yellow(`Ignoring: Command file ${compactFilePath} does not export "data".`));continue}if(!commandObj.data.name){process.emitWarning(colors_default.yellow(`Ignoring: Command file ${compactFilePath} does not export "data.name".`));continue}if(!commandObj.run){process.emitWarning(colors_default.yellow(`Ignoring: Command file ${commandObj.data.name} does not export "run".`));continue}if(typeof commandObj.run!="function"){process.emitWarning(colors_default.yellow(`Ignoring: Command file ${commandObj.data.name} does not export "run" as a function.`));continue}commandObj.filePath=commandFilePath;let commandCategory=((_a=commandFilePath.split(__privateGet(this,_data2).commandsPath)[1])==null?void 0:_a.replace(/\\\\|\\/g,"/").split("/")[1])||null;commandCategory&&allowedExtensions.test(commandCategory)?commandObj.category=null:commandObj.category=commandCategory,__privateGet(this,_data2).commands.push(commandObj)}if(__privateGet(this,_data2).commandkitInstance.appCommandsHandler){let commands=__privateGet(this,_data2).commandkitInstance.appCommandsHandler.getCommandsArray();for(let cmd of commands){let idx=__privateGet(this,_data2).commands.findIndex(c=>c.data.name===cmd.name);idx!==-1?__privateGet(this,_data2).commands[idx]={data:cmd}:__privateGet(this,_data2).commands.push({data:cmd})}}},"#buildCommands"),buildBuiltInValidations_fn=__name(function(){for(let builtInValidationFunction of validations_default)__privateGet(this,_data2).builtInValidations.push(builtInValidationFunction)},"#buildBuiltInValidations"),commandFinalizer_fn=__name(async function(){let env=useEnvironment();await env.runDeferredFunctions(),env.clearAllDeferredFunctions()},"#commandFinalizer"),requestExternalHandler_fn=__name(async function(interaction){let handler=__privateGet(this,_data2).commandkitInstance.appCommandsHandler;if(!handler||!(interaction instanceof import_discord4.Message)&&!(interaction.isCommand()||interaction.isAutocomplete()))return 0;let targetCommand=await handler.prepareCommandRun(interaction);if(!targetCommand)return 0;let environment=useEnvironment();environment.variables.set("commandHandlerType","app");let{command,middlewares,messageCommandParser}=targetCommand,context2=new MiddlewareContext(__privateGet(this,_data2).commandkitInstance,{executionMode:interaction instanceof import_discord4.Message?CommandExecutionMode.Message:interaction.isChatInputCommand()?CommandExecutionMode.SlashCommand:interaction.isUserContextMenuCommand()?CommandExecutionMode.UserContextMenu:interaction.isMessageContextMenuCommand()?CommandExecutionMode.MessageContextMenu:interaction.isAutocomplete()?CommandExecutionMode.Autocomplete:null,interaction:interaction instanceof import_discord4.Message?null:interaction,message:interaction instanceof import_discord4.Message?interaction:null,messageCommandParser});environment.variables.set("currentCommandName",context2.commandName);let exec=__name(async()=>{var _a,_b,_c,_d,_e,_f,_g,_h,_i,_j;if(middlewares.length>0)for(let middleware of middlewares){if(context2.cancelled)return 1;try{await middleware.data.beforeExecute(context2)}catch(e){if(isErrorType(e,CommandKitErrorCodes.ExitMiddleware))break;if(isErrorType(e,[CommandKitErrorCodes.DMOnlyException,CommandKitErrorCodes.GuildOnlyException,CommandKitErrorCodes.ForwardedCommand]))return;throw e}}if(context2.cancelled)return 1;let postStageRunner=!0;try{let commandContext=context2.clone({environment});if(interaction instanceof import_discord4.Message)environment.variables.set("execHandlerKind","message"),await((_b=(_a=command.data).message)==null?void 0:_b.call(_a,commandContext));else switch(!0){case interaction.isChatInputCommand():environment.variables.set("execHandlerKind","chatInput"),await((_d=(_c=command.data).chatInput)==null?void 0:_d.call(_c,commandContext));break;case interaction.isUserContextMenuCommand():environment.variables.set("execHandlerKind","userContextMenu"),await((_f=(_e=command.data).userContextMenu)==null?void 0:_f.call(_e,commandContext));break;case interaction.isMessageContextMenuCommand():environment.variables.set("execHandlerKind","messageContextMenu"),await((_h=(_g=command.data).messageContextMenu)==null?void 0:_h.call(_g,commandContext));break;case interaction.isAutocomplete():environment.variables.set("execHandlerKind","autocomplete"),await((_j=(_i=command.data).autocomplete)==null?void 0:_j.call(_i,commandContext));break;default:break}}catch(e){if(Logger.error(e),isErrorType(e,CommandKitErrorCodes.ExitMiddleware))postStageRunner=!1;else{if(isErrorType(e,[CommandKitErrorCodes.DMOnlyException,CommandKitErrorCodes.GuildOnlyException,CommandKitErrorCodes.ForwardedCommand]))return;throw e}}if(postStageRunner&&middlewares.length>0)for(let middleware of middlewares)try{await middleware.data.afterExecute(context2)}catch(e){if(isErrorType(e,CommandKitErrorCodes.ExitMiddleware))break;if(isErrorType(e,[CommandKitErrorCodes.DMOnlyException,CommandKitErrorCodes.GuildOnlyException,CommandKitErrorCodes.ForwardedCommand]))return;throw e}},"exec");if(!__privateGet(this,_data2).commandkitInstance.isDebuggingCommands())return await exec(),1;afterCommand(env=>{let error=env.getExecutionError(),marker=env.getMarker(),time=`${env.getExecutionTime().toFixed(2)}ms`;if(error){Logger.error(colors_default.red(`[${marker} - ${time}] Error executing command: ${error.stack||error}`));return}Logger.log(colors_default.green(`[${marker} - ${time}] Command executed successfully`))});try{return environment.markStart(`${command.data.command.name}`),await exec(),1}finally{environment.markEnd()}},"#requestExternalHandler"),interactionHandler_fn=__name(async function(interaction){try{if(await __privateMethod(this,_CommandHandler_instances,requestExternalHandler_fn).call(this,interaction)===1)return}catch(e){console.error(e);return}if(!interaction.isChatInputCommand()&&!interaction.isContextMenuCommand()&&!interaction.isAutocomplete())return;let isAutocomplete=interaction.isAutocomplete(),targetCommand=__privateGet(this,_data2).commands.find(cmd=>cmd.data.name===interaction.commandName);if(!targetCommand)return;let env=useEnvironment();env.variables.set("currentCommandName",interaction.commandName),env.variables.set("commandHandlerType","legacy"),env.variables.set("interaction",interaction),env.variables.set("execHandlerKind",isAutocomplete?"autocomplete":"chatInput");let{data,options,run,autocomplete,...rest}=targetCommand;return isAutocomplete&&!autocomplete?void 0:__name(async()=>{let commandObj={data:targetCommand.data,options:targetCommand.options,...rest};if(__privateGet(this,_data2).validationHandler){let canRun2=!0;for(let validationFunction of __privateGet(this,_data2).validationHandler.validations)if(await validationFunction({interaction,commandObj,client:__privateGet(this,_data2).client,handler:__privateGet(this,_data2).commandkitInstance})){canRun2=!1;break}if(!canRun2)return}let canRun=!0;if(!__privateGet(this,_data2).skipBuiltInValidations){for(let validation of __privateGet(this,_data2).builtInValidations)if(validation({targetCommand,interaction,handlerData:__privateGet(this,_data2)})){canRun=!1;break}}if(!canRun)return;let command=targetCommand[isAutocomplete?"autocomplete":"run"];if(!command)return;let context2={interaction,client:__privateGet(this,_data2).client,handler:__privateGet(this,_data2).commandkitInstance};if(!__privateGet(this,_data2).commandkitInstance.isDebuggingCommands())return command(context2);afterCommand(env2=>{let error=env2.getExecutionError(),marker=env2.getMarker(),time=`${env2.getExecutionTime().toFixed(2)}ms`;if(error){Logger.error(colors_default.red(`[${marker} - ${time}] Error executing command: ${error.stack||error}`));return}Logger.log(colors_default.green(`[${marker} - ${time}] Command executed successfully`))});try{return env.markStart(interaction.commandName),await command(context2)}finally{env.markEnd()}},"executor")()},"#interactionHandler"),__name(_CommandHandler,"CommandHandler");var CommandHandler=_CommandHandler;init_cjs_shims();init_colors();var _data3,_listening,_EventHandler_instances,buildEvents_fn,registerEvents_fn,_EventHandler=class _EventHandler{constructor({...options}){__privateAdd(this,_EventHandler_instances);__privateAdd(this,_data3);__privateAdd(this,_listening,new Set);__privateSet(this,_data3,{...options,events:[]})}async init(){await __privateMethod(this,_EventHandler_instances,buildEvents_fn).call(this),__privateMethod(this,_EventHandler_instances,registerEvents_fn).call(this)}async registerExternal(entry){let{event,listeners}=entry,functions=await Promise.all(listeners.map(async l=>import(`${toFileURL(l)}?t=${Date.now()}`).then(m=>m.default))),existing=__privateGet(this,_data3).events.find(e=>e.name===event);existing?existing.functions.unshift(...functions):__privateGet(this,_data3).events.unshift({name:event,functions})}resyncListeners(){let client=__privateGet(this,_data3).client,handler=__privateGet(this,_data3).commandKitInstance;for(let eventObj of __privateGet(this,_data3).events)__privateGet(this,_listening).has(eventObj.name)||(client.on(eventObj.name,async(...params)=>{for(let eventFunction of eventObj.functions)if(await eventFunction(...params,client,handler))break}),__privateGet(this,_listening).add(eventObj.name))}get events(){return __privateGet(this,_data3).events}async reloadEvents(commandHandler){if(!__privateGet(this,_data3).eventsPath)throw new Error(colors_default.red('Cannot reload events as "eventsPath" was not provided when instantiating CommandKit.'));__privateGet(this,_data3).events=[],await __privateMethod(this,_EventHandler_instances,buildEvents_fn).call(this),__privateGet(this,_listening).clear(),__privateGet(this,_data3).client.removeAllListeners(),__privateMethod(this,_EventHandler_instances,registerEvents_fn).call(this),commandHandler==null||commandHandler.handleCommands()}};_data3=new WeakMap,_listening=new WeakMap,_EventHandler_instances=new WeakSet,buildEvents_fn=__name(async function(){if(!__privateGet(this,_data3).eventsPath)return;let eventFolderPaths=await getFolderPaths(__privateGet(this,_data3).eventsPath);for(let eventFolderPath of eventFolderPaths){let eventName=eventFolderPath.replace(/\\\\|\\/g,"/").split("/").pop(),allowedExtensions=/\.(js|mjs|cjs|ts)$/i,eventFilePaths=(await getFilePaths(eventFolderPath,!0)).filter(path4=>allowedExtensions.test(path4)),eventObj=__privateGet(this,_data3).events.find(e=>e.name===eventName);eventObj||(eventObj={name:eventName,functions:[]},__privateGet(this,_data3).events.push(eventObj));for(let eventFilePath of eventFilePaths){let importedFunction=(await import(`${toFileURL(eventFilePath)}?t=${Date.now()}`)).default,eventFunction=clone(importedFunction);typeof module<"u"&&typeof require<"u"&&delete require.cache[require.resolve(eventFilePath)],eventFunction!=null&&eventFunction.default&&(eventFunction=eventFunction.default);let compactFilePath=eventFilePath.split(process.cwd())[1]||eventFilePath;if(typeof eventFunction!="function"){process.emitWarning(colors_default.yellow(`Ignoring: Event file ${compactFilePath} does not export a function.`));continue}eventObj.functions.push(eventFunction)}}},"#buildEvents"),registerEvents_fn=__name(function(){let client=__privateGet(this,_data3).client,handler=__privateGet(this,_data3).commandKitInstance;for(let eventObj of __privateGet(this,_data3).events)client.on(eventObj.name,async(...params)=>{for(let eventFunction of eventObj.functions)if(await eventFunction(...params,client,handler))break}),__privateGet(this,_listening).add(eventObj.name)},"#registerEvents"),__name(_EventHandler,"EventHandler");var EventHandler=_EventHandler;init_cjs_shims();init_colors();var _data4,_ValidationHandler_instances,buildValidations_fn,_ValidationHandler=class _ValidationHandler{constructor({...options}){__privateAdd(this,_ValidationHandler_instances);__privateAdd(this,_data4);__privateSet(this,_data4,{...options,validations:[]})}async init(){__privateGet(this,_data4).validations=await __privateMethod(this,_ValidationHandler_instances,buildValidations_fn).call(this)}get validations(){return __privateGet(this,_data4).validations}async reloadValidations(){if(!__privateGet(this,_data4).validationsPath)throw new Error(colors_default.red('Cannot reload validations as "validationsPath" was not provided when instantiating CommandKit.'));let newValidations=await __privateMethod(this,_ValidationHandler_instances,buildValidations_fn).call(this);__privateGet(this,_data4).validations=newValidations}};_data4=new WeakMap,_ValidationHandler_instances=new WeakSet,buildValidations_fn=__name(async function(){let allowedExtensions=/\.(js|mjs|cjs|ts)$/i,validationFilePaths=(await getFilePaths(__privateGet(this,_data4).validationsPath,!0)).filter(path4=>allowedExtensions.test(path4)),validationFunctions=[];for(let validationFilePath of validationFilePaths){let importedFunction=(await import(`${toFileURL(validationFilePath)}?t=${Date.now()}`)).default,validationFunction=clone(importedFunction);typeof module<"u"&&typeof require<"u"&&delete require.cache[require.resolve(validationFilePath)],validationFunction!=null&&validationFunction.default&&(validationFunction=validationFunction.default);let compactFilePath=validationFilePath.split(process.cwd())[1]||validationFilePath;if(typeof validationFunction!="function"){process.emitWarning(colors_default.yellow(`Ignoring: Validation file ${compactFilePath} does not export a function.`));continue}validationFunctions.push(validationFunction)}return validationFunctions},"#buildValidations"),__name(_ValidationHandler,"ValidationHandler");var ValidationHandler=_ValidationHandler;init_colors();init_cjs_shims();init_cjs_shims();var import_discord5=require("discord.js");function ActionRow(props){let row=new import_discord5.ActionRowBuilder;return Array.isArray(props.children)?row.setComponents(...props.children):props.children&&row.setComponents(props.children),row}__name(ActionRow,"ActionRow");init_cjs_shims();var import_discord6=require("discord.js");var _onClickHandler,_contextData,_unsub,_ButtonKit_instances,getEventInterceptor_fn,setupInteractionCollector_fn,destroyCollector_fn,_ButtonKit=class _ButtonKit extends import_discord6.ButtonBuilder{constructor(){super(...arguments);__privateAdd(this,_ButtonKit_instances);__privateAdd(this,_onClickHandler,null);__privateAdd(this,_contextData,{autoReset:!0,time:5*60*1e3,once:!1});__privateAdd(this,_unsub,null)}onClick(handler,data){var _a,_b,_c,_d;if(this.data.style===import_discord6.ButtonStyle.Link)throw new TypeError('Cannot setup "onClick" handler on link buttons.');if(!handler)throw new TypeError('Cannot setup "onClick" without a handler function parameter.');return __privateGet(this,_onClickHandler)&&__privateMethod(this,_ButtonKit_instances,destroyCollector_fn).call(this),__privateSet(this,_onClickHandler,handler),data&&__privateSet(this,_contextData,{autoReset:data.autoReset??((_a=__privateGet(this,_contextData))==null?void 0:_a.autoReset)??!0,time:data.time??((_b=__privateGet(this,_contextData))==null?void 0:_b.time)??5*60*1e3,filter:data.filter??((_c=__privateGet(this,_contextData))==null?void 0:_c.filter),onEnd:data.onEnd??((_d=__privateGet(this,_contextData))==null?void 0:_d.onEnd)}),__privateMethod(this,_ButtonKit_instances,setupInteractionCollector_fn).call(this),this}onEnd(handler){if(this.data.style===import_discord6.ButtonStyle.Link)throw new TypeError('Cannot setup "onEnd" handler on link buttons.');if(!handler)throw new TypeError('Cannot setup "onEnd" without a handler function parameter.');return __privateGet(this,_contextData)??__privateSet(this,_contextData,{}),__privateGet(this,_contextData).onEnd=handler,this}onError(handler){if(!handler)throw new TypeError('Cannot setup "onError" without a handler function parameter.');return __privateGet(this,_contextData)??__privateSet(this,_contextData,{}),__privateGet(this,_contextData).onError=handler,this}filter(predicate){return __privateGet(this,_contextData)??__privateSet(this,_contextData,{autoReset:!0,time:5*60*1e3}),__privateGet(this,_contextData).filter=predicate,this}get customId(){return this.data.custom_id??this.data.customId}dispose(){return __privateMethod(this,_ButtonKit_instances,destroyCollector_fn).call(this),this}};_onClickHandler=new WeakMap,_contextData=new WeakMap,_unsub=new WeakMap,_ButtonKit_instances=new WeakSet,getEventInterceptor_fn=__name(function(){let ctx=getContext();return ctx?exitContext(()=>ctx.commandkit.eventInterceptor):getCommandKit(!0).eventInterceptor},"#getEventInterceptor"),setupInteractionCollector_fn=__name(function(){if(this.data.style===import_discord6.ButtonStyle.Link||!__privateGet(this,_contextData)||!__privateGet(this,_onClickHandler))return;if((this.customId??null)===null)throw new TypeError('Cannot setup "onClick" handler on a button without a custom id.');let interceptor=__privateMethod(this,_ButtonKit_instances,getEventInterceptor_fn).call(this);__privateSet(this,_unsub,interceptor.subscribe(import_discord6.Events.InteractionCreate,async interaction=>{var _a,_b;if(!interaction.isButton())return;let myCustomId2=this.customId??null,interactionCustomId=interaction.customId;if(myCustomId2&&interactionCustomId!==myCustomId2)return;let filter=(_a=__privateGet(this,_contextData))==null?void 0:_a.filter;if(filter&&!await filter(interaction))return;let handler=__privateGet(this,_onClickHandler);return handler?handler(interaction,this):(_b=__privateGet(this,_unsub))==null?void 0:_b.call(this)},__privateGet(this,_contextData)))},"#setupInteractionCollector"),destroyCollector_fn=__name(function(){var _a;(_a=__privateGet(this,_unsub))==null||_a.call(this),__privateSet(this,_unsub,null),__privateSet(this,_contextData,null),__privateSet(this,_onClickHandler,null)},"#destroyCollector"),__name(_ButtonKit,"ButtonKit");var ButtonKit=_ButtonKit;init_cjs_shims();var import_discord7=require("discord.js");function Button(props){let button=new ButtonKit;props.style??=import_discord7.ButtonStyle.Primary,props.onClick&&(props.customId??=`buttonkit::${crypto.randomUUID()}`),props.customId&&button.setCustomId(props.customId),props.onClick&&button.onClick(props.onClick,props.options),props.disabled&&button.setDisabled(props.disabled),props.emoji&&button.setEmoji(props.emoji),props.skuId&&button.setSKUId(props.skuId),props.url&&button.setURL(props.url),props.style&&button.setStyle(props.style);let label=props.label||props.children;return label&&button.setLabel(Array.isArray(label)?label.join(" "):typeof label=="string"?label:String(label)),props.onEnd&&button.onEnd(props.onEnd),props.onError&&button.onError(props.onError),button}__name(Button,"Button");init_cjs_shims();var import_discord8=require("discord.js");var _onSubmitHandler,_contextData2,_unsub2,_ModalKit_instances,getEventInterceptor_fn2,setupCollector_fn,destroyCollector_fn2,_ModalKit=class _ModalKit extends import_discord8.ModalBuilder{constructor(){super(...arguments);__privateAdd(this,_ModalKit_instances);__privateAdd(this,_onSubmitHandler,null);__privateAdd(this,_contextData2,{autoReset:!1,time:5*60*1e3,once:!0});__privateAdd(this,_unsub2,null)}onSubmit(handler,data){var _a,_b,_c,_d;if(!handler)throw new TypeError('Cannot setup "onClick" without a handler function parameter.');return __privateGet(this,_onSubmitHandler)&&__privateMethod(this,_ModalKit_instances,destroyCollector_fn2).call(this),__privateSet(this,_onSubmitHandler,handler),data&&__privateSet(this,_contextData2,{autoReset:data.autoReset??((_a=__privateGet(this,_contextData2))==null?void 0:_a.autoReset)??!0,time:data.time??((_b=__privateGet(this,_contextData2))==null?void 0:_b.time)??5*60*1e3,filter:data.filter??((_c=__privateGet(this,_contextData2))==null?void 0:_c.filter),onEnd:data.onEnd??((_d=__privateGet(this,_contextData2))==null?void 0:_d.onEnd)}),__privateMethod(this,_ModalKit_instances,setupCollector_fn).call(this),this}onEnd(handler){if(!handler)throw new TypeError('Cannot setup "onEnd" without a handler function parameter.');return __privateGet(this,_contextData2)??__privateSet(this,_contextData2,{}),__privateGet(this,_contextData2).onEnd=handler,this}onError(handler){if(!handler)throw new TypeError('Cannot setup "onError" without a handler function parameter.');return __privateGet(this,_contextData2)??__privateSet(this,_contextData2,{}),__privateGet(this,_contextData2).onError=handler,this}filter(predicate){return __privateGet(this,_contextData2)??__privateSet(this,_contextData2,{autoReset:!0,time:5*60*1e3}),__privateGet(this,_contextData2).filter=predicate,this}get customId(){return this.data.custom_id??this.data.customId}dispose(){return __privateMethod(this,_ModalKit_instances,destroyCollector_fn2).call(this),this}};_onSubmitHandler=new WeakMap,_contextData2=new WeakMap,_unsub2=new WeakMap,_ModalKit_instances=new WeakSet,getEventInterceptor_fn2=__name(function(){let ctx=getContext();return ctx?exitContext(()=>ctx.commandkit.eventInterceptor):getCommandKit(!0).eventInterceptor},"#getEventInterceptor"),setupCollector_fn=__name(function(){if(!__privateGet(this,_contextData2))return;if(!this.customId)throw new TypeError("Cannot setup an modal collector without a custom ID.");let interceptor=__privateMethod(this,_ModalKit_instances,getEventInterceptor_fn2).call(this);interceptor&&__privateSet(this,_unsub2,interceptor.subscribe(import_discord8.Events.InteractionCreate,async interaction=>{var _a,_b;if(!interaction.isModalSubmit())return;let myCustomId=this.customId??null,interactionCustomId=interaction.customId;if(myCustomId&&interactionCustomId!==myCustomId)return;let filter=(_a=__privateGet(this,_contextData2))==null?void 0:_a.filter;if(filter&&!await filter(interaction))return;let handler=__privateGet(this,_onSubmitHandler);return handler?handler(interaction,this):(_b=__privateGet(this,_unsub2))==null?void 0:_b.call(this)},__privateGet(this,_contextData2)))},"#setupCollector"),destroyCollector_fn2=__name(function(){var _a;(_a=__privateGet(this,_unsub2))==null||_a.call(this),__privateSet(this,_unsub2,null),__privateSet(this,_onSubmitHandler,null),__privateSet(this,_contextData2,null)},"#destroyCollector"),__name(_ModalKit,"ModalKit");var ModalKit=_ModalKit;init_cjs_shims();var import_discord9=require("discord.js");function Modal(props){let modal=new ModalKit;if(props.title&&modal.setTitle(props.title),props.onSubmit&&(props.customId??=`modalkit::${crypto.randomUUID()}`),props.customId&&modal.setCustomId(props.customId),props.onSubmit&&modal.onSubmit(props.onSubmit,props.options),props.children){let childs=(Array.isArray(props.children)?props.children:[props.children]).map(c=>{if(c instanceof import_discord9.ActionRowBuilder)return c;if(c instanceof import_discord9.TextInputBuilder)return new import_discord9.ActionRowBuilder().addComponents(c)}).filter(c=>c!=null);modal.addComponents(childs)}return props.onEnd&&modal.onEnd(props.onEnd),props.onError&&modal.onError(props.onError),modal}__name(Modal,"Modal");function TextInput(props){let input=new import_discord9.TextInputBuilder().setStyle(props.style);return props.customId&&input.setCustomId(props.customId),props.label&&input.setLabel(props.label),props.placeholder&&input.setPlaceholder(props.placeholder),props.maxLength&&input.setMaxLength(props.maxLength),props.minLength&&input.setMinLength(props.minLength),props.value&&input.setValue(props.value),props.required&&input.setRequired(props.required),input}__name(TextInput,"TextInput");function ShortInput(props){return TextInput({...props,style:import_discord9.TextInputStyle.Short})}__name(ShortInput,"ShortInput");function ParagraphInput(props){return TextInput({...props,style:import_discord9.TextInputStyle.Paragraph})}__name(ParagraphInput,"ParagraphInput");init_cjs_shims();init_cjs_shims();var WARNED_KEYS=new Set;function emitWarning(message,code="CommandKitWarning"){process.emitWarning(message,{code})}__name(emitWarning,"emitWarning");function warnUnstable(name){WARNED_KEYS.has(name)||(WARNED_KEYS.add(name),emitWarning(`${name} is unstable and may change in future versions.`,"CommandKitUnstableWarning"))}__name(warnUnstable,"warnUnstable");var ElementType={ActionRow:"action-row",Button:"button-kit",Modal:"modal",TextInput:"text-input"};function isCommandKitElement(element){return!(typeof element!="object"||element===null||!Reflect.has(element,"type")||!Reflect.has(element,"data"))}__name(isCommandKitElement,"isCommandKitElement");function getElement(element){return element.data}__name(getElement,"getElement");function Fragment(props){return warnUnstable("CommandKit JSX"),Array.isArray(props.children)?props.children.flat():props.children}__name(Fragment,"Fragment");function createElement(type,props,...children){return warnUnstable("CommandKit JSX"),type({...props,children})}__name(createElement,"createElement");init_cjs_shims();init_cjs_shims();var _EventInterceptor_instances,cleanupLoop_fn,_EventInterceptor=class _EventInterceptor{constructor(client){this.client=client;__privateAdd(this,_EventInterceptor_instances);__publicField(this,"subscribers",new Map);__publicField(this,"globalHandlers",new Map);__publicField(this,"cleanupTimer",null);__privateMethod(this,_EventInterceptor_instances,cleanupLoop_fn).call(this)}destroy(){this.cleanupTimer&&(clearInterval(this.cleanupTimer),this.cleanupTimer=null);for(let[event,handlers]of this.subscribers)for(let handler of handlers)this.unsubscribe(event,handler,"destroy");this.subscribers.clear(),this.globalHandlers.clear()}hasSubscribers(event){return this.subscribers.has(event)}getSubscriberCount(event){let handlers=this.subscribers.get(event);return(handlers==null?void 0:handlers.size)??0}hasGlobalHandlers(){return this.globalHandlers.size>0}getGlobalHandlersCount(){return this.subscribers.size}subscribe(event,listener,options){return this.subscribers.has(event)||(this.subscribers.set(event,new Set),this.client.on(event,this.createGlobalHandler(event)),this.client.setMaxListeners(this.client.getMaxListeners()+1)),options??={},options.registeredAt=Date.now(),Reflect.set(listener,"options",options),this.subscribers.get(event).add(listener),()=>{this.unsubscribe(event,listener)}}unsubscribe(event,listener,reason){var _a,_b;let handlers=this.subscribers.get(event);handlers&&(handlers.delete(listener),handlers.size<1&&(this.subscribers.delete(event),this.client.removeListener(event,this.globalHandlers.get(event)),this.globalHandlers.delete(event),this.client.setMaxListeners(Math.max(this.client.getMaxListeners()-1,0))),(_b=(_a=Reflect.get(listener,"options")).onEnd)==null||_b.call(_a,reason??"unsubscribe"))}createGlobalHandler(event){if(this.globalHandlers.has(event))return this.globalHandlers.get(event);let handler=__name(async(...args)=>{let subscribers=this.subscribers.get(event);if(subscribers&&subscribers.size>0)for(let subscriber of subscribers){let options=Reflect.get(subscriber,"options");if(options.time&&Date.now()-options.registeredAt>options.time){this.unsubscribe(event,subscriber,"time");continue}if(options.autoReset&&(options.registeredAt=Date.now()),!(options.filter&&!await options.filter(...args)))try{await subscriber(...args)}catch(e){if(options.onError)await options.onError(e);else throw e}finally{options.once&&this.unsubscribe(event,subscriber,"once")}}},"handler");return this.globalHandlers.set(event,handler),handler}};_EventInterceptor_instances=new WeakSet,cleanupLoop_fn=__name(function(){this.cleanupTimer&&clearInterval(this.cleanupTimer),this.cleanupTimer=setInterval(()=>{for(let[event,handlers]of this.subscribers)for(let handler of handlers){let options=Reflect.get(handler,"options");options.time&&Date.now()-options.registeredAt>options.time&&this.unsubscribe(event,handler,"time")}},6e4).unref()},"#cleanupLoop"),__name(_EventInterceptor,"EventInterceptor");var EventInterceptor=_EventInterceptor;var import_discord12=require("discord.js");init_cjs_shims();var import_promises2=require("fs/promises"),import_node_path=require("path");var _DefaultLocalizationStrategy=class _DefaultLocalizationStrategy{constructor(commandkit){this.commandkit=commandkit}translations=new Map;async locateTranslation(scope,locale){let localesPath=this.commandkit.getPath("locales");if(!localesPath)return null;let path4=(0,import_node_path.join)(localesPath,locale,`${scope}.json`);try{let data=await(0,import_promises2.readFile)(path4,"utf-8");return JSON.parse(data)}catch{return null}}async getTranslationStrict(scope,locale){let key=`${scope}:${locale}`;if(!this.translations.has(key)){let translation=await this.locateTranslation(scope,locale);if(!translation)throw new Error(`Translation not found for ${key}`);return this.translations.set(key,translation),translation}return this.translations.get(key)}async getTranslation(scope,locale){try{return this.getTranslationStrict(scope,locale)}catch{return null}}async translate(request){let{scope,key,args,locale}=request,translation=await this.getTranslation(scope,locale);if(!translation)return`${scope}.${key}`;let value=translation.translations[key];return this.applyTranslation(value,args)||`${scope}.${key}`}applyTranslation(translation,args){return!translation||!args?translation:translation.replace(/{([^}]+)}/g,(_,key)=>String(args[key]??`{${key}}`))}};__name(_DefaultLocalizationStrategy,"DefaultLocalizationStrategy");var DefaultLocalizationStrategy=_DefaultLocalizationStrategy;init_cjs_shims();var import_node_fs=require("fs"),import_node_path2=require("path");var appDir=null;function findAppDirectory(){if(appDir)return appDir;let root=(0,import_node_path2.join)(process.cwd(),COMMANDKIT_IS_DEV?".commandkit":"dist");(0,import_node_fs.existsSync)(root)||(root=process.cwd());let dirs=["src/app"].map(dir=>(0,import_node_path2.join)(root,dir));for(let dir of dirs)if((0,import_node_fs.existsSync)(dir))return appDir=dir,dir;return null}__name(findAppDirectory,"findAppDirectory");var import_node_path5=require("path");init_cjs_shims();var import_discord11=require("discord.js");init_cjs_shims();var import_discord10=require("discord.js");var _parsed,_options,_args,_MessageCommandParser=class _MessageCommandParser{constructor(message,prefix,schema){this.message=message;this.prefix=prefix;this.schema=schema;__privateAdd(this,_parsed,null);__privateAdd(this,_options,null);__privateAdd(this,_args,[])}getArgs(){return this.parse(),__privateGet(this,_args)}get options(){return __privateGet(this,_options)||__privateSet(this,_options,new MessageCommandOptions(this)),__privateGet(this,_options)}getOption(name){var _a;return(_a=this.parse().options.find(o=>o.name===name))==null?void 0:_a.value}getCommand(){return this.parse().command}getSubcommand(){return this.parse().subcommand}getSubcommandGroup(){return this.parse().subcommandGroup}getPrefix(){for(let p of this.prefix)if(this.message.content.startsWith(p))return p}getFullCommand(){return[this.getCommand(),this.getSubcommandGroup(),this.getSubcommand()].filter(v=>v).join(" ")}parse(){if(__privateGet(this,_parsed))return __privateGet(this,_parsed);let content=this.message.content,prefix=this.getPrefix();if(!prefix)throw createCommandKitError(CommandKitErrorCodes.InvalidCommandPrefix);let parts=content.slice(prefix.length).trim().split(" "),command=parts.shift();__privateSet(this,_args,parts);let subcommandGroup,subcommand;if(command!=null&&command.includes(":")){let[,group,cmd]=command.split(":");!cmd&&group?subcommand=group:cmd&&group&&(subcommandGroup=group,subcommand=cmd)}let schema=this.schema([command,subcommandGroup,subcommand].filter(Boolean).join(" ").trim()),options=parts.map(part=>{try{let[name,value]=part.split(":");if(!(name in schema))return null;switch(schema[name]){case import_discord10.ApplicationCommandOptionType.Boolean:return{name,value:value==="true"};case import_discord10.ApplicationCommandOptionType.Integer:return{name,value:parseInt(value,10)};case import_discord10.ApplicationCommandOptionType.Number:return{name,value:parseFloat(value)};case import_discord10.ApplicationCommandOptionType.String:return{name,value};case import_discord10.ApplicationCommandOptionType.User:return{name,value:this.message.mentions.users.find(u=>u.id===value.replace(/[<@!>]/g,""))};case import_discord10.ApplicationCommandOptionType.Channel:return{name,value:this.message.mentions.channels.find(c=>c.id===value.replace(/[<#>]/g,""))};case import_discord10.ApplicationCommandOptionType.Role:return{name,value:this.message.mentions.roles.find(r=>r.id===value.replace(/[<@&>]/g,""))};case import_discord10.ApplicationCommandOptionType.Attachment:return{name,value:this.message.attachments.find(a=>a.name===value)};default:return null}}catch{return null}}).filter(v=>v!==null);return __privateSet(this,_parsed,{command,options,subcommand,subcommandGroup}),__privateGet(this,_parsed)}};_parsed=new WeakMap,_options=new WeakMap,_args=new WeakMap,__name(_MessageCommandParser,"MessageCommandParser");var MessageCommandParser=_MessageCommandParser,_MessageCommandOptions=class _MessageCommandOptions{constructor(parser2){this.parser=parser2}assertOption(name,required=!1){let option=this.parser.getOption(name);if(required&&option===void 0)throw new Error(`Option "${name}" is required.`);return option??null}getMember(name,required=!1){var _a;let user=this.assertOption(name,required),member=(_a=this.parser.message.guild)==null?void 0:_a.members.cache.get(user==null?void 0:user.id);if(required&&!member)throw new Error(`Member "${name}" is required.`);return member??null}getAttachment(name,required=!1){return this.assertOption(name,required)}getBoolean(name,required=!1){return this.assertOption(name,required)}getNumber(name,required=!1){return this.assertOption(name,required)}getString(name,required=!1){return this.assertOption(name,required)}getInteger(name,required=!1){return this.assertOption(name,required)}getUser(name,required=!1){return this.assertOption(name,required)}getChannel(name,required=!1){return this.assertOption(name,required)}getRole(name,required=!1){return this.assertOption(name,required)}getMentionable(name,required=!1){let target=this.assertOption(name,required);if(target instanceof import_discord10.GuildMember||target instanceof import_discord10.User||target instanceof import_discord10.Role)return target;if(required)throw new Error(`Mentionable "${name}" is required.`);return null}getSubcommand(required=!1){let sub=this.parser.getSubcommand();if(required&&sub===void 0)throw new Error("Subcommand is required.");return sub??null}getSubcommandGroup(required=!1){let sub=this.parser.getSubcommandGroup();if(required&&sub===void 0)throw new Error("Subcommand group is required.");return sub??null}};__name(_MessageCommandOptions,"MessageCommandOptions");var MessageCommandOptions=_MessageCommandOptions;var commandDataSchema={command:__name(c=>c instanceof import_discord11.SlashCommandBuilder||c instanceof import_discord11.ContextMenuCommandBuilder||c&&typeof c=="object","command"),chatInput:__name(c=>typeof c=="function","chatInput"),autocomplete:__name(c=>typeof c=="function","autocomplete"),message:__name(c=>typeof c=="function","message"),messageContextMenu:__name(c=>typeof c=="function","messageContextMenu"),userContextMenu:__name(c=>typeof c=="function","userContextMenu")},middlewareDataSchema={beforeExecute:__name(c=>typeof c=="function","beforeExecute"),afterExecute:__name(c=>typeof c=="function","afterExecute")},_AppCommandHandler=class _AppCommandHandler{constructor(commandkit){this.commandkit=commandkit}loadedCommands=new import_discord11.Collection;loadedMiddlewares=new import_discord11.Collection;getCommandsArray(){return Array.from(this.loadedCommands.values()).map(v=>"toJSON"in v&&typeof v.toJSON=="function"?v.toJSON():v.data.command)}async prepareCommandRun(source){let cmd,parser2;if(source instanceof import_discord11.Message){if(source.author.bot)return null;let prefix=await this.commandkit.config.getMessageCommandPrefix(source);parser2=new MessageCommandParser(source,Array.isArray(prefix)?prefix:[prefix],command=>{var _a;let loadedCommand2=this.loadedCommands.find(c=>c.data.command.name===command);return loadedCommand2?((_a=("toJSON"in loadedCommand2.data.command?loadedCommand2.data.command.toJSON():loadedCommand2.data.command).options)==null?void 0:_a.reduce((acc,opt)=>(acc[opt.name]=opt.type,acc),{}))??{}:null});try{cmd=parser2.getFullCommand()}catch(e){return isErrorType(e,CommandKitErrorCodes.InvalidCommandPrefix)||console.error(e),null}}else{if(!source.isCommand())return null;if(cmd=source.commandName,source.isChatInputCommand()){let subcommandGroup=source.options.getSubcommandGroup(!1),subcommand=source.options.getSubcommand(!1);subcommandGroup&&(cmd+=` ${subcommandGroup}`),subcommand&&(cmd+=` ${subcommand}`)}}let loadedCommand=this.loadedCommands.find(c=>c.data.command.name===cmd);return loadedCommand?{command:loadedCommand,middlewares:loadedCommand.command.middlewares.map(m=>this.loadedMiddlewares.get(m)).filter(m=>!!m),messageCommandParser:parser2}:null}async loadCommands(){let commandsRouter=this.commandkit.commandsRouter;if(!commandsRouter)throw new Error("Commands router has not yet initialized");let{commands,middleware}=commandsRouter.getData();for(let[id,md]of middleware){let data=await import(`${toFileURL(md.fullPath)}?t=${Date.now()}`),handlerCount=0;for(let[key,validator]of Object.entries(middlewareDataSchema)){if(data[key]&&!await validator(data[key]))throw new Error(`Invalid export for middleware ${id}: ${key} does not match expected value`);data[key]&&handlerCount++}if(handlerCount===0)throw new Error(`Invalid export for middleware ${id}: at least one handler function must be provided`);this.loadedMiddlewares.set(id,{middleware:md,data})}for(let[name,command]of commands){let data=await import(`${toFileURL(command.fullPath)}?t=${Date.now()}`);if(!data.command)throw new Error(`Invalid export for command ${name}: no command definition found`);let handlerCount=0;for(let[key,validator]of Object.entries(commandDataSchema))if(key!=="command"&&data[key]&&handlerCount++,data[key]&&!await validator(data[key]))throw new Error(`Invalid export for command ${name}: ${key} does not match expected value`);if(handlerCount===0)throw new Error(`Invalid export for command ${name}: at least one handler function must be provided`);let localizedCommand=await this.applyLocalizations({...data.command});this.loadedCommands.set(name,{command,data:{...data,command:localizedCommand}})}}async applyLocalizations(command){var _a,_b,_c,_d,_e;let localization=this.commandkit.config.localizationStrategy,validLocales=Object.values(import_discord11.Locale).filter(v=>typeof v=="string");for(let locale of validLocales){let translation=await localization.locateTranslation(command.name,locale);if(translation!=null&&translation.command)if(command instanceof import_discord11.SlashCommandBuilder){translation.command.name&&command.setNameLocalization(locale,translation.command.name),translation.command.description&&command.setDescriptionLocalization(locale,translation.command.description);let raw=command.toJSON();if((_a=raw.options)!=null&&_a.length&&((_b=translation.command.options)!=null&&_b.length)){let opt=translation.command.options.slice(),o;for(;o=opt.shift();)(_c=raw.options)==null||_c.forEach(option=>{option.name===o.ref&&(option.name&&(option.name_localizations??={},option.name_localizations[locale]=o.name),option.description&&(option.description_localizations??={},option.description_localizations[locale]=o.description))})}}else{if(command instanceof import_discord11.ContextMenuCommandBuilder)return translation.command.name&&command.setNameLocalization(locale,translation.command.name),command.toJSON();if(command.name_localizations??={},command.name_localizations[locale]=translation.command.name,command.description&&(command.description_localizations??={},command.description_localizations[locale]=translation.command.description),(_d=command.options)!=null&&_d.length&&((_e=translation.command.options)!=null&&_e.length)){let opt=translation.command.options.slice(),o;for(;o=opt.shift();)command.options.forEach(option=>{option.name===o.ref&&(option.name&&(option.name_localizations??={},option.name_localizations[locale]=o.name),option.description&&(option.description_localizations??={},option.description_localizations[locale]=o.description))})}}}return command}};__name(_AppCommandHandler,"AppCommandHandler");var AppCommandHandler=_AppCommandHandler;init_cjs_shims();init_cjs_shims();var import_node_fs2=require("fs"),import_promises3=require("fs/promises"),import_node_path3=__toESM(require("path"));var _CommandsRouter=class _CommandsRouter{constructor(options){this.options=options;if(!options.entrypoint)throw new Error("Entrypoint directory must be provided");options.matcher??={},options.matcher.command??=/command\.(m|c)?(j|t)sx?$/,options.matcher.middleware??=/middleware\.(m|c)?(j|t)sx?$/}commands=new Map;middlewares=new Map;get entrypoint(){return this.options.entrypoint}get matchers(){return this.options.matcher}getData(){return{commands:this.commands,middleware:this.middlewares}}isValidPath(){return(0,import_node_fs2.existsSync)(this.entrypoint)}execMatcher(matcher,path4){return typeof matcher=="string"?path4.endsWith(matcher):matcher instanceof RegExp?matcher.test(path4):matcher(path4)}resolveRelativePath(path4){let regex=new RegExp(`^${this.entrypoint}`);return path4.replace(regex,"")}match(commandOrSegment){if(!(commandOrSegment!=null&&commandOrSegment.length))return null;if(Array.isArray(commandOrSegment)&&commandOrSegment.length===1&&(commandOrSegment=commandOrSegment[0]),!Array.isArray(commandOrSegment)&&!commandOrSegment.includes(" ")){let command2=this.commands.get(commandOrSegment);if(!command2)return null;let middlewares2=command2.middlewares.map(id=>this.middlewares.get(id)).filter(m=>!!m);return{command:command2,middlewares:middlewares2}}let segments=Array.isArray(commandOrSegment)?commandOrSegment:commandOrSegment.split(" "),command=Array.from(this.commands.values()).find(cmd=>{let commandSegments=cmd.parentSegments;return commandSegments.length!==segments.length?!1:commandSegments.every((segment,index)=>segment==="[name]"?!0:segment===segments[index])});if(!command)return null;let middlewares=command.middlewares.map(id=>this.middlewares.get(id)).filter(m=>!!m);return{command,middlewares}}async reload(){return this.clear(),this.scan()}clear(){this.commands.clear(),this.middlewares.clear()}async scan(){let files=await this.scanDirectory(this.entrypoint,[]);for(let file of files){if(this.execMatcher(this.matchers.command,file)){let location=this.resolveRelativePath(file),parts=location.split(import_node_path3.default.sep),parentSegments=[];parts.forEach((part,index,arr)=>{index!==arr.length-1&&(/\(.+\)/.test(part)||parentSegments.push(part.trim()))});let parent=parentSegments.join(" "),name=parts[parts.length-1].replace(/\.(m|c)?(j|t)sx?$/,""),command={name,middlewares:[],parent:parent||null,path:location,fullPath:file,parentSegments};this.commands.set(name,command)}if(this.execMatcher(this.matchers.middleware,file)){let location=this.resolveRelativePath(file),name=location.replace(/\.(m|c)?(j|t)sx?$/,""),middlewareDir=import_node_path3.default.dirname(location),command=Array.from(this.commands.values()).filter(command2=>{let commandDir=import_node_path3.default.dirname(command2.path);return commandDir===middlewareDir||commandDir.startsWith(middlewareDir)}),id=crypto.randomUUID(),middleware={id,name,path:location,fullPath:file};this.middlewares.set(id,middleware),command.forEach(cmd=>{cmd.middlewares.push(id)})}}return this.toJSON()}toJSON(){return{commands:Object.fromEntries(this.commands),middleware:Object.fromEntries(this.middlewares)}}async scanDirectory(dir,entries){let files=await(0,import_promises3.readdir)(dir,{withFileTypes:!0});for(let file of files)if(!(file.name==="node_modules"||file.parentPath.includes("node_modules"))){if(file.isDirectory()){let next=(0,import_node_path3.join)(dir,file.name);await this.scanDirectory(next,entries);continue}entries.push((0,import_node_path3.join)(dir,file.name))}return entries}};__name(_CommandsRouter,"CommandsRouter");var CommandsRouter=_CommandsRouter;init_cjs_shims();var import_node_fs3=require("fs"),import_promises4=require("fs/promises"),import_node_path4=require("path");var _EventsRouter=class _EventsRouter{constructor(options){this.options=options;if(!options.entrypoint)throw new Error("Entrypoint directory must be provided")}events=new Map;match(event){return this.events.get(event)??null}get entrypoint(){return this.options.entrypoint}isValidPath(){return(0,import_node_fs3.existsSync)(this.entrypoint)}clear(){this.events.clear()}async reload(){return this.clear(),this.scan()}async scan(){let dirs=await(0,import_promises4.readdir)(this.entrypoint,{withFileTypes:!0});for(let dir of dirs)if(dir.isDirectory()){let path4=(0,import_node_path4.join)(this.entrypoint,dir.name),event=await this.scanEvent(dir.name,path4);this.events.set(event.event,event)}return Object.fromEntries(this.events)}toJSON(){return Object.fromEntries(this.events)}async scanEvent(event,path4,listeners=[]){let files=await(0,import_promises4.readdir)(path4,{withFileTypes:!0});for(let file of files)if(!/node_modules/.test(file.name)){if(file.isDirectory()){let nextPath=(0,import_node_path4.join)(path4,file.name);await this.scanEvent(event,nextPath,listeners);continue}file.isFile()&&/\.(m|c)?(j|t)sx?$/.test(file.name)&&listeners.push((0,import_node_path4.join)(file.parentPath,file.name))}return{event,path:path4,listeners}}};__name(_EventsRouter,"EventsRouter");var EventsRouter=_EventsRouter;var _data5,_started,_CommandKit_instances,init_fn,initApp_fn,initCommands_fn,initEvents_fn,_CommandKit=class _CommandKit extends import_node_events.default{constructor(options){if(_CommandKit.instance&&process.emitWarning("CommandKit instance already exists. Having multiple instance in same project is discouraged and it may lead to unexpected behavior.",{code:"MultiInstanceWarning"}),!options.client)throw new Error(colors_default.red('"client" is required when instantiating CommandKit.'));if(options.validationsPath&&!options.commandsPath)throw new Error(colors_default.red('"commandsPath" is required when "validationsPath" is set.'));super();__privateAdd(this,_CommandKit_instances);__privateAdd(this,_data5);__privateAdd(this,_started,!1);__publicField(this,"eventInterceptor");__publicField(this,"config",{defaultLocale:import_discord12.Locale.EnglishUS,localizationStrategy:new DefaultLocalizationStrategy(this),getMessageCommandPrefix:__name(()=>"!","getMessageCommandPrefix")});__publicField(this,"commandsRouter");__publicField(this,"eventsRouter");__publicField(this,"appCommandsHandler",new AppCommandHandler(this));options.debugCommands??=process.env.NODE_ENV!=="production",options.cacheProvider!==null&&(!options.cacheProvider||!(options.cacheProvider instanceof CacheProvider))&&(options.cacheProvider=new MemoryCache),this.eventInterceptor=new EventInterceptor(options.client),__privateSet(this,_data5,options),_CommandKit.instance||(_CommandKit.instance=this)}async start(token){__privateGet(this,_started)||(await __privateMethod(this,_CommandKit_instances,init_fn).call(this),this.incrementClientListenersCount(),token!==!1&&!__privateGet(this,_data5).client.isReady()&&await __privateGet(this,_data5).client.login(token??process.env.TOKEN??process.env.DISCORD_TOKEN),__privateSet(this,_started,!0))}get started(){return __privateGet(this,_started)}setPrefixResolver(resolver){return this.config.getMessageCommandPrefix=resolver,this}setDefaultLocale(locale){return this.config.defaultLocale=locale,this}setLocalizationStrategy(strategy){return this.config.localizationStrategy=strategy,this}getCacheProvider(){return __privateGet(this,_data5).cacheProvider??null}isDebuggingCommands(){return __privateGet(this,_data5).debugCommands||!1}get client(){return __privateGet(this,_data5).client}get commandHandler(){return __privateGet(this,_data5).commandHandler}async reloadCommands(type){__privateGet(this,_data5).commandHandler&&await __privateGet(this,_data5).commandHandler.reloadCommands(type)}async reloadEvents(){__privateGet(this,_data5).eventHandler&&await __privateGet(this,_data5).eventHandler.reloadEvents(__privateGet(this,_data5).commandHandler)}async reloadValidations(){__privateGet(this,_data5).validationHandler&&await __privateGet(this,_data5).validationHandler.reloadValidations()}get commands(){return __privateGet(this,_data5).commandHandler?__privateGet(this,_data5).commandHandler.commands.map(cmd=>{let{run,autocomplete,...command}=cmd;return command}):[]}get commandsPath(){return __privateGet(this,_data5).commandsPath}get eventsPath(){return __privateGet(this,_data5).eventsPath}get validationsPath(){return __privateGet(this,_data5).validationsPath}get devUserIds(){return __privateGet(this,_data5).devUserIds||[]}get devGuildIds(){return __privateGet(this,_data5).devGuildIds||[]}get devRoleIds(){return __privateGet(this,_data5).devRoleIds||[]}incrementClientListenersCount(){__privateGet(this,_data5).client.setMaxListeners(__privateGet(this,_data5).client.getMaxListeners()+1)}decrementClientListenersCount(){__privateGet(this,_data5).client.setMaxListeners(__privateGet(this,_data5).client.getMaxListeners()-1)}getAppDirectory(){return findAppDirectory()}getPath(to){let appDir2=this.getAppDirectory();if(!appDir2)return null;switch(to){case"locales":return(0,import_node_path5.join)(appDir2,"locales");case"commands":return(0,import_node_path5.join)(appDir2,"commands");case"events":return(0,import_node_path5.join)(appDir2,"events");default:return to}}};_data5=new WeakMap,_started=new WeakMap,_CommandKit_instances=new WeakSet,init_fn=__name(async function(){let eventHandler=new EventHandler({client:__privateGet(this,_data5).client,eventsPath:__privateGet(this,_data5).eventsPath,commandKitInstance:this});if(await eventHandler.init(),__privateGet(this,_data5).eventHandler=eventHandler,__privateGet(this,_data5).validationsPath){let validationHandler=new ValidationHandler({validationsPath:__privateGet(this,_data5).validationsPath});await validationHandler.init(),__privateGet(this,_data5).validationHandler=validationHandler}let commandHandler=new CommandHandler({client:__privateGet(this,_data5).client,commandsPath:__privateGet(this,_data5).commandsPath,devGuildIds:__privateGet(this,_data5).devGuildIds||[],devUserIds:__privateGet(this,_data5).devUserIds||[],devRoleIds:__privateGet(this,_data5).devRoleIds||[],validationHandler:__privateGet(this,_data5).validationHandler,skipBuiltInValidations:__privateGet(this,_data5).skipBuiltInValidations||!1,commandkitInstance:this,bulkRegister:__privateGet(this,_data5).bulkRegister||!1});__privateGet(this,_data5).commandHandler=commandHandler,await __privateMethod(this,_CommandKit_instances,initApp_fn).call(this),await commandHandler.init()},"#init"),initApp_fn=__name(async function(){if(!this.getAppDirectory())return;let commandsPath=this.getPath("commands"),events=this.getPath("events");this.commandsRouter=new CommandsRouter({entrypoint:commandsPath}),this.eventsRouter=new EventsRouter({entrypoint:events}),await __privateMethod(this,_CommandKit_instances,initEvents_fn).call(this),await __privateMethod(this,_CommandKit_instances,initCommands_fn).call(this)},"#initApp"),initCommands_fn=__name(async function(){this.commandsRouter.isValidPath()&&await this.commandsRouter.scan(),await this.appCommandsHandler.loadCommands()},"#initCommands"),initEvents_fn=__name(async function(){if(this.eventsRouter.isValidPath()&&await this.eventsRouter.scan(),!!__privateGet(this,_data5).eventHandler){for(let event of Object.values(this.eventsRouter.toJSON()))__privateGet(this,_data5).eventHandler.registerExternal(event);__privateGet(this,_data5).eventHandler.resyncListeners()}},"#initEvents"),__name(_CommandKit,"CommandKit"),__publicField(_CommandKit,"createElement",createElement),__publicField(_CommandKit,"Fragment",Fragment),__publicField(_CommandKit,"instance");var CommandKit=_CommandKit;init_cjs_shims();var defaultConfig={outDir:"dist",watch:!0,envExtra:!0,nodeOptions:[],clearRestartLogs:!0,minify:!1,sourcemap:!1,antiCrash:!0,requirePolyfill:!0};function getConfig(){return defaultConfig}__name(getConfig,"getConfig");function defineConfig(config){return{...defaultConfig,...config}}__name(defineConfig,"defineConfig");init_cjs_shims();init_cjs_shims();init_cjs_shims();init_cjs_shims();init_cjs_shims();async function bootstrapCommandkitCLI(argv,options){let{Command}=await import("commander"),{bootstrapDevelopmentServer:bootstrapDevelopmentServer2}=await Promise.resolve().then(()=>(init_development(),development_exports)),{bootstrapProductionServer:bootstrapProductionServer2}=await Promise.resolve().then(()=>(init_production(),production_exports)),{bootstrapProductionBuild:bootstrapProductionBuild2}=await Promise.resolve().then(()=>(init_build(),build_exports)),{generateCommand:generateCommand2,generateEvent:generateEvent2,generateLocale:generateLocale2}=await Promise.resolve().then(()=>(init_generators(),generators_exports)),program=new Command("commandkit");program.command("dev").description("Start your bot in development mode.").option("-c, --config <path>","Path to your commandkit config file.","./commandkit.js").action(()=>{let options2=program.opts();bootstrapDevelopmentServer2(options2)}),program.command("start").description("Start your bot in production mode after running the build command.").option("-c, --config <path>","Path to your commandkit.json file.","./commandkit.js").action(()=>{let options2=program.opts();bootstrapProductionServer2(options2.config)}),program.command("build").description("Build your project for production usage.").option("-c, --config <path>","Path to your commandkit.json file.","./commandkit.json").action(()=>{let options2=program.opts();bootstrapProductionBuild2(options2.config)}),program.command("create").description("Create new commands, events, or locale files").option("-c, --command","Create a new command").option("-e, --event","Create a new event").option("-l, --locale <locale>","Specify the locale code (e.g. nl, es, fr)").argument("<name>","The name of the command or event").action(async(name,options2)=>{if(options2.command)await generateCommand2(name);else if(options2.event)await generateEvent2(name);else if(options2.locale){if(!name){console.error("Please specify a command name for the locale file");return}await generateLocale2(options2.locale,name)}else console.error("Please specify what to create: --command, --event, or --locale")}),await program.parseAsync(argv,options)}__name(bootstrapCommandkitCLI,"bootstrapCommandkitCLI");var index_default=CommandKit,version="0.1.11-dev.20250216081126";0&&(module.exports={ActionRow,AppCommandHandler,Button,ButtonKit,CacheProvider,CommandExecutionMode,CommandKit,CommandKitEnvironment,CommandKitEnvironmentType,CommandsRouter,Context,DefaultLocalizationStrategy,DefaultLogger,ElementType,EventInterceptor,EventsRouter,Fragment,Localization,Logger,MemoryCache,MessageCommandOptions,MessageCommandParser,MiddlewareContext,Modal,ModalKit,ParagraphInput,ShortInput,TextInput,afterCommand,bootstrapCommandkitCLI,cache,cacheLife,cacheTag,cancelAfterCommand,createElement,createLogger,defineConfig,dmOnly,exitContext,exitMiddleware,getCommandKit,getConfig,getContext,getElement,guildOnly,invalidate,isCachedFunction,isCommandKitElement,makeContextAwareFunction,redirect,rethrow,revalidate,super_duper_secret_internal_for_use_cache_directive_of_commandkit_cli_do_not_use_it_directly_or_you_will_be_fired_from_your_job_kthxbai,useEnvironment,version});
49
49
  //# sourceMappingURL=index.js.map