You've already forked wc-bootstrap
Add two-column responsive grid (image gallery + product summary) for
single product pages, following the same bridge pattern used for
product archives.
Key changes:
- Create content-single-product.php bridge and Twig layout template
- Add single product renderer at template_redirect priority 11
- Disable WooCommerce block compatibility layer that strips classic
hooks when parent theme has theme.json
- Move PHP templates to woocommerce/ subfolder for cleaner structure
- Fix Twig templates to self-compute context data not passed by
wc_get_template() (tabs, short-description, meta, rating)
- Fix Underscore.js triple-brace syntax conflict in variation template
by wrapping in {% verbatim %}
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
50 lines
1.8 KiB
Twig
50 lines
1.8 KiB
Twig
{#
|
|
# Product Rating (Bootstrap 5 Override)
|
|
#
|
|
# Renders the star rating with review count link on the single product page.
|
|
#
|
|
# Expected context:
|
|
# product - WC_Product object (from TemplateOverride)
|
|
#
|
|
# WooCommerce PHP equivalent: single-product/rating.php
|
|
#
|
|
# @package WcBootstrap
|
|
# @since 0.1.0
|
|
#}
|
|
|
|
{# Guard: bail if ratings are disabled. #}
|
|
{% if fn('wc_review_ratings_enabled') %}
|
|
|
|
{# Compute rating data from product object when not passed as context. #}
|
|
{% if rating_count is not defined %}
|
|
{% set rating_count = product.get_rating_count() %}
|
|
{% set review_count = product.get_review_count() %}
|
|
{% set average = product.get_average_rating() %}
|
|
{% endif %}
|
|
|
|
{% if rating_count > 0 %}
|
|
<div class="woocommerce-product-rating d-flex align-items-center gap-2 mb-3">
|
|
<div class="wc-star-rating d-flex align-items-center gap-1"
|
|
role="img"
|
|
aria-label="{{ __('%s out of 5 stars')|format(average) }}">
|
|
{% for i in 1..5 %}
|
|
{% if i <= average|round(0, 'floor') %}
|
|
<i class="bi bi-star-fill text-warning" aria-hidden="true"></i>
|
|
{% elseif i - average < 1 %}
|
|
<i class="bi bi-star-half text-warning" aria-hidden="true"></i>
|
|
{% else %}
|
|
<i class="bi bi-star text-warning" aria-hidden="true"></i>
|
|
{% endif %}
|
|
{% endfor %}
|
|
</div>
|
|
|
|
{% if review_count > 0 %}
|
|
<a href="#reviews" class="woocommerce-review-link text-body-secondary text-decoration-none small" rel="nofollow">
|
|
{{ fn('_n', '%s customer review', '%s customer reviews', review_count, 'woocommerce')|format(review_count) }}
|
|
</a>
|
|
{% endif %}
|
|
</div>
|
|
{% endif %}
|
|
|
|
{% endif %}{# wc_review_ratings_enabled #}
|