const Agent = require('./agent/')
const {
InputError,
IgnoredError
} = require('./errors/')
const {
BaseHandler,
CommandHandler,
ReactionHandler
} = require('./modules/')
const {
Command,
Replacer,
Await,
ReactCommand,
ReactInterface
} = require('./structures/')
module.exports = {
Agent,
InputError,
IgnoredError,
BaseHandler,
CommandHandler,
ReactionHandler,
Command,
Replacer,
Await,
ReactCommand,
ReactInterface
}
/**
* @typedef {String} Prefix
*/
/**
* A list of prefixes for each guild supplied to the Agent. It is mapped with a guild's ID equalling its prefix
* @typedef {Object} PrefixList
* @prop {Prefix} guildID
* @example { '463886367496339458': '>' }
*/
/**
* Data for arguments that go into a command
* @typedef {Object} ArgData
* @prop {String} ArgData.name The name of the argument
* @prop {Boolean} [ArgData.mand=false] Whether the argument is mandatory for the command to work or not
* @prop {String} [ArgData.delim=' '] The delimiter (The character(s) that separate(s) it from the argument after it) for the argument
* @prop {String} [ArgData.type='string'] The type of argument
* @example Types: `string` - A regular string
* `number` - A number is parsed from the supplied argument
* `user` - From a username or mention, the Eris.User instance is supplied to the action
* `channel` - From a name or mention, the Eris.Channel instance is supplied to the action
*/
/**
* Object returned by a command action
* @typedef {Object} CommandResults
* @prop {String} [CommandResults.content] The resulting message content sent by the bot
* @prop {Eris.Embed} [CommandResults.embed] The resulting embed sent by the bot
* @prop {Buffer} [CommandResults.file] The resulting file sent by the bot
* @prop {Object} [CommandResults.options={}] Options for the response message
* @prop {String[]|String} [CommandResults.options.channels] The channel IDs to send the resulting messages. By default, it's the same channel the executing message was sent
* @prop {Await[]|Await} [CommandResults.options.awaits] An action or list of actions that are awaited after the results are processed
* @prop {ReactInterface} [CommandResults.options.reactInterface] A react interface that is bound to the resulting message
* @prop {Number} [CommandResults.options.deleteAfter] The number of milliseconds to wait before deleting the response
*/