Persist ngrx state to localStorage / sessionStrage
npm i ngrx-browser-storage-store
npm install
ng build --project ngrx-browser-storage-store
ng build --project ngrx-browser-storage-store-demo
ng serve
To inject 'middleware' meta reducers, use the META_REDUCERS
injection token exported in the @ngrx/store
API and a Provider
to register the meta reducers through dependency injection.
import { MetaReducer, META_REDUCERS } from '@ngrx/store';
import {
BrowserStorage,
BrowserStorageModule,
BrowserStorageMetaReducerLoader,
} from 'ngrx-browser-storage-store';
import * as fromRoot from './reducers';
export function metaReducerFactory(bsLoader: BrowserStorageMetaReducerLoader): MetaReducer<fromRoot.State> {
return bsLoader.get<fromRoot.State>();
}
@NgModule({
imports: [
// The options object is optional. If you do not provide options, the default values are used.
BrowserStorageModule.forRoot({
storage: BrowserStorage.SessionStorage // default: BrowserStorage.LocalStorage
}),
StoreModule.forRoot(reducers),
],
providers: [
{
provide: META_REDUCERS,
deps: [BrowserStorageMetaReducerLoader],
useFactory: metaReducerFactory,
multi: true,
},
],
})
export class AppModule {}
import { StoreModule, StoreConfig } from '@ngrx/store';
import {
BrowserStorage,
BrowserStorageModule,
BrowserStorageMetaReducerLoader,
} from 'ngrx-browser-storage-store';
import * as fromCounter from './store/reducers/counter.reducer';
export const COUNTER_FEATURE_CONFIG = new InjectionToken<StoreConfig<fromCounter.ICounterState>>('Counter Feature Config');
export function getCounterFeatureConfig(bsLoader: BrowserStorageMetaReducerLoader): StoreConfig<fromCounter.ICounterState> {
return {
metaReducers: [
bsLoader.get<fromCounter.ICounterState>()
]
};
}
@NgModule({
imports: [
BrowserStorageModule.forFeature(fromCounter.counterFeatureKey, {
storage: BrowserStorage.SessionStorage,
}),
StoreModule.forFeature(fromCounter.counterFeatureKey, fromCounter.reducer, COUNTER_FEATURE_CONFIG),
],
providers: [
{
provide: COUNTER_FEATURE_CONFIG,
deps: [BrowserStorageMetaReducerLoader],
useFactory: getCounterFeatureConfig,
},
],
})
export class CounterModule {}
You could save your state to localStorage / sessionStorage via @ngrx/effects
import { Injectable } from '@angular/core';
import { Actions } from '@ngrx/effects';
import { BrowserStorageEffects } from 'ngrx-browser-storage-store';
import { ICounterState } from '../reducers/counter.reducer';
import { selectCounterState } from '../selectors/counter.selectors';
@Injectable()
export class CounterEffects {
saveToLocalStorage$ = this.browserStorageEffects.saveForFeature(
this.actions$,
selectCounterState
);
constructor(
private actions$: Actions,
private browserStorageEffects: BrowserStorageEffects<ICounterState>
) {}
}
Take a look into the ngrx-browser-storage-store-demo
application
Licensed to Apache-2.0