UNPKG

@spartacus/core

Version:

Spartacus - the core framework

171 lines 35.8 kB
import { __decorate } from "tslib"; import { Injectable } from '@angular/core'; import { Effect, ofType } from '@ngrx/effects'; import { select } from '@ngrx/store'; import { from, of } from 'rxjs'; import { catchError, concatMap, filter, groupBy, map, mergeMap, switchMap, withLatestFrom, } from 'rxjs/operators'; import { OCC_CART_ID_CURRENT } from '../../../occ/utils/occ-constants'; import { SiteContextActions } from '../../../site-context/store/actions/index'; import { normalizeHttpError } from '../../../util/normalize-http-error'; import { withdrawOn } from '../../../util/rxjs/withdraw-on'; import { isNotUndefined } from '../../../util/type-guards'; import { getCartIdByUserId, isCartNotFoundError } from '../../utils/utils'; import { CartActions } from '../actions/index'; import { getCartHasPendingProcessesSelectorFactory } from '../selectors/multi-cart.selector'; import * as i0 from "@angular/core"; import * as i1 from "@ngrx/effects"; import * as i2 from "../../connectors/cart/cart.connector"; import * as i3 from "@ngrx/store"; export class CartEffects { constructor(actions$, cartConnector, store) { this.actions$ = actions$; this.cartConnector = cartConnector; this.store = store; this.contextChange$ = this.actions$.pipe(ofType(SiteContextActions.CURRENCY_CHANGE, SiteContextActions.LANGUAGE_CHANGE)); this.loadCart$ = this.actions$.pipe(ofType(CartActions.LOAD_CART), map((action) => action.payload), groupBy((payload) => payload.cartId), mergeMap((group$) => group$.pipe(switchMap((payload) => { return of(payload).pipe(withLatestFrom(this.store.pipe(select(getCartHasPendingProcessesSelectorFactory(payload.cartId))))); }), filter(([_, hasPendingProcesses]) => !hasPendingProcesses), map(([payload]) => payload), switchMap((payload) => { return this.cartConnector.load(payload.userId, payload.cartId).pipe(mergeMap((cart) => { let actions = []; if (cart) { actions.push(new CartActions.LoadCartSuccess(Object.assign(Object.assign({}, payload), { cart, cartId: getCartIdByUserId(cart, payload.userId) }))); if (payload.cartId === OCC_CART_ID_CURRENT) { // Removing cart from entity object under `current` key as it is no longer needed. // Current cart is loaded under it's code entity. actions.push(new CartActions.RemoveCart({ cartId: OCC_CART_ID_CURRENT })); } } else { actions = [ new CartActions.LoadCartFail(Object.assign(Object.assign({}, payload), { error: {} })), ]; } return actions; }), catchError((error) => { var _a; if ((_a = error === null || error === void 0 ? void 0 : error.error) === null || _a === void 0 ? void 0 : _a.errors) { const couponExpiredErrors = error.error.errors.filter((err) => err.reason === 'invalid'); if (couponExpiredErrors.length > 0) { // Reload in case of expired coupon. return of(new CartActions.LoadCart(Object.assign({}, payload))); } const cartNotFoundErrors = error.error.errors.filter((err) => isCartNotFoundError(err) || err.reason === 'UnknownResourceError'); if (cartNotFoundErrors.length > 0) { // Remove cart as it doesn't exist on backend (selective cart always exists). return of(new CartActions.RemoveCart({ cartId: payload.cartId })); } } return of(new CartActions.LoadCartFail(Object.assign(Object.assign({}, payload), { error: normalizeHttpError(error) }))); })); }))), withdrawOn(this.contextChange$)); this.createCart$ = this.actions$.pipe(ofType(CartActions.CREATE_CART), map((action) => action.payload), mergeMap((payload) => { return this.cartConnector .create(payload.userId, payload.oldCartId, payload.toMergeCartGuid) .pipe(switchMap((cart) => { const conditionalActions = []; if (payload.oldCartId) { conditionalActions.push(new CartActions.MergeCartSuccess({ extraData: payload.extraData, userId: payload.userId, tempCartId: payload.tempCartId, cartId: getCartIdByUserId(cart, payload.userId), oldCartId: payload.oldCartId, })); } return [ new CartActions.CreateCartSuccess(Object.assign(Object.assign({}, payload), { cart, cartId: getCartIdByUserId(cart, payload.userId) })), new CartActions.SetTempCart({ cart, tempCartId: payload.tempCartId, }), ...conditionalActions, ]; }), catchError((error) => of(new CartActions.CreateCartFail(Object.assign(Object.assign({}, payload), { error: normalizeHttpError(error) }))))); }), withdrawOn(this.contextChange$)); this.mergeCart$ = this.actions$.pipe(ofType(CartActions.MERGE_CART), map((action) => action.payload), switchMap((payload) => { return this.cartConnector.load(payload.userId, OCC_CART_ID_CURRENT).pipe(map((currentCart) => { if ((currentCart === null || currentCart === void 0 ? void 0 : currentCart.code) !== payload.cartId) { return new CartActions.CreateCart({ userId: payload.userId, oldCartId: payload.cartId, toMergeCartGuid: currentCart ? currentCart.guid : undefined, extraData: payload.extraData, tempCartId: payload.tempCartId, }); } }), filter(isNotUndefined)); }), withdrawOn(this.contextChange$)); // TODO(#7241): Remove when AddVoucherSuccess actions will extend processes actions this.refresh$ = this.actions$.pipe(ofType(CartActions.CART_ADD_VOUCHER_SUCCESS), map((action) => action.payload), concatMap((payload) => from([ new CartActions.CartProcessesDecrement(payload.cartId), new CartActions.LoadCart({ userId: payload.userId, cartId: payload.cartId, }), ]))); // TODO: Switch to automatic cart reload on processes count reaching 0 for cart entity this.refreshWithoutProcesses$ = this.actions$.pipe(ofType(CartActions.CART_ADD_ENTRY_SUCCESS, CartActions.CART_REMOVE_ENTRY_SUCCESS, CartActions.CART_UPDATE_ENTRY_SUCCESS, CartActions.CART_REMOVE_VOUCHER_SUCCESS), map((action) => action.payload), map((payload) => new CartActions.LoadCart({ userId: payload.userId, cartId: payload.cartId, }))); this.resetCartDetailsOnSiteContextChange$ = this.actions$.pipe(ofType(SiteContextActions.LANGUAGE_CHANGE, SiteContextActions.CURRENCY_CHANGE), mergeMap(() => { return [new CartActions.ResetCartDetails()]; })); this.addEmail$ = this.actions$.pipe(ofType(CartActions.ADD_EMAIL_TO_CART), map((action) => action.payload), mergeMap((payload) => this.cartConnector .addEmail(payload.userId, payload.cartId, payload.email) .pipe(mergeMap(() => { return [ new CartActions.AddEmailToCartSuccess(Object.assign({}, payload)), new CartActions.LoadCart({ userId: payload.userId, cartId: payload.cartId, }), ]; }), catchError((error) => from([ new CartActions.AddEmailToCartFail(Object.assign(Object.assign({}, payload), { error: normalizeHttpError(error) })), new CartActions.LoadCart({ userId: payload.userId, cartId: payload.cartId, }), ])))), withdrawOn(this.contextChange$)); this.deleteCart$ = this.actions$.pipe(ofType(CartActions.DELETE_CART), map((action) => action.payload), mergeMap((payload) => this.cartConnector.delete(payload.userId, payload.cartId).pipe(map(() => { return new CartActions.DeleteCartSuccess(Object.assign({}, payload)); }), catchError((error) => from([ new CartActions.DeleteCartFail(Object.assign(Object.assign({}, payload), { error: normalizeHttpError(error) })), // Error might happen in higher backend layer and cart could still be removed. // When load fail with NotFound error then RemoveCart action will kick in and clear that cart in our state. new CartActions.LoadCart(Object.assign({}, payload)), ]))))); } } CartEffects.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: CartEffects, deps: [{ token: i1.Actions }, { token: i2.CartConnector }, { token: i3.Store }], target: i0.ɵɵFactoryTarget.Injectable }); CartEffects.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: CartEffects }); __decorate([ Effect() ], CartEffects.prototype, "loadCart$", void 0); __decorate([ Effect() ], CartEffects.prototype, "createCart$", void 0); __decorate([ Effect() ], CartEffects.prototype, "mergeCart$", void 0); __decorate([ Effect() ], CartEffects.prototype, "refresh$", void 0); __decorate([ Effect() ], CartEffects.prototype, "refreshWithoutProcesses$", void 0); __decorate([ Effect() ], CartEffects.prototype, "resetCartDetailsOnSiteContextChange$", void 0); __decorate([ Effect() ], CartEffects.prototype, "addEmail$", void 0); __decorate([ Effect() ], CartEffects.prototype, "deleteCart$", void 0); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: CartEffects, decorators: [{ type: Injectable }], ctorParameters: function () { return [{ type: i1.Actions }, { type: i2.CartConnector }, { type: i3.Store }]; }, propDecorators: { loadCart$: [], createCart$: [], mergeCart$: [], refresh$: [], refreshWithoutProcesses$: [], resetCartDetailsOnSiteContextChange$: [], addEmail$: [], deleteCart$: [] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cart.effect.js","sourceRoot":"","sources":["../../../../../../../projects/core/src/cart/store/effects/cart.effect.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Actions, Effect, ofType } from '@ngrx/effects';\nimport { select, Store } from '@ngrx/store';\nimport { from, Observable, of } from 'rxjs';\nimport {\n  catchError,\n  concatMap,\n  filter,\n  groupBy,\n  map,\n  mergeMap,\n  switchMap,\n  withLatestFrom,\n} from 'rxjs/operators';\nimport { Cart } from '../../../model/cart.model';\nimport { OCC_CART_ID_CURRENT } from '../../../occ/utils/occ-constants';\nimport { SiteContextActions } from '../../../site-context/store/actions/index';\nimport { normalizeHttpError } from '../../../util/normalize-http-error';\nimport { withdrawOn } from '../../../util/rxjs/withdraw-on';\nimport { isNotUndefined } from '../../../util/type-guards';\nimport { CartConnector } from '../../connectors/cart/cart.connector';\nimport { getCartIdByUserId, isCartNotFoundError } from '../../utils/utils';\nimport { CartActions } from '../actions/index';\nimport { StateWithMultiCart } from '../multi-cart-state';\nimport { getCartHasPendingProcessesSelectorFactory } from '../selectors/multi-cart.selector';\n\n@Injectable()\nexport class CartEffects {\n  private contextChange$ = this.actions$.pipe(\n    ofType(\n      SiteContextActions.CURRENCY_CHANGE,\n      SiteContextActions.LANGUAGE_CHANGE\n    )\n  );\n\n  @Effect()\n  loadCart$: Observable<\n    | CartActions.LoadCartFail\n    | CartActions.LoadCartSuccess\n    | CartActions.RemoveCart\n  > = this.actions$.pipe(\n    ofType(CartActions.LOAD_CART),\n    map((action: CartActions.LoadCart) => action.payload),\n    groupBy((payload) => payload.cartId),\n    mergeMap((group$) =>\n      group$.pipe(\n        switchMap((payload) => {\n          return of(payload).pipe(\n            withLatestFrom(\n              this.store.pipe(\n                select(\n                  getCartHasPendingProcessesSelectorFactory(payload.cartId)\n                )\n              )\n            )\n          );\n        }),\n        filter(([_, hasPendingProcesses]) => !hasPendingProcesses),\n        map(([payload]) => payload),\n        switchMap((payload) => {\n          return this.cartConnector.load(payload.userId, payload.cartId).pipe(\n            mergeMap((cart: Cart) => {\n              let actions = [];\n              if (cart) {\n                actions.push(\n                  new CartActions.LoadCartSuccess({\n                    ...payload,\n                    cart,\n                    cartId: getCartIdByUserId(cart, payload.userId),\n                  })\n                );\n\n                if (payload.cartId === OCC_CART_ID_CURRENT) {\n                  // Removing cart from entity object under `current` key as it is no longer needed.\n                  // Current cart is loaded under it's code entity.\n                  actions.push(\n                    new CartActions.RemoveCart({ cartId: OCC_CART_ID_CURRENT })\n                  );\n                }\n              } else {\n                actions = [\n                  new CartActions.LoadCartFail({\n                    ...payload,\n                    error: {},\n                  }),\n                ];\n              }\n              return actions;\n            }),\n            catchError((error) => {\n              if (error?.error?.errors) {\n                const couponExpiredErrors = error.error.errors.filter(\n                  (err) => err.reason === 'invalid'\n                );\n                if (couponExpiredErrors.length > 0) {\n                  // Reload in case of expired coupon.\n                  return of(new CartActions.LoadCart({ ...payload }));\n                }\n\n                const cartNotFoundErrors = error.error.errors.filter(\n                  (err) =>\n                    isCartNotFoundError(err) ||\n                    err.reason === 'UnknownResourceError'\n                );\n                if (cartNotFoundErrors.length > 0) {\n                  // Remove cart as it doesn't exist on backend (selective cart always exists).\n                  return of(\n                    new CartActions.RemoveCart({ cartId: payload.cartId })\n                  );\n                }\n              }\n              return of(\n                new CartActions.LoadCartFail({\n                  ...payload,\n                  error: normalizeHttpError(error),\n                })\n              );\n            })\n          );\n        })\n      )\n    ),\n    withdrawOn(this.contextChange$)\n  );\n\n  @Effect()\n  createCart$: Observable<\n    | CartActions.MergeCartSuccess\n    | CartActions.CreateCartSuccess\n    | CartActions.CreateCartFail\n    | CartActions.SetTempCart\n  > = this.actions$.pipe(\n    ofType(CartActions.CREATE_CART),\n    map((action: CartActions.CreateCart) => action.payload),\n    mergeMap((payload) => {\n      return this.cartConnector\n        .create(payload.userId, payload.oldCartId, payload.toMergeCartGuid)\n        .pipe(\n          switchMap((cart: Cart) => {\n            const conditionalActions = [];\n            if (payload.oldCartId) {\n              conditionalActions.push(\n                new CartActions.MergeCartSuccess({\n                  extraData: payload.extraData,\n                  userId: payload.userId,\n                  tempCartId: payload.tempCartId,\n                  cartId: getCartIdByUserId(cart, payload.userId),\n                  oldCartId: payload.oldCartId,\n                })\n              );\n            }\n            return [\n              new CartActions.CreateCartSuccess({\n                ...payload,\n                cart,\n                cartId: getCartIdByUserId(cart, payload.userId),\n              }),\n              new CartActions.SetTempCart({\n                cart,\n                tempCartId: payload.tempCartId,\n              }),\n              ...conditionalActions,\n            ];\n          }),\n          catchError((error) =>\n            of(\n              new CartActions.CreateCartFail({\n                ...payload,\n                error: normalizeHttpError(error),\n              })\n            )\n          )\n        );\n    }),\n    withdrawOn(this.contextChange$)\n  );\n\n  @Effect()\n  mergeCart$: Observable<CartActions.CreateCart> = this.actions$.pipe(\n    ofType(CartActions.MERGE_CART),\n    map((action: CartActions.MergeCart) => action.payload),\n    switchMap((payload) => {\n      return this.cartConnector.load(payload.userId, OCC_CART_ID_CURRENT).pipe(\n        map((currentCart) => {\n          if (currentCart?.code !== payload.cartId) {\n            return new CartActions.CreateCart({\n              userId: payload.userId,\n              oldCartId: payload.cartId,\n              toMergeCartGuid: currentCart ? currentCart.guid : undefined,\n              extraData: payload.extraData,\n              tempCartId: payload.tempCartId,\n            });\n          }\n        }),\n        filter(isNotUndefined)\n      );\n    }),\n    withdrawOn(this.contextChange$)\n  );\n\n  // TODO(#7241): Remove when AddVoucherSuccess actions will extend processes actions\n  @Effect()\n  refresh$: Observable<\n    CartActions.LoadCart | CartActions.CartProcessesDecrement\n  > = this.actions$.pipe(\n    ofType(CartActions.CART_ADD_VOUCHER_SUCCESS),\n    map((action: CartActions.CartAddVoucherSuccess) => action.payload),\n    concatMap((payload) =>\n      from([\n        new CartActions.CartProcessesDecrement(payload.cartId),\n        new CartActions.LoadCart({\n          userId: payload.userId,\n          cartId: payload.cartId,\n        }),\n      ])\n    )\n  );\n\n  // TODO: Switch to automatic cart reload on processes count reaching 0 for cart entity\n  @Effect()\n  refreshWithoutProcesses$: Observable<CartActions.LoadCart> = this.actions$.pipe(\n    ofType(\n      CartActions.CART_ADD_ENTRY_SUCCESS,\n      CartActions.CART_REMOVE_ENTRY_SUCCESS,\n      CartActions.CART_UPDATE_ENTRY_SUCCESS,\n      CartActions.CART_REMOVE_VOUCHER_SUCCESS\n    ),\n    map(\n      (\n        action:\n          | CartActions.CartAddEntrySuccess\n          | CartActions.CartUpdateEntrySuccess\n          | CartActions.CartRemoveEntrySuccess\n          | CartActions.CartRemoveVoucherSuccess\n      ) => action.payload\n    ),\n    map(\n      (payload) =>\n        new CartActions.LoadCart({\n          userId: payload.userId,\n          cartId: payload.cartId,\n        })\n    )\n  );\n\n  @Effect()\n  resetCartDetailsOnSiteContextChange$: Observable<CartActions.ResetCartDetails> =\n    this.actions$.pipe(\n      ofType(\n        SiteContextActions.LANGUAGE_CHANGE,\n        SiteContextActions.CURRENCY_CHANGE\n      ),\n      mergeMap(() => {\n        return [new CartActions.ResetCartDetails()];\n      })\n    );\n\n  @Effect()\n  addEmail$: Observable<\n    | CartActions.AddEmailToCartSuccess\n    | CartActions.AddEmailToCartFail\n    | CartActions.LoadCart\n  > = this.actions$.pipe(\n    ofType(CartActions.ADD_EMAIL_TO_CART),\n    map((action: CartActions.AddEmailToCart) => action.payload),\n    mergeMap((payload) =>\n      this.cartConnector\n        .addEmail(payload.userId, payload.cartId, payload.email)\n        .pipe(\n          mergeMap(() => {\n            return [\n              new CartActions.AddEmailToCartSuccess({\n                ...payload,\n              }),\n              new CartActions.LoadCart({\n                userId: payload.userId,\n                cartId: payload.cartId,\n              }),\n            ];\n          }),\n          catchError((error) =>\n            from([\n              new CartActions.AddEmailToCartFail({\n                ...payload,\n                error: normalizeHttpError(error),\n              }),\n              new CartActions.LoadCart({\n                userId: payload.userId,\n                cartId: payload.cartId,\n              }),\n            ])\n          )\n        )\n    ),\n    withdrawOn(this.contextChange$)\n  );\n\n  @Effect()\n  deleteCart$: Observable<\n    | CartActions.DeleteCartSuccess\n    | CartActions.DeleteCartFail\n    | CartActions.LoadCart\n  > = this.actions$.pipe(\n    ofType(CartActions.DELETE_CART),\n    map((action: CartActions.DeleteCart) => action.payload),\n    mergeMap((payload) =>\n      this.cartConnector.delete(payload.userId, payload.cartId).pipe(\n        map(() => {\n          return new CartActions.DeleteCartSuccess({ ...payload });\n        }),\n        catchError((error) =>\n          from([\n            new CartActions.DeleteCartFail({\n              ...payload,\n              error: normalizeHttpError(error),\n            }),\n            // Error might happen in higher backend layer and cart could still be removed.\n            // When load fail with NotFound error then RemoveCart action will kick in and clear that cart in our state.\n            new CartActions.LoadCart({\n              ...payload,\n            }),\n          ])\n        )\n      )\n    )\n  );\n\n  constructor(\n    private actions$: Actions,\n    private cartConnector: CartConnector,\n    private store: Store<StateWithMultiCart>\n  ) {}\n}\n"]}