@acorex/layout 6.5.71 → 6.5.72

Sign up to get free protection for your applications and to get access to all the features.
Files changed (34) hide show
  1. package/README.md +7 -2
  2. package/esm2022/acorex-layout.mjs +5 -0
  3. package/esm2022/index.mjs +7 -0
  4. package/esm2022/lib/widget-board/editors/widget-size-editor/widget-size.editor.mjs +49 -0
  5. package/esm2022/lib/widget-board/editors/widget-size-editor/widget-size.module.mjs +21 -0
  6. package/esm2022/lib/widget-board/widget-board.component.mjs +452 -0
  7. package/esm2022/lib/widget-board/widget-board.module.mjs +109 -0
  8. package/esm2022/lib/widget-board/widget-config.component.mjs +85 -0
  9. package/esm2022/lib/widget-board/widget-host.component.mjs +311 -0
  10. package/esm2022/lib/widget-board/widget-save.component.mjs +79 -0
  11. package/esm2022/lib/widget-board/widget.class.mjs +130 -0
  12. package/{fesm2020 → fesm2022}/acorex-layout.mjs +158 -127
  13. package/fesm2022/acorex-layout.mjs.map +1 -0
  14. package/lib/widget-board/editors/widget-size-editor/widget-size.editor.d.ts +1 -1
  15. package/lib/widget-board/widget-board.component.d.ts +1 -1
  16. package/lib/widget-board/widget-config.component.d.ts +1 -1
  17. package/lib/widget-board/widget-host.component.d.ts +1 -1
  18. package/lib/widget-board/widget-save.component.d.ts +1 -1
  19. package/package.json +12 -18
  20. package/acorex-layout.d.ts +0 -5
  21. package/esm2020/acorex-layout.mjs +0 -5
  22. package/esm2020/lib/widget-board/editors/widget-size-editor/widget-size.editor.mjs +0 -46
  23. package/esm2020/lib/widget-board/editors/widget-size-editor/widget-size.module.mjs +0 -21
  24. package/esm2020/lib/widget-board/widget-board.component.mjs +0 -444
  25. package/esm2020/lib/widget-board/widget-board.module.mjs +0 -111
  26. package/esm2020/lib/widget-board/widget-config.component.mjs +0 -82
  27. package/esm2020/lib/widget-board/widget-host.component.mjs +0 -295
  28. package/esm2020/lib/widget-board/widget-save.component.mjs +0 -79
  29. package/esm2020/lib/widget-board/widget.class.mjs +0 -127
  30. package/esm2020/public-api.mjs +0 -7
  31. package/fesm2015/acorex-layout.mjs +0 -1175
  32. package/fesm2015/acorex-layout.mjs.map +0 -1
  33. package/fesm2020/acorex-layout.mjs.map +0 -1
  34. /package/{public-api.d.ts → index.d.ts} +0 -0
@@ -0,0 +1,109 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { AXWidgetBoardComponent } from './widget-board.component';
3
+ import { CommonModule } from '@angular/common';
4
+ import { AXWidgetHostComponent } from './widget-host.component';
5
+ import { AXSearchBoxModule, AXLoadingModule, AXProppertyEditorModule, AXPageModule, AXLabelModule, AXToolbarModule, AXTabStripModule, AXMenuModule, AXFormGroupModule, AXTextAreaModule, AXTextBoxModule, AXFieldsetModule, AXCheckBoxModule, AXValidationModule } from '@acorex/components';
6
+ import { RouterModule } from '@angular/router';
7
+ import { AXWidgetConfigComponent } from './widget-config.component';
8
+ import { AXTranslator, AXTranslatorModule } from '@acorex/core';
9
+ import { AXWidgetSizePropertyEditorComponent } from './editors/widget-size-editor/widget-size.editor';
10
+ import { AXWidgetSaveComponent } from './widget-save.component';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@angular/router";
13
+ export class AXWidgetBoardModule {
14
+ /**
15
+ *
16
+ */
17
+ constructor() {
18
+ AXTranslator.load('en', {
19
+ 'widget-board': {
20
+ 'configurable-props': 'Configurable Properties',
21
+ configure: 'Configure Widget'
22
+ }
23
+ });
24
+ AXTranslator.load('fa', {
25
+ 'widget-board': {
26
+ 'configurable-props': 'ویژگی های قابل تنظیم',
27
+ configure: 'پیکر بندی ابزارک'
28
+ }
29
+ });
30
+ }
31
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AXWidgetBoardModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
32
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: AXWidgetBoardModule, declarations: [AXWidgetBoardComponent, AXWidgetHostComponent, AXWidgetConfigComponent, AXWidgetSaveComponent], imports: [CommonModule,
33
+ AXSearchBoxModule,
34
+ AXLoadingModule,
35
+ RouterModule,
36
+ AXProppertyEditorModule,
37
+ AXPageModule,
38
+ AXToolbarModule,
39
+ AXTranslatorModule,
40
+ AXLabelModule,
41
+ AXTextAreaModule,
42
+ AXFieldsetModule,
43
+ AXTextBoxModule,
44
+ AXFormGroupModule,
45
+ AXTabStripModule,
46
+ AXCheckBoxModule,
47
+ AXMenuModule,
48
+ AXTranslatorModule,
49
+ AXValidationModule, i1.RouterModule], exports: [AXWidgetBoardComponent, AXProppertyEditorModule] });
50
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AXWidgetBoardModule, imports: [CommonModule,
51
+ AXSearchBoxModule,
52
+ AXLoadingModule,
53
+ RouterModule,
54
+ AXProppertyEditorModule,
55
+ AXPageModule,
56
+ AXToolbarModule,
57
+ AXTranslatorModule,
58
+ AXLabelModule,
59
+ AXTextAreaModule,
60
+ AXFieldsetModule,
61
+ AXTextBoxModule,
62
+ AXFormGroupModule,
63
+ AXTabStripModule,
64
+ AXCheckBoxModule,
65
+ AXMenuModule,
66
+ AXTranslatorModule,
67
+ AXValidationModule,
68
+ RouterModule.forChild([
69
+ {
70
+ component: AXWidgetSizePropertyEditorComponent,
71
+ path: 'ax/editors/widget-size'
72
+ },
73
+ ]), AXProppertyEditorModule] });
74
+ }
75
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AXWidgetBoardModule, decorators: [{
76
+ type: NgModule,
77
+ args: [{
78
+ imports: [
79
+ CommonModule,
80
+ AXSearchBoxModule,
81
+ AXLoadingModule,
82
+ RouterModule,
83
+ AXProppertyEditorModule,
84
+ AXPageModule,
85
+ AXToolbarModule,
86
+ AXTranslatorModule,
87
+ AXLabelModule,
88
+ AXTextAreaModule,
89
+ AXFieldsetModule,
90
+ AXTextBoxModule,
91
+ AXFormGroupModule,
92
+ AXTabStripModule,
93
+ AXCheckBoxModule,
94
+ AXMenuModule,
95
+ AXTranslatorModule,
96
+ AXValidationModule,
97
+ RouterModule.forChild([
98
+ {
99
+ component: AXWidgetSizePropertyEditorComponent,
100
+ path: 'ax/editors/widget-size'
101
+ },
102
+ ])
103
+ ],
104
+ exports: [AXWidgetBoardComponent, AXProppertyEditorModule],
105
+ declarations: [AXWidgetBoardComponent, AXWidgetHostComponent, AXWidgetConfigComponent, AXWidgetSaveComponent],
106
+ providers: []
107
+ }]
108
+ }], ctorParameters: function () { return []; } });
109
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LWJvYXJkLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbGF5b3V0L3NyYy9saWIvd2lkZ2V0LWJvYXJkL3dpZGdldC1ib2FyZC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDaEUsT0FBTyxFQUNILGlCQUFpQixFQUNqQixlQUFlLEVBQ2YsdUJBQXVCLEVBQ3ZCLFlBQVksRUFBRSxhQUFhLEVBQzNCLGVBQWUsRUFDZixnQkFBZ0IsRUFDaEIsWUFBWSxFQUNaLGlCQUFpQixFQUNqQixnQkFBZ0IsRUFBRSxlQUFlLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQUUsa0JBQWtCLEVBQzVGLE1BQU0sb0JBQW9CLENBQUM7QUFDNUIsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3BFLE9BQU8sRUFBRSxZQUFZLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDaEUsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLE1BQU0saURBQWlELENBQUM7QUFFdEcsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUJBQXlCLENBQUM7OztBQWlDaEUsTUFBTSxPQUFPLG1CQUFtQjtJQUM1Qjs7T0FFRztJQUNIO1FBQ0ksWUFBWSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUU7WUFDcEIsY0FBYyxFQUFFO2dCQUNaLG9CQUFvQixFQUFFLHlCQUF5QjtnQkFDL0MsU0FBUyxFQUFFLGtCQUFrQjthQUNoQztTQUNKLENBQUMsQ0FBQztRQUNILFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFO1lBQ3BCLGNBQWMsRUFBRTtnQkFDWixvQkFBb0IsRUFBRSxzQkFBc0I7Z0JBQzVDLFNBQVMsRUFBRSxrQkFBa0I7YUFDaEM7U0FDSixDQUFDLENBQUM7SUFFUCxDQUFDO3dHQWxCUSxtQkFBbUI7eUdBQW5CLG1CQUFtQixpQkFIYixzQkFBc0IsRUFBRSxxQkFBcUIsRUFBRSx1QkFBdUIsRUFBRSxxQkFBcUIsYUExQnhHLFlBQVk7WUFDWixpQkFBaUI7WUFDakIsZUFBZTtZQUNmLFlBQVk7WUFDWix1QkFBdUI7WUFDdkIsWUFBWTtZQUNaLGVBQWU7WUFDZixrQkFBa0I7WUFDbEIsYUFBYTtZQUNiLGdCQUFnQjtZQUNoQixnQkFBZ0I7WUFDaEIsZUFBZTtZQUNmLGlCQUFpQjtZQUNqQixnQkFBZ0I7WUFDaEIsZ0JBQWdCO1lBQ2hCLFlBQVk7WUFDWixrQkFBa0I7WUFDbEIsa0JBQWtCLDhCQVFaLHNCQUFzQixFQUFFLHVCQUF1Qjt5R0FJaEQsbUJBQW1CLFlBN0J4QixZQUFZO1lBQ1osaUJBQWlCO1lBQ2pCLGVBQWU7WUFDZixZQUFZO1lBQ1osdUJBQXVCO1lBQ3ZCLFlBQVk7WUFDWixlQUFlO1lBQ2Ysa0JBQWtCO1lBQ2xCLGFBQWE7WUFDYixnQkFBZ0I7WUFDaEIsZ0JBQWdCO1lBQ2hCLGVBQWU7WUFDZixpQkFBaUI7WUFDakIsZ0JBQWdCO1lBQ2hCLGdCQUFnQjtZQUNoQixZQUFZO1lBQ1osa0JBQWtCO1lBQ2xCLGtCQUFrQjtZQUNsQixZQUFZLENBQUMsUUFBUSxDQUFDO2dCQUNsQjtvQkFDSSxTQUFTLEVBQUUsbUNBQW1DO29CQUM5QyxJQUFJLEVBQUUsd0JBQXdCO2lCQUNqQzthQUNKLENBQUMsRUFFNEIsdUJBQXVCOzs0RkFJaEQsbUJBQW1CO2tCQS9CL0IsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixpQkFBaUI7d0JBQ2pCLGVBQWU7d0JBQ2YsWUFBWTt3QkFDWix1QkFBdUI7d0JBQ3ZCLFlBQVk7d0JBQ1osZUFBZTt3QkFDZixrQkFBa0I7d0JBQ2xCLGFBQWE7d0JBQ2IsZ0JBQWdCO3dCQUNoQixnQkFBZ0I7d0JBQ2hCLGVBQWU7d0JBQ2YsaUJBQWlCO3dCQUNqQixnQkFBZ0I7d0JBQ2hCLGdCQUFnQjt3QkFDaEIsWUFBWTt3QkFDWixrQkFBa0I7d0JBQ2xCLGtCQUFrQjt3QkFDbEIsWUFBWSxDQUFDLFFBQVEsQ0FBQzs0QkFDbEI7Z0NBQ0ksU0FBUyxFQUFFLG1DQUFtQztnQ0FDOUMsSUFBSSxFQUFFLHdCQUF3Qjs2QkFDakM7eUJBQ0osQ0FBQztxQkFDTDtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsRUFBRSx1QkFBdUIsQ0FBQztvQkFDMUQsWUFBWSxFQUFFLENBQUMsc0JBQXNCLEVBQUUscUJBQXFCLEVBQUUsdUJBQXVCLEVBQUUscUJBQXFCLENBQUM7b0JBQzdHLFNBQVMsRUFBRSxFQUFFO2lCQUNoQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBWFdpZGdldEJvYXJkQ29tcG9uZW50IH0gZnJvbSAnLi93aWRnZXQtYm9hcmQuY29tcG9uZW50JztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBBWFdpZGdldEhvc3RDb21wb25lbnQgfSBmcm9tICcuL3dpZGdldC1ob3N0LmNvbXBvbmVudCc7XG5pbXBvcnQge1xuICAgIEFYU2VhcmNoQm94TW9kdWxlLFxuICAgIEFYTG9hZGluZ01vZHVsZSxcbiAgICBBWFByb3BwZXJ0eUVkaXRvck1vZHVsZSxcbiAgICBBWFBhZ2VNb2R1bGUsIEFYTGFiZWxNb2R1bGUsXG4gICAgQVhUb29sYmFyTW9kdWxlLFxuICAgIEFYVGFiU3RyaXBNb2R1bGUsXG4gICAgQVhNZW51TW9kdWxlLFxuICAgIEFYRm9ybUdyb3VwTW9kdWxlLFxuICAgIEFYVGV4dEFyZWFNb2R1bGUsIEFYVGV4dEJveE1vZHVsZSwgQVhGaWVsZHNldE1vZHVsZSwgQVhDaGVja0JveE1vZHVsZSwgQVhWYWxpZGF0aW9uTW9kdWxlXG59IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cyc7XG5pbXBvcnQgeyBSb3V0ZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgQVhXaWRnZXRDb25maWdDb21wb25lbnQgfSBmcm9tICcuL3dpZGdldC1jb25maWcuY29tcG9uZW50JztcbmltcG9ydCB7IEFYVHJhbnNsYXRvciwgQVhUcmFuc2xhdG9yTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb3JlJztcbmltcG9ydCB7IEFYV2lkZ2V0U2l6ZVByb3BlcnR5RWRpdG9yQ29tcG9uZW50IH0gZnJvbSAnLi9lZGl0b3JzL3dpZGdldC1zaXplLWVkaXRvci93aWRnZXQtc2l6ZS5lZGl0b3InO1xuaW1wb3J0IHsgQVhXaWRnZXRTaXplUHJvcGVydHlFZGl0b3JNb2R1bGUgfSBmcm9tICcuL2VkaXRvcnMvd2lkZ2V0LXNpemUtZWRpdG9yL3dpZGdldC1zaXplLm1vZHVsZSc7XG5pbXBvcnQgeyBBWFdpZGdldFNhdmVDb21wb25lbnQgfSBmcm9tICcuL3dpZGdldC1zYXZlLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIEFYU2VhcmNoQm94TW9kdWxlLFxuICAgICAgICBBWExvYWRpbmdNb2R1bGUsXG4gICAgICAgIFJvdXRlck1vZHVsZSxcbiAgICAgICAgQVhQcm9wcGVydHlFZGl0b3JNb2R1bGUsXG4gICAgICAgIEFYUGFnZU1vZHVsZSxcbiAgICAgICAgQVhUb29sYmFyTW9kdWxlLFxuICAgICAgICBBWFRyYW5zbGF0b3JNb2R1bGUsXG4gICAgICAgIEFYTGFiZWxNb2R1bGUsXG4gICAgICAgIEFYVGV4dEFyZWFNb2R1bGUsXG4gICAgICAgIEFYRmllbGRzZXRNb2R1bGUsXG4gICAgICAgIEFYVGV4dEJveE1vZHVsZSxcbiAgICAgICAgQVhGb3JtR3JvdXBNb2R1bGUsXG4gICAgICAgIEFYVGFiU3RyaXBNb2R1bGUsXG4gICAgICAgIEFYQ2hlY2tCb3hNb2R1bGUsXG4gICAgICAgIEFYTWVudU1vZHVsZSxcbiAgICAgICAgQVhUcmFuc2xhdG9yTW9kdWxlLFxuICAgICAgICBBWFZhbGlkYXRpb25Nb2R1bGUsXG4gICAgICAgIFJvdXRlck1vZHVsZS5mb3JDaGlsZChbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgY29tcG9uZW50OiBBWFdpZGdldFNpemVQcm9wZXJ0eUVkaXRvckNvbXBvbmVudCxcbiAgICAgICAgICAgICAgICBwYXRoOiAnYXgvZWRpdG9ycy93aWRnZXQtc2l6ZSdcbiAgICAgICAgICAgIH0sXG4gICAgICAgIF0pXG4gICAgXSxcbiAgICBleHBvcnRzOiBbQVhXaWRnZXRCb2FyZENvbXBvbmVudCwgQVhQcm9wcGVydHlFZGl0b3JNb2R1bGVdLFxuICAgIGRlY2xhcmF0aW9uczogW0FYV2lkZ2V0Qm9hcmRDb21wb25lbnQsIEFYV2lkZ2V0SG9zdENvbXBvbmVudCwgQVhXaWRnZXRDb25maWdDb21wb25lbnQsIEFYV2lkZ2V0U2F2ZUNvbXBvbmVudF0sXG4gICAgcHJvdmlkZXJzOiBbXVxufSlcbmV4cG9ydCBjbGFzcyBBWFdpZGdldEJvYXJkTW9kdWxlIHtcbiAgICAvKipcbiAgICAgKlxuICAgICAqL1xuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBBWFRyYW5zbGF0b3IubG9hZCgnZW4nLCB7XG4gICAgICAgICAgICAnd2lkZ2V0LWJvYXJkJzoge1xuICAgICAgICAgICAgICAgICdjb25maWd1cmFibGUtcHJvcHMnOiAnQ29uZmlndXJhYmxlIFByb3BlcnRpZXMnLFxuICAgICAgICAgICAgICAgIGNvbmZpZ3VyZTogJ0NvbmZpZ3VyZSBXaWRnZXQnXG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgICAgICBBWFRyYW5zbGF0b3IubG9hZCgnZmEnLCB7XG4gICAgICAgICAgICAnd2lkZ2V0LWJvYXJkJzoge1xuICAgICAgICAgICAgICAgICdjb25maWd1cmFibGUtcHJvcHMnOiAn2YjbjNqY2q/bjCDZh9in24wg2YLYp9io2YQg2KrZhti424zZhScsXG4gICAgICAgICAgICAgICAgY29uZmlndXJlOiAn2b7bjNqp2LEg2KjZhtiv24wg2KfYqNiy2KfYsdqpJ1xuICAgICAgICAgICAgfVxuICAgICAgICB9KTtcblxuICAgIH1cblxufVxuIl19
@@ -0,0 +1,85 @@
1
+ import { Component, ViewEncapsulation, ChangeDetectionStrategy, ChangeDetectorRef, ViewChild } from '@angular/core';
2
+ import { AXBasePopupPageComponent, AXValidationFormComponent } from '@acorex/components';
3
+ import { AXTranslator } from '@acorex/core';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ import * as i2 from "@acorex/components";
7
+ import * as i3 from "@acorex/core";
8
+ export class AXWidgetConfigComponent extends AXBasePopupPageComponent {
9
+ cdr;
10
+ form;
11
+ constructor(cdr) {
12
+ super();
13
+ this.cdr = cdr;
14
+ }
15
+ widget;
16
+ props = [];
17
+ displayProps = [];
18
+ changes = [];
19
+ context = {};
20
+ getFooterButtons() {
21
+ return [
22
+ {
23
+ name: 'okay',
24
+ submitBehavior: true,
25
+ text: AXTranslator.get('common.confirm'),
26
+ style: 'success'
27
+ },
28
+ {
29
+ name: 'cancel',
30
+ cancelBehavior: true,
31
+ text: AXTranslator.get('common.cancel'),
32
+ style: 'danger blank'
33
+ }
34
+ ];
35
+ }
36
+ onFooterButtonClick(e) {
37
+ if (e.name === 'cancel') {
38
+ this.close();
39
+ }
40
+ if (e.name === 'okay') {
41
+ this.form.validate().then(c => {
42
+ if (c.result) {
43
+ this.close(this.changes);
44
+ }
45
+ });
46
+ }
47
+ }
48
+ handleValueChange(e) {
49
+ const prop = this.changes.find(c => c.property.name === e.property.name);
50
+ if (prop) {
51
+ prop.value = e.value;
52
+ }
53
+ else {
54
+ this.changes.push({ property: e.property, value: e.value });
55
+ }
56
+ this.updateContext();
57
+ }
58
+ ngOnInit() {
59
+ this.displayProps = this.props.filter(c => c.property.visible !== false).sort((a, b) => a.property.order - b.property.order);
60
+ this.updateContext();
61
+ }
62
+ updateContext() {
63
+ const ctx = {};
64
+ this.props.forEach(p => {
65
+ ctx[p.property.name] = p.value;
66
+ });
67
+ this.changes.forEach(p => {
68
+ ctx[p.property.name] = p.value;
69
+ });
70
+ this.context = ctx;
71
+ }
72
+ identify(index, item) {
73
+ return item.property.name;
74
+ }
75
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AXWidgetConfigComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
76
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AXWidgetConfigComponent, selector: "ng-component", viewQueries: [{ propertyName: "form", first: true, predicate: AXValidationFormComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<ax-page>\n <ax-page-content>\n <div class=\"container\">\n <ax-validation-form #form>\n <div class=\"row\" *ngFor=\"let p of displayProps; trackBy: identify\">\n <div class=\"col-12\">\n <ax-label>{{p.property.title | trans}}</ax-label>\n <ng-container ax-property-editor-renderer [property]=\"p\" [context]=\"context\" [host]=\"widget\" [validationForm]=\"form\"\n (onValueChange)=\"handleValueChange($event)\">\n </ng-container>\n </div>\n </div>\n </ax-validation-form>\n </div>\n </ax-page-content>\n</ax-page>", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.AXPropertyEditorRendererDirective, selector: "[ax-property-editor-renderer]", inputs: ["property", "validationForm", "context", "host", "groupId"], outputs: ["onValueChange"] }, { kind: "component", type: i2.AXPageContentComponent, selector: "ax-page-content" }, { kind: "component", type: i2.AXPageComponent, selector: "ax-page" }, { kind: "component", type: i2.AXLabelComponent, selector: "ax-label", inputs: ["size"] }, { kind: "component", type: i2.AXValidationFormComponent, selector: "ax-validation-form", inputs: ["validateOn"], outputs: ["onInit"] }, { kind: "pipe", type: i3.AXTranslatorPipe, name: "trans" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
77
+ }
78
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AXWidgetConfigComponent, decorators: [{
79
+ type: Component,
80
+ args: [{ encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ax-page>\n <ax-page-content>\n <div class=\"container\">\n <ax-validation-form #form>\n <div class=\"row\" *ngFor=\"let p of displayProps; trackBy: identify\">\n <div class=\"col-12\">\n <ax-label>{{p.property.title | trans}}</ax-label>\n <ng-container ax-property-editor-renderer [property]=\"p\" [context]=\"context\" [host]=\"widget\" [validationForm]=\"form\"\n (onValueChange)=\"handleValueChange($event)\">\n </ng-container>\n </div>\n </div>\n </ax-validation-form>\n </div>\n </ax-page-content>\n</ax-page>" }]
81
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { form: [{
82
+ type: ViewChild,
83
+ args: [AXValidationFormComponent]
84
+ }] } });
85
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-config.component.js","sourceRoot":"","sources":["../../../../../../libs/layout/src/lib/widget-board/widget-config.component.ts","../../../../../../libs/layout/src/lib/widget-board/widget-config.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, ChangeDetectionStrategy, ChangeDetectorRef, ViewChild } from '@angular/core';\nimport { AXPropertyConfig, AXBasePopupPageComponent, AXMenuItemClickEvent, AXProperyEditorValueChangeEvent, AXValidationFormComponent } from '@acorex/components';\nimport { AXButtonItem, AXTranslator } from '@acorex/core';\nimport { AXWidgetComponent } from './widget.class';\n\n\n@Component({\n    templateUrl: './widget-config.component.html',\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\n\nexport class AXWidgetConfigComponent extends AXBasePopupPageComponent {\n\n    @ViewChild(AXValidationFormComponent) form: AXValidationFormComponent;\n\n    constructor(private cdr: ChangeDetectorRef) {\n        super();\n    }\n\n\n    widget: AXWidgetComponent;\n    props: AXPropertyConfig[] = [];\n    displayProps: AXPropertyConfig[] = [];\n\n\n    changes: AXPropertyConfig[] = [];\n\n    context: any = {};\n\n\n    getFooterButtons(): AXButtonItem[] {\n        return [\n            {\n                name: 'okay',\n                submitBehavior: true,\n                text: AXTranslator.get('common.confirm'),\n                style: 'success'\n            },\n            {\n                name: 'cancel',\n                cancelBehavior: true,\n                text: AXTranslator.get('common.cancel'),\n                style: 'danger blank'\n            }\n        ];\n    }\n\n\n\n\n\n    onFooterButtonClick(e: AXMenuItemClickEvent) {\n        if (e.name === 'cancel') {\n            this.close();\n        }\n        if (e.name === 'okay') {\n            this.form.validate().then(c => {\n                if (c.result) {\n                    this.close(this.changes);\n                }\n            });\n        }\n    }\n\n    handleValueChange(e: AXProperyEditorValueChangeEvent) {\n        const prop = this.changes.find(c => c.property.name === e.property.name);\n        if (prop) {\n            prop.value = e.value;\n        }\n        else {\n            this.changes.push({ property: e.property, value: e.value });\n        }\n        this.updateContext();\n    }\n\n    ngOnInit() {\n        this.displayProps = this.props.filter(c => c.property.visible !== false).sort((a, b) => a.property.order - b.property.order);\n        this.updateContext();\n    }\n\n\n    private updateContext() {\n        const ctx = {};\n        this.props.forEach(p => {\n            ctx[p.property.name] = p.value;\n        });\n        this.changes.forEach(p => {\n            ctx[p.property.name] = p.value;\n        });\n        this.context = ctx;\n    }\n\n\n    identify(index, item: AXPropertyConfig) {\n        return item.property.name;\n    }\n\n}","<ax-page>\n    <ax-page-content>\n        <div class=\"container\">\n            <ax-validation-form #form>\n                <div class=\"row\" *ngFor=\"let p of displayProps; trackBy: identify\">\n                    <div class=\"col-12\">\n                        <ax-label>{{p.property.title | trans}}</ax-label>\n                        <ng-container ax-property-editor-renderer [property]=\"p\" [context]=\"context\" [host]=\"widget\"  [validationForm]=\"form\"\n                            (onValueChange)=\"handleValueChange($event)\">\n                        </ng-container>\n                    </div>\n                </div>\n            </ax-validation-form>\n        </div>\n    </ax-page-content>\n</ax-page>"]}
@@ -0,0 +1,311 @@
1
+ import { Component, ViewEncapsulation, Input, ElementRef, HostBinding, ComponentFactoryResolver, ViewChild, ViewContainerRef, Output, EventEmitter, ChangeDetectionStrategy, ChangeDetectorRef } from '@angular/core';
2
+ import { AXObjectUtil, AXRenderService } from '@acorex/core';
3
+ import { AXPopupService, AXPropertyDecorators, AXLoadingService } from '@acorex/components';
4
+ import { AXWidgetConfigComponent } from './widget-config.component';
5
+ import { AXTranslator } from '@acorex/core';
6
+ import { AXWidgetSaveComponent } from './widget-save.component';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@acorex/core";
9
+ import * as i2 from "@acorex/components";
10
+ import * as i3 from "@angular/common";
11
+ export class AXWidgetHostComponent {
12
+ ref;
13
+ componentFactoryResolver;
14
+ rendererService;
15
+ cdr;
16
+ popup;
17
+ loadingService;
18
+ _widget;
19
+ get widget() {
20
+ return this._widget;
21
+ }
22
+ _hasProps = false;
23
+ _hasMenu = false;
24
+ provideValue;
25
+ get element() {
26
+ return this.ref.nativeElement;
27
+ }
28
+ configMenuItem = [
29
+ {
30
+ icon: 'far fa-ellipsis-h',
31
+ items: []
32
+ }
33
+ ];
34
+ onRemove = new EventEmitter();
35
+ onConfigChanged = new EventEmitter();
36
+ onResized = new EventEmitter();
37
+ onSave = new EventEmitter();
38
+ config;
39
+ vc;
40
+ readonly = false;
41
+ componentRef;
42
+ //private isLoading: boolean = true;
43
+ // get isBusy() {
44
+ // return this._widget?.isBusy || this.isLoading;
45
+ // }
46
+ _loadingId;
47
+ _isLoading = false;
48
+ get isLoading() {
49
+ return this._isLoading;
50
+ }
51
+ set isLoading(v) {
52
+ this._isLoading = v;
53
+ if (this._loadingId && !v) {
54
+ this.loadingService.hide(this._loadingId);
55
+ this._loadingId = null;
56
+ }
57
+ if (v) {
58
+ this._loadingId = this.loadingService.show(this.ref.nativeElement);
59
+ }
60
+ }
61
+ get isConfigured() {
62
+ return this._widget?.isConfigured || false;
63
+ }
64
+ constructor(ref, componentFactoryResolver, rendererService, cdr, popup, loadingService) {
65
+ this.ref = ref;
66
+ this.componentFactoryResolver = componentFactoryResolver;
67
+ this.rendererService = rendererService;
68
+ this.cdr = cdr;
69
+ this.popup = popup;
70
+ this.loadingService = loadingService;
71
+ }
72
+ ngOnInit() {
73
+ this.isLoading = true;
74
+ }
75
+ async ngAfterViewInit() {
76
+ let component;
77
+ if (typeof this.config.component === 'string') {
78
+ const route = await this.rendererService.findLoadedComponentByRoute(this.config.component, 20);
79
+ component = route?.component;
80
+ }
81
+ else if (typeof this.config.component === 'function') {
82
+ component = this.config.component;
83
+ }
84
+ if (component == null) {
85
+ console.error(`Invalid Widget Component!`, this.config);
86
+ this.onRemove.emit(this);
87
+ return;
88
+ }
89
+ const widgetFactory = this.componentFactoryResolver.resolveComponentFactory(component);
90
+ this.componentRef = this.vc.createComponent(widgetFactory);
91
+ this._widget = this.componentRef.instance;
92
+ this._widget.provideValue = this.provideValue;
93
+ if (this._widget.onBusyChanged) {
94
+ this._widget.onBusyChanged.subscribe((d) => {
95
+ if (!this._widget.widgetSize) {
96
+ this._widget.setValue('widgetSize', [this.sizeX, this.sizeY]);
97
+ }
98
+ else {
99
+ this.setSizeFromOptions();
100
+ }
101
+ this.isLoading = d.value;
102
+ this.cdr.detectChanges();
103
+ });
104
+ }
105
+ if (this._widget.onConfiguredChanged) {
106
+ this._widget.onConfiguredChanged.subscribe(() => {
107
+ this.setSizeFromOptions();
108
+ });
109
+ }
110
+ //
111
+ if (this.config.options) {
112
+ Object.assign(this._widget, this.config.options);
113
+ }
114
+ this._hasProps = AXPropertyDecorators.getProperties(this._widget).length > 0;
115
+ this.isLoading = false;
116
+ this.config['__meta__'].instance = this;
117
+ this._widget['__meta__'] = {};
118
+ this._widget['__meta__'].config = this.config;
119
+ //
120
+ this.configMenuItem[0].items.push({
121
+ name: 'refresh',
122
+ icon: 'far fa-undo',
123
+ text: AXTranslator.get('common.refresh'),
124
+ onClick: () => {
125
+ this?.widget?.refresh();
126
+ }
127
+ });
128
+ //
129
+ if (this._hasProps) {
130
+ this.configMenuItem[0].items.push({
131
+ name: 'configs',
132
+ icon: 'far fa-cogs',
133
+ text: AXTranslator.get('common.configs'),
134
+ onClick: () => {
135
+ this.openConfigDialog();
136
+ }
137
+ });
138
+ }
139
+ this.configMenuItem[0].items.push({
140
+ name: 'save',
141
+ icon: 'far fa-save',
142
+ text: AXTranslator.get('common.save-as'),
143
+ onClick: () => {
144
+ this.openSaveDialog();
145
+ }
146
+ });
147
+ if (true) {
148
+ this.configMenuItem[0].items.push({
149
+ name: 'remove',
150
+ icon: 'far fa-times',
151
+ style: 'ax danger blank',
152
+ text: AXTranslator.get('common.remove'),
153
+ onClick: () => {
154
+ this.onRemove.emit(this);
155
+ }
156
+ });
157
+ }
158
+ this._hasMenu = this.configMenuItem[0].items.length > 0;
159
+ this.cdr.detectChanges();
160
+ }
161
+ sizeX = 1;
162
+ sizeY = 1;
163
+ col = 1;
164
+ row = 1;
165
+ setSizeFromOptions() {
166
+ this._widget.getValue('widgetSize').then(c => {
167
+ const oldSizeX = this.sizeX;
168
+ const oldSizeY = this.sizeY;
169
+ if (c && Array.isArray(c) && (oldSizeX !== c[0] || oldSizeY !== c[1])) {
170
+ this.config.sizeX = this.sizeX = c[0];
171
+ this.config.sizeY = this.sizeY = c[1];
172
+ this.onResized.emit({
173
+ component: this._widget,
174
+ config: this.config
175
+ });
176
+ }
177
+ this.cdr.detectChanges();
178
+ });
179
+ }
180
+ remove(e) {
181
+ e.preventDefault();
182
+ e.stopPropagation();
183
+ if (!this.readonly)
184
+ this.onRemove.emit(this);
185
+ return false;
186
+ }
187
+ handleConfig(e) {
188
+ e.preventDefault();
189
+ e.stopPropagation();
190
+ if (!this.readonly)
191
+ this.openConfigDialog();
192
+ return false;
193
+ }
194
+ openConfigDialog() {
195
+ const ppp = this.getMergedProps();
196
+ this.popup.open(AXWidgetConfigComponent, {
197
+ title: AXTranslator.get('common.configs'),
198
+ size: 'sm',
199
+ data: {
200
+ props: ppp.map(c => ({ property: c.options, value: this._widget[c.options.name] })),
201
+ widget: this.widget
202
+ }
203
+ }).then(c => {
204
+ if (c.data) {
205
+ if (!this.config.options) {
206
+ this.config.options = {};
207
+ }
208
+ c.data.forEach(p => {
209
+ this._widget.setValue(p.property.name, p.value);
210
+ this.config.options[p.property.name] = p.value;
211
+ });
212
+ this.emitConfigChanged();
213
+ this._widget.redraw();
214
+ this.cdr.detectChanges();
215
+ }
216
+ });
217
+ }
218
+ openSaveDialog() {
219
+ const ppp = this.getMergedProps();
220
+ this.popup.open(AXWidgetSaveComponent, {
221
+ title: AXTranslator.get('common.save-as'),
222
+ size: 'sm',
223
+ data: {
224
+ config: this.config,
225
+ props: ppp.map(c => ({ property: c.options, value: this._widget[c.options.name] }))
226
+ }
227
+ }).then(c => {
228
+ if (c.data) {
229
+ this.onSave.emit({
230
+ component: this._widget,
231
+ data: c.data
232
+ });
233
+ }
234
+ });
235
+ }
236
+ handleOptionClick(e) {
237
+ e.preventDefault();
238
+ e.stopPropagation();
239
+ this.openConfigDialog();
240
+ return false;
241
+ }
242
+ ngOnDestroy() {
243
+ this.vc.clear();
244
+ if (this.componentRef) {
245
+ this.componentRef.destroy();
246
+ }
247
+ }
248
+ getMergedProps() {
249
+ const ppp = AXObjectUtil.deepCopy(AXPropertyDecorators.getProperties(this._widget));
250
+ for (const key in this.config.props) {
251
+ if (Object.prototype.hasOwnProperty.call(this.config.props, key)) {
252
+ const newP = this.config.props[key];
253
+ const existPropDec = ppp.find(p => p.property === key);
254
+ if (existPropDec) {
255
+ Object.assign(existPropDec.options, newP);
256
+ }
257
+ }
258
+ }
259
+ return ppp;
260
+ }
261
+ emitConfigChanged() {
262
+ this.onConfigChanged.emit({
263
+ component: this._widget,
264
+ config: this.config
265
+ });
266
+ }
267
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AXWidgetHostComponent, deps: [{ token: i0.ElementRef }, { token: i0.ComponentFactoryResolver }, { token: i1.AXRenderService }, { token: i0.ChangeDetectorRef }, { token: i2.AXPopupService }, { token: i2.AXLoadingService }], target: i0.ɵɵFactoryTarget.Component });
268
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AXWidgetHostComponent, selector: "ax-widget-host", inputs: { provideValue: "provideValue", config: "config", readonly: "readonly", sizeX: "sizeX", sizeY: "sizeY", col: "col", row: "row" }, outputs: { onRemove: "onRemove", onConfigChanged: "onConfigChanged", onResized: "onResized", onSave: "onSave" }, host: { attributes: { "tabindex": "0" }, properties: { "attr.data-size-x": "this.sizeX", "attr.data-size-y": "this.sizeY", "attr.data-col": "this.col", "attr.data-row": "this.row" }, classAttribute: "ax widget-host" }, viewQueries: [{ propertyName: "vc", first: true, predicate: ["vc"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<div class='widget-container'>\n <div class=\"widget-config-overlay\" *ngIf=\"!isConfigured\" (click)=\"handleConfig($event)\">\n <div class=\"widget-title\">{{config.title}}</div>\n <div class=\"widget-config-box\">\n <div class=\"config-title\">{{ 'widget-board.configure' | trans}}</div>\n <div class=\"config-icon\" *ngIf=\"!readonly\"><i class=\"fas fa-cogs fa-5x\" aria-hidden=\"true\"></i></div>\n </div>\n </div>\n <div class='widget-edit-overlay' >\n <div class='widget-edit-menu'>\n <button class=\"widget-edit-menu-button\" (click)=\"handleConfig($event)\"\n (mousedown)=\"$event.stopPropagation()\" *ngIf=\"_hasProps\" (mouseup)=\"$event.stopPropagation()\">\n <i class=\"far fa-cogs\" aria-hidden=\"true\"></i>\n </button>\n <button class=\"widget-edit-menu-button\" (click)=\"remove($event)\" (mousedown)=\"$event.stopPropagation()\"\n (mouseup)=\"$event.stopPropagation()\">\n <i class=\"far fa-times\" aria-hidden=\"true\"></i>\n </button>\n </div>\n\n </div>\n <div class=\"widget-options-menu\" *ngIf=\"_hasMenu && !readonly\">\n <ax-menu [items]='configMenuItem' direction=\"horizontal\"></ax-menu>\n </div>\n <!-- <ax-loading-panel [visible]=\"isBusy\">\n </ax-loading-panel> -->\n <div class=\"widget-content\">\n <ng-container #vc></ng-container>\n </div>\n</div>", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.AXMenuComponent, selector: "ax-menu", inputs: ["menuTemplate", "rtl", "size", "selection", "mode", "target", "floatAlignment", "floatPlacemnet", "direction", "items"], outputs: ["onItemClick"] }, { kind: "pipe", type: i1.AXTranslatorPipe, name: "trans" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
269
+ }
270
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AXWidgetHostComponent, decorators: [{
271
+ type: Component,
272
+ args: [{ selector: 'ax-widget-host', host: { class: 'ax widget-host', tabindex: '0' }, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class='widget-container'>\n <div class=\"widget-config-overlay\" *ngIf=\"!isConfigured\" (click)=\"handleConfig($event)\">\n <div class=\"widget-title\">{{config.title}}</div>\n <div class=\"widget-config-box\">\n <div class=\"config-title\">{{ 'widget-board.configure' | trans}}</div>\n <div class=\"config-icon\" *ngIf=\"!readonly\"><i class=\"fas fa-cogs fa-5x\" aria-hidden=\"true\"></i></div>\n </div>\n </div>\n <div class='widget-edit-overlay' >\n <div class='widget-edit-menu'>\n <button class=\"widget-edit-menu-button\" (click)=\"handleConfig($event)\"\n (mousedown)=\"$event.stopPropagation()\" *ngIf=\"_hasProps\" (mouseup)=\"$event.stopPropagation()\">\n <i class=\"far fa-cogs\" aria-hidden=\"true\"></i>\n </button>\n <button class=\"widget-edit-menu-button\" (click)=\"remove($event)\" (mousedown)=\"$event.stopPropagation()\"\n (mouseup)=\"$event.stopPropagation()\">\n <i class=\"far fa-times\" aria-hidden=\"true\"></i>\n </button>\n </div>\n\n </div>\n <div class=\"widget-options-menu\" *ngIf=\"_hasMenu && !readonly\">\n <ax-menu [items]='configMenuItem' direction=\"horizontal\"></ax-menu>\n </div>\n <!-- <ax-loading-panel [visible]=\"isBusy\">\n </ax-loading-panel> -->\n <div class=\"widget-content\">\n <ng-container #vc></ng-container>\n </div>\n</div>" }]
273
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ComponentFactoryResolver }, { type: i1.AXRenderService }, { type: i0.ChangeDetectorRef }, { type: i2.AXPopupService }, { type: i2.AXLoadingService }]; }, propDecorators: { provideValue: [{
274
+ type: Input
275
+ }], onRemove: [{
276
+ type: Output
277
+ }], onConfigChanged: [{
278
+ type: Output
279
+ }], onResized: [{
280
+ type: Output
281
+ }], onSave: [{
282
+ type: Output
283
+ }], config: [{
284
+ type: Input
285
+ }], vc: [{
286
+ type: ViewChild,
287
+ args: ['vc', { read: ViewContainerRef }]
288
+ }], readonly: [{
289
+ type: Input
290
+ }], sizeX: [{
291
+ type: HostBinding,
292
+ args: ['attr.data-size-x']
293
+ }, {
294
+ type: Input
295
+ }], sizeY: [{
296
+ type: HostBinding,
297
+ args: ['attr.data-size-y']
298
+ }, {
299
+ type: Input
300
+ }], col: [{
301
+ type: HostBinding,
302
+ args: ['attr.data-col']
303
+ }, {
304
+ type: Input
305
+ }], row: [{
306
+ type: HostBinding,
307
+ args: ['attr.data-row']
308
+ }, {
309
+ type: Input
310
+ }] } });
311
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-host.component.js","sourceRoot":"","sources":["../../../../../../libs/layout/src/lib/widget-board/widget-host.component.ts","../../../../../../libs/layout/src/lib/widget-board/widget-host.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ViewEncapsulation, Input,\n    ElementRef, HostBinding, ComponentFactoryResolver, ViewChild,\n    ViewContainerRef, Output, EventEmitter, ChangeDetectionStrategy,\n    ChangeDetectorRef, ComponentRef\n} from '@angular/core';\nimport { AXWidgetConfig, AXWidgetComponent, AXWidgetConfigChanged, AXWidgetConfigSavedEvent } from './widget.class';\nimport { AXObjectUtil, AXRenderService } from '@acorex/core';\nimport { AXPopupService, AXPropertyDecorators, AXPropertyDecorator, AXLoadingService } from '@acorex/components';\nimport { AXWidgetConfigComponent } from './widget-config.component';\nimport { AXMenuItem } from '@acorex/core';\nimport { AXTranslator } from '@acorex/core';\nimport { AXWidgetSaveComponent } from './widget-save.component';\n\n\n\n\n\n@Component({\n    selector: 'ax-widget-host',\n    templateUrl: \"./widget-host.component.html\",\n    host: { class: 'ax widget-host', tabindex: '0' },\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\n\nexport class AXWidgetHostComponent {\n\n    private _widget: AXWidgetComponent;\n    public get widget(): AXWidgetComponent {\n        return this._widget;\n    }\n\n    _hasProps: boolean = false;\n\n\n    _hasMenu: boolean = false;\n\n    @Input()\n    provideValue: (e: any) => any;\n\n\n    get element(): HTMLDivElement {\n        return this.ref.nativeElement;\n    }\n\n\n    configMenuItem: AXMenuItem[] = [\n        {\n            icon: 'far fa-ellipsis-h',\n            items: []\n        }\n    ];\n\n\n    @Output()\n    onRemove: EventEmitter<AXWidgetHostComponent> = new EventEmitter<AXWidgetHostComponent>();\n\n    @Output()\n    onConfigChanged: EventEmitter<AXWidgetConfigChanged> = new EventEmitter<AXWidgetConfigChanged>();\n\n\n    @Output()\n    onResized: EventEmitter<AXWidgetConfigChanged> = new EventEmitter<AXWidgetConfigChanged>();\n\n    @Output()\n    onSave: EventEmitter<AXWidgetConfigSavedEvent> = new EventEmitter<AXWidgetConfigSavedEvent>();\n\n    @Input()\n    config: AXWidgetConfig;\n\n    @ViewChild('vc', { read: ViewContainerRef })\n    vc: ViewContainerRef;\n\n\n\n    @Input()\n    readonly: boolean = false;\n\n    private componentRef: ComponentRef<any>;\n    //private isLoading: boolean = true;\n\n    // get isBusy() {\n    //     return this._widget?.isBusy || this.isLoading;\n    // }\n\n\n    private _loadingId: number;\n\n    private _isLoading: boolean = false;\n    public get isLoading(): boolean {\n        return this._isLoading;\n    }\n    public set isLoading(v: boolean) {\n        this._isLoading = v;\n        if (this._loadingId && !v) {\n            this.loadingService.hide(this._loadingId);\n            this._loadingId = null;\n        }\n        if (v) {\n            this._loadingId = this.loadingService.show(this.ref.nativeElement);\n        }\n    }\n\n\n    get isConfigured(): boolean {\n        return this._widget?.isConfigured || false;\n    }\n\n\n    constructor(\n        private ref: ElementRef<HTMLDivElement>,\n        private componentFactoryResolver: ComponentFactoryResolver,\n        private rendererService: AXRenderService,\n        private cdr: ChangeDetectorRef,\n        private popup: AXPopupService,\n        private loadingService: AXLoadingService\n\n    ) {\n\n    }\n\n\n    ngOnInit() {\n        this.isLoading = true;\n    }\n\n\n    async ngAfterViewInit() {\n        let component: any;\n        if (typeof this.config.component === 'string') {\n            const route = await this.rendererService.findLoadedComponentByRoute(this.config.component, 20);\n            component = route?.component;\n        }\n        else if (typeof this.config.component === 'function') {\n            component = this.config.component;\n        }\n        if (component == null) {\n            console.error(`Invalid Widget Component!`, this.config);\n            this.onRemove.emit(this);\n            return;\n        }\n\n        const widgetFactory = this.componentFactoryResolver.resolveComponentFactory(component);\n        this.componentRef = this.vc.createComponent(widgetFactory);\n        this._widget = this.componentRef.instance as AXWidgetComponent;\n        this._widget.provideValue = this.provideValue;\n        if (this._widget.onBusyChanged) {\n            this._widget.onBusyChanged.subscribe((d) => {\n                if (!this._widget.widgetSize) {\n                    this._widget.setValue('widgetSize', [this.sizeX, this.sizeY]);\n                }\n                else {\n                    this.setSizeFromOptions();\n                }\n                this.isLoading = d.value;\n                this.cdr.detectChanges();\n            });\n        }\n        if (this._widget.onConfiguredChanged) {\n            this._widget.onConfiguredChanged.subscribe(() => {\n                this.setSizeFromOptions();\n            });\n        }\n        //\n        if (this.config.options) {\n            Object.assign(this._widget, this.config.options);\n        }\n        this._hasProps = AXPropertyDecorators.getProperties(this._widget).length > 0;\n\n        this.isLoading = false;\n        this.config['__meta__'].instance = this;\n        this._widget['__meta__'] = {};\n        this._widget['__meta__'].config = this.config;\n        //\n        this.configMenuItem[0].items.push({\n            name: 'refresh',\n            icon: 'far fa-undo',\n            text: AXTranslator.get('common.refresh'),\n            onClick: () => {\n                this?.widget?.refresh();\n            }\n        });\n        //\n        if (this._hasProps) {\n            this.configMenuItem[0].items.push({\n                name: 'configs',\n                icon: 'far fa-cogs',\n                text: AXTranslator.get('common.configs'),\n                onClick: () => {\n                    this.openConfigDialog();\n                }\n            });\n        }\n        this.configMenuItem[0].items.push({\n            name: 'save',\n            icon: 'far fa-save',\n            text: AXTranslator.get('common.save-as'),\n            onClick: () => {\n                this.openSaveDialog();\n            }\n        });\n        if (true) {\n            this.configMenuItem[0].items.push({\n                name: 'remove',\n                icon: 'far fa-times',\n                style: 'ax danger blank',\n                text: AXTranslator.get('common.remove'),\n                onClick: () => {\n                    this.onRemove.emit(this);\n                }\n            });\n        }\n        this._hasMenu = this.configMenuItem[0].items.length > 0;\n        this.cdr.detectChanges();\n    }\n\n    @HostBinding('attr.data-size-x')\n    @Input()\n    sizeX: number = 1;\n\n    @HostBinding('attr.data-size-y')\n    @Input()\n    sizeY: number = 1;\n\n    @HostBinding('attr.data-col')\n    @Input()\n    col: number = 1;\n\n\n    @HostBinding('attr.data-row')\n    @Input()\n    row: number = 1;\n\n\n    private setSizeFromOptions() {\n        this._widget.getValue('widgetSize').then(c => {\n            const oldSizeX = this.sizeX;\n            const oldSizeY = this.sizeY;\n            if (c && Array.isArray(c) && (oldSizeX !== c[0] || oldSizeY !== c[1])) {\n                this.config.sizeX = this.sizeX = c[0];\n                this.config.sizeY = this.sizeY = c[1];\n                this.onResized.emit({\n                    component: this._widget,\n                    config: this.config\n                });\n            }\n            this.cdr.detectChanges();\n        });\n    }\n\n    remove(e: MouseEvent) {\n        e.preventDefault();\n        e.stopPropagation();\n        if (!this.readonly)\n            this.onRemove.emit(this);\n        return false;\n    }\n\n    handleConfig(e: MouseEvent) {\n        e.preventDefault();\n        e.stopPropagation();\n        if (!this.readonly)\n            this.openConfigDialog();\n        return false;\n    }\n\n    private openConfigDialog() {\n        const ppp = this.getMergedProps();\n        this.popup.open(AXWidgetConfigComponent, {\n            title: AXTranslator.get('common.configs'),\n            size: 'sm',\n            data: {\n                props: ppp.map(c => ({ property: c.options, value: this._widget[c.options.name] })),\n                widget: this.widget\n            }\n        }).then(c => {\n            if (c.data) {\n                if (!this.config.options) {\n                    this.config.options = {};\n                }\n                c.data.forEach(p => {\n                    this._widget.setValue(p.property.name, p.value);\n                    this.config.options[p.property.name] = p.value;\n                });\n                this.emitConfigChanged();\n                this._widget.redraw();\n                this.cdr.detectChanges();\n            }\n        });\n    }\n\n    private openSaveDialog() {\n        const ppp = this.getMergedProps();\n        this.popup.open(AXWidgetSaveComponent, {\n            title: AXTranslator.get('common.save-as'),\n            size: 'sm',\n            data: {\n                config: this.config,\n                props: ppp.map(c => ({ property: c.options, value: this._widget[c.options.name] }))\n            }\n        }).then(c => {\n            if (c.data) {\n                this.onSave.emit({\n                    component: this._widget,\n                    data: c.data\n                });\n            }\n        });\n    }\n\n\n\n    handleOptionClick(e: MouseEvent) {\n        e.preventDefault();\n        e.stopPropagation();\n        this.openConfigDialog();\n        return false;\n    }\n\n    ngOnDestroy() {\n        this.vc.clear();\n        if (this.componentRef) {\n            this.componentRef.destroy();\n        }\n    }\n\n    private getMergedProps(): AXPropertyDecorator[] {\n        const ppp = AXObjectUtil.deepCopy(AXPropertyDecorators.getProperties(this._widget)) as AXPropertyDecorator[];\n        for (const key in this.config.props) {\n            if (Object.prototype.hasOwnProperty.call(this.config.props, key)) {\n                const newP = this.config.props[key];\n                const existPropDec = ppp.find(p => p.property === key);\n                if (existPropDec) {\n                    Object.assign(existPropDec.options, newP);\n                }\n            }\n        }\n        return ppp;\n    }\n\n    private emitConfigChanged() {\n        this.onConfigChanged.emit({\n            component: this._widget,\n            config: this.config\n        });\n    }\n\n}","<div class='widget-container'>\n    <div class=\"widget-config-overlay\" *ngIf=\"!isConfigured\" (click)=\"handleConfig($event)\">\n        <div class=\"widget-title\">{{config.title}}</div>\n        <div class=\"widget-config-box\">\n            <div class=\"config-title\">{{ 'widget-board.configure' | trans}}</div>\n            <div class=\"config-icon\" *ngIf=\"!readonly\"><i class=\"fas fa-cogs fa-5x\" aria-hidden=\"true\"></i></div>\n        </div>\n    </div>\n    <div class='widget-edit-overlay' >\n        <div class='widget-edit-menu'>\n            <button class=\"widget-edit-menu-button\" (click)=\"handleConfig($event)\"\n                (mousedown)=\"$event.stopPropagation()\" *ngIf=\"_hasProps\" (mouseup)=\"$event.stopPropagation()\">\n                <i class=\"far fa-cogs\" aria-hidden=\"true\"></i>\n            </button>\n            <button class=\"widget-edit-menu-button\" (click)=\"remove($event)\" (mousedown)=\"$event.stopPropagation()\"\n                (mouseup)=\"$event.stopPropagation()\">\n                <i class=\"far fa-times\" aria-hidden=\"true\"></i>\n            </button>\n        </div>\n\n    </div>\n    <div class=\"widget-options-menu\"  *ngIf=\"_hasMenu && !readonly\">\n        <ax-menu [items]='configMenuItem' direction=\"horizontal\"></ax-menu>\n    </div>\n    <!-- <ax-loading-panel [visible]=\"isBusy\">\n    </ax-loading-panel> -->\n    <div class=\"widget-content\">\n        <ng-container #vc></ng-container>\n    </div>\n</div>"]}