From 4b29c06f444c757d04ca115258ed0b2a03796b53 Mon Sep 17 00:00:00 2001 From: Kittipong Theothaisong Date: Wed, 27 Jul 2022 13:28:43 +0700 Subject: [PATCH] made MaterialApp able to create from RouterDelegate --- lib/src/widget/app.dart | 157 +++++++++++++++++++++++++++++++--------- 1 file changed, 123 insertions(+), 34 deletions(-) diff --git a/lib/src/widget/app.dart b/lib/src/widget/app.dart index 70948b8d..1ba54205 100644 --- a/lib/src/widget/app.dart +++ b/lib/src/widget/app.dart @@ -14,12 +14,12 @@ class NeumorphicApp extends StatelessWidget { final Locale? locale; final Widget? home; final Iterable supportedLocales; - final Map routes; + final Map? routes; final RouteFactory? onGenerateRoute; final RouteFactory? onUnknownRoute; final GenerateAppTitle? onGenerateTitle; final GlobalKey? navigatorKey; - final List navigatorObservers; + final List? navigatorObservers; final InitialRouteListFactory? onGenerateInitialRoutes; final bool debugShowCheckedModeBanner; final Widget Function(BuildContext, Widget?)? builder; @@ -34,8 +34,22 @@ class NeumorphicApp extends StatelessWidget { final Map? shortcuts; final Map>? actions; + /// {@macro flutter.widgets.widgetsApp.routeInformationProvider} + final RouteInformationProvider? routeInformationProvider; + + /// {@macro flutter.widgets.widgetsApp.routeInformationParser} + final RouteInformationParser? routeInformationParser; + + /// {@macro flutter.widgets.widgetsApp.routerDelegate} + final RouterDelegate? routerDelegate; + + /// {@macro flutter.widgets.widgetsApp.backButtonDispatcher} + final BackButtonDispatcher? backButtonDispatcher; + final bool debugShowMaterialGrid; + bool get _usesRouter => routerDelegate != null; + const NeumorphicApp({ Key? key, this.title = '', @@ -70,7 +84,51 @@ class NeumorphicApp extends StatelessWidget { this.debugShowMaterialGrid = false, this.shortcuts, this.actions, - }) : super(key: key); + }) : routeInformationProvider = null, + routeInformationParser = null, + routerDelegate = null, + backButtonDispatcher = null, + super(key: key); + + const NeumorphicApp.router({ + Key? key, + required RouterDelegate this.routerDelegate, + required RouteInformationParser this.routeInformationParser, + this.routeInformationProvider, + this.backButtonDispatcher, + this.title = '', + this.color, + this.debugShowCheckedModeBanner = true, + this.onGenerateTitle, + this.theme = neumorphicDefaultTheme, + this.darkTheme = neumorphicDefaultDarkTheme, + this.locale, + this.localizationsDelegates, + this.supportedLocales = const [Locale('en', 'US')], + this.themeMode = ThemeMode.system, + this.materialDarkTheme, + this.materialTheme, + this.builder, + this.localeResolutionCallback, + this.highContrastTheme, + this.highContrastDarkTheme, + this.localeListResolutionCallback, + this.showPerformanceOverlay = false, + this.checkerboardRasterCacheImages = false, + this.checkerboardOffscreenLayers = false, + this.showSemanticsDebugger = false, + this.debugShowMaterialGrid = false, + this.shortcuts, + this.actions, + }) : navigatorObservers = null, + navigatorKey = null, + onGenerateRoute = null, + home = null, + onGenerateInitialRoutes = null, + onUnknownRoute = null, + routes = null, + initialRoute = null, + super(key: key); ThemeData _getMaterialTheme(NeumorphicThemeData theme) { final color = theme.accentColor; @@ -110,37 +168,68 @@ class NeumorphicApp extends StatelessWidget { child: Builder( builder: (context) => IconTheme( data: NeumorphicTheme.currentTheme(context).iconTheme, - child: MaterialApp( - title: title, - color: color, - theme: materialTheme, - darkTheme: materialDarkTheme, - initialRoute: initialRoute, - routes: routes, - themeMode: themeMode, - localizationsDelegates: localizationsDelegates, - supportedLocales: supportedLocales, - locale: locale, - home: home, - onGenerateRoute: onGenerateRoute, - onUnknownRoute: onUnknownRoute, - onGenerateTitle: onGenerateTitle, - onGenerateInitialRoutes: onGenerateInitialRoutes, - navigatorKey: navigatorKey, - navigatorObservers: navigatorObservers, - debugShowCheckedModeBanner: debugShowCheckedModeBanner, - builder: builder, - localeResolutionCallback: localeResolutionCallback, - highContrastTheme: highContrastTheme, - highContrastDarkTheme: highContrastDarkTheme, - localeListResolutionCallback: localeListResolutionCallback, - showPerformanceOverlay: showPerformanceOverlay, - checkerboardRasterCacheImages: checkerboardRasterCacheImages, - checkerboardOffscreenLayers: checkerboardOffscreenLayers, - showSemanticsDebugger: showSemanticsDebugger, - shortcuts: shortcuts, - actions: actions, - debugShowMaterialGrid: debugShowMaterialGrid), + child: _usesRouter + ? MaterialApp.router( + routeInformationParser: routeInformationParser!, + routerDelegate: routerDelegate!, + routeInformationProvider: routeInformationProvider, + backButtonDispatcher: backButtonDispatcher, + title: title, + color: color, + theme: materialTheme, + darkTheme: materialDarkTheme, + themeMode: themeMode, + localizationsDelegates: localizationsDelegates, + supportedLocales: supportedLocales, + locale: locale, + onGenerateTitle: onGenerateTitle, + debugShowCheckedModeBanner: debugShowCheckedModeBanner, + builder: builder, + localeResolutionCallback: localeResolutionCallback, + highContrastTheme: highContrastTheme, + highContrastDarkTheme: highContrastDarkTheme, + localeListResolutionCallback: localeListResolutionCallback, + showPerformanceOverlay: showPerformanceOverlay, + checkerboardRasterCacheImages: checkerboardRasterCacheImages, + checkerboardOffscreenLayers: checkerboardOffscreenLayers, + showSemanticsDebugger: showSemanticsDebugger, + shortcuts: shortcuts, + actions: actions, + debugShowMaterialGrid: debugShowMaterialGrid, + ) + : MaterialApp( + title: title, + color: color, + theme: materialTheme, + darkTheme: materialDarkTheme, + initialRoute: initialRoute, + routes: routes ?? {}, + themeMode: themeMode, + localizationsDelegates: localizationsDelegates, + supportedLocales: supportedLocales, + locale: locale, + home: home, + onGenerateRoute: onGenerateRoute, + onUnknownRoute: onUnknownRoute, + onGenerateTitle: onGenerateTitle, + onGenerateInitialRoutes: onGenerateInitialRoutes, + navigatorKey: navigatorKey, + navigatorObservers: + navigatorObservers ?? const [], + debugShowCheckedModeBanner: debugShowCheckedModeBanner, + builder: builder, + localeResolutionCallback: localeResolutionCallback, + highContrastTheme: highContrastTheme, + highContrastDarkTheme: highContrastDarkTheme, + localeListResolutionCallback: localeListResolutionCallback, + showPerformanceOverlay: showPerformanceOverlay, + checkerboardRasterCacheImages: checkerboardRasterCacheImages, + checkerboardOffscreenLayers: checkerboardOffscreenLayers, + showSemanticsDebugger: showSemanticsDebugger, + shortcuts: shortcuts, + actions: actions, + debugShowMaterialGrid: debugShowMaterialGrid, + ), ), ), );