2016-10-03 02:28:45 -04:00
|
|
|
|
define(['datetime', 'dom', 'seriesRecordingEditor', 'listView', 'emby-itemscontainer'], function (datetime, dom, seriesRecordingEditor, listView) {
|
2016-10-23 01:11:46 -04:00
|
|
|
|
'use strict';
|
2013-12-15 09:19:24 -05:00
|
|
|
|
|
2016-08-11 18:41:25 -04:00
|
|
|
|
return function (view, params) {
|
2013-12-14 20:17:57 -05:00
|
|
|
|
|
2016-08-11 18:41:25 -04:00
|
|
|
|
function renderTimer(page, item) {
|
2013-12-14 20:17:57 -05:00
|
|
|
|
|
2016-08-11 18:41:25 -04:00
|
|
|
|
page.querySelector('.itemName').innerHTML = item.Name;
|
2013-12-14 20:17:57 -05:00
|
|
|
|
|
2016-08-11 18:41:25 -04:00
|
|
|
|
Dashboard.hideLoadingMsg();
|
|
|
|
|
}
|
2013-12-14 20:17:57 -05:00
|
|
|
|
|
2016-10-03 02:28:45 -04:00
|
|
|
|
function getProgramScheduleHtml(items, options) {
|
|
|
|
|
|
|
|
|
|
options = options || {};
|
|
|
|
|
|
|
|
|
|
var html = '';
|
2016-10-04 01:15:39 -04:00
|
|
|
|
html += '<div is="emby-itemscontainer" class="itemsContainer vertical-list" data-contextmenu="false">';
|
2016-10-03 02:28:45 -04:00
|
|
|
|
html += listView.getListViewHtml({
|
|
|
|
|
items: items,
|
|
|
|
|
enableUserDataButtons: false,
|
|
|
|
|
image: false,
|
|
|
|
|
showProgramDateTime: true,
|
|
|
|
|
mediaInfo: false,
|
|
|
|
|
action: 'none',
|
2016-10-04 01:15:39 -04:00
|
|
|
|
moreButton: false,
|
|
|
|
|
recordButton: false
|
2016-10-03 02:28:45 -04:00
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
html += '</div>';
|
|
|
|
|
|
|
|
|
|
return html;
|
|
|
|
|
}
|
|
|
|
|
|
2016-10-01 03:06:00 -04:00
|
|
|
|
function renderSchedule(page) {
|
2014-01-08 00:25:21 -05:00
|
|
|
|
|
2016-10-04 01:15:39 -04:00
|
|
|
|
ApiClient.getLiveTvTimers({
|
2016-10-01 03:06:00 -04:00
|
|
|
|
UserId: ApiClient.getCurrentUserId(),
|
|
|
|
|
ImageTypeLimit: 1,
|
|
|
|
|
EnableImageTypes: "Primary,Backdrop,Thumb",
|
|
|
|
|
SortBy: "StartDate",
|
|
|
|
|
EnableTotalRecordCount: false,
|
|
|
|
|
EnableUserData: false,
|
|
|
|
|
SeriesTimerId: params.id,
|
2016-10-04 01:15:39 -04:00
|
|
|
|
Fields: "ChannelInfo"
|
2014-01-08 00:25:21 -05:00
|
|
|
|
|
2016-10-01 03:06:00 -04:00
|
|
|
|
}).then(function (result) {
|
2014-01-08 00:25:21 -05:00
|
|
|
|
|
2016-10-01 15:21:42 -04:00
|
|
|
|
if (result.Items.length && result.Items[0].SeriesTimerId != params.id) {
|
|
|
|
|
result.Items = [];
|
|
|
|
|
}
|
|
|
|
|
|
2016-10-03 02:28:45 -04:00
|
|
|
|
var html = getProgramScheduleHtml(result.Items);
|
2013-12-14 20:17:57 -05:00
|
|
|
|
|
2016-10-03 02:28:45 -04:00
|
|
|
|
var scheduleTab = page.querySelector('.scheduleTab');
|
|
|
|
|
scheduleTab.innerHTML = html;
|
2016-10-01 03:06:00 -04:00
|
|
|
|
|
2016-10-03 02:28:45 -04:00
|
|
|
|
ImageLoader.lazyChildren(scheduleTab);
|
2016-08-11 18:41:25 -04:00
|
|
|
|
});
|
|
|
|
|
}
|
2014-01-08 00:25:21 -05:00
|
|
|
|
|
2016-08-11 18:41:25 -04:00
|
|
|
|
function reload() {
|
2014-01-08 00:25:21 -05:00
|
|
|
|
|
2016-08-11 18:41:25 -04:00
|
|
|
|
var id = params.id;
|
|
|
|
|
Dashboard.showLoadingMsg();
|
2014-01-08 00:25:21 -05:00
|
|
|
|
|
2016-08-11 18:41:25 -04:00
|
|
|
|
ApiClient.getLiveTvSeriesTimer(id).then(function (result) {
|
2014-01-08 00:25:21 -05:00
|
|
|
|
|
2016-08-11 18:41:25 -04:00
|
|
|
|
renderTimer(view, result);
|
2014-01-08 00:25:21 -05:00
|
|
|
|
|
2016-08-11 18:41:25 -04:00
|
|
|
|
});
|
2015-06-08 17:32:20 -04:00
|
|
|
|
|
2016-10-01 03:06:00 -04:00
|
|
|
|
renderSchedule(view);
|
2016-08-11 18:41:25 -04:00
|
|
|
|
}
|
2013-12-14 20:17:57 -05:00
|
|
|
|
|
2016-09-30 14:43:59 -04:00
|
|
|
|
seriesRecordingEditor.embed(params.id, ApiClient.serverId(), {
|
|
|
|
|
context: view.querySelector('.recordingEditor')
|
2016-08-11 18:41:25 -04:00
|
|
|
|
});
|
2013-12-14 20:17:57 -05:00
|
|
|
|
|
2016-08-11 18:41:25 -04:00
|
|
|
|
view.querySelector('.scheduleTab').addEventListener('timercancelled', reload);
|
|
|
|
|
view.addEventListener('viewbeforeshow', reload);
|
|
|
|
|
};
|
2016-03-19 05:26:17 +01:00
|
|
|
|
});
|