172 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			172 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
{# templates/zbiorka_form.html #}
 | 
						|
{% extends 'base.html' %}
 | 
						|
 | 
						|
{% set is_edit = zbiorka is not none %}
 | 
						|
 | 
						|
{% block title %}{{ 'Edytuj zbiórkę' if is_edit else 'Dodaj 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 / powrót -->
 | 
						|
    <div class="d-flex align-items-center gap-2 mb-3">
 | 
						|
        {% if is_edit %}
 | 
						|
        <a href="{{ url_for('zbiorka', zbiorka_id=zbiorka.id) }}" class="btn btn-sm btn-outline-light border">←
 | 
						|
            Szczegóły zbiórki</a>
 | 
						|
        {% else %}
 | 
						|
        <a href="{{ url_for('admin_dashboard') }}" class="btn btn-sm btn-outline-light border">← Panel Admina</a>
 | 
						|
        {% endif %}
 | 
						|
    </div>
 | 
						|
 | 
						|
    <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ę' if is_edit else 'Dodaj nową zbiórkę' }}
 | 
						|
            </h3>
 | 
						|
 | 
						|
            {% if is_edit %}
 | 
						|
            <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>
 | 
						|
            {% else %}
 | 
						|
            <small class="opacity-75">Uzupełnij podstawowe dane i dane płatności</small>
 | 
						|
            {% endif %}
 | 
						|
        </div>
 | 
						|
 | 
						|
        <div class="card-body">
 | 
						|
            <form method="post" novalidate id="{{ 'form-edit-zbiorka' if is_edit else 'form-add-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" maxlength="120"
 | 
						|
                                placeholder="{{ 'Krótki, zrozumiały tytuł' if is_edit else 'Np. Wsparcie dla schroniska Azor' }}"
 | 
						|
                                value="{{ zbiorka.nazwa if is_edit else '' }}" required aria-describedby="nazwaHelp">
 | 
						|
                            <div id="nazwaHelp" class="form-text">Krótki, zrozumiały tytuł. Max 120 znakó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 if is_edit else '' }}</textarea>
 | 
						|
                            <div class="d-flex justify-content-between">
 | 
						|
                                <small id="opisHelp" class="form-text text-muted">
 | 
						|
                                    Możesz używać **Markdown** (nagłówki, listy, linki). W edytorze włącz podgląd 👁️.
 | 
						|
                                </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"
 | 
						|
                                    inputmode="numeric" autocomplete="off"
 | 
						|
                                    placeholder="12 3456 7890 1234 5678 9012 3456" required aria-describedby="ibanHelp"
 | 
						|
                                    value="{% if is_edit and zbiorka.numer_konta %}{{ zbiorka.numer_konta }}{% elif global_settings %}{{ global_settings.numer_konta }}{% else %}{% endif %}">
 | 
						|
                            </div>
 | 
						|
                            <div id="ibanHelp" class="form-text">
 | 
						|
                                Wpisz ciąg cyfr; spacje dodadzą się automatycznie dla czytelności.
 | 
						|
                            </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" inputmode="tel" pattern="[0-9 ]{9,13}"
 | 
						|
                                    placeholder="123 456 789" required aria-describedby="blikHelp"
 | 
						|
                                    value="{% if is_edit and zbiorka.numer_telefonu_blik %}{{ zbiorka.numer_telefonu_blik }}{% elif global_settings %}{{ global_settings.numer_telefonu_blik }}{% else %}{% endif %}">
 | 
						|
                            </div>
 | 
						|
                            <div id="blikHelp" class="form-text">Dziewięć cyfr telefonu powiązanego z BLIK. Spacje
 | 
						|
                                opcjonalne.</div>
 | 
						|
                        </div>
 | 
						|
 | 
						|
                        {% if is_edit %}
 | 
						|
                        <div class="col-12 col-md-12 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 %}>Wstaw
 | 
						|
                                globalne ustawienia</button>
 | 
						|
                        </div>
 | 
						|
                        {% endif %}
 | 
						|
                    </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"
 | 
						|
                                    placeholder="0,00" required aria-describedby="celHelp"
 | 
						|
                                    value="{{ zbiorka.cel if is_edit else '' }}">
 | 
						|
                            </div>
 | 
						|
                            <div id="celHelp" class="form-text">Minimalnie 0,01 PLN. Możesz to później edytować.</div>
 | 
						|
                        </div>
 | 
						|
 | 
						|
                        <div class="col-12 col-md-12 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 is_edit and zbiorka.ukryj_kwote %}checked{% endif %}>
 | 
						|
                                <label class="form-check-label" for="ukryj_kwote">Ukryj kwoty (cel i stan)</label>
 | 
						|
                            </div>
 | 
						|
                        </div>
 | 
						|
                    </div>
 | 
						|
                </div>
 | 
						|
 | 
						|
                <!-- CTA -->
 | 
						|
                <div class="d-flex flex-wrap gap-2">
 | 
						|
                    <button type="submit" class="btn btn-success">
 | 
						|
                        {{ ' Zaktualizuj zbiórkę' if is_edit else 'Dodaj zbiórkę' }} </button>
 | 
						|
 | 
						|
                    <a href="{{ url_for('admin_dashboard') }}" class="btn btn-outline-light border">Anuluj</a>
 | 
						|
 | 
						|
                </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/formularz_zbiorek.js') }}"></script>
 | 
						|
{% endblock %} |