(function ($, document) { // The base query options var query = { TargetSystems: 'Server', IsAdult: false }; function reloadList(page) { Dashboard.showLoadingMsg(); if (AppInfo.enableAppStorePolicy) { $('.optionAdultContainer', page).hide(); } else { $('.optionAdultContainer', page).show(); } query.IsAppStoreSafe = true; var promise1 = ApiClient.getAvailablePlugins(query); var promise2 = ApiClient.getInstalledPlugins(); $.when(promise1, promise2).done(function (response1, response2) { populateList({ catalogElement: $('#pluginTiles', page), noItemsElement: $("#noPlugins", page), availablePlugins: response1[0], installedPlugins: response2[0] }); }); } function populateList(options) { requirejs(['scripts/ratingdialog'], function () { populateListInternal(options); }); } function populateListInternal(options) { var availablePlugins = options.availablePlugins; var installedPlugins = options.installedPlugins; availablePlugins = availablePlugins.filter(function (p) { p.category = p.category || "General"; p.categoryDisplayName = Globalize.translate('PluginCategory' + p.category.replace(' ', '')); if (options.categories) { if (options.categories.indexOf(p.category) == -1) { return false; } } if (options.targetSystem) { if (p.targetSystem != options.targetSystem) { return false; } } return p.type == "UserInstalled"; }).sort(function (a, b) { var aName = (a.category) + " " + a.name; var bame = (b.category) + " " + b.name; return aName > bame ? 1 : -1; }); var pluginhtml = ''; var currentCategory; for (var i = 0, length = availablePlugins.length; i < length; i++) { var html = ''; var plugin = availablePlugins[i]; var category = plugin.categoryDisplayName; if (category != currentCategory) { if (options.showCategory !== false) { if (currentCategory) { html += '
'; html += '
'; html += '
'; } html += '
' + category + '
'; } currentCategory = category; } var href = plugin.externalUrl ? plugin.externalUrl : "addplugin.html?name=" + encodeURIComponent(plugin.name) + "&guid=" + plugin.guid; if (options.context) { href += "&context=" + options.context; } var target = plugin.externalUrl ? ' target="_blank"' : ''; html += "
"; html += '
'; html += '
'; html += '
'; html += ''; if (plugin.thumbImage) { html += '"; html += '
'; html += "
"; html += plugin.name; html += "
"; if (!plugin.isExternal) { html += "
"; html += plugin.price > 0 ? "$" + plugin.price.toFixed(2) : Globalize.translate('LabelFree'); html += RatingHelpers.getStoreRatingHtml(plugin.avgRating, plugin.id, plugin.name, true); html += ""; html += " " + Globalize.translate('LabelNumberReviews').replace("{0}", plugin.totalRatings); html += ""; html += "
"; } var installedPlugin = plugin.isApp ? null : installedPlugins.filter(function (ip) { return ip.Id == plugin.guid; })[0]; html += "
"; if (installedPlugin) { html += Globalize.translate('LabelVersionInstalled').replace("{0}", installedPlugin.Version); } else { html += ' '; } html += "
"; // cardFooter html += "
"; // cardBox html += "
"; // card html += "
"; pluginhtml += html; } if (!availablePlugins.length && options.noItemsElement) { $(options.noItemsElement).hide(); } $(options.catalogElement).html(pluginhtml); Dashboard.hideLoadingMsg(); } $(document).on('pageinitdepends', "#pluginCatalogPage", function () { var page = this; $('.chkPremiumFilter', page).on('change', function () { if (this.checked) { query.IsPremium = false; } else { query.IsPremium = null; } reloadList(page); }); $('.radioPackageTypes', page).on('change', function () { var val = $('.radioPackageTypes:checked', page).val(); query.TargetSystems = val; reloadList(page); }); $('#chkAdult', page).on('change', function () { query.IsAdult = this.checked ? null : false; reloadList(page); }); }).on('pageshowready', "#pluginCatalogPage", function () { var page = this; $(".radioPackageTypes", page).each(function () { this.checked = this.value == query.TargetSystems; }).checkboxradio('refresh'); // Reset form values using the last used query $('.chkPremiumFilter', page).each(function () { var filters = query.IsPremium || false; this.checked = filters; }).checkboxradio('refresh'); reloadList(page); }); window.PluginCatalog = { renderCatalog: populateList }; })(jQuery, document);