Files
wc-bootstrap/templates/checkout/payment.html.twig

55 lines
2.0 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
{#
# Payment Methods & Place Order (Bootstrap 5 Override)
#
# Renders payment gateway selection and the place order button.
#
# Expected context:
# available_gateways - Array of WC_Payment_Gateway objects
# order_button_text - Place order button label
#
# WooCommerce PHP equivalent: checkout/payment.php
#
# @package WcBootstrap
# @since 0.1.0
#}
<div id="payment" class="woocommerce-checkout-payment mt-4">
{{ do_action('woocommerce_review_order_before_payment') }}
{% if available_gateways is defined and available_gateways|length > 0 %}
<div class="card shadow-sm mb-3">
<div class="card-header">
<h4 class="h6 mb-0">{{ __('Payment method') }}</h4>
</div>
<ul class="wc_payment_methods payment_methods list-group list-group-flush">
{% for gateway_id, gateway in available_gateways %}
{% include 'checkout/payment-method.html.twig' with { gateway: gateway } %}
{% endfor %}
</ul>
</div>
{% else %}
<div class="alert alert-warning mb-3" role="alert">
{{ __('Sorry, it seems that there are no available payment methods. Please contact us if you require assistance or wish to make alternate arrangements.') }}
</div>
{% endif %}
<div class="place-order">
{{ do_action('woocommerce_review_order_before_submit') }}
{{ wp_nonce_field('woocommerce-process_checkout', 'woocommerce-process-checkout-nonce') }}
<button type="submit"
class="btn btn-primary btn-lg w-100"
name="woocommerce_checkout_place_order"
id="place_order"
value="{{ order_button_text|default(__('Place order')) }}"
data-value="{{ order_button_text|default(__('Place order')) }}">
{{ order_button_text|default(__('Place order')) }}
</button>
{{ do_action('woocommerce_review_order_after_submit') }}
</div>
{{ do_action('woocommerce_review_order_after_payment') }}
</div>