82 lines
3.5 KiB
HTML
82 lines
3.5 KiB
HTML
{% extends "base.html" %}
|
|
{% block title %}Archiv | Nouri{% endblock %}
|
|
{% block content %}
|
|
<section class="page-intro">
|
|
<div>
|
|
<p class="eyebrow">Archiv</p>
|
|
<h1>Frühere Ideen bleiben greifbar</h1>
|
|
<p class="lead">Das Archiv ist ein Erinnerungsspeicher. Von hier aus lassen sich vertraute Dinge leicht wieder auf die Einkaufsliste setzen.</p>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="panel compact-form-panel">
|
|
<form method="get" class="filter-form">
|
|
<label class="wide">
|
|
Suche
|
|
<input type="text" name="q" value="{{ query }}" placeholder="Nach Namen suchen">
|
|
</label>
|
|
<label>
|
|
Bereich
|
|
<select name="kind">
|
|
{% for value, label in kind_options %}
|
|
<option value="{{ value }}" {% if selected_kind == value %}selected{% endif %}>{{ label }}</option>
|
|
{% endfor %}
|
|
</select>
|
|
</label>
|
|
<div class="filter-actions">
|
|
<button type="submit">Filtern</button>
|
|
<a class="ghost-button" href="{{ url_for('main.archive_view') }}">Zurücksetzen</a>
|
|
</div>
|
|
</form>
|
|
</section>
|
|
|
|
{% if items %}
|
|
<section class="card-grid">
|
|
{% for item in items %}
|
|
<article class="item-card">
|
|
<div class="item-media">
|
|
{% if item.photo_filename %}
|
|
<img src="{{ url_for('uploaded_file', filename=item.photo_filename) }}" alt="{{ item.name }}">
|
|
{% else %}
|
|
<div class="placeholder-tile">{{ item.name[:1] }}</div>
|
|
{% endif %}
|
|
</div>
|
|
<div class="item-body">
|
|
<h2>{{ item.name }}</h2>
|
|
<p class="muted">{{ item_kind_labels[item.kind] }}{% if item.category %} · {{ item.category }}{% endif %}</p>
|
|
{% if item.dayparts %}
|
|
<div class="chip-row">
|
|
{% for daypart in item.dayparts %}
|
|
<span class="chip">{{ daypart }}</span>
|
|
{% endfor %}
|
|
</div>
|
|
{% endif %}
|
|
{% if item.components %}
|
|
<p class="muted">Mit: {{ item.components|join(', ') }}</p>
|
|
{% endif %}
|
|
{% if item.note %}
|
|
<p>{{ item.note }}</p>
|
|
{% endif %}
|
|
</div>
|
|
<div class="item-actions">
|
|
<form method="post" action="{{ url_for('main.item_add_to_shopping', item_id=item.id) }}">
|
|
{{ csrf_input() }}
|
|
<button type="submit">Wieder einkaufen</button>
|
|
</form>
|
|
<a class="ghost-button" href="{{ url_for('main.planner_day', date=today.isoformat(), item_id=item.id, daypart_id=item.primary_daypart_id) }}">Im Tagesplan öffnen</a>
|
|
<form method="post" action="{{ url_for('main.item_restore', item_id=item.id) }}">
|
|
{{ csrf_input() }}
|
|
<button class="ghost-button" type="submit">Zur aktiven Liste</button>
|
|
</form>
|
|
</div>
|
|
</article>
|
|
{% endfor %}
|
|
</section>
|
|
{% else %}
|
|
<section class="panel empty-panel">
|
|
<h2>Keine passenden Archiv-Einträge</h2>
|
|
<p>Mit einer kurzen Suche findest du vertraute Dinge meist schnell wieder.</p>
|
|
</section>
|
|
{% endif %}
|
|
{% endblock %}
|