@jubbio/core 1.0.9 → 1.0.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.
@@ -96,17 +96,17 @@ export declare class EmbedBuilder {
96
96
  url?: string;
97
97
  } | null): this;
98
98
  /**
99
- * Adds fields to this embed
99
+ * Adds fields to this embed (max 25 fields per embed)
100
100
  * @param fields The fields to add
101
101
  */
102
102
  addFields(...fields: APIEmbedField[]): this;
103
103
  /**
104
- * Sets the fields of this embed
104
+ * Sets the fields of this embed (max 25 fields per embed)
105
105
  * @param fields The fields to set
106
106
  */
107
107
  setFields(...fields: APIEmbedField[]): this;
108
108
  /**
109
- * Removes, replaces, or inserts fields
109
+ * Removes, replaces, or inserts fields (max 25 fields per embed)
110
110
  * @param index The index to start at
111
111
  * @param deleteCount The number of fields to remove
112
112
  * @param fields The fields to insert
@@ -118,25 +118,31 @@ class EmbedBuilder {
118
118
  return this;
119
119
  }
120
120
  /**
121
- * Adds fields to this embed
121
+ * Adds fields to this embed (max 25 fields per embed)
122
122
  * @param fields The fields to add
123
123
  */
124
124
  addFields(...fields) {
125
125
  if (!this.data.fields)
126
126
  this.data.fields = [];
127
+ if (this.data.fields.length + fields.length > 25) {
128
+ throw new RangeError(`Embed fields cannot exceed 25. Current: ${this.data.fields.length}, adding: ${fields.length}`);
129
+ }
127
130
  this.data.fields.push(...fields);
128
131
  return this;
129
132
  }
130
133
  /**
131
- * Sets the fields of this embed
134
+ * Sets the fields of this embed (max 25 fields per embed)
132
135
  * @param fields The fields to set
133
136
  */
134
137
  setFields(...fields) {
138
+ if (fields.length > 25) {
139
+ throw new RangeError(`Embed fields cannot exceed 25. Provided: ${fields.length}`);
140
+ }
135
141
  this.data.fields = fields;
136
142
  return this;
137
143
  }
138
144
  /**
139
- * Removes, replaces, or inserts fields
145
+ * Removes, replaces, or inserts fields (max 25 fields per embed)
140
146
  * @param index The index to start at
141
147
  * @param deleteCount The number of fields to remove
142
148
  * @param fields The fields to insert
@@ -145,6 +151,9 @@ class EmbedBuilder {
145
151
  if (!this.data.fields)
146
152
  this.data.fields = [];
147
153
  this.data.fields.splice(index, deleteCount, ...fields);
154
+ if (this.data.fields.length > 25) {
155
+ throw new RangeError(`Embed fields cannot exceed 25. Result would have: ${this.data.fields.length}`);
156
+ }
148
157
  return this;
149
158
  }
150
159
  /**
@@ -196,4 +205,4 @@ exports.Colors = {
196
205
  NotQuiteBlack: 0x23272a,
197
206
  };
198
207
  exports.default = EmbedBuilder;
199
- //# 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\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    this.data.fields.push(...fields);\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Sets the fields of this embed\r\n   * @param fields The fields to set\r\n   */\r\n  setFields(...fields: APIEmbedField[]): this {\r\n    this.data.fields = fields;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Removes, replaces, or inserts fields\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    return this;\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":["/**\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"]}
@@ -254,6 +254,34 @@ export declare class REST {
254
254
  * Delete a global command
255
255
  */
256
256
  deleteGlobalCommand(commandId: string): Promise<void>;
257
+ /**
258
+ * Delete a guild-specific command
259
+ */
260
+ deleteGuildCommand(guildId: string, commandId: string): Promise<void>;
261
+ /**
262
+ * List all global commands for this application
263
+ */
264
+ listGlobalCommands(): Promise<APIApplicationCommand[]>;
265
+ /**
266
+ * List all guild-specific commands for this application
267
+ */
268
+ listGuildCommands(guildId: string): Promise<APIApplicationCommand[]>;
269
+ /**
270
+ * Get a specific global command
271
+ */
272
+ getGlobalCommand(commandId: string): Promise<APIApplicationCommand>;
273
+ /**
274
+ * Get a specific guild command
275
+ */
276
+ getGuildCommand(guildId: string, commandId: string): Promise<APIApplicationCommand>;
277
+ /**
278
+ * Update a global command
279
+ */
280
+ updateGlobalCommand(commandId: string, data: Partial<APIApplicationCommand>): Promise<APIApplicationCommand>;
281
+ /**
282
+ * Update a guild-specific command
283
+ */
284
+ updateGuildCommand(guildId: string, commandId: string, data: Partial<APIApplicationCommand>): Promise<APIApplicationCommand>;
257
285
  private applicationId;
258
286
  /**
259
287
  * Set the application ID
package/dist/rest/REST.js CHANGED
@@ -502,6 +502,55 @@ class REST {
502
502
  const appId = this.getApplicationId();
503
503
  await this.request('DELETE', `/applications/${appId}/commands/${commandId}`);
504
504
  }
505
+ /**
506
+ * Delete a guild-specific command
507
+ */
508
+ async deleteGuildCommand(guildId, commandId) {
509
+ const appId = this.getApplicationId();
510
+ await this.request('DELETE', `/applications/${appId}/guilds/${guildId}/commands/${commandId}`);
511
+ }
512
+ /**
513
+ * List all global commands for this application
514
+ */
515
+ async listGlobalCommands() {
516
+ const appId = this.getApplicationId();
517
+ return this.request('GET', `/applications/${appId}/commands`);
518
+ }
519
+ /**
520
+ * List all guild-specific commands for this application
521
+ */
522
+ async listGuildCommands(guildId) {
523
+ const appId = this.getApplicationId();
524
+ return this.request('GET', `/applications/${appId}/guilds/${guildId}/commands`);
525
+ }
526
+ /**
527
+ * Get a specific global command
528
+ */
529
+ async getGlobalCommand(commandId) {
530
+ const appId = this.getApplicationId();
531
+ return this.request('GET', `/applications/${appId}/commands/${commandId}`);
532
+ }
533
+ /**
534
+ * Get a specific guild command
535
+ */
536
+ async getGuildCommand(guildId, commandId) {
537
+ const appId = this.getApplicationId();
538
+ return this.request('GET', `/applications/${appId}/guilds/${guildId}/commands/${commandId}`);
539
+ }
540
+ /**
541
+ * Update a global command
542
+ */
543
+ async updateGlobalCommand(commandId, data) {
544
+ const appId = this.getApplicationId();
545
+ return this.request('PATCH', `/applications/${appId}/commands/${commandId}`, data);
546
+ }
547
+ /**
548
+ * Update a guild-specific command
549
+ */
550
+ async updateGuildCommand(guildId, commandId, data) {
551
+ const appId = this.getApplicationId();
552
+ return this.request('PATCH', `/applications/${appId}/guilds/${guildId}/commands/${commandId}`, data);
553
+ }
505
554
  // ==================== Helpers ====================
506
555
  applicationId = '';
507
556
  /**
@@ -808,4 +857,4 @@ class REST {
808
857
  }
809
858
  }
810
859
  exports.REST = REST;
811
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"REST.js","sourceRoot":"","sources":["../../src/rest/REST.ts"],"names":[],"mappings":";;;AA+BA;;GAEG;AACH,MAAa,IAAI;IACP,OAAO,CAAS;IAChB,KAAK,GAAW,EAAE,CAAC;IAE3B,qDAAqD;IAC7C,SAAS,GAA4B,IAAI,GAAG,EAAE,CAAC;IACtC,cAAc,GAAG,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC,WAAW;IAE5D,YAAY,UAAkB,mCAAmC;QAC/D,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAED,4DAA4D;IAE5D;;;OAGG;IACH,SAAS,CAAC,IAA4F;QACpG,MAAM,MAAM,GAAG,OAAO,IAAI,CAAC,EAAE,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;QAC7E,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,EAAE;YACzB,EAAE,EAAE,MAAM;YACV,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,WAAW,EAAE,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,YAAY;YAClD,QAAQ,EAAE,IAAI,CAAC,GAAG,EAAE;SACrB,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,UAAU,CAAC,KAAoG;QAC7G,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;IAC9C,CAAC;IAED;;OAEG;IACH,aAAa,CAAC,MAAc;QAC1B,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAC1C,IAAI,MAAM,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,QAAQ,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;YACjE,OAAO,MAAM,CAAC;QAChB,CAAC;QACD,6BAA6B;QAC7B,IAAI,MAAM,EAAE,CAAC;YACX,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAChC,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;;;;;;;OAQG;IACH,aAAa,CAAC,IAA+C;QAC3D,MAAM,MAAM,GAAG,OAAO,IAAI,CAAC,EAAE,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;QAC7E,OAAO;YACL,IAAI,EAAE,IAAI,IAAI,CAAC,QAAQ,EAAE;YACzB,IAAI,EAAE;gBACJ,KAAK,EAAE,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC;aACjD;SACF,CAAC;IACJ,CAAC;IAED;;;;;;;OAOG;IACK,eAAe,CAAC,OAAe,EAAE,gBAA+B;QACtE,MAAM,QAAQ,GAAiB;YAC7B,KAAK,EAAE,CAAC,GAAG,CAAC,gBAAgB,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC;YAC3C,KAAK,EAAE,CAAC,GAAG,CAAC,gBAAgB,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC;YAC3C,QAAQ,EAAE,gBAAgB,EAAE,QAAQ;SACrC,CAAC;QAEF,mDAAmD;QACnD,MAAM,YAAY,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;QAEnE,qCAAqC;QACrC,MAAM,gBAAgB,GAAG,aAAa,CAAC;QACvC,IAAI,gBAAgB,GAAG,OAAO,CAAC;QAC/B,IAAI,KAAK,CAAC;QAEV,OAAO,CAAC,KAAK,GAAG,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;YACzD,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACtC,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YAE3B,iCAAiC;YACjC,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YAE9C,IAAI,UAAU,EAAE,CAAC;gBACf,+BAA+B;gBAC/B,gBAAgB,GAAG,gBAAgB,CAAC,OAAO,CAAC,SAAS,EAAE,IAAI,UAAU,CAAC,QAAQ,EAAE,CAAC,CAAC;gBAElF,uCAAuC;gBACvC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;oBAC9B,QAAQ,CAAC,KAAM,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,UAAU,CAAC,QAAQ,EAAE,CAAC,CAAC;oBACpE,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;gBAC3B,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,qEAAqE;gBACrE,gBAAgB,GAAG,gBAAgB,CAAC,OAAO,CAAC,SAAS,EAAE,SAAS,MAAM,EAAE,CAAC,CAAC;gBAE1E,kDAAkD;gBAClD,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;oBAC9B,QAAQ,CAAC,KAAM,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,MAAM,EAAE,EAAE,CAAC,CAAC;oBACjE,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;gBAC3B,CAAC;YACH,CAAC;QACH,CAAC;QAED,sCAAsC;QACtC,MAAM,gBAAgB,GAAG,YAAY,CAAC;QACtC,MAAM,YAAY,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;QAEnE,OAAO,CAAC,KAAK,GAAG,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;YACzD,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YACxB,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YAE3B,8DAA8D;YAC9D,gBAAgB,GAAG,gBAAgB,CAAC,OAAO,CAAC,SAAS,EAAE,SAAS,MAAM,EAAE,CAAC,CAAC;YAE1E,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;gBAC9B,QAAQ,CAAC,KAAM,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;gBACrC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YAC3B,CAAC;QACH,CAAC;QAED,4BAA4B;QAC5B,IAAI,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC;YAClC,QAAQ,CAAC,QAAQ,GAAG,IAAI,CAAC;QAC3B,CAAC;QAED,wBAAwB;QACxB,IAAI,QAAQ,CAAC,KAAK,EAAE,MAAM,KAAK,CAAC;YAAE,OAAO,QAAQ,CAAC,KAAK,CAAC;QACxD,IAAI,QAAQ,CAAC,KAAK,EAAE,MAAM,KAAK,CAAC;YAAE,OAAO,QAAQ,CAAC,KAAK,CAAC;QAExD,OAAO,EAAE,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,CAAC;IACjD,CAAC;IAED;;;OAGG;IACK,kBAAkB,CAAC,IAM1B;QACC,MAAM,MAAM,GAAQ,EAAE,GAAG,IAAI,EAAE,CAAC;QAEhC,kEAAkE;QAClE,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClD,MAAM,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE,CACjD,OAAO,CAAC,CAAC,MAAM,KAAK,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC,CAChD,CAAC;QACJ,CAAC;QAED,IAAI,WAAW,GAAiB,EAAE,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAErD,yCAAyC;QACzC,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;YAC9E,MAAM,CAAC,OAAO,GAAG,OAAO,CAAC;YACzB,WAAW,GAAG,QAAQ,CAAC;QACzB,CAAC;QAED,kEAAkE;QAClE,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC1C,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;gBACtC,iEAAiE;gBACjE,MAAM,QAAQ,GAAG,OAAQ,KAAa,CAAC,MAAM,KAAK,UAAU,CAAC,CAAC,CAAE,KAAa,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;gBAC/F,MAAM,cAAc,GAAQ,EAAE,GAAG,QAAQ,EAAE,CAAC;gBAE5C,sBAAsB;gBACtB,IAAI,QAAQ,CAAC,WAAW,EAAE,CAAC;oBACzB,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;oBACtF,cAAc,CAAC,WAAW,GAAG,OAAO,CAAC;oBACrC,WAAW,GAAG,QAAQ,CAAC;gBACzB,CAAC;gBAED,gBAAgB;gBAChB,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;oBACnB,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;oBAChF,cAAc,CAAC,KAAK,GAAG,OAAO,CAAC;oBAC/B,WAAW,GAAG,QAAQ,CAAC;gBACzB,CAAC;gBAED,sBAAsB;gBACtB,IAAI,QAAQ,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC;oBAC1B,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;oBACtF,cAAc,CAAC,MAAM,GAAG,EAAE,GAAG,QAAQ,CAAC,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;oBAC9D,WAAW,GAAG,QAAQ,CAAC;gBACzB,CAAC;gBAED,iBAAiB;gBACjB,IAAI,QAAQ,CAAC,MAAM,IAAI,QAAQ,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAClD,cAAc,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;wBACzD,MAAM,cAAc,GAAQ,EAAE,GAAG,KAAK,EAAE,CAAC;wBACzC,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;4BAChB,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;4BAC7E,cAAc,CAAC,KAAK,GAAG,OAAO,CAAC;4BAC/B,WAAW,GAAG,QAAQ,CAAC;wBACzB,CAAC;wBACD,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;4BACf,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;4BAC5E,cAAc,CAAC,IAAI,GAAG,OAAO,CAAC;4BAC9B,WAAW,GAAG,QAAQ,CAAC;wBACzB,CAAC;wBACD,OAAO,cAAc,CAAC;oBACxB,CAAC,CAAC,CAAC;gBACL,CAAC;gBAED,OAAO,cAAc,CAAC;YACxB,CAAC,CAAC,CAAC;QACL,CAAC;QAED,gCAAgC;QAChC,IAAI,WAAW,CAAC,KAAK,EAAE,MAAM,IAAI,WAAW,CAAC,KAAK,EAAE,MAAM,IAAI,WAAW,CAAC,QAAQ,EAAE,CAAC;YACnF,MAAM,CAAC,QAAQ,GAAG,WAAW,CAAC;QAChC,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;OAEG;IACH,QAAQ,CAAC,KAAa;QACpB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,OAAO,CAAI,MAAc,EAAE,IAAY,EAAE,IAAU;QAC/D,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,OAAO,GAAG,IAAI,EAAE,CAAC;QAErC,YAAY;QACZ,OAAO,CAAC,GAAG,CAAC,UAAU,MAAM,IAAI,GAAG,EAAE,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAEzE,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,EAAE;YAChC,MAAM;YACN,OAAO,EAAE;gBACP,eAAe,EAAE,OAAO,IAAI,CAAC,KAAK,EAAE;gBACpC,cAAc,EAAE,kBAAkB;aACnC;YACD,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS;SAC9C,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,KAAK,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YACpC,MAAM,IAAI,KAAK,CAAC,aAAa,QAAQ,CAAC,MAAM,KAAK,KAAK,EAAE,CAAC,CAAC;QAC5D,CAAC;QAED,yBAAyB;QACzB,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;QACnC,IAAI,CAAC,IAAI;YAAE,OAAO,EAAO,CAAC;QAE1B,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAED,qDAAqD;IAErD;;;;;;;;;;;;;;;OAeG;IACH,KAAK,CAAC,aAAa,CAAC,kBAA0B,EAAE,eAQ/C,EAAE,IAQF;QACC,sBAAsB;QACtB,2EAA2E;QAC3E,gFAAgF;QAEhF,IAAI,OAAe,CAAC;QACpB,IAAI,SAAiB,CAAC;QACtB,IAAI,WAAgB,CAAC;QAErB,IAAI,OAAO,eAAe,KAAK,QAAQ,IAAI,IAAI,EAAE,CAAC;YAChD,uDAAuD;YACvD,OAAO,GAAG,kBAAkB,CAAC;YAC7B,SAAS,GAAG,eAAe,CAAC;YAC5B,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;YAE5C,iCAAiC;YACjC,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;gBACvB,WAAW,CAAC,cAAc,GAAG,IAAI,CAAC,aAAa,CAAC;YAClD,CAAC;QACH,CAAC;aAAM,IAAI,OAAO,eAAe,KAAK,QAAQ,EAAE,CAAC;YAC/C,4DAA4D;YAC5D,8CAA8C;YAC9C,MAAM,IAAI,KAAK,CAAC,yEAAyE,CAAC,CAAC;QAC7F,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC;QACrD,CAAC;QAED,OAAO,IAAI,CAAC,OAAO,CAAa,MAAM,EAAE,eAAe,OAAO,aAAa,SAAS,WAAW,EAAE,WAAW,CAAC,CAAC;IAChH,CAAC;IAED;;;;;;;;;OASG;IACH,KAAK,CAAC,sBAAsB,CAAC,OAAe,EAAE,SAAiB,EAAE,YAA6B,EAAE,IAG/F;QACC,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;QAElD,OAAO,IAAI,CAAC,OAAO,CAAoD,MAAM,EAAE,eAAe,OAAO,aAAa,SAAS,WAAW,EAAE;YACtI,GAAG,WAAW;YACd,KAAK,EAAE,EAAE,EAAE,iBAAiB;YAC5B,cAAc,EAAE,OAAO,YAAY,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,YAAY;SAC7F,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,eAAe,CAAC,SAAiB,EAAE,IAGxC;QACC,OAAO,IAAI,CAAC,OAAO,CAAa,MAAM,EAAE,WAAW,SAAS,EAAE,EAAE,IAAI,CAAC,CAAC;IACxE,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,WAAW,CAAC,OAAe,EAAE,SAAiB,EAAE,SAAiB,EAAE,IAKxE;QACC,MAAM,IAAI,GAAG,eAAe,OAAO,aAAa,SAAS,aAAa,SAAS,EAAE,CAAC;QAClF,MAAM,aAAa,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;QACpD,OAAO,IAAI,CAAC,OAAO,CAAa,OAAO,EAAE,IAAI,EAAE,aAAa,CAAC,CAAC;IAChE,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,aAAa,CAAC,OAAe,EAAE,SAAiB,EAAE,SAAiB;QACvE,MAAM,IAAI,GAAG,eAAe,OAAO,aAAa,SAAS,aAAa,SAAS,EAAE,CAAC;QAClF,MAAM,IAAI,CAAC,OAAO,CAAO,QAAQ,EAAE,IAAI,CAAC,CAAC;IAC3C,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,WAAW,CAAC,OAAe,EAAE,SAAiB,EAAE,SAAiB,EAAE,KAAa;QACpF,MAAM,IAAI,GAAG,eAAe,OAAO,aAAa,SAAS,aAAa,SAAS,cAAc,kBAAkB,CAAC,KAAK,CAAC,MAAM,CAAC;QAC7H,MAAM,IAAI,CAAC,OAAO,CAAO,KAAK,EAAE,IAAI,CAAC,CAAC;IACxC,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,gBAAgB,CAAC,OAAe,EAAE,SAAiB,EAAE,IAA0D;QACnH,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;QACtC,MAAM,IAAI,GAAG,IAAI,QAAQ,EAAE,CAAC;QAE5B,qDAAqD;QACrD,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,EAAE;YAC7B,QAAQ,EAAE,IAAI,CAAC,IAAI;YACnB,WAAW,EAAE,IAAI,CAAC,WAAW,IAAI,YAAY;SAC9C,CAAC,CAAC;QAEH,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,OAAO,eAAe,OAAO,aAAa,SAAS,cAAc,CAAC;QAEtF,OAAO,CAAC,GAAG,CAAC,gCAAgC,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,SAAS,CAAC,CAAC;QAErF,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,EAAE;YAChC,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACP,eAAe,EAAE,OAAO,IAAI,CAAC,KAAK,EAAE;gBACpC,GAAG,IAAI,CAAC,UAAU,EAAE;aACrB;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,EAAE;SACvB,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,KAAK,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YACpC,MAAM,IAAI,KAAK,CAAC,aAAa,QAAQ,CAAC,MAAM,KAAK,KAAK,EAAE,CAAC,CAAC;QAC5D,CAAC;QAED,OAAO,QAAQ,CAAC,IAAI,EAA4D,CAAC;IACnF,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,qBAAqB,CAAC,OAAe,EAAE,SAAiB,EAAE,IAI/D;QACC,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;QACtC,MAAM,IAAI,GAAG,IAAI,QAAQ,EAAE,CAAC;QAE5B,0BAA0B;QAC1B,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QACvC,CAAC;QAED,kEAAkE;QAClE,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QACpD,CAAC;QAED,WAAW;QACX,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;YACnC,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI;YACxB,WAAW,EAAE,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,YAAY;SACnD,CAAC,CAAC;QAEH,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,OAAO,eAAe,OAAO,aAAa,SAAS,WAAW,CAAC;QAEnF,OAAO,CAAC,GAAG,CAAC,sCAAsC,IAAI,CAAC,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,UAAU,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,kBAAkB,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAEzK,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,EAAE;YAChC,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACP,eAAe,EAAE,OAAO,IAAI,CAAC,KAAK,EAAE;gBACpC,GAAG,IAAI,CAAC,UAAU,EAAE;aACrB;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,EAAE;SACvB,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,KAAK,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YACpC,MAAM,IAAI,KAAK,CAAC,aAAa,QAAQ,CAAC,MAAM,KAAK,KAAK,EAAE,CAAC,CAAC;QAC5D,CAAC;QAED,OAAO,QAAQ,CAAC,IAAI,EAAyB,CAAC;IAChD,CAAC;IAED,yDAAyD;IAEzD;;;OAGG;IACH,KAAK,CAAC,yBAAyB,CAAC,aAAqB,EAAE,KAAa,EAAE,IAGrE;QACC,OAAO,CAAC,GAAG,CAAC,4BAA4B,aAAa,YAAY,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QAC9E,IAAI,CAAC;YACH,+CAA+C;YAC/C,IAAI,aAAa,GAAG,IAAI,CAAC;YACzB,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;gBACzD,aAAa,GAAG;oBACd,GAAG,IAAI;oBACP,IAAI,EAAE,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC;iBACzC,CAAC;YACJ,CAAC;YAED,MAAM,IAAI,CAAC,OAAO,CAAO,MAAM,EAAE,iBAAiB,aAAa,IAAI,KAAK,WAAW,EAAE,aAAa,CAAC,CAAC;YACpG,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC;QAC7C,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,+BAA+B,EAAE,KAAK,CAAC,CAAC;YACtD,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,uBAAuB,CAAC,KAAa,EAAE,IAM5C,EAAE,OAAgB,EAAE,SAAkB,EAAE,aAAsB;QAC7D,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAEtC,8BAA8B;QAC9B,MAAM,aAAa,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;QAEpD,wFAAwF;QACxF,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,OAAO,IAAI,SAAS,EAAE,CAAC;YAChE,OAAO,CAAC,GAAG,CAAC,uCAAuC,IAAI,CAAC,KAAK,CAAC,MAAM,sCAAsC,CAAC,CAAC;YAE5G,2BAA2B;YAC3B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,+BAA+B;YAC3D,MAAM,IAAI,CAAC,qBAAqB,CAAC,OAAO,EAAE,SAAS,EAAE;gBACnD,OAAO,EAAE,aAAa,CAAC,OAAO;gBAC9B,IAAI,EAAE,IAAI;gBACV,aAAa,EAAE,aAAa;aAC7B,CAAC,CAAC;YACH,OAAO;QACT,CAAC;QAED,4FAA4F;QAC5F,wEAAwE;QACxE,IAAI,OAAO,IAAI,SAAS,IAAI,aAAa,EAAE,CAAC;YAC1C,OAAO,CAAC,GAAG,CAAC,0EAA0E,aAAa,EAAE,CAAC,CAAC;YAEvG,MAAM,OAAO,GAAQ;gBACnB,cAAc,EAAE,aAAa;aAC9B,CAAC;YACF,IAAI,aAAa,CAAC,OAAO,KAAK,SAAS;gBAAE,OAAO,CAAC,OAAO,GAAG,aAAa,CAAC,OAAO,CAAC;YACjF,IAAI,aAAa,CAAC,MAAM;gBAAE,OAAO,CAAC,MAAM,GAAG,aAAa,CAAC,MAAM,CAAC;YAChE,IAAI,aAAa,CAAC,UAAU;gBAAE,OAAO,CAAC,UAAU,GAAG,aAAa,CAAC,UAAU,CAAC;YAC5E,IAAI,aAAa,CAAC,QAAQ;gBAAE,OAAO,CAAC,QAAQ,GAAG,aAAa,CAAC,QAAQ,CAAC;YAEtE,MAAM,IAAI,CAAC,OAAO,CAAO,MAAM,EAAE,eAAe,OAAO,aAAa,SAAS,WAAW,EAAE,OAAO,CAAC,CAAC;YACnG,OAAO;QACT,CAAC;QAED,uDAAuD;QACvD,MAAM,OAAO,GAAQ,EAAE,CAAC;QACxB,IAAI,aAAa,CAAC,OAAO,KAAK,SAAS;YAAE,OAAO,CAAC,OAAO,GAAG,aAAa,CAAC,OAAO,CAAC;QACjF,IAAI,aAAa,CAAC,MAAM;YAAE,OAAO,CAAC,MAAM,GAAG,aAAa,CAAC,MAAM,CAAC;QAChE,IAAI,aAAa,CAAC,UAAU;YAAE,OAAO,CAAC,UAAU,GAAG,aAAa,CAAC,UAAU,CAAC;QAC5E,IAAI,aAAa,CAAC,QAAQ;YAAE,OAAO,CAAC,QAAQ,GAAG,aAAa,CAAC,QAAQ,CAAC;QAEtE,MAAM,IAAI,CAAC,OAAO,CAAO,OAAO,EAAE,aAAa,KAAK,IAAI,KAAK,qBAAqB,EAAE,OAAO,CAAC,CAAC;IAC/F,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,yBAAyB,CAAC,KAAa;QAC3C,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACtC,MAAM,IAAI,CAAC,OAAO,CAAO,QAAQ,EAAE,aAAa,KAAK,IAAI,KAAK,qBAAqB,CAAC,CAAC;IACvF,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,cAAc,CAAC,KAAa,EAAE,IAKnC;QACC,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACtC,MAAM,aAAa,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;QACpD,MAAM,IAAI,CAAC,OAAO,CAAO,MAAM,EAAE,aAAa,KAAK,IAAI,KAAK,EAAE,EAAE,aAAa,CAAC,CAAC;IACjF,CAAC;IAED,qDAAqD;IAErD;;OAEG;IACH,KAAK,CAAC,sBAAsB,CAAC,QAAiC;QAC5D,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAEtC,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;YAC/B,MAAM,IAAI,CAAC,OAAO,CAAO,MAAM,EAAE,iBAAiB,KAAK,WAAW,EAAE,OAAO,CAAC,CAAC;QAC/E,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,qBAAqB,CAAC,OAAe,EAAE,QAAiC;QAC5E,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAEtC,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;YAC/B,MAAM,IAAI,CAAC,OAAO,CAAO,MAAM,EAAE,iBAAiB,KAAK,WAAW,OAAO,WAAW,EAAE,OAAO,CAAC,CAAC;QACjG,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,mBAAmB,CAAC,SAAiB;QACzC,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACtC,MAAM,IAAI,CAAC,OAAO,CAAO,QAAQ,EAAE,iBAAiB,KAAK,aAAa,SAAS,EAAE,CAAC,CAAC;IACrF,CAAC;IAED,oDAAoD;IAE5C,aAAa,GAAW,EAAE,CAAC;IAEnC;;OAEG;IACH,gBAAgB,CAAC,EAAU;QACzB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;IAC1B,CAAC;IAED;;OAEG;IACK,gBAAgB;QACtB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YACxB,MAAM,IAAI,KAAK,CAAC,wDAAwD,CAAC,CAAC;QAC5E,CAAC;QACD,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED,qDAAqD;IAErD;;OAEG;IACH,KAAK,CAAC,aAAa,CAAC,OAAe,EAAE,IAWpC;QACC,yDAAyD;QACzD,MAAM,WAAW,GAAQ;YACvB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,IAAI,EAAE,IAAI,CAAC,IAAI,IAAI,CAAC,EAAE,0BAA0B;SACjD,CAAC;QAEF,6CAA6C;QAC7C,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,WAAW,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QAC7C,CAAC;aAAM,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YAC1B,WAAW,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC;QAC3C,CAAC;QAED,wCAAwC;QACxC,IAAI,IAAI,CAAC,qBAAqB,IAAI,IAAI,CAAC,qBAAqB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACxE,WAAW,CAAC,qBAAqB,GAAG,IAAI,CAAC,qBAAqB,CAAC;QACjE,CAAC;QAED,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,OAAO,WAAW,EAAE,WAAW,CAAC,CAAC;IAC9E,CAAC;IAED;;OAEG;IACH;;OAEG;IACH,KAAK,CAAC,aAAa,CAAC,OAAe,EAAE,SAAiB;QACpD,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,eAAe,OAAO,aAAa,SAAS,EAAE,CAAC,CAAC;IAC/E,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,sBAAsB,CAAC,SAAiB,EAAE,WAAmB,EAAE,IAIpE;QACC,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,iBAAiB,SAAS,gBAAgB,WAAW,EAAE,EAAE,IAAI,CAAC,CAAC;IAC3F,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,uBAAuB,CAAC,SAAiB,EAAE,WAAmB;QAClE,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,iBAAiB,SAAS,gBAAgB,WAAW,EAAE,CAAC,CAAC;IACxF,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,WAAW,CAAC,OAAe,EAAE,SAAiB,EAAE,OAIrD;QACC,MAAM,MAAM,GAAG,IAAI,eAAe,EAAE,CAAC;QACrC,IAAI,OAAO,EAAE,KAAK;YAAE,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;QAClE,IAAI,OAAO,EAAE,MAAM;YAAE,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;QAC7D,IAAI,OAAO,EAAE,KAAK;YAAE,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;QAE1D,MAAM,KAAK,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC/D,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,OAAO,CAA6C,KAAK,EAAE,eAAe,OAAO,aAAa,SAAS,YAAY,KAAK,EAAE,CAAC,CAAC;QACxJ,OAAO,QAAQ,CAAC,QAAQ,IAAI,EAAE,CAAC;IACjC,CAAC;IAED,oDAAoD;IAEpD;;OAEG;IACH,KAAK,CAAC,SAAS,CAAC,OAAe,EAAE,MAAc;QAC7C,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,OAAO,YAAY,MAAM,EAAE,CAAC,CAAC;IACzE,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,aAAa,CAAC,OAAe,EAAE,MAAc,EAAE,QAAuB,EAAE,MAAe;QAC3F,IAAI,QAAQ,KAAK,IAAI,EAAE,CAAC;YACtB,gBAAgB;YAChB,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,OAAO,YAAY,MAAM,gBAAgB,EAAE;gBACnF,MAAM;aACP,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,cAAc;YACd,MAAM,KAAK,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;YAC5D,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,OAAO,YAAY,MAAM,UAAU,EAAE;gBAC7E,KAAK;gBACL,MAAM;aACP,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,UAAU,CAAC,OAAe,EAAE,MAAc,EAAE,MAAe;QAC/D,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,WAAW,kBAAkB,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACpE,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,eAAe,OAAO,YAAY,MAAM,GAAG,KAAK,EAAE,CAAC,CAAC;IACnF,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,SAAS,CAAC,OAAe,EAAE,MAAc,EAAE,OAIhD;QACC,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,OAAO,SAAS,MAAM,EAAE,EAAE;YACjE,mBAAmB,EAAE,OAAO,EAAE,iBAAiB;YAC/C,sBAAsB,EAAE,OAAO,EAAE,oBAAoB;YACrD,MAAM,EAAE,OAAO,EAAE,MAAM;SACxB,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,WAAW,CAAC,OAAe,EAAE,MAAc,EAAE,MAAe;QAChE,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,WAAW,kBAAkB,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACpE,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,eAAe,OAAO,SAAS,MAAM,GAAG,KAAK,EAAE,CAAC,CAAC;IAChF,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,UAAU,CAAC,OAAe,EAAE,MAAc,EAAE,IAQjD;QACC,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,eAAe,OAAO,YAAY,MAAM,EAAE,EAAE,IAAI,CAAC,CAAC;IACjF,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,aAAa,CAAC,OAAe,EAAE,MAAc,EAAE,MAAc,EAAE,MAAe;QAClF,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,WAAW,kBAAkB,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACpE,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,OAAO,YAAY,MAAM,UAAU,MAAM,GAAG,KAAK,EAAE,CAAC,CAAC;IAChG,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,gBAAgB,CAAC,OAAe,EAAE,MAAc,EAAE,MAAc,EAAE,MAAe;QACrF,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,WAAW,kBAAkB,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACpE,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,eAAe,OAAO,YAAY,MAAM,UAAU,MAAM,GAAG,KAAK,EAAE,CAAC,CAAC;IACnG,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,kBAAkB,CAAC,OAAe,EAAE,SAAiB,EAAE,UAAoB;QAC/E,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,OAAO,aAAa,SAAS,uBAAuB,EAAE;YAC9F,QAAQ,EAAE,UAAU;SACrB,CAAC,CAAC;IACL,CAAC;IAED,mDAAmD;IAEnD;;OAEG;IACH,KAAK,CAAC,QAAQ,CAAC,OAAe;QAC5B,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,OAAO,EAAE,CAAC,CAAC;IACvD,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,gBAAgB,CAAC,OAAe;QACpC,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,OAAO,WAAW,CAAC,CAAC;IAChE,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,QAAQ,CAAC,OAAe;QAC5B,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,OAAO,QAAQ,CAAC,CAAC;IAC7D,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,UAAU,CAAC,OAAe,EAAE,IAMjC;QACC,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,OAAO,QAAQ,EAAE,IAAI,CAAC,CAAC;IACpE,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,QAAQ,CAAC,OAAe,EAAE,MAAc,EAAE,IAM/C;QACC,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,eAAe,OAAO,UAAU,MAAM,EAAE,EAAE,IAAI,CAAC,CAAC;IAC/E,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,UAAU,CAAC,OAAe,EAAE,MAAc;QAC9C,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,eAAe,OAAO,UAAU,MAAM,EAAE,CAAC,CAAC;IACzE,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,SAAS,CAAC,OAAe;QAC7B,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,OAAO,SAAS,CAAC,CAAC;IAC9D,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,OAAO,CAAC,OAAe;QAC3B,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,OAAO,OAAO,CAAC,CAAC;IAC5D,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,MAAM,CAAC,OAAe,EAAE,MAAc;QAC1C,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,OAAO,SAAS,MAAM,EAAE,CAAC,CAAC;IACtE,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,eAAe,CAAC,OAAe;QACnC,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,OAAO,UAAU,CAAC,CAAC;IAC/D,CAAC;IAED,oDAAoD;IAEpD;;OAEG;IACH,KAAK,CAAC,uBAAuB,CAAC,OAAe,EAAE,SAAiB,EAAE,SAAiB,EAAE,IAGpF;QACC,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,OAAO,aAAa,SAAS,aAAa,SAAS,UAAU,EAAE,IAAI,CAAC,CAAC;IAClH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,YAAY,CAAC,OAAe,EAAE,SAAiB,EAAE,IAKtD;QACC,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,OAAO,aAAa,SAAS,UAAU,EAAE,IAAI,CAAC,CAAC;IAC5F,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,UAAU,CAAC,SAAiB;QAChC,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,iBAAiB,SAAS,qBAAqB,CAAC,CAAC;IAC7E,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,WAAW,CAAC,SAAiB;QACjC,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,iBAAiB,SAAS,qBAAqB,CAAC,CAAC;IAChF,CAAC;IAED,iDAAiD;IAEjD;;OAEG;IACH,KAAK,CAAC,UAAU,CAAC,OAAe,EAAE,SAAiB,EAAE,SAAiB;QACpE,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,OAAO,aAAa,SAAS,SAAS,SAAS,EAAE,CAAC,CAAC;IAC9F,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,YAAY,CAAC,OAAe,EAAE,SAAiB,EAAE,SAAiB;QACtE,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,eAAe,OAAO,aAAa,SAAS,SAAS,SAAS,EAAE,CAAC,CAAC;IACjG,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,iBAAiB,CAAC,OAAe,EAAE,SAAiB;QACxD,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,OAAO,aAAa,SAAS,OAAO,CAAC,CAAC;IAClF,CAAC;IAED,kDAAkD;IAElD;;OAEG;IACH,KAAK,CAAC,OAAO,CAAC,MAAc;QAC1B,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,cAAc,MAAM,EAAE,CAAC,CAAC;IACrD,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,cAAc;QAClB,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,gBAAgB,CAAC,CAAC;IAC/C,CAAC;IAED,oDAAoD;IAEpD;;OAEG;IACH,KAAK,CAAC,YAAY,CAAC,OAAe,EAAE,SAAiB,EAAE,IAKtD;QACC,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,OAAO,aAAa,SAAS,UAAU,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC;IAClG,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,YAAY,CAAC,UAAkB;QACnC,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,gBAAgB,UAAU,EAAE,CAAC,CAAC;IAC7D,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,SAAS,CAAC,UAAkB;QAChC,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,gBAAgB,UAAU,EAAE,CAAC,CAAC;IAC3D,CAAC;IAED,qDAAqD;IAErD;;OAEG;IACH,KAAK,CAAC,kBAAkB,CAAC,OAAe,EAAE,SAAiB;QACzD,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,OAAO,aAAa,SAAS,WAAW,CAAC,CAAC;IACtF,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,aAAa,CAAC,OAAe,EAAE,SAAiB,EAAE,IAGvD;QACC,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,OAAO,aAAa,SAAS,WAAW,EAAE,IAAI,CAAC,CAAC;IAC7F,CAAC;CACF;AA7gCD,oBA6gCC","sourcesContent":["import { APIMessage, APIApplicationCommand, APIEmbed } from '../types';\r\n\r\n/**\r\n * Mention data structure for our system\r\n */\r\nexport interface MentionUser {\r\n  id: number;\r\n  username: string;\r\n}\r\n\r\nexport interface MentionRole {\r\n  id: string;\r\n  name?: string;\r\n}\r\n\r\nexport interface MentionsData {\r\n  users?: MentionUser[];\r\n  roles?: MentionRole[];\r\n  everyone?: boolean;\r\n}\r\n\r\n/**\r\n * User cache entry\r\n */\r\ninterface CachedUser {\r\n  id: number;\r\n  username: string;\r\n  displayName?: string;\r\n  cachedAt: number;\r\n}\r\n\r\n/**\r\n * REST API client for Jubbio\r\n */\r\nexport class REST {\r\n  private baseUrl: string;\r\n  private token: string = '';\r\n  \r\n  // User cache for mention resolution (ID -> username)\r\n  private userCache: Map<number, CachedUser> = new Map();\r\n  private readonly USER_CACHE_TTL = 5 * 60 * 1000; // 5 dakika\r\n\r\n  constructor(baseUrl: string = 'https://gateway.jubbio.com/api/v1') {\r\n    this.baseUrl = baseUrl;\r\n  }\r\n\r\n  // ==================== Mention Helpers ====================\r\n\r\n  /**\r\n   * Cache a user for mention resolution\r\n   * Bot'lar interaction'dan gelen user bilgisini cache'leyebilir\r\n   */\r\n  cacheUser(user: { id: string | number; username: string; displayName?: string; display_name?: string }): void {\r\n    const userId = typeof user.id === 'string' ? parseInt(user.id, 10) : user.id;\r\n    this.userCache.set(userId, {\r\n      id: userId,\r\n      username: user.username,\r\n      displayName: user.displayName || user.display_name,\r\n      cachedAt: Date.now()\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Cache multiple users\r\n   */\r\n  cacheUsers(users: Array<{ id: string | number; username: string; displayName?: string; display_name?: string }>): void {\r\n    users.forEach(user => this.cacheUser(user));\r\n  }\r\n\r\n  /**\r\n   * Get cached user by ID\r\n   */\r\n  getCachedUser(userId: number): CachedUser | undefined {\r\n    const cached = this.userCache.get(userId);\r\n    if (cached && Date.now() - cached.cachedAt < this.USER_CACHE_TTL) {\r\n      return cached;\r\n    }\r\n    // Expired, remove from cache\r\n    if (cached) {\r\n      this.userCache.delete(userId);\r\n    }\r\n    return undefined;\r\n  }\r\n\r\n  /**\r\n   * Format a user mention\r\n   * Returns both the text format and mentions data\r\n   * \r\n   * @example\r\n   * const mention = rest.formatMention(user);\r\n   * // mention.text = \"@ilkay\"\r\n   * // mention.data = { users: [{ id: 1, username: \"ilkay\" }] }\r\n   */\r\n  formatMention(user: { id: string | number; username: string }): { text: string; data: MentionsData } {\r\n    const userId = typeof user.id === 'string' ? parseInt(user.id, 10) : user.id;\r\n    return {\r\n      text: `@${user.username}`,\r\n      data: {\r\n        users: [{ id: userId, username: user.username }]\r\n      }\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Parse mentions (<@ID>) and convert to our format (@username)\r\n   * Also builds the mentions data structure\r\n   * \r\n   * @param content - Message content with mentions\r\n   * @param existingMentions - Existing mentions data to merge with\r\n   * @returns Processed content and mentions data\r\n   */\r\n  private processMentions(content: string, existingMentions?: MentionsData): { content: string; mentions: MentionsData } {\r\n    const mentions: MentionsData = {\r\n      users: [...(existingMentions?.users || [])],\r\n      roles: [...(existingMentions?.roles || [])],\r\n      everyone: existingMentions?.everyone\r\n    };\r\n\r\n    // Track already added user IDs to avoid duplicates\r\n    const addedUserIds = new Set(mentions.users?.map(u => u.id) || []);\r\n\r\n    // Parse <@ID> format (user mentions)\r\n    const userMentionRegex = /<@!?(\\d+)>/g;\r\n    let processedContent = content;\r\n    let match;\r\n\r\n    while ((match = userMentionRegex.exec(content)) !== null) {\r\n      const userId = parseInt(match[1], 10);\r\n      const fullMatch = match[0];\r\n\r\n      // Try to get username from cache\r\n      const cachedUser = this.getCachedUser(userId);\r\n      \r\n      if (cachedUser) {\r\n        // Replace <@ID> with @username\r\n        processedContent = processedContent.replace(fullMatch, `@${cachedUser.username}`);\r\n        \r\n        // Add to mentions if not already added\r\n        if (!addedUserIds.has(userId)) {\r\n          mentions.users!.push({ id: userId, username: cachedUser.username });\r\n          addedUserIds.add(userId);\r\n        }\r\n      } else {\r\n        // User not in cache - keep as @User_ID format (backend will resolve)\r\n        processedContent = processedContent.replace(fullMatch, `@User_${userId}`);\r\n        \r\n        // Still add to mentions with placeholder username\r\n        if (!addedUserIds.has(userId)) {\r\n          mentions.users!.push({ id: userId, username: `User_${userId}` });\r\n          addedUserIds.add(userId);\r\n        }\r\n      }\r\n    }\r\n\r\n    // Parse <@&ID> format (role mentions)\r\n    const roleMentionRegex = /<@&(\\d+)>/g;\r\n    const addedRoleIds = new Set(mentions.roles?.map(r => r.id) || []);\r\n\r\n    while ((match = roleMentionRegex.exec(content)) !== null) {\r\n      const roleId = match[1];\r\n      const fullMatch = match[0];\r\n\r\n      // Replace with @role format (backend handles role resolution)\r\n      processedContent = processedContent.replace(fullMatch, `@role_${roleId}`);\r\n      \r\n      if (!addedRoleIds.has(roleId)) {\r\n        mentions.roles!.push({ id: roleId });\r\n        addedRoleIds.add(roleId);\r\n      }\r\n    }\r\n\r\n    // Parse @everyone and @here\r\n    if (content.includes('@everyone')) {\r\n      mentions.everyone = true;\r\n    }\r\n\r\n    // Clean up empty arrays\r\n    if (mentions.users?.length === 0) delete mentions.users;\r\n    if (mentions.roles?.length === 0) delete mentions.roles;\r\n\r\n    return { content: processedContent, mentions };\r\n  }\r\n\r\n  /**\r\n   * Prepare message data with processed mentions\r\n   * Automatically converts mentions to our format\r\n   */\r\n  private prepareMessageData(data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    message_reference?: { message_id: string };\r\n  }): any {\r\n    const result: any = { ...data };\r\n\r\n    // Resolve components (ActionRowBuilder / ButtonBuilder instances)\r\n    if (data.components && data.components.length > 0) {\r\n      result.components = data.components.map((c: any) =>\r\n        typeof c.toJSON === 'function' ? c.toJSON() : c\r\n      );\r\n    }\r\n\r\n    let allMentions: MentionsData = { ...data.mentions };\r\n\r\n    // Process mentions in content if present\r\n    if (data.content) {\r\n      const { content, mentions } = this.processMentions(data.content, allMentions);\r\n      result.content = content;\r\n      allMentions = mentions;\r\n    }\r\n\r\n    // Process mentions in embeds (description, title, footer, fields)\r\n    if (data.embeds && data.embeds.length > 0) {\r\n      result.embeds = data.embeds.map(embed => {\r\n        // Support EmbedBuilder instances - extract raw data via toJSON()\r\n        const rawEmbed = typeof (embed as any).toJSON === 'function' ? (embed as any).toJSON() : embed;\r\n        const processedEmbed: any = { ...rawEmbed };\r\n        \r\n        // Process description\r\n        if (rawEmbed.description) {\r\n          const { content, mentions } = this.processMentions(rawEmbed.description, allMentions);\r\n          processedEmbed.description = content;\r\n          allMentions = mentions;\r\n        }\r\n        \r\n        // Process title\r\n        if (rawEmbed.title) {\r\n          const { content, mentions } = this.processMentions(rawEmbed.title, allMentions);\r\n          processedEmbed.title = content;\r\n          allMentions = mentions;\r\n        }\r\n        \r\n        // Process footer text\r\n        if (rawEmbed.footer?.text) {\r\n          const { content, mentions } = this.processMentions(rawEmbed.footer.text, allMentions);\r\n          processedEmbed.footer = { ...rawEmbed.footer, text: content };\r\n          allMentions = mentions;\r\n        }\r\n        \r\n        // Process fields\r\n        if (rawEmbed.fields && rawEmbed.fields.length > 0) {\r\n          processedEmbed.fields = rawEmbed.fields.map((field: any) => {\r\n            const processedField: any = { ...field };\r\n            if (field.value) {\r\n              const { content, mentions } = this.processMentions(field.value, allMentions);\r\n              processedField.value = content;\r\n              allMentions = mentions;\r\n            }\r\n            if (field.name) {\r\n              const { content, mentions } = this.processMentions(field.name, allMentions);\r\n              processedField.name = content;\r\n              allMentions = mentions;\r\n            }\r\n            return processedField;\r\n          });\r\n        }\r\n        \r\n        return processedEmbed;\r\n      });\r\n    }\r\n\r\n    // Add merged mentions to result\r\n    if (allMentions.users?.length || allMentions.roles?.length || allMentions.everyone) {\r\n      result.mentions = allMentions;\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  /**\r\n   * Set the bot token\r\n   */\r\n  setToken(token: string): this {\r\n    this.token = token;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Make an authenticated request\r\n   */\r\n  private async request<T>(method: string, path: string, body?: any): Promise<T> {\r\n    const url = `${this.baseUrl}${path}`;\r\n    \r\n    // Debug log\r\n    console.log(`[REST] ${method} ${url}`, body ? JSON.stringify(body) : '');\r\n    \r\n    const response = await fetch(url, {\r\n      method,\r\n      headers: {\r\n        'Authorization': `Bot ${this.token}`,\r\n        'Content-Type': 'application/json'\r\n      },\r\n      body: body ? JSON.stringify(body) : undefined\r\n    });\r\n\r\n    if (!response.ok) {\r\n      const error = await response.text();\r\n      throw new Error(`API Error ${response.status}: ${error}`);\r\n    }\r\n\r\n    // Handle empty responses\r\n    const text = await response.text();\r\n    if (!text) return {} as T;\r\n    \r\n    return JSON.parse(text);\r\n  }\r\n\r\n  // ==================== Messages ====================\r\n\r\n  /**\r\n   * Create a message in a channel\r\n   * Automatically processes mentions (<@ID>) to our format (@username)\r\n   * \r\n   * @example\r\n   * // Mention style (auto-converted):\r\n   * await rest.createMessage(guildId, channelId, {\r\n   *   content: 'Hello <@123>!',  // Becomes \"Hello @username!\"\r\n   * });\r\n   * \r\n   * // Our native format:\r\n   * await rest.createMessage(guildId, channelId, {\r\n   *   content: 'Hello @ilkay!',\r\n   *   mentions: { users: [{ id: 123, username: 'ilkay' }] }\r\n   * });\r\n   */\r\n  async createMessage(guildIdOrChannelId: string, channelIdOrData: string | {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    files?: Array<{ name: string; data: Buffer }>;\r\n    message_reference?: { message_id: string };\r\n    interactionId?: string;\r\n  }, data?: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    files?: Array<{ name: string; data: Buffer }>;\r\n    message_reference?: { message_id: string };\r\n    interactionId?: string;\r\n  }): Promise<APIMessage> {\r\n    // İki kullanım şekli:\r\n    // 1. createMessage(guildId, channelId, data) - guildId ile (tercih edilen)\r\n    // 2. createMessage(channelId, data) - guildId olmadan (eski format, hata verir)\r\n    \r\n    let guildId: string;\r\n    let channelId: string;\r\n    let messageData: any;\r\n    \r\n    if (typeof channelIdOrData === 'string' && data) {\r\n      // Yeni format: createMessage(guildId, channelId, data)\r\n      guildId = guildIdOrChannelId;\r\n      channelId = channelIdOrData;\r\n      messageData = this.prepareMessageData(data);\r\n      \r\n      // Add interaction_id if provided\r\n      if (data.interactionId) {\r\n        messageData.interaction_id = data.interactionId;\r\n      }\r\n    } else if (typeof channelIdOrData === 'object') {\r\n      // Eski format: createMessage(channelId, data) - guildId yok\r\n      // Bu format artık desteklenmiyor, hata fırlat\r\n      throw new Error('createMessage requires guildId: createMessage(guildId, channelId, data)');\r\n    } else {\r\n      throw new Error('Invalid createMessage arguments');\r\n    }\r\n    \r\n    return this.request<APIMessage>('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages`, messageData);\r\n  }\r\n\r\n  /**\r\n   * Create an ephemeral message that is only visible to a specific user\r\n   * Ephemeral messages are NOT saved to database - they are only sent via WebSocket\r\n   * \r\n   * @example\r\n   * // Send a warning only visible to the user\r\n   * await rest.createEphemeralMessage(guildId, channelId, targetUserId, {\r\n   *   embeds: [warningEmbed]\r\n   * });\r\n   */\r\n  async createEphemeralMessage(guildId: string, channelId: string, targetUserId: string | number, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n  }): Promise<{ id: string; ephemeral: boolean; flags: number }> {\r\n    const messageData = this.prepareMessageData(data);\r\n    \r\n    return this.request<{ id: string; ephemeral: boolean; flags: number }>('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages`, {\r\n      ...messageData,\r\n      flags: 64, // EPHEMERAL flag\r\n      target_user_id: typeof targetUserId === 'string' ? parseInt(targetUserId, 10) : targetUserId\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Create a DM message\r\n   */\r\n  async createDMMessage(channelId: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n  }): Promise<APIMessage> {\r\n    return this.request<APIMessage>('POST', `/bot/dm/${channelId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Edit a message\r\n   * Automatically processes mentions\r\n   */\r\n  async editMessage(guildId: string, channelId: string, messageId: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n  }): Promise<APIMessage> {\r\n    const path = `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}`;\r\n    const processedData = this.prepareMessageData(data);\r\n    return this.request<APIMessage>('PATCH', path, processedData);\r\n  }\r\n\r\n  /**\r\n   * Delete a message\r\n   */\r\n  async deleteMessage(guildId: string, channelId: string, messageId: string): Promise<void> {\r\n    const path = `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}`;\r\n    await this.request<void>('DELETE', path);\r\n  }\r\n\r\n  /**\r\n   * Add a reaction to a message\r\n   */\r\n  async addReaction(guildId: string, channelId: string, messageId: string, emoji: string): Promise<void> {\r\n    const path = `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}/reactions/${encodeURIComponent(emoji)}/@me`;\r\n    await this.request<void>('PUT', path);\r\n  }\r\n\r\n  /**\r\n   * Upload an attachment to a channel\r\n   */\r\n  async uploadAttachment(guildId: string, channelId: string, file: { name: string; data: Buffer; contentType?: string }): Promise<{ id: string; url: string; filename: string }> {\r\n    const FormData = require('form-data');\r\n    const form = new FormData();\r\n    \r\n    // form-data expects the buffer directly with options\r\n    form.append('file', file.data, {\r\n      filename: file.name,\r\n      contentType: file.contentType || 'text/plain'\r\n    });\r\n    \r\n    const url = `${this.baseUrl}/bot/guilds/${guildId}/channels/${channelId}/attachments`;\r\n    \r\n    console.log(`[REST] Uploading attachment: ${file.name} (${file.data.length} bytes)`);\r\n    \r\n    const response = await fetch(url, {\r\n      method: 'POST',\r\n      headers: {\r\n        'Authorization': `Bot ${this.token}`,\r\n        ...form.getHeaders()\r\n      },\r\n      body: form.getBuffer()\r\n    });\r\n    \r\n    if (!response.ok) {\r\n      const error = await response.text();\r\n      throw new Error(`API Error ${response.status}: ${error}`);\r\n    }\r\n    \r\n    return response.json() as Promise<{ id: string; url: string; filename: string }>;\r\n  }\r\n\r\n  /**\r\n   * Create a message with a file attachment\r\n   */\r\n  async createMessageWithFile(guildId: string, channelId: string, data: {\r\n    content?: string;\r\n    file: { name: string; data: Buffer; contentType?: string };\r\n    interactionId?: string;\r\n  }): Promise<APIMessage> {\r\n    const FormData = require('form-data');\r\n    const form = new FormData();\r\n    \r\n    // Add content if provided\r\n    if (data.content) {\r\n      form.append('content', data.content);\r\n    }\r\n    \r\n    // Add interaction_id if provided (for deferred response matching)\r\n    if (data.interactionId) {\r\n      form.append('interaction_id', data.interactionId);\r\n    }\r\n    \r\n    // Add file\r\n    form.append('files', data.file.data, {\r\n      filename: data.file.name,\r\n      contentType: data.file.contentType || 'text/plain'\r\n    });\r\n    \r\n    const url = `${this.baseUrl}/bot/guilds/${guildId}/channels/${channelId}/messages`;\r\n    \r\n    console.log(`[REST] Creating message with file: ${data.file.name} (${data.file.data.length} bytes)${data.interactionId ? ` [interaction: ${data.interactionId}]` : ''}`);\r\n    \r\n    const response = await fetch(url, {\r\n      method: 'POST',\r\n      headers: {\r\n        'Authorization': `Bot ${this.token}`,\r\n        ...form.getHeaders()\r\n      },\r\n      body: form.getBuffer()\r\n    });\r\n    \r\n    if (!response.ok) {\r\n      const error = await response.text();\r\n      throw new Error(`API Error ${response.status}: ${error}`);\r\n    }\r\n    \r\n    return response.json() as Promise<APIMessage>;\r\n  }\r\n\r\n  // ==================== Interactions ====================\r\n\r\n  /**\r\n   * Create an interaction response\r\n   * Automatically processes mentions in content and embeds\r\n   */\r\n  async createInteractionResponse(interactionId: string, token: string, data: {\r\n    type: number;\r\n    data?: any;\r\n  }): Promise<void> {\r\n    console.log(`📤 Interaction response: ${interactionId} -> type ${data.type}`);\r\n    try {\r\n      // Process mentions in response data if present\r\n      let processedData = data;\r\n      if (data.data && (data.data.content || data.data.embeds)) {\r\n        processedData = {\r\n          ...data,\r\n          data: this.prepareMessageData(data.data)\r\n        };\r\n      }\r\n      \r\n      await this.request<void>('POST', `/interactions/${interactionId}/${token}/callback`, processedData);\r\n      console.log(`✅ Interaction response sent`);\r\n    } catch (error) {\r\n      console.error(`❌ Interaction response error:`, error);\r\n      throw error;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Edit the original interaction response\r\n   * If files are provided, creates a new message with files (since webhook edit doesn't support file upload)\r\n   * Automatically processes mentions\r\n   */\r\n  async editInteractionResponse(token: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    files?: Array<{ name: string; data: Buffer; contentType?: string }>;\r\n  }, guildId?: string, channelId?: string, interactionId?: string): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    \r\n    // Process mentions in content\r\n    const processedData = this.prepareMessageData(data);\r\n    \r\n    // If files are present and we have guild/channel info, create message with file instead\r\n    if (data.files && data.files.length > 0 && guildId && channelId) {\r\n      console.log(`[REST] editInteractionResponse with ${data.files.length} files - using createMessageWithFile`);\r\n      \r\n      // Create message with file\r\n      const file = data.files[0]; // For now, support single file\r\n      await this.createMessageWithFile(guildId, channelId, {\r\n        content: processedData.content,\r\n        file: file,\r\n        interactionId: interactionId\r\n      });\r\n      return;\r\n    }\r\n    \r\n    // If we have guildId, channelId and interactionId, create a new message with interaction_id\r\n    // This is needed because our deferred response doesn't create a message\r\n    if (guildId && channelId && interactionId) {\r\n      console.log(`[REST] editInteractionResponse - creating message with interaction_id: ${interactionId}`);\r\n      \r\n      const payload: any = {\r\n        interaction_id: interactionId\r\n      };\r\n      if (processedData.content !== undefined) payload.content = processedData.content;\r\n      if (processedData.embeds) payload.embeds = processedData.embeds;\r\n      if (processedData.components) payload.components = processedData.components;\r\n      if (processedData.mentions) payload.mentions = processedData.mentions;\r\n      \r\n      await this.request<void>('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages`, payload);\r\n      return;\r\n    }\r\n    \r\n    // Fallback: Regular edit without files (webhook PATCH)\r\n    const payload: any = {};\r\n    if (processedData.content !== undefined) payload.content = processedData.content;\r\n    if (processedData.embeds) payload.embeds = processedData.embeds;\r\n    if (processedData.components) payload.components = processedData.components;\r\n    if (processedData.mentions) payload.mentions = processedData.mentions;\r\n    \r\n    await this.request<void>('PATCH', `/webhooks/${appId}/${token}/messages/@original`, payload);\r\n  }\r\n\r\n  /**\r\n   * Delete the original interaction response\r\n   */\r\n  async deleteInteractionResponse(token: string): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    await this.request<void>('DELETE', `/webhooks/${appId}/${token}/messages/@original`);\r\n  }\r\n\r\n  /**\r\n   * Create a followup message\r\n   * Automatically processes mentions\r\n   */\r\n  async createFollowup(token: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    mentions?: MentionsData;\r\n    flags?: number;\r\n  }): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    const processedData = this.prepareMessageData(data);\r\n    await this.request<void>('POST', `/webhooks/${appId}/${token}`, processedData);\r\n  }\r\n\r\n  // ==================== Commands ====================\r\n\r\n  /**\r\n   * Register global application commands\r\n   */\r\n  async registerGlobalCommands(commands: APIApplicationCommand[]): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    \r\n    for (const command of commands) {\r\n      await this.request<void>('POST', `/applications/${appId}/commands`, command);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Register guild-specific commands\r\n   */\r\n  async registerGuildCommands(guildId: string, commands: APIApplicationCommand[]): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    \r\n    for (const command of commands) {\r\n      await this.request<void>('POST', `/applications/${appId}/guilds/${guildId}/commands`, command);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Delete a global command\r\n   */\r\n  async deleteGlobalCommand(commandId: string): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    await this.request<void>('DELETE', `/applications/${appId}/commands/${commandId}`);\r\n  }\r\n\r\n  // ==================== Helpers ====================\r\n\r\n  private applicationId: string = '';\r\n\r\n  /**\r\n   * Set the application ID\r\n   */\r\n  setApplicationId(id: string): void {\r\n    this.applicationId = id;\r\n  }\r\n\r\n  /**\r\n   * Get the application ID\r\n   */\r\n  private getApplicationId(): string {\r\n    if (!this.applicationId) {\r\n      throw new Error('Application ID not set. Call setApplicationId() first.');\r\n    }\r\n    return this.applicationId;\r\n  }\r\n\r\n  // ==================== Channels ====================\r\n\r\n  /**\r\n   * Create a channel in a guild\r\n   */\r\n  async createChannel(guildId: string, data: {\r\n    name: string;\r\n    type?: number;\r\n    parent_id?: string | null;\r\n    category_id?: string | null;\r\n    permission_overwrites?: Array<{\r\n      id: string;\r\n      type: number;\r\n      allow?: string;\r\n      deny?: string;\r\n    }>;\r\n  }): Promise<{ id: string; name: string }> {\r\n    // Map parent_id to category_id for backend compatibility\r\n    const requestData: any = {\r\n      name: data.name,\r\n      type: data.type ?? 0, // Default to text channel\r\n    };\r\n    \r\n    // Backend expects category_id, not parent_id\r\n    if (data.category_id) {\r\n      requestData.category_id = data.category_id;\r\n    } else if (data.parent_id) {\r\n      requestData.category_id = data.parent_id;\r\n    }\r\n    \r\n    // Add permission_overwrites if provided\r\n    if (data.permission_overwrites && data.permission_overwrites.length > 0) {\r\n      requestData.permission_overwrites = data.permission_overwrites;\r\n    }\r\n    \r\n    return this.request('POST', `/bot/guilds/${guildId}/channels`, requestData);\r\n  }\r\n\r\n  /**\r\n   * Delete a channel\r\n   */\r\n  /**\r\n   * Delete a channel\r\n   */\r\n  async deleteChannel(guildId: string, channelId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/channels/${channelId}`);\r\n  }\r\n\r\n  /**\r\n   * Edit channel permission overwrites\r\n   */\r\n  async editChannelPermissions(channelId: string, overwriteId: string, data: {\r\n    type: number;\r\n    allow?: string;\r\n    deny?: string;\r\n  }): Promise<void> {\r\n    await this.request('PUT', `/bot/channels/${channelId}/permissions/${overwriteId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Delete channel permission overwrite\r\n   */\r\n  async deleteChannelPermission(channelId: string, overwriteId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/channels/${channelId}/permissions/${overwriteId}`);\r\n  }\r\n\r\n  /**\r\n   * Get messages from a channel\r\n   */\r\n  async getMessages(guildId: string, channelId: string, options?: {\r\n    limit?: number;\r\n    before?: string;\r\n    after?: string;\r\n  }): Promise<APIMessage[]> {\r\n    const params = new URLSearchParams();\r\n    if (options?.limit) params.append('limit', String(options.limit));\r\n    if (options?.before) params.append('before', options.before);\r\n    if (options?.after) params.append('after', options.after);\r\n    \r\n    const query = params.toString() ? `?${params.toString()}` : '';\r\n    const response = await this.request<{ messages: APIMessage[]; page_info: any }>('GET', `/bot/guilds/${guildId}/channels/${channelId}/messages${query}`);\r\n    return response.messages || [];\r\n  }\r\n\r\n  // ==================== Members ====================\r\n\r\n  /**\r\n   * Get a guild member\r\n   */\r\n  async getMember(guildId: string, userId: string): Promise<any> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/members/${userId}`);\r\n  }\r\n\r\n  /**\r\n   * Timeout a guild member\r\n   */\r\n  async timeoutMember(guildId: string, userId: string, duration: number | null, reason?: string): Promise<void> {\r\n    if (duration === null) {\r\n      // Clear timeout\r\n      await this.request('POST', `/bot/guilds/${guildId}/members/${userId}/timeout/clear`, {\r\n        reason\r\n      });\r\n    } else {\r\n      // Set timeout\r\n      const until = new Date(Date.now() + duration).toISOString();\r\n      await this.request('POST', `/bot/guilds/${guildId}/members/${userId}/timeout`, {\r\n        until,\r\n        reason\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Kick a guild member\r\n   */\r\n  async kickMember(guildId: string, userId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/members/${userId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Ban a guild member\r\n   */\r\n  async banMember(guildId: string, userId: string, options?: {\r\n    deleteMessageDays?: number;\r\n    deleteMessageSeconds?: number;\r\n    reason?: string;\r\n  }): Promise<void> {\r\n    await this.request('PUT', `/bot/guilds/${guildId}/bans/${userId}`, {\r\n      delete_message_days: options?.deleteMessageDays,\r\n      delete_message_seconds: options?.deleteMessageSeconds,\r\n      reason: options?.reason\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Unban a user\r\n   */\r\n  async unbanMember(guildId: string, userId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/bans/${userId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Edit a guild member\r\n   */\r\n  async editMember(guildId: string, userId: string, data: {\r\n    nick?: string | null;\r\n    roles?: string[];\r\n    mute?: boolean;\r\n    deaf?: boolean;\r\n    channel_id?: string | null;\r\n    communication_disabled_until?: string | null;\r\n    reason?: string;\r\n  }): Promise<any> {\r\n    return this.request('PATCH', `/bot/guilds/${guildId}/members/${userId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Add a role to a member\r\n   */\r\n  async addMemberRole(guildId: string, userId: string, roleId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('PUT', `/bot/guilds/${guildId}/members/${userId}/roles/${roleId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Remove a role from a member\r\n   */\r\n  async removeMemberRole(guildId: string, userId: string, roleId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/members/${userId}/roles/${roleId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Bulk delete messages\r\n   */\r\n  async bulkDeleteMessages(guildId: string, channelId: string, messageIds: string[]): Promise<void> {\r\n    await this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages/bulk-delete`, {\r\n      messages: messageIds\r\n    });\r\n  }\r\n\r\n  // ==================== Guilds ====================\r\n\r\n  /**\r\n   * Get a guild\r\n   */\r\n  async getGuild(guildId: string): Promise<any> {\r\n    return this.request('GET', `/bot/guilds/${guildId}`);\r\n  }\r\n\r\n  /**\r\n   * Get guild channels\r\n   */\r\n  async getGuildChannels(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/channels`);\r\n  }\r\n\r\n  /**\r\n   * Get guild roles\r\n   */\r\n  async getRoles(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/roles`);\r\n  }\r\n\r\n  /**\r\n   * Create a role\r\n   */\r\n  async createRole(guildId: string, data: {\r\n    name?: string;\r\n    color?: number;\r\n    hoist?: boolean;\r\n    mentionable?: boolean;\r\n    permissions?: string;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/roles`, data);\r\n  }\r\n\r\n  /**\r\n   * Edit a role\r\n   */\r\n  async editRole(guildId: string, roleId: string, data: {\r\n    name?: string;\r\n    color?: number;\r\n    hoist?: boolean;\r\n    mentionable?: boolean;\r\n    permissions?: string;\r\n  }): Promise<any> {\r\n    return this.request('PATCH', `/bot/guilds/${guildId}/roles/${roleId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Delete a role\r\n   */\r\n  async deleteRole(guildId: string, roleId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/roles/${roleId}`);\r\n  }\r\n\r\n  /**\r\n   * Get guild emojis\r\n   */\r\n  async getEmojis(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/emojis`);\r\n  }\r\n\r\n  /**\r\n   * Get guild bans\r\n   */\r\n  async getBans(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/bans`);\r\n  }\r\n\r\n  /**\r\n   * Get a specific ban\r\n   */\r\n  async getBan(guildId: string, userId: string): Promise<any> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/bans/${userId}`);\r\n  }\r\n\r\n  /**\r\n   * Get guild invites\r\n   */\r\n  async getGuildInvites(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/invites`);\r\n  }\r\n\r\n  // ==================== Threads ====================\r\n\r\n  /**\r\n   * Create a thread from a message\r\n   */\r\n  async createThreadFromMessage(guildId: string, channelId: string, messageId: string, data: {\r\n    name: string;\r\n    auto_archive_duration?: number;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}/threads`, data);\r\n  }\r\n\r\n  /**\r\n   * Create a thread without a message\r\n   */\r\n  async createThread(guildId: string, channelId: string, data: {\r\n    name: string;\r\n    type?: number;\r\n    auto_archive_duration?: number;\r\n    invitable?: boolean;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/threads`, data);\r\n  }\r\n\r\n  /**\r\n   * Join a thread\r\n   */\r\n  async joinThread(channelId: string): Promise<void> {\r\n    await this.request('PUT', `/bot/channels/${channelId}/thread-members/@me`);\r\n  }\r\n\r\n  /**\r\n   * Leave a thread\r\n   */\r\n  async leaveThread(channelId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/channels/${channelId}/thread-members/@me`);\r\n  }\r\n\r\n  // ==================== Pins ====================\r\n\r\n  /**\r\n   * Pin a message\r\n   */\r\n  async pinMessage(guildId: string, channelId: string, messageId: string): Promise<void> {\r\n    await this.request('PUT', `/bot/guilds/${guildId}/channels/${channelId}/pins/${messageId}`);\r\n  }\r\n\r\n  /**\r\n   * Unpin a message\r\n   */\r\n  async unpinMessage(guildId: string, channelId: string, messageId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/channels/${channelId}/pins/${messageId}`);\r\n  }\r\n\r\n  /**\r\n   * Get pinned messages\r\n   */\r\n  async getPinnedMessages(guildId: string, channelId: string): Promise<APIMessage[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/channels/${channelId}/pins`);\r\n  }\r\n\r\n  // ==================== Users ====================\r\n\r\n  /**\r\n   * Get a user\r\n   */\r\n  async getUser(userId: string): Promise<any> {\r\n    return this.request('GET', `/bot/users/${userId}`);\r\n  }\r\n\r\n  /**\r\n   * Get current bot user\r\n   */\r\n  async getCurrentUser(): Promise<any> {\r\n    return this.request('GET', `/bot/users/@me`);\r\n  }\r\n\r\n  // ==================== Invites ====================\r\n\r\n  /**\r\n   * Create an invite\r\n   */\r\n  async createInvite(guildId: string, channelId: string, data?: {\r\n    max_age?: number;\r\n    max_uses?: number;\r\n    temporary?: boolean;\r\n    unique?: boolean;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/invites`, data || {});\r\n  }\r\n\r\n  /**\r\n   * Delete an invite\r\n   */\r\n  async deleteInvite(inviteCode: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/invites/${inviteCode}`);\r\n  }\r\n\r\n  /**\r\n   * Get an invite\r\n   */\r\n  async getInvite(inviteCode: string): Promise<any> {\r\n    return this.request('GET', `/bot/invites/${inviteCode}`);\r\n  }\r\n\r\n  // ==================== Webhooks ====================\r\n\r\n  /**\r\n   * Get channel webhooks\r\n   */\r\n  async getChannelWebhooks(guildId: string, channelId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/channels/${channelId}/webhooks`);\r\n  }\r\n\r\n  /**\r\n   * Create a webhook\r\n   */\r\n  async createWebhook(guildId: string, channelId: string, data: {\r\n    name: string;\r\n    avatar?: string;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/webhooks`, data);\r\n  }\r\n}\r\n"]}
860
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"REST.js","sourceRoot":"","sources":["../../src/rest/REST.ts"],"names":[],"mappings":"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","sourcesContent":["import { APIMessage, APIApplicationCommand, APIEmbed } from '../types';\r\n\r\n/**\r\n * Mention data structure for our system\r\n */\r\nexport interface MentionUser {\r\n  id: number;\r\n  username: string;\r\n}\r\n\r\nexport interface MentionRole {\r\n  id: string;\r\n  name?: string;\r\n}\r\n\r\nexport interface MentionsData {\r\n  users?: MentionUser[];\r\n  roles?: MentionRole[];\r\n  everyone?: boolean;\r\n}\r\n\r\n/**\r\n * User cache entry\r\n */\r\ninterface CachedUser {\r\n  id: number;\r\n  username: string;\r\n  displayName?: string;\r\n  cachedAt: number;\r\n}\r\n\r\n/**\r\n * REST API client for Jubbio\r\n */\r\nexport class REST {\r\n  private baseUrl: string;\r\n  private token: string = '';\r\n  \r\n  // User cache for mention resolution (ID -> username)\r\n  private userCache: Map<number, CachedUser> = new Map();\r\n  private readonly USER_CACHE_TTL = 5 * 60 * 1000; // 5 dakika\r\n\r\n  constructor(baseUrl: string = 'https://gateway.jubbio.com/api/v1') {\r\n    this.baseUrl = baseUrl;\r\n  }\r\n\r\n  // ==================== Mention Helpers ====================\r\n\r\n  /**\r\n   * Cache a user for mention resolution\r\n   * Bot'lar interaction'dan gelen user bilgisini cache'leyebilir\r\n   */\r\n  cacheUser(user: { id: string | number; username: string; displayName?: string; display_name?: string }): void {\r\n    const userId = typeof user.id === 'string' ? parseInt(user.id, 10) : user.id;\r\n    this.userCache.set(userId, {\r\n      id: userId,\r\n      username: user.username,\r\n      displayName: user.displayName || user.display_name,\r\n      cachedAt: Date.now()\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Cache multiple users\r\n   */\r\n  cacheUsers(users: Array<{ id: string | number; username: string; displayName?: string; display_name?: string }>): void {\r\n    users.forEach(user => this.cacheUser(user));\r\n  }\r\n\r\n  /**\r\n   * Get cached user by ID\r\n   */\r\n  getCachedUser(userId: number): CachedUser | undefined {\r\n    const cached = this.userCache.get(userId);\r\n    if (cached && Date.now() - cached.cachedAt < this.USER_CACHE_TTL) {\r\n      return cached;\r\n    }\r\n    // Expired, remove from cache\r\n    if (cached) {\r\n      this.userCache.delete(userId);\r\n    }\r\n    return undefined;\r\n  }\r\n\r\n  /**\r\n   * Format a user mention\r\n   * Returns both the text format and mentions data\r\n   * \r\n   * @example\r\n   * const mention = rest.formatMention(user);\r\n   * // mention.text = \"@ilkay\"\r\n   * // mention.data = { users: [{ id: 1, username: \"ilkay\" }] }\r\n   */\r\n  formatMention(user: { id: string | number; username: string }): { text: string; data: MentionsData } {\r\n    const userId = typeof user.id === 'string' ? parseInt(user.id, 10) : user.id;\r\n    return {\r\n      text: `@${user.username}`,\r\n      data: {\r\n        users: [{ id: userId, username: user.username }]\r\n      }\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Parse mentions (<@ID>) and convert to our format (@username)\r\n   * Also builds the mentions data structure\r\n   * \r\n   * @param content - Message content with mentions\r\n   * @param existingMentions - Existing mentions data to merge with\r\n   * @returns Processed content and mentions data\r\n   */\r\n  private processMentions(content: string, existingMentions?: MentionsData): { content: string; mentions: MentionsData } {\r\n    const mentions: MentionsData = {\r\n      users: [...(existingMentions?.users || [])],\r\n      roles: [...(existingMentions?.roles || [])],\r\n      everyone: existingMentions?.everyone\r\n    };\r\n\r\n    // Track already added user IDs to avoid duplicates\r\n    const addedUserIds = new Set(mentions.users?.map(u => u.id) || []);\r\n\r\n    // Parse <@ID> format (user mentions)\r\n    const userMentionRegex = /<@!?(\\d+)>/g;\r\n    let processedContent = content;\r\n    let match;\r\n\r\n    while ((match = userMentionRegex.exec(content)) !== null) {\r\n      const userId = parseInt(match[1], 10);\r\n      const fullMatch = match[0];\r\n\r\n      // Try to get username from cache\r\n      const cachedUser = this.getCachedUser(userId);\r\n      \r\n      if (cachedUser) {\r\n        // Replace <@ID> with @username\r\n        processedContent = processedContent.replace(fullMatch, `@${cachedUser.username}`);\r\n        \r\n        // Add to mentions if not already added\r\n        if (!addedUserIds.has(userId)) {\r\n          mentions.users!.push({ id: userId, username: cachedUser.username });\r\n          addedUserIds.add(userId);\r\n        }\r\n      } else {\r\n        // User not in cache - keep as @User_ID format (backend will resolve)\r\n        processedContent = processedContent.replace(fullMatch, `@User_${userId}`);\r\n        \r\n        // Still add to mentions with placeholder username\r\n        if (!addedUserIds.has(userId)) {\r\n          mentions.users!.push({ id: userId, username: `User_${userId}` });\r\n          addedUserIds.add(userId);\r\n        }\r\n      }\r\n    }\r\n\r\n    // Parse <@&ID> format (role mentions)\r\n    const roleMentionRegex = /<@&(\\d+)>/g;\r\n    const addedRoleIds = new Set(mentions.roles?.map(r => r.id) || []);\r\n\r\n    while ((match = roleMentionRegex.exec(content)) !== null) {\r\n      const roleId = match[1];\r\n      const fullMatch = match[0];\r\n\r\n      // Replace with @role format (backend handles role resolution)\r\n      processedContent = processedContent.replace(fullMatch, `@role_${roleId}`);\r\n      \r\n      if (!addedRoleIds.has(roleId)) {\r\n        mentions.roles!.push({ id: roleId });\r\n        addedRoleIds.add(roleId);\r\n      }\r\n    }\r\n\r\n    // Parse @everyone and @here\r\n    if (content.includes('@everyone')) {\r\n      mentions.everyone = true;\r\n    }\r\n\r\n    // Clean up empty arrays\r\n    if (mentions.users?.length === 0) delete mentions.users;\r\n    if (mentions.roles?.length === 0) delete mentions.roles;\r\n\r\n    return { content: processedContent, mentions };\r\n  }\r\n\r\n  /**\r\n   * Prepare message data with processed mentions\r\n   * Automatically converts mentions to our format\r\n   */\r\n  private prepareMessageData(data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    message_reference?: { message_id: string };\r\n  }): any {\r\n    const result: any = { ...data };\r\n\r\n    // Resolve components (ActionRowBuilder / ButtonBuilder instances)\r\n    if (data.components && data.components.length > 0) {\r\n      result.components = data.components.map((c: any) =>\r\n        typeof c.toJSON === 'function' ? c.toJSON() : c\r\n      );\r\n    }\r\n\r\n    let allMentions: MentionsData = { ...data.mentions };\r\n\r\n    // Process mentions in content if present\r\n    if (data.content) {\r\n      const { content, mentions } = this.processMentions(data.content, allMentions);\r\n      result.content = content;\r\n      allMentions = mentions;\r\n    }\r\n\r\n    // Process mentions in embeds (description, title, footer, fields)\r\n    if (data.embeds && data.embeds.length > 0) {\r\n      result.embeds = data.embeds.map(embed => {\r\n        // Support EmbedBuilder instances - extract raw data via toJSON()\r\n        const rawEmbed = typeof (embed as any).toJSON === 'function' ? (embed as any).toJSON() : embed;\r\n        const processedEmbed: any = { ...rawEmbed };\r\n        \r\n        // Process description\r\n        if (rawEmbed.description) {\r\n          const { content, mentions } = this.processMentions(rawEmbed.description, allMentions);\r\n          processedEmbed.description = content;\r\n          allMentions = mentions;\r\n        }\r\n        \r\n        // Process title\r\n        if (rawEmbed.title) {\r\n          const { content, mentions } = this.processMentions(rawEmbed.title, allMentions);\r\n          processedEmbed.title = content;\r\n          allMentions = mentions;\r\n        }\r\n        \r\n        // Process footer text\r\n        if (rawEmbed.footer?.text) {\r\n          const { content, mentions } = this.processMentions(rawEmbed.footer.text, allMentions);\r\n          processedEmbed.footer = { ...rawEmbed.footer, text: content };\r\n          allMentions = mentions;\r\n        }\r\n        \r\n        // Process fields\r\n        if (rawEmbed.fields && rawEmbed.fields.length > 0) {\r\n          processedEmbed.fields = rawEmbed.fields.map((field: any) => {\r\n            const processedField: any = { ...field };\r\n            if (field.value) {\r\n              const { content, mentions } = this.processMentions(field.value, allMentions);\r\n              processedField.value = content;\r\n              allMentions = mentions;\r\n            }\r\n            if (field.name) {\r\n              const { content, mentions } = this.processMentions(field.name, allMentions);\r\n              processedField.name = content;\r\n              allMentions = mentions;\r\n            }\r\n            return processedField;\r\n          });\r\n        }\r\n        \r\n        return processedEmbed;\r\n      });\r\n    }\r\n\r\n    // Add merged mentions to result\r\n    if (allMentions.users?.length || allMentions.roles?.length || allMentions.everyone) {\r\n      result.mentions = allMentions;\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  /**\r\n   * Set the bot token\r\n   */\r\n  setToken(token: string): this {\r\n    this.token = token;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Make an authenticated request\r\n   */\r\n  private async request<T>(method: string, path: string, body?: any): Promise<T> {\r\n    const url = `${this.baseUrl}${path}`;\r\n    \r\n    // Debug log\r\n    console.log(`[REST] ${method} ${url}`, body ? JSON.stringify(body) : '');\r\n    \r\n    const response = await fetch(url, {\r\n      method,\r\n      headers: {\r\n        'Authorization': `Bot ${this.token}`,\r\n        'Content-Type': 'application/json'\r\n      },\r\n      body: body ? JSON.stringify(body) : undefined\r\n    });\r\n\r\n    if (!response.ok) {\r\n      const error = await response.text();\r\n      throw new Error(`API Error ${response.status}: ${error}`);\r\n    }\r\n\r\n    // Handle empty responses\r\n    const text = await response.text();\r\n    if (!text) return {} as T;\r\n    \r\n    return JSON.parse(text);\r\n  }\r\n\r\n  // ==================== Messages ====================\r\n\r\n  /**\r\n   * Create a message in a channel\r\n   * Automatically processes mentions (<@ID>) to our format (@username)\r\n   * \r\n   * @example\r\n   * // Mention style (auto-converted):\r\n   * await rest.createMessage(guildId, channelId, {\r\n   *   content: 'Hello <@123>!',  // Becomes \"Hello @username!\"\r\n   * });\r\n   * \r\n   * // Our native format:\r\n   * await rest.createMessage(guildId, channelId, {\r\n   *   content: 'Hello @ilkay!',\r\n   *   mentions: { users: [{ id: 123, username: 'ilkay' }] }\r\n   * });\r\n   */\r\n  async createMessage(guildIdOrChannelId: string, channelIdOrData: string | {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    files?: Array<{ name: string; data: Buffer }>;\r\n    message_reference?: { message_id: string };\r\n    interactionId?: string;\r\n  }, data?: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    files?: Array<{ name: string; data: Buffer }>;\r\n    message_reference?: { message_id: string };\r\n    interactionId?: string;\r\n  }): Promise<APIMessage> {\r\n    // İki kullanım şekli:\r\n    // 1. createMessage(guildId, channelId, data) - guildId ile (tercih edilen)\r\n    // 2. createMessage(channelId, data) - guildId olmadan (eski format, hata verir)\r\n    \r\n    let guildId: string;\r\n    let channelId: string;\r\n    let messageData: any;\r\n    \r\n    if (typeof channelIdOrData === 'string' && data) {\r\n      // Yeni format: createMessage(guildId, channelId, data)\r\n      guildId = guildIdOrChannelId;\r\n      channelId = channelIdOrData;\r\n      messageData = this.prepareMessageData(data);\r\n      \r\n      // Add interaction_id if provided\r\n      if (data.interactionId) {\r\n        messageData.interaction_id = data.interactionId;\r\n      }\r\n    } else if (typeof channelIdOrData === 'object') {\r\n      // Eski format: createMessage(channelId, data) - guildId yok\r\n      // Bu format artık desteklenmiyor, hata fırlat\r\n      throw new Error('createMessage requires guildId: createMessage(guildId, channelId, data)');\r\n    } else {\r\n      throw new Error('Invalid createMessage arguments');\r\n    }\r\n    \r\n    return this.request<APIMessage>('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages`, messageData);\r\n  }\r\n\r\n  /**\r\n   * Create an ephemeral message that is only visible to a specific user\r\n   * Ephemeral messages are NOT saved to database - they are only sent via WebSocket\r\n   * \r\n   * @example\r\n   * // Send a warning only visible to the user\r\n   * await rest.createEphemeralMessage(guildId, channelId, targetUserId, {\r\n   *   embeds: [warningEmbed]\r\n   * });\r\n   */\r\n  async createEphemeralMessage(guildId: string, channelId: string, targetUserId: string | number, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n  }): Promise<{ id: string; ephemeral: boolean; flags: number }> {\r\n    const messageData = this.prepareMessageData(data);\r\n    \r\n    return this.request<{ id: string; ephemeral: boolean; flags: number }>('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages`, {\r\n      ...messageData,\r\n      flags: 64, // EPHEMERAL flag\r\n      target_user_id: typeof targetUserId === 'string' ? parseInt(targetUserId, 10) : targetUserId\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Create a DM message\r\n   */\r\n  async createDMMessage(channelId: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n  }): Promise<APIMessage> {\r\n    return this.request<APIMessage>('POST', `/bot/dm/${channelId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Edit a message\r\n   * Automatically processes mentions\r\n   */\r\n  async editMessage(guildId: string, channelId: string, messageId: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n  }): Promise<APIMessage> {\r\n    const path = `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}`;\r\n    const processedData = this.prepareMessageData(data);\r\n    return this.request<APIMessage>('PATCH', path, processedData);\r\n  }\r\n\r\n  /**\r\n   * Delete a message\r\n   */\r\n  async deleteMessage(guildId: string, channelId: string, messageId: string): Promise<void> {\r\n    const path = `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}`;\r\n    await this.request<void>('DELETE', path);\r\n  }\r\n\r\n  /**\r\n   * Add a reaction to a message\r\n   */\r\n  async addReaction(guildId: string, channelId: string, messageId: string, emoji: string): Promise<void> {\r\n    const path = `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}/reactions/${encodeURIComponent(emoji)}/@me`;\r\n    await this.request<void>('PUT', path);\r\n  }\r\n\r\n  /**\r\n   * Upload an attachment to a channel\r\n   */\r\n  async uploadAttachment(guildId: string, channelId: string, file: { name: string; data: Buffer; contentType?: string }): Promise<{ id: string; url: string; filename: string }> {\r\n    const FormData = require('form-data');\r\n    const form = new FormData();\r\n    \r\n    // form-data expects the buffer directly with options\r\n    form.append('file', file.data, {\r\n      filename: file.name,\r\n      contentType: file.contentType || 'text/plain'\r\n    });\r\n    \r\n    const url = `${this.baseUrl}/bot/guilds/${guildId}/channels/${channelId}/attachments`;\r\n    \r\n    console.log(`[REST] Uploading attachment: ${file.name} (${file.data.length} bytes)`);\r\n    \r\n    const response = await fetch(url, {\r\n      method: 'POST',\r\n      headers: {\r\n        'Authorization': `Bot ${this.token}`,\r\n        ...form.getHeaders()\r\n      },\r\n      body: form.getBuffer()\r\n    });\r\n    \r\n    if (!response.ok) {\r\n      const error = await response.text();\r\n      throw new Error(`API Error ${response.status}: ${error}`);\r\n    }\r\n    \r\n    return response.json() as Promise<{ id: string; url: string; filename: string }>;\r\n  }\r\n\r\n  /**\r\n   * Create a message with a file attachment\r\n   */\r\n  async createMessageWithFile(guildId: string, channelId: string, data: {\r\n    content?: string;\r\n    file: { name: string; data: Buffer; contentType?: string };\r\n    interactionId?: string;\r\n  }): Promise<APIMessage> {\r\n    const FormData = require('form-data');\r\n    const form = new FormData();\r\n    \r\n    // Add content if provided\r\n    if (data.content) {\r\n      form.append('content', data.content);\r\n    }\r\n    \r\n    // Add interaction_id if provided (for deferred response matching)\r\n    if (data.interactionId) {\r\n      form.append('interaction_id', data.interactionId);\r\n    }\r\n    \r\n    // Add file\r\n    form.append('files', data.file.data, {\r\n      filename: data.file.name,\r\n      contentType: data.file.contentType || 'text/plain'\r\n    });\r\n    \r\n    const url = `${this.baseUrl}/bot/guilds/${guildId}/channels/${channelId}/messages`;\r\n    \r\n    console.log(`[REST] Creating message with file: ${data.file.name} (${data.file.data.length} bytes)${data.interactionId ? ` [interaction: ${data.interactionId}]` : ''}`);\r\n    \r\n    const response = await fetch(url, {\r\n      method: 'POST',\r\n      headers: {\r\n        'Authorization': `Bot ${this.token}`,\r\n        ...form.getHeaders()\r\n      },\r\n      body: form.getBuffer()\r\n    });\r\n    \r\n    if (!response.ok) {\r\n      const error = await response.text();\r\n      throw new Error(`API Error ${response.status}: ${error}`);\r\n    }\r\n    \r\n    return response.json() as Promise<APIMessage>;\r\n  }\r\n\r\n  // ==================== Interactions ====================\r\n\r\n  /**\r\n   * Create an interaction response\r\n   * Automatically processes mentions in content and embeds\r\n   */\r\n  async createInteractionResponse(interactionId: string, token: string, data: {\r\n    type: number;\r\n    data?: any;\r\n  }): Promise<void> {\r\n    console.log(`📤 Interaction response: ${interactionId} -> type ${data.type}`);\r\n    try {\r\n      // Process mentions in response data if present\r\n      let processedData = data;\r\n      if (data.data && (data.data.content || data.data.embeds)) {\r\n        processedData = {\r\n          ...data,\r\n          data: this.prepareMessageData(data.data)\r\n        };\r\n      }\r\n      \r\n      await this.request<void>('POST', `/interactions/${interactionId}/${token}/callback`, processedData);\r\n      console.log(`✅ Interaction response sent`);\r\n    } catch (error) {\r\n      console.error(`❌ Interaction response error:`, error);\r\n      throw error;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Edit the original interaction response\r\n   * If files are provided, creates a new message with files (since webhook edit doesn't support file upload)\r\n   * Automatically processes mentions\r\n   */\r\n  async editInteractionResponse(token: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    files?: Array<{ name: string; data: Buffer; contentType?: string }>;\r\n  }, guildId?: string, channelId?: string, interactionId?: string): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    \r\n    // Process mentions in content\r\n    const processedData = this.prepareMessageData(data);\r\n    \r\n    // If files are present and we have guild/channel info, create message with file instead\r\n    if (data.files && data.files.length > 0 && guildId && channelId) {\r\n      console.log(`[REST] editInteractionResponse with ${data.files.length} files - using createMessageWithFile`);\r\n      \r\n      // Create message with file\r\n      const file = data.files[0]; // For now, support single file\r\n      await this.createMessageWithFile(guildId, channelId, {\r\n        content: processedData.content,\r\n        file: file,\r\n        interactionId: interactionId\r\n      });\r\n      return;\r\n    }\r\n    \r\n    // If we have guildId, channelId and interactionId, create a new message with interaction_id\r\n    // This is needed because our deferred response doesn't create a message\r\n    if (guildId && channelId && interactionId) {\r\n      console.log(`[REST] editInteractionResponse - creating message with interaction_id: ${interactionId}`);\r\n      \r\n      const payload: any = {\r\n        interaction_id: interactionId\r\n      };\r\n      if (processedData.content !== undefined) payload.content = processedData.content;\r\n      if (processedData.embeds) payload.embeds = processedData.embeds;\r\n      if (processedData.components) payload.components = processedData.components;\r\n      if (processedData.mentions) payload.mentions = processedData.mentions;\r\n      \r\n      await this.request<void>('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages`, payload);\r\n      return;\r\n    }\r\n    \r\n    // Fallback: Regular edit without files (webhook PATCH)\r\n    const payload: any = {};\r\n    if (processedData.content !== undefined) payload.content = processedData.content;\r\n    if (processedData.embeds) payload.embeds = processedData.embeds;\r\n    if (processedData.components) payload.components = processedData.components;\r\n    if (processedData.mentions) payload.mentions = processedData.mentions;\r\n    \r\n    await this.request<void>('PATCH', `/webhooks/${appId}/${token}/messages/@original`, payload);\r\n  }\r\n\r\n  /**\r\n   * Delete the original interaction response\r\n   */\r\n  async deleteInteractionResponse(token: string): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    await this.request<void>('DELETE', `/webhooks/${appId}/${token}/messages/@original`);\r\n  }\r\n\r\n  /**\r\n   * Create a followup message\r\n   * Automatically processes mentions\r\n   */\r\n  async createFollowup(token: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    mentions?: MentionsData;\r\n    flags?: number;\r\n  }): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    const processedData = this.prepareMessageData(data);\r\n    await this.request<void>('POST', `/webhooks/${appId}/${token}`, processedData);\r\n  }\r\n\r\n  // ==================== Commands ====================\r\n\r\n  /**\r\n   * Register global application commands\r\n   */\r\n  async registerGlobalCommands(commands: APIApplicationCommand[]): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    \r\n    for (const command of commands) {\r\n      await this.request<void>('POST', `/applications/${appId}/commands`, command);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Register guild-specific commands\r\n   */\r\n  async registerGuildCommands(guildId: string, commands: APIApplicationCommand[]): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    \r\n    for (const command of commands) {\r\n      await this.request<void>('POST', `/applications/${appId}/guilds/${guildId}/commands`, command);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Delete a global command\r\n   */\r\n  async deleteGlobalCommand(commandId: string): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    await this.request<void>('DELETE', `/applications/${appId}/commands/${commandId}`);\r\n  }\r\n\r\n  /**\r\n   * Delete a guild-specific command\r\n   */\r\n  async deleteGuildCommand(guildId: string, commandId: string): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    await this.request<void>('DELETE', `/applications/${appId}/guilds/${guildId}/commands/${commandId}`);\r\n  }\r\n\r\n  /**\r\n   * List all global commands for this application\r\n   */\r\n  async listGlobalCommands(): Promise<APIApplicationCommand[]> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand[]>('GET', `/applications/${appId}/commands`);\r\n  }\r\n\r\n  /**\r\n   * List all guild-specific commands for this application\r\n   */\r\n  async listGuildCommands(guildId: string): Promise<APIApplicationCommand[]> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand[]>('GET', `/applications/${appId}/guilds/${guildId}/commands`);\r\n  }\r\n\r\n  /**\r\n   * Get a specific global command\r\n   */\r\n  async getGlobalCommand(commandId: string): Promise<APIApplicationCommand> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand>('GET', `/applications/${appId}/commands/${commandId}`);\r\n  }\r\n\r\n  /**\r\n   * Get a specific guild command\r\n   */\r\n  async getGuildCommand(guildId: string, commandId: string): Promise<APIApplicationCommand> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand>('GET', `/applications/${appId}/guilds/${guildId}/commands/${commandId}`);\r\n  }\r\n\r\n  /**\r\n   * Update a global command\r\n   */\r\n  async updateGlobalCommand(commandId: string, data: Partial<APIApplicationCommand>): Promise<APIApplicationCommand> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand>('PATCH', `/applications/${appId}/commands/${commandId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Update a guild-specific command\r\n   */\r\n  async updateGuildCommand(guildId: string, commandId: string, data: Partial<APIApplicationCommand>): Promise<APIApplicationCommand> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand>('PATCH', `/applications/${appId}/guilds/${guildId}/commands/${commandId}`, data);\r\n  }\r\n\r\n  // ==================== Helpers ====================\r\n\r\n  private applicationId: string = '';\r\n\r\n  /**\r\n   * Set the application ID\r\n   */\r\n  setApplicationId(id: string): void {\r\n    this.applicationId = id;\r\n  }\r\n\r\n  /**\r\n   * Get the application ID\r\n   */\r\n  private getApplicationId(): string {\r\n    if (!this.applicationId) {\r\n      throw new Error('Application ID not set. Call setApplicationId() first.');\r\n    }\r\n    return this.applicationId;\r\n  }\r\n\r\n  // ==================== Channels ====================\r\n\r\n  /**\r\n   * Create a channel in a guild\r\n   */\r\n  async createChannel(guildId: string, data: {\r\n    name: string;\r\n    type?: number;\r\n    parent_id?: string | null;\r\n    category_id?: string | null;\r\n    permission_overwrites?: Array<{\r\n      id: string;\r\n      type: number;\r\n      allow?: string;\r\n      deny?: string;\r\n    }>;\r\n  }): Promise<{ id: string; name: string }> {\r\n    // Map parent_id to category_id for backend compatibility\r\n    const requestData: any = {\r\n      name: data.name,\r\n      type: data.type ?? 0, // Default to text channel\r\n    };\r\n    \r\n    // Backend expects category_id, not parent_id\r\n    if (data.category_id) {\r\n      requestData.category_id = data.category_id;\r\n    } else if (data.parent_id) {\r\n      requestData.category_id = data.parent_id;\r\n    }\r\n    \r\n    // Add permission_overwrites if provided\r\n    if (data.permission_overwrites && data.permission_overwrites.length > 0) {\r\n      requestData.permission_overwrites = data.permission_overwrites;\r\n    }\r\n    \r\n    return this.request('POST', `/bot/guilds/${guildId}/channels`, requestData);\r\n  }\r\n\r\n  /**\r\n   * Delete a channel\r\n   */\r\n  /**\r\n   * Delete a channel\r\n   */\r\n  async deleteChannel(guildId: string, channelId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/channels/${channelId}`);\r\n  }\r\n\r\n  /**\r\n   * Edit channel permission overwrites\r\n   */\r\n  async editChannelPermissions(channelId: string, overwriteId: string, data: {\r\n    type: number;\r\n    allow?: string;\r\n    deny?: string;\r\n  }): Promise<void> {\r\n    await this.request('PUT', `/bot/channels/${channelId}/permissions/${overwriteId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Delete channel permission overwrite\r\n   */\r\n  async deleteChannelPermission(channelId: string, overwriteId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/channels/${channelId}/permissions/${overwriteId}`);\r\n  }\r\n\r\n  /**\r\n   * Get messages from a channel\r\n   */\r\n  async getMessages(guildId: string, channelId: string, options?: {\r\n    limit?: number;\r\n    before?: string;\r\n    after?: string;\r\n  }): Promise<APIMessage[]> {\r\n    const params = new URLSearchParams();\r\n    if (options?.limit) params.append('limit', String(options.limit));\r\n    if (options?.before) params.append('before', options.before);\r\n    if (options?.after) params.append('after', options.after);\r\n    \r\n    const query = params.toString() ? `?${params.toString()}` : '';\r\n    const response = await this.request<{ messages: APIMessage[]; page_info: any }>('GET', `/bot/guilds/${guildId}/channels/${channelId}/messages${query}`);\r\n    return response.messages || [];\r\n  }\r\n\r\n  // ==================== Members ====================\r\n\r\n  /**\r\n   * Get a guild member\r\n   */\r\n  async getMember(guildId: string, userId: string): Promise<any> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/members/${userId}`);\r\n  }\r\n\r\n  /**\r\n   * Timeout a guild member\r\n   */\r\n  async timeoutMember(guildId: string, userId: string, duration: number | null, reason?: string): Promise<void> {\r\n    if (duration === null) {\r\n      // Clear timeout\r\n      await this.request('POST', `/bot/guilds/${guildId}/members/${userId}/timeout/clear`, {\r\n        reason\r\n      });\r\n    } else {\r\n      // Set timeout\r\n      const until = new Date(Date.now() + duration).toISOString();\r\n      await this.request('POST', `/bot/guilds/${guildId}/members/${userId}/timeout`, {\r\n        until,\r\n        reason\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Kick a guild member\r\n   */\r\n  async kickMember(guildId: string, userId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/members/${userId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Ban a guild member\r\n   */\r\n  async banMember(guildId: string, userId: string, options?: {\r\n    deleteMessageDays?: number;\r\n    deleteMessageSeconds?: number;\r\n    reason?: string;\r\n  }): Promise<void> {\r\n    await this.request('PUT', `/bot/guilds/${guildId}/bans/${userId}`, {\r\n      delete_message_days: options?.deleteMessageDays,\r\n      delete_message_seconds: options?.deleteMessageSeconds,\r\n      reason: options?.reason\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Unban a user\r\n   */\r\n  async unbanMember(guildId: string, userId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/bans/${userId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Edit a guild member\r\n   */\r\n  async editMember(guildId: string, userId: string, data: {\r\n    nick?: string | null;\r\n    roles?: string[];\r\n    mute?: boolean;\r\n    deaf?: boolean;\r\n    channel_id?: string | null;\r\n    communication_disabled_until?: string | null;\r\n    reason?: string;\r\n  }): Promise<any> {\r\n    return this.request('PATCH', `/bot/guilds/${guildId}/members/${userId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Add a role to a member\r\n   */\r\n  async addMemberRole(guildId: string, userId: string, roleId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('PUT', `/bot/guilds/${guildId}/members/${userId}/roles/${roleId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Remove a role from a member\r\n   */\r\n  async removeMemberRole(guildId: string, userId: string, roleId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/members/${userId}/roles/${roleId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Bulk delete messages\r\n   */\r\n  async bulkDeleteMessages(guildId: string, channelId: string, messageIds: string[]): Promise<void> {\r\n    await this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages/bulk-delete`, {\r\n      messages: messageIds\r\n    });\r\n  }\r\n\r\n  // ==================== Guilds ====================\r\n\r\n  /**\r\n   * Get a guild\r\n   */\r\n  async getGuild(guildId: string): Promise<any> {\r\n    return this.request('GET', `/bot/guilds/${guildId}`);\r\n  }\r\n\r\n  /**\r\n   * Get guild channels\r\n   */\r\n  async getGuildChannels(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/channels`);\r\n  }\r\n\r\n  /**\r\n   * Get guild roles\r\n   */\r\n  async getRoles(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/roles`);\r\n  }\r\n\r\n  /**\r\n   * Create a role\r\n   */\r\n  async createRole(guildId: string, data: {\r\n    name?: string;\r\n    color?: number;\r\n    hoist?: boolean;\r\n    mentionable?: boolean;\r\n    permissions?: string;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/roles`, data);\r\n  }\r\n\r\n  /**\r\n   * Edit a role\r\n   */\r\n  async editRole(guildId: string, roleId: string, data: {\r\n    name?: string;\r\n    color?: number;\r\n    hoist?: boolean;\r\n    mentionable?: boolean;\r\n    permissions?: string;\r\n  }): Promise<any> {\r\n    return this.request('PATCH', `/bot/guilds/${guildId}/roles/${roleId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Delete a role\r\n   */\r\n  async deleteRole(guildId: string, roleId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/roles/${roleId}`);\r\n  }\r\n\r\n  /**\r\n   * Get guild emojis\r\n   */\r\n  async getEmojis(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/emojis`);\r\n  }\r\n\r\n  /**\r\n   * Get guild bans\r\n   */\r\n  async getBans(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/bans`);\r\n  }\r\n\r\n  /**\r\n   * Get a specific ban\r\n   */\r\n  async getBan(guildId: string, userId: string): Promise<any> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/bans/${userId}`);\r\n  }\r\n\r\n  /**\r\n   * Get guild invites\r\n   */\r\n  async getGuildInvites(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/invites`);\r\n  }\r\n\r\n  // ==================== Threads ====================\r\n\r\n  /**\r\n   * Create a thread from a message\r\n   */\r\n  async createThreadFromMessage(guildId: string, channelId: string, messageId: string, data: {\r\n    name: string;\r\n    auto_archive_duration?: number;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}/threads`, data);\r\n  }\r\n\r\n  /**\r\n   * Create a thread without a message\r\n   */\r\n  async createThread(guildId: string, channelId: string, data: {\r\n    name: string;\r\n    type?: number;\r\n    auto_archive_duration?: number;\r\n    invitable?: boolean;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/threads`, data);\r\n  }\r\n\r\n  /**\r\n   * Join a thread\r\n   */\r\n  async joinThread(channelId: string): Promise<void> {\r\n    await this.request('PUT', `/bot/channels/${channelId}/thread-members/@me`);\r\n  }\r\n\r\n  /**\r\n   * Leave a thread\r\n   */\r\n  async leaveThread(channelId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/channels/${channelId}/thread-members/@me`);\r\n  }\r\n\r\n  // ==================== Pins ====================\r\n\r\n  /**\r\n   * Pin a message\r\n   */\r\n  async pinMessage(guildId: string, channelId: string, messageId: string): Promise<void> {\r\n    await this.request('PUT', `/bot/guilds/${guildId}/channels/${channelId}/pins/${messageId}`);\r\n  }\r\n\r\n  /**\r\n   * Unpin a message\r\n   */\r\n  async unpinMessage(guildId: string, channelId: string, messageId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/channels/${channelId}/pins/${messageId}`);\r\n  }\r\n\r\n  /**\r\n   * Get pinned messages\r\n   */\r\n  async getPinnedMessages(guildId: string, channelId: string): Promise<APIMessage[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/channels/${channelId}/pins`);\r\n  }\r\n\r\n  // ==================== Users ====================\r\n\r\n  /**\r\n   * Get a user\r\n   */\r\n  async getUser(userId: string): Promise<any> {\r\n    return this.request('GET', `/bot/users/${userId}`);\r\n  }\r\n\r\n  /**\r\n   * Get current bot user\r\n   */\r\n  async getCurrentUser(): Promise<any> {\r\n    return this.request('GET', `/bot/users/@me`);\r\n  }\r\n\r\n  // ==================== Invites ====================\r\n\r\n  /**\r\n   * Create an invite\r\n   */\r\n  async createInvite(guildId: string, channelId: string, data?: {\r\n    max_age?: number;\r\n    max_uses?: number;\r\n    temporary?: boolean;\r\n    unique?: boolean;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/invites`, data || {});\r\n  }\r\n\r\n  /**\r\n   * Delete an invite\r\n   */\r\n  async deleteInvite(inviteCode: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/invites/${inviteCode}`);\r\n  }\r\n\r\n  /**\r\n   * Get an invite\r\n   */\r\n  async getInvite(inviteCode: string): Promise<any> {\r\n    return this.request('GET', `/bot/invites/${inviteCode}`);\r\n  }\r\n\r\n  // ==================== Webhooks ====================\r\n\r\n  /**\r\n   * Get channel webhooks\r\n   */\r\n  async getChannelWebhooks(guildId: string, channelId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/channels/${channelId}/webhooks`);\r\n  }\r\n\r\n  /**\r\n   * Create a webhook\r\n   */\r\n  async createWebhook(guildId: string, channelId: string, data: {\r\n    name: string;\r\n    avatar?: string;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/webhooks`, data);\r\n  }\r\n}\r\n"]}
@@ -86,7 +86,9 @@ export declare class CommandInteraction extends Interaction {
86
86
  /**
87
87
  * Show a modal
88
88
  */
89
- showModal(modal: ModalData): Promise<void>;
89
+ showModal(modal: ModalData | {
90
+ toJSON(): ModalData;
91
+ }): Promise<void>;
90
92
  }
91
93
  /**
92
94
  * Command interaction options helper
@@ -159,6 +161,12 @@ export declare class ButtonInteraction extends Interaction {
159
161
  * Update the message the button is attached to
160
162
  */
161
163
  update(options: InteractionReplyOptions): Promise<void>;
164
+ /**
165
+ * Show a modal in response to this button interaction
166
+ */
167
+ showModal(modal: ModalData | {
168
+ toJSON(): ModalData;
169
+ }): Promise<void>;
162
170
  }
163
171
  /**
164
172
  * Select menu interaction
@@ -177,6 +185,12 @@ export declare class SelectMenuInteraction extends Interaction {
177
185
  * Update the message the select menu is attached to
178
186
  */
179
187
  update(options: InteractionReplyOptions): Promise<void>;
188
+ /**
189
+ * Show a modal in response to this select menu interaction
190
+ */
191
+ showModal(modal: ModalData | {
192
+ toJSON(): ModalData;
193
+ }): Promise<void>;
180
194
  }
181
195
  /**
182
196
  * Modal submit interaction
@@ -192,12 +206,18 @@ export declare class ModalSubmitInteraction extends Interaction {
192
206
  * Modal fields helper
193
207
  */
194
208
  export declare class ModalFields {
195
- private values;
196
- constructor(values: string[]);
209
+ private fieldMap;
210
+ constructor(components: any[]);
197
211
  /**
198
- * Get a text input value
212
+ * Get a text input value by custom_id
199
213
  */
200
214
  getTextInputValue(customId: string): string | null;
215
+ /**
216
+ * Get a field (alias for getTextInputValue)
217
+ */
218
+ getField(customId: string): {
219
+ value: string;
220
+ } | null;
201
221
  }
202
222
  export interface InteractionReplyOptions {
203
223
  content?: string;
@@ -176,9 +176,10 @@ class CommandInteraction extends Interaction {
176
176
  * Show a modal
177
177
  */
178
178
  async showModal(modal) {
179
+ const modalData = 'toJSON' in modal && typeof modal.toJSON === 'function' ? modal.toJSON() : modal;
179
180
  await this.client.rest.createInteractionResponse(this.id, this.token, {
180
181
  type: enums_1.InteractionResponseType.Modal,
181
- data: modal
182
+ data: modalData
182
183
  });
183
184
  }
184
185
  }
@@ -317,6 +318,16 @@ class ButtonInteraction extends Interaction {
317
318
  });
318
319
  this.replied = true;
319
320
  }
321
+ /**
322
+ * Show a modal in response to this button interaction
323
+ */
324
+ async showModal(modal) {
325
+ const modalData = 'toJSON' in modal && typeof modal.toJSON === 'function' ? modal.toJSON() : modal;
326
+ await this.client.rest.createInteractionResponse(this.id, this.token, {
327
+ type: enums_1.InteractionResponseType.Modal,
328
+ data: modalData
329
+ });
330
+ }
320
331
  }
321
332
  exports.ButtonInteraction = ButtonInteraction;
322
333
  /**
@@ -353,6 +364,16 @@ class SelectMenuInteraction extends Interaction {
353
364
  });
354
365
  this.replied = true;
355
366
  }
367
+ /**
368
+ * Show a modal in response to this select menu interaction
369
+ */
370
+ async showModal(modal) {
371
+ const modalData = 'toJSON' in modal && typeof modal.toJSON === 'function' ? modal.toJSON() : modal;
372
+ await this.client.rest.createInteractionResponse(this.id, this.token, {
373
+ type: enums_1.InteractionResponseType.Modal,
374
+ data: modalData
375
+ });
376
+ }
356
377
  }
357
378
  exports.SelectMenuInteraction = SelectMenuInteraction;
358
379
  /**
@@ -366,7 +387,9 @@ class ModalSubmitInteraction extends Interaction {
366
387
  constructor(client, data) {
367
388
  super(client, data);
368
389
  this.customId = data.data?.custom_id || '';
369
- this.fields = new ModalFields(data.data?.values || []);
390
+ // Modal values come from components array (action rows containing text inputs)
391
+ const components = data.data?.components || [];
392
+ this.fields = new ModalFields(components);
370
393
  }
371
394
  }
372
395
  exports.ModalSubmitInteraction = ModalSubmitInteraction;
@@ -374,17 +397,31 @@ exports.ModalSubmitInteraction = ModalSubmitInteraction;
374
397
  * Modal fields helper
375
398
  */
376
399
  class ModalFields {
377
- values;
378
- constructor(values) {
379
- this.values = values;
400
+ fieldMap;
401
+ constructor(components) {
402
+ this.fieldMap = new Map();
403
+ // Parse action rows → text inputs
404
+ for (const row of components) {
405
+ const innerComponents = row?.components || [];
406
+ for (const comp of innerComponents) {
407
+ if (comp.custom_id && comp.value !== undefined) {
408
+ this.fieldMap.set(comp.custom_id, comp.value);
409
+ }
410
+ }
411
+ }
380
412
  }
381
413
  /**
382
- * Get a text input value
414
+ * Get a text input value by custom_id
383
415
  */
384
416
  getTextInputValue(customId) {
385
- // Modal values are typically parsed from components
386
- // This is a simplified implementation
387
- return null;
417
+ return this.fieldMap.get(customId) ?? null;
418
+ }
419
+ /**
420
+ * Get a field (alias for getTextInputValue)
421
+ */
422
+ getField(customId) {
423
+ const value = this.fieldMap.get(customId);
424
+ return value !== undefined ? { value } : null;
388
425
  }
389
426
  }
390
427
  exports.ModalFields = ModalFields;
@@ -412,4 +449,4 @@ function createInteraction(client, data) {
412
449
  return new Interaction(client, data);
413
450
  }
414
451
  }
415
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Interaction.js","sourceRoot":"","sources":["../../src/structures/Interaction.ts"],"names":[],"mappings":"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","sourcesContent":["import { APIInteraction, APIInteractionOption, APIEmbed } from '../types';\r\nimport { InteractionType, InteractionResponseType, MessageFlags } from '../enums';\r\nimport { User } from './User';\r\nimport { GuildMember } from './GuildMember';\r\nimport { EmbedBuilder } from '../builders/EmbedBuilder';\r\nimport type { Client } from '../Client';\r\n\r\n/**\r\n * Base interaction class\r\n */\r\nexport class Interaction {\r\n  /** Reference to the client */\r\n  public readonly client: Client;\r\n  \r\n  /** Interaction ID */\r\n  public readonly id: string;\r\n  \r\n  /** Application ID */\r\n  public readonly applicationId: string;\r\n  \r\n  /** Interaction type */\r\n  public readonly type: InteractionType;\r\n  \r\n  /** Guild ID */\r\n  public readonly guildId?: string;\r\n  \r\n  /** Channel ID */\r\n  public readonly channelId?: string;\r\n  \r\n  /** Interaction token */\r\n  public readonly token: string;\r\n  \r\n  /** User who triggered the interaction */\r\n  public readonly user: User;\r\n  \r\n  /** Guild member (if in a guild) */\r\n  public readonly member?: GuildMember;\r\n  \r\n  /** Whether the interaction has been replied to */\r\n  public replied = false;\r\n  \r\n  /** Whether the interaction has been deferred */\r\n  public deferred = false;\r\n\r\n  constructor(client: Client, data: APIInteraction) {\r\n    this.client = client;\r\n    // Handle both string and number IDs\r\n    this.id = String(data.id);\r\n    this.applicationId = String(data.application_id);\r\n    this.type = data.type;\r\n    this.guildId = data.guild_id ? String(data.guild_id) : undefined;\r\n    this.channelId = data.channel_id ? String(data.channel_id) : undefined;\r\n    this.token = data.token;\r\n    \r\n    // User can come from member.user or directly from user\r\n    const userData = data.member?.user || data.user;\r\n    this.user = userData ? new User(userData) : new User({ id: '0', username: 'Unknown' });\r\n    \r\n    // Create member if in guild\r\n    if (data.member && this.guildId) {\r\n      const guild = client.guilds.get(this.guildId);\r\n      if (guild) {\r\n        this.member = new GuildMember(client, guild, data.member);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Check if this is a command interaction\r\n   */\r\n  isCommand(): this is CommandInteraction {\r\n    return this.type === InteractionType.ApplicationCommand;\r\n  }\r\n\r\n  /**\r\n   * Check if this is an autocomplete interaction\r\n   */\r\n  isAutocomplete(): this is AutocompleteInteraction {\r\n    return this.type === InteractionType.ApplicationCommandAutocomplete;\r\n  }\r\n\r\n  /**\r\n   * Check if this is a modal submit interaction\r\n   */\r\n  isModalSubmit(): this is ModalSubmitInteraction {\r\n    return this.type === InteractionType.ModalSubmit;\r\n  }\r\n\r\n  /**\r\n   * Check if this is a button interaction\r\n   */\r\n  isButton(): this is ButtonInteraction {\r\n    return this.type === InteractionType.MessageComponent && (this as any).componentType === 2;\r\n  }\r\n\r\n  /**\r\n   * Check if this is a select menu interaction\r\n   */\r\n  isSelectMenu(): this is SelectMenuInteraction {\r\n    return this.type === InteractionType.MessageComponent && (this as any).componentType === 3;\r\n  }\r\n\r\n  /**\r\n   * Reply to the interaction\r\n   */\r\n  async reply(options: string | InteractionReplyOptions): Promise<void> {\r\n    if (this.replied || this.deferred) {\r\n      throw new Error('Interaction has already been replied to or deferred');\r\n    }\r\n    \r\n    const content = typeof options === 'string' ? options : options.content;\r\n    const rawEmbeds = typeof options === 'string' ? undefined : options.embeds;\r\n    const components = typeof options === 'string' ? undefined : options.components;\r\n    const ephemeral = typeof options === 'string' ? false : options.ephemeral;\r\n    \r\n    // Convert EmbedBuilder instances to plain objects\r\n    const embeds = rawEmbeds?.map(e => e instanceof EmbedBuilder ? e.toJSON() : e);\r\n    \r\n    await this.client.rest.createInteractionResponse(this.id, this.token, {\r\n      type: InteractionResponseType.ChannelMessageWithSource,\r\n      data: {\r\n        content,\r\n        embeds,\r\n        components,\r\n        flags: ephemeral ? MessageFlags.Ephemeral : 0\r\n      }\r\n    });\r\n    \r\n    this.replied = true;\r\n  }\r\n\r\n  /**\r\n   * Defer the reply (shows \"thinking...\")\r\n   */\r\n  async deferReply(options?: { ephemeral?: boolean }): Promise<void> {\r\n    if (this.replied || this.deferred) {\r\n      throw new Error('Interaction has already been replied to or deferred');\r\n    }\r\n    \r\n    await this.client.rest.createInteractionResponse(this.id, this.token, {\r\n      type: InteractionResponseType.DeferredChannelMessageWithSource,\r\n      data: options?.ephemeral ? { flags: MessageFlags.Ephemeral } : undefined\r\n    });\r\n    \r\n    this.deferred = true;\r\n  }\r\n\r\n  /**\r\n   * Edit the reply\r\n   */\r\n  async editReply(options: string | InteractionReplyOptions): Promise<void> {\r\n    const content = typeof options === 'string' ? options : options.content;\r\n    const rawEmbeds = typeof options === 'string' ? undefined : options.embeds;\r\n    const components = typeof options === 'string' ? undefined : options.components;\r\n    const files = typeof options === 'string' ? undefined : options.files;\r\n    \r\n    // Convert EmbedBuilder instances to plain objects\r\n    const embeds = rawEmbeds?.map(e => e instanceof EmbedBuilder ? e.toJSON() : e);\r\n    \r\n    await this.client.rest.editInteractionResponse(this.token, {\r\n      content,\r\n      embeds,\r\n      components,\r\n      files\r\n    }, this.guildId, this.channelId, this.id);\r\n  }\r\n\r\n  /**\r\n   * Delete the reply\r\n   */\r\n  async deleteReply(): Promise<void> {\r\n    await this.client.rest.deleteInteractionResponse(this.token);\r\n  }\r\n\r\n  /**\r\n   * Send a followup message\r\n   */\r\n  async followUp(options: string | InteractionReplyOptions): Promise<void> {\r\n    const content = typeof options === 'string' ? options : options.content;\r\n    const rawEmbeds = typeof options === 'string' ? undefined : options.embeds;\r\n    const ephemeral = typeof options === 'string' ? false : options.ephemeral;\r\n    \r\n    // Convert EmbedBuilder instances to plain objects\r\n    const embeds = rawEmbeds?.map(e => e instanceof EmbedBuilder ? e.toJSON() : e);\r\n    \r\n    await this.client.rest.createFollowup(this.token, {\r\n      content,\r\n      embeds,\r\n      flags: ephemeral ? MessageFlags.Ephemeral : 0\r\n    });\r\n  }\r\n}\r\n\r\n/**\r\n * Command interaction\r\n */\r\nexport class CommandInteraction extends Interaction {\r\n  /** Command name */\r\n  public readonly commandName: string;\r\n  \r\n  /** Command options */\r\n  public readonly options: CommandInteractionOptions;\r\n\r\n  constructor(client: Client, data: APIInteraction) {\r\n    super(client, data);\r\n    this.commandName = data.data?.name || '';\r\n    this.options = new CommandInteractionOptions(data.data?.options || []);\r\n  }\r\n\r\n  /**\r\n   * Show a modal\r\n   */\r\n  async showModal(modal: ModalData): Promise<void> {\r\n    await this.client.rest.createInteractionResponse(this.id, this.token, {\r\n      type: InteractionResponseType.Modal,\r\n      data: modal\r\n    });\r\n  }\r\n}\r\n\r\n/**\r\n * Command interaction options helper\r\n */\r\nexport class CommandInteractionOptions {\r\n  private options: APIInteractionOption[];\r\n\r\n  constructor(options: APIInteractionOption[]) {\r\n    this.options = options;\r\n  }\r\n\r\n  /**\r\n   * Get a string option\r\n   */\r\n  getString(name: string, required?: boolean): string | null {\r\n    const option = this.options.find(o => o.name === name);\r\n    if (!option && required) throw new Error(`Required option \"${name}\" not found`);\r\n    return option?.value as string || null;\r\n  }\r\n\r\n  /**\r\n   * Get an integer option\r\n   */\r\n  getInteger(name: string, required?: boolean): number | null {\r\n    const option = this.options.find(o => o.name === name);\r\n    if (!option && required) throw new Error(`Required option \"${name}\" not found`);\r\n    return option?.value as number || null;\r\n  }\r\n\r\n  /**\r\n   * Get a number option\r\n   */\r\n  getNumber(name: string, required?: boolean): number | null {\r\n    return this.getInteger(name, required);\r\n  }\r\n\r\n  /**\r\n   * Get a boolean option\r\n   */\r\n  getBoolean(name: string, required?: boolean): boolean | null {\r\n    const option = this.options.find(o => o.name === name);\r\n    if (!option && required) throw new Error(`Required option \"${name}\" not found`);\r\n    return option?.value as boolean ?? null;\r\n  }\r\n\r\n  /**\r\n   * Get a user option\r\n   */\r\n  getUser(name: string, required?: boolean): string | null {\r\n    const option = this.options.find(o => o.name === name);\r\n    if (!option && required) throw new Error(`Required option \"${name}\" not found`);\r\n    return option?.value as string || null;\r\n  }\r\n\r\n  /**\r\n   * Get a channel option\r\n   */\r\n  getChannel(name: string, required?: boolean): string | null {\r\n    const option = this.options.find(o => o.name === name);\r\n    if (!option && required) throw new Error(`Required option \"${name}\" not found`);\r\n    return option?.value as string || null;\r\n  }\r\n\r\n  /**\r\n   * Get a subcommand name\r\n   */\r\n  getSubcommand(required?: boolean): string | null {\r\n    const option = this.options.find(o => o.type === 1);\r\n    if (!option && required) throw new Error('Required subcommand not found');\r\n    return option?.name || null;\r\n  }\r\n\r\n  /**\r\n   * Get the focused option (for autocomplete)\r\n   */\r\n  getFocused(): { name: string; value: string } | null {\r\n    const option = this.options.find(o => o.focused);\r\n    if (!option) return null;\r\n    return { name: option.name, value: option.value as string };\r\n  }\r\n}\r\n\r\n/**\r\n * Autocomplete interaction\r\n */\r\nexport class AutocompleteInteraction extends Interaction {\r\n  /** Command name */\r\n  public readonly commandName: string;\r\n  \r\n  /** Command options */\r\n  public readonly options: CommandInteractionOptions;\r\n\r\n  constructor(client: Client, data: APIInteraction) {\r\n    super(client, data);\r\n    this.commandName = data.data?.name || '';\r\n    this.options = new CommandInteractionOptions(data.data?.options || []);\r\n  }\r\n\r\n  /**\r\n   * Respond with autocomplete choices\r\n   */\r\n  async respond(choices: AutocompleteChoice[]): Promise<void> {\r\n    await this.client.rest.createInteractionResponse(this.id, this.token, {\r\n      type: InteractionResponseType.ApplicationCommandAutocompleteResult,\r\n      data: { choices }\r\n    });\r\n  }\r\n}\r\n\r\n/**\r\n * Button interaction\r\n */\r\nexport class ButtonInteraction extends Interaction {\r\n  /** Button custom ID */\r\n  public readonly customId: string;\r\n  \r\n  /** Component type (always 2 for buttons) */\r\n  public readonly componentType: number = 2;\r\n  \r\n  /** Message the button is attached to */\r\n  public readonly message?: any;\r\n\r\n  constructor(client: Client, data: APIInteraction) {\r\n    super(client, data);\r\n    this.customId = data.data?.custom_id || '';\r\n    this.message = data.message;\r\n  }\r\n\r\n  /**\r\n   * Update the message the button is attached to\r\n   */\r\n  async update(options: InteractionReplyOptions): Promise<void> {\r\n    // Convert EmbedBuilder instances to plain objects\r\n    const embeds = options.embeds?.map(e => e instanceof EmbedBuilder ? e.toJSON() : e);\r\n    \r\n    await this.client.rest.createInteractionResponse(this.id, this.token, {\r\n      type: InteractionResponseType.UpdateMessage,\r\n      data: {\r\n        content: options.content,\r\n        embeds,\r\n        components: options.components\r\n      }\r\n    });\r\n    this.replied = true;\r\n  }\r\n}\r\n\r\n/**\r\n * Select menu interaction\r\n */\r\nexport class SelectMenuInteraction extends Interaction {\r\n  /** Select menu custom ID */\r\n  public readonly customId: string;\r\n  \r\n  /** Component type (always 3 for select menus) */\r\n  public readonly componentType: number = 3;\r\n  \r\n  /** Selected values */\r\n  public readonly values: string[];\r\n  \r\n  /** Message the select menu is attached to */\r\n  public readonly message?: any;\r\n\r\n  constructor(client: Client, data: APIInteraction) {\r\n    super(client, data);\r\n    this.customId = data.data?.custom_id || '';\r\n    this.values = data.data?.values || [];\r\n    this.message = data.message;\r\n  }\r\n\r\n  /**\r\n   * Update the message the select menu is attached to\r\n   */\r\n  async update(options: InteractionReplyOptions): Promise<void> {\r\n    // Convert EmbedBuilder instances to plain objects\r\n    const embeds = options.embeds?.map(e => e instanceof EmbedBuilder ? e.toJSON() : e);\r\n    \r\n    await this.client.rest.createInteractionResponse(this.id, this.token, {\r\n      type: InteractionResponseType.UpdateMessage,\r\n      data: {\r\n        content: options.content,\r\n        embeds,\r\n        components: options.components\r\n      }\r\n    });\r\n    this.replied = true;\r\n  }\r\n}\r\n\r\n/**\r\n * Modal submit interaction\r\n */\r\nexport class ModalSubmitInteraction extends Interaction {\r\n  /** Modal custom ID */\r\n  public readonly customId: string;\r\n  \r\n  /** Modal fields */\r\n  public readonly fields: ModalFields;\r\n\r\n  constructor(client: Client, data: APIInteraction) {\r\n    super(client, data);\r\n    this.customId = data.data?.custom_id || '';\r\n    this.fields = new ModalFields(data.data?.values || []);\r\n  }\r\n}\r\n\r\n/**\r\n * Modal fields helper\r\n */\r\nexport class ModalFields {\r\n  private values: string[];\r\n\r\n  constructor(values: string[]) {\r\n    this.values = values;\r\n  }\r\n\r\n  /**\r\n   * Get a text input value\r\n   */\r\n  getTextInputValue(customId: string): string | null {\r\n    // Modal values are typically parsed from components\r\n    // This is a simplified implementation\r\n    return null;\r\n  }\r\n}\r\n\r\n// Types\r\nexport interface InteractionReplyOptions {\r\n  content?: string;\r\n  embeds?: (APIEmbed | EmbedBuilder)[];\r\n  components?: any[];\r\n  ephemeral?: boolean;\r\n  files?: Array<{ name: string; data: Buffer; contentType?: string }>;\r\n}\r\n\r\nexport interface AutocompleteChoice {\r\n  name: string;\r\n  value: string | number;\r\n}\r\n\r\nexport interface ModalData {\r\n  custom_id: string;\r\n  title: string;\r\n  components: any[];\r\n}\r\n\r\n/**\r\n * Create appropriate interaction class based on type\r\n */\r\nexport function createInteraction(client: Client, data: APIInteraction): Interaction {\r\n  switch (data.type) {\r\n    case InteractionType.ApplicationCommand:\r\n      return new CommandInteraction(client, data);\r\n    case InteractionType.ApplicationCommandAutocomplete:\r\n      return new AutocompleteInteraction(client, data);\r\n    case InteractionType.ModalSubmit:\r\n      return new ModalSubmitInteraction(client, data);\r\n    case InteractionType.MessageComponent:\r\n      // component_type: 2 = Button, 3 = Select Menu\r\n      if (data.data?.component_type === 2) {\r\n        return new ButtonInteraction(client, data);\r\n      } else if (data.data?.component_type === 3) {\r\n        return new SelectMenuInteraction(client, data);\r\n      }\r\n      return new Interaction(client, data);\r\n    default:\r\n      return new Interaction(client, data);\r\n  }\r\n}\r\n"]}
452
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Interaction.js","sourceRoot":"","sources":["../../src/structures/Interaction.ts"],"names":[],"mappings":"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","sourcesContent":["import { APIInteraction, APIInteractionOption, APIEmbed } from '../types';\r\nimport { InteractionType, InteractionResponseType, MessageFlags } from '../enums';\r\nimport { User } from './User';\r\nimport { GuildMember } from './GuildMember';\r\nimport { EmbedBuilder } from '../builders/EmbedBuilder';\r\nimport type { Client } from '../Client';\r\n\r\n/**\r\n * Base interaction class\r\n */\r\nexport class Interaction {\r\n  /** Reference to the client */\r\n  public readonly client: Client;\r\n  \r\n  /** Interaction ID */\r\n  public readonly id: string;\r\n  \r\n  /** Application ID */\r\n  public readonly applicationId: string;\r\n  \r\n  /** Interaction type */\r\n  public readonly type: InteractionType;\r\n  \r\n  /** Guild ID */\r\n  public readonly guildId?: string;\r\n  \r\n  /** Channel ID */\r\n  public readonly channelId?: string;\r\n  \r\n  /** Interaction token */\r\n  public readonly token: string;\r\n  \r\n  /** User who triggered the interaction */\r\n  public readonly user: User;\r\n  \r\n  /** Guild member (if in a guild) */\r\n  public readonly member?: GuildMember;\r\n  \r\n  /** Whether the interaction has been replied to */\r\n  public replied = false;\r\n  \r\n  /** Whether the interaction has been deferred */\r\n  public deferred = false;\r\n\r\n  constructor(client: Client, data: APIInteraction) {\r\n    this.client = client;\r\n    // Handle both string and number IDs\r\n    this.id = String(data.id);\r\n    this.applicationId = String(data.application_id);\r\n    this.type = data.type;\r\n    this.guildId = data.guild_id ? String(data.guild_id) : undefined;\r\n    this.channelId = data.channel_id ? String(data.channel_id) : undefined;\r\n    this.token = data.token;\r\n    \r\n    // User can come from member.user or directly from user\r\n    const userData = data.member?.user || data.user;\r\n    this.user = userData ? new User(userData) : new User({ id: '0', username: 'Unknown' });\r\n    \r\n    // Create member if in guild\r\n    if (data.member && this.guildId) {\r\n      const guild = client.guilds.get(this.guildId);\r\n      if (guild) {\r\n        this.member = new GuildMember(client, guild, data.member);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Check if this is a command interaction\r\n   */\r\n  isCommand(): this is CommandInteraction {\r\n    return this.type === InteractionType.ApplicationCommand;\r\n  }\r\n\r\n  /**\r\n   * Check if this is an autocomplete interaction\r\n   */\r\n  isAutocomplete(): this is AutocompleteInteraction {\r\n    return this.type === InteractionType.ApplicationCommandAutocomplete;\r\n  }\r\n\r\n  /**\r\n   * Check if this is a modal submit interaction\r\n   */\r\n  isModalSubmit(): this is ModalSubmitInteraction {\r\n    return this.type === InteractionType.ModalSubmit;\r\n  }\r\n\r\n  /**\r\n   * Check if this is a button interaction\r\n   */\r\n  isButton(): this is ButtonInteraction {\r\n    return this.type === InteractionType.MessageComponent && (this as any).componentType === 2;\r\n  }\r\n\r\n  /**\r\n   * Check if this is a select menu interaction\r\n   */\r\n  isSelectMenu(): this is SelectMenuInteraction {\r\n    return this.type === InteractionType.MessageComponent && (this as any).componentType === 3;\r\n  }\r\n\r\n  /**\r\n   * Reply to the interaction\r\n   */\r\n  async reply(options: string | InteractionReplyOptions): Promise<void> {\r\n    if (this.replied || this.deferred) {\r\n      throw new Error('Interaction has already been replied to or deferred');\r\n    }\r\n    \r\n    const content = typeof options === 'string' ? options : options.content;\r\n    const rawEmbeds = typeof options === 'string' ? undefined : options.embeds;\r\n    const components = typeof options === 'string' ? undefined : options.components;\r\n    const ephemeral = typeof options === 'string' ? false : options.ephemeral;\r\n    \r\n    // Convert EmbedBuilder instances to plain objects\r\n    const embeds = rawEmbeds?.map(e => e instanceof EmbedBuilder ? e.toJSON() : e);\r\n    \r\n    await this.client.rest.createInteractionResponse(this.id, this.token, {\r\n      type: InteractionResponseType.ChannelMessageWithSource,\r\n      data: {\r\n        content,\r\n        embeds,\r\n        components,\r\n        flags: ephemeral ? MessageFlags.Ephemeral : 0\r\n      }\r\n    });\r\n    \r\n    this.replied = true;\r\n  }\r\n\r\n  /**\r\n   * Defer the reply (shows \"thinking...\")\r\n   */\r\n  async deferReply(options?: { ephemeral?: boolean }): Promise<void> {\r\n    if (this.replied || this.deferred) {\r\n      throw new Error('Interaction has already been replied to or deferred');\r\n    }\r\n    \r\n    await this.client.rest.createInteractionResponse(this.id, this.token, {\r\n      type: InteractionResponseType.DeferredChannelMessageWithSource,\r\n      data: options?.ephemeral ? { flags: MessageFlags.Ephemeral } : undefined\r\n    });\r\n    \r\n    this.deferred = true;\r\n  }\r\n\r\n  /**\r\n   * Edit the reply\r\n   */\r\n  async editReply(options: string | InteractionReplyOptions): Promise<void> {\r\n    const content = typeof options === 'string' ? options : options.content;\r\n    const rawEmbeds = typeof options === 'string' ? undefined : options.embeds;\r\n    const components = typeof options === 'string' ? undefined : options.components;\r\n    const files = typeof options === 'string' ? undefined : options.files;\r\n    \r\n    // Convert EmbedBuilder instances to plain objects\r\n    const embeds = rawEmbeds?.map(e => e instanceof EmbedBuilder ? e.toJSON() : e);\r\n    \r\n    await this.client.rest.editInteractionResponse(this.token, {\r\n      content,\r\n      embeds,\r\n      components,\r\n      files\r\n    }, this.guildId, this.channelId, this.id);\r\n  }\r\n\r\n  /**\r\n   * Delete the reply\r\n   */\r\n  async deleteReply(): Promise<void> {\r\n    await this.client.rest.deleteInteractionResponse(this.token);\r\n  }\r\n\r\n  /**\r\n   * Send a followup message\r\n   */\r\n  async followUp(options: string | InteractionReplyOptions): Promise<void> {\r\n    const content = typeof options === 'string' ? options : options.content;\r\n    const rawEmbeds = typeof options === 'string' ? undefined : options.embeds;\r\n    const ephemeral = typeof options === 'string' ? false : options.ephemeral;\r\n    \r\n    // Convert EmbedBuilder instances to plain objects\r\n    const embeds = rawEmbeds?.map(e => e instanceof EmbedBuilder ? e.toJSON() : e);\r\n    \r\n    await this.client.rest.createFollowup(this.token, {\r\n      content,\r\n      embeds,\r\n      flags: ephemeral ? MessageFlags.Ephemeral : 0\r\n    });\r\n  }\r\n}\r\n\r\n/**\r\n * Command interaction\r\n */\r\nexport class CommandInteraction extends Interaction {\r\n  /** Command name */\r\n  public readonly commandName: string;\r\n  \r\n  /** Command options */\r\n  public readonly options: CommandInteractionOptions;\r\n\r\n  constructor(client: Client, data: APIInteraction) {\r\n    super(client, data);\r\n    this.commandName = data.data?.name || '';\r\n    this.options = new CommandInteractionOptions(data.data?.options || []);\r\n  }\r\n\r\n  /**\r\n   * Show a modal\r\n   */\r\n  async showModal(modal: ModalData | { toJSON(): ModalData }): Promise<void> {\r\n    const modalData = 'toJSON' in modal && typeof modal.toJSON === 'function' ? modal.toJSON() : modal;\r\n    await this.client.rest.createInteractionResponse(this.id, this.token, {\r\n      type: InteractionResponseType.Modal,\r\n      data: modalData\r\n    });\r\n  }\r\n}\r\n\r\n/**\r\n * Command interaction options helper\r\n */\r\nexport class CommandInteractionOptions {\r\n  private options: APIInteractionOption[];\r\n\r\n  constructor(options: APIInteractionOption[]) {\r\n    this.options = options;\r\n  }\r\n\r\n  /**\r\n   * Get a string option\r\n   */\r\n  getString(name: string, required?: boolean): string | null {\r\n    const option = this.options.find(o => o.name === name);\r\n    if (!option && required) throw new Error(`Required option \"${name}\" not found`);\r\n    return option?.value as string || null;\r\n  }\r\n\r\n  /**\r\n   * Get an integer option\r\n   */\r\n  getInteger(name: string, required?: boolean): number | null {\r\n    const option = this.options.find(o => o.name === name);\r\n    if (!option && required) throw new Error(`Required option \"${name}\" not found`);\r\n    return option?.value as number || null;\r\n  }\r\n\r\n  /**\r\n   * Get a number option\r\n   */\r\n  getNumber(name: string, required?: boolean): number | null {\r\n    return this.getInteger(name, required);\r\n  }\r\n\r\n  /**\r\n   * Get a boolean option\r\n   */\r\n  getBoolean(name: string, required?: boolean): boolean | null {\r\n    const option = this.options.find(o => o.name === name);\r\n    if (!option && required) throw new Error(`Required option \"${name}\" not found`);\r\n    return option?.value as boolean ?? null;\r\n  }\r\n\r\n  /**\r\n   * Get a user option\r\n   */\r\n  getUser(name: string, required?: boolean): string | null {\r\n    const option = this.options.find(o => o.name === name);\r\n    if (!option && required) throw new Error(`Required option \"${name}\" not found`);\r\n    return option?.value as string || null;\r\n  }\r\n\r\n  /**\r\n   * Get a channel option\r\n   */\r\n  getChannel(name: string, required?: boolean): string | null {\r\n    const option = this.options.find(o => o.name === name);\r\n    if (!option && required) throw new Error(`Required option \"${name}\" not found`);\r\n    return option?.value as string || null;\r\n  }\r\n\r\n  /**\r\n   * Get a subcommand name\r\n   */\r\n  getSubcommand(required?: boolean): string | null {\r\n    const option = this.options.find(o => o.type === 1);\r\n    if (!option && required) throw new Error('Required subcommand not found');\r\n    return option?.name || null;\r\n  }\r\n\r\n  /**\r\n   * Get the focused option (for autocomplete)\r\n   */\r\n  getFocused(): { name: string; value: string } | null {\r\n    const option = this.options.find(o => o.focused);\r\n    if (!option) return null;\r\n    return { name: option.name, value: option.value as string };\r\n  }\r\n}\r\n\r\n/**\r\n * Autocomplete interaction\r\n */\r\nexport class AutocompleteInteraction extends Interaction {\r\n  /** Command name */\r\n  public readonly commandName: string;\r\n  \r\n  /** Command options */\r\n  public readonly options: CommandInteractionOptions;\r\n\r\n  constructor(client: Client, data: APIInteraction) {\r\n    super(client, data);\r\n    this.commandName = data.data?.name || '';\r\n    this.options = new CommandInteractionOptions(data.data?.options || []);\r\n  }\r\n\r\n  /**\r\n   * Respond with autocomplete choices\r\n   */\r\n  async respond(choices: AutocompleteChoice[]): Promise<void> {\r\n    await this.client.rest.createInteractionResponse(this.id, this.token, {\r\n      type: InteractionResponseType.ApplicationCommandAutocompleteResult,\r\n      data: { choices }\r\n    });\r\n  }\r\n}\r\n\r\n/**\r\n * Button interaction\r\n */\r\nexport class ButtonInteraction extends Interaction {\r\n  /** Button custom ID */\r\n  public readonly customId: string;\r\n  \r\n  /** Component type (always 2 for buttons) */\r\n  public readonly componentType: number = 2;\r\n  \r\n  /** Message the button is attached to */\r\n  public readonly message?: any;\r\n\r\n  constructor(client: Client, data: APIInteraction) {\r\n    super(client, data);\r\n    this.customId = data.data?.custom_id || '';\r\n    this.message = data.message;\r\n  }\r\n\r\n  /**\r\n   * Update the message the button is attached to\r\n   */\r\n  async update(options: InteractionReplyOptions): Promise<void> {\r\n    // Convert EmbedBuilder instances to plain objects\r\n    const embeds = options.embeds?.map(e => e instanceof EmbedBuilder ? e.toJSON() : e);\r\n    \r\n    await this.client.rest.createInteractionResponse(this.id, this.token, {\r\n      type: InteractionResponseType.UpdateMessage,\r\n      data: {\r\n        content: options.content,\r\n        embeds,\r\n        components: options.components\r\n      }\r\n    });\r\n    this.replied = true;\r\n  }\r\n\r\n  /**\r\n   * Show a modal in response to this button interaction\r\n   */\r\n  async showModal(modal: ModalData | { toJSON(): ModalData }): Promise<void> {\r\n    const modalData = 'toJSON' in modal && typeof modal.toJSON === 'function' ? modal.toJSON() : modal;\r\n    await this.client.rest.createInteractionResponse(this.id, this.token, {\r\n      type: InteractionResponseType.Modal,\r\n      data: modalData\r\n    });\r\n  }\r\n}\r\n\r\n/**\r\n * Select menu interaction\r\n */\r\nexport class SelectMenuInteraction extends Interaction {\r\n  /** Select menu custom ID */\r\n  public readonly customId: string;\r\n  \r\n  /** Component type (always 3 for select menus) */\r\n  public readonly componentType: number = 3;\r\n  \r\n  /** Selected values */\r\n  public readonly values: string[];\r\n  \r\n  /** Message the select menu is attached to */\r\n  public readonly message?: any;\r\n\r\n  constructor(client: Client, data: APIInteraction) {\r\n    super(client, data);\r\n    this.customId = data.data?.custom_id || '';\r\n    this.values = data.data?.values || [];\r\n    this.message = data.message;\r\n  }\r\n\r\n  /**\r\n   * Update the message the select menu is attached to\r\n   */\r\n  async update(options: InteractionReplyOptions): Promise<void> {\r\n    // Convert EmbedBuilder instances to plain objects\r\n    const embeds = options.embeds?.map(e => e instanceof EmbedBuilder ? e.toJSON() : e);\r\n    \r\n    await this.client.rest.createInteractionResponse(this.id, this.token, {\r\n      type: InteractionResponseType.UpdateMessage,\r\n      data: {\r\n        content: options.content,\r\n        embeds,\r\n        components: options.components\r\n      }\r\n    });\r\n    this.replied = true;\r\n  }\r\n\r\n  /**\r\n   * Show a modal in response to this select menu interaction\r\n   */\r\n  async showModal(modal: ModalData | { toJSON(): ModalData }): Promise<void> {\r\n    const modalData = 'toJSON' in modal && typeof modal.toJSON === 'function' ? modal.toJSON() : modal;\r\n    await this.client.rest.createInteractionResponse(this.id, this.token, {\r\n      type: InteractionResponseType.Modal,\r\n      data: modalData\r\n    });\r\n  }\r\n}\r\n\r\n/**\r\n * Modal submit interaction\r\n */\r\nexport class ModalSubmitInteraction extends Interaction {\r\n  /** Modal custom ID */\r\n  public readonly customId: string;\r\n  \r\n  /** Modal fields */\r\n  public readonly fields: ModalFields;\r\n\r\n  constructor(client: Client, data: APIInteraction) {\r\n    super(client, data);\r\n    this.customId = data.data?.custom_id || '';\r\n    // Modal values come from components array (action rows containing text inputs)\r\n    const components = (data.data as any)?.components || [];\r\n    this.fields = new ModalFields(components);\r\n  }\r\n}\r\n\r\n/**\r\n * Modal fields helper\r\n */\r\nexport class ModalFields {\r\n  private fieldMap: Map<string, string>;\r\n\r\n  constructor(components: any[]) {\r\n    this.fieldMap = new Map();\r\n    // Parse action rows → text inputs\r\n    for (const row of components) {\r\n      const innerComponents = row?.components || [];\r\n      for (const comp of innerComponents) {\r\n        if (comp.custom_id && comp.value !== undefined) {\r\n          this.fieldMap.set(comp.custom_id, comp.value);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Get a text input value by custom_id\r\n   */\r\n  getTextInputValue(customId: string): string | null {\r\n    return this.fieldMap.get(customId) ?? null;\r\n  }\r\n\r\n  /**\r\n   * Get a field (alias for getTextInputValue)\r\n   */\r\n  getField(customId: string): { value: string } | null {\r\n    const value = this.fieldMap.get(customId);\r\n    return value !== undefined ? { value } : null;\r\n  }\r\n}\r\n\r\n// Types\r\nexport interface InteractionReplyOptions {\r\n  content?: string;\r\n  embeds?: (APIEmbed | EmbedBuilder)[];\r\n  components?: any[];\r\n  ephemeral?: boolean;\r\n  files?: Array<{ name: string; data: Buffer; contentType?: string }>;\r\n}\r\n\r\nexport interface AutocompleteChoice {\r\n  name: string;\r\n  value: string | number;\r\n}\r\n\r\nexport interface ModalData {\r\n  custom_id: string;\r\n  title: string;\r\n  components: any[];\r\n}\r\n\r\n/**\r\n * Create appropriate interaction class based on type\r\n */\r\nexport function createInteraction(client: Client, data: APIInteraction): Interaction {\r\n  switch (data.type) {\r\n    case InteractionType.ApplicationCommand:\r\n      return new CommandInteraction(client, data);\r\n    case InteractionType.ApplicationCommandAutocomplete:\r\n      return new AutocompleteInteraction(client, data);\r\n    case InteractionType.ModalSubmit:\r\n      return new ModalSubmitInteraction(client, data);\r\n    case InteractionType.MessageComponent:\r\n      // component_type: 2 = Button, 3 = Select Menu\r\n      if (data.data?.component_type === 2) {\r\n        return new ButtonInteraction(client, data);\r\n      } else if (data.data?.component_type === 3) {\r\n        return new SelectMenuInteraction(client, data);\r\n      }\r\n      return new Interaction(client, data);\r\n    default:\r\n      return new Interaction(client, data);\r\n  }\r\n}\r\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@jubbio/core",
3
- "version": "1.0.9",
3
+ "version": "1.0.11",
4
4
  "description": "Core library for Jubbio bots",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",