@veloceapps/sdk 11.0.0-11 → 11.0.0-13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cms/vendor-map.d.ts +7 -6
- package/core/modules/configuration/helpers.d.ts +2 -1
- package/core/modules/configuration/services/configuration-runtime.service.d.ts +1 -3
- package/core/modules/configuration/services/configuration-state.service.d.ts +7 -7
- package/core/modules/configuration/services/configuration.service.d.ts +5 -10
- package/core/modules/flow-configuration/services/flow-configuration.service.d.ts +11 -32
- package/core/services/catalog-products.service.d.ts +11 -0
- package/core/services/flow-info.service.d.ts +23 -10
- package/core/services/flow-state.service.d.ts +9 -12
- package/core/services/index.d.ts +2 -2
- package/core/services/quote-draft.service.d.ts +5 -5
- package/core/services/sales-transaction.service.d.ts +28 -0
- package/core/types/flow-state.types.d.ts +2 -2
- package/esm2020/cms/vendor-map.mjs +8 -7
- package/esm2020/core/core.module.mjs +7 -4
- package/esm2020/core/modules/configuration/helpers.mjs +11 -17
- package/esm2020/core/modules/configuration/services/configuration-runtime.service.mjs +8 -45
- package/esm2020/core/modules/configuration/services/configuration-state.service.mjs +46 -54
- package/esm2020/core/modules/configuration/services/configuration.service.mjs +21 -39
- package/esm2020/core/modules/flow-configuration/services/flow-configuration.service.mjs +34 -110
- package/esm2020/core/services/catalog-products.service.mjs +25 -0
- package/esm2020/core/services/flow-info.service.mjs +70 -28
- package/esm2020/core/services/flow-state.service.mjs +59 -133
- package/esm2020/core/services/index.mjs +3 -3
- package/esm2020/core/services/quote-draft.service.mjs +20 -38
- package/esm2020/core/services/sales-transaction.service.mjs +62 -0
- package/esm2020/core/types/flow-state.types.mjs +1 -1
- package/esm2020/src/components/flow-header/flow-header.component.mjs +3 -6
- package/esm2020/src/components/guided-selling/guided-selling.component.mjs +3 -6
- package/esm2020/src/flow-routing.module.mjs +5 -36
- package/esm2020/src/flow.component.mjs +5 -5
- package/esm2020/src/guards/flow.guard.mjs +10 -9
- package/esm2020/src/guards/product-unload.guard.mjs +5 -7
- package/esm2020/src/index.mjs +1 -2
- package/esm2020/src/pages/assets/assets.component.mjs +3 -3
- package/esm2020/src/pages/catalog/catalog.component.mjs +3 -3
- package/esm2020/src/pages/debug/debug.component.mjs +7 -11
- package/esm2020/src/pages/product/product.component.mjs +47 -67
- package/esm2020/src/pages/product/product.module.mjs +5 -5
- package/esm2020/src/pages/shopping-cart/shopping-cart.component.mjs +3 -3
- package/esm2020/src/resolvers/flow.resolver.mjs +10 -18
- package/esm2020/src/resolvers/quote.resolver.mjs +11 -11
- package/esm2020/src/services/flow-dialog.service.mjs +8 -8
- package/esm2020/src/services/flow-router.service.mjs +11 -21
- package/esm2020/src/services/flow.service.mjs +10 -43
- package/esm2020/src/utils/flow.utils.mjs +2 -13
- package/fesm2015/veloceapps-sdk-cms.mjs +7 -6
- package/fesm2015/veloceapps-sdk-cms.mjs.map +1 -1
- package/fesm2015/veloceapps-sdk-core.mjs +1483 -1636
- package/fesm2015/veloceapps-sdk-core.mjs.map +1 -1
- package/fesm2015/veloceapps-sdk.mjs +126 -672
- package/fesm2015/veloceapps-sdk.mjs.map +1 -1
- package/fesm2020/veloceapps-sdk-cms.mjs +7 -6
- package/fesm2020/veloceapps-sdk-cms.mjs.map +1 -1
- package/fesm2020/veloceapps-sdk-core.mjs +1515 -1707
- package/fesm2020/veloceapps-sdk-core.mjs.map +1 -1
- package/fesm2020/veloceapps-sdk.mjs +124 -667
- package/fesm2020/veloceapps-sdk.mjs.map +1 -1
- package/package.json +1 -1
- package/src/components/flow-header/flow-header.component.d.ts +1 -1
- package/src/components/guided-selling/guided-selling.component.d.ts +1 -1
- package/src/flow-routing.module.d.ts +1 -2
- package/src/flow.component.d.ts +2 -2
- package/src/guards/product-unload.guard.d.ts +4 -5
- package/src/index.d.ts +0 -1
- package/src/pages/assets/assets.component.d.ts +1 -1
- package/src/pages/catalog/catalog.component.d.ts +1 -1
- package/src/pages/debug/debug.component.d.ts +2 -3
- package/src/pages/product/product.component.d.ts +9 -10
- package/src/pages/product/product.module.d.ts +1 -1
- package/src/pages/shopping-cart/shopping-cart.component.d.ts +1 -1
- package/src/resolvers/flow.resolver.d.ts +5 -6
- package/src/resolvers/quote.resolver.d.ts +5 -6
- package/src/services/flow-dialog.service.d.ts +3 -3
- package/src/services/flow-router.service.d.ts +2 -4
- package/src/services/flow.service.d.ts +2 -6
- package/src/utils/flow.utils.d.ts +0 -7
- package/core/services/context.service.d.ts +0 -23
- package/esm2020/core/services/context.service.mjs +0 -91
- package/esm2020/src/guards/context.guard.mjs +0 -91
- package/esm2020/src/guards/index.mjs +0 -2
- package/esm2020/src/pages/remote/remote.component.mjs +0 -342
- package/esm2020/src/pages/remote/remote.module.mjs +0 -20
- package/esm2020/src/pages/remote/remote.types.mjs +0 -2
- package/src/guards/context.guard.d.ts +0 -19
- package/src/guards/index.d.ts +0 -1
- package/src/pages/remote/remote.component.d.ts +0 -46
- package/src/pages/remote/remote.module.d.ts +0 -10
- package/src/pages/remote/remote.types.d.ts +0 -4
package/package.json
CHANGED
|
@@ -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
|
|
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
|
}
|
package/src/flow.component.d.ts
CHANGED
|
@@ -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
|
|
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,
|
|
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,
|
|
3
|
-
import { ConfigurationService,
|
|
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
|
|
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,
|
|
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,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 {
|
|
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,
|
|
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 {
|
|
1
|
+
import { UIDefinitionsApiService } from '@veloceapps/api/v2';
|
|
2
|
+
import { UIDefinitionContainer } from '@veloceapps/core';
|
|
2
3
|
import { CMSPreviewConfig } from '@veloceapps/sdk/cms';
|
|
3
|
-
import {
|
|
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
|
|
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
|
-
|
|
18
|
-
constructor(
|
|
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
|
-
|
|
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,
|
|
2
|
-
import {
|
|
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
|
|
6
|
+
export declare class FlowResolver {
|
|
7
7
|
private router;
|
|
8
8
|
private routerService;
|
|
9
|
-
private
|
|
10
|
-
|
|
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,
|
|
2
|
-
import {
|
|
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
|
|
6
|
+
export declare class QuoteResolver {
|
|
7
7
|
private router;
|
|
8
8
|
private quoteDraftService;
|
|
9
9
|
private routerService;
|
|
10
|
-
private
|
|
11
|
-
private flowInfo;
|
|
10
|
+
private flowInfoService;
|
|
12
11
|
private flowStateService;
|
|
13
|
-
constructor(router: Router, quoteDraftService: QuoteDraftService, routerService: FlowRouterService,
|
|
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 {
|
|
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
|
-
|
|
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 {
|
|
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,
|
|
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,
|
|
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,
|
|
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":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAyD,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAChG,OAAO,EAAE,wBAAwB,EAAE,mBAAmB,EAAE,aAAa,EAAwB,MAAM,kBAAkB,CAAC;AACtH,OAAO,EAAE,cAAc,EAAE,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AAC9E,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,EAAc,EAAE,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AACtE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,EAAE,oBAAoB,EAAE,MAAM,UAAU,CAAC;;;;;AAKhD,MAAM,OAAO,YAAY;IACvB,YACY,MAAc,EACd,aAAgC,EAChC,cAA8B,EAC9B,sBAA8C;QAH9C,WAAM,GAAN,MAAM,CAAQ;QACd,kBAAa,GAAb,aAAa,CAAmB;QAChC,mBAAc,GAAd,cAAc,CAAgB;QAC9B,2BAAsB,GAAtB,sBAAsB,CAAwB;IACvD,CAAC;IAEG,eAAe,CAAC,KAA6B;QAClD,MAAM,EAAE,WAAW,EAAE,GAAG,KAAK,CAAC;QAC9B,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,WAAW,CAAC;QACpD,MAAM,UAAU,GAAG,MAAM,CAAC,WAAW,CAAC;QACtC,MAAM,IAAI,GAAG,IAAI,CAAC,2BAA2B,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;QAEvF,kCAAkC;QAClC,IAAI,IAAI,IAAI,IAAI,EAAE;YAChB,OAAO,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,mBAAmB,CAAC,CAAC;SAC/D;QAED,MAAM,QAAQ,GAAG,SAAS,IAAI,OAAO,IAAI,OAAO,IAAI,IAAI,CAAC,YAAY,IAAI,qBAAqB,CAAC;QAE/F,iEAAiE;QACjE,IAAI,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE;YACrC,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;YAErD,IAAI,QAAQ,IAAI,cAAc,CAAC,QAAQ,KAAK,QAAQ,EAAE;gBACpD,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;aACjB;SACF;QAED,0CAA0C;QAC1C,OAAO,QAAQ,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE,IAAI,CAAC,sBAAsB,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,IAAI,CACtG,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,EAAE;YAChB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC;gBACzB,GAAG,OAAO;gBACV,UAAU,EAAE;oBACV,GAAG,OAAO,CAAC,UAAU;oBACrB,GAAG,CAAC,WAAW,IAAI,EAAE,CAAC;oBACtB,GAAG,oBAAoB,CAAC,EAAE,IAAI,EAAE,CAAC;iBAClC;aACF,CAAC,CAAC;YAEH,yBAAyB;YACzB,IAAI,CAAC,sBAAsB,CAAC,YAAY,CAAC,OAAO,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC,CAAC;QAClF,CAAC,CAAC,EACF,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,EACf,UAAU,CAAC,CAAC,CAAC,EAAE;YACb,MAAM,OAAO,GAAG,CAAC,YAAY,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;YACrE,MAAM,YAAY,GAAG,aAAa,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YAChF,OAAO,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;QAClE,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEM,WAAW,CAAC,KAA6B;QAC9C,OAAO,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;IACrC,CAAC;IAEM,gBAAgB,CAAC,UAAkC;QACxD,OAAO,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;IAC1C,CAAC;IAED,IAAY,YAAY;QACtB,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE;YACvB,OAAO;SACR;QAED,MAAM,UAAU,GAAe,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;QAC9D,MAAM,iBAAiB,GAAG,UAAU,CAAC,aAAa,EAAE,iBAAiB,CAAC;QACtE,MAAM,OAAO,GAAG,UAAU,CAAC,KAAK,EAAE,EAAE,CAAC;QAErC,OAAO,iBAAiB,IAAI,OAAO,CAAC;IACtC,CAAC;IAEO,2BAA2B,CACjC,SAAkB,EAClB,OAAgB,EAChB,OAAgB,EAChB,UAAmB;QAEnB,IAAI,SAAS,EAAE;YACb,OAAO,wBAAwB,CAAC,OAAO,CAAC;SACzC;QAED,IAAI,OAAO,EAAE;YACX,OAAO,wBAAwB,CAAC,KAAK,CAAC;SACvC;QAED,IAAI,OAAO,EAAE;YACX,OAAO,wBAAwB,CAAC,KAAK,CAAC;SACvC;QAED,IAAI,UAAU,EAAE;YACd,OAAO,wBAAwB,CAAC,MAAM,CAAC;SACxC;QAED,OAAO;IACT,CAAC;;yGAjGU,YAAY;6GAAZ,YAAY;2FAAZ,YAAY;kBADxB,UAAU","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
|