@acorex/layout 6.5.26 → 6.5.27

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