jellyfin-web/dashboard-ui/scripts/secondaryitems.js
2016-12-06 03:24:29 -05:00

274 lines
8.5 KiB
JavaScript

define(['libraryBrowser', 'listView', 'cardBuilder', 'imageLoader', 'emby-itemscontainer'], function (libraryBrowser, listView, cardBuilder, imageLoader) {
'use strict';
return function (view, params) {
var data = {};
function addCurrentItemToQuery(query, item) {
if (params.parentId) {
query.ParentId = params.parentId;
}
if (item.Type == "Person") {
query.PersonIds = item.Id;
}
else if (item.Type == "Genre") {
query.Genres = item.Name;
}
else if (item.Type == "MusicGenre") {
query.Genres = item.Name;
}
else if (item.Type == "GameGenre") {
query.Genres = item.Name;
}
else if (item.Type == "Studio") {
query.StudioIds = item.Id;
}
else if (item.Type == "MusicArtist") {
query.ArtistIds = item.Id;
} else {
query.ParentId = item.Id;
}
}
function getQuery(parentItem) {
var key = getSavedQueryKey();
var pageData = data[key];
if (!pageData) {
pageData = data[key] = {
query: {
SortBy: "SortName",
SortOrder: "Ascending",
Recursive: params.recursive !== 'false',
Fields: "PrimaryImageAspectRatio,SortName,BasicSyncInfo",
ImageTypeLimit: 1,
EnableImageTypes: "Primary,Backdrop,Banner,Thumb",
StartIndex: 0,
Limit: libraryBrowser.getDefaultPageSize()
}
};
var type = params.type;
if (type) {
pageData.query.IncludeItemTypes = type;
if (type == 'Audio') {
pageData.query.SortBy = 'Album,SortName';
}
}
var filters = params.filters;
if (type) {
pageData.query.Filters = filters;
}
if (parentItem) {
addCurrentItemToQuery(pageData.query, parentItem);
}
libraryBrowser.loadSavedQueryValues(key, pageData.query);
}
return pageData.query;
}
function getSavedQueryKey() {
return libraryBrowser.getSavedQueryKey();
}
function parentWithClass(elem, className) {
while (!elem.classList || !elem.classList.contains(className)) {
elem = elem.parentNode;
if (!elem) {
return null;
}
}
return elem;
}
function onListItemClick(e) {
var mediaItem = parentWithClass(e.target, 'mediaItem');
if (mediaItem) {
var info = libraryBrowser.getListItemInfo(mediaItem);
if (info.mediaType == 'Photo') {
var query = getQuery();
require(['scripts/photos'], function () {
Photos.startSlideshow(view, query, info.id);
});
return false;
}
}
}
function onViewStyleChange(parentItem) {
var query = getQuery(parentItem);
var itemsContainer = view.querySelector('#items');
if (query.IncludeItemTypes == "Audio") {
itemsContainer.classList.add('vertical-list');
itemsContainer.classList.remove('vertical-wrap');
} else {
itemsContainer.classList.remove('vertical-list');
itemsContainer.classList.add('vertical-wrap');
}
}
function reloadItems(parentItem) {
Dashboard.showLoadingMsg();
var query = getQuery(parentItem);
ApiClient.getItems(Dashboard.getCurrentUserId(), query).then(function (result) {
// Scroll back up so they can see the results from the beginning
window.scrollTo(0, 0);
var html = '';
var pagingHtml = libraryBrowser.getQueryPagingHtml({
startIndex: query.StartIndex,
limit: query.Limit,
totalRecordCount: result.TotalRecordCount,
showLimit: false
});
view.querySelector('.listTopPaging').innerHTML = pagingHtml;
var itemsContainer = view.querySelector('#items');
if (query.IncludeItemTypes == "Audio") {
html = listView.getListViewHtml({
items: result.Items,
playFromHere: true,
action: 'playallfromhere',
smallIcon: true
});
} else {
var posterOptions = {
items: result.Items,
shape: "auto",
centerText: true,
lazy: true
};
if (query.IncludeItemTypes == "MusicAlbum") {
posterOptions.overlayText = false;
posterOptions.showParentTitle = true;
posterOptions.showTitle = true;
posterOptions.overlayPlayButton = true;
}
else if (query.IncludeItemTypes == "MusicArtist") {
posterOptions.overlayText = false;
posterOptions.overlayPlayButton = true;
}
else if (query.IncludeItemTypes == "Episode") {
posterOptions.overlayText = false;
posterOptions.showParentTitle = true;
posterOptions.showTitle = true;
posterOptions.overlayPlayButton = true;
}
// Poster
html = cardBuilder.getCardsHtml(posterOptions);
}
itemsContainer.innerHTML = html + pagingHtml;
imageLoader.lazyChildren(itemsContainer);
var i, length;
var elems;
function onNextPageClick() {
query.StartIndex += query.Limit;
reloadItems(view);
}
function onPreviousPageClick() {
query.StartIndex -= query.Limit;
reloadItems(view);
}
elems = view.querySelectorAll('.btnNextPage');
for (i = 0, length = elems.length; i < length; i++) {
elems[i].addEventListener('click', onNextPageClick);
}
elems = view.querySelectorAll('.btnPreviousPage');
for (i = 0, length = elems.length; i < length; i++) {
elems[i].addEventListener('click', onPreviousPageClick);
}
Dashboard.hideLoadingMsg();
});
}
view.addEventListener('click', onListItemClick);
function getItemPromise() {
var id = params.genreId || params.studioId || params.artistId || params.personId || params.parentId;
if (id) {
return ApiClient.getItem(Dashboard.getCurrentUserId(), id);
}
var name = params.genre;
if (name) {
return ApiClient.getGenre(name, Dashboard.getCurrentUserId());
}
name = params.musicgenre;
if (name) {
return ApiClient.getMusicGenre(name, Dashboard.getCurrentUserId());
}
name = params.gamegenre;
if (name) {
return ApiClient.getGameGenre(name, Dashboard.getCurrentUserId());
}
return null;
}
view.addEventListener('viewbeforeshow', function (e) {
var parentPromise = getItemPromise();
if (parentPromise) {
parentPromise.then(function (parent) {
LibraryMenu.setTitle(parent.Name);
onViewStyleChange(parent);
reloadItems(parent);
});
}
else {
onViewStyleChange();
reloadItems();
}
});
};
});