mirror of
https://github.com/jellyfin/jellyfin-web.git
synced 2024-11-18 03:18:19 -07:00
470 lines
12 KiB
JavaScript
470 lines
12 KiB
JavaScript
(function ($, document, window) {
|
|
|
|
function resetTuner(page, id) {
|
|
|
|
var message = Globalize.translate('MessageConfirmResetTuner');
|
|
|
|
Dashboard.confirm(message, Globalize.translate('HeaderResetTuner'), function (confirmResult) {
|
|
|
|
if (confirmResult) {
|
|
|
|
Dashboard.showLoadingMsg();
|
|
|
|
ApiClient.resetLiveTvTuner(id).done(function () {
|
|
|
|
Dashboard.hideLoadingMsg();
|
|
|
|
reload(page);
|
|
});
|
|
}
|
|
});
|
|
}
|
|
|
|
function renderTuners(page, tuners) {
|
|
|
|
var html = '';
|
|
|
|
for (var i = 0, length = tuners.length; i < length; i++) {
|
|
|
|
var tuner = tuners[i];
|
|
|
|
html += '<tr>';
|
|
|
|
html += '<td>';
|
|
html += tuner.Name;
|
|
html += '</td>';
|
|
|
|
html += '<td>';
|
|
html += tuner.SourceType;
|
|
html += '</td>';
|
|
|
|
html += '<td>';
|
|
|
|
if (tuner.Status == 'RecordingTv') {
|
|
if (tuner.ChannelName) {
|
|
|
|
html += '<a href="livetvchannel.html?id=' + tuner.ChannelId + '">';
|
|
html += Globalize.translate('StatusRecordingProgram').replace('{0}', tuner.ChannelName);
|
|
html += '</a>';
|
|
} else {
|
|
|
|
html += Globalize.translate('StatusRecording');
|
|
}
|
|
}
|
|
else if (tuner.Status == 'LiveTv') {
|
|
|
|
if (tuner.ChannelName) {
|
|
|
|
html += '<a href="livetvchannel.html?id=' + tuner.ChannelId + '">';
|
|
html += Globalize.translate('StatusWatchingProgram').replace('{0}', tuner.ChannelName);
|
|
html += '</a>';
|
|
} else {
|
|
|
|
html += Globalize.translate('StatusWatching');
|
|
}
|
|
}
|
|
else {
|
|
html += tuner.Status;
|
|
}
|
|
html += '</td>';
|
|
|
|
html += '<td>';
|
|
|
|
if (tuner.ProgramName) {
|
|
html += tuner.ProgramName;
|
|
}
|
|
|
|
html += '</td>';
|
|
|
|
html += '<td>';
|
|
html += tuner.Clients.join('<br/>');
|
|
html += '</td>';
|
|
|
|
html += '<td>';
|
|
html += '<button data-tunerid="' + tuner.Id + '" type="button" data-inline="true" data-icon="refresh" data-mini="true" data-iconpos="notext" class="btnResetTuner organizerButton" title="' + Globalize.translate('ButtonResetTuner') + '">' + Globalize.translate('ButtonResetTuner') + '</button>';
|
|
html += '</td>';
|
|
|
|
html += '</tr>';
|
|
}
|
|
|
|
var elem = $('.tunersResultBody', page).html(html).parents('.tblTuners').table("refresh").trigger('create');
|
|
|
|
$('.btnResetTuner', elem).on('click', function () {
|
|
|
|
var id = this.getAttribute('data-tunerid');
|
|
|
|
resetTuner(page, id);
|
|
});
|
|
}
|
|
|
|
function getServiceHtml(service) {
|
|
|
|
var html = '';
|
|
html += '<div>';
|
|
|
|
var serviceUrl = service.HomePageUrl || '#';
|
|
|
|
html += '<p><a href="' + serviceUrl + '" target="_blank">' + service.Name + '</a></p>';
|
|
|
|
var versionHtml = service.Version || 'Unknown';
|
|
|
|
if (service.HasUpdateAvailable) {
|
|
versionHtml += ' <a style="margin-left: .25em;" href="' + serviceUrl + '" target="_blank">' + Globalize.translate('LiveTvUpdateAvailable') + '</a>';
|
|
}
|
|
else {
|
|
versionHtml += '<img src="css/images/checkmarkgreen.png" style="height: 17px; margin-left: 10px; margin-right: 0; position: relative; top: 5px; border-radius:3px;" /> ' + Globalize.translate('LabelVersionUpToDate');
|
|
}
|
|
|
|
html += '<p>' + versionHtml + '</p>';
|
|
|
|
var status = service.Status;
|
|
|
|
if (service.Status == 'Ok') {
|
|
|
|
status = '<span style="color:green;">' + status + '</span>';
|
|
} else {
|
|
|
|
if (service.StatusMessage) {
|
|
status += ' (' + service.StatusMessage + ')';
|
|
}
|
|
|
|
status = '<span style="color:red;">' + status + '</span>';
|
|
}
|
|
|
|
html += '<p>' + Globalize.translate('ValueStatus', status) + '</p>';
|
|
|
|
html += '</div>';
|
|
|
|
return html;
|
|
}
|
|
|
|
function loadPage(page, liveTvInfo) {
|
|
|
|
if (liveTvInfo.IsEnabled) {
|
|
|
|
$('.liveTvStatusContent', page).show();
|
|
|
|
} else {
|
|
$('.liveTvStatusContent', page).hide();
|
|
}
|
|
|
|
var servicesToDisplay = liveTvInfo.Services.filter(function (s) {
|
|
|
|
return s.IsVisible;
|
|
|
|
});
|
|
|
|
if (servicesToDisplay.length) {
|
|
$('.servicesSection', page).show();
|
|
} else {
|
|
$('.servicesSection', page).hide();
|
|
}
|
|
|
|
$('.servicesList', page).html(servicesToDisplay.map(getServiceHtml).join('')).trigger('create');
|
|
|
|
var tuners = [];
|
|
for (var i = 0, length = liveTvInfo.Services.length; i < length; i++) {
|
|
|
|
for (var j = 0, numTuners = liveTvInfo.Services[i].Tuners.length; j < numTuners; j++) {
|
|
tuners.push(liveTvInfo.Services[i].Tuners[j]);
|
|
}
|
|
}
|
|
|
|
renderTuners(page, tuners);
|
|
|
|
ApiClient.getNamedConfiguration("livetv").done(function (config) {
|
|
|
|
renderDevices(page, config.TunerHosts);
|
|
renderProviders(page, config.ListingProviders);
|
|
});
|
|
|
|
Dashboard.hideLoadingMsg();
|
|
}
|
|
|
|
function renderDevices(page, devices) {
|
|
|
|
var html = '';
|
|
|
|
html += '<ul data-role="listview" data-inset="true" data-split-icon="delete">';
|
|
|
|
for (var i = 0, length = devices.length; i < length; i++) {
|
|
|
|
var device = devices[i];
|
|
|
|
var href = 'livetvtunerprovider-' + device.Type + '.html?id=' + device.Id;
|
|
|
|
html += '<li>';
|
|
html += '<a href="' + href + '">';
|
|
|
|
html += '<h3>';
|
|
html += getTunerName(device.Type);
|
|
html += '</h3>';
|
|
|
|
html += '<p>';
|
|
html += device.Url;
|
|
html += '</p>';
|
|
|
|
html += '</a>';
|
|
html += '<a href="#" class="btnDeleteDevice" data-id="' + device.Id + '">';
|
|
html += '</a>';
|
|
html += '</li>';
|
|
}
|
|
|
|
html += '</ul>';
|
|
|
|
var elem = $('.devicesList', page).html(html).trigger('create');
|
|
|
|
$('.btnDeleteDevice', elem).on('click', function () {
|
|
|
|
var id = this.getAttribute('data-id');
|
|
|
|
deleteDevice(page, id);
|
|
});
|
|
}
|
|
|
|
function deleteDevice(page, id) {
|
|
|
|
var message = Globalize.translate('MessageConfirmDeleteTunerDevice');
|
|
|
|
Dashboard.confirm(message, Globalize.translate('HeaderDeleteDevice'), function (confirmResult) {
|
|
|
|
if (confirmResult) {
|
|
|
|
Dashboard.showLoadingMsg();
|
|
|
|
ApiClient.ajax({
|
|
type: "DELETE",
|
|
url: ApiClient.getUrl('LiveTv/TunerHosts', {
|
|
Id: id
|
|
})
|
|
|
|
}).done(function () {
|
|
|
|
reload(page);
|
|
});
|
|
}
|
|
});
|
|
}
|
|
|
|
function reload(page) {
|
|
|
|
Dashboard.showLoadingMsg();
|
|
|
|
ApiClient.getLiveTvInfo().done(function (liveTvInfo) {
|
|
|
|
loadPage(page, liveTvInfo);
|
|
|
|
});
|
|
}
|
|
|
|
function submitAddDeviceForm(page) {
|
|
|
|
page.querySelector('.dlgAddDevice').close();
|
|
Dashboard.showLoadingMsg();
|
|
|
|
ApiClient.ajax({
|
|
type: "POST",
|
|
url: ApiClient.getUrl('LiveTv/TunerHosts'),
|
|
data: JSON.stringify({
|
|
Type: $('#selectTunerDeviceType', page).val(),
|
|
Url: $('#txtDevicePath', page).val()
|
|
}),
|
|
contentType: "application/json"
|
|
|
|
}).done(function () {
|
|
|
|
reload(page);
|
|
|
|
}).fail(function () {
|
|
Dashboard.alert({
|
|
message: Globalize.translate('ErrorAddingTunerDevice')
|
|
});
|
|
});
|
|
|
|
}
|
|
|
|
function renderProviders(page, providers) {
|
|
|
|
var html = '';
|
|
|
|
html += '<ul data-role="listview" data-inset="true" data-split-icon="delete">';
|
|
|
|
for (var i = 0, length = providers.length; i < length; i++) {
|
|
|
|
var provider = providers[i];
|
|
html += '<li>';
|
|
html += '<a href="' + getProviderConfigurationUrl(provider.Type) + '?id=' + provider.Id + '">';
|
|
|
|
html += '<h3>';
|
|
html += getProviderName(provider.Type);
|
|
html += '</h3>';
|
|
|
|
html += '</a>';
|
|
html += '<a href="#" class="btnDelete" data-id="' + provider.Id + '">';
|
|
html += '</a>';
|
|
html += '</li>';
|
|
}
|
|
|
|
html += '</ul>';
|
|
|
|
var elem = $('.providerList', page).html(html).trigger('create');
|
|
|
|
$('.btnDelete', elem).on('click', function () {
|
|
|
|
var id = this.getAttribute('data-id');
|
|
|
|
deleteProvider(page, id);
|
|
});
|
|
}
|
|
|
|
function deleteProvider(page, id) {
|
|
|
|
var message = Globalize.translate('MessageConfirmDeleteGuideProvider');
|
|
|
|
Dashboard.confirm(message, Globalize.translate('HeaderDeleteProvider'), function (confirmResult) {
|
|
|
|
if (confirmResult) {
|
|
|
|
Dashboard.showLoadingMsg();
|
|
|
|
ApiClient.ajax({
|
|
type: "DELETE",
|
|
url: ApiClient.getUrl('LiveTv/ListingProviders', {
|
|
Id: id
|
|
})
|
|
|
|
}).always(function () {
|
|
|
|
reload(page);
|
|
});
|
|
}
|
|
});
|
|
}
|
|
|
|
function getTunerName(providerId) {
|
|
|
|
providerId = providerId.toLowerCase();
|
|
|
|
switch (providerId) {
|
|
|
|
case 'm3u':
|
|
return 'M3U';
|
|
case 'hdhomerun':
|
|
return 'HDHomerun';
|
|
default:
|
|
return 'Unknown';
|
|
}
|
|
}
|
|
|
|
function getProviderName(providerId) {
|
|
|
|
providerId = providerId.toLowerCase();
|
|
|
|
switch (providerId) {
|
|
|
|
case 'schedulesdirect':
|
|
return 'Schedules Direct';
|
|
case 'emby':
|
|
return 'Emby Guide';
|
|
default:
|
|
return 'Unknown';
|
|
}
|
|
}
|
|
|
|
function getProviderConfigurationUrl(providerId) {
|
|
|
|
providerId = providerId.toLowerCase();
|
|
|
|
switch (providerId) {
|
|
|
|
case 'schedulesdirect':
|
|
return 'livetvguideprovider-scd.html';
|
|
case 'emby':
|
|
return 'livetvguideprovider.html';
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
function addProvider(button) {
|
|
|
|
var menuItems = [];
|
|
|
|
menuItems.push({
|
|
name: 'Schedules Direct',
|
|
id: 'SchedulesDirect'
|
|
});
|
|
|
|
//menuItems.push({
|
|
// name: 'Emby Guide',
|
|
// id: 'emby'
|
|
//});
|
|
|
|
require(['actionsheet'], function () {
|
|
|
|
ActionSheetElement.show({
|
|
items: menuItems,
|
|
positionTo: button,
|
|
callback: function (id) {
|
|
|
|
Dashboard.navigate(getProviderConfigurationUrl(id));
|
|
}
|
|
});
|
|
|
|
});
|
|
}
|
|
|
|
function addDevice(button) {
|
|
|
|
var menuItems = [];
|
|
|
|
menuItems.push({
|
|
name: 'HDHomerun',
|
|
id: 'hdhomerun'
|
|
});
|
|
|
|
menuItems.push({
|
|
name: 'M3U',
|
|
id: 'm3u'
|
|
});
|
|
|
|
require(['actionsheet'], function () {
|
|
|
|
ActionSheetElement.show({
|
|
items: menuItems,
|
|
positionTo: button,
|
|
callback: function (id) {
|
|
|
|
Dashboard.navigate('livetvtunerprovider-' + id + '.html');
|
|
}
|
|
});
|
|
|
|
});
|
|
}
|
|
|
|
$(document).on('pageinitdepends', "#liveTvStatusPage", function () {
|
|
|
|
var page = this;
|
|
|
|
$('.btnAddDevice', page).on('click', function () {
|
|
addDevice(this);
|
|
});
|
|
|
|
$('.formAddDevice', page).on('submit', function () {
|
|
submitAddDeviceForm(page);
|
|
return false;
|
|
});
|
|
|
|
$('.btnAddProvider', page).on('click', function () {
|
|
addProvider(this);
|
|
});
|
|
|
|
}).on('pageshowready', "#liveTvStatusPage", function () {
|
|
|
|
var page = this;
|
|
|
|
reload(page);
|
|
});
|
|
|
|
})(jQuery, document, window);
|