@veloceapps/sdk 11.0.0-11 → 11.0.0-12

Sign up to get free protection for your applications and to get access to all the features.
Files changed (89) hide show
  1. package/cms/vendor-map.d.ts +7 -6
  2. package/core/modules/configuration/helpers.d.ts +2 -1
  3. package/core/modules/configuration/services/configuration-runtime.service.d.ts +1 -3
  4. package/core/modules/configuration/services/configuration-state.service.d.ts +7 -7
  5. package/core/modules/configuration/services/configuration.service.d.ts +5 -10
  6. package/core/modules/flow-configuration/services/flow-configuration.service.d.ts +11 -32
  7. package/core/services/catalog-products.service.d.ts +11 -0
  8. package/core/services/flow-info.service.d.ts +23 -10
  9. package/core/services/flow-state.service.d.ts +9 -12
  10. package/core/services/index.d.ts +2 -2
  11. package/core/services/quote-draft.service.d.ts +5 -5
  12. package/core/services/sales-transaction.service.d.ts +28 -0
  13. package/core/types/flow-state.types.d.ts +2 -2
  14. package/esm2020/cms/vendor-map.mjs +8 -7
  15. package/esm2020/core/core.module.mjs +7 -4
  16. package/esm2020/core/modules/configuration/helpers.mjs +11 -17
  17. package/esm2020/core/modules/configuration/services/configuration-runtime.service.mjs +8 -45
  18. package/esm2020/core/modules/configuration/services/configuration-state.service.mjs +46 -54
  19. package/esm2020/core/modules/configuration/services/configuration.service.mjs +21 -39
  20. package/esm2020/core/modules/flow-configuration/services/flow-configuration.service.mjs +34 -110
  21. package/esm2020/core/services/catalog-products.service.mjs +25 -0
  22. package/esm2020/core/services/flow-info.service.mjs +70 -28
  23. package/esm2020/core/services/flow-state.service.mjs +59 -133
  24. package/esm2020/core/services/index.mjs +3 -3
  25. package/esm2020/core/services/quote-draft.service.mjs +20 -38
  26. package/esm2020/core/services/sales-transaction.service.mjs +62 -0
  27. package/esm2020/core/types/flow-state.types.mjs +1 -1
  28. package/esm2020/src/components/flow-header/flow-header.component.mjs +3 -6
  29. package/esm2020/src/components/guided-selling/guided-selling.component.mjs +3 -6
  30. package/esm2020/src/flow-routing.module.mjs +5 -36
  31. package/esm2020/src/flow.component.mjs +5 -5
  32. package/esm2020/src/guards/flow.guard.mjs +10 -9
  33. package/esm2020/src/guards/product-unload.guard.mjs +5 -7
  34. package/esm2020/src/index.mjs +1 -2
  35. package/esm2020/src/pages/assets/assets.component.mjs +3 -3
  36. package/esm2020/src/pages/catalog/catalog.component.mjs +3 -3
  37. package/esm2020/src/pages/debug/debug.component.mjs +7 -11
  38. package/esm2020/src/pages/product/product.component.mjs +47 -67
  39. package/esm2020/src/pages/product/product.module.mjs +5 -5
  40. package/esm2020/src/pages/shopping-cart/shopping-cart.component.mjs +3 -3
  41. package/esm2020/src/resolvers/flow.resolver.mjs +10 -18
  42. package/esm2020/src/resolvers/quote.resolver.mjs +11 -11
  43. package/esm2020/src/services/flow-dialog.service.mjs +8 -8
  44. package/esm2020/src/services/flow-router.service.mjs +11 -21
  45. package/esm2020/src/services/flow.service.mjs +10 -43
  46. package/esm2020/src/utils/flow.utils.mjs +2 -13
  47. package/fesm2015/veloceapps-sdk-cms.mjs +7 -6
  48. package/fesm2015/veloceapps-sdk-cms.mjs.map +1 -1
  49. package/fesm2015/veloceapps-sdk-core.mjs +1483 -1636
  50. package/fesm2015/veloceapps-sdk-core.mjs.map +1 -1
  51. package/fesm2015/veloceapps-sdk.mjs +126 -672
  52. package/fesm2015/veloceapps-sdk.mjs.map +1 -1
  53. package/fesm2020/veloceapps-sdk-cms.mjs +7 -6
  54. package/fesm2020/veloceapps-sdk-cms.mjs.map +1 -1
  55. package/fesm2020/veloceapps-sdk-core.mjs +1515 -1707
  56. package/fesm2020/veloceapps-sdk-core.mjs.map +1 -1
  57. package/fesm2020/veloceapps-sdk.mjs +124 -667
  58. package/fesm2020/veloceapps-sdk.mjs.map +1 -1
  59. package/package.json +1 -1
  60. package/src/components/flow-header/flow-header.component.d.ts +1 -1
  61. package/src/components/guided-selling/guided-selling.component.d.ts +1 -1
  62. package/src/flow-routing.module.d.ts +1 -2
  63. package/src/flow.component.d.ts +2 -2
  64. package/src/guards/product-unload.guard.d.ts +4 -5
  65. package/src/index.d.ts +0 -1
  66. package/src/pages/assets/assets.component.d.ts +1 -1
  67. package/src/pages/catalog/catalog.component.d.ts +1 -1
  68. package/src/pages/debug/debug.component.d.ts +2 -3
  69. package/src/pages/product/product.component.d.ts +9 -10
  70. package/src/pages/product/product.module.d.ts +1 -1
  71. package/src/pages/shopping-cart/shopping-cart.component.d.ts +1 -1
  72. package/src/resolvers/flow.resolver.d.ts +5 -6
  73. package/src/resolvers/quote.resolver.d.ts +5 -6
  74. package/src/services/flow-dialog.service.d.ts +3 -3
  75. package/src/services/flow-router.service.d.ts +2 -4
  76. package/src/services/flow.service.d.ts +2 -6
  77. package/src/utils/flow.utils.d.ts +0 -7
  78. package/core/services/context.service.d.ts +0 -23
  79. package/esm2020/core/services/context.service.mjs +0 -91
  80. package/esm2020/src/guards/context.guard.mjs +0 -91
  81. package/esm2020/src/guards/index.mjs +0 -2
  82. package/esm2020/src/pages/remote/remote.component.mjs +0 -342
  83. package/esm2020/src/pages/remote/remote.module.mjs +0 -20
  84. package/esm2020/src/pages/remote/remote.types.mjs +0 -2
  85. package/src/guards/context.guard.d.ts +0 -19
  86. package/src/guards/index.d.ts +0 -1
  87. package/src/pages/remote/remote.component.d.ts +0 -46
  88. package/src/pages/remote/remote.module.d.ts +0 -10
  89. package/src/pages/remote/remote.types.d.ts +0 -4
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@veloceapps/sdk",
3
- "version": "11.0.0-11",
3
+ "version": "11.0.0-12",
4
4
  "private": false,
5
5
  "peerDependencies": {
6
6
  "@angular/animations": "~15.2.0",
@@ -1,5 +1,5 @@
1
1
  import { OnDestroy } from '@angular/core';
2
- import { UITemplatesApiService } from '@veloceapps/api';
2
+ import { UITemplatesApiService } from '@veloceapps/api/v2';
3
3
  import { ToastService } from '@veloceapps/components';
4
4
  import { UIDefinition } from '@veloceapps/core';
5
5
  import { FlowCustomization, FlowInfoService, FlowStateService } from '@veloceapps/sdk/core';
@@ -1,5 +1,5 @@
1
1
  import { OnDestroy } from '@angular/core';
2
- import { UITemplatesApiService } from '@veloceapps/api';
2
+ import { UITemplatesApiService } from '@veloceapps/api/v2';
3
3
  import { ToastService } from '@veloceapps/components';
4
4
  import { UIDefinition } from '@veloceapps/core';
5
5
  import { FlowCustomization, FlowInfoService, FlowStateService } from '@veloceapps/sdk/core';
@@ -4,9 +4,8 @@ import * as i2 from "./pages/product/product.module";
4
4
  import * as i3 from "./pages/shopping-cart/shopping-cart.module";
5
5
  import * as i4 from "./pages/catalog/catalog.module";
6
6
  import * as i5 from "./pages/assets/assets.module";
7
- import * as i6 from "./pages/remote/remote.module";
8
7
  export declare class FlowRoutingModule {
9
8
  static ɵfac: i0.ɵɵFactoryDeclaration<FlowRoutingModule, never>;
10
- static ɵmod: i0.ɵɵNgModuleDeclaration<FlowRoutingModule, never, [typeof i1.RouterModule, typeof i2.ProductModule, typeof i3.ShoppingCartModule, typeof i4.CatalogModule, typeof i5.AssetsModule, typeof i6.RemoteModule], [typeof i1.RouterModule]>;
9
+ static ɵmod: i0.ɵɵNgModuleDeclaration<FlowRoutingModule, never, [typeof i1.RouterModule, typeof i2.ProductModule, typeof i3.ShoppingCartModule, typeof i4.CatalogModule, typeof i5.AssetsModule], [typeof i1.RouterModule]>;
11
10
  static ɵinj: i0.ɵɵInjectorDeclaration<FlowRoutingModule>;
12
11
  }
@@ -8,13 +8,13 @@ import * as i0 from "@angular/core";
8
8
  export declare class FlowComponent implements OnDestroy {
9
9
  private routerService;
10
10
  private flowService;
11
- private flowInfo;
11
+ private flowInfoService;
12
12
  private guidedSellingService;
13
13
  isLoading$: Observable<boolean>;
14
14
  showHeader$: Observable<boolean>;
15
15
  isStandalone$: Observable<boolean>;
16
16
  guidedSellingVisible$: Observable<boolean>;
17
- constructor(routerService: FlowRouterService, flowService: FlowService, flowInfo: FlowInfoService, guidedSellingService: FlowGuidedSellingService);
17
+ constructor(routerService: FlowRouterService, flowService: FlowService, flowInfoService: FlowInfoService, guidedSellingService: FlowGuidedSellingService);
18
18
  ngOnDestroy(): void;
19
19
  static ɵfac: i0.ɵɵFactoryDeclaration<FlowComponent, never>;
20
20
  static ɵcmp: i0.ɵɵComponentDeclaration<FlowComponent, "vl-flow", never, {}, {}, never, never, false, never>;
@@ -1,16 +1,15 @@
1
1
  import { Component } from '@angular/core';
2
- import { ActivatedRouteSnapshot, CanDeactivate, Router, RouterStateSnapshot, UrlTree } from '@angular/router';
3
- import { ConfigurationService, ContextService, QuoteDraftService } from '@veloceapps/sdk/core';
2
+ import { ActivatedRouteSnapshot, Router, RouterStateSnapshot, UrlTree } from '@angular/router';
3
+ import { ConfigurationService, QuoteDraftService } from '@veloceapps/sdk/core';
4
4
  import { Observable } from 'rxjs';
5
5
  import { FlowDialogService } from '../services/flow-dialog.service';
6
6
  import * as i0 from "@angular/core";
7
- export declare class ProductUnloadGuard implements CanDeactivate<any> {
7
+ export declare class ProductUnloadGuard {
8
8
  private router;
9
- private contextService;
10
9
  private quoteDraftService;
11
10
  private configurationService;
12
11
  private flowDialogService;
13
- constructor(router: Router, contextService: ContextService, quoteDraftService: QuoteDraftService, configurationService: ConfigurationService, flowDialogService: FlowDialogService);
12
+ constructor(router: Router, quoteDraftService: QuoteDraftService, configurationService: ConfigurationService, flowDialogService: FlowDialogService);
14
13
  canDeactivate(_: Component, route: ActivatedRouteSnapshot, currentState: RouterStateSnapshot, nextState?: RouterStateSnapshot): Observable<boolean | UrlTree>;
15
14
  static ɵfac: i0.ɵɵFactoryDeclaration<ProductUnloadGuard, never>;
16
15
  static ɵprov: i0.ɵɵInjectableDeclaration<ProductUnloadGuard>;
package/src/index.d.ts CHANGED
@@ -1,6 +1,5 @@
1
1
  export * from './constants';
2
2
  export * from './flow.module';
3
- export * from './guards';
4
3
  export * from './services';
5
4
  export * from './types';
6
5
  export * from './utils';
@@ -1,5 +1,5 @@
1
1
  import { ChangeDetectorRef, OnDestroy, OnInit } from '@angular/core';
2
- import { UITemplatesApiService } from '@veloceapps/api';
2
+ import { UITemplatesApiService } from '@veloceapps/api/v2';
3
3
  import { ToastService } from '@veloceapps/components';
4
4
  import { UIDefinition } from '@veloceapps/core';
5
5
  import { FlowCustomization, FlowInfoService } from '@veloceapps/sdk/core';
@@ -1,5 +1,5 @@
1
1
  import { ChangeDetectorRef, OnDestroy, OnInit } from '@angular/core';
2
- import { UITemplatesApiService } from '@veloceapps/api';
2
+ import { UITemplatesApiService } from '@veloceapps/api/v2';
3
3
  import { ToastService } from '@veloceapps/components';
4
4
  import { UIDefinition } from '@veloceapps/core';
5
5
  import { FlowCustomization, FlowInfoService } from '@veloceapps/sdk/core';
@@ -2,21 +2,20 @@ import { FormControl, FormGroup } from '@angular/forms';
2
2
  import { ActivatedRoute, Params, Router } from '@angular/router';
3
3
  import { FlowsApiService } from '@veloceapps/api';
4
4
  import { Flow } from '@veloceapps/core';
5
- import { ContextService, QuoteDraftService } from '@veloceapps/sdk/core';
5
+ import { QuoteDraftService } from '@veloceapps/sdk/core';
6
6
  import { Observable } from 'rxjs';
7
7
  import * as i0 from "@angular/core";
8
8
  export declare class DebugComponent {
9
9
  private flowsApiService;
10
10
  private router;
11
11
  private activatedRoute;
12
- private context;
13
12
  private quoteDraftService;
14
13
  form: FormGroup<{
15
14
  id: FormControl<string | null>;
16
15
  }>;
17
16
  selectedFlow?: Flow;
18
17
  flows$: Observable<Flow[]>;
19
- constructor(flowsApiService: FlowsApiService, router: Router, activatedRoute: ActivatedRoute, context: ContextService, quoteDraftService: QuoteDraftService);
18
+ constructor(flowsApiService: FlowsApiService, router: Router, activatedRoute: ActivatedRoute, quoteDraftService: QuoteDraftService);
20
19
  runFlow(): void;
21
20
  getQueryParamsString(params: Params): string;
22
21
  static ɵfac: i0.ɵɵFactoryDeclaration<DebugComponent, never>;
@@ -1,24 +1,23 @@
1
- import { UIDefinition } from '@veloceapps/core';
1
+ import { UIDefinitionsApiService } from '@veloceapps/api/v2';
2
+ import { UIDefinitionContainer } from '@veloceapps/core';
2
3
  import { CMSPreviewConfig } from '@veloceapps/sdk/cms';
3
- import { ConfigurationRuntimeService, ConfigurationService, ConfigurationStateService, ContextService, FlowCustomization, FlowInfoService, FlowStateService, IntegrationState, QuoteDraftService } from '@veloceapps/sdk/core';
4
+ import { ConfigurationService, ConfigurationStateService, FlowCustomization, FlowInfoService, IntegrationState, SalesTransactionService } from '@veloceapps/sdk/core';
4
5
  import { BehaviorSubject } from 'rxjs';
5
6
  import * as i0 from "@angular/core";
6
7
  export declare class ProductComponent {
7
- private contextService;
8
- private configurationRuntimeService;
9
8
  private configurationService;
10
9
  private configurationStateService;
11
- private quoteDraftService;
10
+ private salesTransactionService;
12
11
  private flowInfoService;
13
- private flowStateService;
14
12
  private integrationState;
13
+ private uiDefinitionsApiService;
15
14
  private customizationService?;
16
15
  config: CMSPreviewConfig;
17
- uiDefinition$: BehaviorSubject<UIDefinition | undefined>;
18
- constructor(contextService: ContextService, configurationRuntimeService: ConfigurationRuntimeService, configurationService: ConfigurationService, configurationStateService: ConfigurationStateService, quoteDraftService: QuoteDraftService, flowInfoService: FlowInfoService, flowStateService: FlowStateService, integrationState: IntegrationState, customizationService?: FlowCustomization | undefined);
16
+ uiDefinitionContainer$: BehaviorSubject<UIDefinitionContainer | null>;
17
+ constructor(configurationService: ConfigurationService, configurationStateService: ConfigurationStateService, salesTransactionService: SalesTransactionService, flowInfoService: FlowInfoService, integrationState: IntegrationState, uiDefinitionsApiService: UIDefinitionsApiService, customizationService?: FlowCustomization | undefined);
19
18
  private customizeUI$;
19
+ private fetchUIDefinition$;
20
20
  private init$;
21
- private getLineItem;
22
- static ɵfac: i0.ɵɵFactoryDeclaration<ProductComponent, [null, null, null, null, null, null, null, null, { optional: true; }]>;
21
+ static ɵfac: i0.ɵɵFactoryDeclaration<ProductComponent, [null, null, null, null, null, null, { optional: true; }]>;
23
22
  static ɵcmp: i0.ɵɵComponentDeclaration<ProductComponent, "vl-flow-product", never, {}, {}, never, never, false, never>;
24
23
  }
@@ -5,6 +5,6 @@ import * as i3 from "@veloceapps/sdk/cms";
5
5
  import * as i4 from "@veloceapps/components";
6
6
  export declare class ProductModule {
7
7
  static ɵfac: i0.ɵɵFactoryDeclaration<ProductModule, never>;
8
- static ɵmod: i0.ɵɵNgModuleDeclaration<ProductModule, [typeof i1.ProductComponent], [typeof i2.CommonModule, typeof i3.PreviewModule, typeof i4.LoaderModule], [typeof i1.ProductComponent]>;
8
+ static ɵmod: i0.ɵɵNgModuleDeclaration<ProductModule, [typeof i1.ProductComponent], [typeof i2.CommonModule, typeof i3.PreviewModule, typeof i4.LoaderModule, typeof i4.LetDirectiveModule], [typeof i1.ProductComponent]>;
9
9
  static ɵinj: i0.ɵɵInjectorDeclaration<ProductModule>;
10
10
  }
@@ -1,5 +1,5 @@
1
1
  import { ChangeDetectorRef, OnDestroy, OnInit } from '@angular/core';
2
- import { UITemplatesApiService } from '@veloceapps/api';
2
+ import { UITemplatesApiService } from '@veloceapps/api/v2';
3
3
  import { ToastService } from '@veloceapps/components';
4
4
  import { UIDefinition } from '@veloceapps/core';
5
5
  import { FlowCustomization, FlowInfoService } from '@veloceapps/sdk/core';
@@ -1,14 +1,13 @@
1
- import { ActivatedRouteSnapshot, Resolve, Router } from '@angular/router';
2
- import { ContextService, FlowInfoService } from '@veloceapps/sdk/core';
1
+ import { ActivatedRouteSnapshot, Router } from '@angular/router';
2
+ import { FlowInfoService } from '@veloceapps/sdk/core';
3
3
  import { Observable } from 'rxjs';
4
4
  import { FlowRouterService } from '../services/flow-router.service';
5
5
  import * as i0 from "@angular/core";
6
- export declare class FlowResolver implements Resolve<unknown> {
6
+ export declare class FlowResolver {
7
7
  private router;
8
8
  private routerService;
9
- private contextService;
10
- private flowInfo;
11
- constructor(router: Router, routerService: FlowRouterService, contextService: ContextService, flowInfo: FlowInfoService);
9
+ private flowInfoService;
10
+ constructor(router: Router, routerService: FlowRouterService, flowInfoService: FlowInfoService);
12
11
  resolve(route: ActivatedRouteSnapshot): Observable<boolean>;
13
12
  static ɵfac: i0.ɵɵFactoryDeclaration<FlowResolver, never>;
14
13
  static ɵprov: i0.ɵɵInjectableDeclaration<FlowResolver>;
@@ -1,16 +1,15 @@
1
- import { ActivatedRouteSnapshot, Resolve, Router } from '@angular/router';
2
- import { ContextService, FlowInfoService, FlowStateService, QuoteDraftService } from '@veloceapps/sdk/core';
1
+ import { ActivatedRouteSnapshot, Router } from '@angular/router';
2
+ import { FlowInfoService, FlowStateService, QuoteDraftService } from '@veloceapps/sdk/core';
3
3
  import { Observable } from 'rxjs';
4
4
  import { FlowRouterService } from '../services/flow-router.service';
5
5
  import * as i0 from "@angular/core";
6
- export declare class QuoteResolver implements Resolve<void | boolean> {
6
+ export declare class QuoteResolver {
7
7
  private router;
8
8
  private quoteDraftService;
9
9
  private routerService;
10
- private contextService;
11
- private flowInfo;
10
+ private flowInfoService;
12
11
  private flowStateService;
13
- constructor(router: Router, quoteDraftService: QuoteDraftService, routerService: FlowRouterService, contextService: ContextService, flowInfo: FlowInfoService, flowStateService: FlowStateService);
12
+ constructor(router: Router, quoteDraftService: QuoteDraftService, routerService: FlowRouterService, flowInfoService: FlowInfoService, flowStateService: FlowStateService);
14
13
  resolve(route: ActivatedRouteSnapshot): Observable<boolean>;
15
14
  private checkDynamicNavigation$;
16
15
  private getNavigateTo;
@@ -1,13 +1,13 @@
1
- import { ContextService, RuntimeSettingsService } from '@veloceapps/sdk/core';
1
+ import { FlowInfoService, RuntimeSettingsService } from '@veloceapps/sdk/core';
2
2
  import { DialogService } from 'primeng/dynamicdialog';
3
3
  import { Observable } from 'rxjs';
4
4
  import { FlowDialogConfig } from '../components/dialog/dialog.types';
5
5
  import * as i0 from "@angular/core";
6
6
  export declare class FlowDialogService {
7
7
  private dialogService;
8
- private contextService;
9
8
  private runtimeSettings;
10
- constructor(dialogService: DialogService, contextService: ContextService, runtimeSettings: RuntimeSettingsService);
9
+ private flowInfoService;
10
+ constructor(dialogService: DialogService, runtimeSettings: RuntimeSettingsService, flowInfoService: FlowInfoService);
11
11
  show(config: FlowDialogConfig): Observable<boolean>;
12
12
  showEmptyCartDialog(): Observable<boolean>;
13
13
  showReadonlyModeDialog(): Observable<boolean>;
@@ -1,20 +1,18 @@
1
1
  import { ActivatedRoute, ActivatedRouteSnapshot, Params, Router } from '@angular/router';
2
- import { ContextService, FlowInfoService, FlowStateService, IntegrationState } from '@veloceapps/sdk/core';
2
+ import { FlowStateService, IntegrationState } from '@veloceapps/sdk/core';
3
3
  import { Observable } from 'rxjs';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class FlowRouterService {
6
6
  private router;
7
7
  private route;
8
- private contextService;
9
8
  private integrationState;
10
- private flowInfoService;
11
9
  private flowStateService;
12
10
  private routeChange$;
13
11
  private lastChildParams$;
14
12
  private lastChildRoute$;
15
13
  private urlHistory;
16
14
  loading$: Observable<boolean>;
17
- constructor(router: Router, route: ActivatedRoute, contextService: ContextService, integrationState: IntegrationState, flowInfoService: FlowInfoService, flowStateService: FlowStateService);
15
+ constructor(router: Router, route: ActivatedRoute, integrationState: IntegrationState, flowStateService: FlowStateService);
18
16
  getFlowRootRoute(route: ActivatedRouteSnapshot): ActivatedRouteSnapshot | undefined;
19
17
  getFlowRootPath(route: ActivatedRouteSnapshot): string;
20
18
  get route$(): Observable<ActivatedRouteSnapshot>;
@@ -1,25 +1,21 @@
1
1
  import { IntegrationState } from '@veloceapps/sdk/cms';
2
- import { ConfigurationService, ConfigurationStateService, FlowConfigurationService, FlowInfoService, FlowStateService, QuoteDraftService } from '@veloceapps/sdk/core';
2
+ import { ConfigurationService, ConfigurationStateService, FlowStateService } from '@veloceapps/sdk/core';
3
3
  import { FlowDialogService } from './flow-dialog.service';
4
4
  import { FlowRouterService } from './flow-router.service';
5
5
  import * as i0 from "@angular/core";
6
6
  export declare class FlowService {
7
7
  private integrationState;
8
8
  private flowRouterService;
9
- private quoteDraftService;
10
9
  private configurationService;
11
10
  private configurationStateService;
12
11
  private flowDialogService;
13
- private flowConfigurationService;
14
- private flowInfoService;
15
12
  private flowStateService;
16
13
  private cleanup$;
17
- constructor(integrationState: IntegrationState, flowRouterService: FlowRouterService, quoteDraftService: QuoteDraftService, configurationService: ConfigurationService, configurationStateService: ConfigurationStateService, flowDialogService: FlowDialogService, flowConfigurationService: FlowConfigurationService, flowInfoService: FlowInfoService, flowStateService: FlowStateService);
14
+ constructor(integrationState: IntegrationState, flowRouterService: FlowRouterService, configurationService: ConfigurationService, configurationStateService: ConfigurationStateService, flowDialogService: FlowDialogService, flowStateService: FlowStateService);
18
15
  cleanup(): void;
19
16
  initSubscriptions(): void;
20
17
  private updateFlowParams;
21
18
  private prepareConfiguration$;
22
- private legacyApplyConfiguration;
23
19
  static ɵfac: i0.ɵɵFactoryDeclaration<FlowService, never>;
24
20
  static ɵprov: i0.ɵɵInjectableDeclaration<FlowService>;
25
21
  }
@@ -1,8 +1 @@
1
- import { ConfigurationContextMode, ContextProperties, FlowProperties } from '@veloceapps/core';
2
1
  export declare const getFlowObjectIdPropertyName: (id: string) => string;
3
- interface DefaultPropertiesFnParams {
4
- mode?: ConfigurationContextMode;
5
- flowParams?: FlowProperties;
6
- }
7
- export declare const getDefaultProperties: (params: DefaultPropertiesFnParams) => ContextProperties;
8
- export {};
@@ -1,23 +0,0 @@
1
- import { ContextApiService } from '@veloceapps/api';
2
- import { ConfigurationContext, ConfigurationContextMode } from '@veloceapps/core';
3
- import { Observable } from 'rxjs';
4
- import * as i0 from "@angular/core";
5
- export declare class ContextService {
6
- private contextApiService;
7
- private context;
8
- constructor(contextApiService: ContextApiService);
9
- get isInitialized(): boolean;
10
- get isInitialized$(): Observable<boolean>;
11
- get mode(): ConfigurationContextMode | undefined;
12
- get isEditMode$(): Observable<boolean>;
13
- get isEditMode(): boolean;
14
- resolve(): ConfigurationContext;
15
- resolve$(): Observable<ConfigurationContext>;
16
- create(headerId: string, mode: ConfigurationContextMode): Observable<ConfigurationContext>;
17
- initTestMode(): Observable<ConfigurationContext>;
18
- update(partialContext: Partial<ConfigurationContext>): ConfigurationContext;
19
- set(context: ConfigurationContext): ConfigurationContext;
20
- delete(): void;
21
- static ɵfac: i0.ɵɵFactoryDeclaration<ContextService, never>;
22
- static ɵprov: i0.ɵɵInjectableDeclaration<ContextService>;
23
- }
@@ -1,91 +0,0 @@
1
- import { Injectable } from '@angular/core';
2
- import { ContextApiService } from '@veloceapps/api';
3
- import { ConfigurationContext, ConfigurationContextMode } from '@veloceapps/core';
4
- import { merge } from 'lodash';
5
- import { BehaviorSubject } from 'rxjs';
6
- import { filter, map, tap } from 'rxjs/operators';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "@veloceapps/api";
9
- export class ContextService {
10
- constructor(contextApiService) {
11
- this.contextApiService = contextApiService;
12
- this.context = new BehaviorSubject(null);
13
- }
14
- get isInitialized() {
15
- return Boolean(this.context.value);
16
- }
17
- get isInitialized$() {
18
- return this.context.pipe(map(Boolean));
19
- }
20
- get mode() {
21
- return this.resolve().properties['#mode'];
22
- }
23
- get isEditMode$() {
24
- return this.resolve$().pipe(map(() => this.isEditMode));
25
- }
26
- get isEditMode() {
27
- const context = this.resolve();
28
- if (context.properties['#mode'] === ConfigurationContextMode.ACCOUNT) {
29
- return true;
30
- }
31
- if (context.properties['#mode'] === ConfigurationContextMode.QUOTE) {
32
- return context.properties.Status === 'Draft';
33
- }
34
- return false;
35
- }
36
- resolve() {
37
- if (!this.context.value) {
38
- throw new Error('Context is not initialized yet!');
39
- }
40
- return { ...this.context.value };
41
- }
42
- resolve$() {
43
- return this.context.pipe(filter((ctx) => Boolean(ctx)));
44
- }
45
- create(headerId, mode) {
46
- return this.contextApiService.getContext(headerId, mode).pipe(tap(context => this.context.next(merge(new ConfigurationContext(headerId, mode), context))), map(() => this.resolve()));
47
- }
48
- initTestMode() {
49
- return this.create('TestId', ConfigurationContextMode.TEST).pipe(map(context => {
50
- return this.update({
51
- properties: {
52
- ...context.properties,
53
- RuntimeMode: ConfigurationContextMode.TEST,
54
- StartDate: new Date().toISOString().substring(0, 10),
55
- standalone: 'true',
56
- },
57
- });
58
- }));
59
- }
60
- update(partialContext) {
61
- const originalContext = this.resolve();
62
- const updatedContext = {
63
- ...originalContext,
64
- ...partialContext,
65
- properties: {
66
- ...originalContext.properties,
67
- ...partialContext.properties,
68
- },
69
- };
70
- this.context.next(updatedContext);
71
- return updatedContext;
72
- }
73
- set(context) {
74
- const originalContext = this.resolve();
75
- const updatedContext = {
76
- ...originalContext,
77
- ...context,
78
- };
79
- this.context.next(updatedContext);
80
- return updatedContext;
81
- }
82
- delete() {
83
- this.context.next(null);
84
- }
85
- }
86
- ContextService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ContextService, deps: [{ token: i1.ContextApiService }], target: i0.ɵɵFactoryTarget.Injectable });
87
- ContextService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ContextService });
88
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ContextService, decorators: [{
89
- type: Injectable
90
- }], ctorParameters: function () { return [{ type: i1.ContextApiService }]; } });
91
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context.service.js","sourceRoot":"","sources":["../../../../../../libs/sdk/core/services/context.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { ContextApiService } from '@veloceapps/api';\nimport { ConfigurationContext, ConfigurationContextMode } from '@veloceapps/core';\nimport { merge } from 'lodash';\nimport { BehaviorSubject, Observable } from 'rxjs';\nimport { filter, map, tap } from 'rxjs/operators';\n\n@Injectable()\nexport class ContextService {\n  private context = new BehaviorSubject<ConfigurationContext | null>(null);\n\n  constructor(private contextApiService: ContextApiService) {}\n\n  public get isInitialized(): boolean {\n    return Boolean(this.context.value);\n  }\n\n  public get isInitialized$(): Observable<boolean> {\n    return this.context.pipe(map(Boolean));\n  }\n\n  public get mode(): ConfigurationContextMode | undefined {\n    return this.resolve().properties['#mode'];\n  }\n\n  public get isEditMode$(): Observable<boolean> {\n    return this.resolve$().pipe(map(() => this.isEditMode));\n  }\n\n  public get isEditMode(): boolean {\n    const context = this.resolve();\n\n    if (context.properties['#mode'] === ConfigurationContextMode.ACCOUNT) {\n      return true;\n    }\n\n    if (context.properties['#mode'] === ConfigurationContextMode.QUOTE) {\n      return context.properties.Status === 'Draft';\n    }\n\n    return false;\n  }\n\n  public resolve(): ConfigurationContext {\n    if (!this.context.value) {\n      throw new Error('Context is not initialized yet!');\n    }\n\n    return { ...this.context.value };\n  }\n\n  public resolve$(): Observable<ConfigurationContext> {\n    return this.context.pipe(filter((ctx): ctx is ConfigurationContext => Boolean(ctx)));\n  }\n\n  public create(headerId: string, mode: ConfigurationContextMode): Observable<ConfigurationContext> {\n    return this.contextApiService.getContext(headerId, mode).pipe(\n      tap(context => this.context.next(merge(new ConfigurationContext(headerId, mode), context))),\n      map(() => this.resolve() as ConfigurationContext),\n    );\n  }\n\n  public initTestMode(): Observable<ConfigurationContext> {\n    return this.create('TestId', ConfigurationContextMode.TEST).pipe(\n      map(context => {\n        return this.update({\n          properties: {\n            ...context.properties,\n            RuntimeMode: ConfigurationContextMode.TEST,\n            StartDate: new Date().toISOString().substring(0, 10),\n            standalone: 'true',\n          },\n        });\n      }),\n    );\n  }\n\n  public update(partialContext: Partial<ConfigurationContext>): ConfigurationContext {\n    const originalContext = this.resolve();\n\n    const updatedContext: ConfigurationContext = {\n      ...originalContext,\n      ...(partialContext as ConfigurationContext),\n      properties: {\n        ...originalContext.properties,\n        ...partialContext.properties,\n      },\n    };\n\n    this.context.next(updatedContext);\n\n    return updatedContext;\n  }\n\n  public set(context: ConfigurationContext): ConfigurationContext {\n    const originalContext = this.resolve();\n\n    const updatedContext: ConfigurationContext = {\n      ...originalContext,\n      ...context,\n    };\n\n    this.context.next(updatedContext);\n\n    return updatedContext;\n  }\n\n  public delete(): void {\n    this.context.next(null);\n  }\n}\n"]}
@@ -1,91 +0,0 @@
1
- import { HttpErrorResponse } from '@angular/common/http';
2
- import { Injectable } from '@angular/core';
3
- import { Router } from '@angular/router';
4
- import { ConfigurationContextMode, extractErrorDetails, isVeloceError } from '@veloceapps/core';
5
- import { ContextService, RuntimeSettingsService } from '@veloceapps/sdk/core';
6
- import { catchError, forkJoin, map, of, tap } from 'rxjs';
7
- import { FlowRouterService } from '../services/flow-router.service';
8
- import { getDefaultProperties } from '../utils';
9
- import * as i0 from "@angular/core";
10
- import * as i1 from "@angular/router";
11
- import * as i2 from "../services/flow-router.service";
12
- import * as i3 from "@veloceapps/sdk/core";
13
- export class ContextGuard {
14
- constructor(router, routerService, contextService, runtimeSettingsService) {
15
- this.router = router;
16
- this.routerService = routerService;
17
- this.contextService = contextService;
18
- this.runtimeSettingsService = runtimeSettingsService;
19
- }
20
- checkActivation(route) {
21
- const { queryParams } = route;
22
- const { accountId, quoteId, orderId } = queryParams;
23
- const rpcMessage = window.RPC_MESSAGE;
24
- const mode = this.getConfigurationContextMode(accountId, quoteId, orderId, rpcMessage);
25
- // Restrict if mode is not defined
26
- if (mode == null) {
27
- return this.routerService.showErrorPage$('Mode is undefined');
28
- }
29
- const headerId = accountId || quoteId || orderId || this.rpcMessageId || 'empty-for-test-mode';
30
- // Allow if context is already initialized with the same headerId
31
- if (this.contextService.isInitialized) {
32
- const currentContext = this.contextService.resolve();
33
- if (headerId && currentContext.headerId === headerId) {
34
- return of(true);
35
- }
36
- }
37
- // Initialize context and runtime settings
38
- return forkJoin([this.contextService.create(headerId, mode), this.runtimeSettingsService.create()]).pipe(tap(([context]) => {
39
- this.contextService.update({
40
- ...context,
41
- properties: {
42
- ...context.properties,
43
- ...(queryParams ?? {}),
44
- ...getDefaultProperties({ mode }),
45
- },
46
- });
47
- // Init currency settings
48
- this.runtimeSettingsService.initCurrency(context.properties['CurrencyIsoCode']);
49
- }), map(() => true), catchError(e => {
50
- const message = e instanceof HttpErrorResponse ? e.error.message : e;
51
- const errorDetails = isVeloceError(e.error) ? extractErrorDetails(e.error) : [];
52
- return this.routerService.showErrorPage$(message, errorDetails);
53
- }));
54
- }
55
- canActivate(route) {
56
- return this.checkActivation(route);
57
- }
58
- canActivateChild(childRoute) {
59
- return this.checkActivation(childRoute);
60
- }
61
- get rpcMessageId() {
62
- if (!window.RPC_MESSAGE) {
63
- return;
64
- }
65
- const rpcMessage = JSON.parse(window.RPC_MESSAGE);
66
- const veloceReferenceId = rpcMessage.configuration?.VeloceReferenceId;
67
- const quoteId = rpcMessage.quote?.Id;
68
- return veloceReferenceId || quoteId;
69
- }
70
- getConfigurationContextMode(accountId, quoteId, orderId, rpcMessage) {
71
- if (accountId) {
72
- return ConfigurationContextMode.ACCOUNT;
73
- }
74
- if (quoteId) {
75
- return ConfigurationContextMode.QUOTE;
76
- }
77
- if (orderId) {
78
- return ConfigurationContextMode.ORDER;
79
- }
80
- if (rpcMessage) {
81
- return ConfigurationContextMode.REMOTE;
82
- }
83
- return;
84
- }
85
- }
86
- ContextGuard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ContextGuard, deps: [{ token: i1.Router }, { token: i2.FlowRouterService }, { token: i3.ContextService }, { token: i3.RuntimeSettingsService }], target: i0.ɵɵFactoryTarget.Injectable });
87
- ContextGuard.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ContextGuard });
88
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ContextGuard, decorators: [{
89
- type: Injectable
90
- }], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.FlowRouterService }, { type: i3.ContextService }, { type: i3.RuntimeSettingsService }]; } });
91
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context.guard.js","sourceRoot":"","sources":["../../../../../../libs/sdk/src/guards/context.guard.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpErrorResponse } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { ActivatedRouteSnapshot, CanActivate, CanActivateChild, Router } from '@angular/router';\nimport { ConfigurationContextMode, extractErrorDetails, isVeloceError, RpcMessage, VlWindow } from '@veloceapps/core';\nimport { ContextService, RuntimeSettingsService } from '@veloceapps/sdk/core';\nimport { catchError, forkJoin, map, Observable, of, tap } from 'rxjs';\nimport { FlowRouterService } from '../services/flow-router.service';\nimport { getDefaultProperties } from '../utils';\n\ndeclare const window: VlWindow;\n\n@Injectable()\nexport class ContextGuard implements CanActivate, CanActivateChild {\n  constructor(\n    protected router: Router,\n    protected routerService: FlowRouterService,\n    protected contextService: ContextService,\n    protected runtimeSettingsService: RuntimeSettingsService,\n  ) {}\n\n  public checkActivation(route: ActivatedRouteSnapshot): Observable<boolean> {\n    const { queryParams } = route;\n    const { accountId, quoteId, orderId } = queryParams;\n    const rpcMessage = window.RPC_MESSAGE;\n    const mode = this.getConfigurationContextMode(accountId, quoteId, orderId, rpcMessage);\n\n    // Restrict if mode is not defined\n    if (mode == null) {\n      return this.routerService.showErrorPage$('Mode is undefined');\n    }\n\n    const headerId = accountId || quoteId || orderId || this.rpcMessageId || 'empty-for-test-mode';\n\n    // Allow if context is already initialized with the same headerId\n    if (this.contextService.isInitialized) {\n      const currentContext = this.contextService.resolve();\n\n      if (headerId && currentContext.headerId === headerId) {\n        return of(true);\n      }\n    }\n\n    // Initialize context and runtime settings\n    return forkJoin([this.contextService.create(headerId, mode), this.runtimeSettingsService.create()]).pipe(\n      tap(([context]) => {\n        this.contextService.update({\n          ...context,\n          properties: {\n            ...context.properties,\n            ...(queryParams ?? {}),\n            ...getDefaultProperties({ mode }),\n          },\n        });\n\n        // Init currency settings\n        this.runtimeSettingsService.initCurrency(context.properties['CurrencyIsoCode']);\n      }),\n      map(() => true),\n      catchError(e => {\n        const message = e instanceof HttpErrorResponse ? e.error.message : e;\n        const errorDetails = isVeloceError(e.error) ? extractErrorDetails(e.error) : [];\n        return this.routerService.showErrorPage$(message, errorDetails);\n      }),\n    );\n  }\n\n  public canActivate(route: ActivatedRouteSnapshot): Observable<boolean> | Promise<boolean> | boolean {\n    return this.checkActivation(route);\n  }\n\n  public canActivateChild(childRoute: ActivatedRouteSnapshot): Observable<boolean> | Promise<boolean> | boolean {\n    return this.checkActivation(childRoute);\n  }\n\n  private get rpcMessageId(): string | undefined {\n    if (!window.RPC_MESSAGE) {\n      return;\n    }\n\n    const rpcMessage: RpcMessage = JSON.parse(window.RPC_MESSAGE);\n    const veloceReferenceId = rpcMessage.configuration?.VeloceReferenceId;\n    const quoteId = rpcMessage.quote?.Id;\n\n    return veloceReferenceId || quoteId;\n  }\n\n  private getConfigurationContextMode(\n    accountId?: string,\n    quoteId?: string,\n    orderId?: string,\n    rpcMessage?: string,\n  ): ConfigurationContextMode | undefined {\n    if (accountId) {\n      return ConfigurationContextMode.ACCOUNT;\n    }\n\n    if (quoteId) {\n      return ConfigurationContextMode.QUOTE;\n    }\n\n    if (orderId) {\n      return ConfigurationContextMode.ORDER;\n    }\n\n    if (rpcMessage) {\n      return ConfigurationContextMode.REMOTE;\n    }\n\n    return;\n  }\n}\n"]}
@@ -1,2 +0,0 @@
1
- export * from './context.guard';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Nkay9zcmMvZ3VhcmRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbnRleHQuZ3VhcmQnO1xuIl19