2022-09-05 03:32:36 +01:00
|
|
|
import 'package:dynamic_color/dynamic_color.dart';
|
|
|
|
import 'package:dynamic_themes/dynamic_themes.dart';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:google_fonts/google_fonts.dart';
|
|
|
|
import 'package:revanced_manager/app/app.router.dart';
|
|
|
|
import 'package:revanced_manager/theme.dart';
|
|
|
|
import 'package:stacked_services/stacked_services.dart';
|
|
|
|
|
|
|
|
class DynamicThemeBuilder extends StatelessWidget {
|
|
|
|
final String title;
|
|
|
|
final Widget home;
|
|
|
|
final Iterable<LocalizationsDelegate> localizationsDelegates;
|
|
|
|
|
|
|
|
const DynamicThemeBuilder({
|
|
|
|
Key? key,
|
|
|
|
required this.title,
|
|
|
|
required this.home,
|
|
|
|
required this.localizationsDelegates,
|
|
|
|
}) : super(key: key);
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return DynamicColorBuilder(
|
|
|
|
builder: (lightColorScheme, darkColorScheme) {
|
|
|
|
ThemeData lightDynamicTheme = ThemeData(
|
|
|
|
useMaterial3: true,
|
2022-09-06 18:07:23 +01:00
|
|
|
canvasColor: lightColorScheme?.background,
|
|
|
|
navigationBarTheme: NavigationBarThemeData(
|
|
|
|
backgroundColor: lightColorScheme?.background,
|
|
|
|
indicatorColor: lightColorScheme?.primary.withAlpha(150),
|
|
|
|
labelTextStyle: MaterialStateProperty.all(
|
2022-09-07 12:01:04 +01:00
|
|
|
GoogleFonts.roboto(
|
|
|
|
color: lightColorScheme?.secondary,
|
2022-09-06 18:07:23 +01:00
|
|
|
fontWeight: FontWeight.w500,
|
|
|
|
),
|
|
|
|
),
|
2022-09-07 12:01:04 +01:00
|
|
|
iconTheme: MaterialStateProperty.all(
|
|
|
|
IconThemeData(
|
|
|
|
color: lightColorScheme?.secondary,
|
|
|
|
),
|
|
|
|
),
|
2022-09-06 18:07:23 +01:00
|
|
|
),
|
|
|
|
scaffoldBackgroundColor: lightColorScheme?.background,
|
2022-09-05 03:32:36 +01:00
|
|
|
colorScheme: lightColorScheme?.harmonized(),
|
2022-09-05 17:48:14 +01:00
|
|
|
toggleableActiveColor: lightColorScheme?.primary,
|
2022-09-05 03:32:36 +01:00
|
|
|
textTheme: GoogleFonts.robotoTextTheme(ThemeData.light().textTheme),
|
|
|
|
);
|
|
|
|
ThemeData darkDynamicTheme = ThemeData(
|
|
|
|
useMaterial3: true,
|
2022-09-06 18:07:23 +01:00
|
|
|
canvasColor: darkColorScheme?.background,
|
|
|
|
navigationBarTheme: NavigationBarThemeData(
|
|
|
|
backgroundColor: darkColorScheme?.background,
|
|
|
|
indicatorColor: darkColorScheme?.primary.withOpacity(0.4),
|
|
|
|
labelTextStyle: MaterialStateProperty.all(
|
2022-09-07 12:01:04 +01:00
|
|
|
GoogleFonts.roboto(
|
|
|
|
color: darkColorScheme?.secondary,
|
2022-09-06 18:07:23 +01:00
|
|
|
fontWeight: FontWeight.w500,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
iconTheme: MaterialStateProperty.all(
|
2022-09-07 12:01:04 +01:00
|
|
|
IconThemeData(
|
|
|
|
color: darkColorScheme?.secondary,
|
2022-09-06 18:07:23 +01:00
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
scaffoldBackgroundColor: darkColorScheme?.background,
|
2022-09-05 03:32:36 +01:00
|
|
|
colorScheme: darkColorScheme?.harmonized(),
|
2022-09-05 17:48:14 +01:00
|
|
|
toggleableActiveColor: darkColorScheme?.primary,
|
2022-09-05 03:32:36 +01:00
|
|
|
textTheme: GoogleFonts.robotoTextTheme(ThemeData.dark().textTheme),
|
|
|
|
);
|
|
|
|
return DynamicTheme(
|
|
|
|
themeCollection: ThemeCollection(
|
|
|
|
themes: {
|
|
|
|
0: lightCustomTheme,
|
|
|
|
1: darkCustomTheme,
|
|
|
|
2: lightDynamicTheme,
|
|
|
|
3: darkDynamicTheme,
|
|
|
|
},
|
2022-09-06 18:07:23 +01:00
|
|
|
fallbackTheme: darkCustomTheme,
|
2022-09-05 03:32:36 +01:00
|
|
|
),
|
|
|
|
builder: (context, theme) => MaterialApp(
|
|
|
|
debugShowCheckedModeBanner: false,
|
|
|
|
title: title,
|
|
|
|
navigatorKey: StackedService.navigatorKey,
|
|
|
|
onGenerateRoute: StackedRouter().onGenerateRoute,
|
|
|
|
theme: theme,
|
|
|
|
home: home,
|
|
|
|
localizationsDelegates: localizationsDelegates,
|
|
|
|
),
|
|
|
|
);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|