Prepare the UI for English (default/fallback) and German with auto or manual locale selection, and report import issues with client-translated warnings instead of failing on minor save format changes. Co-authored-by: Cursor <cursoragent@cursor.com>
Idle Fantasy Save Viewer
Lokaler Web-Viewer für Backups des Android-Spiels Idle Fantasy. Parst fantasyidler_save.json, zeigt Skills, Inventar, Quests und Kampfstatistiken in einem dunklen Dashboard – inklusive Filter, Item-Gruppierung und Verlaufsvergleich über SQLite.
Features
- Dashboard mit Charakter, Coins, Skills, Inventar, Ausrüstung, Quests und Kampf
- Inventar mit Textsuche, Kategorie-Filtern, Sortierung und gruppierten Tabellen
- SQLite-Verlauf – mehrere Backups importieren, Snapshots vergleichen, Coins-/Level-Charts
- Import per CLI oder Upload im Browser
- Läuft nur lokal (
127.0.0.1) - i18n – Englisch als Standard/Fallback, Deutsch optional; automatische Browser-Sprache oder manuelle Auswahl in der Sidebar
Voraussetzungen
- Python 3.11+
- Ein Idle-Fantasy-Backup (
fantasyidler_save.jsonvom Spielexport)
Installation
python -m venv .venv
.\.venv\Scripts\Activate.ps1
pip install -r requirements.txt
Nutzung
Server starten und Backup importieren
python app.py fantasyidler_save.json
Der Browser öffnet sich automatisch unter http://127.0.0.1:5000.
Weitere Optionen
# Nur importieren, kein Server
python app.py --import backup2.json
# Anderen Port, Browser nicht öffnen
python app.py fantasyidler_save.json --port 8080 --no-browser
# Eigene SQLite-Datenbank
python app.py --db data\meine_history.db fantasyidler_save.json
Backups im Browser importieren
Im Tab Inventar (Sidebar unten): Backup importieren – wählt eine .json-Datei. Duplikate (gleicher Datei-Hash) werden übersprungen.
Sprache / i18n
- Standard: Englisch (
en) – auch Fallback, wenn ein Übersetzungsschlüssel fehlt - Automatisch: Sidebar → Sprache → Automatisch (Browser) – nutzt
navigator.language(de→ Deutsch, sonst Englisch) - Manuell: English oder Deutsch – Einstellung wird in
localStoragegespeichert - Übersetzungsdateien:
static/locales/en.json,static/locales/de.json - Import-Warnungen vom Server sind auf Englisch codiert (
code+params); die UI übersetzt sie clientseitig
Projektstruktur
idle-fantasy-viewer/
├── app.py # Flask-Server und CLI
├── parser.py # Save parsen und normalisieren
├── categories.py # Item-Kategorien (Heuristiken)
├── db.py # SQLite Snapshots, Diff, Timeline
├── requirements.txt
├── static/
│ ├── i18n.js # Locale-Laden, t(), Fallback en
│ ├── locales/ # en.json, de.json
│ └── app.js # Dashboard-UI
├── templates/ # HTML
└── data/ # history.db (wird angelegt, gitignored)
API (lokal)
| Endpunkt | Beschreibung |
|---|---|
GET / |
Dashboard |
GET /api/snapshot/latest |
Neuester normalisierter Save |
GET /api/snapshots |
Alle Snapshots |
GET /api/snapshots/<älter>/diff/<neuer> |
Vergleich zweier Backups |
GET /api/timeline |
Zeitreihe für Charts |
POST /api/import |
JSON-Upload oder {"path": "..."} |
Save-Format
Die Backup-Datei enthält u. a. doppelt JSON-kodierte Felder (skillLevels, inventory, flags, …). Der Parser löst diese automatisch auf.
Hinweise
data/history.dbspeichert importierte Snapshots lokal; nicht mit ins Repo committen (steht in.gitignore).- Der Viewer ist ein inoffizielles Hilfstool, nicht mit dem Spiel verbunden.
Robustheit bei Spiel-Updates
Das Spiel wird aktiv weiterentwickelt – Save-Dateien können neue Felder, Items oder Quest-Typen enthalten. Der Viewer:
- Parst tolerant: unbekannte Top-Level-Felder werden in
extensionsdurchgereicht und als Info gemeldet - Überspringt defekte Einträge (z. B. einzelne Quests/Sessions) statt abzubrechen
- Meldet Warnungen bei fehlenden Kernfeldern, nicht lesbarem JSON in verschachtelten Feldern oder ungültigen Zahlen
- Blockiert den Import nur bei schwerwiegenden Problemen (keine gültige JSON-Datei, leeres Objekt)
Nach dem Import erscheinen Fehler und Warnungen als Banner im Dashboard; in der CLI unter stderr.
Lizenz
Privates Projekt – Nutzung auf eigene Verantwortung.