@veloceapps/sdk 7.0.2-16 → 7.0.2-18
Sign up to get free protection for your applications and to get access to all the features.
- package/cms/cms.actions.d.ts +7 -1
- package/cms/components/element-children/element-children.component.d.ts +3 -1
- package/cms/components/preview/preview.types.d.ts +4 -0
- package/cms/injection-tokens.d.ts +1 -3
- package/cms/modules/runtime/services/compilation.service.d.ts +2 -1
- package/cms/plugins/element-hover.plugin.d.ts +2 -0
- package/cms/plugins/script.plugin.d.ts +0 -3
- package/cms/types/common.types.d.ts +2 -2
- package/cms/utils/elements-resolver.d.ts +5 -1
- package/cms/utils/script.utils.d.ts +2 -0
- package/cms/vendor-map.d.ts +1 -2
- package/core/types/ui-definition.types.d.ts +7 -2
- package/esm2020/cms/cms.actions.mjs +11 -2
- package/esm2020/cms/cms.elements.mjs +5 -5
- package/esm2020/cms/components/element-children/element-children.component.mjs +11 -6
- package/esm2020/cms/components/element-tools-panel/element-tools-panel.component.mjs +2 -2
- package/esm2020/cms/components/preview/preview.types.mjs +1 -1
- package/esm2020/cms/injection-tokens.mjs +1 -2
- package/esm2020/cms/modules/runtime/services/compilation.service.mjs +3 -3
- package/esm2020/cms/modules/runtime/services/runtime.service.mjs +2 -2
- package/esm2020/cms/plugins/element-hover.plugin.mjs +9 -1
- package/esm2020/cms/plugins/script.plugin.mjs +6 -40
- package/esm2020/cms/services/integration.state.mjs +3 -6
- package/esm2020/cms/types/common.types.mjs +1 -1
- package/esm2020/cms/utils/elements-resolver.mjs +22 -8
- package/esm2020/cms/utils/script.utils.mjs +42 -0
- package/esm2020/core/types/ui-definition.types.mjs +1 -1
- package/esm2020/src/flow-routing.module.mjs +1 -2
- package/fesm2015/veloceapps-sdk-cms.mjs +142 -105
- package/fesm2015/veloceapps-sdk-cms.mjs.map +1 -1
- package/fesm2015/veloceapps-sdk-core.mjs.map +1 -1
- package/fesm2015/veloceapps-sdk.mjs +0 -1
- package/fesm2015/veloceapps-sdk.mjs.map +1 -1
- package/fesm2020/veloceapps-sdk-cms.mjs +155 -117
- package/fesm2020/veloceapps-sdk-cms.mjs.map +1 -1
- package/fesm2020/veloceapps-sdk-core.mjs.map +1 -1
- package/fesm2020/veloceapps-sdk.mjs +0 -1
- package/fesm2020/veloceapps-sdk.mjs.map +1 -1
- package/package.json +1 -1
@@ -1,2 +1,2 @@
|
|
1
1
|
export const UI_DEFINITION_VERSION = 3;
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktZGVmaW5pdGlvbi50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2RrL2NvcmUvdHlwZXMvdWktZGVmaW5pdGlvbi50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBVSURlZmluaXRpb25UeXBlID0gJ0RFRkFVTFQnIHwgJ0NPTkZJR1VSQVRJT04nO1xuXG5leHBvcnQgY29uc3QgVUlfREVGSU5JVElPTl9WRVJTSU9OID0gMztcblxuZXhwb3J0IHR5cGUgVUlFeHRlcm5hbHNUeXBlID0gUmVjb3JkPHN0cmluZywgc3RyaW5nIHwgbnVtYmVyIHwgYm9vbGVhbj47XG5cbmV4cG9ydCBpbnRlcmZhY2UgVUlEZWZpbml0aW9uUHJvcHMge1xuICAvLyBHRU5FUkFMXG4gIHN1cHByZXNzVG9hc3RNZXNzYWdlcz86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFdoZW4gJ3RydWUnLCB0aGUgU3RydWN0dXJlIG1vZHVsZSBpbiBVSSBCdWlsZGVyIGlzIGhpZGRlblxuICAgKi9cbiAgc2ltcGxpZmllZEVkaXRvck1vZGU/OiBib29sZWFuO1xuXG4gIC8vIENPTkZJR1VSQVRJT05cbiAgcm9vdFR5cGU/OiBzdHJpbmc7XG4gIHByaWNpbmdFbmFibGVkPzogYm9vbGVhbjtcbiAgcHJpY2VMaXN0Pzogc3RyaW5nO1xuICBwcm9kdWN0SWQ/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVUlEZWZpbml0aW9uTWV0YWRhdGEge1xuICBuYW1lOiBzdHJpbmc7XG4gIHR5cGU6IFVJRGVmaW5pdGlvblR5cGU7XG4gIHByaW1hcnk6IGJvb2xlYW47XG4gIHZlcnNpb246IG51bWJlcjtcbiAgY3JlYXRlZFRpbWVzdGFtcDogbnVtYmVyO1xuXG4gIHByb3BlcnRpZXM/OiBVSURlZmluaXRpb25Qcm9wcztcbiAgZXh0ZXJuYWxzPzogVUlFeHRlcm5hbHNUeXBlO1xuICBjdXN0b21pemF0aW9uPzogYW55O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFVJRGVmaW5pdGlvbiBleHRlbmRzIFVJRGVmaW5pdGlvbk1ldGFkYXRhIHtcbiAgLyoqXG4gICAqIGBjaGlsZHJlbmAgaXMgZm9yIHNpbXBsZSBwcmV2aWV3cyBvbmx5LlxuICAgKiBGb3IgYXBwbGljYXRpb25zIHVzZSBgcGFnZXNgIHByb3BlcnR5IGluc3RlYWRcbiAgICovXG4gIGNoaWxkcmVuPzogVUlFbGVtZW50W107XG5cbiAgLyoqXG4gICAqIFRoZSBwYWdlIGlzIGFuIEVsZW1lbnQgd2l0aCBgdHlwZTogJ1BBR0UnYFxuICAgKi9cbiAgcGFnZXM/OiBVSUVsZW1lbnRbXTtcblxuICAvKipcbiAgICogU2hhcmVkIGNvbXBvbmVudHNcbiAgICogVGhlc2UgYXJlIG5vdCByZW5kZXJlZCBvbiB0aGUgc2NyZWVuLCBhbmQgb25seSB1c2VkIGJ5IFJFRkVSRU5DRSB0eXBlIGVsZW1lbnRzXG4gICAqL1xuICBjb21wb25lbnRzPzogVUlFbGVtZW50W107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVUlFbGVtZW50IHtcbiAgY2hpbGRyZW46IFVJRWxlbWVudFtdO1xuICB0ZW1wbGF0ZT86IHN0cmluZztcbiAgc2NyaXB0Pzogc3RyaW5nO1xuICBzdHlsZXM/OiBzdHJpbmc7XG59XG4iXX0=
|
@@ -33,7 +33,6 @@ const rootRoute = {
|
|
33
33
|
canActivate: [RootGuard],
|
34
34
|
canDeactivate: [RootGuard],
|
35
35
|
children: [
|
36
|
-
{ path: '', redirectTo: 'debug', pathMatch: 'full' },
|
37
36
|
{
|
38
37
|
path: 'flows',
|
39
38
|
runGuardsAndResolvers: 'paramsOrQueryParamsChange',
|
@@ -146,4 +145,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImpor
|
|
146
145
|
providers: [FlowRouterService, RootGuard, ContextGuard, ProductUnloadGuard, FlowResolver, QuoteResolver],
|
147
146
|
}]
|
148
147
|
}] });
|
149
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flow-routing.module.js","sourceRoot":"","sources":["../../../../../libs/sdk/src/flow-routing.module.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAC5D,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,qBAAqB,EAAE,MAAM,+CAA+C,CAAC;AACtF,OAAO,EAAE,kBAAkB,EAAE,MAAM,4CAA4C,CAAC;AAChF,OAAO,EAAE,sBAAsB,EAAE,MAAM,iDAAiD,CAAC;AACzF,OAAO,EAAE,mBAAmB,EAAE,MAAM,8CAA8C,CAAC;AACnF,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,oBAAoB,EAAE,MAAM,kDAAkD,CAAC;AACxF,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAC5D,OAAO,EAAE,qBAAqB,EAAE,MAAM,+CAA+C,CAAC;AACtF,OAAO,EAAE,kBAAkB,EAAE,MAAM,4CAA4C,CAAC;AAChF,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;;;AAGnE,MAAM,SAAS,GAAgB;IAC7B,EAAE,EAAE,sBAAsB;IAC1B,IAAI,EAAE,EAAE;IACR,SAAS,EAAE,aAAa;IACxB,WAAW,EAAE,CAAC,SAAS,CAAC;IACxB,aAAa,EAAE,CAAC,SAAS,CAAC;IAC1B,QAAQ,EAAE;QACR,EAAE,IAAI,EAAE,EAAE,EAAE,UAAU,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE;QACpD;YACE,IAAI,EAAE,OAAO;YACb,qBAAqB,EAAE,2BAA2B;YAClD,OAAO,EAAE,EAAE,KAAK,EAAE,YAAY,EAAE;YAChC,WAAW,EAAE,CAAC,YAAY,CAAC;YAC3B,QAAQ,EAAE,EAAE;SACb;QACD;YACE,IAAI,EAAE,QAAQ;YACd,QAAQ,EAAE;gBACR;oBACE,IAAI,EAAE,SAAS;oBACf,SAAS,EAAE,sBAAsB;oBACjC,qBAAqB,EAAE,2BAA2B;oBAClD,OAAO,EAAE,EAAE,KAAK,EAAE,aAAa,EAAE;oBACjC,WAAW,EAAE,CAAC,YAAY,CAAC;iBAC5B;aACF;SACF;QACD;YACE,IAAI,EAAE,SAAS;YACf,SAAS,EAAE,gBAAgB;YAC3B,qBAAqB,EAAE,2BAA2B;YAClD,OAAO,EAAE,EAAE,KAAK,EAAE,aAAa,EAAE;YACjC,WAAW,EAAE,CAAC,YAAY,CAAC;YAC3B,aAAa,EAAE,CAAC,kBAAkB,CAAC;YACnC,IAAI,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE;SAC3B;QACD;YACE,IAAI,EAAE,MAAM;YACZ,SAAS,EAAE,qBAAqB;YAChC,qBAAqB,EAAE,2BAA2B;YAClD,OAAO,EAAE,EAAE,KAAK,EAAE,aAAa,EAAE;YACjC,WAAW,EAAE,CAAC,YAAY,CAAC;YAC3B,IAAI,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE;SAC3B;QACD;YACE,IAAI,EAAE,SAAS;YACf,SAAS,EAAE,gBAAgB;YAC3B,qBAAqB,EAAE,2BAA2B;YAClD,OAAO,EAAE,EAAE,KAAK,EAAE,aAAa,EAAE;YACjC,WAAW,EAAE,CAAC,YAAY,CAAC;YAC3B,IAAI,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE;SAC3B;QACD;YACE,IAAI,EAAE,QAAQ;YACd,SAAS,EAAE,eAAe;YAC1B,qBAAqB,EAAE,2BAA2B;YAClD,OAAO,EAAE,EAAE,KAAK,EAAE,aAAa,EAAE;YACjC,WAAW,EAAE,CAAC,YAAY,CAAC;YAC3B,IAAI,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE;SAC3B;QACD;YACE,IAAI,EAAE,OAAO;YACb,SAAS,EAAE,qBAAqB;YAChC,qBAAqB,EAAE,2BAA2B;YAClD,OAAO,EAAE,EAAE,KAAK,EAAE,aAAa,EAAE;YACjC,WAAW,EAAE,CAAC,YAAY,CAAC;YAC3B,IAAI,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE;SAC3B;QACD;YACE,IAAI,EAAE,QAAQ;YACd,SAAS,EAAE,eAAe;YAC1B,qBAAqB,EAAE,2BAA2B;YAClD,OAAO,EAAE,EAAE,KAAK,EAAE,aAAa,EAAE;YACjC,WAAW,EAAE,CAAC,YAAY,CAAC;SAC5B;QACD;YACE,IAAI,EAAE,OAAO;YACb,YAAY,EAAE,GAAG,EAAE,CAAC,WAAW;SAChC;QACD;YACE,IAAI,EAAE,KAAK;YACX,YAAY,EAAE,GAAG,EAAE,CAAC,oBAAoB;SACzC;KACF;CACF,CAAC;AAgBF,MAAM,OAAO,iBAAiB;;8GAAjB,iBAAiB;+GAAjB,iBAAiB,6BAX1B,aAAa;QACb,mBAAmB;QACnB,kBAAkB;QAClB,aAAa;QACb,YAAY;QACZ,YAAY;QACZ,kBAAkB,aAEV,YAAY;+GAGX,iBAAiB,aAFjB,CAAC,iBAAiB,EAAE,SAAS,EAAE,YAAY,EAAE,kBAAkB,EAAE,YAAY,EAAE,aAAa,CAAC,YAVtG,YAAY,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC;QAClC,aAAa;QACb,mBAAmB;QACnB,kBAAkB;QAClB,aAAa;QACb,YAAY;QACZ,YAAY;QACZ,kBAAkB,EAEV,YAAY;2FAGX,iBAAiB;kBAd7B,QAAQ;mBAAC;oBACR,OAAO,EAAE;wBACP,YAAY,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC;wBAClC,aAAa;wBACb,mBAAmB;wBACnB,kBAAkB;wBAClB,aAAa;wBACb,YAAY;wBACZ,YAAY;wBACZ,kBAAkB;qBACnB;oBACD,OAAO,EAAE,CAAC,YAAY,CAAC;oBACvB,SAAS,EAAE,CAAC,iBAAiB,EAAE,SAAS,EAAE,YAAY,EAAE,kBAAkB,EAAE,YAAY,EAAE,aAAa,CAAC;iBACzG","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 { AssetsComponent } from './pages/assets/assets.component';\nimport { AssetsModule } from './pages/assets/assets.module';\nimport { CatalogComponent } from './pages/catalog/catalog.component';\nimport { CatalogModule } from './pages/catalog/catalog.module';\nimport { DebugModule } from './pages/debug/debug.module';\nimport { EmptyAccountComponent } from './pages/empty-account/empty-account.component';\nimport { EmptyAccountModule } from './pages/empty-account/empty-account.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 { RemoteComponent } from './pages/remote/remote.component';\nimport { RemoteModule } from './pages/remote/remote.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    { path: '', redirectTo: 'debug', pathMatch: 'full' },\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: 'assets',\n      component: AssetsComponent,\n      runGuardsAndResolvers: 'paramsOrQueryParamsChange',\n      resolve: { quote: QuoteResolver },\n      canActivate: [ContextGuard],\n      data: { showHeader: true },\n    },\n    {\n      path: 'empty',\n      component: EmptyAccountComponent,\n      runGuardsAndResolvers: 'paramsOrQueryParamsChange',\n      resolve: { quote: QuoteResolver },\n      canActivate: [ContextGuard],\n      data: { showHeader: true },\n    },\n    {\n      path: 'remote',\n      component: RemoteComponent,\n      runGuardsAndResolvers: 'paramsOrQueryParamsChange',\n      resolve: { quote: QuoteResolver },\n      canActivate: [ContextGuard],\n    },\n    {\n      path: 'debug',\n      loadChildren: () => DebugModule,\n    },\n    {\n      path: '404',\n      loadChildren: () => RecordNotFoundModule,\n    },\n  ],\n};\n\n@NgModule({\n  imports: [\n    RouterModule.forChild([rootRoute]),\n    ProductModule,\n    LegacyProductModule,\n    ShoppingCartModule,\n    CatalogModule,\n    AssetsModule,\n    RemoteModule,\n    EmptyAccountModule,\n  ],\n  exports: [RouterModule],\n  providers: [FlowRouterService, RootGuard, ContextGuard, ProductUnloadGuard, FlowResolver, QuoteResolver],\n})\nexport class FlowRoutingModule {}\n"]}
|
148
|
+
//# 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 { AssetsComponent } from './pages/assets/assets.component';\nimport { AssetsModule } from './pages/assets/assets.module';\nimport { CatalogComponent } from './pages/catalog/catalog.component';\nimport { CatalogModule } from './pages/catalog/catalog.module';\nimport { DebugModule } from './pages/debug/debug.module';\nimport { EmptyAccountComponent } from './pages/empty-account/empty-account.component';\nimport { EmptyAccountModule } from './pages/empty-account/empty-account.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 { RemoteComponent } from './pages/remote/remote.component';\nimport { RemoteModule } from './pages/remote/remote.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: 'assets',\n      component: AssetsComponent,\n      runGuardsAndResolvers: 'paramsOrQueryParamsChange',\n      resolve: { quote: QuoteResolver },\n      canActivate: [ContextGuard],\n      data: { showHeader: true },\n    },\n    {\n      path: 'empty',\n      component: EmptyAccountComponent,\n      runGuardsAndResolvers: 'paramsOrQueryParamsChange',\n      resolve: { quote: QuoteResolver },\n      canActivate: [ContextGuard],\n      data: { showHeader: true },\n    },\n    {\n      path: 'remote',\n      component: RemoteComponent,\n      runGuardsAndResolvers: 'paramsOrQueryParamsChange',\n      resolve: { quote: QuoteResolver },\n      canActivate: [ContextGuard],\n    },\n    {\n      path: 'debug',\n      loadChildren: () => DebugModule,\n    },\n    {\n      path: '404',\n      loadChildren: () => RecordNotFoundModule,\n    },\n  ],\n};\n\n@NgModule({\n  imports: [\n    RouterModule.forChild([rootRoute]),\n    ProductModule,\n    LegacyProductModule,\n    ShoppingCartModule,\n    CatalogModule,\n    AssetsModule,\n    RemoteModule,\n    EmptyAccountModule,\n  ],\n  exports: [RouterModule],\n  providers: [FlowRouterService, RootGuard, ContextGuard, ProductUnloadGuard, FlowResolver, QuoteResolver],\n})\nexport class FlowRoutingModule {}\n"]}
|
@@ -7,7 +7,7 @@ import lodash, { compact, isArray, pull, merge, omit, flatten, set, kebabCase, c
|
|
7
7
|
import { getCollectionUniqueName, UUID, isDefined, Operator, Predicate, parseJsonSafely, CoreModule } from '@veloceapps/core';
|
8
8
|
import { applyPatch } from 'rfc6902';
|
9
9
|
import * as i2 from '@veloceapps/sdk/core';
|
10
|
-
import { ConfigurationService,
|
10
|
+
import { ConfigurationService, QuoteDraftService, FlowConfigurationService, LineItemWorker, ProductImagesService, ContextService, lineItemUtils, generateLineItem, getAttributeValue, SdkCoreModule, UI_DEFINITION_VERSION } from '@veloceapps/sdk/core';
|
11
11
|
import * as i3 from 'primeng/api';
|
12
12
|
import * as i5 from '@angular/common';
|
13
13
|
import { CommonModule, DOCUMENT } from '@angular/common';
|
@@ -21,8 +21,8 @@ import { DragDropModule } from '@angular/cdk/drag-drop';
|
|
21
21
|
import { ScrollingModule } from '@angular/cdk/scrolling';
|
22
22
|
import * as angularForms from '@angular/forms';
|
23
23
|
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
24
|
-
import { transform } from '@babel/standalone';
|
25
24
|
import * as rxjsOperators from 'rxjs/operators';
|
25
|
+
import { transform } from '@babel/standalone';
|
26
26
|
import { loadRemoteModule } from '@angular-architects/module-federation';
|
27
27
|
|
28
28
|
var FlowAction;
|
@@ -69,16 +69,25 @@ const SwitchObjectAction = (payload) => ({
|
|
69
69
|
var CmsAction;
|
70
70
|
(function (CmsAction) {
|
71
71
|
CmsAction.GO_TO_PAGE = '[CMS]_GO_TO_PAGE';
|
72
|
+
CmsAction.UPDATE_CUSTOMIZATION = '[CMS]_UPDATE_CUSTOMIZATION';
|
72
73
|
/**
|
73
74
|
* Navigate UI definition to a specific page
|
74
75
|
*
|
75
76
|
* @param pageName name of the page
|
76
|
-
* @returns void
|
77
77
|
*/
|
78
78
|
CmsAction.GoToPage = (pageName) => ({
|
79
79
|
type: CmsAction.GO_TO_PAGE,
|
80
80
|
payload: { pageName },
|
81
81
|
});
|
82
|
+
/**
|
83
|
+
* Update UI definition customization state
|
84
|
+
*
|
85
|
+
* @param pageName name of the page
|
86
|
+
*/
|
87
|
+
CmsAction.UpdateCustomization = (value) => ({
|
88
|
+
type: CmsAction.UPDATE_CUSTOMIZATION,
|
89
|
+
payload: { value },
|
90
|
+
});
|
82
91
|
})(CmsAction || (CmsAction = {}));
|
83
92
|
|
84
93
|
var cmsActions = /*#__PURE__*/Object.freeze({
|
@@ -101,7 +110,6 @@ const UI_DEFINITION_METADATA = new InjectionToken('UI_DEFINITION_METADATA_TOKEN'
|
|
101
110
|
const ELEMENT_METADATA = new InjectionToken('ELEMENT_METADATA_TOKEN');
|
102
111
|
const SHARED_ELEMENT_METADATA = new InjectionToken('SHARED_ELEMENT_METADATA_TOKEN');
|
103
112
|
const ELEMENT_CONFIG = new InjectionToken('ELEMENT_CONFIG_TOKEN');
|
104
|
-
const VENDOR_MAP = new InjectionToken('VENDOR_MAP');
|
105
113
|
|
106
114
|
var cmsInjectionTokens = /*#__PURE__*/Object.freeze({
|
107
115
|
__proto__: null,
|
@@ -109,8 +117,7 @@ var cmsInjectionTokens = /*#__PURE__*/Object.freeze({
|
|
109
117
|
ELEMENT_CONFIG: ELEMENT_CONFIG,
|
110
118
|
ELEMENT_METADATA: ELEMENT_METADATA,
|
111
119
|
SHARED_ELEMENT_METADATA: SHARED_ELEMENT_METADATA,
|
112
|
-
UI_DEFINITION_METADATA: UI_DEFINITION_METADATA
|
113
|
-
VENDOR_MAP: VENDOR_MAP
|
120
|
+
UI_DEFINITION_METADATA: UI_DEFINITION_METADATA
|
114
121
|
});
|
115
122
|
|
116
123
|
class Entity {
|
@@ -307,7 +314,7 @@ class RuntimeService {
|
|
307
314
|
if (!uiDefinition) {
|
308
315
|
return of([]);
|
309
316
|
}
|
310
|
-
return this.compilationService.compileUIDefinition$(uiDefinition).pipe(map(result => {
|
317
|
+
return this.compilationService.compileUIDefinition$(uiDefinition, config).pipe(map(result => {
|
311
318
|
this.applicationTree = result.elements;
|
312
319
|
this.componentTypes = Object.assign(Object.assign({}, this.componentTypes), result.componentTypes);
|
313
320
|
this.moduleRefs.push(result.moduleRef);
|
@@ -436,12 +443,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImpor
|
|
436
443
|
type: Injectable
|
437
444
|
}] });
|
438
445
|
|
439
|
-
const InitAction = { type: 'INIT' };
|
440
|
-
const ClearAction = { type: 'CLEAR' };
|
441
446
|
class IntegrationState {
|
442
447
|
constructor() {
|
443
448
|
this.stateSubj$ = new BehaviorSubject({});
|
444
|
-
this.action$ = new
|
449
|
+
this.action$ = new Subject();
|
445
450
|
}
|
446
451
|
get state$() {
|
447
452
|
return this.stateSubj$.asObservable();
|
@@ -463,7 +468,6 @@ class IntegrationState {
|
|
463
468
|
}
|
464
469
|
clear() {
|
465
470
|
this.stateSubj$.next({});
|
466
|
-
this.action$.next(ClearAction);
|
467
471
|
}
|
468
472
|
}
|
469
473
|
IntegrationState.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: IntegrationState, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
@@ -872,13 +876,18 @@ class ElementChildrenComponent {
|
|
872
876
|
this.destroyed$.next();
|
873
877
|
this.destroyed$.complete();
|
874
878
|
}
|
879
|
+
getFilteredChildren(elements) {
|
880
|
+
return this.filter ? this.filter(elements) : elements;
|
881
|
+
}
|
875
882
|
}
|
876
883
|
ElementChildrenComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: ElementChildrenComponent, deps: [{ token: ElementContextService }, { token: RuntimeService }, { token: RuntimeEditorService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
877
|
-
ElementChildrenComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: ElementChildrenComponent, selector: "element-children", ngImport: i0, template: "<ng-container *ngIf=\"metadata$ | async as metadata\">\n <vl-element-drop-handle *ngIf=\"dragMode$ | async\" [index]=\"0\" [parentPath]=\"metadata.path\"></vl-element-drop-handle>\n <ng-container *ngFor=\"let child of metadata.children; let i = index\">\n <vl-cms-element-renderer [meta]=\"child\"></vl-cms-element-renderer>\n <vl-element-drop-handle\n *ngIf=\"dragMode$ | async\"\n [index]=\"i + 1\"\n [parentPath]=\"metadata.path\"\n ></vl-element-drop-handle>\n </ng-container>\n</ng-container>\n", styles: [":host{display:contents}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ElementRendererComponent, selector: "vl-cms-element-renderer", inputs: ["meta"] }, { kind: "component", type: ElementDropHandleComponent, selector: "vl-element-drop-handle", inputs: ["index", "parentPath"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
884
|
+
ElementChildrenComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: ElementChildrenComponent, selector: "element-children", inputs: { filter: "filter" }, ngImport: i0, template: "<ng-container *ngIf=\"metadata$ | async as metadata\">\n <vl-element-drop-handle *ngIf=\"dragMode$ | async\" [index]=\"0\" [parentPath]=\"metadata.path\"></vl-element-drop-handle>\n <ng-container *ngFor=\"let child of getFilteredChildren(metadata.children); let i = index\">\n <vl-cms-element-renderer [meta]=\"child\"></vl-cms-element-renderer>\n <vl-element-drop-handle\n *ngIf=\"dragMode$ | async\"\n [index]=\"i + 1\"\n [parentPath]=\"metadata.path\"\n ></vl-element-drop-handle>\n </ng-container>\n</ng-container>\n", styles: [":host{display:contents}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ElementRendererComponent, selector: "vl-cms-element-renderer", inputs: ["meta"] }, { kind: "component", type: ElementDropHandleComponent, selector: "vl-element-drop-handle", inputs: ["index", "parentPath"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
878
885
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: ElementChildrenComponent, decorators: [{
|
879
886
|
type: Component,
|
880
|
-
args: [{ selector: 'element-children', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"metadata$ | async as metadata\">\n <vl-element-drop-handle *ngIf=\"dragMode$ | async\" [index]=\"0\" [parentPath]=\"metadata.path\"></vl-element-drop-handle>\n <ng-container *ngFor=\"let child of metadata.children; let i = index\">\n <vl-cms-element-renderer [meta]=\"child\"></vl-cms-element-renderer>\n <vl-element-drop-handle\n *ngIf=\"dragMode$ | async\"\n [index]=\"i + 1\"\n [parentPath]=\"metadata.path\"\n ></vl-element-drop-handle>\n </ng-container>\n</ng-container>\n", styles: [":host{display:contents}\n"] }]
|
881
|
-
}], ctorParameters: function () { return [{ type: ElementContextService }, { type: RuntimeService }, { type: RuntimeEditorService }, { type: i0.ChangeDetectorRef }]; }
|
887
|
+
args: [{ selector: 'element-children', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"metadata$ | async as metadata\">\n <vl-element-drop-handle *ngIf=\"dragMode$ | async\" [index]=\"0\" [parentPath]=\"metadata.path\"></vl-element-drop-handle>\n <ng-container *ngFor=\"let child of getFilteredChildren(metadata.children); let i = index\">\n <vl-cms-element-renderer [meta]=\"child\"></vl-cms-element-renderer>\n <vl-element-drop-handle\n *ngIf=\"dragMode$ | async\"\n [index]=\"i + 1\"\n [parentPath]=\"metadata.path\"\n ></vl-element-drop-handle>\n </ng-container>\n</ng-container>\n", styles: [":host{display:contents}\n"] }]
|
888
|
+
}], ctorParameters: function () { return [{ type: ElementContextService }, { type: RuntimeService }, { type: RuntimeEditorService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { filter: [{
|
889
|
+
type: Input
|
890
|
+
}] } });
|
882
891
|
|
883
892
|
class ElementChildrenModule {
|
884
893
|
}
|
@@ -896,12 +905,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImpor
|
|
896
905
|
|
897
906
|
class ElementToolsPanelComponent {
|
898
907
|
constructor() {
|
899
|
-
var _a;
|
908
|
+
var _a, _b;
|
900
909
|
this.metadata = inject(ELEMENT_METADATA);
|
901
910
|
this.config = inject(ELEMENT_CONFIG);
|
902
911
|
this.elementRef = inject(ElementRef);
|
903
|
-
this.showDeleteButton = !this.config.builder.suppressRemovable;
|
904
|
-
const hostRect = (
|
912
|
+
this.showDeleteButton = !((_a = this.config.builder) === null || _a === void 0 ? void 0 : _a.suppressRemovable);
|
913
|
+
const hostRect = (_b = this.elementRef.nativeElement.parentElement) === null || _b === void 0 ? void 0 : _b.getBoundingClientRect();
|
905
914
|
if (hostRect) {
|
906
915
|
merge(this.elementRef.nativeElement.style, {
|
907
916
|
width: `${hostRect.width}px`,
|
@@ -1012,6 +1021,7 @@ class ElementHoverPlugin {
|
|
1012
1021
|
this.destroyed$ = new Subject();
|
1013
1022
|
this.mouseOverListenerBound = this.mouseOverListener.bind(this);
|
1014
1023
|
this.mouseLeaveListenerBound = this.mouseLeaveListener.bind(this);
|
1024
|
+
this.clickListenerBound = this.clickListener.bind(this);
|
1015
1025
|
combineLatest([this.runtimeEditorService.editorMode$, this.isHovered$, this.isSelected$])
|
1016
1026
|
.pipe(takeUntil(this.destroyed$))
|
1017
1027
|
.subscribe(([editorMode]) => {
|
@@ -1038,10 +1048,12 @@ class ElementHoverPlugin {
|
|
1038
1048
|
attachListeners() {
|
1039
1049
|
this.el.nativeElement.addEventListener('mouseover', this.mouseOverListenerBound);
|
1040
1050
|
this.el.nativeElement.addEventListener('mouseleave', this.mouseLeaveListenerBound);
|
1051
|
+
this.el.nativeElement.addEventListener('click', this.clickListenerBound);
|
1041
1052
|
}
|
1042
1053
|
detachListeners() {
|
1043
1054
|
this.el.nativeElement.removeEventListener('mouseover', this.mouseOverListenerBound);
|
1044
1055
|
this.el.nativeElement.removeEventListener('mouseleave', this.mouseLeaveListenerBound);
|
1056
|
+
this.el.nativeElement.removeEventListener('click', this.clickListenerBound);
|
1045
1057
|
}
|
1046
1058
|
mouseOverListener(e) {
|
1047
1059
|
const path = e.composedPath();
|
@@ -1055,6 +1067,11 @@ class ElementHoverPlugin {
|
|
1055
1067
|
this.isHovered$.next(isHovered);
|
1056
1068
|
}
|
1057
1069
|
}
|
1070
|
+
clickListener(e) {
|
1071
|
+
if (this.el.nativeElement === e.target) {
|
1072
|
+
this.runtimeEditorService.selectedElementPath$.next(this.metadata.path);
|
1073
|
+
}
|
1074
|
+
}
|
1058
1075
|
mouseLeaveListener() {
|
1059
1076
|
this.isHovered$.next(false);
|
1060
1077
|
}
|
@@ -1176,58 +1193,103 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImpor
|
|
1176
1193
|
type: Directive
|
1177
1194
|
}], ctorParameters: function () { return [{ type: ElementComponent }]; } });
|
1178
1195
|
|
1196
|
+
const VELOCE_LIBS = {
|
1197
|
+
'@veloceapps/core': {
|
1198
|
+
isDefined,
|
1199
|
+
Operator,
|
1200
|
+
Predicate,
|
1201
|
+
parseJsonSafely,
|
1202
|
+
},
|
1203
|
+
'@veloceapps/components': {
|
1204
|
+
ToastService,
|
1205
|
+
ToastType,
|
1206
|
+
},
|
1207
|
+
'@veloceapps/api': {
|
1208
|
+
SalesforceApiService,
|
1209
|
+
QuoteApiService,
|
1210
|
+
DocumentTemplatesApiService,
|
1211
|
+
DocumentAttachmentApiService,
|
1212
|
+
RampApiService,
|
1213
|
+
CatalogApiService,
|
1214
|
+
DeltaApiService,
|
1215
|
+
PicklistsApiService,
|
1216
|
+
PriceApiService,
|
1217
|
+
ShoppingCartSettingsApiService,
|
1218
|
+
ConfigurationSettingsApiService,
|
1219
|
+
GuidedSellingApiService,
|
1220
|
+
},
|
1221
|
+
'@veloceapps/sdk/core': Object.assign({ ConfigurationService,
|
1222
|
+
QuoteDraftService,
|
1223
|
+
FlowConfigurationService,
|
1224
|
+
LineItemWorker,
|
1225
|
+
ProductImagesService,
|
1226
|
+
ContextService }, lineItemUtils),
|
1227
|
+
'@veloceapps/sdk/cms': Object.assign(Object.assign(Object.assign({}, cmsInjectionTokens), cmsActions), { TemplatesService,
|
1228
|
+
IntegrationState,
|
1229
|
+
ResourcesService }),
|
1230
|
+
};
|
1231
|
+
const VELOCE_LIBS_BACKWARDS_COMPATIBLE = Object.entries(VELOCE_LIBS).reduce((trunk, [key, value]) => (Object.assign(Object.assign({}, trunk), { [key.replace('@veloceapps/', '@veloce/')]: value })), {});
|
1232
|
+
const vendorMap = Object.assign(Object.assign(Object.assign({}, VELOCE_LIBS), VELOCE_LIBS_BACKWARDS_COMPATIBLE), { '@angular/core': i0, '@angular/forms': angularForms, rxjs: rxjs, 'rxjs/operators': rxjsOperators, lodash: lodash });
|
1233
|
+
|
1234
|
+
const importRegexp = new RegExp(`import([ \\n\\t]*(?:[^ \\n\\t\\{\\}]+[ \\n\\t]*,?)?(?:[ \\n\\t]*\\{(?:[ \\n\\t]*[^ \\n\\t"'\\{\\}]+[ \\n\\t]*,?)+\\})?[ \\n\\t]*)from[ \\n\\t]*(['"])([^'"\\n]+)(?:['"]);`, 'g');
|
1235
|
+
const normalizeImports = (script, elementPath) => {
|
1236
|
+
const result = script.replace(importRegexp, (match, g1, g2, src) => {
|
1237
|
+
const imports = g1
|
1238
|
+
.trim()
|
1239
|
+
.slice(1, -1)
|
1240
|
+
.split(',')
|
1241
|
+
.map(item => item.trim());
|
1242
|
+
imports.forEach(item => {
|
1243
|
+
var _a;
|
1244
|
+
if (!((_a = vendorMap[src]) === null || _a === void 0 ? void 0 : _a[item])) {
|
1245
|
+
throw new Error(`Failed to import ${item} from '${src}' in ${elementPath}/script.ts`);
|
1246
|
+
}
|
1247
|
+
});
|
1248
|
+
return `const ${g1} = vendor['${src}'];`;
|
1249
|
+
});
|
1250
|
+
return result;
|
1251
|
+
};
|
1252
|
+
const getScriptClass = (metadata) => {
|
1253
|
+
var _a;
|
1254
|
+
if (!(metadata === null || metadata === void 0 ? void 0 : metadata.script)) {
|
1255
|
+
return;
|
1256
|
+
}
|
1257
|
+
const id = btoa(UUID.UUID());
|
1258
|
+
const script = document.createElement('script');
|
1259
|
+
script.type = `text/javascript`;
|
1260
|
+
let scriptContent = normalizeImports(metadata.script, metadata.path);
|
1261
|
+
const classMatch = /export class (\S+)/.exec(scriptContent);
|
1262
|
+
const className = classMatch === null || classMatch === void 0 ? void 0 : classMatch[1];
|
1263
|
+
if (!classMatch || !className) {
|
1264
|
+
console.error("Script doesn't have exported class");
|
1265
|
+
return;
|
1266
|
+
}
|
1267
|
+
scriptContent = scriptContent.replace(classMatch[0], `class ${className}`);
|
1268
|
+
script.text = `var ${id} = function(vendor) {${scriptContent}
|
1269
|
+
return ${className}; };`;
|
1270
|
+
document.body.appendChild(script);
|
1271
|
+
const ScriptClass = (_a = window === null || window === void 0 ? void 0 : window[id]) === null || _a === void 0 ? void 0 : _a.call(window, vendorMap);
|
1272
|
+
document.body.removeChild(script);
|
1273
|
+
return ScriptClass;
|
1274
|
+
};
|
1275
|
+
|
1179
1276
|
class ScriptPlugin {
|
1180
1277
|
constructor(host) {
|
1181
1278
|
this.host = host;
|
1182
|
-
this.normalizeImports = (script, elementPath) => {
|
1183
|
-
const regexp = new RegExp(`import([ \\n\\t]*(?:[^ \\n\\t\\{\\}]+[ \\n\\t]*,?)?(?:[ \\n\\t]*\\{(?:[ \\n\\t]*[^ \\n\\t"'\\{\\}]+[ \\n\\t]*,?)+\\})?[ \\n\\t]*)from[ \\n\\t]*(['"])([^'"\\n]+)(?:['"]);`, 'g');
|
1184
|
-
const result = script.replace(regexp, (match, g1, g2, src) => {
|
1185
|
-
const imports = g1
|
1186
|
-
.trim()
|
1187
|
-
.slice(1, -1)
|
1188
|
-
.split(',')
|
1189
|
-
.map(item => item.trim());
|
1190
|
-
imports.forEach(item => {
|
1191
|
-
var _a;
|
1192
|
-
if (!((_a = this.vendorMap[src]) === null || _a === void 0 ? void 0 : _a[item])) {
|
1193
|
-
throw new Error(`Failed to import ${item} from '${src}' in ${elementPath}/script.ts`);
|
1194
|
-
}
|
1195
|
-
});
|
1196
|
-
return `const ${g1} = vendor['${src}'];`;
|
1197
|
-
});
|
1198
|
-
return result;
|
1199
|
-
};
|
1200
|
-
this.document = this.host.injector.get(DOCUMENT);
|
1201
|
-
this.vendorMap = this.host.injector.get(VENDOR_MAP);
|
1202
1279
|
const elementMetadata = this.host.injector.get(ELEMENT_METADATA);
|
1203
1280
|
const sharedElementMetadata = this.host.injector.get(SHARED_ELEMENT_METADATA);
|
1204
1281
|
this.addScript(sharedElementMetadata);
|
1205
1282
|
this.addScript(elementMetadata);
|
1206
1283
|
}
|
1207
1284
|
addScript(metadata) {
|
1208
|
-
var _a;
|
1209
1285
|
if (!(metadata === null || metadata === void 0 ? void 0 : metadata.script)) {
|
1210
1286
|
return;
|
1211
1287
|
}
|
1212
|
-
const
|
1213
|
-
const script = this.document.createElement('script');
|
1214
|
-
script.type = `text/javascript`;
|
1215
|
-
let scriptContent = this.normalizeImports(metadata.script, (_a = metadata.path) !== null && _a !== void 0 ? _a : metadata.name);
|
1216
|
-
const classMatch = /export class (\S+)/.exec(scriptContent);
|
1217
|
-
const className = classMatch === null || classMatch === void 0 ? void 0 : classMatch[1];
|
1218
|
-
if (!classMatch || !className) {
|
1219
|
-
console.error("Script doesn't have exported class");
|
1220
|
-
return;
|
1221
|
-
}
|
1222
|
-
scriptContent = scriptContent.replace(classMatch[0], `class ${className}`);
|
1223
|
-
script.text = `var ${id} = function(vendor) {${scriptContent}
|
1224
|
-
return ${className}; };`;
|
1225
|
-
this.document.body.appendChild(script);
|
1226
|
-
const ScriptClass = window[id](this.vendorMap);
|
1288
|
+
const ScriptClass = getScriptClass(metadata);
|
1227
1289
|
if (ScriptClass instanceof Object) {
|
1228
|
-
|
1290
|
+
const instance = new ScriptClass(this.host);
|
1291
|
+
this.host.registerPlugin(instance);
|
1229
1292
|
}
|
1230
|
-
this.document.body.removeChild(script);
|
1231
1293
|
}
|
1232
1294
|
}
|
1233
1295
|
ScriptPlugin.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: ScriptPlugin, deps: [{ token: ElementComponent }], target: i0.ɵɵFactoryTarget.Directive });
|
@@ -1240,29 +1302,29 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImpor
|
|
1240
1302
|
* ScriptPlugin must always be the last plugin in the list to make sure user code is running after all pre-initializers.
|
1241
1303
|
*/
|
1242
1304
|
const CONFIG = {
|
1305
|
+
CUSTOMIZATION_PAGE: {
|
1306
|
+
component: ElementComponent,
|
1307
|
+
plugins: [IOPlugin, ScriptPlugin],
|
1308
|
+
},
|
1243
1309
|
CUSTOM: {
|
1244
1310
|
component: ElementComponent,
|
1245
1311
|
plugins: [IOPlugin, ElementHoverPlugin, ScriptPlugin],
|
1246
|
-
builder: {},
|
1247
1312
|
},
|
1248
1313
|
CONTAINER: {
|
1249
1314
|
component: ElementComponent,
|
1250
1315
|
defaultTemplate: '<element-children></element-children>',
|
1251
1316
|
plugins: [ScriptPlugin],
|
1252
|
-
builder: {},
|
1253
1317
|
},
|
1254
1318
|
SERVICE: {
|
1255
1319
|
component: ElementComponent,
|
1256
1320
|
plugins: [IOPlugin, ScriptPlugin],
|
1257
1321
|
suppressTemplate: true,
|
1258
1322
|
suppressStyles: true,
|
1259
|
-
builder: {},
|
1260
1323
|
},
|
1261
1324
|
REFERENCE: {
|
1262
1325
|
component: ElementComponent,
|
1263
1326
|
plugins: [IOPlugin, ScriptPlugin],
|
1264
1327
|
suppressTemplate: true,
|
1265
|
-
builder: {},
|
1266
1328
|
},
|
1267
1329
|
PAGE: {
|
1268
1330
|
component: ElementComponent,
|
@@ -1758,47 +1820,11 @@ const LAYOUT = {
|
|
1758
1820
|
},
|
1759
1821
|
};
|
1760
1822
|
|
1761
|
-
const VELOCE_LIBS = {
|
1762
|
-
'@veloceapps/core': {
|
1763
|
-
isDefined,
|
1764
|
-
Operator,
|
1765
|
-
Predicate,
|
1766
|
-
parseJsonSafely,
|
1767
|
-
},
|
1768
|
-
'@veloceapps/components': {
|
1769
|
-
ToastService,
|
1770
|
-
ToastType,
|
1771
|
-
},
|
1772
|
-
'@veloceapps/api': {
|
1773
|
-
SalesforceApiService,
|
1774
|
-
QuoteApiService,
|
1775
|
-
DocumentTemplatesApiService,
|
1776
|
-
DocumentAttachmentApiService,
|
1777
|
-
RampApiService,
|
1778
|
-
CatalogApiService,
|
1779
|
-
DeltaApiService,
|
1780
|
-
PicklistsApiService,
|
1781
|
-
PriceApiService,
|
1782
|
-
ShoppingCartSettingsApiService,
|
1783
|
-
ConfigurationSettingsApiService,
|
1784
|
-
GuidedSellingApiService,
|
1785
|
-
},
|
1786
|
-
'@veloceapps/sdk/core': Object.assign({ ConfigurationService,
|
1787
|
-
QuoteDraftService,
|
1788
|
-
FlowConfigurationService,
|
1789
|
-
LineItemWorker,
|
1790
|
-
ProductImagesService,
|
1791
|
-
ContextService }, lineItemUtils),
|
1792
|
-
'@veloceapps/sdk/cms': Object.assign(Object.assign(Object.assign({}, cmsInjectionTokens), cmsActions), { TemplatesService,
|
1793
|
-
IntegrationState,
|
1794
|
-
ResourcesService }),
|
1795
|
-
};
|
1796
|
-
const VELOCE_LIBS_BACKWARDS_COMPATIBLE = Object.entries(VELOCE_LIBS).reduce((trunk, [key, value]) => (Object.assign(Object.assign({}, trunk), { [key.replace('@veloceapps/', '@veloce/')]: value })), {});
|
1797
|
-
const vendorMap = Object.assign(Object.assign(Object.assign({}, VELOCE_LIBS), VELOCE_LIBS_BACKWARDS_COMPATIBLE), { '@angular/core': i0, '@angular/forms': angularForms, rxjs: rxjs, 'rxjs/operators': rxjsOperators, lodash: lodash });
|
1798
|
-
|
1799
1823
|
class ElementsResolver {
|
1800
|
-
constructor(uiDef, elements, sharedElements = []) {
|
1824
|
+
constructor(uiDef, elements, sharedElements = [], config) {
|
1825
|
+
var _a;
|
1801
1826
|
this.uiDef = uiDef;
|
1827
|
+
this.config = config;
|
1802
1828
|
this.renderableElements = [];
|
1803
1829
|
this.sharedElements = [];
|
1804
1830
|
const transpiledElements = this.transpileScripts(elements);
|
@@ -1808,6 +1834,7 @@ class ElementsResolver {
|
|
1808
1834
|
.concat(transpiledSharedElements);
|
1809
1835
|
this.elements = transpiledElements.map(el => this.processElementMetadata(el)).filter(isDefined);
|
1810
1836
|
this.renderableElements = this.getRenderableElements(this.elements);
|
1837
|
+
this.uiDefMetadata = Object.assign(Object.assign({}, this.uiDef), { customization: (_a = this.uiDef.customization) !== null && _a !== void 0 ? _a : this.getDefaultCustomizationState() });
|
1811
1838
|
}
|
1812
1839
|
addElement(element) {
|
1813
1840
|
if (element.isShared) {
|
@@ -1842,9 +1869,12 @@ class ElementsResolver {
|
|
1842
1869
|
return Boolean(el.isShared) && el.type !== 'REFERENCE';
|
1843
1870
|
}
|
1844
1871
|
getRenderableElements(elements) {
|
1872
|
+
var _a;
|
1845
1873
|
const renderable = [];
|
1846
1874
|
for (const el of elements) {
|
1847
|
-
|
1875
|
+
// In `customizationMode` render only element with CUSTOMIZATION_PAGE type
|
1876
|
+
const typePerMode = Boolean((_a = this.config) === null || _a === void 0 ? void 0 : _a.customizationMode) === (el.type === 'CUSTOMIZATION_PAGE');
|
1877
|
+
if (!this.isSharedElement(el) && typePerMode) {
|
1848
1878
|
const children = el.children.filter(child => !this.isSharedElement(child));
|
1849
1879
|
const renderableChildren = this.getRenderableElements(children);
|
1850
1880
|
renderable.push(Object.assign(Object.assign({}, el), { children }), ...renderableChildren);
|
@@ -1905,7 +1935,7 @@ class ElementsResolver {
|
|
1905
1935
|
resolveElement(element) {
|
1906
1936
|
var _a;
|
1907
1937
|
const config = CONFIG[element.type];
|
1908
|
-
const defaultPlugins = (_a = DEFAULT_PLUGINS[this.
|
1938
|
+
const defaultPlugins = (_a = DEFAULT_PLUGINS[this.uiDefMetadata.type]) !== null && _a !== void 0 ? _a : [];
|
1909
1939
|
if (!config) {
|
1910
1940
|
console.warn(`Unknown element type "${element.type}"`);
|
1911
1941
|
return;
|
@@ -1913,11 +1943,10 @@ class ElementsResolver {
|
|
1913
1943
|
const styles = this.getElementStyles(element);
|
1914
1944
|
const component = Object.assign(Object.assign({ selector: 'vl-element', template: element.template }, (styles ? { styles: [styles] } : {})), { providers: [
|
1915
1945
|
{ provide: DEFAULT_PLUGINS_TOKEN, useValue: defaultPlugins },
|
1916
|
-
{ provide: UI_DEFINITION_METADATA, useValue: this.
|
1946
|
+
{ provide: UI_DEFINITION_METADATA, useValue: this.uiDefMetadata },
|
1917
1947
|
{ provide: ELEMENT_METADATA, useValue: element },
|
1918
1948
|
{ provide: SHARED_ELEMENT_METADATA, useValue: this.getSharedElement(element) },
|
1919
1949
|
{ provide: ELEMENT_CONFIG, useValue: config },
|
1920
|
-
{ provide: VENDOR_MAP, useValue: vendorMap },
|
1921
1950
|
] });
|
1922
1951
|
const cmp = Component(component)(class C extends config.component {
|
1923
1952
|
});
|
@@ -1948,6 +1977,14 @@ class ElementsResolver {
|
|
1948
1977
|
result += '}\n';
|
1949
1978
|
return result;
|
1950
1979
|
}
|
1980
|
+
getDefaultCustomizationState() {
|
1981
|
+
const customizationPage = this.elements.find(el => el.type === 'CUSTOMIZATION_PAGE');
|
1982
|
+
if (!(customizationPage === null || customizationPage === void 0 ? void 0 : customizationPage.script)) {
|
1983
|
+
return;
|
1984
|
+
}
|
1985
|
+
const c = getScriptClass(customizationPage);
|
1986
|
+
return c && 'default' in c ? c.default : undefined;
|
1987
|
+
}
|
1951
1988
|
}
|
1952
1989
|
|
1953
1990
|
class FederatedHostDirective {
|
@@ -2055,7 +2092,7 @@ class CompilationService {
|
|
2055
2092
|
constructor(injector) {
|
2056
2093
|
this.injector = injector;
|
2057
2094
|
}
|
2058
|
-
compileUIDefinition$(uiDefinition) {
|
2095
|
+
compileUIDefinition$(uiDefinition, config) {
|
2059
2096
|
return of([]).pipe(map(() => {
|
2060
2097
|
var _a, _b;
|
2061
2098
|
const { children, pages, components } = uiDefinition, uiDefinitionMeta = __rest(uiDefinition, ["children", "pages", "components"]);
|
@@ -2064,7 +2101,7 @@ class CompilationService {
|
|
2064
2101
|
const sharedElements = components !== null && components !== void 0 ? components : [];
|
2065
2102
|
const metadata = elements.map(element => elementToMetadata(element));
|
2066
2103
|
const sharedMetadata = sharedElements.map(element => elementToMetadata(element));
|
2067
|
-
this.elementsResolver = new ElementsResolver(uiDefinition, metadata, sharedMetadata);
|
2104
|
+
this.elementsResolver = new ElementsResolver(uiDefinition, metadata, sharedMetadata, config);
|
2068
2105
|
const componentTypes = this.elementsResolver.getNgComponents();
|
2069
2106
|
const module = this.getModule(componentTypes);
|
2070
2107
|
return {
|
@@ -2225,5 +2262,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImpor
|
|
2225
2262
|
* Generated bundle index. Do not edit.
|
2226
2263
|
*/
|
2227
2264
|
|
2228
|
-
export { ApplyProductConfigurationAction, CloseDocGenAction, CmsAction, ConfigureProductAction, DEFAULT_PLUGINS_TOKEN, ELEMENT_CONFIG, ELEMENT_METADATA, ElementComponent, ElementDefinition, ElementsResolver, FlowAction, IntegrationState, LauncherModule, MigrationsModule, MigrationsService, NavigateBackAction, NavigateToCatalogAction, OpenDocGenAction, PreviewComponent, PreviewModule, RemoteApplyAction, RemoteCancelAction, ResourcesService, RuntimeEditorService, RuntimeModule, SHARED_ELEMENT_METADATA, SwitchObjectAction, TemplatesService, UI_DEFINITION_METADATA, UiBuildError,
|
2265
|
+
export { ApplyProductConfigurationAction, CloseDocGenAction, CmsAction, ConfigureProductAction, DEFAULT_PLUGINS_TOKEN, ELEMENT_CONFIG, ELEMENT_METADATA, ElementComponent, ElementDefinition, ElementsResolver, FlowAction, IntegrationState, LauncherModule, MigrationsModule, MigrationsService, NavigateBackAction, NavigateToCatalogAction, OpenDocGenAction, PreviewComponent, PreviewModule, RemoteApplyAction, RemoteCancelAction, ResourcesService, RuntimeEditorService, RuntimeModule, SHARED_ELEMENT_METADATA, SwitchObjectAction, TemplatesService, UI_DEFINITION_METADATA, UiBuildError, doesElementSupportIO, elementToMetadata, extendElementMetadata, extractElementMetadata, findElementByModule, findElementByPath, flattenElements, getAbsolutePath, getElementConfig, insertElement, isSharedElement, isValidScript, metadataToElement, normalizeElementMetadata, parseBoundPath, parsePath, removeElement, stringifyElementMetadata };
|
2229
2266
|
//# sourceMappingURL=veloceapps-sdk-cms.mjs.map
|