38 lines
2.7 KiB
HTML
38 lines
2.7 KiB
HTML
{# Adapted from the vendored Penguin UI component
|
|
(assets/views/penguinui/card/ecommerce-product-card.html):
|
|
wired to our product data + i18n + htmx add-to-cart + toast. The demo rating
|
|
stars, hardcoded title/price/description/image and the `max-w-sm` (which fights
|
|
the shop grid) are dropped; the whole card links to the product page. #}
|
|
<article
|
|
class="group flex flex-col overflow-hidden rounded-radius border border-outline bg-surface-alt text-on-surface transition hover:border-primary dark:border-outline-dark dark:bg-surface-dark-alt dark:text-on-surface-dark dark:hover:border-primary-dark">
|
|
<a href="/shop/{{ product.slug }}" class="flex flex-1 flex-col">
|
|
<!-- Image -->
|
|
<div class="h-44 overflow-hidden bg-surface-alt md:h-64 dark:bg-surface-dark">
|
|
{% if product.image %}
|
|
<img src="/images/{{ product.image }}" alt="{{ product.name }}" class="size-full object-cover transition duration-700 ease-out group-hover:scale-105">
|
|
{% endif %}
|
|
</div>
|
|
<!-- Content -->
|
|
<div class="flex flex-1 flex-col gap-1 p-6 pb-2">
|
|
<!-- Header: Title & Price -->
|
|
<div class="flex justify-between gap-4">
|
|
<h3 class="text-lg font-bold text-on-surface-strong dark:text-on-surface-dark-strong">{{ product.name }}</h3>
|
|
<span class="whitespace-nowrap text-xl"><span class="sr-only">Price</span>{{ product.price }} {{ product.currency }}</span>
|
|
</div>
|
|
</div>
|
|
</a>
|
|
<div class="flex flex-col gap-2 p-6 pt-0">
|
|
{% if product.stock > 0 %}
|
|
<p class="text-xs text-on-surface/60 dark:text-on-surface-dark/60">{{ t(key="in-stock", lang=lang | default(value='sk')) }}: {{ product.stock }}</p>
|
|
<form method="post" action="/cart/add" hx-post="/cart/add" hx-swap="none"
|
|
hx-on::after-request="if (event.detail.successful) toast('{{ t(key='cart-added', lang=lang | default(value='sk')) }}')">
|
|
<input type="hidden" name="product_id" value="{{ product.id }}">
|
|
<input type="hidden" name="quantity" value="1">
|
|
{{ ui::button(label=t(key="add-to-cart", lang=lang | default(value='sk')), type="submit", extra="w-full", icon='<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16" fill="currentColor" aria-hidden="true" class="size-3.5"><path fill-rule="evenodd" d="M5 4a3 3 0 0 1 6 0v1h.643a1.5 1.5 0 0 1 1.492 1.35l.7 7A1.5 1.5 0 0 1 12.342 15H3.657a1.5 1.5 0 0 1-1.492-1.65l.7-7A1.5 1.5 0 0 1 4.357 5H5V4Zm4.5 0v1h-3V4a1.5 1.5 0 0 1 3 0Zm-3 3.75a.75.75 0 0 0-1.5 0v1a3 3 0 1 0 6 0v-1a.75.75 0 0 0-1.5 0v1a1.5 1.5 0 1 1-3 0v-1Z" clip-rule="evenodd" /></svg>') }}
|
|
</form>
|
|
{% else %}
|
|
<p class="inline-flex justify-center rounded-radius bg-danger/10 px-3 py-2 text-xs font-medium text-danger">{{ t(key="out-of-stock", lang=lang | default(value='sk')) }}</p>
|
|
{% endif %}
|
|
</div>
|
|
</article>
|