@discordeno/types 22.0.1-next.bd4e6f1 → 22.0.1-next.bd98b3e

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.
@@ -36,10 +36,12 @@ export declare enum MessageComponentTypes {
36
36
  /** Container that visually groups a set of components */
37
37
  Container = 17,
38
38
  /** Container associating a label and description with a component */
39
- Label = 18
39
+ Label = 18,
40
+ /** Component for uploading files */
41
+ FileUpload = 19
40
42
  }
41
43
  export type DiscordMessageComponents = DiscordMessageComponent[];
42
- export type DiscordMessageComponent = DiscordActionRow | DiscordSelectMenuComponent | DiscordButtonComponent | DiscordTextInputComponent | DiscordSectionComponent | DiscordTextDisplayComponent | DiscordThumbnailComponent | DiscordMediaGalleryComponent | DiscordSeparatorComponent | DiscordContainerComponent | DiscordFileComponent | DiscordLabelComponent;
44
+ export type DiscordMessageComponent = DiscordActionRow | DiscordSelectMenuComponent | DiscordButtonComponent | DiscordTextInputComponent | DiscordSectionComponent | DiscordTextDisplayComponent | DiscordThumbnailComponent | DiscordMediaGalleryComponent | DiscordSeparatorComponent | DiscordContainerComponent | DiscordFileComponent | DiscordLabelComponent | DiscordFileUploadComponent;
43
45
  export type DiscordMessageComponentFromModalInteractionResponse = DiscordTextInputInteractionResponse | DiscordTextDisplayInteractionResponse | DiscordLabelInteractionResponse;
44
46
  export type DiscordMessageComponentFromMessageComponentInteractionResponse = DiscordRoleSelectInteractionResponseFromMessageComponent | DiscordUserSelectInteractionResponseFromMessageComponent | DiscordStringSelectInteractionResponseFromMessageComponent | DiscordChannelSelectInteractionResponseFromMessageComponent | DiscordMentionableSelectInteractionResponseFromMessageComponent;
45
47
  /** https://discord.com/developers/docs/components/reference#anatomy-of-a-component */
@@ -455,7 +457,7 @@ export interface DiscordLabelComponent extends DiscordBaseComponent {
455
457
  */
456
458
  description?: string;
457
459
  /** The component within the label */
458
- component: DiscordTextInputComponent | DiscordSelectMenuComponent;
460
+ component: DiscordTextInputComponent | DiscordSelectMenuComponent | DiscordFileUploadComponent;
459
461
  }
460
462
  /** https://discord.com/developers/docs/components/reference#label-label-interaction-response-structure */
461
463
  export interface DiscordLabelInteractionResponse {
@@ -463,7 +465,46 @@ export interface DiscordLabelInteractionResponse {
463
465
  /** 32 bit integer used as an optional identifier for component */
464
466
  id: number;
465
467
  /** The component within the label */
466
- component: DiscordTextInputInteractionResponse | DiscordStringSelectInteractionResponseFromModal | DiscordUserSelectInteractionResponseFromModal | DiscordRoleSelectInteractionResponseFromModal | DiscordMentionableSelectInteractionResponseFromModal | DiscordChannelSelectInteractionResponseFromModal;
468
+ component: DiscordTextInputInteractionResponse | DiscordStringSelectInteractionResponseFromModal | DiscordUserSelectInteractionResponseFromModal | DiscordRoleSelectInteractionResponseFromModal | DiscordMentionableSelectInteractionResponseFromModal | DiscordChannelSelectInteractionResponseFromModal | DiscordFileUploadInteractionResponse;
469
+ }
470
+ /** https://discord.com/developers/docs/components/reference#file-upload-file-upload-structure */
471
+ export interface DiscordFileUploadComponent extends DiscordBaseComponent {
472
+ type: MessageComponentTypes.FileUpload;
473
+ /** The custom id for the file upload */
474
+ custom_id: string;
475
+ /**
476
+ * The minimum number of files that must be uploaded
477
+ *
478
+ * @remarks
479
+ * Between 0-10
480
+ *
481
+ * @default 1
482
+ */
483
+ min_values?: number;
484
+ /** The maximum number of files that can be uploaded
485
+ *
486
+ * @remarks
487
+ * Between 1-10
488
+ *
489
+ * @default 1
490
+ */
491
+ max_values?: number;
492
+ /**
493
+ * Whether this component is required to be filled
494
+ *
495
+ * @default true
496
+ */
497
+ required?: boolean;
498
+ }
499
+ /** https://discord.com/developers/docs/components/reference#file-upload-file-upload-interaction-response-structure */
500
+ export interface DiscordFileUploadInteractionResponse {
501
+ type: MessageComponentTypes.FileUpload;
502
+ /** Unique identifier for the component */
503
+ id: number;
504
+ /** The custom id for the file upload */
505
+ custom_id: string;
506
+ /** IDs of the uploaded files found in the resolved data */
507
+ values: string[];
467
508
  }
468
509
  /** https://discord.com/developers/docs/components/reference#unfurled-media-item-structure */
469
510
  export interface DiscordUnfurledMediaItem {
@@ -1 +1 @@
1
- {"version":3,"file":"components.d.ts","sourceRoot":"","sources":["../../src/discord/components.ts"],"names":[],"mappings":"AAAA,0EAA0E;AAE1E,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AAC3C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAChD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAC9C,OAAO,KAAK,EAAE,8BAA8B,EAAE,MAAM,mBAAmB,CAAA;AAEvE,gGAAgG;AAChG,oBAAY,qBAAqB;IAC/B,uCAAuC;IACvC,SAAS,IAAI;IACb,sBAAsB;IACtB,MAAM,IAAA;IACN,6CAA6C;IAC7C,YAAY,IAAA;IACZ,0BAA0B;IAC1B,SAAS,IAAA;IACT,4BAA4B;IAC5B,UAAU,IAAA;IACV,4BAA4B;IAC5B,UAAU,IAAA;IACV,sCAAsC;IACtC,iBAAiB,IAAA;IACjB,+BAA+B;IAC/B,aAAa,IAAA;IACb,iEAAiE;IACjE,OAAO,IAAA;IACP,oBAAoB;IACpB,WAAW,KAAA;IACX,mDAAmD;IACnD,SAAS,KAAA;IACT,qCAAqC;IACrC,YAAY,KAAA;IACZ,gCAAgC;IAChC,IAAI,KAAA;IACJ,iEAAiE;IACjE,SAAS,KAAA;IACT,yDAAyD;IACzD,SAAS,KAAK;IACd,qEAAqE;IACrE,KAAK,KAAA;CACN;AAED,MAAM,MAAM,wBAAwB,GAAG,uBAAuB,EAAE,CAAA;AAChE,MAAM,MAAM,uBAAuB,GAC/B,gBAAgB,GAChB,0BAA0B,GAC1B,sBAAsB,GACtB,yBAAyB,GACzB,uBAAuB,GACvB,2BAA2B,GAC3B,yBAAyB,GACzB,4BAA4B,GAC5B,yBAAyB,GACzB,yBAAyB,GACzB,oBAAoB,GACpB,qBAAqB,CAAA;AAEzB,MAAM,MAAM,mDAAmD,GAC3D,mCAAmC,GACnC,qCAAqC,GACrC,+BAA+B,CAAA;AAEnC,MAAM,MAAM,8DAA8D,GACtE,wDAAwD,GACxD,wDAAwD,GACxD,0DAA0D,GAC1D,2DAA2D,GAC3D,+DAA+D,CAAA;AAEnE,sFAAsF;AACtF,MAAM,WAAW,oBAAoB;IACnC,gCAAgC;IAChC,IAAI,EAAE,qBAAqB,CAAA;IAC3B,kEAAkE;IAClE,EAAE,CAAC,EAAE,MAAM,CAAA;CACZ;AAED,+FAA+F;AAC/F,MAAM,WAAW,gBAAiB,SAAQ,oBAAoB;IAC5D,IAAI,EAAE,qBAAqB,CAAC,SAAS,CAAA;IAErC;;;;;;;;OAQG;IACH,UAAU,EAAE,CAAC,sBAAsB,GAAG,0BAA0B,GAAG,yBAAyB,CAAC,EAAE,CAAA;CAChG;AAED,uFAAuF;AACvF,MAAM,WAAW,sBAAuB,SAAQ,oBAAoB;IAClE,IAAI,EAAE,qBAAqB,CAAC,MAAM,CAAA;IAElC,iDAAiD;IACjD,KAAK,EAAE,YAAY,CAAA;IACnB;;;;;;OAMG;IACH,KAAK,CAAC,EAAE,MAAM,CAAA;IACd;;;;;OAKG;IACH,KAAK,CAAC,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,GAAG,MAAM,GAAG,UAAU,CAAC,CAAA;IACtD;;;;;OAKG;IACH,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB;;;;;OAKG;IACH,MAAM,CAAC,EAAE,MAAM,CAAA;IACf;;;;;;;OAOG;IACH,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ,6CAA6C;IAC7C,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB;AAED,oFAAoF;AACpF,oBAAY,YAAY;IACtB,uBAAuB;IACvB,OAAO,IAAI;IACX,oBAAoB;IACpB,SAAS,IAAA;IACT,qBAAqB;IACrB,OAAO,IAAA;IACP,mBAAmB;IACnB,MAAM,IAAA;IACN,uCAAuC;IACvC,IAAI,IAAA;IACJ,0DAA0D;IAC1D,OAAO,IAAA;CACR;AAED;;;;;;GAMG;AACH,MAAM,WAAW,0BAA2B,SAAQ,oBAAoB;IACtE,IAAI,EACA,qBAAqB,CAAC,YAAY,GAClC,qBAAqB,CAAC,UAAU,GAChC,qBAAqB,CAAC,UAAU,GAChC,qBAAqB,CAAC,iBAAiB,GACvC,qBAAqB,CAAC,aAAa,CAAA;IAEvC,sEAAsE;IACtE,SAAS,EAAE,MAAM,CAAA;IACjB,+DAA+D;IAC/D,OAAO,CAAC,EAAE,mBAAmB,EAAE,CAAA;IAC/B,gFAAgF;IAChF,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,kFAAkF;IAClF,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,2EAA2E;IAC3E,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB;;;;;;;OAOG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB;;;;;;;OAOG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB;;;;;OAKG;IACH,cAAc,CAAC,EAAE,6BAA6B,EAAE,CAAA;IAChD,6EAA6E;IAC7E,aAAa,CAAC,EAAE,YAAY,EAAE,CAAA;CAC/B;AAED,qGAAqG;AACrG,MAAM,WAAW,mBAAmB;IAClC,iEAAiE;IACjE,KAAK,EAAE,MAAM,CAAA;IACb,mEAAmE;IACnE,KAAK,EAAE,MAAM,CAAA;IACb,sEAAsE;IACtE,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,yDAAyD;IACzD,KAAK,CAAC,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,GAAG,MAAM,GAAG,UAAU,CAAC,CAAA;IACtD,8DAA8D;IAC9D,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB;AAED,2HAA2H;AAC3H,MAAM,WAAW,sCAAsC;IACrD;;;OAGG;IACH,IAAI,CAAC,EAAE,qBAAqB,CAAC,YAAY,CAAA;IACzC;;;OAGG;IACH,cAAc,CAAC,EAAE,qBAAqB,CAAC,YAAY,CAAA;IACnD,kEAAkE;IAClE,EAAE,EAAE,MAAM,CAAA;IACV,+CAA+C;IAC/C,SAAS,EAAE,MAAM,CAAA;IACjB,uCAAuC;IACvC,MAAM,EAAE,MAAM,EAAE,CAAA;CACjB;AAED,0HAA0H;AAC1H,MAAM,MAAM,+CAA+C,GAAG,OAAO,CAAC,IAAI,CAAC,sCAAsC,EAAE,gBAAgB,CAAC,EAAE,MAAM,CAAC,CAAA;AAC7I,0HAA0H;AAC1H,MAAM,MAAM,0DAA0D,GAAG,OAAO,CAC9E,IAAI,CAAC,sCAAsC,EAAE,MAAM,CAAC,EACpD,gBAAgB,CACjB,CAAA;AAED,+FAA+F;AAC/F,MAAM,WAAW,yBAA0B,SAAQ,oBAAoB;IACrE,IAAI,EAAE,qBAAqB,CAAC,SAAS,CAAA;IAErC,oCAAoC;IACpC,SAAS,EAAE,MAAM,CAAA;IACjB,iCAAiC;IACjC,KAAK,EAAE,UAAU,CAAA;IACjB;;;;;;;OAOG;IACH,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,6DAA6D;IAC7D,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,6DAA6D;IAC7D,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,oEAAoE;IACpE,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,uCAAuC;IACvC,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,uCAAuC;IACvC,WAAW,CAAC,EAAE,MAAM,CAAA;CACrB;AAED,4FAA4F;AAC5F,oBAAY,UAAU;IACpB,0CAA0C;IAC1C,KAAK,IAAI;IACT,sCAAsC;IACtC,SAAS,IAAI;CACd;AAED,oHAAoH;AACpH,MAAM,WAAW,mCAAmC;IAClD,IAAI,EAAE,qBAAqB,CAAC,SAAS,CAAA;IACrC,kEAAkE;IAClE,EAAE,EAAE,MAAM,CAAA;IACV,uCAAuC;IACvC,SAAS,EAAE,MAAM,CAAA;IACjB,4BAA4B;IAC5B,KAAK,EAAE,MAAM,CAAA;CACd;AAED,0GAA0G;AAC1G,MAAM,WAAW,6BAA6B;IAC5C,qCAAqC;IACrC,EAAE,EAAE,MAAM,CAAA;IACV,wCAAwC;IACxC,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAAA;CAClC;AAED,sHAAsH;AACtH,MAAM,WAAW,oCAAoC;IACnD;;;OAGG;IACH,IAAI,CAAC,EAAE,qBAAqB,CAAC,UAAU,CAAA;IACvC;;;OAGG;IACH,cAAc,CAAC,EAAE,qBAAqB,CAAC,UAAU,CAAA;IACjD,kEAAkE;IAClE,EAAE,EAAE,MAAM,CAAA;IACV,wCAAwC;IACxC,SAAS,EAAE,MAAM,CAAA;IACjB,8CAA8C;IAC9C,QAAQ,EAAE,8BAA8B,CAAA;IACxC,gCAAgC;IAChC,MAAM,EAAE,MAAM,EAAE,CAAA;CACjB;AAED,sHAAsH;AACtH,MAAM,MAAM,6CAA6C,GAAG,OAAO,CAAC,IAAI,CAAC,oCAAoC,EAAE,gBAAgB,CAAC,EAAE,MAAM,CAAC,CAAA;AACzI,sHAAsH;AACtH,MAAM,MAAM,wDAAwD,GAAG,OAAO,CAAC,IAAI,CAAC,oCAAoC,EAAE,MAAM,CAAC,EAAE,gBAAgB,CAAC,CAAA;AAEpJ,sHAAsH;AACtH,MAAM,WAAW,oCAAoC;IACnD;;;OAGG;IACH,IAAI,CAAC,EAAE,qBAAqB,CAAC,UAAU,CAAA;IACvC;;;OAGG;IACH,cAAc,CAAC,EAAE,qBAAqB,CAAC,UAAU,CAAA;IACjD,kEAAkE;IAClE,EAAE,EAAE,MAAM,CAAA;IACV,wCAAwC;IACxC,SAAS,EAAE,MAAM,CAAA;IACjB,8CAA8C;IAC9C,QAAQ,EAAE,8BAA8B,CAAA;IACxC,gCAAgC;IAChC,MAAM,EAAE,MAAM,EAAE,CAAA;CACjB;AAED,sHAAsH;AACtH,MAAM,MAAM,6CAA6C,GAAG,OAAO,CAAC,IAAI,CAAC,oCAAoC,EAAE,gBAAgB,CAAC,EAAE,MAAM,CAAC,CAAA;AACzI,sHAAsH;AACtH,MAAM,MAAM,wDAAwD,GAAG,OAAO,CAAC,IAAI,CAAC,oCAAoC,EAAE,MAAM,CAAC,EAAE,gBAAgB,CAAC,CAAA;AAEpJ,oIAAoI;AACpI,MAAM,WAAW,2CAA2C;IAC1D;;;OAGG;IACH,IAAI,CAAC,EAAE,qBAAqB,CAAC,iBAAiB,CAAA;IAC9C;;;OAGG;IACH,cAAc,CAAC,EAAE,qBAAqB,CAAC,iBAAiB,CAAA;IACxD,kEAAkE;IAClE,EAAE,EAAE,MAAM,CAAA;IACV,+CAA+C;IAC/C,SAAS,EAAE,MAAM,CAAA;IACjB,8CAA8C;IAC9C,QAAQ,EAAE,8BAA8B,CAAA;IACxC,uCAAuC;IACvC,MAAM,EAAE,MAAM,EAAE,CAAA;CACjB;AAED,oIAAoI;AACpI,MAAM,MAAM,oDAAoD,GAAG,OAAO,CACxE,IAAI,CAAC,2CAA2C,EAAE,gBAAgB,CAAC,EACnE,MAAM,CACP,CAAA;AACD,oIAAoI;AACpI,MAAM,MAAM,+DAA+D,GAAG,OAAO,CACnF,IAAI,CAAC,2CAA2C,EAAE,MAAM,CAAC,EACzD,gBAAgB,CACjB,CAAA;AAED,4HAA4H;AAC5H,MAAM,WAAW,uCAAuC;IACtD;;;OAGG;IACH,IAAI,CAAC,EAAE,qBAAqB,CAAC,aAAa,CAAA;IAC1C;;;OAGG;IACH,cAAc,CAAC,EAAE,qBAAqB,CAAC,aAAa,CAAA;IACpD,kEAAkE;IAClE,EAAE,EAAE,MAAM,CAAA;IACV,2CAA2C;IAC3C,SAAS,EAAE,MAAM,CAAA;IACjB,8CAA8C;IAC9C,QAAQ,EAAE,8BAA8B,CAAA;IACxC,mCAAmC;IACnC,MAAM,EAAE,MAAM,EAAE,CAAA;CACjB;AAED,4HAA4H;AAC5H,MAAM,MAAM,gDAAgD,GAAG,OAAO,CAAC,IAAI,CAAC,uCAAuC,EAAE,gBAAgB,CAAC,EAAE,MAAM,CAAC,CAAA;AAC/I,4HAA4H;AAC5H,MAAM,MAAM,2DAA2D,GAAG,OAAO,CAC/E,IAAI,CAAC,uCAAuC,EAAE,MAAM,CAAC,EACrD,gBAAgB,CACjB,CAAA;AAED,yFAAyF;AACzF,MAAM,WAAW,uBAAwB,SAAQ,oBAAoB;IACnE,IAAI,EAAE,qBAAqB,CAAC,OAAO,CAAA;IAEnC,mCAAmC;IACnC,UAAU,EAAE,2BAA2B,EAAE,CAAA;IACzC,wGAAwG;IACxG,SAAS,EAAE,sBAAsB,GAAG,yBAAyB,CAAA;CAC9D;AAED,mGAAmG;AACnG,MAAM,WAAW,2BAA4B,SAAQ,oBAAoB;IACvE,IAAI,EAAE,qBAAqB,CAAC,WAAW,CAAA;IAEvC,uDAAuD;IACvD,OAAO,EAAE,MAAM,CAAA;CAChB;AAED,wHAAwH;AACxH,MAAM,WAAW,qCAAqC;IACpD,IAAI,EAAE,qBAAqB,CAAC,WAAW,CAAA;IACvC,kEAAkE;IAClE,EAAE,EAAE,MAAM,CAAA;CACX;AAED,MAAM,WAAW,yBAA0B,SAAQ,oBAAoB;IACrE,IAAI,EAAE,qBAAqB,CAAC,SAAS,CAAA;IAErC,0BAA0B;IAC1B,KAAK,EAAE,wBAAwB,CAAA;IAC/B,kDAAkD;IAClD,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,sFAAsF;IACtF,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB;AAED,qGAAqG;AACrG,MAAM,WAAW,4BAA6B,SAAQ,oBAAoB;IACxE,IAAI,EAAE,qBAAqB,CAAC,YAAY,CAAA;IAExC,kCAAkC;IAClC,KAAK,EAAE,uBAAuB,EAAE,CAAA;CACjC;AAED,0GAA0G;AAC1G,MAAM,WAAW,uBAAuB;IACtC,0BAA0B;IAC1B,KAAK,EAAE,wBAAwB,CAAA;IAC/B,kDAAkD;IAClD,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,kFAAkF;IAClF,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB;AAED,mFAAmF;AACnF,MAAM,WAAW,oBAAqB,SAAQ,oBAAoB;IAChE,IAAI,EAAE,qBAAqB,CAAC,IAAI,CAAA;IAEhC,iIAAiI;IACjI,IAAI,EAAE,wBAAwB,CAAA;IAC9B,kFAAkF;IAClF,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,kGAAkG;IAClG,IAAI,EAAE,MAAM,CAAA;IACZ,2GAA2G;IAC3G,IAAI,EAAE,MAAM,CAAA;CACb;AAED,6FAA6F;AAC7F,MAAM,WAAW,yBAA0B,SAAQ,oBAAoB;IACrE,IAAI,EAAE,qBAAqB,CAAC,SAAS,CAAA;IAErC,wFAAwF;IACxF,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,gGAAgG;IAChG,OAAO,CAAC,EAAE,oBAAoB,CAAA;CAC/B;AAED,kHAAkH;AAClH,oBAAY,oBAAoB;IAC9B,KAAK,IAAI;IACT,KAAK,IAAI;CACV;AAED,6FAA6F;AAC7F,MAAM,WAAW,yBAA0B,SAAQ,oBAAoB;IACrE,IAAI,EAAE,qBAAqB,CAAC,SAAS,CAAA;IAErC,kGAAkG;IAClG,UAAU,EAAE,KAAK,CACb,gBAAgB,GAChB,2BAA2B,GAC3B,uBAAuB,GACvB,4BAA4B,GAC5B,yBAAyB,GACzB,oBAAoB,CACvB,CAAA;IACD,6EAA6E;IAC7E,YAAY,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAC5B,sFAAsF;IACtF,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB;AAED,qFAAqF;AACrF,MAAM,WAAW,qBAAsB,SAAQ,oBAAoB;IACjE,IAAI,EAAE,qBAAqB,CAAC,KAAK,CAAA;IAEjC;;;;;OAKG;IACH,KAAK,EAAE,MAAM,CAAA;IACb;;;;;OAKG;IACH,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,qCAAqC;IACrC,SAAS,EAAE,yBAAyB,GAAG,0BAA0B,CAAA;CAClE;AAED,0GAA0G;AAC1G,MAAM,WAAW,+BAA+B;IAC9C,IAAI,EAAE,qBAAqB,CAAC,KAAK,CAAA;IACjC,kEAAkE;IAClE,EAAE,EAAE,MAAM,CAAA;IACV,qCAAqC;IACrC,SAAS,EACL,mCAAmC,GACnC,+CAA+C,GAC/C,6CAA6C,GAC7C,6CAA6C,GAC7C,oDAAoD,GACpD,gDAAgD,CAAA;CACrD;AAED,6FAA6F;AAC7F,MAAM,WAAW,wBAAwB;IACvC,qEAAqE;IACrE,GAAG,EAAE,MAAM,CAAA;IACX,+GAA+G;IAC/G,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,0GAA0G;IAC1G,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACtB,yGAAyG;IACzG,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACrB,2GAA2G;IAC3G,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,wKAAwK;IACxK,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;CAC9B"}
1
+ {"version":3,"file":"components.d.ts","sourceRoot":"","sources":["../../src/discord/components.ts"],"names":[],"mappings":"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"}
@@ -15,6 +15,7 @@
15
15
  /** Component to add vertical padding between other components */ MessageComponentTypes[MessageComponentTypes["Separator"] = 14] = "Separator";
16
16
  /** Container that visually groups a set of components */ MessageComponentTypes[MessageComponentTypes["Container"] = 17] = "Container";
17
17
  /** Container associating a label and description with a component */ MessageComponentTypes[MessageComponentTypes["Label"] = 18] = "Label";
18
+ /** Component for uploading files */ MessageComponentTypes[MessageComponentTypes["FileUpload"] = 19] = "FileUpload";
18
19
  return MessageComponentTypes;
19
20
  }({});
20
21
  /** https://discord.com/developers/docs/components/reference#button-button-styles */ export var ButtonStyles = /*#__PURE__*/ function(ButtonStyles) {
@@ -37,4 +38,4 @@
37
38
  return SeparatorSpacingSize;
38
39
  }({});
39
40
 
40
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/discord/components.ts"],"sourcesContent":["/** Types for: https://discord.com/developers/docs/components/reference */\n\nimport type { Require } from '../shared.js'\nimport type { ChannelTypes } from './channel.js'\nimport type { DiscordEmoji } from './emoji.js'\nimport type { DiscordInteractionDataResolved } from './interactions.js'\n\n/** https://discord.com/developers/docs/components/reference#component-object-component-types */\nexport enum MessageComponentTypes {\n  /** A container for other components */\n  ActionRow = 1,\n  /** A button object */\n  Button,\n  /** A select menu for picking from choices */\n  StringSelect,\n  /** A text input object */\n  TextInput,\n  /** Select menu for users */\n  UserSelect,\n  /** Select menu for roles */\n  RoleSelect,\n  /** Select menu for users and roles */\n  MentionableSelect,\n  /** Select menu for channels */\n  ChannelSelect,\n  /** Container to display text alongside an accessory component */\n  Section,\n  /** Markdown text */\n  TextDisplay,\n  /** Small image that can be used as an accessory */\n  Thumbnail,\n  /** Display images and other media */\n  MediaGallery,\n  /** Displays an attached file */\n  File,\n  /** Component to add vertical padding between other components */\n  Separator,\n  /** Container that visually groups a set of components */\n  Container = 17,\n  /** Container associating a label and description with a component */\n  Label,\n}\n\nexport type DiscordMessageComponents = DiscordMessageComponent[]\nexport type DiscordMessageComponent =\n  | DiscordActionRow\n  | DiscordSelectMenuComponent\n  | DiscordButtonComponent\n  | DiscordTextInputComponent\n  | DiscordSectionComponent\n  | DiscordTextDisplayComponent\n  | DiscordThumbnailComponent\n  | DiscordMediaGalleryComponent\n  | DiscordSeparatorComponent\n  | DiscordContainerComponent\n  | DiscordFileComponent\n  | DiscordLabelComponent\n\nexport type DiscordMessageComponentFromModalInteractionResponse =\n  | DiscordTextInputInteractionResponse\n  | DiscordTextDisplayInteractionResponse\n  | DiscordLabelInteractionResponse\n\nexport type DiscordMessageComponentFromMessageComponentInteractionResponse =\n  | DiscordRoleSelectInteractionResponseFromMessageComponent\n  | DiscordUserSelectInteractionResponseFromMessageComponent\n  | DiscordStringSelectInteractionResponseFromMessageComponent\n  | DiscordChannelSelectInteractionResponseFromMessageComponent\n  | DiscordMentionableSelectInteractionResponseFromMessageComponent\n\n/** https://discord.com/developers/docs/components/reference#anatomy-of-a-component */\nexport interface DiscordBaseComponent {\n  /** The type of the component */\n  type: MessageComponentTypes\n  /** 32 bit integer used as an optional identifier for component */\n  id?: number\n}\n\n/** https://discord.com/developers/docs/components/reference#action-row-action-row-structure */\nexport interface DiscordActionRow extends DiscordBaseComponent {\n  type: MessageComponentTypes.ActionRow\n\n  /**\n   * The components in this row\n   *\n   * @remarks\n   * Up to 5 button components, a single select component or a single text input component\n   *\n   * Using a {@link DiscordTextInputComponent} inside the Action Row is deprecated,\n   * use a {@link DiscordLabelComponent} for modals\n   */\n  components: (DiscordButtonComponent | DiscordSelectMenuComponent | DiscordTextInputComponent)[]\n}\n\n/** https://discord.com/developers/docs/components/reference#button-button-structure */\nexport interface DiscordButtonComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.Button\n\n  /** For different styles/colors of the buttons */\n  style: ButtonStyles\n  /**\n   * Text that appears on the button\n   *\n   * @remarks\n   * A label can have a max of 80 characters\n   * A button of style {@link ButtonStyles.Premium | Premium} cannot have a label\n   */\n  label?: string\n  /**\n   * Emoji object that includes fields of name, id, and animated supporting unicode and custom emojis.\n   *\n   * @remarks\n   * A button of style {@link ButtonStyles.Premium | Premium} cannot have an emoji\n   */\n  emoji?: Pick<DiscordEmoji, 'id' | 'name' | 'animated'>\n  /**\n   * A dev-defined unique string sent on click (max 100 characters).\n   *\n   * @remarks\n   * A button of style {@link ButtonStyles.Link | Link} or {@link ButtonStyles.Premium | Premium} cannot have a custom_id\n   */\n  custom_id?: string\n  /**\n   * Identifier for a purchasable SKU\n   *\n   * @remarks\n   * Buttons of style {@link ButtonStyles.Premium | Premium} must have a sku_id, any other button with a different style can not have a a sku_id\n   */\n  sku_id?: string\n  /**\n   * Url for {@link ButtonStyles.Link | link} buttons that can navigate a user to the web.\n   *\n   * @remarks\n   * Buttons of style {@link ButtonStyles.Link | Link} must have an url, any other button with a different style can not have an url\n   *\n   * Maximum 512 characters.\n   */\n  url?: string\n  /** Whether or not this button is disabled */\n  disabled?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#button-button-styles */\nexport enum ButtonStyles {\n  /** A blurple button */\n  Primary = 1,\n  /** A grey button */\n  Secondary,\n  /** A green button */\n  Success,\n  /** A red button */\n  Danger,\n  /** A button that navigates to a URL */\n  Link,\n  /** A blurple button to show a Premium item in the shop */\n  Premium,\n}\n\n/**\n * https://discord.com/developers/docs/components/reference#string-select\n * https://discord.com/developers/docs/components/reference#user-select\n * https://discord.com/developers/docs/components/reference#role-select\n * https://discord.com/developers/docs/components/reference#mentionable-select\n * https://discord.com/developers/docs/components/reference#channel-select\n */\nexport interface DiscordSelectMenuComponent extends DiscordBaseComponent {\n  type:\n    | MessageComponentTypes.StringSelect\n    | MessageComponentTypes.UserSelect\n    | MessageComponentTypes.RoleSelect\n    | MessageComponentTypes.MentionableSelect\n    | MessageComponentTypes.ChannelSelect\n\n  /** A custom identifier for this component. Maximum 100 characters. */\n  custom_id: string\n  /** Specified choices in a select menu; Maximum of 25 items. */\n  options?: DiscordSelectOption[]\n  /** A custom placeholder text if nothing is selected. Maximum 150 characters. */\n  placeholder?: string\n  /** The minimum number of items that must be selected. Default 1. Between 0-25. */\n  min_values?: number\n  /** The maximum number of items that can be selected. Default 1. Max 25. */\n  max_values?: number\n  /**\n   * Whether this component is required to be filled\n   *\n   * @remarks\n   * This value is only valid for select menus in modals\n   *\n   * @default true\n   */\n  required?: boolean\n  /**\n   * Whether select menu is disabled\n   *\n   * @remarks\n   * This value cannot be set for select menus in modals\n   *\n   * @default false\n   */\n  disabled?: boolean\n  /**\n   * List of default values for auto-populated select menu components\n   *\n   * @remarks\n   * The number of default values must be in the range defined by min_values and max_values\n   */\n  default_values?: DiscordSelectMenuDefaultValue[]\n  /** List of channel types to include in a channel select menu options list */\n  channel_types?: ChannelTypes[]\n}\n\n/** https://discord.com/developers/docs/components/reference#string-select-select-option-structure */\nexport interface DiscordSelectOption {\n  /** The user-facing name of the option. Maximum 25 characters. */\n  label: string\n  /** The dev-defined value of the option. Maximum 100 characters. */\n  value: string\n  /** An additional description of the option. Maximum 50 characters. */\n  description?: string\n  /** The id, name, and animated properties of an emoji. */\n  emoji?: Pick<DiscordEmoji, 'id' | 'name' | 'animated'>\n  /** Will render this option as already-selected by default. */\n  default?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#string-select-strings-select-interaction-response-structure */\nexport interface DiscordStringSelectInteractionResponse {\n  /**\n   * @remarks\n   * This is only returned for interaction responses from modals\n   */\n  type?: MessageComponentTypes.StringSelect\n  /**\n   * @remarks\n   * This is only returned for interaction responses from message interactions\n   */\n  component_type?: MessageComponentTypes.StringSelect\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n  /** The custom id for the string select menu */\n  custom_id: string\n  /** The text of the selected options */\n  values: string[]\n}\n\n/** https://discord.com/developers/docs/components/reference#string-select-string-select-interaction-response-structure */\nexport type DiscordStringSelectInteractionResponseFromModal = Require<Omit<DiscordStringSelectInteractionResponse, 'component_type'>, 'type'>\n/** https://discord.com/developers/docs/components/reference#string-select-string-select-interaction-response-structure */\nexport type DiscordStringSelectInteractionResponseFromMessageComponent = Require<\n  Omit<DiscordStringSelectInteractionResponse, 'type'>,\n  'component_type'\n>\n\n/** https://discord.com/developers/docs/components/reference#text-input-text-input-structure */\nexport interface DiscordTextInputComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.TextInput\n\n  /** The customId of the InputText */\n  custom_id: string\n  /** The style of the InputText */\n  style: TextStyles\n  /**\n   * The label of the InputText.\n   *\n   * @remarks\n   * Maximum 45 characters\n   *\n   * @deprecated Use the `label` and `description` from the {@link DiscordLabelComponent}\n   */\n  label?: string\n  /** The minimum length of the text the user has to provide */\n  min_length?: number\n  /** The maximum length of the text the user has to provide */\n  max_length?: number\n  /** whether this component is required to be filled, default true */\n  required?: boolean\n  /** Pre-filled value for input text. */\n  value?: string\n  /** The placeholder of the InputText */\n  placeholder?: string\n}\n\n/** https://discord.com/developers/docs/components/reference#text-input-text-input-styles */\nexport enum TextStyles {\n  /** Intended for short single-line text */\n  Short = 1,\n  /** Intended for much longer inputs */\n  Paragraph = 2,\n}\n\n/** https://discord.com/developers/docs/components/reference#text-input-text-input-interaction-response-structure */\nexport interface DiscordTextInputInteractionResponse {\n  type: MessageComponentTypes.TextInput\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n  /** The custom id for the text input */\n  custom_id: string\n  /** The user's input text */\n  value: string\n}\n\n/** https://discord.com/developers/docs/components/reference#user-select-select-default-value-structure */\nexport interface DiscordSelectMenuDefaultValue {\n  /** ID of a user, role, or channel */\n  id: string\n  /** Type of value that id represents. */\n  type: 'user' | 'role' | 'channel'\n}\n\n/** https://discord.com/developers/docs/components/reference#user-select-user-select-interaction-response-structure */\nexport interface DiscordUserSelectInteractionResponse {\n  /**\n   * @remarks\n   * This is only returned for interaction responses from modals\n   */\n  type?: MessageComponentTypes.UserSelect\n  /**\n   * @remarks\n   * This is only returned for interaction responses from message interactions\n   */\n  component_type?: MessageComponentTypes.UserSelect\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n  /** The custom id for the user select */\n  custom_id: string\n  /** Resolved entities from selected options */\n  resolved: DiscordInteractionDataResolved\n  /** IDs of the selected users */\n  values: string[]\n}\n\n/** https://discord.com/developers/docs/components/reference#user-select-user-select-interaction-response-structure */\nexport type DiscordUserSelectInteractionResponseFromModal = Require<Omit<DiscordUserSelectInteractionResponse, 'component_type'>, 'type'>\n/** https://discord.com/developers/docs/components/reference#user-select-user-select-interaction-response-structure */\nexport type DiscordUserSelectInteractionResponseFromMessageComponent = Require<Omit<DiscordUserSelectInteractionResponse, 'type'>, 'component_type'>\n\n/** https://discord.com/developers/docs/components/reference#role-select-role-select-interaction-response-structure */\nexport interface DiscordRoleSelectInteractionResponse {\n  /**\n   * @remarks\n   * This is only returned for interaction responses from modals\n   */\n  type?: MessageComponentTypes.RoleSelect\n  /**\n   * @remarks\n   * This is only returned for interaction responses from message interactions\n   */\n  component_type?: MessageComponentTypes.RoleSelect\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n  /** The custom id for the role select */\n  custom_id: string\n  /** Resolved entities from selected options */\n  resolved: DiscordInteractionDataResolved\n  /** IDs of the selected roles */\n  values: string[]\n}\n\n/** https://discord.com/developers/docs/components/reference#role-select-role-select-interaction-response-structure */\nexport type DiscordRoleSelectInteractionResponseFromModal = Require<Omit<DiscordRoleSelectInteractionResponse, 'component_type'>, 'type'>\n/** https://discord.com/developers/docs/components/reference#role-select-role-select-interaction-response-structure */\nexport type DiscordRoleSelectInteractionResponseFromMessageComponent = Require<Omit<DiscordRoleSelectInteractionResponse, 'type'>, 'component_type'>\n\n/** https://discord.com/developers/docs/components/reference#mentionable-select-mentionable-select-interaction-response-structure */\nexport interface DiscordMentionableSelectInteractionResponse {\n  /**\n   * @remarks\n   * This is only returned for interaction responses from modals\n   */\n  type?: MessageComponentTypes.MentionableSelect\n  /**\n   * @remarks\n   * This is only returned for interaction responses from message interactions\n   */\n  component_type?: MessageComponentTypes.MentionableSelect\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n  /** The custom id for the mentionable select */\n  custom_id: string\n  /** Resolved entities from selected options */\n  resolved: DiscordInteractionDataResolved\n  /** IDs of the selected mentionables */\n  values: string[]\n}\n\n/** https://discord.com/developers/docs/components/reference#mentionable-select-mentionable-select-interaction-response-structure */\nexport type DiscordMentionableSelectInteractionResponseFromModal = Require<\n  Omit<DiscordMentionableSelectInteractionResponse, 'component_type'>,\n  'type'\n>\n/** https://discord.com/developers/docs/components/reference#mentionable-select-mentionable-select-interaction-response-structure */\nexport type DiscordMentionableSelectInteractionResponseFromMessageComponent = Require<\n  Omit<DiscordMentionableSelectInteractionResponse, 'type'>,\n  'component_type'\n>\n\n/** https://discord.com/developers/docs/components/reference#channel-select-channel-select-interaction-response-structure */\nexport interface DiscordChannelSelectInteractionResponse {\n  /**\n   * @remarks\n   * This is only returned for interaction responses from modals\n   */\n  type?: MessageComponentTypes.ChannelSelect\n  /**\n   * @remarks\n   * This is only returned for interaction responses from message interactions\n   */\n  component_type?: MessageComponentTypes.ChannelSelect\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n  /** The custom id for the channel select */\n  custom_id: string\n  /** Resolved entities from selected options */\n  resolved: DiscordInteractionDataResolved\n  /** IDs of the selected channels */\n  values: string[]\n}\n\n/** https://discord.com/developers/docs/components/reference#channel-select-channel-select-interaction-response-structure */\nexport type DiscordChannelSelectInteractionResponseFromModal = Require<Omit<DiscordChannelSelectInteractionResponse, 'component_type'>, 'type'>\n/** https://discord.com/developers/docs/components/reference#channel-select-channel-select-interaction-response-structure */\nexport type DiscordChannelSelectInteractionResponseFromMessageComponent = Require<\n  Omit<DiscordChannelSelectInteractionResponse, 'type'>,\n  'component_type'\n>\n\n/** https://discord.com/developers/docs/components/reference#section-section-structure */\nexport interface DiscordSectionComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.Section\n\n  /** One to three text components */\n  components: DiscordTextDisplayComponent[]\n  /** A thumbnail or a button component, with a future possibility of adding more compatible components */\n  accessory: DiscordButtonComponent | DiscordThumbnailComponent\n}\n\n/** https://discord.com/developers/docs/components/reference#text-display-text-display-structure */\nexport interface DiscordTextDisplayComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.TextDisplay\n\n  /** Text that will be displayed similar to a message */\n  content: string\n}\n\n/** https://discord.com/developers/docs/components/reference#text-display-text-display-interaction-response-structure */\nexport interface DiscordTextDisplayInteractionResponse {\n  type: MessageComponentTypes.TextDisplay\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n}\n\nexport interface DiscordThumbnailComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.Thumbnail\n\n  /** A url or attachment */\n  media: DiscordUnfurledMediaItem\n  /** Alt text for the media, max 1024 characters */\n  description?: string\n  /** Whether the thumbnail should be a spoiler (or blurred out). Defaults to `false` */\n  spoiler?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#media-gallery-media-gallery-structure */\nexport interface DiscordMediaGalleryComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.MediaGallery\n\n  /** 1 to 10 media gallery items */\n  items: DiscordMediaGalleryItem[]\n}\n\n/** https://discord.com/developers/docs/components/reference#media-gallery-media-gallery-item-structure */\nexport interface DiscordMediaGalleryItem {\n  /** A url or attachment */\n  media: DiscordUnfurledMediaItem\n  /** Alt text for the media, max 1024 characters */\n  description?: string\n  /** Whether the media should be a spoiler (or blurred out). Defaults to `false` */\n  spoiler?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#file-file-structure */\nexport interface DiscordFileComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.File\n\n  /** This unfurled media item is unique in that it only supports attachment references using the attachment://<filename> syntax */\n  file: DiscordUnfurledMediaItem\n  /** Whether the media should be a spoiler (or blurred out). Defaults to `false` */\n  spoiler?: boolean\n  /** The name of the file. This field is ignored and provided by the API as part of the response */\n  name: string\n  /** The size of the file in bytes. This field is ignored and provided by the API as part of the response */\n  size: number\n}\n\n/** https://discord.com/developers/docs/components/reference#separator-separator-structure */\nexport interface DiscordSeparatorComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.Separator\n\n  /** Whether a visual divider should be displayed in the component. Defaults to `true` */\n  divider?: boolean\n  /** Size of separator padding — `1` for small padding, `2` for large padding. Defaults to `1` */\n  spacing?: SeparatorSpacingSize\n}\n\n/** https://discord.com/developers/docs/components/reference#separator-separator-structure, spacing description */\nexport enum SeparatorSpacingSize {\n  Small = 1,\n  Large = 2,\n}\n\n/** https://discord.com/developers/docs/components/reference#container-container-structure */\nexport interface DiscordContainerComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.Container\n\n  /** Components of the type action row, text display, section, media gallery, separator, or file */\n  components: Array<\n    | DiscordActionRow\n    | DiscordTextDisplayComponent\n    | DiscordSectionComponent\n    | DiscordMediaGalleryComponent\n    | DiscordSeparatorComponent\n    | DiscordFileComponent\n  >\n  /** Color for the accent on the container as RGB from 0x000000 to 0xFFFFFF */\n  accent_color?: number | null\n  /** Whether the container should be a spoiler (or blurred out). Defaults to `false` */\n  spoiler?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#label-label-structure */\nexport interface DiscordLabelComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.Label\n\n  /**\n   * The label text\n   *\n   * @remarks\n   * Max 45 characters.\n   */\n  label: string\n  /**\n   * An optional description text for the label\n   *\n   * @remarks\n   * Max 100 characters.\n   */\n  description?: string\n  /** The component within the label */\n  component: DiscordTextInputComponent | DiscordSelectMenuComponent\n}\n\n/** https://discord.com/developers/docs/components/reference#label-label-interaction-response-structure */\nexport interface DiscordLabelInteractionResponse {\n  type: MessageComponentTypes.Label\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n  /** The component within the label */\n  component:\n    | DiscordTextInputInteractionResponse\n    | DiscordStringSelectInteractionResponseFromModal\n    | DiscordUserSelectInteractionResponseFromModal\n    | DiscordRoleSelectInteractionResponseFromModal\n    | DiscordMentionableSelectInteractionResponseFromModal\n    | DiscordChannelSelectInteractionResponseFromModal\n}\n\n/** https://discord.com/developers/docs/components/reference#unfurled-media-item-structure */\nexport interface DiscordUnfurledMediaItem {\n  /** Supports arbitrary urls and attachment://<filename> references */\n  url: string\n  /** The proxied url of the media item. This field is ignored and provided by the API as part of the response */\n  proxy_url?: string\n  /** The height of the media item. This field is ignored and provided by the API as part of the response */\n  height?: number | null\n  /** The width of the media item. This field is ignored and provided by the API as part of the response */\n  width?: number | null\n  /** The media type of the content. This field is ignored and provided by the API as part of the response */\n  content_type?: string\n  /** The id of the uploaded attachment. Only present if the media was uploaded as an attachment. This field is ignored and provided by the API as part of the response */\n  attachment_id?: string | null\n}\n"],"names":["MessageComponentTypes","ButtonStyles","TextStyles","SeparatorSpacingSize"],"mappings":"AAAA,wEAAwE,GAOxE,8FAA8F,GAC9F,OAAO,IAAA,AAAKA,+CAAAA;IACV,qCAAqC;IAErC,oBAAoB;IAEpB,2CAA2C;IAE3C,wBAAwB;IAExB,0BAA0B;IAE1B,0BAA0B;IAE1B,oCAAoC;IAEpC,6BAA6B;IAE7B,+DAA+D;IAE/D,kBAAkB;IAElB,iDAAiD;IAEjD,mCAAmC;IAEnC,8BAA8B;IAE9B,+DAA+D;IAE/D,uDAAuD;IAEvD,mEAAmE;WA/BzDA;MAiCX;AAqGD,kFAAkF,GAClF,OAAO,IAAA,AAAKC,sCAAAA;IACV,qBAAqB;IAErB,kBAAkB;IAElB,mBAAmB;IAEnB,iBAAiB;IAEjB,qCAAqC;IAErC,wDAAwD;WAX9CA;MAaX;AA+HD,0FAA0F,GAC1F,OAAO,IAAA,AAAKC,oCAAAA;IACV,wCAAwC;IAExC,oCAAoC;WAH1BA;MAKX;AAwND,gHAAgH,GAChH,OAAO,IAAA,AAAKC,8CAAAA;;;WAAAA;MAGX"}
41
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/discord/components.ts"],"sourcesContent":["/** Types for: https://discord.com/developers/docs/components/reference */\n\nimport type { Require } from '../shared.js'\nimport type { ChannelTypes } from './channel.js'\nimport type { DiscordEmoji } from './emoji.js'\nimport type { DiscordInteractionDataResolved } from './interactions.js'\n\n/** https://discord.com/developers/docs/components/reference#component-object-component-types */\nexport enum MessageComponentTypes {\n  /** A container for other components */\n  ActionRow = 1,\n  /** A button object */\n  Button,\n  /** A select menu for picking from choices */\n  StringSelect,\n  /** A text input object */\n  TextInput,\n  /** Select menu for users */\n  UserSelect,\n  /** Select menu for roles */\n  RoleSelect,\n  /** Select menu for users and roles */\n  MentionableSelect,\n  /** Select menu for channels */\n  ChannelSelect,\n  /** Container to display text alongside an accessory component */\n  Section,\n  /** Markdown text */\n  TextDisplay,\n  /** Small image that can be used as an accessory */\n  Thumbnail,\n  /** Display images and other media */\n  MediaGallery,\n  /** Displays an attached file */\n  File,\n  /** Component to add vertical padding between other components */\n  Separator,\n  /** Container that visually groups a set of components */\n  Container = 17,\n  /** Container associating a label and description with a component */\n  Label,\n  /** Component for uploading files */\n  FileUpload,\n}\n\nexport type DiscordMessageComponents = DiscordMessageComponent[]\nexport type DiscordMessageComponent =\n  | DiscordActionRow\n  | DiscordSelectMenuComponent\n  | DiscordButtonComponent\n  | DiscordTextInputComponent\n  | DiscordSectionComponent\n  | DiscordTextDisplayComponent\n  | DiscordThumbnailComponent\n  | DiscordMediaGalleryComponent\n  | DiscordSeparatorComponent\n  | DiscordContainerComponent\n  | DiscordFileComponent\n  | DiscordLabelComponent\n  | DiscordFileUploadComponent\n\nexport type DiscordMessageComponentFromModalInteractionResponse =\n  | DiscordTextInputInteractionResponse\n  | DiscordTextDisplayInteractionResponse\n  | DiscordLabelInteractionResponse\n\nexport type DiscordMessageComponentFromMessageComponentInteractionResponse =\n  | DiscordRoleSelectInteractionResponseFromMessageComponent\n  | DiscordUserSelectInteractionResponseFromMessageComponent\n  | DiscordStringSelectInteractionResponseFromMessageComponent\n  | DiscordChannelSelectInteractionResponseFromMessageComponent\n  | DiscordMentionableSelectInteractionResponseFromMessageComponent\n\n/** https://discord.com/developers/docs/components/reference#anatomy-of-a-component */\nexport interface DiscordBaseComponent {\n  /** The type of the component */\n  type: MessageComponentTypes\n  /** 32 bit integer used as an optional identifier for component */\n  id?: number\n}\n\n/** https://discord.com/developers/docs/components/reference#action-row-action-row-structure */\nexport interface DiscordActionRow extends DiscordBaseComponent {\n  type: MessageComponentTypes.ActionRow\n\n  /**\n   * The components in this row\n   *\n   * @remarks\n   * Up to 5 button components, a single select component or a single text input component\n   *\n   * Using a {@link DiscordTextInputComponent} inside the Action Row is deprecated,\n   * use a {@link DiscordLabelComponent} for modals\n   */\n  components: (DiscordButtonComponent | DiscordSelectMenuComponent | DiscordTextInputComponent)[]\n}\n\n/** https://discord.com/developers/docs/components/reference#button-button-structure */\nexport interface DiscordButtonComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.Button\n\n  /** For different styles/colors of the buttons */\n  style: ButtonStyles\n  /**\n   * Text that appears on the button\n   *\n   * @remarks\n   * A label can have a max of 80 characters\n   * A button of style {@link ButtonStyles.Premium | Premium} cannot have a label\n   */\n  label?: string\n  /**\n   * Emoji object that includes fields of name, id, and animated supporting unicode and custom emojis.\n   *\n   * @remarks\n   * A button of style {@link ButtonStyles.Premium | Premium} cannot have an emoji\n   */\n  emoji?: Pick<DiscordEmoji, 'id' | 'name' | 'animated'>\n  /**\n   * A dev-defined unique string sent on click (max 100 characters).\n   *\n   * @remarks\n   * A button of style {@link ButtonStyles.Link | Link} or {@link ButtonStyles.Premium | Premium} cannot have a custom_id\n   */\n  custom_id?: string\n  /**\n   * Identifier for a purchasable SKU\n   *\n   * @remarks\n   * Buttons of style {@link ButtonStyles.Premium | Premium} must have a sku_id, any other button with a different style can not have a a sku_id\n   */\n  sku_id?: string\n  /**\n   * Url for {@link ButtonStyles.Link | link} buttons that can navigate a user to the web.\n   *\n   * @remarks\n   * Buttons of style {@link ButtonStyles.Link | Link} must have an url, any other button with a different style can not have an url\n   *\n   * Maximum 512 characters.\n   */\n  url?: string\n  /** Whether or not this button is disabled */\n  disabled?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#button-button-styles */\nexport enum ButtonStyles {\n  /** A blurple button */\n  Primary = 1,\n  /** A grey button */\n  Secondary,\n  /** A green button */\n  Success,\n  /** A red button */\n  Danger,\n  /** A button that navigates to a URL */\n  Link,\n  /** A blurple button to show a Premium item in the shop */\n  Premium,\n}\n\n/**\n * https://discord.com/developers/docs/components/reference#string-select\n * https://discord.com/developers/docs/components/reference#user-select\n * https://discord.com/developers/docs/components/reference#role-select\n * https://discord.com/developers/docs/components/reference#mentionable-select\n * https://discord.com/developers/docs/components/reference#channel-select\n */\nexport interface DiscordSelectMenuComponent extends DiscordBaseComponent {\n  type:\n    | MessageComponentTypes.StringSelect\n    | MessageComponentTypes.UserSelect\n    | MessageComponentTypes.RoleSelect\n    | MessageComponentTypes.MentionableSelect\n    | MessageComponentTypes.ChannelSelect\n\n  /** A custom identifier for this component. Maximum 100 characters. */\n  custom_id: string\n  /** Specified choices in a select menu; Maximum of 25 items. */\n  options?: DiscordSelectOption[]\n  /** A custom placeholder text if nothing is selected. Maximum 150 characters. */\n  placeholder?: string\n  /** The minimum number of items that must be selected. Default 1. Between 0-25. */\n  min_values?: number\n  /** The maximum number of items that can be selected. Default 1. Max 25. */\n  max_values?: number\n  /**\n   * Whether this component is required to be filled\n   *\n   * @remarks\n   * This value is only valid for select menus in modals\n   *\n   * @default true\n   */\n  required?: boolean\n  /**\n   * Whether select menu is disabled\n   *\n   * @remarks\n   * This value cannot be set for select menus in modals\n   *\n   * @default false\n   */\n  disabled?: boolean\n  /**\n   * List of default values for auto-populated select menu components\n   *\n   * @remarks\n   * The number of default values must be in the range defined by min_values and max_values\n   */\n  default_values?: DiscordSelectMenuDefaultValue[]\n  /** List of channel types to include in a channel select menu options list */\n  channel_types?: ChannelTypes[]\n}\n\n/** https://discord.com/developers/docs/components/reference#string-select-select-option-structure */\nexport interface DiscordSelectOption {\n  /** The user-facing name of the option. Maximum 25 characters. */\n  label: string\n  /** The dev-defined value of the option. Maximum 100 characters. */\n  value: string\n  /** An additional description of the option. Maximum 50 characters. */\n  description?: string\n  /** The id, name, and animated properties of an emoji. */\n  emoji?: Pick<DiscordEmoji, 'id' | 'name' | 'animated'>\n  /** Will render this option as already-selected by default. */\n  default?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#string-select-strings-select-interaction-response-structure */\nexport interface DiscordStringSelectInteractionResponse {\n  /**\n   * @remarks\n   * This is only returned for interaction responses from modals\n   */\n  type?: MessageComponentTypes.StringSelect\n  /**\n   * @remarks\n   * This is only returned for interaction responses from message interactions\n   */\n  component_type?: MessageComponentTypes.StringSelect\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n  /** The custom id for the string select menu */\n  custom_id: string\n  /** The text of the selected options */\n  values: string[]\n}\n\n/** https://discord.com/developers/docs/components/reference#string-select-string-select-interaction-response-structure */\nexport type DiscordStringSelectInteractionResponseFromModal = Require<Omit<DiscordStringSelectInteractionResponse, 'component_type'>, 'type'>\n/** https://discord.com/developers/docs/components/reference#string-select-string-select-interaction-response-structure */\nexport type DiscordStringSelectInteractionResponseFromMessageComponent = Require<\n  Omit<DiscordStringSelectInteractionResponse, 'type'>,\n  'component_type'\n>\n\n/** https://discord.com/developers/docs/components/reference#text-input-text-input-structure */\nexport interface DiscordTextInputComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.TextInput\n\n  /** The customId of the InputText */\n  custom_id: string\n  /** The style of the InputText */\n  style: TextStyles\n  /**\n   * The label of the InputText.\n   *\n   * @remarks\n   * Maximum 45 characters\n   *\n   * @deprecated Use the `label` and `description` from the {@link DiscordLabelComponent}\n   */\n  label?: string\n  /** The minimum length of the text the user has to provide */\n  min_length?: number\n  /** The maximum length of the text the user has to provide */\n  max_length?: number\n  /** whether this component is required to be filled, default true */\n  required?: boolean\n  /** Pre-filled value for input text. */\n  value?: string\n  /** The placeholder of the InputText */\n  placeholder?: string\n}\n\n/** https://discord.com/developers/docs/components/reference#text-input-text-input-styles */\nexport enum TextStyles {\n  /** Intended for short single-line text */\n  Short = 1,\n  /** Intended for much longer inputs */\n  Paragraph = 2,\n}\n\n/** https://discord.com/developers/docs/components/reference#text-input-text-input-interaction-response-structure */\nexport interface DiscordTextInputInteractionResponse {\n  type: MessageComponentTypes.TextInput\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n  /** The custom id for the text input */\n  custom_id: string\n  /** The user's input text */\n  value: string\n}\n\n/** https://discord.com/developers/docs/components/reference#user-select-select-default-value-structure */\nexport interface DiscordSelectMenuDefaultValue {\n  /** ID of a user, role, or channel */\n  id: string\n  /** Type of value that id represents. */\n  type: 'user' | 'role' | 'channel'\n}\n\n/** https://discord.com/developers/docs/components/reference#user-select-user-select-interaction-response-structure */\nexport interface DiscordUserSelectInteractionResponse {\n  /**\n   * @remarks\n   * This is only returned for interaction responses from modals\n   */\n  type?: MessageComponentTypes.UserSelect\n  /**\n   * @remarks\n   * This is only returned for interaction responses from message interactions\n   */\n  component_type?: MessageComponentTypes.UserSelect\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n  /** The custom id for the user select */\n  custom_id: string\n  /** Resolved entities from selected options */\n  resolved: DiscordInteractionDataResolved\n  /** IDs of the selected users */\n  values: string[]\n}\n\n/** https://discord.com/developers/docs/components/reference#user-select-user-select-interaction-response-structure */\nexport type DiscordUserSelectInteractionResponseFromModal = Require<Omit<DiscordUserSelectInteractionResponse, 'component_type'>, 'type'>\n/** https://discord.com/developers/docs/components/reference#user-select-user-select-interaction-response-structure */\nexport type DiscordUserSelectInteractionResponseFromMessageComponent = Require<Omit<DiscordUserSelectInteractionResponse, 'type'>, 'component_type'>\n\n/** https://discord.com/developers/docs/components/reference#role-select-role-select-interaction-response-structure */\nexport interface DiscordRoleSelectInteractionResponse {\n  /**\n   * @remarks\n   * This is only returned for interaction responses from modals\n   */\n  type?: MessageComponentTypes.RoleSelect\n  /**\n   * @remarks\n   * This is only returned for interaction responses from message interactions\n   */\n  component_type?: MessageComponentTypes.RoleSelect\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n  /** The custom id for the role select */\n  custom_id: string\n  /** Resolved entities from selected options */\n  resolved: DiscordInteractionDataResolved\n  /** IDs of the selected roles */\n  values: string[]\n}\n\n/** https://discord.com/developers/docs/components/reference#role-select-role-select-interaction-response-structure */\nexport type DiscordRoleSelectInteractionResponseFromModal = Require<Omit<DiscordRoleSelectInteractionResponse, 'component_type'>, 'type'>\n/** https://discord.com/developers/docs/components/reference#role-select-role-select-interaction-response-structure */\nexport type DiscordRoleSelectInteractionResponseFromMessageComponent = Require<Omit<DiscordRoleSelectInteractionResponse, 'type'>, 'component_type'>\n\n/** https://discord.com/developers/docs/components/reference#mentionable-select-mentionable-select-interaction-response-structure */\nexport interface DiscordMentionableSelectInteractionResponse {\n  /**\n   * @remarks\n   * This is only returned for interaction responses from modals\n   */\n  type?: MessageComponentTypes.MentionableSelect\n  /**\n   * @remarks\n   * This is only returned for interaction responses from message interactions\n   */\n  component_type?: MessageComponentTypes.MentionableSelect\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n  /** The custom id for the mentionable select */\n  custom_id: string\n  /** Resolved entities from selected options */\n  resolved: DiscordInteractionDataResolved\n  /** IDs of the selected mentionables */\n  values: string[]\n}\n\n/** https://discord.com/developers/docs/components/reference#mentionable-select-mentionable-select-interaction-response-structure */\nexport type DiscordMentionableSelectInteractionResponseFromModal = Require<\n  Omit<DiscordMentionableSelectInteractionResponse, 'component_type'>,\n  'type'\n>\n/** https://discord.com/developers/docs/components/reference#mentionable-select-mentionable-select-interaction-response-structure */\nexport type DiscordMentionableSelectInteractionResponseFromMessageComponent = Require<\n  Omit<DiscordMentionableSelectInteractionResponse, 'type'>,\n  'component_type'\n>\n\n/** https://discord.com/developers/docs/components/reference#channel-select-channel-select-interaction-response-structure */\nexport interface DiscordChannelSelectInteractionResponse {\n  /**\n   * @remarks\n   * This is only returned for interaction responses from modals\n   */\n  type?: MessageComponentTypes.ChannelSelect\n  /**\n   * @remarks\n   * This is only returned for interaction responses from message interactions\n   */\n  component_type?: MessageComponentTypes.ChannelSelect\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n  /** The custom id for the channel select */\n  custom_id: string\n  /** Resolved entities from selected options */\n  resolved: DiscordInteractionDataResolved\n  /** IDs of the selected channels */\n  values: string[]\n}\n\n/** https://discord.com/developers/docs/components/reference#channel-select-channel-select-interaction-response-structure */\nexport type DiscordChannelSelectInteractionResponseFromModal = Require<Omit<DiscordChannelSelectInteractionResponse, 'component_type'>, 'type'>\n/** https://discord.com/developers/docs/components/reference#channel-select-channel-select-interaction-response-structure */\nexport type DiscordChannelSelectInteractionResponseFromMessageComponent = Require<\n  Omit<DiscordChannelSelectInteractionResponse, 'type'>,\n  'component_type'\n>\n\n/** https://discord.com/developers/docs/components/reference#section-section-structure */\nexport interface DiscordSectionComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.Section\n\n  /** One to three text components */\n  components: DiscordTextDisplayComponent[]\n  /** A thumbnail or a button component, with a future possibility of adding more compatible components */\n  accessory: DiscordButtonComponent | DiscordThumbnailComponent\n}\n\n/** https://discord.com/developers/docs/components/reference#text-display-text-display-structure */\nexport interface DiscordTextDisplayComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.TextDisplay\n\n  /** Text that will be displayed similar to a message */\n  content: string\n}\n\n/** https://discord.com/developers/docs/components/reference#text-display-text-display-interaction-response-structure */\nexport interface DiscordTextDisplayInteractionResponse {\n  type: MessageComponentTypes.TextDisplay\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n}\n\nexport interface DiscordThumbnailComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.Thumbnail\n\n  /** A url or attachment */\n  media: DiscordUnfurledMediaItem\n  /** Alt text for the media, max 1024 characters */\n  description?: string\n  /** Whether the thumbnail should be a spoiler (or blurred out). Defaults to `false` */\n  spoiler?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#media-gallery-media-gallery-structure */\nexport interface DiscordMediaGalleryComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.MediaGallery\n\n  /** 1 to 10 media gallery items */\n  items: DiscordMediaGalleryItem[]\n}\n\n/** https://discord.com/developers/docs/components/reference#media-gallery-media-gallery-item-structure */\nexport interface DiscordMediaGalleryItem {\n  /** A url or attachment */\n  media: DiscordUnfurledMediaItem\n  /** Alt text for the media, max 1024 characters */\n  description?: string\n  /** Whether the media should be a spoiler (or blurred out). Defaults to `false` */\n  spoiler?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#file-file-structure */\nexport interface DiscordFileComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.File\n\n  /** This unfurled media item is unique in that it only supports attachment references using the attachment://<filename> syntax */\n  file: DiscordUnfurledMediaItem\n  /** Whether the media should be a spoiler (or blurred out). Defaults to `false` */\n  spoiler?: boolean\n  /** The name of the file. This field is ignored and provided by the API as part of the response */\n  name: string\n  /** The size of the file in bytes. This field is ignored and provided by the API as part of the response */\n  size: number\n}\n\n/** https://discord.com/developers/docs/components/reference#separator-separator-structure */\nexport interface DiscordSeparatorComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.Separator\n\n  /** Whether a visual divider should be displayed in the component. Defaults to `true` */\n  divider?: boolean\n  /** Size of separator padding — `1` for small padding, `2` for large padding. Defaults to `1` */\n  spacing?: SeparatorSpacingSize\n}\n\n/** https://discord.com/developers/docs/components/reference#separator-separator-structure, spacing description */\nexport enum SeparatorSpacingSize {\n  Small = 1,\n  Large = 2,\n}\n\n/** https://discord.com/developers/docs/components/reference#container-container-structure */\nexport interface DiscordContainerComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.Container\n\n  /** Components of the type action row, text display, section, media gallery, separator, or file */\n  components: Array<\n    | DiscordActionRow\n    | DiscordTextDisplayComponent\n    | DiscordSectionComponent\n    | DiscordMediaGalleryComponent\n    | DiscordSeparatorComponent\n    | DiscordFileComponent\n  >\n  /** Color for the accent on the container as RGB from 0x000000 to 0xFFFFFF */\n  accent_color?: number | null\n  /** Whether the container should be a spoiler (or blurred out). Defaults to `false` */\n  spoiler?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#label-label-structure */\nexport interface DiscordLabelComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.Label\n\n  /**\n   * The label text\n   *\n   * @remarks\n   * Max 45 characters.\n   */\n  label: string\n  /**\n   * An optional description text for the label\n   *\n   * @remarks\n   * Max 100 characters.\n   */\n  description?: string\n  /** The component within the label */\n  component: DiscordTextInputComponent | DiscordSelectMenuComponent | DiscordFileUploadComponent\n}\n\n/** https://discord.com/developers/docs/components/reference#label-label-interaction-response-structure */\nexport interface DiscordLabelInteractionResponse {\n  type: MessageComponentTypes.Label\n  /** 32 bit integer used as an optional identifier for component */\n  id: number\n  /** The component within the label */\n  component:\n    | DiscordTextInputInteractionResponse\n    | DiscordStringSelectInteractionResponseFromModal\n    | DiscordUserSelectInteractionResponseFromModal\n    | DiscordRoleSelectInteractionResponseFromModal\n    | DiscordMentionableSelectInteractionResponseFromModal\n    | DiscordChannelSelectInteractionResponseFromModal\n    | DiscordFileUploadInteractionResponse\n}\n\n/** https://discord.com/developers/docs/components/reference#file-upload-file-upload-structure */\nexport interface DiscordFileUploadComponent extends DiscordBaseComponent {\n  type: MessageComponentTypes.FileUpload\n\n  /** The custom id for the file upload */\n  custom_id: string\n  /**\n   * The minimum number of files that must be uploaded\n   *\n   * @remarks\n   * Between 0-10\n   *\n   * @default 1\n   */\n  min_values?: number\n  /** The maximum number of files that can be uploaded\n   *\n   * @remarks\n   * Between 1-10\n   *\n   * @default 1\n   */\n  max_values?: number\n  /**\n   * Whether this component is required to be filled\n   *\n   * @default true\n   */\n  required?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#file-upload-file-upload-interaction-response-structure */\nexport interface DiscordFileUploadInteractionResponse {\n  type: MessageComponentTypes.FileUpload\n\n  /** Unique identifier for the component */\n  id: number\n  /** The custom id for the file upload */\n  custom_id: string\n  /** IDs of the uploaded files found in the resolved data */\n  values: string[]\n}\n\n/** https://discord.com/developers/docs/components/reference#unfurled-media-item-structure */\nexport interface DiscordUnfurledMediaItem {\n  /** Supports arbitrary urls and attachment://<filename> references */\n  url: string\n  /** The proxied url of the media item. This field is ignored and provided by the API as part of the response */\n  proxy_url?: string\n  /** The height of the media item. This field is ignored and provided by the API as part of the response */\n  height?: number | null\n  /** The width of the media item. This field is ignored and provided by the API as part of the response */\n  width?: number | null\n  /** The media type of the content. This field is ignored and provided by the API as part of the response */\n  content_type?: string\n  /** The id of the uploaded attachment. Only present if the media was uploaded as an attachment. This field is ignored and provided by the API as part of the response */\n  attachment_id?: string | null\n}\n"],"names":["MessageComponentTypes","ButtonStyles","TextStyles","SeparatorSpacingSize"],"mappings":"AAAA,wEAAwE,GAOxE,8FAA8F,GAC9F,OAAO,IAAA,AAAKA,+CAAAA;IACV,qCAAqC;IAErC,oBAAoB;IAEpB,2CAA2C;IAE3C,wBAAwB;IAExB,0BAA0B;IAE1B,0BAA0B;IAE1B,oCAAoC;IAEpC,6BAA6B;IAE7B,+DAA+D;IAE/D,kBAAkB;IAElB,iDAAiD;IAEjD,mCAAmC;IAEnC,8BAA8B;IAE9B,+DAA+D;IAE/D,uDAAuD;IAEvD,mEAAmE;IAEnE,kCAAkC;WAjCxBA;MAmCX;AAsGD,kFAAkF,GAClF,OAAO,IAAA,AAAKC,sCAAAA;IACV,qBAAqB;IAErB,kBAAkB;IAElB,mBAAmB;IAEnB,iBAAiB;IAEjB,qCAAqC;IAErC,wDAAwD;WAX9CA;MAaX;AA+HD,0FAA0F,GAC1F,OAAO,IAAA,AAAKC,oCAAAA;IACV,wCAAwC;IAExC,oCAAoC;WAH1BA;MAKX;AAwND,gHAAgH,GAChH,OAAO,IAAA,AAAKC,8CAAAA;;;WAAAA;MAGX"}
@@ -138,6 +138,8 @@ export interface DiscordTokenExchangeAuthorizationCode {
138
138
  code: string;
139
139
  /** The redirect_uri associated with this authorization */
140
140
  redirect_uri: string;
141
+ /** The code verifier for the token exchange if one was sent during the authorization request */
142
+ code_verifier?: string;
141
143
  }
142
144
  /** https://discord.com/developers/docs/topics/oauth2#authorization-code-grant-access-token-response */
143
145
  export interface DiscordAccessTokenResponse {
@@ -1 +1 @@
1
- {"version":3,"file":"oauth2.d.ts","sourceRoot":"","sources":["../../src/discord/oauth2.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"oauth2.d.ts","sourceRoot":"","sources":["../../src/discord/oauth2.ts"],"names":[],"mappings":"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"}
@@ -99,4 +99,4 @@
99
99
  return OAuth2Scope;
100
100
  }({});
101
101
 
102
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/discord/oauth2.ts"],"sourcesContent":["/** Types for: https://discord.com/developers/docs/topics/oauth2 */\n\nimport type { DiscordApplication } from './application.js'\nimport type { DiscordGuild } from './guild.js'\nimport type { DiscordUser } from './user.js'\nimport type { DiscordWebhook } from './webhook.js'\n\n/** https://discord.com/developers/docs/topics/oauth2#shared-resources-oauth2-scopes */\nexport enum OAuth2Scope {\n  /**\n   * Allows your app to fetch data from a user's \"Now Playing/Recently Played\" list\n   *\n   * @remarks\n   * This scope is not currently available for apps\n   */\n  ActivitiesRead = 'activities.read',\n  /**\n   * Allows your app to update a user's activity\n   *\n   * @remarks\n   * This scope not currently available for apps.\n   */\n  ActivitiesWrite = 'activities.write',\n  /** Allows your app to read build data for a user's applications */\n  ApplicationsBuildsRead = 'applications.builds.read',\n  /**\n   * Allows your app to upload/update builds for a user's applications\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  ApplicationsBuildsUpload = 'applications.builds.upload',\n  /** Allows your app to add commands to a guild - included by default with the `bot` scope */\n  ApplicationsCommands = 'applications.commands',\n  /**\n   * Allows your app to update its Application Commands via this bearer token\n   *\n   * @remarks\n   * This scope can only be used when using a [Client Credential Grant](https://discord.com/developers/docs/topics/oauth2#client-credentials-grant)\n   */\n  ApplicationsCommandsUpdate = 'applications.commands.update',\n  /** Allows your app to update permissions for its commands in a guild a user has permissions to */\n  ApplicationCommandsPermissionsUpdate = 'applications.commands.permissions.update',\n  /** Allows your app to read entitlements for a user's applications */\n  ApplicationsEntitlements = 'applications.entitlements',\n  /** Allows your app to read and update store data (SKUs, store listings, achievements, etc.) for a user's applications */\n  ApplicationsStoreUpdate = 'applications.store.update',\n  /** For oauth2 bots, this puts the bot in the user's selected guild by default */\n  Bot = 'bot',\n  /** Allows requests to [/users/@me/connections](https://discord.com/developers/docs/resources/user#get-user-connections) */\n  Connections = 'connections',\n  /**\n   * Allows your app to see information about the user's DMs and group DMs\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  DMChannelsRead = 'dm_channels.read',\n  /** Adds the `email` filed to [/users/@me](https://discord.com/developers/docs/resources/user#get-current-user) */\n  Email = 'email',\n  /** Allows your app to join users to a group dm */\n  GroupDMJoins = 'gdm.join',\n  /** Allows requests to [/users/@me/guilds](https://discord.com/developers/docs/resources/user#get-current-user-guilds) */\n  Guilds = 'guilds',\n  /** Allows requests to [/guilds/{guild.id}/members/{user.id}](https://discord.com/developers/docs/resources/guild#add-guild-member) */\n  GuildsJoin = 'guilds.join',\n  /** Allows requests to [/users/@me/guilds/{guild.id}/member](https://discord.com/developers/docs/resources/user#get-current-user-guild-member) */\n  GuildsMembersRead = 'guilds.members.read',\n  /**\n   * Allows requests to [/users/@me](https://discord.com/developers/docs/resources/user#get-current-user)\n   *\n   * @remarks\n   * The return object from [/users/@me](https://discord.com/developers/docs/resources/user#get-current-user)\n   * does NOT contain the `email` field unless the scope `email` is also used\n   */\n  Identify = 'identify',\n  /**\n   * For local rpc server api access, this allows you to read messages from all client channels\n   * (otherwise restricted to channels/guilds your app creates)\n   */\n  MessagesRead = 'messages.read',\n  /**\n   * Allows your app to know a user's friends and implicit relationships\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RelationshipsRead = 'relationships.read',\n  /** Allows your app to update a user's connection and metadata for the app */\n  RoleConnectionsWrite = 'role_connections.write',\n  /**\n   * For local rpc server access, this allows you to control a user's local Discord client\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPC = 'rpc',\n  /**\n   * For local rpc server access, this allows you to update a user's activity\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCActivitiesWrite = 'rpc.activities.write',\n  /**\n   * For local rpc server api access, this allows you to receive notifications pushed out to the user\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCNotificationsRead = 'rpc.notifications.read',\n  /**\n   * For local rpc server access, this allows you to read a user's voice settings and listen for voice events\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCVoiceRead = 'rpc.voice.read',\n  /**\n   * For local rpc server access, this allows you to update a user's voice settings\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCVoiceWrite = 'rpc.voice.write',\n  /**\n   * Allows your app to connect to voice on user's behalf and see all the voice members\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  Voice = 'voice',\n  /** Generate a webhook that is returned in the oauth token response for authorization code grants */\n  WebhookIncoming = 'webhook.incoming',\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#authorization-code-grant-redirect-url-example */\nexport interface DiscordTokenExchangeAuthorizationCode {\n  grant_type: 'authorization_code'\n  /** The code for the token exchange */\n  code: string\n  /** The redirect_uri associated with this authorization */\n  redirect_uri: string\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#authorization-code-grant-access-token-response */\nexport interface DiscordAccessTokenResponse {\n  /** The access token of the user */\n  access_token: string\n  /** The type of token */\n  token_type: string\n  /** The number of seconds after that the access token is expired */\n  expires_in: number\n  /**\n   * The refresh token to refresh the access token\n   *\n   * @remarks\n   * When the token exchange is a client credentials type grant this value is not defined.\n   */\n  refresh_token: string\n  /** The scopes for the access token */\n  scope: string\n  /** The webhook the user created for the application. Requires the `webhook.incoming` scope */\n  webhook?: DiscordWebhook\n  /** The guild the bot has been added. Requires the `bot` scope */\n  guild?: DiscordGuild\n}\n\n/**\n * https://discord.com/developers/docs/topics/oauth2#authorization-code-grant\n * https://discord.com/developers/docs/topics/oauth2#client-credentials-grant\n */\nexport type DiscordTokenExchange = DiscordTokenExchangeAuthorizationCode | DiscordTokenExchangeRefreshToken | DiscordTokenExchangeClientCredentials\n\n/** https://discord.com/developers/docs/topics/oauth2#authorization-code-grant-refresh-token-exchange-example */\nexport interface DiscordTokenExchangeRefreshToken {\n  grant_type: 'refresh_token'\n  /** the user's refresh token */\n  refresh_token: string\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#authorization-code-grant-token-revocation-example */\nexport interface DiscordTokenRevocation {\n  /** The access token to revoke */\n  token: string\n  /** Optional, the type of token you are using for the revocation */\n  token_type_hint?: 'access_token' | 'refresh_token'\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#client-credentials-grant */\nexport interface DiscordTokenExchangeClientCredentials {\n  grant_type: 'client_credentials'\n  /** The scope(s) for the access token */\n  scope: OAuth2Scope[]\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#get-current-authorization-information-response-structure */\nexport interface DiscordCurrentAuthorization {\n  application: DiscordApplication\n  /** the scopes the user has authorized the application for */\n  scopes: OAuth2Scope[]\n  /** when the access token expires */\n  expires: string\n  /** the user who has authorized, if the user has authorized with the `identify` scope */\n  user?: DiscordUser\n}\n"],"names":["OAuth2Scope"],"mappings":"AAAA,iEAAiE,GAOjE,qFAAqF,GACrF,OAAO,IAAA,AAAKA,qCAAAA;IACV;;;;;GAKC;IAED;;;;;GAKC;IAED,iEAAiE;IAEjE;;;;;GAKC;IAED,0FAA0F;IAE1F;;;;;GAKC;IAED,gGAAgG;IAEhG,mEAAmE;IAEnE,uHAAuH;IAEvH,+EAA+E;IAE/E,yHAAyH;IAEzH;;;;;GAKC;IAED,gHAAgH;IAEhH,gDAAgD;IAEhD,uHAAuH;IAEvH,oIAAoI;IAEpI,+IAA+I;IAE/I;;;;;;GAMC;IAED;;;GAGC;IAED;;;;;GAKC;IAED,2EAA2E;IAE3E;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED,kGAAkG;WA5HxFA;MA8HX"}
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/discord/oauth2.ts"],"sourcesContent":["/** Types for: https://discord.com/developers/docs/topics/oauth2 */\n\nimport type { DiscordApplication } from './application.js'\nimport type { DiscordGuild } from './guild.js'\nimport type { DiscordUser } from './user.js'\nimport type { DiscordWebhook } from './webhook.js'\n\n/** https://discord.com/developers/docs/topics/oauth2#shared-resources-oauth2-scopes */\nexport enum OAuth2Scope {\n  /**\n   * Allows your app to fetch data from a user's \"Now Playing/Recently Played\" list\n   *\n   * @remarks\n   * This scope is not currently available for apps\n   */\n  ActivitiesRead = 'activities.read',\n  /**\n   * Allows your app to update a user's activity\n   *\n   * @remarks\n   * This scope not currently available for apps.\n   */\n  ActivitiesWrite = 'activities.write',\n  /** Allows your app to read build data for a user's applications */\n  ApplicationsBuildsRead = 'applications.builds.read',\n  /**\n   * Allows your app to upload/update builds for a user's applications\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  ApplicationsBuildsUpload = 'applications.builds.upload',\n  /** Allows your app to add commands to a guild - included by default with the `bot` scope */\n  ApplicationsCommands = 'applications.commands',\n  /**\n   * Allows your app to update its Application Commands via this bearer token\n   *\n   * @remarks\n   * This scope can only be used when using a [Client Credential Grant](https://discord.com/developers/docs/topics/oauth2#client-credentials-grant)\n   */\n  ApplicationsCommandsUpdate = 'applications.commands.update',\n  /** Allows your app to update permissions for its commands in a guild a user has permissions to */\n  ApplicationCommandsPermissionsUpdate = 'applications.commands.permissions.update',\n  /** Allows your app to read entitlements for a user's applications */\n  ApplicationsEntitlements = 'applications.entitlements',\n  /** Allows your app to read and update store data (SKUs, store listings, achievements, etc.) for a user's applications */\n  ApplicationsStoreUpdate = 'applications.store.update',\n  /** For oauth2 bots, this puts the bot in the user's selected guild by default */\n  Bot = 'bot',\n  /** Allows requests to [/users/@me/connections](https://discord.com/developers/docs/resources/user#get-user-connections) */\n  Connections = 'connections',\n  /**\n   * Allows your app to see information about the user's DMs and group DMs\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  DMChannelsRead = 'dm_channels.read',\n  /** Adds the `email` filed to [/users/@me](https://discord.com/developers/docs/resources/user#get-current-user) */\n  Email = 'email',\n  /** Allows your app to join users to a group dm */\n  GroupDMJoins = 'gdm.join',\n  /** Allows requests to [/users/@me/guilds](https://discord.com/developers/docs/resources/user#get-current-user-guilds) */\n  Guilds = 'guilds',\n  /** Allows requests to [/guilds/{guild.id}/members/{user.id}](https://discord.com/developers/docs/resources/guild#add-guild-member) */\n  GuildsJoin = 'guilds.join',\n  /** Allows requests to [/users/@me/guilds/{guild.id}/member](https://discord.com/developers/docs/resources/user#get-current-user-guild-member) */\n  GuildsMembersRead = 'guilds.members.read',\n  /**\n   * Allows requests to [/users/@me](https://discord.com/developers/docs/resources/user#get-current-user)\n   *\n   * @remarks\n   * The return object from [/users/@me](https://discord.com/developers/docs/resources/user#get-current-user)\n   * does NOT contain the `email` field unless the scope `email` is also used\n   */\n  Identify = 'identify',\n  /**\n   * For local rpc server api access, this allows you to read messages from all client channels\n   * (otherwise restricted to channels/guilds your app creates)\n   */\n  MessagesRead = 'messages.read',\n  /**\n   * Allows your app to know a user's friends and implicit relationships\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RelationshipsRead = 'relationships.read',\n  /** Allows your app to update a user's connection and metadata for the app */\n  RoleConnectionsWrite = 'role_connections.write',\n  /**\n   * For local rpc server access, this allows you to control a user's local Discord client\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPC = 'rpc',\n  /**\n   * For local rpc server access, this allows you to update a user's activity\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCActivitiesWrite = 'rpc.activities.write',\n  /**\n   * For local rpc server api access, this allows you to receive notifications pushed out to the user\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCNotificationsRead = 'rpc.notifications.read',\n  /**\n   * For local rpc server access, this allows you to read a user's voice settings and listen for voice events\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCVoiceRead = 'rpc.voice.read',\n  /**\n   * For local rpc server access, this allows you to update a user's voice settings\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  RPCVoiceWrite = 'rpc.voice.write',\n  /**\n   * Allows your app to connect to voice on user's behalf and see all the voice members\n   *\n   * @remarks\n   * This scope requires Discord approval to be used\n   */\n  Voice = 'voice',\n  /** Generate a webhook that is returned in the oauth token response for authorization code grants */\n  WebhookIncoming = 'webhook.incoming',\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#authorization-code-grant-redirect-url-example */\nexport interface DiscordTokenExchangeAuthorizationCode {\n  grant_type: 'authorization_code'\n  /** The code for the token exchange */\n  code: string\n  /** The redirect_uri associated with this authorization */\n  redirect_uri: string\n  /** The code verifier for the token exchange if one was sent during the authorization request */\n  code_verifier?: string\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#authorization-code-grant-access-token-response */\nexport interface DiscordAccessTokenResponse {\n  /** The access token of the user */\n  access_token: string\n  /** The type of token */\n  token_type: string\n  /** The number of seconds after that the access token is expired */\n  expires_in: number\n  /**\n   * The refresh token to refresh the access token\n   *\n   * @remarks\n   * When the token exchange is a client credentials type grant this value is not defined.\n   */\n  refresh_token: string\n  /** The scopes for the access token */\n  scope: string\n  /** The webhook the user created for the application. Requires the `webhook.incoming` scope */\n  webhook?: DiscordWebhook\n  /** The guild the bot has been added. Requires the `bot` scope */\n  guild?: DiscordGuild\n}\n\n/**\n * https://discord.com/developers/docs/topics/oauth2#authorization-code-grant\n * https://discord.com/developers/docs/topics/oauth2#client-credentials-grant\n */\nexport type DiscordTokenExchange = DiscordTokenExchangeAuthorizationCode | DiscordTokenExchangeRefreshToken | DiscordTokenExchangeClientCredentials\n\n/** https://discord.com/developers/docs/topics/oauth2#authorization-code-grant-refresh-token-exchange-example */\nexport interface DiscordTokenExchangeRefreshToken {\n  grant_type: 'refresh_token'\n  /** the user's refresh token */\n  refresh_token: string\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#authorization-code-grant-token-revocation-example */\nexport interface DiscordTokenRevocation {\n  /** The access token to revoke */\n  token: string\n  /** Optional, the type of token you are using for the revocation */\n  token_type_hint?: 'access_token' | 'refresh_token'\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#client-credentials-grant */\nexport interface DiscordTokenExchangeClientCredentials {\n  grant_type: 'client_credentials'\n  /** The scope(s) for the access token */\n  scope: OAuth2Scope[]\n}\n\n/** https://discord.com/developers/docs/topics/oauth2#get-current-authorization-information-response-structure */\nexport interface DiscordCurrentAuthorization {\n  application: DiscordApplication\n  /** the scopes the user has authorized the application for */\n  scopes: OAuth2Scope[]\n  /** when the access token expires */\n  expires: string\n  /** the user who has authorized, if the user has authorized with the `identify` scope */\n  user?: DiscordUser\n}\n"],"names":["OAuth2Scope"],"mappings":"AAAA,iEAAiE,GAOjE,qFAAqF,GACrF,OAAO,IAAA,AAAKA,qCAAAA;IACV;;;;;GAKC;IAED;;;;;GAKC;IAED,iEAAiE;IAEjE;;;;;GAKC;IAED,0FAA0F;IAE1F;;;;;GAKC;IAED,gGAAgG;IAEhG,mEAAmE;IAEnE,uHAAuH;IAEvH,+EAA+E;IAE/E,yHAAyH;IAEzH;;;;;GAKC;IAED,gHAAgH;IAEhH,gDAAgD;IAEhD,uHAAuH;IAEvH,oIAAoI;IAEpI,+IAA+I;IAE/I;;;;;;GAMC;IAED;;;GAGC;IAED;;;;;GAKC;IAED,2EAA2E;IAE3E;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED;;;;;GAKC;IAED,kGAAkG;WA5HxFA;MA8HX"}
@@ -101,6 +101,8 @@ export declare const BitwisePermissionFlags: {
101
101
  readonly USE_EXTERNAL_APPS: bigint;
102
102
  /** Allows pinning and unpinning messages */
103
103
  readonly PIN_MESSAGES: bigint;
104
+ /** Allows bypassing slowmode restrictions */
105
+ readonly BYPASS_SLOWMODE: bigint;
104
106
  };
105
107
  /** https://discord.com/developers/docs/topics/permissions#permissions-bitwise-permission-flags */
106
108
  export type PermissionStrings = keyof typeof BitwisePermissionFlags;
@@ -1 +1 @@
1
- {"version":3,"file":"permissions.d.ts","sourceRoot":"","sources":["../../src/discord/permissions.ts"],"names":[],"mappings":"AAAA,wEAAwE;AAExE,kGAAkG;AAClG,eAAO,MAAM,sBAAsB;IACjC,yCAAyC;;IAEzC,6BAA6B;;IAE7B,6BAA6B;;IAE7B,wEAAwE;;IAExE,gDAAgD;;IAEhD,iDAAiD;;IAEjD,uDAAuD;;IAEvD,uCAAuC;;IAEvC,2DAA2D;;IAE3D,iCAAiC;;IAEjC,0HAA0H;;IAE1H,6FAA6F;;IAE7F,0CAA0C;;IAE1C,kDAAkD;;IAElD,qEAAqE;;IAErE,4CAA4C;;IAE5C,4CAA4C;;IAE5C,uIAAuI;;IAEvI,2DAA2D;;IAE3D,wCAAwC;;IAExC,4CAA4C;;IAE5C,6CAA6C;;IAE7C,mDAAmD;;IAEnD,yDAAyD;;IAEzD,0DAA0D;;IAE1D,mEAAmE;;IAEnE,8CAA8C;;IAE9C,uDAAuD;;IAEvD,6CAA6C;;IAE7C,gDAAgD;;IAEhD,mGAAmG;;IAEnG,kEAAkE;;IAElE,wDAAwD;;IAExD,4EAA4E;;IAE5E,iFAAiF;;IAEjF,0DAA0D;;IAE1D,0CAA0C;;IAE1C,6DAA6D;;IAE7D,6CAA6C;;IAE7C,kGAAkG;;IAElG,0JAA0J;;IAE1J,qDAAqD;;IAErD,sDAAsD;;IAEtD,8HAA8H;;IAE9H,uGAAuG;;IAEvG,uEAAuE;;IAEvE,oCAAoC;;IAEpC,2BAA2B;;IAE3B,yNAAyN;;IAEzN,4CAA4C;;CAEpC,CAAA;AAEV,kGAAkG;AAClG,MAAM,MAAM,iBAAiB,GAAG,MAAM,OAAO,sBAAsB,CAAA;AAEnE,wFAAwF;AACxF,MAAM,WAAW,WAAW;IAC1B,cAAc;IACd,EAAE,EAAE,MAAM,CAAA;IACV,gBAAgB;IAChB,IAAI,EAAE,MAAM,CAAA;IACZ;;;OAGG;IACH,KAAK,EAAE,MAAM,CAAA;IACb,uBAAuB;IACvB,MAAM,EAAE,iBAAiB,CAAA;IACzB,4DAA4D;IAC5D,KAAK,EAAE,OAAO,CAAA;IACd,0BAA0B;IAC1B,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,yBAAyB;IACzB,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,4EAA4E;IAC5E,QAAQ,EAAE,MAAM,CAAA;IAChB,yBAAyB;IACzB,WAAW,EAAE,MAAM,CAAA;IACnB,qDAAqD;IACrD,OAAO,EAAE,OAAO,CAAA;IAChB,uCAAuC;IACvC,WAAW,EAAE,OAAO,CAAA;IACpB,6BAA6B;IAC7B,IAAI,CAAC,EAAE,eAAe,CAAA;IACtB,wCAAwC;IACxC,KAAK,EAAE,SAAS,CAAA;CACjB;AAED,6FAA6F;AAC7F,MAAM,WAAW,eAAe;IAC9B,6CAA6C;IAC7C,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,qDAAqD;IACrD,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,0DAA0D;IAC1D,kBAAkB,CAAC,EAAE,IAAI,CAAA;IACzB,sDAAsD;IACtD,uBAAuB,CAAC,EAAE,MAAM,CAAA;IAChC,mDAAmD;IACnD,sBAAsB,CAAC,EAAE,IAAI,CAAA;IAC7B,4CAA4C;IAC5C,iBAAiB,CAAC,EAAE,IAAI,CAAA;CACzB;AAED,4FAA4F;AAC5F,MAAM,WAAW,iBAAiB;IAChC,qCAAqC;IACrC,aAAa,EAAE,MAAM,CAAA;IACrB,6GAA6G;IAC7G,eAAe,EAAE,MAAM,GAAG,IAAI,CAAA;IAC9B,4FAA4F;IAC5F,cAAc,EAAE,MAAM,GAAG,IAAI,CAAA;CAC9B;AAED,oFAAoF;AACpF,oBAAY,SAAS;IACnB,IAAI,IAAA;IACJ,8DAA8D;IAC9D,QAAQ,IAAS;CAClB"}
1
+ {"version":3,"file":"permissions.d.ts","sourceRoot":"","sources":["../../src/discord/permissions.ts"],"names":[],"mappings":"AAAA,wEAAwE;AAExE,kGAAkG;AAClG,eAAO,MAAM,sBAAsB;IACjC,yCAAyC;;IAEzC,6BAA6B;;IAE7B,6BAA6B;;IAE7B,wEAAwE;;IAExE,gDAAgD;;IAEhD,iDAAiD;;IAEjD,uDAAuD;;IAEvD,uCAAuC;;IAEvC,2DAA2D;;IAE3D,iCAAiC;;IAEjC,0HAA0H;;IAE1H,6FAA6F;;IAE7F,0CAA0C;;IAE1C,kDAAkD;;IAElD,qEAAqE;;IAErE,4CAA4C;;IAE5C,4CAA4C;;IAE5C,uIAAuI;;IAEvI,2DAA2D;;IAE3D,wCAAwC;;IAExC,4CAA4C;;IAE5C,6CAA6C;;IAE7C,mDAAmD;;IAEnD,yDAAyD;;IAEzD,0DAA0D;;IAE1D,mEAAmE;;IAEnE,8CAA8C;;IAE9C,uDAAuD;;IAEvD,6CAA6C;;IAE7C,gDAAgD;;IAEhD,mGAAmG;;IAEnG,kEAAkE;;IAElE,wDAAwD;;IAExD,4EAA4E;;IAE5E,iFAAiF;;IAEjF,0DAA0D;;IAE1D,0CAA0C;;IAE1C,6DAA6D;;IAE7D,6CAA6C;;IAE7C,kGAAkG;;IAElG,0JAA0J;;IAE1J,qDAAqD;;IAErD,sDAAsD;;IAEtD,8HAA8H;;IAE9H,uGAAuG;;IAEvG,uEAAuE;;IAEvE,oCAAoC;;IAEpC,2BAA2B;;IAE3B,yNAAyN;;IAEzN,4CAA4C;;IAE5C,6CAA6C;;CAErC,CAAA;AAEV,kGAAkG;AAClG,MAAM,MAAM,iBAAiB,GAAG,MAAM,OAAO,sBAAsB,CAAA;AAEnE,wFAAwF;AACxF,MAAM,WAAW,WAAW;IAC1B,cAAc;IACd,EAAE,EAAE,MAAM,CAAA;IACV,gBAAgB;IAChB,IAAI,EAAE,MAAM,CAAA;IACZ;;;OAGG;IACH,KAAK,EAAE,MAAM,CAAA;IACb,uBAAuB;IACvB,MAAM,EAAE,iBAAiB,CAAA;IACzB,4DAA4D;IAC5D,KAAK,EAAE,OAAO,CAAA;IACd,0BAA0B;IAC1B,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,yBAAyB;IACzB,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,4EAA4E;IAC5E,QAAQ,EAAE,MAAM,CAAA;IAChB,yBAAyB;IACzB,WAAW,EAAE,MAAM,CAAA;IACnB,qDAAqD;IACrD,OAAO,EAAE,OAAO,CAAA;IAChB,uCAAuC;IACvC,WAAW,EAAE,OAAO,CAAA;IACpB,6BAA6B;IAC7B,IAAI,CAAC,EAAE,eAAe,CAAA;IACtB,wCAAwC;IACxC,KAAK,EAAE,SAAS,CAAA;CACjB;AAED,6FAA6F;AAC7F,MAAM,WAAW,eAAe;IAC9B,6CAA6C;IAC7C,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,qDAAqD;IACrD,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,0DAA0D;IAC1D,kBAAkB,CAAC,EAAE,IAAI,CAAA;IACzB,sDAAsD;IACtD,uBAAuB,CAAC,EAAE,MAAM,CAAA;IAChC,mDAAmD;IACnD,sBAAsB,CAAC,EAAE,IAAI,CAAA;IAC7B,4CAA4C;IAC5C,iBAAiB,CAAC,EAAE,IAAI,CAAA;CACzB;AAED,4FAA4F;AAC5F,MAAM,WAAW,iBAAiB;IAChC,qCAAqC;IACrC,aAAa,EAAE,MAAM,CAAA;IACrB,6GAA6G;IAC7G,eAAe,EAAE,MAAM,GAAG,IAAI,CAAA;IAC9B,4FAA4F;IAC5F,cAAc,EAAE,MAAM,GAAG,IAAI,CAAA;CAC9B;AAED,oFAAoF;AACpF,oBAAY,SAAS;IACnB,IAAI,IAAA;IACJ,8DAA8D;IAC9D,QAAQ,IAAS;CAClB"}
@@ -48,7 +48,8 @@
48
48
  /** Allows sending voice messages */ SEND_VOICE_MESSAGES: 1n << 46n,
49
49
  /** Allows sending polls */ SEND_POLLS: 1n << 49n,
50
50
  /** Allows user-installed apps to send public responses. When disabled, users will still be allowed to use their apps but the responses will be ephemeral. This only applies to apps not also installed to the server. */ USE_EXTERNAL_APPS: 1n << 50n,
51
- /** Allows pinning and unpinning messages */ PIN_MESSAGES: 1n << 51n
51
+ /** Allows pinning and unpinning messages */ PIN_MESSAGES: 1n << 51n,
52
+ /** Allows bypassing slowmode restrictions */ BYPASS_SLOWMODE: 1n << 52n
52
53
  };
53
54
  /** https://discord.com/developers/docs/topics/permissions#role-object-role-flags */ export var RoleFlags = /*#__PURE__*/ function(RoleFlags) {
54
55
  RoleFlags[RoleFlags["None"] = 0] = "None";
@@ -56,4 +57,4 @@
56
57
  return RoleFlags;
57
58
  }({});
58
59
 
59
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/discord/permissions.ts"],"sourcesContent":["/** Types for: https://discord.com/developers/docs/topics/permissions */\n\n/** https://discord.com/developers/docs/topics/permissions#permissions-bitwise-permission-flags */\nexport const BitwisePermissionFlags = {\n  /** Allows creation of instant invites */\n  CREATE_INSTANT_INVITE: 1n << 0n,\n  /** Allows kicking members */\n  KICK_MEMBERS: 1n << 1n,\n  /** Allows banning members */\n  BAN_MEMBERS: 1n << 2n,\n  /** Allows all permissions and bypasses channel permission overwrites */\n  ADMINISTRATOR: 1n << 3n,\n  /** Allows management and editing of channels */\n  MANAGE_CHANNELS: 1n << 4n,\n  /** Allows management and editing of the guild */\n  MANAGE_GUILD: 1n << 5n,\n  /** Allows for the addition of reactions to messages */\n  ADD_REACTIONS: 1n << 6n,\n  /** Allows for viewing of audit logs */\n  VIEW_AUDIT_LOG: 1n << 7n,\n  /** Allows for using priority speaker in a voice channel */\n  PRIORITY_SPEAKER: 1n << 8n,\n  /** Allows the user to go live */\n  STREAM: 1n << 9n,\n  /** Allows guild members to view a channel, which includes reading messages in text channels and joining voice channels */\n  VIEW_CHANNEL: 1n << 10n,\n  /** Allows for sending messages in a channel. (does not allow sending messages in threads) */\n  SEND_MESSAGES: 1n << 11n,\n  /** Allows for sending of /tts messages */\n  SEND_TTS_MESSAGES: 1n << 12n,\n  /** Allows for deletion of other users messages */\n  MANAGE_MESSAGES: 1n << 13n,\n  /** Links sent by users with this permission will be auto-embedded */\n  EMBED_LINKS: 1n << 14n,\n  /** Allows for uploading images and files */\n  ATTACH_FILES: 1n << 15n,\n  /** Allows for reading of message history */\n  READ_MESSAGE_HISTORY: 1n << 16n,\n  /** Allows for using the \\@everyone tag to notify all users in a channel, and the \\@here tag to notify all online users in a channel */\n  MENTION_EVERYONE: 1n << 17n,\n  /** Allows the usage of custom emojis from other servers */\n  USE_EXTERNAL_EMOJIS: 1n << 18n,\n  /** Allows for viewing guild insights */\n  VIEW_GUILD_INSIGHTS: 1n << 19n,\n  /** Allows for joining of a voice channel */\n  CONNECT: 1n << 20n,\n  /** Allows for speaking in a voice channel */\n  SPEAK: 1n << 21n,\n  /** Allows for muting members in a voice channel */\n  MUTE_MEMBERS: 1n << 22n,\n  /** Allows for deafening of members in a voice channel */\n  DEAFEN_MEMBERS: 1n << 23n,\n  /** Allows for moving of members between voice channels */\n  MOVE_MEMBERS: 1n << 24n,\n  /** Allows for using voice-activity-detection in a voice channel */\n  USE_VAD: 1n << 25n,\n  /** Allows for modification of own nickname */\n  CHANGE_NICKNAME: 1n << 26n,\n  /** Allows for modification of other users nicknames */\n  MANAGE_NICKNAMES: 1n << 27n,\n  /** Allows management and editing of roles */\n  MANAGE_ROLES: 1n << 28n,\n  /** Allows management and editing of webhooks */\n  MANAGE_WEBHOOKS: 1n << 29n,\n  /** Allows for editing and deleting emojis, stickers, and soundboard sounds created by all users */\n  MANAGE_GUILD_EXPRESSIONS: 1n << 30n,\n  /** Allows members to use application commands in text channels */\n  USE_SLASH_COMMANDS: 1n << 31n,\n  /** Allows for requesting to speak in stage channels. */\n  REQUEST_TO_SPEAK: 1n << 32n,\n  /** Allows for editing and deleting scheduled events created by all users */\n  MANAGE_EVENTS: 1n << 33n,\n  /** Allows for deleting and archiving threads, and viewing all private threads */\n  MANAGE_THREADS: 1n << 34n,\n  /** Allows for creating public and announcement threads */\n  CREATE_PUBLIC_THREADS: 1n << 35n,\n  /** Allows for creating private threads */\n  CREATE_PRIVATE_THREADS: 1n << 36n,\n  /** Allows the usage of custom stickers from other servers */\n  USE_EXTERNAL_STICKERS: 1n << 37n,\n  /** Allows for sending messages in threads */\n  SEND_MESSAGES_IN_THREADS: 1n << 38n,\n  /** Allows for launching activities (applications with the `EMBEDDED` flag) in a voice channel. */\n  USE_EMBEDDED_ACTIVITIES: 1n << 39n,\n  /** Allows for timing out users to prevent them from sending or reacting to messages in chat and threads, and from speaking in voice and stage channels */\n  MODERATE_MEMBERS: 1n << 40n,\n  /** Allows for viewing role subscription insights. */\n  VIEW_CREATOR_MONETIZATION_ANALYTICS: 1n << 41n,\n  /** Allows for using soundboard in a voice channel. */\n  USE_SOUNDBOARD: 1n << 42n,\n  /** Allows for creating emojis, stickers, and soundboard sounds, and editing and deleting those created by the current user */\n  CREATE_GUILD_EXPRESSIONS: 1n << 43n,\n  /** Allows for creating scheduled events, and editing and deleting those created by the current user */\n  CREATE_EVENTS: 1n << 44n,\n  /** Allows the usage of custom soundboards sounds from other servers */\n  USE_EXTERNAL_SOUNDS: 1n << 45n,\n  /** Allows sending voice messages */\n  SEND_VOICE_MESSAGES: 1n << 46n,\n  /** Allows sending polls */\n  SEND_POLLS: 1n << 49n,\n  /** Allows user-installed apps to send public responses. When disabled, users will still be allowed to use their apps but the responses will be ephemeral. This only applies to apps not also installed to the server. */\n  USE_EXTERNAL_APPS: 1n << 50n,\n  /** Allows pinning and unpinning messages */\n  PIN_MESSAGES: 1n << 51n,\n} as const\n\n/** https://discord.com/developers/docs/topics/permissions#permissions-bitwise-permission-flags */\nexport type PermissionStrings = keyof typeof BitwisePermissionFlags\n\n/** https://discord.com/developers/docs/topics/permissions#role-object-role-structure */\nexport interface DiscordRole {\n  /** Role id */\n  id: string\n  /** Role name */\n  name: string\n  /**\n   * RGB color value, default: 0\n   * @deprecated the {@link colors} field is recommended for use instead of this field\n   */\n  color: number\n  /** The role's color */\n  colors: DiscordRoleColors\n  /** If this role is showed separately in the user listing */\n  hoist: boolean\n  /** the role emoji hash */\n  icon?: string\n  /** role unicode emoji */\n  unicode_emoji?: string\n  /** Position of this role (roles with the same position are sorted by id) */\n  position: number\n  /** Permission bit set */\n  permissions: string\n  /** Whether this role is managed by an integration */\n  managed: boolean\n  /** Whether this role is mentionable */\n  mentionable: boolean\n  /** The tags this role has */\n  tags?: DiscordRoleTags\n  /** Role flags combined as a bitfield */\n  flags: RoleFlags\n}\n\n/** https://discord.com/developers/docs/topics/permissions#role-object-role-tags-structure */\nexport interface DiscordRoleTags {\n  /** The id of the bot this role belongs to */\n  bot_id?: string\n  /** The id of the integration this role belongs to */\n  integration_id?: string\n  /** Whether this is the guild's premium subscriber role */\n  premium_subscriber?: null\n  /** Id of this role's subscription sku and listing. */\n  subscription_listing_id?: string\n  /** Whether this role is available for purchase. */\n  available_for_purchase?: null\n  /** Whether this is a guild's linked role */\n  guild_connections?: null\n}\n\n/** https://discord.com/developers/docs/topics/permissions#role-object-role-colors-object */\nexport interface DiscordRoleColors {\n  /** The primary color for the role */\n  primary_color: number\n  /** The secondary color for the role, this will make the role a gradient between the other provided colors */\n  secondary_color: number | null\n  /** The tertiary color for the role, this will turn the gradient into a holographic style */\n  tertiary_color: number | null\n}\n\n/** https://discord.com/developers/docs/topics/permissions#role-object-role-flags */\nexport enum RoleFlags {\n  None,\n  /** Role can be selected by members in an onboarding prompt */\n  InPrompt = 1 << 0,\n}\n"],"names":["BitwisePermissionFlags","CREATE_INSTANT_INVITE","KICK_MEMBERS","BAN_MEMBERS","ADMINISTRATOR","MANAGE_CHANNELS","MANAGE_GUILD","ADD_REACTIONS","VIEW_AUDIT_LOG","PRIORITY_SPEAKER","STREAM","VIEW_CHANNEL","SEND_MESSAGES","SEND_TTS_MESSAGES","MANAGE_MESSAGES","EMBED_LINKS","ATTACH_FILES","READ_MESSAGE_HISTORY","MENTION_EVERYONE","USE_EXTERNAL_EMOJIS","VIEW_GUILD_INSIGHTS","CONNECT","SPEAK","MUTE_MEMBERS","DEAFEN_MEMBERS","MOVE_MEMBERS","USE_VAD","CHANGE_NICKNAME","MANAGE_NICKNAMES","MANAGE_ROLES","MANAGE_WEBHOOKS","MANAGE_GUILD_EXPRESSIONS","USE_SLASH_COMMANDS","REQUEST_TO_SPEAK","MANAGE_EVENTS","MANAGE_THREADS","CREATE_PUBLIC_THREADS","CREATE_PRIVATE_THREADS","USE_EXTERNAL_STICKERS","SEND_MESSAGES_IN_THREADS","USE_EMBEDDED_ACTIVITIES","MODERATE_MEMBERS","VIEW_CREATOR_MONETIZATION_ANALYTICS","USE_SOUNDBOARD","CREATE_GUILD_EXPRESSIONS","CREATE_EVENTS","USE_EXTERNAL_SOUNDS","SEND_VOICE_MESSAGES","SEND_POLLS","USE_EXTERNAL_APPS","PIN_MESSAGES","RoleFlags"],"mappings":"AAAA,sEAAsE,GAEtE,gGAAgG,GAChG,OAAO,MAAMA,yBAAyB;IACpC,uCAAuC,GACvCC,uBAAuB,EAAE,IAAI,EAAE;IAC/B,2BAA2B,GAC3BC,cAAc,EAAE,IAAI,EAAE;IACtB,2BAA2B,GAC3BC,aAAa,EAAE,IAAI,EAAE;IACrB,sEAAsE,GACtEC,eAAe,EAAE,IAAI,EAAE;IACvB,8CAA8C,GAC9CC,iBAAiB,EAAE,IAAI,EAAE;IACzB,+CAA+C,GAC/CC,cAAc,EAAE,IAAI,EAAE;IACtB,qDAAqD,GACrDC,eAAe,EAAE,IAAI,EAAE;IACvB,qCAAqC,GACrCC,gBAAgB,EAAE,IAAI,EAAE;IACxB,yDAAyD,GACzDC,kBAAkB,EAAE,IAAI,EAAE;IAC1B,+BAA+B,GAC/BC,QAAQ,EAAE,IAAI,EAAE;IAChB,wHAAwH,GACxHC,cAAc,EAAE,IAAI,GAAG;IACvB,2FAA2F,GAC3FC,eAAe,EAAE,IAAI,GAAG;IACxB,wCAAwC,GACxCC,mBAAmB,EAAE,IAAI,GAAG;IAC5B,gDAAgD,GAChDC,iBAAiB,EAAE,IAAI,GAAG;IAC1B,mEAAmE,GACnEC,aAAa,EAAE,IAAI,GAAG;IACtB,0CAA0C,GAC1CC,cAAc,EAAE,IAAI,GAAG;IACvB,0CAA0C,GAC1CC,sBAAsB,EAAE,IAAI,GAAG;IAC/B,qIAAqI,GACrIC,kBAAkB,EAAE,IAAI,GAAG;IAC3B,yDAAyD,GACzDC,qBAAqB,EAAE,IAAI,GAAG;IAC9B,sCAAsC,GACtCC,qBAAqB,EAAE,IAAI,GAAG;IAC9B,0CAA0C,GAC1CC,SAAS,EAAE,IAAI,GAAG;IAClB,2CAA2C,GAC3CC,OAAO,EAAE,IAAI,GAAG;IAChB,iDAAiD,GACjDC,cAAc,EAAE,IAAI,GAAG;IACvB,uDAAuD,GACvDC,gBAAgB,EAAE,IAAI,GAAG;IACzB,wDAAwD,GACxDC,cAAc,EAAE,IAAI,GAAG;IACvB,iEAAiE,GACjEC,SAAS,EAAE,IAAI,GAAG;IAClB,4CAA4C,GAC5CC,iBAAiB,EAAE,IAAI,GAAG;IAC1B,qDAAqD,GACrDC,kBAAkB,EAAE,IAAI,GAAG;IAC3B,2CAA2C,GAC3CC,cAAc,EAAE,IAAI,GAAG;IACvB,8CAA8C,GAC9CC,iBAAiB,EAAE,IAAI,GAAG;IAC1B,iGAAiG,GACjGC,0BAA0B,EAAE,IAAI,GAAG;IACnC,gEAAgE,GAChEC,oBAAoB,EAAE,IAAI,GAAG;IAC7B,sDAAsD,GACtDC,kBAAkB,EAAE,IAAI,GAAG;IAC3B,0EAA0E,GAC1EC,eAAe,EAAE,IAAI,GAAG;IACxB,+EAA+E,GAC/EC,gBAAgB,EAAE,IAAI,GAAG;IACzB,wDAAwD,GACxDC,uBAAuB,EAAE,IAAI,GAAG;IAChC,wCAAwC,GACxCC,wBAAwB,EAAE,IAAI,GAAG;IACjC,2DAA2D,GAC3DC,uBAAuB,EAAE,IAAI,GAAG;IAChC,2CAA2C,GAC3CC,0BAA0B,EAAE,IAAI,GAAG;IACnC,gGAAgG,GAChGC,yBAAyB,EAAE,IAAI,GAAG;IAClC,wJAAwJ,GACxJC,kBAAkB,EAAE,IAAI,GAAG;IAC3B,mDAAmD,GACnDC,qCAAqC,EAAE,IAAI,GAAG;IAC9C,oDAAoD,GACpDC,gBAAgB,EAAE,IAAI,GAAG;IACzB,4HAA4H,GAC5HC,0BAA0B,EAAE,IAAI,GAAG;IACnC,qGAAqG,GACrGC,eAAe,EAAE,IAAI,GAAG;IACxB,qEAAqE,GACrEC,qBAAqB,EAAE,IAAI,GAAG;IAC9B,kCAAkC,GAClCC,qBAAqB,EAAE,IAAI,GAAG;IAC9B,yBAAyB,GACzBC,YAAY,EAAE,IAAI,GAAG;IACrB,uNAAuN,GACvNC,mBAAmB,EAAE,IAAI,GAAG;IAC5B,0CAA0C,GAC1CC,cAAc,EAAE,IAAI,GAAG;AACzB,EAAU;AAgEV,kFAAkF,GAClF,OAAO,IAAA,AAAKC,mCAAAA;;IAEV,4DAA4D;WAFlDA;MAIX"}
60
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/discord/permissions.ts"],"sourcesContent":["/** Types for: https://discord.com/developers/docs/topics/permissions */\n\n/** https://discord.com/developers/docs/topics/permissions#permissions-bitwise-permission-flags */\nexport const BitwisePermissionFlags = {\n  /** Allows creation of instant invites */\n  CREATE_INSTANT_INVITE: 1n << 0n,\n  /** Allows kicking members */\n  KICK_MEMBERS: 1n << 1n,\n  /** Allows banning members */\n  BAN_MEMBERS: 1n << 2n,\n  /** Allows all permissions and bypasses channel permission overwrites */\n  ADMINISTRATOR: 1n << 3n,\n  /** Allows management and editing of channels */\n  MANAGE_CHANNELS: 1n << 4n,\n  /** Allows management and editing of the guild */\n  MANAGE_GUILD: 1n << 5n,\n  /** Allows for the addition of reactions to messages */\n  ADD_REACTIONS: 1n << 6n,\n  /** Allows for viewing of audit logs */\n  VIEW_AUDIT_LOG: 1n << 7n,\n  /** Allows for using priority speaker in a voice channel */\n  PRIORITY_SPEAKER: 1n << 8n,\n  /** Allows the user to go live */\n  STREAM: 1n << 9n,\n  /** Allows guild members to view a channel, which includes reading messages in text channels and joining voice channels */\n  VIEW_CHANNEL: 1n << 10n,\n  /** Allows for sending messages in a channel. (does not allow sending messages in threads) */\n  SEND_MESSAGES: 1n << 11n,\n  /** Allows for sending of /tts messages */\n  SEND_TTS_MESSAGES: 1n << 12n,\n  /** Allows for deletion of other users messages */\n  MANAGE_MESSAGES: 1n << 13n,\n  /** Links sent by users with this permission will be auto-embedded */\n  EMBED_LINKS: 1n << 14n,\n  /** Allows for uploading images and files */\n  ATTACH_FILES: 1n << 15n,\n  /** Allows for reading of message history */\n  READ_MESSAGE_HISTORY: 1n << 16n,\n  /** Allows for using the \\@everyone tag to notify all users in a channel, and the \\@here tag to notify all online users in a channel */\n  MENTION_EVERYONE: 1n << 17n,\n  /** Allows the usage of custom emojis from other servers */\n  USE_EXTERNAL_EMOJIS: 1n << 18n,\n  /** Allows for viewing guild insights */\n  VIEW_GUILD_INSIGHTS: 1n << 19n,\n  /** Allows for joining of a voice channel */\n  CONNECT: 1n << 20n,\n  /** Allows for speaking in a voice channel */\n  SPEAK: 1n << 21n,\n  /** Allows for muting members in a voice channel */\n  MUTE_MEMBERS: 1n << 22n,\n  /** Allows for deafening of members in a voice channel */\n  DEAFEN_MEMBERS: 1n << 23n,\n  /** Allows for moving of members between voice channels */\n  MOVE_MEMBERS: 1n << 24n,\n  /** Allows for using voice-activity-detection in a voice channel */\n  USE_VAD: 1n << 25n,\n  /** Allows for modification of own nickname */\n  CHANGE_NICKNAME: 1n << 26n,\n  /** Allows for modification of other users nicknames */\n  MANAGE_NICKNAMES: 1n << 27n,\n  /** Allows management and editing of roles */\n  MANAGE_ROLES: 1n << 28n,\n  /** Allows management and editing of webhooks */\n  MANAGE_WEBHOOKS: 1n << 29n,\n  /** Allows for editing and deleting emojis, stickers, and soundboard sounds created by all users */\n  MANAGE_GUILD_EXPRESSIONS: 1n << 30n,\n  /** Allows members to use application commands in text channels */\n  USE_SLASH_COMMANDS: 1n << 31n,\n  /** Allows for requesting to speak in stage channels. */\n  REQUEST_TO_SPEAK: 1n << 32n,\n  /** Allows for editing and deleting scheduled events created by all users */\n  MANAGE_EVENTS: 1n << 33n,\n  /** Allows for deleting and archiving threads, and viewing all private threads */\n  MANAGE_THREADS: 1n << 34n,\n  /** Allows for creating public and announcement threads */\n  CREATE_PUBLIC_THREADS: 1n << 35n,\n  /** Allows for creating private threads */\n  CREATE_PRIVATE_THREADS: 1n << 36n,\n  /** Allows the usage of custom stickers from other servers */\n  USE_EXTERNAL_STICKERS: 1n << 37n,\n  /** Allows for sending messages in threads */\n  SEND_MESSAGES_IN_THREADS: 1n << 38n,\n  /** Allows for launching activities (applications with the `EMBEDDED` flag) in a voice channel. */\n  USE_EMBEDDED_ACTIVITIES: 1n << 39n,\n  /** Allows for timing out users to prevent them from sending or reacting to messages in chat and threads, and from speaking in voice and stage channels */\n  MODERATE_MEMBERS: 1n << 40n,\n  /** Allows for viewing role subscription insights. */\n  VIEW_CREATOR_MONETIZATION_ANALYTICS: 1n << 41n,\n  /** Allows for using soundboard in a voice channel. */\n  USE_SOUNDBOARD: 1n << 42n,\n  /** Allows for creating emojis, stickers, and soundboard sounds, and editing and deleting those created by the current user */\n  CREATE_GUILD_EXPRESSIONS: 1n << 43n,\n  /** Allows for creating scheduled events, and editing and deleting those created by the current user */\n  CREATE_EVENTS: 1n << 44n,\n  /** Allows the usage of custom soundboards sounds from other servers */\n  USE_EXTERNAL_SOUNDS: 1n << 45n,\n  /** Allows sending voice messages */\n  SEND_VOICE_MESSAGES: 1n << 46n,\n  /** Allows sending polls */\n  SEND_POLLS: 1n << 49n,\n  /** Allows user-installed apps to send public responses. When disabled, users will still be allowed to use their apps but the responses will be ephemeral. This only applies to apps not also installed to the server. */\n  USE_EXTERNAL_APPS: 1n << 50n,\n  /** Allows pinning and unpinning messages */\n  PIN_MESSAGES: 1n << 51n,\n  /** Allows bypassing slowmode restrictions */\n  BYPASS_SLOWMODE: 1n << 52n,\n} as const\n\n/** https://discord.com/developers/docs/topics/permissions#permissions-bitwise-permission-flags */\nexport type PermissionStrings = keyof typeof BitwisePermissionFlags\n\n/** https://discord.com/developers/docs/topics/permissions#role-object-role-structure */\nexport interface DiscordRole {\n  /** Role id */\n  id: string\n  /** Role name */\n  name: string\n  /**\n   * RGB color value, default: 0\n   * @deprecated the {@link colors} field is recommended for use instead of this field\n   */\n  color: number\n  /** The role's color */\n  colors: DiscordRoleColors\n  /** If this role is showed separately in the user listing */\n  hoist: boolean\n  /** the role emoji hash */\n  icon?: string\n  /** role unicode emoji */\n  unicode_emoji?: string\n  /** Position of this role (roles with the same position are sorted by id) */\n  position: number\n  /** Permission bit set */\n  permissions: string\n  /** Whether this role is managed by an integration */\n  managed: boolean\n  /** Whether this role is mentionable */\n  mentionable: boolean\n  /** The tags this role has */\n  tags?: DiscordRoleTags\n  /** Role flags combined as a bitfield */\n  flags: RoleFlags\n}\n\n/** https://discord.com/developers/docs/topics/permissions#role-object-role-tags-structure */\nexport interface DiscordRoleTags {\n  /** The id of the bot this role belongs to */\n  bot_id?: string\n  /** The id of the integration this role belongs to */\n  integration_id?: string\n  /** Whether this is the guild's premium subscriber role */\n  premium_subscriber?: null\n  /** Id of this role's subscription sku and listing. */\n  subscription_listing_id?: string\n  /** Whether this role is available for purchase. */\n  available_for_purchase?: null\n  /** Whether this is a guild's linked role */\n  guild_connections?: null\n}\n\n/** https://discord.com/developers/docs/topics/permissions#role-object-role-colors-object */\nexport interface DiscordRoleColors {\n  /** The primary color for the role */\n  primary_color: number\n  /** The secondary color for the role, this will make the role a gradient between the other provided colors */\n  secondary_color: number | null\n  /** The tertiary color for the role, this will turn the gradient into a holographic style */\n  tertiary_color: number | null\n}\n\n/** https://discord.com/developers/docs/topics/permissions#role-object-role-flags */\nexport enum RoleFlags {\n  None,\n  /** Role can be selected by members in an onboarding prompt */\n  InPrompt = 1 << 0,\n}\n"],"names":["BitwisePermissionFlags","CREATE_INSTANT_INVITE","KICK_MEMBERS","BAN_MEMBERS","ADMINISTRATOR","MANAGE_CHANNELS","MANAGE_GUILD","ADD_REACTIONS","VIEW_AUDIT_LOG","PRIORITY_SPEAKER","STREAM","VIEW_CHANNEL","SEND_MESSAGES","SEND_TTS_MESSAGES","MANAGE_MESSAGES","EMBED_LINKS","ATTACH_FILES","READ_MESSAGE_HISTORY","MENTION_EVERYONE","USE_EXTERNAL_EMOJIS","VIEW_GUILD_INSIGHTS","CONNECT","SPEAK","MUTE_MEMBERS","DEAFEN_MEMBERS","MOVE_MEMBERS","USE_VAD","CHANGE_NICKNAME","MANAGE_NICKNAMES","MANAGE_ROLES","MANAGE_WEBHOOKS","MANAGE_GUILD_EXPRESSIONS","USE_SLASH_COMMANDS","REQUEST_TO_SPEAK","MANAGE_EVENTS","MANAGE_THREADS","CREATE_PUBLIC_THREADS","CREATE_PRIVATE_THREADS","USE_EXTERNAL_STICKERS","SEND_MESSAGES_IN_THREADS","USE_EMBEDDED_ACTIVITIES","MODERATE_MEMBERS","VIEW_CREATOR_MONETIZATION_ANALYTICS","USE_SOUNDBOARD","CREATE_GUILD_EXPRESSIONS","CREATE_EVENTS","USE_EXTERNAL_SOUNDS","SEND_VOICE_MESSAGES","SEND_POLLS","USE_EXTERNAL_APPS","PIN_MESSAGES","BYPASS_SLOWMODE","RoleFlags"],"mappings":"AAAA,sEAAsE,GAEtE,gGAAgG,GAChG,OAAO,MAAMA,yBAAyB;IACpC,uCAAuC,GACvCC,uBAAuB,EAAE,IAAI,EAAE;IAC/B,2BAA2B,GAC3BC,cAAc,EAAE,IAAI,EAAE;IACtB,2BAA2B,GAC3BC,aAAa,EAAE,IAAI,EAAE;IACrB,sEAAsE,GACtEC,eAAe,EAAE,IAAI,EAAE;IACvB,8CAA8C,GAC9CC,iBAAiB,EAAE,IAAI,EAAE;IACzB,+CAA+C,GAC/CC,cAAc,EAAE,IAAI,EAAE;IACtB,qDAAqD,GACrDC,eAAe,EAAE,IAAI,EAAE;IACvB,qCAAqC,GACrCC,gBAAgB,EAAE,IAAI,EAAE;IACxB,yDAAyD,GACzDC,kBAAkB,EAAE,IAAI,EAAE;IAC1B,+BAA+B,GAC/BC,QAAQ,EAAE,IAAI,EAAE;IAChB,wHAAwH,GACxHC,cAAc,EAAE,IAAI,GAAG;IACvB,2FAA2F,GAC3FC,eAAe,EAAE,IAAI,GAAG;IACxB,wCAAwC,GACxCC,mBAAmB,EAAE,IAAI,GAAG;IAC5B,gDAAgD,GAChDC,iBAAiB,EAAE,IAAI,GAAG;IAC1B,mEAAmE,GACnEC,aAAa,EAAE,IAAI,GAAG;IACtB,0CAA0C,GAC1CC,cAAc,EAAE,IAAI,GAAG;IACvB,0CAA0C,GAC1CC,sBAAsB,EAAE,IAAI,GAAG;IAC/B,qIAAqI,GACrIC,kBAAkB,EAAE,IAAI,GAAG;IAC3B,yDAAyD,GACzDC,qBAAqB,EAAE,IAAI,GAAG;IAC9B,sCAAsC,GACtCC,qBAAqB,EAAE,IAAI,GAAG;IAC9B,0CAA0C,GAC1CC,SAAS,EAAE,IAAI,GAAG;IAClB,2CAA2C,GAC3CC,OAAO,EAAE,IAAI,GAAG;IAChB,iDAAiD,GACjDC,cAAc,EAAE,IAAI,GAAG;IACvB,uDAAuD,GACvDC,gBAAgB,EAAE,IAAI,GAAG;IACzB,wDAAwD,GACxDC,cAAc,EAAE,IAAI,GAAG;IACvB,iEAAiE,GACjEC,SAAS,EAAE,IAAI,GAAG;IAClB,4CAA4C,GAC5CC,iBAAiB,EAAE,IAAI,GAAG;IAC1B,qDAAqD,GACrDC,kBAAkB,EAAE,IAAI,GAAG;IAC3B,2CAA2C,GAC3CC,cAAc,EAAE,IAAI,GAAG;IACvB,8CAA8C,GAC9CC,iBAAiB,EAAE,IAAI,GAAG;IAC1B,iGAAiG,GACjGC,0BAA0B,EAAE,IAAI,GAAG;IACnC,gEAAgE,GAChEC,oBAAoB,EAAE,IAAI,GAAG;IAC7B,sDAAsD,GACtDC,kBAAkB,EAAE,IAAI,GAAG;IAC3B,0EAA0E,GAC1EC,eAAe,EAAE,IAAI,GAAG;IACxB,+EAA+E,GAC/EC,gBAAgB,EAAE,IAAI,GAAG;IACzB,wDAAwD,GACxDC,uBAAuB,EAAE,IAAI,GAAG;IAChC,wCAAwC,GACxCC,wBAAwB,EAAE,IAAI,GAAG;IACjC,2DAA2D,GAC3DC,uBAAuB,EAAE,IAAI,GAAG;IAChC,2CAA2C,GAC3CC,0BAA0B,EAAE,IAAI,GAAG;IACnC,gGAAgG,GAChGC,yBAAyB,EAAE,IAAI,GAAG;IAClC,wJAAwJ,GACxJC,kBAAkB,EAAE,IAAI,GAAG;IAC3B,mDAAmD,GACnDC,qCAAqC,EAAE,IAAI,GAAG;IAC9C,oDAAoD,GACpDC,gBAAgB,EAAE,IAAI,GAAG;IACzB,4HAA4H,GAC5HC,0BAA0B,EAAE,IAAI,GAAG;IACnC,qGAAqG,GACrGC,eAAe,EAAE,IAAI,GAAG;IACxB,qEAAqE,GACrEC,qBAAqB,EAAE,IAAI,GAAG;IAC9B,kCAAkC,GAClCC,qBAAqB,EAAE,IAAI,GAAG;IAC9B,yBAAyB,GACzBC,YAAY,EAAE,IAAI,GAAG;IACrB,uNAAuN,GACvNC,mBAAmB,EAAE,IAAI,GAAG;IAC5B,0CAA0C,GAC1CC,cAAc,EAAE,IAAI,GAAG;IACvB,2CAA2C,GAC3CC,iBAAiB,EAAE,IAAI,GAAG;AAC5B,EAAU;AAgEV,kFAAkF,GAClF,OAAO,IAAA,AAAKC,mCAAAA;;IAEV,4DAA4D;WAFlDA;MAIX"}
@@ -31,7 +31,7 @@ export interface DiscordEventWebhookEventBody {
31
31
  /** Timestamp of when the event occurred in ISO8601 format */
32
32
  timestamp: string;
33
33
  /** Data for the event. The shape depends on the event type */
34
- data?: DiscordEventWebhookApplicationAuthorizedBody | DiscordEventWebhookApplicationDeauthorizedBody | DiscordEventWebhookEntitlementCreateBody | DiscordEventWebhookLobbyMessageCreateBody | DiscordEventWebhookLobbyMessageUpdateBody | DiscordEventWebhookLobbyMessageDeleteBody | DiscordEventWebhookGameDirectMessageCreateBody | DiscordEventWebhookGameDirectMessageUpdateBody | DiscordEventWebhookGameDirectMessageDeleteBody;
34
+ data?: DiscordEventWebhookApplicationAuthorizedBody | DiscordEventWebhookApplicationDeauthorizedBody | DiscordEventWebhookEntitlementCreateBody | DiscordEventWebhookEntitlementUpdateBody | DiscordEventWebhookEntitlementDeleteBody | DiscordEventWebhookLobbyMessageCreateBody | DiscordEventWebhookLobbyMessageUpdateBody | DiscordEventWebhookLobbyMessageDeleteBody | DiscordEventWebhookGameDirectMessageCreateBody | DiscordEventWebhookGameDirectMessageUpdateBody | DiscordEventWebhookGameDirectMessageDeleteBody;
35
35
  }
36
36
  /** https://discord.com/developers/docs/events/webhook-events#event-types */
37
37
  export declare enum DiscordWebhookEventType {
@@ -41,6 +41,10 @@ export declare enum DiscordWebhookEventType {
41
41
  ApplicationDeauthorized = "APPLICATION_DEAUTHORIZED",
42
42
  /** Entitlement was created */
43
43
  EntitlementCreate = "ENTITLEMENT_CREATE",
44
+ /** Entitlement was updated */
45
+ EntitlementUpdate = "ENTITLEMENT_UPDATE",
46
+ /** Entitlement was deleted */
47
+ EntitlementDelete = "ENTITLEMENT_DELETE",
44
48
  /** User was added to a Quest (currently unavailable) */
45
49
  QuestUserEnrollment = "QUEST_USER_ENROLLMENT",
46
50
  /** Sent when a message is created in a lobby */
@@ -74,6 +78,10 @@ export interface DiscordEventWebhookApplicationDeauthorizedBody {
74
78
  }
75
79
  /** https://discord.com/developers/docs/events/webhook-events#entitlement-create-entitlement-create-structure */
76
80
  export type DiscordEventWebhookEntitlementCreateBody = DiscordEntitlement;
81
+ /** https://discord.com/developers/docs/events/webhook-events#entitlement-update-entitlement-update-structure */
82
+ export type DiscordEventWebhookEntitlementUpdateBody = DiscordEntitlement;
83
+ /** https://discord.com/developers/docs/events/webhook-events#entitlement-delete-entitlement-delete-structure */
84
+ export type DiscordEventWebhookEntitlementDeleteBody = DiscordEntitlement;
77
85
  /** https://discord.com/developers/docs/events/webhook-events#lobby-message-create-lobby-message-create-structure */
78
86
  export type DiscordEventWebhookLobbyMessageCreateBody = DiscordSocialSDKLobbyMessage;
79
87
  /** https://discord.com/developers/docs/events/webhook-events#lobby-message-update-lobby-message-update-structure */
@@ -1 +1 @@
1
- {"version":3,"file":"webhookEvents.d.ts","sourceRoot":"","sources":["../../src/discord/webhookEvents.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"webhookEvents.d.ts","sourceRoot":"","sources":["../../src/discord/webhookEvents.ts"],"names":[],"mappings":"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"}
@@ -7,6 +7,8 @@
7
7
  /** Sent when an app was authorized by a user to a server or their account */ DiscordWebhookEventType["ApplicationAuthorized"] = "APPLICATION_AUTHORIZED";
8
8
  /** Sent when an app was deauthorized by a user */ DiscordWebhookEventType["ApplicationDeauthorized"] = "APPLICATION_DEAUTHORIZED";
9
9
  /** Entitlement was created */ DiscordWebhookEventType["EntitlementCreate"] = "ENTITLEMENT_CREATE";
10
+ /** Entitlement was updated */ DiscordWebhookEventType["EntitlementUpdate"] = "ENTITLEMENT_UPDATE";
11
+ /** Entitlement was deleted */ DiscordWebhookEventType["EntitlementDelete"] = "ENTITLEMENT_DELETE";
10
12
  /** User was added to a Quest (currently unavailable) */ DiscordWebhookEventType["QuestUserEnrollment"] = "QUEST_USER_ENROLLMENT";
11
13
  /** Sent when a message is created in a lobby */ DiscordWebhookEventType["LobbyMessageCreate"] = "LOBBY_MESSAGE_CREATE";
12
14
  /** Sent when a message is updated in a lobby */ DiscordWebhookEventType["LobbyMessageUpdate"] = "LOBBY_MESSAGE_UPDATE";
@@ -17,4 +19,4 @@
17
19
  return DiscordWebhookEventType;
18
20
  }({});
19
21
 
20
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/discord/webhookEvents.ts"],"sourcesContent":["/** Types for: https://discord.com/developers/docs/events/webhook-events */\n\nimport type { DiscordApplicationIntegrationType } from './application.js'\nimport type { DiscordChannel } from './channel.js'\nimport type { DiscordEntitlement } from './entitlement.js'\nimport type { DiscordGuild } from './guild.js'\nimport type { DiscordMessage, MessageFlags, MessageTypes } from './message.js'\nimport type { OAuth2Scope } from './oauth2.js'\nimport type { DiscordUser } from './user.js'\n\n/** https://discord.com/developers/docs/events/webhook-events#payload-structure */\nexport interface DiscordEventWebhookEvent {\n  /** Version scheme for the webhook event. Currently always 1 */\n  version: 1\n  /** ID of your app */\n  application_id: string\n  /** Type of webhook, either 0 for PING or 1 for webhook events */\n  type: DiscordWebhookEventType\n  /** Event data payload */\n  event?: DiscordEventWebhookEventBody\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#webhook-types */\nexport enum DiscordEventWebhookType {\n  /** PING event sent to verify your Webhook Event URL is active */\n  Ping = 0,\n  /** Webhook event (details for event in event body object) */\n  Event = 1,\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#event-body-object */\nexport interface DiscordEventWebhookEventBody {\n  /** Event type */\n  type: DiscordWebhookEventType\n  /** Timestamp of when the event occurred in ISO8601 format */\n  timestamp: string\n  /** Data for the event. The shape depends on the event type */\n  data?:\n    | DiscordEventWebhookApplicationAuthorizedBody\n    | DiscordEventWebhookApplicationDeauthorizedBody\n    | DiscordEventWebhookEntitlementCreateBody\n    | DiscordEventWebhookLobbyMessageCreateBody\n    | DiscordEventWebhookLobbyMessageUpdateBody\n    | DiscordEventWebhookLobbyMessageDeleteBody\n    | DiscordEventWebhookGameDirectMessageCreateBody\n    | DiscordEventWebhookGameDirectMessageUpdateBody\n    | DiscordEventWebhookGameDirectMessageDeleteBody\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#event-types */\nexport enum DiscordWebhookEventType {\n  /** Sent when an app was authorized by a user to a server or their account */\n  ApplicationAuthorized = 'APPLICATION_AUTHORIZED',\n  /** Sent when an app was deauthorized by a user */\n  ApplicationDeauthorized = 'APPLICATION_DEAUTHORIZED',\n  /** Entitlement was created */\n  EntitlementCreate = 'ENTITLEMENT_CREATE',\n  /** User was added to a Quest (currently unavailable) */\n  QuestUserEnrollment = 'QUEST_USER_ENROLLMENT',\n  /** Sent when a message is created in a lobby */\n  LobbyMessageCreate = 'LOBBY_MESSAGE_CREATE',\n  /** Sent when a message is updated in a lobby */\n  LobbyMessageUpdate = 'LOBBY_MESSAGE_UPDATE',\n  /** Sent when a message is deleted from a lobby */\n  LobbyMessageDelete = 'LOBBY_MESSAGE_DELETE',\n  /** Sent when a direct message is created during an active Social SDK session */\n  GameDirectMessageCreate = 'GAME_DIRECT_MESSAGE_CREATE',\n  /** Sent when a direct message is updated during an active Social SDK session */\n  GameDirectMessageUpdate = 'GAME_DIRECT_MESSAGE_UPDATE',\n  /** Sent when a direct message is deleted during an active Social SDK session */\n  GameDirectMessageDelete = 'GAME_DIRECT_MESSAGE_DELETE',\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#application-authorized-application-authorized-structure */\nexport interface DiscordEventWebhookApplicationAuthorizedBody {\n  /** Installation context for the authorization. Either guild (0) if installed to a server or user (1) if installed to a user's account */\n  integration_type?: DiscordApplicationIntegrationType\n  /** User who authorized the app */\n  user: DiscordUser\n  /** List of scopes the user authorized */\n  scopes: OAuth2Scope[]\n  /** Server which app was authorized for (when integration type is 0) */\n  guild?: DiscordGuild\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#application-authorized-application-authorized-structure */\nexport interface DiscordEventWebhookApplicationDeauthorizedBody {\n  /** User who deauthorized the app */\n  user: DiscordUser\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#entitlement-create-entitlement-create-structure */\nexport type DiscordEventWebhookEntitlementCreateBody = DiscordEntitlement\n\n/** https://discord.com/developers/docs/events/webhook-events#lobby-message-create-lobby-message-create-structure */\nexport type DiscordEventWebhookLobbyMessageCreateBody = DiscordSocialSDKLobbyMessage\n\n// Discord does not explicitly says what \"with additional fields for message updates\" means, so we rely on the example and the DiscordMessage structure\n/** https://discord.com/developers/docs/events/webhook-events#lobby-message-update-lobby-message-update-structure */\nexport interface DiscordEventWebhookLobbyMessageUpdateBody extends DiscordSocialSDKLobbyMessage {\n  /** ISO8601 timestamp of when the message was last edited */\n  edited_timestamp: string | null\n  /** ISO8601 timestamp of when the message was created */\n  timestamp: string\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#lobby-message-delete-lobby-message-delete-structure */\nexport interface DiscordEventWebhookLobbyMessageDeleteBody {\n  /** ID of the deleted message */\n  id: string\n  /** ID of the lobby where the message was deleted */\n  lobby_id: string\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#game-direct-message-create-game-direct-message-create-structure */\nexport type DiscordEventWebhookGameDirectMessageCreateBody = DiscordSocialSDKMessage | DiscordSocialSDKPassthroughMessage\n\n/** https://discord.com/developers/docs/events/webhook-events#game-direct-message-update-game-direct-message-update-structure */\nexport type DiscordEventWebhookGameDirectMessageUpdateBody = DiscordSocialSDKMessage | DiscordSocialSDKPassthroughMessage\n\n/** https://discord.com/developers/docs/events/webhook-events#game-direct-message-delete-game-direct-message-delete-structure */\nexport type DiscordEventWebhookGameDirectMessageDeleteBody = DiscordSocialSDKMessage | DiscordSocialSDKPassthroughMessage\n\n/** https://discord.com/developers/docs/events/webhook-events#lobby-message-object-lobby-message-structure */\nexport interface DiscordSocialSDKLobbyMessage {\n  /** ID of the message */\n  id: string\n  /** Type of message */\n  type: MessageTypes\n  /** Contents of the message */\n  content: string\n  /** ID of the lobby where the message was sent */\n  lobby_id: string\n  /** ID of the channel the message was sent in */\n  channel_id: string\n  /** Author of the message */\n  author: DiscordUser\n  /** Additional metadata for the message (key-value pairs) */\n  metadata?: Record<string, unknown>\n  /**\n   * Message flags combined as a bitfield\n   *\n   * @see {@link MessageFlags}\n   */\n  flags: number\n  /** ID of the application (only present during active Social SDK sessions) */\n  application_id?: string\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#message-object */\nexport interface DiscordSocialSDKMessage extends DiscordMessage {\n  /** ID of the lobby where the message was created (only present in Linked Channel messages) */\n  lobby_id?: string\n  /** Channel object with recipient information */\n  channel: DiscordChannel\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#passthrough-message-object-passthrough-message-structure */\nexport interface DiscordSocialSDKPassthroughMessage {\n  /** ID of the message */\n  id: string\n  /** Type of message */\n  type: MessageTypes\n  /** Contents of the message */\n  content: string\n  /** ID of the channel the message was sent in */\n  channel_id: string\n  /** ID of the message recipient */\n  recipient_id: string\n  /** Author of the message */\n  author: DiscordUser\n  /** Message flags combined as a bitfield\n   *\n   * @see {@link MessageFlags}\n   */\n  flags: MessageFlags\n  /** ID of the application that created the message */\n  application_id: string\n  /** Channel object with recipient information */\n  channel: DiscordChannel\n}\n"],"names":["DiscordEventWebhookType","DiscordWebhookEventType"],"mappings":"AAAA,yEAAyE,GAsBzE,4EAA4E,GAC5E,OAAO,IAAA,AAAKA,iDAAAA;IACV,+DAA+D;IAE/D,2DAA2D;WAHjDA;MAKX;AAqBD,0EAA0E,GAC1E,OAAO,IAAA,AAAKC,iDAAAA;IACV,2EAA2E;IAE3E,gDAAgD;IAEhD,4BAA4B;IAE5B,sDAAsD;IAEtD,8CAA8C;IAE9C,8CAA8C;IAE9C,gDAAgD;IAEhD,8EAA8E;IAE9E,8EAA8E;IAE9E,8EAA8E;WAnBpEA;MAqBX"}
22
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/discord/webhookEvents.ts"],"sourcesContent":["/** Types for: https://discord.com/developers/docs/events/webhook-events */\n\nimport type { DiscordApplicationIntegrationType } from './application.js'\nimport type { DiscordChannel } from './channel.js'\nimport type { DiscordEntitlement } from './entitlement.js'\nimport type { DiscordGuild } from './guild.js'\nimport type { DiscordMessage, MessageFlags, MessageTypes } from './message.js'\nimport type { OAuth2Scope } from './oauth2.js'\nimport type { DiscordUser } from './user.js'\n\n/** https://discord.com/developers/docs/events/webhook-events#payload-structure */\nexport interface DiscordEventWebhookEvent {\n  /** Version scheme for the webhook event. Currently always 1 */\n  version: 1\n  /** ID of your app */\n  application_id: string\n  /** Type of webhook, either 0 for PING or 1 for webhook events */\n  type: DiscordWebhookEventType\n  /** Event data payload */\n  event?: DiscordEventWebhookEventBody\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#webhook-types */\nexport enum DiscordEventWebhookType {\n  /** PING event sent to verify your Webhook Event URL is active */\n  Ping = 0,\n  /** Webhook event (details for event in event body object) */\n  Event = 1,\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#event-body-object */\nexport interface DiscordEventWebhookEventBody {\n  /** Event type */\n  type: DiscordWebhookEventType\n  /** Timestamp of when the event occurred in ISO8601 format */\n  timestamp: string\n  /** Data for the event. The shape depends on the event type */\n  data?:\n    | DiscordEventWebhookApplicationAuthorizedBody\n    | DiscordEventWebhookApplicationDeauthorizedBody\n    | DiscordEventWebhookEntitlementCreateBody\n    | DiscordEventWebhookEntitlementUpdateBody\n    | DiscordEventWebhookEntitlementDeleteBody\n    | DiscordEventWebhookLobbyMessageCreateBody\n    | DiscordEventWebhookLobbyMessageUpdateBody\n    | DiscordEventWebhookLobbyMessageDeleteBody\n    | DiscordEventWebhookGameDirectMessageCreateBody\n    | DiscordEventWebhookGameDirectMessageUpdateBody\n    | DiscordEventWebhookGameDirectMessageDeleteBody\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#event-types */\nexport enum DiscordWebhookEventType {\n  /** Sent when an app was authorized by a user to a server or their account */\n  ApplicationAuthorized = 'APPLICATION_AUTHORIZED',\n  /** Sent when an app was deauthorized by a user */\n  ApplicationDeauthorized = 'APPLICATION_DEAUTHORIZED',\n  /** Entitlement was created */\n  EntitlementCreate = 'ENTITLEMENT_CREATE',\n  /** Entitlement was updated */\n  EntitlementUpdate = 'ENTITLEMENT_UPDATE',\n  /** Entitlement was deleted */\n  EntitlementDelete = 'ENTITLEMENT_DELETE',\n  /** User was added to a Quest (currently unavailable) */\n  QuestUserEnrollment = 'QUEST_USER_ENROLLMENT',\n  /** Sent when a message is created in a lobby */\n  LobbyMessageCreate = 'LOBBY_MESSAGE_CREATE',\n  /** Sent when a message is updated in a lobby */\n  LobbyMessageUpdate = 'LOBBY_MESSAGE_UPDATE',\n  /** Sent when a message is deleted from a lobby */\n  LobbyMessageDelete = 'LOBBY_MESSAGE_DELETE',\n  /** Sent when a direct message is created during an active Social SDK session */\n  GameDirectMessageCreate = 'GAME_DIRECT_MESSAGE_CREATE',\n  /** Sent when a direct message is updated during an active Social SDK session */\n  GameDirectMessageUpdate = 'GAME_DIRECT_MESSAGE_UPDATE',\n  /** Sent when a direct message is deleted during an active Social SDK session */\n  GameDirectMessageDelete = 'GAME_DIRECT_MESSAGE_DELETE',\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#application-authorized-application-authorized-structure */\nexport interface DiscordEventWebhookApplicationAuthorizedBody {\n  /** Installation context for the authorization. Either guild (0) if installed to a server or user (1) if installed to a user's account */\n  integration_type?: DiscordApplicationIntegrationType\n  /** User who authorized the app */\n  user: DiscordUser\n  /** List of scopes the user authorized */\n  scopes: OAuth2Scope[]\n  /** Server which app was authorized for (when integration type is 0) */\n  guild?: DiscordGuild\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#application-authorized-application-authorized-structure */\nexport interface DiscordEventWebhookApplicationDeauthorizedBody {\n  /** User who deauthorized the app */\n  user: DiscordUser\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#entitlement-create-entitlement-create-structure */\nexport type DiscordEventWebhookEntitlementCreateBody = DiscordEntitlement\n\n/** https://discord.com/developers/docs/events/webhook-events#entitlement-update-entitlement-update-structure */\nexport type DiscordEventWebhookEntitlementUpdateBody = DiscordEntitlement\n\n/** https://discord.com/developers/docs/events/webhook-events#entitlement-delete-entitlement-delete-structure */\nexport type DiscordEventWebhookEntitlementDeleteBody = DiscordEntitlement\n\n/** https://discord.com/developers/docs/events/webhook-events#lobby-message-create-lobby-message-create-structure */\nexport type DiscordEventWebhookLobbyMessageCreateBody = DiscordSocialSDKLobbyMessage\n\n// Discord does not explicitly says what \"with additional fields for message updates\" means, so we rely on the example and the DiscordMessage structure\n/** https://discord.com/developers/docs/events/webhook-events#lobby-message-update-lobby-message-update-structure */\nexport interface DiscordEventWebhookLobbyMessageUpdateBody extends DiscordSocialSDKLobbyMessage {\n  /** ISO8601 timestamp of when the message was last edited */\n  edited_timestamp: string | null\n  /** ISO8601 timestamp of when the message was created */\n  timestamp: string\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#lobby-message-delete-lobby-message-delete-structure */\nexport interface DiscordEventWebhookLobbyMessageDeleteBody {\n  /** ID of the deleted message */\n  id: string\n  /** ID of the lobby where the message was deleted */\n  lobby_id: string\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#game-direct-message-create-game-direct-message-create-structure */\nexport type DiscordEventWebhookGameDirectMessageCreateBody = DiscordSocialSDKMessage | DiscordSocialSDKPassthroughMessage\n\n/** https://discord.com/developers/docs/events/webhook-events#game-direct-message-update-game-direct-message-update-structure */\nexport type DiscordEventWebhookGameDirectMessageUpdateBody = DiscordSocialSDKMessage | DiscordSocialSDKPassthroughMessage\n\n/** https://discord.com/developers/docs/events/webhook-events#game-direct-message-delete-game-direct-message-delete-structure */\nexport type DiscordEventWebhookGameDirectMessageDeleteBody = DiscordSocialSDKMessage | DiscordSocialSDKPassthroughMessage\n\n/** https://discord.com/developers/docs/events/webhook-events#lobby-message-object-lobby-message-structure */\nexport interface DiscordSocialSDKLobbyMessage {\n  /** ID of the message */\n  id: string\n  /** Type of message */\n  type: MessageTypes\n  /** Contents of the message */\n  content: string\n  /** ID of the lobby where the message was sent */\n  lobby_id: string\n  /** ID of the channel the message was sent in */\n  channel_id: string\n  /** Author of the message */\n  author: DiscordUser\n  /** Additional metadata for the message (key-value pairs) */\n  metadata?: Record<string, unknown>\n  /**\n   * Message flags combined as a bitfield\n   *\n   * @see {@link MessageFlags}\n   */\n  flags: number\n  /** ID of the application (only present during active Social SDK sessions) */\n  application_id?: string\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#message-object */\nexport interface DiscordSocialSDKMessage extends DiscordMessage {\n  /** ID of the lobby where the message was created (only present in Linked Channel messages) */\n  lobby_id?: string\n  /** Channel object with recipient information */\n  channel: DiscordChannel\n}\n\n/** https://discord.com/developers/docs/events/webhook-events#passthrough-message-object-passthrough-message-structure */\nexport interface DiscordSocialSDKPassthroughMessage {\n  /** ID of the message */\n  id: string\n  /** Type of message */\n  type: MessageTypes\n  /** Contents of the message */\n  content: string\n  /** ID of the channel the message was sent in */\n  channel_id: string\n  /** ID of the message recipient */\n  recipient_id: string\n  /** Author of the message */\n  author: DiscordUser\n  /** Message flags combined as a bitfield\n   *\n   * @see {@link MessageFlags}\n   */\n  flags: MessageFlags\n  /** ID of the application that created the message */\n  application_id: string\n  /** Channel object with recipient information */\n  channel: DiscordChannel\n}\n"],"names":["DiscordEventWebhookType","DiscordWebhookEventType"],"mappings":"AAAA,yEAAyE,GAsBzE,4EAA4E,GAC5E,OAAO,IAAA,AAAKA,iDAAAA;IACV,+DAA+D;IAE/D,2DAA2D;WAHjDA;MAKX;AAuBD,0EAA0E,GAC1E,OAAO,IAAA,AAAKC,iDAAAA;IACV,2EAA2E;IAE3E,gDAAgD;IAEhD,4BAA4B;IAE5B,4BAA4B;IAE5B,4BAA4B;IAE5B,sDAAsD;IAEtD,8CAA8C;IAE9C,8CAA8C;IAE9C,gDAAgD;IAEhD,8EAA8E;IAE9E,8EAA8E;IAE9E,8EAA8E;WAvBpEA;MAyBX"}
@@ -3,7 +3,7 @@ import type { ChannelTypes } from '../discord/channel.js';
3
3
  import type { ButtonStyles, DiscordMediaGalleryItem, DiscordUnfurledMediaItem, MessageComponentTypes, SeparatorSpacingSize, TextStyles } from '../discord/components.js';
4
4
  import type { BigString } from '../shared.js';
5
5
  export type MessageComponents = MessageComponent[];
6
- export type MessageComponent = ActionRow | ButtonComponent | TextInputComponent | StringSelectComponent | ChannelSelectComponent | RoleSelectComponent | UserSelectComponent | MentionableSelectComponent | SectionComponent | TextDisplayComponent | ThumbnailComponent | MediaGalleryComponent | SeparatorComponent | ContainerComponent | FileComponent | LabelComponent;
6
+ export type MessageComponent = ActionRow | ButtonComponent | TextInputComponent | StringSelectComponent | ChannelSelectComponent | RoleSelectComponent | UserSelectComponent | MentionableSelectComponent | SectionComponent | TextDisplayComponent | ThumbnailComponent | MediaGalleryComponent | SeparatorComponent | ContainerComponent | FileComponent | LabelComponent | FileUploadComponent;
7
7
  /** https://discord.com/developers/docs/components/reference#anatomy-of-a-component */
8
8
  export interface BaseComponent {
9
9
  /** The type of the component */
@@ -363,6 +363,31 @@ export interface LabelComponent extends BaseComponent {
363
363
  */
364
364
  description?: string;
365
365
  /** The component within the label */
366
- component: TextInputComponent | StringSelectComponent | UserSelectComponent | RoleSelectComponent | MentionableSelectComponent | ChannelSelectComponent;
366
+ component: TextInputComponent | StringSelectComponent | UserSelectComponent | RoleSelectComponent | MentionableSelectComponent | ChannelSelectComponent | FileUploadComponent;
367
+ }
368
+ /** https://discord.com/developers/docs/components/reference#file-upload-file-upload-structure */
369
+ export interface FileUploadComponent extends BaseComponent {
370
+ type: MessageComponentTypes.FileUpload;
371
+ /** The custom id for the file upload */
372
+ customId: string;
373
+ /**
374
+ * The minimum number of files that must be uploaded
375
+ *
376
+ * @remarks
377
+ * Between 0-10
378
+ */
379
+ minValues?: number;
380
+ /** The maximum number of files that can be uploaded
381
+ *
382
+ * @remarks
383
+ * Between 1-10
384
+ */
385
+ maxValues?: number;
386
+ /**
387
+ * Whether this component is required to be filled
388
+ *
389
+ * @default true
390
+ */
391
+ required?: boolean;
367
392
  }
368
393
  //# sourceMappingURL=components.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"components.d.ts","sourceRoot":"","sources":["../../src/discordeno/components.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"components.d.ts","sourceRoot":"","sources":["../../src/discordeno/components.ts"],"names":[],"mappings":"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"}
@@ -1,3 +1,3 @@
1
- /** Types for: https://discord.com/developers/docs/components/reference */ /** https://discord.com/developers/docs/components/reference#label-label-structure */ export { };
1
+ /** Types for: https://discord.com/developers/docs/components/reference */ /** https://discord.com/developers/docs/components/reference#file-upload-file-upload-structure */ export { };
2
2
 
3
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/discordeno/components.ts"],"sourcesContent":["/** Types for: https://discord.com/developers/docs/components/reference */\n\nimport type { ChannelTypes } from '../discord/channel.js'\nimport type {\n  ButtonStyles,\n  DiscordMediaGalleryItem,\n  DiscordUnfurledMediaItem,\n  MessageComponentTypes,\n  SeparatorSpacingSize,\n  TextStyles,\n} from '../discord/components.js'\nimport type { BigString } from '../shared.js'\n\nexport type MessageComponents = MessageComponent[]\nexport type MessageComponent =\n  | ActionRow\n  | ButtonComponent\n  | TextInputComponent\n  | StringSelectComponent\n  | ChannelSelectComponent\n  | RoleSelectComponent\n  | UserSelectComponent\n  | MentionableSelectComponent\n  | SectionComponent\n  | TextDisplayComponent\n  | ThumbnailComponent\n  | MediaGalleryComponent\n  | SeparatorComponent\n  | ContainerComponent\n  | FileComponent\n  | LabelComponent\n\n/** https://discord.com/developers/docs/components/reference#anatomy-of-a-component */\nexport interface BaseComponent {\n  /** The type of the component */\n  type: MessageComponentTypes\n  /** 32 bit integer used as an optional identifier for component */\n  id?: number\n}\n\n/** https://discord.com/developers/docs/components/reference#action-row-action-row-structure */\nexport interface ActionRow extends BaseComponent {\n  type: MessageComponentTypes.ActionRow\n\n  /**\n   * The components in this row\n   *\n   * @remarks\n   * Up to 5 button components, a single select component or a single text input component\n   *\n   * Using a {@link TextInputComponent} inside the Action Row is deprecated,\n   * use a {@link LabelComponent} for modals\n   */\n  components: (\n    | ButtonComponent\n    | StringSelectComponent\n    | UserSelectComponent\n    | RoleSelectComponent\n    | MentionableSelectComponent\n    | ChannelSelectComponent\n    | TextInputComponent\n  )[]\n}\n\n/** https://discord.com/developers/docs/components/reference#button-button-structure */\nexport interface ButtonComponent extends BaseComponent {\n  type: MessageComponentTypes.Button\n\n  /** For different styles/colors of the buttons */\n  style: ButtonStyles\n  /** for what the button says (max 80 characters) */\n  label?: string\n  /** Emoji object that includes fields of name, id, and animated supporting unicode and custom emojis. */\n  emoji?: {\n    /** Emoji id */\n    id?: BigString\n    /** Emoji name */\n    name?: string\n    /** Whether this emoji is animated */\n    animated?: boolean\n  }\n  /** a dev-defined unique string sent on click (max 100 characters). type 5 Link buttons can not have a custom_id */\n  customId?: string\n  /** Identifier for a purchasable SKU, only available when using premium-style buttons */\n  skuId?: BigString\n  /**\n   * optional url for link-style buttons that can navigate a user to the web.\n   *\n   * @remarks\n   * Only {@link ButtonStyles.Link | Link} buttons can have a url.\n   *\n   * Maximum 512 characters.\n   */\n  url?: string\n  /** Whether or not this button is disabled */\n  disabled?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#string-select-string-select-structure */\nexport interface StringSelectComponent extends BaseComponent {\n  type: MessageComponentTypes.StringSelect\n\n  /** A custom identifier for this component. Maximum 100 characters. */\n  customId: string\n  /** The choices! Maximum of 25 items. */\n  options: SelectOption[]\n  /** A custom placeholder text if nothing is selected. Maximum 150 characters. */\n  placeholder?: string\n  /** The minimum number of items that must be selected. Default 1. Between 0-25. */\n  minValues?: number\n  /** The maximum number of items that can be selected. Default 1. Max 25. */\n  maxValues?: number\n  /**\n   * Whether this component is required to be filled\n   *\n   * @remarks\n   * This value is only valid for string select menus in modals\n   *\n   * @default true\n   */\n  required?: boolean\n  /**\n   * Whether select menu is disabled\n   *\n   * @remarks\n   * This value cannot be set for select menus in modals\n   *\n   * @default false\n   */\n  disabled?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#string-select-select-option-structure */\nexport interface SelectOption {\n  /** The user-facing name of the option. Maximum 25 characters. */\n  label: string\n  /** The dev-defined value of the option. Maximum 100 characters. */\n  value: string\n  /** An additional description of the option. Maximum 50 characters. */\n  description?: string\n  // TODO: Make an alias for this type since it is used a few times\n  /** The id, name, and animated properties of an emoji. */\n  emoji?: {\n    /** Emoji id */\n    id?: BigString\n    /** Emoji name */\n    name?: string\n    /** Whether this emoji is animated */\n    animated?: boolean\n  }\n  /** Will render this option as already-selected by default. */\n  default?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#text-input-text-input-structure */\nexport interface TextInputComponent extends BaseComponent {\n  type: MessageComponentTypes.TextInput\n\n  /** The customId of the InputText */\n  customId: string\n  /** The style of the InputText */\n  style: TextStyles\n  /**\n   * The label of the InputText.\n   *\n   * @remarks\n   * Maximum 45 characters\n   *\n   * @deprecated Use the `label` and `description` from the {@link LabelComponent}\n   */\n  label?: string\n  /** The minimum length of the text the user has to provide */\n  minLength?: number\n  /** The maximum length of the text the user has to provide */\n  maxLength?: number\n  /** Whether or not this input is required. */\n  required?: boolean\n  /** Pre-filled value for input text. */\n  value?: string\n  /** The placeholder of the InputText */\n  placeholder?: string\n}\n\n/** https://discord.com/developers/docs/components/reference#user-select-user-select-structure */\nexport interface UserSelectComponent extends BaseComponent {\n  type: MessageComponentTypes.UserSelect\n\n  /** A custom identifier for this component. Maximum 100 characters. */\n  customId: string\n  /** A custom placeholder text if nothing is selected. Maximum 150 characters. */\n  placeholder?: string\n  /**\n   * List of default values for auto-populated select menu components\n   * The number of default values must be in the range defined by minValues and maxValues\n   */\n  defaultValues?: SelectMenuDefaultValue[]\n  /** The minimum number of items that must be selected. Default 1. Between 0-25. */\n  minValues?: number\n  /** The maximum number of items that can be selected. Default 1. Max 25. */\n  maxValues?: number\n  /**\n   * Whether this component is required to be filled\n   *\n   * @remarks\n   * This value is only valid for string select menus in modals\n   *\n   * @default true\n   */\n  required?: boolean\n  /**\n   * Whether select menu is disabled\n   *\n   * @remarks\n   * This value cannot be set for select menus in modals\n   *\n   * @default false\n   */\n  disabled?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#user-select-select-default-value-structure */\nexport interface SelectMenuDefaultValue {\n  /** ID of a user, role, or channel */\n  id: BigString\n  /** Type of value that id represents. */\n  type: 'user' | 'role' | 'channel'\n}\n\n/** https://discord.com/developers/docs/components/reference#role-select-role-select-structure */\nexport interface RoleSelectComponent extends BaseComponent {\n  type: MessageComponentTypes.RoleSelect\n\n  /** A custom identifier for this component. Maximum 100 characters. */\n  customId: string\n  /** A custom placeholder text if nothing is selected. Maximum 150 characters. */\n  placeholder?: string\n  /**\n   * List of default values for auto-populated select menu components\n   * The number of default values must be in the range defined by minValues and maxValues\n   */\n  defaultValues?: SelectMenuDefaultValue[]\n  /** The minimum number of items that must be selected. Default 1. Between 0-25. */\n  minValues?: number\n  /** The maximum number of items that can be selected. Default 1. Max 25. */\n  maxValues?: number\n  /**\n   * Whether this component is required to be filled\n   *\n   * @remarks\n   * This value is only valid for string select menus in modals\n   *\n   * @default true\n   */\n  required?: boolean\n  /**\n   * Whether select menu is disabled\n   *\n   * @remarks\n   * This value cannot be set for select menus in modals\n   *\n   * @default false\n   */\n  disabled?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#mentionable-select-mentionable-select-structure */\nexport interface MentionableSelectComponent extends BaseComponent {\n  type: MessageComponentTypes.MentionableSelect\n\n  /** A custom identifier for this component. Maximum 100 characters. */\n  customId: string\n  /** A custom placeholder text if nothing is selected. Maximum 150 characters. */\n  placeholder?: string\n  /**\n   * List of default values for auto-populated select menu components\n   * The number of default values must be in the range defined by minValues and maxValues\n   */\n  defaultValues?: SelectMenuDefaultValue[]\n  /** The minimum number of items that must be selected. Default 1. Between 0-25. */\n  minValues?: number\n  /** The maximum number of items that can be selected. Default 1. Max 25. */\n  maxValues?: number\n  /**\n   * Whether this component is required to be filled\n   *\n   * @remarks\n   * This value is only valid for string select menus in modals\n   *\n   * @default true\n   */\n  required?: boolean\n  /**\n   * Whether select menu is disabled\n   *\n   * @remarks\n   * This value cannot be set for select menus in modals\n   *\n   * @default false\n   */\n  disabled?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#channel-select-channel-select-structure */\nexport interface ChannelSelectComponent extends BaseComponent {\n  type: MessageComponentTypes.ChannelSelect\n\n  /** A custom identifier for this component. Maximum 100 characters. */\n  customId: string\n  /** List of channel types to include in the options list */\n  channelTypes?: ChannelTypes[]\n  /** A custom placeholder text if nothing is selected. Maximum 150 characters. */\n  placeholder?: string\n  /**\n   * List of default values for auto-populated select menu components\n   * The number of default values must be in the range defined by minValues and maxValues\n   */\n  defaultValues?: SelectMenuDefaultValue[]\n  /** The minimum number of items that must be selected. Default 1. Between 0-25. */\n  minValues?: number\n  /** The maximum number of items that can be selected. Default 1. Max 25. */\n  maxValues?: number\n  /**\n   * Whether this component is required to be filled\n   *\n   * @remarks\n   * This value is only valid for string select menus in modals\n   *\n   * @default true\n   */\n  required?: boolean\n  /**\n   * Whether select menu is disabled\n   *\n   * @remarks\n   * This value cannot be set for select menus in modals\n   *\n   * @default false\n   */\n  disabled?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#section-section-structure */\nexport interface SectionComponent extends BaseComponent {\n  type: MessageComponentTypes.Section\n\n  /** One to three text components */\n  components: TextDisplayComponent[]\n  /** A thumbnail or a button component, with a future possibility of adding more compatible components */\n  accessory: ButtonComponent | ThumbnailComponent\n}\n\n/** https://discord.com/developers/docs/components/reference#text-display */\nexport interface TextDisplayComponent extends BaseComponent {\n  type: MessageComponentTypes.TextDisplay\n\n  /** Text that will be displayed similar to a message */\n  content: string\n}\n\n/** https://discord.com/developers/docs/components/reference#thumbnail */\nexport interface ThumbnailComponent extends BaseComponent {\n  type: MessageComponentTypes.Thumbnail\n\n  /** A url or attachment */\n  media: DiscordUnfurledMediaItem\n  /** Alt text for the media */\n  description?: string\n  /** Whether the thumbnail should be a spoiler (or blurred out). Defaults to `false` */\n  spoiler?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#media-gallery */\nexport interface MediaGalleryComponent extends BaseComponent {\n  type: MessageComponentTypes.MediaGallery\n\n  /** 1 to 10 media gallery items */\n  items: DiscordMediaGalleryItem[]\n}\n\n/** https://discord.com/developers/docs/components/reference#file */\nexport interface FileComponent extends BaseComponent {\n  type: MessageComponentTypes.File\n\n  /** This unfurled media item is unique in that it only supports attachment references using the attachment://<filename> syntax */\n  file: DiscordUnfurledMediaItem\n  /** Whether the media should be a spoiler (or blurred out). Defaults to `false` */\n  spoiler?: boolean\n  /** The name of the file. This field is ignored and provided by the API as part of the response */\n  name: string\n  /** The size of the file in bytes. This field is ignored and provided by the API as part of the response */\n  size: number\n}\n\n/** https://discord.com/developers/docs/components/reference#separator */\nexport interface SeparatorComponent extends BaseComponent {\n  type: MessageComponentTypes.Separator\n\n  /** Whether a visual divider should be displayed in the component. Defaults to `true` */\n  divider?: boolean\n  /** Size of separator padding — `1` for small padding, `2` for large padding. Defaults to `1` */\n  spacing?: SeparatorSpacingSize\n}\n\n/** https://discord.com/developers/docs/components/reference#container */\nexport interface ContainerComponent extends BaseComponent {\n  type: MessageComponentTypes.Container\n\n  /** Components of the type action row, text display, section, media gallery, separator, or file */\n  components: Array<ActionRow | TextDisplayComponent | SectionComponent | MediaGalleryComponent | SeparatorComponent | FileComponent>\n  /** Color for the accent on the container as RGB from 0x000000 to 0xFFFFFF */\n  accentColor?: number | null\n  /** Whether the container should be a spoiler (or blurred out). Defaults to `false` */\n  spoiler?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#label-label-structure */\nexport interface LabelComponent extends BaseComponent {\n  type: MessageComponentTypes.Label\n\n  /**\n   * The label text\n   *\n   * @remarks\n   * Max 45 characters.\n   */\n  label: string\n  /**\n   * An optional description text for the label\n   *\n   * @remarks\n   * Max 100 characters.\n   */\n  description?: string\n  /** The component within the label */\n  component:\n    | TextInputComponent\n    | StringSelectComponent\n    | UserSelectComponent\n    | RoleSelectComponent\n    | MentionableSelectComponent\n    | ChannelSelectComponent\n}\n"],"names":[],"mappings":"AAAA,wEAAwE,GA+ZxE,mFAAmF,GACnF,WAyBC"}
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/discordeno/components.ts"],"sourcesContent":["/** Types for: https://discord.com/developers/docs/components/reference */\n\nimport type { ChannelTypes } from '../discord/channel.js'\nimport type {\n  ButtonStyles,\n  DiscordMediaGalleryItem,\n  DiscordUnfurledMediaItem,\n  MessageComponentTypes,\n  SeparatorSpacingSize,\n  TextStyles,\n} from '../discord/components.js'\nimport type { BigString } from '../shared.js'\n\nexport type MessageComponents = MessageComponent[]\nexport type MessageComponent =\n  | ActionRow\n  | ButtonComponent\n  | TextInputComponent\n  | StringSelectComponent\n  | ChannelSelectComponent\n  | RoleSelectComponent\n  | UserSelectComponent\n  | MentionableSelectComponent\n  | SectionComponent\n  | TextDisplayComponent\n  | ThumbnailComponent\n  | MediaGalleryComponent\n  | SeparatorComponent\n  | ContainerComponent\n  | FileComponent\n  | LabelComponent\n  | FileUploadComponent\n\n/** https://discord.com/developers/docs/components/reference#anatomy-of-a-component */\nexport interface BaseComponent {\n  /** The type of the component */\n  type: MessageComponentTypes\n  /** 32 bit integer used as an optional identifier for component */\n  id?: number\n}\n\n/** https://discord.com/developers/docs/components/reference#action-row-action-row-structure */\nexport interface ActionRow extends BaseComponent {\n  type: MessageComponentTypes.ActionRow\n\n  /**\n   * The components in this row\n   *\n   * @remarks\n   * Up to 5 button components, a single select component or a single text input component\n   *\n   * Using a {@link TextInputComponent} inside the Action Row is deprecated,\n   * use a {@link LabelComponent} for modals\n   */\n  components: (\n    | ButtonComponent\n    | StringSelectComponent\n    | UserSelectComponent\n    | RoleSelectComponent\n    | MentionableSelectComponent\n    | ChannelSelectComponent\n    | TextInputComponent\n  )[]\n}\n\n/** https://discord.com/developers/docs/components/reference#button-button-structure */\nexport interface ButtonComponent extends BaseComponent {\n  type: MessageComponentTypes.Button\n\n  /** For different styles/colors of the buttons */\n  style: ButtonStyles\n  /** for what the button says (max 80 characters) */\n  label?: string\n  /** Emoji object that includes fields of name, id, and animated supporting unicode and custom emojis. */\n  emoji?: {\n    /** Emoji id */\n    id?: BigString\n    /** Emoji name */\n    name?: string\n    /** Whether this emoji is animated */\n    animated?: boolean\n  }\n  /** a dev-defined unique string sent on click (max 100 characters). type 5 Link buttons can not have a custom_id */\n  customId?: string\n  /** Identifier for a purchasable SKU, only available when using premium-style buttons */\n  skuId?: BigString\n  /**\n   * optional url for link-style buttons that can navigate a user to the web.\n   *\n   * @remarks\n   * Only {@link ButtonStyles.Link | Link} buttons can have a url.\n   *\n   * Maximum 512 characters.\n   */\n  url?: string\n  /** Whether or not this button is disabled */\n  disabled?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#string-select-string-select-structure */\nexport interface StringSelectComponent extends BaseComponent {\n  type: MessageComponentTypes.StringSelect\n\n  /** A custom identifier for this component. Maximum 100 characters. */\n  customId: string\n  /** The choices! Maximum of 25 items. */\n  options: SelectOption[]\n  /** A custom placeholder text if nothing is selected. Maximum 150 characters. */\n  placeholder?: string\n  /** The minimum number of items that must be selected. Default 1. Between 0-25. */\n  minValues?: number\n  /** The maximum number of items that can be selected. Default 1. Max 25. */\n  maxValues?: number\n  /**\n   * Whether this component is required to be filled\n   *\n   * @remarks\n   * This value is only valid for string select menus in modals\n   *\n   * @default true\n   */\n  required?: boolean\n  /**\n   * Whether select menu is disabled\n   *\n   * @remarks\n   * This value cannot be set for select menus in modals\n   *\n   * @default false\n   */\n  disabled?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#string-select-select-option-structure */\nexport interface SelectOption {\n  /** The user-facing name of the option. Maximum 25 characters. */\n  label: string\n  /** The dev-defined value of the option. Maximum 100 characters. */\n  value: string\n  /** An additional description of the option. Maximum 50 characters. */\n  description?: string\n  // TODO: Make an alias for this type since it is used a few times\n  /** The id, name, and animated properties of an emoji. */\n  emoji?: {\n    /** Emoji id */\n    id?: BigString\n    /** Emoji name */\n    name?: string\n    /** Whether this emoji is animated */\n    animated?: boolean\n  }\n  /** Will render this option as already-selected by default. */\n  default?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#text-input-text-input-structure */\nexport interface TextInputComponent extends BaseComponent {\n  type: MessageComponentTypes.TextInput\n\n  /** The customId of the InputText */\n  customId: string\n  /** The style of the InputText */\n  style: TextStyles\n  /**\n   * The label of the InputText.\n   *\n   * @remarks\n   * Maximum 45 characters\n   *\n   * @deprecated Use the `label` and `description` from the {@link LabelComponent}\n   */\n  label?: string\n  /** The minimum length of the text the user has to provide */\n  minLength?: number\n  /** The maximum length of the text the user has to provide */\n  maxLength?: number\n  /** Whether or not this input is required. */\n  required?: boolean\n  /** Pre-filled value for input text. */\n  value?: string\n  /** The placeholder of the InputText */\n  placeholder?: string\n}\n\n/** https://discord.com/developers/docs/components/reference#user-select-user-select-structure */\nexport interface UserSelectComponent extends BaseComponent {\n  type: MessageComponentTypes.UserSelect\n\n  /** A custom identifier for this component. Maximum 100 characters. */\n  customId: string\n  /** A custom placeholder text if nothing is selected. Maximum 150 characters. */\n  placeholder?: string\n  /**\n   * List of default values for auto-populated select menu components\n   * The number of default values must be in the range defined by minValues and maxValues\n   */\n  defaultValues?: SelectMenuDefaultValue[]\n  /** The minimum number of items that must be selected. Default 1. Between 0-25. */\n  minValues?: number\n  /** The maximum number of items that can be selected. Default 1. Max 25. */\n  maxValues?: number\n  /**\n   * Whether this component is required to be filled\n   *\n   * @remarks\n   * This value is only valid for string select menus in modals\n   *\n   * @default true\n   */\n  required?: boolean\n  /**\n   * Whether select menu is disabled\n   *\n   * @remarks\n   * This value cannot be set for select menus in modals\n   *\n   * @default false\n   */\n  disabled?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#user-select-select-default-value-structure */\nexport interface SelectMenuDefaultValue {\n  /** ID of a user, role, or channel */\n  id: BigString\n  /** Type of value that id represents. */\n  type: 'user' | 'role' | 'channel'\n}\n\n/** https://discord.com/developers/docs/components/reference#role-select-role-select-structure */\nexport interface RoleSelectComponent extends BaseComponent {\n  type: MessageComponentTypes.RoleSelect\n\n  /** A custom identifier for this component. Maximum 100 characters. */\n  customId: string\n  /** A custom placeholder text if nothing is selected. Maximum 150 characters. */\n  placeholder?: string\n  /**\n   * List of default values for auto-populated select menu components\n   * The number of default values must be in the range defined by minValues and maxValues\n   */\n  defaultValues?: SelectMenuDefaultValue[]\n  /** The minimum number of items that must be selected. Default 1. Between 0-25. */\n  minValues?: number\n  /** The maximum number of items that can be selected. Default 1. Max 25. */\n  maxValues?: number\n  /**\n   * Whether this component is required to be filled\n   *\n   * @remarks\n   * This value is only valid for string select menus in modals\n   *\n   * @default true\n   */\n  required?: boolean\n  /**\n   * Whether select menu is disabled\n   *\n   * @remarks\n   * This value cannot be set for select menus in modals\n   *\n   * @default false\n   */\n  disabled?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#mentionable-select-mentionable-select-structure */\nexport interface MentionableSelectComponent extends BaseComponent {\n  type: MessageComponentTypes.MentionableSelect\n\n  /** A custom identifier for this component. Maximum 100 characters. */\n  customId: string\n  /** A custom placeholder text if nothing is selected. Maximum 150 characters. */\n  placeholder?: string\n  /**\n   * List of default values for auto-populated select menu components\n   * The number of default values must be in the range defined by minValues and maxValues\n   */\n  defaultValues?: SelectMenuDefaultValue[]\n  /** The minimum number of items that must be selected. Default 1. Between 0-25. */\n  minValues?: number\n  /** The maximum number of items that can be selected. Default 1. Max 25. */\n  maxValues?: number\n  /**\n   * Whether this component is required to be filled\n   *\n   * @remarks\n   * This value is only valid for string select menus in modals\n   *\n   * @default true\n   */\n  required?: boolean\n  /**\n   * Whether select menu is disabled\n   *\n   * @remarks\n   * This value cannot be set for select menus in modals\n   *\n   * @default false\n   */\n  disabled?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#channel-select-channel-select-structure */\nexport interface ChannelSelectComponent extends BaseComponent {\n  type: MessageComponentTypes.ChannelSelect\n\n  /** A custom identifier for this component. Maximum 100 characters. */\n  customId: string\n  /** List of channel types to include in the options list */\n  channelTypes?: ChannelTypes[]\n  /** A custom placeholder text if nothing is selected. Maximum 150 characters. */\n  placeholder?: string\n  /**\n   * List of default values for auto-populated select menu components\n   * The number of default values must be in the range defined by minValues and maxValues\n   */\n  defaultValues?: SelectMenuDefaultValue[]\n  /** The minimum number of items that must be selected. Default 1. Between 0-25. */\n  minValues?: number\n  /** The maximum number of items that can be selected. Default 1. Max 25. */\n  maxValues?: number\n  /**\n   * Whether this component is required to be filled\n   *\n   * @remarks\n   * This value is only valid for string select menus in modals\n   *\n   * @default true\n   */\n  required?: boolean\n  /**\n   * Whether select menu is disabled\n   *\n   * @remarks\n   * This value cannot be set for select menus in modals\n   *\n   * @default false\n   */\n  disabled?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#section-section-structure */\nexport interface SectionComponent extends BaseComponent {\n  type: MessageComponentTypes.Section\n\n  /** One to three text components */\n  components: TextDisplayComponent[]\n  /** A thumbnail or a button component, with a future possibility of adding more compatible components */\n  accessory: ButtonComponent | ThumbnailComponent\n}\n\n/** https://discord.com/developers/docs/components/reference#text-display */\nexport interface TextDisplayComponent extends BaseComponent {\n  type: MessageComponentTypes.TextDisplay\n\n  /** Text that will be displayed similar to a message */\n  content: string\n}\n\n/** https://discord.com/developers/docs/components/reference#thumbnail */\nexport interface ThumbnailComponent extends BaseComponent {\n  type: MessageComponentTypes.Thumbnail\n\n  /** A url or attachment */\n  media: DiscordUnfurledMediaItem\n  /** Alt text for the media */\n  description?: string\n  /** Whether the thumbnail should be a spoiler (or blurred out). Defaults to `false` */\n  spoiler?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#media-gallery */\nexport interface MediaGalleryComponent extends BaseComponent {\n  type: MessageComponentTypes.MediaGallery\n\n  /** 1 to 10 media gallery items */\n  items: DiscordMediaGalleryItem[]\n}\n\n/** https://discord.com/developers/docs/components/reference#file */\nexport interface FileComponent extends BaseComponent {\n  type: MessageComponentTypes.File\n\n  /** This unfurled media item is unique in that it only supports attachment references using the attachment://<filename> syntax */\n  file: DiscordUnfurledMediaItem\n  /** Whether the media should be a spoiler (or blurred out). Defaults to `false` */\n  spoiler?: boolean\n  /** The name of the file. This field is ignored and provided by the API as part of the response */\n  name: string\n  /** The size of the file in bytes. This field is ignored and provided by the API as part of the response */\n  size: number\n}\n\n/** https://discord.com/developers/docs/components/reference#separator */\nexport interface SeparatorComponent extends BaseComponent {\n  type: MessageComponentTypes.Separator\n\n  /** Whether a visual divider should be displayed in the component. Defaults to `true` */\n  divider?: boolean\n  /** Size of separator padding — `1` for small padding, `2` for large padding. Defaults to `1` */\n  spacing?: SeparatorSpacingSize\n}\n\n/** https://discord.com/developers/docs/components/reference#container */\nexport interface ContainerComponent extends BaseComponent {\n  type: MessageComponentTypes.Container\n\n  /** Components of the type action row, text display, section, media gallery, separator, or file */\n  components: Array<ActionRow | TextDisplayComponent | SectionComponent | MediaGalleryComponent | SeparatorComponent | FileComponent>\n  /** Color for the accent on the container as RGB from 0x000000 to 0xFFFFFF */\n  accentColor?: number | null\n  /** Whether the container should be a spoiler (or blurred out). Defaults to `false` */\n  spoiler?: boolean\n}\n\n/** https://discord.com/developers/docs/components/reference#label-label-structure */\nexport interface LabelComponent extends BaseComponent {\n  type: MessageComponentTypes.Label\n\n  /**\n   * The label text\n   *\n   * @remarks\n   * Max 45 characters.\n   */\n  label: string\n  /**\n   * An optional description text for the label\n   *\n   * @remarks\n   * Max 100 characters.\n   */\n  description?: string\n  /** The component within the label */\n  component:\n    | TextInputComponent\n    | StringSelectComponent\n    | UserSelectComponent\n    | RoleSelectComponent\n    | MentionableSelectComponent\n    | ChannelSelectComponent\n    | FileUploadComponent\n}\n\n/** https://discord.com/developers/docs/components/reference#file-upload-file-upload-structure */\nexport interface FileUploadComponent extends BaseComponent {\n  type: MessageComponentTypes.FileUpload\n\n  /** The custom id for the file upload */\n  customId: string\n  /**\n   * The minimum number of files that must be uploaded\n   *\n   * @remarks\n   * Between 0-10\n   */\n  minValues?: number\n  /** The maximum number of files that can be uploaded\n   *\n   * @remarks\n   * Between 1-10\n   */\n  maxValues?: number\n  /**\n   * Whether this component is required to be filled\n   *\n   * @default true\n   */\n  required?: boolean\n}\n"],"names":[],"mappings":"AAAA,wEAAwE,GA6bxE,+FAA+F,GAC/F,WAwBC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@discordeno/types",
3
- "version": "22.0.1-next.bd4e6f1",
3
+ "version": "22.0.1-next.bd98b3e",
4
4
  "exports": "./dist/index.js",
5
5
  "type": "module",
6
6
  "license": "Apache-2.0",
@@ -17,21 +17,20 @@
17
17
  "build:type": "tsc --declaration --emitDeclarationOnly --declarationDir dist",
18
18
  "release-build": "yarn build && yarn build:type",
19
19
  "check": "biome check --write",
20
- "test:unit-coverage": "c8 mocha --no-warnings 'tests/**/*.spec.ts'",
21
- "test:unit": "c8 --r lcov mocha --no-warnings 'tests/**/*.spec.ts' && node ../../scripts/coveragePathFixing.js utils",
22
- "test:unit:watch": "mocha --no-warnings --watch --parallel 'tests/**/*.spec.ts'",
23
- "test:deno-unit": "deno -A ../../node_modules/mocha/bin/mocha.js --config ../../.mocharc.base.cjs 'tests/**/*.spec.ts'",
24
- "test:bun-unit": "bun ../../node_modules/mocha/bin/mocha.js --config ../../.mocharc.base.cjs 'tests/**/*.spec.ts'",
20
+ "test:unit": "c8 -r lcov mocha 'tests/**/*.spec.ts' && node ../../scripts/coveragePathFixing.js types",
21
+ "test:deno-unit": "deno -A npm:mocha 'tests/**/*.spec.ts'",
22
+ "test:bun-unit": "bun --bun mocha 'tests/**/*.spec.ts'",
23
+ "test:test-type": "tsc --project tests/tsconfig.json",
25
24
  "test:type": "tsc --noEmit"
26
25
  },
27
26
  "devDependencies": {
28
- "@biomejs/biome": "2.3.1",
29
- "@swc/cli": "^0.7.8",
30
- "@swc/core": "^1.13.5",
27
+ "@biomejs/biome": "2.3.11",
28
+ "@swc/cli": "^0.7.9",
29
+ "@swc/core": "^1.15.8",
31
30
  "@types/mocha": "^10.0.10",
32
- "@types/node": "^24.9.1",
31
+ "@types/node": "^25.0.3",
33
32
  "c8": "^10.1.3",
34
- "mocha": "^11.7.4",
33
+ "mocha": "^11.7.5",
35
34
  "ts-node": "^10.9.2",
36
35
  "tsconfig": "*",
37
36
  "typescript": "^5.9.3"