0.6.4 • Published 2 years ago
rxo-state v0.6.4
RXO-STATE
Observable state management using RxJs.
Install
npm install rxo-stateUsage
Create a new state by extending RxoState abstract class
RxoState requires an initial state upon instantiation and an implementation for the mutate method.
export class MyState extends RxoState<{test: boolean}> {
    constructor() {
        super({test: true})
    }
    mutate(mutation:Mutation<boolean>): void {
        if(mutation.action === 'change') {
            this.next(mutation.data);
            this.emit("some-event", mutation.data);     // optional event emission
        }
        ...
    }
}View current state value
const value = state.peek();Observe changes to state
const subscription = state.observe().subscribe((value) => {
    console.log(value);
});
subscription.unsubscribe();   // unsubscribe from subscriptionMutate the state
state.mutate({
    action: "change",
    data: {
        test: true
    }
});Listen for events emitted by mutators
state.listen("some-event", (value) => {
    console.log(value);
});Emit an event from a mutator
Events can be emitted from the subclass of RxoState by call the emit method.
this.emit("some-event", mutation.data);Reset the state to the initial value it was created with
The
resetmethod will always emit theRXO_RESETevent with the initial state as its value.
state.reset()Listen for the RXO_RESET event
state.listen(RXO_RESET, (value) => {
    console.log(value);
});Listen for a custom event
state.listen("some-event", (value) => {
    console.log(value);
});Execute a function whenever state changes
const subscription = state.signal((value => {
    console.log(value);
}));
subscription.unsubscribe();   // unsubscribe from subscriptionUpdate Angular signal on state change
@Component({
    selector: 'app-root',
    template: `{{mySignal()}}`,
    ...
})
export class AppComponent implements OnInit, OnDestroy {
    public mySignal: signal(0);
    private subscription: Subscription;
    constructor(private state: MyRxoState) {}
    ngOnInit() {
        this.subscription = this.state.signal(signal.set);
    }
    ngOnDestroy() {
        this.subscription.unsubscribe();
    }
}0.6.4
2 years ago
0.6.3
2 years ago
0.6.2
2 years ago
0.6.1
2 years ago
0.6.0
2 years ago
0.5.1
2 years ago
0.5.0
2 years ago
0.4.10
2 years ago
0.4.9
2 years ago
0.4.8
2 years ago
0.4.7
2 years ago
0.4.6
2 years ago
0.4.5
2 years ago
0.4.4
2 years ago
0.4.3
2 years ago
0.4.1
2 years ago
0.4.0
2 years ago
0.3.1
2 years ago
0.3.0
2 years ago
0.2.0
2 years ago