@kms-ngx-ui/presentational 16.2.0 → 16.3.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.
- package/esm2022/lib/directives/directives.module.mjs +7 -12
- package/esm2022/lib/directives/mousewheel.directive.mjs +4 -4
- package/esm2022/lib/directives/sum-of-height.directive.mjs +4 -4
- package/esm2022/lib/directives/swipe.directive.mjs +4 -4
- package/esm2022/lib/directives/tooltip.directive.mjs +4 -4
- package/esm2022/lib/kms-ngx-ui-presentational.component.mjs +4 -4
- package/esm2022/lib/kms-ngx-ui-presentational.module.mjs +16 -20
- package/esm2022/lib/kms-ngx-ui-presentational.service.mjs +4 -4
- package/esm2022/lib/parent-components/actions.component.mjs +4 -4
- package/esm2022/lib/parent-components/form-control.component.mjs +5 -5
- package/esm2022/lib/parent-components/form.component.mjs +8 -14
- package/esm2022/lib/pipes/custom-pipes.module.mjs +5 -5
- package/esm2022/lib/pipes/decode-uri.pipe.mjs +4 -4
- package/esm2022/lib/pipes/encode-uri.pipe.mjs +4 -4
- package/esm2022/lib/pipes/integer-currency.pipe.mjs +4 -4
- package/esm2022/lib/pipes/safe-html.pipe.mjs +4 -4
- package/esm2022/lib/pipes/safe-resource-url.pipe.mjs +4 -4
- package/esm2022/lib/pipes/safe-style.pipe.mjs +4 -4
- package/esm2022/lib/pipes/safe-url.pipe.mjs +4 -4
- package/esm2022/lib/pipes/to-number.pipe.mjs +4 -4
- package/esm2022/lib/pipes/trim.pipe.mjs +4 -4
- package/esm2022/lib/pipes/typeof.pipe.mjs +4 -4
- package/esm2022/lib/services/viewport.service.mjs +75 -214
- package/esm2022/lib/ui/back-to-top/back-to-top.component.mjs +4 -4
- package/esm2022/lib/ui/button-with-confirm-dialog/button-with-confirm-dialog.component.mjs +5 -5
- package/esm2022/lib/ui/checkbox/checkbox.component.mjs +6 -6
- package/esm2022/lib/ui/color-input/color-input.component.mjs +7 -7
- package/esm2022/lib/ui/dropdown-from-data/dropdown-from-data.component.mjs +9 -14
- package/esm2022/lib/ui/enum-radiogroup/enum-radiogroup.component.mjs +6 -6
- package/esm2022/lib/ui/file-input/file-input.component.mjs +12 -12
- package/esm2022/lib/ui/flyout/flyout.component.mjs +7 -8
- package/esm2022/lib/ui/generic-dialog/generic-dialog.component.mjs +6 -5
- package/esm2022/lib/ui/icon/icon.component.mjs +5 -8
- package/esm2022/lib/ui/icon/iconSize.enum.mjs +1 -12
- package/esm2022/lib/ui/image-slider/image-slider.component.mjs +14 -14
- package/esm2022/lib/ui/kms-accordion-item/kms-accordion-item.component.mjs +11 -11
- package/esm2022/lib/ui/loader/loader.component.mjs +5 -5
- package/esm2022/lib/ui/map/map.component.mjs +5 -5
- package/esm2022/lib/ui/radiobutton/radiobutton.component.mjs +7 -11
- package/esm2022/lib/ui/salutation-dropdown/salutation-dropdown.component.mjs +8 -8
- package/esm2022/lib/ui/salutation-radiogroup/salutation-radiogroup.component.mjs +6 -6
- package/esm2022/lib/ui/time-input/time-input.component.mjs +4 -4
- package/esm2022/lib/ui/tooltip/tooltip.component.mjs +4 -4
- package/esm2022/lib/ui/tooltip-icon/tooltip-icon.component.mjs +8 -9
- package/esm2022/lib/ui/yes-no-radiogroup/yes-no-radiogroup.component.mjs +6 -6
- package/esm2022/public-api.mjs +1 -2
- package/fesm2022/kms-ngx-ui-presentational.mjs +344 -536
- package/fesm2022/kms-ngx-ui-presentational.mjs.map +1 -1
- package/lib/directives/directives.module.d.ts +2 -4
- package/lib/kms-ngx-ui-presentational.module.d.ts +10 -10
- package/lib/services/viewport.service.d.ts +11 -86
- package/lib/ui/dropdown-from-data/dropdown-from-data.component.d.ts +2 -4
- package/lib/ui/file-input/file-input.component.d.ts +2 -2
- package/lib/ui/icon/icon.component.d.ts +1 -7
- package/lib/ui/icon/iconSize.enum.d.ts +0 -10
- package/lib/ui/image-slider/image-slider.component.d.ts +2 -2
- package/lib/ui/kms-accordion-item/kms-accordion-item.component.d.ts +2 -2
- package/lib/ui/radiobutton/radiobutton.component.d.ts +1 -2
- package/lib/ui/tooltip-icon/tooltip-icon.component.d.ts +2 -2
- package/package.json +8 -8
- package/public-api.d.ts +0 -1
- package/src/lib/ui/back-to-top/back-to-top.component.scss +3 -2
- package/src/lib/ui/icon/icon.component.scss +36 -2
- package/src/lib/ui/image-slider/image-slider.component.scss +202 -209
- package/src/styles/styles.scss +0 -1
- package/esm2022/lib/directives/size.directive.mjs +0 -21
- package/lib/directives/size.directive.d.ts +0 -10
- package/src/styles/animations.scss +0 -47
|
@@ -1,167 +1,94 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* @copyright KMS GmbH
|
|
3
3
|
*/
|
|
4
|
-
import {
|
|
4
|
+
import { 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";
|
|
8
|
-
export class WindowDimensions {
|
|
9
|
-
constructor(data) {
|
|
10
|
-
Object.assign(this, data);
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
export class SimpleBreakpoint {
|
|
14
|
-
constructor(data) {
|
|
15
|
-
Object.assign(this, data);
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
export class Breakpoint {
|
|
19
|
-
constructor(data) {
|
|
20
|
-
Object.assign(this, data);
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
8
|
/**
|
|
24
9
|
* Service to get viewport
|
|
25
10
|
*/
|
|
26
11
|
export class ViewportService {
|
|
27
|
-
constructor(platformId
|
|
12
|
+
constructor(platformId) {
|
|
28
13
|
this.platformId = platformId;
|
|
29
|
-
this.
|
|
30
|
-
this.simpleBreakpoints = [
|
|
31
|
-
{ Number: 0, Name: 'mobile', MaximumPixels: 768 },
|
|
32
|
-
{ Number: 1, Name: 'tablet', MaximumPixels: 1024 },
|
|
33
|
-
{ Number: 2, Name: 'desktop', MaximumPixels: 1600 },
|
|
34
|
-
{ Number: 3, Name: 'high', MaximumPixels: 2500 },
|
|
35
|
-
];
|
|
36
|
-
this.breakpoints = [
|
|
14
|
+
this.viewports = [
|
|
37
15
|
{
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
High: 990,
|
|
16
|
+
name: 'xs',
|
|
17
|
+
low: 420,
|
|
18
|
+
high: 990,
|
|
42
19
|
},
|
|
43
20
|
{
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
High: 1024,
|
|
21
|
+
name: 's',
|
|
22
|
+
low: 991,
|
|
23
|
+
high: 1024,
|
|
48
24
|
},
|
|
49
25
|
{
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
High: 1200,
|
|
26
|
+
name: 'm',
|
|
27
|
+
low: 1025,
|
|
28
|
+
high: 1200,
|
|
54
29
|
},
|
|
55
30
|
{
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
High: 1400,
|
|
31
|
+
name: 'l',
|
|
32
|
+
low: 12001,
|
|
33
|
+
high: 1400,
|
|
60
34
|
},
|
|
61
35
|
{
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
High: 1600,
|
|
36
|
+
name: 'xl',
|
|
37
|
+
low: 1401,
|
|
38
|
+
high: 1600,
|
|
66
39
|
},
|
|
67
40
|
{
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
High: 1920,
|
|
41
|
+
name: 'xxl',
|
|
42
|
+
low: 1601,
|
|
43
|
+
high: 1920,
|
|
72
44
|
},
|
|
73
45
|
{
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
High: 99999,
|
|
46
|
+
name: 'xxxl',
|
|
47
|
+
low: 1921,
|
|
48
|
+
high: 99999,
|
|
78
49
|
},
|
|
79
50
|
];
|
|
80
51
|
this.viewportChangedSubscriber = new Subject();
|
|
81
52
|
this.viewportResizedSubscriber = new Subject();
|
|
82
|
-
this.isBrowser = false;
|
|
83
53
|
if (isPlatformBrowser(this.platformId)) {
|
|
84
|
-
window.addEventListener('resize', this.documentSizeChanged.bind(this), {
|
|
85
|
-
passive: true,
|
|
86
|
-
});
|
|
87
|
-
this.isBrowser = true;
|
|
54
|
+
window.addEventListener('resize', this.documentSizeChanged.bind(this), { passive: true });
|
|
88
55
|
}
|
|
89
56
|
}
|
|
90
57
|
/**
|
|
91
|
-
* Get
|
|
58
|
+
* Get window height
|
|
92
59
|
*/
|
|
93
60
|
getDocumentHeight() {
|
|
94
|
-
return this.
|
|
61
|
+
return isPlatformBrowser(this.platformId) ? document.body.clientHeight : 1200;
|
|
95
62
|
}
|
|
96
63
|
/**
|
|
97
|
-
* Get
|
|
64
|
+
* Get window width
|
|
98
65
|
*/
|
|
99
66
|
getDocumentWidth() {
|
|
100
|
-
return this.
|
|
67
|
+
return isPlatformBrowser(this.platformId) ? document.body.clientWidth : 1200;
|
|
101
68
|
}
|
|
102
69
|
/**
|
|
103
70
|
* Get window height
|
|
104
71
|
*/
|
|
105
72
|
getWindowHeight() {
|
|
106
|
-
return this.
|
|
73
|
+
return isPlatformBrowser(this.platformId) ? window.innerHeight : 1200;
|
|
107
74
|
}
|
|
108
75
|
/**
|
|
109
76
|
* Get window width
|
|
110
77
|
*/
|
|
111
78
|
getWindowWidth() {
|
|
112
|
-
return this.
|
|
79
|
+
return isPlatformBrowser(this.platformId) ? window.innerWidth : 1200;
|
|
113
80
|
}
|
|
114
81
|
/**
|
|
115
82
|
* Returns the current viewport MQ as string
|
|
116
83
|
* @returns string
|
|
117
84
|
*/
|
|
118
85
|
getCurrentViewPort() {
|
|
119
|
-
|
|
120
|
-
? document.body.clientWidth
|
|
121
|
-
|
|
122
|
-
|
|
86
|
+
if (!this.currentViewport) {
|
|
87
|
+
const currentWidth = isPlatformBrowser(this.platformId) ? document.body.clientWidth : 1200;
|
|
88
|
+
this.currentViewport = this.convertWidthToMediaQuery(currentWidth);
|
|
89
|
+
}
|
|
123
90
|
return this.currentViewport;
|
|
124
91
|
}
|
|
125
|
-
/**
|
|
126
|
-
* Returns the current viewport MQ as object with all informations
|
|
127
|
-
* @returns string
|
|
128
|
-
*/
|
|
129
|
-
getCurrentViewPortObject() {
|
|
130
|
-
const currentWidth = this.isBrowser
|
|
131
|
-
? document.body.clientWidth
|
|
132
|
-
: 1200;
|
|
133
|
-
this.currentViewportObject = this.convertWidthToMediaQuery(currentWidth);
|
|
134
|
-
return this.currentViewportObject;
|
|
135
|
-
}
|
|
136
|
-
/**
|
|
137
|
-
* Returns the current viewport as number
|
|
138
|
-
* @deprecated use getCurrentViewPortDimensions instead
|
|
139
|
-
* @returns string
|
|
140
|
-
*/
|
|
141
|
-
getCurrentViewPortNumber() {
|
|
142
|
-
return this.isBrowser ? document.body.clientWidth : 1200;
|
|
143
|
-
}
|
|
144
|
-
/**
|
|
145
|
-
* Returns the current viewport width as number
|
|
146
|
-
* @returns string
|
|
147
|
-
*/
|
|
148
|
-
getCurrentViewPortWidth() {
|
|
149
|
-
return this.isBrowser ? document.body.clientWidth : 1200;
|
|
150
|
-
}
|
|
151
|
-
/**
|
|
152
|
-
* Returns the current viewport as number
|
|
153
|
-
* @returns string
|
|
154
|
-
*/
|
|
155
|
-
getCurrentViewPortHeight() {
|
|
156
|
-
return this.isBrowser ? document.body.clientHeight : 600;
|
|
157
|
-
}
|
|
158
|
-
/**
|
|
159
|
-
* Returns the current viewport dimensions
|
|
160
|
-
* @returns string
|
|
161
|
-
*/
|
|
162
|
-
getCurrentViewPortDimensions() {
|
|
163
|
-
return this.isBrowser ? { Width: document.body.clientWidth, Height: document.body.clientWidth, Orientation: this.getOrientationAsString() } : { Width: 800, Height: 600, Orientation: "landscape" };
|
|
164
|
-
}
|
|
165
92
|
/**
|
|
166
93
|
* Provides mq´s as string
|
|
167
94
|
*/
|
|
@@ -174,11 +101,8 @@ export class ViewportService {
|
|
|
174
101
|
getViewportResizedObserver() {
|
|
175
102
|
return this.viewportResizedSubscriber.asObservable();
|
|
176
103
|
}
|
|
177
|
-
/**
|
|
178
|
-
* Scroll to element
|
|
179
|
-
*/
|
|
180
104
|
scrollToElementId(el, alignCenter = false) {
|
|
181
|
-
if (this.
|
|
105
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
182
106
|
this.scrollToElement(document.querySelector('#' + el), alignCenter);
|
|
183
107
|
}
|
|
184
108
|
}
|
|
@@ -188,24 +112,24 @@ export class ViewportService {
|
|
|
188
112
|
* @param alignCenter - defines if the element needs to be centered on window
|
|
189
113
|
*/
|
|
190
114
|
scrollToElement(el, alignCenter = false) {
|
|
191
|
-
if (this.
|
|
115
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
192
116
|
let extraScrollTop = 0;
|
|
193
117
|
if (alignCenter) {
|
|
194
118
|
extraScrollTop = (window.innerHeight - el.clientHeight) / 2;
|
|
195
119
|
}
|
|
196
|
-
|
|
120
|
+
/*
|
|
121
|
+
const elementPos: DOMRect = el.getBoundingClientRect();
|
|
122
|
+
const scrollTopPosition = elementPos.x - extraScrollTop;
|
|
123
|
+
*/
|
|
124
|
+
//let offsetLeft = 0;
|
|
197
125
|
let offsetTop = 0;
|
|
198
126
|
let elTemp = el;
|
|
199
127
|
while (elTemp) {
|
|
200
|
-
offsetLeft += elTemp.offsetLeft;
|
|
128
|
+
//offsetLeft += elTemp.offsetLeft;
|
|
201
129
|
offsetTop += elTemp.offsetTop;
|
|
202
130
|
elTemp = elTemp.parentElement ? elTemp.parentElement : null;
|
|
203
131
|
}
|
|
204
|
-
window.scrollTo({
|
|
205
|
-
left: offsetLeft,
|
|
206
|
-
top: offsetTop - extraScrollTop,
|
|
207
|
-
behavior: 'smooth',
|
|
208
|
-
});
|
|
132
|
+
window.scrollTo({ left: 0, top: offsetTop - extraScrollTop, behavior: 'smooth' });
|
|
209
133
|
}
|
|
210
134
|
}
|
|
211
135
|
/**
|
|
@@ -213,67 +137,13 @@ export class ViewportService {
|
|
|
213
137
|
* @param top - top position value
|
|
214
138
|
*/
|
|
215
139
|
scrollTop(top) {
|
|
216
|
-
if (this.
|
|
140
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
217
141
|
window.scrollTo({ left: 0, top: top, behavior: 'smooth' });
|
|
218
142
|
}
|
|
219
143
|
}
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
isPortrait() {
|
|
224
|
-
if (this.isBrowser)
|
|
225
|
-
return window.innerHeight > window.innerWidth;
|
|
226
|
-
else
|
|
227
|
-
return undefined;
|
|
228
|
-
}
|
|
229
|
-
/**
|
|
230
|
-
* If orientation is landscape
|
|
231
|
-
*/
|
|
232
|
-
isLandscape() {
|
|
233
|
-
if (this.isBrowser) {
|
|
234
|
-
const isLandscape = window.orientation === 90 || window.orientation === -90;
|
|
235
|
-
return isLandscape;
|
|
236
|
-
}
|
|
237
|
-
else {
|
|
238
|
-
return undefined;
|
|
239
|
-
}
|
|
240
|
-
}
|
|
241
|
-
/**
|
|
242
|
-
* Get screen orientation (portrait/landscape)
|
|
243
|
-
*/
|
|
244
|
-
getOrientationAsString() {
|
|
245
|
-
return this.isPortrait ? "portrait" : "landscape";
|
|
246
|
-
}
|
|
247
|
-
/**
|
|
248
|
-
* If mobile breakpoint (below tablet)
|
|
249
|
-
*/
|
|
250
|
-
isMobile() {
|
|
251
|
-
return this.getCurrentViewPortNumber() < this.breakpoints[2].Low;
|
|
252
|
-
}
|
|
253
|
-
/**
|
|
254
|
-
* Get height of an element
|
|
255
|
-
* @deprecated
|
|
256
|
-
*/
|
|
257
|
-
calculateFullscreenElementsheight(id, defaultheight, extra) {
|
|
258
|
-
return this.calculateFullscreenElementsHeight(id, defaultheight, extra);
|
|
259
|
-
}
|
|
260
|
-
/**
|
|
261
|
-
* Get height of an element
|
|
262
|
-
*/
|
|
263
|
-
calculateFullscreenElementsHeight(id, defaultheight, extra) {
|
|
264
|
-
if (!this.isBrowser || this.isMobile()) {
|
|
265
|
-
return defaultheight;
|
|
266
|
-
}
|
|
267
|
-
else {
|
|
268
|
-
const map = this.document.getElementById(id);
|
|
269
|
-
const footer = this.document.getElementsByTagName('footer')[0];
|
|
270
|
-
if (map && footer) {
|
|
271
|
-
return `${window.innerHeight - map.offsetTop - footer.offsetHeight - extra}px`;
|
|
272
|
-
}
|
|
273
|
-
else {
|
|
274
|
-
console.warn('could not calculate map height');
|
|
275
|
-
return defaultheight;
|
|
276
|
-
}
|
|
144
|
+
ngOnDestroy() {
|
|
145
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
146
|
+
window.removeEventListener('resize', this.documentSizeChanged);
|
|
277
147
|
}
|
|
278
148
|
}
|
|
279
149
|
/**
|
|
@@ -285,18 +155,18 @@ export class ViewportService {
|
|
|
285
155
|
// inform who´s interested
|
|
286
156
|
this.viewportResizedSubscriber.next(currentWindowWidth);
|
|
287
157
|
if (currentWindowWidth > 0) {
|
|
288
|
-
for (const mqs of this.
|
|
289
|
-
if (currentWindowWidth > mqs.
|
|
158
|
+
for (const mqs of this.viewports) {
|
|
159
|
+
if (currentWindowWidth > mqs.high) {
|
|
290
160
|
continue;
|
|
291
161
|
}
|
|
292
|
-
else if ((currentWindowWidth >= mqs.
|
|
293
|
-
this.currentViewport !== mqs.
|
|
294
|
-
this.currentViewport = mqs.
|
|
162
|
+
else if ((currentWindowWidth >= mqs.low || currentWindowWidth <= mqs.high) &&
|
|
163
|
+
this.currentViewport !== mqs.name) {
|
|
164
|
+
this.currentViewport = mqs.name;
|
|
295
165
|
// inform who´s interested
|
|
296
|
-
this.viewportChangedSubscriber.next(mqs.
|
|
166
|
+
this.viewportChangedSubscriber.next(mqs.name);
|
|
297
167
|
break;
|
|
298
168
|
}
|
|
299
|
-
else if (this.currentViewport === mqs.
|
|
169
|
+
else if (this.currentViewport === mqs.name) {
|
|
300
170
|
break;
|
|
301
171
|
}
|
|
302
172
|
else {
|
|
@@ -310,46 +180,37 @@ export class ViewportService {
|
|
|
310
180
|
* @param width Width to get the according MQ for
|
|
311
181
|
*/
|
|
312
182
|
convertWidthToMediaQuery(width) {
|
|
313
|
-
let currentViewport =
|
|
314
|
-
for (const mqs of this.
|
|
315
|
-
if (width <= mqs.
|
|
316
|
-
currentViewport = mqs;
|
|
183
|
+
let currentViewport = '';
|
|
184
|
+
for (const mqs of this.viewports) {
|
|
185
|
+
if (width <= mqs.high && width >= mqs.low) {
|
|
186
|
+
currentViewport = mqs.name;
|
|
317
187
|
break;
|
|
318
188
|
}
|
|
319
189
|
}
|
|
320
190
|
return currentViewport;
|
|
321
191
|
}
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
const sizes = this.simpleBreakpoints.slice().reverse(); // we need to reverse it to check step by step from biggest, which breakpoints still fits. Slice is a trick to not mutate the original array and make a copy
|
|
328
|
-
for (const key in sizes) {
|
|
329
|
-
if (screenSize < sizes[key].MaximumPixels) {
|
|
330
|
-
actualBreakpoint = sizes[key];
|
|
331
|
-
}
|
|
332
|
-
}
|
|
333
|
-
if (!actualBreakpoint) {
|
|
334
|
-
actualBreakpoint = sizes[0]; // default screensize is biggest. Will be used if viewport is bigger as maximum. Remember, array is reversed
|
|
335
|
-
}
|
|
336
|
-
return actualBreakpoint;
|
|
192
|
+
isPortrait() {
|
|
193
|
+
if (isPlatformBrowser(this.platformId))
|
|
194
|
+
return window.innerHeight > window.innerWidth;
|
|
195
|
+
else
|
|
196
|
+
return;
|
|
337
197
|
}
|
|
338
|
-
|
|
339
|
-
if (this.
|
|
340
|
-
window.
|
|
198
|
+
isLandscape() {
|
|
199
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
200
|
+
const isLandscape = window.orientation === 90 || window.orientation === -90;
|
|
201
|
+
return isLandscape;
|
|
202
|
+
}
|
|
203
|
+
else {
|
|
204
|
+
return;
|
|
341
205
|
}
|
|
342
206
|
}
|
|
343
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.
|
|
344
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.
|
|
207
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewportService, deps: [{ token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
208
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewportService }); }
|
|
345
209
|
}
|
|
346
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.
|
|
210
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewportService, decorators: [{
|
|
347
211
|
type: Injectable
|
|
348
212
|
}], ctorParameters: function () { return [{ type: Object, decorators: [{
|
|
349
213
|
type: Inject,
|
|
350
214
|
args: [PLATFORM_ID]
|
|
351
|
-
}] }, { type: Document, decorators: [{
|
|
352
|
-
type: Inject,
|
|
353
|
-
args: [DOCUMENT]
|
|
354
215
|
}] }]; } });
|
|
355
|
-
//# 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 */\nimport { DOCUMENT, isPlatformBrowser } from '@angular/common';\nimport { Inject, Injectable, OnDestroy, PLATFORM_ID } from '@angular/core';\nimport { Observable, Subject } from 'rxjs';\nimport { NullAble } from '../models';\n\ndeclare const window: any;\ndeclare const document: any;\n\nexport class WindowDimensions {\n    constructor(data?: Partial<WindowDimensions>) {\n        Object.assign(this, data);\n    }\n    Height!: number;\n    Width!: number;\n    Orientation!: \"landscape\" | \"portrait\";\n}\n\nexport class SimpleBreakpoint {\n    constructor(data?: Partial<SimpleBreakpoint>) {\n        Object.assign(this, data);\n    }\n    Number!: number;\n    Name!: string;\n    MaximumPixels!: number;\n}\n\nexport class Breakpoint {\n    constructor(data?: Partial<Breakpoint>) {\n        Object.assign(this, data);\n    }\n    Number!: number;\n    Name!: string;\n    Low!: number;\n    High!: number;\n}\n\n/**\n * Service to get viewport\n */\n@Injectable()\nexport class ViewportService implements OnDestroy {\n    public readonly simpleBreakpoints: SimpleBreakpoint[] = [\n        { Number: 0, Name: 'mobile', MaximumPixels: 768 },\n        { Number: 1, Name: 'tablet', MaximumPixels: 1024 },\n        { Number: 2, Name: 'desktop', MaximumPixels: 1600 },\n        { Number: 3, Name: 'high', MaximumPixels: 2500 },\n    ];\n\n    public readonly breakpoints: Breakpoint[] = [\n        {\n            Number: 0,\n            Name: 'xs',\n            Low: 360,\n            High: 990,\n        },\n        {\n            Number: 1,\n            Name: 's',\n            Low: 991,\n            High: 1024,\n        },\n        {\n            Number: 2,\n            Name: 'm',\n            Low: 1025,\n            High: 1200,\n        },\n        {\n            Number: 3,\n            Name: 'l',\n            Low: 1201,\n            High: 1400,\n        },\n        {\n            Number: 4,\n            Name: 'xl',\n            Low: 1401,\n            High: 1600,\n        },\n        {\n            Number: 5,\n            Name: 'xxl',\n            Low: 1601,\n            High: 1920,\n        },\n        {\n            Number: 6,\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\n    private currentViewport!: string;\n    private currentViewportObject!: Breakpoint;\n    private isBrowser = false;\n\n    constructor(\n        @Inject(PLATFORM_ID) private platformId: Object,\n        @Inject(DOCUMENT) public document: Document\n    ) {\n        if (isPlatformBrowser(this.platformId)) {\n            window.addEventListener('resize', this.documentSizeChanged.bind(this), {\n                passive: true,\n            });\n            this.isBrowser = true;\n        }\n    }\n\n    /**\n     * Get document height\n     */\n    public getDocumentHeight(): number {\n        return this.isBrowser ? document.body.clientHeight : 1200;\n    }\n\n    /**\n     * Get document width\n     */\n    public getDocumentWidth(): number {\n        return this.isBrowser ? document.body.clientWidth : 1200;\n    }\n\n    /**\n     * Get window height\n     */\n    public getWindowHeight(): number {\n        return this.isBrowser ? window.innerHeight : 1200;\n    }\n\n    /**\n     * Get window width\n     */\n    public getWindowWidth(): number {\n        return this.isBrowser ? window.innerWidth : 1200;\n    }\n\n    /**\n     * Returns the current viewport MQ as string\n     * @returns string\n     */\n    public getCurrentViewPort(): string {\n        const currentWidth: number = this.isBrowser\n            ? document.body.clientWidth\n            : 1200;\n        this.currentViewport = this.convertWidthToMediaQuery(currentWidth).Name;\n\n        return this.currentViewport;\n    }\n\n    /**\n     * Returns the current viewport MQ as object with all informations\n     * @returns string\n     */\n    public getCurrentViewPortObject(): Breakpoint {\n        const currentWidth: number = this.isBrowser\n            ? document.body.clientWidth\n            : 1200;\n        this.currentViewportObject = this.convertWidthToMediaQuery(currentWidth);\n\n        return this.currentViewportObject;\n    }\n\n    /**\n     * Returns the current viewport as number\n     * @deprecated use getCurrentViewPortDimensions instead\n     * @returns string\n     */\n    public getCurrentViewPortNumber(): number {\n        return this.isBrowser ? document.body.clientWidth : 1200;\n    }\n\n    /**\n     * Returns the current viewport width as number\n     * @returns string\n     */\n    public getCurrentViewPortWidth(): number {\n        return this.isBrowser ? document.body.clientWidth : 1200;\n    }\n\n    /**\n     * Returns the current viewport as number\n     * @returns string\n     */\n    public getCurrentViewPortHeight(): number {\n        return this.isBrowser ? document.body.clientHeight : 600;\n    }\n\n    /**\n     * Returns the current viewport dimensions\n     * @returns string\n     */\n    public getCurrentViewPortDimensions(): WindowDimensions {\n        return this.isBrowser ? {Width:document.body.clientWidth,Height:document.body.clientWidth,Orientation:this.getOrientationAsString() } as WindowDimensions : {Width:800, Height:600, Orientation: \"landscape\"} as WindowDimensions;\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    /**\n     * Scroll to element\n     */\n    public scrollToElementId(el: string, alignCenter = false) {\n        if (this.isBrowser) {\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 (this.isBrowser) {\n            let extraScrollTop = 0;\n\n            if (alignCenter) {\n                extraScrollTop = (window.innerHeight - el.clientHeight) / 2;\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({\n                left: offsetLeft,\n                top: offsetTop - extraScrollTop,\n                behavior: 'smooth',\n            });\n        }\n    }\n\n    /**\n     * Scroll to the top position\n     * @param top - top position value\n     */\n    public scrollTop(top: number) {\n        if (this.isBrowser) {\n            window.scrollTo({ left: 0, top: top, behavior: 'smooth' });\n        }\n    }\n\n    /**\n     * If orientation is portrait\n     */\n    public isPortrait() : boolean|undefined {\n        if (this.isBrowser) return window.innerHeight > window.innerWidth;\n        else return undefined;\n    }\n\n    /**\n     * If orientation is landscape\n     */\n    public isLandscape() :boolean|undefined {\n        if (this.isBrowser) {\n            const isLandscape =\n                window.orientation === 90 || window.orientation === -90;\n            return isLandscape;\n        } else {\n            return undefined;\n        }\n    }\n\n    /**\n     * Get screen orientation (portrait/landscape)\n     */\n    public getOrientationAsString() : \"portrait\" | \"landscape\" {\n        return this.isPortrait ? \"portrait\" : \"landscape\";\n    }\n\n    /**\n     * If mobile breakpoint (below tablet)\n     */\n    public isMobile():boolean {\n        return this.getCurrentViewPortNumber() < this.breakpoints[2].Low;\n    }\n\n    /**\n     * Get height of an element\n     * @deprecated\n     */\n    public calculateFullscreenElementsheight(\n        id: string,\n        defaultheight: string,\n        extra: number\n    ) {\n        return this.calculateFullscreenElementsHeight(id, defaultheight, extra);\n    }\n\n    /**\n     * Get height of an element\n     */\n    public calculateFullscreenElementsHeight(\n        id: string,\n        defaultheight: string,\n        extra: number\n    ) {\n        \n        if (!this.isBrowser || this.isMobile()) {\n            return defaultheight;\n        } else {\n            const map = this.document.getElementById(id);\n            const footer = this.document.getElementsByTagName('footer')[0];\n            if (map && footer) {\n                return `${window.innerHeight - map.offsetTop - footer.offsetHeight - extra\n                    }px`;\n            } else {\n                console.warn('could not calculate map height');\n                return defaultheight;\n            }\n        }\n    }\n\n    /**\n     * If viewport changed\n     * @event\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.breakpoints) {\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): Breakpoint {\n        let currentViewport = this.breakpoints[0];\n\n        for (const mqs of this.breakpoints) {\n            if (width <= mqs.High && width >= mqs.Low) {\n                currentViewport = mqs;\n                break;\n            }\n        }\n\n        return currentViewport;\n    }\n\n    /**\n     * Get the breakpoint/device name like mobile,tablet,desktop, high\n     */\n    getSimpleBreakpoint(screenSize: number) :SimpleBreakpoint {\n        let actualBreakpoint: SimpleBreakpoint | undefined;\n\n        const sizes = this.simpleBreakpoints.slice().reverse(); // we need to reverse it to check step by step from biggest, which breakpoints still fits. Slice is a trick to not mutate the original array and make a copy\n        for (const key in sizes) {\n            if (screenSize < sizes[key].MaximumPixels) {\n                actualBreakpoint = sizes[key];\n            }\n        }\n        if (!actualBreakpoint) {\n            actualBreakpoint = sizes[0]; // default screensize is biggest. Will be used if viewport is bigger as maximum. Remember, array is reversed\n        }\n\n        return actualBreakpoint;\n    }\n\n    ngOnDestroy() {\n        if (this.isBrowser) {\n            window.removeEventListener('resize', this.documentSizeChanged);\n        }\n    }\n}\n"]}
|
|
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"]}
|
|
@@ -33,10 +33,10 @@ export class BackToTopComponent {
|
|
|
33
33
|
})();
|
|
34
34
|
}
|
|
35
35
|
}
|
|
36
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.
|
|
37
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.
|
|
36
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BackToTopComponent, deps: [{ token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
37
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", 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>", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.IconComponent, selector: "kms-icon", inputs: ["icon", "iconClass", "iconStyle", "iconSize", "dontUseSprite"] }] }); }
|
|
38
38
|
}
|
|
39
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.
|
|
39
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BackToTopComponent, decorators: [{
|
|
40
40
|
type: Component,
|
|
41
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
42
|
}], ctorParameters: function () { return [{ type: Object, decorators: [{
|
|
@@ -46,4 +46,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
|
|
|
46
46
|
type: HostListener,
|
|
47
47
|
args: ['window:scroll', []]
|
|
48
48
|
}] } });
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFjay10by10b3AuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva21zLW5neC11aS1wcmVzZW50YXRpb25hbC9zcmMvbGliL3VpL2JhY2stdG8tdG9wL2JhY2stdG8tdG9wLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWwvc3JjL2xpYi91aS9iYWNrLXRvLXRvcC9iYWNrLXRvLXRvcC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDN0UsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUJBQWlCLENBQUM7Ozs7QUFNcEQsTUFBTSxPQUFPLGtCQUFrQjtJQUczQixZQUF3QyxVQUFrQjtRQUFsQixlQUFVLEdBQVYsVUFBVSxDQUFRO0lBQUcsQ0FBQztJQUc5RCxjQUFjO1FBQ1YsSUFBSSxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUU7WUFDcEMsSUFBSSxNQUFNLENBQUMsV0FBVyxJQUFJLFFBQVEsQ0FBQyxlQUFlLENBQUMsU0FBUyxJQUFJLFFBQVEsQ0FBQyxJQUFJLENBQUMsU0FBUyxHQUFHLEdBQUcsRUFBRTtnQkFDM0YsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUM7YUFDOUI7aUJBQU0sSUFDSCxDQUFDLElBQUksQ0FBQyxjQUFjLElBQUksTUFBTSxDQUFDLFdBQVcsQ0FBQztnQkFDM0MsUUFBUSxDQUFDLGVBQWUsQ0FBQyxTQUFTO2dCQUNsQyxRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFFLEVBQzlCO2dCQUNFLElBQUksQ0FBQyxjQUFjLEdBQUcsS0FBSyxDQUFDO2FBQy9CO1NBQ0o7SUFDTCxDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksaUJBQWlCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxFQUFFO1lBQ3BDLENBQUMsU0FBUyxZQUFZO2dCQUNsQixNQUFNLGFBQWEsR0FBRyxRQUFRLENBQUMsZUFBZSxDQUFDLFNBQVMsSUFBSSxRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQztnQkFDcEYsSUFBSSxhQUFhLEdBQUcsQ0FBQyxFQUFFO29CQUNuQixNQUFNLENBQUMscUJBQXFCLENBQUMsWUFBWSxDQUFDLENBQUM7b0JBQzNDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxFQUFFLGFBQWEsR0FBRyxhQUFhLEdBQUcsQ0FBQyxDQUFDLENBQUM7aUJBQ3pEO1lBQ0wsQ0FBQyxDQUFDLEVBQUUsQ0FBQztTQUNSO0lBQ0wsQ0FBQzsrR0E5QlEsa0JBQWtCLGtCQUdQLFdBQVc7bUdBSHRCLGtCQUFrQixxSENYL0IsdVFBTU07OzRGREtPLGtCQUFrQjtrQkFKOUIsU0FBUzsrQkFDSSxpQkFBaUI7OzBCQU1kLE1BQU07MkJBQUMsV0FBVzs0Q0FHL0IsY0FBYztzQkFEYixZQUFZO3VCQUFDLGVBQWUsRUFBRSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAY29weXJpZ2h0IEtNUyBHbWJIXG4gKi9cblxuaW1wb3J0IHsgQ29tcG9uZW50LCBIb3N0TGlzdGVuZXIsIEluamVjdCwgUExBVEZPUk1fSUQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGlzUGxhdGZvcm1Ccm93c2VyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdrbXMtYmFjay10by10b3AnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9iYWNrLXRvLXRvcC5jb21wb25lbnQuaHRtbCcsXG59KVxuZXhwb3J0IGNsYXNzIEJhY2tUb1RvcENvbXBvbmVudCB7XG4gICAgd2luZG93U2Nyb2xsZWQ/OiBib29sZWFuO1xuXG4gICAgY29uc3RydWN0b3IoQEluamVjdChQTEFURk9STV9JRCkgcHVibGljIHBsYXRmb3JtSWQ6IE9iamVjdCkge31cblxuICAgIEBIb3N0TGlzdGVuZXIoJ3dpbmRvdzpzY3JvbGwnLCBbXSlcbiAgICBvbldpbmRvd1Njcm9sbCgpIHtcbiAgICAgICAgaWYgKGlzUGxhdGZvcm1Ccm93c2VyKHRoaXMucGxhdGZvcm1JZCkpIHtcbiAgICAgICAgICAgIGlmICh3aW5kb3cucGFnZVlPZmZzZXQgfHwgZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50LnNjcm9sbFRvcCB8fCBkb2N1bWVudC5ib2R5LnNjcm9sbFRvcCA+IDEwMCkge1xuICAgICAgICAgICAgICAgIHRoaXMud2luZG93U2Nyb2xsZWQgPSB0cnVlO1xuICAgICAgICAgICAgfSBlbHNlIGlmIChcbiAgICAgICAgICAgICAgICAodGhpcy53aW5kb3dTY3JvbGxlZCAmJiB3aW5kb3cucGFnZVlPZmZzZXQpIHx8XG4gICAgICAgICAgICAgICAgZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50LnNjcm9sbFRvcCB8fFxuICAgICAgICAgICAgICAgIGRvY3VtZW50LmJvZHkuc2Nyb2xsVG9wIDwgMTBcbiAgICAgICAgICAgICkge1xuICAgICAgICAgICAgICAgIHRoaXMud2luZG93U2Nyb2xsZWQgPSBmYWxzZTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH1cblxuICAgIHNjcm9sbFRvVG9wKCkge1xuICAgICAgICBpZiAoaXNQbGF0Zm9ybUJyb3dzZXIodGhpcy5wbGF0Zm9ybUlkKSkge1xuICAgICAgICAgICAgKGZ1bmN0aW9uIHNtb290aHNjcm9sbCgpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBjdXJyZW50U2Nyb2xsID0gZG9jdW1lbnQuZG9jdW1lbnRFbGVtZW50LnNjcm9sbFRvcCB8fCBkb2N1bWVudC5ib2R5LnNjcm9sbFRvcDtcbiAgICAgICAgICAgICAgICBpZiAoY3VycmVudFNjcm9sbCA+IDApIHtcbiAgICAgICAgICAgICAgICAgICAgd2luZG93LnJlcXVlc3RBbmltYXRpb25GcmFtZShzbW9vdGhzY3JvbGwpO1xuICAgICAgICAgICAgICAgICAgICB3aW5kb3cuc2Nyb2xsVG8oMCwgY3VycmVudFNjcm9sbCAtIGN1cnJlbnRTY3JvbGwgLyA4KTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9KSgpO1xuICAgICAgICB9XG4gICAgfVxufVxuIiwiPGRpdiBjbGFzcz1cInNjcm9sbFRvVG9wXCJcbiAgICBbbmdDbGFzc109XCJ7J3Nob3cnOiB3aW5kb3dTY3JvbGxlZH1cIlxuICAgIChjbGljayk9XCJzY3JvbGxUb1RvcCgpXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJzY3JvbGxUb1RvcC1pbm5lclwiPlxuICAgICAgICAgICAgPGttcy1pY29uIGljb249XCJmbG9hdGluZ19idXR0b25fY2xlYXJcIiBpY29uQ2xhc3M9XCJjb2xvci13aGl0ZVwiPjwva21zLWljb24+XG4gICAgICAgIDwvZGl2PlxuPC9kaXY+Il19
|
|
@@ -4,7 +4,7 @@ import { GenericDialogComponent } from '../generic-dialog/generic-dialog.compone
|
|
|
4
4
|
import { ButtonResponseType } from './button-response-types.enum';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/material/legacy-dialog";
|
|
7
|
-
import * as i2 from "@angular/material/
|
|
7
|
+
import * as i2 from "@angular/material/button";
|
|
8
8
|
export class ButtonWithConfirmDialogComponent {
|
|
9
9
|
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
10
10
|
constructor(dialog) {
|
|
@@ -36,10 +36,10 @@ export class ButtonWithConfirmDialogComponent {
|
|
|
36
36
|
dialogRef.close();
|
|
37
37
|
});
|
|
38
38
|
}
|
|
39
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.
|
|
40
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.
|
|
39
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ButtonWithConfirmDialogComponent, deps: [{ token: i1.MatLegacyDialog }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
40
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ButtonWithConfirmDialogComponent, selector: "kms-button-with-confirm-dialog", inputs: { disabled: "disabled", buttonText: "buttonText", confirmTitle: "confirmTitle", confirmTextYes: "confirmTextYes", confirmTextNo: "confirmTextNo" }, outputs: { onConfirmClosed: "onConfirmClosed" }, ngImport: i0, template: "<button\n type=\"button\"\n (click)=\"start()\"\n mat-stroked-button\n [disabled]=\"disabled\"\n>\n {{ buttonText }}\n</button>\n", styles: [""], dependencies: [{ kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }] }); }
|
|
41
41
|
}
|
|
42
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.
|
|
42
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ButtonWithConfirmDialogComponent, decorators: [{
|
|
43
43
|
type: Component,
|
|
44
44
|
args: [{ selector: 'kms-button-with-confirm-dialog', template: "<button\n type=\"button\"\n (click)=\"start()\"\n mat-stroked-button\n [disabled]=\"disabled\"\n>\n {{ buttonText }}\n</button>\n" }]
|
|
45
45
|
}], ctorParameters: function () { return [{ type: i1.MatLegacyDialog }]; }, propDecorators: { disabled: [{
|
|
@@ -55,4 +55,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
|
|
|
55
55
|
}], onConfirmClosed: [{
|
|
56
56
|
type: Output
|
|
57
57
|
}] } });
|
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLXdpdGgtY29uZmlybS1kaWFsb2cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva21zLW5neC11aS1wcmVzZW50YXRpb25hbC9zcmMvbGliL3VpL2J1dHRvbi13aXRoLWNvbmZpcm0tZGlhbG9nL2J1dHRvbi13aXRoLWNvbmZpcm0tZGlhbG9nLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWwvc3JjL2xpYi91aS9idXR0b24td2l0aC1jb25maXJtLWRpYWxvZy9idXR0b24td2l0aC1jb25maXJtLWRpYWxvZy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRS9FLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFFbEMsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDcEYsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7QUFRbEUsTUFBTSxPQUFPLGdDQUFnQztJQVl6QyxnRUFBZ0U7SUFDaEUsWUFDVyxNQUFpQjtRQUFqQixXQUFNLEdBQU4sTUFBTSxDQUFXO1FBUDVCLHNGQUFzRjtRQUM1RSxvQkFBZSxHQUEwQixJQUFJLFlBQVksRUFBRSxDQUFDO1FBRTlELFNBQUksR0FBRyxJQUFJLE9BQU8sRUFBRSxDQUFDO0lBSzFCLENBQUM7SUFFSixnRUFBZ0U7SUFDaEUsUUFBUSxLQUFJLENBQUM7SUFFYixLQUFLO1FBQ0QsTUFBTSxJQUFJLEdBQWU7WUFDckIsS0FBSyxFQUFFLElBQUksQ0FBQyxZQUFZO1lBQ3hCLE9BQU8sRUFBQztnQkFDSixPQUFPLEVBQUUsSUFBSSxDQUFDLGNBQWM7Z0JBQzVCLFNBQVMsRUFBRSxJQUFJLENBQUMsYUFBYTthQUNoQztTQUNKLENBQUM7UUFDRixNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxzQkFBc0IsRUFBRTtZQUN2RCxJQUFJLEVBQUUsSUFBSTtTQUNiLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxHQUFHLFNBQVMsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDeEQsSUFBSSxNQUFNLEtBQUssa0JBQWtCLENBQUMsT0FBTyxFQUFFO2dCQUN2QyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQzthQUNuQztpQkFBSTtnQkFDRCxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQzthQUNwQztZQUNELFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUN0QixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7K0dBeENRLGdDQUFnQzttR0FBaEMsZ0NBQWdDLG1SQ2I3QyxrSkFRQTs7NEZES2EsZ0NBQWdDO2tCQUw1QyxTQUFTOytCQUNJLGdDQUFnQztzR0FLakMsUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csY0FBYztzQkFBdEIsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUdJLGVBQWU7c0JBQXhCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNYXRMZWdhY3lEaWFsb2cgYXMgTWF0RGlhbG9nIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbGVnYWN5LWRpYWxvZyc7XG5pbXBvcnQgeyBTdWJTaW5rIH0gZnJvbSAnc3Vic2luayc7XG5pbXBvcnQgeyBOdWxsQWJsZSB9IGZyb20gJy4uLy4uL21vZGVscyc7XG5pbXBvcnQgeyBHZW5lcmljRGlhbG9nQ29tcG9uZW50IH0gZnJvbSAnLi4vZ2VuZXJpYy1kaWFsb2cvZ2VuZXJpYy1kaWFsb2cuY29tcG9uZW50JztcbmltcG9ydCB7IEJ1dHRvblJlc3BvbnNlVHlwZSB9IGZyb20gJy4vYnV0dG9uLXJlc3BvbnNlLXR5cGVzLmVudW0nO1xuaW1wb3J0IHsgRGlhbG9nRGF0YSB9IGZyb20gJy4vZGlhbG9nLWRhdGEubW9kZWwnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2ttcy1idXR0b24td2l0aC1jb25maXJtLWRpYWxvZycsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2J1dHRvbi13aXRoLWNvbmZpcm0tZGlhbG9nLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9idXR0b24td2l0aC1jb25maXJtLWRpYWxvZy5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBCdXR0b25XaXRoQ29uZmlybURpYWxvZ0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgQElucHV0KCkgZGlzYWJsZWQ6IE51bGxBYmxlPGJvb2xlYW4+O1xuICAgIEBJbnB1dCgpIGJ1dHRvblRleHQ6IE51bGxBYmxlPHN0cmluZz47XG4gICAgQElucHV0KCkgY29uZmlybVRpdGxlOiBOdWxsQWJsZTxzdHJpbmc+O1xuICAgIEBJbnB1dCgpIGNvbmZpcm1UZXh0WWVzOiBOdWxsQWJsZTxzdHJpbmc+O1xuICAgIEBJbnB1dCgpIGNvbmZpcm1UZXh0Tm86IE51bGxBYmxlPHN0cmluZz47XG5cbiAgICAvLyBPdXRwdXRzIHdoZW4gZGlhbG9ndWUgd2FzIGNsb3NlZC4gUmV0dXJucyB0cnVlLCBpZiB5ZXMgd2FzIGNsaWNrZWQsIGZhbHNlIG90aGVyd2lzZVxuICAgIEBPdXRwdXQoKSBvbkNvbmZpcm1DbG9zZWQ6IEV2ZW50RW1pdHRlcjxib29sZWFuPiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICAgIHByaXZhdGUgc3VicyA9IG5ldyBTdWJTaW5rKCk7XG4gICAgXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1lbXB0eS1mdW5jdGlvblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwdWJsaWMgZGlhbG9nOiBNYXREaWFsb2csXG4gICAgKSB7fVxuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1lbXB0eS1mdW5jdGlvblxuICAgIG5nT25Jbml0KCkge31cblxuICAgIHN0YXJ0KCl7XG4gICAgICAgIGNvbnN0IGRhdGE6IERpYWxvZ0RhdGEgPSB7XG4gICAgICAgICAgICB0aXRsZTogdGhpcy5jb25maXJtVGl0bGUsXG4gICAgICAgICAgICBidXR0b25zOntcbiAgICAgICAgICAgICAgICBwcmltYXJ5OiB0aGlzLmNvbmZpcm1UZXh0WWVzLFxuICAgICAgICAgICAgICAgIHNlY29uZGFyeTogdGhpcy5jb25maXJtVGV4dE5vLFxuICAgICAgICAgICAgfVxuICAgICAgICB9O1xuICAgICAgICBjb25zdCBkaWFsb2dSZWYgPSB0aGlzLmRpYWxvZy5vcGVuKEdlbmVyaWNEaWFsb2dDb21wb25lbnQsIHtcbiAgICAgICAgICAgIGRhdGE6IGRhdGEsXG4gICAgICAgIH0pO1xuXG4gICAgICAgIHRoaXMuc3Vicy5zaW5rID0gZGlhbG9nUmVmLmFmdGVyQ2xvc2VkKCkuc3Vic2NyaWJlKHJlc3VsdCA9PiB7XG4gICAgICAgICAgICBpZiAocmVzdWx0ID09PSBCdXR0b25SZXNwb25zZVR5cGUucHJpbWFyeSkge1xuICAgICAgICAgICAgICAgIHRoaXMub25Db25maXJtQ2xvc2VkLmVtaXQodHJ1ZSk7XG4gICAgICAgICAgICB9ZWxzZXtcbiAgICAgICAgICAgICAgICB0aGlzLm9uQ29uZmlybUNsb3NlZC5lbWl0KGZhbHNlKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGRpYWxvZ1JlZi5jbG9zZSgpO1xuICAgICAgICB9KTtcbiAgICB9XG59XG4iLCI8YnV0dG9uXG4gICAgdHlwZT1cImJ1dHRvblwiXG4gICAgKGNsaWNrKT1cInN0YXJ0KClcIlxuICAgIG1hdC1zdHJva2VkLWJ1dHRvblxuICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXG4+XG4gICAge3sgYnV0dG9uVGV4dCB9fVxuPC9idXR0b24+XG4iXX0=
|