mirror of
https://github.com/jellyfin/jellyfin-web
synced 2025-03-30 19:56:21 +00:00
rework now playing screen
This commit is contained in:
parent
b614bbcf09
commit
bb816420e7
14 changed files with 448 additions and 516 deletions
|
@ -100,6 +100,7 @@ define(['events', 'datetime', 'appSettings', 'pluginManager', 'userSettings', 'g
|
|||
return;
|
||||
}
|
||||
setCurrentPlayerInternal(null, null);
|
||||
return;
|
||||
}
|
||||
|
||||
if (typeof (player) === 'string') {
|
||||
|
@ -244,16 +245,21 @@ define(['events', 'datetime', 'appSettings', 'pluginManager', 'userSettings', 'g
|
|||
|
||||
self.removeActivePlayer = function (name) {
|
||||
|
||||
if (self.getPlayerInfo().name === name) {
|
||||
self.setDefaultPlayerActive();
|
||||
var playerInfo = self.getPlayerInfo();
|
||||
if (playerInfo) {
|
||||
if (playerInfo.name === name) {
|
||||
self.setDefaultPlayerActive();
|
||||
}
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
self.removeActiveTarget = function (id) {
|
||||
|
||||
if (self.getPlayerInfo().id === id) {
|
||||
self.setDefaultPlayerActive();
|
||||
var playerInfo = self.getPlayerInfo();
|
||||
if (playerInfo) {
|
||||
if (playerInfo.id === id) {
|
||||
self.setDefaultPlayerActive();
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -261,6 +267,10 @@ define(['events', 'datetime', 'appSettings', 'pluginManager', 'userSettings', 'g
|
|||
|
||||
var playerInfo = self.getPlayerInfo();
|
||||
|
||||
if (!playerInfo) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (playerInfo.supportedCommands.indexOf('EndSession') !== -1) {
|
||||
|
||||
require(['dialog'], function (dialog) {
|
||||
|
@ -2205,12 +2215,7 @@ define(['events', 'datetime', 'appSettings', 'pluginManager', 'userSettings', 'g
|
|||
}
|
||||
}
|
||||
|
||||
// Gets or sets the current playlist index
|
||||
self.currentPlaylistIndex = function (i) {
|
||||
|
||||
if (i == null) {
|
||||
return currentPlaylistIndex;
|
||||
}
|
||||
self.setCurrentPlaylistIndex = function (i) {
|
||||
|
||||
var newItem = playlist[i];
|
||||
|
||||
|
@ -2219,10 +2224,15 @@ define(['events', 'datetime', 'appSettings', 'pluginManager', 'userSettings', 'g
|
|||
});
|
||||
|
||||
playInternal(newItem, playOptions, function () {
|
||||
self.setPlaylistState(i);
|
||||
currentPlaylistIndex = i;
|
||||
});
|
||||
};
|
||||
|
||||
self.getCurrentPlaylistIndex = function (i) {
|
||||
|
||||
return currentPlaylistIndex;
|
||||
};
|
||||
|
||||
self.setRepeatMode = function (value, player) {
|
||||
|
||||
player = player || currentPlayer;
|
||||
|
@ -2494,6 +2504,11 @@ define(['events', 'datetime', 'appSettings', 'pluginManager', 'userSettings', 'g
|
|||
state.nextMediaType = nextMediaType;
|
||||
state.nextItem = playbackStopInfo.nextItem;
|
||||
|
||||
if (!nextItem) {
|
||||
playlist = [];
|
||||
currentPlaylistIndex = -1;
|
||||
}
|
||||
|
||||
events.trigger(player, 'playbackstop', [state]);
|
||||
events.trigger(self, 'playbackstop', [playbackStopInfo]);
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue