1
0
Fork 0
mirror of https://github.com/jellyfin/jellyfin-web synced 2025-03-30 19:56:21 +00:00
jellyfin-web/src/controllers/livetv/livetvrecordings.js

107 lines
3.7 KiB
JavaScript
Raw Normal View History

define(["layoutManager", "loading", "cardBuilder", "apphost", "imageLoader", "scripts/livetvcomponents", "listViewStyle", "emby-itemscontainer"], function (layoutManager, loading, cardBuilder, appHost, imageLoader) {
2018-10-23 01:05:09 +03:00
"use strict";
function renderRecordings(elem, recordings, cardOptions, scrollX) {
if (recordings.length) {
elem.classList.remove("hide");
} else {
elem.classList.add("hide");
}
2018-10-23 01:05:09 +03:00
var recordingItems = elem.querySelector(".recordingItems");
if (scrollX) {
recordingItems.classList.add("scrollX");
recordingItems.classList.add("hiddenScrollX");
recordingItems.classList.remove("vertical-wrap");
} else {
recordingItems.classList.remove("scrollX");
recordingItems.classList.remove("hiddenScrollX");
recordingItems.classList.add("vertical-wrap");
}
2018-10-23 01:05:09 +03:00
appHost.supports("imageanalysis");
recordingItems.innerHTML = cardBuilder.getCardsHtml(Object.assign({
items: recordings,
shape: scrollX ? "autooverflow" : "auto",
defaultShape: scrollX ? "overflowBackdrop" : "backdrop",
showTitle: true,
showParentTitle: true,
coverImage: true,
cardLayout: false,
centerText: true,
2018-10-23 01:05:09 +03:00
allowBottomPadding: !scrollX,
preferThumb: "auto",
overlayText: false
}, cardOptions || {}));
imageLoader.lazyChildren(recordingItems);
2018-10-23 01:05:09 +03:00
}
function renderLatestRecordings(context, promise) {
promise.then(function (result) {
2018-10-23 01:05:09 +03:00
renderRecordings(context.querySelector("#latestRecordings"), result.Items, {
showYear: true,
2018-10-23 01:05:09 +03:00
lines: 2
}, false);
loading.hide();
});
2018-10-23 01:05:09 +03:00
}
function renderRecordingFolders(context, promise) {
promise.then(function (result) {
2018-10-23 01:05:09 +03:00
renderRecordings(context.querySelector("#recordingFolders"), result.Items, {
showYear: false,
showParentTitle: false
}, false);
});
2018-10-23 01:05:09 +03:00
}
function onMoreClick(e) {
var type = this.getAttribute("data-type");
var serverId = ApiClient.serverId();
2018-10-23 01:05:09 +03:00
switch (type) {
case "latest":
Dashboard.navigate("list.html?type=Recordings&serverId=" + serverId);
2018-10-23 01:05:09 +03:00
}
}
return function (view, params, tabContent) {
2018-10-23 01:05:09 +03:00
function enableFullRender() {
return new Date().getTime() - lastFullRender > 300000;
2018-10-23 01:05:09 +03:00
}
var foldersPromise;
var latestPromise;
var self = this;
var lastFullRender = 0;
var moreButtons = tabContent.querySelectorAll(".more");
for (var i = 0, length = moreButtons.length; i < length; i++) {
moreButtons[i].addEventListener("click", onMoreClick);
2018-10-23 01:05:09 +03:00
}
self.preRender = function () {
if (enableFullRender()) {
latestPromise = ApiClient.getLiveTvRecordings({
UserId: Dashboard.getCurrentUserId(),
Limit: 12,
Fields: "CanDelete,PrimaryImageAspectRatio,BasicSyncInfo",
EnableTotalRecordCount: false,
EnableImageTypes: "Primary,Thumb,Backdrop"
});
foldersPromise = ApiClient.getRecordingFolders(Dashboard.getCurrentUserId());
}
};
self.renderTab = function () {
if (enableFullRender()) {
loading.show();
renderLatestRecordings(tabContent, latestPromise);
renderRecordingFolders(tabContent, foldersPromise);
lastFullRender = new Date().getTime();
}
};
};
});