retro_logger 0.0.7 copy "retro_logger: ^0.0.7" to clipboard
retro_logger: ^0.0.7 copied to clipboard

A simple Logger that does not have any dependencies and is easy to use.

example/lib/main.dart

import 'dart:async';

import 'package:flutter/material.dart';
import 'package:retro_logger/retro_logger.dart';

void main() {
  runApp(const MyApp());
}

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: const LogScreen(),
    );
  }
}

class LogScreen extends StatefulWidget {
  const LogScreen({super.key});

  @override
  State<LogScreen> createState() => _LogScreenState();
}

class _LogScreenState extends State<LogScreen> {
  @override
  void initState() {
    super.initState();
    _simulateLogs();
  }

  Future<void> _simulateLogs() async {
    // List of log types and corresponding messages
    final logMessages = [
      () =>
          Logger.network.log('This is a network log', origin: '_simulateLogs'),
      () => Logger.button.log('This is a button log', origin: '_simulateLogs'),
      () => Logger.database
          .log('This is a database log', origin: '_simulateLogs'),
      () => Logger.ui.log('This is a UI log', origin: '_simulateLogs'),
      () => Logger.api.log('This is an API log', origin: '_simulateLogs'),
      () => Logger.other.log('This is an other log', origin: '_simulateLogs'),
      () => Logger.error.log('This is an error log', origin: '_simulateLogs'),
      () =>
          Logger.warning.log('This is a warning log', origin: '_simulateLogs'),
      () =>
          Logger.success.log('This is a success log', origin: '_simulateLogs'),
      () => Logger.info.log('This is an info log', origin: '_simulateLogs'),
      () => Logger.fatal.log('This is a fatal log', origin: '_simulateLogs'),
      () async => _benchmarkedLog(),
    ];

    // Loop over the log messages
    for (var logMessage in logMessages) {
      await Future.delayed(const Duration(milliseconds: 100));
      logMessage();
    }
  }

  Future<void> _benchmarkedLog() async {
    return Logger.timestamp.benchmarkAsync(() async {
      await Future.delayed(const Duration(milliseconds: 500), () {
        if (!mounted) return;
        ScaffoldMessenger.of(context).showSnackBar(
          const SnackBar(
            content: Text('Benchmark completed'),
          ),
        );
      });
    }, name: '_benchmarkedLog');
  }

  @override
  Widget build(BuildContext context) {
    return Theme(
      data: ThemeData.dark(),
      child: Scaffold(
        appBar: AppBar(
          title: const Text('Logs'),
        ),
        body: const SafeArea(child: LogTabView()),
        floatingActionButton: FloatingActionButton(
          onPressed: () {
            Logger.info.log(
              [
                'This is an info log',
                'with multiple lines',
                'and json data\n\n'
                    '{"key": "value", "list": [1, 2, 3], "nested": {"key": "value"}, "bool": true}, "null": null',
              ],
              origin: 'FloatingActionButton',
            );
          },
          child: const Icon(Icons.add),
        ),
      ),
    );
  }
}
3
likes
0
points
11
downloads

Publisher

verified publisherpolarstork.com

Weekly Downloads

A simple Logger that does not have any dependencies and is easy to use.

Homepage
Repository (GitHub)
View/report issues

License

unknown (license)

Dependencies

fl_chart, flutter

More

Packages that depend on retro_logger