UNPKG

@spartacus/checkout

Version:

Checkout feature library for Spartacus

119 lines 14.9 kB
import { Injectable } from '@angular/core'; import { select } from '@ngrx/store'; import { getLastValueSync, OCC_USER_ID_ANONYMOUS, ProcessSelectors, } from '@spartacus/core'; import { combineLatest } from 'rxjs'; import { filter, take } from 'rxjs/operators'; import { CheckoutActions } from '../store/actions/index'; import { SET_PAYMENT_DETAILS_PROCESS_ID, } from '../store/checkout-state'; import { CheckoutSelectors } from '../store/selectors/index'; import * as i0 from "@angular/core"; import * as i1 from "@ngrx/store"; import * as i2 from "@spartacus/core"; export class CheckoutPaymentService { constructor(checkoutStore, processStateStore, activeCartService, userIdService) { this.checkoutStore = checkoutStore; this.processStateStore = processStateStore; this.activeCartService = activeCartService; this.userIdService = userIdService; } /** * Get card types */ getCardTypes() { return this.checkoutStore.pipe(select(CheckoutSelectors.getAllCardTypes)); } /** * Get payment details */ getPaymentDetails() { return this.checkoutStore.pipe(select(CheckoutSelectors.getPaymentDetails)); } /** * Get status about set Payment Details process */ getSetPaymentDetailsResultProcess() { return this.processStateStore.pipe(select(ProcessSelectors.getProcessStateFactory(SET_PAYMENT_DETAILS_PROCESS_ID))); } /** * Clear info about process of setting Payment Details */ resetSetPaymentDetailsProcess() { this.checkoutStore.dispatch(new CheckoutActions.ResetSetPaymentDetailsProcess()); } /** * Load the supported card types */ loadSupportedCardTypes() { this.checkoutStore.dispatch(new CheckoutActions.LoadCardTypes()); } /** * Create payment details using the given paymentDetails param * @param paymentDetails: the PaymentDetails to be created */ createPaymentDetails(paymentDetails) { if (this.actionAllowed()) { let userId; this.userIdService .getUserId() .subscribe((occUserId) => (userId = occUserId)) .unsubscribe(); let cartId; this.activeCartService .getActiveCartId() .subscribe((activeCartId) => (cartId = activeCartId)) .unsubscribe(); if (userId && cartId) { this.checkoutStore.dispatch(new CheckoutActions.CreatePaymentDetails({ userId, cartId, paymentDetails, })); } } } /** * Set payment details * @param paymentDetails : the PaymentDetails to be set */ setPaymentDetails(paymentDetails) { if (this.actionAllowed()) { const userId = getLastValueSync(this.userIdService.getUserId()); const cartId = getLastValueSync(this.activeCartService.getActiveCartId()); if (userId && cartId) { combineLatest([ this.activeCartService.isStable(), this.checkoutStore.pipe(select(CheckoutSelectors.getCheckoutLoading)), ]) .pipe(filter(([isStable, isLoading]) => isStable && !isLoading), take(1)) .subscribe(() => { this.checkoutStore.dispatch(new CheckoutActions.SetPaymentDetails({ userId, cartId, paymentDetails: paymentDetails, })); }); } } } /** * Sets payment loading to true without having the flicker issue (GH-3102) */ paymentProcessSuccess() { this.checkoutStore.dispatch(new CheckoutActions.PaymentProcessSuccess()); } actionAllowed() { let userId; this.userIdService .getUserId() .subscribe((occUserId) => (userId = occUserId)) .unsubscribe(); return ((userId && userId !== OCC_USER_ID_ANONYMOUS) || this.activeCartService.isGuestCart()); } } CheckoutPaymentService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: CheckoutPaymentService, deps: [{ token: i1.Store }, { token: i1.Store }, { token: i2.ActiveCartService }, { token: i2.UserIdService }], target: i0.ɵɵFactoryTarget.Injectable }); CheckoutPaymentService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: CheckoutPaymentService }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: CheckoutPaymentService, decorators: [{ type: Injectable }], ctorParameters: function () { return [{ type: i1.Store }, { type: i1.Store }, { type: i2.ActiveCartService }, { type: i2.UserIdService }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkout-payment.service.js","sourceRoot":"","sources":["../../../../../feature-libs/checkout/core/facade/checkout-payment.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { select, Store } from '@ngrx/store';\nimport { CheckoutPaymentFacade } from '@spartacus/checkout/root';\nimport {\n  ActiveCartService,\n  CardType,\n  getLastValueSync,\n  OCC_USER_ID_ANONYMOUS,\n  PaymentDetails,\n  ProcessSelectors,\n  StateUtils,\n  StateWithProcess,\n  UserIdService,\n} from '@spartacus/core';\nimport { combineLatest, Observable } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { CheckoutActions } from '../store/actions/index';\nimport {\n  SET_PAYMENT_DETAILS_PROCESS_ID,\n  StateWithCheckout,\n} from '../store/checkout-state';\nimport { CheckoutSelectors } from '../store/selectors/index';\n\n@Injectable()\nexport class CheckoutPaymentService implements CheckoutPaymentFacade {\n  constructor(\n    protected checkoutStore: Store<StateWithCheckout>,\n    protected processStateStore: Store<StateWithProcess<void>>,\n    protected activeCartService: ActiveCartService,\n    protected userIdService: UserIdService\n  ) {}\n\n  /**\n   * Get card types\n   */\n  getCardTypes(): Observable<CardType[]> {\n    return this.checkoutStore.pipe(select(CheckoutSelectors.getAllCardTypes));\n  }\n\n  /**\n   * Get payment details\n   */\n  getPaymentDetails(): Observable<PaymentDetails> {\n    return this.checkoutStore.pipe(select(CheckoutSelectors.getPaymentDetails));\n  }\n\n  /**\n   * Get status about set Payment Details process\n   */\n  getSetPaymentDetailsResultProcess(): Observable<\n    StateUtils.LoaderState<void>\n  > {\n    return this.processStateStore.pipe(\n      select(\n        ProcessSelectors.getProcessStateFactory(SET_PAYMENT_DETAILS_PROCESS_ID)\n      )\n    );\n  }\n\n  /**\n   * Clear info about process of setting Payment Details\n   */\n  resetSetPaymentDetailsProcess(): void {\n    this.checkoutStore.dispatch(\n      new CheckoutActions.ResetSetPaymentDetailsProcess()\n    );\n  }\n\n  /**\n   * Load the supported card types\n   */\n  loadSupportedCardTypes(): void {\n    this.checkoutStore.dispatch(new CheckoutActions.LoadCardTypes());\n  }\n\n  /**\n   * Create payment details using the given paymentDetails param\n   * @param paymentDetails: the PaymentDetails to be created\n   */\n  createPaymentDetails(paymentDetails: PaymentDetails): void {\n    if (this.actionAllowed()) {\n      let userId;\n      this.userIdService\n        .getUserId()\n        .subscribe((occUserId) => (userId = occUserId))\n        .unsubscribe();\n\n      let cartId;\n      this.activeCartService\n        .getActiveCartId()\n        .subscribe((activeCartId) => (cartId = activeCartId))\n        .unsubscribe();\n\n      if (userId && cartId) {\n        this.checkoutStore.dispatch(\n          new CheckoutActions.CreatePaymentDetails({\n            userId,\n            cartId,\n            paymentDetails,\n          })\n        );\n      }\n    }\n  }\n\n  /**\n   * Set payment details\n   * @param paymentDetails : the PaymentDetails to be set\n   */\n  setPaymentDetails(paymentDetails: PaymentDetails): void {\n    if (this.actionAllowed()) {\n      const userId = getLastValueSync(this.userIdService.getUserId());\n      const cartId = getLastValueSync(this.activeCartService.getActiveCartId());\n\n      if (userId && cartId) {\n        combineLatest([\n          this.activeCartService.isStable(),\n          this.checkoutStore.pipe(select(CheckoutSelectors.getCheckoutLoading)),\n        ])\n          .pipe(\n            filter(([isStable, isLoading]) => isStable && !isLoading),\n            take(1)\n          )\n          .subscribe(() => {\n            this.checkoutStore.dispatch(\n              new CheckoutActions.SetPaymentDetails({\n                userId,\n                cartId,\n                paymentDetails: paymentDetails,\n              })\n            );\n          });\n      }\n    }\n  }\n\n  /**\n   * Sets payment loading to true without having the flicker issue (GH-3102)\n   */\n  paymentProcessSuccess() {\n    this.checkoutStore.dispatch(new CheckoutActions.PaymentProcessSuccess());\n  }\n\n  protected actionAllowed(): boolean {\n    let userId;\n    this.userIdService\n      .getUserId()\n      .subscribe((occUserId) => (userId = occUserId))\n      .unsubscribe();\n    return (\n      (userId && userId !== OCC_USER_ID_ANONYMOUS) ||\n      this.activeCartService.isGuestCart()\n    );\n  }\n}\n"]}