mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-17 03:53:29 +01:00
feat: BaseGuildEmojiManager (#4934)
Co-authored-by: Vlad Frangu <kingdgrizzle@gmail.com>
This commit is contained in:
@@ -28,6 +28,7 @@ export const {
|
|||||||
UserFlags,
|
UserFlags,
|
||||||
Util,
|
Util,
|
||||||
version,
|
version,
|
||||||
|
BaseGuildEmojiManager,
|
||||||
ChannelManager,
|
ChannelManager,
|
||||||
GuildChannelManager,
|
GuildChannelManager,
|
||||||
GuildEmojiManager,
|
GuildEmojiManager,
|
||||||
|
|||||||
@@ -5,8 +5,8 @@ const ActionsManager = require('./actions/ActionsManager');
|
|||||||
const ClientVoiceManager = require('./voice/ClientVoiceManager');
|
const ClientVoiceManager = require('./voice/ClientVoiceManager');
|
||||||
const WebSocketManager = require('./websocket/WebSocketManager');
|
const WebSocketManager = require('./websocket/WebSocketManager');
|
||||||
const { Error, TypeError, RangeError } = require('../errors');
|
const { Error, TypeError, RangeError } = require('../errors');
|
||||||
|
const BaseGuildEmojiManager = require('../managers/BaseGuildEmojiManager');
|
||||||
const ChannelManager = require('../managers/ChannelManager');
|
const ChannelManager = require('../managers/ChannelManager');
|
||||||
const GuildEmojiManager = require('../managers/GuildEmojiManager');
|
|
||||||
const GuildManager = require('../managers/GuildManager');
|
const GuildManager = require('../managers/GuildManager');
|
||||||
const UserManager = require('../managers/UserManager');
|
const UserManager = require('../managers/UserManager');
|
||||||
const ShardClientUtil = require('../sharding/ShardClientUtil');
|
const ShardClientUtil = require('../sharding/ShardClientUtil');
|
||||||
@@ -170,7 +170,7 @@ class Client extends BaseClient {
|
|||||||
* @readonly
|
* @readonly
|
||||||
*/
|
*/
|
||||||
get emojis() {
|
get emojis() {
|
||||||
const emojis = new GuildEmojiManager({ client: this });
|
const emojis = new BaseGuildEmojiManager(this);
|
||||||
for (const guild of this.guilds.cache.values()) {
|
for (const guild of this.guilds.cache.values()) {
|
||||||
if (guild.available) for (const emoji of guild.emojis.cache.values()) emojis.cache.set(emoji.id, emoji);
|
if (guild.available) for (const emoji of guild.emojis.cache.values()) emojis.cache.set(emoji.id, emoji);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -33,6 +33,7 @@ module.exports = {
|
|||||||
version: require('../package.json').version,
|
version: require('../package.json').version,
|
||||||
|
|
||||||
// Managers
|
// Managers
|
||||||
|
BaseGuildEmojiManager: require('./managers/BaseGuildEmojiManager'),
|
||||||
ChannelManager: require('./managers/ChannelManager'),
|
ChannelManager: require('./managers/ChannelManager'),
|
||||||
GuildChannelManager: require('./managers/GuildChannelManager'),
|
GuildChannelManager: require('./managers/GuildChannelManager'),
|
||||||
GuildEmojiManager: require('./managers/GuildEmojiManager'),
|
GuildEmojiManager: require('./managers/GuildEmojiManager'),
|
||||||
|
|||||||
80
src/managers/BaseGuildEmojiManager.js
Normal file
80
src/managers/BaseGuildEmojiManager.js
Normal file
@@ -0,0 +1,80 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
const BaseManager = require('./BaseManager');
|
||||||
|
const GuildEmoji = require('../structures/GuildEmoji');
|
||||||
|
const ReactionEmoji = require('../structures/ReactionEmoji');
|
||||||
|
const { parseEmoji } = require('../util/Util');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Holds methods to resolve GuildEmojis and stores their cache.
|
||||||
|
* @extends {BaseManager}
|
||||||
|
*/
|
||||||
|
class BaseGuildEmojiManager extends BaseManager {
|
||||||
|
constructor(client, iterable) {
|
||||||
|
super(client, iterable, GuildEmoji);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The cache of GuildEmojis
|
||||||
|
* @type {Collection<Snowflake, GuildEmoji>}
|
||||||
|
* @name BaseGuildEmojiManager#cache
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Data that can be resolved into a GuildEmoji object. This can be:
|
||||||
|
* * A custom emoji ID
|
||||||
|
* * A GuildEmoji object
|
||||||
|
* * A ReactionEmoji object
|
||||||
|
* @typedef {Snowflake|GuildEmoji|ReactionEmoji} EmojiResolvable
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resolves an EmojiResolvable to an Emoji object.
|
||||||
|
* @param {EmojiResolvable} emoji The Emoji resolvable to identify
|
||||||
|
* @returns {?GuildEmoji}
|
||||||
|
*/
|
||||||
|
resolve(emoji) {
|
||||||
|
if (emoji instanceof ReactionEmoji) return super.resolve(emoji.id);
|
||||||
|
return super.resolve(emoji);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resolves an EmojiResolvable to an Emoji ID string.
|
||||||
|
* @param {EmojiResolvable} emoji The Emoji resolvable to identify
|
||||||
|
* @returns {?Snowflake}
|
||||||
|
*/
|
||||||
|
resolveID(emoji) {
|
||||||
|
if (emoji instanceof ReactionEmoji) return emoji.id;
|
||||||
|
return super.resolveID(emoji);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Data that can be resolved to give an emoji identifier. This can be:
|
||||||
|
* * The unicode representation of an emoji
|
||||||
|
* * The `<a:name:id>`, `<:name:id>`, `a:name:id` or `name:id` emoji identifier string of an emoji
|
||||||
|
* * An EmojiResolvable
|
||||||
|
* @typedef {string|EmojiResolvable} EmojiIdentifierResolvable
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resolves an EmojiResolvable to an emoji identifier.
|
||||||
|
* @param {EmojiIdentifierResolvable} emoji The emoji resolvable to resolve
|
||||||
|
* @returns {?string}
|
||||||
|
*/
|
||||||
|
resolveIdentifier(emoji) {
|
||||||
|
const emojiResolvable = this.resolve(emoji);
|
||||||
|
if (emojiResolvable) return emojiResolvable.identifier;
|
||||||
|
if (emoji instanceof ReactionEmoji) return emoji.identifier;
|
||||||
|
if (typeof emoji === 'string') {
|
||||||
|
const res = parseEmoji(emoji);
|
||||||
|
if (res && res.name.length) {
|
||||||
|
emoji = `${res.animated ? 'a:' : ''}${res.name}${res.id ? `:${res.id}` : ''}`;
|
||||||
|
}
|
||||||
|
if (!emoji.includes('%')) return encodeURIComponent(emoji);
|
||||||
|
return emoji;
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = BaseGuildEmojiManager;
|
||||||
@@ -1,20 +1,18 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
const BaseManager = require('./BaseManager');
|
const BaseGuildEmojiManager = require('./BaseGuildEmojiManager');
|
||||||
const { TypeError } = require('../errors');
|
const { TypeError } = require('../errors');
|
||||||
const GuildEmoji = require('../structures/GuildEmoji');
|
|
||||||
const ReactionEmoji = require('../structures/ReactionEmoji');
|
|
||||||
const Collection = require('../util/Collection');
|
const Collection = require('../util/Collection');
|
||||||
const DataResolver = require('../util/DataResolver');
|
const DataResolver = require('../util/DataResolver');
|
||||||
const { parseEmoji } = require('../util/Util');
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Manages API methods for GuildEmojis and stores their cache.
|
* Manages API methods for GuildEmojis and stores their cache.
|
||||||
* @extends {BaseManager}
|
* @extends {BaseGuildEmojiManager}
|
||||||
*/
|
*/
|
||||||
class GuildEmojiManager extends BaseManager {
|
class GuildEmojiManager extends BaseGuildEmojiManager {
|
||||||
constructor(guild, iterable) {
|
constructor(guild, iterable) {
|
||||||
super(guild.client, iterable, GuildEmoji);
|
super(guild.client, iterable);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The guild this manager belongs to
|
* The guild this manager belongs to
|
||||||
* @type {Guild}
|
* @type {Guild}
|
||||||
@@ -22,12 +20,6 @@ class GuildEmojiManager extends BaseManager {
|
|||||||
this.guild = guild;
|
this.guild = guild;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* The cache of GuildEmojis
|
|
||||||
* @type {Collection<Snowflake, GuildEmoji>}
|
|
||||||
* @name GuildEmojiManager#cache
|
|
||||||
*/
|
|
||||||
|
|
||||||
add(data, cache) {
|
add(data, cache) {
|
||||||
return super.add(data, cache, { extras: [this.guild] });
|
return super.add(data, cache, { extras: [this.guild] });
|
||||||
}
|
}
|
||||||
@@ -74,62 +66,6 @@ class GuildEmojiManager extends BaseManager {
|
|||||||
.emojis.post({ data, reason })
|
.emojis.post({ data, reason })
|
||||||
.then(emoji => this.client.actions.GuildEmojiCreate.handle(this.guild, emoji).emoji);
|
.then(emoji => this.client.actions.GuildEmojiCreate.handle(this.guild, emoji).emoji);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Data that can be resolved into an GuildEmoji object. This can be:
|
|
||||||
* * A custom emoji ID
|
|
||||||
* * A GuildEmoji object
|
|
||||||
* * A ReactionEmoji object
|
|
||||||
* @typedef {Snowflake|GuildEmoji|ReactionEmoji} EmojiResolvable
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Resolves an EmojiResolvable to an Emoji object.
|
|
||||||
* @param {EmojiResolvable} emoji The Emoji resolvable to identify
|
|
||||||
* @returns {?GuildEmoji}
|
|
||||||
*/
|
|
||||||
resolve(emoji) {
|
|
||||||
if (emoji instanceof ReactionEmoji) return super.resolve(emoji.id);
|
|
||||||
return super.resolve(emoji);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Resolves an EmojiResolvable to an Emoji ID string.
|
|
||||||
* @param {EmojiResolvable} emoji The Emoji resolvable to identify
|
|
||||||
* @returns {?Snowflake}
|
|
||||||
*/
|
|
||||||
resolveID(emoji) {
|
|
||||||
if (emoji instanceof ReactionEmoji) return emoji.id;
|
|
||||||
return super.resolveID(emoji);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Data that can be resolved to give an emoji identifier. This can be:
|
|
||||||
* * The unicode representation of an emoji
|
|
||||||
* * The `<a:name:id>`, `<:name:id>`, `:name:id` or `a:name:id` emoji identifier string of an emoji
|
|
||||||
* * An EmojiResolvable
|
|
||||||
* @typedef {string|EmojiResolvable} EmojiIdentifierResolvable
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Resolves an EmojiResolvable to an emoji identifier.
|
|
||||||
* @param {EmojiIdentifierResolvable} emoji The emoji resolvable to resolve
|
|
||||||
* @returns {?string}
|
|
||||||
*/
|
|
||||||
resolveIdentifier(emoji) {
|
|
||||||
const emojiResolvable = this.resolve(emoji);
|
|
||||||
if (emojiResolvable) return emojiResolvable.identifier;
|
|
||||||
if (emoji instanceof ReactionEmoji) return emoji.identifier;
|
|
||||||
if (typeof emoji === 'string') {
|
|
||||||
const res = parseEmoji(emoji);
|
|
||||||
if (res && res.name.length) {
|
|
||||||
emoji = `${res.animated ? 'a:' : ''}${res.name}${res.id ? `:${res.id}` : ''}`;
|
|
||||||
}
|
|
||||||
if (!emoji.includes('%')) return encodeURIComponent(emoji);
|
|
||||||
else return emoji;
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = GuildEmojiManager;
|
module.exports = GuildEmojiManager;
|
||||||
|
|||||||
20
typings/index.d.ts
vendored
20
typings/index.d.ts
vendored
@@ -199,7 +199,7 @@ declare module 'discord.js' {
|
|||||||
private _validateOptions(options?: ClientOptions): void;
|
private _validateOptions(options?: ClientOptions): void;
|
||||||
|
|
||||||
public channels: ChannelManager;
|
public channels: ChannelManager;
|
||||||
public readonly emojis: GuildEmojiManager;
|
public readonly emojis: BaseGuildEmojiManager;
|
||||||
public guilds: GuildManager;
|
public guilds: GuildManager;
|
||||||
public readyAt: Date | null;
|
public readyAt: Date | null;
|
||||||
public readonly readyTimestamp: number | null;
|
public readonly readyTimestamp: number | null;
|
||||||
@@ -1870,11 +1870,6 @@ declare module 'discord.js' {
|
|||||||
|
|
||||||
//#region Managers
|
//#region Managers
|
||||||
|
|
||||||
export class ChannelManager extends BaseManager<Snowflake, Channel, ChannelResolvable> {
|
|
||||||
constructor(client: Client, iterable: Iterable<any>);
|
|
||||||
public fetch(id: Snowflake, cache?: boolean, force?: boolean): Promise<Channel>;
|
|
||||||
}
|
|
||||||
|
|
||||||
export abstract class BaseManager<K, Holds, R> {
|
export abstract class BaseManager<K, Holds, R> {
|
||||||
constructor(client: Client, iterable: Iterable<any>, holds: Constructable<Holds>, cacheType: Collection<K, Holds>);
|
constructor(client: Client, iterable: Iterable<any>, holds: Constructable<Holds>, cacheType: Collection<K, Holds>);
|
||||||
public holds: Constructable<Holds>;
|
public holds: Constructable<Holds>;
|
||||||
@@ -1887,6 +1882,16 @@ declare module 'discord.js' {
|
|||||||
public valueOf(): Collection<K, Holds>;
|
public valueOf(): Collection<K, Holds>;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export class BaseGuildEmojiManager extends BaseManager<Snowflake, GuildEmoji, EmojiResolvable> {
|
||||||
|
constructor(client: Client, iterable?: Iterable<any>);
|
||||||
|
public resolveIdentifier(emoji: EmojiIdentifierResolvable): string | null;
|
||||||
|
}
|
||||||
|
|
||||||
|
export class ChannelManager extends BaseManager<Snowflake, Channel, ChannelResolvable> {
|
||||||
|
constructor(client: Client, iterable: Iterable<any>);
|
||||||
|
public fetch(id: Snowflake, cache?: boolean, force?: boolean): Promise<Channel>;
|
||||||
|
}
|
||||||
|
|
||||||
export class GuildChannelManager extends BaseManager<Snowflake, GuildChannel, GuildChannelResolvable> {
|
export class GuildChannelManager extends BaseManager<Snowflake, GuildChannel, GuildChannelResolvable> {
|
||||||
constructor(guild: Guild, iterable?: Iterable<any>);
|
constructor(guild: Guild, iterable?: Iterable<any>);
|
||||||
public guild: Guild;
|
public guild: Guild;
|
||||||
@@ -1899,7 +1904,7 @@ declare module 'discord.js' {
|
|||||||
): Promise<TextChannel | VoiceChannel | CategoryChannel>;
|
): Promise<TextChannel | VoiceChannel | CategoryChannel>;
|
||||||
}
|
}
|
||||||
|
|
||||||
export class GuildEmojiManager extends BaseManager<Snowflake, GuildEmoji, EmojiResolvable> {
|
export class GuildEmojiManager extends BaseGuildEmojiManager {
|
||||||
constructor(guild: Guild, iterable?: Iterable<any>);
|
constructor(guild: Guild, iterable?: Iterable<any>);
|
||||||
public guild: Guild;
|
public guild: Guild;
|
||||||
public create(
|
public create(
|
||||||
@@ -1907,7 +1912,6 @@ declare module 'discord.js' {
|
|||||||
name: string,
|
name: string,
|
||||||
options?: GuildEmojiCreateOptions,
|
options?: GuildEmojiCreateOptions,
|
||||||
): Promise<GuildEmoji>;
|
): Promise<GuildEmoji>;
|
||||||
public resolveIdentifier(emoji: EmojiIdentifierResolvable): string | null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export class GuildEmojiRoleManager {
|
export class GuildEmojiRoleManager {
|
||||||
|
|||||||
Reference in New Issue
Block a user