UNPKG

@spartacus/core

Version:

Spartacus - the core framework

55 lines 11.8 kB
import { Injectable } from '@angular/core'; import { createEffect, ofType } from '@ngrx/effects'; import { from } from 'rxjs'; import { catchError, groupBy, mergeMap, switchMap } from 'rxjs/operators'; import { AuthActions } from '../../../auth/user-auth/store/actions/index'; import { SiteContextActions } from '../../../site-context/store/actions/index'; import { bufferDebounceTime } from '../../../util/rxjs/buffer-debounce-time'; import { normalizeHttpError } from '../../../util/normalize-http-error'; import { withdrawOn } from '../../../util/rxjs/withdraw-on'; import { serializePageContext } from '../../utils/cms-utils'; import { CmsActions } from '../actions/index'; import * as i0 from "@angular/core"; import * as i1 from "@ngrx/effects"; import * as i2 from "../../connectors/component/cms-component.connector"; export class ComponentsEffects { constructor(actions$, cmsComponentConnector) { this.actions$ = actions$; this.cmsComponentConnector = cmsComponentConnector; this.contextChange$ = this.actions$.pipe(ofType(SiteContextActions.LANGUAGE_CHANGE, AuthActions.LOGOUT, AuthActions.LOGIN)); this.loadComponent$ = createEffect(() => ({ scheduler, debounce = 0 } = {}) => this.actions$.pipe(ofType(CmsActions.LOAD_CMS_COMPONENT), groupBy((actions) => serializePageContext(actions.payload.pageContext)), mergeMap((actionGroup) => actionGroup.pipe(bufferDebounceTime(debounce, scheduler), mergeMap((actions) => this.loadComponentsEffect(actions.map((action) => action.payload.uid), actions[0].payload.pageContext)))), withdrawOn(this.contextChange$))); } loadComponentsEffect(componentUids, pageContext) { return this.cmsComponentConnector.getList(componentUids, pageContext).pipe(switchMap((components) => { const actions = []; const uidsLeft = new Set(componentUids); for (const component of components) { actions.push(new CmsActions.LoadCmsComponentSuccess({ component, uid: component.uid, pageContext, })); uidsLeft.delete(component.uid); } // we have to emit LoadCmsComponentFail for all component's uids that // are missing from the response uidsLeft.forEach((uid) => { actions.push(new CmsActions.LoadCmsComponentFail({ uid, pageContext, })); }); return from(actions); }), catchError((error) => from(componentUids.map((uid) => new CmsActions.LoadCmsComponentFail({ uid, error: normalizeHttpError(error), pageContext, }))))); } } ComponentsEffects.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: ComponentsEffects, deps: [{ token: i1.Actions }, { token: i2.CmsComponentConnector }], target: i0.ɵɵFactoryTarget.Injectable }); ComponentsEffects.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: ComponentsEffects }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: ComponentsEffects, decorators: [{ type: Injectable }], ctorParameters: function () { return [{ type: i1.Actions }, { type: i2.CmsComponentConnector }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"components.effect.js","sourceRoot":"","sources":["../../../../../../../projects/core/src/cms/store/effects/components.effect.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Actions, createEffect, ofType } from '@ngrx/effects';\nimport { Action } from '@ngrx/store';\nimport { from, Observable } from 'rxjs';\nimport { catchError, groupBy, mergeMap, switchMap } from 'rxjs/operators';\nimport { AuthActions } from '../../../auth/user-auth/store/actions/index';\nimport { CmsComponent } from '../../../model/cms.model';\nimport { PageContext } from '../../../routing/index';\nimport { SiteContextActions } from '../../../site-context/store/actions/index';\nimport { bufferDebounceTime } from '../../../util/rxjs/buffer-debounce-time';\nimport { normalizeHttpError } from '../../../util/normalize-http-error';\nimport { withdrawOn } from '../../../util/rxjs/withdraw-on';\nimport { CmsComponentConnector } from '../../connectors/component/cms-component.connector';\nimport { serializePageContext } from '../../utils/cms-utils';\nimport { CmsActions } from '../actions/index';\n\n@Injectable()\nexport class ComponentsEffects {\n  constructor(\n    private actions$: Actions,\n    private cmsComponentConnector: CmsComponentConnector\n  ) {}\n\n  private contextChange$: Observable<Action> = this.actions$.pipe(\n    ofType(\n      SiteContextActions.LANGUAGE_CHANGE,\n      AuthActions.LOGOUT,\n      AuthActions.LOGIN\n    )\n  );\n\n  loadComponent$ = createEffect(\n    () =>\n      ({ scheduler, debounce = 0 } = {}): Observable<\n        | CmsActions.LoadCmsComponentSuccess<CmsComponent>\n        | CmsActions.LoadCmsComponentFail\n      > =>\n        this.actions$.pipe(\n          ofType<CmsActions.LoadCmsComponent>(CmsActions.LOAD_CMS_COMPONENT),\n          groupBy((actions) =>\n            serializePageContext(actions.payload.pageContext)\n          ),\n          mergeMap((actionGroup) =>\n            actionGroup.pipe(\n              bufferDebounceTime(debounce, scheduler),\n              mergeMap((actions) =>\n                this.loadComponentsEffect(\n                  actions.map((action) => action.payload.uid),\n                  actions[0].payload.pageContext\n                )\n              )\n            )\n          ),\n          withdrawOn(this.contextChange$)\n        )\n  );\n\n  private loadComponentsEffect(\n    componentUids: string[],\n    pageContext: PageContext\n  ): Observable<\n    | CmsActions.LoadCmsComponentSuccess<CmsComponent>\n    | CmsActions.LoadCmsComponentFail\n  > {\n    return this.cmsComponentConnector.getList(componentUids, pageContext).pipe(\n      switchMap((components) => {\n        const actions: (\n          | CmsActions.LoadCmsComponentSuccess<CmsComponent>\n          | CmsActions.LoadCmsComponentFail\n        )[] = [];\n        const uidsLeft = new Set<string>(componentUids);\n        for (const component of components) {\n          actions.push(\n            new CmsActions.LoadCmsComponentSuccess({\n              component,\n              uid: component.uid,\n              pageContext,\n            })\n          );\n          uidsLeft.delete(component.uid);\n        }\n        // we have to emit LoadCmsComponentFail for all component's uids that\n        // are missing from the response\n        uidsLeft.forEach((uid) => {\n          actions.push(\n            new CmsActions.LoadCmsComponentFail({\n              uid,\n              pageContext,\n            })\n          );\n        });\n        return from(actions);\n      }),\n      catchError((error) =>\n        from(\n          componentUids.map(\n            (uid) =>\n              new CmsActions.LoadCmsComponentFail({\n                uid,\n                error: normalizeHttpError(error),\n                pageContext,\n              })\n          )\n        )\n      )\n    );\n  }\n}\n"]}