mirror of
https://github.com/jellyfin/jellyfin-web
synced 2025-03-30 19:56:21 +00:00
Merge branch 'master' of https://github.com/MediaBrowser/MediaBrowser
This commit is contained in:
commit
71a0792f0e
4 changed files with 206 additions and 122 deletions
|
@ -167,35 +167,35 @@
|
||||||
|
|
||||||
if (imageTags.Logo) {
|
if (imageTags.Logo) {
|
||||||
|
|
||||||
html += createGalleryImage(item.Id, "Logo", item.ImageTags.Logo);
|
html += LibraryBrowser.createGalleryImage(item.Id, "Logo", item.ImageTags.Logo);
|
||||||
}
|
}
|
||||||
if (imageTags.Thumb) {
|
if (imageTags.Thumb) {
|
||||||
|
|
||||||
html += createGalleryImage(item.Id, "Thumb", item.ImageTags.Thumb);
|
html += LibraryBrowser.createGalleryImage(item.Id, "Thumb", item.ImageTags.Thumb);
|
||||||
}
|
}
|
||||||
if (imageTags.Art) {
|
if (imageTags.Art) {
|
||||||
|
|
||||||
html += createGalleryImage(item.Id, "Art", item.ImageTags.Art);
|
html += LibraryBrowser.createGalleryImage(item.Id, "Art", item.ImageTags.Art);
|
||||||
|
|
||||||
}
|
}
|
||||||
if (imageTags.Menu) {
|
if (imageTags.Menu) {
|
||||||
|
|
||||||
html += createGalleryImage(item.Id, "Menu", item.ImageTags.Menu);
|
html += LibraryBrowser.createGalleryImage(item.Id, "Menu", item.ImageTags.Menu);
|
||||||
|
|
||||||
}
|
}
|
||||||
if (imageTags.Disc) {
|
if (imageTags.Disc) {
|
||||||
|
|
||||||
html += createGalleryImage(item.Id, "Disc", item.ImageTags.Disc);
|
html += LibraryBrowser.createGalleryImage(item.Id, "Disc", item.ImageTags.Disc);
|
||||||
}
|
}
|
||||||
if (imageTags.Box) {
|
if (imageTags.Box) {
|
||||||
|
|
||||||
html += createGalleryImage(item.Id, "Box", item.ImageTags.Box);
|
html += LibraryBrowser.createGalleryImage(item.Id, "Box", item.ImageTags.Box);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (item.BackdropImageTags) {
|
if (item.BackdropImageTags) {
|
||||||
|
|
||||||
for (i = 0, length = item.BackdropImageTags.length; i < length; i++) {
|
for (i = 0, length = item.BackdropImageTags.length; i < length; i++) {
|
||||||
html += createGalleryImage(item.Id, "Backdrop", item.BackdropImageTags[0], i);
|
html += LibraryBrowser.createGalleryImage(item.Id, "Backdrop", item.BackdropImageTags[0], i);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -203,44 +203,13 @@
|
||||||
if (item.ScreenshotImageTags) {
|
if (item.ScreenshotImageTags) {
|
||||||
|
|
||||||
for (i = 0, length = item.ScreenshotImageTags.length; i < length; i++) {
|
for (i = 0, length = item.ScreenshotImageTags.length; i < length; i++) {
|
||||||
html += createGalleryImage(item.Id, "Screenshot", item.ScreenshotImageTags[0], i);
|
html += LibraryBrowser.createGalleryImage(item.Id, "Screenshot", item.ScreenshotImageTags[0], i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$('#galleryContent', page).html(html).trigger('create');
|
$('#galleryContent', page).html(html).trigger('create');
|
||||||
}
|
}
|
||||||
|
|
||||||
function createGalleryImage(itemId, type, tag, index) {
|
|
||||||
|
|
||||||
var downloadWidth = 400;
|
|
||||||
var lightboxWidth = 800;
|
|
||||||
var html = '';
|
|
||||||
|
|
||||||
if (typeof (index) == "undefined") index = 0;
|
|
||||||
|
|
||||||
html += '<div class="posterViewItem" style="padding-bottom:0px;">';
|
|
||||||
html += '<a href="#pop_' + index + '_' + tag + '" data-transition="fade" data-rel="popup" data-position-to="window">';
|
|
||||||
html += '<img class="galleryImage" src="' + ApiClient.getImageUrl(itemId, {
|
|
||||||
type: type,
|
|
||||||
maxwidth: downloadWidth,
|
|
||||||
tag: tag,
|
|
||||||
index: index
|
|
||||||
}) + '" />';
|
|
||||||
html += '</div>';
|
|
||||||
|
|
||||||
html += '<div class="galleryPopup" id="pop_' + index + '_' + tag + '" data-role="popup" data-theme="d" data-corners="false" data-overlay-theme="a">';
|
|
||||||
html += '<a href="#" data-rel="back" data-role="button" data-theme="a" data-icon="delete" data-iconpos="notext" class="ui-btn-right">Close</a>';
|
|
||||||
html += '<img class="" src="' + ApiClient.getImageUrl(itemId, {
|
|
||||||
type: type,
|
|
||||||
maxwidth: lightboxWidth,
|
|
||||||
tag: tag,
|
|
||||||
index: index
|
|
||||||
}) + '" />';
|
|
||||||
html += '</div>';
|
|
||||||
|
|
||||||
return html;
|
|
||||||
}
|
|
||||||
|
|
||||||
function renderMediaInfo(page, item) {
|
function renderMediaInfo(page, item) {
|
||||||
|
|
||||||
var html = '';
|
var html = '';
|
||||||
|
@ -434,31 +403,8 @@
|
||||||
for (var i = 0, length = casts.length; i < length; i++) {
|
for (var i = 0, length = casts.length; i < length; i++) {
|
||||||
|
|
||||||
var cast = casts[i];
|
var cast = casts[i];
|
||||||
var role = cast.Role || cast.Type;
|
|
||||||
|
|
||||||
html += '<a href="itembynamedetails.html?person=' + cast.Name + '">';
|
|
||||||
html += '<div class="posterViewItem posterViewItemWithDualText">';
|
|
||||||
|
|
||||||
if (cast.PrimaryImageTag) {
|
|
||||||
|
|
||||||
var imgUrl = ApiClient.getPersonImageUrl(cast.Name, {
|
|
||||||
width: 185,
|
|
||||||
tag: cast.PrimaryImageTag,
|
|
||||||
type: "primary"
|
|
||||||
});
|
|
||||||
|
|
||||||
html += '<img src="' + imgUrl + '" />';
|
|
||||||
} else {
|
|
||||||
var style = "background-color:" + LibraryBrowser.getMetroColor(cast.Name) + ";";
|
|
||||||
|
|
||||||
html += '<img src="css/images/items/list/person.png" style="max-width:185px; ' + style + '"/>';
|
|
||||||
}
|
|
||||||
|
|
||||||
html += '<div class="posterViewItemText posterViewItemPrimaryText">' + cast.Name + '</div>';
|
|
||||||
html += '<div class="posterViewItemText">' + role + '</div>';
|
|
||||||
|
|
||||||
html += '</div></a>';
|
|
||||||
|
|
||||||
|
html += LibraryBrowser.createCastImage(cast);
|
||||||
}
|
}
|
||||||
|
|
||||||
$('#castContent', page).html(html);
|
$('#castContent', page).html(html);
|
||||||
|
|
|
@ -90,35 +90,35 @@
|
||||||
|
|
||||||
if (imageTags.Logo) {
|
if (imageTags.Logo) {
|
||||||
|
|
||||||
html += createGalleryImage(item.Id, "Logo", item.ImageTags.Logo);
|
html += LibraryBrowser.createGalleryImage(item.Id, "Logo", item.ImageTags.Logo);
|
||||||
}
|
}
|
||||||
if (imageTags.Thumb) {
|
if (imageTags.Thumb) {
|
||||||
|
|
||||||
html += createGalleryImage(item.Id, "Thumb", item.ImageTags.Thumb);
|
html += LibraryBrowser.createGalleryImage(item.Id, "Thumb", item.ImageTags.Thumb);
|
||||||
}
|
}
|
||||||
if (imageTags.Art) {
|
if (imageTags.Art) {
|
||||||
|
|
||||||
html += createGalleryImage(item.Id, "Art", item.ImageTags.Art);
|
html += LibraryBrowser.createGalleryImage(item.Id, "Art", item.ImageTags.Art);
|
||||||
|
|
||||||
}
|
}
|
||||||
if (imageTags.Menu) {
|
if (imageTags.Menu) {
|
||||||
|
|
||||||
html += createGalleryImage(item.Id, "Menu", item.ImageTags.Menu);
|
html += LibraryBrowser.createGalleryImage(item.Id, "Menu", item.ImageTags.Menu);
|
||||||
|
|
||||||
}
|
}
|
||||||
if (imageTags.Disc) {
|
if (imageTags.Disc) {
|
||||||
|
|
||||||
html += createGalleryImage(item.Id, "Disc", item.ImageTags.Disc);
|
html += LibraryBrowser.createGalleryImage(item.Id, "Disc", item.ImageTags.Disc);
|
||||||
}
|
}
|
||||||
if (imageTags.Box) {
|
if (imageTags.Box) {
|
||||||
|
|
||||||
html += createGalleryImage(item.Id, "Box", item.ImageTags.Box);
|
html += LibraryBrowser.createGalleryImage(item.Id, "Box", item.ImageTags.Box);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (item.BackdropImageTags) {
|
if (item.BackdropImageTags) {
|
||||||
|
|
||||||
for (var i = 0, length = item.BackdropImageTags.length; i < length; i++) {
|
for (var i = 0, length = item.BackdropImageTags.length; i < length; i++) {
|
||||||
html += createGalleryImage(item.Id, "Backdrop", item.BackdropImageTags[0], i);
|
html += LibraryBrowser.createGalleryImage(item.Id, "Backdrop", item.BackdropImageTags[0], i);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -126,37 +126,6 @@
|
||||||
$('#galleryContent', page).html(html).trigger('create');
|
$('#galleryContent', page).html(html).trigger('create');
|
||||||
}
|
}
|
||||||
|
|
||||||
function createGalleryImage(itemId, type, tag, index) {
|
|
||||||
|
|
||||||
var downloadWidth = 400;
|
|
||||||
var lightboxWidth = 800;
|
|
||||||
var html = '';
|
|
||||||
|
|
||||||
if (typeof (index) == "undefined") index = 0;
|
|
||||||
|
|
||||||
html += '<div class="posterViewItem" style="padding-bottom:0px;">';
|
|
||||||
html += '<a href="#pop_' + index + '_' + tag + '" data-transition="fade" data-rel="popup" data-position-to="window">';
|
|
||||||
html += '<img class="galleryImage" src="' + ApiClient.getImageUrl(itemId, {
|
|
||||||
type: type,
|
|
||||||
maxwidth: downloadWidth,
|
|
||||||
tag: tag,
|
|
||||||
index: index
|
|
||||||
}) + '" />';
|
|
||||||
html += '</div>';
|
|
||||||
|
|
||||||
html += '<div class="galleryPopup" id="pop_' + index + '_' + tag + '" data-role="popup" data-theme="d" data-corners="false" data-overlay-theme="a">';
|
|
||||||
html += '<a href="#" data-rel="back" data-role="button" data-theme="a" data-icon="delete" data-iconpos="notext" class="ui-btn-right">Close</a>';
|
|
||||||
html += '<img class="" src="' + ApiClient.getImageUrl(itemId, {
|
|
||||||
type: type,
|
|
||||||
maxwidth: lightboxWidth,
|
|
||||||
tag: tag,
|
|
||||||
index: index
|
|
||||||
}) + '" />';
|
|
||||||
html += '</div>';
|
|
||||||
|
|
||||||
return html;
|
|
||||||
}
|
|
||||||
|
|
||||||
function renderTrailers(page, item) {
|
function renderTrailers(page, item) {
|
||||||
var html = '';
|
var html = '';
|
||||||
|
|
||||||
|
|
|
@ -976,6 +976,69 @@
|
||||||
html += "</a></div>";
|
html += "</a></div>";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return html;
|
||||||
|
},
|
||||||
|
|
||||||
|
createGalleryImage: function (itemId, type, tag, index) {
|
||||||
|
|
||||||
|
var downloadWidth = 400;
|
||||||
|
var lightboxWidth = 800;
|
||||||
|
var html = '';
|
||||||
|
|
||||||
|
if (typeof (index) == "undefined") index = 0;
|
||||||
|
|
||||||
|
html += '<div class="posterViewItem" style="padding-bottom:0px;">';
|
||||||
|
html += '<a href="#pop_' + index + '_' + tag + '" data-transition="fade" data-rel="popup" data-position-to="window">';
|
||||||
|
html += '<img class="galleryImage" src="' + ApiClient.getImageUrl(itemId, {
|
||||||
|
type: type,
|
||||||
|
maxwidth: downloadWidth,
|
||||||
|
tag: tag,
|
||||||
|
index: index
|
||||||
|
}) + '" />';
|
||||||
|
html += '</div>';
|
||||||
|
|
||||||
|
html += '<div class="galleryPopup" id="pop_' + index + '_' + tag + '" data-role="popup" data-theme="d" data-corners="false" data-overlay-theme="a">';
|
||||||
|
html += '<a href="#" data-rel="back" data-role="button" data-theme="a" data-icon="delete" data-iconpos="notext" class="ui-btn-right">Close</a>';
|
||||||
|
html += '<img class="" src="' + ApiClient.getImageUrl(itemId, {
|
||||||
|
type: type,
|
||||||
|
maxwidth: lightboxWidth,
|
||||||
|
tag: tag,
|
||||||
|
index: index
|
||||||
|
}) + '" />';
|
||||||
|
html += '</div>';
|
||||||
|
|
||||||
|
return html;
|
||||||
|
},
|
||||||
|
|
||||||
|
createCastImage: function (cast) {
|
||||||
|
|
||||||
|
var html = '';
|
||||||
|
|
||||||
|
var role = cast.Role || cast.Type;
|
||||||
|
|
||||||
|
html += '<a href="itembynamedetails.html?person=' + cast.Name + '">';
|
||||||
|
html += '<div class="posterViewItem posterViewItemWithDualText">';
|
||||||
|
|
||||||
|
if (cast.PrimaryImageTag) {
|
||||||
|
|
||||||
|
var imgUrl = ApiClient.getPersonImageUrl(cast.Name, {
|
||||||
|
width: 185,
|
||||||
|
tag: cast.PrimaryImageTag,
|
||||||
|
type: "primary"
|
||||||
|
});
|
||||||
|
|
||||||
|
html += '<img src="' + imgUrl + '" />';
|
||||||
|
} else {
|
||||||
|
var style = "background-color:" + LibraryBrowser.getMetroColor(cast.Name) + ";";
|
||||||
|
|
||||||
|
html += '<img src="css/images/items/list/person.png" style="max-width:185px; ' + style + '"/>';
|
||||||
|
}
|
||||||
|
|
||||||
|
html += '<div class="posterViewItemText posterViewItemPrimaryText">' + cast.Name + '</div>';
|
||||||
|
html += '<div class="posterViewItemText">' + role + '</div>';
|
||||||
|
|
||||||
|
html += '</div></a>';
|
||||||
|
|
||||||
return html;
|
return html;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
(function ($, document, LibraryBrowser) {
|
(function ($, document, LibraryBrowser, window) {
|
||||||
|
|
||||||
|
var currentItem;
|
||||||
|
|
||||||
function reload(page) {
|
function reload(page) {
|
||||||
|
|
||||||
|
@ -8,6 +10,8 @@
|
||||||
|
|
||||||
ApiClient.getItem(Dashboard.getCurrentUserId(), id).done(function (item) {
|
ApiClient.getItem(Dashboard.getCurrentUserId(), id).done(function (item) {
|
||||||
|
|
||||||
|
currentItem = item;
|
||||||
|
|
||||||
var name = item.Name;
|
var name = item.Name;
|
||||||
|
|
||||||
$('#itemImage', page).html(LibraryBrowser.getDetailImageHtml(item));
|
$('#itemImage', page).html(LibraryBrowser.getDetailImageHtml(item));
|
||||||
|
@ -16,12 +20,22 @@
|
||||||
|
|
||||||
$('#itemName', page).html(name);
|
$('#itemName', page).html(name);
|
||||||
|
|
||||||
|
setInitialCollapsibleState(page, item);
|
||||||
renderDetails(page, item);
|
renderDetails(page, item);
|
||||||
|
|
||||||
Dashboard.hideLoadingMsg();
|
Dashboard.hideLoadingMsg();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function setInitialCollapsibleState(page, item) {
|
||||||
|
|
||||||
|
if (!item.People || !item.People.length) {
|
||||||
|
$('#castCollapsible', page).hide();
|
||||||
|
} else {
|
||||||
|
$('#castCollapsible', page).show();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function renderDetails(page, item) {
|
function renderDetails(page, item) {
|
||||||
|
|
||||||
if (item.Taglines && item.Taglines.length) {
|
if (item.Taglines && item.Taglines.length) {
|
||||||
|
@ -73,12 +87,81 @@
|
||||||
useAverageAspectRatio: true
|
useAverageAspectRatio: true
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
$('#seasonsContent', page).html(html);
|
$('#seasonsContent', page).html(html);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
$(document).on('pageshow', "#tvSeriesPage", function () {
|
function renderGallery(page, item) {
|
||||||
|
|
||||||
|
var imageTags = item.ImageTags || {};
|
||||||
|
var html = '';
|
||||||
|
var i, length;
|
||||||
|
|
||||||
|
if (imageTags.Logo) {
|
||||||
|
|
||||||
|
html += LibraryBrowser.createGalleryImage(item.Id, "Logo", item.ImageTags.Logo);
|
||||||
|
}
|
||||||
|
if (imageTags.Thumb) {
|
||||||
|
|
||||||
|
html += LibraryBrowser.createGalleryImage(item.Id, "Thumb", item.ImageTags.Thumb);
|
||||||
|
}
|
||||||
|
if (imageTags.Art) {
|
||||||
|
|
||||||
|
html += LibraryBrowser.createGalleryImage(item.Id, "Art", item.ImageTags.Art);
|
||||||
|
|
||||||
|
}
|
||||||
|
if (imageTags.Menu) {
|
||||||
|
|
||||||
|
html += LibraryBrowser.createGalleryImage(item.Id, "Menu", item.ImageTags.Menu);
|
||||||
|
|
||||||
|
}
|
||||||
|
if (imageTags.Disc) {
|
||||||
|
|
||||||
|
html += LibraryBrowser.createGalleryImage(item.Id, "Disc", item.ImageTags.Disc);
|
||||||
|
}
|
||||||
|
if (imageTags.Box) {
|
||||||
|
|
||||||
|
html += LibraryBrowser.createGalleryImage(item.Id, "Box", item.ImageTags.Box);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (item.BackdropImageTags) {
|
||||||
|
|
||||||
|
for (i = 0, length = item.BackdropImageTags.length; i < length; i++) {
|
||||||
|
html += LibraryBrowser.createGalleryImage(item.Id, "Backdrop", item.BackdropImageTags[0], i);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (item.ScreenshotImageTags) {
|
||||||
|
|
||||||
|
for (i = 0, length = item.ScreenshotImageTags.length; i < length; i++) {
|
||||||
|
html += LibraryBrowser.createGalleryImage(item.Id, "Screenshot", item.ScreenshotImageTags[0], i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$('#galleryContent', page).html(html).trigger('create');
|
||||||
|
}
|
||||||
|
|
||||||
|
function renderCast(page, item) {
|
||||||
|
var html = '';
|
||||||
|
|
||||||
|
var casts = item.People || [];
|
||||||
|
|
||||||
|
for (var i = 0, length = casts.length; i < length; i++) {
|
||||||
|
|
||||||
|
var cast = casts[i];
|
||||||
|
|
||||||
|
html += LibraryBrowser.createCastImage(cast);
|
||||||
|
}
|
||||||
|
|
||||||
|
$('#castContent', page).html(html);
|
||||||
|
}
|
||||||
|
|
||||||
|
$(document).on('pageinit', "#tvSeriesPage", function () {
|
||||||
|
|
||||||
|
var page = this;
|
||||||
|
|
||||||
|
}).on('pageshow', "#tvSeriesPage", function () {
|
||||||
|
|
||||||
var page = this;
|
var page = this;
|
||||||
|
|
||||||
|
@ -91,12 +174,35 @@
|
||||||
$(this).off('expand.lazyload');
|
$(this).off('expand.lazyload');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$('#castCollapsible', page).on('expand.lazyload', function () {
|
||||||
|
renderCast(page, currentItem);
|
||||||
|
|
||||||
|
$(this).off('expand.lazyload');
|
||||||
|
});
|
||||||
|
|
||||||
|
$('#galleryCollapsible', page).on('expand.lazyload', function () {
|
||||||
|
|
||||||
|
renderGallery(page, currentItem);
|
||||||
|
|
||||||
|
$(this).off('expand.lazyload');
|
||||||
|
});
|
||||||
|
|
||||||
}).on('pagehide', "#tvSeriesPage", function () {
|
}).on('pagehide', "#tvSeriesPage", function () {
|
||||||
|
|
||||||
|
currentItem = null;
|
||||||
var page = this;
|
var page = this;
|
||||||
|
|
||||||
$('#seasonsCollapsible', page).off('expand.lazyload');
|
$('#seasonsCollapsible', page).off('expand.lazyload');
|
||||||
|
$('#castCollapsible', page).off('expand.lazyload');
|
||||||
|
$('#galleryCollapsible', page).off('expand.lazyload');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
function tvSeriesPage() {
|
||||||
|
|
||||||
})(jQuery, document, LibraryBrowser);
|
var self = this;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
window.TvSeriesPage = new tvSeriesPage();
|
||||||
|
|
||||||
|
})(jQuery, document, LibraryBrowser, window);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue