@spartacus/checkout
Version:
Checkout feature library for Spartacus
119 lines • 14.9 kB
JavaScript
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"]}