talker_flutter 1.5.0 talker_flutter: ^1.5.0 copied to clipboard
Flutter implementation of talker (advanced error handler and logger package).
import 'dart:async';
import 'dart:io';
import 'package:flutter/material.dart';
import 'package:talker_example/extended_example/extended_example.dart';
import 'package:talker_flutter/talker_flutter.dart';
import 'talker_wrapper_example/talker_wrapper_example.dart';
/// You can see [ExtendedExample] to
/// check how logs working in realtime
///
///
void main() {
final talker = Talker(
loggerSettings: TalkerLoggerSettings(
enableColors: !Platform.isIOS,
),
);
runZonedGuarded(
() => runApp(
CustomErrorMessagesExample(talker: talker),
),
(Object error, StackTrace stack) {
talker.handle(error, stack, 'Uncaught app exception');
},
);
}
class BaseEample extends StatefulWidget {
const BaseEample({
Key? key,
required this.talker,
}) : super(key: key);
final Talker talker;
@override
State<BaseEample> createState() => _BaseEampleState();
}
class _BaseEampleState extends State<BaseEample> {
@override
void initState() {
_fineLog();
_infoLog();
_handleError();
_handleException();
_warningLog();
_criticalLog();
_customLog();
super.initState();
}
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Talker Flutter',
theme: ThemeData(
primarySwatch: Colors.blue,
scaffoldBackgroundColor: Colors.grey[100],
),
home: Builder(builder: (context) {
return Scaffold(
body: TalkerScreen(talker: widget.talker),
);
}),
);
}
void _handleError() {
try {
throw ArgumentError('-6 is not positive number');
} catch (e, st) {
widget.talker.handle(e, st, 'Something wrong in calculation');
}
}
void _handleException() {
try {
throw Exception('Test service exception');
} catch (e, st) {
widget.talker.handle(e, st, 'FakeService excetion');
}
}
void _fineLog() {
widget.talker.fine('Service send good request');
}
void _infoLog() {
widget.talker.info('Renew token from expire date');
}
void _warningLog() {
widget.talker.warning('Cache images working slowly on this platform');
}
void _customLog() {
widget.talker.logTyped(CustomLog('Custom log message'));
}
void _criticalLog() {
widget.talker.log('Server exception', logLevel: LogLevel.critical);
}
}