Files
food-ai/client/lib/l10n/app_de.arb
dbastrikin 205edbdade feat: rename ingredients→products, products→user_products; add barcode/OFF import
- Rename catalog: ingredient/* → product/* (canonical_name, barcode, nutrition per 100g)
- Rename pantry: product/* → userproduct/* (user-owned items with expiry)
- Squash migrations into single 001_initial_schema.sql (clean-db baseline)
- product_categories: add English canonical name column; fix COALESCE in queries
- Remove product_translations: product names are stored in their original language
- Add default_unit_name to product API responses via unit_translations JOIN
- Add cmd/importoff: bulk import from OpenFoodFacts JSONL dump (COPY + ON CONFLICT)
- Diary: support product_id entries alongside dish_id (CHECK num_nonnulls = 1)
- Home: getLoggedCalories joins both recipes and catalog products
- Flutter: rename models/providers/services to match backend rename
- Flutter: add barcode scan flow for diary (mobile_scanner, product_portion_sheet)
- Flutter: localise 6 new keys across 12 languages (barcode scan, portion weight)
- Routes: GET /products/search, GET /products/barcode/{barcode}, /user-products

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-03-21 12:45:48 +02:00

115 lines
3.8 KiB
Plaintext

{
"@@locale": "de",
"appTitle": "FoodAI",
"greetingMorning": "Guten Morgen",
"greetingAfternoon": "Guten Tag",
"greetingEvening": "Guten Abend",
"caloriesUnit": "kcal",
"gramsUnit": "g",
"goalLabel": "Ziel:",
"consumed": "Verzehrt",
"remaining": "Verbleibend",
"exceeded": "Überschritten",
"proteinLabel": "Protein",
"fatLabel": "Fett",
"carbsLabel": "Kohlenhydrate",
"today": "Heute",
"yesterday": "Gestern",
"mealsSection": "Mahlzeiten",
"addDish": "Gericht hinzufügen",
"scanDish": "Scannen",
"menu": "Menü",
"dishHistory": "Gerichtverlauf",
"recommendCook": "Wir empfehlen zu kochen",
"camera": "Kamera",
"gallery": "Galerie",
"analyzingPhoto": "Foto wird analysiert...",
"inQueue": "Sie sind in der Warteschlange",
"queuePosition": "Position {position}",
"@queuePosition": {
"placeholders": {
"position": {
"type": "int"
}
}
},
"processing": "Verarbeitung...",
"upgradePrompt": "Warteschlange überspringen? Upgrade →",
"recognitionFailed": "Erkennung fehlgeschlagen. Erneut versuchen.",
"dishRecognition": "Gerichterkennung",
"all": "Alle",
"dishRecognized": "Gericht erkannt",
"recognizing": "Wird erkannt…",
"recognitionError": "Erkennungsfehler",
"dishResultTitle": "Gericht erkannt",
"selectDish": "Gericht auswählen",
"dishNotRecognized": "Gericht nicht erkannt",
"tryAgain": "Erneut versuchen",
"nutritionApproximate": "Nährwerte sind ungefähr — aus dem Foto geschätzt.",
"portion": "Portion",
"mealType": "Mahlzeittyp",
"dateLabel": "Datum",
"addToJournal": "Zum Tagebuch hinzufügen",
"addFailed": "Hinzufügen fehlgeschlagen. Erneut versuchen.",
"historyTitle": "Erkennungsverlauf",
"historyLoadError": "Verlauf konnte nicht geladen werden",
"retry": "Wiederholen",
"noHistory": "Noch keine Erkennungen",
"profileTitle": "Profil",
"edit": "Bearbeiten",
"bodyParams": "KÖRPERPARAMETER",
"goalActivity": "ZIEL & AKTIVITÄT",
"nutrition": "ERNÄHRUNG",
"settings": "EINSTELLUNGEN",
"height": "Größe",
"weight": "Gewicht",
"age": "Alter",
"gender": "Geschlecht",
"genderMale": "Männlich",
"genderFemale": "Weiblich",
"goalLoss": "Gewichtsverlust",
"goalMaintain": "Gewicht halten",
"goalGain": "Muskelaufbau",
"activityLow": "Niedrig",
"activityMedium": "Mittel",
"activityHigh": "Hoch",
"calorieGoal": "Kalorienziel",
"mealTypes": "Mahlzeittypen",
"formulaNote": "Berechnet mit der Mifflin-St Jeor Formel",
"language": "Sprache",
"notSet": "Nicht festgelegt",
"calorieHint": "Körperparameter eingeben, um das Kalorienziel zu berechnen",
"logout": "Abmelden",
"editProfile": "Profil bearbeiten",
"cancel": "Abbrechen",
"save": "Speichern",
"nameLabel": "Name",
"heightCm": "Größe (cm)",
"weightKg": "Gewicht (kg)",
"birthDate": "Geburtsdatum",
"nameRequired": "Name eingeben",
"profileUpdated": "Profil aktualisiert",
"profileSaveFailed": "Speichern fehlgeschlagen",
"mealTypeBreakfast": "Frühstück",
"mealTypeSecondBreakfast": "Zweites Frühstück",
"mealTypeLunch": "Mittagessen",
"mealTypeAfternoonSnack": "Nachmittagssnack",
"mealTypeDinner": "Abendessen",
"mealTypeSnack": "Snack",
"navHome": "Startseite",
"navProducts": "Produkte",
"navRecipes": "Rezepte",
"addFromReceiptOrPhoto": "Aus Kassenbon oder Foto hinzufügen",
"chooseMethod": "Methode wählen",
"photoReceipt": "Kassenbon fotografieren",
"photoReceiptSubtitle": "Alle Produkte vom Kassenbon erkennen",
"photoProducts": "Produkte fotografieren",
"photoProductsSubtitle": "Kühlschrank, Tisch, Regal — bis zu 3 Fotos",
"addPackagedFood": "Verpacktes Lebensmittel hinzufügen",
"scanBarcode": "Barcode scannen",
"portionWeightG": "Portionsgewicht (g)",
"productNotFound": "Produkt nicht gefunden",
"enterManually": "Manuell eingeben",
"perHundredG": "pro 100 g"
}