fetcher 3.0.0 copy "fetcher: ^3.0.0" to clipboard
fetcher: ^3.0.0 copied to clipboard

Flutter package to Fetch and display asynchronous data easily

example/lib/main.dart

import 'package:flutter/material.dart';
import 'package:fetcher/fetcher.dart';

import 'pages/fetch_builder.page.dart';
import 'pages/submit_builder.page.dart';
import 'pages/submit_form_builder.page.dart';
import 'pages/event_fetch_builder.page.dart';
import 'pages/async_edit_builder.page.dart';
import 'pages/paged_fetcher_page.dart';

void main() {
  runApp(const MyApp());
}

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return DefaultFetcherConfig(
      config: FetcherConfig(
        fetchingBuilder: (context) => const Center(child: CircularProgressIndicator(color: Colors.red)),
        onDisplayError: (context, error) => ScaffoldMessenger.of(context).showSnackBar(SnackBar(
          content: Text(error.toString()),
          backgroundColor: Colors.red,
        )),
      ),
      child: MaterialApp(
        title: 'Fetcher Example',
        theme: ThemeData(
          primarySwatch: Colors.blue,
        ),
        home: const MyHomePage(),
      ),
    );
  }
}

class MyHomePage extends StatefulWidget {
  const MyHomePage({super.key});

  @override
  State<MyHomePage> createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  int currentPageIndex = 0;

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('Fetcher Example'),
      ),
      bottomNavigationBar: NavigationBar(
        onDestinationSelected: (int index) {
          setState(() {
            currentPageIndex = index;
          });
        },
        selectedIndex: currentPageIndex,
        destinations: const <Widget>[
          NavigationDestination(
            icon: Icon(Icons.download),
            label: 'Fetch',
          ),
          NavigationDestination(
            icon: Icon(Icons.keyboard_double_arrow_down),
            label: 'Event',
          ),
          NavigationDestination(
            icon: Icon(Icons.upload),
            label: 'Submit',
          ),
          NavigationDestination(
            icon: Icon(Icons.edit_document),
            label: 'Form',
          ),
          NavigationDestination(
            icon: Icon(Icons.sync),
            label: 'Edit',
          ),
          NavigationDestination(
            icon: Icon(Icons.numbers),
            label: 'Paged',
          ),
        ],
      ),
      body: <Widget>[
        const FetchBuilderPage(),
        const EventFetchBuilderPage(),
        const SubmitBuilderPage(),
        const SubmitFormBuilderPage(),
        const AsyncEditBuilderPage(),
        const PagedFetcherPage(),
      ][currentPageIndex],
    );
  }
}
5
likes
0
points
1.71k
downloads

Publisher

verified publishericysun.fr

Weekly Downloads

Flutter package to Fetch and display asynchronous data easily

Repository (GitHub)
View/report issues

License

unknown (license)

Dependencies

flutter, value_stream

More

Packages that depend on fetcher