mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-16 11:33:30 +01:00
fix(ForumChannel): Implement missing properties and methods (#8662)
* fix(ForumChannel): implement missing properties and methods * refactor(ForumChannel): remove redundant default * docs(ForumChannel): remove superfluous wording Co-authored-by: kodiakhq[bot] <49736102+kodiakhq[bot]@users.noreply.github.com>
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
const GuildChannel = require('./GuildChannel');
|
const GuildChannel = require('./GuildChannel');
|
||||||
|
const TextBasedChannel = require('./interfaces/TextBasedChannel');
|
||||||
const GuildForumThreadManager = require('../managers/GuildForumThreadManager');
|
const GuildForumThreadManager = require('../managers/GuildForumThreadManager');
|
||||||
const { transformAPIGuildForumTag, transformAPIGuildDefaultReaction } = require('../util/Channels');
|
const { transformAPIGuildForumTag, transformAPIGuildDefaultReaction } = require('../util/Channels');
|
||||||
|
|
||||||
@@ -94,6 +95,34 @@ class ForumChannel extends GuildChannel {
|
|||||||
} else {
|
} else {
|
||||||
this.rateLimitPerUser ??= null;
|
this.rateLimitPerUser ??= null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ('default_auto_archive_duration' in data) {
|
||||||
|
/**
|
||||||
|
* The default auto archive duration for newly created threads in this channel.
|
||||||
|
* @type {?ThreadAutoArchiveDuration}
|
||||||
|
*/
|
||||||
|
this.defaultAutoArchiveDuration = data.default_auto_archive_duration;
|
||||||
|
} else {
|
||||||
|
this.defaultAutoArchiveDuration ??= null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ('nsfw' in data) {
|
||||||
|
/**
|
||||||
|
* If this channel is considered NSFW.
|
||||||
|
* @type {boolean}
|
||||||
|
*/
|
||||||
|
this.nsfw = data.nsfw;
|
||||||
|
} else {
|
||||||
|
this.nsfw ??= false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ('topic' in data) {
|
||||||
|
/**
|
||||||
|
* The topic of this channel.
|
||||||
|
* @type {?string}
|
||||||
|
*/
|
||||||
|
this.topic = data.topic;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -127,14 +156,72 @@ class ForumChannel extends GuildChannel {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the rate limit per user (slowmode) for this channel
|
* Creates an invite to this guild channel.
|
||||||
* @param {?number} rateLimitPerUser The rate limit to set on this channel
|
* @param {CreateInviteOptions} [options={}] The options for creating the invite
|
||||||
* @param {string} [reason] Reason for changing the rate limit
|
* @returns {Promise<Invite>}
|
||||||
|
* @example
|
||||||
|
* // Create an invite to a channel
|
||||||
|
* channel.createInvite()
|
||||||
|
* .then(invite => console.log(`Created an invite with a code of ${invite.code}`))
|
||||||
|
* .catch(console.error);
|
||||||
|
*/
|
||||||
|
createInvite(options) {
|
||||||
|
return this.guild.invites.create(this.id, options);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetches a collection of invites to this guild channel.
|
||||||
|
* Resolves with a collection mapping invites by their codes.
|
||||||
|
* @param {boolean} [cache=true] Whether to cache the fetched invites
|
||||||
|
* @returns {Promise<Collection<string, Invite>>}
|
||||||
|
*/
|
||||||
|
fetchInvites(cache) {
|
||||||
|
return this.guild.invites.fetch({ channelId: this.id, cache });
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the default auto archive duration for all newly created threads in this channel.
|
||||||
|
* @param {ThreadAutoArchiveDuration} defaultAutoArchiveDuration The new default auto archive duration
|
||||||
|
* @param {string} [reason] Reason for changing the channel's default auto archive duration
|
||||||
* @returns {Promise<ForumChannel>}
|
* @returns {Promise<ForumChannel>}
|
||||||
*/
|
*/
|
||||||
setRateLimitPerUser(rateLimitPerUser, reason) {
|
setDefaultAutoArchiveDuration(defaultAutoArchiveDuration, reason) {
|
||||||
return this.edit({ rateLimitPerUser, reason });
|
return this.edit({ defaultAutoArchiveDuration, reason });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets a new topic for the guild channel.
|
||||||
|
* @param {?string} topic The new topic for the guild channel
|
||||||
|
* @param {string} [reason] Reason for changing the guild channel's topic
|
||||||
|
* @returns {Promise<ForumChannel>}
|
||||||
|
* @example
|
||||||
|
* // Set a new channel topic
|
||||||
|
* channel.setTopic('needs more rate limiting')
|
||||||
|
* .then(newChannel => console.log(`Channel's new topic is ${newChannel.topic}`))
|
||||||
|
* .catch(console.error);
|
||||||
|
*/
|
||||||
|
setTopic(topic, reason) {
|
||||||
|
return this.edit({ topic, reason });
|
||||||
|
}
|
||||||
|
|
||||||
|
// These are here only for documentation purposes - they are implemented by TextBasedChannel
|
||||||
|
/* eslint-disable no-empty-function */
|
||||||
|
createWebhook() {}
|
||||||
|
fetchWebhooks() {}
|
||||||
|
setNSFW() {}
|
||||||
|
setRateLimitPerUser() {}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TextBasedChannel.applyToClass(ForumChannel, true, [
|
||||||
|
'send',
|
||||||
|
'lastMessage',
|
||||||
|
'lastPinAt',
|
||||||
|
'bulkDelete',
|
||||||
|
'sendTyping',
|
||||||
|
'createMessageCollector',
|
||||||
|
'awaitMessages',
|
||||||
|
'createMessageComponentCollector',
|
||||||
|
'awaitMessageComponent',
|
||||||
|
]);
|
||||||
|
|
||||||
module.exports = ForumChannel;
|
module.exports = ForumChannel;
|
||||||
|
|||||||
23
packages/discord.js/typings/index.d.ts
vendored
23
packages/discord.js/typings/index.d.ts
vendored
@@ -2077,18 +2077,37 @@ export interface DefaultReactionEmoji {
|
|||||||
name: string | null;
|
name: string | null;
|
||||||
}
|
}
|
||||||
|
|
||||||
export class ForumChannel extends GuildChannel {
|
export class ForumChannel extends TextBasedChannelMixin(GuildChannel, true, [
|
||||||
|
'send',
|
||||||
|
'lastMessage',
|
||||||
|
'lastPinAt',
|
||||||
|
'bulkDelete',
|
||||||
|
'sendTyping',
|
||||||
|
'createMessageCollector',
|
||||||
|
'awaitMessages',
|
||||||
|
'createMessageComponentCollector',
|
||||||
|
'awaitMessageComponent',
|
||||||
|
]) {
|
||||||
public type: ChannelType.GuildForum;
|
public type: ChannelType.GuildForum;
|
||||||
public threads: GuildForumThreadManager;
|
public threads: GuildForumThreadManager;
|
||||||
public availableTags: GuildForumTag[];
|
public availableTags: GuildForumTag[];
|
||||||
public defaultReactionEmoji: DefaultReactionEmoji | null;
|
public defaultReactionEmoji: DefaultReactionEmoji | null;
|
||||||
public defaultThreadRateLimitPerUser: number | null;
|
public defaultThreadRateLimitPerUser: number | null;
|
||||||
public rateLimitPerUser: number | null;
|
public rateLimitPerUser: number | null;
|
||||||
|
public defaultAutoArchiveDuration: ThreadAutoArchiveDuration | null;
|
||||||
|
public nsfw: boolean;
|
||||||
|
public topic: string | null;
|
||||||
|
|
||||||
public setAvailableTags(tags: GuildForumTagData[], reason?: string): Promise<this>;
|
public setAvailableTags(tags: GuildForumTagData[], reason?: string): Promise<this>;
|
||||||
public setDefaultReactionEmoji(emojiId: DefaultReactionEmoji | null, reason?: string): Promise<this>;
|
public setDefaultReactionEmoji(emojiId: DefaultReactionEmoji | null, reason?: string): Promise<this>;
|
||||||
public setDefaultThreadRateLimitPerUser(rateLimit: number, reason?: string): Promise<this>;
|
public setDefaultThreadRateLimitPerUser(rateLimit: number, reason?: string): Promise<this>;
|
||||||
public setRateLimitPerUser(rateLimitPerUser: number | null, reason?: string): Promise<this>;
|
public createInvite(options?: CreateInviteOptions): Promise<Invite>;
|
||||||
|
public fetchInvites(cache?: boolean): Promise<Collection<string, Invite>>;
|
||||||
|
public setDefaultAutoArchiveDuration(
|
||||||
|
defaultAutoArchiveDuration: ThreadAutoArchiveDuration,
|
||||||
|
reason?: string,
|
||||||
|
): Promise<this>;
|
||||||
|
public setTopic(topic: string | null, reason?: string): Promise<this>;
|
||||||
}
|
}
|
||||||
|
|
||||||
export class PermissionOverwrites extends Base {
|
export class PermissionOverwrites extends Base {
|
||||||
|
|||||||
Reference in New Issue
Block a user