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>
33 lines
1.1 KiB
Twig
33 lines
1.1 KiB
Twig
{#
|
|
# Variation Templates (Bootstrap 5 Override)
|
|
#
|
|
# JavaScript templates (Underscore.js syntax) used by WooCommerce to render
|
|
# variation details dynamically when a user selects product attributes.
|
|
# These are script templates, not rendered server-side.
|
|
#
|
|
# WooCommerce PHP equivalent: single-product/add-to-cart/variation.php
|
|
#
|
|
# @package WcBootstrap
|
|
# @since 0.1.0
|
|
#}
|
|
|
|
{% verbatim %}
|
|
<script type="text/template" id="tmpl-variation-template">
|
|
<div class="woocommerce-variation-description mb-2">
|
|
{{{ data.variation.variation_description }}}
|
|
</div>
|
|
<div class="woocommerce-variation-price mb-3">
|
|
<span class="price fs-3 fw-bold">{{{ data.variation.price_html }}}</span>
|
|
</div>
|
|
<div class="woocommerce-variation-availability mb-2">
|
|
{{{ data.variation.availability_html }}}
|
|
</div>
|
|
</script>
|
|
{% endverbatim %}
|
|
|
|
<script type="text/template" id="tmpl-unavailable-variation-template">
|
|
<p class="alert alert-warning mb-0">
|
|
{{ __('Sorry, this product is unavailable. Please choose a different combination.') }}
|
|
</p>
|
|
</script>
|