@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.
- package/bundles/kms-ngx-ui-presentational.umd.js +257 -134
- package/bundles/kms-ngx-ui-presentational.umd.js.map +1 -1
- package/esm2015/lib/directives/directives.module.js +8 -3
- package/esm2015/lib/directives/size.directive.js +21 -0
- package/esm2015/lib/parent-components/colorable.component.js +35 -0
- package/esm2015/lib/parent-components/form-control.component.js +4 -3
- package/esm2015/lib/parent-components/form.component.js +36 -15
- package/esm2015/lib/services/viewport.service.js +66 -40
- package/esm2015/lib/ui/back-to-top/back-to-top.component.js +1 -1
- package/esm2015/lib/ui/file-input/file-input.component.js +6 -6
- package/esm2015/lib/ui/flyout/flyout.component.js +5 -4
- package/esm2015/lib/ui/icon/icon.component.js +5 -2
- package/esm2015/lib/ui/icon/iconSize.enum.js +12 -1
- package/esm2015/lib/ui/image-slider/image-slider.component.js +1 -1
- package/esm2015/lib/ui/kms-accordion-item/kms-accordion-item.component.js +1 -1
- package/esm2015/lib/ui/map/map.component.js +2 -2
- package/esm2015/lib/ui/radiobutton/radiobutton.component.js +7 -3
- package/esm2015/lib/ui/tooltip-icon/tooltip-icon.component.js +5 -4
- package/esm2015/public-api.js +2 -1
- package/fesm2015/kms-ngx-ui-presentational.js +242 -123
- package/fesm2015/kms-ngx-ui-presentational.js.map +1 -1
- package/lib/directives/directives.module.d.ts +4 -2
- package/lib/directives/size.directive.d.ts +10 -0
- package/lib/parent-components/colorable.component.d.ts +10 -0
- package/lib/parent-components/form.component.d.ts +11 -5
- package/lib/services/viewport.service.d.ts +13 -4
- package/lib/ui/file-input/file-input.component.d.ts +2 -2
- package/lib/ui/icon/icon.component.d.ts +7 -1
- package/lib/ui/icon/iconSize.enum.d.ts +10 -0
- package/lib/ui/radiobutton/radiobutton.component.d.ts +2 -1
- package/lib/ui/tooltip-icon/tooltip-icon.component.d.ts +2 -2
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/src/lib/ui/back-to-top/back-to-top.component.scss +2 -3
- package/src/lib/ui/icon/icon.component.scss +2 -36
- package/src/styles/animations.scss +47 -0
- 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
|
|
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,
|
|
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,
|
|
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
|
-
|
|
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,
|
|
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
|
|
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
|
-
|
|
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
|
|
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
|
|
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.
|
|
60
|
-
|
|
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: {
|
|
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,
|
|
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:
|
|
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:
|
|
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
|
|
64
|
+
return this.isBrowser ? document.body.clientHeight : 1200;
|
|
62
65
|
}
|
|
63
66
|
/**
|
|
64
67
|
* Get window width
|
|
65
68
|
*/
|
|
66
69
|
getDocumentWidth() {
|
|
67
|
-
return
|
|
70
|
+
return this.isBrowser ? document.body.clientWidth : 1200;
|
|
68
71
|
}
|
|
69
72
|
/**
|
|
70
73
|
* Get window height
|
|
71
74
|
*/
|
|
72
75
|
getWindowHeight() {
|
|
73
|
-
return
|
|
76
|
+
return this.isBrowser ? window.innerHeight : 1200;
|
|
74
77
|
}
|
|
75
78
|
/**
|
|
76
79
|
* Get window width
|
|
77
80
|
*/
|
|
78
81
|
getWindowWidth() {
|
|
79
|
-
return
|
|
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
|
-
|
|
87
|
-
|
|
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 (
|
|
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 (
|
|
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
|
-
|
|
132
|
+
offsetLeft += elTemp.offsetLeft;
|
|
129
133
|
offsetTop += elTemp.offsetTop;
|
|
130
134
|
elTemp = elTemp.parentElement ? elTemp.parentElement : null;
|
|
131
135
|
}
|
|
132
|
-
window.scrollTo({ left:
|
|
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 (
|
|
144
|
+
if (this.isBrowser) {
|
|
141
145
|
window.scrollTo({ left: 0, top: top, behavior: 'smooth' });
|
|
142
146
|
}
|
|
143
147
|
}
|
|
144
|
-
|
|
145
|
-
if (
|
|
146
|
-
window.
|
|
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
|
-
|
|
193
|
-
if (
|
|
194
|
-
|
|
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":"AAAA;;GAEG;AAEH,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAa,WAAW,EAAE,MAAM,eAAe,CAAC;AAC3E,OAAO,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;;AAS3C;;GAEG;AAEH,MAAM,OAAO,eAAe;IA2CxB,YAAyC,UAAkB;QAAlB,eAAU,GAAV,UAAU,CAAQ;QA1C3C,cAAS,GAAG;YACxB;gBACI,IAAI,EAAE,IAAI;gBACV,GAAG,EAAE,GAAG;gBACR,IAAI,EAAE,GAAG;aACZ;YACD;gBACI,IAAI,EAAE,GAAG;gBACT,GAAG,EAAE,GAAG;gBACR,IAAI,EAAE,IAAI;aACb;YACD;gBACI,IAAI,EAAE,GAAG;gBACT,GAAG,EAAE,IAAI;gBACT,IAAI,EAAE,IAAI;aACb;YACD;gBACI,IAAI,EAAE,GAAG;gBACT,GAAG,EAAE,KAAK;gBACV,IAAI,EAAE,IAAI;aACb;YACD;gBACI,IAAI,EAAE,IAAI;gBACV,GAAG,EAAE,IAAI;gBACT,IAAI,EAAE,IAAI;aACb;YACD;gBACI,IAAI,EAAE,KAAK;gBACX,GAAG,EAAE,IAAI;gBACT,IAAI,EAAE,IAAI;aACb;YACD;gBACI,IAAI,EAAE,MAAM;gBACZ,GAAG,EAAE,IAAI;gBACT,IAAI,EAAE,KAAK;aACd;SACJ,CAAC;QAEM,8BAAyB,GAAoB,IAAI,OAAO,EAAU,CAAC;QACnE,8BAAyB,GAAoB,IAAI,OAAO,EAAU,CAAC;QAIvE,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YACpC,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;SAC7F;IACL,CAAC;IAED;;OAEG;IACI,iBAAiB;QACpB,OAAO,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC;IAClF,CAAC;IAED;;OAEG;IACI,gBAAgB;QACnB,OAAO,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC;IACjF,CAAC;IAED;;OAEG;IACI,eAAe;QAClB,OAAO,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC;IAC1E,CAAC;IAED;;OAEG;IACI,cAAc;QACjB,OAAO,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC;IACzE,CAAC;IAED;;;OAGG;IACH,kBAAkB;QACd,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;YACvB,MAAM,YAAY,GAAW,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC;YACnG,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,wBAAwB,CAAC,YAAY,CAAC,CAAC;SACtE;QAED,OAAO,IAAI,CAAC,eAAe,CAAC;IAChC,CAAC;IAED;;OAEG;IACI,0BAA0B;QAC7B,OAAO,IAAI,CAAC,yBAAyB,CAAC,YAAY,EAAE,CAAC;IACzD,CAAC;IAED;;OAEG;IACI,0BAA0B;QAC7B,OAAO,IAAI,CAAC,yBAAyB,CAAC,YAAY,EAAE,CAAC;IACzD,CAAC;IAEM,iBAAiB,CAAC,EAAU,EAAE,WAAW,GAAG,KAAK;QACpD,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YACpC,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,aAAa,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,WAAW,CAAC,CAAC;SACvE;IACL,CAAC;IAED;;;;OAIG;IAEI,eAAe,CAAC,EAAe,EAAE,WAAW,GAAG,KAAK;QACvD,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YACpC,IAAI,cAAc,GAAG,CAAC,CAAC;YAEvB,IAAI,WAAW,EAAE;gBACb,cAAc,GAAG,CAAC,MAAM,CAAC,WAAW,GAAG,EAAE,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;aAC/D;YAED;;;cAGE;YAEF,qBAAqB;YACrB,IAAI,SAAS,GAAG,CAAC,CAAC;YAElB,IAAI,MAAM,GAA0B,EAAE,CAAC;YAEvC,OAAO,MAAM,EAAE;gBACX,kCAAkC;gBAClC,SAAS,IAAI,MAAM,CAAC,SAAS,CAAC;gBAC9B,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC;aAC/D;YAED,MAAM,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,EAAE,SAAS,GAAG,cAAc,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;SACrF;IACL,CAAC;IAED;;;OAGG;IACI,SAAS,CAAC,GAAW;QACxB,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YACpC,MAAM,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;SAC9D;IACL,CAAC;IAED,WAAW;QACP,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YACpC,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;SAClE;IACL,CAAC;IAED;;;OAGG;IAEK,mBAAmB,CAAC,KAAU;QAClC,MAAM,kBAAkB,GAAW,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC;QAC3D,0BAA0B;QAC1B,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAExD,IAAI,kBAAkB,GAAG,CAAC,EAAE;YACxB,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,SAAS,EAAE;gBAC9B,IAAI,kBAAkB,GAAG,GAAG,CAAC,IAAI,EAAE;oBAC/B,SAAS;iBACZ;qBAAM,IACH,CAAC,kBAAkB,IAAI,GAAG,CAAC,GAAG,IAAI,kBAAkB,IAAI,GAAG,CAAC,IAAI,CAAC;oBACjE,IAAI,CAAC,eAAe,KAAK,GAAG,CAAC,IAAI,EACnC;oBACE,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC,IAAI,CAAC;oBAChC,0BAA0B;oBAC1B,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;oBAC9C,MAAM;iBACT;qBAAM,IAAI,IAAI,CAAC,eAAe,KAAK,GAAG,CAAC,IAAI,EAAE;oBAC1C,MAAM;iBACT;qBAAM;oBACH,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;iBAC1B;aACJ;SACJ;IACL,CAAC;IAED;;;OAGG;IACK,wBAAwB,CAAC,KAAa;QAC1C,IAAI,eAAe,GAAG,EAAE,CAAC;QAEzB,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,SAAS,EAAE;YAC9B,IAAI,KAAK,IAAI,GAAG,CAAC,IAAI,IAAI,KAAK,IAAI,GAAG,CAAC,GAAG,EAAE;gBACvC,eAAe,GAAG,GAAG,CAAC,IAAI,CAAC;gBAC3B,MAAM;aACT;SACJ;QAED,OAAO,eAAe,CAAC;IAC3B,CAAC;IAED,UAAU;QACN,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC;YAAE,OAAO,MAAM,CAAC,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC;;YACjF,OAAO;IAChB,CAAC;IAED,WAAW;QACP,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YACpC,MAAM,WAAW,GAAG,MAAM,CAAC,WAAW,KAAK,EAAE,IAAI,MAAM,CAAC,WAAW,KAAK,CAAC,EAAE,CAAC;YAC5E,OAAO,WAAW,CAAC;SACtB;aAAM;YACH,OAAO;SACV;IACL,CAAC;;6GA5NQ,eAAe,kBA2CJ,WAAW;iHA3CtB,eAAe;4FAAf,eAAe;kBAD3B,UAAU;0DA4C8C,MAAM;0BAA9C,MAAM;2BAAC,WAAW","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: [{
|