Files
food-ai/client/lib/l10n/app_localizations_fr.dart
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

329 lines
6.5 KiB
Dart

// ignore: unused_import
import 'package:intl/intl.dart' as intl;
import 'app_localizations.dart';
// ignore_for_file: type=lint
/// The translations for French (`fr`).
class AppLocalizationsFr extends AppLocalizations {
AppLocalizationsFr([String locale = 'fr']) : super(locale);
@override
String get appTitle => 'FoodAI';
@override
String get greetingMorning => 'Bonjour';
@override
String get greetingAfternoon => 'Bon après-midi';
@override
String get greetingEvening => 'Bonsoir';
@override
String get caloriesUnit => 'kcal';
@override
String get gramsUnit => 'g';
@override
String get goalLabel => 'objectif :';
@override
String get consumed => 'Consommé';
@override
String get remaining => 'Restant';
@override
String get exceeded => 'Dépassé';
@override
String get proteinLabel => 'Protéines';
@override
String get fatLabel => 'Lipides';
@override
String get carbsLabel => 'Glucides';
@override
String get today => 'Aujourd\'hui';
@override
String get yesterday => 'Hier';
@override
String get mealsSection => 'Repas';
@override
String get addDish => 'Ajouter un plat';
@override
String get scanDish => 'Scanner';
@override
String get menu => 'Menu';
@override
String get dishHistory => 'Historique des plats';
@override
String get recommendCook => 'Nous recommandons de cuisiner';
@override
String get camera => 'Appareil photo';
@override
String get gallery => 'Galerie';
@override
String get analyzingPhoto => 'Analyse de la photo...';
@override
String get inQueue => 'Vous êtes en file d\'attente';
@override
String queuePosition(int position) {
return 'Position $position';
}
@override
String get processing => 'Traitement...';
@override
String get upgradePrompt => 'Passer la file ? Passez à Premium →';
@override
String get recognitionFailed => 'Reconnaissance échouée. Réessayez.';
@override
String get dishRecognition => 'Reconnaissance de plats';
@override
String get all => 'Tous';
@override
String get dishRecognized => 'Plat reconnu';
@override
String get recognizing => 'Reconnaissance en cours…';
@override
String get recognitionError => 'Erreur de reconnaissance';
@override
String get dishResultTitle => 'Plat reconnu';
@override
String get selectDish => 'Sélectionner un plat';
@override
String get dishNotRecognized => 'Plat non reconnu';
@override
String get tryAgain => 'Réessayer';
@override
String get nutritionApproximate =>
'Les valeurs nutritionnelles sont approximatives — estimées à partir de la photo.';
@override
String get portion => 'Portion';
@override
String get mealType => 'Type de repas';
@override
String get dateLabel => 'Date';
@override
String get addToJournal => 'Ajouter au journal';
@override
String get addFailed => 'Échec de l\'ajout. Réessayez.';
@override
String get historyTitle => 'Historique des reconnaissances';
@override
String get historyLoadError => 'Impossible de charger l\'historique';
@override
String get retry => 'Réessayer';
@override
String get noHistory => 'Aucune reconnaissance pour l\'instant';
@override
String get profileTitle => 'Profil';
@override
String get edit => 'Modifier';
@override
String get bodyParams => 'PARAMÈTRES CORPORELS';
@override
String get goalActivity => 'OBJECTIF & ACTIVITÉ';
@override
String get nutrition => 'NUTRITION';
@override
String get settings => 'PARAMÈTRES';
@override
String get height => 'Taille';
@override
String get weight => 'Poids';
@override
String get age => 'Âge';
@override
String get gender => 'Sexe';
@override
String get genderMale => 'Masculin';
@override
String get genderFemale => 'Féminin';
@override
String get goalLoss => 'Perte de poids';
@override
String get goalMaintain => 'Maintien';
@override
String get goalGain => 'Prise de masse';
@override
String get activityLow => 'Faible';
@override
String get activityMedium => 'Moyenne';
@override
String get activityHigh => 'Élevée';
@override
String get calorieGoal => 'Objectif calorique';
@override
String get mealTypes => 'Types de repas';
@override
String get formulaNote => 'Calculé avec la formule de Mifflin-St Jeor';
@override
String get language => 'Langue';
@override
String get notSet => 'Non défini';
@override
String get calorieHint =>
'Saisissez les paramètres corporels pour calculer l\'objectif calorique';
@override
String get logout => 'Se déconnecter';
@override
String get editProfile => 'Modifier le profil';
@override
String get cancel => 'Annuler';
@override
String get save => 'Enregistrer';
@override
String get nameLabel => 'Nom';
@override
String get heightCm => 'Taille (cm)';
@override
String get weightKg => 'Poids (kg)';
@override
String get birthDate => 'Date de naissance';
@override
String get nameRequired => 'Saisir le nom';
@override
String get profileUpdated => 'Profil mis à jour';
@override
String get profileSaveFailed => 'Échec de l\'enregistrement';
@override
String get mealTypeBreakfast => 'Petit-déjeuner';
@override
String get mealTypeSecondBreakfast => 'Deuxième petit-déjeuner';
@override
String get mealTypeLunch => 'Déjeuner';
@override
String get mealTypeAfternoonSnack => 'Goûter';
@override
String get mealTypeDinner => 'Dîner';
@override
String get mealTypeSnack => 'Collation';
@override
String get navHome => 'Accueil';
@override
String get navProducts => 'Produits';
@override
String get navRecipes => 'Recettes';
@override
String get addFromReceiptOrPhoto => 'Ajouter depuis ticket ou photo';
@override
String get chooseMethod => 'Choisir la méthode';
@override
String get photoReceipt => 'Photographier le ticket';
@override
String get photoReceiptSubtitle =>
'Reconnaissance de tous les produits du ticket';
@override
String get photoProducts => 'Photographier les produits';
@override
String get photoProductsSubtitle =>
'Réfrigérateur, table, étagère — jusqu\'à 3 photos';
@override
String get addPackagedFood => 'Ajouter un aliment emballé';
@override
String get scanBarcode => 'Scanner le code-barres';
@override
String get portionWeightG => 'Poids de la portion (g)';
@override
String get productNotFound => 'Produit introuvable';
@override
String get enterManually => 'Saisir manuellement';
@override
String get perHundredG => 'pour 100 g';
}