mirror of
https://github.com/JGeek00/adguard-home-manager.git
synced 2025-04-28 17:48:10 +00:00
Added navigation rail
This commit is contained in:
parent
33125e543c
commit
aefdac5650
2 changed files with 90 additions and 11 deletions
|
@ -12,6 +12,7 @@ import 'package:flutter/services.dart';
|
||||||
|
|
||||||
import 'package:adguard_home_manager/widgets/bottom_nav_bar.dart';
|
import 'package:adguard_home_manager/widgets/bottom_nav_bar.dart';
|
||||||
import 'package:adguard_home_manager/widgets/update_modal.dart';
|
import 'package:adguard_home_manager/widgets/update_modal.dart';
|
||||||
|
import 'package:adguard_home_manager/widgets/navigation_rail.dart';
|
||||||
|
|
||||||
import 'package:adguard_home_manager/providers/app_config_provider.dart';
|
import 'package:adguard_home_manager/providers/app_config_provider.dart';
|
||||||
import 'package:adguard_home_manager/models/github_release.dart';
|
import 'package:adguard_home_manager/models/github_release.dart';
|
||||||
|
@ -110,6 +111,8 @@ class _BaseState extends State<Base> with WidgetsBindingObserver {
|
||||||
final serversProvider = Provider.of<ServersProvider>(context);
|
final serversProvider = Provider.of<ServersProvider>(context);
|
||||||
final appConfigProvider = Provider.of<AppConfigProvider>(context);
|
final appConfigProvider = Provider.of<AppConfigProvider>(context);
|
||||||
|
|
||||||
|
final width = MediaQuery.of(context).size.width;
|
||||||
|
|
||||||
List<AppScreen> screens = serversProvider.selectedServer != null
|
List<AppScreen> screens = serversProvider.selectedServer != null
|
||||||
? screensServerConnected
|
? screensServerConnected
|
||||||
: screensSelectServer;
|
: screensSelectServer;
|
||||||
|
@ -129,7 +132,11 @@ class _BaseState extends State<Base> with WidgetsBindingObserver {
|
||||||
: Brightness.light,
|
: Brightness.light,
|
||||||
),
|
),
|
||||||
child: Scaffold(
|
child: Scaffold(
|
||||||
body: PageTransitionSwitcher(
|
body: Row(
|
||||||
|
children: [
|
||||||
|
if (width > 900) const SideNavigationRail(),
|
||||||
|
Expanded(
|
||||||
|
child: PageTransitionSwitcher(
|
||||||
duration: const Duration(milliseconds: 200),
|
duration: const Duration(milliseconds: 200),
|
||||||
transitionBuilder: (
|
transitionBuilder: (
|
||||||
(child, primaryAnimation, secondaryAnimation) => FadeThroughTransition(
|
(child, primaryAnimation, secondaryAnimation) => FadeThroughTransition(
|
||||||
|
@ -140,7 +147,12 @@ class _BaseState extends State<Base> with WidgetsBindingObserver {
|
||||||
),
|
),
|
||||||
child: screens[appConfigProvider.selectedScreen].body,
|
child: screens[appConfigProvider.selectedScreen].body,
|
||||||
),
|
),
|
||||||
bottomNavigationBar: const BottomNavBar(),
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
bottomNavigationBar: width <= 900
|
||||||
|
? const BottomNavBar()
|
||||||
|
: null,
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
67
lib/widgets/navigation_rail.dart
Normal file
67
lib/widgets/navigation_rail.dart
Normal file
|
@ -0,0 +1,67 @@
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:provider/provider.dart';
|
||||||
|
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
|
||||||
|
|
||||||
|
import 'package:adguard_home_manager/config/app_screens.dart';
|
||||||
|
import 'package:adguard_home_manager/models/app_screen.dart';
|
||||||
|
import 'package:adguard_home_manager/providers/app_config_provider.dart';
|
||||||
|
import 'package:adguard_home_manager/providers/servers_provider.dart';
|
||||||
|
|
||||||
|
class SideNavigationRail extends StatelessWidget {
|
||||||
|
const SideNavigationRail({Key? key}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final serversProvider = Provider.of<ServersProvider>(context);
|
||||||
|
final appConfigProvider = Provider.of<AppConfigProvider>(context);
|
||||||
|
|
||||||
|
List<AppScreen> screens = serversProvider.selectedServer != null
|
||||||
|
? screensServerConnected
|
||||||
|
: screensSelectServer;
|
||||||
|
|
||||||
|
String translatedName(String key) {
|
||||||
|
switch (key) {
|
||||||
|
case 'home':
|
||||||
|
return AppLocalizations.of(context)!.home;
|
||||||
|
|
||||||
|
case 'settings':
|
||||||
|
return AppLocalizations.of(context)!.settings;
|
||||||
|
|
||||||
|
case 'connect':
|
||||||
|
return AppLocalizations.of(context)!.connect;
|
||||||
|
|
||||||
|
case 'clients':
|
||||||
|
return AppLocalizations.of(context)!.clients;
|
||||||
|
|
||||||
|
case 'logs':
|
||||||
|
return AppLocalizations.of(context)!.logs;
|
||||||
|
|
||||||
|
case 'filters':
|
||||||
|
return AppLocalizations.of(context)!.filters;
|
||||||
|
|
||||||
|
default:
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return NavigationRail(
|
||||||
|
selectedIndex: appConfigProvider.selectedScreen,
|
||||||
|
destinations: screens.map((screen) => NavigationRailDestination(
|
||||||
|
icon: Icon(
|
||||||
|
screen.icon,
|
||||||
|
color: screens[appConfigProvider.selectedScreen] == screen
|
||||||
|
? Theme.of(context).colorScheme.onSecondaryContainer
|
||||||
|
: Theme.of(context).colorScheme.onSurfaceVariant,
|
||||||
|
),
|
||||||
|
label: Text(translatedName(screen.name))
|
||||||
|
)).toList(),
|
||||||
|
onDestinationSelected: (value) {
|
||||||
|
appConfigProvider.setSelectedScreen(value);
|
||||||
|
},
|
||||||
|
labelType: NavigationRailLabelType.all,
|
||||||
|
useIndicator: true,
|
||||||
|
groupAlignment: 0,
|
||||||
|
backgroundColor: Theme.of(context).colorScheme.primary.withOpacity(0.05),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue