@kms-ngx-ui/presentational 0.0.23 → 13.0.0

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 (164) hide show
  1. package/README.md +28 -28
  2. package/{esm2015/kms-ngx-ui-presentational.js → esm2020/kms-ngx-ui-presentational.mjs} +4 -4
  3. package/{esm2015/lib/directives/directives.module.js → esm2020/lib/directives/directives.module.mjs} +40 -40
  4. package/{esm2015/lib/directives/mousewheel.directive.js → esm2020/lib/directives/mousewheel.directive.mjs} +56 -56
  5. package/{esm2015/lib/directives/sum-of-height.directive.js → esm2020/lib/directives/sum-of-height.directive.mjs} +74 -74
  6. package/{esm2015/lib/directives/swipe.directive.js → esm2020/lib/directives/swipe.directive.mjs} +183 -183
  7. package/esm2020/lib/directives/swipe.model.mjs +5 -0
  8. package/{esm2015/lib/directives/tooltip.directive.js → esm2020/lib/directives/tooltip.directive.mjs} +144 -144
  9. package/{esm2015/lib/kms-ngx-ui-presentational.component.js → esm2020/lib/kms-ngx-ui-presentational.component.mjs} +26 -26
  10. package/{esm2015/lib/kms-ngx-ui-presentational.module.js → esm2020/lib/kms-ngx-ui-presentational.module.mjs} +217 -217
  11. package/{esm2015/lib/kms-ngx-ui-presentational.service.js → esm2020/lib/kms-ngx-ui-presentational.service.mjs} +14 -14
  12. package/esm2020/lib/models/address.model.mjs +6 -0
  13. package/{esm2015/lib/models/iconSize.enum.js → esm2020/lib/models/iconSize.enum.mjs} +17 -17
  14. package/{esm2015/lib/models/image-snippet.model.js → esm2020/lib/models/image-snippet.model.mjs} +18 -18
  15. package/{esm2015/lib/models/index.js → esm2020/lib/models/index.mjs} +5 -5
  16. package/{esm2015/lib/models/is-value.function.js → esm2020/lib/models/is-value.function.mjs} +17 -17
  17. package/{esm2015/lib/models/salutation.enum.js → esm2020/lib/models/salutation.enum.mjs} +8 -8
  18. package/{esm2015/lib/models/types/attached-file-dto.model.js → esm2020/lib/models/types/attached-file-dto.model.mjs} +6 -6
  19. package/{esm2015/lib/models/types/nullable.type.js → esm2020/lib/models/types/nullable.type.mjs} +5 -5
  20. package/{esm2015/lib/parent-components/actions.component.js → esm2020/lib/parent-components/actions.component.mjs} +56 -56
  21. package/{esm2015/lib/parent-components/form-control.component.js → esm2020/lib/parent-components/form-control.component.mjs} +75 -75
  22. package/{esm2015/lib/parent-components/form.component.js → esm2020/lib/parent-components/form.component.mjs} +78 -78
  23. package/{esm2015/lib/pipes/custom-pipes.module.js → esm2020/lib/pipes/custom-pipes.module.mjs} +71 -71
  24. package/{esm2015/lib/pipes/decode-uri.pipe.js → esm2020/lib/pipes/decode-uri.pipe.mjs} +19 -19
  25. package/{esm2015/lib/pipes/encode-uri.pipe.js → esm2020/lib/pipes/encode-uri.pipe.mjs} +19 -19
  26. package/{esm2015/lib/pipes/integer-currency.pipe.js → esm2020/lib/pipes/integer-currency.pipe.mjs} +27 -27
  27. package/{esm2015/lib/pipes/safe-html.pipe.js → esm2020/lib/pipes/safe-html.pipe.mjs} +23 -23
  28. package/{esm2015/lib/pipes/safe-resource-url.pipe.js → esm2020/lib/pipes/safe-resource-url.pipe.mjs} +23 -23
  29. package/{esm2015/lib/pipes/safe-style.pipe.js → esm2020/lib/pipes/safe-style.pipe.mjs} +23 -23
  30. package/{esm2015/lib/pipes/safe-url.pipe.js → esm2020/lib/pipes/safe-url.pipe.mjs} +23 -23
  31. package/{esm2015/lib/pipes/to-number.pipe.js → esm2020/lib/pipes/to-number.pipe.mjs} +23 -23
  32. package/{esm2015/lib/pipes/trim.pipe.js → esm2020/lib/pipes/trim.pipe.mjs} +20 -20
  33. package/{esm2015/lib/pipes/typeof.pipe.js → esm2020/lib/pipes/typeof.pipe.mjs} +16 -16
  34. package/{esm2015/lib/services/viewport.service.js → esm2020/lib/services/viewport.service.mjs} +216 -216
  35. package/esm2020/lib/ui/back-to-top/back-to-top.component.mjs +49 -0
  36. package/{esm2015/lib/ui/button-with-confirm-dialog/button-response-types.enum.js → esm2020/lib/ui/button-with-confirm-dialog/button-response-types.enum.mjs} +6 -6
  37. package/esm2020/lib/ui/button-with-confirm-dialog/button-with-confirm-dialog.component.mjs +58 -0
  38. package/{esm2015/lib/ui/button-with-confirm-dialog/dialog-data.model.js → esm2020/lib/ui/button-with-confirm-dialog/dialog-data.model.mjs} +2 -2
  39. package/esm2020/lib/ui/checkbox/checkbox.component.mjs +71 -0
  40. package/esm2020/lib/ui/color-input/color-input.component.mjs +76 -0
  41. package/esm2020/lib/ui/dropdown-from-data/dropdown-from-data.component.mjs +165 -0
  42. package/esm2020/lib/ui/enum-radiogroup/enum-radiogroup.component.mjs +53 -0
  43. package/esm2020/lib/ui/file-input/file-input.component.mjs +232 -0
  44. package/esm2020/lib/ui/flyout/flyout.component.mjs +119 -0
  45. package/esm2020/lib/ui/generic-dialog/generic-dialog.component.mjs +54 -0
  46. package/esm2020/lib/ui/icon/icon.component.mjs +48 -0
  47. package/{esm2015/lib/ui/icon/iconSize.enum.js → esm2020/lib/ui/icon/iconSize.enum.mjs} +17 -17
  48. package/esm2020/lib/ui/image-slider/image-slider.component.mjs +189 -0
  49. package/esm2020/lib/ui/kms-accordion-item/kms-accordion-item.component.mjs +40 -0
  50. package/esm2020/lib/ui/loader/loader.component.mjs +21 -0
  51. package/esm2020/lib/ui/map/map.component.mjs +116 -0
  52. package/esm2020/lib/ui/radiobutton/radiobutton.component.mjs +73 -0
  53. package/esm2020/lib/ui/salutation-dropdown/salutation-dropdown.component.mjs +55 -0
  54. package/esm2020/lib/ui/salutation-radiogroup/salutation-radiogroup.component.mjs +49 -0
  55. package/esm2020/lib/ui/time-input/time-input.component.mjs +83 -0
  56. package/esm2020/lib/ui/tooltip/tooltip.component.mjs +16 -0
  57. package/esm2020/lib/ui/tooltip-icon/tooltip-icon.component.mjs +35 -0
  58. package/esm2020/lib/ui/yes-no-radiogroup/yes-no-radiogroup.component.mjs +82 -0
  59. package/{esm2015/public-api.js → esm2020/public-api.mjs} +49 -49
  60. package/fesm2015/kms-ngx-ui-presentational.mjs +3019 -0
  61. package/fesm2015/kms-ngx-ui-presentational.mjs.map +1 -0
  62. package/{fesm2015/kms-ngx-ui-presentational.js → fesm2020/kms-ngx-ui-presentational.mjs} +2869 -2958
  63. package/fesm2020/kms-ngx-ui-presentational.mjs.map +1 -0
  64. package/kms-ngx-ui-presentational.d.ts +5 -5
  65. package/lib/directives/directives.module.d.ts +11 -11
  66. package/lib/directives/mousewheel.directive.d.ts +15 -15
  67. package/lib/directives/sum-of-height.directive.d.ts +31 -31
  68. package/lib/directives/swipe.directive.d.ts +45 -45
  69. package/lib/directives/swipe.model.d.ts +49 -49
  70. package/lib/directives/tooltip.directive.d.ts +29 -29
  71. package/lib/kms-ngx-ui-presentational.component.d.ts +8 -8
  72. package/lib/kms-ngx-ui-presentational.module.d.ts +47 -47
  73. package/lib/kms-ngx-ui-presentational.service.d.ts +6 -6
  74. package/lib/models/address.model.d.ts +14 -14
  75. package/lib/models/iconSize.enum.d.ts +15 -15
  76. package/lib/models/image-snippet.model.d.ts +15 -15
  77. package/lib/models/index.d.ts +4 -4
  78. package/lib/models/is-value.function.d.ts +9 -9
  79. package/lib/models/salutation.enum.d.ts +5 -5
  80. package/lib/models/types/attached-file-dto.model.d.ts +11 -11
  81. package/lib/models/types/nullable.type.d.ts +4 -4
  82. package/lib/parent-components/actions.component.d.ts +31 -31
  83. package/lib/parent-components/form-control.component.d.ts +27 -27
  84. package/lib/parent-components/form.component.d.ts +34 -34
  85. package/lib/pipes/custom-pipes.module.d.ts +17 -17
  86. package/lib/pipes/decode-uri.pipe.d.ts +10 -10
  87. package/lib/pipes/encode-uri.pipe.d.ts +10 -10
  88. package/lib/pipes/integer-currency.pipe.d.ts +13 -13
  89. package/lib/pipes/safe-html.pipe.d.ts +13 -13
  90. package/lib/pipes/safe-resource-url.pipe.d.ts +13 -13
  91. package/lib/pipes/safe-style.pipe.d.ts +13 -13
  92. package/lib/pipes/safe-url.pipe.d.ts +13 -13
  93. package/lib/pipes/to-number.pipe.d.ts +10 -10
  94. package/lib/pipes/trim.pipe.d.ts +10 -10
  95. package/lib/pipes/typeof.pipe.d.ts +7 -7
  96. package/lib/services/viewport.service.d.ts +74 -74
  97. package/lib/ui/back-to-top/back-to-top.component.d.ts +10 -10
  98. package/lib/ui/button-with-confirm-dialog/button-response-types.enum.d.ts +4 -4
  99. package/lib/ui/button-with-confirm-dialog/button-with-confirm-dialog.component.d.ts +19 -19
  100. package/lib/ui/button-with-confirm-dialog/dialog-data.model.d.ts +9 -9
  101. package/lib/ui/checkbox/checkbox.component.d.ts +31 -31
  102. package/lib/ui/color-input/color-input.component.d.ts +19 -19
  103. package/lib/ui/dropdown-from-data/dropdown-from-data.component.d.ts +55 -55
  104. package/lib/ui/enum-radiogroup/enum-radiogroup.component.d.ts +17 -17
  105. package/lib/ui/file-input/file-input.component.d.ts +89 -89
  106. package/lib/ui/flyout/flyout.component.d.ts +32 -32
  107. package/lib/ui/generic-dialog/generic-dialog.component.d.ts +26 -26
  108. package/lib/ui/icon/icon.component.d.ts +42 -42
  109. package/lib/ui/icon/iconSize.enum.d.ts +15 -15
  110. package/lib/ui/image-slider/image-slider.component.d.ts +62 -62
  111. package/lib/ui/kms-accordion-item/kms-accordion-item.component.d.ts +22 -22
  112. package/lib/ui/loader/loader.component.d.ts +9 -9
  113. package/lib/ui/map/map.component.d.ts +69 -69
  114. package/lib/ui/radiobutton/radiobutton.component.d.ts +26 -26
  115. package/lib/ui/salutation-dropdown/salutation-dropdown.component.d.ts +17 -17
  116. package/lib/ui/salutation-radiogroup/salutation-radiogroup.component.d.ts +15 -15
  117. package/lib/ui/time-input/time-input.component.d.ts +22 -22
  118. package/lib/ui/tooltip/tooltip.component.d.ts +6 -6
  119. package/lib/ui/tooltip-icon/tooltip-icon.component.d.ts +13 -13
  120. package/lib/ui/yes-no-radiogroup/yes-no-radiogroup.component.d.ts +27 -27
  121. package/package.json +25 -12
  122. package/public-api.d.ts +45 -45
  123. package/src/lib/ui/back-to-top/back-to-top.component.scss +46 -46
  124. package/src/lib/ui/button-with-confirm-dialog/button-with-confirm-dialog.component.scss +2 -2
  125. package/src/lib/ui/checkbox/checkbox.component.scss +48 -48
  126. package/src/lib/ui/color-input/color-input.component.scss +38 -38
  127. package/src/lib/ui/file-input/file-input.component.scss +2 -2
  128. package/src/lib/ui/flyout/flyout.component.scss +34 -34
  129. package/src/lib/ui/generic-dialog/generic-dialog.component.scss +59 -59
  130. package/src/lib/ui/icon/icon.component.scss +148 -148
  131. package/src/lib/ui/image-slider/image-slider.component.scss +219 -219
  132. package/src/lib/ui/kms-accordion-item/kms-accordion-item.component.scss +95 -95
  133. package/src/lib/ui/radiobutton/radiobutton.component.scss +31 -31
  134. package/src/lib/ui/time-input/time-input.component.scss +10 -10
  135. package/src/lib/ui/tooltip/tooltip.component.scss +26 -26
  136. package/src/lib/ui/tooltip-icon/tooltip-icon.component.scss +2 -2
  137. package/src/styles/mixins.scss +8 -8
  138. package/src/styles/styles.scss +30 -30
  139. package/bundles/kms-ngx-ui-presentational.umd.js +0 -3628
  140. package/bundles/kms-ngx-ui-presentational.umd.js.map +0 -1
  141. package/esm2015/lib/directives/swipe.model.js +0 -5
  142. package/esm2015/lib/models/address.model.js +0 -6
  143. package/esm2015/lib/ui/back-to-top/back-to-top.component.js +0 -52
  144. package/esm2015/lib/ui/button-with-confirm-dialog/button-with-confirm-dialog.component.js +0 -62
  145. package/esm2015/lib/ui/checkbox/checkbox.component.js +0 -76
  146. package/esm2015/lib/ui/color-input/color-input.component.js +0 -81
  147. package/esm2015/lib/ui/dropdown-from-data/dropdown-from-data.component.js +0 -169
  148. package/esm2015/lib/ui/enum-radiogroup/enum-radiogroup.component.js +0 -57
  149. package/esm2015/lib/ui/file-input/file-input.component.js +0 -237
  150. package/esm2015/lib/ui/flyout/flyout.component.js +0 -124
  151. package/esm2015/lib/ui/generic-dialog/generic-dialog.component.js +0 -58
  152. package/esm2015/lib/ui/icon/icon.component.js +0 -52
  153. package/esm2015/lib/ui/image-slider/image-slider.component.js +0 -193
  154. package/esm2015/lib/ui/kms-accordion-item/kms-accordion-item.component.js +0 -44
  155. package/esm2015/lib/ui/loader/loader.component.js +0 -25
  156. package/esm2015/lib/ui/map/map.component.js +0 -120
  157. package/esm2015/lib/ui/radiobutton/radiobutton.component.js +0 -78
  158. package/esm2015/lib/ui/salutation-dropdown/salutation-dropdown.component.js +0 -59
  159. package/esm2015/lib/ui/salutation-radiogroup/salutation-radiogroup.component.js +0 -53
  160. package/esm2015/lib/ui/time-input/time-input.component.js +0 -88
  161. package/esm2015/lib/ui/tooltip/tooltip.component.js +0 -20
  162. package/esm2015/lib/ui/tooltip-icon/tooltip-icon.component.js +0 -39
  163. package/esm2015/lib/ui/yes-no-radiogroup/yes-no-radiogroup.component.js +0 -86
  164. package/fesm2015/kms-ngx-ui-presentational.js.map +0 -1
@@ -1,16 +1,16 @@
1
- import { Pipe } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class TypeofPipe {
4
- transform(value) {
5
- return typeof value;
6
- }
7
- }
8
- TypeofPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TypeofPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
9
- TypeofPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TypeofPipe, name: "kmsTypeOf" });
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TypeofPipe, decorators: [{
11
- type: Pipe,
12
- args: [{
13
- name: 'kmsTypeOf',
14
- }]
15
- }] });
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZW9mLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rbXMtbmd4LXVpLXByZXNlbnRhdGlvbmFsL3NyYy9saWIvcGlwZXMvdHlwZW9mLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBS3BELE1BQU0sT0FBTyxVQUFVO0lBQ25CLFNBQVMsQ0FBQyxLQUFVO1FBQ2hCLE9BQU8sT0FBTyxLQUFLLENBQUM7SUFDeEIsQ0FBQzs7d0dBSFEsVUFBVTtzR0FBVixVQUFVOzRGQUFWLFVBQVU7a0JBSHRCLElBQUk7bUJBQUM7b0JBQ0YsSUFBSSxFQUFFLFdBQVc7aUJBQ3BCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQFBpcGUoe1xyXG4gICAgbmFtZTogJ2ttc1R5cGVPZicsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUeXBlb2ZQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XHJcbiAgICB0cmFuc2Zvcm0odmFsdWU6IGFueSk6IGFueSB7XHJcbiAgICAgICAgcmV0dXJuIHR5cGVvZiB2YWx1ZTtcclxuICAgIH1cclxufVxyXG4iXX0=
1
+ import { Pipe } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class TypeofPipe {
4
+ transform(value) {
5
+ return typeof value;
6
+ }
7
+ }
8
+ TypeofPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TypeofPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
9
+ TypeofPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TypeofPipe, name: "kmsTypeOf" });
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TypeofPipe, decorators: [{
11
+ type: Pipe,
12
+ args: [{
13
+ name: 'kmsTypeOf',
14
+ }]
15
+ }] });
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZW9mLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rbXMtbmd4LXVpLXByZXNlbnRhdGlvbmFsL3NyYy9saWIvcGlwZXMvdHlwZW9mLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBS3BELE1BQU0sT0FBTyxVQUFVO0lBQ25CLFNBQVMsQ0FBQyxLQUFVO1FBQ2hCLE9BQU8sT0FBTyxLQUFLLENBQUM7SUFDeEIsQ0FBQzs7dUdBSFEsVUFBVTtxR0FBVixVQUFVOzJGQUFWLFVBQVU7a0JBSHRCLElBQUk7bUJBQUM7b0JBQ0YsSUFBSSxFQUFFLFdBQVc7aUJBQ3BCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AUGlwZSh7XG4gICAgbmFtZTogJ2ttc1R5cGVPZicsXG59KVxuZXhwb3J0IGNsYXNzIFR5cGVvZlBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgICB0cmFuc2Zvcm0odmFsdWU6IGFueSk6IGFueSB7XG4gICAgICAgIHJldHVybiB0eXBlb2YgdmFsdWU7XG4gICAgfVxufVxuIl19
@@ -1,216 +1,216 @@
1
- /**
2
- * @copyright KMS GmbH
3
- */
4
- import { isPlatformBrowser } from '@angular/common';
5
- import { Inject, Injectable, PLATFORM_ID } from '@angular/core';
6
- import { Subject } from 'rxjs';
7
- import * as i0 from "@angular/core";
8
- /**
9
- * Service to get viewport
10
- */
11
- export class ViewportService {
12
- constructor(platformId) {
13
- this.platformId = platformId;
14
- this.viewports = [
15
- {
16
- name: 'xs',
17
- low: 420,
18
- high: 990,
19
- },
20
- {
21
- name: 's',
22
- low: 991,
23
- high: 1024,
24
- },
25
- {
26
- name: 'm',
27
- low: 1025,
28
- high: 1200,
29
- },
30
- {
31
- name: 'l',
32
- low: 12001,
33
- high: 1400,
34
- },
35
- {
36
- name: 'xl',
37
- low: 1401,
38
- high: 1600,
39
- },
40
- {
41
- name: 'xxl',
42
- low: 1601,
43
- high: 1920,
44
- },
45
- {
46
- name: 'xxxl',
47
- low: 1921,
48
- high: 99999,
49
- },
50
- ];
51
- this.viewportChangedSubscriber = new Subject();
52
- this.viewportResizedSubscriber = new Subject();
53
- if (isPlatformBrowser(this.platformId)) {
54
- window.addEventListener('resize', this.documentSizeChanged.bind(this), { passive: true });
55
- }
56
- }
57
- /**
58
- * Get window height
59
- */
60
- getDocumentHeight() {
61
- return isPlatformBrowser(this.platformId) ? document.body.clientHeight : 1200;
62
- }
63
- /**
64
- * Get window width
65
- */
66
- getDocumentWidth() {
67
- return isPlatformBrowser(this.platformId) ? document.body.clientWidth : 1200;
68
- }
69
- /**
70
- * Get window height
71
- */
72
- getWindowHeight() {
73
- return isPlatformBrowser(this.platformId) ? window.innerHeight : 1200;
74
- }
75
- /**
76
- * Get window width
77
- */
78
- getWindowWidth() {
79
- return isPlatformBrowser(this.platformId) ? window.innerWidth : 1200;
80
- }
81
- /**
82
- * Returns the current viewport MQ as string
83
- * @returns string
84
- */
85
- getCurrentViewPort() {
86
- if (!this.currentViewport) {
87
- const currentWidth = isPlatformBrowser(this.platformId) ? document.body.clientWidth : 1200;
88
- this.currentViewport = this.convertWidthToMediaQuery(currentWidth);
89
- }
90
- return this.currentViewport;
91
- }
92
- /**
93
- * Provides mq´s as string
94
- */
95
- getViewportChangedObserver() {
96
- return this.viewportChangedSubscriber.asObservable();
97
- }
98
- /**
99
- * Provides the current window width as number
100
- */
101
- getViewportResizedObserver() {
102
- return this.viewportResizedSubscriber.asObservable();
103
- }
104
- scrollToElementId(el, alignCenter = false) {
105
- if (isPlatformBrowser(this.platformId)) {
106
- this.scrollToElement(document.querySelector('#' + el), alignCenter);
107
- }
108
- }
109
- /**
110
- * Helper function that scrolls to the given markup element.
111
- * @param el - nativeElement from markup
112
- * @param alignCenter - defines if the element needs to be centered on window
113
- */
114
- scrollToElement(el, alignCenter = false) {
115
- if (isPlatformBrowser(this.platformId)) {
116
- let extraScrollTop = 0;
117
- if (alignCenter) {
118
- extraScrollTop = (window.innerHeight - el.clientHeight) / 2;
119
- }
120
- /*
121
- const elementPos: DOMRect = el.getBoundingClientRect();
122
- const scrollTopPosition = elementPos.x - extraScrollTop;
123
- */
124
- //let offsetLeft = 0;
125
- let offsetTop = 0;
126
- let elTemp = el;
127
- while (elTemp) {
128
- //offsetLeft += elTemp.offsetLeft;
129
- offsetTop += elTemp.offsetTop;
130
- elTemp = elTemp.parentElement ? elTemp.parentElement : null;
131
- }
132
- window.scrollTo({ left: 0, top: offsetTop - extraScrollTop, behavior: 'smooth' });
133
- }
134
- }
135
- /**
136
- * Scroll to the top position
137
- * @param top - top position value
138
- */
139
- scrollTop(top) {
140
- if (isPlatformBrowser(this.platformId)) {
141
- window.scrollTo({ left: 0, top: top, behavior: 'smooth' });
142
- }
143
- }
144
- ngOnDestroy() {
145
- if (isPlatformBrowser(this.platformId)) {
146
- window.removeEventListener('resize', this.documentSizeChanged);
147
- }
148
- }
149
- /**
150
- * If viewport changed
151
- * @event
152
- */
153
- documentSizeChanged(event) {
154
- const currentWindowWidth = event.target.innerWidth;
155
- // inform who´s interested
156
- this.viewportResizedSubscriber.next(currentWindowWidth);
157
- if (currentWindowWidth > 0) {
158
- for (const mqs of this.viewports) {
159
- if (currentWindowWidth > mqs.high) {
160
- continue;
161
- }
162
- else if ((currentWindowWidth >= mqs.low || currentWindowWidth <= mqs.high) &&
163
- this.currentViewport !== mqs.name) {
164
- this.currentViewport = mqs.name;
165
- // inform who´s interested
166
- this.viewportChangedSubscriber.next(mqs.name);
167
- break;
168
- }
169
- else if (this.currentViewport === mqs.name) {
170
- break;
171
- }
172
- else {
173
- console.error('ERROR');
174
- }
175
- }
176
- }
177
- }
178
- /**
179
- * Get the Media Query for the given width
180
- * @param width Width to get the according MQ for
181
- */
182
- convertWidthToMediaQuery(width) {
183
- let currentViewport = '';
184
- for (const mqs of this.viewports) {
185
- if (width <= mqs.high && width >= mqs.low) {
186
- currentViewport = mqs.name;
187
- break;
188
- }
189
- }
190
- return currentViewport;
191
- }
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;
205
- }
206
- }
207
- }
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 });
209
- ViewportService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ViewportService });
210
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ViewportService, decorators: [{
211
- type: Injectable
212
- }], ctorParameters: function () { return [{ type: Object, decorators: [{
213
- type: Inject,
214
- args: [PLATFORM_ID]
215
- }] }]; } });
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"]}
1
+ /**
2
+ * @copyright KMS GmbH
3
+ */
4
+ import { isPlatformBrowser } from '@angular/common';
5
+ import { Inject, Injectable, PLATFORM_ID } from '@angular/core';
6
+ import { Subject } from 'rxjs';
7
+ import * as i0 from "@angular/core";
8
+ /**
9
+ * Service to get viewport
10
+ */
11
+ export class ViewportService {
12
+ constructor(platformId) {
13
+ this.platformId = platformId;
14
+ this.viewports = [
15
+ {
16
+ name: 'xs',
17
+ low: 420,
18
+ high: 990,
19
+ },
20
+ {
21
+ name: 's',
22
+ low: 991,
23
+ high: 1024,
24
+ },
25
+ {
26
+ name: 'm',
27
+ low: 1025,
28
+ high: 1200,
29
+ },
30
+ {
31
+ name: 'l',
32
+ low: 12001,
33
+ high: 1400,
34
+ },
35
+ {
36
+ name: 'xl',
37
+ low: 1401,
38
+ high: 1600,
39
+ },
40
+ {
41
+ name: 'xxl',
42
+ low: 1601,
43
+ high: 1920,
44
+ },
45
+ {
46
+ name: 'xxxl',
47
+ low: 1921,
48
+ high: 99999,
49
+ },
50
+ ];
51
+ this.viewportChangedSubscriber = new Subject();
52
+ this.viewportResizedSubscriber = new Subject();
53
+ if (isPlatformBrowser(this.platformId)) {
54
+ window.addEventListener('resize', this.documentSizeChanged.bind(this), { passive: true });
55
+ }
56
+ }
57
+ /**
58
+ * Get window height
59
+ */
60
+ getDocumentHeight() {
61
+ return isPlatformBrowser(this.platformId) ? document.body.clientHeight : 1200;
62
+ }
63
+ /**
64
+ * Get window width
65
+ */
66
+ getDocumentWidth() {
67
+ return isPlatformBrowser(this.platformId) ? document.body.clientWidth : 1200;
68
+ }
69
+ /**
70
+ * Get window height
71
+ */
72
+ getWindowHeight() {
73
+ return isPlatformBrowser(this.platformId) ? window.innerHeight : 1200;
74
+ }
75
+ /**
76
+ * Get window width
77
+ */
78
+ getWindowWidth() {
79
+ return isPlatformBrowser(this.platformId) ? window.innerWidth : 1200;
80
+ }
81
+ /**
82
+ * Returns the current viewport MQ as string
83
+ * @returns string
84
+ */
85
+ getCurrentViewPort() {
86
+ if (!this.currentViewport) {
87
+ const currentWidth = isPlatformBrowser(this.platformId) ? document.body.clientWidth : 1200;
88
+ this.currentViewport = this.convertWidthToMediaQuery(currentWidth);
89
+ }
90
+ return this.currentViewport;
91
+ }
92
+ /**
93
+ * Provides mq´s as string
94
+ */
95
+ getViewportChangedObserver() {
96
+ return this.viewportChangedSubscriber.asObservable();
97
+ }
98
+ /**
99
+ * Provides the current window width as number
100
+ */
101
+ getViewportResizedObserver() {
102
+ return this.viewportResizedSubscriber.asObservable();
103
+ }
104
+ scrollToElementId(el, alignCenter = false) {
105
+ if (isPlatformBrowser(this.platformId)) {
106
+ this.scrollToElement(document.querySelector('#' + el), alignCenter);
107
+ }
108
+ }
109
+ /**
110
+ * Helper function that scrolls to the given markup element.
111
+ * @param el - nativeElement from markup
112
+ * @param alignCenter - defines if the element needs to be centered on window
113
+ */
114
+ scrollToElement(el, alignCenter = false) {
115
+ if (isPlatformBrowser(this.platformId)) {
116
+ let extraScrollTop = 0;
117
+ if (alignCenter) {
118
+ extraScrollTop = (window.innerHeight - el.clientHeight) / 2;
119
+ }
120
+ /*
121
+ const elementPos: DOMRect = el.getBoundingClientRect();
122
+ const scrollTopPosition = elementPos.x - extraScrollTop;
123
+ */
124
+ //let offsetLeft = 0;
125
+ let offsetTop = 0;
126
+ let elTemp = el;
127
+ while (elTemp) {
128
+ //offsetLeft += elTemp.offsetLeft;
129
+ offsetTop += elTemp.offsetTop;
130
+ elTemp = elTemp.parentElement ? elTemp.parentElement : null;
131
+ }
132
+ window.scrollTo({ left: 0, top: offsetTop - extraScrollTop, behavior: 'smooth' });
133
+ }
134
+ }
135
+ /**
136
+ * Scroll to the top position
137
+ * @param top - top position value
138
+ */
139
+ scrollTop(top) {
140
+ if (isPlatformBrowser(this.platformId)) {
141
+ window.scrollTo({ left: 0, top: top, behavior: 'smooth' });
142
+ }
143
+ }
144
+ ngOnDestroy() {
145
+ if (isPlatformBrowser(this.platformId)) {
146
+ window.removeEventListener('resize', this.documentSizeChanged);
147
+ }
148
+ }
149
+ /**
150
+ * If viewport changed
151
+ * @event
152
+ */
153
+ documentSizeChanged(event) {
154
+ const currentWindowWidth = event.target.innerWidth;
155
+ // inform who´s interested
156
+ this.viewportResizedSubscriber.next(currentWindowWidth);
157
+ if (currentWindowWidth > 0) {
158
+ for (const mqs of this.viewports) {
159
+ if (currentWindowWidth > mqs.high) {
160
+ continue;
161
+ }
162
+ else if ((currentWindowWidth >= mqs.low || currentWindowWidth <= mqs.high) &&
163
+ this.currentViewport !== mqs.name) {
164
+ this.currentViewport = mqs.name;
165
+ // inform who´s interested
166
+ this.viewportChangedSubscriber.next(mqs.name);
167
+ break;
168
+ }
169
+ else if (this.currentViewport === mqs.name) {
170
+ break;
171
+ }
172
+ else {
173
+ console.error('ERROR');
174
+ }
175
+ }
176
+ }
177
+ }
178
+ /**
179
+ * Get the Media Query for the given width
180
+ * @param width Width to get the according MQ for
181
+ */
182
+ convertWidthToMediaQuery(width) {
183
+ let currentViewport = '';
184
+ for (const mqs of this.viewports) {
185
+ if (width <= mqs.high && width >= mqs.low) {
186
+ currentViewport = mqs.name;
187
+ break;
188
+ }
189
+ }
190
+ return currentViewport;
191
+ }
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;
205
+ }
206
+ }
207
+ }
208
+ ViewportService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ViewportService, deps: [{ token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Injectable });
209
+ ViewportService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ViewportService });
210
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ViewportService, decorators: [{
211
+ type: Injectable
212
+ }], ctorParameters: function () { return [{ type: Object, decorators: [{
213
+ type: Inject,
214
+ args: [PLATFORM_ID]
215
+ }] }]; } });
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":["/**\n * @copyright KMS GmbH\n */\n\nimport { isPlatformBrowser } from '@angular/common';\nimport { Inject, Injectable, OnDestroy, PLATFORM_ID } from '@angular/core';\nimport { Observable, Subject } from 'rxjs';\nimport { NullAble } from '../models';\n\n// needed for scrollToElement functionality\n\ndeclare const window: any;\n\ndeclare const document: any;\n\n/**\n * Service to get viewport\n */\n@Injectable()\nexport class ViewportService implements OnDestroy {\n    public readonly viewports = [\n        {\n            name: 'xs',\n            low: 420,\n            high: 990,\n        },\n        {\n            name: 's',\n            low: 991,\n            high: 1024,\n        },\n        {\n            name: 'm',\n            low: 1025,\n            high: 1200,\n        },\n        {\n            name: 'l',\n            low: 12001,\n            high: 1400,\n        },\n        {\n            name: 'xl',\n            low: 1401,\n            high: 1600,\n        },\n        {\n            name: 'xxl',\n            low: 1601,\n            high: 1920,\n        },\n        {\n            name: 'xxxl',\n            low: 1921,\n            high: 99999,\n        },\n    ];\n\n    private viewportChangedSubscriber: Subject<string> = new Subject<string>();\n    private viewportResizedSubscriber: Subject<number> = new Subject<number>();\n    private currentViewport!: string;\n\n    constructor(@Inject(PLATFORM_ID) private platformId: Object) {\n        if (isPlatformBrowser(this.platformId)) {\n            window.addEventListener('resize', this.documentSizeChanged.bind(this), { passive: true });\n        }\n    }\n\n    /**\n     * Get window height\n     */\n    public getDocumentHeight(): number {\n        return isPlatformBrowser(this.platformId) ? document.body.clientHeight : 1200;\n    }\n\n    /**\n     * Get window width\n     */\n    public getDocumentWidth(): number {\n        return isPlatformBrowser(this.platformId) ? document.body.clientWidth : 1200;\n    }\n\n    /**\n     * Get window height\n     */\n    public getWindowHeight(): number {\n        return isPlatformBrowser(this.platformId) ? window.innerHeight : 1200;\n    }\n\n    /**\n     * Get window width\n     */\n    public getWindowWidth(): number {\n        return isPlatformBrowser(this.platformId) ? window.innerWidth : 1200;\n    }\n\n    /**\n     * Returns the current viewport MQ as string\n     * @returns string\n     */\n    getCurrentViewPort(): string {\n        if (!this.currentViewport) {\n            const currentWidth: number = isPlatformBrowser(this.platformId) ? document.body.clientWidth : 1200;\n            this.currentViewport = this.convertWidthToMediaQuery(currentWidth);\n        }\n\n        return this.currentViewport;\n    }\n\n    /**\n     * Provides mq´s as string\n     */\n    public getViewportChangedObserver(): Observable<string> {\n        return this.viewportChangedSubscriber.asObservable();\n    }\n\n    /**\n     * Provides the current window width as number\n     */\n    public getViewportResizedObserver(): Observable<number> {\n        return this.viewportResizedSubscriber.asObservable();\n    }\n\n    public scrollToElementId(el: string, alignCenter = false) {\n        if (isPlatformBrowser(this.platformId)) {\n            this.scrollToElement(document.querySelector('#' + el), alignCenter);\n        }\n    }\n\n    /**\n     * Helper function that scrolls to the given markup element.\n     * @param el - nativeElement from markup\n     * @param alignCenter - defines if the element needs to be centered on window\n     */\n\n    public scrollToElement(el: HTMLElement, alignCenter = false) {\n        if (isPlatformBrowser(this.platformId)) {\n            let extraScrollTop = 0;\n\n            if (alignCenter) {\n                extraScrollTop = (window.innerHeight - el.clientHeight) / 2;\n            }\n\n            /*\n            const elementPos: DOMRect = el.getBoundingClientRect();\n            const scrollTopPosition = elementPos.x - extraScrollTop;\n            */\n\n            //let offsetLeft = 0;\n            let offsetTop = 0;\n\n            let elTemp: NullAble<HTMLElement> = el;\n\n            while (elTemp) {\n                //offsetLeft += elTemp.offsetLeft;\n                offsetTop += elTemp.offsetTop;\n                elTemp = elTemp.parentElement ? elTemp.parentElement : null;\n            }\n\n            window.scrollTo({ left: 0, top: offsetTop - extraScrollTop, behavior: 'smooth' });\n        }\n    }\n\n    /**\n     * Scroll to the top position\n     * @param top - top position value\n     */\n    public scrollTop(top: number) {\n        if (isPlatformBrowser(this.platformId)) {\n            window.scrollTo({ left: 0, top: top, behavior: 'smooth' });\n        }\n    }\n\n    ngOnDestroy() {\n        if (isPlatformBrowser(this.platformId)) {\n            window.removeEventListener('resize', this.documentSizeChanged);\n        }\n    }\n\n    /**\n     * If viewport changed\n     * @event\n     */\n\n    private documentSizeChanged(event: any) {\n        const currentWindowWidth: number = event.target.innerWidth;\n        // inform who´s interested\n        this.viewportResizedSubscriber.next(currentWindowWidth);\n\n        if (currentWindowWidth > 0) {\n            for (const mqs of this.viewports) {\n                if (currentWindowWidth > mqs.high) {\n                    continue;\n                } else if (\n                    (currentWindowWidth >= mqs.low || currentWindowWidth <= mqs.high) &&\n                    this.currentViewport !== mqs.name\n                ) {\n                    this.currentViewport = mqs.name;\n                    // inform who´s interested\n                    this.viewportChangedSubscriber.next(mqs.name);\n                    break;\n                } else if (this.currentViewport === mqs.name) {\n                    break;\n                } else {\n                    console.error('ERROR');\n                }\n            }\n        }\n    }\n\n    /**\n     * Get the Media Query for the given width\n     * @param width Width to get the according MQ for\n     */\n    private convertWidthToMediaQuery(width: number) {\n        let currentViewport = '';\n\n        for (const mqs of this.viewports) {\n            if (width <= mqs.high && width >= mqs.low) {\n                currentViewport = mqs.name;\n                break;\n            }\n        }\n\n        return currentViewport;\n    }\n\n    isPortrait() {\n        if (isPlatformBrowser(this.platformId)) return window.innerHeight > window.innerWidth;\n        else return;\n    }\n\n    isLandscape() {\n        if (isPlatformBrowser(this.platformId)) {\n            const isLandscape = window.orientation === 90 || window.orientation === -90;\n            return isLandscape;\n        } else {\n            return;\n        }\n    }\n}\n"]}
@@ -0,0 +1,49 @@
1
+ /**
2
+ * @copyright KMS GmbH
3
+ */
4
+ import { Component, HostListener, Inject, PLATFORM_ID } from '@angular/core';
5
+ import { isPlatformBrowser } from '@angular/common';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../icon/icon.component";
8
+ import * as i2 from "@angular/common";
9
+ export class BackToTopComponent {
10
+ constructor(platformId) {
11
+ this.platformId = platformId;
12
+ }
13
+ onWindowScroll() {
14
+ if (isPlatformBrowser(this.platformId)) {
15
+ if (window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop > 100) {
16
+ this.windowScrolled = true;
17
+ }
18
+ else if ((this.windowScrolled && window.pageYOffset) ||
19
+ document.documentElement.scrollTop ||
20
+ document.body.scrollTop < 10) {
21
+ this.windowScrolled = false;
22
+ }
23
+ }
24
+ }
25
+ scrollToTop() {
26
+ if (isPlatformBrowser(this.platformId)) {
27
+ (function smoothscroll() {
28
+ const currentScroll = document.documentElement.scrollTop || document.body.scrollTop;
29
+ if (currentScroll > 0) {
30
+ window.requestAnimationFrame(smoothscroll);
31
+ window.scrollTo(0, currentScroll - currentScroll / 8);
32
+ }
33
+ })();
34
+ }
35
+ }
36
+ }
37
+ BackToTopComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: BackToTopComponent, deps: [{ token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component });
38
+ BackToTopComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: BackToTopComponent, selector: "kms-back-to-top", host: { listeners: { "window:scroll": "onWindowScroll()" } }, ngImport: i0, template: "<div class=\"scrollToTop\"\n [ngClass]=\"{'show': windowScrolled}\"\n (click)=\"scrollToTop()\">\n <div class=\"scrollToTop-inner\">\n <kms-icon icon=\"floating_button_clear\" iconClass=\"color-white\"></kms-icon>\n </div>\n</div>", components: [{ type: i1.IconComponent, selector: "kms-icon", inputs: ["icon", "iconClass", "iconStyle", "iconSize", "dontUseSprite"] }], directives: [{ type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
39
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: BackToTopComponent, decorators: [{
40
+ type: Component,
41
+ args: [{ selector: 'kms-back-to-top', template: "<div class=\"scrollToTop\"\n [ngClass]=\"{'show': windowScrolled}\"\n (click)=\"scrollToTop()\">\n <div class=\"scrollToTop-inner\">\n <kms-icon icon=\"floating_button_clear\" iconClass=\"color-white\"></kms-icon>\n </div>\n</div>" }]
42
+ }], ctorParameters: function () { return [{ type: Object, decorators: [{
43
+ type: Inject,
44
+ args: [PLATFORM_ID]
45
+ }] }]; }, propDecorators: { onWindowScroll: [{
46
+ type: HostListener,
47
+ args: ['window:scroll', []]
48
+ }] } });
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFjay10by10b3AuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva21zLW5neC11aS1wcmVzZW50YXRpb25hbC9zcmMvbGliL3VpL2JhY2stdG8tdG9wL2JhY2stdG8tdG9wLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWwvc3JjL2xpYi91aS9iYWNrLXRvLXRvcC9iYWNrLXRvLXRvcC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDN0UsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUJBQWlCLENBQUM7Ozs7QUFNcEQsTUFBTSxPQUFPLGtCQUFrQjtJQUczQixZQUF3QyxVQUFrQjtRQUFsQixlQUFVLEdBQVYsVUFBVSxDQUFRO0lBQUcsQ0FBQztJQUc5RCxjQUFjO1FBQ1YsSUFBSSxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUU7WUFDcEMsSUFBSSxNQUFNLENBQUMsV0FBVyxJQUFJLFFBQVEsQ0FBQyxlQUFlLENBQUMsU0FBUyxJQUFJLFFBQVEsQ0FBQyxJQUFJLENBQUMsU0FBUyxHQUFHLEdBQUcsRUFBRTtnQkFDM0YsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUM7YUFDOUI7aUJBQU0sSUFDSCxDQUFDLElBQUksQ0FBQyxjQUFjLElBQUksTUFBTSxDQUFDLFdBQVcsQ0FBQztnQkFDM0MsUUFBUSxDQUFDLGVBQWUsQ0FBQyxTQUFTO2dCQUNsQyxRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFFLEVBQzlCO2dCQUNFLElBQUksQ0FBQyxjQUFjLEdBQUcsS0FBSyxDQUFDO2FBQy9CO1NBQ0o7SUFDTCxDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksaUJBQWlCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxFQUFFO1lBQ3BDLENBQUMsU0FBUyxZQUFZO2dCQUNsQixNQUFNLGFBQWEsR0FBRyxRQUFRLENBQUMsZUFBZSxDQUFDLFNBQVMsSUFBSSxRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQztnQkFDcEYsSUFBSSxhQUFhLEdBQUcsQ0FBQyxFQUFFO29CQUNuQixNQUFNLENBQUMscUJBQXFCLENBQUMsWUFBWSxDQUFDLENBQUM7b0JBQzNDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxFQUFFLGFBQWEsR0FBRyxhQUFhLEdBQUcsQ0FBQyxDQUFDLENBQUM7aUJBQ3pEO1lBQ0wsQ0FBQyxDQUFDLEVBQUUsQ0FBQztTQUNSO0lBQ0wsQ0FBQzs7K0dBOUJRLGtCQUFrQixrQkFHUCxXQUFXO21HQUh0QixrQkFBa0IscUhDWC9CLHVRQU1NOzJGREtPLGtCQUFrQjtrQkFKOUIsU0FBUzsrQkFDSSxpQkFBaUI7MERBTXlCLE1BQU07MEJBQTdDLE1BQU07MkJBQUMsV0FBVzs0Q0FHL0IsY0FBYztzQkFEYixZQUFZO3VCQUFDLGVBQWUsRUFBRSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAY29weXJpZ2h0IEtNUyBHbWJIXG4gKi9cblxuaW1wb3J0IHsgQ29tcG9uZW50LCBIb3N0TGlzdGVuZXIsIEluamVjdCwgUExBVEZPUk1fSUQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGlzUGxhdGZvcm1Ccm93c2VyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdrbXMtYmFjay10by10b3AnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9iYWNrLXRvLXRvcC5jb21wb25lbnQuaHRtbCcsXG59KVxuZXhwb3J0IGNsYXNzIEJhY2tUb1RvcENvbXBvbmVudCB7XG4gICAgd2luZG93U2Nyb2xsZWQ/OiBib29sZWFuO1xuXG4gICAgY29uc3RydWN0b3IoQEluamVjdChQTEFURk9STV9JRCkgcHVibGljIHBsYXRmb3JtSWQ6IE9iamVjdCkge31cblxuICAgIEBIb3N0TGlzdGVuZXIoJ3dpbmRvdzpzY3JvbGwnLCBbXSlcbiAgICBvbldpbmRvd1Njcm9sbCgpIHtcbiAgICAgICAgaWYgKGlzUGxhdGZvcm1Ccm93c2VyKHRoaXMucGxhdGZvcm1JZCkpIHtcbiAgICAgICAgICAgIGlmICh3aW5kb3cucGFnZVlPZmZzZXQgfHwgZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50LnNjcm9sbFRvcCB8fCBkb2N1bWVudC5ib2R5LnNjcm9sbFRvcCA+IDEwMCkge1xuICAgICAgICAgICAgICAgIHRoaXMud2luZG93U2Nyb2xsZWQgPSB0cnVlO1xuICAgICAgICAgICAgfSBlbHNlIGlmIChcbiAgICAgICAgICAgICAgICAodGhpcy53aW5kb3dTY3JvbGxlZCAmJiB3aW5kb3cucGFnZVlPZmZzZXQpIHx8XG4gICAgICAgICAgICAgICAgZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50LnNjcm9sbFRvcCB8fFxuICAgICAgICAgICAgICAgIGRvY3VtZW50LmJvZHkuc2Nyb2xsVG9wIDwgMTBcbiAgICAgICAgICAgICkge1xuICAgICAgICAgICAgICAgIHRoaXMud2luZG93U2Nyb2xsZWQgPSBmYWxzZTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH1cblxuICAgIHNjcm9sbFRvVG9wKCkge1xuICAgICAgICBpZiAoaXNQbGF0Zm9ybUJyb3dzZXIodGhpcy5wbGF0Zm9ybUlkKSkge1xuICAgICAgICAgICAgKGZ1bmN0aW9uIHNtb290aHNjcm9sbCgpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBjdXJyZW50U2Nyb2xsID0gZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50LnNjcm9sbFRvcCB8fCBkb2N1bWVudC5ib2R5LnNjcm9sbFRvcDtcbiAgICAgICAgICAgICAgICBpZiAoY3VycmVudFNjcm9sbCA+IDApIHtcbiAgICAgICAgICAgICAgICAgICAgd2luZG93LnJlcXVlc3RBbmltYXRpb25GcmFtZShzbW9vdGhzY3JvbGwpO1xuICAgICAgICAgICAgICAgICAgICB3aW5kb3cuc2Nyb2xsVG8oMCwgY3VycmVudFNjcm9sbCAtIGN1cnJlbnRTY3JvbGwgLyA4KTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9KSgpO1xuICAgICAgICB9XG4gICAgfVxufVxuIiwiPGRpdiBjbGFzcz1cInNjcm9sbFRvVG9wXCJcbiAgICBbbmdDbGFzc109XCJ7J3Nob3cnOiB3aW5kb3dTY3JvbGxlZH1cIlxuICAgIChjbGljayk9XCJzY3JvbGxUb1RvcCgpXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJzY3JvbGxUb1RvcC1pbm5lclwiPlxuICAgICAgICAgICAgPGttcy1pY29uIGljb249XCJmbG9hdGluZ19idXR0b25fY2xlYXJcIiBpY29uQ2xhc3M9XCJjb2xvci13aGl0ZVwiPjwva21zLWljb24+XG4gICAgICAgIDwvZGl2PlxuPC9kaXY+Il19
@@ -1,6 +1,6 @@
1
- export var ButtonResponseType;
2
- (function (ButtonResponseType) {
3
- ButtonResponseType["primary"] = "primary";
4
- ButtonResponseType["secondary"] = "secondary";
5
- })(ButtonResponseType || (ButtonResponseType = {}));
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLXJlc3BvbnNlLXR5cGVzLmVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rbXMtbmd4LXVpLXByZXNlbnRhdGlvbmFsL3NyYy9saWIvdWkvYnV0dG9uLXdpdGgtY29uZmlybS1kaWFsb2cvYnV0dG9uLXJlc3BvbnNlLXR5cGVzLmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksa0JBR1g7QUFIRCxXQUFZLGtCQUFrQjtJQUMxQix5Q0FBbUIsQ0FBQTtJQUNuQiw2Q0FBdUIsQ0FBQTtBQUMzQixDQUFDLEVBSFcsa0JBQWtCLEtBQWxCLGtCQUFrQixRQUc3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIEJ1dHRvblJlc3BvbnNlVHlwZXtcclxuICAgIHByaW1hcnkgPSAncHJpbWFyeScsXHJcbiAgICBzZWNvbmRhcnkgPSAnc2Vjb25kYXJ5J1xyXG59Il19
1
+ export var ButtonResponseType;
2
+ (function (ButtonResponseType) {
3
+ ButtonResponseType["primary"] = "primary";
4
+ ButtonResponseType["secondary"] = "secondary";
5
+ })(ButtonResponseType || (ButtonResponseType = {}));
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLXJlc3BvbnNlLXR5cGVzLmVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rbXMtbmd4LXVpLXByZXNlbnRhdGlvbmFsL3NyYy9saWIvdWkvYnV0dG9uLXdpdGgtY29uZmlybS1kaWFsb2cvYnV0dG9uLXJlc3BvbnNlLXR5cGVzLmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksa0JBR1g7QUFIRCxXQUFZLGtCQUFrQjtJQUMxQix5Q0FBbUIsQ0FBQTtJQUNuQiw2Q0FBdUIsQ0FBQTtBQUMzQixDQUFDLEVBSFcsa0JBQWtCLEtBQWxCLGtCQUFrQixRQUc3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIEJ1dHRvblJlc3BvbnNlVHlwZXtcbiAgICBwcmltYXJ5ID0gJ3ByaW1hcnknLFxuICAgIHNlY29uZGFyeSA9ICdzZWNvbmRhcnknXG59Il19