Skip to content

Commit

Permalink
Merge branch develop (#1287)
Browse files Browse the repository at this point in the history
* fix(Queue): shuffle all tracks

* Shuffled first track as well

* Fixed queue shuffling to include first element

* fix(AudioFilters): properly get filters

* 5.3.1

Co-authored-by: mjh <[email protected]>
  • Loading branch information
twlite and mjh316 authored Aug 8, 2022
1 parent bf22b25 commit 8d7b841
Show file tree
Hide file tree
Showing 3 changed files with 8 additions and 11 deletions.
4 changes: 2 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "discord-player",
"version": "5.3.0",
"version": "5.3.1",
"description": "Complete framework to facilitate music commands using discord.js",
"main": "dist/index.js",
"types": "dist/index.d.ts",
Expand All @@ -18,7 +18,7 @@
"./dist/*": "./dist/*"
},
"scripts": {
"dev": "cd example/test && ts-node index.ts",
"dev": "cd examples/test && ts-node index.ts",
"build": "rimraf dist && tsc && npm run build:esm",
"build:check": "tsc --noEmit --incremental false",
"prepublishOnly": "rollup-type-bundler -e stream",
Expand Down
5 changes: 1 addition & 4 deletions src/Structures/Queue.ts
Original file line number Diff line number Diff line change
Expand Up @@ -455,16 +455,13 @@ class Queue<T = unknown> {
*/
shuffle() {
if (this.#watchDestroyed()) return;
if (!this.tracks.length || this.tracks.length < 3) return false;
const currentTrack = this.tracks.shift();
if (!this.tracks.length || this.tracks.length < 2) return false;

for (let i = this.tracks.length - 1; i > 0; i--) {
const j = Math.floor(Math.random() * (i + 1));
[this.tracks[i], this.tracks[j]] = [this.tracks[j], this.tracks[i]];
}

this.tracks.unshift(currentTrack);

return true;
}

Expand Down
10 changes: 5 additions & 5 deletions src/utils/AudioFilters.ts
Original file line number Diff line number Diff line change
Expand Up @@ -54,18 +54,18 @@ class AudioFilters {
}

public static *[Symbol.iterator](): IterableIterator<{ name: FiltersName; value: string }> {
for (const [k, v] of Object.entries(this)) {
if (typeof this.filters[k as FiltersName] === "string") yield { name: k as FiltersName, value: v as string };
for (const [k, v] of Object.entries(this.filters)) {
yield { name: k as FiltersName, value: v as string };
}
}

public static get names() {
return Object.keys(this).filter((p) => !["names", "length"].includes(p) && typeof this.filters[p as FiltersName] !== "function") as FiltersName[];
return Object.keys(this.filters) as FiltersName[];
}

// @ts-expect-error AudioFilters.length
public static get length() {
return Object.keys(this).filter((p) => !["names", "length"].includes(p) && typeof this.filters[p as FiltersName] !== "function").length;
return this.names.length;
}

public static toString() {
Expand All @@ -77,7 +77,7 @@ class AudioFilters {
* @param filter The filter name
* @returns
*/
public static create(filters?: FiltersName[]) {
public static create<K extends FiltersName>(filters?: K[]) {
if (!filters || !Array.isArray(filters)) return this.toString();
return filters
.filter((predicate) => typeof predicate === "string")
Expand Down

0 comments on commit 8d7b841

Please sign in to comment.