@acorex/layout 3.0.65 → 4.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (53) hide show
  1. package/acorex-layout.d.ts +1 -2
  2. package/esm2020/acorex-layout.mjs +5 -0
  3. package/esm2020/lib/widget-board/editors/widget-size-editor/widget-size.editor.mjs +46 -0
  4. package/esm2020/lib/widget-board/editors/widget-size-editor/widget-size.module.mjs +21 -0
  5. package/esm2020/lib/widget-board/widget-board.component.mjs +441 -0
  6. package/esm2020/lib/widget-board/widget-board.module.mjs +111 -0
  7. package/esm2020/lib/widget-board/widget-config.component.mjs +82 -0
  8. package/esm2020/lib/widget-board/widget-host.component.mjs +290 -0
  9. package/esm2020/lib/widget-board/widget-save.component.mjs +79 -0
  10. package/esm2020/lib/widget-board/widget.class.mjs +127 -0
  11. package/esm2020/public-api.mjs +7 -0
  12. package/fesm2015/acorex-layout.mjs +1166 -0
  13. package/fesm2015/acorex-layout.mjs.map +1 -0
  14. package/fesm2020/acorex-layout.mjs +1159 -0
  15. package/fesm2020/acorex-layout.mjs.map +1 -0
  16. package/lib/widget-board/editors/widget-size-editor/widget-size.editor.d.ts +3 -0
  17. package/lib/widget-board/editors/widget-size-editor/widget-size.module.d.ts +8 -0
  18. package/lib/widget-board/widget-board.component.d.ts +3 -0
  19. package/lib/widget-board/widget-board.module.d.ts +12 -0
  20. package/lib/widget-board/widget-config.component.d.ts +3 -0
  21. package/lib/widget-board/widget-host.component.d.ts +3 -0
  22. package/lib/widget-board/widget-save.component.d.ts +3 -0
  23. package/lib/widget-board/widget.class.d.ts +3 -0
  24. package/package.json +23 -13
  25. package/acorex-layout.metadata.json +0 -1
  26. package/bundles/acorex-layout.umd.js +0 -1487
  27. package/bundles/acorex-layout.umd.js.map +0 -1
  28. package/bundles/acorex-layout.umd.min.js +0 -16
  29. package/bundles/acorex-layout.umd.min.js.map +0 -1
  30. package/esm2015/acorex-layout.js +0 -7
  31. package/esm2015/lib/widget-board/editors/widget-size-editor/widget-size.editor.js +0 -49
  32. package/esm2015/lib/widget-board/editors/widget-size-editor/widget-size.module.js +0 -19
  33. package/esm2015/lib/widget-board/widget-board.component.js +0 -468
  34. package/esm2015/lib/widget-board/widget-board.module.js +0 -67
  35. package/esm2015/lib/widget-board/widget-config.component.js +0 -86
  36. package/esm2015/lib/widget-board/widget-host.component.js +0 -323
  37. package/esm2015/lib/widget-board/widget-save.component.js +0 -79
  38. package/esm2015/lib/widget-board/widget.class.js +0 -123
  39. package/esm2015/public-api.js +0 -7
  40. package/esm5/acorex-layout.js +0 -7
  41. package/esm5/lib/widget-board/editors/widget-size-editor/widget-size.editor.js +0 -52
  42. package/esm5/lib/widget-board/editors/widget-size-editor/widget-size.module.js +0 -22
  43. package/esm5/lib/widget-board/widget-board.component.js +0 -494
  44. package/esm5/lib/widget-board/widget-board.module.js +0 -68
  45. package/esm5/lib/widget-board/widget-config.component.js +0 -90
  46. package/esm5/lib/widget-board/widget-host.component.js +0 -359
  47. package/esm5/lib/widget-board/widget-save.component.js +0 -83
  48. package/esm5/lib/widget-board/widget.class.js +0 -134
  49. package/esm5/public-api.js +0 -7
  50. package/fesm2015/acorex-layout.js +0 -1177
  51. package/fesm2015/acorex-layout.js.map +0 -1
  52. package/fesm5/acorex-layout.js +0 -1264
  53. package/fesm5/acorex-layout.js.map +0 -1
@@ -1,86 +0,0 @@
1
- import { __decorate, __metadata } from "tslib";
2
- import { Component, ViewEncapsulation, ChangeDetectionStrategy, ChangeDetectorRef, ViewChild } from '@angular/core';
3
- import { AXBasePopupPageComponent, AXValidationFormComponent } from '@acorex/components';
4
- import { AXTranslator } from '@acorex/core';
5
- let AXWidgetConfigComponent = class AXWidgetConfigComponent extends AXBasePopupPageComponent {
6
- constructor(cdr) {
7
- super();
8
- this.cdr = cdr;
9
- this.props = [];
10
- this.displayProps = [];
11
- this.changes = [];
12
- this.context = {};
13
- }
14
- getFooterButtons() {
15
- return [
16
- {
17
- name: 'okay',
18
- submitBehavior: true,
19
- text: AXTranslator.get('common.confirm'),
20
- style: 'success'
21
- },
22
- {
23
- name: 'cancel',
24
- cancelBehavior: true,
25
- text: AXTranslator.get('common.cancel'),
26
- style: 'danger blank'
27
- }
28
- ];
29
- }
30
- onFooterButtonClick(e) {
31
- if (e.name === 'cancel') {
32
- this.close();
33
- }
34
- if (e.name === 'okay') {
35
- this.form.validate().then(c => {
36
- if (c.result) {
37
- this.close(this.changes);
38
- }
39
- });
40
- }
41
- }
42
- handleValueChange(e) {
43
- const prop = this.changes.find(c => c.property.name === e.property.name);
44
- if (prop) {
45
- prop.value = e.value;
46
- }
47
- else {
48
- this.changes.push({ property: e.property, value: e.value });
49
- }
50
- this.updateContext();
51
- }
52
- ngOnInit() {
53
- this.displayProps = this.props.filter(c => c.property.visible !== false).sort((a, b) => a.property.order - b.property.order);
54
- this.updateContext();
55
- }
56
- updateContext() {
57
- const ctx = {};
58
- this.props.forEach(p => {
59
- ctx[p.property.name] = p.value;
60
- });
61
- this.changes.forEach(p => {
62
- ctx[p.property.name] = p.value;
63
- });
64
- this.context = ctx;
65
- }
66
- identify(index, item) {
67
- return item.property.name;
68
- }
69
- };
70
- AXWidgetConfigComponent.ctorParameters = () => [
71
- { type: ChangeDetectorRef }
72
- ];
73
- __decorate([
74
- ViewChild(AXValidationFormComponent),
75
- __metadata("design:type", AXValidationFormComponent)
76
- ], AXWidgetConfigComponent.prototype, "form", void 0);
77
- AXWidgetConfigComponent = __decorate([
78
- Component({
79
- template: "<ax-page>\r\n <ax-page-content>\r\n <div class=\"container\">\r\n <ax-validation-form #form>\r\n <div class=\"row\" *ngFor=\"let p of displayProps; trackBy: identify\">\r\n <div class=\"col-12\">\r\n <ax-label>{{p.property.title | trans}}</ax-label>\r\n <ng-container ax-property-editor-renderer [property]=\"p\" [context]=\"context\" [host]=\"widget\" [validationForm]=\"form\"\r\n (onValueChange)=\"handleValueChange($event)\">\r\n </ng-container>\r\n </div>\r\n </div>\r\n </ax-validation-form>\r\n </div>\r\n </ax-page-content>\r\n</ax-page>",
80
- encapsulation: ViewEncapsulation.None,
81
- changeDetection: ChangeDetectionStrategy.OnPush
82
- }),
83
- __metadata("design:paramtypes", [ChangeDetectorRef])
84
- ], AXWidgetConfigComponent);
85
- export { AXWidgetConfigComponent };
86
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LWNvbmZpZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AYWNvcmV4L2xheW91dC8iLCJzb3VyY2VzIjpbImxpYi93aWRnZXQtYm9hcmQvd2lkZ2V0LWNvbmZpZy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsdUJBQXVCLEVBQUUsaUJBQWlCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3BILE9BQU8sRUFBb0Isd0JBQXdCLEVBQXlELHlCQUF5QixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbEssT0FBTyxFQUFnQixZQUFZLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFVMUQsSUFBYSx1QkFBdUIsR0FBcEMsTUFBYSx1QkFBd0IsU0FBUSx3QkFBd0I7SUFJakUsWUFBb0IsR0FBc0I7UUFDdEMsS0FBSyxFQUFFLENBQUM7UUFEUSxRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQU0xQyxVQUFLLEdBQXVCLEVBQUUsQ0FBQztRQUMvQixpQkFBWSxHQUF1QixFQUFFLENBQUM7UUFHdEMsWUFBTyxHQUF1QixFQUFFLENBQUM7UUFFakMsWUFBTyxHQUFRLEVBQUUsQ0FBQztJQVZsQixDQUFDO0lBYUQsZ0JBQWdCO1FBQ1osT0FBTztZQUNIO2dCQUNJLElBQUksRUFBRSxNQUFNO2dCQUNaLGNBQWMsRUFBRSxJQUFJO2dCQUNwQixJQUFJLEVBQUUsWUFBWSxDQUFDLEdBQUcsQ0FBQyxnQkFBZ0IsQ0FBQztnQkFDeEMsS0FBSyxFQUFFLFNBQVM7YUFDbkI7WUFDRDtnQkFDSSxJQUFJLEVBQUUsUUFBUTtnQkFDZCxjQUFjLEVBQUUsSUFBSTtnQkFDcEIsSUFBSSxFQUFFLFlBQVksQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDO2dCQUN2QyxLQUFLLEVBQUUsY0FBYzthQUN4QjtTQUNKLENBQUM7SUFDTixDQUFDO0lBTUQsbUJBQW1CLENBQUMsQ0FBdUI7UUFDdkMsSUFBSSxDQUFDLENBQUMsSUFBSSxLQUFLLFFBQVEsRUFBRTtZQUNyQixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDaEI7UUFDRCxJQUFJLENBQUMsQ0FBQyxJQUFJLEtBQUssTUFBTSxFQUFFO1lBQ25CLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFO2dCQUMxQixJQUFJLENBQUMsQ0FBQyxNQUFNLEVBQUU7b0JBQ1YsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7aUJBQzVCO1lBQ0wsQ0FBQyxDQUFDLENBQUM7U0FDTjtJQUNMLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxDQUFrQztRQUNoRCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsSUFBSSxLQUFLLENBQUMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDekUsSUFBSSxJQUFJLEVBQUU7WUFDTixJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxLQUFLLENBQUM7U0FDeEI7YUFDSTtZQUNELElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUUsUUFBUSxFQUFFLENBQUMsQ0FBQyxRQUFRLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDO1NBQy9EO1FBQ0QsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFFRCxRQUFRO1FBQ0osSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsT0FBTyxLQUFLLEtBQUssQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDN0gsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFHTyxhQUFhO1FBQ2pCLE1BQU0sR0FBRyxHQUFHLEVBQUUsQ0FBQztRQUNmLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQ25CLEdBQUcsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxLQUFLLENBQUM7UUFDbkMsQ0FBQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUNyQixHQUFHLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxDQUFDO1FBQ25DLENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLE9BQU8sR0FBRyxHQUFHLENBQUM7SUFDdkIsQ0FBQztJQUdELFFBQVEsQ0FBQyxLQUFLLEVBQUUsSUFBc0I7UUFDbEMsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQztJQUM5QixDQUFDO0NBRUosQ0FBQTs7WUFsRjRCLGlCQUFpQjs7QUFGSjtJQUFyQyxTQUFTLENBQUMseUJBQXlCLENBQUM7OEJBQU8seUJBQXlCO3FEQUFDO0FBRjdELHVCQUF1QjtJQU5uQyxTQUFTLENBQUM7UUFDUCw0dkJBQTZDO1FBQzdDLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO1FBQ3JDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO0tBQ2xELENBQUM7cUNBTTJCLGlCQUFpQjtHQUpqQyx1QkFBdUIsQ0FzRm5DO1NBdEZZLHVCQUF1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgVmlld0VuY2Fwc3VsYXRpb24sIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDaGFuZ2VEZXRlY3RvclJlZiwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFYUHJvcGVydHlDb25maWcsIEFYQmFzZVBvcHVwUGFnZUNvbXBvbmVudCwgQVhNZW51SXRlbUNsaWNrRXZlbnQsIEFYUHJvcGVyeUVkaXRvclZhbHVlQ2hhbmdlRXZlbnQsIEFYVmFsaWRhdGlvbkZvcm1Db21wb25lbnQgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBBWEJ1dHRvbkl0ZW0sIEFYVHJhbnNsYXRvciB9IGZyb20gJ0BhY29yZXgvY29yZSc7XHJcbmltcG9ydCB7IEFYV2lkZ2V0Q29tcG9uZW50IH0gZnJvbSAnLi93aWRnZXQuY2xhc3MnO1xyXG5cclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgdGVtcGxhdGVVcmw6ICcuL3dpZGdldC1jb25maWcuY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcblxyXG5leHBvcnQgY2xhc3MgQVhXaWRnZXRDb25maWdDb21wb25lbnQgZXh0ZW5kcyBBWEJhc2VQb3B1cFBhZ2VDb21wb25lbnQge1xyXG5cclxuICAgIEBWaWV3Q2hpbGQoQVhWYWxpZGF0aW9uRm9ybUNvbXBvbmVudCkgZm9ybTogQVhWYWxpZGF0aW9uRm9ybUNvbXBvbmVudDtcclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcclxuICAgICAgICBzdXBlcigpO1xyXG4gICAgfVxyXG5cclxuXHJcbiAgICB3aWRnZXQ6IEFYV2lkZ2V0Q29tcG9uZW50O1xyXG4gICAgcHJvcHM6IEFYUHJvcGVydHlDb25maWdbXSA9IFtdO1xyXG4gICAgZGlzcGxheVByb3BzOiBBWFByb3BlcnR5Q29uZmlnW10gPSBbXTtcclxuXHJcblxyXG4gICAgY2hhbmdlczogQVhQcm9wZXJ0eUNvbmZpZ1tdID0gW107XHJcblxyXG4gICAgY29udGV4dDogYW55ID0ge307XHJcblxyXG5cclxuICAgIGdldEZvb3RlckJ1dHRvbnMoKTogQVhCdXR0b25JdGVtW10ge1xyXG4gICAgICAgIHJldHVybiBbXHJcbiAgICAgICAgICAgIHtcclxuICAgICAgICAgICAgICAgIG5hbWU6ICdva2F5JyxcclxuICAgICAgICAgICAgICAgIHN1Ym1pdEJlaGF2aW9yOiB0cnVlLFxyXG4gICAgICAgICAgICAgICAgdGV4dDogQVhUcmFuc2xhdG9yLmdldCgnY29tbW9uLmNvbmZpcm0nKSxcclxuICAgICAgICAgICAgICAgIHN0eWxlOiAnc3VjY2VzcydcclxuICAgICAgICAgICAgfSxcclxuICAgICAgICAgICAge1xyXG4gICAgICAgICAgICAgICAgbmFtZTogJ2NhbmNlbCcsXHJcbiAgICAgICAgICAgICAgICBjYW5jZWxCZWhhdmlvcjogdHJ1ZSxcclxuICAgICAgICAgICAgICAgIHRleHQ6IEFYVHJhbnNsYXRvci5nZXQoJ2NvbW1vbi5jYW5jZWwnKSxcclxuICAgICAgICAgICAgICAgIHN0eWxlOiAnZGFuZ2VyIGJsYW5rJ1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgXTtcclxuICAgIH1cclxuXHJcblxyXG5cclxuXHJcblxyXG4gICAgb25Gb290ZXJCdXR0b25DbGljayhlOiBBWE1lbnVJdGVtQ2xpY2tFdmVudCkge1xyXG4gICAgICAgIGlmIChlLm5hbWUgPT09ICdjYW5jZWwnKSB7XHJcbiAgICAgICAgICAgIHRoaXMuY2xvc2UoKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgaWYgKGUubmFtZSA9PT0gJ29rYXknKSB7XHJcbiAgICAgICAgICAgIHRoaXMuZm9ybS52YWxpZGF0ZSgpLnRoZW4oYyA9PiB7XHJcbiAgICAgICAgICAgICAgICBpZiAoYy5yZXN1bHQpIHtcclxuICAgICAgICAgICAgICAgICAgICB0aGlzLmNsb3NlKHRoaXMuY2hhbmdlcyk7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH0pO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBoYW5kbGVWYWx1ZUNoYW5nZShlOiBBWFByb3BlcnlFZGl0b3JWYWx1ZUNoYW5nZUV2ZW50KSB7XHJcbiAgICAgICAgY29uc3QgcHJvcCA9IHRoaXMuY2hhbmdlcy5maW5kKGMgPT4gYy5wcm9wZXJ0eS5uYW1lID09PSBlLnByb3BlcnR5Lm5hbWUpO1xyXG4gICAgICAgIGlmIChwcm9wKSB7XHJcbiAgICAgICAgICAgIHByb3AudmFsdWUgPSBlLnZhbHVlO1xyXG4gICAgICAgIH1cclxuICAgICAgICBlbHNlIHtcclxuICAgICAgICAgICAgdGhpcy5jaGFuZ2VzLnB1c2goeyBwcm9wZXJ0eTogZS5wcm9wZXJ0eSwgdmFsdWU6IGUudmFsdWUgfSk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHRoaXMudXBkYXRlQ29udGV4dCgpO1xyXG4gICAgfVxyXG5cclxuICAgIG5nT25Jbml0KCkge1xyXG4gICAgICAgIHRoaXMuZGlzcGxheVByb3BzID0gdGhpcy5wcm9wcy5maWx0ZXIoYyA9PiBjLnByb3BlcnR5LnZpc2libGUgIT09IGZhbHNlKS5zb3J0KChhLCBiKSA9PiBhLnByb3BlcnR5Lm9yZGVyIC0gYi5wcm9wZXJ0eS5vcmRlcik7XHJcbiAgICAgICAgdGhpcy51cGRhdGVDb250ZXh0KCk7XHJcbiAgICB9XHJcblxyXG5cclxuICAgIHByaXZhdGUgdXBkYXRlQ29udGV4dCgpIHtcclxuICAgICAgICBjb25zdCBjdHggPSB7fTtcclxuICAgICAgICB0aGlzLnByb3BzLmZvckVhY2gocCA9PiB7XHJcbiAgICAgICAgICAgIGN0eFtwLnByb3BlcnR5Lm5hbWVdID0gcC52YWx1ZTtcclxuICAgICAgICB9KTtcclxuICAgICAgICB0aGlzLmNoYW5nZXMuZm9yRWFjaChwID0+IHtcclxuICAgICAgICAgICAgY3R4W3AucHJvcGVydHkubmFtZV0gPSBwLnZhbHVlO1xyXG4gICAgICAgIH0pO1xyXG4gICAgICAgIHRoaXMuY29udGV4dCA9IGN0eDtcclxuICAgIH1cclxuXHJcblxyXG4gICAgaWRlbnRpZnkoaW5kZXgsIGl0ZW06IEFYUHJvcGVydHlDb25maWcpIHtcclxuICAgICAgICByZXR1cm4gaXRlbS5wcm9wZXJ0eS5uYW1lO1xyXG4gICAgfVxyXG5cclxufSJdfQ==
@@ -1,323 +0,0 @@
1
- import { __awaiter, __decorate, __metadata } from "tslib";
2
- import { Component, ViewEncapsulation, Input, ElementRef, HostBinding, ComponentFactoryResolver, ViewChild, ViewContainerRef, Output, EventEmitter, ChangeDetectionStrategy, ChangeDetectorRef, ComponentRef } from '@angular/core';
3
- import { AXObjectUtil, AXRenderService } from '@acorex/core';
4
- import { AXPopupService, AXPropertyDecorators, AXPropertyDecorator, AXLoadingService } from '@acorex/components';
5
- import { AXWidgetConfigComponent } from './widget-config.component';
6
- import { AXTranslator } from '@acorex/core';
7
- import { AXWidgetSaveComponent } from './widget-save.component';
8
- let AXWidgetHostComponent = class AXWidgetHostComponent {
9
- constructor(ref, componentFactoryResolver, rendererService, cdr, popup, loadingService) {
10
- this.ref = ref;
11
- this.componentFactoryResolver = componentFactoryResolver;
12
- this.rendererService = rendererService;
13
- this.cdr = cdr;
14
- this.popup = popup;
15
- this.loadingService = loadingService;
16
- this._hasProps = false;
17
- this._hasMenu = false;
18
- this.configMenuItem = [
19
- {
20
- icon: 'far fa-ellipsis-h',
21
- items: []
22
- }
23
- ];
24
- this.onRemove = new EventEmitter();
25
- this.onConfigChanged = new EventEmitter();
26
- this.onResized = new EventEmitter();
27
- this.onSave = new EventEmitter();
28
- this._isLoading = false;
29
- this.sizeX = 1;
30
- this.sizeY = 1;
31
- this.col = 1;
32
- this.row = 1;
33
- }
34
- get widget() {
35
- return this._widget;
36
- }
37
- get element() {
38
- return this.ref.nativeElement;
39
- }
40
- get isLoading() {
41
- return this._isLoading;
42
- }
43
- set isLoading(v) {
44
- this._isLoading = v;
45
- if (this._loadingId && !v) {
46
- this.loadingService.hide(this._loadingId);
47
- this._loadingId = null;
48
- }
49
- if (v) {
50
- this._loadingId = this.loadingService.show(this.ref.nativeElement);
51
- }
52
- }
53
- get isConfigured() {
54
- var _a;
55
- return ((_a = this._widget) === null || _a === void 0 ? void 0 : _a.isConfigured) || false;
56
- }
57
- ngOnInit() {
58
- this.isLoading = true;
59
- }
60
- ngAfterViewInit() {
61
- var _a;
62
- return __awaiter(this, void 0, void 0, function* () {
63
- let component;
64
- if (typeof this.config.component === 'string') {
65
- const route = yield this.rendererService.findLoadedComponentByRoute(this.config.component, 20);
66
- component = (_a = route) === null || _a === void 0 ? void 0 : _a.component;
67
- }
68
- else if (typeof this.config.component === 'function') {
69
- component = this.config.component;
70
- }
71
- if (component == null) {
72
- console.error(`Invalid Widget Component!`, this.config);
73
- this.onRemove.emit(this);
74
- return;
75
- }
76
- const widgetFactory = this.componentFactoryResolver.resolveComponentFactory(component);
77
- this.componentRef = this.vc.createComponent(widgetFactory);
78
- this._widget = this.componentRef.instance;
79
- this._widget.provideValue = this.provideValue;
80
- if (this._widget.onBusyChanged) {
81
- this._widget.onBusyChanged.subscribe((d) => {
82
- if (!this._widget.widgetSize) {
83
- this._widget.setValue('widgetSize', [this.sizeX, this.sizeY]);
84
- }
85
- else {
86
- this.setSizeFromOptions();
87
- }
88
- this.isLoading = d.value;
89
- this.cdr.detectChanges();
90
- });
91
- }
92
- if (this._widget.onConfiguredChanged) {
93
- this._widget.onConfiguredChanged.subscribe(() => {
94
- this.setSizeFromOptions();
95
- });
96
- }
97
- //
98
- if (this.config.options) {
99
- Object.assign(this._widget, this.config.options);
100
- }
101
- this._hasProps = AXPropertyDecorators.getProperties(this._widget).length > 0;
102
- this.isLoading = false;
103
- this.config['__meta__'].instance = this;
104
- this._widget['__meta__'] = {};
105
- this._widget['__meta__'].config = this.config;
106
- //
107
- this.configMenuItem[0].items.push({
108
- name: 'refresh',
109
- icon: 'far fa-undo',
110
- text: AXTranslator.get('common.refresh'),
111
- onClick: () => {
112
- var _a, _b;
113
- (_b = (_a = this) === null || _a === void 0 ? void 0 : _a.widget) === null || _b === void 0 ? void 0 : _b.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
- }
150
- setSizeFromOptions() {
151
- this._widget.getValue('widgetSize').then(c => {
152
- const oldSizeX = this.sizeX;
153
- const oldSizeY = this.sizeY;
154
- if (c && Array.isArray(c) && (oldSizeX !== c[0] || oldSizeY !== c[1])) {
155
- this.config.sizeX = this.sizeX = c[0];
156
- this.config.sizeY = this.sizeY = c[1];
157
- this.onResized.emit({
158
- component: this._widget,
159
- config: this.config
160
- });
161
- }
162
- this.cdr.detectChanges();
163
- });
164
- }
165
- remove(e) {
166
- e.preventDefault();
167
- e.stopPropagation();
168
- this.onRemove.emit(this);
169
- return false;
170
- }
171
- handleConfig(e) {
172
- e.preventDefault();
173
- e.stopPropagation();
174
- this.openConfigDialog();
175
- return false;
176
- }
177
- openConfigDialog() {
178
- const ppp = this.getMergedProps();
179
- this.popup.open(AXWidgetConfigComponent, {
180
- title: AXTranslator.get('common.configs'),
181
- size: 'sm',
182
- data: {
183
- props: ppp.map(c => ({ property: c.options, value: this._widget[c.options.name] })),
184
- widget: this.widget
185
- }
186
- }).then(c => {
187
- if (c.data) {
188
- if (!this.config.options) {
189
- this.config.options = {};
190
- }
191
- c.data.forEach(p => {
192
- this._widget.setValue(p.property.name, p.value);
193
- this.config.options[p.property.name] = p.value;
194
- });
195
- this.emitConfigChanged();
196
- this._widget.redraw();
197
- this.cdr.detectChanges();
198
- }
199
- });
200
- }
201
- openSaveDialog() {
202
- const ppp = this.getMergedProps();
203
- this.popup.open(AXWidgetSaveComponent, {
204
- title: AXTranslator.get('common.save-as'),
205
- size: 'sm',
206
- data: {
207
- config: this.config,
208
- props: ppp.map(c => ({ property: c.options, value: this._widget[c.options.name] }))
209
- }
210
- }).then(c => {
211
- if (c.data) {
212
- this.onSave.emit({
213
- component: this._widget,
214
- data: c.data
215
- });
216
- }
217
- });
218
- }
219
- handleOptionClick(e) {
220
- e.preventDefault();
221
- e.stopPropagation();
222
- this.openConfigDialog();
223
- return false;
224
- }
225
- ngOnDestroy() {
226
- this.vc.clear();
227
- if (this.componentRef) {
228
- this.componentRef.destroy();
229
- }
230
- }
231
- getMergedProps() {
232
- const ppp = AXObjectUtil.deepCopy(AXPropertyDecorators.getProperties(this._widget));
233
- for (const key in this.config.props) {
234
- if (Object.prototype.hasOwnProperty.call(this.config.props, key)) {
235
- const newP = this.config.props[key];
236
- const existPropDec = ppp.find(p => p.property === key);
237
- if (existPropDec) {
238
- Object.assign(existPropDec.options, newP);
239
- }
240
- }
241
- }
242
- return ppp;
243
- }
244
- emitConfigChanged() {
245
- this.onConfigChanged.emit({
246
- component: this._widget,
247
- config: this.config
248
- });
249
- }
250
- };
251
- AXWidgetHostComponent.ctorParameters = () => [
252
- { type: ElementRef },
253
- { type: ComponentFactoryResolver },
254
- { type: AXRenderService },
255
- { type: ChangeDetectorRef },
256
- { type: AXPopupService },
257
- { type: AXLoadingService }
258
- ];
259
- __decorate([
260
- Input(),
261
- __metadata("design:type", Function)
262
- ], AXWidgetHostComponent.prototype, "provideValue", void 0);
263
- __decorate([
264
- Output(),
265
- __metadata("design:type", EventEmitter)
266
- ], AXWidgetHostComponent.prototype, "onRemove", void 0);
267
- __decorate([
268
- Output(),
269
- __metadata("design:type", EventEmitter)
270
- ], AXWidgetHostComponent.prototype, "onConfigChanged", void 0);
271
- __decorate([
272
- Output(),
273
- __metadata("design:type", EventEmitter)
274
- ], AXWidgetHostComponent.prototype, "onResized", void 0);
275
- __decorate([
276
- Output(),
277
- __metadata("design:type", EventEmitter)
278
- ], AXWidgetHostComponent.prototype, "onSave", void 0);
279
- __decorate([
280
- Input(),
281
- __metadata("design:type", Object)
282
- ], AXWidgetHostComponent.prototype, "config", void 0);
283
- __decorate([
284
- ViewChild('vc', { read: ViewContainerRef }),
285
- __metadata("design:type", ViewContainerRef)
286
- ], AXWidgetHostComponent.prototype, "vc", void 0);
287
- __decorate([
288
- HostBinding('attr.data-size-x'),
289
- Input(),
290
- __metadata("design:type", Number)
291
- ], AXWidgetHostComponent.prototype, "sizeX", void 0);
292
- __decorate([
293
- HostBinding('attr.data-size-y'),
294
- Input(),
295
- __metadata("design:type", Number)
296
- ], AXWidgetHostComponent.prototype, "sizeY", void 0);
297
- __decorate([
298
- HostBinding('attr.data-col'),
299
- Input(),
300
- __metadata("design:type", Number)
301
- ], AXWidgetHostComponent.prototype, "col", void 0);
302
- __decorate([
303
- HostBinding('attr.data-row'),
304
- Input(),
305
- __metadata("design:type", Number)
306
- ], AXWidgetHostComponent.prototype, "row", void 0);
307
- AXWidgetHostComponent = __decorate([
308
- Component({
309
- selector: 'ax-widget-host',
310
- template: "<div class='widget-container'>\r\n <div class=\"widget-config-overlay\" *ngIf=\"!isConfigured\" (click)=\"handleConfig($event)\">\r\n <div class=\"widget-title\">{{config.title}}</div>\r\n <div class=\"widget-config-box\">\r\n <div class=\"config-title\">{{ 'widget-board.configure' | trans}}</div>\r\n <div class=\"config-icon\"><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\">\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>",
311
- host: { class: 'ax widget-host', tabindex: '0' },
312
- encapsulation: ViewEncapsulation.None,
313
- changeDetection: ChangeDetectionStrategy.OnPush
314
- }),
315
- __metadata("design:paramtypes", [ElementRef,
316
- ComponentFactoryResolver,
317
- AXRenderService,
318
- ChangeDetectorRef,
319
- AXPopupService,
320
- AXLoadingService])
321
- ], AXWidgetHostComponent);
322
- export { AXWidgetHostComponent };
323
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-host.component.js","sourceRoot":"ng://@acorex/layout/","sources":["lib/widget-board/widget-host.component.ts"],"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    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        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        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}"]}
@@ -1,79 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import { Component, ViewEncapsulation, ChangeDetectionStrategy, } from '@angular/core';
3
- import { AXHtmlUtil, AXObjectUtil, AXTranslator } from '@acorex/core';
4
- import { AXBasePopupPageComponent } from '@acorex/components';
5
- let AXWidgetSaveComponent = class AXWidgetSaveComponent extends AXBasePopupPageComponent {
6
- constructor() {
7
- super(...arguments);
8
- this.props = [];
9
- }
10
- getFooterButtons() {
11
- return [
12
- {
13
- name: 'okay',
14
- submitBehavior: true,
15
- text: AXTranslator.get('common.confirm'),
16
- style: 'ax success'
17
- },
18
- {
19
- name: 'cancel',
20
- cancelBehavior: true,
21
- text: AXTranslator.get('common.cancel'),
22
- style: 'ax light'
23
- }
24
- ];
25
- }
26
- ngOnInit() {
27
- var _a, _b;
28
- const titleProp = this.props.find(c => c.property.name === 'title' || c.property.name === 'name');
29
- const title = ((_a = titleProp) === null || _a === void 0 ? void 0 : _a.value) || this.config.title;
30
- const pp = {};
31
- (_b = this.props) === null || _b === void 0 ? void 0 : _b.forEach(c => {
32
- pp[c.property.name] = c.property;
33
- });
34
- this.data = {
35
- component: this.config.component,
36
- title,
37
- uniqueName: `${this.config.uniqueName}-${AXHtmlUtil.getUID()}`,
38
- options: AXObjectUtil.deepJSONClone(this.config.options),
39
- props: AXObjectUtil.deepJSONClone(pp)
40
- };
41
- this.displayProps = this.props
42
- .filter(c => c.property.visible !== false)
43
- .sort((a, b) => a.property.order - b.property.order)
44
- .map(c => ({
45
- name: c.property.name,
46
- title: c.property.title,
47
- allow: true
48
- }));
49
- }
50
- onFooterButtonClick(e) {
51
- if (e.name === 'cancel') {
52
- this.close();
53
- }
54
- if (e.name === 'okay') {
55
- this.props.forEach(p => {
56
- const pp = this.displayProps.find(c => c.name === p.property.name);
57
- if (pp == null || !pp.allow) {
58
- let ppp = this.data.props[p.property.name];
59
- if (ppp) {
60
- ppp.visible = false;
61
- }
62
- else {
63
- ppp = { visible: false };
64
- }
65
- }
66
- });
67
- this.close(this.data);
68
- }
69
- }
70
- };
71
- AXWidgetSaveComponent = __decorate([
72
- Component({
73
- template: "<ax-page>\r\n <ax-page-content>\r\n <div class=\"container\">\r\n <div class=\"row\">\r\n <div class=\"col-12\">\r\n <ax-form-group>\r\n <ax-label>{{'common.title' | trans}}</ax-label>\r\n <ax-text-box [(value)]=\"data.title\"></ax-text-box>\r\n </ax-form-group>\r\n </div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-12\">\r\n <ax-form-group>\r\n <ax-label>{{'common.description' | trans}}</ax-label>\r\n <ax-text-area [(value)]=\"data.description\"></ax-text-area>\r\n </ax-form-group>\r\n </div>\r\n </div>\r\n <!-- <div class=\"row\">\r\n <div class=\"col-12\">\r\n <ax-form-group>\r\n <ax-label>{{'common.uniquename' | trans}}</ax-label>\r\n <ax-text-box></ax-text-box>\r\n </ax-form-group>\r\n </div>\r\n </div> -->\r\n <div class=\"row\" style=\"margin-block-end: var(--ax-size-md);margin-block-start: var(--ax-size-md);\">\r\n <div class=\"col-12\">\r\n <ax-fieldset caption=\"{{'widget-board.configurable-props' | trans}}\">\r\n <div class=\"row\" *ngFor=\"let prop of displayProps\">\r\n <div class=\"col-12\" style=\"margin-block-end: var(--ax-size-sm)\">\r\n <ax-check-box [(value)]=\"prop.allow\" label=\"{{ prop.title | trans }}\">\r\n\r\n </ax-check-box>\r\n </div>\r\n </div>\r\n </ax-fieldset>\r\n </div>\r\n </div>\r\n </div>\r\n </ax-page-content>\r\n</ax-page>",
74
- encapsulation: ViewEncapsulation.None,
75
- changeDetection: ChangeDetectionStrategy.OnPush
76
- })
77
- ], AXWidgetSaveComponent);
78
- export { AXWidgetSaveComponent };
79
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LXNhdmUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGFjb3JleC9sYXlvdXQvIiwic291cmNlcyI6WyJsaWIvd2lkZ2V0LWJvYXJkL3dpZGdldC1zYXZlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUNILFNBQVMsRUFDVCxpQkFBaUIsRUFDakIsdUJBQXVCLEdBRTFCLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBZ0IsVUFBVSxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDcEYsT0FBTyxFQUEwQyx3QkFBd0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBU3RHLElBQWEscUJBQXFCLEdBQWxDLE1BQWEscUJBQXNCLFNBQVEsd0JBQXdCO0lBQW5FOztRQUVJLFVBQUssR0FBdUIsRUFBRSxDQUFDO0lBb0VuQyxDQUFDO0lBL0RHLGdCQUFnQjtRQUNaLE9BQU87WUFDSDtnQkFDSSxJQUFJLEVBQUUsTUFBTTtnQkFDWixjQUFjLEVBQUUsSUFBSTtnQkFDcEIsSUFBSSxFQUFFLFlBQVksQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUM7Z0JBQ3hDLEtBQUssRUFBRSxZQUFZO2FBQ3RCO1lBQ0Q7Z0JBQ0ksSUFBSSxFQUFFLFFBQVE7Z0JBQ2QsY0FBYyxFQUFFLElBQUk7Z0JBQ3BCLElBQUksRUFBRSxZQUFZLENBQUMsR0FBRyxDQUFDLGVBQWUsQ0FBQztnQkFDdkMsS0FBSyxFQUFFLFVBQVU7YUFDcEI7U0FDSixDQUFDO0lBQ04sQ0FBQztJQUVELFFBQVE7O1FBQ0osTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLElBQUksS0FBSyxPQUFPLElBQUksQ0FBQyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEtBQUssTUFBTSxDQUFDLENBQUM7UUFDbEcsTUFBTSxLQUFL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biAgICBWaWV3RW5jYXBzdWxhdGlvbixcclxuICAgIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxyXG5cclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQVhXaWRnZXRDb25maWcsIEFYV2lkZ2V0U2F2ZUFzRGF0YSB9IGZyb20gJy4vd2lkZ2V0LmNsYXNzJztcclxuaW1wb3J0IHsgQVhCdXR0b25JdGVtLCBBWEh0bWxVdGlsLCBBWE9iamVjdFV0aWwsIEFYVHJhbnNsYXRvciB9IGZyb20gJ0BhY29yZXgvY29yZSc7XHJcbmltcG9ydCB7IEFYUHJvcGVydHlDb25maWcsIEFYTWVudUl0ZW1DbGlja0V2ZW50LCBBWEJhc2VQb3B1cFBhZ2VDb21wb25lbnQgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMnO1xyXG5cclxuXHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHRlbXBsYXRlVXJsOiBcIi4vd2lkZ2V0LXNhdmUuY29tcG9uZW50Lmh0bWxcIixcclxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxufSlcclxuZXhwb3J0IGNsYXNzIEFYV2lkZ2V0U2F2ZUNvbXBvbmVudCBleHRlbmRzIEFYQmFzZVBvcHVwUGFnZUNvbXBvbmVudCB7XHJcbiAgICBjb25maWc6IEFYV2lkZ2V0Q29uZmlnO1xyXG4gICAgcHJvcHM6IEFYUHJvcGVydHlDb25maWdbXSA9IFtdO1xyXG4gICAgZGlzcGxheVByb3BzOiB7IG5hbWU6IHN0cmluZywgdGl0bGU6IHN0cmluZywgYWxsb3c6IGJvb2xlYW4gfVtdO1xyXG5cclxuICAgIGRhdGE6IEFYV2lkZ2V0U2F2ZUFzRGF0YTtcclxuXHJcbiAgICBnZXRGb290ZXJCdXR0b25zKCk6IEFYQnV0dG9uSXRlbVtdIHtcclxuICAgICAgICByZXR1cm4gW1xyXG4gICAgICAgICAgICB7XHJcbiAgICAgICAgICAgICAgICBuYW1lOiAnb2theScsXHJcbiAgICAgICAgICAgICAgICBzdWJtaXRCZWhhdmlvcjogdHJ1ZSxcclxuICAgICAgICAgICAgICAgIHRleHQ6IEFYVHJhbnNsYXRvci5nZXQoJ2NvbW1vbi5jb25maXJtJyksXHJcbiAgICAgICAgICAgICAgICBzdHlsZTogJ2F4IHN1Y2Nlc3MnXHJcbiAgICAgICAgICAgIH0sXHJcbiAgICAgICAgICAgIHtcclxuICAgICAgICAgICAgICAgIG5hbWU6ICdjYW5jZWwnLFxyXG4gICAgICAgICAgICAgICAgY2FuY2VsQmVoYXZpb3I6IHRydWUsXHJcbiAgICAgICAgICAgICAgICB0ZXh0OiBBWFRyYW5zbGF0b3IuZ2V0KCdjb21tb24uY2FuY2VsJyksXHJcbiAgICAgICAgICAgICAgICBzdHlsZTogJ2F4IGxpZ2h0J1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgXTtcclxuICAgIH1cclxuXHJcbiAgICBuZ09uSW5pdCgpIHtcclxuICAgICAgICBjb25zdCB0aXRsZVByb3AgPSB0aGlzLnByb3BzLmZpbmQoYyA9PiBjLnByb3BlcnR5Lm5hbWUgPT09ICd0aXRsZScgfHwgYy5wcm9wZXJ0eS5uYW1lID09PSAnbmFtZScpO1xyXG4gICAgICAgIGNvbnN0IHRpdGxlID0gdGl0bGVQcm9wPy52YWx1ZSB8fCB0aGlzLmNvbmZpZy50aXRsZTtcclxuICAgICAgICBjb25zdCBwcDogYW55ID0ge307XHJcbiAgICAgICAgdGhpcy5wcm9wcz8uZm9yRWFjaChjID0+IHtcclxuICAgICAgICAgICAgcHBbYy5wcm9wZXJ0eS5uYW1lXSA9IGMucHJvcGVydHk7XHJcbiAgICAgICAgfSk7XHJcbiAgICAgICAgdGhpcy5kYXRhID0ge1xyXG4gICAgICAgICAgICBjb21wb25lbnQ6IHRoaXMuY29uZmlnLmNvbXBvbmVudCxcclxuICAgICAgICAgICAgdGl0bGUsXHJcbiAgICAgICAgICAgIHVuaXF1ZU5hbWU6IGAke3RoaXMuY29uZmlnLnVuaXF1ZU5hbWV9LSR7QVhIdG1sVXRpbC5nZXRVSUQoKX1gLFxyXG4gICAgICAgICAgICBvcHRpb25zOiBBWE9iamVjdFV0aWwuZGVlcEpTT05DbG9uZSh0aGlzLmNvbmZpZy5vcHRpb25zKSxcclxuICAgICAgICAgICAgcHJvcHM6IEFYT2JqZWN0VXRpbC5kZWVwSlNPTkNsb25lKHBwKVxyXG4gICAgICAgIH07XHJcbiAgICAgICAgdGhpcy5kaXNwbGF5UHJvcHMgPSB0aGlzLnByb3BzXHJcbiAgICAgICAgICAgIC5maWx0ZXIoYyA9PiBjLnByb3BlcnR5LnZpc2libGUgIT09IGZhbHNlKVxyXG4gICAgICAgICAgICAuc29ydCgoYSwgYikgPT4gYS5wcm9wZXJ0eS5vcmRlciAtIGIucHJvcGVydHkub3JkZXIpXHJcbiAgICAgICAgICAgIC5tYXAoYyA9PiAoe1xyXG4gICAgICAgICAgICAgICAgbmFtZTogYy5wcm9wZXJ0eS5uYW1lLFxyXG4gICAgICAgICAgICAgICAgdGl0bGU6IGMucHJvcGVydHkudGl0bGUsXHJcbiAgICAgICAgICAgICAgICBhbGxvdzogdHJ1ZVxyXG4gICAgICAgICAgICB9KSk7XHJcbiAgICB9XHJcblxyXG5cclxuXHJcbiAgICBvbkZvb3RlckJ1dHRvbkNsaWNrKGU6IEFYTWVudUl0ZW1DbGlja0V2ZW50KSB7XHJcbiAgICAgICAgaWYgKGUubmFtZSA9PT0gJ2NhbmNlbCcpIHtcclxuICAgICAgICAgICAgdGhpcy5jbG9zZSgpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAoZS5uYW1lID09PSAnb2theScpIHtcclxuICAgICAgICAgICAgdGhpcy5wcm9wcy5mb3JFYWNoKHAgPT4ge1xyXG4gICAgICAgICAgICAgICAgY29uc3QgcHAgPSB0aGlzLmRpc3BsYXlQcm9wcy5maW5kKGMgPT4gYy5uYW1lID09PSBwLnByb3BlcnR5Lm5hbWUpO1xyXG4gICAgICAgICAgICAgICAgaWYgKHBwID09IG51bGwgfHwgIXBwLmFsbG93KSB7XHJcbiAgICAgICAgICAgICAgICAgICAgbGV0IHBwcCA9IHRoaXMuZGF0YS5wcm9wc1twLnByb3BlcnR5Lm5hbWVdO1xyXG4gICAgICAgICAgICAgICAgICAgIGlmIChwcHApIHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgcHBwLnZpc2libGUgPSBmYWxzZTtcclxuICAgICAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHBwcCA9IHsgdmlzaWJsZTogZmFsc2UgfTtcclxuICAgICAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH0pO1xyXG4gICAgICAgICAgICB0aGlzLmNsb3NlKHRoaXMuZGF0YSk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG59Il19