fix jsdoc

This commit is contained in:
Snowflake107 2021-04-21 14:55:44 +05:45
parent d3fdc045e2
commit 32a7be23a1
5 changed files with 132 additions and 70 deletions

View file

@ -26,16 +26,7 @@ import YouTube from 'youtube-sr';
const SoundCloud = new SoundCloudClient(); const SoundCloud = new SoundCloudClient();
export class Player extends EventEmitter { export class Player extends EventEmitter {
/**
* The discord client that instantiated this player
* @type {DiscordClient}
*/
public client: Client; public client: Client;
/**
* The player options
* @type {PlayerOptions}
*/
public options: PlayerOptionsType; public options: PlayerOptionsType;
/** /**
@ -45,7 +36,7 @@ export class Player extends EventEmitter {
/** /**
* The collection of queues in this player * The collection of queues in this player
* @type {DiscordCollection} * @type {DiscordCollection<Queue>}
*/ */
public queues = new Collection<Snowflake, Queue>(); public queues = new Collection<Snowflake, Queue>();
private _resultsCollectors = new Collection<string, Collector<Snowflake, Message>>(); private _resultsCollectors = new Collection<string, Collector<Snowflake, Message>>();
@ -53,7 +44,7 @@ export class Player extends EventEmitter {
/** /**
* The extractor model collection * The extractor model collection
* @type {DiscordCollection} * @type {DiscordCollection<ExtractorModel>}
*/ */
public Extractors = new Collection<string, ExtractorModel>(); public Extractors = new Collection<string, ExtractorModel>();
@ -65,16 +56,30 @@ export class Player extends EventEmitter {
constructor(client: Client, options?: PlayerOptionsType) { constructor(client: Client, options?: PlayerOptionsType) {
super(); super();
/**
* The discord client that instantiated this player
* @name Player#client
* @type {DiscordClient}
* @readonly
*/
Object.defineProperty(this, 'client', { Object.defineProperty(this, 'client', {
value: client, value: client,
enumerable: false enumerable: false
}); });
/**
* The player options
* @type {PlayerOptions}
*/
this.options = Object.assign({}, PlayerOptions, options ?? {}); this.options = Object.assign({}, PlayerOptions, options ?? {});
// check FFmpeg // check FFmpeg
void Util.alertFFmpeg(); void Util.alertFFmpeg();
/**
* Audio filters
* @type {Object}
*/
this.filters = AudioFilters; this.filters = AudioFilters;
this.client.on('voiceStateUpdate', (o, n) => void this._handleVoiceStateUpdate(o, n)); this.client.on('voiceStateUpdate', (o, n) => void this._handleVoiceStateUpdate(o, n));
@ -86,6 +91,10 @@ export class Player extends EventEmitter {
} }
} }
/**
* The audio filters
* @returns {Object}
*/
static get AudioFilters(): typeof AudioFilters { static get AudioFilters(): typeof AudioFilters {
return AudioFilters; return AudioFilters;
} }
@ -94,6 +103,7 @@ export class Player extends EventEmitter {
* Define custom extractor in this player * Define custom extractor in this player
* @param {String} extractorName The extractor name * @param {String} extractorName The extractor name
* @param {any} extractor The extractor itself * @param {any} extractor The extractor itself
* @returns {Player}
*/ */
use(extractorName: string, extractor: any): Player { use(extractorName: string, extractor: any): Player {
if (!extractorName) throw new PlayerError('Missing extractor name!', 'PlayerExtractorError'); if (!extractorName) throw new PlayerError('Missing extractor name!', 'PlayerExtractorError');
@ -113,6 +123,7 @@ export class Player extends EventEmitter {
/** /**
* Remove existing extractor from this player * Remove existing extractor from this player
* @param {String} extractorName The extractor name * @param {String} extractorName The extractor name
* @returns {Boolean}
*/ */
unuse(extractorName: string): boolean { unuse(extractorName: string): boolean {
if (!extractorName) throw new PlayerError('Missing extractor name!', 'PlayerExtractorError'); if (!extractorName) throw new PlayerError('Missing extractor name!', 'PlayerExtractorError');
@ -369,6 +380,7 @@ export class Player extends EventEmitter {
* @param {string|Track} query Search query, can be `Player.Track` instance * @param {string|Track} query Search query, can be `Player.Track` instance
* @param {Boolean} [firstResult] If it should play the first result * @param {Boolean} [firstResult] If it should play the first result
* @example await player.play(message, "never gonna give you up", true) * @example await player.play(message, "never gonna give you up", true)
* @returns {Promise<void>}
*/ */
async play(message: Message, query: string | Track, firstResult?: boolean): Promise<void> { async play(message: Message, query: string | Track, firstResult?: boolean): Promise<void> {
if (!message) throw new PlayerError('Play function needs message'); if (!message) throw new PlayerError('Play function needs message');
@ -451,6 +463,7 @@ export class Player extends EventEmitter {
/** /**
* Checks if this player is playing in a server * Checks if this player is playing in a server
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @returns {Boolean}
*/ */
isPlaying(message: Message): boolean { isPlaying(message: Message): boolean {
return this.queues.some((g) => g.guildID === message.guild.id); return this.queues.some((g) => g.guildID === message.guild.id);
@ -459,6 +472,7 @@ export class Player extends EventEmitter {
/** /**
* Returns guild queue object * Returns guild queue object
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @returns {Queue}
*/ */
getQueue(message: Message): Queue { getQueue(message: Message): Queue {
return this.queues.find((g) => g.guildID === message.guild.id); return this.queues.find((g) => g.guildID === message.guild.id);
@ -468,6 +482,7 @@ export class Player extends EventEmitter {
* Sets audio filters in this player * Sets audio filters in this player
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @param {QueueFilters} newFilters Audio filters object * @param {QueueFilters} newFilters Audio filters object
* @returns {Promise<void>}
*/ */
setFilters(message: Message, newFilters: QueueFilters): Promise<void> { setFilters(message: Message, newFilters: QueueFilters): Promise<void> {
return new Promise((resolve) => { return new Promise((resolve) => {
@ -503,6 +518,7 @@ export class Player extends EventEmitter {
* Sets track position * Sets track position
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @param {Number} time Time in ms to set * @param {Number} time Time in ms to set
* @returns {Promise<void>}
*/ */
setPosition(message: Message, time: number): Promise<void> { setPosition(message: Message, time: number): Promise<void> {
return new Promise((resolve) => { return new Promise((resolve) => {
@ -526,6 +542,7 @@ export class Player extends EventEmitter {
* Sets track position * Sets track position
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @param {Number} time Time in ms to set * @param {Number} time Time in ms to set
* @returns {Promise<void>}
*/ */
seek(message: Message, time: number): Promise<void> { seek(message: Message, time: number): Promise<void> {
return this.setPosition(message, time); return this.setPosition(message, time);
@ -534,6 +551,7 @@ export class Player extends EventEmitter {
/** /**
* Skips current track * Skips current track
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @returns {Boolean}
*/ */
skip(message: Message): boolean { skip(message: Message): boolean {
const queue = this.getQueue(message); const queue = this.getQueue(message);
@ -556,6 +574,7 @@ export class Player extends EventEmitter {
* Moves to a new voice channel * Moves to a new voice channel
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @param {DiscordVoiceChannel} channel New voice channel to move to * @param {DiscordVoiceChannel} channel New voice channel to move to
* @returns {Boolean}
*/ */
moveTo(message: Message, channel?: VoiceChannel): boolean { moveTo(message: Message, channel?: VoiceChannel): boolean {
if (!channel || channel.type !== 'voice') return; if (!channel || channel.type !== 'voice') return;
@ -582,6 +601,7 @@ export class Player extends EventEmitter {
/** /**
* Pause the playback * Pause the playback
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @returns {Boolean}
*/ */
pause(message: Message): boolean { pause(message: Message): boolean {
const queue = this.getQueue(message); const queue = this.getQueue(message);
@ -602,6 +622,7 @@ export class Player extends EventEmitter {
/** /**
* Resume the playback * Resume the playback
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @returns {Boolean}
*/ */
resume(message: Message): boolean { resume(message: Message): boolean {
const queue = this.getQueue(message); const queue = this.getQueue(message);
@ -622,6 +643,7 @@ export class Player extends EventEmitter {
/** /**
* Stops the player * Stops the player
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @returns {Boolean}
*/ */
stop(message: Message): boolean { stop(message: Message): boolean {
const queue = this.getQueue(message); const queue = this.getQueue(message);
@ -647,6 +669,7 @@ export class Player extends EventEmitter {
* Sets music volume * Sets music volume
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @param {Number} percent The volume percentage/amount to set * @param {Number} percent The volume percentage/amount to set
* @returns {Boolean}
*/ */
setVolume(message: Message, percent: number): boolean { setVolume(message: Message, percent: number): boolean {
const queue = this.getQueue(message); const queue = this.getQueue(message);
@ -668,6 +691,7 @@ export class Player extends EventEmitter {
/** /**
* Clears the queue * Clears the queue
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @returns {Boolean}
*/ */
clearQueue(message: Message): boolean { clearQueue(message: Message): boolean {
const queue = this.getQueue(message); const queue = this.getQueue(message);
@ -684,6 +708,7 @@ export class Player extends EventEmitter {
/** /**
* Plays previous track * Plays previous track
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @returns {Boolean}
*/ */
back(message: Message): boolean { back(message: Message): boolean {
const queue = this.getQueue(message); const queue = this.getQueue(message);
@ -724,6 +749,7 @@ export class Player extends EventEmitter {
* Sets loop mode * Sets loop mode
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @param {Boolean} enabled If it should enable the loop mode * @param {Boolean} enabled If it should enable the loop mode
* @returns {Boolean}
*/ */
setLoopMode(message: Message, enabled: boolean): boolean { setLoopMode(message: Message, enabled: boolean): boolean {
const queue = this.getQueue(message); const queue = this.getQueue(message);
@ -740,6 +766,7 @@ export class Player extends EventEmitter {
/** /**
* Returns currently playing track * Returns currently playing track
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @returns {Track}
*/ */
nowPlaying(message: Message): Track { nowPlaying(message: Message): Track {
const queue = this.getQueue(message); const queue = this.getQueue(message);
@ -754,6 +781,7 @@ export class Player extends EventEmitter {
/** /**
* Shuffles the queue * Shuffles the queue
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @returns {Queue}
*/ */
shuffle(message: Message): Queue { shuffle(message: Message): Queue {
const queue = this.getQueue(message); const queue = this.getQueue(message);
@ -778,6 +806,7 @@ export class Player extends EventEmitter {
* Removes specified track * Removes specified track
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @param {Track|number} track The track object/id to remove * @param {Track|number} track The track object/id to remove
* @returns {Track}
*/ */
remove(message: Message, track: Track | number): Track { remove(message: Message, track: Track | number): Track {
const queue = this.getQueue(message); const queue = this.getQueue(message);
@ -806,6 +835,7 @@ export class Player extends EventEmitter {
* Returns time code of currently playing song * Returns time code of currently playing song
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @param {Boolean} [queueTime] If it should make the time code of the whole queue * @param {Boolean} [queueTime] If it should make the time code of the whole queue
* @returns {Object}
*/ */
getTimeCode(message: Message, queueTime?: boolean): { current: string; end: string } { getTimeCode(message: Message, queueTime?: boolean): { current: string; end: string } {
const queue = this.getQueue(message); const queue = this.getQueue(message);
@ -830,6 +860,7 @@ export class Player extends EventEmitter {
* Creates progressbar * Creates progressbar
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @param {PlayerProgressbarOptions} [options] Progressbar options * @param {PlayerProgressbarOptions} [options] Progressbar options
* @returns {String}
*/ */
createProgressBar(message: Message, options?: PlayerProgressbarOptions): string { createProgressBar(message: Message, options?: PlayerProgressbarOptions): string {
const queue = this.getQueue(message); const queue = this.getQueue(message);
@ -879,6 +910,7 @@ export class Player extends EventEmitter {
* @param {String} query Search query * @param {String} query Search query
* @example const lyrics = await player.lyrics("alan walker faded") * @example const lyrics = await player.lyrics("alan walker faded")
* message.channel.send(lyrics.lyrics); * message.channel.send(lyrics.lyrics);
* @returns {Promise<LyricsData>}
*/ */
async lyrics(query: string): Promise<LyricsData> { async lyrics(query: string): Promise<LyricsData> {
const extractor = Util.require('@discord-player/extractor'); const extractor = Util.require('@discord-player/extractor');
@ -894,6 +926,7 @@ export class Player extends EventEmitter {
* Toggle autoplay for youtube streams * Toggle autoplay for youtube streams
* @param {DiscordMessage} message The message object * @param {DiscordMessage} message The message object
* @param {Boolean} enable Enable/Disable autoplay * @param {Boolean} enable Enable/Disable autoplay
* @returns {boolean}
*/ */
setAutoPlay(message: Message, enable: boolean): boolean { setAutoPlay(message: Message, enable: boolean): boolean {
const queue = this.getQueue(message); const queue = this.getQueue(message);
@ -906,6 +939,7 @@ export class Player extends EventEmitter {
/** /**
* Player stats * Player stats
* @returns {PlayerStats}
*/ */
getStats(): PlayerStats { getStats(): PlayerStats {
return { return {

View file

@ -22,6 +22,7 @@ class ExtractorModel {
/** /**
* Method to handle requests from `Player.play()` * Method to handle requests from `Player.play()`
* @param {String} query Query to handle * @param {String} query Query to handle
* @returns {Promise<ExtractorModelData>}
*/ */
async handle(query: string): Promise<ExtractorModelData> { async handle(query: string): Promise<ExtractorModelData> {
const data = await this._raw.getInfo(query); const data = await this._raw.getInfo(query);
@ -42,6 +43,7 @@ class ExtractorModel {
/** /**
* Method used by Discord Player to validate query with this extractor * Method used by Discord Player to validate query with this extractor
* @param {String} query The query to validate * @param {String} query The query to validate
* @returns {Boolean}
*/ */
validate(query: string): boolean { validate(query: string): boolean {
return Boolean(this._raw.validate(query)); return Boolean(this._raw.validate(query));

View file

@ -6,9 +6,6 @@ import { Track } from './Track';
import { QueueFilters } from '../types/types'; import { QueueFilters } from '../types/types';
export class Queue extends EventEmitter { export class Queue extends EventEmitter {
/**
* The player that instantiated this Queue
*/
public player!: Player; public player!: Player;
public guildID: Snowflake; public guildID: Snowflake;
public voiceConnection?: VoiceConnection; public voiceConnection?: VoiceConnection;
@ -39,6 +36,12 @@ export class Queue extends EventEmitter {
constructor(player: Player, message: Message) { constructor(player: Player, message: Message) {
super(); super();
/**
* The player that instantiated this Queue
* @name Queue#player
* @type {Player}
* @readonly
*/
Object.defineProperty(this, 'player', { value: player, enumerable: false }); Object.defineProperty(this, 'player', { value: player, enumerable: false });
/** /**
@ -191,7 +194,7 @@ export class Queue extends EventEmitter {
/** /**
* String representation of this Queue * String representation of this Queue
* @type {String} * @returns {String}
*/ */
toString(): string { toString(): string {
return `<Queue ${this.guildID}>`; return `<Queue ${this.guildID}>`;

View file

@ -4,70 +4,16 @@ import { TrackData } from '../types/types';
import Queue from './Queue'; import Queue from './Queue';
export class Track { export class Track {
/**
* The player that instantiated this Track
* @type {Player}
*/
public player!: Player; public player!: Player;
/**
* Title of this track
* @type {String}
*/
public title!: string; public title!: string;
/**
* Description of this track
* @type {String}
*/
public description!: string; public description!: string;
/**
* Author of this track
* @type {String}
*/
public author!: string; public author!: string;
/**
* Link of this track
* @type {String}
*/
public url!: string; public url!: string;
/**
* Thumbnail of this track
* @type {String}
*/
public thumbnail!: string; public thumbnail!: string;
/**
* Duration of this track
* @type {String}
*/
public duration!: string; public duration!: string;
/**
* View count of this track
* @type {Number}
*/
public views!: number; public views!: number;
/**
* Person who requested this track
* @type {DiscordUser}
*/
public requestedBy!: User; public requestedBy!: User;
/**
* If this track belongs to a playlist
* @type {Boolean}
*/
public fromPlaylist!: boolean; public fromPlaylist!: boolean;
/**
* Raw data of this track
* @type {TrackData}
*/
public raw!: TrackData; public raw!: TrackData;
/** /**
@ -76,8 +22,74 @@ export class Track {
* @param {TrackData} data Track data * @param {TrackData} data Track data
*/ */
constructor(player: Player, data: TrackData) { constructor(player: Player, data: TrackData) {
/**
* The player that instantiated this Queue
* @name Track#player
* @type {Player}
* @readonly
*/
Object.defineProperty(this, 'player', { value: player, enumerable: false }); Object.defineProperty(this, 'player', { value: player, enumerable: false });
/**
* Title of this track
* @name Track#title
* @type {String}
*/
/**
* Description of this track
* @name Track#description
* @type {String}
*/
/**
* Author of this track
* @name Track#author
* @type {String}
*/
/**
* URL of this track
* @name Track#url
* @type {String}
*/
/**
* Thumbnail of this track
* @name Track#thumbnail
* @type {String}
*/
/**
* Duration of this track
* @name Track#duration
* @type {String}
*/
/**
* Views count of this track
* @name Track#views
* @type {Number}
*/
/**
* Person who requested this track
* @name Track#requestedBy
* @type {DiscordUser}
*/
/**
* If this track belongs to playlist
* @name Track#fromPlaylist
* @type {Boolean}
*/
/**
* Raw track data
* @name Track#raw
* @type {TrackData}
*/
void this._patch(data); void this._patch(data);
} }
@ -124,7 +136,7 @@ export class Track {
/** /**
* String representation of this track * String representation of this track
* @type {String} * @returns {String}
*/ */
toString(): string { toString(): string {
return `${this.title} by ${this.author}`; return `${this.title} by ${this.author}`;

View file

@ -25,6 +25,7 @@ export class Util {
/** /**
* Checks FFmpeg Version * Checks FFmpeg Version
* @param {Boolean} [force] If it should forcefully get the version * @param {Boolean} [force] If it should forcefully get the version
* @returns {String}
*/ */
static getFFmpegVersion(force?: boolean): string { static getFFmpegVersion(force?: boolean): string {
try { try {
@ -39,6 +40,7 @@ export class Util {
/** /**
* Checks FFmpeg * Checks FFmpeg
* @param {Boolean} [force] If it should forcefully get the version * @param {Boolean} [force] If it should forcefully get the version
* @returns {Boolean}
*/ */
static checkFFmpeg(force?: boolean): boolean { static checkFFmpeg(force?: boolean): boolean {
const version = Util.getFFmpegVersion(force); const version = Util.getFFmpegVersion(force);
@ -60,6 +62,7 @@ export class Util {
/** /**
* Resolves query type * Resolves query type
* @param {String} query The query * @param {String} query The query
* @returns {QueryType}
*/ */
static getQueryType(query: string): QueryType { static getQueryType(query: string): QueryType {
if (SoundcloudValidateURL(query) && !query.includes('/sets/')) return 'soundcloud_track'; if (SoundcloudValidateURL(query) && !query.includes('/sets/')) return 'soundcloud_track';
@ -80,6 +83,7 @@ export class Util {
/** /**
* Checks if the given string is url * Checks if the given string is url
* @param {String} str URL to check * @param {String} str URL to check
* @returns {Boolean}
*/ */
static isURL(str: string): boolean { static isURL(str: string): boolean {
return str.length < 2083 && attachmentRegex.test(str); return str.length < 2083 && attachmentRegex.test(str);
@ -88,6 +92,7 @@ export class Util {
/** /**
* Returns Vimeo ID * Returns Vimeo ID
* @param {String} query Vimeo link * @param {String} query Vimeo link
* @returns {String}
*/ */
static getVimeoID(query: string): string { static getVimeoID(query: string): string {
return Util.getQueryType(query) === 'vimeo' return Util.getQueryType(query) === 'vimeo'
@ -101,6 +106,7 @@ export class Util {
/** /**
* Parses ms time * Parses ms time
* @param {Number} milliseconds Time to parse * @param {Number} milliseconds Time to parse
* @returns {TimeData}
*/ */
static parseMS(milliseconds: number): TimeData { static parseMS(milliseconds: number): TimeData {
const roundTowardsZero = milliseconds > 0 ? Math.floor : Math.ceil; const roundTowardsZero = milliseconds > 0 ? Math.floor : Math.ceil;
@ -116,6 +122,7 @@ export class Util {
/** /**
* Creates simple duration string * Creates simple duration string
* @param {object} durObj Duration object * @param {object} durObj Duration object
* @returns {String}
*/ */
static durationString(durObj: object): string { static durationString(durObj: object): string {
return Object.values(durObj) return Object.values(durObj)
@ -161,6 +168,7 @@ export class Util {
/** /**
* Checks if this system is running in replit.com * Checks if this system is running in replit.com
* @returns {Boolean}
*/ */
static isRepl(): boolean { static isRepl(): boolean {
if ('DP_REPL_NOCHECK' in process.env) return false; if ('DP_REPL_NOCHECK' in process.env) return false;
@ -183,6 +191,7 @@ export class Util {
/** /**
* Checks if the given voice channel is empty * Checks if the given voice channel is empty
* @param {DiscordVoiceChannel} channel The voice channel * @param {DiscordVoiceChannel} channel The voice channel
* @returns {Boolean}
*/ */
static isVoiceEmpty(channel: VoiceChannel): boolean { static isVoiceEmpty(channel: VoiceChannel): boolean {
return channel.members.filter((member) => !member.user.bot).size === 0; return channel.members.filter((member) => !member.user.bot).size === 0;
@ -191,6 +200,7 @@ export class Util {
/** /**
* Builds time code * Builds time code
* @param {object} data The data to build time code from * @param {object} data The data to build time code from
* @returns {String}
*/ */
static buildTimeCode(data: any): string { static buildTimeCode(data: any): string {
const items = Object.keys(data); const items = Object.keys(data);
@ -207,6 +217,7 @@ export class Util {
/** /**
* Manage CJS require * Manage CJS require
* @param {String} id id to require * @param {String} id id to require
* @returns {any}
*/ */
static require(id: string): any { static require(id: string): any {
try { try {