Solian/lib/shells/root_shell.dart

74 lines
2.1 KiB
Dart
Raw Normal View History

import 'package:firebase_analytics/firebase_analytics.dart';
2024-07-06 20:55:53 +08:00
import 'package:flutter/material.dart';
2024-07-12 13:15:46 +08:00
import 'package:go_router/go_router.dart';
2024-07-06 20:55:53 +08:00
import 'package:solian/theme.dart';
2024-10-05 03:38:30 +08:00
import 'package:solian/widgets/navigation/app_navigation.dart';
import 'package:solian/widgets/navigation/app_navigation_bottom.dart';
import 'package:solian/widgets/navigation/app_navigation_rail.dart';
2024-07-06 20:55:53 +08:00
2024-07-12 11:39:44 +08:00
final GlobalKey<ScaffoldState> rootScaffoldKey = GlobalKey<ScaffoldState>();
2024-07-06 20:55:53 +08:00
class RootShell extends StatelessWidget {
final bool showSidebar;
final bool showNavigation;
final bool? showBottomNavigation;
2024-07-12 13:15:46 +08:00
final GoRouterState state;
2024-07-06 20:55:53 +08:00
final Widget child;
const RootShell({
super.key,
2024-07-12 13:15:46 +08:00
required this.state,
2024-07-06 20:55:53 +08:00
required this.child,
this.showSidebar = true,
this.showNavigation = true,
this.showBottomNavigation,
});
2024-07-12 11:39:44 +08:00
void closeDrawer() {
rootScaffoldKey.currentState!.closeDrawer();
}
2024-07-06 20:55:53 +08:00
@override
Widget build(BuildContext context) {
2024-07-12 13:15:46 +08:00
final routeName = state.topRoute?.name;
if (routeName != null) {
FirebaseAnalytics.instance.logEvent(
name: 'screen_view',
parameters: {
'firebase_screen': routeName,
},
);
}
final showRailNavigation = AppTheme.isLargeScreen(context);
2024-10-05 03:38:30 +08:00
final destNames = AppNavigation.destinations.map((x) => x.page).toList();
final showBottomNavigation =
destNames.contains(routeName) && !showRailNavigation;
2024-10-05 03:38:30 +08:00
2024-07-06 20:55:53 +08:00
return Scaffold(
2024-07-12 11:39:44 +08:00
key: rootScaffoldKey,
2024-10-08 00:06:08 +08:00
backgroundColor: Theme.of(context).colorScheme.surface,
2024-10-05 03:38:30 +08:00
bottomNavigationBar: showBottomNavigation
? AppNavigationBottom(
initialIndex: destNames.indexOf(routeName ?? 'page'),
)
: null,
body: AppTheme.isLargeScreen(context)
? Row(
children: [
if (showRailNavigation) const AppNavigationRail(),
if (showRailNavigation)
const VerticalDivider(
width: 0.3,
thickness: 0.3,
),
Expanded(child: child),
],
)
2024-07-12 11:39:44 +08:00
: child,
2024-07-06 20:55:53 +08:00
);
}
}