201 lines
8.0 KiB
HTML
Executable File
201 lines
8.0 KiB
HTML
Executable File
{% extends "admin/base.html" %}
|
|
{% block title %}Buchung: {{ booking.booking_number }}{% endblock %}
|
|
|
|
{% block content %}
|
|
<div class="d-flex justify-content-between align-items-center mb-4">
|
|
<div>
|
|
<nav aria-label="breadcrumb">
|
|
<ol class="breadcrumb mb-2">
|
|
<li class="breadcrumb-item"><a href="{{ url_for('admin.bookings') }}" class="text-info">Buchungen</a></li>
|
|
<li class="breadcrumb-item active">{{ booking.booking_number or 'Details' }}</li>
|
|
</ol>
|
|
</nav>
|
|
<h1><i class="bi bi-calendar-check me-2"></i>{{ booking.booking_number or 'Buchung #' ~ booking.id }}</h1>
|
|
</div>
|
|
<div>
|
|
<span class="badge bg-{{ booking.status_color }} fs-6 me-2">{{ booking.status_display }}</span>
|
|
<a href="{{ url_for('admin.bookings') }}" class="btn btn-outline-secondary">
|
|
<i class="bi bi-arrow-left me-1"></i>Zurueck
|
|
</a>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="row g-4">
|
|
<!-- Buchungsdetails -->
|
|
<div class="col-lg-6">
|
|
<div class="card h-100">
|
|
<div class="card-header">
|
|
<i class="bi bi-info-circle me-2"></i>Buchungsdetails
|
|
</div>
|
|
<div class="card-body">
|
|
<table class="table table-dark table-borderless mb-0">
|
|
<tr>
|
|
<td class="text-muted" style="width: 140px;">Buchungsnummer</td>
|
|
<td><strong>{{ booking.booking_number or '-' }}</strong></td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-muted">WordPress ID</td>
|
|
<td>#{{ booking.wp_booking_id }}</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-muted">Status</td>
|
|
<td><span class="badge bg-{{ booking.status_color }}">{{ booking.status_display }}</span></td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-muted">Gesamtpreis</td>
|
|
<td><strong>{{ booking.formatted_price }}</strong></td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-muted">Ticket-Typ</td>
|
|
<td>{{ booking.ticket_type or '-' }}</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-muted">Anzahl</td>
|
|
<td>{{ booking.ticket_count or 1 }}</td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Kunde -->
|
|
<div class="col-lg-6">
|
|
<div class="card h-100">
|
|
<div class="card-header">
|
|
<i class="bi bi-person me-2"></i>Kunde
|
|
</div>
|
|
<div class="card-body">
|
|
<table class="table table-dark table-borderless mb-0">
|
|
<tr>
|
|
<td class="text-muted" style="width: 140px;">Name</td>
|
|
<td>
|
|
<a href="{{ url_for('admin.customer_detail', customer_id=booking.customer_id) }}" class="text-info">
|
|
{{ booking.customer.display_name }}
|
|
</a>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-muted">E-Mail</td>
|
|
<td>
|
|
<a href="mailto:{{ booking.customer.email }}" class="text-info">{{ booking.customer.email }}</a>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-muted">Telefon</td>
|
|
<td>{{ booking.customer_phone or booking.customer.display_phone or '-' }}</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-muted">Name bei Buchung</td>
|
|
<td>{{ booking.customer_name or '-' }}</td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Kurs-Informationen -->
|
|
<div class="col-lg-6">
|
|
<div class="card h-100">
|
|
<div class="card-header">
|
|
<i class="bi bi-mortarboard me-2"></i>Kurs
|
|
</div>
|
|
<div class="card-body">
|
|
<table class="table table-dark table-borderless mb-0">
|
|
<tr>
|
|
<td class="text-muted" style="width: 140px;">Titel</td>
|
|
<td><strong>{{ booking.kurs_title or '-' }}</strong></td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-muted">WordPress Kurs-ID</td>
|
|
<td>#{{ booking.wp_kurs_id or '-' }}</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-muted">Datum</td>
|
|
<td>{{ booking.formatted_date }}</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-muted">Uhrzeit</td>
|
|
<td>{{ booking.formatted_time }}</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-muted">Ort</td>
|
|
<td>{{ booking.kurs_location or '-' }}</td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- sevDesk Integration -->
|
|
<div class="col-lg-6">
|
|
<div class="card h-100">
|
|
<div class="card-header">
|
|
<i class="bi bi-receipt me-2"></i>sevDesk Rechnung
|
|
</div>
|
|
<div class="card-body">
|
|
{% if booking.sevdesk_invoice_id %}
|
|
<table class="table table-dark table-borderless mb-0">
|
|
<tr>
|
|
<td class="text-muted" style="width: 140px;">Rechnungsnummer</td>
|
|
<td><strong>{{ booking.sevdesk_invoice_number or '-' }}</strong></td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-muted">sevDesk ID</td>
|
|
<td>#{{ booking.sevdesk_invoice_id }}</td>
|
|
</tr>
|
|
</table>
|
|
{% else %}
|
|
<p class="text-muted mb-0">Keine Rechnung verknuepft.</p>
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Timestamps -->
|
|
<div class="col-lg-6">
|
|
<div class="card h-100">
|
|
<div class="card-header">
|
|
<i class="bi bi-clock me-2"></i>Zeitstempel
|
|
</div>
|
|
<div class="card-body">
|
|
<table class="table table-dark table-borderless mb-0">
|
|
<tr>
|
|
<td class="text-muted" style="width: 160px;">Erstellt (WordPress)</td>
|
|
<td>{{ booking.wp_created_at.strftime('%d.%m.%Y um %H:%M') if booking.wp_created_at else '-' }}</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-muted">Importiert</td>
|
|
<td>{{ booking.created_at.strftime('%d.%m.%Y um %H:%M') if booking.created_at else '-' }}</td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-muted">Letzter Sync</td>
|
|
<td>{{ booking.synced_at.strftime('%d.%m.%Y um %H:%M') if booking.synced_at else '-' }}</td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Custom Fields -->
|
|
{% if booking.custom_fields %}
|
|
<div class="col-lg-6">
|
|
<div class="card h-100">
|
|
<div class="card-header">
|
|
<i class="bi bi-list-ul me-2"></i>Zusatzfelder
|
|
</div>
|
|
<div class="card-body">
|
|
<table class="table table-dark table-borderless table-sm mb-0">
|
|
{% for key, value in booking.custom_fields.items() %}
|
|
<tr>
|
|
<td class="text-muted" style="width: 280px; white-space: nowrap;">{{ key }}</td>
|
|
<td>{{ value }}</td>
|
|
</tr>
|
|
{% endfor %}
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endif %}
|
|
</div>
|
|
{% endblock %}
|