jellyfish-web/src/controllers/shows/tvlatest.js

71 lines
2.2 KiB
JavaScript
Raw Normal View History

2020-07-12 15:25:49 +01:00
import loading from 'loading';
import groupedcards from 'components/groupedcards';
import cardBuilder from 'cardBuilder';
import appHost from 'apphost';
import imageLoader from 'imageLoader';
/* eslint-disable indent */
2018-10-23 01:05:09 +03:00
function getLatestPromise(context, params) {
loading.show();
2020-07-12 15:25:49 +01:00
const userId = ApiClient.getCurrentUserId();
const parentId = params.topParentId;
const options = {
2020-05-04 12:44:12 +02:00
IncludeItemTypes: 'Episode',
Limit: 30,
2020-05-04 12:44:12 +02:00
Fields: 'PrimaryImageAspectRatio,BasicSyncInfo',
ParentId: parentId,
ImageTypeLimit: 1,
2020-05-04 12:44:12 +02:00
EnableImageTypes: 'Primary,Backdrop,Thumb'
};
2020-05-04 12:44:12 +02:00
return ApiClient.getJSON(ApiClient.getUrl('Users/' + userId + '/Items/Latest', options));
2018-10-23 01:05:09 +03:00
}
function loadLatest(context, params, promise) {
promise.then(function (items) {
2020-07-12 15:25:49 +01:00
let html = '';
2020-05-04 12:44:12 +02:00
appHost.supports('imageanalysis');
2018-10-23 01:05:09 +03:00
html += cardBuilder.getCardsHtml({
items: items,
2020-05-04 12:44:12 +02:00
shape: 'backdrop',
preferThumb: true,
showTitle: true,
showSeriesYear: true,
showParentTitle: true,
overlayText: false,
cardLayout: false,
showUnplayedIndicator: false,
showChildCountIndicator: true,
centerText: true,
lazy: true,
overlayPlayButton: true,
2018-10-23 01:05:09 +03:00
lines: 2
});
2020-07-12 15:25:49 +01:00
const elem = context.querySelector('#latestEpisodes');
elem.innerHTML = html;
imageLoader.lazyChildren(elem);
loading.hide();
2019-11-02 20:38:58 +03:00
2020-07-12 15:25:49 +01:00
import('autoFocuser').then(({default: autoFocuser}) => {
2019-11-02 20:38:58 +03:00
autoFocuser.autoFocus(context);
});
});
2018-10-23 01:05:09 +03:00
}
2020-07-12 15:25:49 +01:00
export default function (view, params, tabContent) {
const self = this;
let latestPromise;
self.preRender = function () {
latestPromise = getLatestPromise(view, params);
};
self.renderTab = function () {
loadLatest(tabContent, params, latestPromise);
};
2020-07-12 15:25:49 +01:00
tabContent.querySelector('#latestEpisodes').addEventListener('click', groupedcards);
}
/* eslint-enable indent */