@acorex/layout 6.5.29 → 6.5.32
Sign up to get free protection for your applications and to get access to all the features.
- package/README.md +1 -1
- package/acorex-layout.d.ts +5 -5
- package/esm2020/acorex-layout.mjs +4 -4
- package/esm2020/lib/widget-board/editors/widget-size-editor/widget-size.editor.mjs +46 -46
- package/esm2020/lib/widget-board/editors/widget-size-editor/widget-size.module.mjs +21 -21
- package/esm2020/lib/widget-board/widget-board.component.mjs +450 -450
- package/esm2020/lib/widget-board/widget-board.module.mjs +111 -111
- package/esm2020/lib/widget-board/widget-config.component.mjs +82 -82
- package/esm2020/lib/widget-board/widget-host.component.mjs +295 -295
- package/esm2020/lib/widget-board/widget-save.component.mjs +79 -79
- package/esm2020/lib/widget-board/widget.class.mjs +127 -127
- package/esm2020/public-api.mjs +7 -7
- package/fesm2015/acorex-layout.mjs +1147 -1147
- package/fesm2015/acorex-layout.mjs.map +1 -1
- package/fesm2020/acorex-layout.mjs +1140 -1140
- package/fesm2020/acorex-layout.mjs.map +1 -1
- package/lib/widget-board/editors/widget-size-editor/widget-size.editor.d.ts +19 -19
- package/lib/widget-board/editors/widget-size-editor/widget-size.module.d.ts +10 -10
- package/lib/widget-board/widget-board.component.d.ts +61 -61
- package/lib/widget-board/widget-board.module.d.ts +18 -18
- package/lib/widget-board/widget-config.component.d.ts +23 -23
- package/lib/widget-board/widget-host.component.d.ts +52 -52
- package/lib/widget-board/widget-save.component.d.ts +19 -19
- package/lib/widget-board/widget.class.d.ts +58 -58
- package/package.json +1 -1
- package/public-api.d.ts +6 -6
@@ -1,295 +1,295 @@
|
|
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'>\
|
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'>\
|
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>"]}
|
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'>\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>", 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'>\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>" }]
|
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 {\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>"]}
|