fix jsdoc
This commit is contained in:
parent
d3fdc045e2
commit
32a7be23a1
5 changed files with 132 additions and 70 deletions
|
@ -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 {
|
||||||
|
|
|
@ -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));
|
||||||
|
|
|
@ -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}>`;
|
||||||
|
|
|
@ -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}`;
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
Loading…
Reference in a new issue