2024-08-19 01:35:38 +08:00
|
|
|
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';
|
2024-10-05 03:12:47 +08:00
|
|
|
import 'package:solian/widgets/navigation/app_navigation_bottom.dart';
|
2024-10-06 01:17:49 +08:00
|
|
|
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;
|
|
|
|
|
2024-08-19 01:35:38 +08:00
|
|
|
if (routeName != null) {
|
|
|
|
FirebaseAnalytics.instance.logEvent(
|
|
|
|
name: 'screen_view',
|
|
|
|
parameters: {
|
|
|
|
'firebase_screen': routeName,
|
|
|
|
},
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2024-10-06 01:17:49 +08:00
|
|
|
final showRailNavigation = AppTheme.isLargeScreen(context);
|
|
|
|
|
2024-10-05 03:38:30 +08:00
|
|
|
final destNames = AppNavigation.destinations.map((x) => x.page).toList();
|
2024-10-06 01:17:49 +08:00
|
|
|
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,
|
2024-09-13 20:22:10 +08:00
|
|
|
body: AppTheme.isLargeScreen(context)
|
2024-07-07 14:41:23 +08:00
|
|
|
? Row(
|
|
|
|
children: [
|
2024-10-06 01:17:49 +08:00
|
|
|
if (showRailNavigation) const AppNavigationRail(),
|
|
|
|
if (showRailNavigation)
|
|
|
|
const VerticalDivider(
|
|
|
|
width: 0.3,
|
|
|
|
thickness: 0.3,
|
|
|
|
),
|
2024-07-07 14:41:23 +08:00
|
|
|
Expanded(child: child),
|
|
|
|
],
|
|
|
|
)
|
2024-07-12 11:39:44 +08:00
|
|
|
: child,
|
2024-07-06 20:55:53 +08:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|