jellyfish-web/src/controllers/addpluginpage.js

156 lines
6.5 KiB
JavaScript
Raw Normal View History

define(["jQuery", "loading", "libraryMenu", "globalize", "connectionManager", "emby-button"], function($, loading, libraryMenu, globalize, connectionManager) {
2018-10-22 02:12:47 +03:00
"use strict";
function populateHistory(packageInfo, page) {
2019-04-02 21:54:00 -07:00
var html = "";
var length = Math.min(packageInfo.versions.length, 10);
for (var i = 0; i < length; i++) {
2018-10-22 02:12:47 +03:00
var version = packageInfo.versions[i];
2019-04-02 21:54:00 -07:00
html += '<h2 style="margin:.5em 0;">' + version.versionStr + " (" + version.classification + ")</h2>";
html += '<div style="margin-bottom:1.5em;">' + version.description + "</div>";
2018-10-22 02:12:47 +03:00
}
2019-04-02 21:54:00 -07:00
$("#revisionHistory", page).html(html);
2018-10-22 02:12:47 +03:00
}
function populateVersions(packageInfo, page, installedPlugin) {
2019-04-02 21:54:00 -07:00
var html = "";
for (var i = 0; i < packageInfo.versions.length; i++) {
2018-10-22 02:12:47 +03:00
var version = packageInfo.versions[i];
2019-04-02 21:54:00 -07:00
html += '<option value="' + version.versionStr + "|" + version.classification + '">' + version.versionStr + " (" + version.classification + ")</option>";
2018-10-22 02:12:47 +03:00
}
var selectmenu = $("#selectVersion", page).html(html);
2019-04-02 21:54:00 -07:00
if (!installedPlugin) {
$("#pCurrentVersion", page).hide().html("");
}
2018-10-22 02:12:47 +03:00
var packageVersion = packageInfo.versions.filter(function(current) {
2019-04-02 21:54:00 -07:00
return "Release" == current.classification;
})[0];
packageVersion = packageVersion || packageInfo.versions.filter(function(current) {
return "Beta" == current.classification;
2018-10-22 02:12:47 +03:00
})[0];
2019-04-02 21:54:00 -07:00
if (packageVersion) {
2018-10-22 02:12:47 +03:00
var val = packageVersion.versionStr + "|" + packageVersion.classification;
2019-04-02 21:54:00 -07:00
selectmenu.val(val);
2018-10-22 02:12:47 +03:00
}
}
2019-04-02 21:54:00 -07:00
function renderPackage(pkg, installedPlugins, page) {
2018-10-22 02:12:47 +03:00
var installedPlugin = installedPlugins.filter(function(ip) {
return ip.Name == pkg.name
})[0];
populateVersions(pkg, page, installedPlugin);
populateHistory(pkg, page);
$(".pluginName", page).html(pkg.name);
if ("Server" == pkg.targetSystem) {
$("#btnInstallDiv", page).removeClass("hide");
$("#nonServerMsg", page).hide();
$("#pSelectVersion", page).removeClass("hide");
} else {
$("#btnInstallDiv", page).addClass("hide");
$("#pSelectVersion", page).addClass("hide");
2018-10-22 02:12:47 +03:00
var msg = globalize.translate("MessageInstallPluginFromApp");
$("#nonServerMsg", page).html(msg).show();
2018-10-22 02:12:47 +03:00
}
if (pkg.shortDescription) {
$("#tagline", page).show().html(pkg.shortDescription);
} else {
$("#tagline", page).hide();
}
$("#overview", page).html(pkg.overview || "");
$("#developer", page).html(pkg.owner);
if (pkg.richDescUrl) {
$("#pViewWebsite", page).show();
$("#pViewWebsite a", page).attr("href", pkg.richDescUrl);
} else {
$("#pViewWebsite", page).hide();
}
if (pkg.previewImage || pkg.thumbImage) {
2018-10-22 02:12:47 +03:00
var img = pkg.previewImage ? pkg.previewImage : pkg.thumbImage;
$("#pPreviewImage", page).show().html("<img class='pluginPreviewImg' src='" + img + "' style='max-width: 100%;' />");
} else {
$("#pPreviewImage", page).hide().html("");
}
2018-10-22 02:12:47 +03:00
if (installedPlugin) {
var currentVersionText = globalize.translate("MessageYouHaveVersionInstalled").replace("{0}", "<strong>" + installedPlugin.Version + "</strong>");
$("#pCurrentVersion", page).show().html(currentVersionText);
} else {
$("#pCurrentVersion", page).hide().html("");
}
loading.hide();
2018-10-22 02:12:47 +03:00
}
function alertText(options) {
require(["alert"], function(alert) {
alert(options)
})
}
function performInstallation(page, packageName, guid, updateClass, version) {
2019-04-02 21:54:00 -07:00
var developer = $("#developer", page).html().toLowerCase();
var alertCallback = function() {
loading.show();
page.querySelector("#btnInstall").disabled = true;
ApiClient.installPlugin(packageName, guid, updateClass, version).then(function() {
loading.hide();
alertText(globalize.translate("PluginInstalledMessage"));
});
};
if (developer !== 'jellyfin') {
2018-10-22 02:12:47 +03:00
loading.hide();
var msg = globalize.translate("MessagePluginInstallDisclaimer");
2019-04-02 21:54:00 -07:00
msg += "<br/>";
msg += "<br/>";
msg += globalize.translate("PleaseConfirmPluginInstallation");
require(["confirm"], function(confirm) {
2018-10-22 02:12:47 +03:00
confirm(msg, globalize.translate("HeaderConfirmPluginInstallation")).then(function() {
2019-04-02 21:54:00 -07:00
alertCallback();
2018-10-22 02:12:47 +03:00
}, function() {
2019-04-02 21:54:00 -07:00
console.log('plugin not installed');
});
});
} else {
alertCallback();
}
2018-10-22 02:12:47 +03:00
}
2019-04-02 21:54:00 -07:00
2018-10-22 02:12:47 +03:00
return function(view, params) {
2019-04-02 21:54:00 -07:00
$(".addPluginForm", view).on("submit", function() {
2018-10-22 02:12:47 +03:00
loading.show();
2019-04-02 21:54:00 -07:00
var page = $(this).parents("#addPluginPage")[0];
var name = params.name;
var guid = params.guid;
ApiClient.getInstalledPlugins().then(function(plugins) {
var installedPlugin = plugins.filter(function(plugin) {
return plugin.Name == name;
})[0];
var vals = $("#selectVersion", page).val().split("|");
var version = vals[0];
if (installedPlugin) {
if (installedPlugin.Version === version) {
loading.hide();
Dashboard.alert({
message: globalize.translate("MessageAlreadyInstalled"),
title: globalize.translate("HeaderPluginInstallation")
});
} else {
performInstallation(page, name, guid, vals[1], version);
}
}
});
return false;
});
view.addEventListener("viewshow", function() {
2018-10-22 02:12:47 +03:00
var page = this;
loading.show();
2019-04-02 21:54:00 -07:00
var name = params.name;
var guid = params.guid;
var promise1 = ApiClient.getPackageInfo(name, guid);
var promise2 = ApiClient.getInstalledPlugins();
Promise.all([promise1, promise2]).then(function(responses) {
renderPackage(responses[0], responses[1], page);
});
2018-10-22 02:12:47 +03:00
})
}
});