@veloceapps/sdk 2.0.7 → 2.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/veloce-sdk-cms.umd.js +19 -4
- package/bundles/veloce-sdk-cms.umd.js.map +1 -1
- package/cms/components/preview/preview.component.d.ts +1 -0
- package/cms/types/common.types.d.ts +8 -4
- package/esm2015/cms/cms.elements.js +2 -1
- package/esm2015/cms/components/preview/preview.component.js +12 -2
- package/esm2015/cms/types/common.types.js +1 -1
- package/esm2015/cms/utils/element.utils.js +6 -2
- package/esm2015/cms/utils/elements-resolver.js +3 -3
- package/fesm2015/veloce-sdk-cms.js +19 -4
- package/fesm2015/veloce-sdk-cms.js.map +1 -1
- package/package.json +1 -1
|
@@ -25,6 +25,7 @@ export declare class PreviewComponent implements OnInit, OnDestroy {
|
|
|
25
25
|
ngOnInit(): void;
|
|
26
26
|
ngOnDestroy(): void;
|
|
27
27
|
private initializeConfiguration$;
|
|
28
|
+
private elementToMetadataSafe;
|
|
28
29
|
private startPreview;
|
|
29
30
|
static ɵfac: i0.ɵɵFactoryDeclaration<PreviewComponent, never>;
|
|
30
31
|
static ɵcmp: i0.ɵɵComponentDeclaration<PreviewComponent, "vl-cms-preview", never, { "modelId": "modelId"; "uiDefinition": "uiDefinition"; }, {}, never, never>;
|
|
@@ -29,6 +29,12 @@ export interface UIElementModel {
|
|
|
29
29
|
export interface ElementDefaultMetadata {
|
|
30
30
|
name: string;
|
|
31
31
|
type: ELEMENT_TYPE;
|
|
32
|
+
/**
|
|
33
|
+
* Make component shared
|
|
34
|
+
*
|
|
35
|
+
* Used only when `type !== REFERENCE`
|
|
36
|
+
*/
|
|
37
|
+
isShared?: boolean;
|
|
32
38
|
/**
|
|
33
39
|
* Element module name. Module is used for quick access from other elements.
|
|
34
40
|
*
|
|
@@ -79,11 +85,9 @@ export interface ElementDefaultMetadata {
|
|
|
79
85
|
outputs?: Dictionary<string | null>;
|
|
80
86
|
model?: UIElementModel;
|
|
81
87
|
/**
|
|
82
|
-
*
|
|
83
|
-
* When `type === REFERENCE`, then the value defines which shared element to use as reference.
|
|
88
|
+
* Defines a shared component name to use as a reference
|
|
84
89
|
*
|
|
85
|
-
*
|
|
86
|
-
* - `{ type: 'REFERENCE', reference: 'Button' }` - this element uses Button element as reference
|
|
90
|
+
* Used only when `type === REFERENCE`
|
|
87
91
|
*/
|
|
88
92
|
reference?: string;
|
|
89
93
|
}
|
|
@@ -19,6 +19,7 @@ export const CONFIG = {
|
|
|
19
19
|
REFERENCE: {
|
|
20
20
|
component: ElementComponent,
|
|
21
21
|
plugins: [IOPlugin],
|
|
22
|
+
suppressTemplate: true,
|
|
22
23
|
},
|
|
23
24
|
};
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY21zLmVsZW1lbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9zZGsvY21zL2Ntcy5lbGVtZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNsRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFHL0MsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUE2QztJQUM5RCxNQUFNLEVBQUU7UUFDTixTQUFTLEVBQUUsZ0JBQWdCO1FBQzNCLE9BQU8sRUFBRSxDQUFDLFFBQVEsQ0FBQztLQUNwQjtJQUNELFNBQVMsRUFBRTtRQUNULFNBQVMsRUFBRSxnQkFBZ0I7UUFDM0IsZUFBZSxFQUFFLHVDQUF1QztRQUN4RCxPQUFPLEVBQUUsRUFBRTtLQUNaO0lBQ0QsT0FBTyxFQUFFO1FBQ1AsU0FBUyxFQUFFLGdCQUFnQjtRQUMzQixPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUM7UUFDbkIsZ0JBQWdCLEVBQUUsSUFBSTtRQUN0QixjQUFjLEVBQUUsSUFBSTtLQUNyQjtJQUNELFNBQVMsRUFBRTtRQUNULFNBQVMsRUFBRSxnQkFBZ0I7UUFDM0IsT0FBTyxFQUFFLENBQUMsUUFBUSxDQUFDO1FBQ25CLGdCQUFnQixFQUFFLElBQUk7S0FDdkI7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWxlbWVudENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9lbGVtZW50LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJT1BsdWdpbiB9IGZyb20gJy4vcGx1Z2lucy9pby5wbHVnaW4nO1xuaW1wb3J0IHsgRWxlbWVudENvbmZpZywgRUxFTUVOVF9UWVBFIH0gZnJvbSAnLi90eXBlcy9jb21tb24udHlwZXMnO1xuXG5leHBvcnQgY29uc3QgQ09ORklHOiB7IFtrZXkgaW4gRUxFTUVOVF9UWVBFXTogRWxlbWVudENvbmZpZyB9ID0ge1xuICBDVVNUT006IHtcbiAgICBjb21wb25lbnQ6IEVsZW1lbnRDb21wb25lbnQsXG4gICAgcGx1Z2luczogW0lPUGx1Z2luXSxcbiAgfSxcbiAgQ09OVEFJTkVSOiB7XG4gICAgY29tcG9uZW50OiBFbGVtZW50Q29tcG9uZW50LFxuICAgIGRlZmF1bHRUZW1wbGF0ZTogJzxlbGVtZW50LWNoaWxkcmVuPjwvZWxlbWVudC1jaGlsZHJlbj4nLFxuICAgIHBsdWdpbnM6IFtdLFxuICB9LFxuICBTRVJWSUNFOiB7XG4gICAgY29tcG9uZW50OiBFbGVtZW50Q29tcG9uZW50LFxuICAgIHBsdWdpbnM6IFtJT1BsdWdpbl0sXG4gICAgc3VwcHJlc3NUZW1wbGF0ZTogdHJ1ZSxcbiAgICBzdXBwcmVzc1N0eWxlczogdHJ1ZSxcbiAgfSxcbiAgUkVGRVJFTkNFOiB7XG4gICAgY29tcG9uZW50OiBFbGVtZW50Q29tcG9uZW50LFxuICAgIHBsdWdpbnM6IFtJT1BsdWdpbl0sXG4gICAgc3VwcHJlc3NUZW1wbGF0ZTogdHJ1ZSxcbiAgfSxcbn07XG4iXX0=
|
|
@@ -46,12 +46,22 @@ export class PreviewComponent {
|
|
|
46
46
|
.initTestMode(this.modelId, uiDefinitionProps)
|
|
47
47
|
.pipe(switchMap(() => this.configurationService.configure()));
|
|
48
48
|
}
|
|
49
|
+
elementToMetadataSafe(elements) {
|
|
50
|
+
try {
|
|
51
|
+
return elements.map(element => elementToMetadata(element));
|
|
52
|
+
}
|
|
53
|
+
catch (e) {
|
|
54
|
+
console.error(e);
|
|
55
|
+
this.messageService.add({ severity: 'error', summary: String(e) });
|
|
56
|
+
return [];
|
|
57
|
+
}
|
|
58
|
+
}
|
|
49
59
|
startPreview() {
|
|
50
60
|
if (!this.uiDefinition) {
|
|
51
61
|
return;
|
|
52
62
|
}
|
|
53
63
|
const _a = this.uiDefinition, { children } = _a, uiDefinitionMeta = __rest(_a, ["children"]);
|
|
54
|
-
this.elements =
|
|
64
|
+
this.elements = this.elementToMetadataSafe(children);
|
|
55
65
|
const compilation$ = this.launcherService.compileModule(this.elements, uiDefinitionMeta);
|
|
56
66
|
forkJoin([compilation$, this.initializeConfiguration$()])
|
|
57
67
|
.pipe(tap(() => this.state$.next({ loading: false, failure: false })), catchError(error => {
|
|
@@ -81,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
81
91
|
}], uiDefinition: [{
|
|
82
92
|
type: Input
|
|
83
93
|
}] } });
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"preview.component.js","sourceRoot":"","sources":["../../../../../../../libs/sdk/cms/components/preview/preview.component.ts","../../../../../../../libs/sdk/cms/components/preview/preview.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport { MessageService } from 'primeng/api';\nimport { BehaviorSubject, catchError, forkJoin, Observable, of, Subject, switchMap, takeUntil, tap } from 'rxjs';\nimport { ConfigurationRuntimeService } from '../../modules/configuration/services/configuration-runtime.service';\nimport { ConfigurationService } from '../../modules/configuration/services/configuration.service';\nimport { IOProviderService } from '../../services/io-provider.service';\nimport { LauncherService } from '../../services/launcher.service';\nimport { TemplatesService } from '../../services/templates.service';\nimport { ElementMetadata } from '../../types/common.types';\nimport { UIDefinition, UIDefinitionProps, UIElement } from '../../types/ui-definition.types';\nimport { elementToMetadata } from '../../utils/element.utils';\n\ninterface State {\n  loading: boolean;\n  failure: boolean;\n}\n\n@Component({\n  selector: 'vl-cms-preview',\n  templateUrl: './preview.component.html',\n  styleUrls: ['./preview.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [IOProviderService, TemplatesService],\n})\nexport class PreviewComponent implements OnInit, OnDestroy {\n  @Input() modelId?: string;\n  @Input() uiDefinition?: UIDefinition;\n\n  public state$ = new BehaviorSubject<State>({ loading: true, failure: false });\n  public elements: ElementMetadata[] = [];\n\n  private destroy$ = new Subject<void>();\n\n  constructor(\n    private launcherService: LauncherService,\n    private configurationService: ConfigurationService,\n    private messageService: MessageService,\n    private runtimeService: ConfigurationRuntimeService,\n  ) {}\n\n  ngOnInit() {\n    this.startPreview();\n  }\n\n  ngOnDestroy() {\n    this.destroy$.next();\n    this.destroy$.complete();\n\n    this.configurationService.reset();\n  }\n\n  private initializeConfiguration$(): Observable<any> {\n    const isAlreadyInitialized = this.runtimeService.isInitialized;\n    if (!this.uiDefinition || this.uiDefinition.type !== 'CONFIGURATION' || isAlreadyInitialized) {\n      return of({});\n    }\n\n    if (!this.modelId) {\n      console.warn(`No modelId is given for uiDefinition with '${this.uiDefinition.type}' type`);\n      return of({});\n    }\n\n    // If still not initialized - init configuration in Test mode\n    const uiDefinitionProps: UIDefinitionProps = this.uiDefinition.properties ?? {};\n    return this.runtimeService\n      .initTestMode(this.modelId, uiDefinitionProps)\n      .pipe(switchMap(() => this.configurationService.configure()));\n  }\n\n  private elementToMetadataSafe(elements: UIElement[]): ElementMetadata[] {\n    try {\n      return elements.map(element => elementToMetadata(element));\n    } catch (e) {\n      console.error(e);\n      this.messageService.add({ severity: 'error', summary: String(e) });\n      return [];\n    }\n  }\n\n  private startPreview() {\n    if (!this.uiDefinition) {\n      return;\n    }\n\n    const { children, ...uiDefinitionMeta } = this.uiDefinition;\n    this.elements = this.elementToMetadataSafe(children);\n\n    const compilation$ = this.launcherService.compileModule(this.elements, uiDefinitionMeta);\n\n    forkJoin([compilation$, this.initializeConfiguration$()])\n      .pipe(\n        tap(() => this.state$.next({ loading: false, failure: false })),\n        catchError(error => {\n          this.messageService.add({\n            severity: 'error',\n            summary: error,\n          });\n          this.state$.next({ loading: false, failure: true });\n          return of();\n        }),\n        takeUntil(this.destroy$),\n      )\n      .subscribe();\n  }\n}\n","<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"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9zZGsvY21zL3R5cGVzL2NvbW1vbi50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGljdGlvbmFyeSB9IGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQgeyBFbnRpdHkgfSBmcm9tICcuLi9lbmdpbmUvbW9kZWxzL2VudGl0eSc7XG5pbXBvcnQgeyBQbHVnaW4gfSBmcm9tICcuLi9lbmdpbmUvbW9kZWxzL3BsdWdpbic7XG5cbmV4cG9ydCB0eXBlIEVMRU1FTlRfVFlQRSA9ICdDVVNUT00nIHwgJ0NPTlRBSU5FUicgfCAnU0VSVklDRScgfCAnUkVGRVJFTkNFJztcblxuZXhwb3J0IGludGVyZmFjZSBFbGVtZW50Q29uZmlnIHtcbiAgY29tcG9uZW50OiB0eXBlb2YgRW50aXR5O1xuICBwbHVnaW5zPzogdHlwZW9mIFBsdWdpbltdO1xuICBkZWZhdWx0VGVtcGxhdGU/OiBzdHJpbmc7XG4gIHN1cHByZXNzVGVtcGxhdGU/
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9zZGsvY21zL3R5cGVzL2NvbW1vbi50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGljdGlvbmFyeSB9IGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQgeyBFbnRpdHkgfSBmcm9tICcuLi9lbmdpbmUvbW9kZWxzL2VudGl0eSc7XG5pbXBvcnQgeyBQbHVnaW4gfSBmcm9tICcuLi9lbmdpbmUvbW9kZWxzL3BsdWdpbic7XG5cbmV4cG9ydCB0eXBlIEVMRU1FTlRfVFlQRSA9ICdDVVNUT00nIHwgJ0NPTlRBSU5FUicgfCAnU0VSVklDRScgfCAnUkVGRVJFTkNFJztcblxuZXhwb3J0IGludGVyZmFjZSBFbGVtZW50Q29uZmlnIHtcbiAgY29tcG9uZW50OiB0eXBlb2YgRW50aXR5O1xuICBwbHVnaW5zPzogdHlwZW9mIFBsdWdpbltdO1xuICBkZWZhdWx0VGVtcGxhdGU/OiBzdHJpbmc7XG4gIHN1cHByZXNzVGVtcGxhdGU/OiBib29sZWFuO1xuICBzdXBwcmVzc1N0eWxlcz86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVUlFbGVtZW50TW9kZWwge1xuICAvKipcbiAgICogRGVmaW5lcyBhIHBhdGggZm9yIGFuIGVsZW1lbnQgbW9kZWwuXG4gICAqIEl0J3MgY29tYmluZWQgd2l0aCBhIHBhdGggdG8gYSB0YXJnZXQgZWxlbWVudCBhbmQgYW4gb3V0cHV0IHByb3BlcnR5IG5hbWUuXG4gICAqXG4gICAqIElmIHRhcmdldCB2YWx1ZSBpcyBhbiBBcnJheSwgdGhlbiB0aGUgZWxlbWVudCB3aWxsIGJlIHJlcGVhdGVkIGBuYCB0aW1lcyBhbmQgZWFjaCBpbnN0YW5jZSB3aWxsIGdldCBpdCdzIG93biB2YWx1ZS5cbiAgICpcbiAgICogRXhhbXBsZXM6XG4gICAqIC0gYFJvb3QvU2VydmljZXMvRGF0YVNlcnZpY2UvOnByb2R1Y3RzYFxuICAgKiAtIGBAU2VydmljZXMvRGF0YVNlcnZpY2UvOnByb2R1Y3RzYFxuICAgKi9cbiAgcGF0aD86IHN0cmluZztcbiAgLyoqXG4gICAqIFVzZWQgb25seSB3aGVuIGBVSURlZmluaXRpb25UeXBlID0gQ09ORklHVVJBVElPTmAuXG4gICAqL1xuICBsaW5lSXRlbT86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFbGVtZW50RGVmYXVsdE1ldGFkYXRhIHtcbiAgbmFtZTogc3RyaW5nO1xuICB0eXBlOiBFTEVNRU5UX1RZUEU7XG4gIC8qKlxuICAgKiBNYWtlIGNvbXBvbmVudCBzaGFyZWRcbiAgICpcbiAgICogVXNlZCBvbmx5IHdoZW4gYHR5cGUgIT09IFJFRkVSRU5DRWBcbiAgICovXG4gIGlzU2hhcmVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEVsZW1lbnQgbW9kdWxlIG5hbWUuIE1vZHVsZSBpcyB1c2VkIGZvciBxdWljayBhY2Nlc3MgZnJvbSBvdGhlciBlbGVtZW50cy5cbiAgICpcbiAgICogRm9yIGV4YW1wbGUgd2UgaGF2ZSBhIGBEYXRhU2VydmljZWAgZWxlbWVudCwgYW5kIHdlIHNheSBpdCdzIGRlY2xhcmVkIGluIGBTZXJ2aWNlc2AgbW9kdWxlLiBUaGVuIGl0IGNhbiBiZSBhY2Nlc3NlZCBpbiBvdGhlciBlbGVtZW50cyBgbW9kZWxgLCBgaW5wdXRzYCBvciBgb3V0cHV0c2AgcHJvcGVydGllcyB0aGlzIHdheTogYEBTZXJ2aWNlcy9EYXRhU2VydmljZWBcbiAgICpcbiAgICovXG4gIG1vZHVsZT86IHN0cmluZztcbiAgLyoqXG4gICAqIERlZmluZXMgaW5wdXRzIG9mIHRoZSBlbGVtZW50LiBBbiBvYmplY3Qgd2hlcmUgYGtleWAgaXMgdGhlIG5hbWUgb2YgdGhlIGlucHV0IGFuZCBgdmFsdWVgIGlzIHRhcmdldCBwYXRoXG4gICAqXG4gICAqIElmIGB2YWx1ZSA9PSBudWxsYCwgdGhlbiB0aGUgZWxlbWVudCBhY3RzIGxpa2UgYSB0YXJnZXQgLSB3ZSBleHBlY3Qgb3RoZXIgZWxlbWVudCB0byBjb25uZWN0IHRvIGl0LlxuICAgKlxuICAgKiBFeGFtcGxlczpcbiAgICpcbiAgICogMS4gYHByb2R1Y3RzOiAnUm9vdC9TZXJ2aWNlcy9EYXRhU2VydmljZSdgXG4gICAqIFRoZSBlbGVtZW50IHdpbGwgaGF2ZSBgcHJvZHVjdHNgIGlucHV0IHdoaWNoIHdpbGwgZ2V0IHRoZSBkYXRhIGZyb20gYHByb2R1Y3RzYCBvdXRwdXQgaW4gZGF0YXNlcnZpY2UgZWxlbWVudFxuICAgKlxuICAgKiAyLiBgcHJvZHVjdHNMaXN0OiAnUm9vdC9TZXJ2aWNlcy9EYXRhU2VydmljZS86cHJvZHVjdHMnYFxuICAgKiBUaGUgZWxlbWVudCB3aWxsIGhhdmUgYHByb2R1Y3RzTGlzdGAgaW5wdXQgd2hpY2ggd2lsbCBnZXQgdGhlIGRhdGEgZnJvbSBgcHJvZHVjdHNgIG91dHB1dCBpbiBkYXRhc2VydmljZSBlbGVtZW50XG4gICAqXG4gICAqIDMuIGBwcm9kdWN0c0xpc3Q6ICdAU2VydmljZXMvRGF0YVNlcnZpY2UvOnByb2R1Y3RzJ2BcbiAgICogVGhlIGVsZW1lbnQgd2lsbCBoYXZlIGBwcm9kdWN0c0xpc3RgIGlucHV0IHdoaWNoIHdpbGwgZ2V0IHRoZSBkYXRhIGZyb20gYHByb2R1Y3RzYCBvdXRwdXQgaW4gZGF0YXNlcnZpY2UgZWxlbWVudCB3aGljaCBpcyBkZWNsYXJlZCBpbiBgU2VydmljZXNgIG1vZHVsZVxuICAgKlxuICAgKiA0LiBgb25Qcm9kdWN0U2VsZWN0OiBudWxsYFxuICAgKiBUaGUgZWxlbWVudCB3aWxsIGhhdmUgYG9uUHJvZHVjdFNlbGVjdGAgaW5wdXQsIGFuZCB0aGUgc2NyaXB0IGNvdWxkIGhhdmUgYSBsb2dpYyB3aGljaCB3aWxsIGxpc3RlbiBvbiB0aGUgZXZlbnRzXG4gICAqXG4gICAqIFJlbGF0aXZlIHBhdGhzIGFsbG93ZWQ6XG4gICAqXG4gICAqIC0gYC4uYFxuICAgKiAtIGAuLi86cHJvZHVjdHNgXG4gICAqIC0gYC4uLy4uL0RhdGFTZXJ2aWNlLzpwcm9kdWN0c2BcbiAgICpcbiAgICovXG4gIGlucHV0cz86IERpY3Rpb25hcnk8c3RyaW5nIHwgbnVsbD47XG4gIC8qKlxuICAgKiBEZWZpbmVzIG91dHB1dHMgb2YgdGhlIGVsZW1lbnQuIEFuIG9iamVjdCB3aGVyZSBga2V5YCBpcyB0aGUgbmFtZSBvZiB0aGUgb3V0cHV0IGFuZCBgdmFsdWVgIGlzIHRhcmdldCBwYXRoXG4gICAqXG4gICAqIElmIGB2YWx1ZSA9PSBudWxsYCwgdGhlbiB0aGUgZWxlbWVudCBhY3RzIGxpa2UgYSB0YXJnZXQgLSB3ZSBleHBlY3Qgb3RoZXIgZWxlbWVudCB0byBjb25uZWN0IHRvIGl0LlxuICAgKlxuICAgKiBFeGFtcGxlczpcbiAgICpcbiAgICogMS4gYG9uUHJvZHVjdFNlbGVjdDogJ1Jvb3QvU2VydmljZXMvRGF0YVNlcnZpY2UvOmhhbmRsZVByb2R1Y3RTZWxlY3QnYFxuICAgKiBUaGUgZWxlbWVudCB3aWxsIGhhdmUgYG9uUHJvZHVjdFNlbGVjdGAgb3V0cHV0LCB3aGljaCB3aWxsIGVtaXQgZXZlbnRzIHRvIHRoZSBgZGF0YXNlcnZpY2VgIGVsZW1lbnQgYGhhbmRsZVByb2R1Y3RTZWxlY3RgIGlucHV0XG4gICAqXG4gICAqIDIuIGBvblByb2R1Y3RTZWxlY3Q6ICdAU2VydmljZXMvRGF0YVNlcnZpY2UvOmhhbmRsZVByb2R1Y3RTZWxlY3QnYFxuICAgKiBTYW1lIG91dHB1dCBidXQgYWNjZXNzaW5nIGRhdGFzZXJ2aWNlIGJ5IHRoZSBTZXJ2aWNlIG1vZHVsZVxuICAgKi9cbiAgb3V0cHV0cz86IERpY3Rpb25hcnk8c3RyaW5nIHwgbnVsbD47XG4gIG1vZGVsPzogVUlFbGVtZW50TW9kZWw7XG4gIC8qKlxuICAgKiBEZWZpbmVzIGEgc2hhcmVkIGNvbXBvbmVudCBuYW1lIHRvIHVzZSBhcyBhIHJlZmVyZW5jZVxuICAgKlxuICAgKiBVc2VkIG9ubHkgd2hlbiBgdHlwZSA9PT0gUkVGRVJFTkNFYFxuICAgKi9cbiAgcmVmZXJlbmNlPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVsZW1lbnRNZXRhZGF0YSBleHRlbmRzIEVsZW1lbnREZWZhdWx0TWV0YWRhdGEge1xuICBwYXRoPzogc3RyaW5nO1xuICBjaGlsZHJlbjogRWxlbWVudE1ldGFkYXRhW107XG4gIHRlbXBsYXRlPzogc3RyaW5nO1xuICBzdHlsZXM/OiBzdHJpbmc7XG4gIHNjcmlwdD86IHN0cmluZztcbiAgbWV0YWRhdGE/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRWxlbWVudFBhdGgge1xuICBzZWdtZW50czogc3RyaW5nW107XG4gIG1vZHVsZT86IHN0cmluZztcbiAgdmFyaWFibGU/OiBzdHJpbmc7XG59XG4iXX0=
|
|
@@ -9,7 +9,7 @@ export const elementToMetadata = (el, parentPath) => {
|
|
|
9
9
|
const styles = el.styles && window.atob(el.styles);
|
|
10
10
|
const exportedClassName = script && ((_a = EXPORTED_CLASS_REGEX.exec(script)) !== null && _a !== void 0 ? _a : [])[1];
|
|
11
11
|
if (!exportedClassName) {
|
|
12
|
-
|
|
12
|
+
throw new Error("Script doesn't have exported class");
|
|
13
13
|
}
|
|
14
14
|
const elementMetadata = extractElementMetadata(script || '');
|
|
15
15
|
const path = (parentPath ? parentPath + '/' : '') + elementMetadata.name;
|
|
@@ -19,6 +19,7 @@ export const elementToMetadata = (el, parentPath) => {
|
|
|
19
19
|
export const metadataToElement = (metadata) => {
|
|
20
20
|
const elMetadata = {
|
|
21
21
|
name: metadata.name,
|
|
22
|
+
isShared: metadata.isShared,
|
|
22
23
|
type: metadata.type,
|
|
23
24
|
model: metadata.model,
|
|
24
25
|
module: metadata.module,
|
|
@@ -27,6 +28,9 @@ export const metadataToElement = (metadata) => {
|
|
|
27
28
|
outputs: metadata.outputs,
|
|
28
29
|
children: metadata.children.map(({ name }) => name),
|
|
29
30
|
};
|
|
31
|
+
if (!metadata.script || !EXPORTED_CLASS_REGEX.test(metadata.script)) {
|
|
32
|
+
throw new Error(`'${metadata.name}' element script doesn't have exported class`);
|
|
33
|
+
}
|
|
30
34
|
const script = metadata.script &&
|
|
31
35
|
window.btoa(metadata.script.replace(EXPORTED_CLASS_REGEX, `@ElementDefinition(${JSON.stringify(elMetadata)}) export class Script`));
|
|
32
36
|
const template = metadata.template && window.btoa(metadata.template);
|
|
@@ -63,4 +67,4 @@ export const doesElementSupportIO = (type) => {
|
|
|
63
67
|
var _a, _b;
|
|
64
68
|
return (_b = (_a = getElementConfig(type).plugins) === null || _a === void 0 ? void 0 : _a.includes(IOPlugin)) !== null && _b !== void 0 ? _b : false;
|
|
65
69
|
};
|
|
66
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element.utils.js","sourceRoot":"","sources":["../../../../../../libs/sdk/cms/utils/element.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { CONFIG } from '../cms.elements';\nimport { IOPlugin } from '../plugins/io.plugin';\nimport { ElementConfig, ElementMetadata, ELEMENT_TYPE, UIElement, UIElementMetadata } from '../types';\n\nconst EXPORTED_CLASS_REGEX = /export class (\\S+)/;\nconst METADATA_DECORATOR_REGEX = /@ElementDefinition\\(([\\s\\S]+)\\)(\\n|.)*export class/g;\n\nexport const elementToMetadata = (el: UIElement, parentPath?: string): ElementMetadata => {\n  const script = el.script && window.atob(el.script);\n  const template = el.template && window.atob(el.template);\n  const styles = el.styles && window.atob(el.styles);\n\n  const exportedClassName = script && (EXPORTED_CLASS_REGEX.exec(script) ?? [])[1];\n\n  if (!exportedClassName) {\n    throw new Error(\"Script doesn't have exported class\");\n  }\n\n  const elementMetadata = extractElementMetadata(script || '');\n  const path = (parentPath ? parentPath + '/' : '') + elementMetadata.name;\n\n  return {\n    ...elementMetadata,\n    path,\n    script: script?.replace(METADATA_DECORATOR_REGEX, 'export class'),\n    template,\n    styles,\n    children: el.children.map(child => elementToMetadata(child, path)),\n  };\n};\n\nexport const metadataToElement = (metadata: ElementMetadata): UIElement => {\n  const elMetadata: UIElementMetadata = {\n    name: metadata.name,\n    isShared: metadata.isShared,\n    type: metadata.type,\n    model: metadata.model,\n    module: metadata.module,\n    reference: metadata.reference,\n    inputs: metadata.inputs,\n    outputs: metadata.outputs,\n    children: metadata.children.map(({ name }) => name),\n  };\n\n  if (!metadata.script || !EXPORTED_CLASS_REGEX.test(metadata.script)) {\n    throw new Error(`'${metadata.name}' element script doesn't have exported class`);\n  }\n\n  const script =\n    metadata.script &&\n    window.btoa(\n      metadata.script.replace(\n        EXPORTED_CLASS_REGEX,\n        `@ElementDefinition(${JSON.stringify(elMetadata)}) export class Script`,\n      ),\n    );\n  const template = metadata.template && window.btoa(metadata.template);\n  const styles = metadata.styles && window.btoa(metadata.styles);\n\n  return {\n    script,\n    template,\n    styles,\n    children: metadata.children.map(meta => metadataToElement(meta)),\n  };\n};\n\nexport const extractElementMetadata = (script: string): UIElementMetadata => {\n  const metadataString = (METADATA_DECORATOR_REGEX.exec(script) ?? [])[1];\n\n  // need to reset regex last index to prevent null result for next execution\n  METADATA_DECORATOR_REGEX.lastIndex = 0;\n\n  return eval(`(${metadataString})`);\n};\n\nexport const extendElementMetadata = (script: string, extend: Partial<UIElementMetadata>): string => {\n  const metadataString = (METADATA_DECORATOR_REGEX.exec(script) ?? [])[1];\n\n  // need to reset regex last index to prevent null result for next execution\n  METADATA_DECORATOR_REGEX.lastIndex = 0;\n\n  if (!metadataString) {\n    return script;\n  }\n\n  const updated = { ...eval(`(${metadataString})`), ...extend };\n  return script.replace(metadataString, JSON.stringify(updated));\n};\n\nexport const getElementConfig = (type: ELEMENT_TYPE): ElementConfig => {\n  return CONFIG[type];\n};\n\nexport const doesElementSupportIO = (type: ELEMENT_TYPE): boolean => {\n  return getElementConfig(type).plugins?.includes(IOPlugin) ?? false;\n};\n"]}
|
|
@@ -39,13 +39,13 @@ export class ElementsResolver {
|
|
|
39
39
|
return flatten(elements.map(el => [el, ...this.flattenElements(el.children)]));
|
|
40
40
|
}
|
|
41
41
|
isSharedElement(el) {
|
|
42
|
-
return Boolean(el.
|
|
42
|
+
return Boolean(el.isShared) && el.type !== 'REFERENCE';
|
|
43
43
|
}
|
|
44
44
|
getSharedElement(element) {
|
|
45
45
|
if (element.type !== 'REFERENCE') {
|
|
46
46
|
return;
|
|
47
47
|
}
|
|
48
|
-
return this.sharedElements.find(el => element.reference === el.
|
|
48
|
+
return this.sharedElements.find(el => element.reference === el.name);
|
|
49
49
|
}
|
|
50
50
|
resolveElementTemplate(element) {
|
|
51
51
|
const config = CONFIG[element.type];
|
|
@@ -102,4 +102,4 @@ export class ElementsResolver {
|
|
|
102
102
|
return this.renderableElements.map(el => this.resolveElement(el)).filter(Boolean);
|
|
103
103
|
}
|
|
104
104
|
}
|
|
105
|
-
//# 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 { flatten, 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} from '../injection-tokens';\nimport { ElementMetadata, UIDefinitionMetadata } from '../types';\n\nexport class ElementsResolver {\n  public readonly elements: ElementMetadata[];\n\n  private renderableElements: ElementMetadata[] = [];\n  private sharedElements: ElementMetadata[] = [];\n\n  constructor(private uiDef: UIDefinitionMetadata, elements: ElementMetadata[]) {\n    this.elements = this.transpileScripts(elements);\n\n    const flatElements = this.flattenElements(this.elements);\n\n    for (const el of flatElements) {\n      if (this.isSharedElement(el)) {\n        this.sharedElements.push(el);\n      } else {\n        this.renderableElements.push(el);\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.reference) && el.type !== 'REFERENCE';\n  }\n\n  private getSharedElement(element: ElementMetadata): ElementMetadata | undefined {\n    if (element.type !== 'REFERENCE') {\n      return;\n    }\n\n    return this.sharedElements.find(el => element.reference === el.reference);\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    const sharedElement = this.getSharedElement(sourceElement);\n    let finalElement: ElementMetadata;\n\n    if (sourceElement.type === 'REFERENCE') {\n      if (!sharedElement) {\n        console.warn(`Shared element \"${sourceElement.reference}\" not found`);\n        return;\n      }\n\n      finalElement = {\n        ...sourceElement,\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    }\n\n    finalElement.template = this.resolveElementTemplate(finalElement);\n    finalElement.styles = this.resolveElementStyles(finalElement);\n\n    return finalElement;\n  }\n\n  private resolveElement(sourceElement: ElementMetadata): Type<any> | undefined {\n    const element = this.processElementMetadata(sourceElement);\n    if (!element) {\n      return;\n    }\n\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 component: Component = {\n      selector: 'vl-element',\n      template: element.template,\n      ...(element.styles ? { styles: [element.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(sourceElement) },\n        { provide: ELEMENT_CONFIG, useValue: config },\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  public getNgComponents(): Type<any>[] {\n    return this.renderableElements.map(el => this.resolveElement(el)).filter(Boolean) as Type<any>[];\n  }\n}\n"]}
|
|
105
|
+
//# 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 { flatten, 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} from '../injection-tokens';\nimport { ElementMetadata, UIDefinitionMetadata } from '../types';\n\nexport class ElementsResolver {\n  public readonly elements: ElementMetadata[];\n\n  private renderableElements: ElementMetadata[] = [];\n  private sharedElements: ElementMetadata[] = [];\n\n  constructor(private uiDef: UIDefinitionMetadata, elements: ElementMetadata[]) {\n    this.elements = this.transpileScripts(elements);\n\n    const flatElements = this.flattenElements(this.elements);\n\n    for (const el of flatElements) {\n      if (this.isSharedElement(el)) {\n        this.sharedElements.push(el);\n      } else {\n        this.renderableElements.push(el);\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 getSharedElement(element: ElementMetadata): ElementMetadata | undefined {\n    if (element.type !== '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    const sharedElement = this.getSharedElement(sourceElement);\n    let finalElement: ElementMetadata;\n\n    if (sourceElement.type === 'REFERENCE') {\n      if (!sharedElement) {\n        console.warn(`Shared element \"${sourceElement.reference}\" not found`);\n        return;\n      }\n\n      finalElement = {\n        ...sourceElement,\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    }\n\n    finalElement.template = this.resolveElementTemplate(finalElement);\n    finalElement.styles = this.resolveElementStyles(finalElement);\n\n    return finalElement;\n  }\n\n  private resolveElement(sourceElement: ElementMetadata): Type<any> | undefined {\n    const element = this.processElementMetadata(sourceElement);\n    if (!element) {\n      return;\n    }\n\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 component: Component = {\n      selector: 'vl-element',\n      template: element.template,\n      ...(element.styles ? { styles: [element.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(sourceElement) },\n        { provide: ELEMENT_CONFIG, useValue: config },\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  public getNgComponents(): Type<any>[] {\n    return this.renderableElements.map(el => this.resolveElement(el)).filter(Boolean) as Type<any>[];\n  }\n}\n"]}
|
|
@@ -271,6 +271,7 @@ const CONFIG = {
|
|
|
271
271
|
REFERENCE: {
|
|
272
272
|
component: ElementComponent,
|
|
273
273
|
plugins: [IOPlugin],
|
|
274
|
+
suppressTemplate: true,
|
|
274
275
|
},
|
|
275
276
|
};
|
|
276
277
|
|
|
@@ -283,7 +284,7 @@ const elementToMetadata = (el, parentPath) => {
|
|
|
283
284
|
const styles = el.styles && window.atob(el.styles);
|
|
284
285
|
const exportedClassName = script && ((_a = EXPORTED_CLASS_REGEX.exec(script)) !== null && _a !== void 0 ? _a : [])[1];
|
|
285
286
|
if (!exportedClassName) {
|
|
286
|
-
|
|
287
|
+
throw new Error("Script doesn't have exported class");
|
|
287
288
|
}
|
|
288
289
|
const elementMetadata = extractElementMetadata(script || '');
|
|
289
290
|
const path = (parentPath ? parentPath + '/' : '') + elementMetadata.name;
|
|
@@ -293,6 +294,7 @@ const elementToMetadata = (el, parentPath) => {
|
|
|
293
294
|
const metadataToElement = (metadata) => {
|
|
294
295
|
const elMetadata = {
|
|
295
296
|
name: metadata.name,
|
|
297
|
+
isShared: metadata.isShared,
|
|
296
298
|
type: metadata.type,
|
|
297
299
|
model: metadata.model,
|
|
298
300
|
module: metadata.module,
|
|
@@ -301,6 +303,9 @@ const metadataToElement = (metadata) => {
|
|
|
301
303
|
outputs: metadata.outputs,
|
|
302
304
|
children: metadata.children.map(({ name }) => name),
|
|
303
305
|
};
|
|
306
|
+
if (!metadata.script || !EXPORTED_CLASS_REGEX.test(metadata.script)) {
|
|
307
|
+
throw new Error(`'${metadata.name}' element script doesn't have exported class`);
|
|
308
|
+
}
|
|
304
309
|
const script = metadata.script &&
|
|
305
310
|
window.btoa(metadata.script.replace(EXPORTED_CLASS_REGEX, `@ElementDefinition(${JSON.stringify(elMetadata)}) export class Script`));
|
|
306
311
|
const template = metadata.template && window.btoa(metadata.template);
|
|
@@ -1110,13 +1115,13 @@ class ElementsResolver {
|
|
|
1110
1115
|
return flatten(elements.map(el => [el, ...this.flattenElements(el.children)]));
|
|
1111
1116
|
}
|
|
1112
1117
|
isSharedElement(el) {
|
|
1113
|
-
return Boolean(el.
|
|
1118
|
+
return Boolean(el.isShared) && el.type !== 'REFERENCE';
|
|
1114
1119
|
}
|
|
1115
1120
|
getSharedElement(element) {
|
|
1116
1121
|
if (element.type !== 'REFERENCE') {
|
|
1117
1122
|
return;
|
|
1118
1123
|
}
|
|
1119
|
-
return this.sharedElements.find(el => element.reference === el.
|
|
1124
|
+
return this.sharedElements.find(el => element.reference === el.name);
|
|
1120
1125
|
}
|
|
1121
1126
|
resolveElementTemplate(element) {
|
|
1122
1127
|
const config = CONFIG[element.type];
|
|
@@ -1379,12 +1384,22 @@ class PreviewComponent {
|
|
|
1379
1384
|
.initTestMode(this.modelId, uiDefinitionProps)
|
|
1380
1385
|
.pipe(switchMap(() => this.configurationService.configure()));
|
|
1381
1386
|
}
|
|
1387
|
+
elementToMetadataSafe(elements) {
|
|
1388
|
+
try {
|
|
1389
|
+
return elements.map(element => elementToMetadata(element));
|
|
1390
|
+
}
|
|
1391
|
+
catch (e) {
|
|
1392
|
+
console.error(e);
|
|
1393
|
+
this.messageService.add({ severity: 'error', summary: String(e) });
|
|
1394
|
+
return [];
|
|
1395
|
+
}
|
|
1396
|
+
}
|
|
1382
1397
|
startPreview() {
|
|
1383
1398
|
if (!this.uiDefinition) {
|
|
1384
1399
|
return;
|
|
1385
1400
|
}
|
|
1386
1401
|
const _a = this.uiDefinition, { children } = _a, uiDefinitionMeta = __rest(_a, ["children"]);
|
|
1387
|
-
this.elements =
|
|
1402
|
+
this.elements = this.elementToMetadataSafe(children);
|
|
1388
1403
|
const compilation$ = this.launcherService.compileModule(this.elements, uiDefinitionMeta);
|
|
1389
1404
|
forkJoin([compilation$, this.initializeConfiguration$()])
|
|
1390
1405
|
.pipe(tap$1(() => this.state$.next({ loading: false, failure: false })), catchError$1(error => {
|