(function ($, document) { // The base query options var query = { TargetSystems: 'Server' }; function reloadList(page) { Dashboard.showLoadingMsg(); var promise1 = ApiClient.getAvailablePlugins(query); var promise2 = ApiClient.getInstalledPlugins(); $.when(promise1, promise2).done(function (response1, response2) { populateList(page, response1[0], response2[0]); }); Dashboard.hideLoadingMsg(); } function populateList(page, availablePlugins, installedPlugins) { availablePlugins = availablePlugins.filter(function (p) { return p.type == "UserInstalled"; }).sort(function (a, b) { return a.name > b.name ? 1 : -1; }); var html = ""; for (var i = 0, length = availablePlugins.length; i < length; i++) { var plugin = availablePlugins[i]; html += "
"; if (plugin.thumbImage) { html += ""; } else { html += ""; } if (plugin.isPremium) { if (plugin.price > 0) { html += "
"; } else { html += "
"; } } var color = plugin.tileColor || LibraryBrowser.getMetroColor(plugin.name); html += "
"; var installedPlugin = installedPlugins.filter(function (ip) { return ip.Name == plugin.name; })[0]; html += "
"; if (installedPlugin) { html += plugin.name + " (Installed)"; } else { html += plugin.name; } html += "
"; html += "
"; html += "
"; } if (!availablePlugins.length) { html = '
No available plugins
'; } $('#pluginTiles', page).html(html); Dashboard.hideLoadingMsg(); } function selectTab(elem, page) { $("#pluginTabs a").removeClass("ui-btn-active"); $(elem).addClass("ui-btn-active"); query.TargetSystems = $(elem).attr("rel"); reloadList(page); } $(document).on('pageinit', "#pluginCatalogPage", function () { var page = this; $('.chkPremiumFilter', page).on('change', function () { if (this.checked) { query.IsPremium = true; } else { query.IsPremium = null; } reloadList(page); }); $('#pluginTabs a', page).each(function () { $(this).on('click', function () { selectTab(this, page); }); }); }).on('pageshow', "#pluginCatalogPage", function () { var page = this; selectTab($("#pluginTabs a.ui-btn-active"), page); // Reset form values using the last used query $('.chkPremiumFilter', page).each(function () { var filters = query.IsPremium || false; this.checked = filters; }).checkboxradio('refresh'); }); })(jQuery, document);