provide 1.0.2
provide: ^1.0.2 copied to clipboard

A simple framework for state management in Flutter. This package contains classes to allow the passing of data down the widget tree.

example/lib/main.dart

// Copyright 2019 The Fuchsia Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

import 'dart:async';

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

void main() {
  // Initialize the model. Can be done outside a widget, like here.
  var counter = Counter();

  // Here we set up a delayed interaction with the model (increment each
  // 5 seconds), outside of the Flutter widget tree.
  //
  // This is just an example. In a real world app, this could be replaced
  // with a connection to a real-time database, for example.
  Timer.periodic(
    const Duration(seconds: 5),
    (timer) => counter.increment(),
  );

  // Set up a Providers instance.
  var providers = Providers();
  providers.provide(Provider<Counter>.value(counter));

  // Now we're ready to run the app...
  runApp(
    // ... and provide the model to all widgets within.
    ProviderNode(
      providers: providers,
      child: MyApp(),
    ),
  );
}

/// Simplest possible model, with just one field.
class Counter extends ChangeNotifier {
  int value = 0;

  void increment() {
    value += 1;
    notifyListeners();
  }
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: MyHomePage(),
    );
  }
}

class MyHomePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Flutter Demo Home Page'),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Text('You have pushed the button this many times:'),
            // Provide looks for an ancestor ProviderNode widget
            // and retrieves its model (Counter, in this case).
            // Then it uses that model to build widgets, and will trigger
            // rebuilds if the model is updated.
            Provide<Counter>(
              builder: (context, child, counter) => Text(
                    '${counter.value}',
                    style: Theme.of(context).textTheme.display1,
                  ),
            ),
          ],
        ),
      ),
      floatingActionButton: FloatingActionButton(
        // Provide.value is another way to access the model object held
        // by an ancestor ProviderNode. By default, it just returns
        // the current model and doesn't automatically trigger rebuilds.
        // Since this button always looks the same, though, no rebuilds
        // are needed.
        onPressed: () => Provide.value<Counter>(context).increment(),
        tooltip: 'Increment',
        child: Icon(Icons.add),
      ),
    );
  }
}
3
likes
80
pub points
86%
popularity

A simple framework for state management in Flutter. This package contains classes to allow the passing of data down the widget tree.

Repository (GitHub)
View/report issues

Documentation

API reference

Uploaders

filiph@google.com
ejia@google.com
redbrogdon@google.com

License

BSD (LICENSE)

Dependencies

flutter

More

Packages that depend on provide