mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-10 08:33:30 +01:00
* feat: add stage channel type * feat: initialise stage channel structure * feat: add STAGE_MODERATOR permissions bitfield * fix: typo in permissions * fix(Channel): type selection logic * feat: add rtcRegion to StageChannel and VoiceChannel * feat: rtc region editing for stage and voice channels * feat: stage channel userLimit * feat: add stage channels to exports * feat: add computed properties to stage channel * feat(VoiceState): include stage channel in docs * feat: allow ability to join stage channels * feat(StageChannel): join and leave methods * docs: add StageChannel link in GuildChannel docs * feat(VoiceState): suppress and requestToSpeakTimestamp * feat(StageChannel): setRequestToSpeak * refactor(StageChannel): update setRequestToSpeak * feat(VoiceState): add moveToSpeakers and moveToAudience * feat(VoiceState): add methods to move in/out of speakers * feat(VoiceState): add stage channel sanity checks * feat(Permissions): add REQUEST_TO_SPEAK * feat(VoiceState): simpler methods * docs(VoiceState): add documentation for new methods * refactor: remove unused error message * chore: remove debug statements * chore: revert changes to package-lock.json * docs(VoiceState): clarify suppress * docs(VoiceState): add missing @type param * feat(StageChannel): remove nsfw property * fix(VoiceState): check permissions in channel Co-authored-by: Advaith <advaithj1@gmail.com> * fix(VoiceState): instantiate error with new Co-authored-by: BannerBomb <BannerBomb55@gmail.com> * refactor(VoiceState): more readable API route builder Co-authored-by: Sugden <28943913+NotSugden@users.noreply.github.com> * style(VoiceState): fix lint errors * docs(VoiceState): add example usage for new methods * docs: setRTCRegion examples * chore: update typings * fix(VoiceState): calculate permissions for self * refactor(VoiceState): tidy up implementation * Update src/structures/VoiceState.js Co-authored-by: Jan <66554238+vaporox@users.noreply.github.com> * refactor: vaporox's suggestions * style(VoiceState): fix linter errors * chore: update typings * chore: remove unused error message * refactor(VoiceState): use optional chaining Co-authored-by: Sugden <28943913+NotSugden@users.noreply.github.com> * chore: move getters below constructor in typings * refactor(StageChannel): optional chaining Co-authored-by: Sugden <28943913+NotSugden@users.noreply.github.com> * style(VoiceState): fix lint errors * docs: fix incorrect types Co-authored-by: izexi <43889168+izexi@users.noreply.github.com> * Update src/structures/VoiceChannel.js Co-authored-by: izexi <43889168+izexi@users.noreply.github.com> * Update src/structures/VoiceChannel.js Co-authored-by: izexi <43889168+izexi@users.noreply.github.com> * refactor(VoiceState): use optional chaining Co-authored-by: Sugden <28943913+NotSugden@users.noreply.github.com> * refactor(StageChannel): remove permission override check in joinable * refactor: make ChannelTypes a proper enum * Use createEnum Co-authored-by: izexi <43889168+izexi@users.noreply.github.com> * chore: remove unused code from Constants * refactor(StageChannel): remove unnecessary getters * chore: update typings * refactor: introduce BaseGuildVoiceChannel class * refactor(VoiceChannel): reduce code duplication * feat: export BaseGuildVoiceChannel * chore: update typings * docs: fix typos * refactor: move setRTCRegion to BaseGuildVoiceChannel * feat(VoiceState): remove permission checks * chore: update typings * Apply suggestions from code review Co-authored-by: Sugden <28943913+NotSugden@users.noreply.github.com> Co-authored-by: Jan <66554238+vaporox@users.noreply.github.com> * chore: update esm exports and typings * Update src/structures/VoiceState.js Co-authored-by: Vlad Frangu <kingdgrizzle@gmail.com> Co-authored-by: Advaith <advaithj1@gmail.com> Co-authored-by: BannerBomb <BannerBomb55@gmail.com> Co-authored-by: Sugden <28943913+NotSugden@users.noreply.github.com> Co-authored-by: Jan <66554238+vaporox@users.noreply.github.com> Co-authored-by: izexi <43889168+izexi@users.noreply.github.com> Co-authored-by: Vlad Frangu <kingdgrizzle@gmail.com>
168 lines
4.4 KiB
JavaScript
168 lines
4.4 KiB
JavaScript
'use strict';
|
|
|
|
const Base = require('./Base');
|
|
const { ChannelTypes } = require('../util/Constants');
|
|
const Snowflake = require('../util/Snowflake');
|
|
|
|
/**
|
|
* Represents any channel on Discord.
|
|
* @extends {Base}
|
|
* @abstract
|
|
*/
|
|
class Channel extends Base {
|
|
constructor(client, data) {
|
|
super(client);
|
|
|
|
const type = ChannelTypes[data.type];
|
|
/**
|
|
* The type of the channel, either:
|
|
* * `dm` - a DM channel
|
|
* * `text` - a guild text channel
|
|
* * `voice` - a guild voice channel
|
|
* * `category` - a guild category channel
|
|
* * `news` - a guild news channel
|
|
* * `store` - a guild store channel
|
|
* * `stage` - a guild stage channel
|
|
* * `unknown` - a generic channel of unknown type, could be Channel or GuildChannel
|
|
* @type {string}
|
|
*/
|
|
this.type = type ? type.toLowerCase() : 'unknown';
|
|
|
|
/**
|
|
* Whether the channel has been deleted
|
|
* @type {boolean}
|
|
*/
|
|
this.deleted = false;
|
|
|
|
if (data) this._patch(data);
|
|
}
|
|
|
|
_patch(data) {
|
|
/**
|
|
* The unique ID of the channel
|
|
* @type {Snowflake}
|
|
*/
|
|
this.id = data.id;
|
|
}
|
|
|
|
/**
|
|
* The timestamp the channel was created at
|
|
* @type {number}
|
|
* @readonly
|
|
*/
|
|
get createdTimestamp() {
|
|
return Snowflake.deconstruct(this.id).timestamp;
|
|
}
|
|
|
|
/**
|
|
* The time the channel was created at
|
|
* @type {Date}
|
|
* @readonly
|
|
*/
|
|
get createdAt() {
|
|
return new Date(this.createdTimestamp);
|
|
}
|
|
|
|
/**
|
|
* When concatenated with a string, this automatically returns the channel's mention instead of the Channel object.
|
|
* @returns {string}
|
|
* @example
|
|
* // Logs: Hello from <#123456789012345678>!
|
|
* console.log(`Hello from ${channel}!`);
|
|
*/
|
|
toString() {
|
|
return `<#${this.id}>`;
|
|
}
|
|
|
|
/**
|
|
* Deletes this channel.
|
|
* @returns {Promise<Channel>}
|
|
* @example
|
|
* // Delete the channel
|
|
* channel.delete()
|
|
* .then(console.log)
|
|
* .catch(console.error);
|
|
*/
|
|
delete() {
|
|
return this.client.api
|
|
.channels(this.id)
|
|
.delete()
|
|
.then(() => this);
|
|
}
|
|
|
|
/**
|
|
* Fetches this channel.
|
|
* @param {boolean} [force=false] Whether to skip the cache check and request the API
|
|
* @returns {Promise<Channel>}
|
|
*/
|
|
fetch(force = false) {
|
|
return this.client.channels.fetch(this.id, true, force);
|
|
}
|
|
|
|
/**
|
|
* Indicates whether this channel is text-based.
|
|
* @returns {boolean}
|
|
*/
|
|
isText() {
|
|
return 'messages' in this;
|
|
}
|
|
|
|
static create(client, data, guild) {
|
|
const Structures = require('../util/Structures');
|
|
let channel;
|
|
if (!data.guild_id && !guild) {
|
|
if ((data.recipients && data.type !== ChannelTypes.GROUP) || data.type === ChannelTypes.DM) {
|
|
const DMChannel = Structures.get('DMChannel');
|
|
channel = new DMChannel(client, data);
|
|
} else if (data.type === ChannelTypes.GROUP) {
|
|
const PartialGroupDMChannel = require('./PartialGroupDMChannel');
|
|
channel = new PartialGroupDMChannel(client, data);
|
|
}
|
|
} else {
|
|
guild = guild || client.guilds.cache.get(data.guild_id);
|
|
if (guild) {
|
|
switch (data.type) {
|
|
case ChannelTypes.TEXT: {
|
|
const TextChannel = Structures.get('TextChannel');
|
|
channel = new TextChannel(guild, data);
|
|
break;
|
|
}
|
|
case ChannelTypes.VOICE: {
|
|
const VoiceChannel = Structures.get('VoiceChannel');
|
|
channel = new VoiceChannel(guild, data);
|
|
break;
|
|
}
|
|
case ChannelTypes.CATEGORY: {
|
|
const CategoryChannel = Structures.get('CategoryChannel');
|
|
channel = new CategoryChannel(guild, data);
|
|
break;
|
|
}
|
|
case ChannelTypes.NEWS: {
|
|
const NewsChannel = Structures.get('NewsChannel');
|
|
channel = new NewsChannel(guild, data);
|
|
break;
|
|
}
|
|
case ChannelTypes.STORE: {
|
|
const StoreChannel = Structures.get('StoreChannel');
|
|
channel = new StoreChannel(guild, data);
|
|
break;
|
|
}
|
|
case ChannelTypes.STAGE: {
|
|
const StageChannel = Structures.get('StageChannel');
|
|
channel = new StageChannel(guild, data);
|
|
break;
|
|
}
|
|
}
|
|
if (channel) guild.channels.cache.set(channel.id, channel);
|
|
}
|
|
}
|
|
return channel;
|
|
}
|
|
|
|
toJSON(...props) {
|
|
return super.toJSON({ createdTimestamp: true }, ...props);
|
|
}
|
|
}
|
|
|
|
module.exports = Channel;
|