@veloceapps/sdk 11.0.0-10 → 11.0.0-12
Sign up to get free protection for your applications and to get access to all the features.
- 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":"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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
|