crashlytics: log locales, timezone, route changes
This commit is contained in:
parent
ebe02f4dfb
commit
0e42568d85
2 changed files with 81 additions and 36 deletions
|
@ -1,6 +1,8 @@
|
||||||
import 'dart:isolate';
|
import 'dart:isolate';
|
||||||
|
import 'dart:ui';
|
||||||
|
|
||||||
import 'package:aves/model/settings/settings.dart';
|
import 'package:aves/model/settings/settings.dart';
|
||||||
|
import 'package:aves/utils/route_tracker.dart';
|
||||||
import 'package:aves/widgets/common/data_providers/settings_provider.dart';
|
import 'package:aves/widgets/common/data_providers/settings_provider.dart';
|
||||||
import 'package:aves/widgets/common/icons.dart';
|
import 'package:aves/widgets/common/icons.dart';
|
||||||
import 'package:aves/widgets/home_page.dart';
|
import 'package:aves/widgets/home_page.dart';
|
||||||
|
@ -38,9 +40,30 @@ class AvesApp extends StatefulWidget {
|
||||||
|
|
||||||
class _AvesAppState extends State<AvesApp> {
|
class _AvesAppState extends State<AvesApp> {
|
||||||
Future<void> _appSetup;
|
Future<void> _appSetup;
|
||||||
|
final NavigatorObserver _routeTracker = CrashlyticsRouteTracker();
|
||||||
|
|
||||||
static const accentColor = Colors.indigoAccent;
|
static const accentColor = Colors.indigoAccent;
|
||||||
|
|
||||||
|
static final darkTheme = ThemeData(
|
||||||
|
brightness: Brightness.dark,
|
||||||
|
accentColor: accentColor,
|
||||||
|
scaffoldBackgroundColor: Colors.grey[900],
|
||||||
|
buttonColor: accentColor,
|
||||||
|
toggleableActiveColor: accentColor,
|
||||||
|
tooltipTheme: TooltipThemeData(
|
||||||
|
verticalOffset: 32,
|
||||||
|
),
|
||||||
|
appBarTheme: AppBarTheme(
|
||||||
|
textTheme: TextTheme(
|
||||||
|
headline6: TextStyle(
|
||||||
|
fontSize: 20,
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
fontFamily: 'Concourse Caps',
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void initState() {
|
void initState() {
|
||||||
super.initState();
|
super.initState();
|
||||||
|
@ -50,6 +73,9 @@ class _AvesAppState extends State<AvesApp> {
|
||||||
Future<void> _setup() async {
|
Future<void> _setup() async {
|
||||||
await Firebase.initializeApp().then((app) {
|
await Firebase.initializeApp().then((app) {
|
||||||
FlutterError.onError = FirebaseCrashlytics.instance.recordFlutterError;
|
FlutterError.onError = FirebaseCrashlytics.instance.recordFlutterError;
|
||||||
|
FirebaseCrashlytics.instance.setCustomKey('locales', window.locales.join(', '));
|
||||||
|
final now = DateTime.now();
|
||||||
|
FirebaseCrashlytics.instance.setCustomKey('timezone', '${now.timeZoneName} (${now.timeZoneOffset})');
|
||||||
FirebaseCrashlytics.instance.setCustomKey(
|
FirebaseCrashlytics.instance.setCustomKey(
|
||||||
'build_mode',
|
'build_mode',
|
||||||
kReleaseMode
|
kReleaseMode
|
||||||
|
@ -65,44 +91,45 @@ class _AvesAppState extends State<AvesApp> {
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
// place the settings provider above `MaterialApp`
|
// place the settings provider above `MaterialApp`
|
||||||
// so it can be used during navigation transitions
|
// so it can be used during navigation transitions
|
||||||
|
final home = FutureBuilder<void>(
|
||||||
|
future: _appSetup,
|
||||||
|
builder: (context, snapshot) {
|
||||||
|
if (!snapshot.hasError && snapshot.connectionState == ConnectionState.done) {
|
||||||
|
return settings.hasAcceptedTerms ? HomePage() : WelcomePage();
|
||||||
|
}
|
||||||
|
return Scaffold(
|
||||||
|
body: snapshot.hasError
|
||||||
|
? Container(
|
||||||
|
alignment: Alignment.center,
|
||||||
|
padding: EdgeInsets.all(16),
|
||||||
|
child: Column(
|
||||||
|
mainAxisSize: MainAxisSize.min,
|
||||||
|
children: [
|
||||||
|
Icon(AIcons.error),
|
||||||
|
SizedBox(height: 16),
|
||||||
|
Text(snapshot.error.toString()),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
)
|
||||||
|
: SizedBox.shrink(),
|
||||||
|
);
|
||||||
|
},
|
||||||
|
);
|
||||||
return SettingsProvider(
|
return SettingsProvider(
|
||||||
child: OverlaySupport(
|
child: OverlaySupport(
|
||||||
child: MaterialApp(
|
child: FutureBuilder<void>(
|
||||||
title: 'Aves',
|
future: _appSetup,
|
||||||
theme: ThemeData(
|
builder: (context, snapshot) {
|
||||||
brightness: Brightness.dark,
|
return MaterialApp(
|
||||||
accentColor: accentColor,
|
home: home,
|
||||||
scaffoldBackgroundColor: Colors.grey[900],
|
navigatorObservers: [
|
||||||
buttonColor: accentColor,
|
if (!snapshot.hasError && snapshot.connectionState == ConnectionState.done) _routeTracker,
|
||||||
toggleableActiveColor: accentColor,
|
],
|
||||||
tooltipTheme: TooltipThemeData(
|
title: 'Aves',
|
||||||
verticalOffset: 32,
|
darkTheme: darkTheme,
|
||||||
),
|
themeMode: ThemeMode.dark,
|
||||||
appBarTheme: AppBarTheme(
|
);
|
||||||
textTheme: TextTheme(
|
},
|
||||||
headline6: TextStyle(
|
|
||||||
fontSize: 20,
|
|
||||||
fontWeight: FontWeight.bold,
|
|
||||||
fontFamily: 'Concourse Caps',
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
home: FutureBuilder<void>(
|
|
||||||
future: _appSetup,
|
|
||||||
builder: (context, snapshot) {
|
|
||||||
if (snapshot.hasError) {
|
|
||||||
return Column(
|
|
||||||
children: [
|
|
||||||
Icon(AIcons.error),
|
|
||||||
Text(snapshot.error),
|
|
||||||
],
|
|
||||||
);
|
|
||||||
}
|
|
||||||
if (snapshot.connectionState != ConnectionState.done) return Scaffold();
|
|
||||||
return settings.hasAcceptedTerms ? HomePage() : WelcomePage();
|
|
||||||
},
|
|
||||||
),
|
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
18
lib/utils/route_tracker.dart
Normal file
18
lib/utils/route_tracker.dart
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
import 'package:firebase_crashlytics/firebase_crashlytics.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
|
class CrashlyticsRouteTracker extends NavigatorObserver {
|
||||||
|
@override
|
||||||
|
void didPush(Route<dynamic> route, Route<dynamic> previousRoute) => FirebaseCrashlytics.instance.log('Nav didPush to ${_name(route)}');
|
||||||
|
|
||||||
|
@override
|
||||||
|
void didPop(Route<dynamic> route, Route<dynamic> previousRoute) => FirebaseCrashlytics.instance.log('Nav didPop to ${_name(previousRoute)}');
|
||||||
|
|
||||||
|
@override
|
||||||
|
void didRemove(Route<dynamic> route, Route<dynamic> previousRoute) => FirebaseCrashlytics.instance.log('Nav didRemove to ${_name(previousRoute)}');
|
||||||
|
|
||||||
|
@override
|
||||||
|
void didReplace({Route<dynamic> newRoute, Route<dynamic> oldRoute}) => FirebaseCrashlytics.instance.log('Nav didReplace to ${_name(newRoute)}');
|
||||||
|
|
||||||
|
String _name(Route<dynamic> route) => route?.settings?.name ?? 'unnamed ${route?.runtimeType}';
|
||||||
|
}
|
Loading…
Reference in a new issue