mirror of
https://github.com/koloideal/Casha.git
synced 2026-06-10 10:25:28 +03:00
update
This commit is contained in:
@@ -0,0 +1,140 @@
|
||||
enum AppLocale { en, ru }
|
||||
|
||||
class AppStrings {
|
||||
final AppLocale locale;
|
||||
|
||||
const AppStrings(this.locale);
|
||||
|
||||
bool get _ru => locale == AppLocale.ru;
|
||||
|
||||
// ── Dashboard ──
|
||||
String get appTitle => _ru ? 'Мои финансы' : 'My Finances';
|
||||
String get totalBalance => _ru ? 'ОБЩИЙ БАЛАНС' : 'TOTAL BALANCE';
|
||||
String get add => _ru ? 'Добавить' : 'Add';
|
||||
String get transactions => _ru ? 'Транзакции' : 'Transactions';
|
||||
String get searchHint => _ru ? 'Поиск транзакций...' : 'Search transactions...';
|
||||
String get filterAll => _ru ? 'Все' : 'All';
|
||||
String get filterIncome => _ru ? 'Доход' : 'Income';
|
||||
String get filterExpense => _ru ? 'Расход' : 'Expense';
|
||||
String get filterAllTime => _ru ? 'Всё время' : 'All Time';
|
||||
String get filterMonth => _ru ? 'Месяц' : 'Month';
|
||||
String get income => _ru ? 'Доход' : 'Income';
|
||||
String get expenses => _ru ? 'Расходы' : 'Expenses';
|
||||
String get monthlyBudget => _ru ? 'Бюджет на месяц' : 'Monthly Budget';
|
||||
String get spent => _ru ? 'Потрачено' : 'Spent';
|
||||
String get limit => _ru ? 'Лимит' : 'Limit';
|
||||
String get noTransactions => _ru ? 'Транзакции не найдены' : 'No transactions found';
|
||||
String get addFirstTx => _ru ? 'Нажмите + чтобы добавить первую транзакцию' : 'Tap + to add your first transaction';
|
||||
|
||||
// ── Add/Edit transaction screen ──
|
||||
String get addTransaction => _ru ? 'Новая транзакция' : 'Add Transaction';
|
||||
String get editTransaction => _ru ? 'Редактировать' : 'Edit Transaction';
|
||||
String get amount => _ru ? 'Сумма' : 'Amount';
|
||||
String get category => _ru ? 'Категория' : 'Category';
|
||||
String get note => _ru ? 'Заметка' : 'Note';
|
||||
String get date => _ru ? 'Дата' : 'Date';
|
||||
String get time => _ru ? 'Время' : 'Time';
|
||||
String get save => _ru ? 'Сохранить' : 'Save';
|
||||
String get delete => _ru ? 'Удалить' : 'Delete';
|
||||
String get cancel => _ru ? 'Отмена' : 'Cancel';
|
||||
String get typeIncome => _ru ? 'Доход' : 'Income';
|
||||
String get typeExpense => _ru ? 'Расход' : 'Expense';
|
||||
String get confirmDelete => _ru ? 'Удалить транзакцию?' : 'Delete transaction?';
|
||||
String get confirmDeleteBody => _ru ? 'Это действие нельзя отменить.' : 'This action cannot be undone.';
|
||||
String get saveChanges => _ru ? 'Сохранить изменения' : 'Save Changes';
|
||||
String get noteOptional => _ru ? 'Заметка (необязательно)' : 'Note (optional)';
|
||||
String get addNote => _ru ? 'Добавить заметку...' : 'Add a note...';
|
||||
|
||||
// ── Settings ──
|
||||
String get settings => _ru ? 'Настройки' : 'Settings';
|
||||
String get managePreferences => _ru ? 'Управление настройками' : 'Manage your preferences';
|
||||
String get appearance => _ru ? 'Внешний вид' : 'Appearance';
|
||||
String get theme => _ru ? 'Тема' : 'Theme';
|
||||
String get themeDark => _ru ? 'Тёмная' : 'Dark';
|
||||
String get themeLight => _ru ? 'Светлая' : 'Light';
|
||||
String get themeSystem => _ru ? 'Системная' : 'System';
|
||||
String get darkMode => _ru ? 'Тёмная тема' : 'Dark Mode';
|
||||
String get enabled => _ru ? 'Включено' : 'Enabled';
|
||||
String get disabled => _ru ? 'Выключено' : 'Disabled';
|
||||
String get hapticFeedback => _ru ? 'Тактильная отдача' : 'Haptic Feedback';
|
||||
String get vibrationOnInteractions => _ru ? 'Вибрация при взаимодействии' : 'Vibration on interactions';
|
||||
String get biometricLock => _ru ? 'Биометрическая блокировка' : 'Biometric Lock';
|
||||
String get requireFingerprint => _ru ? 'Требовать отпечаток при запуске' : 'Require fingerprint on app launch';
|
||||
String get currency => _ru ? 'Валюта' : 'Currency';
|
||||
String get amountFormat => _ru ? 'Формат суммы' : 'Amount Format';
|
||||
String get language => _ru ? 'Язык' : 'Language';
|
||||
String get langRu => _ru ? 'Русский' : 'Russian';
|
||||
String get langEn => _ru ? 'Английский' : 'English';
|
||||
String get budget => _ru ? 'Бюджет' : 'Budget';
|
||||
String get budgetHint => _ru ? 'Месячный лимит' : 'Monthly limit';
|
||||
String get budgetNone => _ru ? 'Не установлен' : 'Not set';
|
||||
String get monthlyBudgetSetting => _ru ? 'Месячный бюджет' : 'Monthly Budget';
|
||||
String get yourMonthlySpendingLimit => _ru ? 'Ваш месячный лимит расходов' : 'Your monthly spending limit';
|
||||
String get setMonthlySpendingLimit => _ru ? 'Установите месячный лимит расходов для отслеживания бюджета' : 'Set a monthly spending limit to track your budget';
|
||||
String get leaveEmptyToRemove => _ru ? 'Оставьте пустым для удаления лимита' : 'Leave empty to remove budget limit';
|
||||
String get data => _ru ? 'Данные' : 'Data';
|
||||
String get exportData => _ru ? 'Экспорт данных' : 'Export data';
|
||||
String get clearData => _ru ? 'Очистить данные' : 'Clear all data';
|
||||
String get clearAllTransactions => _ru ? 'Очистить все транзакции' : 'Clear All Transactions';
|
||||
String get clearDataConfirm => _ru ? 'Удалить все транзакции?' : 'Clear all transactions?';
|
||||
String get clearDataWarning => _ru ? 'Это навсегда удалит всю историю транзакций. Это действие нельзя отменить.' : 'This will permanently delete all your transaction history. This cannot be undone.';
|
||||
String get areYouSure => _ru ? 'Вы абсолютно уверены?' : 'Are you absolutely sure?';
|
||||
String get allTransactionsDeleted => _ru ? 'Все транзакции удалены' : 'All transactions deleted';
|
||||
String get noKeepThem => _ru ? 'Нет, оставить' : 'No, keep them';
|
||||
String get yesDeleteEverything => _ru ? 'Да, удалить всё' : 'Yes, delete everything';
|
||||
String get allTransactionsWillBeDeleted => _ru ? 'Все транзакции будут удалены навсегда. Восстановить их будет невозможно.' : 'All transactions will be deleted forever. There is no way to recover them.';
|
||||
String get dangerZone => _ru ? 'Опасная зона' : 'Danger Zone';
|
||||
|
||||
// ── Categories ──
|
||||
String get categories => _ru ? 'Категории' : 'Categories';
|
||||
String get rankedByAmount => _ru ? 'По сумме' : 'Ranked by Amount';
|
||||
String get addCategory => _ru ? 'Добавить категорию' : 'Add Category';
|
||||
String get editCategory => _ru ? 'Редактировать' : 'Edit Category';
|
||||
String get categoryName => _ru ? 'Название' : 'Name';
|
||||
String get categoryIcon => _ru ? 'Иконка' : 'Icon';
|
||||
String get categoryColor => _ru ? 'Цвет' : 'Color';
|
||||
String get deleteCategory => _ru ? 'Удалить категорию' : 'Delete Category';
|
||||
String get noCategoriesYet => _ru ? 'Нет категорий' : 'No categories yet';
|
||||
|
||||
// ── Built-in category names (translated for display only, stored in English) ──
|
||||
String categoryLabel(String key) {
|
||||
if (!_ru) return key; // English: return key as-is
|
||||
const map = {
|
||||
'Food': 'Еда',
|
||||
'Transport': 'Транспорт',
|
||||
'Shopping': 'Покупки',
|
||||
'Entertainment': 'Развлечения',
|
||||
'Health': 'Здоровье',
|
||||
'Housing': 'Жильё',
|
||||
'Education': 'Образование',
|
||||
'Travel': 'Путешествия',
|
||||
'Salary': 'Зарплата',
|
||||
'Freelance': 'Фриланс',
|
||||
'Investment': 'Инвестиции',
|
||||
'Gift': 'Подарок',
|
||||
'Other': 'Другое',
|
||||
'Utilities': 'Коммунальные',
|
||||
'Clothing': 'Одежда',
|
||||
'Sports': 'Спорт',
|
||||
'Beauty': 'Красота',
|
||||
'Pets': 'Питомцы',
|
||||
'Business': 'Бизнес',
|
||||
'Savings': 'Накопления',
|
||||
};
|
||||
return map[key] ?? key; // fallback to English key if not in map
|
||||
}
|
||||
|
||||
// ── Color editor overlay ──
|
||||
String get colorPrimary => _ru ? 'Основной' : 'Primary';
|
||||
String get colorSecondary => _ru ? 'Вторичный' : 'Secondary';
|
||||
String get colorSolid => _ru ? 'Однотон' : 'Solid';
|
||||
String get gradientLinear => _ru ? 'Линейный' : 'Linear';
|
||||
String get gradientReverse => _ru ? 'Обратный' : 'Reverse';
|
||||
String get gradientRadial => _ru ? 'Радиус' : 'Radial';
|
||||
String get gradientSweep => _ru ? 'Круговой' : 'Sweep';
|
||||
String get reset => _ru ? 'Сброс' : 'Reset';
|
||||
String get apply => _ru ? 'Применить' : 'Apply';
|
||||
|
||||
// ── Date locale code for intl DateFormat ──
|
||||
String get dateLocale => _ru ? 'ru_RU' : 'en_US';
|
||||
}
|
||||
@@ -0,0 +1,30 @@
|
||||
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
||||
import 'package:shared_preferences/shared_preferences.dart';
|
||||
import '../../features/dashboard/provider.dart';
|
||||
import 'app_strings.dart';
|
||||
|
||||
class LocaleNotifier extends Notifier<AppLocale> {
|
||||
static const _key = 'app_locale';
|
||||
|
||||
@override
|
||||
AppLocale build() {
|
||||
// Load persisted locale synchronously via ref
|
||||
final prefs = ref.read(sharedPreferencesProvider);
|
||||
final saved = prefs.getString(_key);
|
||||
return saved == 'ru' ? AppLocale.ru : AppLocale.en;
|
||||
}
|
||||
|
||||
void setLocale(AppLocale locale) {
|
||||
state = locale;
|
||||
ref.read(sharedPreferencesProvider).setString(_key, locale.name);
|
||||
}
|
||||
}
|
||||
|
||||
final localeProvider = NotifierProvider<LocaleNotifier, AppLocale>(
|
||||
LocaleNotifier.new,
|
||||
);
|
||||
|
||||
final stringsProvider = Provider<AppStrings>((ref) {
|
||||
final locale = ref.watch(localeProvider);
|
||||
return AppStrings(locale);
|
||||
});
|
||||
Reference in New Issue
Block a user