@veloceapps/sdk 6.0.0-36 → 6.0.0-38

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.
Files changed (30) hide show
  1. package/bundles/veloceapps-sdk-cms.umd.js +103 -19
  2. package/bundles/veloceapps-sdk-cms.umd.js.map +1 -1
  3. package/bundles/veloceapps-sdk-core.umd.js +12 -0
  4. package/bundles/veloceapps-sdk-core.umd.js.map +1 -1
  5. package/cms/index.d.ts +1 -0
  6. package/cms/modules/migrations/index.d.ts +2 -0
  7. package/cms/modules/migrations/migrations.d.ts +2 -0
  8. package/cms/modules/migrations/migrations.module.d.ts +6 -0
  9. package/cms/modules/migrations/services/migrations.service.d.ts +10 -0
  10. package/cms/modules/migrations/types/migrations.types.d.ts +2 -0
  11. package/cms/utils/elements-resolver.d.ts +1 -1
  12. package/core/types/ui-definition.types.d.ts +19 -4
  13. package/core/utils/index.d.ts +1 -0
  14. package/core/utils/ui-definition.utils.d.ts +2 -0
  15. package/esm2015/cms/index.js +2 -1
  16. package/esm2015/cms/modules/migrations/index.js +3 -0
  17. package/esm2015/cms/modules/migrations/migrations.js +11 -0
  18. package/esm2015/cms/modules/migrations/migrations.module.js +15 -0
  19. package/esm2015/cms/modules/migrations/services/migrations.service.js +43 -0
  20. package/esm2015/cms/modules/migrations/types/migrations.types.js +2 -0
  21. package/esm2015/cms/modules/runtime/services/compilation.service.js +9 -6
  22. package/esm2015/cms/utils/elements-resolver.js +6 -3
  23. package/esm2015/core/types/ui-definition.types.js +2 -2
  24. package/esm2015/core/utils/index.js +2 -1
  25. package/esm2015/core/utils/ui-definition.utils.js +9 -0
  26. package/fesm2015/veloceapps-sdk-cms.js +79 -13
  27. package/fesm2015/veloceapps-sdk-cms.js.map +1 -1
  28. package/fesm2015/veloceapps-sdk-core.js +12 -2
  29. package/fesm2015/veloceapps-sdk-core.js.map +1 -1
  30. package/package.json +1 -1
package/cms/index.d.ts CHANGED
@@ -5,6 +5,7 @@ export * from './decorators';
5
5
  export * from './injection-tokens';
6
6
  export * from './launcher.module';
7
7
  export * from './modules/federated/export';
8
+ export * from './modules/migrations';
8
9
  export * from './modules/runtime';
9
10
  export * from './services';
10
11
  export * from './types';
@@ -0,0 +1,2 @@
1
+ export * from './migrations.module';
2
+ export * from './services/migrations.service';
@@ -0,0 +1,2 @@
1
+ import { UIDefinitionMigrationFn } from './types/migrations.types';
2
+ export declare const migrations: Record<number, UIDefinitionMigrationFn>;
@@ -0,0 +1,6 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class MigrationsModule {
3
+ static ɵfac: i0.ɵɵFactoryDeclaration<MigrationsModule, never>;
4
+ static ɵmod: i0.ɵɵNgModuleDeclaration<MigrationsModule, never, never, never>;
5
+ static ɵinj: i0.ɵɵInjectorDeclaration<MigrationsModule>;
6
+ }
@@ -0,0 +1,10 @@
1
+ import { ToastService } from '@veloceapps/components';
2
+ import { UIDefinition } from '@veloceapps/sdk/core';
3
+ import * as i0 from "@angular/core";
4
+ export declare class MigrationsService {
5
+ private toastService;
6
+ constructor(toastService: ToastService);
7
+ migrateUIDefinition(uiDef: UIDefinition): UIDefinition | undefined;
8
+ static ɵfac: i0.ɵɵFactoryDeclaration<MigrationsService, never>;
9
+ static ɵprov: i0.ɵɵInjectableDeclaration<MigrationsService>;
10
+ }
@@ -0,0 +1,2 @@
1
+ import { UIDefinition } from '@veloceapps/sdk/core';
2
+ export declare type UIDefinitionMigrationFn = (uiDef: UIDefinition) => UIDefinition;
@@ -6,7 +6,7 @@ export declare class ElementsResolver {
6
6
  elements: ElementMetadata[];
7
7
  private renderableElements;
8
8
  private sharedElements;
9
- constructor(uiDef: UIDefinitionMetadata, elements: ElementMetadata[]);
9
+ constructor(uiDef: UIDefinitionMetadata, elements: ElementMetadata[], sharedElements?: ElementMetadata[]);
10
10
  addElement(element: ElementMetadata): void;
11
11
  getNgComponents(): Type<any>[];
12
12
  private transpile;
@@ -1,5 +1,5 @@
1
1
  export declare type UIDefinitionType = 'DEFAULT' | 'CONFIGURATION';
2
- export declare type UIDefinitionMetadata = Omit<UIDefinition, 'children'>;
2
+ export declare const UI_DEFINITION_VERSION = 3;
3
3
  export declare type UIExternalsType = Record<string, string | number | boolean>;
4
4
  export interface UIDefinitionProps {
5
5
  suppressToastMessages?: boolean;
@@ -8,15 +8,30 @@ export interface UIDefinitionProps {
8
8
  priceList?: string;
9
9
  productId?: string;
10
10
  }
11
- export interface UIDefinition {
11
+ export interface UIDefinitionMetadata {
12
12
  name: string;
13
13
  type: UIDefinitionType;
14
- children: UIElement[];
15
14
  properties?: UIDefinitionProps;
16
15
  primary: boolean;
17
- version: number;
18
16
  createdTimestamp: number;
19
17
  externals?: UIExternalsType;
18
+ version: number;
19
+ }
20
+ export interface UIDefinition extends UIDefinitionMetadata {
21
+ /**
22
+ * `children` is for simple previews only.
23
+ * For applications use `pages` property instead
24
+ */
25
+ children?: UIElement[];
26
+ /**
27
+ * The page is an Element with `type: 'PAGE'`
28
+ */
29
+ pages?: UIElement[];
30
+ /**
31
+ * Shared components
32
+ * These are not rendered on the screen, and only used by REFERENCE type elements
33
+ */
34
+ components?: UIElement[];
20
35
  }
21
36
  export interface UIElement {
22
37
  children: UIElement[];
@@ -1,2 +1,3 @@
1
1
  export * from './line-item.utils';
2
2
  export * from './line-item.worker';
3
+ export * from './ui-definition.utils';
@@ -0,0 +1,2 @@
1
+ import { UIDefinition, UIDefinitionMetadata } from '../types';
2
+ export declare function extractMetadata(uiDefinition: UIDefinition): UIDefinitionMetadata;
@@ -5,8 +5,9 @@ export * from './decorators';
5
5
  export * from './injection-tokens';
6
6
  export * from './launcher.module';
7
7
  export * from './modules/federated/export';
8
+ export * from './modules/migrations';
8
9
  export * from './modules/runtime';
9
10
  export * from './services';
10
11
  export * from './types';
11
12
  export * from './utils';
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3Nkay9jbXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jbXMuYWN0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL3ByZXZpZXcnO1xuZXhwb3J0ICogZnJvbSAnLi9kZWNvcmF0b3JzJztcbmV4cG9ydCAqIGZyb20gJy4vaW5qZWN0aW9uLXRva2Vucyc7XG5leHBvcnQgKiBmcm9tICcuL2xhdW5jaGVyLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL21vZHVsZXMvZmVkZXJhdGVkL2V4cG9ydCc7XG5leHBvcnQgKiBmcm9tICcuL21vZHVsZXMvcnVudGltZSc7XG5leHBvcnQgKiBmcm9tICcuL3NlcnZpY2VzJztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscyc7XG5leHBvcnQgeyBWZW5kb3JNYXAgfSBmcm9tICcuL3ZlbmRvci1tYXAnO1xuIl19
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3Nkay9jbXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Ntcy5hY3Rpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvcHJldmlldyc7XG5leHBvcnQgKiBmcm9tICcuL2RlY29yYXRvcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9pbmplY3Rpb24tdG9rZW5zJztcbmV4cG9ydCAqIGZyb20gJy4vbGF1bmNoZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kdWxlcy9mZWRlcmF0ZWQvZXhwb3J0JztcbmV4cG9ydCAqIGZyb20gJy4vbW9kdWxlcy9taWdyYXRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kdWxlcy9ydW50aW1lJztcbmV4cG9ydCAqIGZyb20gJy4vc2VydmljZXMnO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzJztcbmV4cG9ydCB7IFZlbmRvck1hcCB9IGZyb20gJy4vdmVuZG9yLW1hcCc7XG4iXX0=
@@ -0,0 +1,3 @@
1
+ export * from './migrations.module';
2
+ export * from './services/migrations.service';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Nkay9jbXMvbW9kdWxlcy9taWdyYXRpb25zL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYywrQkFBK0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbWlncmF0aW9ucy5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlcy9taWdyYXRpb25zLnNlcnZpY2UnO1xuIl19
@@ -0,0 +1,11 @@
1
+ export const migrations = {
2
+ 2: () => {
3
+ throw 'Migration from Legacy UI definition is not possible';
4
+ },
5
+ 3: uiDef => {
6
+ var _a;
7
+ const children = (_a = uiDef.children) !== null && _a !== void 0 ? _a : [];
8
+ return Object.assign(Object.assign({}, uiDef), { children: undefined, pages: children, version: 3 });
9
+ },
10
+ };
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWlncmF0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2RrL2Ntcy9tb2R1bGVzL21pZ3JhdGlvbnMvbWlncmF0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQTRDO0lBQ2pFLENBQUMsRUFBRSxHQUFHLEVBQUU7UUFDTixNQUFNLHFEQUFxRCxDQUFDO0lBQzlELENBQUM7SUFDRCxDQUFDLEVBQUUsS0FBSyxDQUFDLEVBQUU7O1FBQ1QsTUFBTSxRQUFRLEdBQUcsTUFBQSxLQUFLLENBQUMsUUFBUSxtQ0FBSSxFQUFFLENBQUM7UUFFdEMsdUNBQ0ssS0FBSyxLQUNSLFFBQVEsRUFBRSxTQUFTLEVBQ25CLEtBQUssRUFBRSxRQUFRLEVBQ2YsT0FBTyxFQUFFLENBQUMsSUFDVjtJQUNKLENBQUM7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVUlEZWZpbml0aW9uTWlncmF0aW9uRm4gfSBmcm9tICcuL3R5cGVzL21pZ3JhdGlvbnMudHlwZXMnO1xuXG5leHBvcnQgY29uc3QgbWlncmF0aW9uczogUmVjb3JkPG51bWJlciwgVUlEZWZpbml0aW9uTWlncmF0aW9uRm4+ID0ge1xuICAyOiAoKSA9PiB7XG4gICAgdGhyb3cgJ01pZ3JhdGlvbiBmcm9tIExlZ2FjeSBVSSBkZWZpbml0aW9uIGlzIG5vdCBwb3NzaWJsZSc7XG4gIH0sXG4gIDM6IHVpRGVmID0+IHtcbiAgICBjb25zdCBjaGlsZHJlbiA9IHVpRGVmLmNoaWxkcmVuID8/IFtdO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLnVpRGVmLFxuICAgICAgY2hpbGRyZW46IHVuZGVmaW5lZCxcbiAgICAgIHBhZ2VzOiBjaGlsZHJlbixcbiAgICAgIHZlcnNpb246IDMsXG4gICAgfTtcbiAgfSxcbn07XG4iXX0=
@@ -0,0 +1,15 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { MigrationsService } from './services/migrations.service';
3
+ import * as i0 from "@angular/core";
4
+ export class MigrationsModule {
5
+ }
6
+ MigrationsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MigrationsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
7
+ MigrationsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MigrationsModule });
8
+ MigrationsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MigrationsModule, providers: [MigrationsService] });
9
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MigrationsModule, decorators: [{
10
+ type: NgModule,
11
+ args: [{
12
+ providers: [MigrationsService],
13
+ }]
14
+ }] });
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWlncmF0aW9ucy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Nkay9jbXMvbW9kdWxlcy9taWdyYXRpb25zL21pZ3JhdGlvbnMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sK0JBQStCLENBQUM7O0FBS2xFLE1BQU0sT0FBTyxnQkFBZ0I7OzhHQUFoQixnQkFBZ0I7K0dBQWhCLGdCQUFnQjsrR0FBaEIsZ0JBQWdCLGFBRmhCLENBQUMsaUJBQWlCLENBQUM7NEZBRW5CLGdCQUFnQjtrQkFINUIsUUFBUTttQkFBQztvQkFDUixTQUFTLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztpQkFDL0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWlncmF0aW9uc1NlcnZpY2UgfSBmcm9tICcuL3NlcnZpY2VzL21pZ3JhdGlvbnMuc2VydmljZSc7XG5cbkBOZ01vZHVsZSh7XG4gIHByb3ZpZGVyczogW01pZ3JhdGlvbnNTZXJ2aWNlXSxcbn0pXG5leHBvcnQgY2xhc3MgTWlncmF0aW9uc01vZHVsZSB7fVxuIl19
@@ -0,0 +1,43 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { ToastType } from '@veloceapps/components';
3
+ import { UI_DEFINITION_VERSION } from '@veloceapps/sdk/core';
4
+ import { cloneDeep } from 'lodash';
5
+ import { migrations } from '../migrations';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@veloceapps/components";
8
+ export class MigrationsService {
9
+ constructor(toastService) {
10
+ this.toastService = toastService;
11
+ }
12
+ migrateUIDefinition(uiDef) {
13
+ const currentVersion = uiDef.version;
14
+ const targetVersion = UI_DEFINITION_VERSION;
15
+ const migrateVersions = Object.keys(migrations)
16
+ .reduce((acc, version) => {
17
+ const v = Number(version);
18
+ if (v > currentVersion && v <= targetVersion) {
19
+ acc.push(v);
20
+ }
21
+ return acc;
22
+ }, [])
23
+ .sort();
24
+ try {
25
+ let result = cloneDeep(uiDef);
26
+ for (const version of migrateVersions) {
27
+ result = migrations[version](result);
28
+ }
29
+ return result;
30
+ }
31
+ catch (e) {
32
+ this.toastService.add({ summary: String(e), severity: ToastType.error });
33
+ return;
34
+ }
35
+ }
36
+ }
37
+ MigrationsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MigrationsService, deps: [{ token: i1.ToastService }], target: i0.ɵɵFactoryTarget.Injectable });
38
+ MigrationsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MigrationsService, providedIn: 'root' });
39
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MigrationsService, decorators: [{
40
+ type: Injectable,
41
+ args: [{ providedIn: 'root' }]
42
+ }], ctorParameters: function () { return [{ type: i1.ToastService }]; } });
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWlncmF0aW9ucy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9zZGsvY21zL21vZHVsZXMvbWlncmF0aW9ucy9zZXJ2aWNlcy9taWdyYXRpb25zLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQWdCLFNBQVMsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ2pFLE9BQU8sRUFBZ0IscUJBQXFCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUMzRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQ25DLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQUczQyxNQUFNLE9BQU8saUJBQWlCO0lBQzVCLFlBQW9CLFlBQTBCO1FBQTFCLGlCQUFZLEdBQVosWUFBWSxDQUFjO0lBQUcsQ0FBQztJQUUzQyxtQkFBbUIsQ0FBQyxLQUFtQjtRQUM1QyxNQUFNLGNBQWMsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDO1FBQ3JDLE1BQU0sYUFBYSxHQUFHLHFCQUFxQixDQUFDO1FBRTVDLE1BQU0sZUFBZSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDO2FBQzVDLE1BQU0sQ0FBQyxDQUFDLEdBQWEsRUFBRSxPQUFPLEVBQUUsRUFBRTtZQUNqQyxNQUFNLENBQUMsR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDMUIsSUFBSSxDQUFDLEdBQUcsY0FBYyxJQUFJLENBQUMsSUFBSSxhQUFhLEVBQUU7Z0JBQzVDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDYjtZQUVELE9BQU8sR0FBRyxDQUFDO1FBQ2IsQ0FBQyxFQUFFLEVBQUUsQ0FBQzthQUNMLElBQUksRUFBRSxDQUFDO1FBRVYsSUFBSTtZQUNGLElBQUksTUFBTSxHQUFHLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUU5QixLQUFLLE1BQU0sT0FBTyxJQUFJLGVBQWUsRUFBRTtnQkFDckMsTUFBTSxHQUFHLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQzthQUN0QztZQUVELE9BQU8sTUFBTSxDQUFDO1NBQ2Y7UUFBQyxPQUFPLENBQUMsRUFBRTtZQUNWLElBQUksQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLEVBQUUsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxRQUFRLEVBQUUsU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7WUFDekUsT0FBTztTQUNSO0lBQ0gsQ0FBQzs7K0dBOUJVLGlCQUFpQjttSEFBakIsaUJBQWlCLGNBREosTUFBTTs0RkFDbkIsaUJBQWlCO2tCQUQ3QixVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRvYXN0U2VydmljZSwgVG9hc3RUeXBlIH0gZnJvbSAnQHZlbG9jZWFwcHMvY29tcG9uZW50cyc7XG5pbXBvcnQgeyBVSURlZmluaXRpb24sIFVJX0RFRklOSVRJT05fVkVSU0lPTiB9IGZyb20gJ0B2ZWxvY2VhcHBzL3Nkay9jb3JlJztcbmltcG9ydCB7IGNsb25lRGVlcCB9IGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQgeyBtaWdyYXRpb25zIH0gZnJvbSAnLi4vbWlncmF0aW9ucyc7XG5cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXG5leHBvcnQgY2xhc3MgTWlncmF0aW9uc1NlcnZpY2Uge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHRvYXN0U2VydmljZTogVG9hc3RTZXJ2aWNlKSB7fVxuXG4gIHB1YmxpYyBtaWdyYXRlVUlEZWZpbml0aW9uKHVpRGVmOiBVSURlZmluaXRpb24pOiBVSURlZmluaXRpb24gfCB1bmRlZmluZWQge1xuICAgIGNvbnN0IGN1cnJlbnRWZXJzaW9uID0gdWlEZWYudmVyc2lvbjtcbiAgICBjb25zdCB0YXJnZXRWZXJzaW9uID0gVUlfREVGSU5JVElPTl9WRVJTSU9OO1xuXG4gICAgY29uc3QgbWlncmF0ZVZlcnNpb25zID0gT2JqZWN0LmtleXMobWlncmF0aW9ucylcbiAgICAgIC5yZWR1Y2UoKGFjYzogbnVtYmVyW10sIHZlcnNpb24pID0+IHtcbiAgICAgICAgY29uc3QgdiA9IE51bWJlcih2ZXJzaW9uKTtcbiAgICAgICAgaWYgKHYgPiBjdXJyZW50VmVyc2lvbiAmJiB2IDw9IHRhcmdldFZlcnNpb24pIHtcbiAgICAgICAgICBhY2MucHVzaCh2KTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBhY2M7XG4gICAgICB9LCBbXSlcbiAgICAgIC5zb3J0KCk7XG5cbiAgICB0cnkge1xuICAgICAgbGV0IHJlc3VsdCA9IGNsb25lRGVlcCh1aURlZik7XG5cbiAgICAgIGZvciAoY29uc3QgdmVyc2lvbiBvZiBtaWdyYXRlVmVyc2lvbnMpIHtcbiAgICAgICAgcmVzdWx0ID0gbWlncmF0aW9uc1t2ZXJzaW9uXShyZXN1bHQpO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gcmVzdWx0O1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIHRoaXMudG9hc3RTZXJ2aWNlLmFkZCh7IHN1bW1hcnk6IFN0cmluZyhlKSwgc2V2ZXJpdHk6IFRvYXN0VHlwZS5lcnJvciB9KTtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWlncmF0aW9ucy50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2RrL2Ntcy9tb2R1bGVzL21pZ3JhdGlvbnMvdHlwZXMvbWlncmF0aW9ucy50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVUlEZWZpbml0aW9uIH0gZnJvbSAnQHZlbG9jZWFwcHMvc2RrL2NvcmUnO1xuXG5leHBvcnQgdHlwZSBVSURlZmluaXRpb25NaWdyYXRpb25GbiA9ICh1aURlZjogVUlEZWZpbml0aW9uKSA9PiBVSURlZmluaXRpb247XG4iXX0=
@@ -1,10 +1,9 @@
1
- import { __decorate } from "tslib";
1
+ import { __decorate, __rest } from "tslib";
2
2
  import { DragDropModule } from '@angular/cdk/drag-drop';
3
3
  import { ScrollingModule } from '@angular/cdk/scrolling';
4
4
  import { CommonModule } from '@angular/common';
5
5
  import { Injectable, NgModule } from '@angular/core';
6
6
  import { FormsModule, ReactiveFormsModule } from '@angular/forms';
7
- import { omit } from 'lodash';
8
7
  import { DndModule } from 'ngx-drag-drop';
9
8
  import { combineLatest, from, map, of, switchMap } from 'rxjs';
10
9
  import { ElementChildrenComponent } from '../../../components/element-children/element-children.component';
@@ -19,10 +18,14 @@ export class CompilationService {
19
18
  this.compiler = compiler;
20
19
  }
21
20
  compileUIDefinition$(uiDefinition) {
22
- this.uiDefinitionMeta = omit(uiDefinition, 'children');
23
21
  return of([]).pipe(switchMap(() => {
24
- const metadata = uiDefinition.children.map(element => elementToMetadata(element));
25
- this.elementsResolver = new ElementsResolver(uiDefinition, metadata);
22
+ const { children, pages, components } = uiDefinition, uiDefinitionMeta = __rest(uiDefinition, ["children", "pages", "components"]);
23
+ this.uiDefinitionMeta = uiDefinitionMeta;
24
+ const elements = [...(children !== null && children !== void 0 ? children : []), ...(pages !== null && pages !== void 0 ? pages : [])];
25
+ const sharedElements = components !== null && components !== void 0 ? components : [];
26
+ const metadata = elements.map(element => elementToMetadata(element));
27
+ const sharedMetadata = sharedElements.map(element => elementToMetadata(element));
28
+ this.elementsResolver = new ElementsResolver(uiDefinition, metadata, sharedMetadata);
26
29
  const module = this.getModule(this.elementsResolver.getNgComponents());
27
30
  return combineLatest([
28
31
  from(this.compiler.compileModuleAndAllComponentsAsync(module)),
@@ -78,4 +81,4 @@ CompilationService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", v
78
81
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: CompilationService, decorators: [{
79
82
  type: Injectable
80
83
  }], ctorParameters: function () { return [{ type: i0.Compiler }]; } });
81
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compilation.service.js","sourceRoot":"","sources":["../../../../../../../../libs/sdk/cms/modules/runtime/services/compilation.service.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAY,UAAU,EAAE,QAAQ,EAAQ,MAAM,eAAe,CAAC;AACrE,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAElE,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAC9B,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,IAAI,EAAE,GAAG,EAAc,EAAE,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAC3E,OAAO,EAAE,wBAAwB,EAAE,MAAM,iEAAiE,CAAC;AAC3G,OAAO,EAAE,0BAA0B,EAAE,MAAM,uEAAuE,CAAC;AACnH,OAAO,EAAE,wBAAwB,EAAE,MAAM,iEAAiE,CAAC;AAC3G,OAAO,EAAE,uBAAuB,EAAE,MAAM,+CAA+C,CAAC;AAGxF,OAAO,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACrE,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;;AAGnE,MAAM,OAAO,kBAAkB;IAI7B,YAAoB,QAAkB;QAAlB,aAAQ,GAAR,QAAQ,CAAU;IAAG,CAAC;IAEnC,oBAAoB,CAAC,YAA0B;QACpD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC;QAEvD,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,IAAI,CAChB,SAAS,CAAC,GAAG,EAAE;YACb,MAAM,QAAQ,GAAG,YAAY,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,CAAC;YAClF,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;YACrE,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,eAAe,EAAE,CAAC,CAAC;YAEvE,OAAO,aAAa,CAAC;gBACnB,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,kCAAkC,CAAC,MAAM,CAAC,CAAC;gBAC9D,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC;aAC1B,CAAC,CAAC;QACL,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,gBAAgB,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,gBAAgB,CAAC,QAAQ,EAAE,CAAC,CAAC,CACvF,CAAC;IACJ,CAAC;IAEM,eAAe,CAAC,OAAwB;QAC7C,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;YAC1B,MAAM,0BAA0B,CAAC;SAClC;QAED,OAAO,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,IAAI,CACnC,SAAS,CAAC,YAAY,CAAC,EAAE;;YACvB,MAAM,gBAAgB,GAAG,MAAA,IAAI,CAAC,gBAAgB,mCAAI,IAAI,gBAAgB,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;YACzF,gBAAgB,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;YACrC,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,eAAe,EAAE,CAAC,CAAC;YAElE,OAAO,aAAa,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,kCAAkC,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;QAC/G,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,gBAAgB,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,gBAAgB,CAAC,QAAQ,EAAE,CAAC,CAAC,CACvF,CAAC;IACJ,CAAC;IAEM,gBAAgB,CAAC,OAAyB;QAC/C,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC;QAC/D,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAC;IACpC,CAAC;IAEO,SAAS,CAAC,UAAuB;QACvC,MAAM,gBAAgB,GAAG;YACvB,wBAAwB;YACxB,wBAAwB;YACxB,0BAA0B;YAC1B,uBAAuB;SACxB,CAAC;QAeF,IAAM,aAAa,GAAnB,MAAM,aAAa;SAAG,CAAA;QAAhB,aAAa;YAblB,QAAQ,CAAC;gBACR,OAAO,EAAE;oBACP,YAAY;oBACZ,WAAW;oBACX,mBAAmB;oBACnB,eAAe;oBACf,cAAc;oBACd,SAAS;oBACT,eAAe;iBAChB;gBACD,YAAY,EAAE,CAAC,GAAG,gBAAgB,EAAE,GAAG,UAAU,CAAC;gBAClD,GAAG,EAAE,IAAI;aACV,CAAC;WACI,aAAa,CAAG;QAEtB,OAAO,aAAa,CAAC;IACvB,CAAC;;gHAtEU,kBAAkB;oHAAlB,kBAAkB;4FAAlB,kBAAkB;kBAD9B,UAAU","sourcesContent":["import { DragDropModule } from '@angular/cdk/drag-drop';\nimport { ScrollingModule } from '@angular/cdk/scrolling';\nimport { CommonModule } from '@angular/common';\nimport { Compiler, Injectable, NgModule, Type } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { UIDefinition, UIDefinitionMetadata } from '@veloceapps/sdk/core';\nimport { omit } from 'lodash';\nimport { DndModule } from 'ngx-drag-drop';\nimport { combineLatest, from, map, Observable, of, switchMap } from 'rxjs';\nimport { ElementChildrenComponent } from '../../../components/element-children/element-children.component';\nimport { ElementDropHandleComponent } from '../../../components/element-drop-handle/element-drop-handle.component';\nimport { ElementRendererComponent } from '../../../components/element-renderer/element-renderer.component';\nimport { CustomTemplateDirective } from '../../../directives/custom-template.directive';\nimport { CompilationResult } from '../../../modules/runtime/types/compilation.types';\nimport { ElementMetadata } from '../../../types/common.types';\nimport { ElementsResolver, elementToMetadata } from '../../../utils';\nimport { FederatedModule } from '../../federated/federated.module';\n\n@Injectable()\nexport class CompilationService {\n  private uiDefinitionMeta?: UIDefinitionMetadata;\n  private elementsResolver?: ElementsResolver;\n\n  constructor(private compiler: Compiler) {}\n\n  public compileUIDefinition$(uiDefinition: UIDefinition): Observable<CompilationResult> {\n    this.uiDefinitionMeta = omit(uiDefinition, 'children');\n\n    return of([]).pipe(\n      switchMap(() => {\n        const metadata = uiDefinition.children.map(element => elementToMetadata(element));\n        this.elementsResolver = new ElementsResolver(uiDefinition, metadata);\n        const module = this.getModule(this.elementsResolver.getNgComponents());\n\n        return combineLatest([\n          from(this.compiler.compileModuleAndAllComponentsAsync(module)),\n          of(this.elementsResolver),\n        ]);\n      }),\n      map(([module, elementsResolver]) => ({ module, elements: elementsResolver.elements })),\n    );\n  }\n\n  public compileElement$(element: ElementMetadata): Observable<CompilationResult> {\n    if (!this.uiDefinitionMeta) {\n      throw 'No UI Definition context';\n    }\n\n    return of(this.uiDefinitionMeta).pipe(\n      switchMap(uiDefinition => {\n        const elementsResolver = this.elementsResolver ?? new ElementsResolver(uiDefinition, []);\n        elementsResolver.addElement(element);\n        const module = this.getModule(elementsResolver.getNgComponents());\n\n        return combineLatest([from(this.compiler.compileModuleAndAllComponentsAsync(module)), of(elementsResolver)]);\n      }),\n      map(([module, elementsResolver]) => ({ module, elements: elementsResolver.elements })),\n    );\n  }\n\n  public clearModuleCache(modules: Type<NgModule>[]): void {\n    modules.forEach(module => this.compiler.clearCacheFor(module));\n    this.uiDefinitionMeta = undefined;\n  }\n\n  private getModule(components: Type<any>[]): Type<NgModule> {\n    const staticComponents = [\n      ElementChildrenComponent,\n      ElementRendererComponent,\n      ElementDropHandleComponent,\n      CustomTemplateDirective,\n    ];\n\n    @NgModule({\n      imports: [\n        CommonModule,\n        FormsModule,\n        ReactiveFormsModule,\n        FederatedModule,\n        DragDropModule,\n        DndModule,\n        ScrollingModule,\n      ],\n      declarations: [...staticComponents, ...components],\n      jit: true,\n    })\n    class DynamicModule {}\n\n    return DynamicModule;\n  }\n}\n"]}
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compilation.service.js","sourceRoot":"","sources":["../../../../../../../../libs/sdk/cms/modules/runtime/services/compilation.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { DragDropModule } from '@angular/cdk/drag-drop';\nimport { ScrollingModule } from '@angular/cdk/scrolling';\nimport { CommonModule } from '@angular/common';\nimport { Compiler, Injectable, NgModule, Type } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { UIDefinition, UIDefinitionMetadata } from '@veloceapps/sdk/core';\nimport { DndModule } from 'ngx-drag-drop';\nimport { combineLatest, from, map, Observable, of, switchMap } from 'rxjs';\nimport { ElementChildrenComponent } from '../../../components/element-children/element-children.component';\nimport { ElementDropHandleComponent } from '../../../components/element-drop-handle/element-drop-handle.component';\nimport { ElementRendererComponent } from '../../../components/element-renderer/element-renderer.component';\nimport { CustomTemplateDirective } from '../../../directives/custom-template.directive';\nimport { CompilationResult } from '../../../modules/runtime/types/compilation.types';\nimport { ElementMetadata } from '../../../types/common.types';\nimport { ElementsResolver, elementToMetadata } from '../../../utils';\nimport { FederatedModule } from '../../federated/federated.module';\n\n@Injectable()\nexport class CompilationService {\n  private uiDefinitionMeta?: UIDefinitionMetadata;\n  private elementsResolver?: ElementsResolver;\n\n  constructor(private compiler: Compiler) {}\n\n  public compileUIDefinition$(uiDefinition: UIDefinition): Observable<CompilationResult> {\n    return of([]).pipe(\n      switchMap(() => {\n        const { children, pages, components, ...uiDefinitionMeta } = uiDefinition;\n        this.uiDefinitionMeta = uiDefinitionMeta;\n\n        const elements = [...(children ?? []), ...(pages ?? [])];\n        const sharedElements = components ?? [];\n\n        const metadata = elements.map(element => elementToMetadata(element));\n        const sharedMetadata = sharedElements.map(element => elementToMetadata(element));\n\n        this.elementsResolver = new ElementsResolver(uiDefinition, metadata, sharedMetadata);\n        const module = this.getModule(this.elementsResolver.getNgComponents());\n\n        return combineLatest([\n          from(this.compiler.compileModuleAndAllComponentsAsync(module)),\n          of(this.elementsResolver),\n        ]);\n      }),\n      map(([module, elementsResolver]) => ({ module, elements: elementsResolver.elements })),\n    );\n  }\n\n  public compileElement$(element: ElementMetadata): Observable<CompilationResult> {\n    if (!this.uiDefinitionMeta) {\n      throw 'No UI Definition context';\n    }\n\n    return of(this.uiDefinitionMeta).pipe(\n      switchMap(uiDefinition => {\n        const elementsResolver = this.elementsResolver ?? new ElementsResolver(uiDefinition, []);\n        elementsResolver.addElement(element);\n        const module = this.getModule(elementsResolver.getNgComponents());\n\n        return combineLatest([from(this.compiler.compileModuleAndAllComponentsAsync(module)), of(elementsResolver)]);\n      }),\n      map(([module, elementsResolver]) => ({ module, elements: elementsResolver.elements })),\n    );\n  }\n\n  public clearModuleCache(modules: Type<NgModule>[]): void {\n    modules.forEach(module => this.compiler.clearCacheFor(module));\n    this.uiDefinitionMeta = undefined;\n  }\n\n  private getModule(components: Type<any>[]): Type<NgModule> {\n    const staticComponents = [\n      ElementChildrenComponent,\n      ElementRendererComponent,\n      ElementDropHandleComponent,\n      CustomTemplateDirective,\n    ];\n\n    @NgModule({\n      imports: [\n        CommonModule,\n        FormsModule,\n        ReactiveFormsModule,\n        FederatedModule,\n        DragDropModule,\n        DndModule,\n        ScrollingModule,\n      ],\n      declarations: [...staticComponents, ...components],\n      jit: true,\n    })\n    class DynamicModule {}\n\n    return DynamicModule;\n  }\n}\n"]}
@@ -7,12 +7,15 @@ import { CONFIG } from '../cms.elements';
7
7
  import { DEFAULT_PLUGINS_TOKEN, ELEMENT_CONFIG, ELEMENT_METADATA, SHARED_ELEMENT_METADATA, UI_DEFINITION_METADATA, VENDOR_MAP, } from '../injection-tokens';
8
8
  import { vendorMap } from '../vendor-map';
9
9
  export class ElementsResolver {
10
- constructor(uiDef, elements) {
10
+ constructor(uiDef, elements, sharedElements = []) {
11
11
  this.uiDef = uiDef;
12
12
  this.renderableElements = [];
13
13
  this.sharedElements = [];
14
14
  const transpiledElements = this.transpileScripts(elements);
15
- this.sharedElements = this.flattenElements(transpiledElements).filter(el => this.isSharedElement(el));
15
+ const transpiledSharedElements = this.transpileScripts(sharedElements);
16
+ this.sharedElements = this.flattenElements(transpiledElements)
17
+ .filter(el => this.isSharedElement(el))
18
+ .concat(transpiledSharedElements);
16
19
  this.elements = transpiledElements.map(el => this.processElementMetadata(el)).filter(isDefined);
17
20
  this.renderableElements = this.getRenderableElements(this.elements);
18
21
  }
@@ -151,4 +154,4 @@ export class ElementsResolver {
151
154
  return result;
152
155
  }
153
156
  }
154
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elements-resolver.js","sourceRoot":"","sources":["../../../../../../libs/sdk/cms/utils/elements-resolver.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Type } from '@angular/core';\nimport { transform } from '@babel/standalone';\nimport { isDefined } from '@veloceapps/core';\nimport { UIDefinitionMetadata } from '@veloceapps/sdk/core';\nimport { flatten, kebabCase, set } from 'lodash';\nimport { DEFAULT_PLUGINS } from '../cms.default';\nimport { CONFIG } from '../cms.elements';\nimport {\n  DEFAULT_PLUGINS_TOKEN,\n  ELEMENT_CONFIG,\n  ELEMENT_METADATA,\n  SHARED_ELEMENT_METADATA,\n  UI_DEFINITION_METADATA,\n  VENDOR_MAP,\n} from '../injection-tokens';\nimport { ElementMetadata, ElementStyleDeclaration } from '../types';\nimport { vendorMap } from '../vendor-map';\n\nexport class ElementsResolver {\n  public elements: ElementMetadata[];\n\n  private renderableElements: ElementMetadata[] = [];\n  private sharedElements: ElementMetadata[] = [];\n\n  constructor(private uiDef: UIDefinitionMetadata, elements: ElementMetadata[]) {\n    const transpiledElements = this.transpileScripts(elements);\n\n    this.sharedElements = this.flattenElements(transpiledElements).filter(el => this.isSharedElement(el));\n\n    this.elements = transpiledElements.map(el => this.processElementMetadata(el)).filter(isDefined);\n\n    this.renderableElements = this.getRenderableElements(this.elements);\n  }\n\n  public addElement(element: ElementMetadata): void {\n    if (element.isShared) {\n      return;\n    }\n\n    const transpiledElements = this.transpileScripts([element]);\n    this.elements = transpiledElements.map(el => this.processElementMetadata(el)).filter(isDefined);\n    this.renderableElements = this.getRenderableElements(this.elements);\n  }\n\n  public getNgComponents(): Type<any>[] {\n    return this.renderableElements.map(el => this.resolveElement(el)).filter(isDefined);\n  }\n\n  private transpile(el: ElementMetadata): string | undefined {\n    if (!el.script) {\n      return;\n    }\n\n    const transformed = transform(el.script, {\n      filename: el.name + '.ts',\n      presets: ['typescript'],\n      sourceMaps: 'inline',\n    });\n\n    return transformed.code ?? undefined;\n  }\n\n  private transpileScripts(elements: ElementMetadata[]): ElementMetadata[] {\n    return elements.map(el => ({\n      ...el,\n      script: this.transpile(el),\n      children: this.transpileScripts(el.children),\n    }));\n  }\n\n  private flattenElements(elements: ElementMetadata[]): ElementMetadata[] {\n    return flatten(elements.map(el => [el, ...this.flattenElements(el.children)]));\n  }\n\n  private isSharedElement(el: ElementMetadata): boolean {\n    return Boolean(el.isShared) && el.type !== 'REFERENCE';\n  }\n\n  private getRenderableElements(elements: ElementMetadata[]): ElementMetadata[] {\n    const renderable: ElementMetadata[] = [];\n\n    for (const el of elements) {\n      if (!this.isSharedElement(el)) {\n        const children = el.children.filter(child => !this.isSharedElement(child));\n        const renderableChildren = this.getRenderableElements(children);\n        renderable.push({ ...el, children }, ...renderableChildren);\n      }\n    }\n\n    return renderable;\n  }\n\n  private getSharedElement(element: ElementMetadata): ElementMetadata | undefined {\n    if (!element.reference) {\n      return;\n    }\n\n    return this.sharedElements.find(el => element.reference === el.name);\n  }\n\n  private resolveElementTemplate(element: ElementMetadata): string {\n    const config = CONFIG[element.type];\n    const template = !config.suppressTemplate ? element.template : '';\n\n    return template || config.defaultTemplate || '';\n  }\n\n  private resolveElementStyles(element: ElementMetadata): string {\n    const config = CONFIG[element.type];\n    return !config.suppressStyles ? element.styles ?? '' : '';\n  }\n\n  private processElementMetadata(sourceElement: ElementMetadata): ElementMetadata | undefined {\n    let finalElement: ElementMetadata;\n\n    if (sourceElement.type === 'REFERENCE') {\n      const sharedElement = this.getSharedElement(sourceElement);\n\n      if (!sharedElement) {\n        console.warn(`Shared element \"${sourceElement.reference}\" not found`);\n        return;\n      }\n\n      finalElement = {\n        ...sourceElement,\n        children: this.getSharedChildren(sharedElement.children, sourceElement.path),\n        type: sharedElement.type,\n        template: sharedElement.template,\n        styles: (sharedElement.styles ?? '') + '\\n' + (sourceElement.styles ?? ''),\n        inputs: {\n          ...sharedElement.inputs,\n          ...sourceElement.inputs,\n        },\n        outputs: {\n          ...sharedElement.outputs,\n          ...sourceElement.outputs,\n        },\n      };\n    } else {\n      finalElement = sourceElement;\n      delete sourceElement.reference;\n    }\n\n    finalElement.template = this.resolveElementTemplate(finalElement);\n    finalElement.styles = this.resolveElementStyles(finalElement);\n\n    return {\n      ...finalElement,\n      children: finalElement.children.map(child => this.processElementMetadata(child)).filter(isDefined),\n    };\n  }\n\n  private getSharedChildren(children: ElementMetadata[], parentPath?: string): ElementMetadata[] {\n    return children.map(c => {\n      if (!c.path) {\n        return c;\n      }\n\n      const [elName] = c.path.split('/').reverse();\n      const path = parentPath + '/' + elName;\n\n      return {\n        ...c,\n        path,\n        children: this.getSharedChildren(c.children, path),\n      };\n    });\n  }\n\n  private resolveElement(element: ElementMetadata): Type<any> | undefined {\n    const config = CONFIG[element.type];\n    const defaultPlugins = DEFAULT_PLUGINS[this.uiDef.type] ?? [];\n\n    if (!config) {\n      console.warn(`Unknown element type \"${element.type}\"`);\n      return;\n    }\n\n    const styles = this.getElementStyles(element);\n\n    const component: Component = {\n      selector: 'vl-element',\n      template: element.template,\n      ...(styles ? { styles: [styles] } : {}),\n      providers: [\n        { provide: DEFAULT_PLUGINS_TOKEN, useValue: defaultPlugins },\n        { provide: UI_DEFINITION_METADATA, useValue: this.uiDef },\n        { provide: ELEMENT_METADATA, useValue: element },\n        { provide: SHARED_ELEMENT_METADATA, useValue: this.getSharedElement(element) },\n        { provide: ELEMENT_CONFIG, useValue: config },\n        { provide: VENDOR_MAP, useValue: vendorMap },\n      ],\n    };\n\n    const cmp = Component(component)(class C extends config.component {});\n\n    set(cmp, 'path', element.path);\n\n    return cmp;\n  }\n\n  private getElementStyles(element: ElementMetadata): string | undefined {\n    let result = '';\n\n    const configuredStyles = this.convertInlineStylesToCSS(element.configuredStyles);\n    if (configuredStyles) {\n      // order is important: styles written by user in CSS code should has higher priority\n      result += configuredStyles;\n    }\n\n    if (element.styles) {\n      result += element.styles;\n    }\n\n    return result || undefined;\n  }\n\n  private convertInlineStylesToCSS(styles?: ElementStyleDeclaration): string {\n    if (!styles) {\n      return '';\n    }\n\n    const entries = Object.entries(styles);\n    let result = ':host {\\n';\n\n    entries.forEach(([style, value]) => {\n      result += `  ${kebabCase(style)}:${value};\\n`;\n    });\n\n    result += '}\\n';\n\n    return result;\n  }\n}\n"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elements-resolver.js","sourceRoot":"","sources":["../../../../../../libs/sdk/cms/utils/elements-resolver.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Type } from '@angular/core';\nimport { transform } from '@babel/standalone';\nimport { isDefined } from '@veloceapps/core';\nimport { UIDefinitionMetadata } from '@veloceapps/sdk/core';\nimport { flatten, kebabCase, set } from 'lodash';\nimport { DEFAULT_PLUGINS } from '../cms.default';\nimport { CONFIG } from '../cms.elements';\nimport {\n  DEFAULT_PLUGINS_TOKEN,\n  ELEMENT_CONFIG,\n  ELEMENT_METADATA,\n  SHARED_ELEMENT_METADATA,\n  UI_DEFINITION_METADATA,\n  VENDOR_MAP,\n} from '../injection-tokens';\nimport { ElementMetadata, ElementStyleDeclaration } from '../types';\nimport { vendorMap } from '../vendor-map';\n\nexport class ElementsResolver {\n  public elements: ElementMetadata[];\n\n  private renderableElements: ElementMetadata[] = [];\n  private sharedElements: ElementMetadata[] = [];\n\n  constructor(\n    private uiDef: UIDefinitionMetadata,\n    elements: ElementMetadata[],\n    sharedElements: ElementMetadata[] = [],\n  ) {\n    const transpiledElements = this.transpileScripts(elements);\n    const transpiledSharedElements = this.transpileScripts(sharedElements);\n\n    this.sharedElements = this.flattenElements(transpiledElements)\n      .filter(el => this.isSharedElement(el))\n      .concat(transpiledSharedElements);\n\n    this.elements = transpiledElements.map(el => this.processElementMetadata(el)).filter(isDefined);\n\n    this.renderableElements = this.getRenderableElements(this.elements);\n  }\n\n  public addElement(element: ElementMetadata): void {\n    if (element.isShared) {\n      return;\n    }\n\n    const transpiledElements = this.transpileScripts([element]);\n    this.elements = transpiledElements.map(el => this.processElementMetadata(el)).filter(isDefined);\n    this.renderableElements = this.getRenderableElements(this.elements);\n  }\n\n  public getNgComponents(): Type<any>[] {\n    return this.renderableElements.map(el => this.resolveElement(el)).filter(isDefined);\n  }\n\n  private transpile(el: ElementMetadata): string | undefined {\n    if (!el.script) {\n      return;\n    }\n\n    const transformed = transform(el.script, {\n      filename: el.name + '.ts',\n      presets: ['typescript'],\n      sourceMaps: 'inline',\n    });\n\n    return transformed.code ?? undefined;\n  }\n\n  private transpileScripts(elements: ElementMetadata[]): ElementMetadata[] {\n    return elements.map(el => ({\n      ...el,\n      script: this.transpile(el),\n      children: this.transpileScripts(el.children),\n    }));\n  }\n\n  private flattenElements(elements: ElementMetadata[]): ElementMetadata[] {\n    return flatten(elements.map(el => [el, ...this.flattenElements(el.children)]));\n  }\n\n  private isSharedElement(el: ElementMetadata): boolean {\n    return Boolean(el.isShared) && el.type !== 'REFERENCE';\n  }\n\n  private getRenderableElements(elements: ElementMetadata[]): ElementMetadata[] {\n    const renderable: ElementMetadata[] = [];\n\n    for (const el of elements) {\n      if (!this.isSharedElement(el)) {\n        const children = el.children.filter(child => !this.isSharedElement(child));\n        const renderableChildren = this.getRenderableElements(children);\n        renderable.push({ ...el, children }, ...renderableChildren);\n      }\n    }\n\n    return renderable;\n  }\n\n  private getSharedElement(element: ElementMetadata): ElementMetadata | undefined {\n    if (!element.reference) {\n      return;\n    }\n\n    return this.sharedElements.find(el => element.reference === el.name);\n  }\n\n  private resolveElementTemplate(element: ElementMetadata): string {\n    const config = CONFIG[element.type];\n    const template = !config.suppressTemplate ? element.template : '';\n\n    return template || config.defaultTemplate || '';\n  }\n\n  private resolveElementStyles(element: ElementMetadata): string {\n    const config = CONFIG[element.type];\n    return !config.suppressStyles ? element.styles ?? '' : '';\n  }\n\n  private processElementMetadata(sourceElement: ElementMetadata): ElementMetadata | undefined {\n    let finalElement: ElementMetadata;\n\n    if (sourceElement.type === 'REFERENCE') {\n      const sharedElement = this.getSharedElement(sourceElement);\n\n      if (!sharedElement) {\n        console.warn(`Shared element \"${sourceElement.reference}\" not found`);\n        return;\n      }\n\n      finalElement = {\n        ...sourceElement,\n        children: this.getSharedChildren(sharedElement.children, sourceElement.path),\n        type: sharedElement.type,\n        template: sharedElement.template,\n        styles: (sharedElement.styles ?? '') + '\\n' + (sourceElement.styles ?? ''),\n        inputs: {\n          ...sharedElement.inputs,\n          ...sourceElement.inputs,\n        },\n        outputs: {\n          ...sharedElement.outputs,\n          ...sourceElement.outputs,\n        },\n      };\n    } else {\n      finalElement = sourceElement;\n      delete sourceElement.reference;\n    }\n\n    finalElement.template = this.resolveElementTemplate(finalElement);\n    finalElement.styles = this.resolveElementStyles(finalElement);\n\n    return {\n      ...finalElement,\n      children: finalElement.children.map(child => this.processElementMetadata(child)).filter(isDefined),\n    };\n  }\n\n  private getSharedChildren(children: ElementMetadata[], parentPath?: string): ElementMetadata[] {\n    return children.map(c => {\n      if (!c.path) {\n        return c;\n      }\n\n      const [elName] = c.path.split('/').reverse();\n      const path = parentPath + '/' + elName;\n\n      return {\n        ...c,\n        path,\n        children: this.getSharedChildren(c.children, path),\n      };\n    });\n  }\n\n  private resolveElement(element: ElementMetadata): Type<any> | undefined {\n    const config = CONFIG[element.type];\n    const defaultPlugins = DEFAULT_PLUGINS[this.uiDef.type] ?? [];\n\n    if (!config) {\n      console.warn(`Unknown element type \"${element.type}\"`);\n      return;\n    }\n\n    const styles = this.getElementStyles(element);\n\n    const component: Component = {\n      selector: 'vl-element',\n      template: element.template,\n      ...(styles ? { styles: [styles] } : {}),\n      providers: [\n        { provide: DEFAULT_PLUGINS_TOKEN, useValue: defaultPlugins },\n        { provide: UI_DEFINITION_METADATA, useValue: this.uiDef },\n        { provide: ELEMENT_METADATA, useValue: element },\n        { provide: SHARED_ELEMENT_METADATA, useValue: this.getSharedElement(element) },\n        { provide: ELEMENT_CONFIG, useValue: config },\n        { provide: VENDOR_MAP, useValue: vendorMap },\n      ],\n    };\n\n    const cmp = Component(component)(class C extends config.component {});\n\n    set(cmp, 'path', element.path);\n\n    return cmp;\n  }\n\n  private getElementStyles(element: ElementMetadata): string | undefined {\n    let result = '';\n\n    const configuredStyles = this.convertInlineStylesToCSS(element.configuredStyles);\n    if (configuredStyles) {\n      // order is important: styles written by user in CSS code should has higher priority\n      result += configuredStyles;\n    }\n\n    if (element.styles) {\n      result += element.styles;\n    }\n\n    return result || undefined;\n  }\n\n  private convertInlineStylesToCSS(styles?: ElementStyleDeclaration): string {\n    if (!styles) {\n      return '';\n    }\n\n    const entries = Object.entries(styles);\n    let result = ':host {\\n';\n\n    entries.forEach(([style, value]) => {\n      result += `  ${kebabCase(style)}:${value};\\n`;\n    });\n\n    result += '}\\n';\n\n    return result;\n  }\n}\n"]}
@@ -1,2 +1,2 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktZGVmaW5pdGlvbi50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2RrL2NvcmUvdHlwZXMvdWktZGVmaW5pdGlvbi50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgVUlEZWZpbml0aW9uVHlwZSA9ICdERUZBVUxUJyB8ICdDT05GSUdVUkFUSU9OJztcblxuZXhwb3J0IHR5cGUgVUlEZWZpbml0aW9uTWV0YWRhdGEgPSBPbWl0PFVJRGVmaW5pdGlvbiwgJ2NoaWxkcmVuJz47XG5cbmV4cG9ydCB0eXBlIFVJRXh0ZXJuYWxzVHlwZSA9IFJlY29yZDxzdHJpbmcsIHN0cmluZyB8IG51bWJlciB8IGJvb2xlYW4+O1xuXG5leHBvcnQgaW50ZXJmYWNlIFVJRGVmaW5pdGlvblByb3BzIHtcbiAgLy8gR0VORVJBTFxuICBzdXBwcmVzc1RvYXN0TWVzc2FnZXM/OiBib29sZWFuO1xuXG4gIC8vIENPTkZJR1VSQVRJT05cbiAgcm9vdFR5cGU/OiBzdHJpbmc7XG4gIHByaWNpbmdFbmFibGVkPzogYm9vbGVhbjtcbiAgcHJpY2VMaXN0Pzogc3RyaW5nO1xuICBwcm9kdWN0SWQ/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVUlEZWZpbml0aW9uIHtcbiAgbmFtZTogc3RyaW5nO1xuICB0eXBlOiBVSURlZmluaXRpb25UeXBlO1xuICBjaGlsZHJlbjogVUlFbGVtZW50W107XG4gIHByb3BlcnRpZXM/OiBVSURlZmluaXRpb25Qcm9wcztcbiAgcHJpbWFyeTogYm9vbGVhbjtcbiAgdmVyc2lvbjogbnVtYmVyO1xuICBjcmVhdGVkVGltZXN0YW1wOiBudW1iZXI7XG4gIGV4dGVybmFscz86IFVJRXh0ZXJuYWxzVHlwZTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVSUVsZW1lbnQge1xuICBjaGlsZHJlbjogVUlFbGVtZW50W107XG4gIHRlbXBsYXRlPzogc3RyaW5nO1xuICBzY3JpcHQ/OiBzdHJpbmc7XG4gIHN0eWxlcz86IHN0cmluZztcbn1cbiJdfQ==
1
+ export const UI_DEFINITION_VERSION = 3;
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktZGVmaW5pdGlvbi50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2RrL2NvcmUvdHlwZXMvdWktZGVmaW5pdGlvbi50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQUMsTUFBTSxxQkFBcUIsR0FBRyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBVSURlZmluaXRpb25UeXBlID0gJ0RFRkFVTFQnIHwgJ0NPTkZJR1VSQVRJT04nO1xuXG5leHBvcnQgY29uc3QgVUlfREVGSU5JVElPTl9WRVJTSU9OID0gMztcblxuZXhwb3J0IHR5cGUgVUlFeHRlcm5hbHNUeXBlID0gUmVjb3JkPHN0cmluZywgc3RyaW5nIHwgbnVtYmVyIHwgYm9vbGVhbj47XG5cbmV4cG9ydCBpbnRlcmZhY2UgVUlEZWZpbml0aW9uUHJvcHMge1xuICAvLyBHRU5FUkFMXG4gIHN1cHByZXNzVG9hc3RNZXNzYWdlcz86IGJvb2xlYW47XG5cbiAgLy8gQ09ORklHVVJBVElPTlxuICByb290VHlwZT86IHN0cmluZztcbiAgcHJpY2luZ0VuYWJsZWQ/OiBib29sZWFuO1xuICBwcmljZUxpc3Q/OiBzdHJpbmc7XG4gIHByb2R1Y3RJZD86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVSURlZmluaXRpb25NZXRhZGF0YSB7XG4gIG5hbWU6IHN0cmluZztcbiAgdHlwZTogVUlEZWZpbml0aW9uVHlwZTtcbiAgcHJvcGVydGllcz86IFVJRGVmaW5pdGlvblByb3BzO1xuICBwcmltYXJ5OiBib29sZWFuO1xuICBjcmVhdGVkVGltZXN0YW1wOiBudW1iZXI7XG4gIGV4dGVybmFscz86IFVJRXh0ZXJuYWxzVHlwZTtcbiAgdmVyc2lvbjogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFVJRGVmaW5pdGlvbiBleHRlbmRzIFVJRGVmaW5pdGlvbk1ldGFkYXRhIHtcbiAgLyoqXG4gICAqIGBjaGlsZHJlbmAgaXMgZm9yIHNpbXBsZSBwcmV2aWV3cyBvbmx5LlxuICAgKiBGb3IgYXBwbGljYXRpb25zIHVzZSBgcGFnZXNgIHByb3BlcnR5IGluc3RlYWRcbiAgICovXG4gIGNoaWxkcmVuPzogVUlFbGVtZW50W107XG5cbiAgLyoqXG4gICAqIFRoZSBwYWdlIGlzIGFuIEVsZW1lbnQgd2l0aCBgdHlwZTogJ1BBR0UnYFxuICAgKi9cbiAgcGFnZXM/OiBVSUVsZW1lbnRbXTtcblxuICAvKipcbiAgICogU2hhcmVkIGNvbXBvbmVudHNcbiAgICogVGhlc2UgYXJlIG5vdCByZW5kZXJlZCBvbiB0aGUgc2NyZWVuLCBhbmQgb25seSB1c2VkIGJ5IFJFRkVSRU5DRSB0eXBlIGVsZW1lbnRzXG4gICAqL1xuICBjb21wb25lbnRzPzogVUlFbGVtZW50W107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVUlFbGVtZW50IHtcbiAgY2hpbGRyZW46IFVJRWxlbWVudFtdO1xuICB0ZW1wbGF0ZT86IHN0cmluZztcbiAgc2NyaXB0Pzogc3RyaW5nO1xuICBzdHlsZXM/OiBzdHJpbmc7XG59XG4iXX0=
@@ -1,3 +1,4 @@
1
1
  export * from './line-item.utils';
2
2
  export * from './line-item.worker';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Nkay9jb3JlL3V0aWxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxvQkFBb0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGluZS1pdGVtLnV0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vbGluZS1pdGVtLndvcmtlcic7XG4iXX0=
3
+ export * from './ui-definition.utils';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Nkay9jb3JlL3V0aWxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saW5lLWl0ZW0udXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saW5lLWl0ZW0ud29ya2VyJztcbmV4cG9ydCAqIGZyb20gJy4vdWktZGVmaW5pdGlvbi51dGlscyc7XG4iXX0=
@@ -0,0 +1,9 @@
1
+ import { omit } from 'lodash';
2
+ export function extractMetadata(uiDefinition) {
3
+ return omit(uiDefinition, [
4
+ 'children',
5
+ 'pages',
6
+ 'components',
7
+ ]);
8
+ }
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktZGVmaW5pdGlvbi51dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2RrL2NvcmUvdXRpbHMvdWktZGVmaW5pdGlvbi51dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBRzlCLE1BQU0sVUFBVSxlQUFlLENBQUMsWUFBMEI7SUFDeEQsT0FBTyxJQUFJLENBQXFFLFlBQVksRUFBRTtRQUM1RixVQUFVO1FBQ1YsT0FBTztRQUNQLFlBQVk7S0FDYixDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgb21pdCB9IGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQgeyBVSURlZmluaXRpb24sIFVJRGVmaW5pdGlvbk1ldGFkYXRhIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgZnVuY3Rpb24gZXh0cmFjdE1ldGFkYXRhKHVpRGVmaW5pdGlvbjogVUlEZWZpbml0aW9uKTogVUlEZWZpbml0aW9uTWV0YWRhdGEge1xuICByZXR1cm4gb21pdDxVSURlZmluaXRpb24sIGtleW9mIE9taXQ8VUlEZWZpbml0aW9uLCBrZXlvZiBVSURlZmluaXRpb25NZXRhZGF0YT4+KHVpRGVmaW5pdGlvbiwgW1xuICAgICdjaGlsZHJlbicsXG4gICAgJ3BhZ2VzJyxcbiAgICAnY29tcG9uZW50cycsXG4gIF0pO1xufVxuIl19
@@ -1,16 +1,16 @@
1
- import { __decorate, __param, __awaiter } from 'tslib';
1
+ import { __decorate, __param, __awaiter, __rest } from 'tslib';
2
2
  import * as i0 from '@angular/core';
3
3
  import { InjectionToken, Component, ChangeDetectionStrategy, Inject, Injector, Injectable, ViewContainerRef, SkipSelf, ViewChild, Input, ViewEncapsulation, NgModule, Directive, ElementRef } from '@angular/core';
4
4
  import * as rxjs from 'rxjs';
5
5
  import { BehaviorSubject, Subject, of, map, tap, switchMap, startWith, distinctUntilChanged, filter, takeUntil, forkJoin, catchError, ReplaySubject, combineLatest, from } from 'rxjs';
6
6
  import * as lodash from 'lodash';
7
- import { compact, isArray, pull, merge, flatten, set, kebabCase, omit } from 'lodash';
7
+ import { compact, isArray, pull, merge, flatten, set, kebabCase, cloneDeep } from 'lodash';
8
8
  import { applyPatch } from 'rfc6902';
9
9
  import * as i2 from '@veloceapps/sdk/core';
10
- import { ConfigurationService, LineItemWorker, generateLineItem, getAttributeValue, QuoteDraftService, FlowConfigurationService, ProductImagesService, ContextService, lineItemUtils, SdkCoreModule } from '@veloceapps/sdk/core';
10
+ import { ConfigurationService, LineItemWorker, generateLineItem, getAttributeValue, QuoteDraftService, FlowConfigurationService, ProductImagesService, ContextService, lineItemUtils, SdkCoreModule, UI_DEFINITION_VERSION } from '@veloceapps/sdk/core';
11
11
  import * as i3 from 'primeng/api';
12
- import * as i5 from '@veloceapps/components';
13
- import { LetDirectiveModule, LoaderModule, ToastService } from '@veloceapps/components';
12
+ import * as i1 from '@veloceapps/components';
13
+ import { LetDirectiveModule, LoaderModule, ToastService, ToastType } from '@veloceapps/components';
14
14
  import { UUID, isDefined, CoreModule } from '@veloceapps/core';
15
15
  import * as i7 from '@angular/common';
16
16
  import { CommonModule, DOCUMENT } from '@angular/common';
@@ -703,7 +703,7 @@ class PreviewComponent {
703
703
  }
704
704
  }
705
705
  PreviewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: PreviewComponent, deps: [{ token: RuntimeService }, { token: i2.ConfigurationService }, { token: i3.MessageService }, { token: i2.ConfigurationRuntimeService }, { token: IntegrationState }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
706
- PreviewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: PreviewComponent, selector: "vl-cms-preview", inputs: { modelId: "modelId", uiDefinition: "uiDefinition", config: "config" }, providers: [IOProviderService, TemplatesService], ngImport: i0, template: "<ng-container *ngIf=\"state$ | async as state\">\n <vl-loader *ngIf=\"state.loading; else content\" [label]=\"'Loading UI'\"></vl-loader>\n\n <ng-template #content>\n <ng-container *ngIf=\"!state.failure\">\n <vl-cms-element-renderer *ngFor=\"let el of elements\" [meta]=\"el\"></vl-cms-element-renderer>\n </ng-container>\n </ng-template>\n</ng-container>\n", styles: [":host{flex-grow:1;display:flex;flex-direction:column;height:100%}\n"], components: [{ type: i5.LoaderComponent, selector: "vl-loader", inputs: ["label", "overlayVisible"] }, { type: ElementRendererComponent, selector: "vl-cms-element-renderer", inputs: ["meta"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i7.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.ShadowDom });
706
+ PreviewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: PreviewComponent, selector: "vl-cms-preview", inputs: { modelId: "modelId", uiDefinition: "uiDefinition", config: "config" }, providers: [IOProviderService, TemplatesService], ngImport: i0, template: "<ng-container *ngIf=\"state$ | async as state\">\n <vl-loader *ngIf=\"state.loading; else content\" [label]=\"'Loading UI'\"></vl-loader>\n\n <ng-template #content>\n <ng-container *ngIf=\"!state.failure\">\n <vl-cms-element-renderer *ngFor=\"let el of elements\" [meta]=\"el\"></vl-cms-element-renderer>\n </ng-container>\n </ng-template>\n</ng-container>\n", styles: [":host{flex-grow:1;display:flex;flex-direction:column;height:100%}\n"], components: [{ type: i1.LoaderComponent, selector: "vl-loader", inputs: ["label", "overlayVisible"] }, { type: ElementRendererComponent, selector: "vl-cms-element-renderer", inputs: ["meta"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i7.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.ShadowDom });
707
707
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: PreviewComponent, decorators: [{
708
708
  type: Component,
709
709
  args: [{
@@ -1461,12 +1461,15 @@ const VELOCE_LIBS_BACKWARDS_COMPATIBLE = Object.entries(VELOCE_LIBS).reduce((tru
1461
1461
  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 });
1462
1462
 
1463
1463
  class ElementsResolver {
1464
- constructor(uiDef, elements) {
1464
+ constructor(uiDef, elements, sharedElements = []) {
1465
1465
  this.uiDef = uiDef;
1466
1466
  this.renderableElements = [];
1467
1467
  this.sharedElements = [];
1468
1468
  const transpiledElements = this.transpileScripts(elements);
1469
- this.sharedElements = this.flattenElements(transpiledElements).filter(el => this.isSharedElement(el));
1469
+ const transpiledSharedElements = this.transpileScripts(sharedElements);
1470
+ this.sharedElements = this.flattenElements(transpiledElements)
1471
+ .filter(el => this.isSharedElement(el))
1472
+ .concat(transpiledSharedElements);
1470
1473
  this.elements = transpiledElements.map(el => this.processElementMetadata(el)).filter(isDefined);
1471
1474
  this.renderableElements = this.getRenderableElements(this.elements);
1472
1475
  }
@@ -1697,7 +1700,7 @@ class FederatedComponent {
1697
1700
  }
1698
1701
  }
1699
1702
  FederatedComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FederatedComponent, deps: [{ token: i0.Injector }, { token: i0.Compiler }, { token: i0.ApplicationRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
1700
- FederatedComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FederatedComponent, selector: "veloce-host-federated", inputs: { remoteEntry: "remoteEntry", remoteName: "remoteName", exposedModule: "exposedModule", data: "data", options: "options" }, viewQueries: [{ propertyName: "moduleHostRef", first: true, predicate: ["moduleHost"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div #moduleHost></div>\n\n<vl-loader *ngIf=\"!suppressLoading && (isLoading$ | async)\" [label]=\"loadingLabel\"></vl-loader>\n", styles: [":host{display:block}div{height:100%}\n"], components: [{ type: i5.LoaderComponent, selector: "vl-loader", inputs: ["label", "overlayVisible"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i7.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
1703
+ FederatedComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FederatedComponent, selector: "veloce-host-federated", inputs: { remoteEntry: "remoteEntry", remoteName: "remoteName", exposedModule: "exposedModule", data: "data", options: "options" }, viewQueries: [{ propertyName: "moduleHostRef", first: true, predicate: ["moduleHost"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div #moduleHost></div>\n\n<vl-loader *ngIf=\"!suppressLoading && (isLoading$ | async)\" [label]=\"loadingLabel\"></vl-loader>\n", styles: [":host{display:block}div{height:100%}\n"], components: [{ type: i1.LoaderComponent, selector: "vl-loader", inputs: ["label", "overlayVisible"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i7.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
1701
1704
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FederatedComponent, decorators: [{
1702
1705
  type: Component,
1703
1706
  args: [{
@@ -1741,10 +1744,14 @@ class CompilationService {
1741
1744
  this.compiler = compiler;
1742
1745
  }
1743
1746
  compileUIDefinition$(uiDefinition) {
1744
- this.uiDefinitionMeta = omit(uiDefinition, 'children');
1745
1747
  return of([]).pipe(switchMap(() => {
1746
- const metadata = uiDefinition.children.map(element => elementToMetadata(element));
1747
- this.elementsResolver = new ElementsResolver(uiDefinition, metadata);
1748
+ const { children, pages, components } = uiDefinition, uiDefinitionMeta = __rest(uiDefinition, ["children", "pages", "components"]);
1749
+ this.uiDefinitionMeta = uiDefinitionMeta;
1750
+ const elements = [...(children !== null && children !== void 0 ? children : []), ...(pages !== null && pages !== void 0 ? pages : [])];
1751
+ const sharedElements = components !== null && components !== void 0 ? components : [];
1752
+ const metadata = elements.map(element => elementToMetadata(element));
1753
+ const sharedMetadata = sharedElements.map(element => elementToMetadata(element));
1754
+ this.elementsResolver = new ElementsResolver(uiDefinition, metadata, sharedMetadata);
1748
1755
  const module = this.getModule(this.elementsResolver.getNgComponents());
1749
1756
  return combineLatest([
1750
1757
  from(this.compiler.compileModuleAndAllComponentsAsync(module)),
@@ -1838,9 +1845,68 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
1838
1845
  }]
1839
1846
  }] });
1840
1847
 
1848
+ const migrations = {
1849
+ 2: () => {
1850
+ throw 'Migration from Legacy UI definition is not possible';
1851
+ },
1852
+ 3: uiDef => {
1853
+ var _a;
1854
+ const children = (_a = uiDef.children) !== null && _a !== void 0 ? _a : [];
1855
+ return Object.assign(Object.assign({}, uiDef), { children: undefined, pages: children, version: 3 });
1856
+ },
1857
+ };
1858
+
1859
+ class MigrationsService {
1860
+ constructor(toastService) {
1861
+ this.toastService = toastService;
1862
+ }
1863
+ migrateUIDefinition(uiDef) {
1864
+ const currentVersion = uiDef.version;
1865
+ const targetVersion = UI_DEFINITION_VERSION;
1866
+ const migrateVersions = Object.keys(migrations)
1867
+ .reduce((acc, version) => {
1868
+ const v = Number(version);
1869
+ if (v > currentVersion && v <= targetVersion) {
1870
+ acc.push(v);
1871
+ }
1872
+ return acc;
1873
+ }, [])
1874
+ .sort();
1875
+ try {
1876
+ let result = cloneDeep(uiDef);
1877
+ for (const version of migrateVersions) {
1878
+ result = migrations[version](result);
1879
+ }
1880
+ return result;
1881
+ }
1882
+ catch (e) {
1883
+ this.toastService.add({ summary: String(e), severity: ToastType.error });
1884
+ return;
1885
+ }
1886
+ }
1887
+ }
1888
+ MigrationsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MigrationsService, deps: [{ token: i1.ToastService }], target: i0.ɵɵFactoryTarget.Injectable });
1889
+ MigrationsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MigrationsService, providedIn: 'root' });
1890
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MigrationsService, decorators: [{
1891
+ type: Injectable,
1892
+ args: [{ providedIn: 'root' }]
1893
+ }], ctorParameters: function () { return [{ type: i1.ToastService }]; } });
1894
+
1895
+ class MigrationsModule {
1896
+ }
1897
+ MigrationsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MigrationsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
1898
+ MigrationsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MigrationsModule });
1899
+ MigrationsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MigrationsModule, providers: [MigrationsService] });
1900
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: MigrationsModule, decorators: [{
1901
+ type: NgModule,
1902
+ args: [{
1903
+ providers: [MigrationsService],
1904
+ }]
1905
+ }] });
1906
+
1841
1907
  /**
1842
1908
  * Generated bundle index. Do not edit.
1843
1909
  */
1844
1910
 
1845
- export { ApplyProductConfigurationAction, CloseDocGenAction, ConfigureProductAction, DEFAULT_PLUGINS_TOKEN, ELEMENT_CONFIG, ELEMENT_METADATA, ElementComponent, ElementDefinition, ElementsResolver, FlowAction, IntegrationState, LauncherModule, NavigateBackAction, NavigateToCatalogAction, OpenDocGenAction, PreviewComponent, PreviewModule, RemoteApplyAction, RemoteCancelAction, RuntimeEditorService, RuntimeModule, SHARED_ELEMENT_METADATA, SetDefaultMetrics, SwitchObjectAction, TemplatesService, UI_DEFINITION_METADATA, UiBuildError, VENDOR_MAP, doesElementSupportIO, elementToMetadata, extendElementMetadata, extractElementMetadata, findElementByModule, findElementByPath, flattenElements, getAbsolutePath, getElementConfig, getElementUniqueName, insertElement, isSharedElement, isValidScript, metadataToElement, normalizeElementMetadata, parseBoundPath, parsePath, removeElement, stringifyElementMetadata };
1911
+ export { ApplyProductConfigurationAction, CloseDocGenAction, ConfigureProductAction, DEFAULT_PLUGINS_TOKEN, ELEMENT_CONFIG, ELEMENT_METADATA, ElementComponent, ElementDefinition, ElementsResolver, FlowAction, IntegrationState, LauncherModule, MigrationsModule, MigrationsService, NavigateBackAction, NavigateToCatalogAction, OpenDocGenAction, PreviewComponent, PreviewModule, RemoteApplyAction, RemoteCancelAction, RuntimeEditorService, RuntimeModule, SHARED_ELEMENT_METADATA, SetDefaultMetrics, SwitchObjectAction, TemplatesService, UI_DEFINITION_METADATA, UiBuildError, VENDOR_MAP, doesElementSupportIO, elementToMetadata, extendElementMetadata, extractElementMetadata, findElementByModule, findElementByPath, flattenElements, getAbsolutePath, getElementConfig, getElementUniqueName, insertElement, isSharedElement, isValidScript, metadataToElement, normalizeElementMetadata, parseBoundPath, parsePath, removeElement, stringifyElementMetadata };
1846
1912
  //# sourceMappingURL=veloceapps-sdk-cms.js.map