1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
import 'package:dynamic_color/dynamic_color.dart';
import 'package:firebase_auth/firebase_auth.dart';
import 'package:firebase_core/firebase_core.dart';
import 'package:flutter/material.dart';
import 'package:linkchat/screens/dashboard_screen.dart';
import 'package:linkchat/screens/login_screen.dart';
import 'package:linkchat/screens/onboarding_screen.dart';
import 'package:linkchat/settings/preferences.dart';
import 'package:linkchat/widgets/loading_modal_widget.dart';
import 'package:provider/provider.dart';
import 'firebase/auth.dart';
import 'providers/theme_provider.dart';
import 'routes.dart';
import 'settings/themes.dart';
void main(List<String> args) async {
WidgetsFlutterBinding.ensureInitialized();
await Firebase.initializeApp();
return runApp(const MainContent());
}
class MainContent extends StatefulWidget {
const MainContent({super.key});
@override
State<MainContent> createState() => _MainContentState();
}
class _MainContentState extends State<MainContent> {
int contador = 0;
@override
void initState() {
super.initState();
contador = 0;
}
@override
Widget build(BuildContext context) {
return MultiProvider(
providers: [
ChangeNotifierProvider(create: (_) => ThemeProvider()),
],
child: LinkChat(),
);
}
}
class LinkChat extends StatelessWidget {
final Auth _auth = Auth();
LinkChat({super.key});
@override
Widget build(BuildContext context) {
final ThemeProvider provider = context.watch<ThemeProvider>();
final ThemeEnum themeEnum = provider.theme;
return StreamBuilder(
stream: _auth.userChanges,
builder: (context, authSnapshot) => DynamicColorBuilder(
builder: (lightDynamic, darkDynamic) {
provider.syncFromPrefs();
ThemeData lightTheme = ThemeSettings.lightTheme(lightDynamic);
ThemeData darkTheme = ThemeSettings.darkTheme(darkDynamic);
ThemeData? theme;
switch (themeEnum) {
case ThemeEnum.light:
theme = lightTheme;
case ThemeEnum.dark:
theme = darkTheme;
case ThemeEnum.auto:
theme = null;
}
return MaterialApp(
theme: theme ?? lightTheme,
darkTheme: theme ?? darkTheme,
themeMode: ThemeMode.system,
routes: getApplicationRoutes(),
home: FutureBuilder(
initialData: const LoadingModal(),
future: getHomeScreen(context, authSnapshot.data),
builder: (context, homeSnapshot) {
if (homeSnapshot.hasData) {
return homeSnapshot.data!;
} else if (homeSnapshot.hasError) {
return const LoginScreen();
} else {
return const LoadingModal();
}
},
),
);
},
),
);
}
Future<Widget> getHomeScreen(BuildContext context, User? user) async {
if (user != null && !user.isAnonymous && user.emailVerified) {
bool showOnboarding = await Preferences.getShowOnboarding();
if (showOnboarding) {
return const OnboardingScreen();
} else {
return const DashboardScreen();
}
} else {
return const LoginScreen();
}
}
}
|