UNPKG

@angular-redux/store

Version:
142 lines 14.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { applyMiddleware, compose, createStore, } from 'redux'; import { NgZone } from '@angular/core'; import { BehaviorSubject, Observable } from 'rxjs'; import { distinctUntilChanged, filter, map, switchMap } from 'rxjs/operators'; import { assert } from '../utils/assert'; import { enableFractalReducers } from './fractal-reducer-map'; import { NgRedux } from './ng-redux'; import { resolveToFunctionSelector, } from './selectors'; import { SubStore } from './sub-store'; /** * @hidden * @template RootState */ var /** * @hidden * @template RootState */ RootStore = /** @class */ (function (_super) { tslib_1.__extends(RootStore, _super); function RootStore(ngZone) { var _this = _super.call(this) || this; _this.ngZone = ngZone; _this.store = undefined; _this.configureStore = function (rootReducer, initState, middleware, enhancers) { if (middleware === void 0) { middleware = []; } if (enhancers === void 0) { enhancers = []; } assert(!_this.store, 'Store already configured!'); // Variable-arity compose in typescript FTW. _this.setStore(compose.apply(void 0, tslib_1.__spread([applyMiddleware.apply(void 0, tslib_1.__spread(middleware))], enhancers))(createStore)(enableFractalReducers(rootReducer), initState)); }; _this.provideStore = function (store) { assert(!_this.store, 'Store already configured!'); _this.setStore(store); }; _this.getState = function () { return (/** @type {?} */ (_this.store)).getState(); }; _this.subscribe = function (listener) { return (/** @type {?} */ (_this.store)).subscribe(listener); }; _this.replaceReducer = function (nextReducer) { (/** @type {?} */ (_this.store)).replaceReducer(nextReducer); }; _this.dispatch = function (action) { assert(!!_this.store, 'Dispatch failed: did you forget to configure your store? ' + 'https://github.com/angular-redux/platform/blob/master/packages/store/' + 'README.md#quick-start'); if (!NgZone.isInAngularZone()) { return _this.ngZone.run(function () { return (/** @type {?} */ (_this.store)).dispatch(action); }); } else { return (/** @type {?} */ (_this.store)).dispatch(action); } }; _this.select = function (selector, comparator) { return _this.store$.pipe(distinctUntilChanged(), map(resolveToFunctionSelector(selector)), distinctUntilChanged(comparator)); }; _this.configureSubStore = function (basePath, localReducer) { return new SubStore(_this, basePath, localReducer); }; _this.storeToObservable = function (store) { return new Observable(function (observer) { observer.next(store.getState()); /** @type {?} */ var unsubscribeFromRedux = store.subscribe(function () { return observer.next(store.getState()); }); return function () { unsubscribeFromRedux(); observer.complete(); }; }); }; NgRedux.instance = _this; _this.store$ = (/** @type {?} */ (new BehaviorSubject(undefined).pipe(filter(function (n) { return n !== undefined; }), switchMap(function (observableStore) { return (/** @type {?} */ (observableStore)); })))); return _this; } /** * @private * @param {?} store * @return {?} */ RootStore.prototype.setStore = /** * @private * @param {?} store * @return {?} */ function (store) { this.store = store; /** @type {?} */ var storeServable = this.storeToObservable(store); this.store$.next((/** @type {?} */ (storeServable))); }; return RootStore; }(NgRedux)); /** * @hidden * @template RootState */ export { RootStore }; if (false) { /** * @type {?} * @private */ RootStore.prototype.store; /** * @type {?} * @private */ RootStore.prototype.store$; /** @type {?} */ RootStore.prototype.configureStore; /** @type {?} */ RootStore.prototype.provideStore; /** @type {?} */ RootStore.prototype.getState; /** @type {?} */ RootStore.prototype.subscribe; /** @type {?} */ RootStore.prototype.replaceReducer; /** @type {?} */ RootStore.prototype.dispatch; /** @type {?} */ RootStore.prototype.select; /** @type {?} */ RootStore.prototype.configureSubStore; /** * @type {?} * @private */ RootStore.prototype.storeToObservable; /** * @type {?} * @private */ RootStore.prototype.ngZone; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"root-store.js","sourceRoot":"ng://@angular-redux/store/","sources":["components/root-store.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AnyAction,\n  applyMiddleware,\n  compose,\n  createStore,\n  Dispatch,\n  Middleware,\n  Reducer,\n  Store,\n  StoreCreator,\n  StoreEnhancer,\n  Unsubscribe,\n} from 'redux';\n\nimport { NgZone } from '@angular/core';\nimport { BehaviorSubject, Observable, Observer } from 'rxjs';\nimport { distinctUntilChanged, filter, map, switchMap } from 'rxjs/operators';\nimport { assert } from '../utils/assert';\nimport { enableFractalReducers } from './fractal-reducer-map';\nimport { NgRedux } from './ng-redux';\nimport { ObservableStore } from './observable-store';\nimport {\n  Comparator,\n  PathSelector,\n  resolveToFunctionSelector,\n  Selector,\n} from './selectors';\nimport { SubStore } from './sub-store';\n\n/** @hidden */\nexport class RootStore<RootState> extends NgRedux<RootState> {\n  private store: Store<RootState> | undefined = undefined;\n  private store$: BehaviorSubject<RootState>;\n\n  constructor(private ngZone: NgZone) {\n    super();\n\n    NgRedux.instance = this;\n    this.store$ = new BehaviorSubject<RootState | undefined>(undefined).pipe(\n      filter(n => n !== undefined),\n      switchMap(observableStore => observableStore as any),\n      // TODO: fix this? needing to explicitly cast this is wrong\n    ) as BehaviorSubject<RootState>;\n  }\n\n  configureStore = (\n    rootReducer: Reducer<RootState, AnyAction>,\n    initState: RootState,\n    middleware: Middleware[] = [],\n    enhancers: StoreEnhancer<RootState>[] = [],\n  ): void => {\n    assert(!this.store, 'Store already configured!');\n    // Variable-arity compose in typescript FTW.\n    this.setStore(\n      compose<StoreCreator>(\n        applyMiddleware(...middleware),\n        ...enhancers,\n      )(createStore)(enableFractalReducers(rootReducer), initState),\n    );\n  };\n\n  provideStore = (store: Store<RootState>) => {\n    assert(!this.store, 'Store already configured!');\n    this.setStore(store);\n  };\n\n  getState = (): RootState => this.store!.getState();\n\n  subscribe = (listener: () => void): Unsubscribe =>\n    this.store!.subscribe(listener);\n\n  replaceReducer = (nextReducer: Reducer<RootState, AnyAction>): void => {\n    this.store!.replaceReducer(nextReducer);\n  };\n\n  dispatch: Dispatch<AnyAction> = <A extends AnyAction>(action: A): A => {\n    assert(\n      !!this.store,\n      'Dispatch failed: did you forget to configure your store? ' +\n        'https://github.com/angular-redux/platform/blob/master/packages/store/' +\n        'README.md#quick-start',\n    );\n\n    if (!NgZone.isInAngularZone()) {\n      return this.ngZone.run(() => this.store!.dispatch(action));\n    } else {\n      return this.store!.dispatch(action);\n    }\n  };\n\n  select = <SelectedType>(\n    selector?: Selector<RootState, SelectedType>,\n    comparator?: Comparator,\n  ): Observable<SelectedType> =>\n    this.store$.pipe(\n      distinctUntilChanged(),\n      map(resolveToFunctionSelector(selector)),\n      distinctUntilChanged(comparator),\n    );\n\n  configureSubStore = <SubState>(\n    basePath: PathSelector,\n    localReducer: Reducer<SubState, AnyAction>,\n  ): ObservableStore<SubState> =>\n    new SubStore<SubState>(this, basePath, localReducer);\n\n  private setStore(store: Store<RootState>) {\n    this.store = store;\n    const storeServable = this.storeToObservable(store);\n    this.store$.next(storeServable as any);\n  }\n\n  private storeToObservable = (\n    store: Store<RootState>,\n  ): Observable<RootState> =>\n    new Observable<RootState>((observer: Observer<RootState>) => {\n      observer.next(store.getState());\n      const unsubscribeFromRedux = store.subscribe(() =>\n        observer.next(store.getState()),\n      );\n      return () => {\n        unsubscribeFromRedux();\n        observer.complete();\n      };\n    });\n}\n"]}