io.sphere.sdk.reviews.Review Maven / Gradle / Ivy
package io.sphere.sdk.reviews;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import io.sphere.sdk.customers.Customer;
import io.sphere.sdk.models.Reference;
import io.sphere.sdk.models.Resource;
import io.sphere.sdk.states.State;
import io.sphere.sdk.types.Custom;
import io.sphere.sdk.types.CustomFields;
import javax.annotation.Nullable;
import java.util.Locale;
/**
Reviews are used to evaluate products and channels.
Review Approval Process
If you do not need any approval process, skip this part.
If we have an approval process for a review to be used for a product or a channel, we model the approval process with a state machine.
First of all, once per commercetools project, we create the approved state. Then we create the initial to-approve state, which has a possible transition to the approved state:
{@include.example io.sphere.sdk.reviews.approvaldemo.CreateReviewStates}
Only states with {@link io.sphere.sdk.states.StateRole#REVIEW_INCLUDED_IN_STATISTICS} makes review ratings count in statistics.
Creating reviews
Now we can create a review in the initial state to-approve:
{@include.example io.sphere.sdk.reviews.approvaldemo.CreateReviewToApprove}
Querying which reviews should be approved
{@include.example io.sphere.sdk.reviews.approvaldemo.QueryReviewsToApprove}
Approving a review
{@include.example io.sphere.sdk.reviews.approvaldemo.ApprovingAReview}
Displaying Products
Searching for Products with a Minimal Rating
We can display all products that:
- have at least 2 stars (average rating superior to 2)
- with facets about the number of products rated with an average in the different ranges 0 to 1 star, 1 to 2 stars, 2 to 3 stars, 3 to 4 stars and 4 to 5 stars.
- sorted by average ratings
{@include.example io.sphere.sdk.reviews.ReviewProductProjectionSearchTest#searchForReviewsWithAverageRatingGreaterThan2()}
Getting reviews for one product (only approved)
{@include.example io.sphere.sdk.reviews.ReviewProductProjectionSearchTest#getApprovedReviewsForOneProduct()}
Getting reviews for one product
{@include.example io.sphere.sdk.reviews.ReviewProductProjectionSearchTest#getReviewsForOneProduct()}
@see io.sphere.sdk.reviews.commands.ReviewCreateCommand
@see io.sphere.sdk.reviews.commands.ReviewUpdateCommand
@see io.sphere.sdk.reviews.commands.ReviewDeleteCommand
@see io.sphere.sdk.reviews.queries.ReviewQuery
@see io.sphere.sdk.reviews.queries.ReviewByIdGet
@see io.sphere.sdk.reviews.queries.ReviewByKeyGet
*/
@JsonDeserialize(as = ReviewImpl.class)
public interface Review extends Resource, Custom {
/**
* The name of the author which created this review or null.
*
* @see io.sphere.sdk.reviews.commands.updateactions.SetAuthorName
* @return author name
*/
@Nullable
String getAuthorName();
/**
* Gets the custom fields of this review or null.
* @see io.sphere.sdk.reviews.commands.updateactions.SetCustomField
* @see io.sphere.sdk.reviews.commands.updateactions.SetCustomType
* @return custom fields
*/
@Nullable
CustomFields getCustom();
/**
* Gets the customer which created this review or null.
* @see io.sphere.sdk.reviews.commands.updateactions.SetCustomer
* @return customer
*/
@Nullable
Reference getCustomer();
/**
* Gets the key assigned to this review or null.
*
* @see io.sphere.sdk.reviews.commands.updateactions.SetKey
* @return key
*/
@Nullable
String getKey();
/**
* Gets the locale (language) in which the text and title are or null.
* @return locale
*/
@Nullable
Locale getLocale();
/**
* Gets the rating or null.
* @see io.sphere.sdk.reviews.commands.updateactions.SetRating
* @return the rating
*/
@Nullable
Integer getRating();
/**
* Gets the state of this review or null.
* @see io.sphere.sdk.reviews.commands.updateactions.TransitionState
* @return state
*/
@Nullable
Reference getState();
/**
* Identifies the target of the review. Can be a Product or a Channel or nothing.
* @see io.sphere.sdk.reviews.commands.updateactions.SetTarget
* @return the target of this review or null
*/
@Nullable
Reference> getTarget();
/**
* Gets the text of this review or null.
* @see io.sphere.sdk.reviews.commands.updateactions.SetText
* @return text
*/
@Nullable
String getText();
/**
* Gets the title of this review or null.
* @see io.sphere.sdk.reviews.commands.updateactions.SetTitle
* @return title
*/
@Nullable
String getTitle();
@Nullable
String getUniquenessValue();
/**
* Indicates if this review is taken into account in the ratings statistics of the target.
A review is per default used in the statistics, unless the review is in a state that does not have the role ReviewIncludedInStatistics.
If the role of a State is modified after the calculation of this field, the calculation is not updated.
* @return is included in review rating of target
*/
Boolean isIncludedInStatistics();
static String referenceTypeId() {
return "review";
}
static String resourceTypeId() {
return "review";
}
static TypeReference typeReference(){
return new TypeReference() {
@Override
public String toString() {
return "TypeReference";
}
};
}
static Reference referenceOfId(final String id) {
return Reference.of(referenceTypeId(), id);
}
default Reference toReference() {
return Reference.of(referenceTypeId(), getId(), this);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy