UNPKG

@spartacus/checkout

Version:

Checkout feature library for Spartacus

135 lines 19.3 kB
import { Injectable, isDevMode } from '@angular/core'; import { CheckoutStepType, } from '@spartacus/checkout/root'; import { combineLatest, of } from 'rxjs'; import { map, switchMap, take, tap } from 'rxjs/operators'; import * as i0 from "@angular/core"; import * as i1 from "@spartacus/checkout/root"; import * as i2 from "../services/checkout-step.service"; import * as i3 from "../services/checkout-details.service"; import * as i4 from "@spartacus/core"; import * as i5 from "@angular/router"; export class CheckoutStepsSetGuard { constructor(paymentTypeService, checkoutStepService, checkoutDetailsService, routingConfigService, checkoutCostCenterService, router) { this.paymentTypeService = paymentTypeService; this.checkoutStepService = checkoutStepService; this.checkoutDetailsService = checkoutDetailsService; this.routingConfigService = routingConfigService; this.checkoutCostCenterService = checkoutCostCenterService; this.router = router; } canActivate(route, _) { let currentIndex = -1; const currentRouteUrl = '/' + route.url.join('/'); // check whether the previous step is set return combineLatest([ this.checkoutStepService.steps$, this.paymentTypeService.isAccountPayment(), ]).pipe(tap(([, isAccount]) => { this.checkoutStepService.disableEnableStep(CheckoutStepType.PAYMENT_DETAILS, isAccount); }), take(1), switchMap(([steps, isAccount]) => { currentIndex = steps.findIndex((step) => { var _a; const stepRouteUrl = `/${(_a = this.routingConfigService.getRouteConfig(step.routeName).paths) === null || _a === void 0 ? void 0 : _a[0]}`; return stepRouteUrl === currentRouteUrl; }); // get current step let currentStep; if (currentIndex >= 0) { currentStep = steps[currentIndex]; } if (Boolean(currentStep)) { return this.isStepSet(steps[currentIndex - 1], isAccount); } else { if (isDevMode()) { console.warn(`Missing step with route '${currentRouteUrl}' in checkout configuration or this step is disabled.`); } return of(this.getUrl('checkout')); } })); } isStepSet(step, isAccountPayment) { if (step && !step.disabled) { switch (step.type[0]) { case CheckoutStepType.PAYMENT_TYPE: { return this.isPaymentTypeSet(step); } case CheckoutStepType.SHIPPING_ADDRESS: { return this.isShippingAddressAndCostCenterSet(step, isAccountPayment); } case CheckoutStepType.DELIVERY_MODE: { return this.isDeliveryModeSet(step); } case CheckoutStepType.PAYMENT_DETAILS: { return this.isPaymentDetailsSet(step); } case CheckoutStepType.REVIEW_ORDER: { break; } } } return of(true); } isPaymentTypeSet(step) { return this.paymentTypeService.getSelectedPaymentType().pipe(map((paymentType) => { if (Boolean(paymentType)) { return true; } else { return this.getUrl(step.routeName); } })); } isShippingAddressAndCostCenterSet(step, isAccountPayment) { return combineLatest([ this.checkoutDetailsService.getDeliveryAddress(), this.checkoutCostCenterService.getCostCenter(), ]).pipe(map(([deliveryAddress, costCenter]) => { if (isAccountPayment) { if (deliveryAddress && Object.keys(deliveryAddress).length && Boolean(costCenter)) { return true; } else { return this.getUrl(step.routeName); } } else { if (deliveryAddress && Object.keys(deliveryAddress).length && costCenter === undefined) { return true; } else { return this.getUrl(step.routeName); } } })); } isDeliveryModeSet(step) { return this.checkoutDetailsService .getSelectedDeliveryModeCode() .pipe(map((mode) => mode && mode.length ? true : this.getUrl(step.routeName))); } isPaymentDetailsSet(step) { return this.checkoutDetailsService .getPaymentDetails() .pipe(map((paymentDetails) => paymentDetails && Object.keys(paymentDetails).length !== 0 ? true : this.getUrl(step.routeName))); } getUrl(routeName) { var _a; return this.router.parseUrl((_a = this.routingConfigService.getRouteConfig(routeName).paths) === null || _a === void 0 ? void 0 : _a[0]); } } CheckoutStepsSetGuard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: CheckoutStepsSetGuard, deps: [{ token: i1.PaymentTypeFacade }, { token: i2.CheckoutStepService }, { token: i3.CheckoutDetailsService }, { token: i4.RoutingConfigService }, { token: i1.CheckoutCostCenterFacade }, { token: i5.Router }], target: i0.ɵɵFactoryTarget.Injectable }); CheckoutStepsSetGuard.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: CheckoutStepsSetGuard, providedIn: 'root' }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: CheckoutStepsSetGuard, decorators: [{ type: Injectable, args: [{ providedIn: 'root', }] }], ctorParameters: function () { return [{ type: i1.PaymentTypeFacade }, { type: i2.CheckoutStepService }, { type: i3.CheckoutDetailsService }, { type: i4.RoutingConfigService }, { type: i1.CheckoutCostCenterFacade }, { type: i5.Router }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkout-steps-set.guard.js","sourceRoot":"","sources":["../../../../../feature-libs/checkout/components/guards/checkout-steps-set.guard.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, isDevMode } from '@angular/core';\nimport {\n  ActivatedRouteSnapshot,\n  CanActivate,\n  Router,\n  RouterStateSnapshot,\n  UrlTree,\n} from '@angular/router';\nimport {\n  CheckoutCostCenterFacade,\n  CheckoutStep,\n  CheckoutStepType,\n  PaymentTypeFacade,\n} from '@spartacus/checkout/root';\nimport { RoutingConfigService } from '@spartacus/core';\nimport { combineLatest, Observable, of } from 'rxjs';\nimport { map, switchMap, take, tap } from 'rxjs/operators';\nimport { CheckoutDetailsService } from '../services/checkout-details.service';\nimport { CheckoutStepService } from '../services/checkout-step.service';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class CheckoutStepsSetGuard implements CanActivate {\n  constructor(\n    protected paymentTypeService: PaymentTypeFacade,\n    protected checkoutStepService: CheckoutStepService,\n    protected checkoutDetailsService: CheckoutDetailsService,\n    protected routingConfigService: RoutingConfigService,\n    protected checkoutCostCenterService: CheckoutCostCenterFacade,\n    protected router: Router\n  ) {}\n\n  canActivate(\n    route: ActivatedRouteSnapshot,\n    _: RouterStateSnapshot\n  ): Observable<boolean | UrlTree> {\n    let currentIndex = -1;\n    const currentRouteUrl = '/' + route.url.join('/');\n\n    // check whether the previous step is set\n    return combineLatest([\n      this.checkoutStepService.steps$,\n      this.paymentTypeService.isAccountPayment(),\n    ]).pipe(\n      tap(([, isAccount]) => {\n        this.checkoutStepService.disableEnableStep(\n          CheckoutStepType.PAYMENT_DETAILS,\n          isAccount\n        );\n      }),\n      take(1),\n      switchMap(([steps, isAccount]) => {\n        currentIndex = steps.findIndex((step) => {\n          const stepRouteUrl = `/${\n            this.routingConfigService.getRouteConfig(step.routeName).paths?.[0]\n          }`;\n          return stepRouteUrl === currentRouteUrl;\n        });\n        // get current step\n        let currentStep;\n        if (currentIndex >= 0) {\n          currentStep = steps[currentIndex];\n        }\n        if (Boolean(currentStep)) {\n          return this.isStepSet(steps[currentIndex - 1], isAccount);\n        } else {\n          if (isDevMode()) {\n            console.warn(\n              `Missing step with route '${currentRouteUrl}' in checkout configuration or this step is disabled.`\n            );\n          }\n          return of(this.getUrl('checkout'));\n        }\n      })\n    );\n  }\n\n  protected isStepSet(\n    step: CheckoutStep,\n    isAccountPayment: boolean\n  ): Observable<boolean | UrlTree> {\n    if (step && !step.disabled) {\n      switch (step.type[0]) {\n        case CheckoutStepType.PAYMENT_TYPE: {\n          return this.isPaymentTypeSet(step);\n        }\n        case CheckoutStepType.SHIPPING_ADDRESS: {\n          return this.isShippingAddressAndCostCenterSet(step, isAccountPayment);\n        }\n        case CheckoutStepType.DELIVERY_MODE: {\n          return this.isDeliveryModeSet(step);\n        }\n        case CheckoutStepType.PAYMENT_DETAILS: {\n          return this.isPaymentDetailsSet(step);\n        }\n        case CheckoutStepType.REVIEW_ORDER: {\n          break;\n        }\n      }\n    }\n    return of(true);\n  }\n\n  protected isPaymentTypeSet(\n    step: CheckoutStep\n  ): Observable<boolean | UrlTree> {\n    return this.paymentTypeService.getSelectedPaymentType().pipe(\n      map((paymentType) => {\n        if (Boolean(paymentType)) {\n          return true;\n        } else {\n          return this.getUrl(step.routeName);\n        }\n      })\n    );\n  }\n\n  protected isShippingAddressAndCostCenterSet(\n    step: CheckoutStep,\n    isAccountPayment: boolean\n  ): Observable<boolean | UrlTree> {\n    return combineLatest([\n      this.checkoutDetailsService.getDeliveryAddress(),\n      this.checkoutCostCenterService.getCostCenter(),\n    ]).pipe(\n      map(([deliveryAddress, costCenter]) => {\n        if (isAccountPayment) {\n          if (\n            deliveryAddress &&\n            Object.keys(deliveryAddress).length &&\n            Boolean(costCenter)\n          ) {\n            return true;\n          } else {\n            return this.getUrl(step.routeName);\n          }\n        } else {\n          if (\n            deliveryAddress &&\n            Object.keys(deliveryAddress).length &&\n            costCenter === undefined\n          ) {\n            return true;\n          } else {\n            return this.getUrl(step.routeName);\n          }\n        }\n      })\n    );\n  }\n\n  protected isDeliveryModeSet(\n    step: CheckoutStep\n  ): Observable<boolean | UrlTree> {\n    return this.checkoutDetailsService\n      .getSelectedDeliveryModeCode()\n      .pipe(\n        map((mode: string) =>\n          mode && mode.length ? true : this.getUrl(step.routeName)\n        )\n      );\n  }\n\n  protected isPaymentDetailsSet(\n    step: CheckoutStep\n  ): Observable<boolean | UrlTree> {\n    return this.checkoutDetailsService\n      .getPaymentDetails()\n      .pipe(\n        map((paymentDetails) =>\n          paymentDetails && Object.keys(paymentDetails).length !== 0\n            ? true\n            : this.getUrl(step.routeName)\n        )\n      );\n  }\n\n  private getUrl(routeName: string): UrlTree {\n    return this.router.parseUrl(\n      this.routingConfigService.getRouteConfig(routeName).paths?.[0] as string\n    );\n  }\n}\n"]}