define(['jQuery'], function ($) {
function resetTuner(page, id) {
var message = Globalize.translate('MessageConfirmResetTuner');
require(['confirm'], function (confirm) {
confirm(message, Globalize.translate('HeaderResetTuner')).then(function () {
Dashboard.showLoadingMsg();
ApiClient.resetLiveTvTuner(id).then(function () {
Dashboard.hideLoadingMsg();
reload(page);
});
});
});
}
function renderTuners(page, tuners) {
var html = '';
if (tuners.length) {
html += '
';
for (var i = 0, length = tuners.length; i < length; i++) {
var tuner = tuners[i];
html += '';
html += '';
html += '';
html += '
';
html += '';
if (tuner.CanReset) {
html += '';
}
html += '';
}
html += '
';
}
if (tuners.length) {
page.querySelector('.tunerSection').classList.remove('hide');
} else {
page.querySelector('.tunerSection').classList.add('hide');
}
var elem = $('.tunerList', page).html(html);
$('.btnResetTuner', elem).on('click', function () {
var id = this.getAttribute('data-tunerid');
resetTuner(page, id);
});
}
function getServiceHtml(service) {
var html = '';
html += '
';
var serviceUrl = service.HomePageUrl || '#';
html += '
';
var status = service.Status;
if (service.Status == 'Ok') {
status = '' + status + '';
} else {
if (service.StatusMessage) {
status += ' (' + service.StatusMessage + ')';
}
status = '' + status + '';
}
html += '
';
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(''));
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").then(function (config) {
renderDevices(page, config.TunerHosts);
renderProviders(page, config.ListingProviders);
});
Dashboard.hideLoadingMsg();
}
function renderDevices(page, devices) {
var html = '';
if (devices.length) {
html += '
';
for (var i = 0, length = devices.length; i < length; i++) {
var device = devices[i];
var href = 'livetvtunerprovider-' + device.Type + '.html?id=' + device.Id;
html += '';
html += '';
html += '';
html += '';
html += '
';
html += '';
html += '';
html += '';
html += '';
}
html += '
';
}
var elem = $('.devicesList', page).html(html);
$('.btnDeleteDevice', elem).on('click', function () {
var id = this.getAttribute('data-id');
deleteDevice(page, id);
});
}
function deleteDevice(page, id) {
var message = Globalize.translate('MessageConfirmDeleteTunerDevice');
require(['confirm'], function (confirm) {
confirm(message, Globalize.translate('HeaderDeleteDevice')).then(function () {
Dashboard.showLoadingMsg();
ApiClient.ajax({
type: "DELETE",
url: ApiClient.getUrl('LiveTv/TunerHosts', {
Id: id
})
}).then(function () {
reload(page);
});
});
});
}
function reload(page) {
Dashboard.showLoadingMsg();
ApiClient.getLiveTvInfo().then(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"
}).then(function () {
reload(page);
}, function () {
Dashboard.alert({
message: Globalize.translate('ErrorAddingTunerDevice')
});
});
}
function renderProviders(page, providers) {
var html = '';
if (providers.length) {
html += '
';
for (var i = 0, length = providers.length; i < length; i++) {
var provider = providers[i];
html += '';
html += '';
html += '';
html += '';
html += '