@kms-ngx-ui/presentational 16.3.1 → 16.3.3
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 +8 -3
- package/esm2022/lib/directives/size.directive.mjs +21 -0
- package/esm2022/lib/kms-ngx-ui-presentational.module.mjs +21 -26
- package/esm2022/lib/parent-components/form-control.component.mjs +2 -2
- package/esm2022/lib/parent-components/form.component.mjs +11 -5
- package/esm2022/lib/services/viewport.service.mjs +212 -73
- package/esm2022/lib/ui/back-to-top/back-to-top.component.mjs +1 -1
- package/esm2022/lib/ui/dropdown-from-data/dropdown-from-data.component.mjs +9 -4
- package/esm2022/lib/ui/file-input/file-input.component.mjs +8 -8
- package/esm2022/lib/ui/flyout/flyout.component.mjs +6 -5
- package/esm2022/lib/ui/icon/icon.component.mjs +6 -3
- package/esm2022/lib/ui/icon/iconSize.enum.mjs +12 -1
- package/esm2022/lib/ui/image-slider/image-slider.component.mjs +3 -3
- package/esm2022/lib/ui/kms-accordion-item/kms-accordion-item.component.mjs +9 -9
- package/esm2022/lib/ui/map/map.component.mjs +3 -3
- package/esm2022/lib/ui/radiobutton/radiobutton.component.mjs +9 -5
- package/esm2022/lib/ui/tooltip-icon/tooltip-icon.component.mjs +7 -6
- package/esm2022/public-api.mjs +21 -21
- package/fesm2022/kms-ngx-ui-presentational.mjs +1885 -1713
- package/fesm2022/kms-ngx-ui-presentational.mjs.map +1 -1
- package/lib/directives/directives.module.d.ts +4 -2
- package/lib/directives/size.directive.d.ts +10 -0
- package/lib/kms-ngx-ui-presentational.module.d.ts +21 -22
- package/lib/services/viewport.service.d.ts +86 -11
- package/lib/ui/dropdown-from-data/dropdown-from-data.component.d.ts +4 -2
- package/lib/ui/file-input/file-input.component.d.ts +2 -2
- package/lib/ui/icon/icon.component.d.ts +7 -1
- package/lib/ui/icon/iconSize.enum.d.ts +10 -0
- package/lib/ui/kms-accordion-item/kms-accordion-item.component.d.ts +2 -2
- package/lib/ui/radiobutton/radiobutton.component.d.ts +2 -1
- package/lib/ui/tooltip-icon/tooltip-icon.component.d.ts +2 -2
- package/package.json +1 -1
- package/public-api.d.ts +20 -20
- package/src/lib/ui/back-to-top/back-to-top.component.scss +2 -3
- package/src/lib/ui/icon/icon.component.scss +2 -36
- package/src/lib/ui/image-slider/image-slider.component.scss +209 -202
- package/src/styles/animations.scss +47 -0
- package/src/styles/styles.scss +1 -0
- package/esm2022/lib/ui/tooltip/tooltip.component.mjs +0 -16
- package/lib/ui/tooltip/tooltip.component.d.ts +0 -6
- package/src/lib/ui/tooltip/tooltip.component.scss +0 -27
|
@@ -1,94 +1,167 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* @copyright KMS GmbH
|
|
3
3
|
*/
|
|
4
|
-
import { isPlatformBrowser } from '@angular/common';
|
|
4
|
+
import { DOCUMENT, isPlatformBrowser } from '@angular/common';
|
|
5
5
|
import { Inject, Injectable, PLATFORM_ID } from '@angular/core';
|
|
6
6
|
import { Subject } from 'rxjs';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
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
|
+
}
|
|
8
23
|
/**
|
|
9
24
|
* Service to get viewport
|
|
10
25
|
*/
|
|
11
26
|
export class ViewportService {
|
|
12
|
-
constructor(platformId) {
|
|
27
|
+
constructor(platformId, document) {
|
|
13
28
|
this.platformId = platformId;
|
|
14
|
-
this.
|
|
29
|
+
this.document = document;
|
|
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 = [
|
|
15
37
|
{
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
38
|
+
Number: 0,
|
|
39
|
+
Name: 'xs',
|
|
40
|
+
Low: 360,
|
|
41
|
+
High: 990,
|
|
19
42
|
},
|
|
20
43
|
{
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
44
|
+
Number: 1,
|
|
45
|
+
Name: 's',
|
|
46
|
+
Low: 991,
|
|
47
|
+
High: 1024,
|
|
24
48
|
},
|
|
25
49
|
{
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
50
|
+
Number: 2,
|
|
51
|
+
Name: 'm',
|
|
52
|
+
Low: 1025,
|
|
53
|
+
High: 1200,
|
|
29
54
|
},
|
|
30
55
|
{
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
56
|
+
Number: 3,
|
|
57
|
+
Name: 'l',
|
|
58
|
+
Low: 1201,
|
|
59
|
+
High: 1400,
|
|
34
60
|
},
|
|
35
61
|
{
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
62
|
+
Number: 4,
|
|
63
|
+
Name: 'xl',
|
|
64
|
+
Low: 1401,
|
|
65
|
+
High: 1600,
|
|
39
66
|
},
|
|
40
67
|
{
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
68
|
+
Number: 5,
|
|
69
|
+
Name: 'xxl',
|
|
70
|
+
Low: 1601,
|
|
71
|
+
High: 1920,
|
|
44
72
|
},
|
|
45
73
|
{
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
74
|
+
Number: 6,
|
|
75
|
+
Name: 'xxxl',
|
|
76
|
+
Low: 1921,
|
|
77
|
+
High: 99999,
|
|
49
78
|
},
|
|
50
79
|
];
|
|
51
80
|
this.viewportChangedSubscriber = new Subject();
|
|
52
81
|
this.viewportResizedSubscriber = new Subject();
|
|
82
|
+
this.isBrowser = false;
|
|
53
83
|
if (isPlatformBrowser(this.platformId)) {
|
|
54
|
-
window.addEventListener('resize', this.documentSizeChanged.bind(this), {
|
|
84
|
+
window.addEventListener('resize', this.documentSizeChanged.bind(this), {
|
|
85
|
+
passive: true,
|
|
86
|
+
});
|
|
87
|
+
this.isBrowser = true;
|
|
55
88
|
}
|
|
56
89
|
}
|
|
57
90
|
/**
|
|
58
|
-
* Get
|
|
91
|
+
* Get document height
|
|
59
92
|
*/
|
|
60
93
|
getDocumentHeight() {
|
|
61
|
-
return
|
|
94
|
+
return this.isBrowser ? document.body.clientHeight : 1200;
|
|
62
95
|
}
|
|
63
96
|
/**
|
|
64
|
-
* Get
|
|
97
|
+
* Get document width
|
|
65
98
|
*/
|
|
66
99
|
getDocumentWidth() {
|
|
67
|
-
return
|
|
100
|
+
return this.isBrowser ? document.body.clientWidth : 1200;
|
|
68
101
|
}
|
|
69
102
|
/**
|
|
70
103
|
* Get window height
|
|
71
104
|
*/
|
|
72
105
|
getWindowHeight() {
|
|
73
|
-
return
|
|
106
|
+
return this.isBrowser ? window.innerHeight : 1200;
|
|
74
107
|
}
|
|
75
108
|
/**
|
|
76
109
|
* Get window width
|
|
77
110
|
*/
|
|
78
111
|
getWindowWidth() {
|
|
79
|
-
return
|
|
112
|
+
return this.isBrowser ? window.innerWidth : 1200;
|
|
80
113
|
}
|
|
81
114
|
/**
|
|
82
115
|
* Returns the current viewport MQ as string
|
|
83
116
|
* @returns string
|
|
84
117
|
*/
|
|
85
118
|
getCurrentViewPort() {
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
119
|
+
const currentWidth = this.isBrowser
|
|
120
|
+
? document.body.clientWidth
|
|
121
|
+
: 1200;
|
|
122
|
+
this.currentViewport = this.convertWidthToMediaQuery(currentWidth).Name;
|
|
90
123
|
return this.currentViewport;
|
|
91
124
|
}
|
|
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
|
+
}
|
|
92
165
|
/**
|
|
93
166
|
* Provides mq´s as string
|
|
94
167
|
*/
|
|
@@ -101,8 +174,11 @@ export class ViewportService {
|
|
|
101
174
|
getViewportResizedObserver() {
|
|
102
175
|
return this.viewportResizedSubscriber.asObservable();
|
|
103
176
|
}
|
|
177
|
+
/**
|
|
178
|
+
* Scroll to element
|
|
179
|
+
*/
|
|
104
180
|
scrollToElementId(el, alignCenter = false) {
|
|
105
|
-
if (
|
|
181
|
+
if (this.isBrowser) {
|
|
106
182
|
this.scrollToElement(document.querySelector('#' + el), alignCenter);
|
|
107
183
|
}
|
|
108
184
|
}
|
|
@@ -112,24 +188,24 @@ export class ViewportService {
|
|
|
112
188
|
* @param alignCenter - defines if the element needs to be centered on window
|
|
113
189
|
*/
|
|
114
190
|
scrollToElement(el, alignCenter = false) {
|
|
115
|
-
if (
|
|
191
|
+
if (this.isBrowser) {
|
|
116
192
|
let extraScrollTop = 0;
|
|
117
193
|
if (alignCenter) {
|
|
118
194
|
extraScrollTop = (window.innerHeight - el.clientHeight) / 2;
|
|
119
195
|
}
|
|
120
|
-
|
|
121
|
-
const elementPos: DOMRect = el.getBoundingClientRect();
|
|
122
|
-
const scrollTopPosition = elementPos.x - extraScrollTop;
|
|
123
|
-
*/
|
|
124
|
-
//let offsetLeft = 0;
|
|
196
|
+
let offsetLeft = 0;
|
|
125
197
|
let offsetTop = 0;
|
|
126
198
|
let elTemp = el;
|
|
127
199
|
while (elTemp) {
|
|
128
|
-
|
|
200
|
+
offsetLeft += elTemp.offsetLeft;
|
|
129
201
|
offsetTop += elTemp.offsetTop;
|
|
130
202
|
elTemp = elTemp.parentElement ? elTemp.parentElement : null;
|
|
131
203
|
}
|
|
132
|
-
window.scrollTo({
|
|
204
|
+
window.scrollTo({
|
|
205
|
+
left: offsetLeft,
|
|
206
|
+
top: offsetTop - extraScrollTop,
|
|
207
|
+
behavior: 'smooth',
|
|
208
|
+
});
|
|
133
209
|
}
|
|
134
210
|
}
|
|
135
211
|
/**
|
|
@@ -137,13 +213,67 @@ export class ViewportService {
|
|
|
137
213
|
* @param top - top position value
|
|
138
214
|
*/
|
|
139
215
|
scrollTop(top) {
|
|
140
|
-
if (
|
|
216
|
+
if (this.isBrowser) {
|
|
141
217
|
window.scrollTo({ left: 0, top: top, behavior: 'smooth' });
|
|
142
218
|
}
|
|
143
219
|
}
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
220
|
+
/**
|
|
221
|
+
* If orientation is portrait
|
|
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
|
+
}
|
|
147
277
|
}
|
|
148
278
|
}
|
|
149
279
|
/**
|
|
@@ -155,18 +285,18 @@ export class ViewportService {
|
|
|
155
285
|
// inform who´s interested
|
|
156
286
|
this.viewportResizedSubscriber.next(currentWindowWidth);
|
|
157
287
|
if (currentWindowWidth > 0) {
|
|
158
|
-
for (const mqs of this.
|
|
159
|
-
if (currentWindowWidth > mqs.
|
|
288
|
+
for (const mqs of this.breakpoints) {
|
|
289
|
+
if (currentWindowWidth > mqs.High) {
|
|
160
290
|
continue;
|
|
161
291
|
}
|
|
162
|
-
else if ((currentWindowWidth >= mqs.
|
|
163
|
-
this.currentViewport !== mqs.
|
|
164
|
-
this.currentViewport = mqs.
|
|
292
|
+
else if ((currentWindowWidth >= mqs.Low || currentWindowWidth <= mqs.High) &&
|
|
293
|
+
this.currentViewport !== mqs.Name) {
|
|
294
|
+
this.currentViewport = mqs.Name;
|
|
165
295
|
// inform who´s interested
|
|
166
|
-
this.viewportChangedSubscriber.next(mqs.
|
|
296
|
+
this.viewportChangedSubscriber.next(mqs.Name);
|
|
167
297
|
break;
|
|
168
298
|
}
|
|
169
|
-
else if (this.currentViewport === mqs.
|
|
299
|
+
else if (this.currentViewport === mqs.Name) {
|
|
170
300
|
break;
|
|
171
301
|
}
|
|
172
302
|
else {
|
|
@@ -180,31 +310,37 @@ export class ViewportService {
|
|
|
180
310
|
* @param width Width to get the according MQ for
|
|
181
311
|
*/
|
|
182
312
|
convertWidthToMediaQuery(width) {
|
|
183
|
-
let currentViewport =
|
|
184
|
-
for (const mqs of this.
|
|
185
|
-
if (width <= mqs.
|
|
186
|
-
currentViewport = mqs
|
|
313
|
+
let currentViewport = this.breakpoints[0];
|
|
314
|
+
for (const mqs of this.breakpoints) {
|
|
315
|
+
if (width <= mqs.High && width >= mqs.Low) {
|
|
316
|
+
currentViewport = mqs;
|
|
187
317
|
break;
|
|
188
318
|
}
|
|
189
319
|
}
|
|
190
320
|
return currentViewport;
|
|
191
321
|
}
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
322
|
+
/**
|
|
323
|
+
* Get the breakpoint/device name like mobile,tablet,desktop, high
|
|
324
|
+
*/
|
|
325
|
+
getSimpleBreakpoint(screenSize) {
|
|
326
|
+
let actualBreakpoint;
|
|
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
|
+
}
|
|
202
332
|
}
|
|
203
|
-
|
|
204
|
-
|
|
333
|
+
if (!actualBreakpoint) {
|
|
334
|
+
actualBreakpoint = sizes[0]; // default screensize is biggest. Will be used if viewport is bigger as maximum. Remember, array is reversed
|
|
205
335
|
}
|
|
336
|
+
return actualBreakpoint;
|
|
206
337
|
}
|
|
207
|
-
|
|
338
|
+
ngOnDestroy() {
|
|
339
|
+
if (this.isBrowser) {
|
|
340
|
+
window.removeEventListener('resize', this.documentSizeChanged);
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewportService, deps: [{ token: PLATFORM_ID }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
208
344
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewportService }); }
|
|
209
345
|
}
|
|
210
346
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewportService, decorators: [{
|
|
@@ -212,5 +348,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
212
348
|
}], ctorParameters: function () { return [{ type: Object, decorators: [{
|
|
213
349
|
type: Inject,
|
|
214
350
|
args: [PLATFORM_ID]
|
|
351
|
+
}] }, { type: Document, decorators: [{
|
|
352
|
+
type: Inject,
|
|
353
|
+
args: [DOCUMENT]
|
|
215
354
|
}] }]; } });
|
|
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"]}
|
|
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"]}
|
|
@@ -34,7 +34,7 @@ export class BackToTopComponent {
|
|
|
34
34
|
}
|
|
35
35
|
}
|
|
36
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"] }] }); }
|
|
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", "size", "dontUseSprite"] }] }); }
|
|
38
38
|
}
|
|
39
39
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BackToTopComponent, decorators: [{
|
|
40
40
|
type: Component,
|
|
@@ -99,6 +99,9 @@ export class DropdownFromDataComponent extends FormControlParentComponent {
|
|
|
99
99
|
if (this.translation.isPrefix) {
|
|
100
100
|
return this.translation.service?.instant?.(this.translation.path + '.' + key);
|
|
101
101
|
}
|
|
102
|
+
else if (this.translation.useKeyAsValue) {
|
|
103
|
+
return this.translation.service?.instant?.(this.translation.path, { key: key });
|
|
104
|
+
}
|
|
102
105
|
else {
|
|
103
106
|
return this.translation.service?.instant?.(this.translation.path);
|
|
104
107
|
}
|
|
@@ -112,13 +115,13 @@ export class DropdownFromDataComponent extends FormControlParentComponent {
|
|
|
112
115
|
this.onSelectItemEmitter.emit(value);
|
|
113
116
|
}
|
|
114
117
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DropdownFromDataComponent, deps: [{ token: i1.UntypedFormBuilder }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
115
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DropdownFromDataComponent, selector: "kms-dropdown-from-data", inputs: { optionsEnum: "optionsEnum", optionsPlainArray: "optionsPlainArray", optionsObjArray: "optionsObjArray", mapKey: "mapKey", mapValue: "mapValue", hasNullOption: "hasNullOption", translation: "translation", placeholder: "placeholder", label: "label", required: "required", useEnumIndexAsValue: "useEnumIndexAsValue", multiple: "multiple" }, providers: [
|
|
118
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DropdownFromDataComponent, selector: "kms-dropdown-from-data", inputs: { optionsEnum: "optionsEnum", optionsPlainArray: "optionsPlainArray", optionsObjArray: "optionsObjArray", mapKey: "mapKey", mapValue: "mapValue", hasNullOption: "hasNullOption", translation: "translation", placeholder: "placeholder", label: "label", required: "required", useEnumIndexAsValue: "useEnumIndexAsValue", multiple: "multiple", control: "control" }, providers: [
|
|
116
119
|
{
|
|
117
120
|
provide: NG_VALUE_ACCESSOR,
|
|
118
121
|
useExisting: forwardRef(() => DropdownFromDataComponent),
|
|
119
122
|
multi: true,
|
|
120
123
|
},
|
|
121
|
-
], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<form [formGroup]=\"form\">\n <mat-form-field\n [attr.required]=\"required\"\n [floatLabel]=\"placeholder ? 'always' : 'auto'\"\n >\n <mat-label>{{ label }}</mat-label>\n <mat-select\n placeholder=\"{{ placeholder }}\"\n disableOptionCentering\n [(value)]=\"value\"\n (selectionChange)=\"valueChanged($event?.value)\"\n #child\n [disabled]=\"disabled\"\n [multiple]=\"multiple\"\n >\n <mat-option *ngFor=\"let key of keys; let i = index\" [value]=\"values[i]\">\n <span>{{
|
|
124
|
+
], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<form [formGroup]=\"form\">\n <mat-form-field\n [attr.required]=\"required\"\n [floatLabel]=\"placeholder ? 'always' : 'auto'\"\n >\n <mat-label>{{ label }}</mat-label>\n <mat-select\n placeholder=\"{{ placeholder }}\"\n disableOptionCentering\n [(value)]=\"control?.value ? control.value : value\"\n (selectionChange)=\"valueChanged($event?.value)\"\n #child\n [disabled]=\"disabled\"\n [multiple]=\"multiple\"\n >\n <mat-option *ngFor=\"let key of keys; let i = index\" [value]=\"values[i]\">\n <span *ngIf=\"(hasNullOption && i != 0) || !hasNullOption\">{{\n setDisplayKey(key)\n }}</span>\n </mat-option>\n </mat-select>\n </mat-form-field>\n</form>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "component", type: i4.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "panelWidth", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "component", type: i5.MatOption, selector: "mat-option", exportAs: ["matOption"] }] }); }
|
|
122
125
|
}
|
|
123
126
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DropdownFromDataComponent, decorators: [{
|
|
124
127
|
type: Component,
|
|
@@ -128,7 +131,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
128
131
|
useExisting: forwardRef(() => DropdownFromDataComponent),
|
|
129
132
|
multi: true,
|
|
130
133
|
},
|
|
131
|
-
], template: "<form [formGroup]=\"form\">\n <mat-form-field\n [attr.required]=\"required\"\n [floatLabel]=\"placeholder ? 'always' : 'auto'\"\n >\n <mat-label>{{ label }}</mat-label>\n <mat-select\n placeholder=\"{{ placeholder }}\"\n disableOptionCentering\n [(value)]=\"value\"\n (selectionChange)=\"valueChanged($event?.value)\"\n #child\n [disabled]=\"disabled\"\n [multiple]=\"multiple\"\n >\n <mat-option *ngFor=\"let key of keys; let i = index\" [value]=\"values[i]\">\n <span>{{
|
|
134
|
+
], template: "<form [formGroup]=\"form\">\n <mat-form-field\n [attr.required]=\"required\"\n [floatLabel]=\"placeholder ? 'always' : 'auto'\"\n >\n <mat-label>{{ label }}</mat-label>\n <mat-select\n placeholder=\"{{ placeholder }}\"\n disableOptionCentering\n [(value)]=\"control?.value ? control.value : value\"\n (selectionChange)=\"valueChanged($event?.value)\"\n #child\n [disabled]=\"disabled\"\n [multiple]=\"multiple\"\n >\n <mat-option *ngFor=\"let key of keys; let i = index\" [value]=\"values[i]\">\n <span *ngIf=\"(hasNullOption && i != 0) || !hasNullOption\">{{\n setDisplayKey(key)\n }}</span>\n </mat-option>\n </mat-select>\n </mat-form-field>\n</form>\n" }]
|
|
132
135
|
}], ctorParameters: function () { return [{ type: i1.UntypedFormBuilder }, { type: i0.Renderer2 }]; }, propDecorators: { optionsEnum: [{
|
|
133
136
|
type: Input
|
|
134
137
|
}], optionsPlainArray: [{
|
|
@@ -153,5 +156,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
153
156
|
type: Input
|
|
154
157
|
}], multiple: [{
|
|
155
158
|
type: Input
|
|
159
|
+
}], control: [{
|
|
160
|
+
type: Input
|
|
156
161
|
}] } });
|
|
157
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-from-data.component.js","sourceRoot":"","sources":["../../../../../../../projects/kms-ngx-ui-presentational/src/lib/ui/dropdown-from-data/dropdown-from-data.component.ts","../../../../../../../projects/kms-ngx-ui-presentational/src/lib/ui/dropdown-from-data/dropdown-from-data.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  forwardRef,\n  Input,\n  OnInit,\n  OnChanges,\n  SimpleChanges,\n  Renderer2,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  UntypedFormBuilder,\n  NG_VALUE_ACCESSOR,\n} from '@angular/forms';\nimport { EnumValues } from 'enum-values/src/enumValues';\nimport { FormControlParentComponent } from '../../parent-components/form-control.component';\n\n/**\n * Dropdown from data component {@link https://leaseplan-dev.rentoffice.de/styleguide#ui-elements}\n */\n@Component({\n  selector: 'kms-dropdown-from-data',\n  templateUrl: './dropdown-from-data.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DropdownFromDataComponent),\n      multi: true,\n    },\n  ],\n})\nexport class DropdownFromDataComponent\n  extends FormControlParentComponent\n  implements OnInit, ControlValueAccessor, OnChanges\n{\n  // structured data as a enum set. Can be used in combination with 'optionsPlainArray' to set diferent values by index\n  @Input() optionsEnum: any;\n\n  // structured data as a simple array of elements\n  @Input() optionsPlainArray: any;\n\n  // structured data as an array of objects used in combination with the input 'mapKey' and 'mapValue'\n  @Input() optionsObjArray: any;\n  // key identifier of the obj. If mapValue doesnt exist, mapKey is also the value\n  @Input() mapKey?: any;\n  // value identifier of the obj\n  @Input() mapValue?: any;\n\n  // options for the dropdown have a null value at the beginning of the array\n  @Input() hasNullOption = false;\n\n  // translation object for the label and placeholder\n  @Input() translation?: ITranslation;\n  @Input() placeholder = '';\n  @Input() label = '';\n  @Input() required = false;\n  @Input() useEnumIndexAsValue = false;\n\n  // multiple selection\n  @Input() multiple = false;\n\n  public keys: any[] = [];\n  public values: any[] = [];\n\n  Object = Object;\n\n  constructor(\n    public formBuilder: UntypedFormBuilder,\n    public renderer: Renderer2\n  ) {\n    super(formBuilder, renderer);\n  }\n\n  /**\n   * Hook used to sync changes on set Label and Type\n   * @param changes\n   */\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.optionsPlainArray) {\n      this.values = this.optionsPlainArray;\n      this.keys = this.optionsPlainArray;\n    }\n    this.setKeyValues();\n  }\n\n  ngOnInit() {\n    this.form = this.formBuilder.group({\n      dropdownData: [],\n    });\n    this.formInitialized = true;\n\n    this.form.valueChanges.subscribe((value) => {\n      this.internalValue = value.dropdownData;\n      this.onChange(value.dropdownData);\n    });\n\n    super.ngOnInit();\n  }\n\n  /**\n   * transofrms the data values to the correct format for be used by the template\n   * @param value\n   */\n  private setKeyValues(): void {\n    if (this.optionsObjArray && this.mapKey && this.mapValue) {\n      this.keys = this.optionsObjArray.map((obj: any) => obj[`${this.mapKey}`]);\n      this.values = this.optionsObjArray.map(\n        (obj: any) => obj[`${this.mapValue}`]\n      );\n    } else if (this.optionsObjArray && this.mapKey) {\n      this.keys = this.optionsObjArray.map((obj: any) => obj[`${this.mapKey}`]);\n      this.values = this.optionsObjArray.map(\n        (obj: any) => obj[`${this.mapKey}`]\n      );\n    }\n    if (this.optionsEnum) {\n      this.keys = EnumValues.getNames(this.optionsEnum);\n      if (this.optionsPlainArray) {\n        this.values = this.optionsPlainArray;\n      } else {\n        const values = EnumValues.getValues(this.optionsEnum);\n\n        // var who defines if enum is componed just with keys or keyValues. E.g enum KeyEnum { VALUE1, VALUE2 } or enum KeyValueEnum { VALUE4 = 'V4', VALUE5 = 'V5' }\n        let keyValueEnum = false;\n\n        for (let i = 0; i < this.keys.length; i++) {\n          if (i !== values[i]) {\n            keyValueEnum = true;\n          }\n        }\n        if (keyValueEnum || this.useEnumIndexAsValue) {\n          this.values = values;\n        } else {\n          this.values = EnumValues.getNames(this.optionsEnum);\n        }\n      }\n    }\n    if (this.hasNullOption === true) this.keys.unshift(null);\n    if (this.hasNullOption === true) this.values.unshift(null);\n  }\n\n  /**\n   * set the value of the dropdown based if translation is set\n   * @param key\n   */\n  public setDisplayKey(key: any) {\n    if (this.translation) {\n      if (this.translation.isPrefix) {\n        return this.translation.service?.instant?.(\n          this.translation.path + '.' + key\n        );\n      } else {\n        return this.translation.service?.instant?.(this.translation.path);\n      }\n    }\n    return key;\n  }\n\n  valueChanged(value: any) {\n    this.form.patchValue({\n      dropdownData: value,\n    });\n    this.onSelectItemEmitter.emit(value);\n  }\n}\n\n/**\n * Interface that defines the translation object in template\n */\ninterface ITranslation {\n  path: string;\n  isPrefix?: boolean;\n  service: any;\n}\n","<form [formGroup]=\"form\">\n  <mat-form-field\n    [attr.required]=\"required\"\n    [floatLabel]=\"placeholder ? 'always' : 'auto'\"\n  >\n    <mat-label>{{ label }}</mat-label>\n    <mat-select\n      placeholder=\"{{ placeholder }}\"\n      disableOptionCentering\n      [(value)]=\"value\"\n      (selectionChange)=\"valueChanged($event?.value)\"\n      #child\n      [disabled]=\"disabled\"\n      [multiple]=\"multiple\"\n    >\n      <mat-option *ngFor=\"let key of keys; let i = index\" [value]=\"values[i]\">\n        <span>{{ setDisplayKey(key) }}</span>\n      </mat-option>\n    </mat-select>\n  </mat-form-field>\n</form>\n"]}
|
|
162
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-from-data.component.js","sourceRoot":"","sources":["../../../../../../../projects/kms-ngx-ui-presentational/src/lib/ui/dropdown-from-data/dropdown-from-data.component.ts","../../../../../../../projects/kms-ngx-ui-presentational/src/lib/ui/dropdown-from-data/dropdown-from-data.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,UAAU,EACV,KAAK,GAKN,MAAM,eAAe,CAAC;AACvB,OAAO,EAGL,iBAAiB,GAElB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AACxD,OAAO,EAAE,0BAA0B,EAAE,MAAM,gDAAgD,CAAC;;;;;;;AAE5F;;GAEG;AAYH,MAAM,OAAO,yBACX,SAAQ,0BAA0B;IAoClC,YACS,WAA+B,EAC/B,QAAmB;QAE1B,KAAK,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QAHtB,gBAAW,GAAX,WAAW,CAAoB;QAC/B,aAAQ,GAAR,QAAQ,CAAW;QAtB5B,2EAA2E;QAClE,kBAAa,GAAG,KAAK,CAAC;QAItB,gBAAW,GAAG,EAAE,CAAC;QACjB,UAAK,GAAG,EAAE,CAAC;QACX,aAAQ,GAAG,KAAK,CAAC;QACjB,wBAAmB,GAAG,KAAK,CAAC;QAErC,qBAAqB;QACZ,aAAQ,GAAG,KAAK,CAAC;QAInB,SAAI,GAAU,EAAE,CAAC;QACjB,WAAM,GAAU,EAAE,CAAC;QAE1B,WAAM,GAAG,MAAM,CAAC;IAOhB,CAAC;IAED;;;OAGG;IACH,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,iBAAiB,EAAE;YAC7B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,iBAAiB,CAAC;YACrC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,iBAAiB,CAAC;SACpC;QACD,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;YACjC,YAAY,EAAE,EAAE;SACjB,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAE5B,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACzC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,YAAY,CAAC;YACxC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,QAAQ,EAAE,CAAC;IACnB,CAAC;IAED;;;OAGG;IACK,YAAY;QAClB,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,QAAQ,EAAE;YACxD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAC1E,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CACpC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,CACtC,CAAC;SACH;aAAM,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,MAAM,EAAE;YAC9C,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAC1E,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CACpC,CAAC,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,CACpC,CAAC;SACH;QACD,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YAClD,IAAI,IAAI,CAAC,iBAAiB,EAAE;gBAC1B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,iBAAiB,CAAC;aACtC;iBAAM;gBACL,MAAM,MAAM,GAAG,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBAEtD,6JAA6J;gBAC7J,IAAI,YAAY,GAAG,KAAK,CAAC;gBAEzB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBACzC,IAAI,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,EAAE;wBACnB,YAAY,GAAG,IAAI,CAAC;qBACrB;iBACF;gBACD,IAAI,YAAY,IAAI,IAAI,CAAC,mBAAmB,EAAE;oBAC5C,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;iBACtB;qBAAM;oBACL,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;iBACrD;aACF;SACF;QACD,IAAI,IAAI,CAAC,aAAa,KAAK,IAAI;YAAE,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACzD,IAAI,IAAI,CAAC,aAAa,KAAK,IAAI;YAAE,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7D,CAAC;IAED;;;OAGG;IACI,aAAa,CAAC,GAAQ;QAC3B,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE;gBAC7B,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,OAAO,EAAE,CACxC,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,GAAG,GAAG,GAAG,CAClC,CAAC;aACH;iBAAM,IAAI,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE;gBACzC,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;aACjF;iBAAM;gBACL,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;aACnE;SACF;QACD,OAAO,GAAG,CAAC;IACb,CAAC;IAED,YAAY,CAAC,KAAU;QACrB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;YACnB,YAAY,EAAE,KAAK;SACpB,CAAC,CAAC;QACH,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACvC,CAAC;+GAxIU,yBAAyB;mGAAzB,yBAAyB,iaARzB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC;gBACxD,KAAK,EAAE,IAAI;aACZ;SACF,sEC9BH,0uBAuBA;;4FDSa,yBAAyB;kBAXrC,SAAS;+BACE,wBAAwB,aAEvB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,0BAA0B,CAAC;4BACxD,KAAK,EAAE,IAAI;yBACZ;qBACF;iIAOQ,WAAW;sBAAnB,KAAK;gBAGG,iBAAiB;sBAAzB,KAAK;gBAGG,eAAe;sBAAvB,KAAK;gBAEG,MAAM;sBAAd,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,WAAW;sBAAnB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBAGG,QAAQ;sBAAhB,KAAK;gBAEG,OAAO;sBAAf,KAAK","sourcesContent":["import {\n  Component,\n  forwardRef,\n  Input,\n  OnInit,\n  OnChanges,\n  SimpleChanges,\n  Renderer2,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  UntypedFormBuilder,\n  NG_VALUE_ACCESSOR,\n  AbstractControl,\n} from '@angular/forms';\nimport { EnumValues } from 'enum-values/src/enumValues';\nimport { FormControlParentComponent } from '../../parent-components/form-control.component';\n\n/**\n * Dropdown from data component {@link https://leaseplan-dev.rentoffice.de/styleguide#ui-elements}\n */\n@Component({\n  selector: 'kms-dropdown-from-data',\n  templateUrl: './dropdown-from-data.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DropdownFromDataComponent),\n      multi: true,\n    },\n  ],\n})\nexport class DropdownFromDataComponent\n  extends FormControlParentComponent\n  implements OnInit, ControlValueAccessor, OnChanges\n{\n  // structured data as a enum set. Can be used in combination with 'optionsPlainArray' to set diferent values by index\n  @Input() optionsEnum: any;\n\n  // structured data as a simple array of elements\n  @Input() optionsPlainArray: any;\n\n  // structured data as an array of objects used in combination with the input 'mapKey' and 'mapValue'\n  @Input() optionsObjArray: any;\n  // key identifier of the obj. If mapValue doesnt exist, mapKey is also the value\n  @Input() mapKey?: any;\n  // value identifier of the obj\n  @Input() mapValue?: any;\n\n  // options for the dropdown have a null value at the beginning of the array\n  @Input() hasNullOption = false;\n\n  // translation object for the label and placeholder\n  @Input() translation?: ITranslation;\n  @Input() placeholder = '';\n  @Input() label = '';\n  @Input() required = false;\n  @Input() useEnumIndexAsValue = false;\n\n  // multiple selection\n  @Input() multiple = false;\n\n  @Input() control?: AbstractControl;\n\n  public keys: any[] = [];\n  public values: any[] = [];\n\n  Object = Object;\n\n  constructor(\n    public formBuilder: UntypedFormBuilder,\n    public renderer: Renderer2\n  ) {\n    super(formBuilder, renderer);\n  }\n\n  /**\n   * Hook used to sync changes on set Label and Type\n   * @param changes\n   */\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.optionsPlainArray) {\n      this.values = this.optionsPlainArray;\n      this.keys = this.optionsPlainArray;\n    }\n    this.setKeyValues();\n  }\n\n  ngOnInit() {\n    this.form = this.formBuilder.group({\n      dropdownData: [],\n    });\n    this.formInitialized = true;\n\n    this.form.valueChanges.subscribe((value) => {\n      this.internalValue = value.dropdownData;\n      this.onChange(value.dropdownData);\n    });\n\n    super.ngOnInit();\n  }\n\n  /**\n   * transofrms the data values to the correct format for be used by the template\n   * @param value\n   */\n  private setKeyValues(): void {\n    if (this.optionsObjArray && this.mapKey && this.mapValue) {\n      this.keys = this.optionsObjArray.map((obj: any) => obj[`${this.mapKey}`]);\n      this.values = this.optionsObjArray.map(\n        (obj: any) => obj[`${this.mapValue}`]\n      );\n    } else if (this.optionsObjArray && this.mapKey) {\n      this.keys = this.optionsObjArray.map((obj: any) => obj[`${this.mapKey}`]);\n      this.values = this.optionsObjArray.map(\n        (obj: any) => obj[`${this.mapKey}`]\n      );\n    }\n    if (this.optionsEnum) {\n      this.keys = EnumValues.getNames(this.optionsEnum);\n      if (this.optionsPlainArray) {\n        this.values = this.optionsPlainArray;\n      } else {\n        const values = EnumValues.getValues(this.optionsEnum);\n\n        // var who defines if enum is componed just with keys or keyValues. E.g enum KeyEnum { VALUE1, VALUE2 } or enum KeyValueEnum { VALUE4 = 'V4', VALUE5 = 'V5' }\n        let keyValueEnum = false;\n\n        for (let i = 0; i < this.keys.length; i++) {\n          if (i !== values[i]) {\n            keyValueEnum = true;\n          }\n        }\n        if (keyValueEnum || this.useEnumIndexAsValue) {\n          this.values = values;\n        } else {\n          this.values = EnumValues.getNames(this.optionsEnum);\n        }\n      }\n    }\n    if (this.hasNullOption === true) this.keys.unshift(null);\n    if (this.hasNullOption === true) this.values.unshift(null);\n  }\n\n  /**\n   * set the value of the dropdown based if translation is set\n   * @param key\n   */\n  public setDisplayKey(key: any) {\n    if (this.translation) {\n      if (this.translation.isPrefix) {\n        return this.translation.service?.instant?.(\n          this.translation.path + '.' + key\n        );\n      } else if (this.translation.useKeyAsValue) {\n        return this.translation.service?.instant?.(this.translation.path, { key: key });\n      } else {\n        return this.translation.service?.instant?.(this.translation.path);\n      }\n    }\n    return key;\n  }\n\n  valueChanged(value: any) {\n    this.form.patchValue({\n      dropdownData: value,\n    });\n    this.onSelectItemEmitter.emit(value);\n  }\n}\n\n/**\n * Interface that defines the translation object in template\n */\ninterface ITranslation {\n  path: string;\n  isPrefix?: boolean;\n  useKeyAsValue?: boolean;\n  service: any;\n}\n","<form [formGroup]=\"form\">\n  <mat-form-field\n    [attr.required]=\"required\"\n    [floatLabel]=\"placeholder ? 'always' : 'auto'\"\n  >\n    <mat-label>{{ label }}</mat-label>\n    <mat-select\n      placeholder=\"{{ placeholder }}\"\n      disableOptionCentering\n      [(value)]=\"control?.value ? control.value : value\"\n      (selectionChange)=\"valueChanged($event?.value)\"\n      #child\n      [disabled]=\"disabled\"\n      [multiple]=\"multiple\"\n    >\n      <mat-option *ngFor=\"let key of keys; let i = index\" [value]=\"values[i]\">\n        <span *ngIf=\"(hasNullOption && i != 0) || !hasNullOption\">{{\n          setDisplayKey(key)\n        }}</span>\n      </mat-option>\n    </mat-select>\n  </mat-form-field>\n</form>\n"]}
|