diff --git a/ApiClient.js b/ApiClient.js index 3254b84f36..151e62462f 100644 --- a/ApiClient.js +++ b/ApiClient.js @@ -3569,6 +3569,16 @@ MediaBrowser.ApiClient = function ($, navigator, JSON, WebSocket, setTimeout, wi url: url }); }; + + self.createPackageReview = function(review) { + + var url = self.getUrl("PackageReviews/" + review.id, review); + + return self.ajax({ + type: "POST", + url: url, + }); + }; } }(jQuery, navigator, window.JSON, window.WebSocket, setTimeout, window); diff --git a/dashboard-ui/css/librarybrowser.css b/dashboard-ui/css/librarybrowser.css index b1e09245d2..921422d9a7 100644 --- a/dashboard-ui/css/librarybrowser.css +++ b/dashboard-ui/css/librarybrowser.css @@ -174,6 +174,18 @@ max-width: 300px; } +.storeStarRating { + background-image: url(); + background-position: left center; + background-repeat: no-repeat; + width: 19px; + height: 16px; + display: inline-block; + background-size: cover; + vertical-align: central; + cursor: pointer; +} + .starRating { background-image: url(); background-position: left center; diff --git a/dashboard-ui/css/posteritem.css b/dashboard-ui/css/posteritem.css index 6c531e4898..d136e18dbe 100644 --- a/dashboard-ui/css/posteritem.css +++ b/dashboard-ui/css/posteritem.css @@ -36,6 +36,18 @@ border: 0; } +.posterItemStoreText { + font-family: 'Open Sans', sans-serif; + font-weight: normal; + font-size: 16px; + text-overflow: ellipsis; + overflow: hidden; + text-wrap: none; + white-space: nowrap; + text-shadow: none; +} + + .posterItemText { text-overflow: ellipsis; overflow: hidden; @@ -71,6 +83,20 @@ height: 150px; } +.storeItem { + width: 270px; + display: inline-block; + margin: 10px; +} + +.storePosterItem { + width: 270px; +} + .storePosterItem .posterItemImage { + height: 150px; + } + + .backdropPosterItem { width: 160px; } diff --git a/dashboard-ui/plugincatalog.html b/dashboard-ui/plugincatalog.html index 93ba24ecb5..03e9612bbb 100644 --- a/dashboard-ui/plugincatalog.html +++ b/dashboard-ui/plugincatalog.html @@ -2,6 +2,7 @@ Plugins +
diff --git a/dashboard-ui/scripts/plugincatalogpage.js b/dashboard-ui/scripts/plugincatalogpage.js index 78362aa57a..368a5f390c 100644 --- a/dashboard-ui/scripts/plugincatalogpage.js +++ b/dashboard-ui/scripts/plugincatalogpage.js @@ -47,6 +47,28 @@ Dashboard.hideLoadingMsg(); } + function getRatingHtml(rating, id, name) { + + var html = "
"; + if (!rating) rating = 0; + + for (var i = 1; i <= 5; i++) { + html += ""; + if (rating < i - 1 || rating == 0) { + html += "
"; + } else if (rating < i) { + html += "
"; + } else { + html += "
"; + } + html += "
"; + } + + html += "
"; + + return html; + } + function populateList(page, availablePlugins, installedPlugins) { Dashboard.showLoadingMsg(); @@ -79,7 +101,7 @@ var href = plugin.externalUrl ? plugin.externalUrl : "addPlugin.html?name=" + encodeURIComponent(plugin.name) + "&guid=" + plugin.guid; var target = plugin.externalUrl ? ' target="_blank"' : ''; - html += ""; + html += "
"; if (plugin.thumbImage) { html += '
'; @@ -95,9 +117,9 @@ } } - var color = plugin.tileColor || LibraryBrowser.getMetroColor(plugin.name); + html += "
"; - html += "
"; + html += "
"; var installedPlugin = plugin.isApp ? null : installedPlugins.filter(function (ip) { return ip.Name == plugin.name; @@ -108,10 +130,20 @@ } else { html += plugin.name; } - + html += "
"; - html += ""; + html += "
"; + html += plugin.price > 0 ? "$" + plugin.price.toFixed(2) : "Free"; + html += getRatingHtml(plugin.avgRating, plugin.id, plugin.name); + html += " " + plugin.totalRatings + " Reviews"; + + if (plugin.isPremium && plugin.isRegistered) { + html += " ®"; + } + + html += "
"; + html += "
"; pluginhtml += html; @@ -126,7 +158,6 @@ Dashboard.hideLoadingMsg(); } - $(document).on('pageinit', "#pluginCatalogPage", function () { var page = this; diff --git a/dashboard-ui/scripts/ratingdialog.js b/dashboard-ui/scripts/ratingdialog.js new file mode 100644 index 0000000000..5235e76f39 --- /dev/null +++ b/dashboard-ui/scripts/ratingdialog.js @@ -0,0 +1,98 @@ +(function (window, document, $) { + + window.RatingDialog = function (page) { + + var self = this; + + self.show = function (options) { + + options = options || {}; + + options.header = options.header || "Rate and Review"; + + var html = ''; + + $(page).append(html); + + var popup = $('#popupRatingDialog').popup().trigger('create').on("popupafteropen", function() { + + $('#txtRatingDialogTitle', this).focus(); + + }).popup("open").on("popupafterclose", function() { + + $('form', this).off("submit"); + + $(this).off("popupafterclose").remove(); + + }); + + $('form', popup).on('submit', function () { + + if (options.callback) { + var review = { + id: options.id, + rating: $('#txtRatingDialogRating', this).val(), + title: $('#txtRatingDialogTitle', this).val(), + recommend: $('#txtRatingDialogRecommend', this).checked(), + review: $('#txtRatingDialogReview', this).val(), + }; + + if (review.rating < 3) { + if (!review.title) { + $('#errorMsg', this).html("Please give reason for low rating").show(); + $('#txtRatingDialogTitle', this).focus(); + return false; + } + } + + if (!review.recommend) { + if (!review.title) { + $('#errorMsg', this).html("Please give reason for not recommending").show(); + $('#txtRatingDialogTitle', this).focus(); + return false; + } + } + + options.callback(review); + } else console.log("No callback function provided"); + + return false; + }); + + }; + + self.close = function () { + $('#popupRatingDialog', page).popup("close"); + }; + }; + +})(window, document, jQuery); \ No newline at end of file diff --git a/dashboard-ui/scripts/site.js b/dashboard-ui/scripts/site.js index 840100d8f1..59303fb950 100644 --- a/dashboard-ui/scripts/site.js +++ b/dashboard-ui/scripts/site.js @@ -1120,7 +1120,25 @@ var Dashboard = { parts.push(seconds); return parts.join(':'); - } + }, + + ratePackage: function(link) { + var id = link.getAttribute('data-id'); + var name = link.getAttribute('data-name'); + var rating = link.getAttribute('data-rating'); + + var dialog = new RatingDialog($.mobile.activePage); + dialog.show({ header: "Rate and review " + name, id: id, rating: rating, callback: function(review) { + console.log(review); + dialog.close(); + + ApiClient.createPackageReview(review).done(function() { + Dashboard.alert("Thank you for your review"); + }); + } }); + +} + }; if (!window.WebSocket) {