jellyfin-web/dashboard-ui/scripts/addpluginpage.js

357 lines
11 KiB
JavaScript
Raw Normal View History

define(['jQuery'], function ($) {
2016-10-22 22:11:46 -07:00
'use strict';
2013-02-20 18:33:05 -07:00
function populateHistory(packageInfo, page) {
2013-02-20 18:33:05 -07:00
var html = '';
2013-02-20 18:33:05 -07:00
for (var i = 0, length = Math.min(packageInfo.versions.length, 10) ; i < length; i++) {
2013-02-20 18:33:05 -07:00
var version = packageInfo.versions[i];
2013-02-20 18:33:05 -07:00
html += '<h2 style="margin:.5em 0;">' + version.versionStr + ' (' + version.classification + ')</h2>';
2013-02-20 18:33:05 -07:00
html += '<div style="margin-bottom:1.5em;">' + version.description + '</div>';
}
2013-02-20 18:33:05 -07:00
$('#revisionHistory', page).html(html);
}
2013-02-20 18:33:05 -07:00
function populateVersions(packageInfo, page, installedPlugin) {
2015-06-19 15:01:47 -07:00
var html = '';
for (var i = 0, length = packageInfo.versions.length; i < length; i++) {
var version = packageInfo.versions[i];
html += '<option value="' + version.versionStr + '|' + version.classification + '">' + version.versionStr + ' (' + version.classification + ')</option>';
}
var selectmenu = $('#selectVersion', page).html(html);
2013-05-13 08:55:59 -07:00
if (!installedPlugin) {
$('#pCurrentVersion', page).hide().html("");
}
var packageVersion = packageInfo.versions.filter(function (current) {
return current.classification == "Release";
})[0];
// If we still don't have a package version to select, pick the first Beta build
if (!packageVersion) {
packageVersion = packageInfo.versions.filter(function (current) {
return current.classification == "Beta";
})[0];
}
if (packageVersion) {
var val = packageVersion.versionStr + '|' + packageVersion.classification;
2015-09-03 10:01:51 -07:00
selectmenu.val(val);
}
}
2014-01-02 14:21:06 -07:00
2016-08-16 13:54:13 -07:00
function renderPluginInfo(page, pkg, pluginSecurityInfo) {
if (AppInfo.isNativeApp) {
return;
}
2016-10-02 23:28:45 -07:00
if (pkg.isPremium) {
$('.premiumPackage', page).show();
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
// Fill in registration info
var regStatus = "";
if (pkg.isRegistered) {
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
regStatus += "<p style='color:green;'>";
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
regStatus += Globalize.translate('MessageFeatureIncludedWithSupporter');
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
} else {
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
var expDateTime = new Date(pkg.expDate).getTime();
var nowTime = new Date().getTime();
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
if (expDateTime <= nowTime) {
regStatus += "<p style='color:red;'>";
regStatus += Globalize.translate('MessageTrialExpired');
} else if (expDateTime > new Date(1970, 1, 1).getTime()) {
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
regStatus += "<p style='color:blue;'>";
regStatus += Globalize.translate('MessageTrialWillExpireIn').replace('{0}', Math.round(expDateTime - nowTime) / (86400000));
2016-08-16 13:54:13 -07:00
}
2016-10-02 23:28:45 -07:00
}
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
regStatus += "</p>";
$('#regStatus', page).html(regStatus);
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
if (pluginSecurityInfo.IsMBSupporter) {
$('#regInfo', page).html(pkg.regInfo || "");
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
$('.premiumDescription', page).hide();
$('.supporterDescription', page).hide();
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
if (pkg.price > 0) {
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
$('.premiumHasPrice', page).show();
$('#featureId', page).val(pkg.featureId);
$('#featureName', page).val(pkg.name);
$('#amount', page).val(pkg.price);
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
$('#regPrice', page).html("<h3>" + Globalize.translate('ValuePriceUSD').replace('{0}', "$" + pkg.price.toFixed(2)) + "</h3>");
$('#ppButton', page).hide();
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
var url = "https://mb3admin.com/admin/service/user/getPayPalEmail?id=" + pkg.owner;
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
fetch(url).then(function (response) {
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
return response.json();
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
}).then(function (dev) {
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
if (dev.payPalEmail) {
$('#payPalEmail', page).val(dev.payPalEmail);
$('#ppButton', page).show();
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
}
});
2016-08-16 13:54:13 -07:00
} else {
2016-10-02 23:28:45 -07:00
// Supporter-only feature
$('.premiumHasPrice', page).hide();
}
} else {
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
if (pkg.price) {
$('.premiumDescription', page).show();
$('.supporterDescription', page).hide();
$('#regInfo', page).html("");
2016-08-16 13:54:13 -07:00
2016-10-02 23:28:45 -07:00
} else {
$('.premiumDescription', page).hide();
$('.supporterDescription', page).show();
$('#regInfo', page).html("");
2016-08-16 13:54:13 -07:00
}
2016-10-02 23:28:45 -07:00
$('#ppButton', page).hide();
2016-08-16 13:54:13 -07:00
}
2016-10-02 23:28:45 -07:00
} else {
$('.premiumPackage', page).hide();
}
2016-08-16 13:54:13 -07:00
}
function renderPackage(pkg, installedPlugins, pluginSecurityInfo, page) {
2013-02-20 18:33:05 -07:00
var installedPlugin = installedPlugins.filter(function (ip) {
return ip.Name == pkg.name;
})[0];
populateVersions(pkg, page, installedPlugin);
populateHistory(pkg, page);
2014-01-02 14:21:06 -07:00
2014-07-10 21:27:46 -07:00
$('.pluginName', page).html(pkg.name);
2013-02-20 18:33:05 -07:00
if (pkg.targetSystem == 'Server') {
2015-12-14 08:43:03 -07:00
$("#btnInstallDiv", page).removeClass('hide');
$("#nonServerMsg", page).hide();
2015-12-14 08:43:03 -07:00
$("#pSelectVersion", page).removeClass('hide');
} else {
2015-12-14 08:43:03 -07:00
$("#btnInstallDiv", page).addClass('hide');
$("#pSelectVersion", page).addClass('hide');
2014-08-31 12:15:33 -07:00
var msg = Globalize.translate('MessageInstallPluginFromApp');
$("#nonServerMsg", page).html(msg).show();
}
2013-02-20 18:33:05 -07:00
if (pkg.shortDescription) {
$('#tagline', page).show().html(pkg.shortDescription);
} else {
$('#tagline', page).hide();
}
$('#overview', page).html(pkg.overview || "");
$('#developer', page).html(pkg.owner);
2016-08-16 13:54:13 -07:00
renderPluginInfo(page, pkg, pluginSecurityInfo);
2014-01-02 14:21:06 -07:00
2013-02-20 18:33:05 -07:00
if (pkg.richDescUrl) {
$('#pViewWebsite', page).show();
2015-08-14 18:10:07 -07:00
$('#pViewWebsite a', page).attr('href', pkg.richDescUrl);
2013-02-20 18:33:05 -07:00
} else {
$('#pViewWebsite', page).hide();
}
2013-05-11 23:05:51 -07:00
if (pkg.previewImage || pkg.thumbImage) {
2013-02-20 18:33:05 -07:00
2014-02-12 22:11:54 -07:00
var color = pkg.tileColor || "#38c";
2013-02-20 18:33:05 -07:00
var img = pkg.previewImage ? pkg.previewImage : pkg.thumbImage;
$('#pPreviewImage', page).show().html("<img src='" + img + "' style='max-width: 100%;-moz-box-shadow: 0 0 20px 3px " + color + ";-webkit-box-shadow: 0 0 20px 3px " + color + ";box-shadow: 0 0 20px 3px " + color + ";' />");
2013-02-20 18:33:05 -07:00
} else {
$('#pPreviewImage', page).hide().html("");
}
if (installedPlugin) {
2014-08-31 12:15:33 -07:00
var currentVersionText = Globalize.translate('MessageYouHaveVersionInstalled').replace('{0}', '<strong>' + installedPlugin.Version + '</strong>');
$('#pCurrentVersion', page).show().html(currentVersionText);
2013-02-20 18:33:05 -07:00
} else {
$('#pCurrentVersion', page).hide().html("");
}
Dashboard.hideLoadingMsg();
}
2013-02-20 18:33:05 -07:00
2015-12-14 08:43:03 -07:00
function performInstallation(page, packageName, guid, updateClass, version) {
2013-02-20 18:33:05 -07:00
2015-12-14 08:43:03 -07:00
var developer = $('#developer', page).html().toLowerCase();
var alertCallback = function (confirmed) {
if (confirmed) {
Dashboard.showLoadingMsg();
2016-04-03 10:34:52 -07:00
page.querySelector('#btnInstall').disabled = true;
2015-12-14 08:43:03 -07:00
ApiClient.installPlugin(packageName, guid, updateClass, version).then(function () {
Dashboard.hideLoadingMsg();
});
}
};
if (developer != 'luke' && developer != 'ebr') {
2013-02-20 18:33:05 -07:00
Dashboard.hideLoadingMsg();
2015-12-14 08:43:03 -07:00
var msg = Globalize.translate('MessagePluginInstallDisclaimer');
msg += '<br/>';
msg += '<br/>';
msg += Globalize.translate('PleaseConfirmPluginInstallation');
2016-02-22 12:31:28 -07:00
require(['confirm'], function (confirm) {
confirm(msg, Globalize.translate('HeaderConfirmPluginInstallation')).then(function () {
alertCallback(true);
}, function () {
alertCallback(false);
});
});
2015-12-14 08:43:03 -07:00
} else {
alertCallback(true);
}
}
2013-02-20 18:33:05 -07:00
2016-10-02 23:28:45 -07:00
function updateHelpUrl(page, params) {
var context = params.context;
$('.notificationsTabs', page).hide();
if (context == 'sync') {
page.setAttribute('data-helpurl', 'https://github.com/MediaBrowser/Wiki/wiki/Sync');
LibraryMenu.setTitle(Globalize.translate('TitleSync'));
}
else if (context == 'livetv') {
LibraryMenu.setTitle(Globalize.translate('TitleLiveTV'));
page.setAttribute('data-helpurl', 'https://github.com/MediaBrowser/Wiki/wiki/Live%20TV');
}
else if (context == 'notifications') {
$('.notificationsTabs', page).show();
2013-02-20 18:33:05 -07:00
2016-10-02 23:28:45 -07:00
LibraryMenu.setTitle(Globalize.translate('TitleNotifications'));
page.setAttribute('data-helpurl', 'https://github.com/MediaBrowser/Wiki/wiki/Notifications');
}
else {
page.setAttribute('data-helpurl', 'https://github.com/MediaBrowser/Wiki/wiki/Plugins');
LibraryMenu.setTitle(Globalize.translate('TitlePlugins'));
}
}
2013-02-20 18:33:05 -07:00
2016-10-02 23:28:45 -07:00
return function (view, params) {
var onSubmit = function () {
2013-02-20 18:33:05 -07:00
Dashboard.showLoadingMsg();
2013-02-20 18:33:05 -07:00
2016-02-14 11:32:29 -07:00
var page = $(this).parents('#addPluginPage')[0];
2013-02-20 18:33:05 -07:00
2016-10-02 23:28:45 -07:00
var name = params.name;
var guid = params.guid;
2013-02-20 18:33:05 -07:00
2015-12-14 08:43:03 -07:00
ApiClient.getInstalledPlugins().then(function (plugins) {
2013-02-20 18:33:05 -07:00
var installedPlugin = plugins.filter(function (ip) {
return ip.Name == name;
})[0];
2013-02-20 18:33:05 -07:00
var vals = $('#selectVersion', page).val().split('|');
2013-02-20 18:33:05 -07:00
var version = vals[0];
2013-02-20 18:33:05 -07:00
if (installedPlugin && installedPlugin.Version == version) {
2013-02-20 18:33:05 -07:00
Dashboard.hideLoadingMsg();
2013-02-20 18:33:05 -07:00
2014-08-31 12:15:33 -07:00
Dashboard.alert({
message: Globalize.translate('MessageAlreadyInstalled'),
title: Globalize.translate('HeaderPluginInstallation')
});
} else {
2015-12-14 08:43:03 -07:00
performInstallation(page, name, guid, vals[1], version);
}
});
2013-02-20 18:33:05 -07:00
return false;
};
2013-02-20 18:33:05 -07:00
2016-10-02 23:28:45 -07:00
$('.addPluginForm', view).on('submit', onSubmit);
updateHelpUrl(view, params);
2016-10-02 23:28:45 -07:00
view.addEventListener('viewbeforeshow', function () {
var page = this;
updateHelpUrl(page, params);
});
view.addEventListener('viewshow', function () {
var page = this;
Dashboard.showLoadingMsg();
var name = params.name;
var guid = params.guid;
var promise1 = ApiClient.getPackageInfo(name, guid);
var promise2 = ApiClient.getInstalledPlugins();
var promise3 = ApiClient.getPluginSecurityInfo();
Promise.all([promise1, promise2, promise3]).then(function (responses) {
renderPackage(responses[0], responses[1], responses[2], page);
});
updateHelpUrl(page, params);
});
};
});