Note: This tutorial and its steps are based on a Wix Editor site. You can adapt the steps for a Wix Studio site by using the equivalent Wix Studio features.
This article describes how you can use Velo to add ratings and reviews to a Wix Stores site. Throughout this article we're going to use this site to illustrate the process. We're going to explain how we set up the sample site and the code we added to make it work.
In our site we added the following:
Then we added code to do the following:
To recreate this functionality, you'll need to have Wix Stores added to your site with some products. Once you add Stores to your site, you'll see pages and collections automatically added to your site.
Note You may need to save or publish the site and refresh your browser to view the Stores collections in the Database.
This is what some of the data in our site looks like:
The Products and Collections collections are created automatically when you have a site with Wix Stores. Because these collections are read-only, you must use the Store Manager to create your product list. In this example we don't work with the Collections collection, although it is in our sample site's store.
We also added a Review Box lightbox to the site, and review-stats and reviews collections to our database. We'll describe the Review Box lightbox's setup later in this article.
The review-stats collection has the following fields:
We use the statistics stored in the review-stats collection to calculate the number of reviews, the average rating, and the recommended percentage for each product.
The reviews collection has fields to store the review information entered via the Review Box lightbox, plus a field that references the item in the Products collection.
We use the data stored in the reviews collection to display each review on the Product page, and to calculate the statistics for each product stored in the review-stats collection.
On the Shop Product Page we added:
We also added:
Note that there are two types of ratings displayed on the Product page:
In the Review Box lightbox we added:
On the Product Page we start by importing the modules we need to work with data collections and lightboxes in our code. Then we define a global variable to represent the current product. Finally, we run the initReviews
function to load the current product's ratings and reviews on the page.
Note: Throughout this example we use the async/await JavaScript functionality.
1
Lines 1-3: Import the modules we need to work with Wix Data, Wix Window Frontend, and Wix Location Frontend libraries.
Line 5: Define the global product
variable.
Line 7: When the page loads, do the following:
Line 8: Using the getProduct
function on the current product page, set the product
variable to the currently displayed product.
Line 9: Run the initReviews
function to load the current product's ratings and reviews.
Line 11: Some functionalities change the product without refreshing the page (for example, next/previous buttons and related products gallery). This change triggers Wix Location Frontend's onChange() API, then:
Line 12: Update the product
variable for the newly displayed product.
Line 13: Run the initReviews
function to load the current product's ratings and reviews.
If you want to use this exact scenario and code in your site, you may need to modify these items to match the ones on your site:
#productPage1
The initReviews
function filters the Reviews
dataset to contain only reviews of the currently displayed product, and then displays the product's reviews and statistics.
Note There are two ways to filter a dataset: using code (as in this example) or via the Dataset Settings panel of the dataset.
1
Line 2: Chain an eq
function to setFilter
to filter out all items in the Reviews
dataset where the product ID doesn't match the ID of the currently displayed product.
Line 3: Run the showReviews
function to display all filtered reviews.
Line 4: Run the loadStatistics
function to load and display statistics for the current product.
If you want to use this exact scenario and code in your site, you may need to modify these items to match the ones on your site:
#Reviews
productId
The loadStatistics
function gets and displays statistics for the current product.
1
Line 2: Use the current product's ID to get the product's statistics from the review-stats
collection and assign them to the stats
variable.
Line 3: Check whether there are any statistics related to the current product, indicating that one or more users have rated the product. If there are stats, do the following:
Line 4: Calculate the average rating of the product by dividing the sum of all ratings the product received from all reviewers by the number of times the product was rated, multiplying by ten, and rounding the number.
Line 5: Calculate the percentage of people who recommended the product by dividing the total number of recommendations the product received by the number of times the product was rated, multiplying by 100, and rounding the number.
Line 6: Get the generalRatings
ratings element and assign it to the ratings
variable.
Line 7: Set the ratings element's rating value to the average rating calculated above.
Line 8: Set the ratings element's total number of ratings from the count
field in the review-stats
collection for the current product.
Line 9: Set the text that displays the recommended percent.
Line 10: Show the ratings element.
Lines 11-14: If there are no stats (indicating that no reviewers have rated the product yet), display text stating that there are no reviews yet.
If you want to use this exact scenario and code in your site, you may need to modify these items to match the ones on your site:
review-stats
#generalRatings
#recoPercent
We selected the reviewsRepeater
element and, in the Properties & Events panel, added an onItemReady
event handler.
In Step 5 the initReviews
function filters the Reviews
dataset to contain only reviews of the currently displayed product. Each filtered item (row) in the collection is passed to the reviewsRepeater_itemReady
event handler as the itemData
parameter.
After the page loads and the filtered dataset connects to the repeater, reviewsRepeater_itemReady
loads data from the collection into each element in the repeater.
1
Line 2: Check if the reviewer recommended the product using the boolean recommends
field in the reviews
collection of the current item.
Lines 3-4: Display text that states whether the reviewer recommended or didn't recommend the product.
Lines 7-9: If the reviewer uploaded a photo, set the image URL from the item photo and expand the image.
Line 11: Set the rating value for the review in the oneRating
ratings display as the rating of the current item.
Line 12: Get the date the review was submitted and assign it to the date
variable.
Line 13: Use the toLocalString
function to format the date text according to date format settings on the visitor's computer.
If you want to use this exact scenario and code in your site, you may need to modify these items to match the ones on your site:
#recommendation
#reviewImage
#oneRating
#submissionTime
showReviews
expands or collapses the review strip that displays the reviews depending on whether any reviews were submitted.
1
Line 2: Use the getTotalCount
function to check whether there are any reviews in the Reviews
dataset for the current product.
Lines 3-5: If there are reviews, expand the review strip. If there are no reviews, collapse the review strip.
If you want to use this exact scenario and code in your site, you may need to modify these items to match the ones on your site:
#Reviews
#reviewsStrip
addReview_click
runs when the reviewer clicks the "Write a Review" button. We selected the "Write a Review" button and, in the Properties & Events panel, added an onClick
event handler.
The function opens the Review Box lightbox, sends it the current product's ID, and waits for the lightbox to close.
After the lightbox has closed, the function refreshes the Reviews
dataset so the new reviews appear on the page, reloads the product statistics to reflect the new rating, and displays a thank you message.
1
Lines 2-3: Create a dataForLightbox
object contaning the current product's ID to be sent to the Review Box lightbox.
Line 5: Open the Review Box lightbox, send it the product ID object created above, and wait for it to close.
Line 6: After the review lightbox is closed, refresh the Reviews
dataset so the new review appears on the page.
Line 7-9: Reload the current products statistics to reflect the new rating.
Line 10: Show a thank you message.
If you want to use this exact scenario and code in your site, you may need to modify these items to match the ones on your site:
#Reviews
#thankYouMessage
resultsPages_click
runs when the reviewer clicks the "load more" text at the bottom of the Product page. We selected the "load more" text and, in the Properties & Events panel, added an onClick
event handler.
When the visitor clicks the text, the resultsPages_click
event handler loads another page (chunk) of reviews into the reviewsRepeater
.
Note The number of reviews displayed in each page (chunk) of the repeater is defined in the Reviews dataset. Click the dataset, click Manage Dataset, and enter the Number of items to display.
1
Lines 1-2: When the event handler is triggered, the Reviews
dataset loads the next page (chunk) of reviews using the loadMore
function.
If you want to use this exact scenario and code in your site, you may need to modify these items to match the ones on your site:
#Reviews
In the Review Box lightbox, we started by importing the modules we need to work with data collections and lightboxes in our code. Then we declare a variable to store the current product ID.
When the lightbox finishes loading, we get the current product ID passed to the lightbox in Step 9 via the openLightbox
function.
After reviewers complete their review and click the "Post Review" button, the new review data is sent to the SubmitReview
dataset. Before the new review is saved to the reviews
collection, we use the onBeforeSave
event handler to check whether the reviewer rated the product. If the user did not rate the product, an error message is displayed and the review is not saved.
After the new review is saved to the reviews
collection, we use the onAfterSave
event handler to update the statistics for the current product, and to close the lightbox.
First, add the following to the lightbox page's code:
1
Lines 1-2: Import the modules we need to work with Wix Data and Wix Window Frontend libraries.
Line 4: Declare a global variable to store the product ID.
Then, add the following code to the onReady function:
1
Line 3: When the page loads, use the getContext
function to get the object passed to the lightbox when it was opened. In this case, the object containins the current product ID.
Line 5: Set the action that occurs before the new review is saved to the reviews
collection via the SubmitReviews
dataset.
Line 6: Check if the reviewer rated the product.
Lines 7-8: If the reviewer did not rate the product, show the rateError
error message and do not save the the new review.
Line 11: If the reviewer did rate the product, use the setFieldValues
function to update the SubmitReviews
dataset.
Lines 12-14: Update the dataset item with the input element values. The item will then be saved to the reviews
collection.
And finally, add the following code to the onReady function:
1
Line 1: Set the action that occurs after the new review is saved to the reviews
collection via the SubmitReviews
dataset.
Line 2: Update the product's statistics using the updateStatistics
function. The reviewer's recommendation (or not), as stored in the radioGroup1
radio buttons, is sent as a parameter to the function.
Line 3: After the statistics are updated, close the lightbox to return the reviewer to the Product page.
If you want to use this exact scenario and code in your site, you may need to modify these items to match the ones on your site:
productID
#SubmitReviews
#radioRating
#rateError
#radioGroup1
This function updates the statistics stored in the review-stats
collection to include data from the current review. If no previous statistics exist for the current product, it creates a new statistics item.
1
Line 2: Get the review statistics for the current product from the review-stats
collection.
Line 4: If statistics data already exist for this product, do the following:
Line 5: Extract the string representing the value of the radio button rating selected by the user. Use the parseInt
function to convert the string to an integer. Add the integer to the total rating points.
Line 6: Increase the ratings count by one.
Line 7: Check if the reviewer recommended the product. If the isRecommended
input parameter from the reviews
collection is true, increase the recommendation count by one.
Line 8: Update the product's statistics in the review-stats
collection.
Line 11: If no previous statistics data exist for this product, create a new statistics item:
LIne 12: Set the statistics item's ID to the current product's ID.
Line 13: Extract the string representing the value of the radio button rating selected by the user. Use the parseInt
function to convert the string to an integer. Set the statistics item's rating to the integer.
Line 14: Set the statistics item's ratings count to 1 because this is the first rating.
Line 15: Check if the reviewer recommended the product. If they did, set the recommendation count to 1.
Line 17: Insert the new product's statistics into the review-stats
collection.
If you want to use this exact scenario and code in your site, you may need to modify these items to match the ones on your site:
review-stats
#radioRating
radioRating_change
runs when the reviewer chooses a rating. We selected the radioRating
radio buttons element under "Overall Rating" and, in the Properties & Events panel, added an onChange
event handler.
When the visitor chooses a rate, the radioRating_change
event handler hides the error message displayed when a visitor fails to rate the product.
1
Lines 1-2: When the vistor selects a rate, hide the error message stating "Please rate this product".
If you want to use this exact scenario and code in your site, you may need to modify these items to match the ones on your site:
#rateError