@storeon/angular
A tiny event-based Redux-like state manager Storeon for Angular.
Online Demo | Demo with Angular Ivy
It is just 533 bytes (minified and gzipped) Angular module. It uses Size Limit to control size.
Read more about Storeon article.
How to use
import * as createStore from 'storeon'
import * as devTools from 'storeon/devtools';
export interface State {
count: number
}
let increment = (store: createStore.Store<State>) => {
store.on('@init', () => ({ count: 0 }))
store.on('inc', ({ count }) => ({ count: count + 1 }))
}
export const store = createStore([increment, !environment.production && devTools])
import { NgStoreonModule, STOREON } from '@storeon/angular';
@NgModule({
imports: [NgStoreonModule],
...
providers: [{
provide: STOREON,
useValue: store
}],
...
import { Component, OnInit } from '@angular/core';
import { NgStoreonService } from '@storeon/angular';
import { State } from './app.module';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.scss']
})
export class AppComponent implements OnInit {
changes: Observable<number>;
constructor(private ngstoreon: NgStoreonService<State>) { }
title = 'storeon-angular';
ngOnInit() {
this.changes = this.ngstoreon.useStoreon('count');
}
updateState() {
this.ngstoreon.dispatch('inc');
}
}