54 lines
1.6 KiB
Dart
Raw Normal View History

2025-08-13 00:15:53 +07:00
import 'package:auto_route/auto_route.dart';
import 'package:flutter/material.dart';
2025-08-13 01:17:00 +07:00
import 'package:flutter_bloc/flutter_bloc.dart';
2025-08-13 00:15:53 +07:00
2025-08-13 01:17:00 +07:00
import '../../../application/language/language_bloc.dart';
import '../../../common/extension/extension.dart';
2025-08-13 00:15:53 +07:00
import '../../../common/theme/theme.dart';
2025-08-13 01:17:00 +07:00
import '../../../infrastructure/language/language.dart';
2025-08-13 00:15:53 +07:00
import 'widgets/language_tile.dart';
@RoutePage()
2025-08-13 01:17:00 +07:00
class LanguagePage extends StatelessWidget {
2025-08-13 00:15:53 +07:00
const LanguagePage({super.key});
@override
Widget build(BuildContext context) {
return Scaffold(
backgroundColor: AppColor.background,
appBar: AppBar(
2025-08-13 01:17:00 +07:00
title: Text(context.lang.select_language),
2025-08-13 00:15:53 +07:00
elevation: 0,
leading: IconButton(
icon: const Icon(Icons.arrow_back, color: Colors.white),
onPressed: () => context.router.back(),
),
),
2025-08-13 01:17:00 +07:00
body: BlocBuilder<LanguageBloc, LanguageState>(
builder: (context, state) {
return ListView.builder(
2025-08-13 00:15:53 +07:00
padding: const EdgeInsets.all(16),
2025-08-13 01:17:00 +07:00
itemCount: languages.length,
itemBuilder: (context, index) {
final language = languages[index];
final isSelected =
state.language.locale.languageCode ==
language.locale.languageCode
? true
: false;
return LanguageTile(
isSelected: isSelected,
language: language,
onTap: () => context.read<LanguageBloc>().add(
LanguageEvent.changeLanguage(language),
),
);
},
);
},
2025-08-13 00:15:53 +07:00
),
);
}
}