@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.
- package/LICENSE +21 -0
- package/README.md +166 -0
- package/dist/Client.d.ts +147 -0
- package/dist/Client.js +471 -0
- package/dist/builders/ActionRowBuilder.d.ts +53 -0
- package/dist/builders/ActionRowBuilder.js +68 -0
- package/dist/builders/ButtonBuilder.d.ts +77 -0
- package/dist/builders/ButtonBuilder.js +96 -0
- package/dist/builders/EmbedBuilder.d.ts +157 -0
- package/dist/builders/EmbedBuilder.js +199 -0
- package/dist/builders/ModalBuilder.d.ts +122 -0
- package/dist/builders/ModalBuilder.js +162 -0
- package/dist/builders/SelectMenuBuilder.d.ts +123 -0
- package/dist/builders/SelectMenuBuilder.js +165 -0
- package/dist/builders/SlashCommandBuilder.d.ts +197 -0
- package/dist/builders/SlashCommandBuilder.js +324 -0
- package/dist/builders/index.d.ts +9 -0
- package/dist/builders/index.js +26 -0
- package/dist/enums.d.ts +196 -0
- package/dist/enums.js +216 -0
- package/dist/index.d.ts +25 -0
- package/dist/index.js +128 -0
- package/dist/managers/BaseManager.d.ts +69 -0
- package/dist/managers/BaseManager.js +106 -0
- package/dist/managers/ChannelManager.d.ts +98 -0
- package/dist/managers/ChannelManager.js +209 -0
- package/dist/managers/GuildMemberManager.d.ts +74 -0
- package/dist/managers/GuildMemberManager.js +156 -0
- package/dist/managers/RoleManager.d.ts +84 -0
- package/dist/managers/RoleManager.js +207 -0
- package/dist/managers/index.d.ts +7 -0
- package/dist/managers/index.js +24 -0
- package/dist/rest/REST.d.ts +483 -0
- package/dist/rest/REST.js +805 -0
- package/dist/rest/index.d.ts +1 -0
- package/dist/rest/index.js +18 -0
- package/dist/sharding/ShardingManager.d.ts +179 -0
- package/dist/sharding/ShardingManager.js +375 -0
- package/dist/sharding/index.d.ts +4 -0
- package/dist/sharding/index.js +21 -0
- package/dist/structures/Channel.d.ts +120 -0
- package/dist/structures/Channel.js +224 -0
- package/dist/structures/Collection.d.ts +53 -0
- package/dist/structures/Collection.js +115 -0
- package/dist/structures/Guild.d.ts +59 -0
- package/dist/structures/Guild.js +90 -0
- package/dist/structures/GuildMember.d.ts +130 -0
- package/dist/structures/GuildMember.js +208 -0
- package/dist/structures/Interaction.d.ts +224 -0
- package/dist/structures/Interaction.js +404 -0
- package/dist/structures/Message.d.ts +93 -0
- package/dist/structures/Message.js +145 -0
- package/dist/structures/User.d.ts +37 -0
- package/dist/structures/User.js +65 -0
- package/dist/structures/index.d.ts +7 -0
- package/dist/structures/index.js +25 -0
- package/dist/structures.d.ts +1 -0
- package/dist/structures.js +19 -0
- package/dist/types.d.ts +255 -0
- package/dist/types.js +3 -0
- package/dist/utils/BitField.d.ts +66 -0
- package/dist/utils/BitField.js +138 -0
- package/dist/utils/Collection.d.ts +116 -0
- package/dist/utils/Collection.js +265 -0
- package/dist/utils/Collector.d.ts +152 -0
- package/dist/utils/Collector.js +314 -0
- package/dist/utils/DataResolver.d.ts +61 -0
- package/dist/utils/DataResolver.js +146 -0
- package/dist/utils/Formatters.d.ts +145 -0
- package/dist/utils/Formatters.js +213 -0
- package/dist/utils/IntentsBitField.d.ts +85 -0
- package/dist/utils/IntentsBitField.js +99 -0
- package/dist/utils/Partials.d.ts +105 -0
- package/dist/utils/Partials.js +149 -0
- package/dist/utils/PermissionsBitField.d.ts +118 -0
- package/dist/utils/PermissionsBitField.js +145 -0
- package/dist/utils/SnowflakeUtil.d.ts +63 -0
- package/dist/utils/SnowflakeUtil.js +93 -0
- package/dist/utils/Sweepers.d.ts +127 -0
- package/dist/utils/Sweepers.js +270 -0
- package/dist/utils/index.d.ts +13 -0
- package/dist/utils/index.js +30 -0
- 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;
|