@acorex/components 3.0.45 → 3.0.50
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/acorex-components.metadata.json +1 -1
- package/bundles/acorex-components.umd.js +164 -76
- package/bundles/acorex-components.umd.js.map +1 -1
- package/bundles/acorex-components.umd.min.js +1 -1
- package/bundles/acorex-components.umd.min.js.map +1 -1
- package/esm2015/lib/calendar/calendar-box/calendar-box.component.js +6 -6
- package/esm2015/lib/property-editor/editors/color-editor/color.editor.js +2 -2
- package/esm2015/lib/property-editor/editors/column-editor/column.editor.js +2 -2
- package/esm2015/lib/property-editor/editors/conditional-color-editor/conditional-color.editor.js +2 -2
- package/esm2015/lib/property-editor/editors/date-editor/date.editor.js +2 -2
- package/esm2015/lib/property-editor/editors/number-editor/number.editor.js +2 -2
- package/esm2015/lib/property-editor/editors/range-editor/range.editor.js +2 -2
- package/esm2015/lib/property-editor/editors/selectbox-editor/selectbox.editor.js +22 -12
- package/esm2015/lib/property-editor/editors/switch-editor/number.editor.js +2 -2
- package/esm2015/lib/property-editor/editors/text-editor/text.editor.js +2 -2
- package/esm2015/lib/property-editor/editors/time-editor/time.editor.js +2 -2
- package/esm2015/lib/property-editor/property-editor-renderer.directive.js +83 -37
- package/esm2015/lib/property-editor/property-editor.class.js +18 -4
- package/esm2015/lib/selectbox/selectbox.component.js +6 -3
- package/esm2015/lib/selection-list/selection-list.component.js +6 -7
- package/esm2015/lib/tab-strip/tab-strip.component.js +11 -9
- package/esm5/lib/calendar/calendar-box/calendar-box.component.js +6 -6
- package/esm5/lib/property-editor/editors/color-editor/color.editor.js +2 -2
- package/esm5/lib/property-editor/editors/column-editor/column.editor.js +2 -2
- package/esm5/lib/property-editor/editors/conditional-color-editor/conditional-color.editor.js +2 -2
- package/esm5/lib/property-editor/editors/date-editor/date.editor.js +2 -2
- package/esm5/lib/property-editor/editors/number-editor/number.editor.js +2 -2
- package/esm5/lib/property-editor/editors/range-editor/range.editor.js +2 -2
- package/esm5/lib/property-editor/editors/selectbox-editor/selectbox.editor.js +26 -12
- package/esm5/lib/property-editor/editors/switch-editor/number.editor.js +2 -2
- package/esm5/lib/property-editor/editors/text-editor/text.editor.js +2 -2
- package/esm5/lib/property-editor/editors/time-editor/time.editor.js +2 -2
- package/esm5/lib/property-editor/property-editor-renderer.directive.js +89 -39
- package/esm5/lib/property-editor/property-editor.class.js +24 -4
- package/esm5/lib/selectbox/selectbox.component.js +6 -3
- package/esm5/lib/selection-list/selection-list.component.js +3 -4
- package/esm5/lib/tab-strip/tab-strip.component.js +11 -9
- package/fesm2015/acorex-components.js +152 -78
- package/fesm2015/acorex-components.js.map +1 -1
- package/fesm5/acorex-components.js +165 -77
- package/fesm5/acorex-components.js.map +1 -1
- package/lib/property-editor/editors/selectbox-editor/selectbox.editor.d.ts +7 -4
- package/lib/property-editor/property-editor-renderer.directive.d.ts +5 -3
- package/lib/property-editor/property-editor.class.d.ts +4 -2
- package/package.json +1 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
|
2
2
|
import { Component, OnInit, ChangeDetectorRef, ViewChild } from '@angular/core';
|
|
3
3
|
import { AXProperyEditorComponent } from '../../property-editor.class';
|
|
4
|
-
import {
|
|
4
|
+
import { AXSelectBoxComponent } from '../../../selectbox/selectbox.component';
|
|
5
5
|
let AXSelectBoxPropertyEditorComponent = class AXSelectBoxPropertyEditorComponent extends AXProperyEditorComponent {
|
|
6
6
|
constructor(cdr) {
|
|
7
7
|
super(cdr);
|
|
@@ -12,16 +12,18 @@ let AXSelectBoxPropertyEditorComponent = class AXSelectBoxPropertyEditorComponen
|
|
|
12
12
|
this.selectionDataMode = 'value';
|
|
13
13
|
this.allowSearch = true;
|
|
14
14
|
this.allowNull = false;
|
|
15
|
+
this.disabled = false;
|
|
15
16
|
this.items = [];
|
|
16
17
|
this.remoteOperation = false;
|
|
17
18
|
this.provideData = (e) => {
|
|
18
19
|
return new Promise((resolve) => {
|
|
19
20
|
const func = () => {
|
|
20
21
|
if (Array.isArray(this.items)) {
|
|
21
|
-
resolve(this.items);
|
|
22
|
+
resolve(this.items.slice());
|
|
22
23
|
}
|
|
23
24
|
else if (typeof this.items === 'function') {
|
|
24
|
-
|
|
25
|
+
const a = Object.assign(e, { sender: this });
|
|
26
|
+
resolve(this.items(a));
|
|
25
27
|
}
|
|
26
28
|
else {
|
|
27
29
|
resolve([]);
|
|
@@ -36,29 +38,37 @@ let AXSelectBoxPropertyEditorComponent = class AXSelectBoxPropertyEditorComponen
|
|
|
36
38
|
});
|
|
37
39
|
};
|
|
38
40
|
}
|
|
41
|
+
get filter() {
|
|
42
|
+
return this._filter;
|
|
43
|
+
}
|
|
44
|
+
set filter(v) {
|
|
45
|
+
var _a;
|
|
46
|
+
this._filter = v;
|
|
47
|
+
if (this.value && this.initiated) {
|
|
48
|
+
this.value = null;
|
|
49
|
+
(_a = this.selectBox) === null || _a === void 0 ? void 0 : _a.refresh();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
39
52
|
handleValueChange(e) {
|
|
40
|
-
super.handleValueChange(e.
|
|
53
|
+
super.handleValueChange(e.selectedValues);
|
|
41
54
|
}
|
|
42
55
|
ngAfterViewInit() {
|
|
43
|
-
this.selectBox.refresh();
|
|
44
56
|
this.registerForValidationForm(this.selectBox);
|
|
45
|
-
|
|
46
|
-
initiat() {
|
|
47
|
-
this.initiated = true;
|
|
57
|
+
this.onRenderCompleted.emit();
|
|
48
58
|
}
|
|
49
59
|
};
|
|
50
60
|
AXSelectBoxPropertyEditorComponent.ctorParameters = () => [
|
|
51
61
|
{ type: ChangeDetectorRef }
|
|
52
62
|
];
|
|
53
63
|
__decorate([
|
|
54
|
-
ViewChild(
|
|
55
|
-
__metadata("design:type",
|
|
64
|
+
ViewChild(AXSelectBoxComponent, { static: true }),
|
|
65
|
+
__metadata("design:type", AXSelectBoxComponent)
|
|
56
66
|
], AXSelectBoxPropertyEditorComponent.prototype, "selectBox", void 0);
|
|
57
67
|
AXSelectBoxPropertyEditorComponent = __decorate([
|
|
58
68
|
Component({
|
|
59
|
-
template: "<ax-select-
|
|
69
|
+
template: "<ax-select-box [mode]=\"selectionMode\"\r\n [textField]=\"textField\" \r\n [valueField]=\"valueField\" \r\n [selectedValues]=\"value\" \r\n [remoteOperation]=\"remoteOperation\"\r\n [allowSearch]=\"allowSearch\" \r\n [allowNull]=\"allowNull\"\r\n [readonly]=\"readonly\"\r\n [disabled]=\"disabled\"\r\n (selectionChanged)=\"handleValueChange($event)\">\r\n <ax-data-source [provideData]=\"provideData\">\r\n </ax-data-source>\r\n <ax-validation [rules]=\"validation?.rules\">\r\n </ax-validation>\r\n</ax-select-box>"
|
|
60
70
|
}),
|
|
61
71
|
__metadata("design:paramtypes", [ChangeDetectorRef])
|
|
62
72
|
], AXSelectBoxPropertyEditorComponent);
|
|
63
73
|
export { AXSelectBoxPropertyEditorComponent };
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0Ym94LmVkaXRvci5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BhY29yZXgvY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImxpYi9wcm9wZXJ0eS1lZGl0b3IvZWRpdG9ycy9zZWxlY3Rib3gtZWRpdG9yL3NlbGVjdGJveC5lZGl0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUV2RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUs5RSxJQUFhLGtDQUFrQyxHQUEvQyxNQUFhLGtDQUFtQyxTQUFRLHdCQUE2QjtJQWlDakYsWUFBc0IsR0FBc0I7UUFDeEMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBRE8sUUFBRyxHQUFILEdBQUcsQ0FBbUI7UUE5QjVDLGVBQVUsR0FBVyxJQUFJLENBQUM7UUFDMUIsY0FBUyxHQUFXLE1BQU0sQ0FBQztRQUMzQixrQkFBYSxHQUFXLFFBQVEsQ0FBQztRQUNqQyxzQkFBaUIsR0FBVyxPQUFPLENBQUM7UUFDcEMsZ0JBQVcsR0FBWSxJQUFJLENBQUM7UUFDNUIsY0FBUyxHQUFZLEtBQUssQ0FBQztRQUMzQixhQUFRLEdBQVksS0FBSyxDQUFDO1FBQzFCLFVBQUssR0FBUSxFQUFFLENBQUM7UUFDaEIsb0JBQWUsR0FBRyxLQUFLLENBQUM7UUFtQ3hCLGdCQUFXLEdBQUcsQ0FBQyxDQUFDLEVBQWdCLEVBQUU7WUFDOUIsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFO2dCQUMzQixNQUFNLElBQUksR0FBRyxHQUFHLEVBQUU7b0JBQ2QsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRTt3QkFDM0IsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztxQkFDL0I7eUJBQ0ksSUFBSSxPQUFPLElBQUksQ0FBQyxLQUFLLEtBQUssVUFBVSxFQUFFO3dCQUN2QyxNQUFNLENBQUMsR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFBO3dCQUM1QyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO3FCQUMxQjt5QkFDSTt3QkFDRCxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUM7cUJBQ2Y7Z0JBQ0wsQ0FBQyxDQUFDO2dCQUNGLE1BQU0sTUFBTSxHQUFHLFdBQVcsQ0FBQyxHQUFHLEVBQUU7b0JBQzVCLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRTt3QkFDaEIsSUFBSSxFQUFFLENBQUM7d0JBQ1AsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDO3FCQUN6QjtnQkFDTCxDQUFDLEVBQUMsRUFBRSxDQUFDLENBQUM7WUFDVixDQUFDLENBQUMsQ0FBQztRQUNQLENBQUMsQ0FBQTtJQWhDRCxDQUFDO0lBZEQsSUFBVyxNQUFNO1FBQ2IsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3hCLENBQUM7SUFDRCxJQUFXLE1BQU0sQ0FBQyxDQUFNOztRQUNwQixJQUFJLENBQUMsT0FBTyxHQUFHLENBQUMsQ0FBQztRQUNqQixJQUFJLElBQUksQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRTtZQUM5QixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQztZQUNsQixNQUFBLElBQUksQ0FBQyxTQUFTLDBDQUFFLE9BQU8sR0FBRztTQUM3QjtJQUNMLENBQUM7SUFPRCxpQkFBaUIsQ0FBQyxDQUFNO1FBQ3BCLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDOUMsQ0FBQztJQUVELGVBQWU7UUFDWCxJQUFJLENBQUMseUJBQXlCLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQy9DLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNsQyxDQUFDO0NBd0JKLENBQUE7O1lBbkM4QixpQkFBaUI7O0FBakI1QztJQURDLFNBQVMsQ0FBQyxvQkFBb0IsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsQ0FBQzs4QkFDdkMsb0JBQW9CO3FFQUFDO0FBaEJ2QixrQ0FBa0M7SUFIOUMsU0FBUyxDQUFDO1FBQ1AsbXFCQUFzQztLQUN6QyxDQUFDO3FDQWtDNkIsaUJBQWlCO0dBakNuQyxrQ0FBa0MsQ0FvRTlDO1NBcEVZLGtDQUFrQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBDaGFuZ2VEZXRlY3RvclJlZiwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFYUHJvcGVyeUVkaXRvckNvbXBvbmVudCB9IGZyb20gJy4uLy4uL3Byb3BlcnR5LWVkaXRvci5jbGFzcyc7XHJcbmltcG9ydCB7IEFYVmFsaWRhdGlvbiB9IGZyb20gJy4uLy4uLy4uL3ZhbGlkYXRpb24vdmFsaWRhdGlvbi5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBBWFNlbGVjdEJveENvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL3NlbGVjdGJveC9zZWxlY3Rib3guY29tcG9uZW50JztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgdGVtcGxhdGVVcmw6ICcuL3NlbGVjdGJveC5lZGl0b3IuaHRtbCcsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBWFNlbGVjdEJveFByb3BlcnR5RWRpdG9yQ29tcG9uZW50IGV4dGVuZHMgQVhQcm9wZXJ5RWRpdG9yQ29tcG9uZW50PGFueT4gIHtcclxuXHJcblxyXG4gICAgdmFsdWVGaWVsZDogc3RyaW5nID0gJ2lkJztcclxuICAgIHRleHRGaWVsZDogc3RyaW5nID0gJ3RleHQnO1xyXG4gICAgc2VsZWN0aW9uTW9kZTogc3RyaW5nID0gJ3NpbmdsZSc7XHJcbiAgICBzZWxlY3Rpb25EYXRhTW9kZTogc3RyaW5nID0gJ3ZhbHVlJztcclxuICAgIGFsbG93U2VhcmNoOiBib29sZWFuID0gdHJ1ZTtcclxuICAgIGFsbG93TnVsbDogYm9vbGVhbiA9IGZhbHNlO1xyXG4gICAgZGlzYWJsZWQ6IGJvb2xlYW4gPSBmYWxzZTtcclxuICAgIGl0ZW1zOiBhbnkgPSBbXTtcclxuICAgIHJlbW90ZU9wZXJhdGlvbiA9IGZhbHNlO1xyXG5cclxuICAgIHZhbGlkYXRpb246IEFYVmFsaWRhdGlvbjtcclxuXHJcbiAgICBAVmlld0NoaWxkKEFYU2VsZWN0Qm94Q29tcG9uZW50LCB7IHN0YXRpYzogdHJ1ZSB9KVxyXG4gICAgc2VsZWN0Qm94OiBBWFNlbGVjdEJveENvbXBvbmVudDtcclxuXHJcblxyXG5cclxuICAgIHByaXZhdGUgX2ZpbHRlcjogYW55O1xyXG4gICAgcHVibGljIGdldCBmaWx0ZXIoKTogYW55IHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fZmlsdGVyO1xyXG4gICAgfVxyXG4gICAgcHVibGljIHNldCBmaWx0ZXIodjogYW55KSB7XHJcbiAgICAgICAgdGhpcy5fZmlsdGVyID0gdjtcclxuICAgICAgICBpZiAodGhpcy52YWx1ZSAmJiB0aGlzLmluaXRpYXRlZCkge1xyXG4gICAgICAgICAgICB0aGlzLnZhbHVlID0gbnVsbDtcclxuICAgICAgICAgICAgdGhpcy5zZWxlY3RCb3g/LnJlZnJlc2goKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG5cclxuICAgIGNvbnN0cnVjdG9yKHByb3RlY3RlZCBjZHI6IENoYW5nZURldGVjdG9yUmVmKSB7XHJcbiAgICAgICAgc3VwZXIoY2RyKTtcclxuICAgIH1cclxuXHJcbiAgICBoYW5kbGVWYWx1ZUNoYW5nZShlOiBhbnkpIHtcclxuICAgICAgICBzdXBlci5oYW5kbGVWYWx1ZUNoYW5nZShlLnNlbGVjdGVkVmFsdWVzKTtcclxuICAgIH1cclxuXHJcbiAgICBuZ0FmdGVyVmlld0luaXQoKSB7XHJcbiAgICAgICAgdGhpcy5yZWdpc3RlckZvclZhbGlkYXRpb25Gb3JtKHRoaXMuc2VsZWN0Qm94KTtcclxuICAgICAgICB0aGlzLm9uUmVuZGVyQ29tcGxldGVkLmVtaXQoKTtcclxuICAgIH1cclxuXHJcbiAgICBwcm92aWRlRGF0YSA9IChlKTogUHJvbWlzZTxhbnk+ID0+IHtcclxuICAgICAgICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUpID0+IHtcclxuICAgICAgICAgICAgY29uc3QgZnVuYyA9ICgpID0+IHtcclxuICAgICAgICAgICAgICAgIGlmIChBcnJheS5pc0FycmF5KHRoaXMuaXRlbXMpKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgcmVzb2x2ZSh0aGlzLml0ZW1zLnNsaWNlKCkpO1xyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgZWxzZSBpZiAodHlwZW9mIHRoaXMuaXRlbXMgPT09ICdmdW5jdGlvbicpIHtcclxuICAgICAgICAgICAgICAgICAgICBjb25zdCBhID0gT2JqZWN0LmFzc2lnbihlLCB7IHNlbmRlcjogdGhpcyB9KVxyXG4gICAgICAgICAgICAgICAgICAgIHJlc29sdmUodGhpcy5pdGVtcyhhKSk7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICBlbHNlIHtcclxuICAgICAgICAgICAgICAgICAgICByZXNvbHZlKFtdKTtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgfTtcclxuICAgICAgICAgICAgY29uc3QgaW50VmFsID0gc2V0SW50ZXJ2YWwoKCkgPT4ge1xyXG4gICAgICAgICAgICAgICAgaWYgKHRoaXMuaW5pdGlhdGVkKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgZnVuYygpO1xyXG4gICAgICAgICAgICAgICAgICAgIGNsZWFySW50ZXJ2YWwoaW50VmFsKTtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgfSw1MCk7XHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcbn1cclxuIl19
|
|
@@ -10,7 +10,7 @@ let AXSwitchPropertyEditorComponent = class AXSwitchPropertyEditorComponent exte
|
|
|
10
10
|
super.handleValueChange(e.value);
|
|
11
11
|
}
|
|
12
12
|
ngAfterViewInit() {
|
|
13
|
-
this.
|
|
13
|
+
this.onRenderCompleted.emit();
|
|
14
14
|
}
|
|
15
15
|
};
|
|
16
16
|
AXSwitchPropertyEditorComponent.ctorParameters = () => [
|
|
@@ -25,4 +25,4 @@ AXSwitchPropertyEditorComponent = __decorate([
|
|
|
25
25
|
__metadata("design:paramtypes", [ChangeDetectorRef])
|
|
26
26
|
], AXSwitchPropertyEditorComponent);
|
|
27
27
|
export { AXSwitchPropertyEditorComponent };
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyLmVkaXRvci5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BhY29yZXgvY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImxpYi9wcm9wZXJ0eS1lZGl0b3IvZWRpdG9ycy9zd2l0Y2gtZWRpdG9yL251bWJlci5lZGl0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQU92RSxJQUFhLCtCQUErQixHQUE1QyxNQUFhLCtCQUFnQyxTQUFRLHdCQUFpQztJQUlsRixZQUFzQixHQUFzQjtRQUN4QyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFETyxRQUFHLEdBQUgsR0FBRyxDQUFtQjtJQUU1QyxDQUFDO0lBR0QsaUJBQWlCLENBQUMsQ0FBTTtRQUNwQixLQUFLLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFFRCxlQUFlO1FBQ1gsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2xDLENBQUM7Q0FFSixDQUFBOztZQWI4QixpQkFBaUI7O0FBSm5DLCtCQUErQjtJQUwzQyxTQUFTLENBQUM7UUFDUCxRQUFRLEVBQUU7O0tBRVQ7S0FDSixDQUFDO3FDQUs2QixpQkFBaUI7R0FKbkMsK0JBQStCLENBaUIzQztTQWpCWSwrQkFBK0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgQ2hhbmdlRGV0ZWN0b3JSZWYsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBWFByb3BlcnlFZGl0b3JDb21wb25lbnQgfSBmcm9tICcuLi8uLi9wcm9wZXJ0eS1lZGl0b3IuY2xhc3MnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICB0ZW1wbGF0ZTogYFxyXG4gICAgICAgIDxheC1zd2l0Y2ggKG9uVmFsdWVDaGFuZ2VkKT1cImhhbmRsZVZhbHVlQ2hhbmdlKCRldmVudClcIiBbdmFsdWVdPVwidmFsdWVcIj48L2F4LXN3aXRjaD5cclxuICAgIGAsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBWFN3aXRjaFByb3BlcnR5RWRpdG9yQ29tcG9uZW50IGV4dGVuZHMgQVhQcm9wZXJ5RWRpdG9yQ29tcG9uZW50PGJvb2xlYW4+ICB7XHJcblxyXG5cclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihwcm90ZWN0ZWQgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge1xyXG4gICAgICAgIHN1cGVyKGNkcik7XHJcbiAgICB9XHJcblxyXG5cclxuICAgIGhhbmRsZVZhbHVlQ2hhbmdlKGU6IGFueSkge1xyXG4gICAgICAgIHN1cGVyLmhhbmRsZVZhbHVlQ2hhbmdlKGUudmFsdWUpO1xyXG4gICAgfVxyXG5cclxuICAgIG5nQWZ0ZXJWaWV3SW5pdCgpIHtcclxuICAgICAgICB0aGlzLm9uUmVuZGVyQ29tcGxldGVkLmVtaXQoKTtcclxuICAgIH1cclxuXHJcbn1cclxuIl19
|
|
@@ -13,7 +13,7 @@ let AXTextPropertyEditorComponent = class AXTextPropertyEditorComponent extends
|
|
|
13
13
|
}
|
|
14
14
|
ngAfterViewInit() {
|
|
15
15
|
this.registerForValidationForm(this.textBox);
|
|
16
|
-
this.
|
|
16
|
+
this.onRenderCompleted.emit();
|
|
17
17
|
}
|
|
18
18
|
};
|
|
19
19
|
AXTextPropertyEditorComponent.ctorParameters = () => [
|
|
@@ -30,4 +30,4 @@ AXTextPropertyEditorComponent = __decorate([
|
|
|
30
30
|
__metadata("design:paramtypes", [ChangeDetectorRef])
|
|
31
31
|
], AXTextPropertyEditorComponent);
|
|
32
32
|
export { AXTextPropertyEditorComponent };
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC5lZGl0b3IuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AYWNvcmV4L2NvbXBvbmVudHMvIiwic291cmNlcyI6WyJsaWIvcHJvcGVydHktZWRpdG9yL2VkaXRvcnMvdGV4dC1lZGl0b3IvdGV4dC5lZGl0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUcsaUJBQWlCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBRXhFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBS3ZFLElBQWEsNkJBQTZCLEdBQTFDLE1BQWEsNkJBQThCLFNBQVEsd0JBQWdDO0lBVy9FLFlBQXNCLEdBQXNCO1FBQ3hDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQURPLFFBQUcsR0FBSCxHQUFHLENBQW1CO1FBSDVDLGdCQUFXLEdBQVksS0FBSyxDQUFDO0lBSzdCLENBQUM7SUFHRCxpQkFBaUIsQ0FBQyxDQUFNO1FBQ3BCLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUdELGVBQWU7UUFDWCxJQUFJLENBQUMseUJBQXlCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzdDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNsQyxDQUFDO0NBRUosQ0FBQTs7WUFmOEIsaUJBQWlCOztBQVA1QztJQURDLFNBQVMsQ0FBQyxrQkFBa0IsQ0FBQzs4QkFDYixrQkFBa0I7OERBQUM7QUFKM0IsNkJBQTZCO0lBSHpDLFNBQVMsQ0FBQztRQUNQLDhPQUFpQztLQUNwQyxDQUFDO3FDQVk2QixpQkFBaUI7R0FYbkMsNkJBQTZCLENBMEJ6QztTQTFCWSw2QkFBNkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsICBDaGFuZ2VEZXRlY3RvclJlZiwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFYVGV4dEJveENvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL3RleHRib3gvdGV4dGJveC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBBWFZhbGlkYXRpb24gfSBmcm9tICcuLi8uLi8uLi92YWxpZGF0aW9uL3ZhbGlkYXRpb24uY29tcG9uZW50JztcclxuaW1wb3J0IHsgQVhQcm9wZXJ5RWRpdG9yQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vcHJvcGVydHktZWRpdG9yLmNsYXNzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgdGVtcGxhdGVVcmw6ICcuL3RleHQuZWRpdG9yLmh0bWwnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQVhUZXh0UHJvcGVydHlFZGl0b3JDb21wb25lbnQgZXh0ZW5kcyBBWFByb3BlcnlFZGl0b3JDb21wb25lbnQ8c3RyaW5nPiAge1xyXG5cclxuXHJcbiAgICBAVmlld0NoaWxkKEFYVGV4dEJveENvbXBvbmVudClcclxuICAgIHByaXZhdGUgdGV4dEJveDogQVhUZXh0Qm94Q29tcG9uZW50O1xyXG5cclxuXHJcbiAgICB2YWxpZGF0aW9uOiBBWFZhbGlkYXRpb247XHJcbiAgICBjbGVhckJ1dHRvbjogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihwcm90ZWN0ZWQgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge1xyXG4gICAgICAgIHN1cGVyKGNkcik7XHJcbiAgICB9XHJcblxyXG5cclxuICAgIGhhbmRsZVZhbHVlQ2hhbmdlKGU6IGFueSkge1xyXG4gICAgICAgIHN1cGVyLmhhbmRsZVZhbHVlQ2hhbmdlKGUudmFsdWUpO1xyXG4gICAgfVxyXG5cclxuXHJcbiAgICBuZ0FmdGVyVmlld0luaXQoKSB7XHJcbiAgICAgICAgdGhpcy5yZWdpc3RlckZvclZhbGlkYXRpb25Gb3JtKHRoaXMudGV4dEJveCk7XHJcbiAgICAgICAgdGhpcy5vblJlbmRlckNvbXBsZXRlZC5lbWl0KCk7XHJcbiAgICB9XHJcblxyXG59XHJcbiJdfQ==
|
|
@@ -14,8 +14,8 @@ let AXTimePropertyEditorComponent = class AXTimePropertyEditorComponent extends
|
|
|
14
14
|
super.handleValueChange((_a = e.value) === null || _a === void 0 ? void 0 : _a.time);
|
|
15
15
|
}
|
|
16
16
|
ngAfterViewInit() {
|
|
17
|
-
this.initiated = true;
|
|
18
17
|
this.registerForValidationForm(this.time);
|
|
18
|
+
this.onRenderCompleted.emit();
|
|
19
19
|
}
|
|
20
20
|
};
|
|
21
21
|
AXTimePropertyEditorComponent.ctorParameters = () => [
|
|
@@ -37,4 +37,4 @@ AXTimePropertyEditorComponent = __decorate([
|
|
|
37
37
|
__metadata("design:paramtypes", [ChangeDetectorRef])
|
|
38
38
|
], AXTimePropertyEditorComponent);
|
|
39
39
|
export { AXTimePropertyEditorComponent };
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS5lZGl0b3IuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AYWNvcmV4L2NvbXBvbmVudHMvIiwic291cmNlcyI6WyJsaWIvcHJvcGVydHktZWRpdG9yL2VkaXRvcnMvdGltZS1lZGl0b3IvdGltZS5lZGl0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRixPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUVuRixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQVV2RSxJQUFhLDZCQUE2QixHQUExQyxNQUFhLDZCQUE4QixTQUFRLHdCQUFnQztJQVcvRSxZQUFzQixHQUFzQjtRQUN4QyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFETyxRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQU41QyxtQkFBYyxHQUFZLEtBQUssQ0FBQztRQUNoQyxnQkFBVyxHQUFZLEtBQUssQ0FBQztJQU83QixDQUFDO0lBRUQsaUJBQWlCLENBQUMsQ0FBTTs7UUFDcEIsS0FBSyxDQUFDLGlCQUFpQixPQUFDLENBQUMsQ0FBQyxLQUFLLDBDQUFFLElBQUksQ0FBQyxDQUFDO0lBQzNDLENBQUM7SUFFRCxlQUFlO1FBQ1gsSUFBSSxDQUFDLHlCQUF5QixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMxQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDbEMsQ0FBQztDQUVKLENBQUE7O1lBYjhCLGlCQUFpQjs7QUFGNUM7SUFEQyxTQUFTLENBQUMscUJBQXFCLENBQUM7OEJBQ25CLHFCQUFxQjsyREFBQztBQVQzQiw2QkFBNkI7SUFSekMsU0FBUyxDQUFDO1FBQ1AsUUFBUSxFQUFFOzs7OztVQUtKO0tBQ1QsQ0FBQztxQ0FZNkIsaUJBQWlCO0dBWG5DLDZCQUE2QixDQXdCekM7U0F4QlksNkJBQTZCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIENoYW5nZURldGVjdG9yUmVmLCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQVhEYXRlUGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vZGF0ZS1waWNrZXIvZGF0ZS1waWNrZXIuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQVhWYWxpZGF0aW9uIH0gZnJvbSAnLi4vLi4vLi4vdmFsaWRhdGlvbi92YWxpZGF0aW9uLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEFYUHJvcGVyeUVkaXRvckNvbXBvbmVudCB9IGZyb20gJy4uLy4uL3Byb3BlcnR5LWVkaXRvci5jbGFzcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHRlbXBsYXRlOiBgXHJcbiAgICA8YXgtdGltZS1waWNrZXIgW3Nob3dDdXJlbnRUaW1lXT1cInNob3dDdXJlbnRUaW1lXCIgW3RpbWVUeXBlXT1cInRpbWVUeXBlXCIgW2FsbG93Q2xlYXJdPVwiY2xlYXJCdXR0b25cIiAob25WYWx1ZUNoYW5nZWQpPVwiaGFuZGxlVmFsdWVDaGFuZ2UoJGV2ZW50KVwiPlxyXG4gICAgICAgIDxheC12YWxpZGF0aW9uIFtydWxlc109XCJ2YWxpZGF0aW9uPy5ydWxlc1wiPlxyXG4gICAgICAgIDwvYXgtdmFsaWRhdGlvbj5cclxuICAgIDwvYXgtdGltZS1waWNrZXI+XHJcbiAgICAgICAgIGAsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBWFRpbWVQcm9wZXJ0eUVkaXRvckNvbXBvbmVudCBleHRlbmRzIEFYUHJvcGVyeUVkaXRvckNvbXBvbmVudDxTdHJpbmc+ICB7XHJcblxyXG5cclxuICAgIHRpbWVUeXBlOiBhbnk7XHJcbiAgICB2YWxpZGF0aW9uOiBBWFZhbGlkYXRpb247XHJcbiAgICBzaG93Q3VyZW50VGltZTogYm9vbGVhbiA9IGZhbHNlO1xyXG4gICAgY2xlYXJCdXR0b246IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgICBAVmlld0NoaWxkKEFYRGF0ZVBpY2tlckNvbXBvbmVudClcclxuICAgIHByaXZhdGUgdGltZTogQVhEYXRlUGlja2VyQ29tcG9uZW50O1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKHByb3RlY3RlZCBjZHI6IENoYW5nZURldGVjdG9yUmVmKSB7XHJcbiAgICAgICAgc3VwZXIoY2RyKTtcclxuICAgIH1cclxuXHJcbiAgICBoYW5kbGVWYWx1ZUNoYW5nZShlOiBhbnkpIHtcclxuICAgICAgICBzdXBlci5oYW5kbGVWYWx1ZUNoYW5nZShlLnZhbHVlPy50aW1lKTtcclxuICAgIH1cclxuXHJcbiAgICBuZ0FmdGVyVmlld0luaXQoKSB7XHJcbiAgICAgICAgdGhpcy5yZWdpc3RlckZvclZhbGlkYXRpb25Gb3JtKHRoaXMudGltZSk7XHJcbiAgICAgICAgdGhpcy5vblJlbmRlckNvbXBsZXRlZC5lbWl0KCk7XHJcbiAgICB9XHJcblxyXG59XHJcbiJdfQ==
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
|
2
|
-
import { Directive, ViewContainerRef, ComponentFactoryResolver, Input, Output, EventEmitter } from '@angular/core';
|
|
3
|
-
import { AXObjectUtil, AXRenderService, getPropByPath } from '@acorex/core';
|
|
2
|
+
import { Directive, ViewContainerRef, ComponentFactoryResolver, Input, Output, EventEmitter, KeyValueDiffer, KeyValueDiffers } from '@angular/core';
|
|
3
|
+
import { AXEventService, AXObjectUtil, AXRenderService, getPropByPath, setPropByPath } from '@acorex/core';
|
|
4
4
|
import { AXValidationFormComponent } from '../validation/validation-form.component';
|
|
5
5
|
let AXPropertyEditorRendererDirective = class AXPropertyEditorRendererDirective {
|
|
6
|
-
constructor(target, componentFactoryResolver, renderService) {
|
|
6
|
+
constructor(target, componentFactoryResolver, renderService, eventService) {
|
|
7
7
|
this.target = target;
|
|
8
8
|
this.componentFactoryResolver = componentFactoryResolver;
|
|
9
9
|
this.renderService = renderService;
|
|
10
|
-
this.
|
|
10
|
+
this.eventService = eventService;
|
|
11
|
+
this._context = {};
|
|
11
12
|
this.onValueChange = new EventEmitter();
|
|
12
13
|
}
|
|
13
14
|
get context() {
|
|
@@ -15,9 +16,6 @@ let AXPropertyEditorRendererDirective = class AXPropertyEditorRendererDirective
|
|
|
15
16
|
}
|
|
16
17
|
set context(v) {
|
|
17
18
|
this._context = v;
|
|
18
|
-
if (v && this.instance) {
|
|
19
|
-
this.assignProps();
|
|
20
|
-
}
|
|
21
19
|
}
|
|
22
20
|
clear() {
|
|
23
21
|
this.instance.value = null;
|
|
@@ -32,52 +30,98 @@ let AXPropertyEditorRendererDirective = class AXPropertyEditorRendererDirective
|
|
|
32
30
|
const cmpRef = this.target.createComponent(factory);
|
|
33
31
|
this.instance = cmpRef.instance;
|
|
34
32
|
this.subscription = this.instance.valueChange.subscribe(value => {
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
33
|
+
var _a, _b;
|
|
34
|
+
this.property.value = value;
|
|
35
|
+
this.onValueChange.emit(this.property);
|
|
36
|
+
if ((_b = (_a = this.property) === null || _a === void 0 ? void 0 : _a.property) === null || _b === void 0 ? void 0 : _b.name) {
|
|
37
|
+
setTimeout(() => {
|
|
38
|
+
this.eventService.broadcast(`props-${this.groupId}-${this.property.property.name}`, this.property);
|
|
39
|
+
}, 0);
|
|
38
40
|
}
|
|
39
41
|
});
|
|
40
|
-
|
|
42
|
+
this.watchChanges();
|
|
43
|
+
this.assignProps();
|
|
44
|
+
this.instance.value = this.property.value;
|
|
45
|
+
// this.instance.onRenderCompleted.subscribe(() => {
|
|
46
|
+
// });
|
|
41
47
|
if (this.validationForm) {
|
|
42
48
|
this.instance.validatableComponentRegistered.subscribe(v => {
|
|
43
49
|
this.validationForm.addWidget(v);
|
|
44
50
|
});
|
|
45
51
|
}
|
|
46
|
-
//
|
|
47
|
-
//setTimeout(() => {
|
|
48
|
-
this.instance.readonly = this.readonly;
|
|
49
|
-
this.assignProps();
|
|
50
|
-
this.instance.value = this.property.value;
|
|
51
|
-
this.instance.initiat();
|
|
52
|
-
cmpRef.changeDetectorRef.markForCheck();
|
|
53
|
-
//});
|
|
54
52
|
}
|
|
55
53
|
});
|
|
56
54
|
}
|
|
55
|
+
watchChanges() {
|
|
56
|
+
var _a, _b;
|
|
57
|
+
const varsRegx = /((\$\{[a-zA-Z_0-9]+\})+)/gm;
|
|
58
|
+
const varNameRegx = /[a-zA-Z_0-9]+/gm;
|
|
59
|
+
const options = this.property.property.editorOptions;
|
|
60
|
+
if (!options) {
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
for (const p in options) {
|
|
64
|
+
if (options.hasOwnProperty(p)) {
|
|
65
|
+
const opt = options[p];
|
|
66
|
+
const vars = typeof opt === 'string' ? (_a = opt) === null || _a === void 0 ? void 0 : _a.match(varsRegx) : [];
|
|
67
|
+
// bind the props
|
|
68
|
+
if ((_b = vars) === null || _b === void 0 ? void 0 : _b.length) {
|
|
69
|
+
vars.forEach(v => {
|
|
70
|
+
var _a;
|
|
71
|
+
const path = ((_a = v.match(varNameRegx)) === null || _a === void 0 ? void 0 : _a.length) ? v.match(varNameRegx)[0] : null;
|
|
72
|
+
if (path) {
|
|
73
|
+
this.eventService.on(`props-${this.groupId}-${path}`, (e) => {
|
|
74
|
+
let execCode = opt.slice();
|
|
75
|
+
const params = {};
|
|
76
|
+
vars.forEach(vv => {
|
|
77
|
+
var _a;
|
|
78
|
+
const p2 = ((_a = vv.match(varNameRegx)) === null || _a === void 0 ? void 0 : _a.length) ? vv.match(varNameRegx)[0] : null;
|
|
79
|
+
params[p2] = AXObjectUtil.deepCopy(this.context[p2]) || null;
|
|
80
|
+
execCode = execCode.replace(vv, `__params__.${p2}`);
|
|
81
|
+
});
|
|
82
|
+
const func = new Function('__params__', `try { return ${execCode}} catch(e){ console.log(e); return null; }`);
|
|
83
|
+
const val = func(params);
|
|
84
|
+
const keys = p.split('.');
|
|
85
|
+
const prop = Object.assign({}, this.instance[keys[0]]);
|
|
86
|
+
if (keys.length > 1) {
|
|
87
|
+
this.instance[keys[0]] = setPropByPath(prop, p, val);
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
setPropByPath(this.instance, p, val);
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
// else {
|
|
97
|
+
// this.assignProps();
|
|
98
|
+
// }
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
57
102
|
assignProps() {
|
|
103
|
+
var _a, _b;
|
|
58
104
|
const options = this.property.property.editorOptions;
|
|
59
105
|
if (!options) {
|
|
60
106
|
return;
|
|
61
107
|
}
|
|
108
|
+
const varsRegx = /((\$\{[a-zA-Z_0-9]+\})+)/gm;
|
|
62
109
|
for (const p in options) {
|
|
63
110
|
if (options.hasOwnProperty(p)) {
|
|
64
111
|
const opt = options[p];
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
if (val) {
|
|
69
|
-
this.instance[p] = typeof val === 'function' ? val({ data: this.context, host: this.host }, this.property) : val;
|
|
70
|
-
}
|
|
112
|
+
const vars = typeof opt === 'string' ? (_a = opt) === null || _a === void 0 ? void 0 : _a.match(varsRegx) : [];
|
|
113
|
+
if ((_b = vars) === null || _b === void 0 ? void 0 : _b.length) {
|
|
114
|
+
continue;
|
|
71
115
|
}
|
|
72
116
|
else {
|
|
73
|
-
const
|
|
74
|
-
if (
|
|
75
|
-
|
|
76
|
-
this.instance
|
|
117
|
+
const val = typeof opt === 'function' ? opt({ data: this.context, host: this.host }, this.property) : opt;
|
|
118
|
+
if (val instanceof Promise) {
|
|
119
|
+
val.then(v => {
|
|
120
|
+
setPropByPath(this.instance, p, val);
|
|
77
121
|
});
|
|
78
122
|
}
|
|
79
123
|
else {
|
|
80
|
-
this.instance
|
|
124
|
+
setPropByPath(this.instance, p, val);
|
|
81
125
|
}
|
|
82
126
|
}
|
|
83
127
|
}
|
|
@@ -92,16 +136,13 @@ let AXPropertyEditorRendererDirective = class AXPropertyEditorRendererDirective
|
|
|
92
136
|
AXPropertyEditorRendererDirective.ctorParameters = () => [
|
|
93
137
|
{ type: ViewContainerRef },
|
|
94
138
|
{ type: ComponentFactoryResolver },
|
|
95
|
-
{ type: AXRenderService }
|
|
139
|
+
{ type: AXRenderService },
|
|
140
|
+
{ type: AXEventService }
|
|
96
141
|
];
|
|
97
142
|
__decorate([
|
|
98
143
|
Input(),
|
|
99
144
|
__metadata("design:type", Object)
|
|
100
145
|
], AXPropertyEditorRendererDirective.prototype, "property", void 0);
|
|
101
|
-
__decorate([
|
|
102
|
-
Input(),
|
|
103
|
-
__metadata("design:type", Boolean)
|
|
104
|
-
], AXPropertyEditorRendererDirective.prototype, "readonly", void 0);
|
|
105
146
|
__decorate([
|
|
106
147
|
Input(),
|
|
107
148
|
__metadata("design:type", AXValidationFormComponent)
|
|
@@ -115,6 +156,10 @@ __decorate([
|
|
|
115
156
|
Input(),
|
|
116
157
|
__metadata("design:type", Object)
|
|
117
158
|
], AXPropertyEditorRendererDirective.prototype, "host", void 0);
|
|
159
|
+
__decorate([
|
|
160
|
+
Input(),
|
|
161
|
+
__metadata("design:type", Object)
|
|
162
|
+
], AXPropertyEditorRendererDirective.prototype, "groupId", void 0);
|
|
118
163
|
__decorate([
|
|
119
164
|
Output(),
|
|
120
165
|
__metadata("design:type", EventEmitter)
|
|
@@ -125,7 +170,8 @@ AXPropertyEditorRendererDirective = __decorate([
|
|
|
125
170
|
}),
|
|
126
171
|
__metadata("design:paramtypes", [ViewContainerRef,
|
|
127
172
|
ComponentFactoryResolver,
|
|
128
|
-
AXRenderService
|
|
173
|
+
AXRenderService,
|
|
174
|
+
AXEventService])
|
|
129
175
|
], AXPropertyEditorRendererDirective);
|
|
130
176
|
export { AXPropertyEditorRendererDirective };
|
|
131
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-editor-renderer.directive.js","sourceRoot":"ng://@acorex/components/","sources":["lib/property-editor/property-editor-renderer.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ViewContainerRef, ComponentFactoryResolver, Input, Output, EventEmitter } from '@angular/core';\r\nimport { AXProperyEditorComponent, AXProperyEditorValueChangeEvent, AXPropertyConfig } from './property-editor.class';\r\nimport { AXObjectUtil, AXRenderService, getPropByPath } from '@acorex/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { AXValidationFormComponent } from '../validation/validation-form.component';\r\n\r\n@Directive({\r\n    selector: '[ax-property-editor-renderer]',\r\n})\r\nexport class AXPropertyEditorRendererDirective {\r\n\r\n    private instance: AXProperyEditorComponent<any>;\r\n\r\n\r\n    @Input()\r\n    property: AXPropertyConfig;\r\n\r\n\r\n    @Input()\r\n    readonly: boolean = false;\r\n\r\n    @Input()\r\n    validationForm: AXValidationFormComponent;\r\n\r\n\r\n\r\n    private _context: any;\r\n    @Input()\r\n    public get context(): any {\r\n        return this._context;\r\n    }\r\n    public set context(v: any) {\r\n        this._context = v;\r\n        if (v && this.instance) {\r\n            this.assignProps();\r\n        }\r\n    }\r\n\r\n    @Input()\r\n    host: any;\r\n\r\n\r\n    @Output()\r\n    onValueChange: EventEmitter<AXProperyEditorValueChangeEvent> = new EventEmitter<AXProperyEditorValueChangeEvent>();\r\n\r\n    private subscription: Subscription;\r\n\r\n    constructor(\r\n        private target: ViewContainerRef,\r\n        private componentFactoryResolver: ComponentFactoryResolver,\r\n        private renderService: AXRenderService\r\n    ) {\r\n\r\n    }\r\n\r\n\r\n    clear() {\r\n        this.instance.value = null;\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.createComponent();\r\n    }\r\n\r\n\r\n\r\n    createComponent() {\r\n        this.renderService.findLoadedComponentByRoute(this.property.property.editorClass).then(c => {\r\n            if (c) {\r\n                const factory = this.componentFactoryResolver.resolveComponentFactory(c.component);\r\n                const cmpRef = this.target.createComponent(factory);\r\n                this.instance = cmpRef.instance as AXProperyEditorComponent<any>;\r\n                this.subscription = this.instance.valueChange.subscribe(value => {\r\n                    if (this.instance.initiated === true) {\r\n                        this.property.value = value;\r\n                        this.onValueChange.emit(this.property);\r\n                    }\r\n                });\r\n                //          \r\n                if (this.validationForm) {\r\n                    this.instance.validatableComponentRegistered.subscribe(v => {\r\n                        this.validationForm.addWidget(v);\r\n                    });\r\n                }\r\n                //\r\n                //setTimeout(() => {\r\n                    this.instance.readonly = this.readonly;\r\n                    this.assignProps();\r\n                    this.instance.value = this.property.value;\r\n                    this.instance.initiat();\r\n                    cmpRef.changeDetectorRef.markForCheck();\r\n                //});\r\n            }\r\n        });\r\n    }\r\n\r\n\r\n    private assignProps() {\r\n        const options = this.property.property.editorOptions;\r\n        if (!options) {\r\n            return;\r\n        }\r\n        for (const p in options) {\r\n            if (options.hasOwnProperty(p)) {\r\n                const opt = options[p];\r\n                if (typeof opt === 'string' && opt.startsWith('$$')) {\r\n                    const key = opt.substring(2);\r\n                    const val = getPropByPath(this.context, key);\r\n                    if (val) {\r\n                        this.instance[p] = typeof val === 'function' ? val({ data: this.context, host: this.host }, this.property) : val;\r\n                    }\r\n                }\r\n                else {\r\n                    const res = typeof opt === 'function' ? opt({ data: this.context, host: this.host }, this.property) : opt;\r\n                    if (res instanceof Promise) {\r\n                        res.then(v => {\r\n                            this.instance[p] = v;\r\n                        });\r\n                    }\r\n                    else {\r\n                        this.instance[p] = res;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        if (this.subscription) {\r\n            this.subscription.unsubscribe();\r\n        }\r\n    }\r\n}"]}
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-editor-renderer.directive.js","sourceRoot":"ng://@acorex/components/","sources":["lib/property-editor/property-editor-renderer.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ViewContainerRef, ComponentFactoryResolver, Input, Output, EventEmitter, KeyValueDiffer, KeyValueDiffers } from '@angular/core';\r\nimport { AXProperyEditorComponent, AXProperyEditorValueChangeEvent, AXPropertyConfig } from './property-editor.class';\r\nimport { AXEventService, AXObjectUtil, AXRenderService, getPropByPath, setPropByPath } from '@acorex/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { AXValidationFormComponent } from '../validation/validation-form.component';\r\n\r\n@Directive({\r\n    selector: '[ax-property-editor-renderer]',\r\n})\r\nexport class AXPropertyEditorRendererDirective {\r\n\r\n    private instance: AXProperyEditorComponent<any>;\r\n\r\n    @Input()\r\n    property: AXPropertyConfig;\r\n\r\n\r\n    @Input()\r\n    validationForm: AXValidationFormComponent;\r\n\r\n\r\n\r\n    private _context: any = {};\r\n    @Input()\r\n    public get context(): any {\r\n        return this._context;\r\n    }\r\n    public set context(v: any) {\r\n        this._context = v;\r\n    }\r\n\r\n    @Input()\r\n    host: any;\r\n\r\n    @Input()\r\n    groupId: any;\r\n\r\n\r\n    @Output()\r\n    onValueChange: EventEmitter<AXProperyEditorValueChangeEvent> = new EventEmitter<AXProperyEditorValueChangeEvent>();\r\n\r\n    private subscription: Subscription;\r\n\r\n    constructor(\r\n        private target: ViewContainerRef,\r\n        private componentFactoryResolver: ComponentFactoryResolver,\r\n        private renderService: AXRenderService,\r\n        private eventService: AXEventService\r\n    ) {\r\n\r\n    }\r\n\r\n\r\n    clear() {\r\n        this.instance.value = null;\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.createComponent();\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n    createComponent() {\r\n        this.renderService.findLoadedComponentByRoute(this.property.property.editorClass).then(c => {\r\n            if (c) {\r\n                const factory = this.componentFactoryResolver.resolveComponentFactory(c.component);\r\n                const cmpRef = this.target.createComponent(factory);\r\n                this.instance = cmpRef.instance as AXProperyEditorComponent<any>;\r\n                this.subscription = this.instance.valueChange.subscribe(value => {\r\n                    this.property.value = value;\r\n                    this.onValueChange.emit(this.property);\r\n                    if (this.property?.property?.name) {\r\n                        setTimeout(() => {\r\n                            this.eventService.broadcast(`props-${this.groupId}-${this.property.property.name}`, this.property);\r\n                        }, 0);\r\n                    }\r\n                });\r\n                this.watchChanges();\r\n                this.assignProps();\r\n                this.instance.value = this.property.value;\r\n\r\n                // this.instance.onRenderCompleted.subscribe(() => {\r\n                    \r\n                    \r\n                // });\r\n           \r\n                if (this.validationForm) {\r\n                    this.instance.validatableComponentRegistered.subscribe(v => {\r\n                        this.validationForm.addWidget(v);\r\n                    });\r\n                }\r\n            }\r\n        });\r\n    }\r\n\r\n\r\n    private watchChanges() {\r\n        const varsRegx = /((\\$\\{[a-zA-Z_0-9]+\\})+)/gm;\r\n        const varNameRegx = /[a-zA-Z_0-9]+/gm;\r\n        const options = this.property.property.editorOptions;\r\n        if (!options) {\r\n            return;\r\n        }\r\n        for (const p in options) {\r\n            if (options.hasOwnProperty(p)) {\r\n                const opt = options[p];\r\n                const vars = typeof opt === 'string' ? opt?.match(varsRegx) : [];\r\n                // bind the props\r\n                if (vars?.length) {\r\n                    vars.forEach(v => {\r\n                        const path = v.match(varNameRegx)?.length ? v.match(varNameRegx)[0] : null;\r\n                        if (path) {\r\n                            this.eventService.on(`props-${this.groupId}-${path}`, (e: AXPropertyConfig) => {\r\n                                let execCode = opt.slice();\r\n                                const params = {};\r\n                                vars.forEach(vv => {\r\n                                    const p2 = vv.match(varNameRegx)?.length ? vv.match(varNameRegx)[0] : null;\r\n                                    params[p2] = AXObjectUtil.deepCopy(this.context[p2]) || null;\r\n                                    execCode = execCode.replace(vv, `__params__.${p2}`);\r\n                                });\r\n\r\n                                const func = new Function('__params__', `try { return ${execCode}} catch(e){  console.log(e); return null;  }`);\r\n                                const val = func(params);\r\n\r\n                                const keys = p.split('.');\r\n                                const prop = Object.assign({}, this.instance[keys[0]]);\r\n                                if (keys.length > 1) {\r\n                                    this.instance[keys[0]] = setPropByPath(prop, p, val);\r\n                                }\r\n                                else {\r\n                                    setPropByPath(this.instance, p, val)\r\n                                }\r\n                            });\r\n                        }\r\n                    });\r\n                }\r\n                // else {\r\n                //    this.assignProps();\r\n                // }\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    private assignProps() {\r\n        const options = this.property.property.editorOptions;\r\n        if (!options) {\r\n            return;\r\n        }\r\n        const varsRegx = /((\\$\\{[a-zA-Z_0-9]+\\})+)/gm;\r\n        for (const p in options) {\r\n            if (options.hasOwnProperty(p)) {\r\n                const opt = options[p];\r\n                const vars = typeof opt === 'string' ? opt?.match(varsRegx) : [];\r\n                if (vars?.length) {\r\n                    continue;\r\n                }\r\n                else {\r\n                    const val = typeof opt === 'function' ? opt({ data: this.context, host: this.host }, this.property) : opt;\r\n                    if (val instanceof Promise) {\r\n                        val.then(v => {\r\n                            setPropByPath(this.instance, p, val);\r\n                        });\r\n                    }\r\n                    else {\r\n                        setPropByPath(this.instance, p, val);\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        if (this.subscription) {\r\n            this.subscription.unsubscribe();\r\n        }\r\n    }\r\n}"]}
|
|
@@ -5,9 +5,17 @@ export class AXProperyEditorComponent {
|
|
|
5
5
|
constructor(cdr) {
|
|
6
6
|
this.cdr = cdr;
|
|
7
7
|
this.readonly = false;
|
|
8
|
-
this.
|
|
8
|
+
this._initiated = false;
|
|
9
|
+
this._valueBound = false;
|
|
9
10
|
this.validatableComponentRegistered = new Subject();
|
|
10
11
|
this.valueChange = new EventEmitter();
|
|
12
|
+
this.onRenderCompleted = new EventEmitter();
|
|
13
|
+
this.onRenderCompleted.subscribe(() => {
|
|
14
|
+
this._initiated = true;
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
get initiated() {
|
|
18
|
+
return this._initiated && this._valueBound;
|
|
11
19
|
}
|
|
12
20
|
registerForValidationForm(component) {
|
|
13
21
|
this.validatableComponentRegistered.next(component);
|
|
@@ -20,18 +28,24 @@ export class AXProperyEditorComponent {
|
|
|
20
28
|
this._value = v;
|
|
21
29
|
this.valueChange.emit(v);
|
|
22
30
|
this.cdr.detectChanges();
|
|
31
|
+
//TODO: find better solution
|
|
32
|
+
setTimeout(() => {
|
|
33
|
+
this._valueBound = true;
|
|
34
|
+
}, 100);
|
|
23
35
|
}
|
|
24
36
|
}
|
|
25
37
|
handleValueChange(v) {
|
|
26
38
|
this.value = v;
|
|
27
39
|
}
|
|
28
|
-
initiat() {
|
|
29
|
-
}
|
|
30
40
|
}
|
|
31
41
|
__decorate([
|
|
32
42
|
Output(),
|
|
33
43
|
__metadata("design:type", EventEmitter)
|
|
34
44
|
], AXProperyEditorComponent.prototype, "valueChange", void 0);
|
|
45
|
+
__decorate([
|
|
46
|
+
Output(),
|
|
47
|
+
__metadata("design:type", EventEmitter)
|
|
48
|
+
], AXProperyEditorComponent.prototype, "onRenderCompleted", void 0);
|
|
35
49
|
__decorate([
|
|
36
50
|
Input(),
|
|
37
51
|
__metadata("design:type", Object),
|
|
@@ -86,4 +100,4 @@ export function propertyEditor(options) {
|
|
|
86
100
|
AXPropertyDecorators.register(target, key, options);
|
|
87
101
|
};
|
|
88
102
|
}
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-editor.class.js","sourceRoot":"ng://@acorex/components/","sources":["lib/property-editor/property-editor.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { Input, Output, EventEmitter, ChangeDetectorRef } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { AXValidatableComponent } from '../base/element.class';\r\n\r\nexport type AXDataType = 'string' | 'number' | 'date' | 'boolean' | 'object';\r\nexport type AXControlType = 'textbox' | 'numberbox' | 'datePicker' | 'switch' | 'custom';\r\n\r\n\r\n\r\nexport interface AXPropertyDef {\r\n    name: string;\r\n    title: string;\r\n    hint?: string;\r\n    defaultValue?: any;\r\n    editorClass: any;\r\n    editorOptions?: any;\r\n    visible?: boolean | (() => boolean);\r\n    order?: number;\r\n}\r\n\r\nexport interface AXPropertyEditorDef {\r\n    title: string;\r\n    hint?: string;\r\n    defaultValue?: any;\r\n    editorClass: any;\r\n    editorOptions?: any;\r\n    visible?: boolean | (() => boolean);\r\n    order?: number;\r\n}\r\n\r\n\r\n\r\n\r\nexport interface AXPropertyConfig {\r\n    property: AXPropertyDef;\r\n    value: any;\r\n}\r\n\r\n\r\nexport interface AXProperyEditorValueChangeEvent {\r\n    property: AXPropertyDef;\r\n    value: any;\r\n}\r\n\r\n\r\n\r\nexport abstract class AXProperyEditorComponent<T>{\r\n\r\n\r\n    readonly: boolean = false;\r\n    initiated: boolean = false;\r\n\r\n\r\n    validatableComponentRegistered: Subject<AXValidatableComponent> = new Subject<AXValidatableComponent>();\r\n\r\n\r\n    registerForValidationForm(component?: AXValidatableComponent) {\r\n        this.validatableComponentRegistered.next(component);\r\n    }\r\n\r\n\r\n    @Output()\r\n    valueChange: EventEmitter<T> = new EventEmitter<T>();\r\n\r\n    private _value: T;\r\n    @Input()\r\n    public get value(): T {\r\n        return this._value;\r\n    }\r\n\r\n    public set value(v: T) {\r\n        if (v !== this._value) {\r\n            this._value = v;\r\n            this.valueChange.emit(v);\r\n            this.cdr.detectChanges();\r\n        }\r\n    }\r\n\r\n    constructor(protected cdr: ChangeDetectorRef) {\r\n    }\r\n\r\n    uid: string;\r\n\r\n    handleValueChange(v: T) {\r\n        this.value = v;\r\n    }\r\n\r\n    initiat(): void {\r\n\r\n    }\r\n\r\n\r\n}\r\n\r\n\r\n\r\nexport class AXPropertyDecorator {\r\n    cls: any;\r\n    property: string;\r\n    options: any;\r\n\r\n    constructor(\r\n        cls: any,\r\n        property: string,\r\n        options: any) {\r\n        this.cls = cls;\r\n        this.property = property;\r\n        this.options = options;\r\n    }\r\n}\r\n\r\n\r\n// @dynamic\r\nexport class AXPropertyDecorators {\r\n    private static REGISTRY = new Array<AXPropertyDecorator>();\r\n\r\n    static register(cls: string, property: string, options?: any) {\r\n        const item = AXPropertyDecorators.REGISTRY.find(c => c.cls === cls && c.property === property);\r\n        if (item) {\r\n            item.options = options;\r\n        }\r\n        else {\r\n            AXPropertyDecorators.REGISTRY.push(new AXPropertyDecorator(cls, property, options));\r\n        }\r\n    }\r\n\r\n\r\n\r\n    static has(cls: string, property: string): boolean {\r\n        return AXPropertyDecorators.REGISTRY.some(c => c.cls === cls && c.property === property);\r\n    }\r\n\r\n    static get(cls: string, property: string): AXPropertyDecorator {\r\n        return AXPropertyDecorators.REGISTRY.find(c => c.cls === cls && c.property === property);\r\n    }\r\n\r\n    static isValid(property: string): boolean {\r\n        if (property) {\r\n            return AXPropertyDecorators.REGISTRY.some(c => c.property === property);\r\n        }\r\n        return false;\r\n    }\r\n\r\n    static getProperties(target: any): AXPropertyDecorator[] {\r\n        const list: AXPropertyDecorator[] = [];\r\n        const p: any[] = Array<any>();\r\n        let superClass = Object.getPrototypeOf(target);\r\n        while (superClass.constructor.name !== 'Object') {\r\n            p.push(superClass.constructor);\r\n            superClass = Object.getPrototypeOf(superClass);\r\n        }\r\n        list.push(...AXPropertyDecorators.REGISTRY.filter(c => p.includes(c.cls.constructor)));\r\n        return list;\r\n    }\r\n}\r\n\r\n\r\n\r\nexport function propertyEditor(options: AXPropertyEditorDef) {\r\n    return (target: any, key: string) => {\r\n        (options as any).name = key;\r\n        AXPropertyDecorators.register(target, key, options);\r\n    };\r\n}\r\n\r\n"]}
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-editor.class.js","sourceRoot":"ng://@acorex/components/","sources":["lib/property-editor/property-editor.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { Input, Output, EventEmitter, ChangeDetectorRef } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { AXValidatableComponent } from '../base/element.class';\r\n\r\nexport type AXDataType = 'string' | 'number' | 'date' | 'boolean' | 'object';\r\nexport type AXControlType = 'textbox' | 'numberbox' | 'datePicker' | 'switch' | 'custom';\r\n\r\n\r\n\r\nexport interface AXPropertyDef {\r\n    name: string;\r\n    title: string;\r\n    hint?: string;\r\n    defaultValue?: any;\r\n    editorClass: any;\r\n    editorOptions?: any;\r\n    visible?: boolean | (() => boolean);\r\n    order?: number;\r\n}\r\n\r\nexport interface AXPropertyEditorDef {\r\n    title: string;\r\n    hint?: string;\r\n    defaultValue?: any;\r\n    editorClass: any;\r\n    editorOptions?: any;\r\n    visible?: boolean | (() => boolean);\r\n    order?: number;\r\n}\r\n\r\n\r\n\r\n\r\nexport interface AXPropertyConfig {\r\n    property: AXPropertyDef;\r\n    value: any;\r\n}\r\n\r\n\r\nexport interface AXProperyEditorValueChangeEvent {\r\n    property: AXPropertyDef;\r\n    value: any;\r\n}\r\n\r\n\r\n\r\nexport abstract class AXProperyEditorComponent<T>{\r\n\r\n\r\n    readonly: boolean = false;\r\n\r\n\r\n    private _initiated: boolean = false;\r\n    private _valueBound: boolean = false;\r\n\r\n    public get initiated(): boolean {\r\n        return this._initiated && this._valueBound;\r\n    }\r\n\r\n\r\n    validatableComponentRegistered: Subject<AXValidatableComponent> = new Subject<AXValidatableComponent>();\r\n\r\n\r\n    registerForValidationForm(component?: AXValidatableComponent) {\r\n        this.validatableComponentRegistered.next(component);\r\n    }\r\n\r\n\r\n    @Output()\r\n    valueChange: EventEmitter<T> = new EventEmitter<T>();\r\n\r\n\r\n    @Output()\r\n    onRenderCompleted: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n    private _value: T;\r\n    @Input()\r\n    public get value(): T {\r\n        return this._value;\r\n    }\r\n\r\n    public set value(v: T) {\r\n        if (v !== this._value) {\r\n            this._value = v;\r\n            this.valueChange.emit(v);\r\n            this.cdr.detectChanges();\r\n            //TODO: find better solution\r\n            setTimeout(() => {\r\n                this._valueBound = true;\r\n            }, 100);\r\n        }\r\n    }\r\n\r\n    constructor(protected cdr: ChangeDetectorRef) {\r\n        this.onRenderCompleted.subscribe(() => {\r\n            this._initiated = true;\r\n        });\r\n    }\r\n\r\n    uid: string;\r\n\r\n    handleValueChange(v: T) {\r\n        this.value = v;\r\n    }\r\n}\r\n\r\n\r\n\r\nexport class AXPropertyDecorator {\r\n    cls: any;\r\n    property: string;\r\n    options: any;\r\n\r\n    constructor(\r\n        cls: any,\r\n        property: string,\r\n        options: any) {\r\n        this.cls = cls;\r\n        this.property = property;\r\n        this.options = options;\r\n    }\r\n}\r\n\r\n\r\n// @dynamic\r\nexport class AXPropertyDecorators {\r\n    private static REGISTRY = new Array<AXPropertyDecorator>();\r\n\r\n    static register(cls: string, property: string, options?: any) {\r\n        const item = AXPropertyDecorators.REGISTRY.find(c => c.cls === cls && c.property === property);\r\n        if (item) {\r\n            item.options = options;\r\n        }\r\n        else {\r\n            AXPropertyDecorators.REGISTRY.push(new AXPropertyDecorator(cls, property, options));\r\n        }\r\n    }\r\n\r\n\r\n\r\n    static has(cls: string, property: string): boolean {\r\n        return AXPropertyDecorators.REGISTRY.some(c => c.cls === cls && c.property === property);\r\n    }\r\n\r\n    static get(cls: string, property: string): AXPropertyDecorator {\r\n        return AXPropertyDecorators.REGISTRY.find(c => c.cls === cls && c.property === property);\r\n    }\r\n\r\n    static isValid(property: string): boolean {\r\n        if (property) {\r\n            return AXPropertyDecorators.REGISTRY.some(c => c.property === property);\r\n        }\r\n        return false;\r\n    }\r\n\r\n    static getProperties(target: any): AXPropertyDecorator[] {\r\n        const list: AXPropertyDecorator[] = [];\r\n        const p: any[] = Array<any>();\r\n        let superClass = Object.getPrototypeOf(target);\r\n        while (superClass.constructor.name !== 'Object') {\r\n            p.push(superClass.constructor);\r\n            superClass = Object.getPrototypeOf(superClass);\r\n        }\r\n        list.push(...AXPropertyDecorators.REGISTRY.filter(c => p.includes(c.cls.constructor)));\r\n        return list;\r\n    }\r\n}\r\n\r\n\r\n\r\nexport function propertyEditor(options: AXPropertyEditorDef) {\r\n    return (target: any, key: string) => {\r\n        (options as any).name = key;\r\n        AXPropertyDecorators.register(target, key, options);\r\n    };\r\n}\r\n\r\n"]}
|