@veloceapps/sdk 7.0.1-1 → 7.0.1-2
Sign up to get free protection for your applications and to get access to all the features.
- package/cms/components/element-children/element-children.module.d.ts +5 -4
- package/cms/components/element-renderer/element-renderer.component.d.ts +1 -1
- package/cms/directives/custom-template.directive.d.ts +6 -1
- package/cms/modules/federated/federated.component.d.ts +1 -1
- package/cms/modules/runtime/services/compilation.service.d.ts +4 -4
- package/cms/modules/runtime/services/runtime.service.d.ts +4 -4
- package/cms/modules/runtime/types/compilation.types.d.ts +4 -2
- package/cms/utils/elements-resolver.d.ts +2 -1
- package/esm2020/cms/components/element-children/element-children.component.mjs +5 -4
- package/esm2020/cms/components/element-children/element-children.module.mjs +5 -4
- package/esm2020/cms/components/element-renderer/element-renderer.component.mjs +33 -23
- package/esm2020/cms/directives/custom-template.directive.mjs +14 -2
- package/esm2020/cms/modules/federated/federated.component.mjs +1 -2
- package/esm2020/cms/modules/runtime/services/compilation.service.mjs +36 -32
- package/esm2020/cms/modules/runtime/services/runtime.service.mjs +18 -12
- package/esm2020/cms/modules/runtime/types/compilation.types.mjs +1 -1
- package/esm2020/cms/utils/elements-resolver.mjs +5 -2
- package/fesm2015/veloceapps-sdk-cms.mjs +91 -66
- package/fesm2015/veloceapps-sdk-cms.mjs.map +1 -1
- package/fesm2020/veloceapps-sdk-cms.mjs +96 -63
- package/fesm2020/veloceapps-sdk-cms.mjs.map +1 -1
- package/package.json +2 -2
@@ -2,23 +2,23 @@ import { __decorate } 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
|
-
import {
|
5
|
+
import { Injectable, Injector, NgModule, createNgModule } from '@angular/core';
|
6
6
|
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
7
7
|
import { DndModule } from 'ngx-drag-drop';
|
8
|
-
import {
|
9
|
-
import {
|
10
|
-
import {
|
11
|
-
import {
|
12
|
-
import {
|
8
|
+
import { map, of } from 'rxjs';
|
9
|
+
import { ElementChildrenModule } from '../../../components/element-children/element-children.module';
|
10
|
+
import { ElementDropHandleModule } from '../../../components/element-drop-handle/element-drop-handle.module';
|
11
|
+
import { ElementRendererModule } from '../../../components/element-renderer/element-renderer.module';
|
12
|
+
import { CustomTemplateDirectiveModule } from '../../../directives/custom-template.directive';
|
13
13
|
import { ElementsResolver, elementToMetadata } from '../../../utils';
|
14
14
|
import { FederatedModule } from '../../federated/federated.module';
|
15
15
|
import * as i0 from "@angular/core";
|
16
16
|
export class CompilationService {
|
17
|
-
constructor(
|
18
|
-
this.
|
17
|
+
constructor(injector) {
|
18
|
+
this.injector = injector;
|
19
19
|
}
|
20
20
|
compileUIDefinition$(uiDefinition) {
|
21
|
-
return of([]).pipe(
|
21
|
+
return of([]).pipe(map(() => {
|
22
22
|
const { children, pages, components, ...uiDefinitionMeta } = uiDefinition;
|
23
23
|
this.uiDefinitionMeta = uiDefinitionMeta;
|
24
24
|
const elements = [...(children ?? []), ...(pages ?? [])];
|
@@ -26,35 +26,35 @@ export class CompilationService {
|
|
26
26
|
const metadata = elements.map(element => elementToMetadata(element));
|
27
27
|
const sharedMetadata = sharedElements.map(element => elementToMetadata(element));
|
28
28
|
this.elementsResolver = new ElementsResolver(uiDefinition, metadata, sharedMetadata);
|
29
|
-
const
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
29
|
+
const componentTypes = this.elementsResolver.getNgComponents();
|
30
|
+
const module = this.getModule(componentTypes);
|
31
|
+
return {
|
32
|
+
moduleRef: createNgModule(module, this.injector),
|
33
|
+
elements: this.elementsResolver?.elements ?? [],
|
34
|
+
componentTypes,
|
35
|
+
};
|
36
|
+
}));
|
35
37
|
}
|
36
38
|
compileElement$(element) {
|
37
39
|
if (!this.uiDefinitionMeta) {
|
38
40
|
throw 'No UI Definition context';
|
39
41
|
}
|
40
|
-
return of(this.uiDefinitionMeta).pipe(
|
42
|
+
return of(this.uiDefinitionMeta).pipe(map(uiDefinition => {
|
41
43
|
const elementsResolver = this.elementsResolver ?? new ElementsResolver(uiDefinition, []);
|
42
44
|
elementsResolver.addElement(element);
|
43
|
-
const
|
44
|
-
|
45
|
-
|
45
|
+
const componentTypes = elementsResolver.getNgComponents();
|
46
|
+
const module = this.getModule(componentTypes);
|
47
|
+
return {
|
48
|
+
moduleRef: createNgModule(module, this.injector),
|
49
|
+
elements: this.elementsResolver?.elements ?? [],
|
50
|
+
componentTypes,
|
51
|
+
};
|
52
|
+
}));
|
46
53
|
}
|
47
|
-
|
48
|
-
modules.forEach(module => this.compiler.clearCacheFor(module));
|
54
|
+
clear() {
|
49
55
|
this.uiDefinitionMeta = undefined;
|
50
56
|
}
|
51
57
|
getModule(components) {
|
52
|
-
const staticComponents = [
|
53
|
-
ElementChildrenComponent,
|
54
|
-
ElementRendererComponent,
|
55
|
-
ElementDropHandleComponent,
|
56
|
-
CustomTemplateDirective,
|
57
|
-
];
|
58
58
|
let DynamicModule = class DynamicModule {
|
59
59
|
};
|
60
60
|
DynamicModule = __decorate([
|
@@ -63,21 +63,25 @@ export class CompilationService {
|
|
63
63
|
CommonModule,
|
64
64
|
FormsModule,
|
65
65
|
ReactiveFormsModule,
|
66
|
-
FederatedModule,
|
67
66
|
DragDropModule,
|
68
67
|
DndModule,
|
69
68
|
ScrollingModule,
|
69
|
+
ElementChildrenModule,
|
70
|
+
ElementRendererModule,
|
71
|
+
ElementDropHandleModule,
|
72
|
+
CustomTemplateDirectiveModule,
|
73
|
+
FederatedModule,
|
70
74
|
],
|
71
|
-
declarations:
|
75
|
+
declarations: Object.values(components),
|
72
76
|
jit: true,
|
73
77
|
})
|
74
78
|
], DynamicModule);
|
75
79
|
return DynamicModule;
|
76
80
|
}
|
77
81
|
}
|
78
|
-
CompilationService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: CompilationService, deps: [{ token: i0.
|
82
|
+
CompilationService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: CompilationService, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable });
|
79
83
|
CompilationService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: CompilationService });
|
80
84
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: CompilationService, decorators: [{
|
81
85
|
type: Injectable
|
82
|
-
}], ctorParameters: function () { return [{ type: i0.
|
83
|
-
//# sourceMappingURL=data:application/json;base64,
|
86
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }]; } });
|
87
|
+
//# 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 { Injectable, Injector, NgModule, Type, createNgModule } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { UIDefinition, UIDefinitionMetadata } from '@veloceapps/sdk/core';\nimport { DndModule } from 'ngx-drag-drop';\nimport { Observable, map, of } from 'rxjs';\nimport { ElementChildrenModule } from '../../../components/element-children/element-children.module';\nimport { ElementDropHandleModule } from '../../../components/element-drop-handle/element-drop-handle.module';\nimport { ElementRendererModule } from '../../../components/element-renderer/element-renderer.module';\nimport { CustomTemplateDirectiveModule } from '../../../directives/custom-template.directive';\nimport { Entity } from '../../../engine/models/entity';\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 injector: Injector) {}\n\n  public compileUIDefinition$(uiDefinition: UIDefinition): Observable<CompilationResult> {\n    return of([]).pipe(\n      map(() => {\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 componentTypes = this.elementsResolver.getNgComponents();\n        const module = this.getModule(componentTypes);\n\n        return {\n          moduleRef: createNgModule(module, this.injector),\n          elements: this.elementsResolver?.elements ?? [],\n          componentTypes,\n        };\n      }),\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      map(uiDefinition => {\n        const elementsResolver = this.elementsResolver ?? new ElementsResolver(uiDefinition, []);\n        elementsResolver.addElement(element);\n        const componentTypes = elementsResolver.getNgComponents();\n        const module = this.getModule(componentTypes);\n\n        return {\n          moduleRef: createNgModule(module, this.injector),\n          elements: this.elementsResolver?.elements ?? [],\n          componentTypes,\n        };\n      }),\n    );\n  }\n\n  public clear(): void {\n    this.uiDefinitionMeta = undefined;\n  }\n\n  private getModule(components: Record<string, Type<Entity>>): Type<NgModule> {\n    @NgModule({\n      imports: [\n        CommonModule,\n        FormsModule,\n        ReactiveFormsModule,\n        DragDropModule,\n        DndModule,\n        ScrollingModule,\n        ElementChildrenModule,\n        ElementRendererModule,\n        ElementDropHandleModule,\n        CustomTemplateDirectiveModule,\n        FederatedModule,\n      ],\n      declarations: Object.values(components),\n      jit: true,\n    })\n    class DynamicModule {}\n\n    return DynamicModule;\n  }\n}\n"]}
|
@@ -1,14 +1,14 @@
|
|
1
1
|
import { Injectable, Injector } from '@angular/core';
|
2
2
|
import { applyPatch } from 'rfc6902';
|
3
|
-
import { BehaviorSubject, distinctUntilChanged, map, of, startWith,
|
3
|
+
import { BehaviorSubject, Subject, distinctUntilChanged, map, of, startWith, switchMap, tap } from 'rxjs';
|
4
4
|
import { findElementByPath } from '../../../utils/ui-definition.utils';
|
5
5
|
import { CMS_COMPILATION_SERVICE } from '../tokens';
|
6
6
|
import * as i0 from "@angular/core";
|
7
7
|
export class RuntimeService {
|
8
8
|
constructor(injector) {
|
9
9
|
this.injector = injector;
|
10
|
-
this.
|
11
|
-
this.
|
10
|
+
this.moduleRefs = [];
|
11
|
+
this.componentTypes = {};
|
12
12
|
this.applicationTree = [];
|
13
13
|
this.isInitialized$ = new BehaviorSubject(false);
|
14
14
|
this.updated$ = new Subject();
|
@@ -21,7 +21,11 @@ export class RuntimeService {
|
|
21
21
|
}
|
22
22
|
return this.compilationService.compileUIDefinition$(uiDefinition).pipe(map(result => {
|
23
23
|
this.applicationTree = result.elements;
|
24
|
-
this.
|
24
|
+
this.componentTypes = {
|
25
|
+
...this.componentTypes,
|
26
|
+
...result.componentTypes,
|
27
|
+
};
|
28
|
+
this.moduleRefs.push(result.moduleRef);
|
25
29
|
return result.elements;
|
26
30
|
}), tap(() => this.isInitialized$.next(true)));
|
27
31
|
}
|
@@ -47,28 +51,30 @@ export class RuntimeService {
|
|
47
51
|
return this.updated$.pipe(startWith(undefined), map(() => findElementByPath(this.applicationTree, path)), distinctUntilChanged());
|
48
52
|
}
|
49
53
|
clear() {
|
50
|
-
this.compilationService.
|
51
|
-
this.
|
54
|
+
this.compilationService.clear();
|
55
|
+
this.moduleRefs.forEach(m => m.destroy());
|
56
|
+
this.moduleRefs = [];
|
52
57
|
this.applicationTree = [];
|
53
|
-
this.
|
58
|
+
this.componentTypes = {};
|
54
59
|
this.isInitialized$.next(false);
|
55
60
|
}
|
56
61
|
addElement$(operation) {
|
57
62
|
return this.compilationService.compileElement$(operation.value).pipe(map(result => {
|
58
|
-
this.
|
63
|
+
this.componentTypes = {
|
64
|
+
...this.componentTypes,
|
65
|
+
...result.componentTypes,
|
66
|
+
};
|
67
|
+
this.moduleRefs.push(result.moduleRef);
|
59
68
|
applyPatch(this.applicationTree, [{ ...operation, value: result.elements[0] }]);
|
60
69
|
}));
|
61
70
|
}
|
62
71
|
deleteElement(operation) {
|
63
72
|
applyPatch(this.applicationTree, [operation]);
|
64
73
|
}
|
65
|
-
addComponentFactories(list) {
|
66
|
-
list.forEach(item => (this.componentFactories[item.componentType.path] = item));
|
67
|
-
}
|
68
74
|
}
|
69
75
|
RuntimeService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: RuntimeService, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable });
|
70
76
|
RuntimeService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: RuntimeService });
|
71
77
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: RuntimeService, decorators: [{
|
72
78
|
type: Injectable
|
73
79
|
}], ctorParameters: function () { return [{ type: i0.Injector }]; } });
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
80
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runtime.service.js","sourceRoot":"","sources":["../../../../../../../../libs/sdk/cms/modules/runtime/services/runtime.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector, NgModule, NgModuleRef, Type } from '@angular/core';\nimport { UIDefinition } from '@veloceapps/sdk/core';\nimport { Patch, applyPatch } from 'rfc6902';\nimport { AddOperation, RemoveOperation } from 'rfc6902/diff';\nimport { BehaviorSubject, Observable, Subject, distinctUntilChanged, map, of, startWith, switchMap, tap } from 'rxjs';\nimport { CMSPreviewConfig } from '../../../components/preview/preview.types';\nimport { Entity } from '../../../engine/models/entity';\nimport { ElementMetadata } from '../../../types';\nimport { findElementByPath } from '../../../utils/ui-definition.utils';\nimport { CMS_COMPILATION_SERVICE } from '../tokens';\nimport type { CompilationService } from './compilation.service';\n\n@Injectable()\nexport class RuntimeService {\n  public moduleRefs: NgModuleRef<NgModule>[] = [];\n  public componentTypes: Record<string, Type<Entity>> = {};\n  public applicationTree: ElementMetadata[] = [];\n  public config?: CMSPreviewConfig;\n  public isInitialized$ = new BehaviorSubject(false);\n  public updated$ = new Subject<void>();\n\n  private compilationService: CompilationService;\n\n  constructor(private injector: Injector) {\n    this.compilationService = this.injector.get(CMS_COMPILATION_SERVICE);\n  }\n\n  public initialize$(uiDefinition?: UIDefinition, config?: CMSPreviewConfig): Observable<ElementMetadata[]> {\n    this.config = config;\n\n    if (!uiDefinition) {\n      return of([]);\n    }\n\n    return this.compilationService.compileUIDefinition$(uiDefinition).pipe(\n      map(result => {\n        this.applicationTree = result.elements;\n        this.componentTypes = {\n          ...this.componentTypes,\n          ...result.componentTypes,\n        };\n        this.moduleRefs.push(result.moduleRef);\n        return result.elements;\n      }),\n      tap(() => this.isInitialized$.next(true)),\n    );\n  }\n\n  public applyPatch$(patch: Patch): Observable<void> {\n    let observable$: Observable<void> = of(undefined);\n\n    patch.forEach(operation => {\n      switch (operation.op) {\n        case 'add': {\n          observable$ = observable$.pipe(switchMap(() => this.addElement$(operation)));\n          break;\n        }\n        case 'remove': {\n          observable$ = observable$.pipe(map(() => this.deleteElement(operation)));\n          break;\n        }\n        default:\n          observable$ = of();\n      }\n    });\n\n    return observable$.pipe(tap(() => this.updated$.next()));\n  }\n\n  public getCompiledElement$(path: string): Observable<ElementMetadata | undefined> {\n    return this.updated$.pipe(\n      startWith(undefined),\n      map(() => findElementByPath(this.applicationTree, path)),\n      distinctUntilChanged(),\n    );\n  }\n\n  public clear(): void {\n    this.compilationService.clear();\n    this.moduleRefs.forEach(m => m.destroy());\n    this.moduleRefs = [];\n    this.applicationTree = [];\n    this.componentTypes = {};\n    this.isInitialized$.next(false);\n  }\n\n  private addElement$(operation: AddOperation): Observable<void> {\n    return this.compilationService.compileElement$(operation.value).pipe(\n      map(result => {\n        this.componentTypes = {\n          ...this.componentTypes,\n          ...result.componentTypes,\n        };\n        this.moduleRefs.push(result.moduleRef);\n        applyPatch(this.applicationTree, [{ ...operation, value: result.elements[0] }]);\n      }),\n    );\n  }\n\n  private deleteElement(operation: RemoveOperation): void {\n    applyPatch(this.applicationTree, [operation]);\n  }\n}\n"]}
|
@@ -1,2 +1,2 @@
|
|
1
1
|
export {};
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcGlsYXRpb24udHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3Nkay9jbXMvbW9kdWxlcy9ydW50aW1lL3R5cGVzL2NvbXBpbGF0aW9uLnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSwgTmdNb2R1bGVSZWYsIFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEVudGl0eSB9IGZyb20gJy4uLy4uLy4uL2VuZ2luZS9tb2RlbHMvZW50aXR5JztcbmltcG9ydCB7IEVsZW1lbnRNZXRhZGF0YSB9IGZyb20gJy4uLy4uLy4uL3R5cGVzL2NvbW1vbi50eXBlcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29tcGlsYXRpb25SZXN1bHQge1xuICBlbGVtZW50czogRWxlbWVudE1ldGFkYXRhW107XG4gIG1vZHVsZVJlZjogTmdNb2R1bGVSZWY8TmdNb2R1bGU+O1xuICBjb21wb25lbnRUeXBlczogUmVjb3JkPHN0cmluZywgVHlwZTxFbnRpdHk+Pjtcbn1cbiJdfQ==
|
@@ -29,7 +29,10 @@ export class ElementsResolver {
|
|
29
29
|
this.renderableElements = this.getRenderableElements(this.elements);
|
30
30
|
}
|
31
31
|
getNgComponents() {
|
32
|
-
return this.renderableElements.
|
32
|
+
return this.renderableElements.filter(isDefined).reduce((trunk, el) => ({
|
33
|
+
...trunk,
|
34
|
+
[el.path]: this.resolveElement(el),
|
35
|
+
}), {});
|
33
36
|
}
|
34
37
|
transpile(el) {
|
35
38
|
if (!el.script) {
|
@@ -186,4 +189,4 @@ export class ElementsResolver {
|
|
186
189
|
return result;
|
187
190
|
}
|
188
191
|
}
|
189
|
-
//# 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 { LAYOUT } from '../cms.layouts';\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    let styles = !config.suppressStyles ? element.styles ?? '' : '';\n\n    const layout = element.layout && LAYOUT[element.layout];\n    if (layout?.styles) {\n      styles += layout.styles;\n    }\n\n    return 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"]}
|
192
|
+
//# 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 { LAYOUT } from '../cms.layouts';\nimport { Entity } from '../engine/models/entity';\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(): Record<string, Type<Entity>> {\n    return this.renderableElements.filter(isDefined).reduce(\n      (trunk, el) => ({\n        ...trunk,\n        [el.path]: this.resolveElement(el),\n      }),\n      {},\n    );\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    let styles = !config.suppressStyles ? element.styles ?? '' : '';\n\n    const layout = element.layout && LAYOUT[element.layout];\n    if (layout?.styles) {\n      styles += layout.styles;\n    }\n\n    return 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<Entity> | 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"]}
|