talker_logger 4.0.0-dev.5 copy "talker_logger: ^4.0.0-dev.5" to clipboard
talker_logger: ^4.0.0-dev.5 copied to clipboard

Logger. Easy, customizable, extensible logging, lightweight with filters, formatters, custom logs, log levels.

example/talker_logger_example.dart

import 'dart:convert';

import 'package:talker_logger/talker_logger.dart';

void main() {
  // Create instance
  final logger = TalkerLogger(
    settings: TalkerLoggerSettings(
      // You can setup custom log level to filter logs
      level: LogLevel.debug,
      // Setup custom colors for log levels
      colors: {
        LogLevel.warning: AnsiPen()..cyan(),
      },
    ),
  );

  // Log messages
  logger.debug('debug');
  logger.info('info');
  logger.warning('warning');
  logger.error('error');
  logger.warning('warning');
  logger.verbose('verbose');
  logger.log('log with level info', level: LogLevel.info);
  logger.log('custom pen log ', pen: AnsiPen()..xterm(49));
  logger.log(
    '''Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.\nUt enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\nDuis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.''',
  );

  const encoder = JsonEncoder.withIndent('  ');
  final prettyData = encoder.convert(
    {
      "widget": {
        "debug": "on",
        "window": {
          "title": "Sample Konfabulator Widget",
          "name": "main_window",
          "width": 500,
          "height": 500,
        },
        "image": {
          "src": "Images/Sun.png",
          "name": "sun1",
          "hOffset": 250,
          "vOffset": 250,
          "alignment": "center",
        },
      },
    },
  );
  logger.log(prettyData, pen: AnsiPen()..xterm(46));
}

// ignore: unused_element
class _ColoredLoggerFormatter implements LoggerFormatter {
  @override
  String fmt(LogDetails details, TalkerLoggerSettings settings) {
    final msg = details.message?.toString() ?? '';
    final coloredMsg =
        msg.split('\n').map((e) => details.pen.write(e)).toList().join('\n');
    return coloredMsg;
  }
}
46
likes
0
pub points
90%
popularity

Publisher

verified publisherfrezycode.com

Logger. Easy, customizable, extensible logging, lightweight with filters, formatters, custom logs, log levels.

Repository (GitHub)
View/report issues

Topics

#logging #console #cli

License

unknown (license)

Dependencies

ansicolor

More

Packages that depend on talker_logger