@kms-ngx-ui/presentational 0.0.23 → 0.0.24

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 (37) hide show
  1. package/bundles/kms-ngx-ui-presentational.umd.js +257 -134
  2. package/bundles/kms-ngx-ui-presentational.umd.js.map +1 -1
  3. package/esm2015/lib/directives/directives.module.js +8 -3
  4. package/esm2015/lib/directives/size.directive.js +21 -0
  5. package/esm2015/lib/parent-components/colorable.component.js +35 -0
  6. package/esm2015/lib/parent-components/form-control.component.js +4 -3
  7. package/esm2015/lib/parent-components/form.component.js +36 -15
  8. package/esm2015/lib/services/viewport.service.js +66 -40
  9. package/esm2015/lib/ui/back-to-top/back-to-top.component.js +1 -1
  10. package/esm2015/lib/ui/file-input/file-input.component.js +6 -6
  11. package/esm2015/lib/ui/flyout/flyout.component.js +5 -4
  12. package/esm2015/lib/ui/icon/icon.component.js +5 -2
  13. package/esm2015/lib/ui/icon/iconSize.enum.js +12 -1
  14. package/esm2015/lib/ui/image-slider/image-slider.component.js +1 -1
  15. package/esm2015/lib/ui/kms-accordion-item/kms-accordion-item.component.js +1 -1
  16. package/esm2015/lib/ui/map/map.component.js +2 -2
  17. package/esm2015/lib/ui/radiobutton/radiobutton.component.js +7 -3
  18. package/esm2015/lib/ui/tooltip-icon/tooltip-icon.component.js +5 -4
  19. package/esm2015/public-api.js +2 -1
  20. package/fesm2015/kms-ngx-ui-presentational.js +242 -123
  21. package/fesm2015/kms-ngx-ui-presentational.js.map +1 -1
  22. package/lib/directives/directives.module.d.ts +4 -2
  23. package/lib/directives/size.directive.d.ts +10 -0
  24. package/lib/parent-components/colorable.component.d.ts +10 -0
  25. package/lib/parent-components/form.component.d.ts +11 -5
  26. package/lib/services/viewport.service.d.ts +13 -4
  27. package/lib/ui/file-input/file-input.component.d.ts +2 -2
  28. package/lib/ui/icon/icon.component.d.ts +7 -1
  29. package/lib/ui/icon/iconSize.enum.d.ts +10 -0
  30. package/lib/ui/radiobutton/radiobutton.component.d.ts +2 -1
  31. package/lib/ui/tooltip-icon/tooltip-icon.component.d.ts +2 -2
  32. package/package.json +1 -1
  33. package/public-api.d.ts +1 -0
  34. package/src/lib/ui/back-to-top/back-to-top.component.scss +2 -3
  35. package/src/lib/ui/icon/icon.component.scss +2 -36
  36. package/src/styles/animations.scss +47 -0
  37. package/src/styles/styles.scss +1 -0
@@ -7,6 +7,7 @@ import { MouseWheelDirective } from './mousewheel.directive';
7
7
  import { GetMaxHeightDirective } from './sum-of-height.directive';
8
8
  import { SwipeDirective } from './swipe.directive';
9
9
  import { TooltipDirective } from './tooltip.directive';
10
+ import { SizeDirective } from './size.directive';
10
11
  import * as i0 from "@angular/core";
11
12
  export class DirectivesModule {
12
13
  }
@@ -14,10 +15,12 @@ DirectivesModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version
14
15
  DirectivesModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: DirectivesModule, declarations: [SwipeDirective,
15
16
  MouseWheelDirective,
16
17
  GetMaxHeightDirective,
17
- TooltipDirective], imports: [CommonModule], exports: [SwipeDirective,
18
+ TooltipDirective,
19
+ SizeDirective], imports: [CommonModule], exports: [SwipeDirective,
18
20
  MouseWheelDirective,
19
21
  GetMaxHeightDirective,
20
- TooltipDirective] });
22
+ TooltipDirective,
23
+ SizeDirective] });
21
24
  DirectivesModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: DirectivesModule, imports: [[CommonModule]] });
22
25
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: DirectivesModule, decorators: [{
23
26
  type: NgModule,
@@ -27,6 +30,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
27
30
  MouseWheelDirective,
28
31
  GetMaxHeightDirective,
29
32
  TooltipDirective,
33
+ SizeDirective,
30
34
  ],
31
35
  imports: [CommonModule],
32
36
  exports: [
@@ -34,7 +38,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
34
38
  MouseWheelDirective,
35
39
  GetMaxHeightDirective,
36
40
  TooltipDirective,
41
+ SizeDirective,
37
42
  ],
38
43
  }]
39
44
  }] });
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0aXZlcy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rbXMtbmd4LXVpLXByZXNlbnRhdGlvbmFsL3NyYy9saWIvZGlyZWN0aXZlcy9kaXJlY3RpdmVzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzdELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7QUFpQnZELE1BQU0sT0FBTyxnQkFBZ0I7OzhHQUFoQixnQkFBZ0I7K0dBQWhCLGdCQUFnQixpQkFiekIsY0FBYztRQUNkLG1CQUFtQjtRQUNuQixxQkFBcUI7UUFDckIsZ0JBQWdCLGFBRVIsWUFBWSxhQUVwQixjQUFjO1FBQ2QsbUJBQW1CO1FBQ25CLHFCQUFxQjtRQUNyQixnQkFBZ0I7K0dBR1AsZ0JBQWdCLFlBUmxCLENBQUMsWUFBWSxDQUFDOzRGQVFaLGdCQUFnQjtrQkFmNUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osY0FBYzt3QkFDZCxtQkFBbUI7d0JBQ25CLHFCQUFxQjt3QkFDckIsZ0JBQWdCO3FCQUNqQjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7b0JBQ3ZCLE9BQU8sRUFBRTt3QkFDUCxjQUFjO3dCQUNkLG1CQUFtQjt3QkFDbkIscUJBQXFCO3dCQUNyQixnQkFBZ0I7cUJBQ2pCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIEBjb3B5cmlnaHQgS01TIEdtYkhcclxuICovXHJcblxyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgTW91c2VXaGVlbERpcmVjdGl2ZSB9IGZyb20gJy4vbW91c2V3aGVlbC5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBHZXRNYXhIZWlnaHREaXJlY3RpdmUgfSBmcm9tICcuL3N1bS1vZi1oZWlnaHQuZGlyZWN0aXZlJztcclxuaW1wb3J0IHsgU3dpcGVEaXJlY3RpdmUgfSBmcm9tICcuL3N3aXBlLmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IFRvb2x0aXBEaXJlY3RpdmUgfSBmcm9tICcuL3Rvb2x0aXAuZGlyZWN0aXZlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBTd2lwZURpcmVjdGl2ZSxcclxuICAgIE1vdXNlV2hlZWxEaXJlY3RpdmUsXHJcbiAgICBHZXRNYXhIZWlnaHREaXJlY3RpdmUsXHJcbiAgICBUb29sdGlwRGlyZWN0aXZlLFxyXG4gIF0sXHJcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgU3dpcGVEaXJlY3RpdmUsXHJcbiAgICBNb3VzZVdoZWVsRGlyZWN0aXZlLFxyXG4gICAgR2V0TWF4SGVpZ2h0RGlyZWN0aXZlLFxyXG4gICAgVG9vbHRpcERpcmVjdGl2ZSxcclxuICBdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGlyZWN0aXZlc01vZHVsZSB7fVxyXG4iXX0=
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0aXZlcy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rbXMtbmd4LXVpLXByZXNlbnRhdGlvbmFsL3NyYy9saWIvZGlyZWN0aXZlcy9kaXJlY3RpdmVzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzdELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7O0FBbUJqRCxNQUFNLE9BQU8sZ0JBQWdCOzs4R0FBaEIsZ0JBQWdCOytHQUFoQixnQkFBZ0IsaUJBZnpCLGNBQWM7UUFDZCxtQkFBbUI7UUFDbkIscUJBQXFCO1FBQ3JCLGdCQUFnQjtRQUNoQixhQUFhLGFBRUwsWUFBWSxhQUVwQixjQUFjO1FBQ2QsbUJBQW1CO1FBQ25CLHFCQUFxQjtRQUNyQixnQkFBZ0I7UUFDaEIsYUFBYTsrR0FHSixnQkFBZ0IsWUFUbEIsQ0FBQyxZQUFZLENBQUM7NEZBU1osZ0JBQWdCO2tCQWpCNUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osY0FBYzt3QkFDZCxtQkFBbUI7d0JBQ25CLHFCQUFxQjt3QkFDckIsZ0JBQWdCO3dCQUNoQixhQUFhO3FCQUNkO29CQUNELE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsT0FBTyxFQUFFO3dCQUNQLGNBQWM7d0JBQ2QsbUJBQW1CO3dCQUNuQixxQkFBcUI7d0JBQ3JCLGdCQUFnQjt3QkFDaEIsYUFBYTtxQkFDZDtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBAY29weXJpZ2h0IEtNUyBHbWJIXHJcbiAqL1xyXG5cclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IE1vdXNlV2hlZWxEaXJlY3RpdmUgfSBmcm9tICcuL21vdXNld2hlZWwuZGlyZWN0aXZlJztcclxuaW1wb3J0IHsgR2V0TWF4SGVpZ2h0RGlyZWN0aXZlIH0gZnJvbSAnLi9zdW0tb2YtaGVpZ2h0LmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IFN3aXBlRGlyZWN0aXZlIH0gZnJvbSAnLi9zd2lwZS5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBUb29sdGlwRGlyZWN0aXZlIH0gZnJvbSAnLi90b29sdGlwLmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IFNpemVEaXJlY3RpdmUgfSBmcm9tICcuL3NpemUuZGlyZWN0aXZlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBTd2lwZURpcmVjdGl2ZSxcclxuICAgIE1vdXNlV2hlZWxEaXJlY3RpdmUsXHJcbiAgICBHZXRNYXhIZWlnaHREaXJlY3RpdmUsXHJcbiAgICBUb29sdGlwRGlyZWN0aXZlLFxyXG4gICAgU2l6ZURpcmVjdGl2ZSxcclxuICBdLFxyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIFN3aXBlRGlyZWN0aXZlLFxyXG4gICAgTW91c2VXaGVlbERpcmVjdGl2ZSxcclxuICAgIEdldE1heEhlaWdodERpcmVjdGl2ZSxcclxuICAgIFRvb2x0aXBEaXJlY3RpdmUsXHJcbiAgICBTaXplRGlyZWN0aXZlLFxyXG4gIF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBEaXJlY3RpdmVzTW9kdWxlIHtTaXplRGlyZWN0aXZlfVxyXG4iXX0=
@@ -0,0 +1,21 @@
1
+ import { Directive, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class SizeDirective {
4
+ constructor(elementRef) {
5
+ this.elementRef = elementRef;
6
+ this.size = '';
7
+ }
8
+ ngOnInit() {
9
+ this.elementRef.nativeElement.style.width(this.size + 'px');
10
+ this.elementRef.nativeElement.style.height(this.size + 'px');
11
+ }
12
+ }
13
+ SizeDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: SizeDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
14
+ SizeDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: SizeDirective, selector: "[size]", inputs: { size: "size" }, ngImport: i0 });
15
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: SizeDirective, decorators: [{
16
+ type: Directive,
17
+ args: [{ selector: '[size]' }]
18
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { size: [{
19
+ type: Input
20
+ }] } });
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2l6ZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rbXMtbmd4LXVpLXByZXNlbnRhdGlvbmFsL3NyYy9saWIvZGlyZWN0aXZlcy9zaXplLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFHN0QsTUFBTSxPQUFPLGFBQWE7SUFFdEIsWUFBb0IsVUFBc0I7UUFBdEIsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQURqQyxTQUFJLEdBQVcsRUFBRSxDQUFDO0lBQ21CLENBQUM7SUFFL0MsUUFBUTtRQUNKLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsQ0FBQztRQUM1RCxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLENBQUM7SUFDakUsQ0FBQzs7MkdBUFEsYUFBYTsrRkFBYixhQUFhOzRGQUFiLGFBQWE7a0JBRHpCLFNBQVM7bUJBQUMsRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFO2lHQUVwQixJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5ARGlyZWN0aXZlKHsgc2VsZWN0b3I6ICdbc2l6ZV0nIH0pXHJcbmV4cG9ydCBjbGFzcyBTaXplRGlyZWN0aXZlIHtcclxuICAgIEBJbnB1dCgpIHNpemU6IHN0cmluZyA9ICcnO1xyXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBlbGVtZW50UmVmOiBFbGVtZW50UmVmKSB7IH1cclxuXHJcbiAgICBuZ09uSW5pdCgpIHtcclxuICAgICAgICB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5zdHlsZS53aWR0aCh0aGlzLnNpemUgKyAncHgnKTtcclxuICAgICAgICB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5zdHlsZS5oZWlnaHQodGhpcy5zaXplICsgJ3B4Jyk7XHJcbiAgICB9XHJcbn0iXX0=
@@ -0,0 +1,35 @@
1
+ /*!
2
+ * @copyright FLYACTS GmbH 2019
3
+ */
4
+ import { Component, Input } from '@angular/core';
5
+ import * as i0 from "@angular/core";
6
+ export class ColorableParentComponent {
7
+ setupColors(elementRef) {
8
+ if (this.color) {
9
+ let color1;
10
+ let color2;
11
+ if (this.color === 'primary' || this.color === 'accent') {
12
+ color1 = 'var(--' + this.color + 'Color)';
13
+ color2 = 'var(--' + this.color + 'ColorHover)';
14
+ }
15
+ else {
16
+ color1 = this.color;
17
+ color2 = this.color;
18
+ }
19
+ elementRef.style.setProperty('--componentColor', color1);
20
+ elementRef.style.setProperty('--componentColorHover', color2);
21
+ }
22
+ }
23
+ }
24
+ ColorableParentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ColorableParentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
25
+ ColorableParentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: ColorableParentComponent, selector: "ng-component", inputs: { color: "color" }, ngImport: i0, template: '', isInline: true });
26
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ColorableParentComponent, decorators: [{
27
+ type: Component,
28
+ args: [{
29
+ selector: '',
30
+ template: '',
31
+ }]
32
+ }], propDecorators: { color: [{
33
+ type: Input
34
+ }] } });
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3JhYmxlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWwvc3JjL2xpYi9wYXJlbnQtY29tcG9uZW50cy9jb2xvcmFibGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTWpELE1BQU0sT0FBTyx3QkFBd0I7SUFNakMsV0FBVyxDQUFDLFVBQXVCO1FBQy9CLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNaLElBQUksTUFBTSxDQUFDO1lBQ1gsSUFBSSxNQUFNLENBQUM7WUFDWCxJQUFJLElBQUksQ0FBQyxLQUFLLEtBQUssU0FBUyxJQUFJLElBQUksQ0FBQyxLQUFLLEtBQUssUUFBUSxFQUFFO2dCQUNyRCxNQUFNLEdBQUcsUUFBUSxHQUFHLElBQUksQ0FBQyxLQUFLLEdBQUcsUUFBUSxDQUFDO2dCQUMxQyxNQUFNLEdBQUcsUUFBUSxHQUFHLElBQUksQ0FBQyxLQUFLLEdBQUcsYUFBYSxDQUFDO2FBQ2xEO2lCQUFNO2dCQUNILE1BQU0sR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDO2dCQUNwQixNQUFNLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQzthQUN2QjtZQUNELFVBQVUsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLGtCQUFrQixFQUFFLE1BQU0sQ0FBQyxDQUFDO1lBQ3pELFVBQVUsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLHVCQUF1QixFQUFFLE1BQU0sQ0FBQyxDQUFDO1NBQ2pFO0lBQ0wsQ0FBQzs7c0hBcEJRLHdCQUF3QjswR0FBeEIsd0JBQXdCLGdGQUZ2QixFQUFFOzRGQUVILHdCQUF3QjtrQkFKcEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsRUFBRTtvQkFDWixRQUFRLEVBQUUsRUFBRTtpQkFDZjs4QkFLWSxLQUFLO3NCQUFiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyIvKiFcclxuICogQGNvcHlyaWdodCBGTFlBQ1RTIEdtYkggMjAxOVxyXG4gKi9cclxuXHJcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICcnLFxyXG4gICAgdGVtcGxhdGU6ICcnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ29sb3JhYmxlUGFyZW50Q29tcG9uZW50IHtcclxuICAgIC8qKlxyXG4gICAgICogRGVmaW5lcyB0aGUgY29sb3IgcHJvcGVydHlcclxuICAgICAqL1xyXG4gICAgQElucHV0KCkgY29sb3I/OiBzdHJpbmc7XHJcblxyXG4gICAgc2V0dXBDb2xvcnMoZWxlbWVudFJlZjogSFRNTEVsZW1lbnQpIHtcclxuICAgICAgICBpZiAodGhpcy5jb2xvcikge1xyXG4gICAgICAgICAgICBsZXQgY29sb3IxO1xyXG4gICAgICAgICAgICBsZXQgY29sb3IyO1xyXG4gICAgICAgICAgICBpZiAodGhpcy5jb2xvciA9PT0gJ3ByaW1hcnknIHx8IHRoaXMuY29sb3IgPT09ICdhY2NlbnQnKSB7XHJcbiAgICAgICAgICAgICAgICBjb2xvcjEgPSAndmFyKC0tJyArIHRoaXMuY29sb3IgKyAnQ29sb3IpJztcclxuICAgICAgICAgICAgICAgIGNvbG9yMiA9ICd2YXIoLS0nICsgdGhpcy5jb2xvciArICdDb2xvckhvdmVyKSc7XHJcbiAgICAgICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgICAgICBjb2xvcjEgPSB0aGlzLmNvbG9yO1xyXG4gICAgICAgICAgICAgICAgY29sb3IyID0gdGhpcy5jb2xvcjtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICBlbGVtZW50UmVmLnN0eWxlLnNldFByb3BlcnR5KCctLWNvbXBvbmVudENvbG9yJywgY29sb3IxKTtcclxuICAgICAgICAgICAgZWxlbWVudFJlZi5zdHlsZS5zZXRQcm9wZXJ0eSgnLS1jb21wb25lbnRDb2xvckhvdmVyJywgY29sb3IyKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbn1cclxuIl19
@@ -1,4 +1,4 @@
1
- import { Component, Input, EventEmitter, Output, ViewChild } from '@angular/core';
1
+ import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
2
  import { FormParentComponent } from './form.component';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/forms";
@@ -48,7 +48,8 @@ export class FormControlParentComponent extends FormParentComponent {
48
48
  this.onTouch = fn;
49
49
  }
50
50
  setDisabledState(isDisabled) {
51
- if (this.child) {
51
+ var _a;
52
+ if ((_a = this.child) === null || _a === void 0 ? void 0 : _a.nativeElement) {
52
53
  this.renderer.setProperty(this.child.nativeElement, 'disabled', isDisabled);
53
54
  }
54
55
  }
@@ -72,4 +73,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
72
73
  type: ViewChild,
73
74
  args: ['child']
74
75
  }] } });
75
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1jb250cm9sLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWwvc3JjL2xpYi9wYXJlbnQtY29tcG9uZW50cy9mb3JtLWNvbnRyb2wuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBRXpHLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGtCQUFrQixDQUFDOzs7QUFNdkQsTUFBTSxPQUFPLDBCQUEyQixTQUFRLG1CQUFtQjtJQVEvRCxZQUFtQixXQUF3QixFQUFTLFFBQW1CO1FBQ25FLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztRQURKLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBQVMsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQVA5RCx3QkFBbUIsR0FBRyxFQUFFLENBQUMsQ0FBQyx3RUFBd0U7UUFDakcsd0JBQW1CLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUlwRCxrQkFBYSxHQUFHLEVBQUUsQ0FBQztRQWUxQixnRUFBZ0U7UUFDekQsYUFBUSxHQUFRLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FBQztRQUVoQyxnRUFBZ0U7UUFDaEUsWUFBTyxHQUFRLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FBQztRQUV4QixnRUFBZ0U7UUFDaEUsY0FBUyxHQUFRLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FBQztJQWxCMUIsQ0FBQztJQUVELFFBQVE7UUFDSixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELE1BQU0sQ0FBQyxLQUFhO1FBQ2hCLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDckIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFXRCxJQUFJLEtBQUs7UUFDTCxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUM7SUFDOUIsQ0FBQztJQUVELElBQUksS0FBSyxDQUFDLEtBQWE7UUFDbkIsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7UUFDM0IsSUFBSSxLQUFLLEtBQUssU0FBUyxJQUFJLElBQUksQ0FBQyxhQUFhLEtBQUssS0FBSyxFQUFFO1lBQ3JELElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxJQUFJLElBQUksQ0FBQyxtQkFBbUIsRUFBRTtnQkFDakQsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUM7YUFDakQ7WUFDRCxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3JCLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDdkI7SUFDTCxDQUFDO0lBRUQsVUFBVSxDQUFDLEtBQWE7UUFDcEIsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7UUFDM0IsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7SUFDdkIsQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQU87UUFDcEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQU87UUFDckIsSUFBSSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUVELGdCQUFnQixDQUFFLFVBQW1CO1FBQ2pDLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNaLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxFQUFFLFVBQVUsRUFBRSxVQUFVLENBQUMsQ0FBQztTQUMvRTtJQUNMLENBQUM7SUFFRCxRQUFRLENBQUMsQ0FBYztRQUNuQixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQztJQUMxQyxDQUFDOzt3SEFsRVEsMEJBQTBCOzRHQUExQiwwQkFBMEIscVNBRnpCLEVBQUU7NEZBRUgsMEJBQTBCO2tCQUp0QyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLFFBQVEsRUFBRSxFQUFFO2lCQUNmOzBIQUVZLG1CQUFtQjtzQkFBM0IsS0FBSztnQkFDSSxtQkFBbUI7c0JBQTVCLE1BQU07Z0JBRW9CLEtBQUs7c0JBQS9CLFNBQVM7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgSW5wdXQsIEV2ZW50RW1pdHRlciwgT3V0cHV0LCBWaWV3Q2hpbGQsIFJlbmRlcmVyMiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3JtQnVpbGRlciwgRm9ybUNvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IEZvcm1QYXJlbnRDb21wb25lbnQgfSBmcm9tICcuL2Zvcm0uY29tcG9uZW50JztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdrbXMtZm9ybUNvbnRyb2xQYXJlbnQnLFxyXG4gICAgdGVtcGxhdGU6ICcnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRm9ybUNvbnRyb2xQYXJlbnRDb21wb25lbnQgZXh0ZW5kcyBGb3JtUGFyZW50Q29tcG9uZW50IHtcclxuICAgIEBJbnB1dCgpIGRlZmF1bHREYXRhT3ZlcnJpZGUgPSAnJzsgLy8gd2hlbiB3ZSBoYXZlIE5PIGZvcm0gYXJvdW5kLCBnZXQgZGVmYXVsdCB2aWEgaW5wdXQgdG8gc2V0IGl0IG1hbnVhbGx5XHJcbiAgICBAT3V0cHV0KCkgb25TZWxlY3RJdGVtRW1pdHRlciA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpO1xyXG5cclxuICAgIEBWaWV3Q2hpbGQoJ2NoaWxkJykgcHVibGljIGNoaWxkPzogRWxlbWVudFJlZjxIVE1MSW5wdXRFbGVtZW50PjtcclxuXHJcbiAgICBwdWJsaWMgaW50ZXJuYWxWYWx1ZSA9ICcnO1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyBmb3JtQnVpbGRlcjogRm9ybUJ1aWxkZXIsIHB1YmxpYyByZW5kZXJlcjogUmVuZGVyZXIyKSB7XHJcbiAgICAgICAgc3VwZXIoZm9ybUJ1aWxkZXIpO1xyXG4gICAgfVxyXG5cclxuICAgIG5nT25Jbml0KCl7XHJcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcclxuICAgIH1cclxuXHJcbiAgICBjaGFuZ2UodmFsdWU6IHN0cmluZykge1xyXG4gICAgICAgIHRoaXMub25DaGFuZ2UodmFsdWUpO1xyXG4gICAgICAgIHRoaXMub25Ub3VjaGVkKCk7XHJcbiAgICB9XHJcblxyXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1lbXB0eS1mdW5jdGlvblxyXG4gICAgcHVibGljIG9uQ2hhbmdlOiBhbnkgPSAoKSA9PiB7fTtcclxuXHJcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWVtcHR5LWZ1bmN0aW9uXHJcbiAgICBvblRvdWNoOiBhbnkgPSAoKSA9PiB7fTtcclxuXHJcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWVtcHR5LWZ1bmN0aW9uXHJcbiAgICBvblRvdWNoZWQ6IGFueSA9ICgpID0+IHt9O1xyXG5cclxuICAgIGdldCB2YWx1ZSgpOiBzdHJpbmcge1xyXG4gICAgICAgIHJldHVybiB0aGlzLmludGVybmFsVmFsdWU7XHJcbiAgICB9XHJcblxyXG4gICAgc2V0IHZhbHVlKHZhbHVlOiBzdHJpbmcpIHtcclxuICAgICAgICB0aGlzLmludGVybmFsVmFsdWUgPSB2YWx1ZTtcclxuICAgICAgICBpZiAodmFsdWUgIT09IHVuZGVmaW5lZCAmJiB0aGlzLmludGVybmFsVmFsdWUgIT09IHZhbHVlKSB7XHJcbiAgICAgICAgICAgIGlmICghdGhpcy5pbnRlcm5hbFZhbHVlICYmIHRoaXMuZGVmYXVsdERhdGFPdmVycmlkZSkge1xyXG4gICAgICAgICAgICAgICAgdGhpcy5pbnRlcm5hbFZhbHVlID0gdGhpcy5kZWZhdWx0RGF0YU92ZXJyaWRlO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIHRoaXMub25DaGFuZ2UodmFsdWUpO1xyXG4gICAgICAgICAgICB0aGlzLm9uVG91Y2godmFsdWUpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICB3cml0ZVZhbHVlKHZhbHVlOiBzdHJpbmcpIHtcclxuICAgICAgICB0aGlzLmludGVybmFsVmFsdWUgPSB2YWx1ZTtcclxuICAgICAgICB0aGlzLnZhbHVlID0gdmFsdWU7XHJcbiAgICB9XHJcblxyXG4gICAgcmVnaXN0ZXJPbkNoYW5nZShmbjogYW55KSB7XHJcbiAgICAgICAgdGhpcy5vbkNoYW5nZSA9IGZuO1xyXG4gICAgfVxyXG5cclxuICAgIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiBhbnkpIHtcclxuICAgICAgICB0aGlzLm9uVG91Y2ggPSBmbjtcclxuICAgIH1cclxuXHJcbiAgICBzZXREaXNhYmxlZFN0YXRlPyhpc0Rpc2FibGVkOiBib29sZWFuKSB7XHJcbiAgICAgICAgaWYgKHRoaXMuY2hpbGQpIHtcclxuICAgICAgICAgICAgdGhpcy5yZW5kZXJlci5zZXRQcm9wZXJ0eSh0aGlzLmNoaWxkLm5hdGl2ZUVsZW1lbnQsICdkaXNhYmxlZCcsIGlzRGlzYWJsZWQpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICB2YWxpZGF0ZShfOiBGb3JtQ29udHJvbCkge1xyXG4gICAgICAgIHJldHVybiB0aGlzLmZvcm0udmFsaWQgPyBudWxsIDogZmFsc2U7XHJcbiAgICB9XHJcblxyXG59XHJcbiJdfQ==
76
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1jb250cm9sLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWwvc3JjL2xpYi9wYXJlbnQtY29tcG9uZW50cy9mb3JtLWNvbnRyb2wuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQWEsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpHLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGtCQUFrQixDQUFDOzs7QUFNdkQsTUFBTSxPQUFPLDBCQUEyQixTQUFRLG1CQUFtQjtJQVEvRCxZQUFtQixXQUF3QixFQUFTLFFBQW1CO1FBQ25FLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztRQURKLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBQVMsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQVA5RCx3QkFBbUIsR0FBRyxFQUFFLENBQUMsQ0FBQyx3RUFBd0U7UUFDakcsd0JBQW1CLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUlwRCxrQkFBYSxHQUFHLEVBQUUsQ0FBQztRQWUxQixnRUFBZ0U7UUFDekQsYUFBUSxHQUFRLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FBQztRQUVoQyxnRUFBZ0U7UUFDaEUsWUFBTyxHQUFRLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FBQztRQUV4QixnRUFBZ0U7UUFDaEUsY0FBUyxHQUFRLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FBQztJQWxCMUIsQ0FBQztJQUVELFFBQVE7UUFDSixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELE1BQU0sQ0FBQyxLQUFhO1FBQ2hCLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDckIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFXRCxJQUFJLEtBQUs7UUFDTCxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUM7SUFDOUIsQ0FBQztJQUVELElBQUksS0FBSyxDQUFDLEtBQWE7UUFDbkIsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7UUFDM0IsSUFBSSxLQUFLLEtBQUssU0FBUyxJQUFJLElBQUksQ0FBQyxhQUFhLEtBQUssS0FBSyxFQUFFO1lBQ3JELElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxJQUFJLElBQUksQ0FBQyxtQkFBbUIsRUFBRTtnQkFDakQsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUM7YUFDakQ7WUFDRCxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3JCLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDdkI7SUFDTCxDQUFDO0lBRUQsVUFBVSxDQUFDLEtBQWE7UUFDcEIsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7UUFDM0IsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7SUFDdkIsQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQU87UUFDcEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQU87UUFDckIsSUFBSSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUVELGdCQUFnQixDQUFFLFVBQW1COztRQUNqQyxJQUFJLE1BQUEsSUFBSSxDQUFDLEtBQUssMENBQUUsYUFBYSxFQUFFO1lBQzNCLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxFQUFFLFVBQVUsRUFBRSxVQUFVLENBQUMsQ0FBQztTQUMvRTtJQUNMLENBQUM7SUFFRCxRQUFRLENBQUMsQ0FBYztRQUNuQixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQztJQUMxQyxDQUFDOzt3SEFsRVEsMEJBQTBCOzRHQUExQiwwQkFBMEIscVNBRnpCLEVBQUU7NEZBRUgsMEJBQTBCO2tCQUp0QyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLFFBQVEsRUFBRSxFQUFFO2lCQUNmOzBIQUVZLG1CQUFtQjtzQkFBM0IsS0FBSztnQkFDSSxtQkFBbUI7c0JBQTVCLE1BQU07Z0JBRW9CLEtBQUs7c0JBQS9CLFNBQVM7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0LCBSZW5kZXJlcjIsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3JtQnVpbGRlciwgRm9ybUNvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IEZvcm1QYXJlbnRDb21wb25lbnQgfSBmcm9tICcuL2Zvcm0uY29tcG9uZW50JztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdrbXMtZm9ybUNvbnRyb2xQYXJlbnQnLFxyXG4gICAgdGVtcGxhdGU6ICcnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRm9ybUNvbnRyb2xQYXJlbnRDb21wb25lbnQgZXh0ZW5kcyBGb3JtUGFyZW50Q29tcG9uZW50IHtcclxuICAgIEBJbnB1dCgpIGRlZmF1bHREYXRhT3ZlcnJpZGUgPSAnJzsgLy8gd2hlbiB3ZSBoYXZlIE5PIGZvcm0gYXJvdW5kLCBnZXQgZGVmYXVsdCB2aWEgaW5wdXQgdG8gc2V0IGl0IG1hbnVhbGx5XHJcbiAgICBAT3V0cHV0KCkgb25TZWxlY3RJdGVtRW1pdHRlciA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpO1xyXG5cclxuICAgIEBWaWV3Q2hpbGQoJ2NoaWxkJykgcHVibGljIGNoaWxkPzogRWxlbWVudFJlZjxIVE1MSW5wdXRFbGVtZW50PjtcclxuXHJcbiAgICBwdWJsaWMgaW50ZXJuYWxWYWx1ZSA9ICcnO1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyBmb3JtQnVpbGRlcjogRm9ybUJ1aWxkZXIsIHB1YmxpYyByZW5kZXJlcjogUmVuZGVyZXIyKSB7XHJcbiAgICAgICAgc3VwZXIoZm9ybUJ1aWxkZXIpO1xyXG4gICAgfVxyXG5cclxuICAgIG5nT25Jbml0KCkge1xyXG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XHJcbiAgICB9XHJcblxyXG4gICAgY2hhbmdlKHZhbHVlOiBzdHJpbmcpIHtcclxuICAgICAgICB0aGlzLm9uQ2hhbmdlKHZhbHVlKTtcclxuICAgICAgICB0aGlzLm9uVG91Y2hlZCgpO1xyXG4gICAgfVxyXG5cclxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktZnVuY3Rpb25cclxuICAgIHB1YmxpYyBvbkNoYW5nZTogYW55ID0gKCkgPT4ge307XHJcblxyXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1lbXB0eS1mdW5jdGlvblxyXG4gICAgb25Ub3VjaDogYW55ID0gKCkgPT4ge307XHJcblxyXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1lbXB0eS1mdW5jdGlvblxyXG4gICAgb25Ub3VjaGVkOiBhbnkgPSAoKSA9PiB7fTtcclxuXHJcbiAgICBnZXQgdmFsdWUoKTogc3RyaW5nIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5pbnRlcm5hbFZhbHVlO1xyXG4gICAgfVxyXG5cclxuICAgIHNldCB2YWx1ZSh2YWx1ZTogc3RyaW5nKSB7XHJcbiAgICAgICAgdGhpcy5pbnRlcm5hbFZhbHVlID0gdmFsdWU7XHJcbiAgICAgICAgaWYgKHZhbHVlICE9PSB1bmRlZmluZWQgJiYgdGhpcy5pbnRlcm5hbFZhbHVlICE9PSB2YWx1ZSkge1xyXG4gICAgICAgICAgICBpZiAoIXRoaXMuaW50ZXJuYWxWYWx1ZSAmJiB0aGlzLmRlZmF1bHREYXRhT3ZlcnJpZGUpIHtcclxuICAgICAgICAgICAgICAgIHRoaXMuaW50ZXJuYWxWYWx1ZSA9IHRoaXMuZGVmYXVsdERhdGFPdmVycmlkZTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB0aGlzLm9uQ2hhbmdlKHZhbHVlKTtcclxuICAgICAgICAgICAgdGhpcy5vblRvdWNoKHZhbHVlKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgd3JpdGVWYWx1ZSh2YWx1ZTogc3RyaW5nKSB7XHJcbiAgICAgICAgdGhpcy5pbnRlcm5hbFZhbHVlID0gdmFsdWU7XHJcbiAgICAgICAgdGhpcy52YWx1ZSA9IHZhbHVlO1xyXG4gICAgfVxyXG5cclxuICAgIHJlZ2lzdGVyT25DaGFuZ2UoZm46IGFueSkge1xyXG4gICAgICAgIHRoaXMub25DaGFuZ2UgPSBmbjtcclxuICAgIH1cclxuXHJcbiAgICByZWdpc3Rlck9uVG91Y2hlZChmbjogYW55KSB7XHJcbiAgICAgICAgdGhpcy5vblRvdWNoID0gZm47XHJcbiAgICB9XHJcblxyXG4gICAgc2V0RGlzYWJsZWRTdGF0ZT8oaXNEaXNhYmxlZDogYm9vbGVhbikge1xyXG4gICAgICAgIGlmICh0aGlzLmNoaWxkPy5uYXRpdmVFbGVtZW50KSB7XHJcbiAgICAgICAgICAgIHRoaXMucmVuZGVyZXIuc2V0UHJvcGVydHkodGhpcy5jaGlsZC5uYXRpdmVFbGVtZW50LCAnZGlzYWJsZWQnLCBpc0Rpc2FibGVkKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgdmFsaWRhdGUoXzogRm9ybUNvbnRyb2wpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5mb3JtLnZhbGlkID8gbnVsbCA6IGZhbHNlO1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
@@ -2,17 +2,22 @@
2
2
  * @copyright FLYACTS GmbH 2019
3
3
  */
4
4
  import { Component, EventEmitter, Input, Output } from '@angular/core';
5
+ import { SubSink } from 'subsink';
6
+ import { ColorableParentComponent } from './colorable.component';
5
7
  import * as i0 from "@angular/core";
6
8
  import * as i1 from "@angular/forms";
7
- export class FormParentComponent {
9
+ export class FormParentComponent extends ColorableParentComponent {
8
10
  constructor(formBuilder) {
11
+ super();
9
12
  this.formBuilder = formBuilder;
13
+ this.disabled = false;
14
+ this.showRequired = false;
10
15
  this.formInitialized = false;
11
- this.allowedCharsOnlyNumbers = new Set('0123456789'.split('').map(c => c.charCodeAt(0)));
16
+ this.allowedCharsOnlyNumbers = new Set('0123456789'.split('').map((c) => c.charCodeAt(0)));
17
+ this.subs = new SubSink();
12
18
  this.formDataChanged = new EventEmitter();
13
- this.disabled = false;
14
19
  }
15
- // TODO make a service or make own compoennt etc.
20
+ // TODO make a service or make own component etc.
16
21
  /**
17
22
  * Returns if a number was pressed
18
23
  * @param e
@@ -25,9 +30,15 @@ export class FormParentComponent {
25
30
  const isArrows = e.keyCode >= 37 && e.keyCode <= 40;
26
31
  const isDelete = e.keyCode == 8 || e.keyCode == 46;
27
32
  const isCutCopyOrPaste = (e.ctrlKey || e.metaKey) && (e.keyCode == 86 || e.keyCode == 88 || e.keyCode == 67);
28
- return (isNumberRow) || (isNumberPad) || (allowDelete && isDelete) || (allowArrows && isArrows) || (allowCutCopyPaste && isCutCopyOrPaste);
33
+ const isTab = 9;
34
+ return (isNumberRow ||
35
+ isNumberPad ||
36
+ isTab ||
37
+ (allowDelete && isDelete) ||
38
+ (allowArrows && isArrows) ||
39
+ (allowCutCopyPaste && isCutCopyOrPaste));
29
40
  }
30
- // TODO make a service or make own compoennt etc.
41
+ // TODO make a service or make own component etc.
31
42
  /**
32
43
  * Prevents to input other chars than numbers in input
33
44
  * @param event
@@ -38,7 +49,7 @@ export class FormParentComponent {
38
49
  event.preventDefault();
39
50
  }
40
51
  }
41
- // TODO make a service or make own compoennt etc.
52
+ // TODO make a service or make own component etc.
42
53
  /**
43
54
  * Prevents input when pasting which is not number
44
55
  * @param event
@@ -56,23 +67,33 @@ export class FormParentComponent {
56
67
  }
57
68
  }
58
69
  ngOnInit() {
59
- this.formDataChanged.emit(this.form);
60
- this.form.valueChanges.subscribe(() => {
70
+ this.initFormEvent();
71
+ }
72
+ ngOnDestroy() {
73
+ this.subs.unsubscribe();
74
+ }
75
+ initFormEvent() {
76
+ if (this.form) {
61
77
  this.formDataChanged.emit(this.form);
62
- });
78
+ this.form.valueChanges.subscribe(() => {
79
+ this.formDataChanged.emit(this.form);
80
+ });
81
+ }
63
82
  }
64
83
  }
65
84
  FormParentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FormParentComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
66
- FormParentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: FormParentComponent, selector: "kms-form", inputs: { disabled: "disabled" }, outputs: { formDataChanged: "formDataChanged" }, ngImport: i0, template: '', isInline: true });
85
+ FormParentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: FormParentComponent, selector: "kms-form", inputs: { disabled: "disabled", showRequired: "showRequired" }, outputs: { formDataChanged: "formDataChanged" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
67
86
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FormParentComponent, decorators: [{
68
87
  type: Component,
69
88
  args: [{
70
89
  selector: 'kms-form',
71
90
  template: '',
72
91
  }]
73
- }], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: { formDataChanged: [{
74
- type: Output
75
- }], disabled: [{
92
+ }], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: { disabled: [{
76
93
  type: Input
94
+ }], showRequired: [{
95
+ type: Input
96
+ }], formDataChanged: [{
97
+ type: Output
77
98
  }] } });
78
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rbXMtbmd4LXVpLXByZXNlbnRhdGlvbmFsL3NyYy9saWIvcGFyZW50LWNvbXBvbmVudHMvZm9ybS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFPL0UsTUFBTSxPQUFPLG1CQUFtQjtJQVM1QixZQUNXLFdBQXdCO1FBQXhCLGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBUjVCLG9CQUFlLEdBQUcsS0FBSyxDQUFDO1FBQ3ZCLDRCQUF1QixHQUFHLElBQUksR0FBRyxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFFbEYsb0JBQWUsR0FBNEIsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUUvRCxhQUFRLEdBQUcsS0FBSyxDQUFDO0lBTTFCLENBQUM7SUFFRCxpREFBaUQ7SUFDakQ7Ozs7T0FJRztJQUNILG1CQUFtQixDQUFDLENBQWdCLEVBQUUsV0FBVyxHQUFHLElBQUksRUFBRSxXQUFXLEdBQUcsSUFBSSxFQUFFLGlCQUFpQixHQUFHLElBQUk7UUFDbEcsa0dBQWtHO1FBQ2xHLE1BQU0sV0FBVyxHQUFHLENBQUMsQ0FBQyxPQUFPLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDO1FBQ3ZELE1BQU0sV0FBVyxHQUFHLENBQUMsQ0FBQyxPQUFPLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQyxPQUFPLElBQUksR0FBRyxDQUFDO1FBQ3hELE1BQU0sUUFBUSxHQUFHLENBQUMsQ0FBQyxPQUFPLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDO1FBQ3BELE1BQU0sUUFBUSxHQUFHLENBQUMsQ0FBQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDO1FBQ25ELE1BQU0sZ0JBQWdCLEdBQUcsQ0FBQyxDQUFDLENBQUMsT0FBTyxJQUFJLENBQUMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxPQUFPLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQyxPQUFPLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDLENBQUM7UUFDN0csT0FBTyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxXQUFXLElBQUksUUFBUSxDQUFDLElBQUksQ0FBQyxXQUFXLElBQUksUUFBUSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsSUFBSSxnQkFBZ0IsQ0FBQyxDQUFDO0lBQy9JLENBQUM7SUFFRCxpREFBaUQ7SUFDakQ7OztPQUdHO0lBQ0gsbUJBQW1CLENBQUMsS0FBb0I7UUFDcEMsaUdBQWlHO1FBQ2pHLElBQUksQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsdUJBQXVCLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUN0RixLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7U0FDMUI7SUFDTCxDQUFDO0lBRUQsaURBQWlEO0lBQ2pEOzs7T0FHRztJQUNILG9CQUFvQixDQUFDLEtBQXFCO1FBQ3RDLE1BQU0sYUFBYSxHQUFHLEtBQUssQ0FBQyxhQUFhLENBQUM7UUFDMUMsSUFBRyxhQUFhLEVBQUM7WUFDYixNQUFNLFVBQVUsR0FBRyxhQUFhLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ2pELElBQUcsVUFBVSxFQUFDO2dCQUNWLE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7Z0JBQ3ZDLElBQUcsQ0FBQyxLQUFLLEVBQUU7b0JBQ1AsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO2lCQUMxQjthQUNKO1NBQ0o7SUFDTCxDQUFDO0lBRUQsUUFBUTtRQUNKLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNyQyxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2xDLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6QyxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7O2lIQWxFUSxtQkFBbUI7cUdBQW5CLG1CQUFtQixtSUFGbEIsRUFBRTs0RkFFSCxtQkFBbUI7a0JBSi9CLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLFVBQVU7b0JBQ3BCLFFBQVEsRUFBRSxFQUFFO2lCQUNmO2tHQU1hLGVBQWU7c0JBQXhCLE1BQU07Z0JBRUUsUUFBUTtzQkFBaEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbIi8qIVxyXG4gKiBAY29weXJpZ2h0IEZMWUFDVFMgR21iSCAyMDE5XHJcbiAqL1xyXG5cclxuaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3JtQnVpbGRlciwgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2ttcy1mb3JtJyxcclxuICAgIHRlbXBsYXRlOiAnJyxcclxufSlcclxuZXhwb3J0IGNsYXNzIEZvcm1QYXJlbnRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gICAgcHVibGljIGZvcm0hOiBGb3JtR3JvdXA7XHJcbiAgICBwdWJsaWMgZm9ybUluaXRpYWxpemVkID0gZmFsc2U7XHJcbiAgICBwcml2YXRlIGFsbG93ZWRDaGFyc09ubHlOdW1iZXJzID0gbmV3IFNldCgnMDEyMzQ1Njc4OScuc3BsaXQoJycpLm1hcChjID0+IGMuY2hhckNvZGVBdCgwKSkpO1xyXG5cclxuICAgIEBPdXRwdXQoKSBmb3JtRGF0YUNoYW5nZWQ6IEV2ZW50RW1pdHRlcjxGb3JtR3JvdXA+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG5cclxuICAgIEBJbnB1dCgpIGRpc2FibGVkID0gZmFsc2U7XHJcblxyXG4gICAgY29uc3RydWN0b3IoXHJcbiAgICAgICAgcHVibGljIGZvcm1CdWlsZGVyOiBGb3JtQnVpbGRlclxyXG4gICAgKSB7XHJcblxyXG4gICAgfVxyXG5cclxuICAgIC8vIFRPRE8gbWFrZSBhIHNlcnZpY2Ugb3IgbWFrZSBvd24gY29tcG9lbm50IGV0Yy5cclxuICAgIC8qKlxyXG4gICAgICogUmV0dXJucyBpZiBhIG51bWJlciB3YXMgcHJlc3NlZFxyXG4gICAgICogQHBhcmFtIGUgXHJcbiAgICAgKiBAcmV0dXJucyBcclxuICAgICAqL1xyXG4gICAgY2hlY2tJZktleVdhc051bWJlcihlOiBLZXlib2FyZEV2ZW50LCBhbGxvd0RlbGV0ZSA9IHRydWUsIGFsbG93QXJyb3dzID0gdHJ1ZSwgYWxsb3dDdXRDb3B5UGFzdGUgPSB0cnVlKXtcclxuICAgICAgICAvLyByZXR1cm5zIGlmIGtleWNvZGUgb2YgbnVtYmVycy1yb3cgb3IgbnVtYmVycGFkLiBPciBpZiBwYXJhbWV0ZXIgc2V0LCBhbGxvdyBkZWxldGUvYmFja3NwYWNlIGtleVxyXG4gICAgICAgIGNvbnN0IGlzTnVtYmVyUm93ID0gZS5rZXlDb2RlID49IDQ4ICYmIGUua2V5Q29kZSA8PSA1NztcclxuICAgICAgICBjb25zdCBpc051bWJlclBhZCA9IGUua2V5Q29kZSA+PSA5NiAmJiBlLmtleUNvZGUgPD0gMTA1O1xyXG4gICAgICAgIGNvbnN0IGlzQXJyb3dzID0gZS5rZXlDb2RlID49IDM3ICYmIGUua2V5Q29kZSA8PSA0MDtcclxuICAgICAgICBjb25zdCBpc0RlbGV0ZSA9IGUua2V5Q29kZSA9PSA4IHx8IGUua2V5Q29kZSA9PSA0NjtcclxuICAgICAgICBjb25zdCBpc0N1dENvcHlPclBhc3RlID0gKGUuY3RybEtleSB8fCBlLm1ldGFLZXkpICYmIChlLmtleUNvZGUgPT0gODYgfHwgZS5rZXlDb2RlID09IDg4IHx8IGUua2V5Q29kZSA9PSA2Nyk7XHJcbiAgICAgICAgcmV0dXJuIChpc051bWJlclJvdykgfHwgKGlzTnVtYmVyUGFkKSB8fCAoYWxsb3dEZWxldGUgJiYgaXNEZWxldGUpIHx8IChhbGxvd0Fycm93cyAmJiBpc0Fycm93cykgfHwgKGFsbG93Q3V0Q29weVBhc3RlICYmIGlzQ3V0Q29weU9yUGFzdGUpO1xyXG4gICAgfVxyXG5cclxuICAgIC8vIFRPRE8gbWFrZSBhIHNlcnZpY2Ugb3IgbWFrZSBvd24gY29tcG9lbm50IGV0Yy5cclxuICAgIC8qKlxyXG4gICAgICogUHJldmVudHMgdG8gaW5wdXQgb3RoZXIgY2hhcnMgdGhhbiBudW1iZXJzIGluIGlucHV0XHJcbiAgICAgKiBAcGFyYW0gZXZlbnQgXHJcbiAgICAgKi9cclxuICAgIHJlbW92ZU51bWJlcnNPblR5cGUoZXZlbnQ6IEtleWJvYXJkRXZlbnQpIHtcclxuICAgICAgICAvLyBvbmx5IGFsbG93IGtleWRvd24gZnJvbSBudW1iZXJzLXJvdyBvciBudW1iZXJwYWQgb2Yga2V5YmFyZCBhbmQgYmxvY2sgb3RoZXIgY2hhcnMgdGhhbiBudW1iZXJzXHJcbiAgICAgICAgaWYgKCF0aGlzLmNoZWNrSWZLZXlXYXNOdW1iZXIoZXZlbnQpICYmICF0aGlzLmFsbG93ZWRDaGFyc09ubHlOdW1iZXJzLmhhcyhldmVudC5rZXlDb2RlKSkge1xyXG4gICAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICAvLyBUT0RPIG1ha2UgYSBzZXJ2aWNlIG9yIG1ha2Ugb3duIGNvbXBvZW5udCBldGMuXHJcbiAgICAvKipcclxuICAgICAqIFByZXZlbnRzIGlucHV0IHdoZW4gcGFzdGluZyB3aGljaCBpcyBub3QgbnVtYmVyXHJcbiAgICAgKiBAcGFyYW0gZXZlbnRcclxuICAgICAqL1xyXG4gICAgcmVtb3ZlTnVtYmVyc09uUGFzdGUoZXZlbnQ6IENsaXBib2FyZEV2ZW50KXtcclxuICAgICAgICBjb25zdCBjbGlwYm9hcmREYXRhID0gZXZlbnQuY2xpcGJvYXJkRGF0YTtcclxuICAgICAgICBpZihjbGlwYm9hcmREYXRhKXtcclxuICAgICAgICAgICAgY29uc3QgcGFzdGVkVGV4dCA9IGNsaXBib2FyZERhdGEuZ2V0RGF0YSgndGV4dCcpO1xyXG4gICAgICAgICAgICBpZihwYXN0ZWRUZXh0KXtcclxuICAgICAgICAgICAgICAgIGNvbnN0IGlzbnVtID0gL15cXGQrJC8udGVzdChwYXN0ZWRUZXh0KTtcclxuICAgICAgICAgICAgICAgIGlmKCFpc251bSkge1xyXG4gICAgICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgbmdPbkluaXQoKSB7XHJcbiAgICAgICAgdGhpcy5mb3JtRGF0YUNoYW5nZWQuZW1pdCh0aGlzLmZvcm0pO1xyXG4gICAgICAgIHRoaXMuZm9ybS52YWx1ZUNoYW5nZXMuc3Vic2NyaWJlKCgpID0+IHtcclxuICAgICAgICAgICAgdGhpcy5mb3JtRGF0YUNoYW5nZWQuZW1pdCh0aGlzLmZvcm0pO1xyXG4gICAgICAgIH0pO1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/kms-ngx-ui-presentational/src/lib/parent-components/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*!\r\n * @copyright FLYACTS GmbH 2019\r\n */\r\n\r\nimport { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { FormBuilder, FormGroup } from '@angular/forms';\r\nimport { SubSink } from 'subsink';\r\nimport { ColorableParentComponent } from './colorable.component';\r\n\r\n@Component({\r\n    selector: 'kms-form',\r\n    template: '',\r\n})\r\nexport class FormParentComponent extends ColorableParentComponent implements OnInit, OnDestroy {\r\n    @Input() disabled = false;\r\n    @Input() showRequired = false;\r\n\r\n    public form!: FormGroup;\r\n    public formInitialized = false;\r\n    private allowedCharsOnlyNumbers = new Set('0123456789'.split('').map((c) => c.charCodeAt(0)));\r\n\r\n    public subs = new SubSink();\r\n\r\n    @Output() formDataChanged: EventEmitter<FormGroup> = new EventEmitter();\r\n\r\n    constructor(public formBuilder: FormBuilder) {\r\n        super();\r\n    }\r\n\r\n    // TODO make a service or make own component etc.\r\n    /**\r\n     * Returns if a number was pressed\r\n     * @param e\r\n     * @returns\r\n     */\r\n    checkIfKeyWasNumber(e: KeyboardEvent, allowDelete = true, allowArrows = true, allowCutCopyPaste = true) {\r\n        // returns if keycode of numbers-row or numberpad. Or if parameter set, allow delete/backspace key\r\n        const isNumberRow = e.keyCode >= 48 && e.keyCode <= 57;\r\n        const isNumberPad = e.keyCode >= 96 && e.keyCode <= 105;\r\n        const isArrows = e.keyCode >= 37 && e.keyCode <= 40;\r\n        const isDelete = e.keyCode == 8 || e.keyCode == 46;\r\n        const isCutCopyOrPaste = (e.ctrlKey || e.metaKey) && (e.keyCode == 86 || e.keyCode == 88 || e.keyCode == 67);\r\n        const isTab = 9;\r\n        return (\r\n            isNumberRow ||\r\n            isNumberPad ||\r\n            isTab ||\r\n            (allowDelete && isDelete) ||\r\n            (allowArrows && isArrows) ||\r\n            (allowCutCopyPaste && isCutCopyOrPaste)\r\n        );\r\n    }\r\n\r\n    // TODO make a service or make own component etc.\r\n    /**\r\n     * Prevents to input other chars than numbers in input\r\n     * @param event\r\n     */\r\n    removeNumbersOnType(event: KeyboardEvent) {\r\n        // only allow keydown from numbers-row or numberpad of keybard and block other chars than numbers\r\n        if (!this.checkIfKeyWasNumber(event) && !this.allowedCharsOnlyNumbers.has(event.keyCode)) {\r\n            event.preventDefault();\r\n        }\r\n    }\r\n\r\n    // TODO make a service or make own component etc.\r\n    /**\r\n     * Prevents input when pasting which is not number\r\n     * @param event\r\n     */\r\n    removeNumbersOnPaste(event: ClipboardEvent) {\r\n        const clipboardData = event.clipboardData;\r\n        if (clipboardData) {\r\n            const pastedText = clipboardData.getData('text');\r\n            if (pastedText) {\r\n                const isnum = /^\\d+$/.test(pastedText);\r\n                if (!isnum) {\r\n                    event.preventDefault();\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.initFormEvent();\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this.subs.unsubscribe();\r\n    }\r\n\r\n    initFormEvent() {\r\n        if (this.form) {\r\n            this.formDataChanged.emit(this.form);\r\n            this.form.valueChanges.subscribe(() => {\r\n                this.formDataChanged.emit(this.form);\r\n            });\r\n        }\r\n    }\r\n}\r\n"]}
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @copyright KMS GmbH
3
3
  */
4
- import { isPlatformBrowser } from '@angular/common';
4
+ import { DOCUMENT, isPlatformBrowser } from '@angular/common';
5
5
  import { Inject, Injectable, PLATFORM_ID } from '@angular/core';
6
6
  import { Subject } from 'rxjs';
7
7
  import * as i0 from "@angular/core";
@@ -9,12 +9,13 @@ import * as i0 from "@angular/core";
9
9
  * Service to get viewport
10
10
  */
11
11
  export class ViewportService {
12
- constructor(platformId) {
12
+ constructor(platformId, document) {
13
13
  this.platformId = platformId;
14
+ this.document = document;
14
15
  this.viewports = [
15
16
  {
16
17
  name: 'xs',
17
- low: 420,
18
+ low: 360,
18
19
  high: 990,
19
20
  },
20
21
  {
@@ -29,7 +30,7 @@ export class ViewportService {
29
30
  },
30
31
  {
31
32
  name: 'l',
32
- low: 12001,
33
+ low: 1201,
33
34
  high: 1400,
34
35
  },
35
36
  {
@@ -50,45 +51,52 @@ export class ViewportService {
50
51
  ];
51
52
  this.viewportChangedSubscriber = new Subject();
52
53
  this.viewportResizedSubscriber = new Subject();
54
+ this.isBrowser = false;
53
55
  if (isPlatformBrowser(this.platformId)) {
54
56
  window.addEventListener('resize', this.documentSizeChanged.bind(this), { passive: true });
57
+ this.isBrowser = true;
55
58
  }
56
59
  }
57
60
  /**
58
61
  * Get window height
59
62
  */
60
63
  getDocumentHeight() {
61
- return isPlatformBrowser(this.platformId) ? document.body.clientHeight : 1200;
64
+ return this.isBrowser ? document.body.clientHeight : 1200;
62
65
  }
63
66
  /**
64
67
  * Get window width
65
68
  */
66
69
  getDocumentWidth() {
67
- return isPlatformBrowser(this.platformId) ? document.body.clientWidth : 1200;
70
+ return this.isBrowser ? document.body.clientWidth : 1200;
68
71
  }
69
72
  /**
70
73
  * Get window height
71
74
  */
72
75
  getWindowHeight() {
73
- return isPlatformBrowser(this.platformId) ? window.innerHeight : 1200;
76
+ return this.isBrowser ? window.innerHeight : 1200;
74
77
  }
75
78
  /**
76
79
  * Get window width
77
80
  */
78
81
  getWindowWidth() {
79
- return isPlatformBrowser(this.platformId) ? window.innerWidth : 1200;
82
+ return this.isBrowser ? window.innerWidth : 1200;
80
83
  }
81
84
  /**
82
85
  * Returns the current viewport MQ as string
83
86
  * @returns string
84
87
  */
85
88
  getCurrentViewPort() {
86
- if (!this.currentViewport) {
87
- const currentWidth = isPlatformBrowser(this.platformId) ? document.body.clientWidth : 1200;
88
- this.currentViewport = this.convertWidthToMediaQuery(currentWidth);
89
- }
89
+ const currentWidth = this.isBrowser ? document.body.clientWidth : 1200;
90
+ this.currentViewport = this.convertWidthToMediaQuery(currentWidth);
90
91
  return this.currentViewport;
91
92
  }
93
+ /**
94
+ * Returns the current viewport MQ as string
95
+ * @returns string
96
+ */
97
+ getCurrentViewPortNumber() {
98
+ return this.isBrowser ? document.body.clientWidth : 1200;
99
+ }
92
100
  /**
93
101
  * Provides mq´s as string
94
102
  */
@@ -102,7 +110,7 @@ export class ViewportService {
102
110
  return this.viewportResizedSubscriber.asObservable();
103
111
  }
104
112
  scrollToElementId(el, alignCenter = false) {
105
- if (isPlatformBrowser(this.platformId)) {
113
+ if (this.isBrowser) {
106
114
  this.scrollToElement(document.querySelector('#' + el), alignCenter);
107
115
  }
108
116
  }
@@ -112,24 +120,20 @@ export class ViewportService {
112
120
  * @param alignCenter - defines if the element needs to be centered on window
113
121
  */
114
122
  scrollToElement(el, alignCenter = false) {
115
- if (isPlatformBrowser(this.platformId)) {
123
+ if (this.isBrowser) {
116
124
  let extraScrollTop = 0;
117
125
  if (alignCenter) {
118
126
  extraScrollTop = (window.innerHeight - el.clientHeight) / 2;
119
127
  }
120
- /*
121
- const elementPos: DOMRect = el.getBoundingClientRect();
122
- const scrollTopPosition = elementPos.x - extraScrollTop;
123
- */
124
- //let offsetLeft = 0;
128
+ let offsetLeft = 0;
125
129
  let offsetTop = 0;
126
130
  let elTemp = el;
127
131
  while (elTemp) {
128
- //offsetLeft += elTemp.offsetLeft;
132
+ offsetLeft += elTemp.offsetLeft;
129
133
  offsetTop += elTemp.offsetTop;
130
134
  elTemp = elTemp.parentElement ? elTemp.parentElement : null;
131
135
  }
132
- window.scrollTo({ left: 0, top: offsetTop - extraScrollTop, behavior: 'smooth' });
136
+ window.scrollTo({ left: offsetLeft, top: offsetTop - extraScrollTop, behavior: 'smooth' });
133
137
  }
134
138
  }
135
139
  /**
@@ -137,13 +141,42 @@ export class ViewportService {
137
141
  * @param top - top position value
138
142
  */
139
143
  scrollTop(top) {
140
- if (isPlatformBrowser(this.platformId)) {
144
+ if (this.isBrowser) {
141
145
  window.scrollTo({ left: 0, top: top, behavior: 'smooth' });
142
146
  }
143
147
  }
144
- ngOnDestroy() {
145
- if (isPlatformBrowser(this.platformId)) {
146
- window.removeEventListener('resize', this.documentSizeChanged);
148
+ isPortrait() {
149
+ if (this.isBrowser)
150
+ return window.innerHeight > window.innerWidth;
151
+ else
152
+ return;
153
+ }
154
+ isLandscape() {
155
+ if (this.isBrowser) {
156
+ const isLandscape = window.orientation === 90 || window.orientation === -90;
157
+ return isLandscape;
158
+ }
159
+ else {
160
+ return;
161
+ }
162
+ }
163
+ isMobile() {
164
+ return this.getCurrentViewPortNumber() < this.viewports[2].low;
165
+ }
166
+ calculateFullscreenElementsheight(id, defaultheight, extra) {
167
+ if (!this.isBrowser || this.isMobile()) {
168
+ return defaultheight;
169
+ }
170
+ else {
171
+ const map = this.document.getElementById(id);
172
+ const footer = this.document.getElementsByTagName('footer')[0];
173
+ if (map && footer) {
174
+ return `${window.innerHeight - map.offsetTop - footer.offsetHeight - extra}px`;
175
+ }
176
+ else {
177
+ console.warn('could not calculate map height');
178
+ return defaultheight;
179
+ }
147
180
  }
148
181
  }
149
182
  /**
@@ -189,28 +222,21 @@ export class ViewportService {
189
222
  }
190
223
  return currentViewport;
191
224
  }
192
- isPortrait() {
193
- if (isPlatformBrowser(this.platformId))
194
- return window.innerHeight > window.innerWidth;
195
- else
196
- return;
197
- }
198
- isLandscape() {
199
- if (isPlatformBrowser(this.platformId)) {
200
- const isLandscape = window.orientation === 90 || window.orientation === -90;
201
- return isLandscape;
202
- }
203
- else {
204
- return;
225
+ ngOnDestroy() {
226
+ if (this.isBrowser) {
227
+ window.removeEventListener('resize', this.documentSizeChanged);
205
228
  }
206
229
  }
207
230
  }
208
- ViewportService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ViewportService, deps: [{ token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Injectable });
231
+ ViewportService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ViewportService, deps: [{ token: PLATFORM_ID }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable });
209
232
  ViewportService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ViewportService });
210
233
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ViewportService, decorators: [{
211
234
  type: Injectable
212
235
  }], ctorParameters: function () { return [{ type: Object, decorators: [{
213
236
  type: Inject,
214
237
  args: [PLATFORM_ID]
238
+ }] }, { type: Document, decorators: [{
239
+ type: Inject,
240
+ args: [DOCUMENT]
215
241
  }] }]; } });
216
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewport.service.js","sourceRoot":"","sources":["../../../../../../projects/kms-ngx-ui-presentational/src/lib/services/viewport.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * @copyright KMS GmbH\r\n */\r\n\r\nimport { isPlatformBrowser } from '@angular/common';\r\nimport { Inject, Injectable, OnDestroy, PLATFORM_ID } from '@angular/core';\r\nimport { Observable, Subject } from 'rxjs';\r\nimport { NullAble } from '../models';\r\n\r\n// needed for scrollToElement functionality\r\n\r\ndeclare const window: any;\r\n\r\ndeclare const document: any;\r\n\r\n/**\r\n * Service to get viewport\r\n */\r\n@Injectable()\r\nexport class ViewportService implements OnDestroy {\r\n    public readonly viewports = [\r\n        {\r\n            name: 'xs',\r\n            low: 420,\r\n            high: 990,\r\n        },\r\n        {\r\n            name: 's',\r\n            low: 991,\r\n            high: 1024,\r\n        },\r\n        {\r\n            name: 'm',\r\n            low: 1025,\r\n            high: 1200,\r\n        },\r\n        {\r\n            name: 'l',\r\n            low: 12001,\r\n            high: 1400,\r\n        },\r\n        {\r\n            name: 'xl',\r\n            low: 1401,\r\n            high: 1600,\r\n        },\r\n        {\r\n            name: 'xxl',\r\n            low: 1601,\r\n            high: 1920,\r\n        },\r\n        {\r\n            name: 'xxxl',\r\n            low: 1921,\r\n            high: 99999,\r\n        },\r\n    ];\r\n\r\n    private viewportChangedSubscriber: Subject<string> = new Subject<string>();\r\n    private viewportResizedSubscriber: Subject<number> = new Subject<number>();\r\n    private currentViewport!: string;\r\n\r\n    constructor(@Inject(PLATFORM_ID) private platformId: Object) {\r\n        if (isPlatformBrowser(this.platformId)) {\r\n            window.addEventListener('resize', this.documentSizeChanged.bind(this), { passive: true });\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Get window height\r\n     */\r\n    public getDocumentHeight(): number {\r\n        return isPlatformBrowser(this.platformId) ? document.body.clientHeight : 1200;\r\n    }\r\n\r\n    /**\r\n     * Get window width\r\n     */\r\n    public getDocumentWidth(): number {\r\n        return isPlatformBrowser(this.platformId) ? document.body.clientWidth : 1200;\r\n    }\r\n\r\n    /**\r\n     * Get window height\r\n     */\r\n    public getWindowHeight(): number {\r\n        return isPlatformBrowser(this.platformId) ? window.innerHeight : 1200;\r\n    }\r\n\r\n    /**\r\n     * Get window width\r\n     */\r\n    public getWindowWidth(): number {\r\n        return isPlatformBrowser(this.platformId) ? window.innerWidth : 1200;\r\n    }\r\n\r\n    /**\r\n     * Returns the current viewport MQ as string\r\n     * @returns string\r\n     */\r\n    getCurrentViewPort(): string {\r\n        if (!this.currentViewport) {\r\n            const currentWidth: number = isPlatformBrowser(this.platformId) ? document.body.clientWidth : 1200;\r\n            this.currentViewport = this.convertWidthToMediaQuery(currentWidth);\r\n        }\r\n\r\n        return this.currentViewport;\r\n    }\r\n\r\n    /**\r\n     * Provides mq´s as string\r\n     */\r\n    public getViewportChangedObserver(): Observable<string> {\r\n        return this.viewportChangedSubscriber.asObservable();\r\n    }\r\n\r\n    /**\r\n     * Provides the current window width as number\r\n     */\r\n    public getViewportResizedObserver(): Observable<number> {\r\n        return this.viewportResizedSubscriber.asObservable();\r\n    }\r\n\r\n    public scrollToElementId(el: string, alignCenter = false) {\r\n        if (isPlatformBrowser(this.platformId)) {\r\n            this.scrollToElement(document.querySelector('#' + el), alignCenter);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Helper function that scrolls to the given markup element.\r\n     * @param el - nativeElement from markup\r\n     * @param alignCenter - defines if the element needs to be centered on window\r\n     */\r\n\r\n    public scrollToElement(el: HTMLElement, alignCenter = false) {\r\n        if (isPlatformBrowser(this.platformId)) {\r\n            let extraScrollTop = 0;\r\n\r\n            if (alignCenter) {\r\n                extraScrollTop = (window.innerHeight - el.clientHeight) / 2;\r\n            }\r\n\r\n            /*\r\n            const elementPos: DOMRect = el.getBoundingClientRect();\r\n            const scrollTopPosition = elementPos.x - extraScrollTop;\r\n            */\r\n\r\n            //let offsetLeft = 0;\r\n            let offsetTop = 0;\r\n\r\n            let elTemp: NullAble<HTMLElement> = el;\r\n\r\n            while (elTemp) {\r\n                //offsetLeft += elTemp.offsetLeft;\r\n                offsetTop += elTemp.offsetTop;\r\n                elTemp = elTemp.parentElement ? elTemp.parentElement : null;\r\n            }\r\n\r\n            window.scrollTo({ left: 0, top: offsetTop - extraScrollTop, behavior: 'smooth' });\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Scroll to the top position\r\n     * @param top - top position value\r\n     */\r\n    public scrollTop(top: number) {\r\n        if (isPlatformBrowser(this.platformId)) {\r\n            window.scrollTo({ left: 0, top: top, behavior: 'smooth' });\r\n        }\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        if (isPlatformBrowser(this.platformId)) {\r\n            window.removeEventListener('resize', this.documentSizeChanged);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * If viewport changed\r\n     * @event\r\n     */\r\n\r\n    private documentSizeChanged(event: any) {\r\n        const currentWindowWidth: number = event.target.innerWidth;\r\n        // inform who´s interested\r\n        this.viewportResizedSubscriber.next(currentWindowWidth);\r\n\r\n        if (currentWindowWidth > 0) {\r\n            for (const mqs of this.viewports) {\r\n                if (currentWindowWidth > mqs.high) {\r\n                    continue;\r\n                } else if (\r\n                    (currentWindowWidth >= mqs.low || currentWindowWidth <= mqs.high) &&\r\n                    this.currentViewport !== mqs.name\r\n                ) {\r\n                    this.currentViewport = mqs.name;\r\n                    // inform who´s interested\r\n                    this.viewportChangedSubscriber.next(mqs.name);\r\n                    break;\r\n                } else if (this.currentViewport === mqs.name) {\r\n                    break;\r\n                } else {\r\n                    console.error('ERROR');\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Get the Media Query for the given width\r\n     * @param width Width to get the according MQ for\r\n     */\r\n    private convertWidthToMediaQuery(width: number) {\r\n        let currentViewport = '';\r\n\r\n        for (const mqs of this.viewports) {\r\n            if (width <= mqs.high && width >= mqs.low) {\r\n                currentViewport = mqs.name;\r\n                break;\r\n            }\r\n        }\r\n\r\n        return currentViewport;\r\n    }\r\n\r\n    isPortrait() {\r\n        if (isPlatformBrowser(this.platformId)) return window.innerHeight > window.innerWidth;\r\n        else return;\r\n    }\r\n\r\n    isLandscape() {\r\n        if (isPlatformBrowser(this.platformId)) {\r\n            const isLandscape = window.orientation === 90 || window.orientation === -90;\r\n            return isLandscape;\r\n        } else {\r\n            return;\r\n        }\r\n    }\r\n}\r\n"]}
242
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewport.service.js","sourceRoot":"","sources":["../../../../../../projects/kms-ngx-ui-presentational/src/lib/services/viewport.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * @copyright KMS GmbH\r\n */\r\nimport { DOCUMENT, isPlatformBrowser } from '@angular/common';\r\nimport { Inject, Injectable, OnDestroy, PLATFORM_ID } from '@angular/core';\r\nimport { Observable, Subject } from 'rxjs';\r\nimport { NullAble } from '../models';\r\n\r\ndeclare const window: any;\r\ndeclare const document: any;\r\n\r\n/**\r\n * Service to get viewport\r\n */\r\n@Injectable()\r\nexport class ViewportService implements OnDestroy {\r\n    public readonly viewports = [\r\n        {\r\n            name: 'xs',\r\n            low: 360,\r\n            high: 990,\r\n        },\r\n        {\r\n            name: 's',\r\n            low: 991,\r\n            high: 1024,\r\n        },\r\n        {\r\n            name: 'm',\r\n            low: 1025,\r\n            high: 1200,\r\n        },\r\n        {\r\n            name: 'l',\r\n            low: 1201,\r\n            high: 1400,\r\n        },\r\n        {\r\n            name: 'xl',\r\n            low: 1401,\r\n            high: 1600,\r\n        },\r\n        {\r\n            name: 'xxl',\r\n            low: 1601,\r\n            high: 1920,\r\n        },\r\n        {\r\n            name: 'xxxl',\r\n            low: 1921,\r\n            high: 99999,\r\n        },\r\n    ];\r\n\r\n    private viewportChangedSubscriber: Subject<string> = new Subject<string>();\r\n    private viewportResizedSubscriber: Subject<number> = new Subject<number>();\r\n    private currentViewport!: string;\r\n    private isBrowser = false;\r\n\r\n    constructor(@Inject(PLATFORM_ID) private platformId: Object, @Inject(DOCUMENT) public document: Document) {\r\n        if (isPlatformBrowser(this.platformId)) {\r\n            window.addEventListener('resize', this.documentSizeChanged.bind(this), { passive: true });\r\n            this.isBrowser = true;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Get window height\r\n     */\r\n    public getDocumentHeight(): number {\r\n        return this.isBrowser ? document.body.clientHeight : 1200;\r\n    }\r\n\r\n    /**\r\n     * Get window width\r\n     */\r\n    public getDocumentWidth(): number {\r\n        return this.isBrowser ? document.body.clientWidth : 1200;\r\n    }\r\n\r\n    /**\r\n     * Get window height\r\n     */\r\n    public getWindowHeight(): number {\r\n        return this.isBrowser ? window.innerHeight : 1200;\r\n    }\r\n\r\n    /**\r\n     * Get window width\r\n     */\r\n    public getWindowWidth(): number {\r\n        return this.isBrowser ? window.innerWidth : 1200;\r\n    }\r\n\r\n    /**\r\n     * Returns the current viewport MQ as string\r\n     * @returns string\r\n     */\r\n    public getCurrentViewPort(): string {\r\n        const currentWidth: number = this.isBrowser ? document.body.clientWidth : 1200;\r\n        this.currentViewport = this.convertWidthToMediaQuery(currentWidth);\r\n\r\n        return this.currentViewport;\r\n    }\r\n\r\n    /**\r\n     * Returns the current viewport MQ as string\r\n     * @returns string\r\n     */\r\n    public getCurrentViewPortNumber(): number {\r\n        return this.isBrowser ? document.body.clientWidth : 1200;\r\n    }\r\n\r\n    /**\r\n     * Provides mq´s as string\r\n     */\r\n    public getViewportChangedObserver(): Observable<string> {\r\n        return this.viewportChangedSubscriber.asObservable();\r\n    }\r\n\r\n    /**\r\n     * Provides the current window width as number\r\n     */\r\n    public getViewportResizedObserver(): Observable<number> {\r\n        return this.viewportResizedSubscriber.asObservable();\r\n    }\r\n\r\n    public scrollToElementId(el: string, alignCenter = false) {\r\n        if (this.isBrowser) {\r\n            this.scrollToElement(document.querySelector('#' + el), alignCenter);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Helper function that scrolls to the given markup element.\r\n     * @param el - nativeElement from markup\r\n     * @param alignCenter - defines if the element needs to be centered on window\r\n     */\r\n\r\n    public scrollToElement(el: HTMLElement, alignCenter = false) {\r\n        if (this.isBrowser) {\r\n            let extraScrollTop = 0;\r\n\r\n            if (alignCenter) {\r\n                extraScrollTop = (window.innerHeight - el.clientHeight) / 2;\r\n            }\r\n\r\n            let offsetLeft = 0;\r\n            let offsetTop = 0;\r\n\r\n            let elTemp: NullAble<HTMLElement> = el;\r\n\r\n            while (elTemp) {\r\n                offsetLeft += elTemp.offsetLeft;\r\n                offsetTop += elTemp.offsetTop;\r\n                elTemp = elTemp.parentElement ? elTemp.parentElement : null;\r\n            }\r\n\r\n            window.scrollTo({ left: offsetLeft, top: offsetTop - extraScrollTop, behavior: 'smooth' });\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Scroll to the top position\r\n     * @param top - top position value\r\n     */\r\n    public scrollTop(top: number) {\r\n        if (this.isBrowser) {\r\n            window.scrollTo({ left: 0, top: top, behavior: 'smooth' });\r\n        }\r\n    }\r\n\r\n    public isPortrait() {\r\n        if (this.isBrowser) return window.innerHeight > window.innerWidth;\r\n        else return;\r\n    }\r\n\r\n    public isLandscape() {\r\n        if (this.isBrowser) {\r\n            const isLandscape = window.orientation === 90 || window.orientation === -90;\r\n            return isLandscape;\r\n        } else {\r\n            return;\r\n        }\r\n    }\r\n\r\n    public isMobile() {\r\n        return this.getCurrentViewPortNumber() < this.viewports[2].low;\r\n    }\r\n\r\n    public calculateFullscreenElementsheight(id: string, defaultheight: string, extra: number) {\r\n        if (!this.isBrowser || this.isMobile()) {\r\n            return defaultheight;\r\n        } else {\r\n            const map = this.document.getElementById(id);\r\n            const footer = this.document.getElementsByTagName('footer')[0];\r\n            if (map && footer) {\r\n                return `${window.innerHeight - map.offsetTop - footer.offsetHeight - extra}px`;\r\n            } else {\r\n                console.warn('could not calculate map height');\r\n                return defaultheight;\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * If viewport changed\r\n     * @event\r\n     */\r\n\r\n    private documentSizeChanged(event: any) {\r\n        const currentWindowWidth: number = event.target.innerWidth;\r\n        // inform who´s interested\r\n        this.viewportResizedSubscriber.next(currentWindowWidth);\r\n\r\n        if (currentWindowWidth > 0) {\r\n            for (const mqs of this.viewports) {\r\n                if (currentWindowWidth > mqs.high) {\r\n                    continue;\r\n                } else if (\r\n                    (currentWindowWidth >= mqs.low || currentWindowWidth <= mqs.high) &&\r\n                    this.currentViewport !== mqs.name\r\n                ) {\r\n                    this.currentViewport = mqs.name;\r\n                    // inform who´s interested\r\n                    this.viewportChangedSubscriber.next(mqs.name);\r\n                    break;\r\n                } else if (this.currentViewport === mqs.name) {\r\n                    break;\r\n                } else {\r\n                    console.error('ERROR');\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Get the Media Query for the given width\r\n     * @param width Width to get the according MQ for\r\n     */\r\n    private convertWidthToMediaQuery(width: number) {\r\n        let currentViewport = '';\r\n\r\n        for (const mqs of this.viewports) {\r\n            if (width <= mqs.high && width >= mqs.low) {\r\n                currentViewport = mqs.name;\r\n                break;\r\n            }\r\n        }\r\n\r\n        return currentViewport;\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        if (this.isBrowser) {\r\n            window.removeEventListener('resize', this.documentSizeChanged);\r\n        }\r\n    }\r\n}\r\n"]}
@@ -35,7 +35,7 @@ export class BackToTopComponent {
35
35
  }
36
36
  }
37
37
  BackToTopComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: BackToTopComponent, deps: [{ token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component });
38
- BackToTopComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: BackToTopComponent, selector: "kms-back-to-top", host: { listeners: { "window:scroll": "onWindowScroll()" } }, ngImport: i0, template: "<div class=\"scrollToTop\"\r\n [ngClass]=\"{'show': windowScrolled}\"\r\n (click)=\"scrollToTop()\">\r\n <div class=\"scrollToTop-inner\">\r\n <kms-icon icon=\"floating_button_clear\" iconClass=\"color-white\"></kms-icon>\r\n </div>\r\n</div>", components: [{ type: i1.IconComponent, selector: "kms-icon", inputs: ["icon", "iconClass", "iconStyle", "iconSize", "dontUseSprite"] }], directives: [{ type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
38
+ BackToTopComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: BackToTopComponent, selector: "kms-back-to-top", host: { listeners: { "window:scroll": "onWindowScroll()" } }, ngImport: i0, template: "<div class=\"scrollToTop\"\r\n [ngClass]=\"{'show': windowScrolled}\"\r\n (click)=\"scrollToTop()\">\r\n <div class=\"scrollToTop-inner\">\r\n <kms-icon icon=\"floating_button_clear\" iconClass=\"color-white\"></kms-icon>\r\n </div>\r\n</div>", components: [{ type: i1.IconComponent, selector: "kms-icon", inputs: ["icon", "iconClass", "iconStyle", "iconSize", "size", "dontUseSprite"] }], directives: [{ type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
39
39
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: BackToTopComponent, decorators: [{
40
40
  type: Component,
41
41
  args: [{