Files
e-ticket/templates/order/_summary.html.twig
Serreau Jovann 7167a58c7c Add reservation flow: BilletBuyer, guest checkout, Stripe payment
- Create BilletBuyer entity: event, user (nullable for guests), firstName,
  lastName, email, reference (ETICKET-XXXX-XXXX-XXXX), totalHT, status,
  stripeSessionId, paidAt, items (OneToMany)
- Create BilletBuyerItem entity: billet, billetName (snapshot), quantity,
  unitPriceHT, line total helpers
- OrderController with full checkout flow:
  - POST /evenement/{id}/commander: create order from cart JSON
  - GET/POST /commande/{id}/informations: guest form (name, email)
  - GET /commande/{id}/paiement: payment page with recap
  - POST /commande/{id}/stripe: Stripe Checkout on connected account
    with application_fee, productId, and quantities
  - GET /commande/{id}/confirmation: success page
- Cart JS: POST cart data on Commander click, redirect to guest/payment
- Templates: guest form, payment page, order summary partial, success page
- Stripe payment uses organizer connected account, application_fee based
  on commissionRate, existing productId when available
- Tests: BilletBuyerTest (12), BilletBuyerItemTest (6), cart.test.js (13)

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-03-21 13:54:17 +01:00

26 lines
1.2 KiB
Twig

<div class="card-brutal overflow-hidden">
<div class="section-header">
<h2 class="text-[10px] font-black uppercase tracking-widest text-white">Recapitulatif</h2>
</div>
<div class="p-6">
<p class="font-black uppercase text-sm tracking-widest mb-4">{{ order.event.title }}</p>
{% for item in order.items %}
<div class="flex justify-between py-2 {{ not loop.last ? 'border-b border-gray-200' : '' }}">
<div>
<p class="font-bold text-sm">{{ item.billetName }}</p>
<p class="text-xs text-gray-400 font-bold">x{{ item.quantity }}{{ item.unitPriceHTDecimal|number_format(2, ',', ' ') }} &euro;/u</p>
</div>
<p class="font-black text-sm text-indigo-600">{{ item.lineTotalHTDecimal|number_format(2, ',', ' ') }} &euro;</p>
</div>
{% endfor %}
<div class="flex justify-between pt-4 mt-4 border-t-2 border-gray-900">
<span class="font-black uppercase text-sm">Total HT</span>
<span class="font-black text-lg text-indigo-600">{{ order.totalHTDecimal|number_format(2, ',', ' ') }} &euro;</span>
</div>
<p class="text-[10px] font-bold text-gray-400 mt-2">Ref: {{ order.reference }}</p>
</div>
</div>