reactive_notifier 2.10.5  reactive_notifier: ^2.10.5 copied to clipboard
reactive_notifier: ^2.10.5 copied to clipboard
Efficient Dart state management with MVVM-inspired ViewModels & Notifiers. Offers fine-grained control for reactive, complex, and interconnected states.
2.10.4 #
Listen and Initialization #
- callOnInitimplemented for- listenand- listenVM, for execute function on init instance.
- onResumeCalled after the ViewModel's primary initialization
2.10.0 #
π οΈ ViewModel State Enhancements #
- Introduced transformDataStatefor modifying the data within a success state and notifying listeners.
- Introduced transformDataStateSilentlyfor modifying the data within a success state without notifying listeners.
- initnow init es default form of initialization.
- builder,- onSucessoptional.
- onDataoptional and more.
2.9.0 #
π Reactive State Management #
π Enhancements #
- Introduced ReactiveFutureBuilderfor seamless data loading without flickering
- Enhanced navigation experience with persistent state between screens
- Optimized memory usage by avoiding redundant rebuilds
- Improved UI responsiveness with immediate data display
- Streamlined integration with existing ReactiveNotifier system
π New Features #
- Added ReactiveFutureBuilder<T>widget with automatic state persistence
- Implemented defaultDataparameter for flickerless navigation
- Added reactive notifier integration via createStateNotifierparameter
- Introduced state update control with notifyChangesFromNewStateflag
- Enhanced error and loading state handling with customizable builders
- Added comprehensive documentation with usage examples
- New listener API:
- listen()allows directly listening to the main- ReactiveNotifierstate, ideal for simple types like- String,- int, or plain models.
- listenVM()enables listening to complex state objects like ViewModels inside the- ReactiveNotifier.notifier, managing their internal lifecycle properly.
- These additions improve fine-grained reactivity and reduce boilerplate when dealing with nested logic.
 
π Bug Fixes #
- Fixed UI flickering when navigating back to previously loaded screens
- Resolved state loss issues during navigation transitions
- Fixed race conditions between default data and async data loading
- Modified AsyncViewModelImplto support nullable data types, enabling safer initialization validation
- Added proper null checks to prevent errors during state updates
- Improved type safety with stronger null handling throughout the reactive system
π» Developer Experience #
- Simplified state management code for async operations
- Reduced boilerplate when implementing loading/success/error states
- Improved code readability with clear separation of UI and data concerns
- Added type safety with generic parameter support
2.8.1 #
- Update documentation
- Comment format
2.8.0 #
π§ ViewModel Listeners #
π Enhancements #
- Introduced formal ViewModel Lifecycle management through the new Listeners system
- Added automatic listener registration and cleanup tied to ViewModel lifecycle
- Enhanced debugging experience with formatted listener logs
- Optimized memory management by preventing listener leaks
- Improved separation of UI and business logic with centralized reactivity
π New Features #
- Added setupListeners()method for registering reactive dependencies
- Added removeListeners()method for automatic cleanup
- Implemented hasInitializedListenerExecutionguard for preventing premature updates
- Integrated listeners with existing lifecycle events (dispose, reload, cleanState)
- Added debug logging system for monitoring listener activity
π§Ή Code Quality #
- Improved memory management with automatic listener cleanup
- Enhanced predictability by centralizing reactive code
- Reduced widget complexity by moving reactivity to ViewModels
- Better separation of concerns between UI and business logic
π Documentation #
- Added comprehensive examples for implementing ViewModel Listeners
- Updated best practices for reactive programming in Flutter
- Included debugging tips for listener management
- Expanded API reference with new listener-related methods
2.7.4 #
- loadNotifierfor- AsyncViewModelImpl.
2.7.3 #
- Export complete api π .
2.7.2 #
- Expose AsyncViewModelImpl
2.7.1 #
- Update documentation
2.7.0 #
Breaking Changes π¨ #
- Strict implementation of ViewModel patterns for state management
- Updated ReactiveViewModelBuilder to work exclusively with ViewModel
- Enforced proper mixin-based architecture for state organization
- Improved related states handling with cleaner dependency management
π Enhancements #
- Enhanced ViewModel lifecycle management with detailed logging
- Added cleanState()as the recommended approach instead of full dispose
- Improved error detection for circular references and state dependencies
- Comprehensive diagnostic logging for all lifecycle events
- More granular control over rebuilds with optimized keep functionality
- Efficient cross-module communication with direct state updates
π New Features #
- Added loadNotifier()method for explicit initialization of ViewModels at app startup
- Added updateSilently()for state changes without triggering UI rebuilds
- Added transformStateSilently()for granular model updates without notifications
- Enhanced ReactiveStreamBuilder with more comprehensive stream state handling
- Expanded debugging tools with detailed instance tracking
π§Ή Code Quality #
- Improved type safety across all components
- Better error messages with actionable recommendations
- Repository pattern integration with dependency injection support
- Enhanced testing support with simplified mocking approach
π Documentation #
- Complete architecture examples with feature-based MVVM structure
- Improved examples for cross-module communication
- Expanded API reference with best practices for this library
- Better guidance for performance optimization
2.6.3 #
- transformStateSilentlyfor Viewmodel and ReactiveNotifier.
2.6.2 #
- updateSilentlyfor Simple reactiveNotifiers and- loadNotifierfor first initialization.
2.6.1 #
- Added mounted check in _valueChanged() method to prevent "setState() called after dispose()" errors when asynchronous notifications arrive after widget removal from the tree.
π Bug Fixes #
- where ReactiveViewModelBuildercould attempt to update no longer available widgets, causing runtime exceptions, especially during integration tests.
- Improved lifecycle management of listeners to prevent memory leaks and unexpected behaviors.
2.6.0 #
- Added new ViewModel<T>abstract class with robust lifecycle management, automatic reinitialization, and detailed diagnostic logging.
- Implemented ReactiveNotifierViewModel<VM, T>to better encapsulate ReactiveNotifier's singleton management with ViewModels.
- Added auto-dispose functionality to clean up resources automatically when a ViewModel is no longer in use.
- Enhanced ReactiveViewModelBuilderto support both traditionalStateNotifierImpland new ViewModel pattern.
- Implemented cleanCurrentNotifier(),cleanupInstance(), and cleanupByType()methods to provide granular control over instance cleanup.
- Added detailed error messages for ViewModel initialization, disposal, and state updates.
- Improved debugging with instance tracking, performance analytics, and detailed state change logging.
- Added comprehensive validations and safeguards to prevent state inconsistencies.
- Remove debounceon builder.
2.5.2 #
- Implement updateSilentlyonAsyncViewModelImpl.
- Format, etc.
2.5.1 #
- Implement transformStateonAsyncViewModelImplandgetStateByKeyfor ReactiveNotifier.
- Format, etc.
2.5.0 #
- Implement ReactiveViewModelBuilderfor complex state management.
2.4.2 #
- Some dart format.
2.4.1 #
- Update name of state and documentation for StateNotifierImpl.
2.4.0 #
Breaking Changes π¨ #
- 
Introducing transformStatefunction for model editing, allowing state modifications at any nesting level. This function supports implementations likecopyWith, enabling selective value updates in your models.
- 
Simplified state management: unified notifierand VM into a single approach usingReactiveBuilder,ReactiveAsync, andReactiveStream. Access functions directly through notifier reference (e.g.,instance.notifier.replaceData(...)). AccessReactiveAsyncdata vianotifier.data.
- 
Removed ValueNotifiervalue dependency, eliminating nested state update issues (previouslyinstance.value.value, nowinstance.data).
- 
Protected internal builder functions for improved encapsulation. 
- 
Maintained compatibility with ListenableBuilderforReactiveNotifier.
- 
Removed contextdependency from builder asReactiveNotifierdoesn't require it.
Best Practices #
- Recommend using mixins to store related Notifiers, avoiding global variables and maintaining proper context encapsulation.
2.3.1 #
- Update documentation.
- Protected value for NotifierImpl.
2.3.0 #
π Enhancements #
- Added support for direct access to ReactiveNotifier value and simple state management
- New constructor ReactiveBuilder.notifierfor simpler state cases
- Improved type safety and handling of ViewModelState implementations
π¨ Usage Changes #
- For ViewModels/Complex States:
ReactiveBuilder( notifier: stateConnection.value, builder: (context, state, keep) => YourWidget() )
- For Simple States:
ReactiveBuilder.notifier( notifier: simpleNotifier, builder: (context, value, keep) => YourWidget() )
π Bug Fixes #
- Fixed state propagation in complex ViewModelState scenarios
- Improved debouncing mechanism for state updates
- Better memory management for kept widgets
π Documentation #
- Added examples for both ViewModelState and simple state usage
- Updated documentation to reflect new constructor patterns
- Improved comments and code documentation
ποΈ Internal Changes #
- Refactored internal state handling for better performance
- Optimized rebuilding patterns for kept widgets
- Enhanced type safety across the implementation
π¦ Dependencies #
- No changes in dependencies
π Migration Guide #
No breaking changes. Existing code will continue to work as expected. The new .notifier constructor is additive and optional for simpler state management cases.
2.2.1 #
- Update example and doc on readme.
2.2.0 #
- Update documentations and images.
- Implement Ci for actions.
2.1.1 #
- Update Readme.
2.1.0 #
- Few bits, and name convention
- New ViewModelStateImplfor simple viewmodel state.
2.0.0 #
Breaking Changes π¨ #
- Complete project architecture overhaul
- New reference handling system
- Changed how related states are managed
New Features π #
- 
Enhanced Debugging System - Improved error messages
- Better stack traces
- Detailed circular reference detection
 
- 
Advanced State Management - Support for nested ReactiveNotifier instances in related states
- Improved multiple reference handling
- Better state isolation and context management
 
- 
Async & Stream Support - Built-in async state handling
- Stream state management
- Automatic state synchronization
 
- 
Extended Testing Support - More test cases
- Better coverage
- Improved testing utilities
 
Improvements π§ #
- Better performance in state updates
- Reduced memory footprint
- Improved type safety
- Enhanced error handling
- Better documentation
Bug Fixes π #
- Fixed issues with circular references
- Improved state cleanup
- Better error reporting
- Fixed memory leaks in complex state trees
Documentation π #
- Complete documentation overhaul
- New examples and use cases
- Better API documentation
- Improved error messages
1.0.5 #
- Update documentation.
1.0.4 #
- Implement when and callback when finish setState.
- Help to execute any other params when change state
1.0.3 #
- Upgrade SDK.
1.0.2 #
- Add gif for visual context.
- Change name from StatetoNotify.
- Update golden test.
1.0.1 #
- Change name from StatetoNotify.
- Improve README.md.
1.0.0 #
- Initial version.