Skip to content

musiolmarco/msl_fetcher

Repository files navigation

msl_fetcher 🌐

With msl_fetcher you can fetch and handle data easily. Handle all states (Loading, Error, Data available) within a minute.🕚

Getting started 🚀

Add this lines to your pubspec.yaml dependencies:

dependencies:
  msl_fetcher: <Newest version>

Setup your own default widgets (optional) 👷

void main() {

  MslFetcher.setup(
    defaultErrorWidget: (error, onRefresh) => const Text('An error has occured...'),
    defaultLoadingWidget: const CircularProgressIndicator(),
  );

  runApp(const MyApp());
}

You can use the MslFetcher.setup() method in the void main() method to setup your own default widgets. This widgets will be displayed by default if you don't provide any other widgets into the MslFetcher().

Fetching, displaying data & handling states 🗂

The main Widget of this package is the MslFetcher widget.

MslFetcher<List<Todo>>(
            showErrorLogs: true,
            fetchData: () => _todosRepository.getExampleTodosFromApi(),
            dataAvailableWidget: (List<Todo> availableData, onRefresh) => TodoListView(
              todos: availableData,
            ),
            fetchingErrorWidget: (error, onRefresh) =>
                const Text('Error while fetching...'),
            loadingWidget: const Text('Loading...'),
          ),

Important ❗️

The fetchingErrorWidget and loadingWidget widgets are optional. If you wont pass them it will use the default widgets of the package.

fetchData 📂

This method should fetch & return the available data coming from the backend. It is important that it matches the generic from the MslFetcher. In this case it's <List<Todo>>.

dataAvailableWidget ⬇️

This Widget is displayed if the data is fetched and returned. You can access the downloaded data by the availableData. It also returns the onRefresh method. With it you can refresh the fetch if necessary. This can be useful if you add some data to your database and refetch it for example.

fetchingErrorWidget ⚠️

This Widget is displayed if there was an error while fetching and returning the data. Here you can for example display an error message that says "An error occured. Please try again". You can also use the error Object if you want to handle something based on what error has been catched. The onRefresh method makes it available to redo the fetching process if you want to implement a "try again" button for example.

loadingWidget 🕑

This Widget is displayed while the data is being fetched.

Other parameters ⚒

Here you can find a code snipped from the source code that explains everything you can pass into the MslFetcher widget.

  /// The method that fetches and returns the data
  final Future<T> Function() fetchData;

  /// This [Widget] is displayed while the data is being fetched
  final Widget? loadingWidget;

  /// This [Widget] is displayed if the data is available
  ///
  /// [availableData] is the data that got fetched from the backend
  ///
  /// [onRefresh] is the method that will refresh the fetching.
  /// This can be used if you add some data and watch to refetch the data.
  final Widget Function(
    T availableData,
    VoidCallback onRefresh,
  ) dataAvailableWidget;

  /// Tis [Widget] is displayed if there was an error while fetching the data
  ///
  /// [error] is the [Object] that got catched by the [MslFetcherProvider]
  ///
  /// [onRefresh] is the function that will redo the fetch again
  final Widget Function(
    Object error,
    VoidCallback onRefresh,
  )? fetchingErrorWidget;

  /// Pass [showErrorLog] as true if you want to log errors into the console
  final bool? showErrorLogs;