PluginUpdatesPage.js 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. var PluginUpdatesPage = {
  2. onPageShow: function () {
  3. Dashboard.showLoadingMsg();
  4. $('.liPluginUpdate', this).remove();
  5. ApiClient.getInstalledPlugins().done(PluginUpdatesPage.loadPlugins);
  6. },
  7. loadPlugins: function (plugins) {
  8. plugins = plugins.filter(function (p) {
  9. return !p.IsCorePlugin;
  10. });
  11. var elem = $('#tbodyPluginUpdates', $.mobile.activePage).html('');
  12. for (var i = 0, length = plugins.length; i < length; i++) {
  13. PluginUpdatesPage.addPlugin(plugins[i], i, elem);
  14. }
  15. Dashboard.hideLoadingMsg();
  16. },
  17. addPlugin: function (plugin, fieldIndex, elem) {
  18. var html = "";
  19. html += "<tr>";
  20. html += "<td><h3>" + plugin.Name + "</h3></td>";
  21. var fieldId = "liPluginUpdateFielda" + fieldIndex;
  22. var options = PluginUpdatesPage.getHtmlOptions(["Off", "On"], (plugin.EnableAutoUpdate ? "On" : "Off"));
  23. html += "<td>";
  24. html += "<select data-id='" + plugin.Id + "' onchange='PluginUpdatesPage.setAutoUpdate(this);' data-role='slider' id='" + fieldId + "' name='" + fieldId + "'>" + options + "</select>";
  25. html += "</td>";
  26. fieldId = "liPluginUpdateFieldb" + fieldIndex;
  27. options = PluginUpdatesPage.getHtmlOptions(["Release", "Beta", "Dev"], plugin.UpdateClass);
  28. html += "<td>";
  29. html += "<select data-id='" + plugin.Id + "' onchange='PluginUpdatesPage.setUpdateClass(this);' data-inline='true' id='" + fieldId + "' name='" + fieldId + "'>" + options + "</select>";
  30. html += "</td>";
  31. html += "</tr>";
  32. elem.append(html).trigger('create');
  33. },
  34. getHtmlOptions: function (names, selectedValue) {
  35. var html = "";
  36. for (var i = 0, length = names.length; i < length; i++) {
  37. var name = names[i];
  38. if (name == selectedValue) {
  39. html += '<option value="' + name + '" selected="selected">' + name + '</option>';
  40. } else {
  41. html += '<option value="' + name + '">' + name + '</option>';
  42. }
  43. }
  44. return html;
  45. },
  46. setAutoUpdate: function (select) {
  47. var id = $(select).attr('data-id');
  48. Dashboard.showLoadingMsg();
  49. ApiClient.getPluginConfiguration(id).done(function (config) {
  50. config.EnableAutoUpdate = select.selectedIndex === 1;
  51. ApiClient.updatePluginConfiguration(id, config).done(Dashboard.hideLoadingMsg);
  52. });
  53. },
  54. setUpdateClass: function (select) {
  55. var id = $(select).attr('data-id');
  56. Dashboard.showLoadingMsg();
  57. ApiClient.getPluginConfiguration(id).done(function (config) {
  58. config.UpdateClass = select.value;
  59. ApiClient.updatePluginConfiguration(id, config).done(Dashboard.hideLoadingMsg);
  60. });
  61. }
  62. };
  63. $(document).on('pageshow', "#pluginUpdatesPage", PluginUpdatesPage.onPageShow);