2024-04-13 00:38:20 +08:00
|
|
|
import 'package:flutter/material.dart';
|
2024-04-14 00:10:22 +08:00
|
|
|
import 'package:provider/provider.dart';
|
|
|
|
import 'package:solian/providers/navigation.dart';
|
2024-04-13 00:38:20 +08:00
|
|
|
import 'package:solian/router.dart';
|
|
|
|
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
|
|
|
|
|
|
|
|
class SolianNavigationDrawer extends StatefulWidget {
|
|
|
|
const SolianNavigationDrawer({super.key});
|
|
|
|
|
|
|
|
@override
|
|
|
|
State<SolianNavigationDrawer> createState() => _SolianNavigationDrawerState();
|
|
|
|
}
|
|
|
|
|
|
|
|
class _SolianNavigationDrawerState extends State<SolianNavigationDrawer> {
|
|
|
|
var _selectedIndex = 0;
|
|
|
|
|
|
|
|
void _onSelect(String name, int idx) {
|
|
|
|
setState(() => _selectedIndex = idx);
|
2024-04-14 00:10:22 +08:00
|
|
|
context.read<NavigationProvider>().selectedIndex = idx;
|
2024-04-13 00:38:20 +08:00
|
|
|
router.goNamed(name);
|
|
|
|
}
|
|
|
|
|
2024-04-14 00:10:22 +08:00
|
|
|
@override
|
|
|
|
void initState() {
|
|
|
|
Future.delayed(Duration.zero, () {
|
|
|
|
setState(() {
|
|
|
|
_selectedIndex = context.read<NavigationProvider>().selectedIndex;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
super.initState();
|
|
|
|
}
|
|
|
|
|
2024-04-13 00:38:20 +08:00
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
final navigationItems = [
|
|
|
|
(
|
|
|
|
NavigationDrawerDestination(
|
|
|
|
icon: const Icon(Icons.explore),
|
|
|
|
label: Text(AppLocalizations.of(context)!.explore),
|
|
|
|
),
|
|
|
|
"explore",
|
|
|
|
),
|
2024-04-16 22:29:58 +08:00
|
|
|
(
|
|
|
|
NavigationDrawerDestination(
|
|
|
|
icon: const Icon(Icons.send),
|
|
|
|
label: Text(AppLocalizations.of(context)!.chat),
|
|
|
|
),
|
|
|
|
"chat",
|
|
|
|
),
|
2024-04-14 00:03:50 +08:00
|
|
|
(
|
|
|
|
NavigationDrawerDestination(
|
|
|
|
icon: const Icon(Icons.account_circle),
|
|
|
|
label: Text(AppLocalizations.of(context)!.account),
|
|
|
|
),
|
|
|
|
"account",
|
|
|
|
),
|
2024-04-13 00:38:20 +08:00
|
|
|
];
|
|
|
|
|
|
|
|
return NavigationDrawer(
|
|
|
|
selectedIndex: _selectedIndex,
|
|
|
|
onDestinationSelected: (int idx) {
|
|
|
|
final element = navigationItems[idx];
|
|
|
|
_onSelect(element.$2, idx);
|
|
|
|
},
|
|
|
|
children: [
|
|
|
|
Padding(
|
|
|
|
padding: const EdgeInsets.fromLTRB(28, 16, 16, 10),
|
|
|
|
child: Row(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.start,
|
|
|
|
children: [
|
|
|
|
Image.asset("assets/logo.png", width: 26, height: 26),
|
|
|
|
const SizedBox(width: 10),
|
|
|
|
Text(
|
|
|
|
AppLocalizations.of(context)!.solian,
|
|
|
|
style: const TextStyle(fontWeight: FontWeight.w900),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
...navigationItems.map((x) => x.$1)
|
|
|
|
],
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|