@jubbio/core 1.1.10 → 1.1.11

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.
@@ -372,4 +372,4 @@ class ShardClientUtil {
372
372
  }
373
373
  exports.ShardClientUtil = ShardClientUtil;
374
374
  exports.default = ShardingManager;
375
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ShardingManager.js","sourceRoot":"","sources":["../../src/sharding/ShardingManager.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * ShardingManager - Multi-process bot support\r\n */\r\n\r\nimport { EventEmitter } from 'events';\r\nimport { fork, ChildProcess } from 'child_process';\r\nimport path from 'path';\r\n\r\n/**\r\n * Shard status\r\n */\r\nexport enum ShardStatus {\r\n  Ready = 0,\r\n  Connecting = 1,\r\n  Reconnecting = 2,\r\n  Idle = 3,\r\n  Nearly = 4,\r\n  Disconnected = 5,\r\n  WaitingForGuilds = 6,\r\n  Identifying = 7,\r\n  Resuming = 8,\r\n}\r\n\r\n/**\r\n * Options for ShardingManager\r\n */\r\nexport interface ShardingManagerOptions {\r\n  /** Total number of shards (auto if not specified) */\r\n  totalShards?: number | 'auto';\r\n  /** Specific shard IDs to spawn */\r\n  shardList?: number[] | 'auto';\r\n  /** Sharding mode */\r\n  mode?: 'process' | 'worker';\r\n  /** Respawn shards on exit */\r\n  respawn?: boolean;\r\n  /** Arguments to pass to shards */\r\n  shardArgs?: string[];\r\n  /** Arguments to pass to node */\r\n  execArgv?: string[];\r\n  /** Bot token */\r\n  token?: string;\r\n}\r\n\r\n/**\r\n * Represents a single shard\r\n */\r\nexport class Shard extends EventEmitter {\r\n  /** The manager that spawned this shard */\r\n  public manager: ShardingManager;\r\n  /** The shard ID */\r\n  public id: number;\r\n  /** The child process */\r\n  public process: ChildProcess | null = null;\r\n  /** Whether the shard is ready */\r\n  public ready: boolean = false;\r\n  /** Shard status */\r\n  public status: ShardStatus = ShardStatus.Idle;\r\n  /** Environment variables for the shard */\r\n  private env: Record<string, string>;\r\n\r\n  constructor(manager: ShardingManager, id: number) {\r\n    super();\r\n    this.manager = manager;\r\n    this.id = id;\r\n    this.env = {\r\n      SHARD_ID: String(id),\r\n      SHARD_COUNT: String(manager.totalShards),\r\n      JUBBIO_TOKEN: manager.token ?? '',\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Spawn the shard process\r\n   */\r\n  async spawn(timeout = 30000): Promise<ChildProcess> {\r\n    if (this.process) {\r\n      throw new Error(`Shard ${this.id} already has a process`);\r\n    }\r\n\r\n    this.status = ShardStatus.Connecting;\r\n\r\n    this.process = fork(this.manager.file, this.manager.shardArgs, {\r\n      env: { ...process.env, ...this.env },\r\n      execArgv: this.manager.execArgv,\r\n    });\r\n\r\n    this.process.on('message', this._handleMessage.bind(this));\r\n    this.process.on('exit', this._handleExit.bind(this));\r\n    this.process.on('error', this._handleError.bind(this));\r\n\r\n    // Wait for ready\r\n    return new Promise((resolve, reject) => {\r\n      const timer = setTimeout(() => {\r\n        reject(new Error(`Shard ${this.id} took too long to become ready`));\r\n      }, timeout);\r\n\r\n      this.once('ready', () => {\r\n        clearTimeout(timer);\r\n        resolve(this.process!);\r\n      });\r\n\r\n      this.once('disconnect', () => {\r\n        clearTimeout(timer);\r\n        reject(new Error(`Shard ${this.id} disconnected before becoming ready`));\r\n      });\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Kill the shard process\r\n   */\r\n  kill(): void {\r\n    if (this.process) {\r\n      this.process.removeAllListeners();\r\n      this.process.kill();\r\n      this.process = null;\r\n    }\r\n    this.status = ShardStatus.Disconnected;\r\n    this.ready = false;\r\n  }\r\n\r\n  /**\r\n   * Respawn the shard\r\n   */\r\n  async respawn(options?: { delay?: number; timeout?: number }): Promise<ChildProcess> {\r\n    this.kill();\r\n    if (options?.delay) {\r\n      await new Promise(r => setTimeout(r, options.delay));\r\n    }\r\n    return this.spawn(options?.timeout);\r\n  }\r\n\r\n  /**\r\n   * Send a message to the shard\r\n   */\r\n  send(message: any): Promise<void> {\r\n    return new Promise((resolve, reject) => {\r\n      if (!this.process) {\r\n        reject(new Error(`Shard ${this.id} has no process`));\r\n        return;\r\n      }\r\n      this.process.send(message, (err) => {\r\n        if (err) reject(err);\r\n        else resolve();\r\n      });\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Evaluate code on the shard\r\n   */\r\n  async eval<T>(script: string | ((client: any) => T)): Promise<T> {\r\n    const _eval = typeof script === 'function' ? `(${script})(this)` : script;\r\n    \r\n    return new Promise((resolve, reject) => {\r\n      const id = Date.now().toString(36) + Math.random().toString(36);\r\n      \r\n      const handler = (message: any) => {\r\n        if (message._evalId !== id) return;\r\n        this.process?.off('message', handler);\r\n        \r\n        if (message._error) {\r\n          reject(new Error(message._error));\r\n        } else {\r\n          resolve(message._result);\r\n        }\r\n      };\r\n      \r\n      this.process?.on('message', handler);\r\n      this.send({ _eval, _evalId: id }).catch(reject);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Fetch a client property\r\n   */\r\n  async fetchClientValue(prop: string): Promise<any> {\r\n    return this.eval(`this.${prop}`);\r\n  }\r\n\r\n  private _handleMessage(message: any): void {\r\n    if (message._ready) {\r\n      this.ready = true;\r\n      this.status = ShardStatus.Ready;\r\n      this.emit('ready');\r\n      this.manager.emit('shardReady', this.id);\r\n      return;\r\n    }\r\n\r\n    if (message._disconnect) {\r\n      this.ready = false;\r\n      this.status = ShardStatus.Disconnected;\r\n      this.emit('disconnect');\r\n      this.manager.emit('shardDisconnect', this.id);\r\n      return;\r\n    }\r\n\r\n    if (message._reconnecting) {\r\n      this.ready = false;\r\n      this.status = ShardStatus.Reconnecting;\r\n      this.emit('reconnecting');\r\n      this.manager.emit('shardReconnecting', this.id);\r\n      return;\r\n    }\r\n\r\n    this.emit('message', message);\r\n    this.manager.emit('message', this.id, message);\r\n  }\r\n\r\n  private _handleExit(code: number, signal: string): void {\r\n    this.ready = false;\r\n    this.status = ShardStatus.Disconnected;\r\n    this.process = null;\r\n    \r\n    this.emit('death', { code, signal });\r\n    this.manager.emit('shardDeath', this.id, { code, signal });\r\n\r\n    if (this.manager.respawn) {\r\n      this.spawn().catch(err => {\r\n        this.manager.emit('shardError', this.id, err);\r\n      });\r\n    }\r\n  }\r\n\r\n  private _handleError(error: Error): void {\r\n    this.emit('error', error);\r\n    this.manager.emit('shardError', this.id, error);\r\n  }\r\n}\r\n\r\n/**\r\n * Manages multiple shards for large bots\r\n */\r\nexport class ShardingManager extends EventEmitter {\r\n  /** Path to the bot file */\r\n  public file: string;\r\n  /** Total number of shards */\r\n  public totalShards: number | 'auto';\r\n  /** List of shard IDs to spawn */\r\n  public shardList: number[];\r\n  /** Sharding mode */\r\n  public mode: 'process' | 'worker';\r\n  /** Whether to respawn shards */\r\n  public respawn: boolean;\r\n  /** Arguments to pass to shards */\r\n  public shardArgs: string[];\r\n  /** Arguments to pass to node */\r\n  public execArgv: string[];\r\n  /** Bot token */\r\n  public token?: string;\r\n  /** Collection of shards */\r\n  public shards: Map<number, Shard> = new Map();\r\n\r\n  constructor(file: string, options: ShardingManagerOptions = {}) {\r\n    super();\r\n    \r\n    this.file = path.resolve(file);\r\n    this.totalShards = options.totalShards ?? 'auto';\r\n    this.shardList = options.shardList === 'auto' ? [] : (options.shardList ?? []);\r\n    this.mode = options.mode ?? 'process';\r\n    this.respawn = options.respawn ?? true;\r\n    this.shardArgs = options.shardArgs ?? [];\r\n    this.execArgv = options.execArgv ?? [];\r\n    this.token = options.token;\r\n  }\r\n\r\n  /**\r\n   * Spawn all shards\r\n   */\r\n  async spawn(options?: {\r\n    amount?: number | 'auto';\r\n    delay?: number;\r\n    timeout?: number;\r\n  }): Promise<Map<number, Shard>> {\r\n    // Determine shard count\r\n    if (this.totalShards === 'auto' || options?.amount === 'auto') {\r\n      this.totalShards = await this.fetchRecommendedShards();\r\n    } else if (options?.amount) {\r\n      this.totalShards = options.amount;\r\n    }\r\n\r\n    // Build shard list if not specified\r\n    if (this.shardList.length === 0) {\r\n      this.shardList = Array.from({ length: this.totalShards as number }, (_, i) => i);\r\n    }\r\n\r\n    // Spawn shards sequentially with delay\r\n    const delay = options?.delay ?? 5500;\r\n    \r\n    for (const id of this.shardList) {\r\n      const shard = this.createShard(id);\r\n      await shard.spawn(options?.timeout);\r\n      \r\n      if (id !== this.shardList[this.shardList.length - 1]) {\r\n        await new Promise(r => setTimeout(r, delay));\r\n      }\r\n    }\r\n\r\n    return this.shards;\r\n  }\r\n\r\n  /**\r\n   * Create a shard\r\n   */\r\n  createShard(id: number): Shard {\r\n    const shard = new Shard(this, id);\r\n    this.shards.set(id, shard);\r\n    return shard;\r\n  }\r\n\r\n  /**\r\n   * Fetch recommended shard count from API\r\n   */\r\n  async fetchRecommendedShards(): Promise<number> {\r\n    // In a real implementation, this would call the API\r\n    // For now, return a default\r\n    return 1;\r\n  }\r\n\r\n  /**\r\n   * Broadcast a message to all shards\r\n   */\r\n  async broadcast(message: any): Promise<void[]> {\r\n    const promises = [...this.shards.values()].map(shard => shard.send(message));\r\n    return Promise.all(promises);\r\n  }\r\n\r\n  /**\r\n   * Broadcast an eval to all shards\r\n   */\r\n  async broadcastEval<T>(script: string | ((client: any) => T)): Promise<T[]> {\r\n    const promises = [...this.shards.values()].map(shard => shard.eval(script));\r\n    return Promise.all(promises);\r\n  }\r\n\r\n  /**\r\n   * Fetch a client value from all shards\r\n   */\r\n  async fetchClientValues(prop: string): Promise<any[]> {\r\n    return this.broadcastEval(`this.${prop}`);\r\n  }\r\n\r\n  /**\r\n   * Respawn all shards\r\n   */\r\n  async respawnAll(options?: {\r\n    shardDelay?: number;\r\n    respawnDelay?: number;\r\n    timeout?: number;\r\n  }): Promise<Map<number, Shard>> {\r\n    for (const shard of this.shards.values()) {\r\n      await shard.respawn({ delay: options?.respawnDelay, timeout: options?.timeout });\r\n      if (options?.shardDelay) {\r\n        await new Promise(r => setTimeout(r, options.shardDelay));\r\n      }\r\n    }\r\n    return this.shards;\r\n  }\r\n}\r\n\r\n/**\r\n * Shard client utilities - use in bot file\r\n */\r\nexport class ShardClientUtil {\r\n  /** The client */\r\n  public client: any;\r\n  /** The shard ID */\r\n  public id: number;\r\n  /** Total shard count */\r\n  public count: number;\r\n\r\n  constructor(client: any) {\r\n    this.client = client;\r\n    this.id = parseInt(process.env.SHARD_ID ?? '0', 10);\r\n    this.count = parseInt(process.env.SHARD_COUNT ?? '1', 10);\r\n  }\r\n\r\n  /**\r\n   * Send a message to the parent process\r\n   */\r\n  send(message: any): Promise<void> {\r\n    return new Promise((resolve, reject) => {\r\n      process.send?.(message, (err: Error | null) => {\r\n        if (err) reject(err);\r\n        else resolve();\r\n      });\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Fetch a client value from all shards\r\n   */\r\n  async fetchClientValues(prop: string): Promise<any[]> {\r\n    return this.broadcastEval(`this.${prop}`);\r\n  }\r\n\r\n  /**\r\n   * Broadcast an eval to all shards\r\n   */\r\n  async broadcastEval<T>(script: string | ((client: any) => T)): Promise<T[]> {\r\n    const _eval = typeof script === 'function' ? `(${script})(this)` : script;\r\n    \r\n    return new Promise((resolve, reject) => {\r\n      const id = Date.now().toString(36) + Math.random().toString(36);\r\n      \r\n      const handler = (message: any) => {\r\n        if (message._broadcastEvalId !== id) return;\r\n        process.off('message', handler);\r\n        \r\n        if (message._error) {\r\n          reject(new Error(message._error));\r\n        } else {\r\n          resolve(message._results);\r\n        }\r\n      };\r\n      \r\n      process.on('message', handler);\r\n      this.send({ _broadcastEval: _eval, _broadcastEvalId: id }).catch(reject);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Signal ready to the parent process\r\n   */\r\n  ready(): void {\r\n    process.send?.({ _ready: true });\r\n  }\r\n\r\n  /**\r\n   * Get the shard ID for a guild\r\n   */\r\n  static shardIdForGuildId(guildId: string, shardCount: number): number {\r\n    const id = BigInt(guildId);\r\n    return Number(id >> 22n) % shardCount;\r\n  }\r\n}\r\n\r\nexport default ShardingManager;\r\n"]}
375
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ShardingManager.js","sourceRoot":"","sources":["../../src/sharding/ShardingManager.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ShardingManager - Multi-process bot support\n */\n\nimport { EventEmitter } from 'events';\nimport { fork, ChildProcess } from 'child_process';\nimport path from 'path';\n\n/**\n * Shard status\n */\nexport enum ShardStatus {\n  Ready = 0,\n  Connecting = 1,\n  Reconnecting = 2,\n  Idle = 3,\n  Nearly = 4,\n  Disconnected = 5,\n  WaitingForGuilds = 6,\n  Identifying = 7,\n  Resuming = 8,\n}\n\n/**\n * Options for ShardingManager\n */\nexport interface ShardingManagerOptions {\n  /** Total number of shards (auto if not specified) */\n  totalShards?: number | 'auto';\n  /** Specific shard IDs to spawn */\n  shardList?: number[] | 'auto';\n  /** Sharding mode */\n  mode?: 'process' | 'worker';\n  /** Respawn shards on exit */\n  respawn?: boolean;\n  /** Arguments to pass to shards */\n  shardArgs?: string[];\n  /** Arguments to pass to node */\n  execArgv?: string[];\n  /** Bot token */\n  token?: string;\n}\n\n/**\n * Represents a single shard\n */\nexport class Shard extends EventEmitter {\n  /** The manager that spawned this shard */\n  public manager: ShardingManager;\n  /** The shard ID */\n  public id: number;\n  /** The child process */\n  public process: ChildProcess | null = null;\n  /** Whether the shard is ready */\n  public ready: boolean = false;\n  /** Shard status */\n  public status: ShardStatus = ShardStatus.Idle;\n  /** Environment variables for the shard */\n  private env: Record<string, string>;\n\n  constructor(manager: ShardingManager, id: number) {\n    super();\n    this.manager = manager;\n    this.id = id;\n    this.env = {\n      SHARD_ID: String(id),\n      SHARD_COUNT: String(manager.totalShards),\n      JUBBIO_TOKEN: manager.token ?? '',\n    };\n  }\n\n  /**\n   * Spawn the shard process\n   */\n  async spawn(timeout = 30000): Promise<ChildProcess> {\n    if (this.process) {\n      throw new Error(`Shard ${this.id} already has a process`);\n    }\n\n    this.status = ShardStatus.Connecting;\n\n    this.process = fork(this.manager.file, this.manager.shardArgs, {\n      env: { ...process.env, ...this.env },\n      execArgv: this.manager.execArgv,\n    });\n\n    this.process.on('message', this._handleMessage.bind(this));\n    this.process.on('exit', this._handleExit.bind(this));\n    this.process.on('error', this._handleError.bind(this));\n\n    // Wait for ready\n    return new Promise((resolve, reject) => {\n      const timer = setTimeout(() => {\n        reject(new Error(`Shard ${this.id} took too long to become ready`));\n      }, timeout);\n\n      this.once('ready', () => {\n        clearTimeout(timer);\n        resolve(this.process!);\n      });\n\n      this.once('disconnect', () => {\n        clearTimeout(timer);\n        reject(new Error(`Shard ${this.id} disconnected before becoming ready`));\n      });\n    });\n  }\n\n  /**\n   * Kill the shard process\n   */\n  kill(): void {\n    if (this.process) {\n      this.process.removeAllListeners();\n      this.process.kill();\n      this.process = null;\n    }\n    this.status = ShardStatus.Disconnected;\n    this.ready = false;\n  }\n\n  /**\n   * Respawn the shard\n   */\n  async respawn(options?: { delay?: number; timeout?: number }): Promise<ChildProcess> {\n    this.kill();\n    if (options?.delay) {\n      await new Promise(r => setTimeout(r, options.delay));\n    }\n    return this.spawn(options?.timeout);\n  }\n\n  /**\n   * Send a message to the shard\n   */\n  send(message: any): Promise<void> {\n    return new Promise((resolve, reject) => {\n      if (!this.process) {\n        reject(new Error(`Shard ${this.id} has no process`));\n        return;\n      }\n      this.process.send(message, (err) => {\n        if (err) reject(err);\n        else resolve();\n      });\n    });\n  }\n\n  /**\n   * Evaluate code on the shard\n   */\n  async eval<T>(script: string | ((client: any) => T)): Promise<T> {\n    const _eval = typeof script === 'function' ? `(${script})(this)` : script;\n    \n    return new Promise((resolve, reject) => {\n      const id = Date.now().toString(36) + Math.random().toString(36);\n      \n      const handler = (message: any) => {\n        if (message._evalId !== id) return;\n        this.process?.off('message', handler);\n        \n        if (message._error) {\n          reject(new Error(message._error));\n        } else {\n          resolve(message._result);\n        }\n      };\n      \n      this.process?.on('message', handler);\n      this.send({ _eval, _evalId: id }).catch(reject);\n    });\n  }\n\n  /**\n   * Fetch a client property\n   */\n  async fetchClientValue(prop: string): Promise<any> {\n    return this.eval(`this.${prop}`);\n  }\n\n  private _handleMessage(message: any): void {\n    if (message._ready) {\n      this.ready = true;\n      this.status = ShardStatus.Ready;\n      this.emit('ready');\n      this.manager.emit('shardReady', this.id);\n      return;\n    }\n\n    if (message._disconnect) {\n      this.ready = false;\n      this.status = ShardStatus.Disconnected;\n      this.emit('disconnect');\n      this.manager.emit('shardDisconnect', this.id);\n      return;\n    }\n\n    if (message._reconnecting) {\n      this.ready = false;\n      this.status = ShardStatus.Reconnecting;\n      this.emit('reconnecting');\n      this.manager.emit('shardReconnecting', this.id);\n      return;\n    }\n\n    this.emit('message', message);\n    this.manager.emit('message', this.id, message);\n  }\n\n  private _handleExit(code: number, signal: string): void {\n    this.ready = false;\n    this.status = ShardStatus.Disconnected;\n    this.process = null;\n    \n    this.emit('death', { code, signal });\n    this.manager.emit('shardDeath', this.id, { code, signal });\n\n    if (this.manager.respawn) {\n      this.spawn().catch(err => {\n        this.manager.emit('shardError', this.id, err);\n      });\n    }\n  }\n\n  private _handleError(error: Error): void {\n    this.emit('error', error);\n    this.manager.emit('shardError', this.id, error);\n  }\n}\n\n/**\n * Manages multiple shards for large bots\n */\nexport class ShardingManager extends EventEmitter {\n  /** Path to the bot file */\n  public file: string;\n  /** Total number of shards */\n  public totalShards: number | 'auto';\n  /** List of shard IDs to spawn */\n  public shardList: number[];\n  /** Sharding mode */\n  public mode: 'process' | 'worker';\n  /** Whether to respawn shards */\n  public respawn: boolean;\n  /** Arguments to pass to shards */\n  public shardArgs: string[];\n  /** Arguments to pass to node */\n  public execArgv: string[];\n  /** Bot token */\n  public token?: string;\n  /** Collection of shards */\n  public shards: Map<number, Shard> = new Map();\n\n  constructor(file: string, options: ShardingManagerOptions = {}) {\n    super();\n    \n    this.file = path.resolve(file);\n    this.totalShards = options.totalShards ?? 'auto';\n    this.shardList = options.shardList === 'auto' ? [] : (options.shardList ?? []);\n    this.mode = options.mode ?? 'process';\n    this.respawn = options.respawn ?? true;\n    this.shardArgs = options.shardArgs ?? [];\n    this.execArgv = options.execArgv ?? [];\n    this.token = options.token;\n  }\n\n  /**\n   * Spawn all shards\n   */\n  async spawn(options?: {\n    amount?: number | 'auto';\n    delay?: number;\n    timeout?: number;\n  }): Promise<Map<number, Shard>> {\n    // Determine shard count\n    if (this.totalShards === 'auto' || options?.amount === 'auto') {\n      this.totalShards = await this.fetchRecommendedShards();\n    } else if (options?.amount) {\n      this.totalShards = options.amount;\n    }\n\n    // Build shard list if not specified\n    if (this.shardList.length === 0) {\n      this.shardList = Array.from({ length: this.totalShards as number }, (_, i) => i);\n    }\n\n    // Spawn shards sequentially with delay\n    const delay = options?.delay ?? 5500;\n    \n    for (const id of this.shardList) {\n      const shard = this.createShard(id);\n      await shard.spawn(options?.timeout);\n      \n      if (id !== this.shardList[this.shardList.length - 1]) {\n        await new Promise(r => setTimeout(r, delay));\n      }\n    }\n\n    return this.shards;\n  }\n\n  /**\n   * Create a shard\n   */\n  createShard(id: number): Shard {\n    const shard = new Shard(this, id);\n    this.shards.set(id, shard);\n    return shard;\n  }\n\n  /**\n   * Fetch recommended shard count from API\n   */\n  async fetchRecommendedShards(): Promise<number> {\n    // In a real implementation, this would call the API\n    // For now, return a default\n    return 1;\n  }\n\n  /**\n   * Broadcast a message to all shards\n   */\n  async broadcast(message: any): Promise<void[]> {\n    const promises = [...this.shards.values()].map(shard => shard.send(message));\n    return Promise.all(promises);\n  }\n\n  /**\n   * Broadcast an eval to all shards\n   */\n  async broadcastEval<T>(script: string | ((client: any) => T)): Promise<T[]> {\n    const promises = [...this.shards.values()].map(shard => shard.eval(script));\n    return Promise.all(promises);\n  }\n\n  /**\n   * Fetch a client value from all shards\n   */\n  async fetchClientValues(prop: string): Promise<any[]> {\n    return this.broadcastEval(`this.${prop}`);\n  }\n\n  /**\n   * Respawn all shards\n   */\n  async respawnAll(options?: {\n    shardDelay?: number;\n    respawnDelay?: number;\n    timeout?: number;\n  }): Promise<Map<number, Shard>> {\n    for (const shard of this.shards.values()) {\n      await shard.respawn({ delay: options?.respawnDelay, timeout: options?.timeout });\n      if (options?.shardDelay) {\n        await new Promise(r => setTimeout(r, options.shardDelay));\n      }\n    }\n    return this.shards;\n  }\n}\n\n/**\n * Shard client utilities - use in bot file\n */\nexport class ShardClientUtil {\n  /** The client */\n  public client: any;\n  /** The shard ID */\n  public id: number;\n  /** Total shard count */\n  public count: number;\n\n  constructor(client: any) {\n    this.client = client;\n    this.id = parseInt(process.env.SHARD_ID ?? '0', 10);\n    this.count = parseInt(process.env.SHARD_COUNT ?? '1', 10);\n  }\n\n  /**\n   * Send a message to the parent process\n   */\n  send(message: any): Promise<void> {\n    return new Promise((resolve, reject) => {\n      process.send?.(message, (err: Error | null) => {\n        if (err) reject(err);\n        else resolve();\n      });\n    });\n  }\n\n  /**\n   * Fetch a client value from all shards\n   */\n  async fetchClientValues(prop: string): Promise<any[]> {\n    return this.broadcastEval(`this.${prop}`);\n  }\n\n  /**\n   * Broadcast an eval to all shards\n   */\n  async broadcastEval<T>(script: string | ((client: any) => T)): Promise<T[]> {\n    const _eval = typeof script === 'function' ? `(${script})(this)` : script;\n    \n    return new Promise((resolve, reject) => {\n      const id = Date.now().toString(36) + Math.random().toString(36);\n      \n      const handler = (message: any) => {\n        if (message._broadcastEvalId !== id) return;\n        process.off('message', handler);\n        \n        if (message._error) {\n          reject(new Error(message._error));\n        } else {\n          resolve(message._results);\n        }\n      };\n      \n      process.on('message', handler);\n      this.send({ _broadcastEval: _eval, _broadcastEvalId: id }).catch(reject);\n    });\n  }\n\n  /**\n   * Signal ready to the parent process\n   */\n  ready(): void {\n    process.send?.({ _ready: true });\n  }\n\n  /**\n   * Get the shard ID for a guild\n   */\n  static shardIdForGuildId(guildId: string, shardCount: number): number {\n    const id = BigInt(guildId);\n    return Number(id >> 22n) % shardCount;\n  }\n}\n\nexport default ShardingManager;\n"]}
@@ -18,4 +18,4 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
18
18
  };
19
19
  Object.defineProperty(exports, "__esModule", { value: true });
20
20
  __exportStar(require("./ShardingManager"), exports);
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2hhcmRpbmcvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOztHQUVHOzs7Ozs7Ozs7Ozs7Ozs7O0FBRUgsb0RBQWtDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIFNoYXJkaW5nIGV4cG9ydHNcclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL1NoYXJkaW5nTWFuYWdlcic7XHJcbiJdfQ==
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2hhcmRpbmcvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOztHQUVHOzs7Ozs7Ozs7Ozs7Ozs7O0FBRUgsb0RBQWtDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBTaGFyZGluZyBleHBvcnRzXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9TaGFyZGluZ01hbmFnZXInO1xuIl19
@@ -135,4 +135,4 @@ class BitField {
135
135
  }
136
136
  exports.BitField = BitField;
137
137
  exports.default = BitField;
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"BitField.js","sourceRoot":"","sources":["../../src/utils/BitField.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Generic BitField class\r\n * API compatible with Discord.js BitField\r\n */\r\n\r\nexport type BitFieldResolvable<S extends string, N extends bigint | number> = \r\n  | N \r\n  | N[] \r\n  | S \r\n  | S[] \r\n  | BitField<S, N>;\r\n\r\n/**\r\n * Data structure for bit fields\r\n */\r\nexport class BitField<S extends string = string, N extends bigint | number = bigint> {\r\n  /** The raw bits */\r\n  public bitfield: N;\r\n\r\n  /** Flags for this bitfield (override in subclass) */\r\n  static Flags: Record<string, bigint | number> = {};\r\n\r\n  /** Default bit value */\r\n  static DefaultBit: bigint | number = 0n;\r\n\r\n  constructor(bits: BitFieldResolvable<S, N> = BitField.DefaultBit as N) {\r\n    this.bitfield = (this.constructor as typeof BitField).resolve<S, N>(bits);\r\n  }\r\n\r\n  /**\r\n   * Check if this bitfield has a bit\r\n   */\r\n  has(bit: BitFieldResolvable<S, N>): boolean {\r\n    const resolved = (this.constructor as typeof BitField).resolve<S, N>(bit);\r\n    return ((this.bitfield as bigint) & (resolved as bigint)) === (resolved as bigint);\r\n  }\r\n\r\n  /**\r\n   * Check if this bitfield has any of the bits\r\n   */\r\n  any(bits: BitFieldResolvable<S, N>): boolean {\r\n    const resolved = (this.constructor as typeof BitField).resolve<S, N>(bits);\r\n    return ((this.bitfield as bigint) & (resolved as bigint)) !== 0n;\r\n  }\r\n\r\n  /**\r\n   * Add bits to this bitfield\r\n   */\r\n  add(...bits: BitFieldResolvable<S, N>[]): this {\r\n    let total = 0n;\r\n    for (const bit of bits) {\r\n      total |= (this.constructor as typeof BitField).resolve<S, N>(bit) as bigint;\r\n    }\r\n    (this.bitfield as bigint) |= total;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Remove bits from this bitfield\r\n   */\r\n  remove(...bits: BitFieldResolvable<S, N>[]): this {\r\n    let total = 0n;\r\n    for (const bit of bits) {\r\n      total |= (this.constructor as typeof BitField).resolve<S, N>(bit) as bigint;\r\n    }\r\n    (this.bitfield as bigint) &= ~total;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Serialize to array of flag names\r\n   */\r\n  toArray(): S[] {\r\n    const flags = (this.constructor as typeof BitField).Flags;\r\n    const result: S[] = [];\r\n    \r\n    for (const [name, bit] of Object.entries(flags)) {\r\n      if ((this.bitfield as bigint) & (bit as bigint)) {\r\n        result.push(name as S);\r\n      }\r\n    }\r\n    \r\n    return result;\r\n  }\r\n\r\n  /**\r\n   * Serialize to JSON\r\n   */\r\n  toJSON(): string | number {\r\n    return typeof this.bitfield === 'bigint' \r\n      ? this.bitfield.toString() \r\n      : this.bitfield;\r\n  }\r\n\r\n  /**\r\n   * Get string representation\r\n   */\r\n  toString(): string {\r\n    return this.bitfield.toString();\r\n  }\r\n\r\n  /**\r\n   * Get iterator\r\n   */\r\n  *[Symbol.iterator](): IterableIterator<S> {\r\n    yield* this.toArray();\r\n  }\r\n\r\n  /**\r\n   * Freeze this bitfield\r\n   */\r\n  freeze(): Readonly<this> {\r\n    return Object.freeze(this);\r\n  }\r\n\r\n  /**\r\n   * Check equality\r\n   */\r\n  equals(other: BitFieldResolvable<S, N>): boolean {\r\n    return this.bitfield === (this.constructor as typeof BitField).resolve<S, N>(other);\r\n  }\r\n\r\n  /**\r\n   * Clone this bitfield\r\n   */\r\n  clone(): BitField<S, N> {\r\n    return new (this.constructor as new (bits: N) => BitField<S, N>)(this.bitfield);\r\n  }\r\n\r\n  /**\r\n   * Resolve a bit to the numeric type\r\n   */\r\n  static resolve<S extends string, N extends bigint | number>(bit: BitFieldResolvable<S, N>): N {\r\n    if (typeof bit === 'bigint' || typeof bit === 'number') {\r\n      return bit as N;\r\n    }\r\n\r\n    if (bit instanceof BitField) {\r\n      return bit.bitfield as N;\r\n    }\r\n\r\n    if (typeof bit === 'string') {\r\n      const resolved = this.Flags[bit];\r\n      if (resolved === undefined) {\r\n        throw new Error(`Unknown bit: ${bit}`);\r\n      }\r\n      return resolved as N;\r\n    }\r\n\r\n    if (Array.isArray(bit)) {\r\n      let result = this.DefaultBit as bigint;\r\n      for (const b of bit) {\r\n        const resolved = this.resolve<S, N>(b);\r\n        result |= resolved as bigint;\r\n      }\r\n      return result as N;\r\n    }\r\n\r\n    throw new Error(`Invalid bit: ${bit}`);\r\n  }\r\n}\r\n\r\nexport default BitField;\r\n"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"BitField.js","sourceRoot":"","sources":["../../src/utils/BitField.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Generic BitField class\n * API compatible with Discord.js BitField\n */\n\nexport type BitFieldResolvable<S extends string, N extends bigint | number> = \n  | N \n  | N[] \n  | S \n  | S[] \n  | BitField<S, N>;\n\n/**\n * Data structure for bit fields\n */\nexport class BitField<S extends string = string, N extends bigint | number = bigint> {\n  /** The raw bits */\n  public bitfield: N;\n\n  /** Flags for this bitfield (override in subclass) */\n  static Flags: Record<string, bigint | number> = {};\n\n  /** Default bit value */\n  static DefaultBit: bigint | number = 0n;\n\n  constructor(bits: BitFieldResolvable<S, N> = BitField.DefaultBit as N) {\n    this.bitfield = (this.constructor as typeof BitField).resolve<S, N>(bits);\n  }\n\n  /**\n   * Check if this bitfield has a bit\n   */\n  has(bit: BitFieldResolvable<S, N>): boolean {\n    const resolved = (this.constructor as typeof BitField).resolve<S, N>(bit);\n    return ((this.bitfield as bigint) & (resolved as bigint)) === (resolved as bigint);\n  }\n\n  /**\n   * Check if this bitfield has any of the bits\n   */\n  any(bits: BitFieldResolvable<S, N>): boolean {\n    const resolved = (this.constructor as typeof BitField).resolve<S, N>(bits);\n    return ((this.bitfield as bigint) & (resolved as bigint)) !== 0n;\n  }\n\n  /**\n   * Add bits to this bitfield\n   */\n  add(...bits: BitFieldResolvable<S, N>[]): this {\n    let total = 0n;\n    for (const bit of bits) {\n      total |= (this.constructor as typeof BitField).resolve<S, N>(bit) as bigint;\n    }\n    (this.bitfield as bigint) |= total;\n    return this;\n  }\n\n  /**\n   * Remove bits from this bitfield\n   */\n  remove(...bits: BitFieldResolvable<S, N>[]): this {\n    let total = 0n;\n    for (const bit of bits) {\n      total |= (this.constructor as typeof BitField).resolve<S, N>(bit) as bigint;\n    }\n    (this.bitfield as bigint) &= ~total;\n    return this;\n  }\n\n  /**\n   * Serialize to array of flag names\n   */\n  toArray(): S[] {\n    const flags = (this.constructor as typeof BitField).Flags;\n    const result: S[] = [];\n    \n    for (const [name, bit] of Object.entries(flags)) {\n      if ((this.bitfield as bigint) & (bit as bigint)) {\n        result.push(name as S);\n      }\n    }\n    \n    return result;\n  }\n\n  /**\n   * Serialize to JSON\n   */\n  toJSON(): string | number {\n    return typeof this.bitfield === 'bigint' \n      ? this.bitfield.toString() \n      : this.bitfield;\n  }\n\n  /**\n   * Get string representation\n   */\n  toString(): string {\n    return this.bitfield.toString();\n  }\n\n  /**\n   * Get iterator\n   */\n  *[Symbol.iterator](): IterableIterator<S> {\n    yield* this.toArray();\n  }\n\n  /**\n   * Freeze this bitfield\n   */\n  freeze(): Readonly<this> {\n    return Object.freeze(this);\n  }\n\n  /**\n   * Check equality\n   */\n  equals(other: BitFieldResolvable<S, N>): boolean {\n    return this.bitfield === (this.constructor as typeof BitField).resolve<S, N>(other);\n  }\n\n  /**\n   * Clone this bitfield\n   */\n  clone(): BitField<S, N> {\n    return new (this.constructor as new (bits: N) => BitField<S, N>)(this.bitfield);\n  }\n\n  /**\n   * Resolve a bit to the numeric type\n   */\n  static resolve<S extends string, N extends bigint | number>(bit: BitFieldResolvable<S, N>): N {\n    if (typeof bit === 'bigint' || typeof bit === 'number') {\n      return bit as N;\n    }\n\n    if (bit instanceof BitField) {\n      return bit.bitfield as N;\n    }\n\n    if (typeof bit === 'string') {\n      const resolved = this.Flags[bit];\n      if (resolved === undefined) {\n        throw new Error(`Unknown bit: ${bit}`);\n      }\n      return resolved as N;\n    }\n\n    if (Array.isArray(bit)) {\n      let result = this.DefaultBit as bigint;\n      for (const b of bit) {\n        const resolved = this.resolve<S, N>(b);\n        result |= resolved as bigint;\n      }\n      return result as N;\n    }\n\n    throw new Error(`Invalid bit: ${bit}`);\n  }\n}\n\nexport default BitField;\n"]}
@@ -262,4 +262,4 @@ class Collection extends Map {
262
262
  }
263
263
  }
264
264
  exports.Collection = Collection;
265
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Collection.js","sourceRoot":"","sources":["../../src/utils/Collection.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * A Map with additional utility methods\r\n */\r\nexport class Collection<K, V> extends Map<K, V> {\r\n  /**\r\n   * Identical to Map.get()\r\n   * Ensures the value exists\r\n   */\r\n  ensure(key: K, defaultValueGenerator: (key: K, collection: this) => V): V {\r\n    if (this.has(key)) return this.get(key)!;\r\n    const defaultValue = defaultValueGenerator(key, this);\r\n    this.set(key, defaultValue);\r\n    return defaultValue;\r\n  }\r\n\r\n  /**\r\n   * Checks if all items pass a test\r\n   */\r\n  every(fn: (value: V, key: K, collection: this) => boolean): boolean {\r\n    for (const [key, val] of this) {\r\n      if (!fn(val, key, this)) return false;\r\n    }\r\n    return true;\r\n  }\r\n\r\n  /**\r\n   * Checks if any item passes a test\r\n   */\r\n  some(fn: (value: V, key: K, collection: this) => boolean): boolean {\r\n    for (const [key, val] of this) {\r\n      if (fn(val, key, this)) return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  /**\r\n   * Identical to Array.filter(), but returns a Collection\r\n   */\r\n  filter(fn: (value: V, key: K, collection: this) => boolean): Collection<K, V> {\r\n    const results = new Collection<K, V>();\r\n    for (const [key, val] of this) {\r\n      if (fn(val, key, this)) results.set(key, val);\r\n    }\r\n    return results;\r\n  }\r\n\r\n  /**\r\n   * Partitions the collection into two collections\r\n   */\r\n  partition(fn: (value: V, key: K, collection: this) => boolean): [Collection<K, V>, Collection<K, V>] {\r\n    const results: [Collection<K, V>, Collection<K, V>] = [new Collection<K, V>(), new Collection<K, V>()];\r\n    for (const [key, val] of this) {\r\n      if (fn(val, key, this)) {\r\n        results[0].set(key, val);\r\n      } else {\r\n        results[1].set(key, val);\r\n      }\r\n    }\r\n    return results;\r\n  }\r\n\r\n  /**\r\n   * Maps each item to another value\r\n   */\r\n  map<T>(fn: (value: V, key: K, collection: this) => T): T[] {\r\n    const results: T[] = [];\r\n    for (const [key, val] of this) {\r\n      results.push(fn(val, key, this));\r\n    }\r\n    return results;\r\n  }\r\n\r\n  /**\r\n   * Maps each item to another value into a Collection\r\n   */\r\n  mapValues<T>(fn: (value: V, key: K, collection: this) => T): Collection<K, T> {\r\n    const results = new Collection<K, T>();\r\n    for (const [key, val] of this) {\r\n      results.set(key, fn(val, key, this));\r\n    }\r\n    return results;\r\n  }\r\n\r\n  /**\r\n   * Searches for a single item\r\n   */\r\n  find(fn: (value: V, key: K, collection: this) => boolean): V | undefined {\r\n    for (const [key, val] of this) {\r\n      if (fn(val, key, this)) return val;\r\n    }\r\n    return undefined;\r\n  }\r\n\r\n  /**\r\n   * Searches for the key of a single item\r\n   */\r\n  findKey(fn: (value: V, key: K, collection: this) => boolean): K | undefined {\r\n    for (const [key, val] of this) {\r\n      if (fn(val, key, this)) return key;\r\n    }\r\n    return undefined;\r\n  }\r\n\r\n  /**\r\n   * Removes items that satisfy the provided filter function\r\n   */\r\n  sweep(fn: (value: V, key: K, collection: this) => boolean): number {\r\n    const previousSize = this.size;\r\n    for (const [key, val] of this) {\r\n      if (fn(val, key, this)) this.delete(key);\r\n    }\r\n    return previousSize - this.size;\r\n  }\r\n\r\n  /**\r\n   * Reduces the collection to a single value\r\n   */\r\n  reduce<T>(fn: (accumulator: T, value: V, key: K, collection: this) => T, initialValue: T): T {\r\n    let accumulator = initialValue;\r\n    for (const [key, val] of this) {\r\n      accumulator = fn(accumulator, val, key, this);\r\n    }\r\n    return accumulator;\r\n  }\r\n\r\n  /**\r\n   * Identical to Array.forEach()\r\n   */\r\n  each(fn: (value: V, key: K, collection: this) => void): this {\r\n    for (const [key, val] of this) {\r\n      fn(val, key, this);\r\n    }\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Returns the first item(s) in the collection\r\n   */\r\n  first(): V | undefined;\r\n  first(amount: number): V[];\r\n  first(amount?: number): V | V[] | undefined {\r\n    if (amount === undefined) return this.values().next().value;\r\n    if (amount < 0) return this.last(amount * -1);\r\n    amount = Math.min(this.size, amount);\r\n    const iter = this.values();\r\n    return Array.from({ length: amount }, () => iter.next().value);\r\n  }\r\n\r\n  /**\r\n   * Returns the first key(s) in the collection\r\n   */\r\n  firstKey(): K | undefined;\r\n  firstKey(amount: number): K[];\r\n  firstKey(amount?: number): K | K[] | undefined {\r\n    if (amount === undefined) return this.keys().next().value;\r\n    if (amount < 0) return this.lastKey(amount * -1);\r\n    amount = Math.min(this.size, amount);\r\n    const iter = this.keys();\r\n    return Array.from({ length: amount }, () => iter.next().value);\r\n  }\r\n\r\n  /**\r\n   * Returns the last item(s) in the collection\r\n   */\r\n  last(): V | undefined;\r\n  last(amount: number): V[];\r\n  last(amount?: number): V | V[] | undefined {\r\n    const arr = [...this.values()];\r\n    if (amount === undefined) return arr[arr.length - 1];\r\n    if (amount < 0) return this.first(amount * -1);\r\n    if (!amount) return [];\r\n    return arr.slice(-amount);\r\n  }\r\n\r\n  /**\r\n   * Returns the last key(s) in the collection\r\n   */\r\n  lastKey(): K | undefined;\r\n  lastKey(amount: number): K[];\r\n  lastKey(amount?: number): K | K[] | undefined {\r\n    const arr = [...this.keys()];\r\n    if (amount === undefined) return arr[arr.length - 1];\r\n    if (amount < 0) return this.firstKey(amount * -1);\r\n    if (!amount) return [];\r\n    return arr.slice(-amount);\r\n  }\r\n\r\n  /**\r\n   * Returns a random item from the collection\r\n   */\r\n  random(): V | undefined;\r\n  random(amount: number): V[];\r\n  random(amount?: number): V | V[] | undefined {\r\n    const arr = [...this.values()];\r\n    if (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\r\n    if (!arr.length || !amount) return [];\r\n    return Array.from({ length: Math.min(amount, arr.length) }, () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]);\r\n  }\r\n\r\n  /**\r\n   * Returns a random key from the collection\r\n   */\r\n  randomKey(): K | undefined;\r\n  randomKey(amount: number): K[];\r\n  randomKey(amount?: number): K | K[] | undefined {\r\n    const arr = [...this.keys()];\r\n    if (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\r\n    if (!arr.length || !amount) return [];\r\n    return Array.from({ length: Math.min(amount, arr.length) }, () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]);\r\n  }\r\n\r\n  /**\r\n   * Combines this collection with others\r\n   */\r\n  concat(...collections: Collection<K, V>[]): Collection<K, V> {\r\n    const newColl = this.clone();\r\n    for (const coll of collections) {\r\n      for (const [key, val] of coll) newColl.set(key, val);\r\n    }\r\n    return newColl;\r\n  }\r\n\r\n  /**\r\n   * Checks if this collection shares identical items with another\r\n   */\r\n  equals(collection: Collection<K, V>): boolean {\r\n    if (this === collection) return true;\r\n    if (this.size !== collection.size) return false;\r\n    for (const [key, value] of this) {\r\n      if (!collection.has(key) || value !== collection.get(key)) {\r\n        return false;\r\n      }\r\n    }\r\n    return true;\r\n  }\r\n\r\n  /**\r\n   * Creates an identical shallow copy of this collection\r\n   */\r\n  clone(): Collection<K, V> {\r\n    return new Collection(this);\r\n  }\r\n\r\n  /**\r\n   * Sorts the collection and returns it\r\n   */\r\n  sort(compareFunction: (firstValue: V, secondValue: V, firstKey: K, secondKey: K) => number = Collection.defaultSort): this {\r\n    const entries = [...this.entries()];\r\n    entries.sort((a, b) => compareFunction(a[1], b[1], a[0], b[0]));\r\n    this.clear();\r\n    for (const [k, v] of entries) {\r\n      this.set(k, v);\r\n    }\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sorts the collection by keys and returns it\r\n   */\r\n  sortByKey(compareFunction: (firstKey: K, secondKey: K, firstValue: V, secondValue: V) => number = Collection.defaultSort): this {\r\n    const entries = [...this.entries()];\r\n    entries.sort((a, b) => compareFunction(a[0], b[0], a[1], b[1]));\r\n    this.clear();\r\n    for (const [k, v] of entries) {\r\n      this.set(k, v);\r\n    }\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Returns an array of items\r\n   */\r\n  toJSON(): V[] {\r\n    return [...this.values()];\r\n  }\r\n\r\n  /**\r\n   * Default sort function\r\n   */\r\n  private static defaultSort<V>(firstValue: V, secondValue: V): number {\r\n    return Number(firstValue > secondValue) || Number(firstValue === secondValue) - 1;\r\n  }\r\n\r\n  /**\r\n   * Creates a Collection from an array\r\n   */\r\n  static from<K, V>(entries: Iterable<readonly [K, V]>): Collection<K, V> {\r\n    return new Collection(entries);\r\n  }\r\n}\r\n"]}
265
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Collection.js","sourceRoot":"","sources":["../../src/utils/Collection.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * A Map with additional utility methods\n */\nexport class Collection<K, V> extends Map<K, V> {\n  /**\n   * Identical to Map.get()\n   * Ensures the value exists\n   */\n  ensure(key: K, defaultValueGenerator: (key: K, collection: this) => V): V {\n    if (this.has(key)) return this.get(key)!;\n    const defaultValue = defaultValueGenerator(key, this);\n    this.set(key, defaultValue);\n    return defaultValue;\n  }\n\n  /**\n   * Checks if all items pass a test\n   */\n  every(fn: (value: V, key: K, collection: this) => boolean): boolean {\n    for (const [key, val] of this) {\n      if (!fn(val, key, this)) return false;\n    }\n    return true;\n  }\n\n  /**\n   * Checks if any item passes a test\n   */\n  some(fn: (value: V, key: K, collection: this) => boolean): boolean {\n    for (const [key, val] of this) {\n      if (fn(val, key, this)) return true;\n    }\n    return false;\n  }\n\n  /**\n   * Identical to Array.filter(), but returns a Collection\n   */\n  filter(fn: (value: V, key: K, collection: this) => boolean): Collection<K, V> {\n    const results = new Collection<K, V>();\n    for (const [key, val] of this) {\n      if (fn(val, key, this)) results.set(key, val);\n    }\n    return results;\n  }\n\n  /**\n   * Partitions the collection into two collections\n   */\n  partition(fn: (value: V, key: K, collection: this) => boolean): [Collection<K, V>, Collection<K, V>] {\n    const results: [Collection<K, V>, Collection<K, V>] = [new Collection<K, V>(), new Collection<K, V>()];\n    for (const [key, val] of this) {\n      if (fn(val, key, this)) {\n        results[0].set(key, val);\n      } else {\n        results[1].set(key, val);\n      }\n    }\n    return results;\n  }\n\n  /**\n   * Maps each item to another value\n   */\n  map<T>(fn: (value: V, key: K, collection: this) => T): T[] {\n    const results: T[] = [];\n    for (const [key, val] of this) {\n      results.push(fn(val, key, this));\n    }\n    return results;\n  }\n\n  /**\n   * Maps each item to another value into a Collection\n   */\n  mapValues<T>(fn: (value: V, key: K, collection: this) => T): Collection<K, T> {\n    const results = new Collection<K, T>();\n    for (const [key, val] of this) {\n      results.set(key, fn(val, key, this));\n    }\n    return results;\n  }\n\n  /**\n   * Searches for a single item\n   */\n  find(fn: (value: V, key: K, collection: this) => boolean): V | undefined {\n    for (const [key, val] of this) {\n      if (fn(val, key, this)) return val;\n    }\n    return undefined;\n  }\n\n  /**\n   * Searches for the key of a single item\n   */\n  findKey(fn: (value: V, key: K, collection: this) => boolean): K | undefined {\n    for (const [key, val] of this) {\n      if (fn(val, key, this)) return key;\n    }\n    return undefined;\n  }\n\n  /**\n   * Removes items that satisfy the provided filter function\n   */\n  sweep(fn: (value: V, key: K, collection: this) => boolean): number {\n    const previousSize = this.size;\n    for (const [key, val] of this) {\n      if (fn(val, key, this)) this.delete(key);\n    }\n    return previousSize - this.size;\n  }\n\n  /**\n   * Reduces the collection to a single value\n   */\n  reduce<T>(fn: (accumulator: T, value: V, key: K, collection: this) => T, initialValue: T): T {\n    let accumulator = initialValue;\n    for (const [key, val] of this) {\n      accumulator = fn(accumulator, val, key, this);\n    }\n    return accumulator;\n  }\n\n  /**\n   * Identical to Array.forEach()\n   */\n  each(fn: (value: V, key: K, collection: this) => void): this {\n    for (const [key, val] of this) {\n      fn(val, key, this);\n    }\n    return this;\n  }\n\n  /**\n   * Returns the first item(s) in the collection\n   */\n  first(): V | undefined;\n  first(amount: number): V[];\n  first(amount?: number): V | V[] | undefined {\n    if (amount === undefined) return this.values().next().value;\n    if (amount < 0) return this.last(amount * -1);\n    amount = Math.min(this.size, amount);\n    const iter = this.values();\n    return Array.from({ length: amount }, () => iter.next().value);\n  }\n\n  /**\n   * Returns the first key(s) in the collection\n   */\n  firstKey(): K | undefined;\n  firstKey(amount: number): K[];\n  firstKey(amount?: number): K | K[] | undefined {\n    if (amount === undefined) return this.keys().next().value;\n    if (amount < 0) return this.lastKey(amount * -1);\n    amount = Math.min(this.size, amount);\n    const iter = this.keys();\n    return Array.from({ length: amount }, () => iter.next().value);\n  }\n\n  /**\n   * Returns the last item(s) in the collection\n   */\n  last(): V | undefined;\n  last(amount: number): V[];\n  last(amount?: number): V | V[] | undefined {\n    const arr = [...this.values()];\n    if (amount === undefined) return arr[arr.length - 1];\n    if (amount < 0) return this.first(amount * -1);\n    if (!amount) return [];\n    return arr.slice(-amount);\n  }\n\n  /**\n   * Returns the last key(s) in the collection\n   */\n  lastKey(): K | undefined;\n  lastKey(amount: number): K[];\n  lastKey(amount?: number): K | K[] | undefined {\n    const arr = [...this.keys()];\n    if (amount === undefined) return arr[arr.length - 1];\n    if (amount < 0) return this.firstKey(amount * -1);\n    if (!amount) return [];\n    return arr.slice(-amount);\n  }\n\n  /**\n   * Returns a random item from the collection\n   */\n  random(): V | undefined;\n  random(amount: number): V[];\n  random(amount?: number): V | V[] | undefined {\n    const arr = [...this.values()];\n    if (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\n    if (!arr.length || !amount) return [];\n    return Array.from({ length: Math.min(amount, arr.length) }, () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]);\n  }\n\n  /**\n   * Returns a random key from the collection\n   */\n  randomKey(): K | undefined;\n  randomKey(amount: number): K[];\n  randomKey(amount?: number): K | K[] | undefined {\n    const arr = [...this.keys()];\n    if (amount === undefined) return arr[Math.floor(Math.random() * arr.length)];\n    if (!arr.length || !amount) return [];\n    return Array.from({ length: Math.min(amount, arr.length) }, () => arr.splice(Math.floor(Math.random() * arr.length), 1)[0]);\n  }\n\n  /**\n   * Combines this collection with others\n   */\n  concat(...collections: Collection<K, V>[]): Collection<K, V> {\n    const newColl = this.clone();\n    for (const coll of collections) {\n      for (const [key, val] of coll) newColl.set(key, val);\n    }\n    return newColl;\n  }\n\n  /**\n   * Checks if this collection shares identical items with another\n   */\n  equals(collection: Collection<K, V>): boolean {\n    if (this === collection) return true;\n    if (this.size !== collection.size) return false;\n    for (const [key, value] of this) {\n      if (!collection.has(key) || value !== collection.get(key)) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  /**\n   * Creates an identical shallow copy of this collection\n   */\n  clone(): Collection<K, V> {\n    return new Collection(this);\n  }\n\n  /**\n   * Sorts the collection and returns it\n   */\n  sort(compareFunction: (firstValue: V, secondValue: V, firstKey: K, secondKey: K) => number = Collection.defaultSort): this {\n    const entries = [...this.entries()];\n    entries.sort((a, b) => compareFunction(a[1], b[1], a[0], b[0]));\n    this.clear();\n    for (const [k, v] of entries) {\n      this.set(k, v);\n    }\n    return this;\n  }\n\n  /**\n   * Sorts the collection by keys and returns it\n   */\n  sortByKey(compareFunction: (firstKey: K, secondKey: K, firstValue: V, secondValue: V) => number = Collection.defaultSort): this {\n    const entries = [...this.entries()];\n    entries.sort((a, b) => compareFunction(a[0], b[0], a[1], b[1]));\n    this.clear();\n    for (const [k, v] of entries) {\n      this.set(k, v);\n    }\n    return this;\n  }\n\n  /**\n   * Returns an array of items\n   */\n  toJSON(): V[] {\n    return [...this.values()];\n  }\n\n  /**\n   * Default sort function\n   */\n  private static defaultSort<V>(firstValue: V, secondValue: V): number {\n    return Number(firstValue > secondValue) || Number(firstValue === secondValue) - 1;\n  }\n\n  /**\n   * Creates a Collection from an array\n   */\n  static from<K, V>(entries: Iterable<readonly [K, V]>): Collection<K, V> {\n    return new Collection(entries);\n  }\n}\n"]}
@@ -311,4 +311,4 @@ function awaitReactions(client, messageId, options) {
311
311
  });
312
312
  }
313
313
  exports.default = Collector;
314
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Collector.js","sourceRoot":"","sources":["../../src/utils/Collector.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AA6XH,sCAgBC;AAKD,wCAgBC;AAhaD,mCAAsC;AACtC,6CAA0C;AAsB1C;;GAEG;AACH,MAAsB,SAA+B,SAAQ,qBAAY;IACvE,kDAAkD;IAClC,MAAM,CAAM;IAE5B,0BAA0B;IACV,SAAS,GAAqB,IAAI,uBAAU,EAAE,CAAC;IAE/D,sCAAsC;IAC/B,KAAK,GAAG,KAAK,CAAC;IAErB,qCAAqC;IAC9B,SAAS,GAAkB,IAAI,CAAC;IAEvC,sBAAsB;IACf,MAAM,CAAuE;IAEpF,wBAAwB;IACjB,OAAO,CAAsB;IAEpC,gCAAgC;IACxB,eAAe,GAAG,CAAC,CAAC;IAE5B,6BAA6B;IACrB,QAAQ,GAA0B,IAAI,CAAC;IAE/C,6BAA6B;IACrB,YAAY,GAA0B,IAAI,CAAC;IAEnD,YAAY,MAAW,EAAE,UAA+B,EAAE;QACxD,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,MAAM,GAAI,OAAO,CAAC,MAAc,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC;QAEtD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEnD,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;YACjB,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;QACpE,CAAC;QACD,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;YACjB,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;QACxE,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,aAAa,CAAC,IAAO;QACzB,IAAI,IAAI,CAAC,KAAK;YAAE,OAAO;QAEvB,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QAC7D,IAAI,CAAC,YAAY;YAAE,OAAO;QAE1B,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC/B,IAAI,GAAG,KAAK,IAAI;YAAE,OAAO;QAEzB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;QAC9B,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAE3B,mBAAmB;QACnB,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAChC,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,IAAK,CAAC,CAAC;QAC9E,CAAC;QAED,eAAe;QACf,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC;YAChE,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACrB,CAAC;QACD,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;YACnF,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC;IAED;;OAEG;IACH,aAAa,CAAC,IAAO;QACnB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO;YAAE,OAAO;QAElC,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC/B,IAAI,GAAG,KAAK,IAAI;YAAE,OAAO;QAEzB,IAAI,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;YAC5B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YAC3B,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC;IAYD;;OAEG;IACH,IAAI,CAAC,MAAM,GAAG,MAAM;QAClB,IAAI,IAAI,CAAC,KAAK;YAAE,OAAO;QAEvB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC;QAExB,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC5B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACvB,CAAC;QACD,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAChC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QAC3B,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;IAC3C,CAAC;IAED;;OAEG;IACH,UAAU,CAAC,UAAsC,EAAE;QACjD,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC5B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACvB,CAAC;QACD,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAChC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QAC3B,CAAC;QAED,IAAI,OAAO,CAAC,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;YACtC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACzF,CAAC;QACD,IAAI,OAAO,CAAC,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;YACtC,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC7F,CAAC;IACH,CAAC;IAED;;OAEG;IACH,QAAQ;QACN,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC;QAC9B,IAAI,MAAM,EAAE,CAAC;YACX,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAClB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;OAEG;IACH,IAAI,IAAI;QACN,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;gBACf,MAAM,CAAC,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC,CAAC;gBACzC,OAAO;YACT,CAAC;YAED,MAAM,OAAO,GAAG,GAAG,EAAE;gBACnB,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;gBAC1C,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YACpC,CAAC,CAAC;YAEF,MAAM,SAAS,GAAG,CAAC,IAAO,EAAE,EAAE;gBAC5B,OAAO,EAAE,CAAC;gBACV,OAAO,CAAC,IAAI,CAAC,CAAC;YAChB,CAAC,CAAC;YAEF,MAAM,KAAK,GAAG,GAAG,EAAE;gBACjB,OAAO,EAAE,CAAC;gBACV,MAAM,CAAC,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC,CAAC;YACvC,CAAC,CAAC;YAEF,IAAI,CAAC,EAAE,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;YAC9B,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QACxB,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AAzLD,8BAyLC;AAUD;;GAEG;AACH,MAAa,gBAAiB,SAAQ,SAAsB;IAC1C,SAAS,CAAS;IACjB,cAAc,CAAyB;IAExD,YAAY,MAAW,EAAE,SAAiB,EAAE,UAAmC,EAAE;QAC/E,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QACvB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAE3B,qDAAqD;QACrD,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC;QAElC,IAAI,CAAC,cAAc,GAAG,CAAC,OAAY,EAAE,EAAE;YACrC,IAAI,OAAO,CAAC,UAAU,KAAK,IAAI,CAAC,SAAS,IAAI,OAAO,CAAC,SAAS,KAAK,IAAI,CAAC,SAAS,EAAE,CAAC;gBAClF,8CAA8C;gBAC9C,MAAM,QAAQ,GAAG,OAAO,CAAC,MAAM,EAAE,EAAE,IAAI,OAAO,CAAC,SAAS,CAAC;gBACzD,IAAI,SAAS,IAAI,QAAQ,KAAK,SAAS;oBAAE,OAAO;gBAEhD,yDAAyD;gBACzD,IAAI,OAAO,CAAC,cAAc,IAAI,OAAO,CAAC,aAAa;oBAAE,OAAO;gBAE5D,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;YAC9B,CAAC;QACH,CAAC,CAAC;QAEF,MAAM,CAAC,EAAE,CAAC,eAAe,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;QAEhD,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,EAAE;YACpB,MAAM,CAAC,cAAc,CAAC,eAAe,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;QAC9D,CAAC,CAAC,CAAC;IACL,CAAC;IAED,OAAO,CAAC,OAAY;QAClB,OAAO,OAAO,CAAC,EAAE,IAAI,IAAI,CAAC;IAC5B,CAAC;IAED,OAAO,CAAC,OAAY;QAClB,OAAO,OAAO,CAAC,EAAE,IAAI,IAAI,CAAC;IAC5B,CAAC;CACF;AAtCD,4CAsCC;AAkBD;;GAEG;AACH,MAAa,oBAAqB,SAAQ,SAAsB;IAC9C,SAAS,CAAU;IACnB,OAAO,CAAU;IACjB,SAAS,CAAU;IACnB,eAAe,CAAY;IAC3B,aAAa,CAAY;IACxB,kBAAkB,CAA6B;IAEhE,YAAY,MAAW,EAAE,UAAuC,EAAE;QAChE,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QACvB,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;QACnC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;QAC/B,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;QACnC,IAAI,CAAC,eAAe,GAAG,OAAO,CAAC,eAAe;YAC5C,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC;YAC9F,CAAC,CAAC,SAAS,CAAC;QACd,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,aAAa;YACxC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC;YACxF,CAAC,CAAC,SAAS,CAAC;QAEd,IAAI,CAAC,kBAAkB,GAAG,CAAC,WAAgB,EAAE,EAAE;YAC7C,oBAAoB;YACpB,IAAI,IAAI,CAAC,SAAS,IAAI,WAAW,CAAC,SAAS,KAAK,IAAI,CAAC,SAAS;gBAAE,OAAO;YACvE,kBAAkB;YAClB,IAAI,IAAI,CAAC,OAAO,IAAI,WAAW,CAAC,OAAO,KAAK,IAAI,CAAC,OAAO;gBAAE,OAAO;YACjE,oBAAoB;YACpB,IAAI,IAAI,CAAC,SAAS,IAAI,WAAW,CAAC,OAAO,EAAE,EAAE,KAAK,IAAI,CAAC,SAAS;gBAAE,OAAO;YACzE,6BAA6B;YAC7B,IAAI,IAAI,CAAC,eAAe,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC;gBAAE,OAAO;YACrF,2BAA2B;YAC3B,IAAI,IAAI,CAAC,aAAa,IAAI,WAAW,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,WAAW,CAAC,aAAa,CAAC;gBAAE,OAAO;YAEvH,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;QAClC,CAAC,CAAC;QAEF,MAAM,CAAC,EAAE,CAAC,mBAAmB,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAExD,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,EAAE;YACpB,MAAM,CAAC,cAAc,CAAC,mBAAmB,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAC;QACtE,CAAC,CAAC,CAAC;IACL,CAAC;IAED,OAAO,CAAC,WAAgB;QACtB,OAAO,WAAW,CAAC,EAAE,IAAI,IAAI,CAAC;IAChC,CAAC;IAED,OAAO,CAAC,WAAgB;QACtB,OAAO,WAAW,CAAC,EAAE,IAAI,IAAI,CAAC;IAChC,CAAC;CACF;AAjDD,oDAiDC;AAUD;;GAEG;AACH,MAAa,iBAAkB,SAAQ,SAAsB;IAC3C,SAAS,CAAS;IACjB,eAAe,CAA0B;IAE1D,YAAY,MAAW,EAAE,SAAiB,EAAE,OAAiC;QAC3E,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QACvB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAE3B,IAAI,CAAC,eAAe,GAAG,CAAC,QAAa,EAAE,EAAE;YACvC,IAAI,QAAQ,CAAC,UAAU,KAAK,IAAI,CAAC,SAAS,IAAI,QAAQ,CAAC,SAAS,KAAK,IAAI,CAAC,SAAS,EAAE,CAAC;gBACpF,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YAC/B,CAAC;QACH,CAAC,CAAC;QAEF,MAAM,CAAC,EAAE,CAAC,oBAAoB,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QAEtD,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,EAAE;YACpB,MAAM,CAAC,cAAc,CAAC,oBAAoB,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QACpE,CAAC,CAAC,CAAC;IACL,CAAC;IAED,OAAO,CAAC,QAAa;QACnB,0BAA0B;QAC1B,OAAO,QAAQ,CAAC,KAAK,EAAE,EAAE,IAAI,QAAQ,CAAC,KAAK,EAAE,IAAI,IAAI,IAAI,CAAC;IAC5D,CAAC;IAED,OAAO,CAAC,QAAa;QACnB,OAAO,QAAQ,CAAC,KAAK,EAAE,EAAE,IAAI,QAAQ,CAAC,KAAK,EAAE,IAAI,IAAI,IAAI,CAAC;IAC5D,CAAC;CACF;AA7BD,8CA6BC;AAED;;GAEG;AACH,SAAgB,aAAa,CAC3B,MAAW,EACX,SAAiB,EACjB,UAAmC,EAAE;IAErC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,MAAM,SAAS,GAAG,IAAI,gBAAgB,CAAC,MAAM,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAEnE,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,EAAE;YAC1C,IAAI,OAAO,CAAC,GAAG,IAAI,SAAS,CAAC,IAAI,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;gBAChD,MAAM,CAAC,IAAI,KAAK,CAAC,gCAAgC,MAAM,EAAE,CAAC,CAAC,CAAC;YAC9D,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,SAAS,CAAC,CAAC;YACrB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED;;GAEG;AACH,SAAgB,cAAc,CAC5B,MAAW,EACX,SAAiB,EACjB,OAAiC;IAEjC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,MAAM,SAAS,GAAG,IAAI,iBAAiB,CAAC,MAAM,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAEpE,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,EAAE;YAC1C,IAAI,OAAO,CAAC,GAAG,IAAI,SAAS,CAAC,IAAI,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;gBAChD,MAAM,CAAC,IAAI,KAAK,CAAC,gCAAgC,MAAM,EAAE,CAAC,CAAC,CAAC;YAC9D,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,SAAS,CAAC,CAAC;YACrB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED,kBAAe,SAAS,CAAC","sourcesContent":["/**\r\n * Collectors for awaiting messages, reactions, and interactions\r\n * API compatible with Discord.js Collectors\r\n */\r\n\r\nimport { EventEmitter } from 'events';\r\nimport { Collection } from './Collection';\r\n\r\nexport interface CollectorOptions<T> {\r\n  /** How long to run the collector for in milliseconds */\r\n  time?: number;\r\n  /** How long to wait for the next item in milliseconds */\r\n  idle?: number;\r\n  /** Maximum number of items to collect */\r\n  max?: number;\r\n  /** Maximum number of items to process */\r\n  maxProcessed?: number;\r\n  /** Filter function */\r\n  filter?: (item: T, collected: Collection<string, T>) => boolean | Promise<boolean>;\r\n  /** Whether to dispose of items when the collector ends */\r\n  dispose?: boolean;\r\n}\r\n\r\nexport interface CollectorResetTimerOptions {\r\n  time?: number;\r\n  idle?: number;\r\n}\r\n\r\n/**\r\n * Abstract base class for collectors\r\n */\r\nexport abstract class Collector<K extends string, V> extends EventEmitter {\r\n  /** The client that instantiated this collector */\r\n  public readonly client: any;\r\n  \r\n  /** The items collected */\r\n  public readonly collected: Collection<K, V> = new Collection();\r\n  \r\n  /** Whether the collector has ended */\r\n  public ended = false;\r\n  \r\n  /** The reason the collector ended */\r\n  public endReason: string | null = null;\r\n  \r\n  /** Filter function */\r\n  public filter: (item: V, collected: Collection<K, V>) => boolean | Promise<boolean>;\r\n  \r\n  /** Collector options */\r\n  public options: CollectorOptions<V>;\r\n  \r\n  /** Number of items processed */\r\n  private _processedCount = 0;\r\n  \r\n  /** Timeout for time limit */\r\n  private _timeout: NodeJS.Timeout | null = null;\r\n  \r\n  /** Timeout for idle limit */\r\n  private _idleTimeout: NodeJS.Timeout | null = null;\r\n\r\n  constructor(client: any, options: CollectorOptions<V> = {}) {\r\n    super();\r\n    this.client = client;\r\n    this.options = options;\r\n    this.filter = (options.filter as any) ?? (() => true);\r\n    \r\n    this.handleCollect = this.handleCollect.bind(this);\r\n    this.handleDispose = this.handleDispose.bind(this);\r\n    \r\n    if (options.time) {\r\n      this._timeout = setTimeout(() => this.stop('time'), options.time);\r\n    }\r\n    if (options.idle) {\r\n      this._idleTimeout = setTimeout(() => this.stop('idle'), options.idle);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle an item being collected\r\n   */\r\n  async handleCollect(item: V): Promise<void> {\r\n    if (this.ended) return;\r\n    \r\n    this._processedCount++;\r\n    \r\n    const filterResult = await this.filter(item, this.collected);\r\n    if (!filterResult) return;\r\n    \r\n    const key = this.collect(item);\r\n    if (key === null) return;\r\n    \r\n    this.collected.set(key, item);\r\n    this.emit('collect', item);\r\n    \r\n    // Reset idle timer\r\n    if (this._idleTimeout) {\r\n      clearTimeout(this._idleTimeout);\r\n      this._idleTimeout = setTimeout(() => this.stop('idle'), this.options.idle!);\r\n    }\r\n    \r\n    // Check limits\r\n    if (this.options.max && this.collected.size >= this.options.max) {\r\n      this.stop('limit');\r\n    }\r\n    if (this.options.maxProcessed && this._processedCount >= this.options.maxProcessed) {\r\n      this.stop('processedLimit');\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle an item being disposed\r\n   */\r\n  handleDispose(item: V): void {\r\n    if (!this.options.dispose) return;\r\n    \r\n    const key = this.dispose(item);\r\n    if (key === null) return;\r\n    \r\n    if (this.collected.has(key)) {\r\n      this.collected.delete(key);\r\n      this.emit('dispose', item);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Get the key for an item\r\n   */\r\n  abstract collect(item: V): K | null;\r\n\r\n  /**\r\n   * Get the key for disposing an item\r\n   */\r\n  abstract dispose(item: V): K | null;\r\n\r\n  /**\r\n   * Stop the collector\r\n   */\r\n  stop(reason = 'user'): void {\r\n    if (this.ended) return;\r\n    \r\n    this.ended = true;\r\n    this.endReason = reason;\r\n    \r\n    if (this._timeout) {\r\n      clearTimeout(this._timeout);\r\n      this._timeout = null;\r\n    }\r\n    if (this._idleTimeout) {\r\n      clearTimeout(this._idleTimeout);\r\n      this._idleTimeout = null;\r\n    }\r\n    \r\n    this.emit('end', this.collected, reason);\r\n  }\r\n\r\n  /**\r\n   * Reset the collector's timer\r\n   */\r\n  resetTimer(options: CollectorResetTimerOptions = {}): void {\r\n    if (this._timeout) {\r\n      clearTimeout(this._timeout);\r\n      this._timeout = null;\r\n    }\r\n    if (this._idleTimeout) {\r\n      clearTimeout(this._idleTimeout);\r\n      this._idleTimeout = null;\r\n    }\r\n    \r\n    if (options.time ?? this.options.time) {\r\n      this._timeout = setTimeout(() => this.stop('time'), options.time ?? this.options.time);\r\n    }\r\n    if (options.idle ?? this.options.idle) {\r\n      this._idleTimeout = setTimeout(() => this.stop('idle'), options.idle ?? this.options.idle);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Check the end conditions\r\n   */\r\n  checkEnd(): boolean {\r\n    const reason = this.endReason;\r\n    if (reason) {\r\n      this.stop(reason);\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  /**\r\n   * Get the next item\r\n   */\r\n  get next(): Promise<V> {\r\n    return new Promise((resolve, reject) => {\r\n      if (this.ended) {\r\n        reject(new Error('Collector has ended'));\r\n        return;\r\n      }\r\n      \r\n      const cleanup = () => {\r\n        this.removeListener('collect', onCollect);\r\n        this.removeListener('end', onEnd);\r\n      };\r\n      \r\n      const onCollect = (item: V) => {\r\n        cleanup();\r\n        resolve(item);\r\n      };\r\n      \r\n      const onEnd = () => {\r\n        cleanup();\r\n        reject(new Error('Collector ended'));\r\n      };\r\n      \r\n      this.on('collect', onCollect);\r\n      this.on('end', onEnd);\r\n    });\r\n  }\r\n}\r\n\r\n/**\r\n * Message collector options\r\n */\r\nexport interface MessageCollectorOptions extends CollectorOptions<any> {\r\n  /** Channel to collect messages from */\r\n  channelId?: string;\r\n}\r\n\r\n/**\r\n * Collector for messages\r\n */\r\nexport class MessageCollector extends Collector<string, any> {\r\n  public readonly channelId: string;\r\n  private readonly messageHandler: (message: any) => void;\r\n\r\n  constructor(client: any, channelId: string, options: MessageCollectorOptions = {}) {\r\n    super(client, options);\r\n    this.channelId = channelId;\r\n    \r\n    // Get bot's user ID to filter out bot's own messages\r\n    const botUserId = client.user?.id;\r\n    \r\n    this.messageHandler = (message: any) => {\r\n      if (message.channel_id === this.channelId || message.channelId === this.channelId) {\r\n        // Automatically filter out bot's own messages\r\n        const authorId = message.author?.id || message.author_id;\r\n        if (botUserId && authorId === botUserId) return;\r\n        \r\n        // Also filter by application_id (bot messages have this)\r\n        if (message.application_id || message.applicationId) return;\r\n        \r\n        this.handleCollect(message);\r\n      }\r\n    };\r\n    \r\n    client.on('messageCreate', this.messageHandler);\r\n    \r\n    this.once('end', () => {\r\n      client.removeListener('messageCreate', this.messageHandler);\r\n    });\r\n  }\r\n\r\n  collect(message: any): string | null {\r\n    return message.id ?? null;\r\n  }\r\n\r\n  dispose(message: any): string | null {\r\n    return message.id ?? null;\r\n  }\r\n}\r\n\r\n/**\r\n * Interaction collector options\r\n */\r\nexport interface InteractionCollectorOptions extends CollectorOptions<any> {\r\n  /** Channel to collect interactions from */\r\n  channelId?: string;\r\n  /** Guild to collect interactions from */\r\n  guildId?: string;\r\n  /** Message to collect interactions from */\r\n  messageId?: string;\r\n  /** Interaction types to collect */\r\n  interactionType?: number | number[];\r\n  /** Component types to collect */\r\n  componentType?: number | number[];\r\n}\r\n\r\n/**\r\n * Collector for interactions (buttons, select menus, etc.)\r\n */\r\nexport class InteractionCollector extends Collector<string, any> {\r\n  public readonly channelId?: string;\r\n  public readonly guildId?: string;\r\n  public readonly messageId?: string;\r\n  public readonly interactionType?: number[];\r\n  public readonly componentType?: number[];\r\n  private readonly interactionHandler: (interaction: any) => void;\r\n\r\n  constructor(client: any, options: InteractionCollectorOptions = {}) {\r\n    super(client, options);\r\n    this.channelId = options.channelId;\r\n    this.guildId = options.guildId;\r\n    this.messageId = options.messageId;\r\n    this.interactionType = options.interactionType \r\n      ? Array.isArray(options.interactionType) ? options.interactionType : [options.interactionType]\r\n      : undefined;\r\n    this.componentType = options.componentType\r\n      ? Array.isArray(options.componentType) ? options.componentType : [options.componentType]\r\n      : undefined;\r\n    \r\n    this.interactionHandler = (interaction: any) => {\r\n      // Filter by channel\r\n      if (this.channelId && interaction.channelId !== this.channelId) return;\r\n      // Filter by guild\r\n      if (this.guildId && interaction.guildId !== this.guildId) return;\r\n      // Filter by message\r\n      if (this.messageId && interaction.message?.id !== this.messageId) return;\r\n      // Filter by interaction type\r\n      if (this.interactionType && !this.interactionType.includes(interaction.type)) return;\r\n      // Filter by component type\r\n      if (this.componentType && interaction.componentType && !this.componentType.includes(interaction.componentType)) return;\r\n      \r\n      this.handleCollect(interaction);\r\n    };\r\n    \r\n    client.on('interactionCreate', this.interactionHandler);\r\n    \r\n    this.once('end', () => {\r\n      client.removeListener('interactionCreate', this.interactionHandler);\r\n    });\r\n  }\r\n\r\n  collect(interaction: any): string | null {\r\n    return interaction.id ?? null;\r\n  }\r\n\r\n  dispose(interaction: any): string | null {\r\n    return interaction.id ?? null;\r\n  }\r\n}\r\n\r\n/**\r\n * Reaction collector options\r\n */\r\nexport interface ReactionCollectorOptions extends CollectorOptions<any> {\r\n  /** Message to collect reactions from */\r\n  messageId: string;\r\n}\r\n\r\n/**\r\n * Collector for reactions\r\n */\r\nexport class ReactionCollector extends Collector<string, any> {\r\n  public readonly messageId: string;\r\n  private readonly reactionHandler: (reaction: any) => void;\r\n\r\n  constructor(client: any, messageId: string, options: ReactionCollectorOptions) {\r\n    super(client, options);\r\n    this.messageId = messageId;\r\n    \r\n    this.reactionHandler = (reaction: any) => {\r\n      if (reaction.message_id === this.messageId || reaction.messageId === this.messageId) {\r\n        this.handleCollect(reaction);\r\n      }\r\n    };\r\n    \r\n    client.on('messageReactionAdd', this.reactionHandler);\r\n    \r\n    this.once('end', () => {\r\n      client.removeListener('messageReactionAdd', this.reactionHandler);\r\n    });\r\n  }\r\n\r\n  collect(reaction: any): string | null {\r\n    // Key is emoji identifier\r\n    return reaction.emoji?.id ?? reaction.emoji?.name ?? null;\r\n  }\r\n\r\n  dispose(reaction: any): string | null {\r\n    return reaction.emoji?.id ?? reaction.emoji?.name ?? null;\r\n  }\r\n}\r\n\r\n/**\r\n * Await messages helper\r\n */\r\nexport function awaitMessages(\r\n  client: any,\r\n  channelId: string,\r\n  options: MessageCollectorOptions = {}\r\n): Promise<Collection<string, any>> {\r\n  return new Promise((resolve, reject) => {\r\n    const collector = new MessageCollector(client, channelId, options);\r\n    \r\n    collector.once('end', (collected, reason) => {\r\n      if (options.max && collected.size < options.max) {\r\n        reject(new Error(`Collector ended with reason: ${reason}`));\r\n      } else {\r\n        resolve(collected);\r\n      }\r\n    });\r\n  });\r\n}\r\n\r\n/**\r\n * Await reactions helper\r\n */\r\nexport function awaitReactions(\r\n  client: any,\r\n  messageId: string,\r\n  options: ReactionCollectorOptions\r\n): Promise<Collection<string, any>> {\r\n  return new Promise((resolve, reject) => {\r\n    const collector = new ReactionCollector(client, messageId, options);\r\n    \r\n    collector.once('end', (collected, reason) => {\r\n      if (options.max && collected.size < options.max) {\r\n        reject(new Error(`Collector ended with reason: ${reason}`));\r\n      } else {\r\n        resolve(collected);\r\n      }\r\n    });\r\n  });\r\n}\r\n\r\nexport default Collector;\r\n"]}
314
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Collector.js","sourceRoot":"","sources":["../../src/utils/Collector.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Collectors for awaiting messages, reactions, and interactions\n * API compatible with Discord.js Collectors\n */\n\nimport { EventEmitter } from 'events';\nimport { Collection } from './Collection';\n\nexport interface CollectorOptions<T> {\n  /** How long to run the collector for in milliseconds */\n  time?: number;\n  /** How long to wait for the next item in milliseconds */\n  idle?: number;\n  /** Maximum number of items to collect */\n  max?: number;\n  /** Maximum number of items to process */\n  maxProcessed?: number;\n  /** Filter function */\n  filter?: (item: T, collected: Collection<string, T>) => boolean | Promise<boolean>;\n  /** Whether to dispose of items when the collector ends */\n  dispose?: boolean;\n}\n\nexport interface CollectorResetTimerOptions {\n  time?: number;\n  idle?: number;\n}\n\n/**\n * Abstract base class for collectors\n */\nexport abstract class Collector<K extends string, V> extends EventEmitter {\n  /** The client that instantiated this collector */\n  public readonly client: any;\n  \n  /** The items collected */\n  public readonly collected: Collection<K, V> = new Collection();\n  \n  /** Whether the collector has ended */\n  public ended = false;\n  \n  /** The reason the collector ended */\n  public endReason: string | null = null;\n  \n  /** Filter function */\n  public filter: (item: V, collected: Collection<K, V>) => boolean | Promise<boolean>;\n  \n  /** Collector options */\n  public options: CollectorOptions<V>;\n  \n  /** Number of items processed */\n  private _processedCount = 0;\n  \n  /** Timeout for time limit */\n  private _timeout: NodeJS.Timeout | null = null;\n  \n  /** Timeout for idle limit */\n  private _idleTimeout: NodeJS.Timeout | null = null;\n\n  constructor(client: any, options: CollectorOptions<V> = {}) {\n    super();\n    this.client = client;\n    this.options = options;\n    this.filter = (options.filter as any) ?? (() => true);\n    \n    this.handleCollect = this.handleCollect.bind(this);\n    this.handleDispose = this.handleDispose.bind(this);\n    \n    if (options.time) {\n      this._timeout = setTimeout(() => this.stop('time'), options.time);\n    }\n    if (options.idle) {\n      this._idleTimeout = setTimeout(() => this.stop('idle'), options.idle);\n    }\n  }\n\n  /**\n   * Handle an item being collected\n   */\n  async handleCollect(item: V): Promise<void> {\n    if (this.ended) return;\n    \n    this._processedCount++;\n    \n    const filterResult = await this.filter(item, this.collected);\n    if (!filterResult) return;\n    \n    const key = this.collect(item);\n    if (key === null) return;\n    \n    this.collected.set(key, item);\n    this.emit('collect', item);\n    \n    // Reset idle timer\n    if (this._idleTimeout) {\n      clearTimeout(this._idleTimeout);\n      this._idleTimeout = setTimeout(() => this.stop('idle'), this.options.idle!);\n    }\n    \n    // Check limits\n    if (this.options.max && this.collected.size >= this.options.max) {\n      this.stop('limit');\n    }\n    if (this.options.maxProcessed && this._processedCount >= this.options.maxProcessed) {\n      this.stop('processedLimit');\n    }\n  }\n\n  /**\n   * Handle an item being disposed\n   */\n  handleDispose(item: V): void {\n    if (!this.options.dispose) return;\n    \n    const key = this.dispose(item);\n    if (key === null) return;\n    \n    if (this.collected.has(key)) {\n      this.collected.delete(key);\n      this.emit('dispose', item);\n    }\n  }\n\n  /**\n   * Get the key for an item\n   */\n  abstract collect(item: V): K | null;\n\n  /**\n   * Get the key for disposing an item\n   */\n  abstract dispose(item: V): K | null;\n\n  /**\n   * Stop the collector\n   */\n  stop(reason = 'user'): void {\n    if (this.ended) return;\n    \n    this.ended = true;\n    this.endReason = reason;\n    \n    if (this._timeout) {\n      clearTimeout(this._timeout);\n      this._timeout = null;\n    }\n    if (this._idleTimeout) {\n      clearTimeout(this._idleTimeout);\n      this._idleTimeout = null;\n    }\n    \n    this.emit('end', this.collected, reason);\n  }\n\n  /**\n   * Reset the collector's timer\n   */\n  resetTimer(options: CollectorResetTimerOptions = {}): void {\n    if (this._timeout) {\n      clearTimeout(this._timeout);\n      this._timeout = null;\n    }\n    if (this._idleTimeout) {\n      clearTimeout(this._idleTimeout);\n      this._idleTimeout = null;\n    }\n    \n    if (options.time ?? this.options.time) {\n      this._timeout = setTimeout(() => this.stop('time'), options.time ?? this.options.time);\n    }\n    if (options.idle ?? this.options.idle) {\n      this._idleTimeout = setTimeout(() => this.stop('idle'), options.idle ?? this.options.idle);\n    }\n  }\n\n  /**\n   * Check the end conditions\n   */\n  checkEnd(): boolean {\n    const reason = this.endReason;\n    if (reason) {\n      this.stop(reason);\n      return true;\n    }\n    return false;\n  }\n\n  /**\n   * Get the next item\n   */\n  get next(): Promise<V> {\n    return new Promise((resolve, reject) => {\n      if (this.ended) {\n        reject(new Error('Collector has ended'));\n        return;\n      }\n      \n      const cleanup = () => {\n        this.removeListener('collect', onCollect);\n        this.removeListener('end', onEnd);\n      };\n      \n      const onCollect = (item: V) => {\n        cleanup();\n        resolve(item);\n      };\n      \n      const onEnd = () => {\n        cleanup();\n        reject(new Error('Collector ended'));\n      };\n      \n      this.on('collect', onCollect);\n      this.on('end', onEnd);\n    });\n  }\n}\n\n/**\n * Message collector options\n */\nexport interface MessageCollectorOptions extends CollectorOptions<any> {\n  /** Channel to collect messages from */\n  channelId?: string;\n}\n\n/**\n * Collector for messages\n */\nexport class MessageCollector extends Collector<string, any> {\n  public readonly channelId: string;\n  private readonly messageHandler: (message: any) => void;\n\n  constructor(client: any, channelId: string, options: MessageCollectorOptions = {}) {\n    super(client, options);\n    this.channelId = channelId;\n    \n    // Get bot's user ID to filter out bot's own messages\n    const botUserId = client.user?.id;\n    \n    this.messageHandler = (message: any) => {\n      if (message.channel_id === this.channelId || message.channelId === this.channelId) {\n        // Automatically filter out bot's own messages\n        const authorId = message.author?.id || message.author_id;\n        if (botUserId && authorId === botUserId) return;\n        \n        // Also filter by application_id (bot messages have this)\n        if (message.application_id || message.applicationId) return;\n        \n        this.handleCollect(message);\n      }\n    };\n    \n    client.on('messageCreate', this.messageHandler);\n    \n    this.once('end', () => {\n      client.removeListener('messageCreate', this.messageHandler);\n    });\n  }\n\n  collect(message: any): string | null {\n    return message.id ?? null;\n  }\n\n  dispose(message: any): string | null {\n    return message.id ?? null;\n  }\n}\n\n/**\n * Interaction collector options\n */\nexport interface InteractionCollectorOptions extends CollectorOptions<any> {\n  /** Channel to collect interactions from */\n  channelId?: string;\n  /** Guild to collect interactions from */\n  guildId?: string;\n  /** Message to collect interactions from */\n  messageId?: string;\n  /** Interaction types to collect */\n  interactionType?: number | number[];\n  /** Component types to collect */\n  componentType?: number | number[];\n}\n\n/**\n * Collector for interactions (buttons, select menus, etc.)\n */\nexport class InteractionCollector extends Collector<string, any> {\n  public readonly channelId?: string;\n  public readonly guildId?: string;\n  public readonly messageId?: string;\n  public readonly interactionType?: number[];\n  public readonly componentType?: number[];\n  private readonly interactionHandler: (interaction: any) => void;\n\n  constructor(client: any, options: InteractionCollectorOptions = {}) {\n    super(client, options);\n    this.channelId = options.channelId;\n    this.guildId = options.guildId;\n    this.messageId = options.messageId;\n    this.interactionType = options.interactionType \n      ? Array.isArray(options.interactionType) ? options.interactionType : [options.interactionType]\n      : undefined;\n    this.componentType = options.componentType\n      ? Array.isArray(options.componentType) ? options.componentType : [options.componentType]\n      : undefined;\n    \n    this.interactionHandler = (interaction: any) => {\n      // Filter by channel\n      if (this.channelId && interaction.channelId !== this.channelId) return;\n      // Filter by guild\n      if (this.guildId && interaction.guildId !== this.guildId) return;\n      // Filter by message\n      if (this.messageId && interaction.message?.id !== this.messageId) return;\n      // Filter by interaction type\n      if (this.interactionType && !this.interactionType.includes(interaction.type)) return;\n      // Filter by component type\n      if (this.componentType && interaction.componentType && !this.componentType.includes(interaction.componentType)) return;\n      \n      this.handleCollect(interaction);\n    };\n    \n    client.on('interactionCreate', this.interactionHandler);\n    \n    this.once('end', () => {\n      client.removeListener('interactionCreate', this.interactionHandler);\n    });\n  }\n\n  collect(interaction: any): string | null {\n    return interaction.id ?? null;\n  }\n\n  dispose(interaction: any): string | null {\n    return interaction.id ?? null;\n  }\n}\n\n/**\n * Reaction collector options\n */\nexport interface ReactionCollectorOptions extends CollectorOptions<any> {\n  /** Message to collect reactions from */\n  messageId: string;\n}\n\n/**\n * Collector for reactions\n */\nexport class ReactionCollector extends Collector<string, any> {\n  public readonly messageId: string;\n  private readonly reactionHandler: (reaction: any) => void;\n\n  constructor(client: any, messageId: string, options: ReactionCollectorOptions) {\n    super(client, options);\n    this.messageId = messageId;\n    \n    this.reactionHandler = (reaction: any) => {\n      if (reaction.message_id === this.messageId || reaction.messageId === this.messageId) {\n        this.handleCollect(reaction);\n      }\n    };\n    \n    client.on('messageReactionAdd', this.reactionHandler);\n    \n    this.once('end', () => {\n      client.removeListener('messageReactionAdd', this.reactionHandler);\n    });\n  }\n\n  collect(reaction: any): string | null {\n    // Key is emoji identifier\n    return reaction.emoji?.id ?? reaction.emoji?.name ?? null;\n  }\n\n  dispose(reaction: any): string | null {\n    return reaction.emoji?.id ?? reaction.emoji?.name ?? null;\n  }\n}\n\n/**\n * Await messages helper\n */\nexport function awaitMessages(\n  client: any,\n  channelId: string,\n  options: MessageCollectorOptions = {}\n): Promise<Collection<string, any>> {\n  return new Promise((resolve, reject) => {\n    const collector = new MessageCollector(client, channelId, options);\n    \n    collector.once('end', (collected, reason) => {\n      if (options.max && collected.size < options.max) {\n        reject(new Error(`Collector ended with reason: ${reason}`));\n      } else {\n        resolve(collected);\n      }\n    });\n  });\n}\n\n/**\n * Await reactions helper\n */\nexport function awaitReactions(\n  client: any,\n  messageId: string,\n  options: ReactionCollectorOptions\n): Promise<Collection<string, any>> {\n  return new Promise((resolve, reject) => {\n    const collector = new ReactionCollector(client, messageId, options);\n    \n    collector.once('end', (collected, reason) => {\n      if (options.max && collected.size < options.max) {\n        reject(new Error(`Collector ended with reason: ${reason}`));\n      } else {\n        resolve(collected);\n      }\n    });\n  });\n}\n\nexport default Collector;\n"]}
@@ -143,4 +143,4 @@ class DataResolver {
143
143
  }
144
144
  exports.DataResolver = DataResolver;
145
145
  exports.default = DataResolver;
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DataResolver.js","sourceRoot":"","sources":["../../src/utils/DataResolver.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Data resolver utilities for handling various data types\r\n */\r\n\r\nimport { readFile } from 'fs/promises';\r\nimport { basename } from 'path';\r\n\r\nexport type BufferResolvable = Buffer | string;\r\nexport type Base64Resolvable = Buffer | string;\r\n\r\n/**\r\n * Resolves various data types to usable formats\r\n */\r\nexport class DataResolver {\r\n  /**\r\n   * Resolves a BufferResolvable to a Buffer\r\n   * @param resource The resource to resolve\r\n   */\r\n  static async resolveBuffer(resource: BufferResolvable): Promise<Buffer> {\r\n    if (Buffer.isBuffer(resource)) return resource;\r\n    \r\n    if (typeof resource === 'string') {\r\n      // Check if it's a file path\r\n      if (resource.startsWith('/') || resource.startsWith('./') || resource.startsWith('../') || /^[a-zA-Z]:/.test(resource)) {\r\n        return readFile(resource);\r\n      }\r\n      \r\n      // Check if it's a URL\r\n      if (resource.startsWith('http://') || resource.startsWith('https://')) {\r\n        const response = await fetch(resource);\r\n        const arrayBuffer = await response.arrayBuffer();\r\n        return Buffer.from(arrayBuffer);\r\n      }\r\n      \r\n      // Check if it's base64\r\n      if (resource.startsWith('data:')) {\r\n        const base64Data = resource.split(',')[1];\r\n        return Buffer.from(base64Data, 'base64');\r\n      }\r\n      \r\n      // Assume it's a file path\r\n      return readFile(resource);\r\n    }\r\n    \r\n    throw new TypeError('Invalid resource type');\r\n  }\r\n\r\n  /**\r\n   * Resolves a Base64Resolvable to a base64 string\r\n   * @param resource The resource to resolve\r\n   * @param mimeType The MIME type for the data URI\r\n   */\r\n  static async resolveBase64(resource: Base64Resolvable, mimeType = 'image/png'): Promise<string> {\r\n    const buffer = await this.resolveBuffer(resource);\r\n    return `data:${mimeType};base64,${buffer.toString('base64')}`;\r\n  }\r\n\r\n  /**\r\n   * Resolves a file to a name and buffer\r\n   * @param resource The file resource\r\n   */\r\n  static async resolveFile(resource: BufferResolvable | { name?: string; attachment: BufferResolvable }): Promise<{ name: string; data: Buffer }> {\r\n    if (typeof resource === 'object' && 'attachment' in resource) {\r\n      const buffer = await this.resolveBuffer(resource.attachment);\r\n      const name = resource.name ?? 'file';\r\n      return { name, data: buffer };\r\n    }\r\n    \r\n    const buffer = await this.resolveBuffer(resource);\r\n    const name = typeof resource === 'string' ? basename(resource) : 'file';\r\n    return { name, data: buffer };\r\n  }\r\n\r\n  /**\r\n   * Resolves multiple files\r\n   * @param resources The file resources\r\n   */\r\n  static async resolveFiles(resources: (BufferResolvable | { name?: string; attachment: BufferResolvable })[]): Promise<{ name: string; data: Buffer }[]> {\r\n    return Promise.all(resources.map(r => this.resolveFile(r)));\r\n  }\r\n\r\n  /**\r\n   * Resolves a color to a number\r\n   * @param color The color to resolve\r\n   */\r\n  static resolveColor(color: number | string | [number, number, number] | null): number | null {\r\n    if (color === null) return null;\r\n    \r\n    if (typeof color === 'number') {\r\n      if (color < 0 || color > 0xFFFFFF) throw new RangeError('Color must be between 0 and 16777215');\r\n      return color;\r\n    }\r\n    \r\n    if (typeof color === 'string') {\r\n      if (color.startsWith('#')) {\r\n        return parseInt(color.slice(1), 16);\r\n      }\r\n      // Named colors\r\n      const namedColors: Record<string, number> = {\r\n        default: 0x000000,\r\n        white: 0xFFFFFF,\r\n        aqua: 0x1ABC9C,\r\n        green: 0x57F287,\r\n        blue: 0x3498DB,\r\n        yellow: 0xFEE75C,\r\n        purple: 0x9B59B6,\r\n        fuchsia: 0xEB459E,\r\n        gold: 0xF1C40F,\r\n        orange: 0xE67E22,\r\n        red: 0xED4245,\r\n        grey: 0x95A5A6,\r\n        navy: 0x34495E,\r\n        blurple: 0x5865F2,\r\n      };\r\n      const lower = color.toLowerCase();\r\n      if (lower in namedColors) return namedColors[lower];\r\n      return parseInt(color, 16);\r\n    }\r\n    \r\n    if (Array.isArray(color)) {\r\n      return (color[0] << 16) + (color[1] << 8) + color[2];\r\n    }\r\n    \r\n    throw new TypeError('Invalid color type');\r\n  }\r\n\r\n  /**\r\n   * Resolves a string to a snowflake ID\r\n   * @param value The value to resolve\r\n   */\r\n  static resolveSnowflake(value: string | number | { id: string | number }): string {\r\n    if (typeof value === 'object' && 'id' in value) {\r\n      return String(value.id);\r\n    }\r\n    return String(value);\r\n  }\r\n\r\n  /**\r\n   * Resolves an image to a base64 data URI\r\n   * @param image The image to resolve\r\n   */\r\n  static async resolveImage(image: BufferResolvable): Promise<string> {\r\n    const buffer = await this.resolveBuffer(image);\r\n    \r\n    // Detect MIME type from magic bytes\r\n    let mimeType = 'image/png';\r\n    if (buffer[0] === 0xFF && buffer[1] === 0xD8) {\r\n      mimeType = 'image/jpeg';\r\n    } else if (buffer[0] === 0x47 && buffer[1] === 0x49 && buffer[2] === 0x46) {\r\n      mimeType = 'image/gif';\r\n    } else if (buffer[0] === 0x52 && buffer[1] === 0x49 && buffer[2] === 0x46 && buffer[3] === 0x46) {\r\n      mimeType = 'image/webp';\r\n    }\r\n    \r\n    return `data:${mimeType};base64,${buffer.toString('base64')}`;\r\n  }\r\n}\r\n\r\nexport default DataResolver;\r\n"]}
146
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DataResolver.js","sourceRoot":"","sources":["../../src/utils/DataResolver.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Data resolver utilities for handling various data types\n */\n\nimport { readFile } from 'fs/promises';\nimport { basename } from 'path';\n\nexport type BufferResolvable = Buffer | string;\nexport type Base64Resolvable = Buffer | string;\n\n/**\n * Resolves various data types to usable formats\n */\nexport class DataResolver {\n  /**\n   * Resolves a BufferResolvable to a Buffer\n   * @param resource The resource to resolve\n   */\n  static async resolveBuffer(resource: BufferResolvable): Promise<Buffer> {\n    if (Buffer.isBuffer(resource)) return resource;\n    \n    if (typeof resource === 'string') {\n      // Check if it's a file path\n      if (resource.startsWith('/') || resource.startsWith('./') || resource.startsWith('../') || /^[a-zA-Z]:/.test(resource)) {\n        return readFile(resource);\n      }\n      \n      // Check if it's a URL\n      if (resource.startsWith('http://') || resource.startsWith('https://')) {\n        const response = await fetch(resource);\n        const arrayBuffer = await response.arrayBuffer();\n        return Buffer.from(arrayBuffer);\n      }\n      \n      // Check if it's base64\n      if (resource.startsWith('data:')) {\n        const base64Data = resource.split(',')[1];\n        return Buffer.from(base64Data, 'base64');\n      }\n      \n      // Assume it's a file path\n      return readFile(resource);\n    }\n    \n    throw new TypeError('Invalid resource type');\n  }\n\n  /**\n   * Resolves a Base64Resolvable to a base64 string\n   * @param resource The resource to resolve\n   * @param mimeType The MIME type for the data URI\n   */\n  static async resolveBase64(resource: Base64Resolvable, mimeType = 'image/png'): Promise<string> {\n    const buffer = await this.resolveBuffer(resource);\n    return `data:${mimeType};base64,${buffer.toString('base64')}`;\n  }\n\n  /**\n   * Resolves a file to a name and buffer\n   * @param resource The file resource\n   */\n  static async resolveFile(resource: BufferResolvable | { name?: string; attachment: BufferResolvable }): Promise<{ name: string; data: Buffer }> {\n    if (typeof resource === 'object' && 'attachment' in resource) {\n      const buffer = await this.resolveBuffer(resource.attachment);\n      const name = resource.name ?? 'file';\n      return { name, data: buffer };\n    }\n    \n    const buffer = await this.resolveBuffer(resource);\n    const name = typeof resource === 'string' ? basename(resource) : 'file';\n    return { name, data: buffer };\n  }\n\n  /**\n   * Resolves multiple files\n   * @param resources The file resources\n   */\n  static async resolveFiles(resources: (BufferResolvable | { name?: string; attachment: BufferResolvable })[]): Promise<{ name: string; data: Buffer }[]> {\n    return Promise.all(resources.map(r => this.resolveFile(r)));\n  }\n\n  /**\n   * Resolves a color to a number\n   * @param color The color to resolve\n   */\n  static resolveColor(color: number | string | [number, number, number] | null): number | null {\n    if (color === null) return null;\n    \n    if (typeof color === 'number') {\n      if (color < 0 || color > 0xFFFFFF) throw new RangeError('Color must be between 0 and 16777215');\n      return color;\n    }\n    \n    if (typeof color === 'string') {\n      if (color.startsWith('#')) {\n        return parseInt(color.slice(1), 16);\n      }\n      // Named colors\n      const namedColors: Record<string, number> = {\n        default: 0x000000,\n        white: 0xFFFFFF,\n        aqua: 0x1ABC9C,\n        green: 0x57F287,\n        blue: 0x3498DB,\n        yellow: 0xFEE75C,\n        purple: 0x9B59B6,\n        fuchsia: 0xEB459E,\n        gold: 0xF1C40F,\n        orange: 0xE67E22,\n        red: 0xED4245,\n        grey: 0x95A5A6,\n        navy: 0x34495E,\n        blurple: 0x5865F2,\n      };\n      const lower = color.toLowerCase();\n      if (lower in namedColors) return namedColors[lower];\n      return parseInt(color, 16);\n    }\n    \n    if (Array.isArray(color)) {\n      return (color[0] << 16) + (color[1] << 8) + color[2];\n    }\n    \n    throw new TypeError('Invalid color type');\n  }\n\n  /**\n   * Resolves a string to a snowflake ID\n   * @param value The value to resolve\n   */\n  static resolveSnowflake(value: string | number | { id: string | number }): string {\n    if (typeof value === 'object' && 'id' in value) {\n      return String(value.id);\n    }\n    return String(value);\n  }\n\n  /**\n   * Resolves an image to a base64 data URI\n   * @param image The image to resolve\n   */\n  static async resolveImage(image: BufferResolvable): Promise<string> {\n    const buffer = await this.resolveBuffer(image);\n    \n    // Detect MIME type from magic bytes\n    let mimeType = 'image/png';\n    if (buffer[0] === 0xFF && buffer[1] === 0xD8) {\n      mimeType = 'image/jpeg';\n    } else if (buffer[0] === 0x47 && buffer[1] === 0x49 && buffer[2] === 0x46) {\n      mimeType = 'image/gif';\n    } else if (buffer[0] === 0x52 && buffer[1] === 0x49 && buffer[2] === 0x46 && buffer[3] === 0x46) {\n      mimeType = 'image/webp';\n    }\n    \n    return `data:${mimeType};base64,${buffer.toString('base64')}`;\n  }\n}\n\nexport default DataResolver;\n"]}
@@ -210,4 +210,4 @@ exports.Formatters = {
210
210
  orderedList,
211
211
  TimestampStyles,
212
212
  };
213
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Formatters.js","sourceRoot":"","sources":["../../src/utils/Formatters.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Formatters for markdown and mentions\r\n */\r\n\r\n/**\r\n * Formats a user mention\r\n * @param userId The user ID to mention\r\n */\r\nexport function userMention(userId: string | number): string {\r\n  return `<@${userId}>`;\r\n}\r\n\r\n/**\r\n * Formats a channel mention\r\n * @param channelId The channel ID to mention\r\n */\r\nexport function channelMention(channelId: string | number): string {\r\n  return `<#${channelId}>`;\r\n}\r\n\r\n/**\r\n * Formats a role mention\r\n * @param roleId The role ID to mention\r\n */\r\nexport function roleMention(roleId: string | number): string {\r\n  return `<@&${roleId}>`;\r\n}\r\n\r\n/**\r\n * Formats a custom emoji\r\n * @param emojiId The emoji ID\r\n * @param name The emoji name\r\n * @param animated Whether the emoji is animated\r\n */\r\nexport function formatEmoji(emojiId: string | number, name: string, animated = false): string {\r\n  return `<${animated ? 'a' : ''}:${name}:${emojiId}>`;\r\n}\r\n\r\n/**\r\n * Formats text as bold\r\n * @param text The text to format\r\n */\r\nexport function bold(text: string): string {\r\n  return `**${text}**`;\r\n}\r\n\r\n/**\r\n * Formats text as italic\r\n * @param text The text to format\r\n */\r\nexport function italic(text: string): string {\r\n  return `*${text}*`;\r\n}\r\n\r\n/**\r\n * Formats text as underline\r\n * @param text The text to format\r\n */\r\nexport function underline(text: string): string {\r\n  return `__${text}__`;\r\n}\r\n\r\n/**\r\n * Formats text as strikethrough\r\n * @param text The text to format\r\n */\r\nexport function strikethrough(text: string): string {\r\n  return `~~${text}~~`;\r\n}\r\n\r\n/**\r\n * Formats text as spoiler\r\n * @param text The text to format\r\n */\r\nexport function spoiler(text: string): string {\r\n  return `||${text}||`;\r\n}\r\n\r\n/**\r\n * Formats text as inline code\r\n * @param text The text to format\r\n */\r\nexport function inlineCode(text: string): string {\r\n  return `\\`${text}\\``;\r\n}\r\n\r\n/**\r\n * Formats text as a code block\r\n * @param text The text to format\r\n * @param language The language for syntax highlighting\r\n */\r\nexport function codeBlock(text: string, language?: string): string {\r\n  return `\\`\\`\\`${language ?? ''}\\n${text}\\n\\`\\`\\``;\r\n}\r\n\r\n/**\r\n * Formats text as a block quote\r\n * @param text The text to format\r\n */\r\nexport function blockQuote(text: string): string {\r\n  return `>>> ${text}`;\r\n}\r\n\r\n/**\r\n * Formats text as a single-line quote\r\n * @param text The text to format\r\n */\r\nexport function quote(text: string): string {\r\n  return `> ${text}`;\r\n}\r\n\r\n/**\r\n * Formats a URL as a hyperlink\r\n * @param text The text to display\r\n * @param url The URL to link to\r\n * @param title Optional title for the link\r\n */\r\nexport function hyperlink(text: string, url: string, title?: string): string {\r\n  return title ? `[${text}](${url} \"${title}\")` : `[${text}](${url})`;\r\n}\r\n\r\n/**\r\n * Formats a URL to hide the embed\r\n * @param url The URL to format\r\n */\r\nexport function hideLinkEmbed(url: string): string {\r\n  return `<${url}>`;\r\n}\r\n\r\n/**\r\n * Time format styles\r\n */\r\nexport enum TimestampStyles {\r\n  /** Short time format (e.g., 16:20) */\r\n  ShortTime = 't',\r\n  /** Long time format (e.g., 16:20:30) */\r\n  LongTime = 'T',\r\n  /** Short date format (e.g., 20/04/2021) */\r\n  ShortDate = 'd',\r\n  /** Long date format (e.g., 20 April 2021) */\r\n  LongDate = 'D',\r\n  /** Short date/time format (e.g., 20 April 2021 16:20) */\r\n  ShortDateTime = 'f',\r\n  /** Long date/time format (e.g., Tuesday, 20 April 2021 16:20) */\r\n  LongDateTime = 'F',\r\n  /** Relative time format (e.g., 2 months ago) */\r\n  RelativeTime = 'R',\r\n}\r\n\r\n/**\r\n * Formats a timestamp\r\n * @param timestamp The timestamp (Date, number in ms, or seconds)\r\n * @param style The style to use\r\n */\r\nexport function time(timestamp: Date | number, style?: TimestampStyles): string {\r\n  const seconds = timestamp instanceof Date \r\n    ? Math.floor(timestamp.getTime() / 1000) \r\n    : typeof timestamp === 'number' && timestamp > 1e12 \r\n      ? Math.floor(timestamp / 1000) \r\n      : timestamp;\r\n  \r\n  return style ? `<t:${seconds}:${style}>` : `<t:${seconds}>`;\r\n}\r\n\r\n/**\r\n * Formats a heading (H1)\r\n * @param text The text to format\r\n */\r\nexport function heading(text: string, level: 1 | 2 | 3 = 1): string {\r\n  return `${'#'.repeat(level)} ${text}`;\r\n}\r\n\r\n/**\r\n * Formats an unordered list\r\n * @param items The items to list\r\n */\r\nexport function unorderedList(items: string[]): string {\r\n  return items.map(item => `- ${item}`).join('\\n');\r\n}\r\n\r\n/**\r\n * Formats an ordered list\r\n * @param items The items to list\r\n */\r\nexport function orderedList(items: string[]): string {\r\n  return items.map((item, i) => `${i + 1}. ${item}`).join('\\n');\r\n}\r\n\r\n// Export all formatters as a namespace too (DJS compatibility)\r\nexport const Formatters = {\r\n  userMention,\r\n  channelMention,\r\n  roleMention,\r\n  formatEmoji,\r\n  bold,\r\n  italic,\r\n  underline,\r\n  strikethrough,\r\n  spoiler,\r\n  inlineCode,\r\n  codeBlock,\r\n  blockQuote,\r\n  quote,\r\n  hyperlink,\r\n  hideLinkEmbed,\r\n  time,\r\n  heading,\r\n  unorderedList,\r\n  orderedList,\r\n  TimestampStyles,\r\n};\r\n"]}
213
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Formatters.js","sourceRoot":"","sources":["../../src/utils/Formatters.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Formatters for markdown and mentions\n */\n\n/**\n * Formats a user mention\n * @param userId The user ID to mention\n */\nexport function userMention(userId: string | number): string {\n  return `<@${userId}>`;\n}\n\n/**\n * Formats a channel mention\n * @param channelId The channel ID to mention\n */\nexport function channelMention(channelId: string | number): string {\n  return `<#${channelId}>`;\n}\n\n/**\n * Formats a role mention\n * @param roleId The role ID to mention\n */\nexport function roleMention(roleId: string | number): string {\n  return `<@&${roleId}>`;\n}\n\n/**\n * Formats a custom emoji\n * @param emojiId The emoji ID\n * @param name The emoji name\n * @param animated Whether the emoji is animated\n */\nexport function formatEmoji(emojiId: string | number, name: string, animated = false): string {\n  return `<${animated ? 'a' : ''}:${name}:${emojiId}>`;\n}\n\n/**\n * Formats text as bold\n * @param text The text to format\n */\nexport function bold(text: string): string {\n  return `**${text}**`;\n}\n\n/**\n * Formats text as italic\n * @param text The text to format\n */\nexport function italic(text: string): string {\n  return `*${text}*`;\n}\n\n/**\n * Formats text as underline\n * @param text The text to format\n */\nexport function underline(text: string): string {\n  return `__${text}__`;\n}\n\n/**\n * Formats text as strikethrough\n * @param text The text to format\n */\nexport function strikethrough(text: string): string {\n  return `~~${text}~~`;\n}\n\n/**\n * Formats text as spoiler\n * @param text The text to format\n */\nexport function spoiler(text: string): string {\n  return `||${text}||`;\n}\n\n/**\n * Formats text as inline code\n * @param text The text to format\n */\nexport function inlineCode(text: string): string {\n  return `\\`${text}\\``;\n}\n\n/**\n * Formats text as a code block\n * @param text The text to format\n * @param language The language for syntax highlighting\n */\nexport function codeBlock(text: string, language?: string): string {\n  return `\\`\\`\\`${language ?? ''}\\n${text}\\n\\`\\`\\``;\n}\n\n/**\n * Formats text as a block quote\n * @param text The text to format\n */\nexport function blockQuote(text: string): string {\n  return `>>> ${text}`;\n}\n\n/**\n * Formats text as a single-line quote\n * @param text The text to format\n */\nexport function quote(text: string): string {\n  return `> ${text}`;\n}\n\n/**\n * Formats a URL as a hyperlink\n * @param text The text to display\n * @param url The URL to link to\n * @param title Optional title for the link\n */\nexport function hyperlink(text: string, url: string, title?: string): string {\n  return title ? `[${text}](${url} \"${title}\")` : `[${text}](${url})`;\n}\n\n/**\n * Formats a URL to hide the embed\n * @param url The URL to format\n */\nexport function hideLinkEmbed(url: string): string {\n  return `<${url}>`;\n}\n\n/**\n * Time format styles\n */\nexport enum TimestampStyles {\n  /** Short time format (e.g., 16:20) */\n  ShortTime = 't',\n  /** Long time format (e.g., 16:20:30) */\n  LongTime = 'T',\n  /** Short date format (e.g., 20/04/2021) */\n  ShortDate = 'd',\n  /** Long date format (e.g., 20 April 2021) */\n  LongDate = 'D',\n  /** Short date/time format (e.g., 20 April 2021 16:20) */\n  ShortDateTime = 'f',\n  /** Long date/time format (e.g., Tuesday, 20 April 2021 16:20) */\n  LongDateTime = 'F',\n  /** Relative time format (e.g., 2 months ago) */\n  RelativeTime = 'R',\n}\n\n/**\n * Formats a timestamp\n * @param timestamp The timestamp (Date, number in ms, or seconds)\n * @param style The style to use\n */\nexport function time(timestamp: Date | number, style?: TimestampStyles): string {\n  const seconds = timestamp instanceof Date \n    ? Math.floor(timestamp.getTime() / 1000) \n    : typeof timestamp === 'number' && timestamp > 1e12 \n      ? Math.floor(timestamp / 1000) \n      : timestamp;\n  \n  return style ? `<t:${seconds}:${style}>` : `<t:${seconds}>`;\n}\n\n/**\n * Formats a heading (H1)\n * @param text The text to format\n */\nexport function heading(text: string, level: 1 | 2 | 3 = 1): string {\n  return `${'#'.repeat(level)} ${text}`;\n}\n\n/**\n * Formats an unordered list\n * @param items The items to list\n */\nexport function unorderedList(items: string[]): string {\n  return items.map(item => `- ${item}`).join('\\n');\n}\n\n/**\n * Formats an ordered list\n * @param items The items to list\n */\nexport function orderedList(items: string[]): string {\n  return items.map((item, i) => `${i + 1}. ${item}`).join('\\n');\n}\n\n// Export all formatters as a namespace too (DJS compatibility)\nexport const Formatters = {\n  userMention,\n  channelMention,\n  roleMention,\n  formatEmoji,\n  bold,\n  italic,\n  underline,\n  strikethrough,\n  spoiler,\n  inlineCode,\n  codeBlock,\n  blockQuote,\n  quote,\n  hyperlink,\n  hideLinkEmbed,\n  time,\n  heading,\n  unorderedList,\n  orderedList,\n  TimestampStyles,\n};\n"]}