A bundle to display customer reviews for the Sulu CMS. Reviews can be retrieved automatically from Google My Business.
- PHP >= 8.0
- Composer
- Sulu >= 2.5.*
- Symfony >= 5.4
- Display reviews on the website
- Settings management
- Possibility to retrieve reviews from Google My Business
Execute the following composer command to add the bundle to the dependencies of your project:
composer require pixelopen/sulu-reviewbundle
Enable the bundle by adding it to the list of registered bundles in the config/bundles.php
file of your project:
return [
/* ... */
Pixel\ReviewBundle\ReviewBundle::class => ['all' => true],
];
Use a doctrine migration for this.
Define the Admin Api Route in routes_admin.yaml
review.reviews_api:
type: rest
prefix: /admin/api
resource: pixel_review.reviews_route_controller
name_prefix: review.
review.setting_api:
type: rest
prefix: /admin/api
resource: pixel_review.settings_route_controller
name_prefix: review.
Go to the "Reviews" section in the administration interface. Then, click on "Add". Fill the fields that are needed for your use.
Here is the list of the fields:
- Customer name (mandatory)
- Review date (mandatory)
- Rating (mandatory)
- Message (Mandatory)
- Retrieve from Google My Business? (Read only. Allows you to know if the review was automatically picked up from Google)
- Customer image
Once you finished, click on "Save"
To edit a review, simply click on the pencil at the left of the review you wish to edit.
There are two ways to remove a review:
- Check every review you want to remove and then click on "Delete"
- Go to the detail of a review (see the above section) and click on "Delete".
In both cases, the review will be put in the trash.
To access the trash, go to the "Settings" and click on "Trash". To restore a review, click on the clock at the left. Confirm the restore. You will be redirected to the detail of the review you restored.
To remove permanently a review, check all the reviews you want to remove and click on "Delete".
This bundle comes with settings. Here the list of the different settings available:
- Total reviews (mandatory)
- Average rating (mandatory)
- Use Google rating?
- Retrieve Google review?
- Place ID
- API key
The total reviews and the average rating must be filled manually unless you use the Google rating.
The option "Use Google rating?" allows you to pick up the total rating and the average rating from Google. If you want to retrieve the reviews as well, check the "Retrieve Google review?" checkbox.
If you decide to use the reviews information from Google, you will need to fill the place ID and the API key. Once that is done, run the following command:
bin/console sync:google:rating
There are several twig function in order to help you use the reviews and the settings on your website:
get_latest_reviews(limit): returns the latest reviews. It takes one parameter:
- limit: represents the number of the latest reviews to display. If no limit is provided, the default value is 3.
Example of use:
<div class="w-full flex flex-row gap-6 justify-between">
{% set reviews = get_latest_reviews(4) %}
{% for review in reviews %}
<div class="containerAvis bg-white rounded-xl p-6 w-1/4">
{{ review.message|raw }}
<h3 class="block text-center text-base font-bold">{{ review.name }} - {{ review.rating }}/5 </h3>
</div>
{% endfor %}
</div>
get_latest_reviews_html(limit): do the same thing as get_latest_reviews() but it renders a view instead. It takes one parameter:
- limit: represents the number of the latest reviews to display. If no limit is provided, the default value is 3.
Example of use:
<div>
{{ get_latest_reviews_html(4) }}
</div>
reviews_settings(): returns the settings of the bundle. No parameters are required.
Example of use:
{% set reviewsSettings = reviews_settings() %}
{% if reviewsSettings is not null %}
<div class="noteGoogle">
<p>Note : {{ reviewsSettings.averageRating }}</p>
<ul class="star">
<li><img src="{{ asset('/assets/images/noteGoogle/star.svg') }}" alt=""></li>
<li><img src="{{ asset('/assets/images/noteGoogle/star.svg') }}" alt=""></li>
<li><img src="{{ asset('/assets/images/noteGoogle/star.svg') }}" alt=""></li>
<li><img src="{{ asset('/assets/images/noteGoogle/star.svg') }}" alt=""></li>
<li><img src="{{ asset('/assets/images/noteGoogle/star.svg') }}" alt=""></li>
<li>
More than <strong>{{ reviewsSettings.totalRating }}</strong> reviews
</li>
</ul>
</div>
{% endif %}
You can contribute to this bundle. The only thing you must do is respect the coding standard we implements.
You can find them in the ecs.php
file.