mirror of
https://github.com/jellyfin/jellyfin-web.git
synced 2024-11-18 03:18:19 -07:00
97 lines
2.7 KiB
JavaScript
97 lines
2.7 KiB
JavaScript
define(['libraryBrowser', 'cardBuilder', 'imageLoader', 'emby-itemscontainer', 'emby-tabs', 'emby-button', 'scripts/channelslatest', 'scripts/sections'], function (libraryBrowser, cardBuilder, imageLoader) {
|
|
'use strict';
|
|
|
|
// The base query options
|
|
var query = {
|
|
|
|
StartIndex: 0
|
|
};
|
|
|
|
function reloadItems(page) {
|
|
|
|
Dashboard.showLoadingMsg();
|
|
|
|
query.UserId = Dashboard.getCurrentUserId();
|
|
|
|
ApiClient.getJSON(ApiClient.getUrl("Channels", query)).then(function (result) {
|
|
|
|
// Scroll back up so they can see the results from the beginning
|
|
window.scrollTo(0, 0);
|
|
|
|
var html = '';
|
|
|
|
var view = 'Thumb';
|
|
|
|
if (view == "Thumb") {
|
|
|
|
html = cardBuilder.getCardsHtml({
|
|
items: result.Items,
|
|
shape: "backdrop",
|
|
context: 'channels',
|
|
showTitle: true,
|
|
lazy: true,
|
|
centerText: true,
|
|
preferThumb: true
|
|
});
|
|
|
|
}
|
|
else if (view == "ThumbCard") {
|
|
|
|
html = cardBuilder.getCardsHtml({
|
|
items: result.Items,
|
|
shape: "backdrop",
|
|
preferThumb: true,
|
|
context: 'channels',
|
|
lazy: true,
|
|
cardLayout: true,
|
|
showTitle: true
|
|
});
|
|
}
|
|
|
|
var elem = page.querySelector('#items');
|
|
elem.innerHTML = html;
|
|
imageLoader.lazyChildren(elem);
|
|
|
|
libraryBrowser.saveQueryValues('channels', query);
|
|
|
|
Dashboard.hideLoadingMsg();
|
|
});
|
|
}
|
|
|
|
function loadTab(page, index) {
|
|
|
|
switch (index) {
|
|
|
|
case 1:
|
|
libraryBrowser.loadSavedQueryValues('channels', query);
|
|
reloadItems(page);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
return function (view, params) {
|
|
|
|
var self = this;
|
|
var viewTabs = view.querySelector('.libraryViewNav');
|
|
|
|
libraryBrowser.configurePaperLibraryTabs(view, viewTabs, view.querySelectorAll('.pageTabContent'), [0, 1]);
|
|
|
|
viewTabs.addEventListener('tabchange', function (e) {
|
|
loadTab(view, parseInt(e.detail.selectedTabIndex));
|
|
});
|
|
|
|
require(["headroom-window"], function (headroom) {
|
|
headroom.add(viewTabs);
|
|
self.headroom = headroom;
|
|
});
|
|
|
|
view.addEventListener('viewdestroy', function (e) {
|
|
|
|
if (self.headroom) {
|
|
self.headroom.remove(viewTabs);
|
|
}
|
|
});
|
|
};
|
|
}); |