Skip to content

Commit

Permalink
Merge pull request #14 from thila-cs/master
Browse files Browse the repository at this point in the history
support dio v4.0
  • Loading branch information
Milad-Akarie authored Mar 20, 2021
2 parents a36f4d0 + 1446274 commit 9ca6510
Show file tree
Hide file tree
Showing 3 changed files with 27 additions and 27 deletions.
50 changes: 25 additions & 25 deletions lib/pretty_dio_logger.dart
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
import 'dart:async';
import 'dart:math' as math;

import 'package:dio/dio.dart';
Expand Down Expand Up @@ -51,13 +50,13 @@ class PrettyDioLogger extends Interceptor {
this.logPrint = print});

@override
Future onRequest(RequestOptions options) async {
void onRequest(RequestOptions options, RequestInterceptorHandler handler) {
if (request) {
_printRequestHeader(options);
}
if (requestHeader) {
_printMapAsTable(options.queryParameters, header: 'Query Parameters');
final requestHeaders = {};
final requestHeaders = <String, dynamic>{};
requestHeaders.addAll(options.headers);
requestHeaders['contentType'] = options.contentType?.toString();
requestHeaders['responseType'] = options.responseType.toString();
Expand All @@ -68,11 +67,11 @@ class PrettyDioLogger extends Interceptor {
_printMapAsTable(options.extra, header: 'Extras');
}
if (requestBody && options.method != 'GET') {
final data = options.data;
final dynamic data = options.data;
if (data != null) {
if (data is Map) _printMapAsTable(options.data as Map?, header: 'Body');
if (data is FormData) {
final formDataMap = {}
final formDataMap = <String, dynamic>{}
..addEntries(data.fields)
..addEntries(data.files);
_printMapAsTable(formDataMap, header: 'Form data | ${data.boundary}');
Expand All @@ -81,15 +80,14 @@ class PrettyDioLogger extends Interceptor {
}
}
}

return options;
super.onRequest(options, handler);
}

@override
Future onError(DioError err) async {
void onError(DioError err, ErrorInterceptorHandler handler) {
if (error) {
if (err.type == DioErrorType.response) {
final uri = err.response?.request.uri;
final uri = err.response?.requestOptions.uri;
_printBoxed(
header:
'DioError ║ Status: ${err.response?.statusCode} ${err.response?.statusMessage}',
Expand All @@ -104,11 +102,11 @@ class PrettyDioLogger extends Interceptor {
_printBoxed(header: 'DioError ║ ${err.type}', text: err.message);
}
}
return err;
super.onError(err, handler);
}

@override
Future onResponse(Response response) async {
void onResponse(Response response, ResponseInterceptorHandler handler) {
_printResponseHeader(response);
if (responseHeader) {
final responseHeaders = <String, String>{};
Expand All @@ -124,8 +122,7 @@ class PrettyDioLogger extends Interceptor {
logPrint('║');
_printLine('╚');
}

return response;
super.onResponse(response, handler);
}

void _printBoxed({String? header, String? text}) {
Expand All @@ -150,8 +147,8 @@ class PrettyDioLogger extends Interceptor {
}

void _printResponseHeader(Response response) {
final uri = response.request.uri;
final method = response.request.method;
final uri = response.requestOptions.uri;
final method = response.requestOptions.method;
_printBoxed(
header:
'Response ║ $method ║ Status: ${response.statusCode} ${response.statusMessage}',
Expand Down Expand Up @@ -180,8 +177,8 @@ class PrettyDioLogger extends Interceptor {
}

void _printBlock(String msg) {
final int lines = (msg.length / maxWidth).ceil();
for (int i = 0; i < lines; ++i) {
final lines = (msg.length / maxWidth).ceil();
for (var i = 0; i < lines; ++i) {
logPrint((i >= 0 ? '║ ' : '') +
msg.substring(i * maxWidth,
math.min<int>(i * maxWidth + maxWidth, msg.length)));
Expand All @@ -197,15 +194,15 @@ class PrettyDioLogger extends Interceptor {
bool isLast = false,
}) {
var _tabs = tabs;
final bool isRoot = _tabs == initialTab;
final isRoot = _tabs == initialTab;
final initialIndent = _indent(_tabs);
_tabs++;

if (isRoot || isListItem) logPrint('║$initialIndent{');

data.keys.toList().asMap().forEach((index, key) {
data.keys.toList().asMap().forEach((index, dynamic key) {
final isLast = index == data.length - 1;
var value = data[key];
dynamic value = data[key];
if (value is String) {
value = '"${value.toString().replaceAll(RegExp(r'(\r|\n)+'), " ")}"';
}
Expand All @@ -229,8 +226,8 @@ class PrettyDioLogger extends Interceptor {
final indent = _indent(_tabs);
final linWidth = maxWidth - indent.length;
if (msg.length + indent.length > linWidth) {
final int lines = (msg.length / linWidth).ceil();
for (int i = 0; i < lines; ++i) {
final lines = (msg.length / linWidth).ceil();
for (var i = 0; i < lines; ++i) {
logPrint(
'║${_indent(_tabs)} ${msg.substring(i * linWidth, math.min<int>(i * linWidth + linWidth, msg.length))}');
}
Expand All @@ -244,7 +241,7 @@ class PrettyDioLogger extends Interceptor {
}

void _printList(List list, {int tabs = initialTab}) {
list.asMap().forEach((i, e) {
list.asMap().forEach((i, dynamic e) {
final isLast = i == list.length - 1;
if (e is Map) {
if (compact && _canFlattenMap(e)) {
Expand All @@ -259,7 +256,9 @@ class PrettyDioLogger extends Interceptor {
}

bool _canFlattenMap(Map map) {
return map.values.where((val) => val is Map || val is List).isEmpty &&
return map.values
.where((dynamic val) => val is Map || val is List)
.isEmpty &&
map.toString().length < maxWidth;
}

Expand All @@ -270,7 +269,8 @@ class PrettyDioLogger extends Interceptor {
void _printMapAsTable(Map? map, {String? header}) {
if (map == null || map.isEmpty) return;
logPrint('╔ $header ');
map.forEach((key, value) => _printKV(key.toString(), value));
map.forEach(
(dynamic key, dynamic value) => _printKV(key.toString(), value));
_printLine('╚');
}
}
2 changes: 1 addition & 1 deletion pubspec.lock
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ packages:
name: dio
url: "https://pub.dartlang.org"
source: hosted
version: "4.0.0-beta6"
version: "4.0.0-prev1"
http_parser:
dependency: transitive
description:
Expand Down
2 changes: 1 addition & 1 deletion pubspec.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,4 @@ environment:
sdk: ">=2.12.0 <3.0.0"

dependencies:
dio: ">=4.0.0-beta <=5.0.0"
dio: ">=4.0.0-prev1 <=5.0.0"

0 comments on commit 9ca6510

Please sign in to comment.