Compare commits

...

31 Commits

Author SHA1 Message Date
Thomas Viesmose Birch
5211a4a976 Adding songtype to playlists 2024-05-04 17:31:58 +02:00
Thomas Viesmose Birch
58f972156e Typescript is hard! 2024-05-04 16:20:19 +02:00
Thomas Viesmose Birch
1f69d0e867 Added OthersPlaylists to the parseMessages 2024-05-04 16:19:16 +02:00
Thomas Viesmose Birch
de19886518 Added OthersPlaylists to the parseMessages 2024-05-04 16:16:45 +02:00
Thomas Viesmose Birch
4ef0946605 Removed the ListenerJoined and ListenerLeft events 2024-05-04 16:09:35 +02:00
Thomas Viesmose Birch
365132977a Fixed unused include before bump 2024-05-04 15:36:49 +02:00
Thomas Viesmose Birch
3c80493446 bump to 17! 2024-05-04 15:35:11 +02:00
Thomas Viesmose Birch
927aa80398 bump to 16 2024-05-04 15:29:06 +02:00
Thomas Viesmose Birch
1b31aaf549 Renaming to GetOtherPlaylists 2024-05-04 15:27:43 +02:00
Thomas Viesmose Birch
7e1136acad Me and typescript is not friends. 2024-05-04 14:50:27 +02:00
Thomas Viesmose Birch
1487f6e1f5 Changed "Added new messages for returning users with playlists" to a call that just returns all playslists. 2024-05-04 14:43:05 +02:00
Thomas Viesmose Birch
8760a3affc Added new messages for returning users with playlists. 2024-05-04 13:17:06 +02:00
Thomas Viesmose Birch
00dedc1d85 Added inAutoPlay property to songs 2024-05-04 12:31:30 +02:00
Thomas Viesmose Birch
283d7ea4ec Added inAutoPlay property to songs 2024-05-04 12:16:22 +02:00
Thomas Viesmose Birch
e2475c254e Added inAutoPlay property to songs 2024-05-04 12:13:59 +02:00
Thomas Viesmose Birch
d08afcc4d6 Added RemoveSongFromAutoPlay 2024-05-04 10:28:11 +02:00
Torben Pi Jensen
d47379aacc Added remove playlist 2024-02-04 08:51:53 +01:00
Torben Pi Jensen
01b8319aef Added shuffle 2024-02-03 19:18:22 +01:00
Torben Pi Jensen
993501f049 Added tags 2024-02-03 17:06:07 +01:00
Torben Pi Jensen
343126bee3 Fix? 2024-02-03 15:40:38 +01:00
Torben Pi Jensen
588c778122 Fix? 2024-02-03 15:37:46 +01:00
Torben Pi Jensen
2ec9585c74 Fix? 2024-02-03 15:37:38 +01:00
Torben Pi Jensen
d5b4cfefc3 Added playlist 2024-02-03 14:47:27 +01:00
Torben Pi Jensen
807cd568e1 Added playlist 2024-02-03 14:45:02 +01:00
Torben Pi Jensen
04253f753a Added playlist 2024-02-03 14:42:42 +01:00
Torben Pi Jensen
829e9c599b Added playlist 2024-02-03 14:32:03 +01:00
Torben Pi Jensen
9345dd1fd0 Added playlist 2024-02-03 10:31:20 +01:00
Torben Pi Jensen
9ce896cd33 Added playlist 2024-02-03 10:31:04 +01:00
Torben Pi Jensen
29d8ee56f6 package 2023-12-04 21:45:03 +01:00
Torben Pi Jensen
4b88313d0e add like 2023-12-04 21:22:39 +01:00
Torben Pi Jensen
a671b53634 add like 2023-12-04 21:22:34 +01:00
12 changed files with 398 additions and 87 deletions

View File

@ -5,19 +5,29 @@ export enum SongType {
export class Song {
constructor(public type: SongType, public title: string, public songId: string, public image: string) {
constructor(public type: SongType, public title: string, public songId: string, public image: string, public inAutoPlay: boolean) {
}
}
export class QueuedSong extends Song {
constructor(type: SongType, title: string, songId: string, image: string, public listener: string) {
super(type, title, songId, image);
constructor(type: SongType, title: string, songId: string, image: string, public listener: string, public inAutoPlay: boolean) {
super(type, title, songId, image, inAutoPlay);
}
}
export class PlayingSong extends QueuedSong {
constructor(type: SongType, title: string, songId: string, image: string, listener: string, public length: number, public position: number) {
super(type, title, songId, image, listener);
constructor(type: SongType, title: string, songId: string, image: string, listener: string, public length: number, public position: number, public tags: string[], public inAutoPlay: boolean) {
super(type, title, songId, image, listener, inAutoPlay);
}
}
export class Playlist {
constructor(public title: string, public listener: string, public type: SongType, public songs: Song[]) {
}
}
export class PlaylistDescription {
constructor(public title: string, public listener: string, public type: SongType) {
}
}

2
dist/common.js vendored
View File

@ -13,7 +13,7 @@ var __createBinding = (this && this.__createBinding) || (Object.create ? (functi
var __exportStar = (this && this.__exportStar) || function(m, exports) {
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
};
exports.__esModule = true;
Object.defineProperty(exports, "__esModule", { value: true });
__exportStar(require("./dataTypes"), exports);
__exportStar(require("./messageTypes"), exports);
__exportStar(require("./parseMessage"), exports);

23
dist/dataTypes.d.ts vendored
View File

@ -7,14 +7,31 @@ export declare class Song {
title: string;
songId: string;
image: string;
constructor(type: SongType, title: string, songId: string, image: string);
inAutoPlay: boolean;
constructor(type: SongType, title: string, songId: string, image: string, inAutoPlay: boolean);
}
export declare class QueuedSong extends Song {
listener: string;
constructor(type: SongType, title: string, songId: string, image: string, listener: string);
inAutoPlay: boolean;
constructor(type: SongType, title: string, songId: string, image: string, listener: string, inAutoPlay: boolean);
}
export declare class PlayingSong extends QueuedSong {
length: number;
position: number;
constructor(type: SongType, title: string, songId: string, image: string, listener: string, length: number, position: number);
tags: string[];
inAutoPlay: boolean;
constructor(type: SongType, title: string, songId: string, image: string, listener: string, length: number, position: number, tags: string[], inAutoPlay: boolean);
}
export declare class Playlist {
title: string;
listener: string;
type: SongType;
songs: Song[];
constructor(title: string, listener: string, type: SongType, songs: Song[]);
}
export declare class PlaylistDescription {
title: string;
listener: string;
type: SongType;
constructor(title: string, listener: string, type: SongType);
}

39
dist/dataTypes.js vendored
View File

@ -14,28 +14,30 @@ var __extends = (this && this.__extends) || (function () {
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
exports.__esModule = true;
exports.PlayingSong = exports.QueuedSong = exports.Song = exports.SongType = void 0;
Object.defineProperty(exports, "__esModule", { value: true });
exports.PlaylistDescription = exports.Playlist = exports.PlayingSong = exports.QueuedSong = exports.Song = exports.SongType = void 0;
var SongType;
(function (SongType) {
SongType[SongType["YouTube"] = 0] = "YouTube";
SongType[SongType["Spotify"] = 1] = "Spotify";
})(SongType = exports.SongType || (exports.SongType = {}));
})(SongType || (exports.SongType = SongType = {}));
var Song = /** @class */ (function () {
function Song(type, title, songId, image) {
function Song(type, title, songId, image, inAutoPlay) {
this.type = type;
this.title = title;
this.songId = songId;
this.image = image;
this.inAutoPlay = inAutoPlay;
}
return Song;
}());
exports.Song = Song;
var QueuedSong = /** @class */ (function (_super) {
__extends(QueuedSong, _super);
function QueuedSong(type, title, songId, image, listener) {
var _this = _super.call(this, type, title, songId, image) || this;
function QueuedSong(type, title, songId, image, listener, inAutoPlay) {
var _this = _super.call(this, type, title, songId, image, inAutoPlay) || this;
_this.listener = listener;
_this.inAutoPlay = inAutoPlay;
return _this;
}
return QueuedSong;
@ -43,12 +45,33 @@ var QueuedSong = /** @class */ (function (_super) {
exports.QueuedSong = QueuedSong;
var PlayingSong = /** @class */ (function (_super) {
__extends(PlayingSong, _super);
function PlayingSong(type, title, songId, image, listener, length, position) {
var _this = _super.call(this, type, title, songId, image, listener) || this;
function PlayingSong(type, title, songId, image, listener, length, position, tags, inAutoPlay) {
var _this = _super.call(this, type, title, songId, image, listener, inAutoPlay) || this;
_this.length = length;
_this.position = position;
_this.tags = tags;
_this.inAutoPlay = inAutoPlay;
return _this;
}
return PlayingSong;
}(QueuedSong));
exports.PlayingSong = PlayingSong;
var Playlist = /** @class */ (function () {
function Playlist(title, listener, type, songs) {
this.title = title;
this.listener = listener;
this.type = type;
this.songs = songs;
}
return Playlist;
}());
exports.Playlist = Playlist;
var PlaylistDescription = /** @class */ (function () {
function PlaylistDescription(title, listener, type) {
this.title = title;
this.listener = listener;
this.type = type;
}
return PlaylistDescription;
}());
exports.PlaylistDescription = PlaylistDescription;

View File

@ -1,5 +1,5 @@
import { Song, PlayingSong, QueuedSong } from "./dataTypes";
export declare type StuenMessages = ListenerLeft | ListenerList | ListenerJoined | SendChatMessage | SearchSong | SearchSongResult | Join | QueueSong | CurrentQueue | CurrentSong | UnqueueSong | ReorderSong | SkipSong;
import { Song, PlayingSong, QueuedSong, Playlist, PlaylistDescription } from "./dataTypes";
export type StuenMessages = ListenerList | SendChatMessage | SearchSong | SearchSongResult | Join | QueueSong | CurrentQueue | CurrentSong | UnqueueSong | ReorderSong | SkipSong | SongLikes | ToggleSongLike | CreatePlaylist | RemovePlaylist | AddSongToPlaylist | RemoveSongFromPlaylist | Playlists | GetPlaylist | PlaylistSongs | GetOtherPlaylists | ToggleTag | Shuffle | RemoveFromAutoPlay;
export declare abstract class StuenMessage {
type: string;
constructor(type: string);
@ -8,14 +8,6 @@ export declare class Join extends StuenMessage {
name: string;
constructor(name: string);
}
export declare class ListenerJoined extends StuenMessage {
name: string;
constructor(name: string);
}
export declare class ListenerLeft extends StuenMessage {
name: string;
constructor(name: string);
}
export declare class ListenerList extends StuenMessage {
names: string[];
constructor(names: string[]);
@ -69,3 +61,51 @@ export declare class SongLikes extends StuenMessage {
listeners: string[];
constructor(listeners: string[]);
}
export declare class CreatePlaylist extends StuenMessage {
title: string;
constructor(title: string);
}
export declare class RemovePlaylist extends StuenMessage {
title: string;
constructor(title: string);
}
export declare class Playlists extends StuenMessage {
playlists: PlaylistDescription[];
constructor(playlists: PlaylistDescription[]);
}
export declare class GetPlaylist extends StuenMessage {
playlist: PlaylistDescription;
constructor(playlist: PlaylistDescription);
}
export declare class PlaylistSongs extends StuenMessage {
playlist: Playlist;
constructor(playlist: Playlist);
}
export declare class GetOtherPlaylists extends StuenMessage {
constructor();
}
export declare class OthersPlaylists extends StuenMessage {
playlists: PlaylistDescription[];
constructor(playlists: PlaylistDescription[]);
}
export declare class AddSongToPlaylist extends StuenMessage {
song: Song;
playlist: string;
constructor(song: Song, playlist: string);
}
export declare class RemoveSongFromPlaylist extends StuenMessage {
song: Song;
playlist: string;
constructor(song: Song, playlist: string);
}
export declare class ToggleTag extends StuenMessage {
song: Song;
tag: string;
constructor(song: Song, tag: string);
}
export declare class Shuffle extends StuenMessage {
constructor();
}
export declare class RemoveFromAutoPlay extends StuenMessage {
constructor();
}

143
dist/messageTypes.js vendored
View File

@ -14,8 +14,8 @@ var __extends = (this && this.__extends) || (function () {
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
exports.__esModule = true;
exports.SongLikes = exports.ToggleSongLike = exports.SkipSong = exports.ReorderSong = exports.UnqueueSong = exports.CurrentSong = exports.CurrentQueue = exports.QueueSong = exports.SearchSongResult = exports.SearchSong = exports.ChatMessage = exports.SendChatMessage = exports.ListenerList = exports.ListenerLeft = exports.ListenerJoined = exports.Join = exports.StuenMessage = void 0;
Object.defineProperty(exports, "__esModule", { value: true });
exports.RemoveFromAutoPlay = exports.Shuffle = exports.ToggleTag = exports.RemoveSongFromPlaylist = exports.AddSongToPlaylist = exports.OthersPlaylists = exports.GetOtherPlaylists = exports.PlaylistSongs = exports.GetPlaylist = exports.Playlists = exports.RemovePlaylist = exports.CreatePlaylist = exports.SongLikes = exports.ToggleSongLike = exports.SkipSong = exports.ReorderSong = exports.UnqueueSong = exports.CurrentSong = exports.CurrentQueue = exports.QueueSong = exports.SearchSongResult = exports.SearchSong = exports.ChatMessage = exports.SendChatMessage = exports.ListenerList = exports.Join = exports.StuenMessage = void 0;
var StuenMessage = /** @class */ (function () {
function StuenMessage(type) {
this.type = type;
@ -33,26 +33,6 @@ var Join = /** @class */ (function (_super) {
return Join;
}(StuenMessage));
exports.Join = Join;
var ListenerJoined = /** @class */ (function (_super) {
__extends(ListenerJoined, _super);
function ListenerJoined(name) {
var _this = _super.call(this, 'ListenerJoined') || this;
_this.name = name;
return _this;
}
return ListenerJoined;
}(StuenMessage));
exports.ListenerJoined = ListenerJoined;
var ListenerLeft = /** @class */ (function (_super) {
__extends(ListenerLeft, _super);
function ListenerLeft(name) {
var _this = _super.call(this, 'ListenerLeft') || this;
_this.name = name;
return _this;
}
return ListenerLeft;
}(StuenMessage));
exports.ListenerLeft = ListenerLeft;
var ListenerList = /** @class */ (function (_super) {
__extends(ListenerList, _super);
function ListenerList(names) {
@ -176,10 +156,127 @@ exports.ToggleSongLike = ToggleSongLike;
var SongLikes = /** @class */ (function (_super) {
__extends(SongLikes, _super);
function SongLikes(listeners) {
var _this = _super.call(this, 'SongLikeChanged') || this;
var _this = _super.call(this, 'SongLikes') || this;
_this.listeners = listeners;
return _this;
}
return SongLikes;
}(StuenMessage));
exports.SongLikes = SongLikes;
var CreatePlaylist = /** @class */ (function (_super) {
__extends(CreatePlaylist, _super);
function CreatePlaylist(title) {
var _this = _super.call(this, 'CreatePlaylist') || this;
_this.title = title;
return _this;
}
return CreatePlaylist;
}(StuenMessage));
exports.CreatePlaylist = CreatePlaylist;
var RemovePlaylist = /** @class */ (function (_super) {
__extends(RemovePlaylist, _super);
function RemovePlaylist(title) {
var _this = _super.call(this, 'RemovePlaylist') || this;
_this.title = title;
return _this;
}
return RemovePlaylist;
}(StuenMessage));
exports.RemovePlaylist = RemovePlaylist;
var Playlists = /** @class */ (function (_super) {
__extends(Playlists, _super);
function Playlists(playlists) {
var _this = _super.call(this, 'Playlists') || this;
_this.playlists = playlists;
return _this;
}
return Playlists;
}(StuenMessage));
exports.Playlists = Playlists;
var GetPlaylist = /** @class */ (function (_super) {
__extends(GetPlaylist, _super);
function GetPlaylist(playlist) {
var _this = _super.call(this, 'GetPlaylist') || this;
_this.playlist = playlist;
return _this;
}
return GetPlaylist;
}(StuenMessage));
exports.GetPlaylist = GetPlaylist;
var PlaylistSongs = /** @class */ (function (_super) {
__extends(PlaylistSongs, _super);
function PlaylistSongs(playlist) {
var _this = _super.call(this, 'PlaylistSongs') || this;
_this.playlist = playlist;
return _this;
}
return PlaylistSongs;
}(StuenMessage));
exports.PlaylistSongs = PlaylistSongs;
var GetOtherPlaylists = /** @class */ (function (_super) {
__extends(GetOtherPlaylists, _super);
function GetOtherPlaylists() {
return _super.call(this, 'GetOtherPlaylists') || this;
}
return GetOtherPlaylists;
}(StuenMessage));
exports.GetOtherPlaylists = GetOtherPlaylists;
var OthersPlaylists = /** @class */ (function (_super) {
__extends(OthersPlaylists, _super);
function OthersPlaylists(playlists) {
var _this = _super.call(this, 'OthersPlaylists') || this;
_this.playlists = playlists;
return _this;
}
return OthersPlaylists;
}(StuenMessage));
exports.OthersPlaylists = OthersPlaylists;
var AddSongToPlaylist = /** @class */ (function (_super) {
__extends(AddSongToPlaylist, _super);
function AddSongToPlaylist(song, playlist) {
var _this = _super.call(this, 'AddSongToPlaylist') || this;
_this.song = song;
_this.playlist = playlist;
return _this;
}
return AddSongToPlaylist;
}(StuenMessage));
exports.AddSongToPlaylist = AddSongToPlaylist;
var RemoveSongFromPlaylist = /** @class */ (function (_super) {
__extends(RemoveSongFromPlaylist, _super);
function RemoveSongFromPlaylist(song, playlist) {
var _this = _super.call(this, 'RemoveSongFromPlaylist') || this;
_this.song = song;
_this.playlist = playlist;
return _this;
}
return RemoveSongFromPlaylist;
}(StuenMessage));
exports.RemoveSongFromPlaylist = RemoveSongFromPlaylist;
var ToggleTag = /** @class */ (function (_super) {
__extends(ToggleTag, _super);
function ToggleTag(song, tag) {
var _this = _super.call(this, 'ToggleTag') || this;
_this.song = song;
_this.tag = tag;
return _this;
}
return ToggleTag;
}(StuenMessage));
exports.ToggleTag = ToggleTag;
var Shuffle = /** @class */ (function (_super) {
__extends(Shuffle, _super);
function Shuffle() {
return _super.call(this, 'Shuffle') || this;
}
return Shuffle;
}(StuenMessage));
exports.Shuffle = Shuffle;
var RemoveFromAutoPlay = /** @class */ (function (_super) {
__extends(RemoveFromAutoPlay, _super);
function RemoveFromAutoPlay() {
return _super.call(this, 'RemoveFromAutoPlay') || this;
}
return RemoveFromAutoPlay;
}(StuenMessage));
exports.RemoveFromAutoPlay = RemoveFromAutoPlay;

View File

@ -1 +1 @@
{"version":3,"file":"messageTypes.js","sourceRoot":"","sources":["../messageTypes.ts"],"names":[],"mappings":"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"}
{"version":3,"file":"messageTypes.js","sourceRoot":"","sources":["../messageTypes.ts"],"names":[],"mappings":"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"}

32
dist/parseMessage.js vendored
View File

@ -1,5 +1,5 @@
"use strict";
exports.__esModule = true;
Object.defineProperty(exports, "__esModule", { value: true });
var messageTypes_1 = require("./messageTypes");
function parseMessage(message) {
try {
@ -7,10 +7,6 @@ function parseMessage(message) {
switch (data.type) {
case 'Join':
return new messageTypes_1.Join(data.name);
case 'ListenerJoined':
return new messageTypes_1.ListenerJoined(data.name);
case 'ListenerLeft':
return new messageTypes_1.ListenerLeft(data.name);
case 'ListenerList':
return new messageTypes_1.ListenerList(data.names);
case 'SendChatMessage':
@ -37,6 +33,30 @@ function parseMessage(message) {
return new messageTypes_1.ToggleSongLike();
case 'SongLikes':
return new messageTypes_1.SongLikes(data.listeners);
case 'Playlists':
return new messageTypes_1.Playlists(data.playlists);
case 'GetPlaylist':
return new messageTypes_1.GetPlaylist(data.playlist);
case 'PlaylistSongs':
return new messageTypes_1.PlaylistSongs(data.playlist);
case 'CreatePlaylist':
return new messageTypes_1.CreatePlaylist(data.title);
case 'RemovePlaylist':
return new messageTypes_1.RemovePlaylist(data.title);
case 'AddSongToPlaylist':
return new messageTypes_1.AddSongToPlaylist(data.song, data.playlist);
case 'RemoveSongFromPlaylist':
return new messageTypes_1.RemoveSongFromPlaylist(data.song, data.playlist);
case 'GetOtherPlaylists':
return new messageTypes_1.GetOtherPlaylists();
case 'OthersPlaylists':
return new messageTypes_1.OthersPlaylists(data.playlists);
case 'ToggleTag':
return new messageTypes_1.ToggleTag(data.song, data.tag);
case 'Shuffle':
return new messageTypes_1.Shuffle();
case 'RemoveFromAutoPlay':
return new messageTypes_1.RemoveFromAutoPlay();
default:
console.error('Unknown message type:', data.type);
return null;
@ -47,4 +67,4 @@ function parseMessage(message) {
return null; // Handle parsing errors
}
}
exports["default"] = parseMessage;
exports.default = parseMessage;

View File

@ -1 +1 @@
{"version":3,"file":"parseMessage.js","sourceRoot":"","sources":["../parseMessage.ts"],"names":[],"mappings":";;AAAA,+CAQwB;AAExB,SAAwB,YAAY,CAAC,OAAe;IAChD,IAAI;QACA,IAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAEjC,QAAQ,IAAI,CAAC,IAAI,EAAE;YACf,KAAK,MAAM;gBACP,OAAO,IAAI,mBAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC/B,KAAK,gBAAgB;gBACjB,OAAO,IAAI,6BAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACzC,KAAK,cAAc;gBACf,OAAO,IAAI,2BAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACvC,KAAK,cAAc;gBACf,OAAO,IAAI,2BAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACxC,KAAK,iBAAiB;gBAClB,OAAO,IAAI,8BAAe,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC7C,KAAK,aAAa;gBACd,OAAO,IAAI,0BAAW,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;YACpD,KAAK,YAAY;gBACb,OAAO,IAAI,yBAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACtC,KAAK,kBAAkB;gBACnB,OAAO,IAAI,+BAAgB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC7C,KAAK,WAAW;gBACZ,OAAO,IAAI,wBAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACpC,KAAK,cAAc;gBACf,OAAO,IAAI,2BAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YACvC,KAAK,aAAa;gBACd,OAAO,IAAI,0BAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACtC;gBACI,OAAO,CAAC,KAAK,CAAC,uBAAuB,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;gBAClD,OAAO,IAAI,CAAC;SACnB;KACJ;IAAC,OAAO,KAAK,EAAE;QACZ,OAAO,CAAC,KAAK,CAAC,kCAAkC,EAAE,KAAK,CAAC,CAAC;QACzD,OAAO,IAAI,CAAC,CAAC,wBAAwB;KACxC;AACL,CAAC;AAnCD,+BAmCC"}
{"version":3,"file":"parseMessage.js","sourceRoot":"","sources":["../parseMessage.ts"],"names":[],"mappings":";;AAAA,+CAQwB;AAExB,SAAwB,YAAY,CAAC,OAAe;IAChD,IAAI;QACA,IAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAEjC,QAAQ,IAAI,CAAC,IAAI,EAAE;YACf,KAAK,MAAM;gBACP,OAAO,IAAI,mBAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC/B,KAAK,gBAAgB;gBACjB,OAAO,IAAI,6BAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACzC,KAAK,cAAc;gBACf,OAAO,IAAI,2BAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACvC,KAAK,cAAc;gBACf,OAAO,IAAI,2BAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACxC,KAAK,iBAAiB;gBAClB,OAAO,IAAI,8BAAe,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC7C,KAAK,aAAa;gBACd,OAAO,IAAI,0BAAW,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;YACpD,KAAK,YAAY;gBACb,OAAO,IAAI,yBAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACtC,KAAK,kBAAkB;gBACnB,OAAO,IAAI,+BAAgB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC7C,KAAK,WAAW;gBACZ,OAAO,IAAI,wBAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACpC,KAAK,cAAc;gBACf,OAAO,IAAI,2BAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YACvC,KAAK,aAAa;gBACd,OAAO,IAAI,0BAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACtC,KAAK,aAAa;gBACd,OAAO,IAAI,0BAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;YACpD,KAAK,aAAa;gBACd,OAAO,IAAI,0BAAW,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;YACpE,KAAK,UAAU;gBACX,OAAO,IAAI,uBAAQ,EAAE,CAAC;YAC1B,KAAK,gBAAgB;gBACjB,OAAO,IAAI,6BAAc,EAAE,CAAC;YAChC,KAAK,WAAW;gBACZ,OAAO,IAAI,wBAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YACzC;gBACI,OAAO,CAAC,KAAK,CAAC,uBAAuB,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;gBAClD,OAAO,IAAI,CAAC;SACnB;KACJ;IAAC,OAAO,KAAK,EAAE;QACZ,OAAO,CAAC,KAAK,CAAC,kCAAkC,EAAE,KAAK,CAAC,CAAC;QACzD,OAAO,IAAI,CAAC,CAAC,wBAAwB;KACxC;AACL,CAAC;AA7CD,+BA6CC"}

View File

@ -1,9 +1,7 @@
import {Song, PlayingSong, QueuedSong} from "./dataTypes";
import {Song, PlayingSong, QueuedSong, Playlist, PlaylistDescription} from "./dataTypes";
export type StuenMessages =
ListenerLeft
| ListenerList
| ListenerJoined
ListenerList
| SendChatMessage
| SearchSong
| SearchSongResult
@ -13,7 +11,20 @@ export type StuenMessages =
| CurrentSong
| UnqueueSong
| ReorderSong
| SkipSong;
| SkipSong
| SongLikes
| ToggleSongLike
| CreatePlaylist
| RemovePlaylist
| AddSongToPlaylist
| RemoveSongFromPlaylist
| Playlists
| GetPlaylist
| PlaylistSongs
| GetOtherPlaylists
| ToggleTag
| Shuffle
| RemoveFromAutoPlay
export abstract class StuenMessage {
constructor(public type: string) {
@ -26,18 +37,6 @@ export class Join extends StuenMessage {
}
}
export class ListenerJoined extends StuenMessage {
constructor(public name: string) {
super('ListenerJoined');
}
}
export class ListenerLeft extends StuenMessage {
constructor(public name: string) {
super('ListenerLeft');
}
}
export class ListenerList extends StuenMessage {
constructor(public names: string[]) {
super('ListenerList');
@ -115,6 +114,76 @@ export class ToggleSongLike extends StuenMessage {
export class SongLikes extends StuenMessage {
constructor(public listeners: string[]) {
super('SongLikeChanged');
super('SongLikes');
}
}
export class CreatePlaylist extends StuenMessage {
constructor(public title: string) {
super('CreatePlaylist');
}
}
export class RemovePlaylist extends StuenMessage {
constructor(public title: string) {
super('RemovePlaylist');
}
}
export class Playlists extends StuenMessage {
constructor(public playlists: PlaylistDescription[]) {
super('Playlists');
}
}
export class GetPlaylist extends StuenMessage {
constructor(public playlist: PlaylistDescription) {
super('GetPlaylist');
}
}
export class PlaylistSongs extends StuenMessage {
constructor(public playlist: Playlist) {
super('PlaylistSongs');
}
}
export class GetOtherPlaylists extends StuenMessage {
constructor() {
super('GetOtherPlaylists');
}
}
export class OthersPlaylists extends StuenMessage {
constructor(public playlists: PlaylistDescription[]) {
super('OthersPlaylists');
}
}
export class AddSongToPlaylist extends StuenMessage {
constructor(public song: Song, public playlist: string) {
super('AddSongToPlaylist');
}
}
export class RemoveSongFromPlaylist extends StuenMessage {
constructor(public song: Song, public playlist: string) {
super('RemoveSongFromPlaylist');
}
}
export class ToggleTag extends StuenMessage {
constructor(public song: Song, public tag: string) {
super('ToggleTag');
}
}
export class Shuffle extends StuenMessage {
constructor() {
super('Shuffle');
}
}
export class RemoveFromAutoPlay extends StuenMessage {
constructor() {
super('RemoveFromAutoPlay');
}
}

View File

@ -1,6 +1,6 @@
{
"name": "stuen-common",
"version": "1.1.4",
"version": "1.2.17",
"main": "dist/common.js",
"type": "commonjs",
"types": "dist/common.d.ts",

View File

@ -1,11 +1,26 @@
import {
ChatMessage, CurrentQueue, CurrentSong,
AddSongToPlaylist,
ChatMessage,
CreatePlaylist,
CurrentQueue,
CurrentSong,
GetPlaylist,
Join,
ListenerJoined,
ListenerLeft,
ListenerList, QueueSong, ReorderSong, SearchSong, SearchSongResult,
SendChatMessage, SkipSong, SongLikes,
StuenMessage, ToggleSongLike, UnqueueSong
ListenerList,
Playlists,
PlaylistSongs,
GetOtherPlaylists,
QueueSong, RemoveFromAutoPlay, RemovePlaylist,
RemoveSongFromPlaylist,
ReorderSong,
SearchSong,
SearchSongResult,
SendChatMessage, Shuffle,
SkipSong,
SongLikes,
StuenMessage,
ToggleSongLike, ToggleTag,
UnqueueSong, OthersPlaylists,
} from "./messageTypes";
export default function parseMessage(message: string): StuenMessage | null {
@ -15,10 +30,6 @@ export default function parseMessage(message: string): StuenMessage | null {
switch (data.type) {
case 'Join':
return new Join(data.name);
case 'ListenerJoined':
return new ListenerJoined(data.name);
case 'ListenerLeft':
return new ListenerLeft(data.name);
case 'ListenerList':
return new ListenerList(data.names);
case 'SendChatMessage':
@ -45,6 +56,30 @@ export default function parseMessage(message: string): StuenMessage | null {
return new ToggleSongLike();
case 'SongLikes':
return new SongLikes(data.listeners);
case 'Playlists':
return new Playlists(data.playlists);
case 'GetPlaylist':
return new GetPlaylist(data.playlist);
case 'PlaylistSongs':
return new PlaylistSongs(data.playlist);
case 'CreatePlaylist':
return new CreatePlaylist(data.title);
case 'RemovePlaylist':
return new RemovePlaylist(data.title);
case 'AddSongToPlaylist':
return new AddSongToPlaylist(data.song, data.playlist);
case 'RemoveSongFromPlaylist':
return new RemoveSongFromPlaylist(data.song, data.playlist);
case 'GetOtherPlaylists':
return new GetOtherPlaylists();
case 'OthersPlaylists':
return new OthersPlaylists(data.playlists);
case 'ToggleTag':
return new ToggleTag(data.song, data.tag);
case 'Shuffle':
return new Shuffle();
case 'RemoveFromAutoPlay':
return new RemoveFromAutoPlay();
default:
console.error('Unknown message type:', data.type);
return null;