http_base_client 1.2.0
http_base_client: ^1.2.0 copied to clipboard
A minimalistic http client wrapped around the dart HTTP package.
A minimalistic http client.
Features #
This package simplifies http requests, making it really easy and simple.
NOTE: Since dart:io and Socket connections are not supported in web browsers, the checkInternetConnection getter will ALWAYS return true when the code is compiled to JavaScript (Web). For all other platforms (Mobile and Desktop), the socket-based connection check remains fully functional.
Usage #
import 'package:flutter/material.dart';
import 'package:http_base_client/http_base_client.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Test',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: const MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
const MyHomePage({
super.key,
required this.title,
});
final String title;
@override
State<MyHomePage> createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
String _data = "";
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
),
body: Padding(
padding: const EdgeInsets.all(10.0),
child: SingleChildScrollView(
child: Center(
child: Column(
mainAxisSize: MainAxisSize.min,
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
const SizedBox(
height: 15,
),
const Text(
'Press the button to fetch data',
),
const SizedBox(
height: 25,
),
Text(
_data,
),
],
),
),
),
),
floatingActionButton: FloatingActionButton(
onPressed: _fetchData,
tooltip: 'fetch data',
child: const Icon(Icons.download),
),
);
}
Future _fetchData() async {
/// CHECKING IF THERE IS INTERNET
bool check = await HttpBaseClient.checkInternetConnection;
if (check) {
/// MAKING A GET CALL
var res = await HttpBaseClient.get(
Uri.parse("https://jsonplaceholder.typicode.com/users"),
);
if (res.body.isNotEmpty) {
setState(() {
_data = ObjectConverter.jsonEncode(
ObjectConverter.jsonDecode(res.body),
);
});
}
await Future.delayed(const Duration(seconds: 3));
/// MAKING A POST CALL
Map<String, dynamic> requestBody = {
"title": "foo",
"body": "bar",
"userId": 1,
};
var res2 = await HttpBaseClient.post(
Uri.parse("https://jsonplaceholder.typicode.com/posts"),
requestBody: ObjectConverter.jsonEncode(requestBody),
headers: {
'Content-type': 'application/json; charset=UTF-8',
},
);
if (res2.body.isNotEmpty) {
setState(() {
_data = ObjectConverter.jsonEncode(
ObjectConverter.jsonDecode(res2.body),
);
});
}
}
}
}
Additional information #
If you like this package and find it usefull, please give it a like.