@jubbio/core 1.0.0

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