talker_rhttp_logger 0.0.4 talker_rhttp_logger: ^0.0.4 copied to clipboard
A Flutter package for logging HTTP requests and responses using Talker.
import 'package:flutter/material.dart';
import 'package:rhttp/rhttp.dart';
import 'package:talker_flutter/talker_flutter.dart';
import 'package:talker_rhttp_logger/talker_rhttp_logger.dart';
void main() async {
await Rhttp.init();
runApp(const MainApp());
}
class MainApp extends StatelessWidget {
const MainApp({super.key});
@override
Widget build(BuildContext context) {
return const MaterialApp(
home: RhttpLoggerUi(),
);
}
}
class RhttpLoggerUi extends StatefulWidget {
const RhttpLoggerUi({super.key});
@override
State<RhttpLoggerUi> createState() => _RhttpLoggerUiState();
}
class _RhttpLoggerUiState extends State<RhttpLoggerUi> {
late RhttpClient rhttpClient;
String response = '';
@override
void dispose() {
rhttpClient.dispose();
super.dispose();
}
@override
void initState() {
rhttpClient = RhttpClient.createSync(
interceptors: [
TalkerRhttpLogger(
talker: TalkerFlutter.init(),
settings: const TalkerRhttpLoggerSettings(
printRequestHeaders: true,
printResponseHeaders: true,
),
)
],
);
super.initState();
fetchComments();
}
Future<String> getComments() async {
final response = await rhttpClient.get('https://httpstat.us/204',
headers: const HttpHeaders.rawMap({
'Accept': 'application/json',
}));
return response.body;
}
Future<void> fetchComments() async {
try {
final result = await getComments();
setState(() {
response = result.isEmpty ? "No Data" : result.toString();
});
} catch (e) {
setState(() {
response = 'Error: ${e.toString()}';
});
}
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('Rhttp Logger UI'),
),
body: Center(
child: response.isEmpty
? const CircularProgressIndicator()
: SingleChildScrollView(
padding: const EdgeInsets.all(16),
child: Text(response),
),
),
);
}
}