jellyfin-web/dashboard-ui/scripts/remotecontrol.js

522 lines
16 KiB
JavaScript
Raw Normal View History

2013-05-28 18:45:39 -07:00
(function (window, document, $) {
2013-05-30 12:58:07 -07:00
function showMenu(options, sessionsPromise, usersPromise) {
var playFromRendered;
var trailersRendered;
var specialFeaturesRendered;
var themeVideosRendered;
var themeSongsRendered;
var item = options.item;
2013-05-28 18:45:39 -07:00
2013-05-28 21:00:24 -07:00
var html = '<div data-role="popup" id="remoteControlFlyout">';
html += '<div class="ui-corner-top ui-bar-a" style="text-align:center;">';
2013-05-30 12:58:07 -07:00
html += '<div style="margin:.5em 0;">Remote Control</div>';
2013-05-28 21:00:24 -07:00
html += '</div>';
html += '<div data-role="content" class="ui-corner-bottom ui-content">';
2013-05-30 12:58:07 -07:00
html += '<form id="sendToForm">';
html += '<input type="hidden" value="PlayNow" id="fldPlayCommand" />';
html += '<div class="sessionsPopupContent">';
2013-05-28 21:00:24 -07:00
html += '<div class="circle"></div><div class="circle1"></div>';
html += '</div>';
2013-05-30 12:58:07 -07:00
html += '<p style="text-align:center;margin:.5em 0 0;">';
html += '<span id="playButtonContainer" onclick="$(\'#fldPlayCommand\').val(\'PlayNow\');" style="display:none;"><button type="submit" data-icon="play" data-theme="b" data-mini="true" data-inline="true">Play</button></span>';
html += '<span id="queueButtonContainer" onclick="$(\'#fldPlayCommand\').val(\'PlayLast\');" style="display:none;"><button type="submit" data-icon="play" data-theme="b" data-mini="true" data-inline="true">Queue</button></span>';
html += '<span id="okButtonContainer"><button type="submit" data-icon="ok" data-theme="b" data-mini="true" data-inline="true">Ok</button></span>';
html += '<button type="button" data-icon="delete" onclick="$(\'#remoteControlFlyout\').popup(\'close\');" data-theme="a" data-mini="true" data-inline="true">Cancel</button>';
html += '</p>';
2013-05-28 18:45:39 -07:00
2013-05-28 21:00:24 -07:00
html += '</form></div>';
2013-05-28 18:45:39 -07:00
2013-05-28 21:00:24 -07:00
html += '</div>';
2013-05-28 18:45:39 -07:00
2013-05-28 21:00:24 -07:00
$(document.body).append(html);
2013-05-28 18:45:39 -07:00
2013-05-30 12:58:07 -07:00
var popup = $('#remoteControlFlyout').popup({ history: false, tolerance: 0, corners: false }).trigger('create').popup("open").on("popupafterclose", function () {
2013-05-28 18:45:39 -07:00
2013-05-28 21:00:24 -07:00
$(this).off("popupafterclose").remove();
});
2013-05-28 18:45:39 -07:00
2013-05-30 12:58:07 -07:00
popup.on('click', '.trSession', function () {
$('input', this).checked(true);
}).on('click', '.trSelectPlayTime', function () {
$('input', this).checked(true);
}).on('click', '.trItem', function () {
$('input', this).checked(true);
});
2013-05-28 21:00:24 -07:00
$('#sendToForm', popup).on('submit', function () {
2013-05-28 18:45:39 -07:00
2013-05-28 21:00:24 -07:00
var checkboxes = $('.chkClient', popup);
2013-05-28 18:45:39 -07:00
2013-05-28 21:00:24 -07:00
if (!checkboxes.length) {
$('#remoteControlFlyout').popup("close");
return false;
}
2013-05-28 18:45:39 -07:00
2013-05-28 21:00:24 -07:00
checkboxes = $('.chkClient:checked', popup);
2013-05-28 18:45:39 -07:00
2013-05-28 21:00:24 -07:00
if (!checkboxes.length) {
Dashboard.alert('Please select a device to control.');
return false;
}
2013-05-28 18:45:39 -07:00
2013-05-28 21:00:24 -07:00
var sessionIds = [];
checkboxes.parents('.trSession').each(function () {
sessionIds.push(this.getAttribute('data-sessionid'));
2013-05-28 18:45:39 -07:00
});
2013-05-28 21:00:24 -07:00
var command = $('#selectCommand', popup).val();
var promise;
if (command == "Browse") {
promise = ApiClient.sendBrowseCommand(sessionIds[0], {
ItemId: item.Id,
ItemName: item.Name,
ItemType: item.Type,
2013-05-30 12:58:07 -07:00
Context: options.context
2013-05-28 21:00:24 -07:00
});
}
2013-05-30 12:58:07 -07:00
else if (command == "Play" || command == "PlayFromChapter") {
var checkedChapter = $('.chkSelectPlayTime:checked', popup);
var ticks = checkedChapter.length ? checkedChapter.parents('.trSelectPlayTime').attr('data-ticks') : 0;
2013-05-28 21:00:24 -07:00
promise = ApiClient.sendPlayCommand(sessionIds[0], {
ItemIds: [item.Id].join(','),
2013-05-30 12:58:07 -07:00
PlayCommand: $('#fldPlayCommand', popup).val(),
StartPositionTicks: ticks
});
}
else if (command == "Resume") {
promise = ApiClient.sendPlayCommand(sessionIds[0], {
ItemIds: [item.Id].join(','),
PlayCommand: 'PlayNow',
StartPositionTicks: item.UserData.PlaybackPositionTicks
});
}
else if (command == "Trailer" || command == "SpecialFeature" || command == "ThemeSong" || command == "ThemeVideo") {
var id = $('.chkSelectItem:checked', popup).parents('.trItem').attr('data-id');
if (!id) {
Dashboard.alert('Please select an item.');
return false;
}
promise = ApiClient.sendPlayCommand(sessionIds[0], {
ItemIds: [id].join(','),
PlayCommand: $('#fldPlayCommand', popup).val()
2013-05-28 21:00:24 -07:00
});
}
promise.done(function () {
$('#remoteControlFlyout').popup("close");
});
return false;
});
var elem = $('.sessionsPopupContent');
$.when(sessionsPromise, usersPromise).done(function (response1, response2) {
var deviceId = ApiClient.deviceId();
var sessions = response1[0].filter(function (s) {
return s.DeviceId != deviceId;
});
2013-05-30 12:58:07 -07:00
renderSessions(sessions, response2[0], options, elem);
$('#selectCommand', popup).on('change', function () {
var playFromMenu = $('.playFromMenu', popup).hide();
var trailersElem = $('.trailers', popup).hide();
var specialFeaturesElem = $('.specialFeatures', popup).hide();
var themeSongsElem = $('.themeSongs', popup).hide();
var themeVideosElem = $('.themeVideos', popup).hide();
var playButtonContainer = $('#playButtonContainer', popup).hide();
var queueButtonContainer = $('#queueButtonContainer', popup).hide();
var okButtonContainer = $('#okButtonContainer', popup).hide();
var value = this.value;
if (value == "Browse") {
okButtonContainer.show();
}
else if (value == "Play") {
playButtonContainer.show();
queueButtonContainer.show();
}
else if (value == "Resume") {
playButtonContainer.show();
}
else if (value == "PlayFromChapter" && item.Chapters && item.Chapters.length) {
2013-05-28 21:00:24 -07:00
2013-05-30 12:58:07 -07:00
playFromMenu.show();
playButtonContainer.show();
if (!playFromRendered) {
playFromRendered = true;
renderPlayFromOptions(playFromMenu, item);
}
$('#remoteControlFlyout').popup("reposition", { tolerance: 0 });
}
else if (value == "Trailer") {
trailersElem.show();
playButtonContainer.show();
queueButtonContainer.show();
if (!trailersRendered) {
trailersRendered = true;
ApiClient.getLocalTrailers(Dashboard.getCurrentUserId(), item.Id).done(function (trailers) {
renderVideos(trailersElem, trailers, 'Trailers');
$('#remoteControlFlyout').popup("reposition", { tolerance: 0 });
});
}
}
else if (value == "SpecialFeature") {
specialFeaturesElem.show();
playButtonContainer.show();
queueButtonContainer.show();
if (!specialFeaturesRendered) {
specialFeaturesRendered = true;
ApiClient.getSpecialFeatures(Dashboard.getCurrentUserId(), item.Id).done(function (videos) {
renderVideos(specialFeaturesElem, videos, 'Special Features');
$('#remoteControlFlyout').popup("reposition", { tolerance: 0 });
});
}
}
else if (value == "ThemeSong") {
themeSongsElem.show();
playButtonContainer.show();
queueButtonContainer.show();
if (!themeSongsRendered) {
themeSongsRendered = true;
ApiClient.getThemeSongs(Dashboard.getCurrentUserId(), item.Id).done(function (result) {
renderVideos(themeSongsElem, result.Items, 'Theme Songs');
$('#remoteControlFlyout').popup("reposition", { tolerance: 0 });
});
}
}
else if (value == "ThemeVideo") {
themeVideosElem.show();
playButtonContainer.show();
queueButtonContainer.show();
if (!themeVideosRendered) {
themeVideosRendered = true;
ApiClient.getThemeVideos(Dashboard.getCurrentUserId(), item.Id).done(function (result) {
renderVideos(themeVideosElem, result.Items, 'Theme Videos');
$('#remoteControlFlyout').popup("reposition", { tolerance: 0 });
});
}
}
});
2013-05-28 21:00:24 -07:00
});
}
2013-05-30 12:58:07 -07:00
function renderPlayFromOptions(elem, item) {
var html = '';
html += '<h4 style="margin: 1em 0 .5em;">Play from scene</h4>';
html += '<div class="playMenuOptions">';
html += '<table class="tblRemoteControl tblRemoteControlNoHeader">';
html += '<tbody>';
for (var i = 0, length = item.Chapters.length; i < length; i++) {
var chapter = item.Chapters[i];
html += '<tr class="trSelectPlayTime" data-ticks="' + chapter.StartPositionTicks + '">';
var name = chapter.Name || ("Chapter " + (i + 1));
html += '<td class="tdSelectPlayTime"></td>';
html += '<td class="tdRemoteControlImage">';
var imgUrl;
if (chapter.ImageTag) {
imgUrl = ApiClient.getImageUrl(item.Id, {
maxheight: 80,
tag: chapter.ImageTag,
type: "Chapter",
index: i
});
} else {
imgUrl = "css/images/media/chapterflyout.png";
}
html += '<img src="' + imgUrl + '" />';
html += '</td>';
html += '<td>' + name + '<br/>' + DashboardPage.getDisplayText(chapter.StartPositionTicks) + '</td>';
html += '</tr>';
}
html += '</tbody>';
html += '</table>';
html += '</div>';
elem.html(html);
$('.tdSelectPlayTime', elem).html('<input type="radio" class="chkSelectPlayTime" name="chkSelectPlayTime" />');
$('.chkSelectPlayTime:first', elem).checked(true);
}
function renderSessions(sessions, users, options, elem) {
2013-05-28 21:00:24 -07:00
if (!sessions.length) {
elem.html('<p>There are currently no available media browser sessions to control.</p>');
$('#remoteControlFlyout').popup("reposition", {});
return;
}
2013-05-30 12:58:07 -07:00
var item = options.item;
2013-05-28 21:00:24 -07:00
var html = '';
2013-05-30 12:58:07 -07:00
html += '<div style="margin-top:0;">';
html += '<label for="selectCommand">Select command</label>';
2013-05-28 21:00:24 -07:00
html += '<select id="selectCommand" data-mini="true">';
2013-05-30 12:58:07 -07:00
html += '<option value="Browse">Browse to</label>';
2013-05-28 21:05:58 -07:00
if (item.Type != 'Person' && item.Type != 'Genre' && item.Type != 'Studio' && item.Type != 'Artist') {
2013-05-30 12:58:07 -07:00
2013-05-28 21:05:58 -07:00
html += '<option value="Play">Play</label>';
2013-05-30 12:58:07 -07:00
if (!item.IsFolder && item.UserData && item.UserData.PlaybackPositionTicks) {
html += '<option value="Resume">Resume</label>';
}
if (item.Chapters && item.Chapters.length) {
html += '<option value="PlayFromChapter">Play from scene</label>';
}
if (item.LocalTrailerCount) {
html += '<option value="Trailer">Play trailer</label>';
}
if (item.SpecialFeatureCount) {
html += '<option value="SpecialFeature">Play special feature</label>';
}
if (options.themeSongs) {
html += '<option value="ThemeSong">Play theme song</label>';
}
if (options.themeVideos) {
html += '<option value="ThemeVideo">Play theme video</label>';
}
2013-05-28 21:05:58 -07:00
}
2013-05-28 21:00:24 -07:00
html += '</select>';
2013-05-30 12:58:07 -07:00
html += '</div>';
2013-05-28 21:00:24 -07:00
2013-05-30 12:58:07 -07:00
html += '<div class="playFromMenu" style="display:none;"></div>';
html += '<div class="trailers" style="display:none;"></div>';
html += '<div class="specialFeatures" style="display:none;"></div>';
html += '<div class="themeSongs" style="display:none;"></div>';
html += '<div class="themeVideos" style="display:none;"></div>';
2013-05-28 21:00:24 -07:00
2013-05-30 12:58:07 -07:00
html += '<h4 style="margin: 1em 0 .5em;">Select Device</h4>';
2013-05-28 21:00:24 -07:00
2013-05-30 12:58:07 -07:00
html += '<table class="tblRemoteControl">';
2013-05-28 21:00:24 -07:00
html += '<thead><tr>';
html += '<th></th>';
html += '<th>Client</th>';
html += '<th>Device</th>';
html += '<th>User</th>';
2013-05-30 12:58:07 -07:00
html += '<th class="nowPlayingCell">Now Playing</th>';
2013-05-28 21:00:24 -07:00
html += '</tr></thead>';
html += '<tbody>';
for (var i = 0, length = sessions.length; i < length; i++) {
var session = sessions[i];
html += '<tr class="trSession" data-sessionid="' + session.Id + '">';
2013-05-30 12:58:07 -07:00
html += '<td class="tdSelectSession"></td>';
2013-05-28 21:00:24 -07:00
html += '<td>' + session.Client + '</td>';
html += '<td>' + session.DeviceName + '</td>';
html += '<td>';
var user = null;
if (session.UserId) {
user = users.filter(function (u) {
return u.Id == session.UserId;
})[0];
}
html += user ? user.Name : '&nbsp;';
html += '</td>';
2013-05-30 12:58:07 -07:00
html += '<td class="nowPlayingCell">';
html += session.NowPlayingItem ? session.NowPlayingItem.Name : '';
html += '</td>';
2013-05-28 21:00:24 -07:00
html += '</tr>';
}
html += '</tbody>';
html += '</table>';
html += '</div>';
elem.html(html).trigger('create');
2013-05-30 12:58:07 -07:00
$('.tdSelectSession', elem).html('<input type="radio" class="chkClient" name="chkClient" />');
$('.chkClient:first', elem).checked(true);
$('#remoteControlFlyout').popup("reposition", { tolerance: 0 });
}
function renderVideos(elem, videos, header) {
var html = '';
html += '<h4 style="margin: 1em 0 .5em;">' + header + '</h4>';
html += '<div class="playMenuOptions">';
html += '<table class="tblRemoteControl tblRemoteControlNoHeader">';
html += '<tbody>';
for (var i = 0, length = videos.length; i < length; i++) {
var video = videos[i];
html += '<tr class="trItem" data-id="' + video.Id + '">';
html += '<td class="tdSelectItem"></td>';
html += '<td class="tdRemoteControlImage">';
var imgUrl;
if (video.ImageTags && video.ImageTags.Primary) {
imgUrl = ApiClient.getImageUrl(video.Id, {
maxheight: 80,
tag: video.ImageTags.Primary,
type: "Primary"
});
html += '<img src="' + imgUrl + '" />';
}
html += '</td>';
html += '<td>' + video.Name;
if (video.RunTimeTicks) {
html += '<br/>' + DashboardPage.getDisplayText(video.RunTimeTicks);
}
html += '</td>';
html += '</tr>';
}
html += '</tbody>';
html += '</table>';
html += '</div>';
elem.html(html);
$('.tdSelectItem', elem).html('<input type="radio" class="chkSelectItem" name="chkSelectItem" />');
2013-05-28 21:00:24 -07:00
2013-05-30 12:58:07 -07:00
$('.chkSelectItem:first', elem).checked(true);
2013-05-28 21:00:24 -07:00
}
function remoteControl() {
var self = this;
2013-05-30 12:58:07 -07:00
self.showMenu = function (options) {
showMenu(options, ApiClient.getSessions({ SupportsRemoteControl: true }), ApiClient.getUsers());
2013-05-28 18:45:39 -07:00
};
}
window.RemoteControl = new remoteControl();
})(window, document, jQuery);