Files
wc-bootstrap/templates/cart/mini-cart.html.twig

88 lines
3.3 KiB
Twig
Raw Normal View History

Implement Phase 4 & 5: cart and checkout templates (Bootstrap 5, HPOS) Phase 4 - Cart (9 templates): - cart: 8+4 column layout, table-responsive items, coupon input-group - cart-empty: centered empty state with cart-x icon - cart-item-data: inline dl for variation details - cart-totals: card with list-group-flush rows, sticky sidebar - cart-shipping: form-check radio per shipping method - cross-sells: product loop grid section - mini-cart: offcanvas-compatible item list with remove buttons - proceed-to-checkout-button: btn-primary btn-lg w-100 - shipping-calculator: collapsible form with form-select/form-control Phase 5 - Checkout (12 templates): - form-checkout: 7+5 column layout, sticky order review sidebar - form-billing: card with field wrapper, optional account creation - form-shipping: card with ship-to-different-address collapse toggle - form-coupon: collapsible input-group with alert-info toggle - form-login: collapsible login reusing global/form-login.html.twig - review-order: card with table-sm, tfoot subtotal/shipping/total - payment: list-group of payment gateways with radio selection - payment-method: form-check with description collapse - terms: form-check checkbox with T&C link - thankyou: HPOS compatible, alert-success + order details list-group - order-received: confirmation message - cart-errors: alert-danger with return-to-cart button All order data accessed via WC_Order methods (HPOS compatible). CSS additions: cart thumbnail sizing, checkout form field overrides, payment box transitions, dark mode focus states. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-28 10:33:49 +01:00
{#
# Mini Cart / Cart Widget (Bootstrap 5 Override)
#
# Renders the mini cart as an offcanvas slide-in panel.
#
# Expected context:
# cart_items - Array from WC()->cart->get_cart()
# cart_is_empty - Whether cart is empty
# cart_subtotal - Cart subtotal HTML
# args - Widget arguments (list_class)
#
# WooCommerce PHP equivalent: cart/mini-cart.php
#
# @package WcBootstrap
# @since 0.1.0
#}
{{ do_action('woocommerce_before_mini_cart') }}
{% if not cart_is_empty|default(true) %}
<ul class="woocommerce-mini-cart list-unstyled {{ args.list_class|default('') }}">
{{ do_action('woocommerce_before_mini_cart_contents') }}
{% if cart_items is defined %}
{% for item in cart_items %}
<li class="woocommerce-mini-cart-item d-flex gap-3 py-2 border-bottom {{ item.css_class|default('') }}">
{# Remove link #}
<a href="{{ item.remove_url|esc_url }}"
class="btn btn-sm btn-outline-danger remove remove_from_cart_button"
Implement Phase 4 & 5: cart and checkout templates (Bootstrap 5, HPOS) Phase 4 - Cart (9 templates): - cart: 8+4 column layout, table-responsive items, coupon input-group - cart-empty: centered empty state with cart-x icon - cart-item-data: inline dl for variation details - cart-totals: card with list-group-flush rows, sticky sidebar - cart-shipping: form-check radio per shipping method - cross-sells: product loop grid section - mini-cart: offcanvas-compatible item list with remove buttons - proceed-to-checkout-button: btn-primary btn-lg w-100 - shipping-calculator: collapsible form with form-select/form-control Phase 5 - Checkout (12 templates): - form-checkout: 7+5 column layout, sticky order review sidebar - form-billing: card with field wrapper, optional account creation - form-shipping: card with ship-to-different-address collapse toggle - form-coupon: collapsible input-group with alert-info toggle - form-login: collapsible login reusing global/form-login.html.twig - review-order: card with table-sm, tfoot subtotal/shipping/total - payment: list-group of payment gateways with radio selection - payment-method: form-check with description collapse - terms: form-check checkbox with T&C link - thankyou: HPOS compatible, alert-success + order details list-group - order-received: confirmation message - cart-errors: alert-danger with return-to-cart button All order data accessed via WC_Order methods (HPOS compatible). CSS additions: cart thumbnail sizing, checkout form field overrides, payment box transitions, dark mode focus states. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-28 10:33:49 +01:00
aria-label="{{ __('Remove this item') }}"
data-product_id="{{ item.product_id }}"
data-cart_item_key="{{ item.key }}">
<i class="bi bi-x" aria-hidden="true"></i>
</a>
{# Thumbnail #}
{% if item.permalink %}
<a href="{{ item.permalink|esc_url }}" class="flex-shrink-0" style="width: 50px;">
{{ item.thumbnail|raw }}
</a>
{% endif %}
{# Product info #}
<div class="flex-grow-1">
{% if item.permalink %}
<a href="{{ item.permalink|esc_url }}" class="text-decoration-none d-block small fw-semibold">
{{ item.product_name }}
</a>
{% else %}
<span class="d-block small fw-semibold">{{ item.product_name }}</span>
{% endif %}
{{ item.item_data_html|default('')|raw }}
<span class="quantity small text-body-secondary">
{{ item.quantity }} &times; {{ item.price|raw }}
</span>
</div>
</li>
{% endfor %}
{% endif %}
{{ do_action('woocommerce_mini_cart_contents') }}
</ul>
<div class="woocommerce-mini-cart__total border-top pt-3 mt-2">
{{ do_action('woocommerce_widget_shopping_cart_total') }}
<p class="total d-flex justify-content-between fw-bold mb-3">
<span>{{ __('Subtotal:') }}</span>
<span>{{ cart_subtotal|raw }}</span>
</p>
</div>
{{ do_action('woocommerce_widget_shopping_cart_before_buttons') }}
<div class="woocommerce-mini-cart__buttons d-grid gap-2">
{{ do_action('woocommerce_widget_shopping_cart_buttons') }}
</div>
{{ do_action('woocommerce_widget_shopping_cart_after_buttons') }}
{% else %}
<p class="woocommerce-mini-cart__empty-message text-body-secondary text-center py-3">
{{ __('No products in the cart.') }}
</p>
{% endif %}
{{ do_action('woocommerce_after_mini_cart') }}