rx_observable 0.5.6 rx_observable: ^0.5.6 copied to clipboard
Simple reactive variables and widgets. Ideal to use with MVVM like patterns.
import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart';
import 'package:rx_observable/rx_observable.dart';
import 'package:rx_observable/widgets.dart';
import 'example_screen.dart';
void main() {
// All constructors gives the same result
var test1 = Observable(25);
var test2 = Observable<int>(25);
var test3 = Obs(25);
var test4 = 25.obs;
var test5 = ObservableInt(25);
var test6 = ObservableReadOnly(25); /// You can only read this value
test1.close();
test2.close();
test3.close();
test4.close();
test5.close();
test6.close();
runApp(const ExampleApp());
}
class ExampleApp extends StatefulWidget {
const ExampleApp({super.key});
@override
State<ExampleApp> createState() => _ExampleAppState();
}
class _ExampleAppState extends State<ExampleApp> {
var test1 = Observable(25);
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Rx Observable Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
/// Listen observable without UI updating
/// Also see ObservableConsumer widget to get both
home: ObservableListener(
observable: test1,
listener: (v, context) {
if (kDebugMode) { print(v); }
},
/// See other examples on [ExampleScreen]
child: const ExampleScreen()
),
);
}
}