@colijnit/corecomponents_v12 12.2.4 → 12.2.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (24) hide show
  1. package/bundles/colijnit-corecomponents_v12.umd.js +428 -81
  2. package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
  3. package/colijnit-corecomponents_v12.d.ts +0 -2
  4. package/colijnit-corecomponents_v12.metadata.json +1 -1
  5. package/esm2015/colijnit-corecomponents_v12.js +1 -3
  6. package/esm2015/lib/components/button/button.component.js +27 -20
  7. package/esm2015/lib/components/filter-item/filter-item.component.js +10 -5
  8. package/esm2015/lib/components/input-date-picker/input-date-picker.component.js +3 -1
  9. package/esm2015/lib/components/list-of-values/list-of-values.component.js +14 -6
  10. package/esm2015/lib/directives/screen-configuration/screen-configuration.directive.js +123 -33
  11. package/esm2015/lib/directives/screen-configuration/screen-configuration.module.js +4 -6
  12. package/esm2015/lib/service/base-module-screen-config.service.js +205 -0
  13. package/esm2015/lib/service/base-module.service.js +42 -0
  14. package/esm2015/public-api.js +4 -1
  15. package/fesm2015/colijnit-corecomponents_v12.js +402 -83
  16. package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
  17. package/lib/components/button/button.component.d.ts +11 -3
  18. package/lib/directives/screen-configuration/screen-configuration.directive.d.ts +25 -9
  19. package/lib/service/base-module-screen-config.service.d.ts +47 -0
  20. package/lib/service/base-module.service.d.ts +22 -0
  21. package/package.json +5 -4
  22. package/public-api.d.ts +3 -0
  23. package/esm2015/lib/directives/screen-configuration/screen-config-component-wrapper.component.js +0 -30
  24. package/lib/directives/screen-configuration/screen-config-component-wrapper.component.d.ts +0 -11
@@ -1,9 +1,10 @@
1
- import { Component, ElementRef, HostBinding, Input, ViewChild, ViewEncapsulation } from '@angular/core';
1
+ import { Component, ElementRef, forwardRef, HostBinding, Input, ViewChild, ViewEncapsulation } from '@angular/core';
2
2
  import { BaseInputComponent } from '../base/base-input.component';
3
3
  import { CoreComponentsIcon } from '../../core/enum/core-components-icon.enum';
4
4
  import { OverlayService } from '../../service/overlay.service';
5
5
  import { ListOfValuesPopupComponent } from './list-of-values-popup.component';
6
6
  import { KeyboardKey } from '../../core/enum/keyboard-key.enum';
7
+ import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from '../../interfaces/screen-config-adapter-component-interface-name';
7
8
  export class ListOfValuesComponent extends BaseInputComponent {
8
9
  constructor() {
9
10
  super(...arguments);
@@ -40,8 +41,11 @@ export class ListOfValuesComponent extends BaseInputComponent {
40
41
  if (this._lovPopupComponentRef) {
41
42
  this._lovPopupComponentRef.instance.searchTerm = model;
42
43
  }
43
- if (!this.selectedModel && model) {
44
- this.openPopup();
44
+ else {
45
+ if (!this.selectedModel && model) {
46
+ this.openPopup();
47
+ this._lovPopupComponentRef.instance.searchTerm = model;
48
+ }
45
49
  }
46
50
  this.selectedModel = model;
47
51
  }
@@ -160,7 +164,7 @@ export class ListOfValuesComponent extends BaseInputComponent {
160
164
  this.selectedModel = this.model[this.displayField];
161
165
  }
162
166
  else {
163
- this.selectedModel = "";
167
+ this.selectedModel = '';
164
168
  }
165
169
  }
166
170
  }
@@ -203,7 +207,11 @@ ListOfValuesComponent.decorators = [
203
207
  </co-input-text>
204
208
  `,
205
209
  providers: [
206
- OverlayService
210
+ OverlayService,
211
+ {
212
+ provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,
213
+ useExisting: forwardRef(() => ListOfValuesComponent)
214
+ }
207
215
  ],
208
216
  encapsulation: ViewEncapsulation.None
209
217
  },] }
@@ -221,4 +229,4 @@ ListOfValuesComponent.propDecorators = {
221
229
  searchDisabled: [{ type: Input }],
222
230
  showClass: [{ type: HostBinding, args: ['class.co-list-of-values',] }]
223
231
  };
224
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-of-values.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/list-of-values/list-of-values.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ComponentRef, ElementRef, HostBinding, Input, OnInit, ViewChild, ViewEncapsulation} from '@angular/core';\r\nimport {BaseInputComponent} from '../base/base-input.component';\r\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\r\nimport {OverlayService} from '../../service/overlay.service';\r\nimport {ListOfValuesPopupComponent} from './list-of-values-popup.component';\r\nimport {KeyboardKey} from '../../core/enum/keyboard-key.enum';\r\nimport {SafeHtml} from '@angular/platform-browser';\r\n\r\n@Component({\r\n    selector: 'co-list-of-values',\r\n    template: `\r\n        <co-input-text aria-haspopup=\"listbox\" [attr.aria-expanded]=\"isSelectOpen\" aria-controls=\"lov-popup\" role=\"combobox\"\r\n                       class=\"no-focus-line\"\r\n                       overlayParent\r\n                       #parentForOverlay=\"overlayParent\" type=\"text\" [id]=\"label\"\r\n                       [model]=\"multiselect ? selectedModels : selectedModel\"\r\n                       [placeholder]=\"label\"\r\n                       [readonly]=\"readonly\"\r\n                       [disabled]=\"disabled\"\r\n                       [required]=\"required\"\r\n                       [noClickFocus]=\"false\"\r\n                       [leftIconData]=\"leftIconData\"\r\n                       [rightIcon]=\"isSelectOpen ? icons.ChevronUpRegular : icons.ChevronDownRegular\"\r\n                       [showClearButton]=\"true\"\r\n                       [useContent]=\"multiselect\"\r\n                       [customHeight]=\"multiselect\"\r\n                       [keepFocussed]=\"keepFocussed\"\r\n                       (modelChange)=\"handleInputModelChange($event)\"\r\n                       (click)=\"openPopup()\"\r\n                       (rightIconClick)=\"toggleSelect()\"\r\n                       (keydown)=\"handleInputKeyDown($event)\"\r\n                       (clearIconClick)=\"clearModel($event)\"\r\n                       (blur)=\"checkModel()\"\r\n        >\r\n            <ng-container *ngIf=\"multiselect\">\r\n                <div class=\"multiselect-chips-wrapper\">\r\n                    <div class=\"chips\" *ngFor=\"let chip of model\">\r\n                        <span class=\"chips-description\" [textContent]=\"chip[displayField]\"></span>\r\n                        <co-icon class=\"remove-chip-icon\" [icon]=\"icons.CrossSkinny\" (click)=\"removeOptionFromModel(chip)\"></co-icon>\r\n                    </div>\r\n                </div>\r\n            </ng-container>\r\n        </co-input-text>\r\n    `,\r\n    providers: [\r\n        OverlayService\r\n    ],\r\n    encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class ListOfValuesComponent extends BaseInputComponent<any> implements OnInit {\r\n    public readonly icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n\r\n    @Input()\r\n    public set model(value: any) {\r\n        super.model = value;\r\n        this._setSelectedModel();\r\n    }\r\n\r\n    public get model(): any {\r\n        return super.model;\r\n    }\r\n\r\n    @ViewChild('parentForOverlay', {read: ElementRef})\r\n    public parentForOverlay: ElementRef;\r\n\r\n    @HostBinding('class.custom-height')\r\n    @HostBinding('class.multi-select')\r\n    @Input()\r\n    public multiselect: boolean = false;\r\n\r\n    @Input()\r\n    public displayField: string = 'description';\r\n\r\n    @Input()\r\n    public set collection(value: any[]) {\r\n        this._collection = value || [];\r\n    }\r\n\r\n    public get collection(): any[] {\r\n        return this._collection;\r\n    }\r\n\r\n    @Input()\r\n    public leftIconData: SafeHtml | undefined;\r\n\r\n    @Input()\r\n    public searchPlaceholder: string;\r\n\r\n    @Input()\r\n    public label: string;\r\n\r\n    @Input()\r\n    public customCssClass: string;\r\n\r\n    @Input()\r\n    public searchDisabled: boolean = false;\r\n\r\n    @HostBinding('class.co-list-of-values')\r\n    public showClass() {\r\n        return true;\r\n    }\r\n\r\n    public isSelectOpen: boolean = false;\r\n    public state: string = 'default';\r\n    public selectedModel: string;\r\n    public selectedModels: string[] = [];\r\n\r\n    private _collection: any[] = [];\r\n\r\n    private _lovPopupComponentRef: ComponentRef<any>;\r\n\r\n    ngOnInit() {\r\n        super.ngOnInit();\r\n        this._setSelectedModel();\r\n    }\r\n\r\n    public handleInputModelChange(model: string): void {\r\n        if (this._lovPopupComponentRef) {\r\n            this._lovPopupComponentRef.instance.searchTerm = model;\r\n        }\r\n        if (!this.selectedModel && model) {\r\n            this.openPopup();\r\n        }\r\n        this.selectedModel = model;\r\n    }\r\n\r\n    public handleInputKeyDown(event: KeyboardEvent): boolean {\r\n        if (event) {\r\n            if (event.altKey && event.code === KeyboardKey.Down && !this._lovPopupComponentRef) {\r\n                this.openPopup();\r\n                return false;\r\n            }\r\n            if (this._lovPopupComponentRef) {\r\n                switch (event.code) {\r\n                    case KeyboardKey.Down:\r\n                        this._lovPopupComponentRef.instance.selectNextOption();\r\n                        return false;\r\n                    case KeyboardKey.Up:\r\n                        this._lovPopupComponentRef.instance.selectNextOption(true);\r\n                        return false;\r\n                    case KeyboardKey.Enter:\r\n                        this._lovPopupComponentRef.instance.selectOptionAndClosePopup();\r\n                        return false;\r\n                    case KeyboardKey.Tab:\r\n                        this._lovPopupComponentRef.instance.selectOptionAndClosePopup();\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    public clearModel(event: MouseEvent): void {\r\n        this.setModel(undefined);\r\n    }\r\n\r\n    public toggleSelect(): void {\r\n        if (this.readonly) {\r\n            return;\r\n        }\r\n        this.isSelectOpen = !this.isSelectOpen;\r\n        if (this.isSelectOpen) {\r\n            this.openPopup();\r\n        } else {\r\n            this.closePopup();\r\n        }\r\n        this.state = (this.state === 'default' ? 'rotated' : 'default');\r\n    }\r\n\r\n    public openPopup(): void {\r\n        if (this.readonly) {\r\n            return;\r\n        }\r\n        this.isSelectOpen = true;\r\n        this._lovPopupComponentRef = this.overlayService.createComponent(ListOfValuesPopupComponent, {\r\n                parentForOverlay: this.elementRef,\r\n                customCssClass: this.customCssClass,\r\n                searchDisabled: this.searchDisabled,\r\n                searchPlaceholder: this.searchPlaceholder,\r\n                displayField: this.displayField,\r\n                multiselect: this.multiselect,\r\n                model: this.model,\r\n                collection: this.collection\r\n            }, {\r\n                modelChange: (value) => this.optionChosen(value),\r\n                closePopup: () => this.closePopup(),\r\n                keyDown: (event: KeyboardEvent) => this.handleInputKeyDown(event)\r\n            });\r\n        this.keepFocussed = true;\r\n    }\r\n\r\n    public removeOptionFromModel(chip: any): void {\r\n        if (this.multiselect) {\r\n            const idx: number = this.model.findIndex(m => m === chip);\r\n            this.model.splice(idx, 1);\r\n            this.modelChange.emit(this.model);\r\n        }\r\n    }\r\n\r\n    public optionChosen(option: any): void {\r\n        if (option) {\r\n            if (this.multiselect) {\r\n                this.selectedModels = option.map(o => o[this.displayField]);\r\n            } else {\r\n                this.selectedModel = option[this.displayField];\r\n            }\r\n        }\r\n        this.model = option;\r\n        this.modelChange.emit(this.model);\r\n    }\r\n\r\n    public closePopup(): void {\r\n        this.keepFocussed = false;\r\n        this.isSelectOpen = false;\r\n        this.overlayService.removeComponent(this._lovPopupComponentRef);\r\n        this._lovPopupComponentRef = undefined;\r\n        this.focused = false;\r\n    }\r\n\r\n    public checkModel(): void {\r\n        if (!this.multiselect && this.selectedModel && this.collection) {\r\n            const model: any = this.collection.find(c => c[this.displayField] === this.selectedModel);\r\n            if (model) {\r\n                this.model = model;\r\n            } else {\r\n                this.model = undefined;\r\n            }\r\n            this.modelChange.emit(this.model);\r\n        }\r\n    }\r\n\r\n    private _setSelectedModel(): void {\r\n        if (this.multiselect) {\r\n            if (this.model) {\r\n                this.selectedModels.length = 0;\r\n                this.model.forEach(m => {\r\n                    this.selectedModels.push(m[this.displayField]);\r\n                });\r\n            } else {\r\n                this.selectedModels.length = 0;\r\n            }\r\n        } else {\r\n            if (this.model) {\r\n                this.selectedModel = this.model[this.displayField];\r\n            } else {\r\n                this.selectedModel = \"\";\r\n            }\r\n        }\r\n    }\r\n\r\n}\r\n"]}
232
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-of-values.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/list-of-values/list-of-values.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ComponentRef, ElementRef, forwardRef, HostBinding, Input, OnInit, ViewChild, ViewEncapsulation} from '@angular/core';\r\nimport {BaseInputComponent} from '../base/base-input.component';\r\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\r\nimport {OverlayService} from '../../service/overlay.service';\r\nimport {ListOfValuesPopupComponent} from './list-of-values-popup.component';\r\nimport {KeyboardKey} from '../../core/enum/keyboard-key.enum';\r\nimport {SafeHtml} from '@angular/platform-browser';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\r\n\r\n@Component({\r\n    selector: 'co-list-of-values',\r\n    template: `\r\n        <co-input-text aria-haspopup=\"listbox\" [attr.aria-expanded]=\"isSelectOpen\" aria-controls=\"lov-popup\" role=\"combobox\"\r\n                       class=\"no-focus-line\"\r\n                       overlayParent\r\n                       #parentForOverlay=\"overlayParent\" type=\"text\" [id]=\"label\"\r\n                       [model]=\"multiselect ? selectedModels : selectedModel\"\r\n                       [placeholder]=\"label\"\r\n                       [readonly]=\"readonly\"\r\n                       [disabled]=\"disabled\"\r\n                       [required]=\"required\"\r\n                       [noClickFocus]=\"false\"\r\n                       [leftIconData]=\"leftIconData\"\r\n                       [rightIcon]=\"isSelectOpen ? icons.ChevronUpRegular : icons.ChevronDownRegular\"\r\n                       [showClearButton]=\"true\"\r\n                       [useContent]=\"multiselect\"\r\n                       [customHeight]=\"multiselect\"\r\n                       [keepFocussed]=\"keepFocussed\"\r\n                       (modelChange)=\"handleInputModelChange($event)\"\r\n                       (click)=\"openPopup()\"\r\n                       (rightIconClick)=\"toggleSelect()\"\r\n                       (keydown)=\"handleInputKeyDown($event)\"\r\n                       (clearIconClick)=\"clearModel($event)\"\r\n                       (blur)=\"checkModel()\"\r\n        >\r\n            <ng-container *ngIf=\"multiselect\">\r\n                <div class=\"multiselect-chips-wrapper\">\r\n                    <div class=\"chips\" *ngFor=\"let chip of model\">\r\n                        <span class=\"chips-description\" [textContent]=\"chip[displayField]\"></span>\r\n                        <co-icon class=\"remove-chip-icon\" [icon]=\"icons.CrossSkinny\" (click)=\"removeOptionFromModel(chip)\"></co-icon>\r\n                    </div>\r\n                </div>\r\n            </ng-container>\r\n        </co-input-text>\r\n    `,\r\n    providers: [\r\n        OverlayService,\r\n        {\r\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n            useExisting: forwardRef(() => ListOfValuesComponent)\r\n        }\r\n    ],\r\n    encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class ListOfValuesComponent extends BaseInputComponent<any> implements OnInit {\r\n    public readonly icons: typeof CoreComponentsIcon = CoreComponentsIcon;\r\n\r\n    @Input()\r\n    public set model(value: any) {\r\n        super.model = value;\r\n        this._setSelectedModel();\r\n    }\r\n\r\n    public get model(): any {\r\n        return super.model;\r\n    }\r\n\r\n    @ViewChild('parentForOverlay', {read: ElementRef})\r\n    public parentForOverlay: ElementRef;\r\n\r\n    @HostBinding('class.custom-height')\r\n    @HostBinding('class.multi-select')\r\n    @Input()\r\n    public multiselect: boolean = false;\r\n\r\n    @Input()\r\n    public displayField: string = 'description';\r\n\r\n    @Input()\r\n    public set collection(value: any[]) {\r\n        this._collection = value || [];\r\n    }\r\n\r\n    public get collection(): any[] {\r\n        return this._collection;\r\n    }\r\n\r\n    @Input()\r\n    public leftIconData: SafeHtml | undefined;\r\n\r\n    @Input()\r\n    public searchPlaceholder: string;\r\n\r\n    @Input()\r\n    public label: string;\r\n\r\n    @Input()\r\n    public customCssClass: string;\r\n\r\n    @Input()\r\n    public searchDisabled: boolean = false;\r\n\r\n    @HostBinding('class.co-list-of-values')\r\n    public showClass() {\r\n        return true;\r\n    }\r\n\r\n    public isSelectOpen: boolean = false;\r\n    public state: string = 'default';\r\n    public selectedModel: string;\r\n    public selectedModels: string[] = [];\r\n\r\n    private _collection: any[] = [];\r\n\r\n    private _lovPopupComponentRef: ComponentRef<any>;\r\n\r\n    ngOnInit() {\r\n        super.ngOnInit();\r\n        this._setSelectedModel();\r\n    }\r\n\r\n    public handleInputModelChange(model: string): void {\r\n        if (this._lovPopupComponentRef) {\r\n            this._lovPopupComponentRef.instance.searchTerm = model;\r\n        } else {\r\n            if (!this.selectedModel && model) {\r\n                this.openPopup();\r\n                this._lovPopupComponentRef.instance.searchTerm = model;\r\n            }\r\n        }\r\n        this.selectedModel = model;\r\n    }\r\n\r\n    public handleInputKeyDown(event: KeyboardEvent): boolean {\r\n        if (event) {\r\n            if (event.altKey && event.code === KeyboardKey.Down && !this._lovPopupComponentRef) {\r\n                this.openPopup();\r\n                return false;\r\n            }\r\n            if (this._lovPopupComponentRef) {\r\n                switch (event.code) {\r\n                    case KeyboardKey.Down:\r\n                        this._lovPopupComponentRef.instance.selectNextOption();\r\n                        return false;\r\n                    case KeyboardKey.Up:\r\n                        this._lovPopupComponentRef.instance.selectNextOption(true);\r\n                        return false;\r\n                    case KeyboardKey.Enter:\r\n                        this._lovPopupComponentRef.instance.selectOptionAndClosePopup();\r\n                        return false;\r\n                    case KeyboardKey.Tab:\r\n                        this._lovPopupComponentRef.instance.selectOptionAndClosePopup();\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    public clearModel(event: MouseEvent): void {\r\n        this.setModel(undefined);\r\n    }\r\n\r\n    public toggleSelect(): void {\r\n        if (this.readonly) {\r\n            return;\r\n        }\r\n        this.isSelectOpen = !this.isSelectOpen;\r\n        if (this.isSelectOpen) {\r\n            this.openPopup();\r\n        } else {\r\n            this.closePopup();\r\n        }\r\n        this.state = (this.state === 'default' ? 'rotated' : 'default');\r\n    }\r\n\r\n    public openPopup(): void {\r\n        if (this.readonly) {\r\n            return;\r\n        }\r\n        this.isSelectOpen = true;\r\n        this._lovPopupComponentRef = this.overlayService.createComponent(ListOfValuesPopupComponent, {\r\n            parentForOverlay: this.elementRef,\r\n            customCssClass: this.customCssClass,\r\n            searchDisabled: this.searchDisabled,\r\n            searchPlaceholder: this.searchPlaceholder,\r\n            displayField: this.displayField,\r\n            multiselect: this.multiselect,\r\n            model: this.model,\r\n            collection: this.collection\r\n        }, {\r\n            modelChange: (value) => this.optionChosen(value),\r\n            closePopup: () => this.closePopup(),\r\n            keyDown: (event: KeyboardEvent) => this.handleInputKeyDown(event)\r\n        });\r\n        this.keepFocussed = true;\r\n    }\r\n\r\n    public removeOptionFromModel(chip: any): void {\r\n        if (this.multiselect) {\r\n            const idx: number = this.model.findIndex(m => m === chip);\r\n            this.model.splice(idx, 1);\r\n            this.modelChange.emit(this.model);\r\n        }\r\n    }\r\n\r\n    public optionChosen(option: any): void {\r\n        if (option) {\r\n            if (this.multiselect) {\r\n                this.selectedModels = option.map(o => o[this.displayField]);\r\n            } else {\r\n                this.selectedModel = option[this.displayField];\r\n            }\r\n        }\r\n        this.model = option;\r\n        this.modelChange.emit(this.model);\r\n    }\r\n\r\n    public closePopup(): void {\r\n        this.keepFocussed = false;\r\n        this.isSelectOpen = false;\r\n        this.overlayService.removeComponent(this._lovPopupComponentRef);\r\n        this._lovPopupComponentRef = undefined;\r\n        this.focused = false;\r\n    }\r\n\r\n    public checkModel(): void {\r\n        if (!this.multiselect && this.selectedModel && this.collection) {\r\n            const model: any = this.collection.find(c => c[this.displayField] === this.selectedModel);\r\n            if (model) {\r\n                this.model = model;\r\n            } else {\r\n                this.model = undefined;\r\n            }\r\n            this.modelChange.emit(this.model);\r\n        }\r\n    }\r\n\r\n    private _setSelectedModel(): void {\r\n        if (this.multiselect) {\r\n            if (this.model) {\r\n                this.selectedModels.length = 0;\r\n                this.model.forEach(m => {\r\n                    this.selectedModels.push(m[this.displayField]);\r\n                });\r\n            } else {\r\n                this.selectedModels.length = 0;\r\n            }\r\n        } else {\r\n            if (this.model) {\r\n                this.selectedModel = this.model[this.displayField];\r\n            } else {\r\n                this.selectedModel = '';\r\n            }\r\n        }\r\n    }\r\n\r\n}\r\n"]}
@@ -1,68 +1,158 @@
1
1
  import { __decorate } from "tslib";
2
- import { ComponentFactoryResolver, Directive, Inject, Input, ViewContainerRef } from "@angular/core";
3
- import { InputBoolean } from "../../core/decorator/input-boolean.decorator";
4
- import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from "../../interfaces/screen-config-adapter-component-interface-name";
5
- import { ScreenConfigComponentWrapper } from "./screen-config-component-wrapper.component";
2
+ import { Directive, ElementRef, Inject, Input, Renderer2 } from '@angular/core';
3
+ import { InputBoolean } from '../../core/decorator/input-boolean.decorator';
4
+ import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from '../../interfaces/screen-config-adapter-component-interface-name';
5
+ import { BaseModuleScreenConfigService } from '../../service/base-module-screen-config.service';
6
+ import { BaseModuleService } from '../../service/base-module.service';
6
7
  // Directive to represents the marker of "screen config name ID's" of components within a module.
7
8
  // Manipulates visibility, readonly and other dynamic states of an input element according to its db-fetched screen configuration object.
8
9
  export class ScreenConfigurationDirective {
9
- constructor(hostComponent, _viewContainerRef, _componentFactoryResolver) {
10
+ constructor(hostComponent, _element,
11
+ // we must always have a config service to fetch config objects with
12
+ _configService, _renderer,
13
+ // to make host readonly when MODULE switches to readonly:
14
+ _moduleService) {
10
15
  this.hostComponent = hostComponent;
11
- this._viewContainerRef = _viewContainerRef;
12
- this._componentFactoryResolver = _componentFactoryResolver;
16
+ this._element = _element;
17
+ this._configService = _configService;
18
+ this._renderer = _renderer;
19
+ this._moduleService = _moduleService;
20
+ this.screenConfigNativeElement = false;
13
21
  this.noModuleService = false;
22
+ // feature toggle for devs so you can see the whole screen with all inputs etc by temporarily turning off the hiding effects of this directive on its host
23
+ this._isTurnedOff = false;
24
+ this._subs = [];
25
+ this._subs.push(this._configService.configSet.subscribe((configObjects) => {
26
+ if (configObjects && configObjects.length > 0) {
27
+ this._updateHost();
28
+ }
29
+ }));
30
+ if (this._moduleService && !this.noModuleService) {
31
+ this._subs.push(this._moduleService.readonlyChange.subscribe((moduleInReadonlyState) => {
32
+ if (this.hostComponent) {
33
+ this.hostComponent.readonly = this.hostComponent.forceReadonly || moduleInReadonlyState;
34
+ }
35
+ }), this._moduleService.errorValidationReceived.subscribe((validationResult) => {
36
+ this._setErrorRedBackgroundAfterScrCfgValidate(validationResult);
37
+ }), this._moduleService.successfulUpdate.subscribe(() => {
38
+ if (this.hostComponent) {
39
+ this.hostComponent.redErrorBackground = false;
40
+ }
41
+ }));
42
+ }
14
43
  }
15
- set screenConfigurationObject(screenConfigurationObject) {
16
- if (screenConfigurationObject) {
17
- this._screenConfigurationObject = screenConfigurationObject;
18
- this._initWrapperComponent();
44
+ set screenConfigurationObject(value) {
45
+ if (value) {
46
+ this._screenConfigurationObject = value;
19
47
  this._updateHost();
20
48
  }
21
49
  }
22
50
  get screenConfigurationObject() {
23
51
  return this._screenConfigurationObject;
24
52
  }
53
+ ngOnInit() {
54
+ this._updateHost();
55
+ // this._updateHeaderStateOnHostComponent(true);
56
+ // show initial error message if any
57
+ if (!this.noModuleService) {
58
+ // this._setErrorRedBackgroundAfterScrCfgValidate(this._moduleService.lastError);
59
+ }
60
+ }
25
61
  ngOnDestroy() {
62
+ this._subs.forEach(sub => sub.unsubscribe());
63
+ if (this._isHeader) {
64
+ // this._doubleClickHeaders.handleCollapseableDestroy(this.screenConfigurationObject);
65
+ }
66
+ this._element = undefined;
26
67
  this.hostComponent = undefined;
27
- this._wrapperComponentInstance = undefined;
28
68
  }
29
- _initWrapperComponent() {
30
- if (!this._wrapperComponentInstance) {
31
- const componentFactory = this._componentFactoryResolver.resolveComponentFactory(ScreenConfigComponentWrapper);
32
- const componentRef = this._viewContainerRef.createComponent(componentFactory);
33
- const visibleOnViewInit = !!this.screenConfigurationObject ? this.screenConfigurationObject.immediatelyVisible() : false;
34
- this._wrapperComponentInstance = componentRef.instance;
35
- this._wrapperComponentInstance.setWrapperContent(this._viewContainerRef.element.nativeElement, visibleOnViewInit);
69
+ // Sets host component visibility, required, readonly etc. if specified in backend screen config OR module readonly status.
70
+ _updateHost() {
71
+ if (this._mayUpdateHost() || this.screenConfigNativeElement) {
72
+ if (!this.screenConfigNativeElement) {
73
+ this.hostComponent.objectConfigName = this.screenConfigurationObject;
74
+ }
75
+ const myCfgObj = this._configService.getObjectConfigurationFor(this.screenConfigurationObject);
76
+ if (myCfgObj) {
77
+ this._setHostVisible(myCfgObj.immediatelyVisible());
78
+ // if (this.hostComponent instanceof GridColumnComponent) {
79
+ // this.hostComponent.rights = myCfgObj.rights;
80
+ // }
81
+ if (!this.screenConfigNativeElement) {
82
+ this.hostComponent.required = myCfgObj.isRequired();
83
+ this.hostComponent.readonly = this.hostComponent.forceReadonly || this._moduleInReadonlyMode() || myCfgObj.isReadonly();
84
+ this.hostComponent.decimals = myCfgObj.scale;
85
+ this.hostComponent.maxLength = myCfgObj.maxLength;
86
+ }
87
+ }
88
+ else {
89
+ this._setHostVisible(false);
90
+ if (!this.screenConfigNativeElement) {
91
+ this.hostComponent.readonly = this._moduleInReadonlyMode();
92
+ }
93
+ }
94
+ }
95
+ }
96
+ /**
97
+ * Spawn error message tooltip onto our host comp, if any error was meant for the host (found by screenConfigurationObject);
98
+ * @param errorValidation A top-level full validation result, either from the backend or from some client-side validation error.
99
+ */
100
+ _setErrorRedBackgroundAfterScrCfgValidate(errorValidation) {
101
+ if (this.hostComponent && errorValidation) {
102
+ const errorMessages = errorValidation.getAllErrorMessagesOfMyValidationFields();
103
+ for (let i = 0, len = errorMessages.length; i < len; i++) {
104
+ const errorMsg = errorMessages[i];
105
+ const configName = this.dataName ? this.dataName : this.screenConfigurationObject;
106
+ if (errorMsg.fieldId === configName && this._element /*&& this._properHost(errorMsg.boId)*/) {
107
+ this.hostComponent.redErrorBackground = true;
108
+ }
109
+ }
36
110
  }
37
111
  }
38
- _updateHost() {
39
- if (!!this.hostComponent && !!this._screenConfigurationObject) {
40
- this.hostComponent.objectConfigName = this.screenConfigurationObject.configName;
41
- if (this.screenConfigurationObject) {
42
- this.hostComponent.required = this.screenConfigurationObject.isRequired();
43
- // readonly based on forced boolean, based on rights value or based on variable value affected by module read only state
44
- this.hostComponent.readonly = this.hostComponent.forceReadonly || this.screenConfigurationObject.isReadonly() || this.screenConfigurationObject.variableReadOnly;
45
- this.hostComponent.decimals = this.screenConfigurationObject.scale;
46
- this.hostComponent.maxLength = this.screenConfigurationObject.maxLength;
112
+ _moduleInReadonlyMode() {
113
+ return !this.noModuleService ? (this._moduleService ? this._moduleService.readonly : false) : false;
114
+ }
115
+ _mayUpdateHost() {
116
+ return !!this.hostComponent && !this._isTurnedOff && !!this.screenConfigurationObject;
117
+ }
118
+ _setHostVisible(visible) {
119
+ if (!this.screenConfigNativeElement) {
120
+ this.hostComponent.hidden = !visible;
121
+ }
122
+ else {
123
+ if (this._element && this._element.nativeElement) {
124
+ if (!visible) {
125
+ this._renderer.addClass(this._element.nativeElement, 'hidden');
126
+ }
127
+ else {
128
+ this._renderer.removeClass(this._element.nativeElement, 'hidden');
129
+ }
47
130
  }
48
131
  }
49
132
  }
50
133
  }
51
134
  ScreenConfigurationDirective.decorators = [
52
135
  { type: Directive, args: [{
53
- selector: "[screenConfigurationObject]"
136
+ selector: '[screenConfigurationObject]'
54
137
  },] }
55
138
  ];
56
139
  ScreenConfigurationDirective.ctorParameters = () => [
57
140
  { type: undefined, decorators: [{ type: Inject, args: [SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,] }] },
58
- { type: ViewContainerRef },
59
- { type: ComponentFactoryResolver }
141
+ { type: ElementRef },
142
+ { type: BaseModuleScreenConfigService },
143
+ { type: Renderer2 },
144
+ { type: BaseModuleService }
60
145
  ];
61
146
  ScreenConfigurationDirective.propDecorators = {
62
- screenConfigurationObject: [{ type: Input }],
147
+ screenConfigurationObject: [{ type: Input, args: ['screenConfigurationObject',] }],
148
+ dataName: [{ type: Input }],
149
+ screenConfigNativeElement: [{ type: Input }],
63
150
  noModuleService: [{ type: Input }]
64
151
  };
152
+ __decorate([
153
+ InputBoolean()
154
+ ], ScreenConfigurationDirective.prototype, "screenConfigNativeElement", void 0);
65
155
  __decorate([
66
156
  InputBoolean()
67
157
  ], ScreenConfigurationDirective.prototype, "noModuleService", void 0);
68
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NyZWVuLWNvbmZpZ3VyYXRpb24uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9kaXJlY3RpdmVzL3NjcmVlbi1jb25maWd1cmF0aW9uL3NjcmVlbi1jb25maWd1cmF0aW9uLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUNMLHdCQUF3QixFQUN4QixTQUFTLEVBQ1QsTUFBTSxFQUNOLEtBQUssRUFDTCxnQkFBZ0IsRUFDakIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLDhDQUE4QyxDQUFDO0FBRTFFLE9BQU8sRUFBRSw4Q0FBOEMsRUFBRSxNQUFNLGlFQUFpRSxDQUFDO0FBQ2pJLE9BQU8sRUFDTCw0QkFBNEIsRUFDN0IsTUFBTSw2Q0FBNkMsQ0FBQztBQUVyRCxpR0FBaUc7QUFDakcseUlBQXlJO0FBSXpJLE1BQU0sT0FBTyw0QkFBNEI7SUFzQnZDLFlBRVMsYUFBMkMsRUFDMUMsaUJBQW1DLEVBQ25DLHlCQUFtRDtRQUZwRCxrQkFBYSxHQUFiLGFBQWEsQ0FBOEI7UUFDMUMsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFrQjtRQUNuQyw4QkFBeUIsR0FBekIseUJBQXlCLENBQTBCO1FBVHRELG9CQUFlLEdBQVksS0FBSyxDQUFDO0lBVXBDLENBQUM7SUF6QkwsSUFDVyx5QkFBeUIsQ0FBQyx5QkFBOEI7UUFDakUsSUFBSSx5QkFBeUIsRUFBRTtZQUM3QixJQUFJLENBQUMsMEJBQTBCLEdBQUcseUJBQXlCLENBQUM7WUFDNUQsSUFBSSxDQUFDLHFCQUFxQixFQUFFLENBQUM7WUFDN0IsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1NBQ3BCO0lBQ0gsQ0FBQztJQUVELElBQVcseUJBQXlCO1FBQ2xDLE9BQU8sSUFBSSxDQUFDLDBCQUEwQixDQUFDO0lBQ3pDLENBQUM7SUFnQk0sV0FBVztRQUNoQixJQUFJLENBQUMsYUFBYSxHQUFHLFNBQVMsQ0FBQztRQUMvQixJQUFJLENBQUMseUJBQXlCLEdBQUcsU0FBUyxDQUFDO0lBQzdDLENBQUM7SUFFTyxxQkFBcUI7UUFDM0IsSUFBSSxDQUFDLElBQUksQ0FBQyx5QkFBeUIsRUFBRTtZQUNuQyxNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyx1QkFBdUIsQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDO1lBQzlHLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxlQUFlLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztZQUM5RSxNQUFNLGlCQUFpQixHQUFZLENBQUMsQ0FBQyxJQUFJLENBQUMseUJBQXlCLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxrQkFBa0IsRUFBRSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7WUFDbEksSUFBSSxDQUFDLHlCQUF5QixHQUFHLFlBQVksQ0FBQyxRQUFRLENBQUM7WUFDdkQsSUFBSSxDQUFDLHlCQUF5QixDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxPQUFPLENBQUMsYUFBYSxFQUFFLGlCQUFpQixDQUFDLENBQUM7U0FDbkg7SUFDSCxDQUFDO0lBRU8sV0FBVztRQUNqQixJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsYUFBYSxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsMEJBQTBCLEVBQUU7WUFDN0QsSUFBSSxDQUFDLGFBQWEsQ0FBQyxnQkFBZ0IsR0FBRyxJQUFJLENBQUMseUJBQXlCLENBQUMsVUFBVSxDQUFDO1lBQ2hGLElBQUksSUFBSSxDQUFDLHlCQUF5QixFQUFFO2dCQUNsQyxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMseUJBQXlCLENBQUMsVUFBVSxFQUFFLENBQUM7Z0JBQzFFLHdIQUF3SDtnQkFDeEgsSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxhQUFhLElBQUksSUFBSSxDQUFDLHlCQUF5QixDQUFDLFVBQVUsRUFBRSxJQUFJLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxnQkFBZ0IsQ0FBQztnQkFDakssSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLHlCQUF5QixDQUFDLEtBQUssQ0FBQztnQkFDbkUsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLHlCQUF5QixDQUFDLFNBQVMsQ0FBQzthQUN6RTtTQUNGO0lBQ0gsQ0FBQzs7O1lBMURGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsNkJBQTZCO2FBQ3hDOzs7NENBd0JJLE1BQU0sU0FBQyw4Q0FBOEM7WUFyQ3hELGdCQUFnQjtZQUpoQix3QkFBd0I7Ozt3Q0FvQnZCLEtBQUs7OEJBYUwsS0FBSzs7QUFFTjtJQURDLFlBQVksRUFBRTtxRUFDeUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENvbXBvbmVudEZhY3RvcnlSZXNvbHZlcixcclxuICBEaXJlY3RpdmUsXHJcbiAgSW5qZWN0LFxyXG4gIElucHV0LCBPbkRlc3Ryb3ksXHJcbiAgVmlld0NvbnRhaW5lclJlZlxyXG59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7SW5wdXRCb29sZWFufSBmcm9tIFwiLi4vLi4vY29yZS9kZWNvcmF0b3IvaW5wdXQtYm9vbGVhbi5kZWNvcmF0b3JcIjtcclxuaW1wb3J0IHtTY3JlZW5Db25maWdBZGFwdGVyQ29tcG9uZW50fSBmcm9tIFwiLi4vLi4vaW50ZXJmYWNlcy9zY3JlZW4tY29uZmlnLWFkYXB0ZXIuY29tcG9uZW50LmludGVyZmFjZVwiO1xyXG5pbXBvcnQgeyBTQ1JFRU5fQ09ORklHX0FEQVBURVJfQ09NUE9ORU5UX0lOVEVSRkFDRV9OQU1FIH0gZnJvbSBcIi4uLy4uL2ludGVyZmFjZXMvc2NyZWVuLWNvbmZpZy1hZGFwdGVyLWNvbXBvbmVudC1pbnRlcmZhY2UtbmFtZVwiO1xyXG5pbXBvcnQge1xyXG4gIFNjcmVlbkNvbmZpZ0NvbXBvbmVudFdyYXBwZXJcclxufSBmcm9tIFwiLi9zY3JlZW4tY29uZmlnLWNvbXBvbmVudC13cmFwcGVyLmNvbXBvbmVudFwiO1xyXG5cclxuLy8gRGlyZWN0aXZlIHRvIHJlcHJlc2VudHMgdGhlIG1hcmtlciBvZiBcInNjcmVlbiBjb25maWcgbmFtZSBJRCdzXCIgb2YgY29tcG9uZW50cyB3aXRoaW4gYSBtb2R1bGUuXHJcbi8vIE1hbmlwdWxhdGVzIHZpc2liaWxpdHksIHJlYWRvbmx5IGFuZCBvdGhlciBkeW5hbWljIHN0YXRlcyBvZiBhbiBpbnB1dCBlbGVtZW50IGFjY29yZGluZyB0byBpdHMgZGItZmV0Y2hlZCBzY3JlZW4gY29uZmlndXJhdGlvbiBvYmplY3QuXHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOiBcIltzY3JlZW5Db25maWd1cmF0aW9uT2JqZWN0XVwiXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTY3JlZW5Db25maWd1cmF0aW9uRGlyZWN0aXZlIGltcGxlbWVudHMgT25EZXN0cm95IHtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgc2V0IHNjcmVlbkNvbmZpZ3VyYXRpb25PYmplY3Qoc2NyZWVuQ29uZmlndXJhdGlvbk9iamVjdDogYW55KSB7XHJcbiAgICBpZiAoc2NyZWVuQ29uZmlndXJhdGlvbk9iamVjdCkge1xyXG4gICAgICB0aGlzLl9zY3JlZW5Db25maWd1cmF0aW9uT2JqZWN0ID0gc2NyZWVuQ29uZmlndXJhdGlvbk9iamVjdDtcclxuICAgICAgdGhpcy5faW5pdFdyYXBwZXJDb21wb25lbnQoKTtcclxuICAgICAgdGhpcy5fdXBkYXRlSG9zdCgpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBzY3JlZW5Db25maWd1cmF0aW9uT2JqZWN0KCk6IGFueSB7XHJcbiAgICByZXR1cm4gdGhpcy5fc2NyZWVuQ29uZmlndXJhdGlvbk9iamVjdDtcclxuICB9XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgQElucHV0Qm9vbGVhbigpXHJcbiAgcHVibGljIG5vTW9kdWxlU2VydmljZTogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBwcml2YXRlIF9zY3JlZW5Db25maWd1cmF0aW9uT2JqZWN0OiBhbnk7XHJcbiAgcHJpdmF0ZSBfd3JhcHBlckNvbXBvbmVudEluc3RhbmNlOiBTY3JlZW5Db25maWdDb21wb25lbnRXcmFwcGVyO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIEBJbmplY3QoU0NSRUVOX0NPTkZJR19BREFQVEVSX0NPTVBPTkVOVF9JTlRFUkZBQ0VfTkFNRSlcclxuICAgIHB1YmxpYyBob3N0Q29tcG9uZW50OiBTY3JlZW5Db25maWdBZGFwdGVyQ29tcG9uZW50LFxyXG4gICAgcHJpdmF0ZSBfdmlld0NvbnRhaW5lclJlZjogVmlld0NvbnRhaW5lclJlZixcclxuICAgIHByaXZhdGUgX2NvbXBvbmVudEZhY3RvcnlSZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyXHJcbiAgKSB7IH1cclxuXHJcbiAgcHVibGljIG5nT25EZXN0cm95KCk6IHZvaWQge1xyXG4gICAgdGhpcy5ob3N0Q29tcG9uZW50ID0gdW5kZWZpbmVkO1xyXG4gICAgdGhpcy5fd3JhcHBlckNvbXBvbmVudEluc3RhbmNlID0gdW5kZWZpbmVkO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBfaW5pdFdyYXBwZXJDb21wb25lbnQoKTogdm9pZCB7XHJcbiAgICBpZiAoIXRoaXMuX3dyYXBwZXJDb21wb25lbnRJbnN0YW5jZSkge1xyXG4gICAgICBjb25zdCBjb21wb25lbnRGYWN0b3J5ID0gdGhpcy5fY29tcG9uZW50RmFjdG9yeVJlc29sdmVyLnJlc29sdmVDb21wb25lbnRGYWN0b3J5KFNjcmVlbkNvbmZpZ0NvbXBvbmVudFdyYXBwZXIpO1xyXG4gICAgICBjb25zdCBjb21wb25lbnRSZWYgPSB0aGlzLl92aWV3Q29udGFpbmVyUmVmLmNyZWF0ZUNvbXBvbmVudChjb21wb25lbnRGYWN0b3J5KTtcclxuICAgICAgY29uc3QgdmlzaWJsZU9uVmlld0luaXQ6IGJvb2xlYW4gPSAhIXRoaXMuc2NyZWVuQ29uZmlndXJhdGlvbk9iamVjdCA/IHRoaXMuc2NyZWVuQ29uZmlndXJhdGlvbk9iamVjdC5pbW1lZGlhdGVseVZpc2libGUoKSA6IGZhbHNlO1xyXG4gICAgICB0aGlzLl93cmFwcGVyQ29tcG9uZW50SW5zdGFuY2UgPSBjb21wb25lbnRSZWYuaW5zdGFuY2U7XHJcbiAgICAgIHRoaXMuX3dyYXBwZXJDb21wb25lbnRJbnN0YW5jZS5zZXRXcmFwcGVyQ29udGVudCh0aGlzLl92aWV3Q29udGFpbmVyUmVmLmVsZW1lbnQubmF0aXZlRWxlbWVudCwgdmlzaWJsZU9uVmlld0luaXQpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBfdXBkYXRlSG9zdCgpOiB2b2lkIHtcclxuICAgIGlmICghIXRoaXMuaG9zdENvbXBvbmVudCAmJiAhIXRoaXMuX3NjcmVlbkNvbmZpZ3VyYXRpb25PYmplY3QpIHtcclxuICAgICAgdGhpcy5ob3N0Q29tcG9uZW50Lm9iamVjdENvbmZpZ05hbWUgPSB0aGlzLnNjcmVlbkNvbmZpZ3VyYXRpb25PYmplY3QuY29uZmlnTmFtZTtcclxuICAgICAgaWYgKHRoaXMuc2NyZWVuQ29uZmlndXJhdGlvbk9iamVjdCkge1xyXG4gICAgICAgIHRoaXMuaG9zdENvbXBvbmVudC5yZXF1aXJlZCA9IHRoaXMuc2NyZWVuQ29uZmlndXJhdGlvbk9iamVjdC5pc1JlcXVpcmVkKCk7XHJcbiAgICAgICAgLy8gcmVhZG9ubHkgYmFzZWQgb24gZm9yY2VkIGJvb2xlYW4sIGJhc2VkIG9uIHJpZ2h0cyB2YWx1ZSBvciBiYXNlZCBvbiB2YXJpYWJsZSB2YWx1ZSBhZmZlY3RlZCBieSBtb2R1bGUgcmVhZCBvbmx5IHN0YXRlXHJcbiAgICAgICAgdGhpcy5ob3N0Q29tcG9uZW50LnJlYWRvbmx5ID0gdGhpcy5ob3N0Q29tcG9uZW50LmZvcmNlUmVhZG9ubHkgfHwgdGhpcy5zY3JlZW5Db25maWd1cmF0aW9uT2JqZWN0LmlzUmVhZG9ubHkoKSB8fCB0aGlzLnNjcmVlbkNvbmZpZ3VyYXRpb25PYmplY3QudmFyaWFibGVSZWFkT25seTtcclxuICAgICAgICB0aGlzLmhvc3RDb21wb25lbnQuZGVjaW1hbHMgPSB0aGlzLnNjcmVlbkNvbmZpZ3VyYXRpb25PYmplY3Quc2NhbGU7XHJcbiAgICAgICAgdGhpcy5ob3N0Q29tcG9uZW50Lm1heExlbmd0aCA9IHRoaXMuc2NyZWVuQ29uZmlndXJhdGlvbk9iamVjdC5tYXhMZW5ndGg7XHJcbiAgICAgIH1cclxuICAgIH1cclxuICB9XHJcbn1cclxuIl19
158
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"screen-configuration.directive.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/directives/screen-configuration/screen-configuration.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, Inject, Input, OnDestroy, Renderer2} from '@angular/core';\r\nimport {InputBoolean} from '../../core/decorator/input-boolean.decorator';\r\nimport {ScreenConfigAdapterComponent} from '../../interfaces/screen-config-adapter.component.interface';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\r\nimport {Subscription} from 'rxjs';\r\nimport {BaseModuleScreenConfigService} from '../../service/base-module-screen-config.service';\r\nimport {BaseModuleService} from '../../service/base-module.service';\r\nimport {ValidationResult} from '@colijnit/ioneconnector/build/model/validation-result';\r\nimport {ValidationMessage} from '@colijnit/ioneconnector/build/model/validation-message';\r\nimport {ObjectConfiguration} from '@colijnit/ioneconnector/build/model/object-configuration';\r\n\r\n// Directive to represents the marker of \"screen config name ID's\" of components within a module.\r\n// Manipulates visibility, readonly and other dynamic states of an input element according to its db-fetched screen configuration object.\r\n@Directive({\r\n    selector: '[screenConfigurationObject]'\r\n})\r\nexport class ScreenConfigurationDirective implements OnDestroy {\r\n    @Input('screenConfigurationObject')\r\n    public set screenConfigurationObject(value: string) {\r\n        if (value) {\r\n            this._screenConfigurationObject = value;\r\n            this._updateHost();\r\n        }\r\n    }\r\n\r\n    public get screenConfigurationObject(): string {\r\n        return this._screenConfigurationObject;\r\n    }\r\n\r\n    @Input()\r\n    public dataName: string;\r\n\r\n    @Input()\r\n    @InputBoolean()\r\n    public screenConfigNativeElement: boolean = false;\r\n\r\n    @Input()\r\n    @InputBoolean()\r\n    public noModuleService: boolean = false;\r\n\r\n    private _isHeader: boolean;\r\n\r\n    private _screenConfigurationObject: string;\r\n\r\n    // feature toggle for devs so you can see the whole screen with all inputs etc by temporarily turning off the hiding effects of this directive on its host\r\n    private _isTurnedOff: boolean = false;\r\n\r\n    private _subs: Subscription[] = [];\r\n\r\n    constructor(\r\n        @Inject(SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME)\r\n        public hostComponent: ScreenConfigAdapterComponent,\r\n        private _element: ElementRef,\r\n        // we must always have a config service to fetch config objects with\r\n        private _configService: BaseModuleScreenConfigService,\r\n        private _renderer: Renderer2,\r\n        // to make host readonly when MODULE switches to readonly:\r\n        private _moduleService?: BaseModuleService\r\n    ) {\r\n        this._subs.push(this._configService.configSet.subscribe((configObjects: string[]) => {\r\n            if (configObjects && configObjects.length > 0) {\r\n                this._updateHost();\r\n            }\r\n        }));\r\n\r\n        if (this._moduleService && !this.noModuleService) {\r\n            this._subs.push(\r\n                this._moduleService.readonlyChange.subscribe((moduleInReadonlyState: boolean) => {\r\n                    if (this.hostComponent) {\r\n                        this.hostComponent.readonly = this.hostComponent.forceReadonly || moduleInReadonlyState;\r\n                    }\r\n                }),\r\n                this._moduleService.errorValidationReceived.subscribe((validationResult: any) => {\r\n                    this._setErrorRedBackgroundAfterScrCfgValidate(validationResult);\r\n                }),\r\n                this._moduleService.successfulUpdate.subscribe(() => {\r\n                    if (this.hostComponent) {\r\n                        this.hostComponent.redErrorBackground = false;\r\n                    }\r\n                })\r\n            );\r\n        }\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this._updateHost();\r\n\r\n        // this._updateHeaderStateOnHostComponent(true);\r\n\r\n        // show initial error message if any\r\n        if (!this.noModuleService) {\r\n            // this._setErrorRedBackgroundAfterScrCfgValidate(this._moduleService.lastError);\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this._subs.forEach(sub => sub.unsubscribe());\r\n        if (this._isHeader) {\r\n            // this._doubleClickHeaders.handleCollapseableDestroy(this.screenConfigurationObject);\r\n        }\r\n        this._element = undefined;\r\n        this.hostComponent = undefined;\r\n    }\r\n\r\n    // Sets host component visibility, required, readonly etc. if specified in backend screen config OR module readonly status.\r\n    private _updateHost(): void {\r\n        if (this._mayUpdateHost() || this.screenConfigNativeElement) {\r\n            if (!this.screenConfigNativeElement) {\r\n                this.hostComponent.objectConfigName = this.screenConfigurationObject;\r\n            }\r\n            const myCfgObj: ObjectConfiguration = this._configService.getObjectConfigurationFor(this.screenConfigurationObject);\r\n            if (myCfgObj) {\r\n                this._setHostVisible(myCfgObj.immediatelyVisible());\r\n                // if (this.hostComponent instanceof GridColumnComponent) {\r\n                //   this.hostComponent.rights = myCfgObj.rights;\r\n                // }\r\n                if (!this.screenConfigNativeElement) {\r\n                    this.hostComponent.required = myCfgObj.isRequired();\r\n                    this.hostComponent.readonly = this.hostComponent.forceReadonly || this._moduleInReadonlyMode() || myCfgObj.isReadonly();\r\n                    this.hostComponent.decimals = myCfgObj.scale;\r\n                    this.hostComponent.maxLength = myCfgObj.maxLength;\r\n                }\r\n            } else {\r\n                this._setHostVisible(false);\r\n                if (!this.screenConfigNativeElement) {\r\n                    this.hostComponent.readonly = this._moduleInReadonlyMode();\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Spawn error message tooltip onto our host comp, if any error was meant for the host (found by screenConfigurationObject);\r\n     * @param errorValidation A top-level full validation result, either from the backend or from some client-side validation error.\r\n     */\r\n    private _setErrorRedBackgroundAfterScrCfgValidate(errorValidation: ValidationResult): void {\r\n        if (this.hostComponent && errorValidation) {\r\n            const errorMessages: ValidationMessage[] = errorValidation.getAllErrorMessagesOfMyValidationFields();\r\n            for (let i: number = 0, len: number = errorMessages.length; i < len; i++) {\r\n                const errorMsg: ValidationMessage = errorMessages[i];\r\n                const configName: string = this.dataName ? this.dataName : this.screenConfigurationObject;\r\n                if (errorMsg.fieldId === configName && this._element /*&& this._properHost(errorMsg.boId)*/) {\r\n                    this.hostComponent.redErrorBackground = true;\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    private _moduleInReadonlyMode(): boolean {\r\n        return !this.noModuleService ? (this._moduleService ? this._moduleService.readonly : false) : false;\r\n    }\r\n\r\n    private _mayUpdateHost(): boolean {\r\n        return !!this.hostComponent && !this._isTurnedOff && !!this.screenConfigurationObject;\r\n    }\r\n\r\n    private _setHostVisible(visible: boolean): void {\r\n        if (!this.screenConfigNativeElement) {\r\n            this.hostComponent.hidden = !visible;\r\n        } else {\r\n            if (this._element && this._element.nativeElement) {\r\n                if (!visible) {\r\n                    this._renderer.addClass(this._element.nativeElement, 'hidden');\r\n                } else {\r\n                    this._renderer.removeClass(this._element.nativeElement, 'hidden');\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n"]}
@@ -1,7 +1,6 @@
1
1
  import { NgModule } from '@angular/core';
2
- import { ScreenConfigurationDirective } from "./screen-configuration.directive";
3
- import { CommonModule } from "@angular/common";
4
- import { ScreenConfigComponentWrapper } from "./screen-config-component-wrapper.component";
2
+ import { ScreenConfigurationDirective } from './screen-configuration.directive';
3
+ import { CommonModule } from '@angular/common';
5
4
  export class ScreenConfigurationModule {
6
5
  }
7
6
  ScreenConfigurationModule.decorators = [
@@ -10,12 +9,11 @@ ScreenConfigurationModule.decorators = [
10
9
  CommonModule
11
10
  ],
12
11
  declarations: [
13
- ScreenConfigurationDirective,
14
- ScreenConfigComponentWrapper
12
+ ScreenConfigurationDirective
15
13
  ],
16
14
  exports: [
17
15
  ScreenConfigurationDirective,
18
16
  ]
19
17
  },] }
20
18
  ];
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NyZWVuLWNvbmZpZ3VyYXRpb24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9kaXJlY3RpdmVzL3NjcmVlbi1jb25maWd1cmF0aW9uL3NjcmVlbi1jb25maWd1cmF0aW9uLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQzlFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsNEJBQTRCLEVBQUMsTUFBTSw2Q0FBNkMsQ0FBQztBQWN6RixNQUFNLE9BQU8seUJBQXlCOzs7WUFackMsUUFBUSxTQUFDO2dCQUNSLE9BQU8sRUFBRTtvQkFDUCxZQUFZO2lCQUNiO2dCQUNELFlBQVksRUFBRTtvQkFDWiw0QkFBNEI7b0JBQzVCLDRCQUE0QjtpQkFDN0I7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLDRCQUE0QjtpQkFDN0I7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1NjcmVlbkNvbmZpZ3VyYXRpb25EaXJlY3RpdmV9IGZyb20gXCIuL3NjcmVlbi1jb25maWd1cmF0aW9uLmRpcmVjdGl2ZVwiO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcbmltcG9ydCB7U2NyZWVuQ29uZmlnQ29tcG9uZW50V3JhcHBlcn0gZnJvbSBcIi4vc2NyZWVuLWNvbmZpZy1jb21wb25lbnQtd3JhcHBlci5jb21wb25lbnRcIjtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZVxuICBdLFxuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBTY3JlZW5Db25maWd1cmF0aW9uRGlyZWN0aXZlLFxuICAgIFNjcmVlbkNvbmZpZ0NvbXBvbmVudFdyYXBwZXJcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIFNjcmVlbkNvbmZpZ3VyYXRpb25EaXJlY3RpdmUsXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgU2NyZWVuQ29uZmlndXJhdGlvbk1vZHVsZSB7IH1cbiJdfQ==
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NyZWVuLWNvbmZpZ3VyYXRpb24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9kaXJlY3RpdmVzL3NjcmVlbi1jb25maWd1cmF0aW9uL3NjcmVlbi1jb25maWd1cmF0aW9uLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQzlFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQWE3QyxNQUFNLE9BQU8seUJBQXlCOzs7WUFYckMsUUFBUSxTQUFDO2dCQUNSLE9BQU8sRUFBRTtvQkFDUCxZQUFZO2lCQUNiO2dCQUNELFlBQVksRUFBRTtvQkFDWiw0QkFBNEI7aUJBQzdCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCw0QkFBNEI7aUJBQzdCO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7U2NyZWVuQ29uZmlndXJhdGlvbkRpcmVjdGl2ZX0gZnJvbSAnLi9zY3JlZW4tY29uZmlndXJhdGlvbi5kaXJlY3RpdmUnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGVcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgU2NyZWVuQ29uZmlndXJhdGlvbkRpcmVjdGl2ZVxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgU2NyZWVuQ29uZmlndXJhdGlvbkRpcmVjdGl2ZSxcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBTY3JlZW5Db25maWd1cmF0aW9uTW9kdWxlIHsgfVxuIl19