http_solver
A package help you to make api call and handle error faster, also you can check for internet before call api.
Make your model
BaseModelForHttpSolver is a abstract class, your model should implements it.
class YourModel implements BaseModelForHttpSolver{}
Get data from your api
getFromApi static method take YourModel and your Api url and return Future and it is have some option parameter checkInternet, headers for Api.
YourModel dataInModel = await HttpSolver.getFromApi(YourModel(), apiUrl, checkInternet: true);
Post to api
getFromApi static method take YourModel and your Api url and return Future and it is have some option parameter checkInternet, headers for Api.
YourModel dataInModel = await HttpSolver.postToApi(YourModel(), apiUrl,body: body , checkInternet: true);
convert model to either
toEither() extension on Future to handle all error and return Either<Failure, YourModel>.
Future<YourModel> dataInModel = HttpSolver.getFromApi(YourModel(), apiUrl, checkInternet: true); Either<Failure, YourModel> modelOrError= dataInModel.toEither();
Using Either With UI
modelOrError.fold((failure) => Text("${failure.message}"), //if has error show Text with failure message
(model) => Text(post.title)), //else show Text data
Full Example
import 'dart:collection';
import 'dart:convert';
import 'package:flutter/material.dart';
import 'package:http_solver/http_solver.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: HomePage(),
);
}
}
class HomePage extends StatefulWidget {
Either<Failure, Post> _data;
final url = "http://www.mocky.io/v2/5e3c29393000009c2e214bf8";
@override
_HomePageState createState() => _HomePageState();
}
class _HomePageState extends State<HomePage> {
@override
Widget build(BuildContext context) {
return Scaffold(
floatingActionButton:
FloatingActionButton(onPressed: _getEither, child: Text('Get')),
body: Center(
child: (widget._data == null)
? Text('No Data Yet')
: widget._data.fold((failure) => Text("${failure.message}"),
(post) => Text(post.title)),
));
}
void _getEither() async {
widget._data = await HttpSolver.getFromApi(Post(), widget.url, checkInternet: true).toEither();
setState(() {});
}
}
class Post implements BaseModelForHttpSolver {
final int id;
final int userId;
final String title;
final String body;
Post({
this.id,
this.userId,
this.title,
this.body,
});
Post fromJson(String source) {
Map<String, dynamic> jsonData = (json.decode(source));
if (jsonData == null) return null;
return Post(
id: jsonData['id'],
userId: jsonData['userId'],
title: jsonData['title'],
body: jsonData['body'],
);
}
@override
Map<String, dynamic> toJson() {
final Map<String, dynamic> data = HashMap<String, dynamic>();
data['id'] = this.id;
data['userId'] = this.userId;
data['title'] = this.title;
data['body'] = this.body;
return data;
}
}
Download Flutter http solver package source code on GitHub
https://github.com/AbdOoSaed/http_solver
Provides the list of the opensource Flutter apps collection with GitHub repository.

