154 lines
7.1 KiB
HTML
154 lines
7.1 KiB
HTML
{% extends 'base.html' %}
|
|
{% block title %}Edytuj zbiórkę{% endblock %}
|
|
|
|
{% block extra_head %}
|
|
{{ super() }}
|
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/simplemde/latest/simplemde.min.css">
|
|
{% endblock %}
|
|
|
|
{% block content %}
|
|
<div class="container my-4">
|
|
|
|
<!-- Nawigacja -->
|
|
<div class="d-flex align-items-center gap-2 mb-3">
|
|
<a href="{{ url_for('zbiorka', zbiorka_id=zbiorka.id) }}" class="btn btn-sm btn-outline-light border">← Szczegóły
|
|
zbiórki</a>
|
|
<a href="{{ url_for('admin_dashboard') }}" class="btn btn-sm btn-outline-light border">← Panel Admina</a>
|
|
</div>
|
|
|
|
<!-- Nagłówek + meta -->
|
|
<div class="card shadow-sm">
|
|
<div class="card-header bg-secondary text-white d-flex flex-wrap align-items-center justify-content-between gap-2">
|
|
<h3 class="card-title mb-0">Edytuj zbiórkę</h3>
|
|
<div class="d-flex flex-wrap align-items-center gap-2">
|
|
{% if zbiorka.cel %}
|
|
<span class="badge bg-dark border" style="border-color: var(--border);">Cel: {{ zbiorka.cel|round(2) }}
|
|
PLN</span>
|
|
{% endif %}
|
|
{% if zbiorka.ukryj_kwote %}
|
|
<span class="badge bg-secondary">Kwoty ukryte</span>
|
|
{% else %}
|
|
<span class="badge bg-success">Kwoty widoczne</span>
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
|
|
<div class="card-body">
|
|
<!-- GŁÓWNY FORMULARZ -->
|
|
<form method="post" novalidate id="form-edit-zbiorka">
|
|
{# {{ form.csrf_token }} jeśli używasz Flask-WTF #}
|
|
|
|
<!-- SEKCJA: Podstawowe -->
|
|
<div class="mb-4">
|
|
<h6 class="text-muted mb-2">Podstawowe</h6>
|
|
<div class="row g-3">
|
|
<div class="col-12">
|
|
<label for="nazwa" class="form-label">Nazwa zbiórki</label>
|
|
<input type="text" class="form-control" id="nazwa" name="nazwa" value="{{ zbiorka.nazwa }}"
|
|
maxlength="120" placeholder="Krótki, zrozumiały tytuł" required aria-describedby="nazwaHelp">
|
|
<div id="nazwaHelp" class="form-text">Max 120 znaków. Użyj konkretów.</div>
|
|
</div>
|
|
|
|
<div class="col-12">
|
|
<label for="opis" class="form-label">Opis (Markdown)</label>
|
|
<textarea class="form-control" id="opis" name="opis" rows="8" required
|
|
aria-describedby="opisHelp">{{ zbiorka.opis }}</textarea>
|
|
<div class="d-flex justify-content-between">
|
|
<small id="opisHelp" class="form-text text-muted">Wspieramy **Markdown** — użyj nagłówków, list, linków.
|
|
Włącz podgląd w edytorze 👁️.</small>
|
|
<small class="text-muted"><span id="opisCount">0</span> znaków</small>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<hr class="my-4" />
|
|
|
|
<!-- SEKCJA: Dane płatności -->
|
|
<div class="mb-4">
|
|
<h6 class="text-muted mb-2">Dane płatności</h6>
|
|
<div class="row g-3">
|
|
<div class="col-12">
|
|
<label for="numer_konta" class="form-label">Numer konta (IBAN)</label>
|
|
<div class="input-group">
|
|
<span class="input-group-text">PL</span>
|
|
<input type="text" class="form-control" id="numer_konta" name="numer_konta"
|
|
value="{{ zbiorka.numer_konta if zbiorka.numer_konta else (global_settings.numer_konta if global_settings else '') }}"
|
|
inputmode="numeric" autocomplete="off" placeholder="12 3456 7890 1234 5678 9012 3456" required
|
|
aria-describedby="ibanHelp">
|
|
</div>
|
|
<div id="ibanHelp" class="form-text">Wpisz same cyfry — spacje dodadzą się automatycznie co 4 znaki.</div>
|
|
</div>
|
|
|
|
<div class="col-12 col-md-6">
|
|
<label for="numer_telefonu_blik" class="form-label">Numer telefonu BLIK</label>
|
|
<div class="input-group">
|
|
<span class="input-group-text">+48</span>
|
|
<input type="tel" class="form-control" id="numer_telefonu_blik" name="numer_telefonu_blik"
|
|
value="{{ zbiorka.numer_telefonu_blik if zbiorka.numer_telefonu_blik else (global_settings.numer_telefonu_blik if global_settings else '') }}"
|
|
inputmode="tel" pattern="[0-9 ]{9,13}" placeholder="123 456 789" required aria-describedby="blikHelp">
|
|
</div>
|
|
<div id="blikHelp" class="form-text">9 cyfr. Spacje dodadzą się automatycznie (format 3-3-3).</div>
|
|
</div>
|
|
|
|
<div class="col-12 col-md-6 d-flex align-items-end">
|
|
<button type="button" class="btn btn-sm btn-outline-light border" id="ustaw-globalne"
|
|
title="Wstaw wartości z ustawień globalnych" {% if global_settings %}
|
|
data-iban="{{ global_settings.numer_konta }}" data-blik="{{ global_settings.numer_telefonu_blik }}" {%
|
|
endif %}>Ustaw globalne</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<hr class="my-4" />
|
|
|
|
<!-- SEKCJA: Cel i widoczność -->
|
|
<div class="mb-4">
|
|
<h6 class="text-muted mb-2">Cel i widoczność</h6>
|
|
<div class="row g-3">
|
|
<div class="col-12 col-md-6">
|
|
<label for="cel" class="form-label">Cel zbiórki</label>
|
|
<div class="input-group">
|
|
<span class="input-group-text">PLN</span>
|
|
<input type="number" class="form-control" id="cel" name="cel" step="0.01" min="0.01"
|
|
value="{{ zbiorka.cel }}" placeholder="0,00" required aria-describedby="celHelp">
|
|
</div>
|
|
<div id="celHelp" class="form-text">Minimalnie 0,01 PLN. W razie potrzeby zmienisz to później.</div>
|
|
</div>
|
|
|
|
<div class="col-12 col-md-6 d-flex align-items-end">
|
|
<div class="form-check form-switch">
|
|
<input class="form-check-input" type="checkbox" id="ukryj_kwote" name="ukryj_kwote" {% if
|
|
zbiorka.ukryj_kwote %}checked{% endif %}>
|
|
<label class="form-check-label" for="ukryj_kwote">Ukryj kwoty (cel i stan)</label>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- CTA: zapisz/anuluj + osobna akcja „zrealizowana” -->
|
|
<div class="d-flex flex-wrap gap-2">
|
|
<button type="submit" class="btn btn-success">Zaktualizuj zbiórkę</button>
|
|
<a href="{{ url_for('zbiorka', zbiorka_id=zbiorka.id) }}" class="btn btn-outline-light border">Anuluj</a>
|
|
|
|
<!-- Osobny formularz dla oznaczenia „zrealizowana” -->
|
|
<form action="{{ url_for('oznacz_zbiorka', zbiorka_id=zbiorka.id) }}" method="post" class="ms-auto">
|
|
<button type="submit" class="btn btn-outline-light"
|
|
onclick="return confirm('Oznaczyć zbiórkę jako zrealizowaną?');">
|
|
Oznacz jako zrealizowana
|
|
</button>
|
|
</form>
|
|
</div>
|
|
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endblock %}
|
|
|
|
{% block extra_scripts %}
|
|
{{ super() }}
|
|
<script src="https://cdn.jsdelivr.net/simplemde/latest/simplemde.min.js"></script>
|
|
<script src="{{ url_for('static', filename='js/mde_custom.js') }}"></script>
|
|
<script src="{{ url_for('static', filename='js/edytuj_zbiorke.js') }}"></script>
|
|
{% endblock %} |