@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.
package/LICENSE CHANGED
@@ -1,21 +1,21 @@
1
- MIT License
2
-
3
- Copyright (c) 2024 Jubbio Team
4
-
5
- Permission is hereby granted, free of charge, to any person obtaining a copy
6
- of this software and associated documentation files (the "Software"), to deal
7
- in the Software without restriction, including without limitation the rights
8
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
- copies of the Software, and to permit persons to whom the Software is
10
- furnished to do so, subject to the following conditions:
11
-
12
- The above copyright notice and this permission notice shall be included in all
13
- copies or substantial portions of the Software.
14
-
15
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
- SOFTWARE.
1
+ MIT License
2
+
3
+ Copyright (c) 2024 Jubbio Team
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/dist/Client.d.ts CHANGED
@@ -54,11 +54,21 @@ export declare class Client extends EventEmitter {
54
54
  /** Voice state update handlers (for voice adapters) */
55
55
  private voiceStateHandlers;
56
56
  private voiceServerHandlers;
57
+ /** Whether the client is currently in the login flow */
58
+ private _loginState;
59
+ /** Reconnect attempt counter */
60
+ private _reconnectAttempts;
61
+ /** Maximum reconnect attempts before giving up */
62
+ private readonly _maxReconnectAttempts;
57
63
  constructor(options: ClientOptions);
58
64
  /**
59
65
  * Calculate intents value
60
66
  */
61
67
  private getIntentsValue;
68
+ /**
69
+ * Gateway close code descriptions
70
+ */
71
+ private static readonly CLOSE_CODES;
62
72
  /**
63
73
  * Login to the gateway
64
74
  */
package/dist/Client.js CHANGED
@@ -49,6 +49,12 @@ class Client extends events_1.EventEmitter {
49
49
  /** Voice state update handlers (for voice adapters) */
50
50
  voiceStateHandlers = new Map();
51
51
  voiceServerHandlers = new Map();
52
+ /** Whether the client is currently in the login flow */
53
+ _loginState = 'idle';
54
+ /** Reconnect attempt counter */
55
+ _reconnectAttempts = 0;
56
+ /** Maximum reconnect attempts before giving up */
57
+ _maxReconnectAttempts = 5;
52
58
  constructor(options) {
53
59
  super();
54
60
  this.options = options;
@@ -68,26 +74,71 @@ class Client extends events_1.EventEmitter {
68
74
  }
69
75
  return this.options.intents.reduce((acc, intent) => acc | intent, 0);
70
76
  }
77
+ /**
78
+ * Gateway close code descriptions
79
+ */
80
+ static CLOSE_CODES = {
81
+ 4000: { message: 'Bilinmeyen hata (Unknown error)', reconnectable: true },
82
+ 4001: { message: 'Bilinmeyen opcode gönderildi (Unknown opcode)', reconnectable: true },
83
+ 4002: { message: 'Geçersiz payload gönderildi (Decode error)', reconnectable: true },
84
+ 4003: { message: 'Henüz kimlik doğrulaması yapılmadı (Not authenticated)', reconnectable: true },
85
+ 4004: { message: 'Geçersiz bot token\'ı (Authentication failed)', reconnectable: false },
86
+ 4005: { message: 'Zaten kimlik doğrulaması yapılmış (Already authenticated)', reconnectable: true },
87
+ 4007: { message: 'Geçersiz sequence numarası (Invalid seq)', reconnectable: true },
88
+ 4008: { message: 'Rate limit aşıldı (Rate limited)', reconnectable: true },
89
+ 4009: { message: 'Oturum zaman aşımına uğradı (Session timed out)', reconnectable: true },
90
+ 4010: { message: 'Geçersiz shard yapılandırması (Invalid shard)', reconnectable: false },
91
+ 4011: { message: 'Sharding gerekli (Sharding required)', reconnectable: false },
92
+ 4014: { message: 'İzin verilmeyen intent\'ler istendi (Disallowed intents)', reconnectable: false },
93
+ };
71
94
  /**
72
95
  * Login to the gateway
73
96
  */
74
97
  async login(token) {
98
+ if (!token || typeof token !== 'string') {
99
+ throw new Error('Geçerli bir bot token\'ı sağlanmalıdır. Örnek: client.login(process.env.BOT_TOKEN)');
100
+ }
75
101
  this.token = token.replace(/^Bot\s+/i, '');
76
102
  this.rest.setToken(this.token);
103
+ this._loginState = 'connecting';
104
+ this._reconnectAttempts = 0;
77
105
  return new Promise((resolve, reject) => {
78
- this.connect();
79
- // Wait for ready event
106
+ const cleanup = () => {
107
+ clearTimeout(timeout);
108
+ this.removeListener('ready', onReady);
109
+ this.removeListener('error', onError);
110
+ this.removeListener('gatewayClose', onGatewayClose);
111
+ };
80
112
  const timeout = setTimeout(() => {
81
- reject(new Error('Login timeout'));
113
+ cleanup();
114
+ this._loginState = 'idle';
115
+ reject(new Error('Gateway\'e bağlanılamadı: 30 saniye içinde READY event\'i alınamadı. ' +
116
+ 'Olası sebepler: gateway sunucusu erişilemez, token geçersiz veya ağ sorunu.'));
82
117
  }, 30000);
83
- this.once('ready', () => {
84
- clearTimeout(timeout);
118
+ const onReady = () => {
119
+ cleanup();
120
+ this._loginState = 'ready';
121
+ this._reconnectAttempts = 0;
85
122
  resolve(this.token);
86
- });
87
- this.once('error', (error) => {
88
- clearTimeout(timeout);
123
+ };
124
+ const onError = (error) => {
125
+ cleanup();
126
+ this._loginState = 'idle';
89
127
  reject(error);
90
- });
128
+ };
129
+ const onGatewayClose = (code, reason) => {
130
+ const info = Client.CLOSE_CODES[code];
131
+ if (info && !info.reconnectable) {
132
+ cleanup();
133
+ this._loginState = 'idle';
134
+ reject(new Error(`Gateway bağlantısı reddedildi [${code}]: ${info.message}${reason ? ' - ' + reason : ''}`));
135
+ }
136
+ // Reconnectable codes: login promise stays alive, connect() will retry
137
+ };
138
+ this.once('ready', onReady);
139
+ this.once('error', onError);
140
+ this.on('gatewayClose', onGatewayClose);
141
+ this.connect();
91
142
  });
92
143
  }
93
144
  /**
@@ -96,20 +147,46 @@ class Client extends events_1.EventEmitter {
96
147
  connect() {
97
148
  this.ws = new ws_1.default(this.gatewayUrl);
98
149
  this.ws.on('open', () => {
99
- this.emit('debug', 'WebSocket connection opened');
150
+ this.emit('debug', 'WebSocket bağlantısı açıldı');
151
+ this._reconnectAttempts = 0;
100
152
  });
101
153
  this.ws.on('message', (data) => {
102
154
  this.handleMessage(data.toString());
103
155
  });
104
156
  this.ws.on('close', (code, reason) => {
105
- this.emit('debug', `WebSocket closed: ${code} - ${reason}`);
157
+ const reasonStr = reason?.toString() || '';
158
+ const info = Client.CLOSE_CODES[code];
159
+ if (info) {
160
+ this.emit('debug', `Gateway bağlantısı kapandı [${code}]: ${info.message}${reasonStr ? ' - ' + reasonStr : ''}`);
161
+ }
162
+ else {
163
+ this.emit('debug', `WebSocket kapandı: ${code} - ${reasonStr}`);
164
+ }
106
165
  this.cleanup();
107
- // Reconnect on certain close codes
108
- if (code !== 1000 && code !== 4004) {
109
- setTimeout(() => this.connect(), 5000);
166
+ // Emit gatewayClose so login() can handle non-reconnectable codes
167
+ this.emit('gatewayClose', code, reasonStr);
168
+ // Non-reconnectable codes: don't retry
169
+ if (info && !info.reconnectable) {
170
+ this.emit('debug', `Kod ${code} yeniden bağlanılamaz, bağlantı sonlandırılıyor.`);
171
+ return;
172
+ }
173
+ // Normal close: don't retry
174
+ if (code === 1000) {
175
+ return;
176
+ }
177
+ // Reconnectable: retry with backoff
178
+ this._reconnectAttempts++;
179
+ if (this._reconnectAttempts > this._maxReconnectAttempts) {
180
+ this.emit('debug', `Maksimum yeniden bağlanma denemesi aşıldı (${this._maxReconnectAttempts})`);
181
+ this.emit('error', new Error(`Gateway bağlantısı ${this._maxReconnectAttempts} denemeden sonra kurulamadı. Son kapanma kodu: ${code}`));
182
+ return;
110
183
  }
184
+ const delay = Math.min(1000 * Math.pow(2, this._reconnectAttempts - 1), 30000);
185
+ this.emit('debug', `Yeniden bağlanılıyor (deneme ${this._reconnectAttempts}/${this._maxReconnectAttempts}), ${delay}ms sonra...`);
186
+ setTimeout(() => this.connect(), delay);
111
187
  });
112
188
  this.ws.on('error', (error) => {
189
+ this.emit('debug', `WebSocket hatası: ${error.message}`);
113
190
  this.emit('error', error);
114
191
  });
115
192
  }
@@ -147,7 +224,16 @@ class Client extends events_1.EventEmitter {
147
224
  this.emit('debug', 'Heartbeat acknowledged');
148
225
  break;
149
226
  case enums_1.GatewayOpcodes.InvalidSession:
150
- this.emit('debug', 'Invalid session, re-identifying...');
227
+ this.emit('debug', 'Geçersiz oturum, yeniden kimlik doğrulanıyor...');
228
+ // InvalidSession may carry error data from sendError()
229
+ if (payload.d && typeof payload.d === 'object' && payload.d.code && payload.d.message) {
230
+ this.emit('debug', `Sunucu hatası [${payload.d.code}]: ${payload.d.message}`);
231
+ const info = Client.CLOSE_CODES[payload.d.code];
232
+ if (info && !info.reconnectable) {
233
+ this.emit('error', new Error(`Gateway hatası [${payload.d.code}]: ${info.message}`));
234
+ return;
235
+ }
236
+ }
151
237
  setTimeout(() => this.identify(), 5000);
152
238
  break;
153
239
  case enums_1.GatewayOpcodes.Reconnect:
@@ -484,6 +570,8 @@ class Client extends events_1.EventEmitter {
484
570
  * Destroy the client
485
571
  */
486
572
  destroy() {
573
+ this._loginState = 'idle';
574
+ this._reconnectAttempts = this._maxReconnectAttempts + 1; // Prevent reconnect
487
575
  this.cleanup();
488
576
  this.ws?.close(1000);
489
577
  this.ws = null;
@@ -491,4 +579,4 @@ class Client extends events_1.EventEmitter {
491
579
  }
492
580
  }
493
581
  exports.Client = Client;
494
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Client.js","sourceRoot":"","sources":["../src/Client.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter } from 'events';\r\nimport WebSocket from 'ws';\r\nimport { \r\n  ClientOptions, \r\n  GatewayPayload, \r\n  ReadyEventData,\r\n  APIGuild,\r\n  APIInteraction,\r\n  APIMessage,\r\n  APIVoiceServerUpdate,\r\n  APIChannel,\r\n  APIUser\r\n} from './types';\r\nimport { GatewayOpcodes, GatewayIntentBits } from './enums';\r\nimport { Collection } from './structures/Collection';\r\nimport { User } from './structures/User';\r\nimport { Guild } from './structures/Guild';\r\nimport { Message } from './structures/Message';\r\nimport { createInteraction, Interaction } from './structures/Interaction';\r\nimport { BaseChannel, createChannel } from './structures/Channel';\r\nimport { REST } from './rest/REST';\r\n\r\n/**\r\n * Voice adapter creator type for @jubbio/voice compatibility\r\n */\r\ntype VoiceAdapterCreator = (methods: {\r\n  onVoiceServerUpdate(data: any): void;\r\n  onVoiceStateUpdate(data: any): void;\r\n  destroy(): void;\r\n}) => {\r\n  sendPayload(payload: any): boolean;\r\n  destroy(): void;\r\n};\r\n\r\n/**\r\n * Main client class\r\n */\r\nexport class Client extends EventEmitter {\r\n  /** Client options */\r\n  public readonly options: ClientOptions;\r\n  \r\n  /** REST API client */\r\n  public readonly rest: REST;\r\n  \r\n  /** The bot user */\r\n  public user: User | null = null;\r\n  \r\n  /** Application ID */\r\n  public applicationId: string | null = null;\r\n  \r\n  /** Cached guilds */\r\n  public guilds: Collection<string, Guild> = new Collection();\r\n  \r\n  /** Cached channels */\r\n  public channels: Collection<string, BaseChannel> = new Collection();\r\n  \r\n  /** Cached users */\r\n  public users: Collection<string, User> = new Collection();\r\n  \r\n  /** Voice adapter management */\r\n  public voice: {\r\n    adapters: Map<string, VoiceAdapterCreator>;\r\n  };\r\n  \r\n  /** WebSocket connection */\r\n  private ws: WebSocket | null = null;\r\n  \r\n  /** Bot token */\r\n  private token: string = '';\r\n  \r\n  /** Session ID */\r\n  private sessionId: string | null = null;\r\n  \r\n  /** Sequence number */\r\n  private sequence: number | null = null;\r\n  \r\n  /** Heartbeat interval */\r\n  private heartbeatInterval: NodeJS.Timeout | null = null;\r\n  \r\n  /** Gateway URL */\r\n  private gatewayUrl: string;\r\n  \r\n  /** Voice state update handlers (for voice adapters) */\r\n  private voiceStateHandlers: Map<string, (data: any) => void> = new Map();\r\n  private voiceServerHandlers: Map<string, (data: any) => void> = new Map();\r\n\r\n  constructor(options: ClientOptions) {\r\n    super();\r\n    this.options = options;\r\n    this.gatewayUrl = options.gatewayUrl || 'wss://realtime.jubbio.com/ws/bot';\r\n    this.rest = new REST(options.apiUrl);\r\n    \r\n    // Initialize voice adapter system\r\n    this.voice = {\r\n      adapters: new Map()\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Calculate intents value\r\n   */\r\n  private getIntentsValue(): number {\r\n    if (typeof this.options.intents === 'number') {\r\n      return this.options.intents;\r\n    }\r\n    return this.options.intents.reduce((acc, intent) => acc | intent, 0);\r\n  }\r\n\r\n  /**\r\n   * Login to the gateway\r\n   */\r\n  async login(token: string): Promise<string> {\r\n    this.token = token.replace(/^Bot\\s+/i, '');\r\n    this.rest.setToken(this.token);\r\n    \r\n    return new Promise((resolve, reject) => {\r\n      this.connect();\r\n      \r\n      // Wait for ready event\r\n      const timeout = setTimeout(() => {\r\n        reject(new Error('Login timeout'));\r\n      }, 30000);\r\n      \r\n      this.once('ready', () => {\r\n        clearTimeout(timeout);\r\n        resolve(this.token);\r\n      });\r\n      \r\n      this.once('error', (error) => {\r\n        clearTimeout(timeout);\r\n        reject(error);\r\n      });\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Connect to the gateway\r\n   */\r\n  private connect(): void {\r\n    this.ws = new WebSocket(this.gatewayUrl);\r\n    \r\n    this.ws.on('open', () => {\r\n      this.emit('debug', 'WebSocket connection opened');\r\n    });\r\n    \r\n    this.ws.on('message', (data) => {\r\n      this.handleMessage(data.toString());\r\n    });\r\n    \r\n    this.ws.on('close', (code, reason) => {\r\n      this.emit('debug', `WebSocket closed: ${code} - ${reason}`);\r\n      this.cleanup();\r\n      \r\n      // Reconnect on certain close codes\r\n      if (code !== 1000 && code !== 4004) {\r\n        setTimeout(() => this.connect(), 5000);\r\n      }\r\n    });\r\n    \r\n    this.ws.on('error', (error) => {\r\n      this.emit('error', error);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Handle incoming gateway message\r\n   */\r\n  private handleMessage(data: string): void {\r\n    // Handle multiple messages in one frame\r\n    const messages = data.split('\\n').filter(m => m.trim());\r\n    \r\n    for (const msg of messages) {\r\n      try {\r\n        const payload: GatewayPayload = JSON.parse(msg);\r\n        this.handlePayload(payload);\r\n      } catch (e) {\r\n        this.emit('debug', `Failed to parse message: ${msg}`);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle gateway payload\r\n   */\r\n  private handlePayload(payload: GatewayPayload): void {\r\n    if (payload.s) {\r\n      this.sequence = payload.s;\r\n    }\r\n\r\n    switch (payload.op) {\r\n      case GatewayOpcodes.Hello:\r\n        this.handleHello(payload.d);\r\n        break;\r\n        \r\n      case GatewayOpcodes.Dispatch:\r\n        this.handleDispatch(payload.t!, payload.d);\r\n        break;\r\n        \r\n      case GatewayOpcodes.HeartbeatAck:\r\n        this.emit('debug', 'Heartbeat acknowledged');\r\n        break;\r\n        \r\n      case GatewayOpcodes.InvalidSession:\r\n        this.emit('debug', 'Invalid session, re-identifying...');\r\n        setTimeout(() => this.identify(), 5000);\r\n        break;\r\n        \r\n      case GatewayOpcodes.Reconnect:\r\n        this.emit('debug', 'Reconnect requested');\r\n        this.ws?.close();\r\n        setTimeout(() => this.connect(), 1000);\r\n        break;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle Hello payload\r\n   */\r\n  private handleHello(data: { heartbeat_interval: number }): void {\r\n    this.emit('debug', `Received Hello, heartbeat interval: ${data.heartbeat_interval}ms`);\r\n    this.startHeartbeat(data.heartbeat_interval);\r\n    this.identify();\r\n  }\r\n\r\n  /**\r\n   * Handle Dispatch events\r\n   */\r\n  private handleDispatch(eventType: string, data: any): void {\r\n    this.emit('debug', `Dispatch: ${eventType}`);\r\n    \r\n    switch (eventType) {\r\n      case 'READY':\r\n        this.handleReady(data);\r\n        break;\r\n        \r\n      case 'GUILD_CREATE':\r\n        this.handleGuildCreate(data);\r\n        break;\r\n        \r\n      case 'GUILD_UPDATE':\r\n        this.handleGuildUpdate(data);\r\n        break;\r\n        \r\n      case 'GUILD_DELETE':\r\n        this.handleGuildDelete(data);\r\n        break;\r\n        \r\n      case 'MESSAGE_CREATE':\r\n        this.handleMessageCreate(data);\r\n        break;\r\n        \r\n      case 'MESSAGE_UPDATE':\r\n        this.emit('messageUpdate', data);\r\n        break;\r\n        \r\n      case 'MESSAGE_DELETE':\r\n        this.emit('messageDelete', data);\r\n        break;\r\n        \r\n      case 'MESSAGE_DELETE_BULK':\r\n        this.emit('messageDeleteBulk', data);\r\n        break;\r\n        \r\n      case 'CHANNEL_CREATE': {\r\n        // Update guild channel cache\r\n        const guildId = data.guild_id;\r\n        const channelId = data.id || data.channel_id;\r\n        if (guildId && channelId) {\r\n          const guild = this.guilds.get(guildId);\r\n          if (guild) {\r\n            guild.channels.set(channelId, data);\r\n          }\r\n        }\r\n        this.emit('channelCreate', data);\r\n        break;\r\n      }\r\n        \r\n      case 'CHANNEL_UPDATE': {\r\n        const guildId = data.guild_id;\r\n        const channelId = data.id || data.channel_id;\r\n        if (guildId && channelId) {\r\n          const guild = this.guilds.get(guildId);\r\n          if (guild) {\r\n            guild.channels.set(channelId, data);\r\n          }\r\n        }\r\n        this.emit('channelUpdate', data);\r\n        break;\r\n      }\r\n        \r\n      case 'CHANNEL_DELETE': {\r\n        const guildId = data.guild_id;\r\n        const channelId = data.id || data.channel_id;\r\n        if (guildId && channelId) {\r\n          const guild = this.guilds.get(guildId);\r\n          if (guild) {\r\n            guild.channels.delete(channelId);\r\n          }\r\n        }\r\n        this.emit('channelDelete', data);\r\n        break;\r\n      }\r\n        \r\n      case 'GUILD_MEMBER_ADD':\r\n        this.emit('guildMemberAdd', data);\r\n        break;\r\n        \r\n      case 'GUILD_MEMBER_UPDATE':\r\n        this.emit('guildMemberUpdate', data);\r\n        break;\r\n        \r\n      case 'GUILD_MEMBER_REMOVE':\r\n        this.emit('guildMemberRemove', data);\r\n        break;\r\n        \r\n      case 'GUILD_ROLE_CREATE':\r\n        this.emit('roleCreate', data);\r\n        break;\r\n        \r\n      case 'GUILD_ROLE_UPDATE':\r\n        this.emit('roleUpdate', data);\r\n        break;\r\n        \r\n      case 'GUILD_ROLE_DELETE':\r\n        this.emit('roleDelete', data);\r\n        break;\r\n        \r\n      case 'GUILD_BAN_ADD':\r\n        this.emit('guildBanAdd', data);\r\n        break;\r\n        \r\n      case 'GUILD_BAN_REMOVE':\r\n        this.emit('guildBanRemove', data);\r\n        break;\r\n        \r\n      case 'INVITE_CREATE':\r\n        this.emit('inviteCreate', data);\r\n        break;\r\n        \r\n      case 'INVITE_DELETE':\r\n        this.emit('inviteDelete', data);\r\n        break;\r\n        \r\n      case 'TYPING_START':\r\n        this.emit('typingStart', data);\r\n        break;\r\n        \r\n      case 'PRESENCE_UPDATE':\r\n        this.emit('presenceUpdate', data);\r\n        break;\r\n        \r\n      case 'INTERACTION_CREATE':\r\n        this.handleInteractionCreate(data);\r\n        break;\r\n        \r\n      case 'VOICE_STATE_UPDATE':\r\n        this.handleVoiceStateUpdate(data);\r\n        break;\r\n        \r\n      case 'VOICE_SERVER_UPDATE':\r\n        this.handleVoiceServerUpdate(data);\r\n        break;\r\n        \r\n      default:\r\n        // Emit raw event for unhandled types\r\n        this.emit('raw', { t: eventType, d: data });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle Ready event\r\n   */\r\n  private handleReady(data: ReadyEventData): void {\r\n    this.sessionId = data.session_id;\r\n    this.user = new User(data.user);\r\n    // Handle both string and number application IDs\r\n    this.applicationId = data.application?.id ? String(data.application.id) : null;\r\n    if (this.applicationId) {\r\n      this.rest.setApplicationId(this.applicationId);\r\n    }\r\n    \r\n    // Cache guilds (as unavailable initially)\r\n    if (data.guilds) {\r\n      for (const guild of data.guilds) {\r\n        this.guilds.set(String(guild.id), new Guild(this, guild));\r\n      }\r\n    }\r\n    \r\n    // Setup voice adapters for each guild\r\n    this.setupVoiceAdapters();\r\n    \r\n    console.log(`✅ Bot hazır! User: ${this.user.username} (${this.user.id}), App: ${this.applicationId}`);\r\n    this.emit('ready', this);\r\n  }\r\n\r\n  /**\r\n   * Setup voice adapters for all guilds\r\n   */\r\n  private setupVoiceAdapters(): void {\r\n    for (const [guildId] of this.guilds) {\r\n      this.createVoiceAdapter(guildId);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Create a voice adapter for a guild\r\n   */\r\n  private createVoiceAdapter(guildId: string): void {\r\n    const adapter: VoiceAdapterCreator = (methods) => {\r\n      // Store handlers for this guild\r\n      this.voiceStateHandlers.set(guildId, methods.onVoiceStateUpdate);\r\n      this.voiceServerHandlers.set(guildId, methods.onVoiceServerUpdate);\r\n      \r\n      return {\r\n        sendPayload: (payload) => {\r\n          if (this.ws?.readyState === WebSocket.OPEN) {\r\n            this.ws.send(JSON.stringify(payload));\r\n            return true;\r\n          }\r\n          return false;\r\n        },\r\n        destroy: () => {\r\n          this.voiceStateHandlers.delete(guildId);\r\n          this.voiceServerHandlers.delete(guildId);\r\n        }\r\n      };\r\n    };\r\n    \r\n    this.voice.adapters.set(guildId, adapter);\r\n  }\r\n\r\n  /**\r\n   * Handle Guild Create event\r\n   */\r\n  private handleGuildCreate(data: APIGuild): void {\r\n    let guild = this.guilds.get(data.id);\r\n    \r\n    if (guild) {\r\n      guild._patch(data);\r\n    } else {\r\n      guild = new Guild(this, data);\r\n      this.guilds.set(data.id, guild);\r\n      this.createVoiceAdapter(data.id);\r\n    }\r\n    \r\n    this.emit('guildCreate', guild);\r\n  }\r\n\r\n  /**\r\n   * Handle Guild Update event\r\n   */\r\n  private handleGuildUpdate(data: APIGuild): void {\r\n    const guild = this.guilds.get(data.id);\r\n    if (guild) {\r\n      guild._patch(data);\r\n      this.emit('guildUpdate', guild);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle Guild Delete event\r\n   */\r\n  private handleGuildDelete(data: { id: string }): void {\r\n    const guild = this.guilds.get(data.id);\r\n    if (guild) {\r\n      this.guilds.delete(data.id);\r\n      this.voice.adapters.delete(data.id);\r\n      this.emit('guildDelete', guild);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle Message Create event\r\n   */\r\n  private handleMessageCreate(data: APIMessage): void {\r\n    // Backend sends user_id separately, map it to author.id for compatibility\r\n    if (data.user_id && data.author && !data.author.id) {\r\n      (data.author as any).id = data.user_id;\r\n    }\r\n    \r\n    // Cache the author\r\n    if (data.author) {\r\n      const user = new User(data.author);\r\n      this.users.set(user.id, user);\r\n      // Also cache in REST for mention resolution\r\n      this.rest.cacheUser(data.author);\r\n    }\r\n    \r\n    const message = new Message(this, data);\r\n\r\n    // Mark message as from bot if author ID matches the bot's own user ID\r\n    if (this.user && String(message.author.id) === String(this.user.id)) {\r\n      (message.author as any).bot = true;\r\n    }\r\n\r\n    this.emit('messageCreate', message);\r\n  }\r\n\r\n  /**\r\n   * Handle Interaction Create event\r\n   */\r\n  private handleInteractionCreate(data: APIInteraction): void {\r\n    console.log('[DEBUG] handleInteractionCreate called with:', JSON.stringify(data, null, 2));\r\n    \r\n    // Cache the user\r\n    const userData = data.member?.user || data.user;\r\n    if (userData) {\r\n      const user = new User(userData);\r\n      this.users.set(user.id, user);\r\n      this.rest.cacheUser(userData);\r\n    }\r\n    \r\n    const interaction = createInteraction(this, data);\r\n    console.log('[DEBUG] Created interaction type:', interaction.constructor.name, 'customId:', (interaction as any).customId);\r\n    this.emit('interactionCreate', interaction);\r\n  }\r\n\r\n  /**\r\n   * Handle Voice State Update event\r\n   */\r\n  private handleVoiceStateUpdate(data: any): void {\r\n    const guildId = data.guild_id;\r\n    \r\n    // Forward to voice adapter if exists\r\n    const handler = this.voiceStateHandlers.get(guildId);\r\n    if (handler) {\r\n      handler(data);\r\n    }\r\n    \r\n    this.emit('voiceStateUpdate', data);\r\n  }\r\n\r\n  /**\r\n   * Handle Voice Server Update event\r\n   */\r\n  private handleVoiceServerUpdate(data: APIVoiceServerUpdate): void {\r\n    const guildId = data.guild_id;\r\n    \r\n    // Forward to voice adapter if exists\r\n    const handler = this.voiceServerHandlers.get(guildId);\r\n    if (handler) {\r\n      handler({\r\n        token: data.token,\r\n        endpoint: data.endpoint,\r\n        room: data.room\r\n      });\r\n    }\r\n    \r\n    this.emit('voiceServerUpdate', data);\r\n  }\r\n\r\n  /**\r\n   * Send Identify payload\r\n   */\r\n  private identify(): void {\r\n    const payload: GatewayPayload = {\r\n      op: GatewayOpcodes.Identify,\r\n      d: {\r\n        token: `Bot ${this.token}`,\r\n        intents: this.getIntentsValue(),\r\n        shard: this.options.shards || [0, 1]\r\n      }\r\n    };\r\n    \r\n    this.send(payload);\r\n  }\r\n\r\n  /**\r\n   * Start heartbeat\r\n   */\r\n  private startHeartbeat(interval: number): void {\r\n    this.heartbeatInterval = setInterval(() => {\r\n      this.send({\r\n        op: GatewayOpcodes.Heartbeat,\r\n        d: this.sequence\r\n      });\r\n    }, interval);\r\n  }\r\n\r\n  /**\r\n   * Send payload to gateway\r\n   */\r\n  private send(payload: GatewayPayload): void {\r\n    if (this.ws?.readyState === WebSocket.OPEN) {\r\n      this.ws.send(JSON.stringify(payload));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Cleanup on disconnect\r\n   */\r\n  private cleanup(): void {\r\n    if (this.heartbeatInterval) {\r\n      clearInterval(this.heartbeatInterval);\r\n      this.heartbeatInterval = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Destroy the client\r\n   */\r\n  destroy(): void {\r\n    this.cleanup();\r\n    this.ws?.close(1000);\r\n    this.ws = null;\r\n    this.removeAllListeners();\r\n  }\r\n}\r\n\r\n// Re-export for convenience\r\nexport { GatewayIntentBits };\r\n"]}
582
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Client.js","sourceRoot":"","sources":["../src/Client.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter } from 'events';\r\nimport WebSocket from 'ws';\r\nimport { \r\n  ClientOptions, \r\n  GatewayPayload, \r\n  ReadyEventData,\r\n  APIGuild,\r\n  APIInteraction,\r\n  APIMessage,\r\n  APIVoiceServerUpdate,\r\n  APIChannel,\r\n  APIUser\r\n} from './types';\r\nimport { GatewayOpcodes, GatewayIntentBits } from './enums';\r\nimport { Collection } from './structures/Collection';\r\nimport { User } from './structures/User';\r\nimport { Guild } from './structures/Guild';\r\nimport { Message } from './structures/Message';\r\nimport { createInteraction, Interaction } from './structures/Interaction';\r\nimport { BaseChannel, createChannel } from './structures/Channel';\r\nimport { REST } from './rest/REST';\r\n\r\n/**\r\n * Voice adapter creator type for @jubbio/voice compatibility\r\n */\r\ntype VoiceAdapterCreator = (methods: {\r\n  onVoiceServerUpdate(data: any): void;\r\n  onVoiceStateUpdate(data: any): void;\r\n  destroy(): void;\r\n}) => {\r\n  sendPayload(payload: any): boolean;\r\n  destroy(): void;\r\n};\r\n\r\n/**\r\n * Main client class\r\n */\r\nexport class Client extends EventEmitter {\r\n  /** Client options */\r\n  public readonly options: ClientOptions;\r\n  \r\n  /** REST API client */\r\n  public readonly rest: REST;\r\n  \r\n  /** The bot user */\r\n  public user: User | null = null;\r\n  \r\n  /** Application ID */\r\n  public applicationId: string | null = null;\r\n  \r\n  /** Cached guilds */\r\n  public guilds: Collection<string, Guild> = new Collection();\r\n  \r\n  /** Cached channels */\r\n  public channels: Collection<string, BaseChannel> = new Collection();\r\n  \r\n  /** Cached users */\r\n  public users: Collection<string, User> = new Collection();\r\n  \r\n  /** Voice adapter management */\r\n  public voice: {\r\n    adapters: Map<string, VoiceAdapterCreator>;\r\n  };\r\n  \r\n  /** WebSocket connection */\r\n  private ws: WebSocket | null = null;\r\n  \r\n  /** Bot token */\r\n  private token: string = '';\r\n  \r\n  /** Session ID */\r\n  private sessionId: string | null = null;\r\n  \r\n  /** Sequence number */\r\n  private sequence: number | null = null;\r\n  \r\n  /** Heartbeat interval */\r\n  private heartbeatInterval: NodeJS.Timeout | null = null;\r\n  \r\n  /** Gateway URL */\r\n  private gatewayUrl: string;\r\n  \r\n  /** Voice state update handlers (for voice adapters) */\r\n  private voiceStateHandlers: Map<string, (data: any) => void> = new Map();\r\n  private voiceServerHandlers: Map<string, (data: any) => void> = new Map();\r\n\r\n  /** Whether the client is currently in the login flow */\r\n  private _loginState: 'idle' | 'connecting' | 'ready' = 'idle';\r\n\r\n  /** Reconnect attempt counter */\r\n  private _reconnectAttempts: number = 0;\r\n\r\n  /** Maximum reconnect attempts before giving up */\r\n  private readonly _maxReconnectAttempts: number = 5;\r\n\r\n  constructor(options: ClientOptions) {\r\n    super();\r\n    this.options = options;\r\n    this.gatewayUrl = options.gatewayUrl || 'wss://realtime.jubbio.com/ws/bot';\r\n    this.rest = new REST(options.apiUrl);\r\n    \r\n    // Initialize voice adapter system\r\n    this.voice = {\r\n      adapters: new Map()\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Calculate intents value\r\n   */\r\n  private getIntentsValue(): number {\r\n    if (typeof this.options.intents === 'number') {\r\n      return this.options.intents;\r\n    }\r\n    return this.options.intents.reduce((acc, intent) => acc | intent, 0);\r\n  }\r\n\r\n  /**\r\n   * Gateway close code descriptions\r\n   */\r\n  private static readonly CLOSE_CODES: Record<number, { message: string; reconnectable: boolean }> = {\r\n    4000: { message: 'Bilinmeyen hata (Unknown error)', reconnectable: true },\r\n    4001: { message: 'Bilinmeyen opcode gönderildi (Unknown opcode)', reconnectable: true },\r\n    4002: { message: 'Geçersiz payload gönderildi (Decode error)', reconnectable: true },\r\n    4003: { message: 'Henüz kimlik doğrulaması yapılmadı (Not authenticated)', reconnectable: true },\r\n    4004: { message: 'Geçersiz bot token\\'ı (Authentication failed)', reconnectable: false },\r\n    4005: { message: 'Zaten kimlik doğrulaması yapılmış (Already authenticated)', reconnectable: true },\r\n    4007: { message: 'Geçersiz sequence numarası (Invalid seq)', reconnectable: true },\r\n    4008: { message: 'Rate limit aşıldı (Rate limited)', reconnectable: true },\r\n    4009: { message: 'Oturum zaman aşımına uğradı (Session timed out)', reconnectable: true },\r\n    4010: { message: 'Geçersiz shard yapılandırması (Invalid shard)', reconnectable: false },\r\n    4011: { message: 'Sharding gerekli (Sharding required)', reconnectable: false },\r\n    4014: { message: 'İzin verilmeyen intent\\'ler istendi (Disallowed intents)', reconnectable: false },\r\n  };\r\n\r\n  /**\r\n   * Login to the gateway\r\n   */\r\n  async login(token: string): Promise<string> {\r\n    if (!token || typeof token !== 'string') {\r\n      throw new Error(\r\n        'Geçerli bir bot token\\'ı sağlanmalıdır. Örnek: client.login(process.env.BOT_TOKEN)'\r\n      );\r\n    }\r\n\r\n    this.token = token.replace(/^Bot\\s+/i, '');\r\n    this.rest.setToken(this.token);\r\n    this._loginState = 'connecting';\r\n    this._reconnectAttempts = 0;\r\n\r\n    return new Promise((resolve, reject) => {\r\n      const cleanup = () => {\r\n        clearTimeout(timeout);\r\n        this.removeListener('ready', onReady);\r\n        this.removeListener('error', onError);\r\n        this.removeListener('gatewayClose', onGatewayClose);\r\n      };\r\n\r\n      const timeout = setTimeout(() => {\r\n        cleanup();\r\n        this._loginState = 'idle';\r\n        reject(new Error(\r\n          'Gateway\\'e bağlanılamadı: 30 saniye içinde READY event\\'i alınamadı. ' +\r\n          'Olası sebepler: gateway sunucusu erişilemez, token geçersiz veya ağ sorunu.'\r\n        ));\r\n      }, 30000);\r\n\r\n      const onReady = () => {\r\n        cleanup();\r\n        this._loginState = 'ready';\r\n        this._reconnectAttempts = 0;\r\n        resolve(this.token);\r\n      };\r\n\r\n      const onError = (error: Error) => {\r\n        cleanup();\r\n        this._loginState = 'idle';\r\n        reject(error);\r\n      };\r\n\r\n      const onGatewayClose = (code: number, reason: string) => {\r\n        const info = Client.CLOSE_CODES[code];\r\n        if (info && !info.reconnectable) {\r\n          cleanup();\r\n          this._loginState = 'idle';\r\n          reject(new Error(`Gateway bağlantısı reddedildi [${code}]: ${info.message}${reason ? ' - ' + reason : ''}`));\r\n        }\r\n        // Reconnectable codes: login promise stays alive, connect() will retry\r\n      };\r\n\r\n      this.once('ready', onReady);\r\n      this.once('error', onError);\r\n      this.on('gatewayClose', onGatewayClose);\r\n\r\n      this.connect();\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Connect to the gateway\r\n   */\r\n  private connect(): void {\r\n    this.ws = new WebSocket(this.gatewayUrl);\r\n    \r\n    this.ws.on('open', () => {\r\n      this.emit('debug', 'WebSocket bağlantısı açıldı');\r\n      this._reconnectAttempts = 0;\r\n    });\r\n    \r\n    this.ws.on('message', (data) => {\r\n      this.handleMessage(data.toString());\r\n    });\r\n    \r\n    this.ws.on('close', (code, reason) => {\r\n      const reasonStr = reason?.toString() || '';\r\n      const info = Client.CLOSE_CODES[code];\r\n      \r\n      if (info) {\r\n        this.emit('debug', `Gateway bağlantısı kapandı [${code}]: ${info.message}${reasonStr ? ' - ' + reasonStr : ''}`);\r\n      } else {\r\n        this.emit('debug', `WebSocket kapandı: ${code} - ${reasonStr}`);\r\n      }\r\n      \r\n      this.cleanup();\r\n\r\n      // Emit gatewayClose so login() can handle non-reconnectable codes\r\n      this.emit('gatewayClose', code, reasonStr);\r\n\r\n      // Non-reconnectable codes: don't retry\r\n      if (info && !info.reconnectable) {\r\n        this.emit('debug', `Kod ${code} yeniden bağlanılamaz, bağlantı sonlandırılıyor.`);\r\n        return;\r\n      }\r\n\r\n      // Normal close: don't retry\r\n      if (code === 1000) {\r\n        return;\r\n      }\r\n\r\n      // Reconnectable: retry with backoff\r\n      this._reconnectAttempts++;\r\n      if (this._reconnectAttempts > this._maxReconnectAttempts) {\r\n        this.emit('debug', `Maksimum yeniden bağlanma denemesi aşıldı (${this._maxReconnectAttempts})`);\r\n        this.emit('error', new Error(\r\n          `Gateway bağlantısı ${this._maxReconnectAttempts} denemeden sonra kurulamadı. Son kapanma kodu: ${code}`\r\n        ));\r\n        return;\r\n      }\r\n\r\n      const delay = Math.min(1000 * Math.pow(2, this._reconnectAttempts - 1), 30000);\r\n      this.emit('debug', `Yeniden bağlanılıyor (deneme ${this._reconnectAttempts}/${this._maxReconnectAttempts}), ${delay}ms sonra...`);\r\n      setTimeout(() => this.connect(), delay);\r\n    });\r\n    \r\n    this.ws.on('error', (error) => {\r\n      this.emit('debug', `WebSocket hatası: ${error.message}`);\r\n      this.emit('error', error);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Handle incoming gateway message\r\n   */\r\n  private handleMessage(data: string): void {\r\n    // Handle multiple messages in one frame\r\n    const messages = data.split('\\n').filter(m => m.trim());\r\n    \r\n    for (const msg of messages) {\r\n      try {\r\n        const payload: GatewayPayload = JSON.parse(msg);\r\n        this.handlePayload(payload);\r\n      } catch (e) {\r\n        this.emit('debug', `Failed to parse message: ${msg}`);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle gateway payload\r\n   */\r\n  private handlePayload(payload: GatewayPayload): void {\r\n    if (payload.s) {\r\n      this.sequence = payload.s;\r\n    }\r\n\r\n    switch (payload.op) {\r\n      case GatewayOpcodes.Hello:\r\n        this.handleHello(payload.d);\r\n        break;\r\n        \r\n      case GatewayOpcodes.Dispatch:\r\n        this.handleDispatch(payload.t!, payload.d);\r\n        break;\r\n        \r\n      case GatewayOpcodes.HeartbeatAck:\r\n        this.emit('debug', 'Heartbeat acknowledged');\r\n        break;\r\n        \r\n      case GatewayOpcodes.InvalidSession:\r\n        this.emit('debug', 'Geçersiz oturum, yeniden kimlik doğrulanıyor...');\r\n        // InvalidSession may carry error data from sendError()\r\n        if (payload.d && typeof payload.d === 'object' && payload.d.code && payload.d.message) {\r\n          this.emit('debug', `Sunucu hatası [${payload.d.code}]: ${payload.d.message}`);\r\n          const info = Client.CLOSE_CODES[payload.d.code];\r\n          if (info && !info.reconnectable) {\r\n            this.emit('error', new Error(`Gateway hatası [${payload.d.code}]: ${info.message}`));\r\n            return;\r\n          }\r\n        }\r\n        setTimeout(() => this.identify(), 5000);\r\n        break;\r\n        \r\n      case GatewayOpcodes.Reconnect:\r\n        this.emit('debug', 'Reconnect requested');\r\n        this.ws?.close();\r\n        setTimeout(() => this.connect(), 1000);\r\n        break;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle Hello payload\r\n   */\r\n  private handleHello(data: { heartbeat_interval: number }): void {\r\n    this.emit('debug', `Received Hello, heartbeat interval: ${data.heartbeat_interval}ms`);\r\n    this.startHeartbeat(data.heartbeat_interval);\r\n    this.identify();\r\n  }\r\n\r\n  /**\r\n   * Handle Dispatch events\r\n   */\r\n  private handleDispatch(eventType: string, data: any): void {\r\n    this.emit('debug', `Dispatch: ${eventType}`);\r\n    \r\n    switch (eventType) {\r\n      case 'READY':\r\n        this.handleReady(data);\r\n        break;\r\n        \r\n      case 'GUILD_CREATE':\r\n        this.handleGuildCreate(data);\r\n        break;\r\n        \r\n      case 'GUILD_UPDATE':\r\n        this.handleGuildUpdate(data);\r\n        break;\r\n        \r\n      case 'GUILD_DELETE':\r\n        this.handleGuildDelete(data);\r\n        break;\r\n        \r\n      case 'MESSAGE_CREATE':\r\n        this.handleMessageCreate(data);\r\n        break;\r\n        \r\n      case 'MESSAGE_UPDATE':\r\n        this.emit('messageUpdate', data);\r\n        break;\r\n        \r\n      case 'MESSAGE_DELETE':\r\n        this.emit('messageDelete', data);\r\n        break;\r\n        \r\n      case 'MESSAGE_DELETE_BULK':\r\n        this.emit('messageDeleteBulk', data);\r\n        break;\r\n        \r\n      case 'CHANNEL_CREATE': {\r\n        // Update guild channel cache\r\n        const guildId = data.guild_id;\r\n        const channelId = data.id || data.channel_id;\r\n        if (guildId && channelId) {\r\n          const guild = this.guilds.get(guildId);\r\n          if (guild) {\r\n            guild.channels.set(channelId, data);\r\n          }\r\n        }\r\n        this.emit('channelCreate', data);\r\n        break;\r\n      }\r\n        \r\n      case 'CHANNEL_UPDATE': {\r\n        const guildId = data.guild_id;\r\n        const channelId = data.id || data.channel_id;\r\n        if (guildId && channelId) {\r\n          const guild = this.guilds.get(guildId);\r\n          if (guild) {\r\n            guild.channels.set(channelId, data);\r\n          }\r\n        }\r\n        this.emit('channelUpdate', data);\r\n        break;\r\n      }\r\n        \r\n      case 'CHANNEL_DELETE': {\r\n        const guildId = data.guild_id;\r\n        const channelId = data.id || data.channel_id;\r\n        if (guildId && channelId) {\r\n          const guild = this.guilds.get(guildId);\r\n          if (guild) {\r\n            guild.channels.delete(channelId);\r\n          }\r\n        }\r\n        this.emit('channelDelete', data);\r\n        break;\r\n      }\r\n        \r\n      case 'GUILD_MEMBER_ADD':\r\n        this.emit('guildMemberAdd', data);\r\n        break;\r\n        \r\n      case 'GUILD_MEMBER_UPDATE':\r\n        this.emit('guildMemberUpdate', data);\r\n        break;\r\n        \r\n      case 'GUILD_MEMBER_REMOVE':\r\n        this.emit('guildMemberRemove', data);\r\n        break;\r\n        \r\n      case 'GUILD_ROLE_CREATE':\r\n        this.emit('roleCreate', data);\r\n        break;\r\n        \r\n      case 'GUILD_ROLE_UPDATE':\r\n        this.emit('roleUpdate', data);\r\n        break;\r\n        \r\n      case 'GUILD_ROLE_DELETE':\r\n        this.emit('roleDelete', data);\r\n        break;\r\n        \r\n      case 'GUILD_BAN_ADD':\r\n        this.emit('guildBanAdd', data);\r\n        break;\r\n        \r\n      case 'GUILD_BAN_REMOVE':\r\n        this.emit('guildBanRemove', data);\r\n        break;\r\n        \r\n      case 'INVITE_CREATE':\r\n        this.emit('inviteCreate', data);\r\n        break;\r\n        \r\n      case 'INVITE_DELETE':\r\n        this.emit('inviteDelete', data);\r\n        break;\r\n        \r\n      case 'TYPING_START':\r\n        this.emit('typingStart', data);\r\n        break;\r\n        \r\n      case 'PRESENCE_UPDATE':\r\n        this.emit('presenceUpdate', data);\r\n        break;\r\n        \r\n      case 'INTERACTION_CREATE':\r\n        this.handleInteractionCreate(data);\r\n        break;\r\n        \r\n      case 'VOICE_STATE_UPDATE':\r\n        this.handleVoiceStateUpdate(data);\r\n        break;\r\n        \r\n      case 'VOICE_SERVER_UPDATE':\r\n        this.handleVoiceServerUpdate(data);\r\n        break;\r\n        \r\n      default:\r\n        // Emit raw event for unhandled types\r\n        this.emit('raw', { t: eventType, d: data });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle Ready event\r\n   */\r\n  private handleReady(data: ReadyEventData): void {\r\n    this.sessionId = data.session_id;\r\n    this.user = new User(data.user);\r\n    // Handle both string and number application IDs\r\n    this.applicationId = data.application?.id ? String(data.application.id) : null;\r\n    if (this.applicationId) {\r\n      this.rest.setApplicationId(this.applicationId);\r\n    }\r\n    \r\n    // Cache guilds (as unavailable initially)\r\n    if (data.guilds) {\r\n      for (const guild of data.guilds) {\r\n        this.guilds.set(String(guild.id), new Guild(this, guild));\r\n      }\r\n    }\r\n    \r\n    // Setup voice adapters for each guild\r\n    this.setupVoiceAdapters();\r\n    \r\n    console.log(`✅ Bot hazır! User: ${this.user.username} (${this.user.id}), App: ${this.applicationId}`);\r\n    this.emit('ready', this);\r\n  }\r\n\r\n  /**\r\n   * Setup voice adapters for all guilds\r\n   */\r\n  private setupVoiceAdapters(): void {\r\n    for (const [guildId] of this.guilds) {\r\n      this.createVoiceAdapter(guildId);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Create a voice adapter for a guild\r\n   */\r\n  private createVoiceAdapter(guildId: string): void {\r\n    const adapter: VoiceAdapterCreator = (methods) => {\r\n      // Store handlers for this guild\r\n      this.voiceStateHandlers.set(guildId, methods.onVoiceStateUpdate);\r\n      this.voiceServerHandlers.set(guildId, methods.onVoiceServerUpdate);\r\n      \r\n      return {\r\n        sendPayload: (payload) => {\r\n          if (this.ws?.readyState === WebSocket.OPEN) {\r\n            this.ws.send(JSON.stringify(payload));\r\n            return true;\r\n          }\r\n          return false;\r\n        },\r\n        destroy: () => {\r\n          this.voiceStateHandlers.delete(guildId);\r\n          this.voiceServerHandlers.delete(guildId);\r\n        }\r\n      };\r\n    };\r\n    \r\n    this.voice.adapters.set(guildId, adapter);\r\n  }\r\n\r\n  /**\r\n   * Handle Guild Create event\r\n   */\r\n  private handleGuildCreate(data: APIGuild): void {\r\n    let guild = this.guilds.get(data.id);\r\n    \r\n    if (guild) {\r\n      guild._patch(data);\r\n    } else {\r\n      guild = new Guild(this, data);\r\n      this.guilds.set(data.id, guild);\r\n      this.createVoiceAdapter(data.id);\r\n    }\r\n    \r\n    this.emit('guildCreate', guild);\r\n  }\r\n\r\n  /**\r\n   * Handle Guild Update event\r\n   */\r\n  private handleGuildUpdate(data: APIGuild): void {\r\n    const guild = this.guilds.get(data.id);\r\n    if (guild) {\r\n      guild._patch(data);\r\n      this.emit('guildUpdate', guild);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle Guild Delete event\r\n   */\r\n  private handleGuildDelete(data: { id: string }): void {\r\n    const guild = this.guilds.get(data.id);\r\n    if (guild) {\r\n      this.guilds.delete(data.id);\r\n      this.voice.adapters.delete(data.id);\r\n      this.emit('guildDelete', guild);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle Message Create event\r\n   */\r\n  private handleMessageCreate(data: APIMessage): void {\r\n    // Backend sends user_id separately, map it to author.id for compatibility\r\n    if (data.user_id && data.author && !data.author.id) {\r\n      (data.author as any).id = data.user_id;\r\n    }\r\n    \r\n    // Cache the author\r\n    if (data.author) {\r\n      const user = new User(data.author);\r\n      this.users.set(user.id, user);\r\n      // Also cache in REST for mention resolution\r\n      this.rest.cacheUser(data.author);\r\n    }\r\n    \r\n    const message = new Message(this, data);\r\n\r\n    // Mark message as from bot if author ID matches the bot's own user ID\r\n    if (this.user && String(message.author.id) === String(this.user.id)) {\r\n      (message.author as any).bot = true;\r\n    }\r\n\r\n    this.emit('messageCreate', message);\r\n  }\r\n\r\n  /**\r\n   * Handle Interaction Create event\r\n   */\r\n  private handleInteractionCreate(data: APIInteraction): void {\r\n    console.log('[DEBUG] handleInteractionCreate called with:', JSON.stringify(data, null, 2));\r\n    \r\n    // Cache the user\r\n    const userData = data.member?.user || data.user;\r\n    if (userData) {\r\n      const user = new User(userData);\r\n      this.users.set(user.id, user);\r\n      this.rest.cacheUser(userData);\r\n    }\r\n    \r\n    const interaction = createInteraction(this, data);\r\n    console.log('[DEBUG] Created interaction type:', interaction.constructor.name, 'customId:', (interaction as any).customId);\r\n    this.emit('interactionCreate', interaction);\r\n  }\r\n\r\n  /**\r\n   * Handle Voice State Update event\r\n   */\r\n  private handleVoiceStateUpdate(data: any): void {\r\n    const guildId = data.guild_id;\r\n    \r\n    // Forward to voice adapter if exists\r\n    const handler = this.voiceStateHandlers.get(guildId);\r\n    if (handler) {\r\n      handler(data);\r\n    }\r\n    \r\n    this.emit('voiceStateUpdate', data);\r\n  }\r\n\r\n  /**\r\n   * Handle Voice Server Update event\r\n   */\r\n  private handleVoiceServerUpdate(data: APIVoiceServerUpdate): void {\r\n    const guildId = data.guild_id;\r\n    \r\n    // Forward to voice adapter if exists\r\n    const handler = this.voiceServerHandlers.get(guildId);\r\n    if (handler) {\r\n      handler({\r\n        token: data.token,\r\n        endpoint: data.endpoint,\r\n        room: data.room\r\n      });\r\n    }\r\n    \r\n    this.emit('voiceServerUpdate', data);\r\n  }\r\n\r\n  /**\r\n   * Send Identify payload\r\n   */\r\n  private identify(): void {\r\n    const payload: GatewayPayload = {\r\n      op: GatewayOpcodes.Identify,\r\n      d: {\r\n        token: `Bot ${this.token}`,\r\n        intents: this.getIntentsValue(),\r\n        shard: this.options.shards || [0, 1]\r\n      }\r\n    };\r\n    \r\n    this.send(payload);\r\n  }\r\n\r\n  /**\r\n   * Start heartbeat\r\n   */\r\n  private startHeartbeat(interval: number): void {\r\n    this.heartbeatInterval = setInterval(() => {\r\n      this.send({\r\n        op: GatewayOpcodes.Heartbeat,\r\n        d: this.sequence\r\n      });\r\n    }, interval);\r\n  }\r\n\r\n  /**\r\n   * Send payload to gateway\r\n   */\r\n  private send(payload: GatewayPayload): void {\r\n    if (this.ws?.readyState === WebSocket.OPEN) {\r\n      this.ws.send(JSON.stringify(payload));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Cleanup on disconnect\r\n   */\r\n  private cleanup(): void {\r\n    if (this.heartbeatInterval) {\r\n      clearInterval(this.heartbeatInterval);\r\n      this.heartbeatInterval = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Destroy the client\r\n   */\r\n  destroy(): void {\r\n    this._loginState = 'idle';\r\n    this._reconnectAttempts = this._maxReconnectAttempts + 1; // Prevent reconnect\r\n    this.cleanup();\r\n    this.ws?.close(1000);\r\n    this.ws = null;\r\n    this.removeAllListeners();\r\n  }\r\n}\r\n\r\n// Re-export for convenience\r\nexport { GatewayIntentBits };\r\n"]}
@@ -65,4 +65,4 @@ class ActionRowBuilder {
65
65
  }
66
66
  exports.ActionRowBuilder = ActionRowBuilder;
67
67
  exports.default = ActionRowBuilder;
68
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQWN0aW9uUm93QnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9idWlsZGVycy9BY3Rpb25Sb3dCdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7R0FFRzs7O0FBWUg7O0dBRUc7QUFDSCxNQUFhLGdCQUFnQjtJQUNYLElBQUksQ0FBK0I7SUFFbkQsWUFBWSxPQUE4QixFQUFFO1FBQzFDLElBQUksQ0FBQyxJQUFJLEdBQUc7WUFDVixJQUFJLEVBQUUsQ0FBQztZQUNQLFVBQVUsRUFBRyxJQUFJLENBQUMsVUFBa0IsSUFBSSxFQUFFO1NBQzNDLENBQUM7SUFDSixDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsYUFBYSxDQUFDLEdBQUcsVUFBbUM7UUFDbEQsS0FBSyxNQUFNLFNBQVMsSUFBSSxVQUFVLEVBQUUsQ0FBQztZQUNuQyxJQUFJLFFBQVEsSUFBSSxTQUFTLElBQUksT0FBTyxTQUFTLENBQUMsTUFBTSxLQUFLLFVBQVUsRUFBRSxDQUFDO2dCQUNwRSxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7WUFDaEQsQ0FBQztpQkFBTSxDQUFDO2dCQUNOLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxTQUFjLENBQUMsQ0FBQztZQUM1QyxDQUFDO1FBQ0gsQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOzs7T0FHRztJQUNILGFBQWEsQ0FBQyxHQUFHLFVBQW1DO1FBQ2xELElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxHQUFHLEVBQUUsQ0FBQztRQUMxQixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxVQUFVLENBQUMsQ0FBQztJQUMzQyxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxnQkFBZ0IsQ0FBQyxLQUFhLEVBQUUsV0FBbUIsRUFBRSxHQUFHLFVBQW1DO1FBQ3pGLE1BQU0sUUFBUSxHQUFHLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FDbEMsUUFBUSxJQUFJLENBQUMsSUFBSSxPQUFPLENBQUMsQ0FBQyxNQUFNLEtBQUssVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQU0sQ0FDdEUsQ0FBQztRQUNGLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsV0FBVyxFQUFFLEdBQUcsUUFBUSxDQUFDLENBQUM7UUFDN0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxNQUFNO1FBQ0osT0FBTyxFQUFFLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBa0IsQ0FBQztJQUMxQyxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsTUFBTSxDQUFDLElBQUksQ0FBa0MsS0FBa0Q7UUFDN0YsT0FBTyxJQUFJLGdCQUFnQixDQUFJLEtBQUssWUFBWSxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDekYsQ0FBQztDQUNGO0FBOURELDRDQThEQztBQUVELGtCQUFlLGdCQUFnQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIEFjdGlvblJvd0J1aWxkZXIgZm9yIGNyZWF0aW5nIGNvbXBvbmVudCByb3dzXHJcbiAqL1xyXG5cclxuaW1wb3J0IHsgQVBJQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi9CdXR0b25CdWlsZGVyJztcclxuaW1wb3J0IHsgQVBJU2VsZWN0TWVudUNvbXBvbmVudCB9IGZyb20gJy4vU2VsZWN0TWVudUJ1aWxkZXInO1xyXG5cclxuZXhwb3J0IHR5cGUgQVBJQWN0aW9uUm93Q29tcG9uZW50ID0gQVBJQnV0dG9uQ29tcG9uZW50IHwgQVBJU2VsZWN0TWVudUNvbXBvbmVudDtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQVBJQWN0aW9uUm93IHtcclxuICB0eXBlOiAxO1xyXG4gIGNvbXBvbmVudHM6IEFQSUFjdGlvblJvd0NvbXBvbmVudFtdO1xyXG59XHJcblxyXG4vKipcclxuICogQSBidWlsZGVyIGZvciBjcmVhdGluZyBhY3Rpb24gcm93c1xyXG4gKi9cclxuZXhwb3J0IGNsYXNzIEFjdGlvblJvd0J1aWxkZXI8VCBleHRlbmRzIEFQSUFjdGlvblJvd0NvbXBvbmVudCA9IEFQSUFjdGlvblJvd0NvbXBvbmVudD4ge1xyXG4gIHB1YmxpYyByZWFkb25seSBkYXRhOiB7IHR5cGU6IDE7IGNvbXBvbmVudHM6IFRbXSB9O1xyXG5cclxuICBjb25zdHJ1Y3RvcihkYXRhOiBQYXJ0aWFsPEFQSUFjdGlvblJvdz4gPSB7fSkge1xyXG4gICAgdGhpcy5kYXRhID0geyBcclxuICAgICAgdHlwZTogMSwgXHJcbiAgICAgIGNvbXBvbmVudHM6IChkYXRhLmNvbXBvbmVudHMgYXMgVFtdKSB8fCBbXSBcclxuICAgIH07XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBBZGRzIGNvbXBvbmVudHMgdG8gdGhpcyBhY3Rpb24gcm93XHJcbiAgICogQHBhcmFtIGNvbXBvbmVudHMgVGhlIGNvbXBvbmVudHMgdG8gYWRkXHJcbiAgICovXHJcbiAgYWRkQ29tcG9uZW50cyguLi5jb21wb25lbnRzOiAoVCB8IHsgdG9KU09OKCk6IFQgfSlbXSk6IHRoaXMge1xyXG4gICAgZm9yIChjb25zdCBjb21wb25lbnQgb2YgY29tcG9uZW50cykge1xyXG4gICAgICBpZiAoJ3RvSlNPTicgaW4gY29tcG9uZW50ICYmIHR5cGVvZiBjb21wb25lbnQudG9KU09OID09PSAnZnVuY3Rpb24nKSB7XHJcbiAgICAgICAgdGhpcy5kYXRhLmNvbXBvbmVudHMucHVzaChjb21wb25lbnQudG9KU09OKCkpO1xyXG4gICAgICB9IGVsc2Uge1xyXG4gICAgICAgIHRoaXMuZGF0YS5jb21wb25lbnRzLnB1c2goY29tcG9uZW50IGFzIFQpO1xyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgICByZXR1cm4gdGhpcztcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFNldHMgdGhlIGNvbXBvbmVudHMgb2YgdGhpcyBhY3Rpb24gcm93XHJcbiAgICogQHBhcmFtIGNvbXBvbmVudHMgVGhlIGNvbXBvbmVudHMgdG8gc2V0XHJcbiAgICovXHJcbiAgc2V0Q29tcG9uZW50cyguLi5jb21wb25lbnRzOiAoVCB8IHsgdG9KU09OKCk6IFQgfSlbXSk6IHRoaXMge1xyXG4gICAgdGhpcy5kYXRhLmNvbXBvbmVudHMgPSBbXTtcclxuICAgIHJldHVybiB0aGlzLmFkZENvbXBvbmVudHMoLi4uY29tcG9uZW50cyk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBSZW1vdmVzLCByZXBsYWNlcywgb3IgaW5zZXJ0cyBjb21wb25lbnRzXHJcbiAgICogQHBhcmFtIGluZGV4IFRoZSBpbmRleCB0byBzdGFydCBhdFxyXG4gICAqIEBwYXJhbSBkZWxldGVDb3VudCBUaGUgbnVtYmVyIG9mIGNvbXBvbmVudHMgdG8gcmVtb3ZlXHJcbiAgICogQHBhcmFtIGNvbXBvbmVudHMgVGhlIGNvbXBvbmVudHMgdG8gaW5zZXJ0XHJcbiAgICovXHJcbiAgc3BsaWNlQ29tcG9uZW50cyhpbmRleDogbnVtYmVyLCBkZWxldGVDb3VudDogbnVtYmVyLCAuLi5jb21wb25lbnRzOiAoVCB8IHsgdG9KU09OKCk6IFQgfSlbXSk6IHRoaXMge1xyXG4gICAgY29uc3QgcmVzb2x2ZWQgPSBjb21wb25lbnRzLm1hcChjID0+IFxyXG4gICAgICAndG9KU09OJyBpbiBjICYmIHR5cGVvZiBjLnRvSlNPTiA9PT0gJ2Z1bmN0aW9uJyA/IGMudG9KU09OKCkgOiBjIGFzIFRcclxuICAgICk7XHJcbiAgICB0aGlzLmRhdGEuY29tcG9uZW50cy5zcGxpY2UoaW5kZXgsIGRlbGV0ZUNvdW50LCAuLi5yZXNvbHZlZCk7XHJcbiAgICByZXR1cm4gdGhpcztcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFJldHVybnMgdGhlIEpTT04gcmVwcmVzZW50YXRpb24gb2YgdGhpcyBhY3Rpb24gcm93XHJcbiAgICovXHJcbiAgdG9KU09OKCk6IEFQSUFjdGlvblJvdyB7XHJcbiAgICByZXR1cm4geyAuLi50aGlzLmRhdGEgfSBhcyBBUElBY3Rpb25Sb3c7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBDcmVhdGVzIGEgbmV3IGFjdGlvbiByb3cgYnVpbGRlciBmcm9tIGV4aXN0aW5nIGRhdGFcclxuICAgKiBAcGFyYW0gb3RoZXIgVGhlIGFjdGlvbiByb3cgZGF0YSB0byBjb3B5XHJcbiAgICovXHJcbiAgc3RhdGljIGZyb208VCBleHRlbmRzIEFQSUFjdGlvblJvd0NvbXBvbmVudD4ob3RoZXI6IFBhcnRpYWw8QVBJQWN0aW9uUm93PiB8IEFjdGlvblJvd0J1aWxkZXI8VD4pOiBBY3Rpb25Sb3dCdWlsZGVyPFQ+IHtcclxuICAgIHJldHVybiBuZXcgQWN0aW9uUm93QnVpbGRlcjxUPihvdGhlciBpbnN0YW5jZW9mIEFjdGlvblJvd0J1aWxkZXIgPyBvdGhlci5kYXRhIDogb3RoZXIpO1xyXG4gIH1cclxufVxyXG5cclxuZXhwb3J0IGRlZmF1bHQgQWN0aW9uUm93QnVpbGRlcjtcclxuIl19
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQWN0aW9uUm93QnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9idWlsZGVycy9BY3Rpb25Sb3dCdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7R0FFRzs7O0FBWUg7O0dBRUc7QUFDSCxNQUFhLGdCQUFnQjtJQUNYLElBQUksQ0FBK0I7SUFFbkQsWUFBWSxPQUE4QixFQUFFO1FBQzFDLElBQUksQ0FBQyxJQUFJLEdBQUc7WUFDVixJQUFJLEVBQUUsQ0FBQztZQUNQLFVBQVUsRUFBRyxJQUFJLENBQUMsVUFBa0IsSUFBSSxFQUFFO1NBQzNDLENBQUM7SUFDSixDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsYUFBYSxDQUFDLEdBQUcsVUFBbUM7UUFDbEQsS0FBSyxNQUFNLFNBQVMsSUFBSSxVQUFVLEVBQUUsQ0FBQztZQUNuQyxJQUFJLFFBQVEsSUFBSSxTQUFTLElBQUksT0FBTyxTQUFTLENBQUMsTUFBTSxLQUFLLFVBQVUsRUFBRSxDQUFDO2dCQUNwRSxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7WUFDaEQsQ0FBQztpQkFBTSxDQUFDO2dCQUNOLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxTQUFjLENBQUMsQ0FBQztZQUM1QyxDQUFDO1FBQ0gsQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOzs7T0FHRztJQUNILGFBQWEsQ0FBQyxHQUFHLFVBQW1DO1FBQ2xELElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxHQUFHLEVBQUUsQ0FBQztRQUMxQixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxVQUFVLENBQUMsQ0FBQztJQUMzQyxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxnQkFBZ0IsQ0FBQyxLQUFhLEVBQUUsV0FBbUIsRUFBRSxHQUFHLFVBQW1DO1FBQ3pGLE1BQU0sUUFBUSxHQUFHLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FDbEMsUUFBUSxJQUFJLENBQUMsSUFBSSxPQUFPLENBQUMsQ0FBQyxNQUFNLEtBQUssVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQU0sQ0FDdEUsQ0FBQztRQUNGLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsV0FBVyxFQUFFLEdBQUcsUUFBUSxDQUFDLENBQUM7UUFDN0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxNQUFNO1FBQ0osT0FBTyxFQUFFLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBa0IsQ0FBQztJQUMxQyxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsTUFBTSxDQUFDLElBQUksQ0FBa0MsS0FBa0Q7UUFDN0YsT0FBTyxJQUFJLGdCQUFnQixDQUFJLEtBQUssWUFBWSxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDekYsQ0FBQztDQUNGO0FBOURELDRDQThEQztBQUVELGtCQUFlLGdCQUFnQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBBY3Rpb25Sb3dCdWlsZGVyIGZvciBjcmVhdGluZyBjb21wb25lbnQgcm93c1xuICovXG5cbmltcG9ydCB7IEFQSUJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vQnV0dG9uQnVpbGRlcic7XG5pbXBvcnQgeyBBUElTZWxlY3RNZW51Q29tcG9uZW50IH0gZnJvbSAnLi9TZWxlY3RNZW51QnVpbGRlcic7XG5cbmV4cG9ydCB0eXBlIEFQSUFjdGlvblJvd0NvbXBvbmVudCA9IEFQSUJ1dHRvbkNvbXBvbmVudCB8IEFQSVNlbGVjdE1lbnVDb21wb25lbnQ7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQVBJQWN0aW9uUm93IHtcbiAgdHlwZTogMTtcbiAgY29tcG9uZW50czogQVBJQWN0aW9uUm93Q29tcG9uZW50W107XG59XG5cbi8qKlxuICogQSBidWlsZGVyIGZvciBjcmVhdGluZyBhY3Rpb24gcm93c1xuICovXG5leHBvcnQgY2xhc3MgQWN0aW9uUm93QnVpbGRlcjxUIGV4dGVuZHMgQVBJQWN0aW9uUm93Q29tcG9uZW50ID0gQVBJQWN0aW9uUm93Q29tcG9uZW50PiB7XG4gIHB1YmxpYyByZWFkb25seSBkYXRhOiB7IHR5cGU6IDE7IGNvbXBvbmVudHM6IFRbXSB9O1xuXG4gIGNvbnN0cnVjdG9yKGRhdGE6IFBhcnRpYWw8QVBJQWN0aW9uUm93PiA9IHt9KSB7XG4gICAgdGhpcy5kYXRhID0geyBcbiAgICAgIHR5cGU6IDEsIFxuICAgICAgY29tcG9uZW50czogKGRhdGEuY29tcG9uZW50cyBhcyBUW10pIHx8IFtdIFxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogQWRkcyBjb21wb25lbnRzIHRvIHRoaXMgYWN0aW9uIHJvd1xuICAgKiBAcGFyYW0gY29tcG9uZW50cyBUaGUgY29tcG9uZW50cyB0byBhZGRcbiAgICovXG4gIGFkZENvbXBvbmVudHMoLi4uY29tcG9uZW50czogKFQgfCB7IHRvSlNPTigpOiBUIH0pW10pOiB0aGlzIHtcbiAgICBmb3IgKGNvbnN0IGNvbXBvbmVudCBvZiBjb21wb25lbnRzKSB7XG4gICAgICBpZiAoJ3RvSlNPTicgaW4gY29tcG9uZW50ICYmIHR5cGVvZiBjb21wb25lbnQudG9KU09OID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgIHRoaXMuZGF0YS5jb21wb25lbnRzLnB1c2goY29tcG9uZW50LnRvSlNPTigpKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRoaXMuZGF0YS5jb21wb25lbnRzLnB1c2goY29tcG9uZW50IGFzIFQpO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXRzIHRoZSBjb21wb25lbnRzIG9mIHRoaXMgYWN0aW9uIHJvd1xuICAgKiBAcGFyYW0gY29tcG9uZW50cyBUaGUgY29tcG9uZW50cyB0byBzZXRcbiAgICovXG4gIHNldENvbXBvbmVudHMoLi4uY29tcG9uZW50czogKFQgfCB7IHRvSlNPTigpOiBUIH0pW10pOiB0aGlzIHtcbiAgICB0aGlzLmRhdGEuY29tcG9uZW50cyA9IFtdO1xuICAgIHJldHVybiB0aGlzLmFkZENvbXBvbmVudHMoLi4uY29tcG9uZW50cyk7XG4gIH1cblxuICAvKipcbiAgICogUmVtb3ZlcywgcmVwbGFjZXMsIG9yIGluc2VydHMgY29tcG9uZW50c1xuICAgKiBAcGFyYW0gaW5kZXggVGhlIGluZGV4IHRvIHN0YXJ0IGF0XG4gICAqIEBwYXJhbSBkZWxldGVDb3VudCBUaGUgbnVtYmVyIG9mIGNvbXBvbmVudHMgdG8gcmVtb3ZlXG4gICAqIEBwYXJhbSBjb21wb25lbnRzIFRoZSBjb21wb25lbnRzIHRvIGluc2VydFxuICAgKi9cbiAgc3BsaWNlQ29tcG9uZW50cyhpbmRleDogbnVtYmVyLCBkZWxldGVDb3VudDogbnVtYmVyLCAuLi5jb21wb25lbnRzOiAoVCB8IHsgdG9KU09OKCk6IFQgfSlbXSk6IHRoaXMge1xuICAgIGNvbnN0IHJlc29sdmVkID0gY29tcG9uZW50cy5tYXAoYyA9PiBcbiAgICAgICd0b0pTT04nIGluIGMgJiYgdHlwZW9mIGMudG9KU09OID09PSAnZnVuY3Rpb24nID8gYy50b0pTT04oKSA6IGMgYXMgVFxuICAgICk7XG4gICAgdGhpcy5kYXRhLmNvbXBvbmVudHMuc3BsaWNlKGluZGV4LCBkZWxldGVDb3VudCwgLi4ucmVzb2x2ZWQpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIEpTT04gcmVwcmVzZW50YXRpb24gb2YgdGhpcyBhY3Rpb24gcm93XG4gICAqL1xuICB0b0pTT04oKTogQVBJQWN0aW9uUm93IHtcbiAgICByZXR1cm4geyAuLi50aGlzLmRhdGEgfSBhcyBBUElBY3Rpb25Sb3c7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBhIG5ldyBhY3Rpb24gcm93IGJ1aWxkZXIgZnJvbSBleGlzdGluZyBkYXRhXG4gICAqIEBwYXJhbSBvdGhlciBUaGUgYWN0aW9uIHJvdyBkYXRhIHRvIGNvcHlcbiAgICovXG4gIHN0YXRpYyBmcm9tPFQgZXh0ZW5kcyBBUElBY3Rpb25Sb3dDb21wb25lbnQ+KG90aGVyOiBQYXJ0aWFsPEFQSUFjdGlvblJvdz4gfCBBY3Rpb25Sb3dCdWlsZGVyPFQ+KTogQWN0aW9uUm93QnVpbGRlcjxUPiB7XG4gICAgcmV0dXJuIG5ldyBBY3Rpb25Sb3dCdWlsZGVyPFQ+KG90aGVyIGluc3RhbmNlb2YgQWN0aW9uUm93QnVpbGRlciA/IG90aGVyLmRhdGEgOiBvdGhlcik7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgQWN0aW9uUm93QnVpbGRlcjtcbiJdfQ==
@@ -93,4 +93,4 @@ class ButtonBuilder {
93
93
  }
94
94
  exports.ButtonBuilder = ButtonBuilder;
95
95
  exports.default = ButtonBuilder;
96
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQnV0dG9uQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9idWlsZGVycy9CdXR0b25CdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7R0FFRzs7O0FBRUg7O0dBRUc7QUFDSCxJQUFZLFdBTVg7QUFORCxXQUFZLFdBQVc7SUFDckIsbURBQVcsQ0FBQTtJQUNYLHVEQUFhLENBQUE7SUFDYixtREFBVyxDQUFBO0lBQ1gsaURBQVUsQ0FBQTtJQUNWLDZDQUFRLENBQUE7QUFDVixDQUFDLEVBTlcsV0FBVywyQkFBWCxXQUFXLFFBTXRCO0FBWUQ7O0dBRUc7QUFDSCxNQUFhLGFBQWE7SUFDUixJQUFJLENBQThCO0lBRWxELFlBQVksT0FBb0MsRUFBRTtRQUNoRCxJQUFJLENBQUMsSUFBSSxHQUFHLEVBQUUsSUFBSSxFQUFFLENBQUMsRUFBRSxHQUFHLElBQUksRUFBRSxDQUFDO0lBQ25DLENBQUM7SUFFRDs7O09BR0c7SUFDSCxXQUFXLENBQUMsUUFBZ0I7UUFDMUIsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEdBQUcsUUFBUSxDQUFDO1FBQy9CLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOzs7T0FHRztJQUNILFFBQVEsQ0FBQyxLQUFhO1FBQ3BCLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUN4QixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRDs7O09BR0c7SUFDSCxRQUFRLENBQUMsS0FBa0I7UUFDekIsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ3hCLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOzs7T0FHRztJQUNILFFBQVEsQ0FBQyxLQUFrRTtRQUN6RSxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsRUFBRSxDQUFDO1lBQzlCLGdCQUFnQjtZQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssR0FBRyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsQ0FBQztRQUNwQyxDQUFDO2FBQU0sQ0FBQztZQUNOLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUMxQixDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsTUFBTSxDQUFDLEdBQVc7UUFDaEIsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDO1FBQ3BCLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOzs7T0FHRztJQUNILFdBQVcsQ0FBQyxRQUFRLEdBQUcsSUFBSTtRQUN6QixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUM7UUFDOUIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxNQUFNO1FBQ0osT0FBTyxFQUFFLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBd0IsQ0FBQztJQUNoRCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFrRDtRQUM1RCxPQUFPLElBQUksYUFBYSxDQUFDLEtBQUssWUFBWSxhQUFhLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2hGLENBQUM7Q0FDRjtBQWhGRCxzQ0FnRkM7QUFFRCxrQkFBZSxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogQnV0dG9uQnVpbGRlciBmb3IgY3JlYXRpbmcgaW50ZXJhY3RpdmUgYnV0dG9uc1xyXG4gKi9cclxuXHJcbi8qKlxyXG4gKiBCdXR0b24gc3R5bGVzXHJcbiAqL1xyXG5leHBvcnQgZW51bSBCdXR0b25TdHlsZSB7XHJcbiAgUHJpbWFyeSA9IDEsXHJcbiAgU2Vjb25kYXJ5ID0gMixcclxuICBTdWNjZXNzID0gMyxcclxuICBEYW5nZXIgPSA0LFxyXG4gIExpbmsgPSA1LFxyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEFQSUJ1dHRvbkNvbXBvbmVudCB7XHJcbiAgdHlwZTogMjtcclxuICBzdHlsZTogQnV0dG9uU3R5bGU7XHJcbiAgbGFiZWw/OiBzdHJpbmc7XHJcbiAgZW1vamk/OiB7IGlkPzogc3RyaW5nOyBuYW1lPzogc3RyaW5nOyBhbmltYXRlZD86IGJvb2xlYW4gfTtcclxuICBjdXN0b21faWQ/OiBzdHJpbmc7XHJcbiAgdXJsPzogc3RyaW5nO1xyXG4gIGRpc2FibGVkPzogYm9vbGVhbjtcclxufVxyXG5cclxuLyoqXHJcbiAqIEEgYnVpbGRlciBmb3IgY3JlYXRpbmcgYnV0dG9uc1xyXG4gKi9cclxuZXhwb3J0IGNsYXNzIEJ1dHRvbkJ1aWxkZXIge1xyXG4gIHB1YmxpYyByZWFkb25seSBkYXRhOiBQYXJ0aWFsPEFQSUJ1dHRvbkNvbXBvbmVudD47XHJcblxyXG4gIGNvbnN0cnVjdG9yKGRhdGE6IFBhcnRpYWw8QVBJQnV0dG9uQ29tcG9uZW50PiA9IHt9KSB7XHJcbiAgICB0aGlzLmRhdGEgPSB7IHR5cGU6IDIsIC4uLmRhdGEgfTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFNldHMgdGhlIGN1c3RvbSBJRCBvZiB0aGlzIGJ1dHRvblxyXG4gICAqIEBwYXJhbSBjdXN0b21JZCBUaGUgY3VzdG9tIElEXHJcbiAgICovXHJcbiAgc2V0Q3VzdG9tSWQoY3VzdG9tSWQ6IHN0cmluZyk6IHRoaXMge1xyXG4gICAgdGhpcy5kYXRhLmN1c3RvbV9pZCA9IGN1c3RvbUlkO1xyXG4gICAgcmV0dXJuIHRoaXM7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBTZXRzIHRoZSBsYWJlbCBvZiB0aGlzIGJ1dHRvblxyXG4gICAqIEBwYXJhbSBsYWJlbCBUaGUgbGFiZWxcclxuICAgKi9cclxuICBzZXRMYWJlbChsYWJlbDogc3RyaW5nKTogdGhpcyB7XHJcbiAgICB0aGlzLmRhdGEubGFiZWwgPSBsYWJlbDtcclxuICAgIHJldHVybiB0aGlzO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogU2V0cyB0aGUgc3R5bGUgb2YgdGhpcyBidXR0b25cclxuICAgKiBAcGFyYW0gc3R5bGUgVGhlIHN0eWxlXHJcbiAgICovXHJcbiAgc2V0U3R5bGUoc3R5bGU6IEJ1dHRvblN0eWxlKTogdGhpcyB7XHJcbiAgICB0aGlzLmRhdGEuc3R5bGUgPSBzdHlsZTtcclxuICAgIHJldHVybiB0aGlzO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogU2V0cyB0aGUgZW1vamkgb2YgdGhpcyBidXR0b25cclxuICAgKiBAcGFyYW0gZW1vamkgVGhlIGVtb2ppXHJcbiAgICovXHJcbiAgc2V0RW1vamkoZW1vamk6IHsgaWQ/OiBzdHJpbmc7IG5hbWU/OiBzdHJpbmc7IGFuaW1hdGVkPzogYm9vbGVhbiB9IHwgc3RyaW5nKTogdGhpcyB7XHJcbiAgICBpZiAodHlwZW9mIGVtb2ppID09PSAnc3RyaW5nJykge1xyXG4gICAgICAvLyBVbmljb2RlIGVtb2ppXHJcbiAgICAgIHRoaXMuZGF0YS5lbW9qaSA9IHsgbmFtZTogZW1vamkgfTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHRoaXMuZGF0YS5lbW9qaSA9IGVtb2ppO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIHRoaXM7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBTZXRzIHRoZSBVUkwgb2YgdGhpcyBidXR0b24gKG9ubHkgZm9yIExpbmsgc3R5bGUpXHJcbiAgICogQHBhcmFtIHVybCBUaGUgVVJMXHJcbiAgICovXHJcbiAgc2V0VVJMKHVybDogc3RyaW5nKTogdGhpcyB7XHJcbiAgICB0aGlzLmRhdGEudXJsID0gdXJsO1xyXG4gICAgcmV0dXJuIHRoaXM7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBTZXRzIHdoZXRoZXIgdGhpcyBidXR0b24gaXMgZGlzYWJsZWRcclxuICAgKiBAcGFyYW0gZGlzYWJsZWQgV2hldGhlciB0aGUgYnV0dG9uIGlzIGRpc2FibGVkXHJcbiAgICovXHJcbiAgc2V0RGlzYWJsZWQoZGlzYWJsZWQgPSB0cnVlKTogdGhpcyB7XHJcbiAgICB0aGlzLmRhdGEuZGlzYWJsZWQgPSBkaXNhYmxlZDtcclxuICAgIHJldHVybiB0aGlzO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogUmV0dXJucyB0aGUgSlNPTiByZXByZXNlbnRhdGlvbiBvZiB0aGlzIGJ1dHRvblxyXG4gICAqL1xyXG4gIHRvSlNPTigpOiBBUElCdXR0b25Db21wb25lbnQge1xyXG4gICAgcmV0dXJuIHsgLi4udGhpcy5kYXRhIH0gYXMgQVBJQnV0dG9uQ29tcG9uZW50O1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogQ3JlYXRlcyBhIG5ldyBidXR0b24gYnVpbGRlciBmcm9tIGV4aXN0aW5nIGRhdGFcclxuICAgKiBAcGFyYW0gb3RoZXIgVGhlIGJ1dHRvbiBkYXRhIHRvIGNvcHlcclxuICAgKi9cclxuICBzdGF0aWMgZnJvbShvdGhlcjogUGFydGlhbDxBUElCdXR0b25Db21wb25lbnQ+IHwgQnV0dG9uQnVpbGRlcik6IEJ1dHRvbkJ1aWxkZXIge1xyXG4gICAgcmV0dXJuIG5ldyBCdXR0b25CdWlsZGVyKG90aGVyIGluc3RhbmNlb2YgQnV0dG9uQnVpbGRlciA/IG90aGVyLmRhdGEgOiBvdGhlcik7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgZGVmYXVsdCBCdXR0b25CdWlsZGVyO1xyXG4iXX0=
96
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQnV0dG9uQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9idWlsZGVycy9CdXR0b25CdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7R0FFRzs7O0FBRUg7O0dBRUc7QUFDSCxJQUFZLFdBTVg7QUFORCxXQUFZLFdBQVc7SUFDckIsbURBQVcsQ0FBQTtJQUNYLHVEQUFhLENBQUE7SUFDYixtREFBVyxDQUFBO0lBQ1gsaURBQVUsQ0FBQTtJQUNWLDZDQUFRLENBQUE7QUFDVixDQUFDLEVBTlcsV0FBVywyQkFBWCxXQUFXLFFBTXRCO0FBWUQ7O0dBRUc7QUFDSCxNQUFhLGFBQWE7SUFDUixJQUFJLENBQThCO0lBRWxELFlBQVksT0FBb0MsRUFBRTtRQUNoRCxJQUFJLENBQUMsSUFBSSxHQUFHLEVBQUUsSUFBSSxFQUFFLENBQUMsRUFBRSxHQUFHLElBQUksRUFBRSxDQUFDO0lBQ25DLENBQUM7SUFFRDs7O09BR0c7SUFDSCxXQUFXLENBQUMsUUFBZ0I7UUFDMUIsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEdBQUcsUUFBUSxDQUFDO1FBQy9CLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOzs7T0FHRztJQUNILFFBQVEsQ0FBQyxLQUFhO1FBQ3BCLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUN4QixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRDs7O09BR0c7SUFDSCxRQUFRLENBQUMsS0FBa0I7UUFDekIsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ3hCLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOzs7T0FHRztJQUNILFFBQVEsQ0FBQyxLQUFrRTtRQUN6RSxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsRUFBRSxDQUFDO1lBQzlCLGdCQUFnQjtZQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssR0FBRyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsQ0FBQztRQUNwQyxDQUFDO2FBQU0sQ0FBQztZQUNOLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUMxQixDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsTUFBTSxDQUFDLEdBQVc7UUFDaEIsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDO1FBQ3BCLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVEOzs7T0FHRztJQUNILFdBQVcsQ0FBQyxRQUFRLEdBQUcsSUFBSTtRQUN6QixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUM7UUFDOUIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxNQUFNO1FBQ0osT0FBTyxFQUFFLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBd0IsQ0FBQztJQUNoRCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFrRDtRQUM1RCxPQUFPLElBQUksYUFBYSxDQUFDLEtBQUssWUFBWSxhQUFhLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2hGLENBQUM7Q0FDRjtBQWhGRCxzQ0FnRkM7QUFFRCxrQkFBZSxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEJ1dHRvbkJ1aWxkZXIgZm9yIGNyZWF0aW5nIGludGVyYWN0aXZlIGJ1dHRvbnNcbiAqL1xuXG4vKipcbiAqIEJ1dHRvbiBzdHlsZXNcbiAqL1xuZXhwb3J0IGVudW0gQnV0dG9uU3R5bGUge1xuICBQcmltYXJ5ID0gMSxcbiAgU2Vjb25kYXJ5ID0gMixcbiAgU3VjY2VzcyA9IDMsXG4gIERhbmdlciA9IDQsXG4gIExpbmsgPSA1LFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFQSUJ1dHRvbkNvbXBvbmVudCB7XG4gIHR5cGU6IDI7XG4gIHN0eWxlOiBCdXR0b25TdHlsZTtcbiAgbGFiZWw/OiBzdHJpbmc7XG4gIGVtb2ppPzogeyBpZD86IHN0cmluZzsgbmFtZT86IHN0cmluZzsgYW5pbWF0ZWQ/OiBib29sZWFuIH07XG4gIGN1c3RvbV9pZD86IHN0cmluZztcbiAgdXJsPzogc3RyaW5nO1xuICBkaXNhYmxlZD86IGJvb2xlYW47XG59XG5cbi8qKlxuICogQSBidWlsZGVyIGZvciBjcmVhdGluZyBidXR0b25zXG4gKi9cbmV4cG9ydCBjbGFzcyBCdXR0b25CdWlsZGVyIHtcbiAgcHVibGljIHJlYWRvbmx5IGRhdGE6IFBhcnRpYWw8QVBJQnV0dG9uQ29tcG9uZW50PjtcblxuICBjb25zdHJ1Y3RvcihkYXRhOiBQYXJ0aWFsPEFQSUJ1dHRvbkNvbXBvbmVudD4gPSB7fSkge1xuICAgIHRoaXMuZGF0YSA9IHsgdHlwZTogMiwgLi4uZGF0YSB9O1xuICB9XG5cbiAgLyoqXG4gICAqIFNldHMgdGhlIGN1c3RvbSBJRCBvZiB0aGlzIGJ1dHRvblxuICAgKiBAcGFyYW0gY3VzdG9tSWQgVGhlIGN1c3RvbSBJRFxuICAgKi9cbiAgc2V0Q3VzdG9tSWQoY3VzdG9tSWQ6IHN0cmluZyk6IHRoaXMge1xuICAgIHRoaXMuZGF0YS5jdXN0b21faWQgPSBjdXN0b21JZDtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXRzIHRoZSBsYWJlbCBvZiB0aGlzIGJ1dHRvblxuICAgKiBAcGFyYW0gbGFiZWwgVGhlIGxhYmVsXG4gICAqL1xuICBzZXRMYWJlbChsYWJlbDogc3RyaW5nKTogdGhpcyB7XG4gICAgdGhpcy5kYXRhLmxhYmVsID0gbGFiZWw7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogU2V0cyB0aGUgc3R5bGUgb2YgdGhpcyBidXR0b25cbiAgICogQHBhcmFtIHN0eWxlIFRoZSBzdHlsZVxuICAgKi9cbiAgc2V0U3R5bGUoc3R5bGU6IEJ1dHRvblN0eWxlKTogdGhpcyB7XG4gICAgdGhpcy5kYXRhLnN0eWxlID0gc3R5bGU7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogU2V0cyB0aGUgZW1vamkgb2YgdGhpcyBidXR0b25cbiAgICogQHBhcmFtIGVtb2ppIFRoZSBlbW9qaVxuICAgKi9cbiAgc2V0RW1vamkoZW1vamk6IHsgaWQ/OiBzdHJpbmc7IG5hbWU/OiBzdHJpbmc7IGFuaW1hdGVkPzogYm9vbGVhbiB9IHwgc3RyaW5nKTogdGhpcyB7XG4gICAgaWYgKHR5cGVvZiBlbW9qaSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIC8vIFVuaWNvZGUgZW1vamlcbiAgICAgIHRoaXMuZGF0YS5lbW9qaSA9IHsgbmFtZTogZW1vamkgfTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5kYXRhLmVtb2ppID0gZW1vamk7XG4gICAgfVxuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldHMgdGhlIFVSTCBvZiB0aGlzIGJ1dHRvbiAob25seSBmb3IgTGluayBzdHlsZSlcbiAgICogQHBhcmFtIHVybCBUaGUgVVJMXG4gICAqL1xuICBzZXRVUkwodXJsOiBzdHJpbmcpOiB0aGlzIHtcbiAgICB0aGlzLmRhdGEudXJsID0gdXJsO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldHMgd2hldGhlciB0aGlzIGJ1dHRvbiBpcyBkaXNhYmxlZFxuICAgKiBAcGFyYW0gZGlzYWJsZWQgV2hldGhlciB0aGUgYnV0dG9uIGlzIGRpc2FibGVkXG4gICAqL1xuICBzZXREaXNhYmxlZChkaXNhYmxlZCA9IHRydWUpOiB0aGlzIHtcbiAgICB0aGlzLmRhdGEuZGlzYWJsZWQgPSBkaXNhYmxlZDtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBKU09OIHJlcHJlc2VudGF0aW9uIG9mIHRoaXMgYnV0dG9uXG4gICAqL1xuICB0b0pTT04oKTogQVBJQnV0dG9uQ29tcG9uZW50IHtcbiAgICByZXR1cm4geyAuLi50aGlzLmRhdGEgfSBhcyBBUElCdXR0b25Db21wb25lbnQ7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBhIG5ldyBidXR0b24gYnVpbGRlciBmcm9tIGV4aXN0aW5nIGRhdGFcbiAgICogQHBhcmFtIG90aGVyIFRoZSBidXR0b24gZGF0YSB0byBjb3B5XG4gICAqL1xuICBzdGF0aWMgZnJvbShvdGhlcjogUGFydGlhbDxBUElCdXR0b25Db21wb25lbnQ+IHwgQnV0dG9uQnVpbGRlcik6IEJ1dHRvbkJ1aWxkZXIge1xuICAgIHJldHVybiBuZXcgQnV0dG9uQnVpbGRlcihvdGhlciBpbnN0YW5jZW9mIEJ1dHRvbkJ1aWxkZXIgPyBvdGhlci5kYXRhIDogb3RoZXIpO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IEJ1dHRvbkJ1aWxkZXI7XG4iXX0=
@@ -205,4 +205,4 @@ exports.Colors = {
205
205
  NotQuiteBlack: 0x23272a,
206
206
  };
207
207
  exports.default = EmbedBuilder;
208
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EmbedBuilder.js","sourceRoot":"","sources":["../../src/builders/EmbedBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * EmbedBuilder for creating rich embeds\r\n */\r\n\r\nexport interface APIEmbedField {\r\n  name: string;\r\n  value: string;\r\n  inline?: boolean;\r\n}\r\n\r\nexport interface APIEmbedAuthor {\r\n  name: string;\r\n  url?: string;\r\n  icon_url?: string;\r\n}\r\n\r\nexport interface APIEmbedFooter {\r\n  text: string;\r\n  icon_url?: string;\r\n}\r\n\r\nexport interface APIEmbedImage {\r\n  url: string;\r\n  height?: number;\r\n  width?: number;\r\n}\r\n\r\nexport interface APIEmbedThumbnail {\r\n  url: string;\r\n  height?: number;\r\n  width?: number;\r\n}\r\n\r\nexport interface APIEmbed {\r\n  title?: string;\r\n  description?: string;\r\n  url?: string;\r\n  timestamp?: string;\r\n  color?: number;\r\n  footer?: APIEmbedFooter;\r\n  image?: APIEmbedImage;\r\n  thumbnail?: APIEmbedThumbnail;\r\n  author?: APIEmbedAuthor;\r\n  fields?: APIEmbedField[];\r\n}\r\n\r\n/**\r\n * A builder for creating embeds\r\n */\r\nexport class EmbedBuilder {\r\n  public readonly data: APIEmbed;\r\n\r\n  constructor(data: APIEmbed = {}) {\r\n    this.data = { ...data };\r\n    if (data.fields) {\r\n      this.data.fields = [...data.fields];\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Sets the title of this embed\r\n   * @param title The title\r\n   */\r\n  setTitle(title: string | null): this {\r\n    this.data.title = title ?? undefined;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the description of this embed\r\n   * @param description The description\r\n   */\r\n  setDescription(description: string | null): this {\r\n    this.data.description = description ?? undefined;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the URL of this embed\r\n   * @param url The URL\r\n   */\r\n  setURL(url: string | null): this {\r\n    this.data.url = url ?? undefined;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the timestamp of this embed\r\n   * @param timestamp The timestamp or date\r\n   */\r\n  setTimestamp(timestamp: Date | number | null = Date.now()): this {\r\n    this.data.timestamp = timestamp === null \r\n      ? undefined \r\n      : new Date(timestamp).toISOString();\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the color of this embed\r\n   * @param color The color (number, hex string, or RGB array)\r\n   */\r\n  setColor(color: number | `#${string}` | [number, number, number] | null): this {\r\n    if (color === null) {\r\n      this.data.color = undefined;\r\n    } else if (typeof color === 'number') {\r\n      this.data.color = color;\r\n    } else if (typeof color === 'string') {\r\n      this.data.color = parseInt(color.replace('#', ''), 16);\r\n    } else if (Array.isArray(color)) {\r\n      this.data.color = (color[0] << 16) + (color[1] << 8) + color[2];\r\n    }\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the footer of this embed\r\n   * @param options The footer options\r\n   */\r\n  setFooter(options: { text: string; iconURL?: string } | null): this {\r\n    if (options === null) {\r\n      this.data.footer = undefined;\r\n    } else {\r\n      this.data.footer = {\r\n        text: options.text,\r\n        icon_url: options.iconURL,\r\n      };\r\n    }\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the image of this embed\r\n   * @param url The image URL\r\n   */\r\n  setImage(url: string | null): this {\r\n    this.data.image = url === null ? undefined : { url };\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the thumbnail of this embed\r\n   * @param url The thumbnail URL\r\n   */\r\n  setThumbnail(url: string | null): this {\r\n    this.data.thumbnail = url === null ? undefined : { url };\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the author of this embed\r\n   * @param options The author options\r\n   */\r\n  setAuthor(options: { name: string; iconURL?: string; url?: string } | null): this {\r\n    if (options === null) {\r\n      this.data.author = undefined;\r\n    } else {\r\n      this.data.author = {\r\n        name: options.name,\r\n        icon_url: options.iconURL,\r\n        url: options.url,\r\n      };\r\n    }\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Adds fields to this embed (max 25 fields per embed)\r\n   * @param fields The fields to add\r\n   */\r\n  addFields(...fields: APIEmbedField[]): this {\r\n    if (!this.data.fields) this.data.fields = [];\r\n    if (this.data.fields.length + fields.length > 25) {\r\n      throw new RangeError(`Embed fields cannot exceed 25. Current: ${this.data.fields.length}, adding: ${fields.length}`);\r\n    }\r\n    this.data.fields.push(...fields);\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the fields of this embed (max 25 fields per embed)\r\n   * @param fields The fields to set\r\n   */\r\n  setFields(...fields: APIEmbedField[]): this {\r\n    if (fields.length > 25) {\r\n      throw new RangeError(`Embed fields cannot exceed 25. Provided: ${fields.length}`);\r\n    }\r\n    this.data.fields = fields;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Removes, replaces, or inserts fields (max 25 fields per embed)\r\n   * @param index The index to start at\r\n   * @param deleteCount The number of fields to remove\r\n   * @param fields The fields to insert\r\n   */\r\n  spliceFields(index: number, deleteCount: number, ...fields: APIEmbedField[]): this {\r\n    if (!this.data.fields) this.data.fields = [];\r\n    this.data.fields.splice(index, deleteCount, ...fields);\r\n    if (this.data.fields.length > 25) {\r\n      throw new RangeError(`Embed fields cannot exceed 25. Result would have: ${this.data.fields.length}`);\r\n    }\r\n    return this;\r\n  }\r\n\r\n\r\n  /**\r\n   * Returns the JSON representation of this embed\r\n   */\r\n  toJSON(): APIEmbed {\r\n    return { ...this.data };\r\n  }\r\n\r\n  /**\r\n   * Creates a new embed builder from existing data\r\n   * @param other The embed data to copy\r\n   */\r\n  static from(other: APIEmbed | EmbedBuilder): EmbedBuilder {\r\n    return new EmbedBuilder(other instanceof EmbedBuilder ? other.data : other);\r\n  }\r\n}\r\n\r\n// Color constants (DJS compatibility)\r\nexport const Colors = {\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  LuminousVividPink: 0xe91e63,\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  DarkAqua: 0x11806a,\r\n  DarkGreen: 0x1f8b4c,\r\n  DarkBlue: 0x206694,\r\n  DarkPurple: 0x71368a,\r\n  DarkVividPink: 0xad1457,\r\n  DarkGold: 0xc27c0e,\r\n  DarkOrange: 0xa84300,\r\n  DarkRed: 0x992d22,\r\n  DarkGrey: 0x979c9f,\r\n  DarkerGrey: 0x7f8c8d,\r\n  LightGrey: 0xbcc0c0,\r\n  DarkNavy: 0x2c3e50,\r\n  Blurple: 0x5865f2,\r\n  Greyple: 0x99aab5,\r\n  DarkButNotBlack: 0x2c2f33,\r\n  NotQuiteBlack: 0x23272a,\r\n} as const;\r\n\r\nexport default EmbedBuilder;\r\n"]}
208
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EmbedBuilder.js","sourceRoot":"","sources":["../../src/builders/EmbedBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * EmbedBuilder for creating rich embeds\n */\n\nexport interface APIEmbedField {\n  name: string;\n  value: string;\n  inline?: boolean;\n}\n\nexport interface APIEmbedAuthor {\n  name: string;\n  url?: string;\n  icon_url?: string;\n}\n\nexport interface APIEmbedFooter {\n  text: string;\n  icon_url?: string;\n}\n\nexport interface APIEmbedImage {\n  url: string;\n  height?: number;\n  width?: number;\n}\n\nexport interface APIEmbedThumbnail {\n  url: string;\n  height?: number;\n  width?: number;\n}\n\nexport interface APIEmbed {\n  title?: string;\n  description?: string;\n  url?: string;\n  timestamp?: string;\n  color?: number;\n  footer?: APIEmbedFooter;\n  image?: APIEmbedImage;\n  thumbnail?: APIEmbedThumbnail;\n  author?: APIEmbedAuthor;\n  fields?: APIEmbedField[];\n}\n\n/**\n * A builder for creating embeds\n */\nexport class EmbedBuilder {\n  public readonly data: APIEmbed;\n\n  constructor(data: APIEmbed = {}) {\n    this.data = { ...data };\n    if (data.fields) {\n      this.data.fields = [...data.fields];\n    }\n  }\n\n  /**\n   * Sets the title of this embed\n   * @param title The title\n   */\n  setTitle(title: string | null): this {\n    this.data.title = title ?? undefined;\n    return this;\n  }\n\n  /**\n   * Sets the description of this embed\n   * @param description The description\n   */\n  setDescription(description: string | null): this {\n    this.data.description = description ?? undefined;\n    return this;\n  }\n\n  /**\n   * Sets the URL of this embed\n   * @param url The URL\n   */\n  setURL(url: string | null): this {\n    this.data.url = url ?? undefined;\n    return this;\n  }\n\n  /**\n   * Sets the timestamp of this embed\n   * @param timestamp The timestamp or date\n   */\n  setTimestamp(timestamp: Date | number | null = Date.now()): this {\n    this.data.timestamp = timestamp === null \n      ? undefined \n      : new Date(timestamp).toISOString();\n    return this;\n  }\n\n  /**\n   * Sets the color of this embed\n   * @param color The color (number, hex string, or RGB array)\n   */\n  setColor(color: number | `#${string}` | [number, number, number] | null): this {\n    if (color === null) {\n      this.data.color = undefined;\n    } else if (typeof color === 'number') {\n      this.data.color = color;\n    } else if (typeof color === 'string') {\n      this.data.color = parseInt(color.replace('#', ''), 16);\n    } else if (Array.isArray(color)) {\n      this.data.color = (color[0] << 16) + (color[1] << 8) + color[2];\n    }\n    return this;\n  }\n\n  /**\n   * Sets the footer of this embed\n   * @param options The footer options\n   */\n  setFooter(options: { text: string; iconURL?: string } | null): this {\n    if (options === null) {\n      this.data.footer = undefined;\n    } else {\n      this.data.footer = {\n        text: options.text,\n        icon_url: options.iconURL,\n      };\n    }\n    return this;\n  }\n\n  /**\n   * Sets the image of this embed\n   * @param url The image URL\n   */\n  setImage(url: string | null): this {\n    this.data.image = url === null ? undefined : { url };\n    return this;\n  }\n\n  /**\n   * Sets the thumbnail of this embed\n   * @param url The thumbnail URL\n   */\n  setThumbnail(url: string | null): this {\n    this.data.thumbnail = url === null ? undefined : { url };\n    return this;\n  }\n\n  /**\n   * Sets the author of this embed\n   * @param options The author options\n   */\n  setAuthor(options: { name: string; iconURL?: string; url?: string } | null): this {\n    if (options === null) {\n      this.data.author = undefined;\n    } else {\n      this.data.author = {\n        name: options.name,\n        icon_url: options.iconURL,\n        url: options.url,\n      };\n    }\n    return this;\n  }\n\n  /**\n   * Adds fields to this embed (max 25 fields per embed)\n   * @param fields The fields to add\n   */\n  addFields(...fields: APIEmbedField[]): this {\n    if (!this.data.fields) this.data.fields = [];\n    if (this.data.fields.length + fields.length > 25) {\n      throw new RangeError(`Embed fields cannot exceed 25. Current: ${this.data.fields.length}, adding: ${fields.length}`);\n    }\n    this.data.fields.push(...fields);\n    return this;\n  }\n\n  /**\n   * Sets the fields of this embed (max 25 fields per embed)\n   * @param fields The fields to set\n   */\n  setFields(...fields: APIEmbedField[]): this {\n    if (fields.length > 25) {\n      throw new RangeError(`Embed fields cannot exceed 25. Provided: ${fields.length}`);\n    }\n    this.data.fields = fields;\n    return this;\n  }\n\n  /**\n   * Removes, replaces, or inserts fields (max 25 fields per embed)\n   * @param index The index to start at\n   * @param deleteCount The number of fields to remove\n   * @param fields The fields to insert\n   */\n  spliceFields(index: number, deleteCount: number, ...fields: APIEmbedField[]): this {\n    if (!this.data.fields) this.data.fields = [];\n    this.data.fields.splice(index, deleteCount, ...fields);\n    if (this.data.fields.length > 25) {\n      throw new RangeError(`Embed fields cannot exceed 25. Result would have: ${this.data.fields.length}`);\n    }\n    return this;\n  }\n\n\n  /**\n   * Returns the JSON representation of this embed\n   */\n  toJSON(): APIEmbed {\n    return { ...this.data };\n  }\n\n  /**\n   * Creates a new embed builder from existing data\n   * @param other The embed data to copy\n   */\n  static from(other: APIEmbed | EmbedBuilder): EmbedBuilder {\n    return new EmbedBuilder(other instanceof EmbedBuilder ? other.data : other);\n  }\n}\n\n// Color constants (DJS compatibility)\nexport const Colors = {\n  Default: 0x000000,\n  White: 0xffffff,\n  Aqua: 0x1abc9c,\n  Green: 0x57f287,\n  Blue: 0x3498db,\n  Yellow: 0xfee75c,\n  Purple: 0x9b59b6,\n  LuminousVividPink: 0xe91e63,\n  Fuchsia: 0xeb459e,\n  Gold: 0xf1c40f,\n  Orange: 0xe67e22,\n  Red: 0xed4245,\n  Grey: 0x95a5a6,\n  Navy: 0x34495e,\n  DarkAqua: 0x11806a,\n  DarkGreen: 0x1f8b4c,\n  DarkBlue: 0x206694,\n  DarkPurple: 0x71368a,\n  DarkVividPink: 0xad1457,\n  DarkGold: 0xc27c0e,\n  DarkOrange: 0xa84300,\n  DarkRed: 0x992d22,\n  DarkGrey: 0x979c9f,\n  DarkerGrey: 0x7f8c8d,\n  LightGrey: 0xbcc0c0,\n  DarkNavy: 0x2c3e50,\n  Blurple: 0x5865f2,\n  Greyple: 0x99aab5,\n  DarkButNotBlack: 0x2c2f33,\n  NotQuiteBlack: 0x23272a,\n} as const;\n\nexport default EmbedBuilder;\n"]}