UNPKG

@spartacus/checkout

Version:

Checkout feature library for Spartacus

141 lines 20.4 kB
import { Injectable } from '@angular/core'; import { BehaviorSubject } from 'rxjs'; import { map, switchMap } from 'rxjs/operators'; import * as i0 from "@angular/core"; import * as i1 from "@spartacus/core"; import * as i2 from "@spartacus/checkout/root"; export class CheckoutStepService { constructor(routingService, checkoutConfig, routingConfigService) { this.routingService = routingService; this.checkoutConfig = checkoutConfig; this.routingConfigService = routingConfigService; this.steps$ = new BehaviorSubject([]); this.activeStepIndex$ = this.routingService .getRouterState() .pipe(switchMap((router) => { const activeStepUrl = router.state.context.id; return this.steps$.pipe(map((steps) => { let activeIndex = 0; steps.forEach((step, index) => { var _a; const routeUrl = `/${(_a = this.routingConfigService.getRouteConfig(step.routeName) .paths) === null || _a === void 0 ? void 0 : _a[0]}`; if (routeUrl === activeStepUrl) { activeIndex = index; } }); return activeIndex; })); })); this.resetSteps(); } back(activatedRoute) { const previousUrl = this.getPreviousCheckoutStepUrl(activatedRoute); this.routingService.go(previousUrl === null ? 'cart' : previousUrl); } next(activatedRoute) { const nextUrl = this.getNextCheckoutStepUrl(activatedRoute); this.routingService.go(nextUrl); } goToStepWithIndex(stepIndex) { this.routingService.go(this.getStepUrlFromStepRoute(this.allSteps[stepIndex].routeName)); } getBackBntText(activatedRoute) { if (this.getPreviousCheckoutStepUrl(activatedRoute) === null) { return 'checkout.backToCart'; } return 'common.back'; } resetSteps() { var _a, _b; this.allSteps = ((_b = (_a = this.checkoutConfig.checkout) === null || _a === void 0 ? void 0 : _a.steps) !== null && _b !== void 0 ? _b : []) .filter((step) => !step.disabled) .map((x) => Object.assign({}, x)); this.steps$.next(this.allSteps); } disableEnableStep(currentStepType, disabled) { const currentStep = this.allSteps.find((step) => step.type.includes(currentStepType)); if (currentStep && currentStep.disabled !== disabled) { currentStep.disabled = disabled; this.steps$.next(this.allSteps.filter((step) => !step.disabled)); } } getCheckoutStep(currentStepType) { const index = this.getCheckoutStepIndex('type', currentStepType); if (index !== null) { return this.allSteps[index]; } } getCheckoutStepRoute(currentStepType) { var _a; return (_a = this.getCheckoutStep(currentStepType)) === null || _a === void 0 ? void 0 : _a.routeName; } getFirstCheckoutStepRoute() { return this.allSteps[0].routeName; } getNextCheckoutStepUrl(activatedRoute) { const stepIndex = this.getCurrentStepIndex(activatedRoute); if (stepIndex !== null && stepIndex >= 0) { let i = 1; while (this.allSteps[stepIndex + i] && this.allSteps[stepIndex + i].disabled) { i++; } const nextStep = this.allSteps[stepIndex + i]; if (nextStep) { return this.getStepUrlFromStepRoute(nextStep.routeName); } } return null; } getPreviousCheckoutStepUrl(activatedRoute) { const stepIndex = this.getCurrentStepIndex(activatedRoute); if (stepIndex !== null && stepIndex >= 0) { let i = 1; while (this.allSteps[stepIndex - i] && this.allSteps[stepIndex - i].disabled) { i++; } const previousStep = this.allSteps[stepIndex - i]; if (previousStep) { return this.getStepUrlFromStepRoute(previousStep.routeName); } } return null; } getCurrentStepIndex(activatedRoute) { const currentStepUrl = this.getStepUrlFromActivatedRoute(activatedRoute); const stepIndex = this.allSteps.findIndex((step) => currentStepUrl === `/${this.getStepUrlFromStepRoute(step.routeName)}`); return stepIndex === -1 ? null : stepIndex; } getStepUrlFromActivatedRoute(activatedRoute) { return activatedRoute && activatedRoute.snapshot && activatedRoute.snapshot.url ? `/${activatedRoute.snapshot.url.join('/')}` : null; } getStepUrlFromStepRoute(stepRoute) { var _a, _b; return ((_b = (_a = this.routingConfigService.getRouteConfig(stepRoute).paths) === null || _a === void 0 ? void 0 : _a[0]) !== null && _b !== void 0 ? _b : null); } getCheckoutStepIndex(key, value) { return key && value ? this.allSteps.findIndex((step) => { const propertyVal = step[key]; return propertyVal instanceof Array ? propertyVal.includes(value) : propertyVal === value; }) : null; } } CheckoutStepService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: CheckoutStepService, deps: [{ token: i1.RoutingService }, { token: i2.CheckoutConfig }, { token: i1.RoutingConfigService }], target: i0.ɵɵFactoryTarget.Injectable }); CheckoutStepService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: CheckoutStepService, providedIn: 'root' }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: CheckoutStepService, decorators: [{ type: Injectable, args: [{ providedIn: 'root', }] }], ctorParameters: function () { return [{ type: i1.RoutingService }, { type: i2.CheckoutConfig }, { type: i1.RoutingConfigService }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkout-step.service.js","sourceRoot":"","sources":["../../../../../feature-libs/checkout/components/services/checkout-step.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport {\n  CheckoutConfig,\n  CheckoutStep,\n  CheckoutStepType,\n} from '@spartacus/checkout/root';\nimport { RoutingConfigService, RoutingService } from '@spartacus/core';\nimport { BehaviorSubject, Observable } from 'rxjs';\nimport { map, switchMap } from 'rxjs/operators';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class CheckoutStepService {\n  // initial enabled steps\n  allSteps: CheckoutStep[];\n\n  readonly steps$: BehaviorSubject<CheckoutStep[]> = new BehaviorSubject<\n    CheckoutStep[]\n  >([]);\n\n  readonly activeStepIndex$: Observable<number> = this.routingService\n    .getRouterState()\n    .pipe(\n      switchMap((router) => {\n        const activeStepUrl = router.state.context.id;\n        return this.steps$.pipe(\n          map((steps) => {\n            let activeIndex: number = 0;\n            steps.forEach((step, index) => {\n              const routeUrl = `/${\n                this.routingConfigService.getRouteConfig(step.routeName)\n                  .paths?.[0]\n              }`;\n              if (routeUrl === activeStepUrl) {\n                activeIndex = index;\n              }\n            });\n            return activeIndex;\n          })\n        );\n      })\n    );\n\n  constructor(\n    protected routingService: RoutingService,\n    protected checkoutConfig: CheckoutConfig,\n    protected routingConfigService: RoutingConfigService\n  ) {\n    this.resetSteps();\n  }\n\n  back(activatedRoute: ActivatedRoute): void {\n    const previousUrl = this.getPreviousCheckoutStepUrl(activatedRoute);\n    this.routingService.go(previousUrl === null ? 'cart' : previousUrl);\n  }\n\n  next(activatedRoute: ActivatedRoute): void {\n    const nextUrl = this.getNextCheckoutStepUrl(activatedRoute);\n    this.routingService.go(nextUrl);\n  }\n\n  goToStepWithIndex(stepIndex: number): void {\n    this.routingService.go(\n      this.getStepUrlFromStepRoute(this.allSteps[stepIndex].routeName)\n    );\n  }\n\n  getBackBntText(activatedRoute: ActivatedRoute): string {\n    if (this.getPreviousCheckoutStepUrl(activatedRoute) === null) {\n      return 'checkout.backToCart';\n    }\n    return 'common.back';\n  }\n\n  resetSteps(): void {\n    this.allSteps = (this.checkoutConfig.checkout?.steps ?? [])\n      .filter((step) => !step.disabled)\n      .map((x) => Object.assign({}, x));\n    this.steps$.next(this.allSteps);\n  }\n\n  disableEnableStep(\n    currentStepType: CheckoutStepType,\n    disabled: boolean\n  ): void {\n    const currentStep = this.allSteps.find((step) =>\n      step.type.includes(currentStepType)\n    );\n    if (currentStep && currentStep.disabled !== disabled) {\n      currentStep.disabled = disabled;\n      this.steps$.next(this.allSteps.filter((step) => !step.disabled));\n    }\n  }\n\n  getCheckoutStep(currentStepType: CheckoutStepType): CheckoutStep | undefined {\n    const index = this.getCheckoutStepIndex('type', currentStepType);\n    if (index !== null) {\n      return this.allSteps[index];\n    }\n  }\n\n  getCheckoutStepRoute(currentStepType: CheckoutStepType): string | undefined {\n    return this.getCheckoutStep(currentStepType)?.routeName;\n  }\n\n  getFirstCheckoutStepRoute(): string {\n    return this.allSteps[0].routeName;\n  }\n\n  getNextCheckoutStepUrl(activatedRoute: ActivatedRoute): string | null {\n    const stepIndex = this.getCurrentStepIndex(activatedRoute);\n\n    if (stepIndex !== null && stepIndex >= 0) {\n      let i = 1;\n      while (\n        this.allSteps[stepIndex + i] &&\n        this.allSteps[stepIndex + i].disabled\n      ) {\n        i++;\n      }\n      const nextStep = this.allSteps[stepIndex + i];\n      if (nextStep) {\n        return this.getStepUrlFromStepRoute(nextStep.routeName);\n      }\n    }\n    return null;\n  }\n\n  getPreviousCheckoutStepUrl(activatedRoute: ActivatedRoute): string | null {\n    const stepIndex = this.getCurrentStepIndex(activatedRoute);\n\n    if (stepIndex !== null && stepIndex >= 0) {\n      let i = 1;\n      while (\n        this.allSteps[stepIndex - i] &&\n        this.allSteps[stepIndex - i].disabled\n      ) {\n        i++;\n      }\n      const previousStep = this.allSteps[stepIndex - i];\n      if (previousStep) {\n        return this.getStepUrlFromStepRoute(previousStep.routeName);\n      }\n    }\n    return null;\n  }\n\n  getCurrentStepIndex(activatedRoute: ActivatedRoute): number | null {\n    const currentStepUrl = this.getStepUrlFromActivatedRoute(activatedRoute);\n\n    const stepIndex = this.allSteps.findIndex(\n      (step) =>\n        currentStepUrl === `/${this.getStepUrlFromStepRoute(step.routeName)}`\n    );\n    return stepIndex === -1 ? null : stepIndex;\n  }\n\n  private getStepUrlFromActivatedRoute(\n    activatedRoute: ActivatedRoute\n  ): string | null {\n    return activatedRoute &&\n      activatedRoute.snapshot &&\n      activatedRoute.snapshot.url\n      ? `/${activatedRoute.snapshot.url.join('/')}`\n      : null;\n  }\n\n  private getStepUrlFromStepRoute(stepRoute: string): string | null {\n    return (\n      this.routingConfigService.getRouteConfig(stepRoute).paths?.[0] ?? null\n    );\n  }\n\n  private getCheckoutStepIndex(key: string, value: any): number | null {\n    return key && value\n      ? this.allSteps.findIndex((step: CheckoutStep) => {\n          const propertyVal = step[key as keyof CheckoutStep];\n          return propertyVal instanceof Array\n            ? propertyVal.includes(value)\n            : propertyVal === value;\n        })\n      : null;\n  }\n}\n"]}