You've already forked wc-bootstrap
88 lines
3.3 KiB
Twig
88 lines
3.3 KiB
Twig
|
|
{#
|
||
|
|
# 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="remove remove_from_cart_button text-danger"
|
||
|
|
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 }} × {{ 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') }}
|