- Surface "X/Y passende Wohnungen mit Koordinaten" on the Karte view +
admin-only "Koordinaten nachladen" button (POST /actions/backfill-coords)
that geocodes missing flats via Google Maps directly from the web container
- Add googlemaps dep + GMAPS_API_KEY env to web service
- Light console.log in map.js ("rendering N/M markers", "building Leaflet…")
so the browser DevTools shows what's happening
- Drop e-mail channel from notifications UI, notify dispatcher, and _alert_status;
coerce legacy 'email' channel rows back to 'ui' on save
- Countdown said "Aktualisierung läuft…" next to "nächste Aktualisierung" →
shortened to "aktualisiere…"
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
44 lines
2.1 KiB
HTML
44 lines
2.1 KiB
HTML
<h2 class="font-semibold mb-2">Benachrichtigungen</h2>
|
|
<p class="text-sm text-slate-600 mb-4">
|
|
Wähle einen Kanal und entscheide, welche Events dich erreichen sollen.
|
|
</p>
|
|
|
|
<form method="post" action="/actions/notifications" class="space-y-4 max-w-xl">
|
|
<input type="hidden" name="csrf" value="{{ csrf }}">
|
|
|
|
<div>
|
|
<label class="block text-xs uppercase text-slate-500 mb-1">Kanal</label>
|
|
<select class="input" name="channel">
|
|
<option value="ui" {% if notifications.channel == 'ui' %}selected{% endif %}>Nur im Dashboard (kein Push)</option>
|
|
<option value="telegram" {% if notifications.channel == 'telegram' %}selected{% endif %}>Telegram</option>
|
|
</select>
|
|
</div>
|
|
|
|
<div>
|
|
<label class="block text-xs uppercase text-slate-500 mb-1">Telegram Bot-Token</label>
|
|
<input class="input" name="telegram_bot_token" value="{{ notifications.telegram_bot_token }}"
|
|
placeholder="123456:ABC...">
|
|
<p class="text-xs text-slate-500 mt-1">Bot bei @BotFather anlegen, Token hier eintragen.</p>
|
|
</div>
|
|
<div>
|
|
<label class="block text-xs uppercase text-slate-500 mb-1">Telegram Chat-ID</label>
|
|
<input class="input" name="telegram_chat_id" value="{{ notifications.telegram_chat_id }}" placeholder="987654321">
|
|
</div>
|
|
|
|
<div class="border-t border-soft pt-4 space-y-2">
|
|
<label class="flex items-center gap-2">
|
|
<input type="checkbox" name="notify_on_match" {% if notifications.notify_on_match %}checked{% endif %}>
|
|
<span>Bei passender Wohnung</span>
|
|
</label>
|
|
<label class="flex items-center gap-2">
|
|
<input type="checkbox" name="notify_on_apply_success" {% if notifications.notify_on_apply_success %}checked{% endif %}>
|
|
<span>Bei erfolgreicher Bewerbung</span>
|
|
</label>
|
|
<label class="flex items-center gap-2">
|
|
<input type="checkbox" name="notify_on_apply_fail" {% if notifications.notify_on_apply_fail %}checked{% endif %}>
|
|
<span>Bei fehlgeschlagener Bewerbung</span>
|
|
</label>
|
|
</div>
|
|
|
|
<button class="btn btn-primary" type="submit">Speichern</button>
|
|
</form>
|