You've already forked wc-bootstrap
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>
This commit is contained in:
66
templates/checkout/form-billing.html.twig
Normal file
66
templates/checkout/form-billing.html.twig
Normal file
@@ -0,0 +1,66 @@
|
||||
{#
|
||||
# Billing Form (Bootstrap 5 Override)
|
||||
#
|
||||
# Renders billing address fields within a Bootstrap card.
|
||||
#
|
||||
# Expected context:
|
||||
# checkout - WC_Checkout object with:
|
||||
# .get_checkout_fields('billing') - Array of billing field configs
|
||||
#
|
||||
# WooCommerce PHP equivalent: checkout/form-billing.php
|
||||
#
|
||||
# @package WcBootstrap
|
||||
# @since 0.1.0
|
||||
#}
|
||||
|
||||
<div class="woocommerce-billing-fields">
|
||||
<div class="card shadow-sm mb-4">
|
||||
<div class="card-header">
|
||||
<h3 class="h5 mb-0">{{ __('Billing details') }}</h3>
|
||||
</div>
|
||||
<div class="card-body">
|
||||
{{ do_action('woocommerce_before_checkout_billing_form', checkout) }}
|
||||
|
||||
<div class="woocommerce-billing-fields__field-wrapper row g-3">
|
||||
{% if billing_fields is defined %}
|
||||
{% for key, field in billing_fields %}
|
||||
{{ woocommerce_form_field(key, field, checkout.get_value(key)) }}
|
||||
{% endfor %}
|
||||
{% endif %}
|
||||
</div>
|
||||
|
||||
{{ do_action('woocommerce_after_checkout_billing_form', checkout) }}
|
||||
</div>
|
||||
</div>
|
||||
|
||||
{# Account creation fields (for guest checkout) #}
|
||||
{% if checkout.is_registration_enabled() is defined and checkout.is_registration_enabled() and not is_user_logged_in() %}
|
||||
{% if checkout.is_registration_required() is not defined or not checkout.is_registration_required() %}
|
||||
<div class="woocommerce-account-fields mb-4">
|
||||
<div class="form-check mb-3">
|
||||
<input class="form-check-input"
|
||||
type="checkbox"
|
||||
name="createaccount"
|
||||
id="createaccount"
|
||||
value="1"
|
||||
{{ checkout.get_value('createaccount') ? 'checked' : '' }} />
|
||||
<label class="form-check-label" for="createaccount">
|
||||
{{ __('Create an account?') }}
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
{% endif %}
|
||||
|
||||
{{ do_action('woocommerce_before_checkout_registration_form', checkout) }}
|
||||
|
||||
<div class="create-account collapse{% if checkout.get_value('createaccount') %} show{% endif %}">
|
||||
{% if account_fields is defined %}
|
||||
{% for key, field in account_fields %}
|
||||
{{ woocommerce_form_field(key, field, checkout.get_value(key)) }}
|
||||
{% endfor %}
|
||||
{% endif %}
|
||||
</div>
|
||||
|
||||
{{ do_action('woocommerce_after_checkout_registration_form', checkout) }}
|
||||
{% endif %}
|
||||
</div>
|
||||
Reference in New Issue
Block a user