@jubbio/core 1.3.1 → 1.3.2

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.
Files changed (121) hide show
  1. package/dist/cjs/Client.d.ts +157 -0
  2. package/dist/cjs/Client.js +640 -0
  3. package/dist/cjs/builders/ActionRowBuilder.d.ts +53 -0
  4. package/dist/cjs/builders/ActionRowBuilder.js +68 -0
  5. package/dist/cjs/builders/ButtonBuilder.d.ts +77 -0
  6. package/dist/cjs/builders/ButtonBuilder.js +96 -0
  7. package/dist/cjs/builders/EmbedBuilder.d.ts +157 -0
  8. package/dist/cjs/builders/EmbedBuilder.js +208 -0
  9. package/dist/cjs/builders/ModalBuilder.d.ts +122 -0
  10. package/dist/cjs/builders/ModalBuilder.js +162 -0
  11. package/dist/cjs/builders/SelectMenuBuilder.d.ts +123 -0
  12. package/dist/cjs/builders/SelectMenuBuilder.js +165 -0
  13. package/dist/cjs/builders/SlashCommandBuilder.d.ts +197 -0
  14. package/dist/cjs/builders/SlashCommandBuilder.js +324 -0
  15. package/dist/cjs/builders/index.d.ts +9 -0
  16. package/dist/cjs/builders/index.js +26 -0
  17. package/dist/cjs/enums.d.ts +191 -0
  18. package/dist/cjs/enums.js +211 -0
  19. package/dist/cjs/index.d.ts +25 -0
  20. package/dist/cjs/index.js +130 -0
  21. package/dist/cjs/managers/BaseManager.d.ts +69 -0
  22. package/dist/cjs/managers/BaseManager.js +106 -0
  23. package/dist/cjs/managers/ChannelManager.d.ts +95 -0
  24. package/dist/cjs/managers/ChannelManager.js +205 -0
  25. package/dist/cjs/managers/GuildMemberManager.d.ts +74 -0
  26. package/dist/cjs/managers/GuildMemberManager.js +157 -0
  27. package/dist/cjs/managers/RoleManager.d.ts +84 -0
  28. package/dist/cjs/managers/RoleManager.js +207 -0
  29. package/dist/cjs/managers/index.d.ts +7 -0
  30. package/dist/cjs/managers/index.js +24 -0
  31. package/dist/cjs/rest/REST.d.ts +527 -0
  32. package/dist/cjs/rest/REST.js +904 -0
  33. package/dist/cjs/rest/index.d.ts +1 -0
  34. package/dist/cjs/rest/index.js +18 -0
  35. package/dist/cjs/sharding/ShardingManager.d.ts +179 -0
  36. package/dist/cjs/sharding/ShardingManager.js +375 -0
  37. package/dist/cjs/sharding/index.d.ts +4 -0
  38. package/dist/cjs/sharding/index.js +21 -0
  39. package/dist/cjs/structures/Channel.d.ts +122 -0
  40. package/dist/cjs/structures/Channel.js +240 -0
  41. package/dist/cjs/structures/Collection.d.ts +53 -0
  42. package/dist/cjs/structures/Collection.js +115 -0
  43. package/dist/cjs/structures/Guild.d.ts +59 -0
  44. package/dist/cjs/structures/Guild.js +94 -0
  45. package/dist/cjs/structures/GuildMember.d.ts +174 -0
  46. package/dist/cjs/structures/GuildMember.js +311 -0
  47. package/dist/cjs/structures/Interaction.d.ts +245 -0
  48. package/dist/cjs/structures/Interaction.js +450 -0
  49. package/dist/cjs/structures/Message.d.ts +98 -0
  50. package/dist/cjs/structures/Message.js +195 -0
  51. package/dist/cjs/structures/User.d.ts +37 -0
  52. package/dist/cjs/structures/User.js +65 -0
  53. package/dist/cjs/structures/index.d.ts +7 -0
  54. package/dist/cjs/structures/index.js +25 -0
  55. package/dist/cjs/structures.d.ts +1 -0
  56. package/dist/cjs/structures.js +19 -0
  57. package/dist/cjs/types.d.ts +255 -0
  58. package/dist/cjs/types.js +3 -0
  59. package/dist/cjs/utils/BitField.d.ts +66 -0
  60. package/dist/cjs/utils/BitField.js +138 -0
  61. package/dist/cjs/utils/Collection.d.ts +116 -0
  62. package/dist/cjs/utils/Collection.js +265 -0
  63. package/dist/cjs/utils/Collector.d.ts +152 -0
  64. package/dist/cjs/utils/Collector.js +314 -0
  65. package/dist/cjs/utils/DataResolver.d.ts +61 -0
  66. package/dist/cjs/utils/DataResolver.js +146 -0
  67. package/dist/cjs/utils/Formatters.d.ts +145 -0
  68. package/dist/cjs/utils/Formatters.js +213 -0
  69. package/dist/cjs/utils/IntentsBitField.d.ts +85 -0
  70. package/dist/cjs/utils/IntentsBitField.js +99 -0
  71. package/dist/cjs/utils/Partials.d.ts +104 -0
  72. package/dist/cjs/utils/Partials.js +148 -0
  73. package/dist/cjs/utils/PermissionsBitField.d.ts +118 -0
  74. package/dist/cjs/utils/PermissionsBitField.js +145 -0
  75. package/dist/cjs/utils/SnowflakeUtil.d.ts +63 -0
  76. package/dist/cjs/utils/SnowflakeUtil.js +93 -0
  77. package/dist/cjs/utils/Sweepers.d.ts +119 -0
  78. package/dist/cjs/utils/Sweepers.js +249 -0
  79. package/dist/cjs/utils/index.d.ts +13 -0
  80. package/dist/cjs/utils/index.js +30 -0
  81. package/dist/esm/Client.js +634 -0
  82. package/dist/esm/builders/ActionRowBuilder.js +64 -0
  83. package/dist/esm/builders/ButtonBuilder.js +92 -0
  84. package/dist/esm/builders/EmbedBuilder.js +204 -0
  85. package/dist/esm/builders/ModalBuilder.js +157 -0
  86. package/dist/esm/builders/SelectMenuBuilder.js +161 -0
  87. package/dist/esm/builders/SlashCommandBuilder.js +311 -0
  88. package/dist/esm/builders/index.js +10 -0
  89. package/dist/esm/enums.js +208 -0
  90. package/dist/esm/index.js +34 -0
  91. package/dist/esm/managers/BaseManager.js +100 -0
  92. package/dist/esm/managers/ChannelManager.js +200 -0
  93. package/dist/esm/managers/GuildMemberManager.js +153 -0
  94. package/dist/esm/managers/RoleManager.js +203 -0
  95. package/dist/esm/managers/index.js +8 -0
  96. package/dist/esm/rest/REST.js +900 -0
  97. package/dist/esm/rest/index.js +2 -0
  98. package/dist/esm/sharding/ShardingManager.js +366 -0
  99. package/dist/esm/sharding/index.js +5 -0
  100. package/dist/esm/structures/Channel.js +232 -0
  101. package/dist/esm/structures/Collection.js +111 -0
  102. package/dist/esm/structures/Guild.js +90 -0
  103. package/dist/esm/structures/GuildMember.js +306 -0
  104. package/dist/esm/structures/Interaction.js +438 -0
  105. package/dist/esm/structures/Message.js +191 -0
  106. package/dist/esm/structures/User.js +61 -0
  107. package/dist/esm/structures/index.js +9 -0
  108. package/dist/esm/structures.js +3 -0
  109. package/dist/esm/types.js +2 -0
  110. package/dist/esm/utils/BitField.js +134 -0
  111. package/dist/esm/utils/Collection.js +261 -0
  112. package/dist/esm/utils/Collector.js +305 -0
  113. package/dist/esm/utils/DataResolver.js +142 -0
  114. package/dist/esm/utils/Formatters.js +191 -0
  115. package/dist/esm/utils/IntentsBitField.js +93 -0
  116. package/dist/esm/utils/Partials.js +137 -0
  117. package/dist/esm/utils/PermissionsBitField.js +141 -0
  118. package/dist/esm/utils/SnowflakeUtil.js +89 -0
  119. package/dist/esm/utils/Sweepers.js +245 -0
  120. package/dist/esm/utils/index.js +14 -0
  121. package/package.json +14 -4
@@ -0,0 +1,142 @@
1
+ /**
2
+ * Data resolver utilities for handling various data types
3
+ */
4
+ import { readFile } from 'fs/promises';
5
+ import { basename } from 'path';
6
+ /**
7
+ * Resolves various data types to usable formats
8
+ */
9
+ export class DataResolver {
10
+ /**
11
+ * Resolves a BufferResolvable to a Buffer
12
+ * @param resource The resource to resolve
13
+ */
14
+ static async resolveBuffer(resource) {
15
+ if (Buffer.isBuffer(resource))
16
+ return resource;
17
+ if (typeof resource === 'string') {
18
+ // Check if it's a file path
19
+ if (resource.startsWith('/') || resource.startsWith('./') || resource.startsWith('../') || /^[a-zA-Z]:/.test(resource)) {
20
+ return readFile(resource);
21
+ }
22
+ // Check if it's a URL
23
+ if (resource.startsWith('http://') || resource.startsWith('https://')) {
24
+ const response = await fetch(resource);
25
+ const arrayBuffer = await response.arrayBuffer();
26
+ return Buffer.from(arrayBuffer);
27
+ }
28
+ // Check if it's base64
29
+ if (resource.startsWith('data:')) {
30
+ const base64Data = resource.split(',')[1];
31
+ return Buffer.from(base64Data, 'base64');
32
+ }
33
+ // Assume it's a file path
34
+ return readFile(resource);
35
+ }
36
+ throw new TypeError('Invalid resource type');
37
+ }
38
+ /**
39
+ * Resolves a Base64Resolvable to a base64 string
40
+ * @param resource The resource to resolve
41
+ * @param mimeType The MIME type for the data URI
42
+ */
43
+ static async resolveBase64(resource, mimeType = 'image/png') {
44
+ const buffer = await this.resolveBuffer(resource);
45
+ return `data:${mimeType};base64,${buffer.toString('base64')}`;
46
+ }
47
+ /**
48
+ * Resolves a file to a name and buffer
49
+ * @param resource The file resource
50
+ */
51
+ static async resolveFile(resource) {
52
+ if (typeof resource === 'object' && 'attachment' in resource) {
53
+ const buffer = await this.resolveBuffer(resource.attachment);
54
+ const name = resource.name ?? 'file';
55
+ return { name, data: buffer };
56
+ }
57
+ const buffer = await this.resolveBuffer(resource);
58
+ const name = typeof resource === 'string' ? basename(resource) : 'file';
59
+ return { name, data: buffer };
60
+ }
61
+ /**
62
+ * Resolves multiple files
63
+ * @param resources The file resources
64
+ */
65
+ static async resolveFiles(resources) {
66
+ return Promise.all(resources.map(r => this.resolveFile(r)));
67
+ }
68
+ /**
69
+ * Resolves a color to a number
70
+ * @param color The color to resolve
71
+ */
72
+ static resolveColor(color) {
73
+ if (color === null)
74
+ return null;
75
+ if (typeof color === 'number') {
76
+ if (color < 0 || color > 0xFFFFFF)
77
+ throw new RangeError('Color must be between 0 and 16777215');
78
+ return color;
79
+ }
80
+ if (typeof color === 'string') {
81
+ if (color.startsWith('#')) {
82
+ return parseInt(color.slice(1), 16);
83
+ }
84
+ // Named colors
85
+ const namedColors = {
86
+ default: 0x000000,
87
+ white: 0xFFFFFF,
88
+ aqua: 0x1ABC9C,
89
+ green: 0x57F287,
90
+ blue: 0x3498DB,
91
+ yellow: 0xFEE75C,
92
+ purple: 0x9B59B6,
93
+ fuchsia: 0xEB459E,
94
+ gold: 0xF1C40F,
95
+ orange: 0xE67E22,
96
+ red: 0xED4245,
97
+ grey: 0x95A5A6,
98
+ navy: 0x34495E,
99
+ blurple: 0x5865F2,
100
+ };
101
+ const lower = color.toLowerCase();
102
+ if (lower in namedColors)
103
+ return namedColors[lower];
104
+ return parseInt(color, 16);
105
+ }
106
+ if (Array.isArray(color)) {
107
+ return (color[0] << 16) + (color[1] << 8) + color[2];
108
+ }
109
+ throw new TypeError('Invalid color type');
110
+ }
111
+ /**
112
+ * Resolves a string to a snowflake ID
113
+ * @param value The value to resolve
114
+ */
115
+ static resolveSnowflake(value) {
116
+ if (typeof value === 'object' && 'id' in value) {
117
+ return String(value.id);
118
+ }
119
+ return String(value);
120
+ }
121
+ /**
122
+ * Resolves an image to a base64 data URI
123
+ * @param image The image to resolve
124
+ */
125
+ static async resolveImage(image) {
126
+ const buffer = await this.resolveBuffer(image);
127
+ // Detect MIME type from magic bytes
128
+ let mimeType = 'image/png';
129
+ if (buffer[0] === 0xFF && buffer[1] === 0xD8) {
130
+ mimeType = 'image/jpeg';
131
+ }
132
+ else if (buffer[0] === 0x47 && buffer[1] === 0x49 && buffer[2] === 0x46) {
133
+ mimeType = 'image/gif';
134
+ }
135
+ else if (buffer[0] === 0x52 && buffer[1] === 0x49 && buffer[2] === 0x46 && buffer[3] === 0x46) {
136
+ mimeType = 'image/webp';
137
+ }
138
+ return `data:${mimeType};base64,${buffer.toString('base64')}`;
139
+ }
140
+ }
141
+ export default DataResolver;
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DataResolver.js","sourceRoot":"","sources":["../../../src/utils/DataResolver.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Data resolver utilities for handling various data types\n */\n\nimport { readFile } from 'fs/promises';\nimport { basename } from 'path';\n\nexport type BufferResolvable = Buffer | string;\nexport type Base64Resolvable = Buffer | string;\n\n/**\n * Resolves various data types to usable formats\n */\nexport class DataResolver {\n  /**\n   * Resolves a BufferResolvable to a Buffer\n   * @param resource The resource to resolve\n   */\n  static async resolveBuffer(resource: BufferResolvable): Promise<Buffer> {\n    if (Buffer.isBuffer(resource)) return resource;\n    \n    if (typeof resource === 'string') {\n      // Check if it's a file path\n      if (resource.startsWith('/') || resource.startsWith('./') || resource.startsWith('../') || /^[a-zA-Z]:/.test(resource)) {\n        return readFile(resource);\n      }\n      \n      // Check if it's a URL\n      if (resource.startsWith('http://') || resource.startsWith('https://')) {\n        const response = await fetch(resource);\n        const arrayBuffer = await response.arrayBuffer();\n        return Buffer.from(arrayBuffer);\n      }\n      \n      // Check if it's base64\n      if (resource.startsWith('data:')) {\n        const base64Data = resource.split(',')[1];\n        return Buffer.from(base64Data, 'base64');\n      }\n      \n      // Assume it's a file path\n      return readFile(resource);\n    }\n    \n    throw new TypeError('Invalid resource type');\n  }\n\n  /**\n   * Resolves a Base64Resolvable to a base64 string\n   * @param resource The resource to resolve\n   * @param mimeType The MIME type for the data URI\n   */\n  static async resolveBase64(resource: Base64Resolvable, mimeType = 'image/png'): Promise<string> {\n    const buffer = await this.resolveBuffer(resource);\n    return `data:${mimeType};base64,${buffer.toString('base64')}`;\n  }\n\n  /**\n   * Resolves a file to a name and buffer\n   * @param resource The file resource\n   */\n  static async resolveFile(resource: BufferResolvable | { name?: string; attachment: BufferResolvable }): Promise<{ name: string; data: Buffer }> {\n    if (typeof resource === 'object' && 'attachment' in resource) {\n      const buffer = await this.resolveBuffer(resource.attachment);\n      const name = resource.name ?? 'file';\n      return { name, data: buffer };\n    }\n    \n    const buffer = await this.resolveBuffer(resource);\n    const name = typeof resource === 'string' ? basename(resource) : 'file';\n    return { name, data: buffer };\n  }\n\n  /**\n   * Resolves multiple files\n   * @param resources The file resources\n   */\n  static async resolveFiles(resources: (BufferResolvable | { name?: string; attachment: BufferResolvable })[]): Promise<{ name: string; data: Buffer }[]> {\n    return Promise.all(resources.map(r => this.resolveFile(r)));\n  }\n\n  /**\n   * Resolves a color to a number\n   * @param color The color to resolve\n   */\n  static resolveColor(color: number | string | [number, number, number] | null): number | null {\n    if (color === null) return null;\n    \n    if (typeof color === 'number') {\n      if (color < 0 || color > 0xFFFFFF) throw new RangeError('Color must be between 0 and 16777215');\n      return color;\n    }\n    \n    if (typeof color === 'string') {\n      if (color.startsWith('#')) {\n        return parseInt(color.slice(1), 16);\n      }\n      // Named colors\n      const namedColors: Record<string, number> = {\n        default: 0x000000,\n        white: 0xFFFFFF,\n        aqua: 0x1ABC9C,\n        green: 0x57F287,\n        blue: 0x3498DB,\n        yellow: 0xFEE75C,\n        purple: 0x9B59B6,\n        fuchsia: 0xEB459E,\n        gold: 0xF1C40F,\n        orange: 0xE67E22,\n        red: 0xED4245,\n        grey: 0x95A5A6,\n        navy: 0x34495E,\n        blurple: 0x5865F2,\n      };\n      const lower = color.toLowerCase();\n      if (lower in namedColors) return namedColors[lower];\n      return parseInt(color, 16);\n    }\n    \n    if (Array.isArray(color)) {\n      return (color[0] << 16) + (color[1] << 8) + color[2];\n    }\n    \n    throw new TypeError('Invalid color type');\n  }\n\n  /**\n   * Resolves a string to a snowflake ID\n   * @param value The value to resolve\n   */\n  static resolveSnowflake(value: string | number | { id: string | number }): string {\n    if (typeof value === 'object' && 'id' in value) {\n      return String(value.id);\n    }\n    return String(value);\n  }\n\n  /**\n   * Resolves an image to a base64 data URI\n   * @param image The image to resolve\n   */\n  static async resolveImage(image: BufferResolvable): Promise<string> {\n    const buffer = await this.resolveBuffer(image);\n    \n    // Detect MIME type from magic bytes\n    let mimeType = 'image/png';\n    if (buffer[0] === 0xFF && buffer[1] === 0xD8) {\n      mimeType = 'image/jpeg';\n    } else if (buffer[0] === 0x47 && buffer[1] === 0x49 && buffer[2] === 0x46) {\n      mimeType = 'image/gif';\n    } else if (buffer[0] === 0x52 && buffer[1] === 0x49 && buffer[2] === 0x46 && buffer[3] === 0x46) {\n      mimeType = 'image/webp';\n    }\n    \n    return `data:${mimeType};base64,${buffer.toString('base64')}`;\n  }\n}\n\nexport default DataResolver;\n"]}
@@ -0,0 +1,191 @@
1
+ /**
2
+ * Formatters for markdown and mentions
3
+ */
4
+ /**
5
+ * Formats a user mention
6
+ * @param userId The user ID to mention
7
+ */
8
+ export function userMention(userId) {
9
+ return `<@${userId}>`;
10
+ }
11
+ /**
12
+ * Formats a channel mention
13
+ * @param channelId The channel ID to mention
14
+ */
15
+ export function channelMention(channelId) {
16
+ return `<#${channelId}>`;
17
+ }
18
+ /**
19
+ * Formats a role mention
20
+ * @param roleId The role ID to mention
21
+ */
22
+ export function roleMention(roleId) {
23
+ return `<@&${roleId}>`;
24
+ }
25
+ /**
26
+ * Formats a custom emoji
27
+ * @param emojiId The emoji ID
28
+ * @param name The emoji name
29
+ * @param animated Whether the emoji is animated
30
+ */
31
+ export function formatEmoji(emojiId, name, animated = false) {
32
+ return `<${animated ? 'a' : ''}:${name}:${emojiId}>`;
33
+ }
34
+ /**
35
+ * Formats text as bold
36
+ * @param text The text to format
37
+ */
38
+ export function bold(text) {
39
+ return `**${text}**`;
40
+ }
41
+ /**
42
+ * Formats text as italic
43
+ * @param text The text to format
44
+ */
45
+ export function italic(text) {
46
+ return `*${text}*`;
47
+ }
48
+ /**
49
+ * Formats text as underline
50
+ * @param text The text to format
51
+ */
52
+ export function underline(text) {
53
+ return `__${text}__`;
54
+ }
55
+ /**
56
+ * Formats text as strikethrough
57
+ * @param text The text to format
58
+ */
59
+ export function strikethrough(text) {
60
+ return `~~${text}~~`;
61
+ }
62
+ /**
63
+ * Formats text as spoiler
64
+ * @param text The text to format
65
+ */
66
+ export function spoiler(text) {
67
+ return `||${text}||`;
68
+ }
69
+ /**
70
+ * Formats text as inline code
71
+ * @param text The text to format
72
+ */
73
+ export function inlineCode(text) {
74
+ return `\`${text}\``;
75
+ }
76
+ /**
77
+ * Formats text as a code block
78
+ * @param text The text to format
79
+ * @param language The language for syntax highlighting
80
+ */
81
+ export function codeBlock(text, language) {
82
+ return `\`\`\`${language ?? ''}\n${text}\n\`\`\``;
83
+ }
84
+ /**
85
+ * Formats text as a block quote
86
+ * @param text The text to format
87
+ */
88
+ export function blockQuote(text) {
89
+ return `>>> ${text}`;
90
+ }
91
+ /**
92
+ * Formats text as a single-line quote
93
+ * @param text The text to format
94
+ */
95
+ export function quote(text) {
96
+ return `> ${text}`;
97
+ }
98
+ /**
99
+ * Formats a URL as a hyperlink
100
+ * @param text The text to display
101
+ * @param url The URL to link to
102
+ * @param title Optional title for the link
103
+ */
104
+ export function hyperlink(text, url, title) {
105
+ return title ? `[${text}](${url} "${title}")` : `[${text}](${url})`;
106
+ }
107
+ /**
108
+ * Formats a URL to hide the embed
109
+ * @param url The URL to format
110
+ */
111
+ export function hideLinkEmbed(url) {
112
+ return `<${url}>`;
113
+ }
114
+ /**
115
+ * Time format styles
116
+ */
117
+ export var TimestampStyles;
118
+ (function (TimestampStyles) {
119
+ /** Short time format (e.g., 16:20) */
120
+ TimestampStyles["ShortTime"] = "t";
121
+ /** Long time format (e.g., 16:20:30) */
122
+ TimestampStyles["LongTime"] = "T";
123
+ /** Short date format (e.g., 20/04/2021) */
124
+ TimestampStyles["ShortDate"] = "d";
125
+ /** Long date format (e.g., 20 April 2021) */
126
+ TimestampStyles["LongDate"] = "D";
127
+ /** Short date/time format (e.g., 20 April 2021 16:20) */
128
+ TimestampStyles["ShortDateTime"] = "f";
129
+ /** Long date/time format (e.g., Tuesday, 20 April 2021 16:20) */
130
+ TimestampStyles["LongDateTime"] = "F";
131
+ /** Relative time format (e.g., 2 months ago) */
132
+ TimestampStyles["RelativeTime"] = "R";
133
+ })(TimestampStyles || (TimestampStyles = {}));
134
+ /**
135
+ * Formats a timestamp
136
+ * @param timestamp The timestamp (Date, number in ms, or seconds)
137
+ * @param style The style to use
138
+ */
139
+ export function time(timestamp, style) {
140
+ const seconds = timestamp instanceof Date
141
+ ? Math.floor(timestamp.getTime() / 1000)
142
+ : typeof timestamp === 'number' && timestamp > 1e12
143
+ ? Math.floor(timestamp / 1000)
144
+ : timestamp;
145
+ return style ? `<t:${seconds}:${style}>` : `<t:${seconds}>`;
146
+ }
147
+ /**
148
+ * Formats a heading (H1)
149
+ * @param text The text to format
150
+ */
151
+ export function heading(text, level = 1) {
152
+ return `${'#'.repeat(level)} ${text}`;
153
+ }
154
+ /**
155
+ * Formats an unordered list
156
+ * @param items The items to list
157
+ */
158
+ export function unorderedList(items) {
159
+ return items.map(item => `- ${item}`).join('\n');
160
+ }
161
+ /**
162
+ * Formats an ordered list
163
+ * @param items The items to list
164
+ */
165
+ export function orderedList(items) {
166
+ return items.map((item, i) => `${i + 1}. ${item}`).join('\n');
167
+ }
168
+ // Export all formatters as a namespace too (DJS compatibility)
169
+ export const Formatters = {
170
+ userMention,
171
+ channelMention,
172
+ roleMention,
173
+ formatEmoji,
174
+ bold,
175
+ italic,
176
+ underline,
177
+ strikethrough,
178
+ spoiler,
179
+ inlineCode,
180
+ codeBlock,
181
+ blockQuote,
182
+ quote,
183
+ hyperlink,
184
+ hideLinkEmbed,
185
+ time,
186
+ heading,
187
+ unorderedList,
188
+ orderedList,
189
+ TimestampStyles,
190
+ };
191
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Formatters.js","sourceRoot":"","sources":["../../../src/utils/Formatters.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Formatters for markdown and mentions\n */\n\n/**\n * Formats a user mention\n * @param userId The user ID to mention\n */\nexport function userMention(userId: string | number): string {\n  return `<@${userId}>`;\n}\n\n/**\n * Formats a channel mention\n * @param channelId The channel ID to mention\n */\nexport function channelMention(channelId: string | number): string {\n  return `<#${channelId}>`;\n}\n\n/**\n * Formats a role mention\n * @param roleId The role ID to mention\n */\nexport function roleMention(roleId: string | number): string {\n  return `<@&${roleId}>`;\n}\n\n/**\n * Formats a custom emoji\n * @param emojiId The emoji ID\n * @param name The emoji name\n * @param animated Whether the emoji is animated\n */\nexport function formatEmoji(emojiId: string | number, name: string, animated = false): string {\n  return `<${animated ? 'a' : ''}:${name}:${emojiId}>`;\n}\n\n/**\n * Formats text as bold\n * @param text The text to format\n */\nexport function bold(text: string): string {\n  return `**${text}**`;\n}\n\n/**\n * Formats text as italic\n * @param text The text to format\n */\nexport function italic(text: string): string {\n  return `*${text}*`;\n}\n\n/**\n * Formats text as underline\n * @param text The text to format\n */\nexport function underline(text: string): string {\n  return `__${text}__`;\n}\n\n/**\n * Formats text as strikethrough\n * @param text The text to format\n */\nexport function strikethrough(text: string): string {\n  return `~~${text}~~`;\n}\n\n/**\n * Formats text as spoiler\n * @param text The text to format\n */\nexport function spoiler(text: string): string {\n  return `||${text}||`;\n}\n\n/**\n * Formats text as inline code\n * @param text The text to format\n */\nexport function inlineCode(text: string): string {\n  return `\\`${text}\\``;\n}\n\n/**\n * Formats text as a code block\n * @param text The text to format\n * @param language The language for syntax highlighting\n */\nexport function codeBlock(text: string, language?: string): string {\n  return `\\`\\`\\`${language ?? ''}\\n${text}\\n\\`\\`\\``;\n}\n\n/**\n * Formats text as a block quote\n * @param text The text to format\n */\nexport function blockQuote(text: string): string {\n  return `>>> ${text}`;\n}\n\n/**\n * Formats text as a single-line quote\n * @param text The text to format\n */\nexport function quote(text: string): string {\n  return `> ${text}`;\n}\n\n/**\n * Formats a URL as a hyperlink\n * @param text The text to display\n * @param url The URL to link to\n * @param title Optional title for the link\n */\nexport function hyperlink(text: string, url: string, title?: string): string {\n  return title ? `[${text}](${url} \"${title}\")` : `[${text}](${url})`;\n}\n\n/**\n * Formats a URL to hide the embed\n * @param url The URL to format\n */\nexport function hideLinkEmbed(url: string): string {\n  return `<${url}>`;\n}\n\n/**\n * Time format styles\n */\nexport enum TimestampStyles {\n  /** Short time format (e.g., 16:20) */\n  ShortTime = 't',\n  /** Long time format (e.g., 16:20:30) */\n  LongTime = 'T',\n  /** Short date format (e.g., 20/04/2021) */\n  ShortDate = 'd',\n  /** Long date format (e.g., 20 April 2021) */\n  LongDate = 'D',\n  /** Short date/time format (e.g., 20 April 2021 16:20) */\n  ShortDateTime = 'f',\n  /** Long date/time format (e.g., Tuesday, 20 April 2021 16:20) */\n  LongDateTime = 'F',\n  /** Relative time format (e.g., 2 months ago) */\n  RelativeTime = 'R',\n}\n\n/**\n * Formats a timestamp\n * @param timestamp The timestamp (Date, number in ms, or seconds)\n * @param style The style to use\n */\nexport function time(timestamp: Date | number, style?: TimestampStyles): string {\n  const seconds = timestamp instanceof Date \n    ? Math.floor(timestamp.getTime() / 1000) \n    : typeof timestamp === 'number' && timestamp > 1e12 \n      ? Math.floor(timestamp / 1000) \n      : timestamp;\n  \n  return style ? `<t:${seconds}:${style}>` : `<t:${seconds}>`;\n}\n\n/**\n * Formats a heading (H1)\n * @param text The text to format\n */\nexport function heading(text: string, level: 1 | 2 | 3 = 1): string {\n  return `${'#'.repeat(level)} ${text}`;\n}\n\n/**\n * Formats an unordered list\n * @param items The items to list\n */\nexport function unorderedList(items: string[]): string {\n  return items.map(item => `- ${item}`).join('\\n');\n}\n\n/**\n * Formats an ordered list\n * @param items The items to list\n */\nexport function orderedList(items: string[]): string {\n  return items.map((item, i) => `${i + 1}. ${item}`).join('\\n');\n}\n\n// Export all formatters as a namespace too (DJS compatibility)\nexport const Formatters = {\n  userMention,\n  channelMention,\n  roleMention,\n  formatEmoji,\n  bold,\n  italic,\n  underline,\n  strikethrough,\n  spoiler,\n  inlineCode,\n  codeBlock,\n  blockQuote,\n  quote,\n  hyperlink,\n  hideLinkEmbed,\n  time,\n  heading,\n  unorderedList,\n  orderedList,\n  TimestampStyles,\n};\n"]}
@@ -0,0 +1,93 @@
1
+ /**
2
+ * Intents BitField for calculating gateway intents
3
+ */
4
+ import { BitField } from './BitField';
5
+ /**
6
+ * Gateway Intent Bits
7
+ */
8
+ export const GatewayIntentBits = {
9
+ Guilds: 1 << 0,
10
+ GuildMembers: 1 << 1,
11
+ GuildModeration: 1 << 2,
12
+ GuildEmojisAndStickers: 1 << 3,
13
+ GuildIntegrations: 1 << 4,
14
+ GuildWebhooks: 1 << 5,
15
+ GuildInvites: 1 << 6,
16
+ GuildVoiceStates: 1 << 7,
17
+ GuildPresences: 1 << 8,
18
+ GuildMessages: 1 << 9,
19
+ GuildMessageReactions: 1 << 10,
20
+ GuildMessageTyping: 1 << 11,
21
+ DirectMessages: 1 << 12,
22
+ DirectMessageReactions: 1 << 13,
23
+ DirectMessageTyping: 1 << 14,
24
+ MessageContent: 1 << 15,
25
+ GuildScheduledEvents: 1 << 16,
26
+ AutoModerationConfiguration: 1 << 20,
27
+ AutoModerationExecution: 1 << 21,
28
+ };
29
+ /**
30
+ * All non-privileged intents
31
+ */
32
+ export const IntentsAll = Object.values(GatewayIntentBits).reduce((all, i) => all | i, 0);
33
+ /**
34
+ * Privileged intents that require approval
35
+ */
36
+ export const PrivilegedIntents = GatewayIntentBits.GuildMembers |
37
+ GatewayIntentBits.GuildPresences |
38
+ GatewayIntentBits.MessageContent;
39
+ /**
40
+ * Data structure for gateway intents
41
+ */
42
+ export class IntentsBitField extends BitField {
43
+ static Flags = GatewayIntentBits;
44
+ static DefaultBit = 0;
45
+ constructor(bits = 0) {
46
+ super(bits);
47
+ }
48
+ /**
49
+ * Check if any privileged intents are enabled
50
+ */
51
+ hasPrivileged() {
52
+ return this.any(PrivilegedIntents);
53
+ }
54
+ /**
55
+ * Get all privileged intents that are enabled
56
+ */
57
+ getPrivileged() {
58
+ const privileged = [];
59
+ if (this.has(GatewayIntentBits.GuildMembers))
60
+ privileged.push('GuildMembers');
61
+ if (this.has(GatewayIntentBits.GuildPresences))
62
+ privileged.push('GuildPresences');
63
+ if (this.has(GatewayIntentBits.MessageContent))
64
+ privileged.push('MessageContent');
65
+ return privileged;
66
+ }
67
+ }
68
+ /**
69
+ * Calculate intents from an array of intent names or values
70
+ */
71
+ export function calculateIntents(intents) {
72
+ return intents.reduce((acc, intent) => {
73
+ if (typeof intent === 'number')
74
+ return acc | intent;
75
+ if (intent in GatewayIntentBits)
76
+ return acc | GatewayIntentBits[intent];
77
+ return acc;
78
+ }, 0);
79
+ }
80
+ /**
81
+ * Get all intent names from a bitfield value
82
+ */
83
+ export function resolveIntents(bits) {
84
+ const names = [];
85
+ for (const [name, value] of Object.entries(GatewayIntentBits)) {
86
+ if ((bits & value) === value) {
87
+ names.push(name);
88
+ }
89
+ }
90
+ return names;
91
+ }
92
+ export default IntentsBitField;
93
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSW50ZW50c0JpdEZpZWxkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL0ludGVudHNCaXRGaWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILE9BQU8sRUFBRSxRQUFRLEVBQXNCLE1BQU0sWUFBWSxDQUFDO0FBTzFEOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUc7SUFDL0IsTUFBTSxFQUFFLENBQUMsSUFBSSxDQUFDO0lBQ2QsWUFBWSxFQUFFLENBQUMsSUFBSSxDQUFDO0lBQ3BCLGVBQWUsRUFBRSxDQUFDLElBQUksQ0FBQztJQUN2QixzQkFBc0IsRUFBRSxDQUFDLElBQUksQ0FBQztJQUM5QixpQkFBaUIsRUFBRSxDQUFDLElBQUksQ0FBQztJQUN6QixhQUFhLEVBQUUsQ0FBQyxJQUFJLENBQUM7SUFDckIsWUFBWSxFQUFFLENBQUMsSUFBSSxDQUFDO0lBQ3BCLGdCQUFnQixFQUFFLENBQUMsSUFBSSxDQUFDO0lBQ3hCLGNBQWMsRUFBRSxDQUFDLElBQUksQ0FBQztJQUN0QixhQUFhLEVBQUUsQ0FBQyxJQUFJLENBQUM7SUFDckIscUJBQXFCLEVBQUUsQ0FBQyxJQUFJLEVBQUU7SUFDOUIsa0JBQWtCLEVBQUUsQ0FBQyxJQUFJLEVBQUU7SUFDM0IsY0FBYyxFQUFFLENBQUMsSUFBSSxFQUFFO0lBQ3ZCLHNCQUFzQixFQUFFLENBQUMsSUFBSSxFQUFFO0lBQy9CLG1CQUFtQixFQUFFLENBQUMsSUFBSSxFQUFFO0lBQzVCLGNBQWMsRUFBRSxDQUFDLElBQUksRUFBRTtJQUN2QixvQkFBb0IsRUFBRSxDQUFDLElBQUksRUFBRTtJQUM3QiwyQkFBMkIsRUFBRSxDQUFDLElBQUksRUFBRTtJQUNwQyx1QkFBdUIsRUFBRSxDQUFDLElBQUksRUFBRTtDQUN4QixDQUFDO0FBRVg7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLEdBQUcsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFFMUY7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FDNUIsaUJBQWlCLENBQUMsWUFBWTtJQUM5QixpQkFBaUIsQ0FBQyxjQUFjO0lBQ2hDLGlCQUFpQixDQUFDLGNBQWMsQ0FBQztBQUVuQzs7R0FFRztBQUNILE1BQU0sT0FBTyxlQUFnQixTQUFRLFFBQW1DO0lBQ3RFLE1BQU0sQ0FBQyxLQUFLLEdBQUcsaUJBQWlCLENBQUM7SUFDakMsTUFBTSxDQUFDLFVBQVUsR0FBRyxDQUFDLENBQUM7SUFFdEIsWUFBWSxPQUFzRCxDQUFDO1FBQ2pFLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNkLENBQUM7SUFFRDs7T0FFRztJQUNILGFBQWE7UUFDWCxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsaUJBQWlCLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQ7O09BRUc7SUFDSCxhQUFhO1FBQ1gsTUFBTSxVQUFVLEdBQXdCLEVBQUUsQ0FBQztRQUMzQyxJQUFJLElBQUksQ0FBQyxHQUFHLENBQUMsaUJBQWlCLENBQUMsWUFBWSxDQUFDO1lBQUUsVUFBVSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUM5RSxJQUFJLElBQUksQ0FBQyxHQUFHLENBQUMsaUJBQWlCLENBQUMsY0FBYyxDQUFDO1lBQUUsVUFBVSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQ2xGLElBQUksSUFBSSxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxjQUFjLENBQUM7WUFBRSxVQUFVLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDbEYsT0FBTyxVQUFVLENBQUM7SUFDcEIsQ0FBQzs7QUFHSDs7R0FFRztBQUNILE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxPQUF1QztJQUN0RSxPQUFPLE9BQU8sQ0FBQyxNQUFNLENBQVMsQ0FBQyxHQUFHLEVBQUUsTUFBTSxFQUFFLEVBQUU7UUFDNUMsSUFBSSxPQUFPLE1BQU0sS0FBSyxRQUFRO1lBQUUsT0FBTyxHQUFHLEdBQUcsTUFBTSxDQUFDO1FBQ3BELElBQUksTUFBTSxJQUFJLGlCQUFpQjtZQUFFLE9BQU8sR0FBRyxHQUFHLGlCQUFpQixDQUFDLE1BQXdDLENBQUMsQ0FBQztRQUMxRyxPQUFPLEdBQUcsQ0FBQztJQUNiLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztBQUNSLENBQUM7QUFFRDs7R0FFRztBQUNILE1BQU0sVUFBVSxjQUFjLENBQUMsSUFBWTtJQUN6QyxNQUFNLEtBQUssR0FBd0IsRUFBRSxDQUFDO0lBQ3RDLEtBQUssTUFBTSxDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsSUFBSSxNQUFNLENBQUMsT0FBTyxDQUFDLGlCQUFpQixDQUFDLEVBQUUsQ0FBQztRQUM5RCxJQUFJLENBQUMsSUFBSSxHQUFHLEtBQUssQ0FBQyxLQUFLLEtBQUssRUFBRSxDQUFDO1lBQzdCLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBeUIsQ0FBQyxDQUFDO1FBQ3hDLENBQUM7SUFDSCxDQUFDO0lBQ0QsT0FBTyxLQUFLLENBQUM7QUFDZixDQUFDO0FBRUQsZUFBZSxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEludGVudHMgQml0RmllbGQgZm9yIGNhbGN1bGF0aW5nIGdhdGV3YXkgaW50ZW50c1xuICovXG5cbmltcG9ydCB7IEJpdEZpZWxkLCBCaXRGaWVsZFJlc29sdmFibGUgfSBmcm9tICcuL0JpdEZpZWxkJztcblxuLyoqXG4gKiBJbnRlbnQgZmxhZyBuYW1lc1xuICovXG5leHBvcnQgdHlwZSBJbnRlbnRGbGFnc1N0cmluZyA9IGtleW9mIHR5cGVvZiBJbnRlbnRzQml0RmllbGQuRmxhZ3M7XG5cbi8qKlxuICogR2F0ZXdheSBJbnRlbnQgQml0c1xuICovXG5leHBvcnQgY29uc3QgR2F0ZXdheUludGVudEJpdHMgPSB7XG4gIEd1aWxkczogMSA8PCAwLFxuICBHdWlsZE1lbWJlcnM6IDEgPDwgMSxcbiAgR3VpbGRNb2RlcmF0aW9uOiAxIDw8IDIsXG4gIEd1aWxkRW1vamlzQW5kU3RpY2tlcnM6IDEgPDwgMyxcbiAgR3VpbGRJbnRlZ3JhdGlvbnM6IDEgPDwgNCxcbiAgR3VpbGRXZWJob29rczogMSA8PCA1LFxuICBHdWlsZEludml0ZXM6IDEgPDwgNixcbiAgR3VpbGRWb2ljZVN0YXRlczogMSA8PCA3LFxuICBHdWlsZFByZXNlbmNlczogMSA8PCA4LFxuICBHdWlsZE1lc3NhZ2VzOiAxIDw8IDksXG4gIEd1aWxkTWVzc2FnZVJlYWN0aW9uczogMSA8PCAxMCxcbiAgR3VpbGRNZXNzYWdlVHlwaW5nOiAxIDw8IDExLFxuICBEaXJlY3RNZXNzYWdlczogMSA8PCAxMixcbiAgRGlyZWN0TWVzc2FnZVJlYWN0aW9uczogMSA8PCAxMyxcbiAgRGlyZWN0TWVzc2FnZVR5cGluZzogMSA8PCAxNCxcbiAgTWVzc2FnZUNvbnRlbnQ6IDEgPDwgMTUsXG4gIEd1aWxkU2NoZWR1bGVkRXZlbnRzOiAxIDw8IDE2LFxuICBBdXRvTW9kZXJhdGlvbkNvbmZpZ3VyYXRpb246IDEgPDwgMjAsXG4gIEF1dG9Nb2RlcmF0aW9uRXhlY3V0aW9uOiAxIDw8IDIxLFxufSBhcyBjb25zdDtcblxuLyoqXG4gKiBBbGwgbm9uLXByaXZpbGVnZWQgaW50ZW50c1xuICovXG5leHBvcnQgY29uc3QgSW50ZW50c0FsbCA9IE9iamVjdC52YWx1ZXMoR2F0ZXdheUludGVudEJpdHMpLnJlZHVjZSgoYWxsLCBpKSA9PiBhbGwgfCBpLCAwKTtcblxuLyoqXG4gKiBQcml2aWxlZ2VkIGludGVudHMgdGhhdCByZXF1aXJlIGFwcHJvdmFsXG4gKi9cbmV4cG9ydCBjb25zdCBQcml2aWxlZ2VkSW50ZW50cyA9IFxuICBHYXRld2F5SW50ZW50Qml0cy5HdWlsZE1lbWJlcnMgfCBcbiAgR2F0ZXdheUludGVudEJpdHMuR3VpbGRQcmVzZW5jZXMgfCBcbiAgR2F0ZXdheUludGVudEJpdHMuTWVzc2FnZUNvbnRlbnQ7XG5cbi8qKlxuICogRGF0YSBzdHJ1Y3R1cmUgZm9yIGdhdGV3YXkgaW50ZW50c1xuICovXG5leHBvcnQgY2xhc3MgSW50ZW50c0JpdEZpZWxkIGV4dGVuZHMgQml0RmllbGQ8SW50ZW50RmxhZ3NTdHJpbmcsIG51bWJlcj4ge1xuICBzdGF0aWMgRmxhZ3MgPSBHYXRld2F5SW50ZW50Qml0cztcbiAgc3RhdGljIERlZmF1bHRCaXQgPSAwO1xuXG4gIGNvbnN0cnVjdG9yKGJpdHM6IEJpdEZpZWxkUmVzb2x2YWJsZTxJbnRlbnRGbGFnc1N0cmluZywgbnVtYmVyPiA9IDApIHtcbiAgICBzdXBlcihiaXRzKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDaGVjayBpZiBhbnkgcHJpdmlsZWdlZCBpbnRlbnRzIGFyZSBlbmFibGVkXG4gICAqL1xuICBoYXNQcml2aWxlZ2VkKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLmFueShQcml2aWxlZ2VkSW50ZW50cyk7XG4gIH1cblxuICAvKipcbiAgICogR2V0IGFsbCBwcml2aWxlZ2VkIGludGVudHMgdGhhdCBhcmUgZW5hYmxlZFxuICAgKi9cbiAgZ2V0UHJpdmlsZWdlZCgpOiBJbnRlbnRGbGFnc1N0cmluZ1tdIHtcbiAgICBjb25zdCBwcml2aWxlZ2VkOiBJbnRlbnRGbGFnc1N0cmluZ1tdID0gW107XG4gICAgaWYgKHRoaXMuaGFzKEdhdGV3YXlJbnRlbnRCaXRzLkd1aWxkTWVtYmVycykpIHByaXZpbGVnZWQucHVzaCgnR3VpbGRNZW1iZXJzJyk7XG4gICAgaWYgKHRoaXMuaGFzKEdhdGV3YXlJbnRlbnRCaXRzLkd1aWxkUHJlc2VuY2VzKSkgcHJpdmlsZWdlZC5wdXNoKCdHdWlsZFByZXNlbmNlcycpO1xuICAgIGlmICh0aGlzLmhhcyhHYXRld2F5SW50ZW50Qml0cy5NZXNzYWdlQ29udGVudCkpIHByaXZpbGVnZWQucHVzaCgnTWVzc2FnZUNvbnRlbnQnKTtcbiAgICByZXR1cm4gcHJpdmlsZWdlZDtcbiAgfVxufVxuXG4vKipcbiAqIENhbGN1bGF0ZSBpbnRlbnRzIGZyb20gYW4gYXJyYXkgb2YgaW50ZW50IG5hbWVzIG9yIHZhbHVlc1xuICovXG5leHBvcnQgZnVuY3Rpb24gY2FsY3VsYXRlSW50ZW50cyhpbnRlbnRzOiAoSW50ZW50RmxhZ3NTdHJpbmcgfCBudW1iZXIpW10pOiBudW1iZXIge1xuICByZXR1cm4gaW50ZW50cy5yZWR1Y2U8bnVtYmVyPigoYWNjLCBpbnRlbnQpID0+IHtcbiAgICBpZiAodHlwZW9mIGludGVudCA9PT0gJ251bWJlcicpIHJldHVybiBhY2MgfCBpbnRlbnQ7XG4gICAgaWYgKGludGVudCBpbiBHYXRld2F5SW50ZW50Qml0cykgcmV0dXJuIGFjYyB8IEdhdGV3YXlJbnRlbnRCaXRzW2ludGVudCBhcyBrZXlvZiB0eXBlb2YgR2F0ZXdheUludGVudEJpdHNdO1xuICAgIHJldHVybiBhY2M7XG4gIH0sIDApO1xufVxuXG4vKipcbiAqIEdldCBhbGwgaW50ZW50IG5hbWVzIGZyb20gYSBiaXRmaWVsZCB2YWx1ZVxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVzb2x2ZUludGVudHMoYml0czogbnVtYmVyKTogSW50ZW50RmxhZ3NTdHJpbmdbXSB7XG4gIGNvbnN0IG5hbWVzOiBJbnRlbnRGbGFnc1N0cmluZ1tdID0gW107XG4gIGZvciAoY29uc3QgW25hbWUsIHZhbHVlXSBvZiBPYmplY3QuZW50cmllcyhHYXRld2F5SW50ZW50Qml0cykpIHtcbiAgICBpZiAoKGJpdHMgJiB2YWx1ZSkgPT09IHZhbHVlKSB7XG4gICAgICBuYW1lcy5wdXNoKG5hbWUgYXMgSW50ZW50RmxhZ3NTdHJpbmcpO1xuICAgIH1cbiAgfVxuICByZXR1cm4gbmFtZXM7XG59XG5cbmV4cG9ydCBkZWZhdWx0IEludGVudHNCaXRGaWVsZDtcbiJdfQ==
@@ -0,0 +1,137 @@
1
+ /**
2
+ * Partials - Handle uncached/partial data structures
3
+ */
4
+ /**
5
+ * Partial types that can be enabled
6
+ */
7
+ export var Partials;
8
+ (function (Partials) {
9
+ Partials[Partials["User"] = 0] = "User";
10
+ Partials[Partials["Channel"] = 1] = "Channel";
11
+ Partials[Partials["GuildMember"] = 2] = "GuildMember";
12
+ Partials[Partials["Message"] = 3] = "Message";
13
+ Partials[Partials["Reaction"] = 4] = "Reaction";
14
+ Partials[Partials["GuildScheduledEvent"] = 5] = "GuildScheduledEvent";
15
+ })(Partials || (Partials = {}));
16
+ /**
17
+ * Check if a structure is partial (missing data)
18
+ */
19
+ export function isPartial(obj) {
20
+ return obj?.partial === true;
21
+ }
22
+ /**
23
+ * Create a partial user structure
24
+ */
25
+ export function createPartialUser(id) {
26
+ return {
27
+ id,
28
+ partial: true,
29
+ username: null,
30
+ discriminator: null,
31
+ avatar: null,
32
+ bot: null,
33
+ async fetch() {
34
+ throw new Error('Cannot fetch partial user without client context');
35
+ },
36
+ toString() {
37
+ return `<@${id}>`;
38
+ },
39
+ };
40
+ }
41
+ /**
42
+ * Create a partial channel structure
43
+ */
44
+ export function createPartialChannel(id) {
45
+ return {
46
+ id,
47
+ partial: true,
48
+ type: null,
49
+ name: null,
50
+ async fetch() {
51
+ throw new Error('Cannot fetch partial channel without client context');
52
+ },
53
+ toString() {
54
+ return `<#${id}>`;
55
+ },
56
+ };
57
+ }
58
+ /**
59
+ * Create a partial message structure
60
+ */
61
+ export function createPartialMessage(id, channelId) {
62
+ return {
63
+ id,
64
+ channelId,
65
+ partial: true,
66
+ content: null,
67
+ author: null,
68
+ embeds: null,
69
+ attachments: null,
70
+ async fetch() {
71
+ throw new Error('Cannot fetch partial message without client context');
72
+ },
73
+ toString() {
74
+ return `Message(${id})`;
75
+ },
76
+ };
77
+ }
78
+ /**
79
+ * Create a partial guild member structure
80
+ */
81
+ export function createPartialGuildMember(userId, guildId) {
82
+ return {
83
+ id: userId,
84
+ guildId,
85
+ partial: true,
86
+ user: null,
87
+ nick: null,
88
+ roles: null,
89
+ joinedAt: null,
90
+ async fetch() {
91
+ throw new Error('Cannot fetch partial member without client context');
92
+ },
93
+ toString() {
94
+ return `<@${userId}>`;
95
+ },
96
+ };
97
+ }
98
+ /**
99
+ * Create a partial reaction structure
100
+ */
101
+ export function createPartialReaction(messageId, emoji) {
102
+ return {
103
+ messageId,
104
+ emoji,
105
+ partial: true,
106
+ count: null,
107
+ me: null,
108
+ async fetch() {
109
+ throw new Error('Cannot fetch partial reaction without client context');
110
+ },
111
+ toString() {
112
+ return emoji;
113
+ },
114
+ };
115
+ }
116
+ /**
117
+ * Make a structure partial-aware with fetch capability
118
+ */
119
+ export function makePartialAware(structure, client, fetchFn) {
120
+ return {
121
+ ...structure,
122
+ partial: false,
123
+ async fetch() {
124
+ const fetched = await fetchFn(structure.id);
125
+ Object.assign(this, fetched, { partial: false });
126
+ return this;
127
+ },
128
+ };
129
+ }
130
+ /**
131
+ * Check if partials are enabled for a type
132
+ */
133
+ export function hasPartial(client, partial) {
134
+ return client.options?.partials?.includes(partial) ?? false;
135
+ }
136
+ export default Partials;
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Partials.js","sourceRoot":"","sources":["../../../src/utils/Partials.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Partials - Handle uncached/partial data structures\n */\n\n/**\n * Partial types that can be enabled\n */\nexport enum Partials {\n  User = 0,\n  Channel = 1,\n  GuildMember = 2,\n  Message = 3,\n  Reaction = 4,\n  GuildScheduledEvent = 5,\n}\n\n/**\n * Check if a structure is partial (missing data)\n */\nexport function isPartial(obj: any): boolean {\n  return obj?.partial === true;\n}\n\n/**\n * Create a partial user structure\n */\nexport function createPartialUser(id: string): PartialUser {\n  return {\n    id,\n    partial: true,\n    username: null,\n    discriminator: null,\n    avatar: null,\n    bot: null,\n    \n    async fetch() {\n      throw new Error('Cannot fetch partial user without client context');\n    },\n    \n    toString() {\n      return `<@${id}>`;\n    },\n  };\n}\n\n/**\n * Create a partial channel structure\n */\nexport function createPartialChannel(id: string): PartialChannel {\n  return {\n    id,\n    partial: true,\n    type: null,\n    name: null,\n    \n    async fetch() {\n      throw new Error('Cannot fetch partial channel without client context');\n    },\n    \n    toString() {\n      return `<#${id}>`;\n    },\n  };\n}\n\n/**\n * Create a partial message structure\n */\nexport function createPartialMessage(id: string, channelId: string): PartialMessage {\n  return {\n    id,\n    channelId,\n    partial: true,\n    content: null,\n    author: null,\n    embeds: null,\n    attachments: null,\n    \n    async fetch() {\n      throw new Error('Cannot fetch partial message without client context');\n    },\n    \n    toString() {\n      return `Message(${id})`;\n    },\n  };\n}\n\n/**\n * Create a partial guild member structure\n */\nexport function createPartialGuildMember(userId: string, guildId: string): PartialGuildMember {\n  return {\n    id: userId,\n    guildId,\n    partial: true,\n    user: null,\n    nick: null,\n    roles: null,\n    joinedAt: null,\n    \n    async fetch() {\n      throw new Error('Cannot fetch partial member without client context');\n    },\n    \n    toString() {\n      return `<@${userId}>`;\n    },\n  };\n}\n\n/**\n * Create a partial reaction structure\n */\nexport function createPartialReaction(messageId: string, emoji: string): PartialReaction {\n  return {\n    messageId,\n    emoji,\n    partial: true,\n    count: null,\n    me: null,\n    \n    async fetch() {\n      throw new Error('Cannot fetch partial reaction without client context');\n    },\n    \n    toString() {\n      return emoji;\n    },\n  };\n}\n\n/**\n * Partial structure types\n */\nexport interface PartialUser {\n  id: string;\n  partial: true;\n  username: string | null;\n  discriminator: string | null;\n  avatar: string | null;\n  bot: boolean | null;\n  fetch(): Promise<any>;\n  toString(): string;\n}\n\nexport interface PartialChannel {\n  id: string;\n  partial: true;\n  type: number | null;\n  name: string | null;\n  fetch(): Promise<any>;\n  toString(): string;\n}\n\nexport interface PartialMessage {\n  id: string;\n  channelId: string;\n  partial: true;\n  content: string | null;\n  author: any | null;\n  embeds: any[] | null;\n  attachments: any[] | null;\n  fetch(): Promise<any>;\n  toString(): string;\n}\n\nexport interface PartialGuildMember {\n  id: string;\n  guildId: string;\n  partial: true;\n  user: any | null;\n  nick: string | null;\n  roles: string[] | null;\n  joinedAt: Date | null;\n  fetch(): Promise<any>;\n  toString(): string;\n}\n\nexport interface PartialReaction {\n  messageId: string;\n  emoji: string;\n  partial: true;\n  count: number | null;\n  me: boolean | null;\n  fetch(): Promise<any>;\n  toString(): string;\n}\n\n/**\n * Make a structure partial-aware with fetch capability\n */\nexport function makePartialAware<T extends { id: string }>(\n  structure: T,\n  client: any,\n  fetchFn: (id: string) => Promise<T>\n): T & { partial: boolean; fetch: () => Promise<T> } {\n  return {\n    ...structure,\n    partial: false,\n    async fetch() {\n      const fetched = await fetchFn(structure.id);\n      Object.assign(this, fetched, { partial: false });\n      return this as T;\n    },\n  };\n}\n\n/**\n * Check if partials are enabled for a type\n */\nexport function hasPartial(client: any, partial: Partials): boolean {\n  return client.options?.partials?.includes(partial) ?? false;\n}\n\nexport default Partials;\n"]}