@acorex/layout 6.5.29 → 6.5.32

Sign up to get free protection for your applications and to get access to all the features.
Files changed (26) hide show
  1. package/README.md +1 -1
  2. package/acorex-layout.d.ts +5 -5
  3. package/esm2020/acorex-layout.mjs +4 -4
  4. package/esm2020/lib/widget-board/editors/widget-size-editor/widget-size.editor.mjs +46 -46
  5. package/esm2020/lib/widget-board/editors/widget-size-editor/widget-size.module.mjs +21 -21
  6. package/esm2020/lib/widget-board/widget-board.component.mjs +450 -450
  7. package/esm2020/lib/widget-board/widget-board.module.mjs +111 -111
  8. package/esm2020/lib/widget-board/widget-config.component.mjs +82 -82
  9. package/esm2020/lib/widget-board/widget-host.component.mjs +295 -295
  10. package/esm2020/lib/widget-board/widget-save.component.mjs +79 -79
  11. package/esm2020/lib/widget-board/widget.class.mjs +127 -127
  12. package/esm2020/public-api.mjs +7 -7
  13. package/fesm2015/acorex-layout.mjs +1147 -1147
  14. package/fesm2015/acorex-layout.mjs.map +1 -1
  15. package/fesm2020/acorex-layout.mjs +1140 -1140
  16. package/fesm2020/acorex-layout.mjs.map +1 -1
  17. package/lib/widget-board/editors/widget-size-editor/widget-size.editor.d.ts +19 -19
  18. package/lib/widget-board/editors/widget-size-editor/widget-size.module.d.ts +10 -10
  19. package/lib/widget-board/widget-board.component.d.ts +61 -61
  20. package/lib/widget-board/widget-board.module.d.ts +18 -18
  21. package/lib/widget-board/widget-config.component.d.ts +23 -23
  22. package/lib/widget-board/widget-host.component.d.ts +52 -52
  23. package/lib/widget-board/widget-save.component.d.ts +19 -19
  24. package/lib/widget-board/widget.class.d.ts +58 -58
  25. package/package.json +1 -1
  26. package/public-api.d.ts +6 -6
@@ -1,79 +1,79 @@
1
- import { Component, ViewEncapsulation, ChangeDetectionStrategy, } from '@angular/core';
2
- import { AXHtmlUtil, AXObjectUtil, AXTranslator } from '@acorex/core';
3
- import { AXBasePopupPageComponent } from '@acorex/components';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@acorex/components";
6
- import * as i2 from "@angular/common";
7
- import * as i3 from "@acorex/core";
8
- export class AXWidgetSaveComponent extends AXBasePopupPageComponent {
9
- constructor() {
10
- super(...arguments);
11
- this.props = [];
12
- }
13
- getFooterButtons() {
14
- return [
15
- {
16
- name: 'okay',
17
- submitBehavior: true,
18
- text: AXTranslator.get('common.confirm'),
19
- style: 'ax success'
20
- },
21
- {
22
- name: 'cancel',
23
- cancelBehavior: true,
24
- text: AXTranslator.get('common.cancel'),
25
- style: 'ax light'
26
- }
27
- ];
28
- }
29
- ngOnInit() {
30
- const titleProp = this.props.find(c => c.property.name === 'title' || c.property.name === 'name');
31
- const title = titleProp?.value || this.config.title;
32
- const pp = {};
33
- this.props?.forEach(c => {
34
- pp[c.property.name] = c.property;
35
- });
36
- this.data = {
37
- component: this.config.component,
38
- title,
39
- uniqueName: `${this.config.uniqueName}-${AXHtmlUtil.getUID()}`,
40
- options: AXObjectUtil.deepJSONClone(this.config.options),
41
- props: AXObjectUtil.deepJSONClone(pp)
42
- };
43
- this.displayProps = this.props
44
- .filter(c => c.property.visible !== false)
45
- .sort((a, b) => a.property.order - b.property.order)
46
- .map(c => ({
47
- name: c.property.name,
48
- title: c.property.title,
49
- allow: true
50
- }));
51
- }
52
- onFooterButtonClick(e) {
53
- if (e.name === 'cancel') {
54
- this.close();
55
- }
56
- if (e.name === 'okay') {
57
- this.props.forEach(p => {
58
- const pp = this.displayProps.find(c => c.name === p.property.name);
59
- if (pp == null || !pp.allow) {
60
- let ppp = this.data.props[p.property.name];
61
- if (ppp) {
62
- ppp.visible = false;
63
- }
64
- else {
65
- ppp = { visible: false };
66
- }
67
- }
68
- });
69
- this.close(this.data);
70
- }
71
- }
72
- }
73
- AXWidgetSaveComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXWidgetSaveComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
74
- AXWidgetSaveComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: AXWidgetSaveComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, 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>", components: [{ type: i1.AXPageComponent, selector: "ax-page" }, { type: i1.AXPageContentComponent, selector: "ax-page-content" }, { type: i1.AXFormGroupComponent, selector: "ax-form-group", inputs: ["size"] }, { type: i1.AXLabelComponent, selector: "ax-label", inputs: ["size"] }, { type: i1.AXTextBoxComponent, selector: "ax-text-box", inputs: ["mask", "type", "showMask", "maxLength", "maskGuid", "maskPlaceholder", "maskKeepCharPositions"] }, { type: i1.AXTextAreaComponent, selector: "ax-text-area", inputs: ["rows", "cols", "maxLength"] }, { type: i1.AXFieldsetComponent, selector: "ax-fieldset", inputs: ["size", "caption", "allowCollapse"] }, { type: i1.AXCheckBoxComponent, selector: "ax-check-box", inputs: ["readonly", "disabled", "size", "label", "tabIndex", "indeterminate", "value"], outputs: ["onValueChanged", "valueChange", "onClick"] }], directives: [{ type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "trans": i3.AXTranslatorPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
75
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXWidgetSaveComponent, decorators: [{
76
- type: Component,
77
- args: [{ encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ax-page>\r\n <ax-page-content>\r\n <div class=\"container\">\r\n <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>" }]
78
- }] });
79
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-save.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/layout/src/lib/widget-board/widget-save.component.ts","../../../../../../projects/acorex/layout/src/lib/widget-board/widget-save.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Component,\r\n    ViewEncapsulation,\r\n    ChangeDetectionStrategy,\r\n\r\n} from '@angular/core';\r\nimport { AXWidgetConfig, AXWidgetSaveAsData } from './widget.class';\r\nimport { AXButtonItem, AXHtmlUtil, AXObjectUtil, AXTranslator } from '@acorex/core';\r\nimport { AXPropertyConfig, AXMenuItemClickEvent, AXBasePopupPageComponent } from '@acorex/components';\r\n\r\n\r\n\r\n@Component({\r\n    templateUrl: \"./widget-save.component.html\",\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AXWidgetSaveComponent extends AXBasePopupPageComponent {\r\n    config: AXWidgetConfig;\r\n    props: AXPropertyConfig[] = [];\r\n    displayProps: { name: string, title: string, allow: boolean }[];\r\n\r\n    data: AXWidgetSaveAsData;\r\n\r\n    getFooterButtons(): AXButtonItem[] {\r\n        return [\r\n            {\r\n                name: 'okay',\r\n                submitBehavior: true,\r\n                text: AXTranslator.get('common.confirm'),\r\n                style: 'ax success'\r\n            },\r\n            {\r\n                name: 'cancel',\r\n                cancelBehavior: true,\r\n                text: AXTranslator.get('common.cancel'),\r\n                style: 'ax light'\r\n            }\r\n        ];\r\n    }\r\n\r\n    ngOnInit() {\r\n        const titleProp = this.props.find(c => c.property.name === 'title' || c.property.name === 'name');\r\n        const title = titleProp?.value || this.config.title;\r\n        const pp: any = {};\r\n        this.props?.forEach(c => {\r\n            pp[c.property.name] = c.property;\r\n        });\r\n        this.data = {\r\n            component: this.config.component,\r\n            title,\r\n            uniqueName: `${this.config.uniqueName}-${AXHtmlUtil.getUID()}`,\r\n            options: AXObjectUtil.deepJSONClone(this.config.options),\r\n            props: AXObjectUtil.deepJSONClone(pp)\r\n        };\r\n        this.displayProps = this.props\r\n            .filter(c => c.property.visible !== false)\r\n            .sort((a, b) => a.property.order - b.property.order)\r\n            .map(c => ({\r\n                name: c.property.name,\r\n                title: c.property.title,\r\n                allow: true\r\n            }));\r\n    }\r\n\r\n\r\n\r\n    onFooterButtonClick(e: AXMenuItemClickEvent) {\r\n        if (e.name === 'cancel') {\r\n            this.close();\r\n        }\r\n        if (e.name === 'okay') {\r\n            this.props.forEach(p => {\r\n                const pp = this.displayProps.find(c => c.name === p.property.name);\r\n                if (pp == null || !pp.allow) {\r\n                    let ppp = this.data.props[p.property.name];\r\n                    if (ppp) {\r\n                        ppp.visible = false;\r\n                    }\r\n                    else {\r\n                        ppp = { visible: false };\r\n                    }\r\n                }\r\n            });\r\n            this.close(this.data);\r\n        }\r\n    }\r\n}","<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>"]}
1
+ import { Component, ViewEncapsulation, ChangeDetectionStrategy, } from '@angular/core';
2
+ import { AXHtmlUtil, AXObjectUtil, AXTranslator } from '@acorex/core';
3
+ import { AXBasePopupPageComponent } from '@acorex/components';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@acorex/components";
6
+ import * as i2 from "@angular/common";
7
+ import * as i3 from "@acorex/core";
8
+ export class AXWidgetSaveComponent extends AXBasePopupPageComponent {
9
+ constructor() {
10
+ super(...arguments);
11
+ this.props = [];
12
+ }
13
+ getFooterButtons() {
14
+ return [
15
+ {
16
+ name: 'okay',
17
+ submitBehavior: true,
18
+ text: AXTranslator.get('common.confirm'),
19
+ style: 'ax success'
20
+ },
21
+ {
22
+ name: 'cancel',
23
+ cancelBehavior: true,
24
+ text: AXTranslator.get('common.cancel'),
25
+ style: 'ax light'
26
+ }
27
+ ];
28
+ }
29
+ ngOnInit() {
30
+ const titleProp = this.props.find(c => c.property.name === 'title' || c.property.name === 'name');
31
+ const title = titleProp?.value || this.config.title;
32
+ const pp = {};
33
+ this.props?.forEach(c => {
34
+ pp[c.property.name] = c.property;
35
+ });
36
+ this.data = {
37
+ component: this.config.component,
38
+ title,
39
+ uniqueName: `${this.config.uniqueName}-${AXHtmlUtil.getUID()}`,
40
+ options: AXObjectUtil.deepJSONClone(this.config.options),
41
+ props: AXObjectUtil.deepJSONClone(pp)
42
+ };
43
+ this.displayProps = this.props
44
+ .filter(c => c.property.visible !== false)
45
+ .sort((a, b) => a.property.order - b.property.order)
46
+ .map(c => ({
47
+ name: c.property.name,
48
+ title: c.property.title,
49
+ allow: true
50
+ }));
51
+ }
52
+ onFooterButtonClick(e) {
53
+ if (e.name === 'cancel') {
54
+ this.close();
55
+ }
56
+ if (e.name === 'okay') {
57
+ this.props.forEach(p => {
58
+ const pp = this.displayProps.find(c => c.name === p.property.name);
59
+ if (pp == null || !pp.allow) {
60
+ let ppp = this.data.props[p.property.name];
61
+ if (ppp) {
62
+ ppp.visible = false;
63
+ }
64
+ else {
65
+ ppp = { visible: false };
66
+ }
67
+ }
68
+ });
69
+ this.close(this.data);
70
+ }
71
+ }
72
+ }
73
+ AXWidgetSaveComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXWidgetSaveComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
74
+ AXWidgetSaveComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: AXWidgetSaveComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<ax-page>\n <ax-page-content>\n <div class=\"container\">\n <div class=\"row\">\n <div class=\"col-12\">\n <ax-form-group>\n <ax-label>{{'common.title' | trans}}</ax-label>\n <ax-text-box [(value)]=\"data.title\"></ax-text-box>\n </ax-form-group>\n </div>\n </div>\n <div class=\"row\">\n <div class=\"col-12\">\n <ax-form-group>\n <ax-label>{{'common.description' | trans}}</ax-label>\n <ax-text-area [(value)]=\"data.description\"></ax-text-area>\n </ax-form-group>\n </div>\n </div>\n <!-- <div class=\"row\">\n <div class=\"col-12\">\n <ax-form-group>\n <ax-label>{{'common.uniquename' | trans}}</ax-label>\n <ax-text-box></ax-text-box>\n </ax-form-group>\n </div>\n </div> -->\n <div class=\"row\" style=\"margin-block-end: var(--ax-size-md);margin-block-start: var(--ax-size-md);\">\n <div class=\"col-12\">\n <ax-fieldset caption=\"{{'widget-board.configurable-props' | trans}}\">\n <div class=\"row\" *ngFor=\"let prop of displayProps\">\n <div class=\"col-12\" style=\"margin-block-end: var(--ax-size-sm)\">\n <ax-check-box [(value)]=\"prop.allow\" label=\"{{ prop.title | trans }}\">\n\n </ax-check-box>\n </div>\n </div>\n </ax-fieldset>\n </div>\n </div>\n </div>\n </ax-page-content>\n</ax-page>", components: [{ type: i1.AXPageComponent, selector: "ax-page" }, { type: i1.AXPageContentComponent, selector: "ax-page-content" }, { type: i1.AXFormGroupComponent, selector: "ax-form-group", inputs: ["size"] }, { type: i1.AXLabelComponent, selector: "ax-label", inputs: ["size"] }, { type: i1.AXTextBoxComponent, selector: "ax-text-box", inputs: ["mask", "type", "showMask", "maxLength", "maskGuid", "maskPlaceholder", "maskKeepCharPositions"] }, { type: i1.AXTextAreaComponent, selector: "ax-text-area", inputs: ["rows", "cols", "maxLength"] }, { type: i1.AXFieldsetComponent, selector: "ax-fieldset", inputs: ["size", "caption", "allowCollapse"] }, { type: i1.AXCheckBoxComponent, selector: "ax-check-box", inputs: ["readonly", "disabled", "size", "label", "tabIndex", "indeterminate", "value"], outputs: ["onValueChanged", "valueChange", "onClick"] }], directives: [{ type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "trans": i3.AXTranslatorPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
75
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXWidgetSaveComponent, decorators: [{
76
+ type: Component,
77
+ args: [{ encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ax-page>\n <ax-page-content>\n <div class=\"container\">\n <div class=\"row\">\n <div class=\"col-12\">\n <ax-form-group>\n <ax-label>{{'common.title' | trans}}</ax-label>\n <ax-text-box [(value)]=\"data.title\"></ax-text-box>\n </ax-form-group>\n </div>\n </div>\n <div class=\"row\">\n <div class=\"col-12\">\n <ax-form-group>\n <ax-label>{{'common.description' | trans}}</ax-label>\n <ax-text-area [(value)]=\"data.description\"></ax-text-area>\n </ax-form-group>\n </div>\n </div>\n <!-- <div class=\"row\">\n <div class=\"col-12\">\n <ax-form-group>\n <ax-label>{{'common.uniquename' | trans}}</ax-label>\n <ax-text-box></ax-text-box>\n </ax-form-group>\n </div>\n </div> -->\n <div class=\"row\" style=\"margin-block-end: var(--ax-size-md);margin-block-start: var(--ax-size-md);\">\n <div class=\"col-12\">\n <ax-fieldset caption=\"{{'widget-board.configurable-props' | trans}}\">\n <div class=\"row\" *ngFor=\"let prop of displayProps\">\n <div class=\"col-12\" style=\"margin-block-end: var(--ax-size-sm)\">\n <ax-check-box [(value)]=\"prop.allow\" label=\"{{ prop.title | trans }}\">\n\n </ax-check-box>\n </div>\n </div>\n </ax-fieldset>\n </div>\n </div>\n </div>\n </ax-page-content>\n</ax-page>" }]
78
+ }] });
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-save.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/layout/src/lib/widget-board/widget-save.component.ts","../../../../../../projects/acorex/layout/src/lib/widget-board/widget-save.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ViewEncapsulation,\n    ChangeDetectionStrategy,\n\n} from '@angular/core';\nimport { AXWidgetConfig, AXWidgetSaveAsData } from './widget.class';\nimport { AXButtonItem, AXHtmlUtil, AXObjectUtil, AXTranslator } from '@acorex/core';\nimport { AXPropertyConfig, AXMenuItemClickEvent, AXBasePopupPageComponent } from '@acorex/components';\n\n\n\n@Component({\n    templateUrl: \"./widget-save.component.html\",\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AXWidgetSaveComponent extends AXBasePopupPageComponent {\n    config: AXWidgetConfig;\n    props: AXPropertyConfig[] = [];\n    displayProps: { name: string, title: string, allow: boolean }[];\n\n    data: AXWidgetSaveAsData;\n\n    getFooterButtons(): AXButtonItem[] {\n        return [\n            {\n                name: 'okay',\n                submitBehavior: true,\n                text: AXTranslator.get('common.confirm'),\n                style: 'ax success'\n            },\n            {\n                name: 'cancel',\n                cancelBehavior: true,\n                text: AXTranslator.get('common.cancel'),\n                style: 'ax light'\n            }\n        ];\n    }\n\n    ngOnInit() {\n        const titleProp = this.props.find(c => c.property.name === 'title' || c.property.name === 'name');\n        const title = titleProp?.value || this.config.title;\n        const pp: any = {};\n        this.props?.forEach(c => {\n            pp[c.property.name] = c.property;\n        });\n        this.data = {\n            component: this.config.component,\n            title,\n            uniqueName: `${this.config.uniqueName}-${AXHtmlUtil.getUID()}`,\n            options: AXObjectUtil.deepJSONClone(this.config.options),\n            props: AXObjectUtil.deepJSONClone(pp)\n        };\n        this.displayProps = this.props\n            .filter(c => c.property.visible !== false)\n            .sort((a, b) => a.property.order - b.property.order)\n            .map(c => ({\n                name: c.property.name,\n                title: c.property.title,\n                allow: true\n            }));\n    }\n\n\n\n    onFooterButtonClick(e: AXMenuItemClickEvent) {\n        if (e.name === 'cancel') {\n            this.close();\n        }\n        if (e.name === 'okay') {\n            this.props.forEach(p => {\n                const pp = this.displayProps.find(c => c.name === p.property.name);\n                if (pp == null || !pp.allow) {\n                    let ppp = this.data.props[p.property.name];\n                    if (ppp) {\n                        ppp.visible = false;\n                    }\n                    else {\n                        ppp = { visible: false };\n                    }\n                }\n            });\n            this.close(this.data);\n        }\n    }\n}","<ax-page>\n    <ax-page-content>\n        <div class=\"container\">\n            <div class=\"row\">\n                <div class=\"col-12\">\n                    <ax-form-group>\n                        <ax-label>{{'common.title' | trans}}</ax-label>\n                        <ax-text-box [(value)]=\"data.title\"></ax-text-box>\n                    </ax-form-group>\n                </div>\n            </div>\n            <div class=\"row\">\n                <div class=\"col-12\">\n                    <ax-form-group>\n                        <ax-label>{{'common.description' | trans}}</ax-label>\n                        <ax-text-area [(value)]=\"data.description\"></ax-text-area>\n                    </ax-form-group>\n                </div>\n            </div>\n            <!-- <div class=\"row\">\n                <div class=\"col-12\">\n                    <ax-form-group>\n                        <ax-label>{{'common.uniquename' | trans}}</ax-label>\n                        <ax-text-box></ax-text-box>\n                    </ax-form-group>\n                </div>\n            </div> -->\n            <div class=\"row\" style=\"margin-block-end: var(--ax-size-md);margin-block-start: var(--ax-size-md);\">\n                <div class=\"col-12\">\n                    <ax-fieldset caption=\"{{'widget-board.configurable-props' | trans}}\">\n                        <div class=\"row\" *ngFor=\"let prop of displayProps\">\n                            <div class=\"col-12\" style=\"margin-block-end: var(--ax-size-sm)\">\n                                <ax-check-box [(value)]=\"prop.allow\" label=\"{{ prop.title | trans }}\">\n\n                                </ax-check-box>\n                            </div>\n                        </div>\n                    </ax-fieldset>\n                </div>\n            </div>\n        </div>\n    </ax-page-content>\n</ax-page>"]}
@@ -1,127 +1,127 @@
1
- import { __decorate, __metadata } from "tslib";
2
- import { EventEmitter, Injectable } from '@angular/core';
3
- import { propertyEditor } from '@acorex/components';
4
- import { AXHtmlUtil, AXTranslator } from '@acorex/core';
5
- import * as i0 from "@angular/core";
6
- // @dynamic
7
- // TODO: Add Angular decorator.
8
- export class AXWidgetComponent {
9
- constructor() {
10
- this.uid = AXHtmlUtil.getUID();
11
- this.onBusyChanged = new EventEmitter();
12
- this._isBusy = true;
13
- this.refreshRate = [{
14
- id: 60000 * 5,
15
- text: AXTranslator.get('dateTime.duration.format_minute').replace('{0}', '5')
16
- }];
17
- this.onConfiguredChanged = new EventEmitter();
18
- this.onConfiguredChanged.subscribe(() => {
19
- if (this.isConfigured === true && this.getRefreshRate()) {
20
- this.restartRefreshTimer();
21
- }
22
- else {
23
- this.stopRefreshTimer();
24
- }
25
- });
26
- }
27
- get isBusy() {
28
- return this._isBusy;
29
- }
30
- set isBusy(v) {
31
- if (v !== this._isBusy) {
32
- const eventData = {
33
- component: this,
34
- oldValue: this._isBusy,
35
- value: v
36
- };
37
- this._isBusy = v;
38
- this.onBusyChanged.emit(eventData);
39
- }
40
- }
41
- // ???
42
- getRefreshRate() {
43
- return Array.isArray(this.refreshRate) && this.refreshRate.length ? this.refreshRate[0].id : this.refreshRate;
44
- }
45
- startRefreshTimer() {
46
- this.intervalId = window.setInterval(this.refresh.bind(this), this.getRefreshRate());
47
- }
48
- stopRefreshTimer() {
49
- window.clearInterval(this.intervalId);
50
- }
51
- restartRefreshTimer() {
52
- this.stopRefreshTimer();
53
- this.startRefreshTimer();
54
- }
55
- ngOnDestroy() {
56
- this.stopRefreshTimer();
57
- }
58
- redraw() {
59
- }
60
- refresh() {
61
- this.restartRefreshTimer();
62
- }
63
- get isConfigured() {
64
- return true;
65
- }
66
- setValue(name, value) {
67
- this[name] = value;
68
- this.onConfiguredChanged.emit();
69
- }
70
- getValue(name) {
71
- const val = this[name];
72
- const config = this['__meta__'].config;
73
- const runtime = config.props[name]?.runtime;
74
- if (runtime && this.provideValue) {
75
- const res = this.provideValue({
76
- name,
77
- value: val,
78
- uniqueName: config.uniqueName,
79
- options: config.options,
80
- });
81
- if (this.provideValue instanceof Promise) {
82
- return res;
83
- }
84
- else {
85
- return Promise.resolve(res);
86
- }
87
- }
88
- return Promise.resolve(val);
89
- }
90
- }
91
- AXWidgetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXWidgetComponent, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
92
- AXWidgetComponent.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXWidgetComponent });
93
- __decorate([
94
- propertyEditor({
95
- editorClass: 'ax/editors/widget-size',
96
- title: 'common.size',
97
- visible: false,
98
- order: -99,
99
- }),
100
- __metadata("design:type", Array)
101
- ], AXWidgetComponent.prototype, "widgetSize", void 0);
102
- __decorate([
103
- propertyEditor({
104
- editorClass: 'ax/editors/select',
105
- title: 'common.refresh-rate',
106
- visible: true,
107
- order: -98,
108
- editorOptions: {
109
- items: () => {
110
- return [1, 2, 3, 5, 10, 20, 30, 60].map(c => ({
111
- id: 60000 * c,
112
- text: AXTranslator.get('dateTime.duration.format_minute').replace('{0}', c.toString())
113
- }));
114
- },
115
- allowNull: false,
116
- allowSearch: false,
117
- selectionDataMode: 'value',
118
- selectionMode: 'single',
119
- valueField: 'id',
120
- }
121
- }),
122
- __metadata("design:type", Object)
123
- ], AXWidgetComponent.prototype, "refreshRate", void 0);
124
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXWidgetComponent, decorators: [{
125
- type: Injectable
126
- }], ctorParameters: function () { return []; }, propDecorators: { widgetSize: [], refreshRate: [] } });
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget.class.js","sourceRoot":"","sources":["../../../../../../projects/acorex/layout/src/lib/widget-board/widget.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Injectable } from '@angular/core';\r\nimport { AXValueEvent, AXBaseEvent, propertyEditor, AXDataEvent } from '@acorex/components';\r\nimport { AXHtmlUtil, AXTranslator } from '@acorex/core';\r\n\r\nexport interface AXWidgetConfig {\r\n    uniqueName: string;\r\n    component: any;\r\n    title: string;\r\n    sizeX: number;\r\n    sizeY: number;\r\n    col?: number;\r\n    row?: number;\r\n    options?: any;\r\n    props?: any;\r\n    readonly?: boolean;\r\n}\r\n\r\nexport interface AXWidgetConfigChanged extends AXBaseEvent {\r\n    config: AXWidgetConfig;\r\n}\r\n\r\n\r\n\r\nexport interface AXWidgetBoardConfigChanged extends AXBaseEvent {\r\n    mode: 'clear' | 'add' | 'remove' | 'load' | 'config';\r\n}\r\n\r\nexport interface AXWidgetConfigSavedEvent extends AXDataEvent<AXWidgetSaveAsData> {\r\n\r\n}\r\n\r\n\r\nexport interface AXWidgetSaveAsData {\r\n    title?: string;\r\n    description?: string;\r\n    icon?: string;\r\n    group?: string;\r\n    //\r\n    uniqueName: string;\r\n    component: any;\r\n    options?: any;\r\n    props?: any;\r\n}\r\n\r\n// @dynamic\r\n// TODO: Add Angular decorator.\r\n@Injectable()\r\nexport abstract class AXWidgetComponent {\r\n\r\n    readonly uid: string = AXHtmlUtil.getUID();\r\n    provideValue: (e: any) => any;\r\n\r\n    onBusyChanged: EventEmitter<AXValueEvent<boolean>> = new EventEmitter<AXValueEvent<boolean>>();\r\n\r\n    private _isBusy: boolean = true;\r\n    public get isBusy(): boolean {\r\n        return this._isBusy;\r\n    }\r\n    public set isBusy(v: boolean) {\r\n        if (v !== this._isBusy) {\r\n            const eventData: AXValueEvent<boolean> = {\r\n                component: this,\r\n                oldValue: this._isBusy,\r\n                value: v\r\n            };\r\n            this._isBusy = v;\r\n            this.onBusyChanged.emit(eventData);\r\n        }\r\n    }\r\n\r\n    @propertyEditor({\r\n        editorClass: 'ax/editors/widget-size',\r\n        title: 'common.size',\r\n        visible: false,\r\n        order: -99,\r\n    })\r\n    widgetSize: number[];\r\n\r\n    @propertyEditor({\r\n        editorClass: 'ax/editors/select',\r\n        title: 'common.refresh-rate',\r\n        visible: true,\r\n        order: -98,\r\n        editorOptions: {\r\n            items: () => {\r\n                return [1, 2, 3, 5, 10, 20, 30, 60].map(c => ({\r\n                    id: 60000 * c,\r\n                    text: AXTranslator.get('dateTime.duration.format_minute').replace('{0}', c.toString())\r\n                }));\r\n            },\r\n            allowNull: false,\r\n            allowSearch: false,\r\n            selectionDataMode: 'value',\r\n            selectionMode: 'single',\r\n            valueField: 'id',\r\n        }\r\n    })\r\n    refreshRate: any = [{\r\n        id: 60000 * 5,\r\n        text: AXTranslator.get('dateTime.duration.format_minute').replace('{0}', '5')\r\n    }];\r\n\r\n    // ???\r\n    getRefreshRate() {\r\n        return Array.isArray(this.refreshRate) && this.refreshRate.length ? this.refreshRate[0].id : this.refreshRate;\r\n    }\r\n\r\n    private intervalId: number;\r\n\r\n    constructor() {\r\n        this.onConfiguredChanged.subscribe(() => {\r\n            if (this.isConfigured === true && this.getRefreshRate()) {\r\n                this.restartRefreshTimer();\r\n            }\r\n            else {\r\n                this.stopRefreshTimer();\r\n            }\r\n        });\r\n    }\r\n\r\n\r\n    private startRefreshTimer() {\r\n        this.intervalId = window.setInterval(this.refresh.bind(this), this.getRefreshRate());\r\n    }\r\n\r\n    private stopRefreshTimer() {\r\n        window.clearInterval(this.intervalId);\r\n    }\r\n\r\n    private restartRefreshTimer() {\r\n        this.stopRefreshTimer();\r\n        this.startRefreshTimer();\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this.stopRefreshTimer();\r\n    }\r\n\r\n    public redraw() {\r\n\r\n    }\r\n\r\n    public refresh() {\r\n        this.restartRefreshTimer();\r\n    }\r\n\r\n    onConfiguredChanged: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n    get isConfigured(): boolean {\r\n        return true;\r\n    }\r\n\r\n    public setValue(name: string, value?: any) {\r\n        this[name] = value;\r\n        this.onConfiguredChanged.emit();\r\n    }\r\n\r\n    public getValue(name: string): Promise<any> {\r\n        const val = this[name];\r\n        const config = this['__meta__'].config;\r\n        const runtime = config.props[name]?.runtime;\r\n        if (runtime && this.provideValue) {\r\n            const res = this.provideValue({\r\n                name,\r\n                value: val,\r\n                uniqueName: config.uniqueName,\r\n                options: config.options,\r\n            });\r\n            if (this.provideValue instanceof Promise) {\r\n                return res;\r\n            }\r\n            else {\r\n                return Promise.resolve(res);\r\n            }\r\n        }\r\n        return Promise.resolve(val);\r\n    }\r\n\r\n}"]}
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { EventEmitter, Injectable } from '@angular/core';
3
+ import { propertyEditor } from '@acorex/components';
4
+ import { AXHtmlUtil, AXTranslator } from '@acorex/core';
5
+ import * as i0 from "@angular/core";
6
+ // @dynamic
7
+ // TODO: Add Angular decorator.
8
+ export class AXWidgetComponent {
9
+ constructor() {
10
+ this.uid = AXHtmlUtil.getUID();
11
+ this.onBusyChanged = new EventEmitter();
12
+ this._isBusy = true;
13
+ this.refreshRate = [{
14
+ id: 60000 * 5,
15
+ text: AXTranslator.get('dateTime.duration.format_minute').replace('{0}', '5')
16
+ }];
17
+ this.onConfiguredChanged = new EventEmitter();
18
+ this.onConfiguredChanged.subscribe(() => {
19
+ if (this.isConfigured === true && this.getRefreshRate()) {
20
+ this.restartRefreshTimer();
21
+ }
22
+ else {
23
+ this.stopRefreshTimer();
24
+ }
25
+ });
26
+ }
27
+ get isBusy() {
28
+ return this._isBusy;
29
+ }
30
+ set isBusy(v) {
31
+ if (v !== this._isBusy) {
32
+ const eventData = {
33
+ component: this,
34
+ oldValue: this._isBusy,
35
+ value: v
36
+ };
37
+ this._isBusy = v;
38
+ this.onBusyChanged.emit(eventData);
39
+ }
40
+ }
41
+ // ???
42
+ getRefreshRate() {
43
+ return Array.isArray(this.refreshRate) && this.refreshRate.length ? this.refreshRate[0].id : this.refreshRate;
44
+ }
45
+ startRefreshTimer() {
46
+ this.intervalId = window.setInterval(this.refresh.bind(this), this.getRefreshRate());
47
+ }
48
+ stopRefreshTimer() {
49
+ window.clearInterval(this.intervalId);
50
+ }
51
+ restartRefreshTimer() {
52
+ this.stopRefreshTimer();
53
+ this.startRefreshTimer();
54
+ }
55
+ ngOnDestroy() {
56
+ this.stopRefreshTimer();
57
+ }
58
+ redraw() {
59
+ }
60
+ refresh() {
61
+ this.restartRefreshTimer();
62
+ }
63
+ get isConfigured() {
64
+ return true;
65
+ }
66
+ setValue(name, value) {
67
+ this[name] = value;
68
+ this.onConfiguredChanged.emit();
69
+ }
70
+ getValue(name) {
71
+ const val = this[name];
72
+ const config = this['__meta__'].config;
73
+ const runtime = config.props[name]?.runtime;
74
+ if (runtime && this.provideValue) {
75
+ const res = this.provideValue({
76
+ name,
77
+ value: val,
78
+ uniqueName: config.uniqueName,
79
+ options: config.options,
80
+ });
81
+ if (this.provideValue instanceof Promise) {
82
+ return res;
83
+ }
84
+ else {
85
+ return Promise.resolve(res);
86
+ }
87
+ }
88
+ return Promise.resolve(val);
89
+ }
90
+ }
91
+ AXWidgetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXWidgetComponent, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
92
+ AXWidgetComponent.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXWidgetComponent });
93
+ __decorate([
94
+ propertyEditor({
95
+ editorClass: 'ax/editors/widget-size',
96
+ title: 'common.size',
97
+ visible: false,
98
+ order: -99,
99
+ }),
100
+ __metadata("design:type", Array)
101
+ ], AXWidgetComponent.prototype, "widgetSize", void 0);
102
+ __decorate([
103
+ propertyEditor({
104
+ editorClass: 'ax/editors/select',
105
+ title: 'common.refresh-rate',
106
+ visible: true,
107
+ order: -98,
108
+ editorOptions: {
109
+ items: () => {
110
+ return [1, 2, 3, 5, 10, 20, 30, 60].map(c => ({
111
+ id: 60000 * c,
112
+ text: AXTranslator.get('dateTime.duration.format_minute').replace('{0}', c.toString())
113
+ }));
114
+ },
115
+ allowNull: false,
116
+ allowSearch: false,
117
+ selectionDataMode: 'value',
118
+ selectionMode: 'single',
119
+ valueField: 'id',
120
+ }
121
+ }),
122
+ __metadata("design:type", Object)
123
+ ], AXWidgetComponent.prototype, "refreshRate", void 0);
124
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXWidgetComponent, decorators: [{
125
+ type: Injectable
126
+ }], ctorParameters: function () { return []; }, propDecorators: { widgetSize: [], refreshRate: [] } });
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget.class.js","sourceRoot":"","sources":["../../../../../../projects/acorex/layout/src/lib/widget-board/widget.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Injectable } from '@angular/core';\nimport { AXValueEvent, AXBaseEvent, propertyEditor, AXDataEvent } from '@acorex/components';\nimport { AXHtmlUtil, AXTranslator } from '@acorex/core';\n\nexport interface AXWidgetConfig {\n    uniqueName: string;\n    component: any;\n    title: string;\n    sizeX: number;\n    sizeY: number;\n    col?: number;\n    row?: number;\n    options?: any;\n    props?: any;\n    readonly?: boolean;\n}\n\nexport interface AXWidgetConfigChanged extends AXBaseEvent {\n    config: AXWidgetConfig;\n}\n\n\n\nexport interface AXWidgetBoardConfigChanged extends AXBaseEvent {\n    mode: 'clear' | 'add' | 'remove' | 'load' | 'config';\n}\n\nexport interface AXWidgetConfigSavedEvent extends AXDataEvent<AXWidgetSaveAsData> {\n\n}\n\n\nexport interface AXWidgetSaveAsData {\n    title?: string;\n    description?: string;\n    icon?: string;\n    group?: string;\n    //\n    uniqueName: string;\n    component: any;\n    options?: any;\n    props?: any;\n}\n\n// @dynamic\n// TODO: Add Angular decorator.\n@Injectable()\nexport abstract class AXWidgetComponent {\n\n    readonly uid: string = AXHtmlUtil.getUID();\n    provideValue: (e: any) => any;\n\n    onBusyChanged: EventEmitter<AXValueEvent<boolean>> = new EventEmitter<AXValueEvent<boolean>>();\n\n    private _isBusy: boolean = true;\n    public get isBusy(): boolean {\n        return this._isBusy;\n    }\n    public set isBusy(v: boolean) {\n        if (v !== this._isBusy) {\n            const eventData: AXValueEvent<boolean> = {\n                component: this,\n                oldValue: this._isBusy,\n                value: v\n            };\n            this._isBusy = v;\n            this.onBusyChanged.emit(eventData);\n        }\n    }\n\n    @propertyEditor({\n        editorClass: 'ax/editors/widget-size',\n        title: 'common.size',\n        visible: false,\n        order: -99,\n    })\n    widgetSize: number[];\n\n    @propertyEditor({\n        editorClass: 'ax/editors/select',\n        title: 'common.refresh-rate',\n        visible: true,\n        order: -98,\n        editorOptions: {\n            items: () => {\n                return [1, 2, 3, 5, 10, 20, 30, 60].map(c => ({\n                    id: 60000 * c,\n                    text: AXTranslator.get('dateTime.duration.format_minute').replace('{0}', c.toString())\n                }));\n            },\n            allowNull: false,\n            allowSearch: false,\n            selectionDataMode: 'value',\n            selectionMode: 'single',\n            valueField: 'id',\n        }\n    })\n    refreshRate: any = [{\n        id: 60000 * 5,\n        text: AXTranslator.get('dateTime.duration.format_minute').replace('{0}', '5')\n    }];\n\n    // ???\n    getRefreshRate() {\n        return Array.isArray(this.refreshRate) && this.refreshRate.length ? this.refreshRate[0].id : this.refreshRate;\n    }\n\n    private intervalId: number;\n\n    constructor() {\n        this.onConfiguredChanged.subscribe(() => {\n            if (this.isConfigured === true && this.getRefreshRate()) {\n                this.restartRefreshTimer();\n            }\n            else {\n                this.stopRefreshTimer();\n            }\n        });\n    }\n\n\n    private startRefreshTimer() {\n        this.intervalId = window.setInterval(this.refresh.bind(this), this.getRefreshRate());\n    }\n\n    private stopRefreshTimer() {\n        window.clearInterval(this.intervalId);\n    }\n\n    private restartRefreshTimer() {\n        this.stopRefreshTimer();\n        this.startRefreshTimer();\n    }\n\n    ngOnDestroy() {\n        this.stopRefreshTimer();\n    }\n\n    public redraw() {\n\n    }\n\n    public refresh() {\n        this.restartRefreshTimer();\n    }\n\n    onConfiguredChanged: EventEmitter<void> = new EventEmitter<void>();\n\n    get isConfigured(): boolean {\n        return true;\n    }\n\n    public setValue(name: string, value?: any) {\n        this[name] = value;\n        this.onConfiguredChanged.emit();\n    }\n\n    public getValue(name: string): Promise<any> {\n        const val = this[name];\n        const config = this['__meta__'].config;\n        const runtime = config.props[name]?.runtime;\n        if (runtime && this.provideValue) {\n            const res = this.provideValue({\n                name,\n                value: val,\n                uniqueName: config.uniqueName,\n                options: config.options,\n            });\n            if (this.provideValue instanceof Promise) {\n                return res;\n            }\n            else {\n                return Promise.resolve(res);\n            }\n        }\n        return Promise.resolve(val);\n    }\n\n}"]}
@@ -1,7 +1,7 @@
1
- export * from './lib/widget-board/widget.class';
2
- export * from './lib/widget-board/widget-board.component';
3
- export * from './lib/widget-board/widget-host.component';
4
- export * from './lib/widget-board/widget-board.module';
5
- export * from './lib/widget-board/editors/widget-size-editor/widget-size.editor';
6
- export * from './lib/widget-board/editors/widget-size-editor/widget-size.module';
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2Fjb3JleC9sYXlvdXQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLGtFQUFrRSxDQUFDO0FBQ2pGLGNBQWMsa0VBQWtFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi93aWRnZXQtYm9hcmQvd2lkZ2V0LmNsYXNzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvd2lkZ2V0LWJvYXJkL3dpZGdldC1ib2FyZC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi93aWRnZXQtYm9hcmQvd2lkZ2V0LWhvc3QuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvd2lkZ2V0LWJvYXJkL3dpZGdldC1ib2FyZC5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi93aWRnZXQtYm9hcmQvZWRpdG9ycy93aWRnZXQtc2l6ZS1lZGl0b3Ivd2lkZ2V0LXNpemUuZWRpdG9yJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvd2lkZ2V0LWJvYXJkL2VkaXRvcnMvd2lkZ2V0LXNpemUtZWRpdG9yL3dpZGdldC1zaXplLm1vZHVsZSc7XHJcbiJdfQ==
1
+ export * from './lib/widget-board/widget.class';
2
+ export * from './lib/widget-board/widget-board.component';
3
+ export * from './lib/widget-board/widget-host.component';
4
+ export * from './lib/widget-board/widget-board.module';
5
+ export * from './lib/widget-board/editors/widget-size-editor/widget-size.editor';
6
+ export * from './lib/widget-board/editors/widget-size-editor/widget-size.module';
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2Fjb3JleC9sYXlvdXQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLGtFQUFrRSxDQUFDO0FBQ2pGLGNBQWMsa0VBQWtFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi93aWRnZXQtYm9hcmQvd2lkZ2V0LmNsYXNzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldC1ib2FyZC93aWRnZXQtYm9hcmQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldC1ib2FyZC93aWRnZXQtaG9zdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvd2lkZ2V0LWJvYXJkL3dpZGdldC1ib2FyZC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvd2lkZ2V0LWJvYXJkL2VkaXRvcnMvd2lkZ2V0LXNpemUtZWRpdG9yL3dpZGdldC1zaXplLmVkaXRvcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi93aWRnZXQtYm9hcmQvZWRpdG9ycy93aWRnZXQtc2l6ZS1lZGl0b3Ivd2lkZ2V0LXNpemUubW9kdWxlJztcbiJdfQ==