@veloceapps/sdk 3.1.7 → 3.1.9
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/bundles/veloce-sdk-cms.umd.js +2 -1
- package/bundles/veloce-sdk-cms.umd.js.map +1 -1
- package/bundles/veloce-sdk-core.umd.js +35 -2
- package/bundles/veloce-sdk-core.umd.js.map +1 -1
- package/bundles/veloce-sdk.umd.js +208 -262
- package/bundles/veloce-sdk.umd.js.map +1 -1
- package/cms/vendor-map.d.ts +5 -2
- package/core/services/index.d.ts +1 -0
- package/core/services/product-images.service.d.ts +12 -0
- package/esm2015/cms/vendor-map.js +7 -4
- package/esm2015/core/core.module.js +4 -4
- package/esm2015/core/services/index.js +2 -1
- package/esm2015/core/services/product-images.service.js +30 -0
- package/esm2015/src/components/header/cart-overlay/cart-preview.component.js +116 -0
- package/esm2015/src/components/header/cart-overlay/cart-preview.module.js +23 -0
- package/esm2015/src/components/header/header.component.js +3 -3
- package/esm2015/src/components/header/header.module.js +5 -5
- package/esm2015/src/flow-routing.module.js +7 -24
- package/esm2015/src/guards/context.guard.js +45 -33
- package/esm2015/src/guards/product-unload.guard.js +22 -10
- package/esm2015/src/resolvers/quote.resolver.js +3 -2
- package/fesm2015/veloce-sdk-cms.js +6 -3
- package/fesm2015/veloce-sdk-cms.js.map +1 -1
- package/fesm2015/veloce-sdk-core.js +34 -8
- package/fesm2015/veloce-sdk-core.js.map +1 -1
- package/fesm2015/veloce-sdk.js +136 -184
- package/fesm2015/veloce-sdk.js.map +1 -1
- package/package.json +1 -1
- package/src/components/header/cart-overlay/{cart-overlay.component.d.ts → cart-preview.component.d.ts} +7 -10
- package/src/components/header/cart-overlay/cart-preview.module.d.ts +13 -0
- package/src/components/header/header.module.d.ts +2 -2
- package/src/guards/context.guard.d.ts +6 -4
- package/src/guards/product-unload.guard.d.ts +5 -3
- package/esm2015/src/components/header/cart-overlay/cart-overlay.component.js +0 -133
- package/esm2015/src/components/header/cart-overlay/cart-overlay.module.js +0 -23
- package/esm2015/src/resolvers/context.resolver.js +0 -44
- package/src/components/header/cart-overlay/cart-overlay.module.d.ts +0 -13
- package/src/resolvers/context.resolver.d.ts +0 -16
@@ -4,20 +4,20 @@ import { LetDirectiveModule } from '@veloce/components';
|
|
4
4
|
import { ButtonModule } from 'primeng/button';
|
5
5
|
import { OverlayPanelModule } from 'primeng/overlaypanel';
|
6
6
|
import { TooltipModule } from 'primeng/tooltip';
|
7
|
-
import {
|
7
|
+
import { CartPreviewModule } from './cart-overlay/cart-preview.module';
|
8
8
|
import { FlowHeaderComponent } from './header.component';
|
9
9
|
import * as i0 from "@angular/core";
|
10
10
|
export class FlowHeaderModule {
|
11
11
|
}
|
12
12
|
FlowHeaderModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: FlowHeaderModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
13
|
-
FlowHeaderModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: FlowHeaderModule, declarations: [FlowHeaderComponent], imports: [CommonModule, OverlayPanelModule, LetDirectiveModule, TooltipModule, ButtonModule,
|
14
|
-
FlowHeaderModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: FlowHeaderModule, imports: [[CommonModule, OverlayPanelModule, LetDirectiveModule, TooltipModule, ButtonModule,
|
13
|
+
FlowHeaderModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: FlowHeaderModule, declarations: [FlowHeaderComponent], imports: [CommonModule, OverlayPanelModule, LetDirectiveModule, TooltipModule, ButtonModule, CartPreviewModule], exports: [FlowHeaderComponent] });
|
14
|
+
FlowHeaderModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: FlowHeaderModule, imports: [[CommonModule, OverlayPanelModule, LetDirectiveModule, TooltipModule, ButtonModule, CartPreviewModule]] });
|
15
15
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: FlowHeaderModule, decorators: [{
|
16
16
|
type: NgModule,
|
17
17
|
args: [{
|
18
18
|
declarations: [FlowHeaderComponent],
|
19
|
-
imports: [CommonModule, OverlayPanelModule, LetDirectiveModule, TooltipModule, ButtonModule,
|
19
|
+
imports: [CommonModule, OverlayPanelModule, LetDirectiveModule, TooltipModule, ButtonModule, CartPreviewModule],
|
20
20
|
exports: [FlowHeaderComponent],
|
21
21
|
}]
|
22
22
|
}] });
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2RrL3NyYy9jb21wb25lbnRzL2hlYWRlci9oZWFkZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUMxRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDaEQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDdkUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7O0FBT3pELE1BQU0sT0FBTyxnQkFBZ0I7OzhHQUFoQixnQkFBZ0I7K0dBQWhCLGdCQUFnQixpQkFKWixtQkFBbUIsYUFDeEIsWUFBWSxFQUFFLGtCQUFrQixFQUFFLGtCQUFrQixFQUFFLGFBQWEsRUFBRSxZQUFZLEVBQUUsaUJBQWlCLGFBQ3BHLG1CQUFtQjsrR0FFbEIsZ0JBQWdCLFlBSGxCLENBQUMsWUFBWSxFQUFFLGtCQUFrQixFQUFFLGtCQUFrQixFQUFFLGFBQWEsRUFBRSxZQUFZLEVBQUUsaUJBQWlCLENBQUM7NEZBR3BHLGdCQUFnQjtrQkFMNUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztvQkFDbkMsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGtCQUFrQixFQUFFLGtCQUFrQixFQUFFLGFBQWEsRUFBRSxZQUFZLEVBQUUsaUJBQWlCLENBQUM7b0JBQy9HLE9BQU8sRUFBRSxDQUFDLG1CQUFtQixDQUFDO2lCQUMvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTGV0RGlyZWN0aXZlTW9kdWxlIH0gZnJvbSAnQHZlbG9jZS9jb21wb25lbnRzJztcbmltcG9ydCB7IEJ1dHRvbk1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvYnV0dG9uJztcbmltcG9ydCB7IE92ZXJsYXlQYW5lbE1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvb3ZlcmxheXBhbmVsJztcbmltcG9ydCB7IFRvb2x0aXBNb2R1bGUgfSBmcm9tICdwcmltZW5nL3Rvb2x0aXAnO1xuaW1wb3J0IHsgQ2FydFByZXZpZXdNb2R1bGUgfSBmcm9tICcuL2NhcnQtb3ZlcmxheS9jYXJ0LXByZXZpZXcubW9kdWxlJztcbmltcG9ydCB7IEZsb3dIZWFkZXJDb21wb25lbnQgfSBmcm9tICcuL2hlYWRlci5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtGbG93SGVhZGVyQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgT3ZlcmxheVBhbmVsTW9kdWxlLCBMZXREaXJlY3RpdmVNb2R1bGUsIFRvb2x0aXBNb2R1bGUsIEJ1dHRvbk1vZHVsZSwgQ2FydFByZXZpZXdNb2R1bGVdLFxuICBleHBvcnRzOiBbRmxvd0hlYWRlckNvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIEZsb3dIZWFkZXJNb2R1bGUge31cbiJdfQ==
|
@@ -15,7 +15,6 @@ import { ProductModule } from './pages/product/product.module';
|
|
15
15
|
import { RecordNotFoundModule } from './pages/record-not-found/record-not-found.module';
|
16
16
|
import { ShoppingCartComponent } from './pages/shopping-cart/shopping-cart.component';
|
17
17
|
import { ShoppingCartModule } from './pages/shopping-cart/shopping-cart.module';
|
18
|
-
import { ContextResolver } from './resolvers/context.resolver';
|
19
18
|
import { FlowResolver } from './resolvers/flow.resolver';
|
20
19
|
import { QuoteResolver } from './resolvers/quote.resolver';
|
21
20
|
import { FlowRouterService } from './services/flow-router.service';
|
@@ -42,7 +41,7 @@ const rootRoute = {
|
|
42
41
|
path: 'product',
|
43
42
|
component: LegacyProductComponent,
|
44
43
|
runGuardsAndResolvers: 'paramsOrQueryParamsChange',
|
45
|
-
resolve: {
|
44
|
+
resolve: { quote: QuoteResolver },
|
46
45
|
canActivate: [ContextGuard],
|
47
46
|
},
|
48
47
|
],
|
@@ -51,7 +50,7 @@ const rootRoute = {
|
|
51
50
|
path: 'product',
|
52
51
|
component: ProductComponent,
|
53
52
|
runGuardsAndResolvers: 'paramsOrQueryParamsChange',
|
54
|
-
resolve: {
|
53
|
+
resolve: { quote: QuoteResolver },
|
55
54
|
canActivate: [ContextGuard],
|
56
55
|
canDeactivate: [ProductUnloadGuard],
|
57
56
|
data: { showHeader: true },
|
@@ -60,7 +59,7 @@ const rootRoute = {
|
|
60
59
|
path: 'cart',
|
61
60
|
component: ShoppingCartComponent,
|
62
61
|
runGuardsAndResolvers: 'paramsOrQueryParamsChange',
|
63
|
-
resolve: {
|
62
|
+
resolve: { quote: QuoteResolver },
|
64
63
|
canActivate: [ContextGuard],
|
65
64
|
data: { showHeader: true },
|
66
65
|
},
|
@@ -68,7 +67,7 @@ const rootRoute = {
|
|
68
67
|
path: 'catalog',
|
69
68
|
component: CatalogComponent,
|
70
69
|
runGuardsAndResolvers: 'paramsOrQueryParamsChange',
|
71
|
-
resolve: {
|
70
|
+
resolve: { quote: QuoteResolver },
|
72
71
|
canActivate: [ContextGuard],
|
73
72
|
data: { showHeader: true },
|
74
73
|
},
|
@@ -86,29 +85,13 @@ export class FlowRoutingModule {
|
|
86
85
|
}
|
87
86
|
FlowRoutingModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: FlowRoutingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
88
87
|
FlowRoutingModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: FlowRoutingModule, imports: [i1.RouterModule, ProductModule, LegacyProductModule, ShoppingCartModule, CatalogModule], exports: [RouterModule] });
|
89
|
-
FlowRoutingModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: FlowRoutingModule, providers: [
|
90
|
-
FlowRouterService,
|
91
|
-
RootGuard,
|
92
|
-
ContextGuard,
|
93
|
-
ProductUnloadGuard,
|
94
|
-
ContextResolver,
|
95
|
-
FlowResolver,
|
96
|
-
QuoteResolver,
|
97
|
-
], imports: [[RouterModule.forChild([rootRoute]), ProductModule, LegacyProductModule, ShoppingCartModule, CatalogModule], RouterModule] });
|
88
|
+
FlowRoutingModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: FlowRoutingModule, providers: [FlowRouterService, RootGuard, ContextGuard, ProductUnloadGuard, FlowResolver, QuoteResolver], imports: [[RouterModule.forChild([rootRoute]), ProductModule, LegacyProductModule, ShoppingCartModule, CatalogModule], RouterModule] });
|
98
89
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: FlowRoutingModule, decorators: [{
|
99
90
|
type: NgModule,
|
100
91
|
args: [{
|
101
92
|
imports: [RouterModule.forChild([rootRoute]), ProductModule, LegacyProductModule, ShoppingCartModule, CatalogModule],
|
102
93
|
exports: [RouterModule],
|
103
|
-
providers: [
|
104
|
-
FlowRouterService,
|
105
|
-
RootGuard,
|
106
|
-
ContextGuard,
|
107
|
-
ProductUnloadGuard,
|
108
|
-
ContextResolver,
|
109
|
-
FlowResolver,
|
110
|
-
QuoteResolver,
|
111
|
-
],
|
94
|
+
providers: [FlowRouterService, RootGuard, ContextGuard, ProductUnloadGuard, FlowResolver, QuoteResolver],
|
112
95
|
}]
|
113
96
|
}] });
|
114
|
-
//# sourceMappingURL=data:application/json;base64,
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flow-routing.module.js","sourceRoot":"","sources":["../../../../../libs/sdk/src/flow-routing.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\nimport { RouterModule } from '@angular/router';\nimport { VELOCE_FLOW_ROOT_ROUTE } from './constants';\nimport { FlowComponent } from './flow.component';\nimport { ContextGuard } from './guards/context.guard';\nimport { ProductUnloadGuard } from './guards/product-unload.guard';\nimport { RootGuard } from './guards/root.guard';\nimport { CatalogComponent } from './pages/catalog/catalog.component';\nimport { CatalogModule } from './pages/catalog/catalog.module';\nimport { DebugModule } from './pages/debug/debug.module';\nimport { LegacyProductComponent } from './pages/legacy-product/legacy-product.component';\nimport { LegacyProductModule } from './pages/legacy-product/legacy-product.module';\nimport { ProductComponent } from './pages/product/product.component';\nimport { ProductModule } from './pages/product/product.module';\nimport { RecordNotFoundModule } from './pages/record-not-found/record-not-found.module';\nimport { ShoppingCartComponent } from './pages/shopping-cart/shopping-cart.component';\nimport { ShoppingCartModule } from './pages/shopping-cart/shopping-cart.module';\nimport { FlowResolver } from './resolvers/flow.resolver';\nimport { QuoteResolver } from './resolvers/quote.resolver';\nimport { FlowRouterService } from './services/flow-router.service';\nimport { RouteWithId } from './types/route.types';\n\nconst rootRoute: RouteWithId = {\n  id: VELOCE_FLOW_ROOT_ROUTE,\n  path: '',\n  component: FlowComponent,\n  canActivate: [RootGuard],\n  canDeactivate: [RootGuard],\n  children: [\n    {\n      path: 'flows',\n      runGuardsAndResolvers: 'paramsOrQueryParamsChange',\n      resolve: { quote: FlowResolver },\n      canActivate: [ContextGuard],\n      children: [],\n    },\n    {\n      path: 'legacy',\n      children: [\n        {\n          path: 'product',\n          component: LegacyProductComponent,\n          runGuardsAndResolvers: 'paramsOrQueryParamsChange',\n          resolve: { quote: QuoteResolver },\n          canActivate: [ContextGuard],\n        },\n      ],\n    },\n    {\n      path: 'product',\n      component: ProductComponent,\n      runGuardsAndResolvers: 'paramsOrQueryParamsChange',\n      resolve: { quote: QuoteResolver },\n      canActivate: [ContextGuard],\n      canDeactivate: [ProductUnloadGuard],\n      data: { showHeader: true },\n    },\n    {\n      path: 'cart',\n      component: ShoppingCartComponent,\n      runGuardsAndResolvers: 'paramsOrQueryParamsChange',\n      resolve: { quote: QuoteResolver },\n      canActivate: [ContextGuard],\n      data: { showHeader: true },\n    },\n    {\n      path: 'catalog',\n      component: CatalogComponent,\n      runGuardsAndResolvers: 'paramsOrQueryParamsChange',\n      resolve: { quote: QuoteResolver },\n      canActivate: [ContextGuard],\n      data: { showHeader: true },\n    },\n    {\n      path: 'debug',\n      loadChildren: () => DebugModule,\n    },\n    {\n      path: '404',\n      loadChildren: () => RecordNotFoundModule,\n    },\n  ],\n};\n\n@NgModule({\n  imports: [RouterModule.forChild([rootRoute]), ProductModule, LegacyProductModule, ShoppingCartModule, CatalogModule],\n  exports: [RouterModule],\n  providers: [FlowRouterService, RootGuard, ContextGuard, ProductUnloadGuard, FlowResolver, QuoteResolver],\n})\nexport class FlowRoutingModule {}\n"]}
|
@@ -1,12 +1,50 @@
|
|
1
|
+
import { HttpErrorResponse } from '@angular/common/http';
|
1
2
|
import { Injectable } from '@angular/core';
|
2
3
|
import { ConfigurationContextMode } from '@veloce/core';
|
4
|
+
import { catchError, from, map, of, tap } from 'rxjs';
|
3
5
|
import * as i0 from "@angular/core";
|
4
6
|
import * as i1 from "@angular/router";
|
5
7
|
import * as i2 from "../services/flow-router.service";
|
8
|
+
import * as i3 from "@veloce/sdk/core";
|
6
9
|
export class ContextGuard {
|
7
|
-
constructor(router, routerService) {
|
10
|
+
constructor(router, routerService, contextService) {
|
8
11
|
this.router = router;
|
9
12
|
this.routerService = routerService;
|
13
|
+
this.contextService = contextService;
|
14
|
+
}
|
15
|
+
checkActivation(route) {
|
16
|
+
var _a, _b;
|
17
|
+
const { queryParams } = route;
|
18
|
+
const { accountId, quoteId, orderId } = queryParams;
|
19
|
+
const rpcMessage = window.RPC_MESSAGE;
|
20
|
+
const mode = this.getConfigurationContextMode(accountId, quoteId, orderId, rpcMessage);
|
21
|
+
// Restrict if mode is not defined
|
22
|
+
if (mode == null) {
|
23
|
+
return this.handleError(route, 'Mode is undefined');
|
24
|
+
}
|
25
|
+
const rpcMessageId = rpcMessage && ((_b = (_a = JSON.parse(rpcMessage)) === null || _a === void 0 ? void 0 : _a.quote) === null || _b === void 0 ? void 0 : _b.Id);
|
26
|
+
const headerId = accountId || quoteId || orderId || rpcMessageId || 'empty-for-test-mode';
|
27
|
+
// Allow if context is already initialized with the same headerId
|
28
|
+
if (this.contextService.isInitialized) {
|
29
|
+
const currentContext = this.contextService.resolve();
|
30
|
+
if (headerId && currentContext.headerId === headerId) {
|
31
|
+
return of(true);
|
32
|
+
}
|
33
|
+
}
|
34
|
+
// Initialize context
|
35
|
+
return this.contextService.create(headerId, mode).pipe(tap((context) => {
|
36
|
+
// Update context with queryParams
|
37
|
+
this.contextService.update(Object.assign(Object.assign({}, context), { properties: Object.assign(Object.assign({}, context.properties), (queryParams !== null && queryParams !== void 0 ? queryParams : {})) }));
|
38
|
+
}), map(() => true), catchError(e => {
|
39
|
+
const message = e instanceof HttpErrorResponse ? e.error.message : e;
|
40
|
+
return this.handleError(route, message);
|
41
|
+
}));
|
42
|
+
}
|
43
|
+
canActivate(route) {
|
44
|
+
return this.checkActivation(route);
|
45
|
+
}
|
46
|
+
canActivateChild(childRoute) {
|
47
|
+
return this.checkActivation(childRoute);
|
10
48
|
}
|
11
49
|
getConfigurationContextMode(accountId, quoteId, orderId, rpcMessage) {
|
12
50
|
if (accountId) {
|
@@ -23,41 +61,15 @@ export class ContextGuard {
|
|
23
61
|
}
|
24
62
|
return;
|
25
63
|
}
|
26
|
-
|
27
|
-
|
28
|
-
const { queryParams } = route;
|
29
|
-
const { accountId, quoteId, orderId } = queryParams;
|
30
|
-
const rpcMessage = window['RPC_MESSAGE'];
|
31
|
-
const rpcMessageId = rpcMessage && ((_b = (_a = JSON.parse(rpcMessage)) === null || _a === void 0 ? void 0 : _a.quote) === null || _b === void 0 ? void 0 : _b.Id);
|
32
|
-
const headerId = accountId || quoteId || orderId || rpcMessageId || 'empty-for-test-mode';
|
33
|
-
const mode = this.getConfigurationContextMode(accountId, quoteId, orderId, rpcMessage);
|
34
|
-
if (mode === void 0) {
|
35
|
-
return this.reject(route, 'Mode is undefined');
|
36
|
-
}
|
37
|
-
const contextRouteData = {
|
38
|
-
headerId,
|
39
|
-
mode,
|
40
|
-
};
|
41
|
-
route.data = Object.assign(Object.assign({}, route.data), contextRouteData);
|
42
|
-
return true;
|
43
|
-
}
|
44
|
-
canActivate(route) {
|
45
|
-
return this.checkActivation(route);
|
46
|
-
}
|
47
|
-
canActivateChild(childRoute) {
|
48
|
-
return this.checkActivation(childRoute);
|
49
|
-
}
|
50
|
-
reject(route, message) {
|
64
|
+
handleError(route, message) {
|
65
|
+
this.contextService.delete();
|
51
66
|
const parentUrl = this.routerService.getFlowRootPath(route);
|
52
|
-
this.router.navigate([parentUrl, '404'], {
|
53
|
-
state: { message },
|
54
|
-
});
|
55
|
-
return false;
|
67
|
+
return from(this.router.navigate([parentUrl, '404'], { state: { message } })).pipe(map(() => false));
|
56
68
|
}
|
57
69
|
}
|
58
|
-
ContextGuard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: ContextGuard, deps: [{ token: i1.Router }, { token: i2.FlowRouterService }], target: i0.ɵɵFactoryTarget.Injectable });
|
70
|
+
ContextGuard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: ContextGuard, deps: [{ token: i1.Router }, { token: i2.FlowRouterService }, { token: i3.ContextService }], target: i0.ɵɵFactoryTarget.Injectable });
|
59
71
|
ContextGuard.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: ContextGuard });
|
60
72
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: ContextGuard, decorators: [{
|
61
73
|
type: Injectable
|
62
|
-
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.FlowRouterService }]; } });
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
74
|
+
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.FlowRouterService }, { type: i3.ContextService }]; } });
|
75
|
+
//# 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 { ConfigurationContext, ConfigurationContextMode, VlWindow } from '@veloce/core';\nimport { ContextService } from '@veloce/sdk/core';\nimport { catchError, from, map, Observable, of, tap } from 'rxjs';\nimport { FlowRouterService } from '../services/flow-router.service';\n\ndeclare const window: VlWindow;\n\n@Injectable()\nexport class ContextGuard implements CanActivate, CanActivateChild {\n  constructor(\n    private router: Router,\n    private routerService: FlowRouterService,\n    private contextService: ContextService,\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.handleError(route, 'Mode is undefined');\n    }\n\n    const rpcMessageId: string = rpcMessage && JSON.parse(rpcMessage)?.quote?.Id;\n    const headerId = accountId || quoteId || orderId || 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\n    return this.contextService.create(headerId, mode).pipe(\n      tap((context: ConfigurationContext) => {\n        // Update context with queryParams\n        this.contextService.update({\n          ...context,\n          properties: {\n            ...context.properties,\n            ...(queryParams ?? {}),\n          },\n        });\n      }),\n      map(() => true),\n      catchError(e => {\n        const message = e instanceof HttpErrorResponse ? e.error.message : e;\n        return this.handleError(route, message);\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 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  private handleError(route: ActivatedRouteSnapshot, message: string): Observable<boolean> {\n    this.contextService.delete();\n    const parentUrl = this.routerService.getFlowRootPath(route);\n    return from(this.router.navigate([parentUrl, '404'], { state: { message } })).pipe(map(() => false));\n  }\n}\n"]}
|
@@ -1,31 +1,43 @@
|
|
1
1
|
import { Injectable } from '@angular/core';
|
2
|
-
import { map, of
|
2
|
+
import { map, of } from 'rxjs';
|
3
3
|
import * as i0 from "@angular/core";
|
4
|
-
import * as i1 from "@
|
5
|
-
import * as i2 from "
|
4
|
+
import * as i1 from "@angular/router";
|
5
|
+
import * as i2 from "@veloce/sdk/core";
|
6
|
+
import * as i3 from "../services/flow-dialog.service";
|
6
7
|
export class ProductUnloadGuard {
|
7
|
-
constructor(contextService, quoteDraftService, configurationService, flowDialogService) {
|
8
|
+
constructor(router, contextService, quoteDraftService, configurationService, flowDialogService) {
|
9
|
+
this.router = router;
|
8
10
|
this.contextService = contextService;
|
9
11
|
this.quoteDraftService = quoteDraftService;
|
10
12
|
this.configurationService = configurationService;
|
11
13
|
this.flowDialogService = flowDialogService;
|
12
14
|
}
|
13
|
-
canDeactivate() {
|
15
|
+
canDeactivate(_, route, currentState, nextState) {
|
14
16
|
let observable = of(true);
|
15
17
|
if (!this.quoteDraftService.isStandalone && this.configurationService.hasUnsavedChanges) {
|
16
18
|
observable = this.flowDialogService.showUnsavedChangesDialog().pipe(map(confirmed => !confirmed));
|
17
19
|
}
|
18
|
-
return observable.pipe(
|
20
|
+
return observable.pipe(map(unload => {
|
19
21
|
if (unload) {
|
20
|
-
this.contextService.update({ properties: { productId: undefined, lineItemId: undefined } });
|
21
22
|
this.configurationService.reset();
|
23
|
+
this.contextService.update({ properties: { productId: undefined, lineItemId: undefined } });
|
24
|
+
if (!nextState || currentState.url === nextState.url) {
|
25
|
+
return true;
|
26
|
+
}
|
27
|
+
// clear obsolete queryParams
|
28
|
+
const urlTree = this.router.parseUrl(nextState.url);
|
29
|
+
delete urlTree.queryParams.productId;
|
30
|
+
// replace url after deactivation has finished
|
31
|
+
setTimeout(() => this.router.navigateByUrl(urlTree.toString(), { replaceUrl: true }));
|
32
|
+
return true;
|
22
33
|
}
|
34
|
+
return false;
|
23
35
|
}));
|
24
36
|
}
|
25
37
|
}
|
26
|
-
ProductUnloadGuard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: ProductUnloadGuard, deps: [{ token: i1.ContextService }, { token:
|
38
|
+
ProductUnloadGuard.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: ProductUnloadGuard, deps: [{ token: i1.Router }, { token: i2.ContextService }, { token: i2.QuoteDraftService }, { token: i2.ConfigurationService }, { token: i3.FlowDialogService }], target: i0.ɵɵFactoryTarget.Injectable });
|
27
39
|
ProductUnloadGuard.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: ProductUnloadGuard });
|
28
40
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: ProductUnloadGuard, decorators: [{
|
29
41
|
type: Injectable
|
30
|
-
}], ctorParameters: function () { return [{ type: i1.ContextService }, { type:
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
42
|
+
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.ContextService }, { type: i2.QuoteDraftService }, { type: i2.ConfigurationService }, { type: i3.FlowDialogService }]; } });
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC11bmxvYWQuZ3VhcmQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Nkay9zcmMvZ3VhcmRzL3Byb2R1Y3QtdW5sb2FkLmd1YXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBYSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHdEQsT0FBTyxFQUFFLEdBQUcsRUFBRSxFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7O0FBSS9CLE1BQU0sT0FBTyxrQkFBa0I7SUFDN0IsWUFDVSxNQUFjLEVBQ2QsY0FBOEIsRUFDOUIsaUJBQW9DLEVBQ3BDLG9CQUEwQyxFQUMxQyxpQkFBb0M7UUFKcEMsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNkLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQUM5QixzQkFBaUIsR0FBakIsaUJBQWlCLENBQW1CO1FBQ3BDLHlCQUFvQixHQUFwQixvQkFBb0IsQ0FBc0I7UUFDMUMsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtJQUMzQyxDQUFDO0lBRUosYUFBYSxDQUNYLENBQVksRUFDWixLQUE2QixFQUM3QixZQUFpQyxFQUNqQyxTQUErQjtRQUUvQixJQUFJLFVBQVUsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFMUIsSUFBSSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxZQUFZLElBQUksSUFBSSxDQUFDLG9CQUFvQixDQUFDLGlCQUFpQixFQUFFO1lBQ3ZGLFVBQVUsR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsd0JBQXdCLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDO1NBQ25HO1FBRUQsT0FBTyxVQUFVLENBQUMsSUFBSSxDQUNwQixHQUFHLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDWCxJQUFJLE1BQU0sRUFBRTtnQkFDVixJQUFJLENBQUMsb0JBQW9CLENBQUMsS0FBSyxFQUFFLENBQUM7Z0JBQ2xDLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLEVBQUUsVUFBVSxFQUFFLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFFLEVBQUUsQ0FBQyxDQUFDO2dCQUU1RixJQUFJLENBQUMsU0FBUyxJQUFJLFlBQVksQ0FBQyxHQUFHLEtBQUssU0FBUyxDQUFDLEdBQUcsRUFBRTtvQkFDcEQsT0FBTyxJQUFJLENBQUM7aUJBQ2I7Z0JBRUQsNkJBQTZCO2dCQUM3QixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUM7Z0JBQ3BELE9BQU8sT0FBTyxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUM7Z0JBRXJDLDhDQUE4QztnQkFDOUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUUsRUFBRSxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7Z0JBRXRGLE9BQU8sSUFBSSxDQUFDO2FBQ2I7WUFFRCxPQUFPLEtBQUssQ0FBQztRQUNmLENBQUMsQ0FBQyxDQUNILENBQUM7SUFDSixDQUFDOztnSEE1Q1Usa0JBQWtCO29IQUFsQixrQkFBa0I7NEZBQWxCLGtCQUFrQjtrQkFEOUIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgQ2FuRGVhY3RpdmF0ZSwgUm91dGVyLCBSb3V0ZXJTdGF0ZVNuYXBzaG90IH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7IENvbmZpZ3VyYXRpb25TZXJ2aWNlLCBDb250ZXh0U2VydmljZSwgUXVvdGVEcmFmdFNlcnZpY2UgfSBmcm9tICdAdmVsb2NlL3Nkay9jb3JlJztcbmltcG9ydCB7IG1hcCwgb2YgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IEZsb3dEaWFsb2dTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvZmxvdy1kaWFsb2cuc2VydmljZSc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBQcm9kdWN0VW5sb2FkR3VhcmQgaW1wbGVtZW50cyBDYW5EZWFjdGl2YXRlPGFueT4ge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJvdXRlcjogUm91dGVyLFxuICAgIHByaXZhdGUgY29udGV4dFNlcnZpY2U6IENvbnRleHRTZXJ2aWNlLFxuICAgIHByaXZhdGUgcXVvdGVEcmFmdFNlcnZpY2U6IFF1b3RlRHJhZnRTZXJ2aWNlLFxuICAgIHByaXZhdGUgY29uZmlndXJhdGlvblNlcnZpY2U6IENvbmZpZ3VyYXRpb25TZXJ2aWNlLFxuICAgIHByaXZhdGUgZmxvd0RpYWxvZ1NlcnZpY2U6IEZsb3dEaWFsb2dTZXJ2aWNlLFxuICApIHt9XG5cbiAgY2FuRGVhY3RpdmF0ZShcbiAgICBfOiBDb21wb25lbnQsXG4gICAgcm91dGU6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QsXG4gICAgY3VycmVudFN0YXRlOiBSb3V0ZXJTdGF0ZVNuYXBzaG90LFxuICAgIG5leHRTdGF0ZT86IFJvdXRlclN0YXRlU25hcHNob3QsXG4gICkge1xuICAgIGxldCBvYnNlcnZhYmxlID0gb2YodHJ1ZSk7XG5cbiAgICBpZiAoIXRoaXMucXVvdGVEcmFmdFNlcnZpY2UuaXNTdGFuZGFsb25lICYmIHRoaXMuY29uZmlndXJhdGlvblNlcnZpY2UuaGFzVW5zYXZlZENoYW5nZXMpIHtcbiAgICAgIG9ic2VydmFibGUgPSB0aGlzLmZsb3dEaWFsb2dTZXJ2aWNlLnNob3dVbnNhdmVkQ2hhbmdlc0RpYWxvZygpLnBpcGUobWFwKGNvbmZpcm1lZCA9PiAhY29uZmlybWVkKSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIG9ic2VydmFibGUucGlwZShcbiAgICAgIG1hcCh1bmxvYWQgPT4ge1xuICAgICAgICBpZiAodW5sb2FkKSB7XG4gICAgICAgICAgdGhpcy5jb25maWd1cmF0aW9uU2VydmljZS5yZXNldCgpO1xuICAgICAgICAgIHRoaXMuY29udGV4dFNlcnZpY2UudXBkYXRlKHsgcHJvcGVydGllczogeyBwcm9kdWN0SWQ6IHVuZGVmaW5lZCwgbGluZUl0ZW1JZDogdW5kZWZpbmVkIH0gfSk7XG5cbiAgICAgICAgICBpZiAoIW5leHRTdGF0ZSB8fCBjdXJyZW50U3RhdGUudXJsID09PSBuZXh0U3RhdGUudXJsKSB7XG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICAvLyBjbGVhciBvYnNvbGV0ZSBxdWVyeVBhcmFtc1xuICAgICAgICAgIGNvbnN0IHVybFRyZWUgPSB0aGlzLnJvdXRlci5wYXJzZVVybChuZXh0U3RhdGUudXJsKTtcbiAgICAgICAgICBkZWxldGUgdXJsVHJlZS5xdWVyeVBhcmFtcy5wcm9kdWN0SWQ7XG5cbiAgICAgICAgICAvLyByZXBsYWNlIHVybCBhZnRlciBkZWFjdGl2YXRpb24gaGFzIGZpbmlzaGVkXG4gICAgICAgICAgc2V0VGltZW91dCgoKSA9PiB0aGlzLnJvdXRlci5uYXZpZ2F0ZUJ5VXJsKHVybFRyZWUudG9TdHJpbmcoKSwgeyByZXBsYWNlVXJsOiB0cnVlIH0pKTtcblxuICAgICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgfSksXG4gICAgKTtcbiAgfVxufVxuIl19
|
@@ -24,12 +24,13 @@ export class QuoteResolver {
|
|
24
24
|
return this.flowConfiguration.initialize$();
|
25
25
|
}
|
26
26
|
resolve(route) {
|
27
|
-
const { headerId } =
|
27
|
+
const { headerId } = this.contextService.resolve();
|
28
28
|
const quote = this.quoteDraftService.quoteSnapshot;
|
29
29
|
if (quote && quote.quoteId === headerId) {
|
30
30
|
return of(true);
|
31
31
|
}
|
32
32
|
const { queryParams } = route;
|
33
|
+
this.contextService.update({ properties: queryParams });
|
33
34
|
return this.quoteDraftService.init(headerId, queryParams).pipe(switchMap(() => this.initFlow$()), catchError(e => {
|
34
35
|
const message = e instanceof HttpErrorResponse ? e.error.message : e;
|
35
36
|
return this.handleError(route, message);
|
@@ -41,4 +42,4 @@ QuoteResolver.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", versio
|
|
41
42
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: QuoteResolver, decorators: [{
|
42
43
|
type: Injectable
|
43
44
|
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.QuoteDraftService }, { type: i3.FlowRouterService }, { type: i2.ContextService }, { type: i2.FlowConfigurationService }]; } });
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVvdGUucmVzb2x2ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Nkay9zcmMvcmVzb2x2ZXJzL3F1b3RlLnJlc29sdmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHM0MsT0FBTyxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQWMsRUFBRSxFQUFFLFNBQVMsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7Ozs7QUFJbkUsTUFBTSxPQUFPLGFBQWE7SUFDeEIsWUFDVSxNQUFjLEVBQ2QsaUJBQW9DLEVBQ3BDLGFBQWdDLEVBQ2hDLGNBQThCLEVBQzlCLGlCQUEyQztRQUozQyxXQUFNLEdBQU4sTUFBTSxDQUFRO1FBQ2Qsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtRQUNwQyxrQkFBYSxHQUFiLGFBQWEsQ0FBbUI7UUFDaEMsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQzlCLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBMEI7SUFDbEQsQ0FBQztJQUVJLFdBQVcsQ0FBQyxLQUE2QixFQUFFLE9BQWU7UUFDaEUsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDNUQsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxTQUFTLEVBQUUsS0FBSyxDQUFDLEVBQUUsRUFBRSxLQUFLLEVBQUUsRUFBRSxPQUFPLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUNoRixDQUFDO0lBRU8sU0FBUztRQUNmLElBQUksSUFBSSxDQUFDLGlCQUFpQixDQUFDLFlBQVksRUFBRTtZQUN2QyxPQUFPLEVBQUUsQ0FBQyxTQUFTLENBQUMsQ0FBQztTQUN0QjtRQUVELE9BQU8sSUFBSSxDQUFDLGlCQUFpQixDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQzlDLENBQUM7SUFFRCxPQUFPLENBQUMsS0FBNkI7UUFDbkMsTUFBTSxFQUFFLFFBQVEsRUFBRSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDbkQsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGFBQWEsQ0FBQztRQUVuRCxJQUFJLEtBQUssSUFBSSxLQUFLLENBQUMsT0FBTyxLQUFLLFFBQVEsRUFBRTtZQUN2QyxPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUNqQjtRQUVELE1BQU0sRUFBRSxXQUFXLEVBQUUsR0FBRyxLQUFLLENBQUM7UUFDOUIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsRUFBRSxVQUFVLEVBQUUsV0FBVyxFQUFFLENBQUMsQ0FBQztRQUV4RCxPQUFPLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLFdBQVcsQ0FBQyxDQUFDLElBQUksQ0FDNUQsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQyxFQUNqQyxVQUFVLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDYixNQUFNLE9BQU8sR0FBRyxDQUFDLFlBQVksaUJBQWlCLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDckUsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztRQUMxQyxDQUFDLENBQUMsQ0FDSCxDQUFDO0lBQ0osQ0FBQzs7MkdBeENVLGFBQWE7K0dBQWIsYUFBYTs0RkFBYixhQUFhO2tCQUR6QixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cEVycm9yUmVzcG9uc2UgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90LCBSZXNvbHZlLCBSb3V0ZXIgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgQ29udGV4dFNlcnZpY2UsIEZsb3dDb25maWd1cmF0aW9uU2VydmljZSwgUXVvdGVEcmFmdFNlcnZpY2UgfSBmcm9tICdAdmVsb2NlL3Nkay9jb3JlJztcbmltcG9ydCB7IGNhdGNoRXJyb3IsIGZyb20sIE9ic2VydmFibGUsIG9mLCBzd2l0Y2hNYXAgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IEZsb3dSb3V0ZXJTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvZmxvdy1yb3V0ZXIuc2VydmljZSc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBRdW90ZVJlc29sdmVyIGltcGxlbWVudHMgUmVzb2x2ZTx2b2lkIHwgYm9vbGVhbj4ge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJvdXRlcjogUm91dGVyLFxuICAgIHByaXZhdGUgcXVvdGVEcmFmdFNlcnZpY2U6IFF1b3RlRHJhZnRTZXJ2aWNlLFxuICAgIHByaXZhdGUgcm91dGVyU2VydmljZTogRmxvd1JvdXRlclNlcnZpY2UsXG4gICAgcHJpdmF0ZSBjb250ZXh0U2VydmljZTogQ29udGV4dFNlcnZpY2UsXG4gICAgcHJpdmF0ZSBmbG93Q29uZmlndXJhdGlvbjogRmxvd0NvbmZpZ3VyYXRpb25TZXJ2aWNlLFxuICApIHt9XG5cbiAgcHJpdmF0ZSBoYW5kbGVFcnJvcihyb3V0ZTogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgbWVzc2FnZTogc3RyaW5nKTogT2JzZXJ2YWJsZTxib29sZWFuPiB7XG4gICAgY29uc3QgcGFyZW50VXJsID0gdGhpcy5yb3V0ZXJTZXJ2aWNlLmdldEZsb3dSb290UGF0aChyb3V0ZSk7XG4gICAgcmV0dXJuIGZyb20odGhpcy5yb3V0ZXIubmF2aWdhdGUoW3BhcmVudFVybCwgJzQwNCddLCB7IHN0YXRlOiB7IG1lc3NhZ2UgfSB9KSk7XG4gIH1cblxuICBwcml2YXRlIGluaXRGbG93JCgpOiBPYnNlcnZhYmxlPGFueT4ge1xuICAgIGlmICh0aGlzLnF1b3RlRHJhZnRTZXJ2aWNlLmlzU3RhbmRhbG9uZSkge1xuICAgICAgcmV0dXJuIG9mKHVuZGVmaW5lZCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXMuZmxvd0NvbmZpZ3VyYXRpb24uaW5pdGlhbGl6ZSQoKTtcbiAgfVxuXG4gIHJlc29sdmUocm91dGU6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QpOiBPYnNlcnZhYmxlPHZvaWQgfCBib29sZWFuPiB7XG4gICAgY29uc3QgeyBoZWFkZXJJZCB9ID0gdGhpcy5jb250ZXh0U2VydmljZS5yZXNvbHZlKCk7XG4gICAgY29uc3QgcXVvdGUgPSB0aGlzLnF1b3RlRHJhZnRTZXJ2aWNlLnF1b3RlU25hcHNob3Q7XG5cbiAgICBpZiAocXVvdGUgJiYgcXVvdGUucXVvdGVJZCA9PT0gaGVhZGVySWQpIHtcbiAgICAgIHJldHVybiBvZih0cnVlKTtcbiAgICB9XG5cbiAgICBjb25zdCB7IHF1ZXJ5UGFyYW1zIH0gPSByb3V0ZTtcbiAgICB0aGlzLmNvbnRleHRTZXJ2aWNlLnVwZGF0ZSh7IHByb3BlcnRpZXM6IHF1ZXJ5UGFyYW1zIH0pO1xuXG4gICAgcmV0dXJuIHRoaXMucXVvdGVEcmFmdFNlcnZpY2UuaW5pdChoZWFkZXJJZCwgcXVlcnlQYXJhbXMpLnBpcGUoXG4gICAgICBzd2l0Y2hNYXAoKCkgPT4gdGhpcy5pbml0RmxvdyQoKSksXG4gICAgICBjYXRjaEVycm9yKGUgPT4ge1xuICAgICAgICBjb25zdCBtZXNzYWdlID0gZSBpbnN0YW5jZW9mIEh0dHBFcnJvclJlc3BvbnNlID8gZS5lcnJvci5tZXNzYWdlIDogZTtcbiAgICAgICAgcmV0dXJuIHRoaXMuaGFuZGxlRXJyb3Iocm91dGUsIG1lc3NhZ2UpO1xuICAgICAgfSksXG4gICAgKTtcbiAgfVxufVxuIl19
|
@@ -12,11 +12,11 @@ import { DragDropModule } from '@angular/cdk/drag-drop';
|
|
12
12
|
import * as angularForms from '@angular/forms';
|
13
13
|
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
14
14
|
import * as i2 from '@veloce/sdk/core';
|
15
|
-
import { ConfigurationService, LineItemWorker, generateLineItem, getAttributeValue, FlowConfigurationService, lineItemUtils, SdkCoreModule } from '@veloce/sdk/core';
|
15
|
+
import { ConfigurationService, LineItemWorker, generateLineItem, getAttributeValue, QuoteDraftService, FlowConfigurationService, ProductImagesService, lineItemUtils, SdkCoreModule } from '@veloce/sdk/core';
|
16
16
|
import * as i1 from '@veloce/components';
|
17
17
|
import { LoaderModule } from '@veloce/components';
|
18
18
|
import { transform } from '@babel/standalone';
|
19
|
-
import { SalesforceApiService, QuoteApiService, DocumentTemplatesApiService, DocumentAttachmentApiService, RampApiService, CatalogApiService, ApiModule } from '@veloce/api';
|
19
|
+
import { SalesforceApiService, QuoteApiService, DocumentTemplatesApiService, DocumentAttachmentApiService, RampApiService, CatalogApiService, DeltaApiService, ApiModule } from '@veloce/api';
|
20
20
|
import * as rxjsOperators from 'rxjs/operators';
|
21
21
|
import * as i3 from 'primeng/api';
|
22
22
|
import { DialogService } from 'primeng/dynamicdialog';
|
@@ -974,8 +974,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
|
|
974
974
|
|
975
975
|
const vendorMap = {
|
976
976
|
'@veloce/sdk/core': Object.assign({ ConfigurationService,
|
977
|
+
QuoteDraftService,
|
977
978
|
FlowConfigurationService,
|
978
|
-
LineItemWorker
|
979
|
+
LineItemWorker,
|
980
|
+
ProductImagesService }, lineItemUtils),
|
979
981
|
'@veloce/sdk/cms': Object.assign(Object.assign(Object.assign({}, cmsInjectionTokens), cmsActions), { TemplatesService,
|
980
982
|
IntegrationState }),
|
981
983
|
'@veloce/api': {
|
@@ -985,6 +987,7 @@ const vendorMap = {
|
|
985
987
|
DocumentAttachmentApiService,
|
986
988
|
RampApiService,
|
987
989
|
CatalogApiService,
|
990
|
+
DeltaApiService,
|
988
991
|
},
|
989
992
|
'@angular/core': i0,
|
990
993
|
'@angular/forms': angularForms,
|