@kms-ngx-ui/presentational 0.0.1
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/README.md +24 -0
- package/bundles/kms-ngx-ui-presentational.umd.js +2441 -0
- package/bundles/kms-ngx-ui-presentational.umd.js.map +1 -0
- package/bundles/kms-ngx-ui-presentational.umd.min.js +38 -0
- package/bundles/kms-ngx-ui-presentational.umd.min.js.map +1 -0
- package/esm2015/kms-ngx-ui-presentational.js +37 -0
- package/esm2015/lib/kms-ngx-ui-presentational.component.js +18 -0
- package/esm2015/lib/kms-ngx-ui-presentational.module.js +98 -0
- package/esm2015/lib/kms-ngx-ui-presentational.service.js +13 -0
- package/esm2015/lib/models/address.model.js +6 -0
- package/esm2015/lib/models/iconSize.enum.js +17 -0
- package/esm2015/lib/models/index.js +5 -0
- package/esm2015/lib/models/is-value.function.js +17 -0
- package/esm2015/lib/models/salutation.enum.js +8 -0
- package/esm2015/lib/models/types/attached-file-dto.model.js +6 -0
- package/esm2015/lib/models/types/nullable.type.js +5 -0
- package/esm2015/lib/parent-components/actions.component.js +48 -0
- package/esm2015/lib/parent-components/form-control.component.js +73 -0
- package/esm2015/lib/parent-components/form.component.js +77 -0
- package/esm2015/lib/pipes/custom-pipes.module.js +45 -0
- package/esm2015/lib/pipes/decode-uri.pipe.js +15 -0
- package/esm2015/lib/pipes/encode-uri.pipe.js +15 -0
- package/esm2015/lib/pipes/integer-currency.pipe.js +29 -0
- package/esm2015/lib/pipes/safe-html.pipe.js +22 -0
- package/esm2015/lib/pipes/safe-style.pipe.js +22 -0
- package/esm2015/lib/pipes/safe-url.pipe.js +22 -0
- package/esm2015/lib/pipes/to-number.pipe.js +19 -0
- package/esm2015/lib/pipes/trim.pipe.js +16 -0
- package/esm2015/lib/pipes/typeof.pipe.js +12 -0
- package/esm2015/lib/services/viewport.service.js +213 -0
- package/esm2015/lib/ui/back-to-top/back-to-top.component.js +46 -0
- package/esm2015/lib/ui/button-with-confirm-dialog/button-response-types.enum.js +6 -0
- package/esm2015/lib/ui/button-with-confirm-dialog/button-with-confirm-dialog.component.js +56 -0
- package/esm2015/lib/ui/button-with-confirm-dialog/dialog-data.model.js +2 -0
- package/esm2015/lib/ui/checkbox/checkbox.component.js +63 -0
- package/esm2015/lib/ui/color-input/color-input.component.js +63 -0
- package/esm2015/lib/ui/enum-radiogroup/enum-radiogroup.component.js +46 -0
- package/esm2015/lib/ui/file-input/file-input.component.js +215 -0
- package/esm2015/lib/ui/flyout/flyout.component.js +84 -0
- package/esm2015/lib/ui/generic-dialog/generic-dialog.component.js +54 -0
- package/esm2015/lib/ui/icon/icon.component.js +47 -0
- package/esm2015/lib/ui/icon/iconSize.enum.js +17 -0
- package/esm2015/lib/ui/kms-accordion-item/kms-accordion-item.component.js +36 -0
- package/esm2015/lib/ui/loader/loader.component.js +21 -0
- package/esm2015/lib/ui/map/map.component.js +137 -0
- package/esm2015/lib/ui/radiobutton/radiobutton.component.js +66 -0
- package/esm2015/lib/ui/salutation-dropdown/salutation-dropdown.component.js +49 -0
- package/esm2015/lib/ui/salutation-radiogroup/salutation-radiogroup.component.js +44 -0
- package/esm2015/lib/ui/time-input/time-input.component.js +80 -0
- package/esm2015/lib/ui/tooltip/tooltip.component.js +17 -0
- package/esm2015/lib/ui/tooltip-icon/tooltip-icon.component.js +29 -0
- package/esm2015/lib/ui/yes-no-radiogroup/yes-no-radiogroup.component.js +74 -0
- package/esm2015/public-api.js +12 -0
- package/fesm2015/kms-ngx-ui-presentational.js +1962 -0
- package/fesm2015/kms-ngx-ui-presentational.js.map +1 -0
- package/kms-ngx-ui-presentational.d.ts +37 -0
- package/kms-ngx-ui-presentational.metadata.json +1 -0
- package/lib/kms-ngx-ui-presentational.component.d.ts +5 -0
- package/lib/kms-ngx-ui-presentational.module.d.ts +2 -0
- package/lib/kms-ngx-ui-presentational.service.d.ts +3 -0
- package/lib/models/address.model.d.ts +14 -0
- package/lib/models/iconSize.enum.d.ts +15 -0
- package/lib/models/index.d.ts +4 -0
- package/lib/models/is-value.function.d.ts +9 -0
- package/lib/models/salutation.enum.d.ts +5 -0
- package/lib/models/types/attached-file-dto.model.d.ts +11 -0
- package/lib/models/types/nullable.type.d.ts +4 -0
- package/lib/parent-components/actions.component.d.ts +28 -0
- package/lib/parent-components/form-control.component.d.ts +24 -0
- package/lib/parent-components/form.component.d.ts +31 -0
- package/lib/pipes/custom-pipes.module.d.ts +5 -0
- package/lib/pipes/decode-uri.pipe.d.ts +7 -0
- package/lib/pipes/encode-uri.pipe.d.ts +7 -0
- package/lib/pipes/integer-currency.pipe.d.ts +10 -0
- package/lib/pipes/safe-html.pipe.d.ts +10 -0
- package/lib/pipes/safe-style.pipe.d.ts +10 -0
- package/lib/pipes/safe-url.pipe.d.ts +10 -0
- package/lib/pipes/to-number.pipe.d.ts +7 -0
- package/lib/pipes/trim.pipe.d.ts +7 -0
- package/lib/pipes/typeof.pipe.d.ts +4 -0
- package/lib/services/viewport.service.d.ts +74 -0
- package/lib/ui/back-to-top/back-to-top.component.d.ts +10 -0
- package/lib/ui/button-with-confirm-dialog/button-response-types.enum.d.ts +4 -0
- package/lib/ui/button-with-confirm-dialog/button-with-confirm-dialog.component.d.ts +16 -0
- package/lib/ui/button-with-confirm-dialog/dialog-data.model.d.ts +9 -0
- package/lib/ui/checkbox/checkbox.component.d.ts +28 -0
- package/lib/ui/color-input/color-input.component.d.ts +15 -0
- package/lib/ui/enum-radiogroup/enum-radiogroup.component.d.ts +14 -0
- package/lib/ui/file-input/file-input.component.d.ts +86 -0
- package/lib/ui/flyout/flyout.component.d.ts +32 -0
- package/lib/ui/generic-dialog/generic-dialog.component.d.ts +23 -0
- package/lib/ui/icon/icon.component.d.ts +39 -0
- package/lib/ui/icon/iconSize.enum.d.ts +15 -0
- package/lib/ui/kms-accordion-item/kms-accordion-item.component.d.ts +18 -0
- package/lib/ui/loader/loader.component.d.ts +6 -0
- package/lib/ui/map/map.component.d.ts +70 -0
- package/lib/ui/radiobutton/radiobutton.component.d.ts +23 -0
- package/lib/ui/salutation-dropdown/salutation-dropdown.component.d.ts +14 -0
- package/lib/ui/salutation-radiogroup/salutation-radiogroup.component.d.ts +12 -0
- package/lib/ui/time-input/time-input.component.d.ts +19 -0
- package/lib/ui/tooltip/tooltip.component.d.ts +3 -0
- package/lib/ui/tooltip-icon/tooltip-icon.component.d.ts +10 -0
- package/lib/ui/yes-no-radiogroup/yes-no-radiogroup.component.d.ts +24 -0
- package/package.json +25 -0
- package/public-api.d.ts +6 -0
- package/src/lib/ui/back-to-top/back-to-top.component.scss +47 -0
- package/src/lib/ui/button-with-confirm-dialog/button-with-confirm-dialog.component.scss +0 -0
- package/src/lib/ui/checkbox/checkbox.component.scss +57 -0
- package/src/lib/ui/color-input/color-input.component.scss +38 -0
- package/src/lib/ui/file-input/file-input.component.scss +0 -0
- package/src/lib/ui/flyout/flyout.component.scss +34 -0
- package/src/lib/ui/generic-dialog/generic-dialog.component.scss +59 -0
- package/src/lib/ui/icon/icon.component.scss +149 -0
- package/src/lib/ui/kms-accordion-item/kms-accordion-item.component.scss +95 -0
- package/src/lib/ui/loader/loader.component.scss +0 -0
- package/src/lib/ui/map/map.component.scss +0 -0
- package/src/lib/ui/radiobutton/radiobutton.component.scss +30 -0
- package/src/lib/ui/time-input/time-input.component.scss +10 -0
- package/src/lib/ui/tooltip/tooltip.component.scss +27 -0
- package/src/lib/ui/tooltip-icon/tooltip-icon.component.scss +2 -0
- package/src/styles/mixins.scss +9 -0
- package/src/styles/styles.scss +30 -0
|
@@ -0,0 +1,215 @@
|
|
|
1
|
+
import { Component, Input, forwardRef, ViewChild, Renderer2, EventEmitter, Output, ApplicationRef, ChangeDetectorRef } from '@angular/core';
|
|
2
|
+
import { FormBuilder, FormControl, NG_VALIDATORS, NG_VALUE_ACCESSOR, } from '@angular/forms';
|
|
3
|
+
//import { TranslateService } from '@ngx-translate/core';
|
|
4
|
+
import { IconSize } from '../../models/iconSize.enum';
|
|
5
|
+
import { isValue } from '../../models/is-value.function';
|
|
6
|
+
// Max size in bytes of uploaded image
|
|
7
|
+
const MAX_SIZE_BYTES = 2097152;
|
|
8
|
+
export class FileInputComponent {
|
|
9
|
+
/**
|
|
10
|
+
* Constructor
|
|
11
|
+
* @param formBuilder
|
|
12
|
+
* @param appRef
|
|
13
|
+
* @param cd
|
|
14
|
+
* @param translateService
|
|
15
|
+
* @param renderer
|
|
16
|
+
*/
|
|
17
|
+
constructor(formBuilder, appRef, cd,
|
|
18
|
+
//private translateService: TranslateService,
|
|
19
|
+
renderer) {
|
|
20
|
+
this.formBuilder = formBuilder;
|
|
21
|
+
this.appRef = appRef;
|
|
22
|
+
this.cd = cd;
|
|
23
|
+
this.renderer = renderer;
|
|
24
|
+
this.label = '';
|
|
25
|
+
this.previewImage = true;
|
|
26
|
+
this.allowRemove = true;
|
|
27
|
+
this.previewImageText = '';
|
|
28
|
+
this.maxSizeBytes = MAX_SIZE_BYTES;
|
|
29
|
+
this.resizePixels = 0;
|
|
30
|
+
this.acceptedFileMimetypes = 'image/jpeg, image/jpg, image/png';
|
|
31
|
+
this.form = this.formBuilder.group({
|
|
32
|
+
ImageIdent: new FormControl(''),
|
|
33
|
+
ImageLink: new FormControl(''),
|
|
34
|
+
Filename: new FormControl(''),
|
|
35
|
+
ImageAsDataURL: new FormControl(''),
|
|
36
|
+
Text: new FormControl(''),
|
|
37
|
+
});
|
|
38
|
+
this.subscriptions = [];
|
|
39
|
+
this.newImageLoading = false;
|
|
40
|
+
this.IconSize = IconSize;
|
|
41
|
+
this.formDataChanged = new EventEmitter();
|
|
42
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
43
|
+
this.onChange = () => { };
|
|
44
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
45
|
+
this.onTouch = () => { };
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Click on button triggers file-input to open OS file dialog
|
|
49
|
+
*/
|
|
50
|
+
selectImageOverlay() {
|
|
51
|
+
this.fileInput.nativeElement.click();
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Function to manage the input image
|
|
55
|
+
* Returns an error if the file exceeds maximum wanted filesize (Mb).
|
|
56
|
+
* @param ev
|
|
57
|
+
* @returns
|
|
58
|
+
*/
|
|
59
|
+
selectImage(ev) {
|
|
60
|
+
if (ev.target.files && ev.target.files[0]) {
|
|
61
|
+
const file = ev.target.files[0];
|
|
62
|
+
if (file.size > this.maxSizeBytes) {
|
|
63
|
+
this.clearInputValue(ev);
|
|
64
|
+
//alert(this.translateService.instant('errors.fileTooBig'));
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
this.newImageLoading = true;
|
|
69
|
+
if (this.resizePixels > 0) {
|
|
70
|
+
const logoUrl = URL.createObjectURL(file);
|
|
71
|
+
const imgEl = document.createElement('img');
|
|
72
|
+
imgEl.addEventListener('load', () => {
|
|
73
|
+
const resizedLogo = this.resizeImage(imgEl, this.resizePixels);
|
|
74
|
+
const newFile = this.generateModel(file.name, resizedLogo, this.value.ImageIdent, this.value.ImageLink, this.value.Text);
|
|
75
|
+
this.value = newFile;
|
|
76
|
+
this.newImageLoading = false;
|
|
77
|
+
this.cd.markForCheck();
|
|
78
|
+
});
|
|
79
|
+
imgEl.src = logoUrl;
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
const reader = new FileReader();
|
|
83
|
+
reader.readAsDataURL(file);
|
|
84
|
+
reader.onload = (e) => {
|
|
85
|
+
const newFile = this.generateModel(file.name, e.target.result, this.value.ImageIdent, this.value.ImageLink, this.value.Text);
|
|
86
|
+
this.value = newFile;
|
|
87
|
+
this.newImageLoading = false;
|
|
88
|
+
this.cd.markForCheck();
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
console.warn("No file selected");
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Resize an image
|
|
99
|
+
* @param imgEl
|
|
100
|
+
* @param wantedWidth as number
|
|
101
|
+
* @returns string
|
|
102
|
+
*/
|
|
103
|
+
resizeImage(imgEl, wantedWidth) {
|
|
104
|
+
const canvas = document.createElement('canvas');
|
|
105
|
+
const ctx = canvas.getContext('2d');
|
|
106
|
+
const aspect = imgEl.width / imgEl.height;
|
|
107
|
+
canvas.width = wantedWidth;
|
|
108
|
+
canvas.height = wantedWidth / aspect;
|
|
109
|
+
if (isValue(ctx))
|
|
110
|
+
ctx.drawImage(imgEl, 0, 0, canvas.width, canvas.height);
|
|
111
|
+
return canvas.toDataURL();
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Generate default object
|
|
115
|
+
* @param name as string
|
|
116
|
+
* @param content as string
|
|
117
|
+
* @returns AttachedFileDTO
|
|
118
|
+
*/
|
|
119
|
+
generateModel(name, content, ident, imageLink, text) {
|
|
120
|
+
return {
|
|
121
|
+
ImageIdent: ident ? ident : '',
|
|
122
|
+
Filename: name ? name : '',
|
|
123
|
+
ImageAsDataURL: content ? content : '',
|
|
124
|
+
ImageLink: imageLink ? imageLink : '',
|
|
125
|
+
Text: text ? text : ''
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Remove image
|
|
130
|
+
*/
|
|
131
|
+
removeFromList() {
|
|
132
|
+
this.value = this.generateModel('', '', '', '');
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* get value
|
|
136
|
+
*/
|
|
137
|
+
get value() {
|
|
138
|
+
return this.form.value;
|
|
139
|
+
}
|
|
140
|
+
/**
|
|
141
|
+
* set value
|
|
142
|
+
*/
|
|
143
|
+
set value(value) {
|
|
144
|
+
this.form.setValue(value);
|
|
145
|
+
this.onChange(value);
|
|
146
|
+
this.formDataChanged.emit(this.form);
|
|
147
|
+
}
|
|
148
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
149
|
+
ngOnInit() { }
|
|
150
|
+
ngOnDestroy() {
|
|
151
|
+
this.subscriptions.forEach(s => s.unsubscribe());
|
|
152
|
+
}
|
|
153
|
+
registerOnChange(fn) {
|
|
154
|
+
this.onChange = fn;
|
|
155
|
+
}
|
|
156
|
+
registerOnTouched(fn) {
|
|
157
|
+
this.onTouch = fn;
|
|
158
|
+
}
|
|
159
|
+
writeValue(value) {
|
|
160
|
+
if (value) {
|
|
161
|
+
this.value = value;
|
|
162
|
+
}
|
|
163
|
+
if (value === null) {
|
|
164
|
+
this.form.reset();
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
// eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures
|
|
168
|
+
validate(_) {
|
|
169
|
+
return this.form.valid ? null : { styles: { valid: false } };
|
|
170
|
+
}
|
|
171
|
+
/**
|
|
172
|
+
* OnClick event listener of input#fileInput to clear his input value
|
|
173
|
+
*/
|
|
174
|
+
clearInputValue(ev) {
|
|
175
|
+
const element = ev.target;
|
|
176
|
+
element.value = '';
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
FileInputComponent.decorators = [
|
|
180
|
+
{ type: Component, args: [{
|
|
181
|
+
selector: 'kms-file-input',
|
|
182
|
+
template: "<form [formGroup]=\"form\" (change)=\"newImageLoading=true\" class=\"fileInput\"> \n\n <div *ngIf=\"form.value.Filename && previewImage\">\n <div *ngIf=\"newImageLoading\">\n {{ 'file-input.loading' | translate }}\n </div>\n <div *ngIf=\"!newImageLoading\">\n <div class=\"\">\n <div class=\"\">\n <img *ngIf=\"form.value.ImageLink && form.value.ImageLink !== '' && !(form.value.ImageAsDataURL && form.value.ImageAsDataURL !== '')\" [src]=\"form.value.ImageAsDataURL\" [src]=\"form.value.ImageLink\" style=\"height: 40px; width: fit-content;\" />\n <img *ngIf=\"form.value.ImageAsDataURL && form.value.ImageAsDataURL !== ''\" [src]=\"form.value.ImageAsDataURL\" style=\"height: 40px; width: fit-content;\" />\n </div>\n <div class=\"\">{{form.value.Filename}}</div>\n <div class=\"\">\n <div (click)=\"removeFromList()\" *ngIf=\"allowRemove\">\n <kms-icon icon=\"trash\" [iconSize]=\"IconSize.TINY\" iconClass=\"color-black\"></kms-icon> \n {{ 'file-input.remove' }}\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"!previewImage\">\n <div class=\"\">{{form.value.Filename}}</div>\n </div>\n\n <button (click)=\"selectImageOverlay()\" class=\"button-primary-font-color\" mat-stroked-button>\n <span>{{ label }}</span>\n </button>\n <input\n type=\"file\"\n [accept]=\"acceptedFileMimetypes\"\n style=\"display: none\"\n #fileInput\n (click)=\"clearInputValue($event)\"\n (change)=\"selectImage($event)\"\n />\n\n <input type=\"hidden\" [formControl]=\"form.controls['ImageIdent']\" />\n <input type=\"hidden\" [formControl]=\"form.controls['ImageLink']\" />\n <input type=\"hidden\" [formControl]=\"form.controls['Filename']\" />\n <input type=\"hidden\" [formControl]=\"form.controls['ImageAsDataURL']\" />\n <input type=\"hidden\" [formControl]=\"form.controls['Text']\" />\n\n</form>",
|
|
183
|
+
providers: [
|
|
184
|
+
{
|
|
185
|
+
provide: NG_VALUE_ACCESSOR,
|
|
186
|
+
useExisting: forwardRef(() => FileInputComponent),
|
|
187
|
+
multi: true,
|
|
188
|
+
},
|
|
189
|
+
{
|
|
190
|
+
provide: NG_VALIDATORS,
|
|
191
|
+
useExisting: forwardRef(() => FileInputComponent),
|
|
192
|
+
multi: true,
|
|
193
|
+
},
|
|
194
|
+
],
|
|
195
|
+
styles: [""]
|
|
196
|
+
},] }
|
|
197
|
+
];
|
|
198
|
+
FileInputComponent.ctorParameters = () => [
|
|
199
|
+
{ type: FormBuilder },
|
|
200
|
+
{ type: ApplicationRef },
|
|
201
|
+
{ type: ChangeDetectorRef },
|
|
202
|
+
{ type: Renderer2 }
|
|
203
|
+
];
|
|
204
|
+
FileInputComponent.propDecorators = {
|
|
205
|
+
fileInput: [{ type: ViewChild, args: ['fileInput',] }],
|
|
206
|
+
label: [{ type: Input }],
|
|
207
|
+
previewImage: [{ type: Input }],
|
|
208
|
+
allowRemove: [{ type: Input }],
|
|
209
|
+
previewImageText: [{ type: Input }],
|
|
210
|
+
maxSizeBytes: [{ type: Input }],
|
|
211
|
+
resizePixels: [{ type: Input }],
|
|
212
|
+
acceptedFileMimetypes: [{ type: Input }],
|
|
213
|
+
formDataChanged: [{ type: Output }]
|
|
214
|
+
};
|
|
215
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/kms-ngx-ui-presentational/src/lib/ui/file-input/file-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, forwardRef, OnInit, ViewChild, Renderer2, EventEmitter, Output, ApplicationRef, ChangeDetectorRef } from '@angular/core';\n\nimport {\n    ControlValueAccessor,\n    FormBuilder,\n    FormControl,\n    FormGroup,\n    NG_VALIDATORS,\n    NG_VALUE_ACCESSOR,\n} from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\n//import { TranslateService } from '@ngx-translate/core';\nimport { IconSize } from '../../models/iconSize.enum';\nimport { AttachedFileDTO } from '../../models/types/attached-file-dto.model';\nimport { isValue } from '../../models/is-value.function';\n\n// Max size in bytes of uploaded image\nconst MAX_SIZE_BYTES = 2097152;\n\n@Component({\n    selector: 'kms-file-input',\n    templateUrl: './file-input.component.html',\n    styleUrls: ['./file-input.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => FileInputComponent),\n            multi: true,\n        },\n        {\n            provide: NG_VALIDATORS,\n            useExisting: forwardRef(() => FileInputComponent),\n            multi: true,\n        },\n    ],\n})\n\nexport class FileInputComponent implements ControlValueAccessor, OnInit {\n    \n    @ViewChild('fileInput') public fileInput: any;\n\n    @Input() label = '';\n    \n    @Input() previewImage = true; \n    @Input() allowRemove = true; \n    @Input() previewImageText = ''; \n    @Input() maxSizeBytes = MAX_SIZE_BYTES; \n    @Input() resizePixels = 0; \n    @Input() acceptedFileMimetypes = 'image/jpeg, image/jpg, image/png'; \n\n    form= this.formBuilder.group({\n        ImageIdent: new FormControl(''),\n        ImageLink: new FormControl(''),\n        Filename: new FormControl(''),\n        ImageAsDataURL: new FormControl(''),\n        Text: new FormControl(''),\n    });\n\n    subscriptions: Subscription[] = [];\n    newImageLoading = false\n\n    IconSize = IconSize;\n\n    @Output() formDataChanged: EventEmitter<FormGroup> = new EventEmitter();\n\n    /**\n     * Constructor\n     * @param formBuilder \n     * @param appRef \n     * @param cd \n     * @param translateService \n     * @param renderer \n     */\n    constructor(\n        public formBuilder: FormBuilder, \n        public appRef: ApplicationRef,\n        public cd: ChangeDetectorRef,\n        //private translateService: TranslateService,\n        public renderer: Renderer2\n    ) {\n        \n    }\n\n    /**\n     *  Click on button triggers file-input to open OS file dialog\n     */\n    selectImageOverlay() {\n        this.fileInput.nativeElement.click();\n    }\n\n    /**\n     * Function to manage the input image\n     * Returns an error if the file exceeds maximum wanted filesize (Mb). \n     * @param ev\n     * @returns\n     */\n    selectImage(ev: any) {\n        if (ev.target.files && ev.target.files[0]) {\n            const file:File = ev.target.files[0];\n\n            if (file.size > this.maxSizeBytes) {\n                this.clearInputValue(ev);\n                //alert(this.translateService.instant('errors.fileTooBig'));\n                return;\n            } else {\n                this.newImageLoading = true;\n\n                if(this.resizePixels > 0){\n                    const logoUrl = URL.createObjectURL(file);\n                    const imgEl = document.createElement('img');\n                    imgEl.addEventListener('load', () => {\n                        const resizedLogo = this.resizeImage(imgEl, this.resizePixels);\n                        const newFile = this.generateModel(file.name, resizedLogo, this.value.ImageIdent, this.value.ImageLink, this.value.Text);\n                        this.value=newFile;\n                        this.newImageLoading = false;\n                        this.cd.markForCheck();\n                    });\n                    imgEl.src = logoUrl;\n                }else{\n                    const reader = new FileReader();\n                    reader.readAsDataURL(file);\n                    reader.onload = (e: any) => {\n                        const newFile = this.generateModel(file.name, e.target.result, this.value.ImageIdent, this.value.ImageLink, this.value.Text);\n                        this.value=newFile;\n                        this.newImageLoading = false;\n                        this.cd.markForCheck();\n                    };\n                }\n                \n            }\n        }else{\n            console.warn(\"No file selected\");\n        }\n    }\n\n    /**\n     * Resize an image\n     * @param imgEl\n     * @param wantedWidth as number\n     * @returns string \n     */\n     private resizeImage(imgEl: any, wantedWidth: number) {\n        const canvas = document.createElement('canvas');\n        const ctx = canvas.getContext('2d');\n        const aspect = imgEl.width / imgEl.height;\n        canvas.width = wantedWidth;\n        canvas.height = wantedWidth / aspect;\n        if (isValue(ctx)) ctx.drawImage(imgEl, 0, 0, canvas.width, canvas.height);\n        return canvas.toDataURL();\n    }\n\n    /**\n     * Generate default object\n     * @param name as string\n     * @param content as string\n     * @returns AttachedFileDTO\n     */\n    generateModel(name?: string, content?: string, ident?: string, imageLink?: string, text?: string){\n        return {\n            ImageIdent: ident ? ident : '',\n            Filename: name ? name : '',\n            ImageAsDataURL: content ? content : '',\n            ImageLink: imageLink ? imageLink : '',\n            Text: text ? text : ''\n        } as AttachedFileDTO;\n    }\n\n    /**\n     * Remove image \n     */\n     removeFromList(){\n        this.value= this.generateModel('','', '', '');\n    }\n\n    /**\n     * get value\n     */\n        get value(): AttachedFileDTO {\n        return this.form.value;\n    }\n\n    /**\n     * set value\n     */\n    set value(value: AttachedFileDTO) {\n        this.form.setValue(value);\n        this.onChange(value);\n        this.formDataChanged.emit(this.form);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    onChange: any = () => {};\n\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    onTouch: any = () => {};\n\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    ngOnInit() {}\n\n\n    ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }   \n\n    registerOnChange(fn: any) {\n        this.onChange = fn;\n    }\n\n    registerOnTouched(fn: any) {\n        this.onTouch = fn;\n    }\n\n    writeValue(value: AttachedFileDTO | null) {\n        if (value) {\n            this.value = value;\n        }\n\n        if (value === null) {\n            this.form.reset();\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\n    validate(_: FormControl) {\n        return this.form.valid ? null : { styles: { valid: false } };\n    }\n\n    /**\n     * OnClick event listener of input#fileInput to clear his input value\n     */\n    clearInputValue(ev: any) {\n        const element = ev.target as HTMLInputElement;\n        element.value = '';\n    }\n}\n"]}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* @copyright FLYACTS GmbH 2019
|
|
3
|
+
*/
|
|
4
|
+
import { state, style, trigger } from '@angular/animations';
|
|
5
|
+
import { Component, Input, ViewChild, } from '@angular/core';
|
|
6
|
+
export class FlyoutComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.icon = 'filter';
|
|
9
|
+
this.isDropdownOpened = false;
|
|
10
|
+
this.targetHeight = '0';
|
|
11
|
+
this.animationTime = 5000;
|
|
12
|
+
this.headerCssClass = '';
|
|
13
|
+
this.bodyCssClass = '';
|
|
14
|
+
this.headerTitle = '';
|
|
15
|
+
this.headerText = '';
|
|
16
|
+
this.hasButtonForMore = false;
|
|
17
|
+
this.moreText = '';
|
|
18
|
+
this.lessText = '';
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Open/close dropdown if click on header.
|
|
22
|
+
* Except, if mode is set to hasButtonForMore. When there is a extra button to open/close
|
|
23
|
+
*/
|
|
24
|
+
toggleDropdownHeader() {
|
|
25
|
+
if (!this.hasButtonForMore) {
|
|
26
|
+
this.toggleDropdown();
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Open or close the dropdown
|
|
31
|
+
*/
|
|
32
|
+
toggleDropdown() {
|
|
33
|
+
this.isDropdownOpened = !this.isDropdownOpened;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Set the height of the dropdown list items dynamic - needed for the animation
|
|
37
|
+
*/
|
|
38
|
+
setDropdownListHeight(contentHeight) {
|
|
39
|
+
this.targetHeight = `${contentHeight}px`;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
FlyoutComponent.decorators = [
|
|
43
|
+
{ type: Component, args: [{
|
|
44
|
+
selector: 'kms-flyout',
|
|
45
|
+
template: "<div class=\"flyout\"\n [ngClass]=\"{'is-active': isDropdownOpened}\"\n>\n <div class=\"flyout-header\" (click)=\"toggleDropdownHeader()\" [ngClass]=\"headerCssClass\">\n <span [innerHtml]=\"headerTitle | kmsSafeHtml\"></span>\n <span [innerHtml]=\"headerText | kmsSafeHtml\"></span>\n\n <ng-content select=\"[header]\"></ng-content>\n\n <div *ngIf=\"hasButtonForMore\" (click)=\"toggleDropdown()\" class=\"flyout-header-more\">\n <span *ngIf=\"!isDropdownOpened\">\n {{ moreText }}\n </span>\n <span *ngIf=\"isDropdownOpened\">\n {{ lessText }}\n </span>\n <kms-icon [icon]=\"'chevron-down'\"\n [iconClass]=\"{'size-16': true, 'is-rotating180': isDropdownOpened}\" >\n </kms-icon>\n </div>\n </div>\n <div \n class=\"flyout-body\"\n [ngClass]=\"bodyCssClass\"\n tabindex=\"0\"\n [@dropdownAnimation]=\"{value: isDropdownOpened, params: {targetHeight: targetHeight, animationTime: '500'}}\"\n getMaxHeight=\"inner\"\n (sumOfHeight)=\"setDropdownListHeight($event)\"\n #flyoutHeader>\n <div class=\"inner\" #content>\n <ng-content ></ng-content>\n </div>\n </div>\n\n</div>\n",
|
|
46
|
+
animations: [
|
|
47
|
+
trigger('dropdownAnimation', [
|
|
48
|
+
state('true', style({
|
|
49
|
+
height: '{{targetHeight}}',
|
|
50
|
+
transition: 'height {{animationTime}}ms ease-in-out',
|
|
51
|
+
}), {
|
|
52
|
+
params: {
|
|
53
|
+
targetHeight: '300px',
|
|
54
|
+
animationTime: 3000,
|
|
55
|
+
},
|
|
56
|
+
}),
|
|
57
|
+
state('false', style({
|
|
58
|
+
height: 0,
|
|
59
|
+
transition: 'height {{animationTime}}ms ease-in-out',
|
|
60
|
+
}), {
|
|
61
|
+
params: {
|
|
62
|
+
targetHeight: '300px',
|
|
63
|
+
opacity: 0,
|
|
64
|
+
animationTime: 3000,
|
|
65
|
+
},
|
|
66
|
+
}),
|
|
67
|
+
]),
|
|
68
|
+
],
|
|
69
|
+
styles: [".flyout{position:relative;display:block;padding:20px 45px}.flyout-header-more{font:normal normal normal 16px/25px var(--fontName-text03);letter-spacing:.26px;color:var(--primaryColor);cursor:pointer}.flyout-header-more kms-icon .icon,.flyout-header-more kms-icon .icon svg{width:16px!important;height:20px!important}.flyout-header-more kms-icon .icon svg use{fill:var(--primaryColor)}.flyout-body{padding:0;margin:0;overflow:hidden;outline:none}"]
|
|
70
|
+
},] }
|
|
71
|
+
];
|
|
72
|
+
FlyoutComponent.propDecorators = {
|
|
73
|
+
icon: [{ type: Input }],
|
|
74
|
+
headerCssClass: [{ type: Input }],
|
|
75
|
+
bodyCssClass: [{ type: Input }],
|
|
76
|
+
headerTitle: [{ type: Input }],
|
|
77
|
+
headerText: [{ type: Input }],
|
|
78
|
+
hasButtonForMore: [{ type: Input }],
|
|
79
|
+
moreText: [{ type: Input }],
|
|
80
|
+
lessText: [{ type: Input }],
|
|
81
|
+
content: [{ type: ViewChild, args: ['content',] }],
|
|
82
|
+
flyoutHeader: [{ type: ViewChild, args: ['flyoutHeader',] }]
|
|
83
|
+
};
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmx5b3V0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWwvc3JjL2xpYi91aS9mbHlvdXQvZmx5b3V0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILE9BQU8sRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzVELE9BQU8sRUFDSCxTQUFTLEVBRVQsS0FBSyxFQUNMLFNBQVMsR0FDWixNQUFNLGVBQWUsQ0FBQztBQXVDdkIsTUFBTSxPQUFPLGVBQWU7SUFyQzVCO1FBdUNhLFNBQUksR0FBRyxRQUFRLENBQUM7UUFFekIscUJBQWdCLEdBQUcsS0FBSyxDQUFDO1FBQ3pCLGlCQUFZLEdBQUcsR0FBRyxDQUFDO1FBQ25CLGtCQUFhLEdBQUcsSUFBSSxDQUFDO1FBRVosbUJBQWMsR0FBRyxFQUFFLENBQUM7UUFDcEIsaUJBQVksR0FBRyxFQUFFLENBQUM7UUFFbEIsZ0JBQVcsR0FBRyxFQUFFLENBQUM7UUFDakIsZUFBVSxHQUFJLEVBQUUsQ0FBQztRQUNqQixxQkFBZ0IsR0FBRyxLQUFLLENBQUM7UUFDekIsYUFBUSxHQUFHLEVBQUUsQ0FBQztRQUNkLGFBQVEsR0FBRyxFQUFFLENBQUM7SUE4QjNCLENBQUM7SUF2Qkc7OztPQUdHO0lBQ0gsb0JBQW9CO1FBQ2hCLElBQUksQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLEVBQUU7WUFDeEIsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO1NBQ3pCO0lBQ0wsQ0FBQztJQUVEOztPQUVHO0lBQ0gsY0FBYztRQUNWLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztJQUNuRCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxxQkFBcUIsQ0FBQyxhQUFxQjtRQUN2QyxJQUFJLENBQUMsWUFBWSxHQUFHLEdBQUcsYUFBYSxJQUFJLENBQUM7SUFDN0MsQ0FBQzs7O1lBakZKLFNBQVMsU0FBQztnQkFFUCxRQUFRLEVBQUUsWUFBWTtnQkFDdEIsMnlDQUFzQztnQkFFdEMsVUFBVSxFQUFFO29CQUNSLE9BQU8sQ0FBQyxtQkFBbUIsRUFBRTt3QkFDekIsS0FBSyxDQUNELE1BQU0sRUFDTixLQUFLLENBQUM7NEJBQ0YsTUFBTSxFQUFFLGtCQUFrQjs0QkFDMUIsVUFBVSxFQUFFLHdDQUF3Qzt5QkFDdkQsQ0FBQyxFQUNGOzRCQUNJLE1BQU0sRUFBRTtnQ0FDSixZQUFZLEVBQUUsT0FBTztnQ0FDckIsYUFBYSxFQUFFLElBQUk7NkJBQ3RCO3lCQUNKLENBQ0o7d0JBQ0QsS0FBSyxDQUNELE9BQU8sRUFDUCxLQUFLLENBQUM7NEJBQ0YsTUFBTSxFQUFFLENBQUM7NEJBQ1QsVUFBVSxFQUFFLHdDQUF3Qzt5QkFDdkQsQ0FBQyxFQUNGOzRCQUNJLE1BQU0sRUFBRTtnQ0FDSixZQUFZLEVBQUUsT0FBTztnQ0FDckIsT0FBTyxFQUFFLENBQUM7Z0NBQ1YsYUFBYSxFQUFFLElBQUk7NkJBQ3RCO3lCQUNKLENBQ0o7cUJBQ0osQ0FBQztpQkFDTDs7YUFDSjs7O21CQUdJLEtBQUs7NkJBTUwsS0FBSzsyQkFDTCxLQUFLOzBCQUVMLEtBQUs7eUJBQ0wsS0FBSzsrQkFDTCxLQUFLO3VCQUNMLEtBQUs7dUJBQ0wsS0FBSztzQkFHTCxTQUFTLFNBQUMsU0FBUzsyQkFFbkIsU0FBUyxTQUFDLGNBQWMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiFcbiAqIEBjb3B5cmlnaHQgRkxZQUNUUyBHbWJIIDIwMTlcbiAqL1xuXG5pbXBvcnQgeyBzdGF0ZSwgc3R5bGUsIHRyaWdnZXIgfSBmcm9tICdAYW5ndWxhci9hbmltYXRpb25zJztcbmltcG9ydCB7XG4gICAgQ29tcG9uZW50LFxuICAgIEVsZW1lbnRSZWYsXG4gICAgSW5wdXQsXG4gICAgVmlld0NoaWxkLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gICAgXG4gICAgc2VsZWN0b3I6ICdrbXMtZmx5b3V0JyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZmx5b3V0LmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9mbHlvdXQuY29tcG9uZW50LnNjc3MnXSxcbiAgICBhbmltYXRpb25zOiBbXG4gICAgICAgIHRyaWdnZXIoJ2Ryb3Bkb3duQW5pbWF0aW9uJywgW1xuICAgICAgICAgICAgc3RhdGUoXG4gICAgICAgICAgICAgICAgJ3RydWUnLFxuICAgICAgICAgICAgICAgIHN0eWxlKHtcbiAgICAgICAgICAgICAgICAgICAgaGVpZ2h0OiAne3t0YXJnZXRIZWlnaHR9fScsXG4gICAgICAgICAgICAgICAgICAgIHRyYW5zaXRpb246ICdoZWlnaHQge3thbmltYXRpb25UaW1lfX1tcyBlYXNlLWluLW91dCcsXG4gICAgICAgICAgICAgICAgfSksXG4gICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgICBwYXJhbXM6IHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHRhcmdldEhlaWdodDogJzMwMHB4JyxcbiAgICAgICAgICAgICAgICAgICAgICAgIGFuaW1hdGlvblRpbWU6IDMwMDAsXG4gICAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICksXG4gICAgICAgICAgICBzdGF0ZShcbiAgICAgICAgICAgICAgICAnZmFsc2UnLFxuICAgICAgICAgICAgICAgIHN0eWxlKHtcbiAgICAgICAgICAgICAgICAgICAgaGVpZ2h0OiAwLFxuICAgICAgICAgICAgICAgICAgICB0cmFuc2l0aW9uOiAnaGVpZ2h0IHt7YW5pbWF0aW9uVGltZX19bXMgZWFzZS1pbi1vdXQnLFxuICAgICAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgcGFyYW1zOiB7XG4gICAgICAgICAgICAgICAgICAgICAgICB0YXJnZXRIZWlnaHQ6ICczMDBweCcsXG4gICAgICAgICAgICAgICAgICAgICAgICBvcGFjaXR5OiAwLFxuICAgICAgICAgICAgICAgICAgICAgICAgYW5pbWF0aW9uVGltZTogMzAwMCxcbiAgICAgICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgKSxcbiAgICAgICAgXSksXG4gICAgXSxcbn0pXG5leHBvcnQgY2xhc3MgRmx5b3V0Q29tcG9uZW50IHtcblxuICAgIEBJbnB1dCgpIGljb24gPSAnZmlsdGVyJztcblxuICAgIGlzRHJvcGRvd25PcGVuZWQgPSBmYWxzZTtcbiAgICB0YXJnZXRIZWlnaHQgPSAnMCc7XG4gICAgYW5pbWF0aW9uVGltZSA9IDUwMDA7XG5cbiAgICBASW5wdXQoKSBoZWFkZXJDc3NDbGFzcyA9ICcnO1xuICAgIEBJbnB1dCgpIGJvZHlDc3NDbGFzcyA9ICcnO1xuXG4gICAgQElucHV0KCkgaGVhZGVyVGl0bGUgPSAnJztcbiAgICBASW5wdXQoKSBoZWFkZXJUZXh0ICA9ICcnO1xuICAgIEBJbnB1dCgpIGhhc0J1dHRvbkZvck1vcmUgPSBmYWxzZTtcbiAgICBASW5wdXQoKSBtb3JlVGV4dCA9ICcnO1xuICAgIEBJbnB1dCgpIGxlc3NUZXh0ID0gJyc7XG5cbiAgICBcbiAgICBAVmlld0NoaWxkKCdjb250ZW50JykgY29udGVudDogRWxlbWVudFJlZiB8IHVuZGVmaW5lZDtcbiAgICBcbiAgICBAVmlld0NoaWxkKCdmbHlvdXRIZWFkZXInKSBmbHlvdXRIZWFkZXI6IEVsZW1lbnRSZWYgfCB1bmRlZmluZWQ7XG5cbiAgICAvKipcbiAgICAgKiBPcGVuL2Nsb3NlIGRyb3Bkb3duIGlmIGNsaWNrIG9uIGhlYWRlci5cbiAgICAgKiBFeGNlcHQsIGlmIG1vZGUgaXMgc2V0IHRvIGhhc0J1dHRvbkZvck1vcmUuIFdoZW4gdGhlcmUgaXMgYSBleHRyYSBidXR0b24gdG8gb3Blbi9jbG9zZVxuICAgICAqL1xuICAgIHRvZ2dsZURyb3Bkb3duSGVhZGVyKCkge1xuICAgICAgICBpZiAoIXRoaXMuaGFzQnV0dG9uRm9yTW9yZSkge1xuICAgICAgICAgICAgdGhpcy50b2dnbGVEcm9wZG93bigpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogT3BlbiBvciBjbG9zZSB0aGUgZHJvcGRvd25cbiAgICAgKi9cbiAgICB0b2dnbGVEcm9wZG93bigpIHtcbiAgICAgICAgdGhpcy5pc0Ryb3Bkb3duT3BlbmVkID0gIXRoaXMuaXNEcm9wZG93bk9wZW5lZDtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBTZXQgdGhlIGhlaWdodCBvZiB0aGUgZHJvcGRvd24gbGlzdCBpdGVtcyBkeW5hbWljIC0gbmVlZGVkIGZvciB0aGUgYW5pbWF0aW9uXG4gICAgICovXG4gICAgc2V0RHJvcGRvd25MaXN0SGVpZ2h0KGNvbnRlbnRIZWlnaHQ6IG51bWJlcikge1xuICAgICAgICB0aGlzLnRhcmdldEhlaWdodCA9IGAke2NvbnRlbnRIZWlnaHR9cHhgO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @copyright KMS GmbH
|
|
3
|
+
*/
|
|
4
|
+
import { Component, Inject, NgZone } from '@angular/core';
|
|
5
|
+
import { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';
|
|
6
|
+
import { isValue } from '../../models';
|
|
7
|
+
import { ButtonResponseType } from '../button-with-confirm-dialog/button-response-types.enum';
|
|
8
|
+
/**
|
|
9
|
+
* A generic dialog component
|
|
10
|
+
*/
|
|
11
|
+
export class GenericDialogComponent {
|
|
12
|
+
constructor(dialogRef, zone, data) {
|
|
13
|
+
this.dialogRef = dialogRef;
|
|
14
|
+
this.zone = zone;
|
|
15
|
+
this.data = data;
|
|
16
|
+
this.ButtonResponseType = ButtonResponseType;
|
|
17
|
+
if (isValue(data.buttons)) {
|
|
18
|
+
this.buttons = data.buttons;
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
this.buttons = { primary: 'Yes', secondary: 'No' };
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Action called when clicked
|
|
26
|
+
* @param clickedButton Whether the primary or secondary button was clicked
|
|
27
|
+
*/
|
|
28
|
+
onClickAction(clickedButton) {
|
|
29
|
+
this.zone.run(() => {
|
|
30
|
+
this.dialogRef.close(clickedButton);
|
|
31
|
+
this.dialogRef.afterClosed().subscribe(() => {
|
|
32
|
+
const buttonList = document.querySelectorAll('.mat-flat-button, .mat-button');
|
|
33
|
+
let i = 0;
|
|
34
|
+
for (i; i < buttonList.length; i++) {
|
|
35
|
+
buttonList[i].classList.remove('cdk-focused');
|
|
36
|
+
buttonList[i].classList.remove('cdk-program-focused');
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
GenericDialogComponent.decorators = [
|
|
43
|
+
{ type: Component, args: [{
|
|
44
|
+
selector: 'kms-generic-dialog',
|
|
45
|
+
template: "<div mat-dialog-title class=\"mat-dialog-title\">\n <h3>{{ data.title }}</h3>\n</div>\n<div mat-dialog-content class=\"mat-dialog-content\">\n {{ data.message }}\n</div>\n<div mat-dialog-actions class=\"custom-dialog-actions\">\n <button\n mat-flat-button\n class=\"test_secondary_button\"\n color=\"accent\"\n (click)=\"onClickAction(ButtonResponseType.secondary)\"\n >\n {{ buttons.secondary }}\n </button>\n <button\n mat-flat-button\n class=\"test_primary_button\"\n color=\"primary\"\n (click)=\"onClickAction(ButtonResponseType.primary)\"\n >\n {{ buttons.primary }}\n </button>\n</div>\n",
|
|
46
|
+
styles: [""]
|
|
47
|
+
},] }
|
|
48
|
+
];
|
|
49
|
+
GenericDialogComponent.ctorParameters = () => [
|
|
50
|
+
{ type: MatDialogRef },
|
|
51
|
+
{ type: NgZone },
|
|
52
|
+
{ type: undefined, decorators: [{ type: Inject, args: [MAT_DIALOG_DATA,] }] }
|
|
53
|
+
];
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJpYy1kaWFsb2cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva21zLW5neC11aS1wcmVzZW50YXRpb25hbC9zcmMvbGliL3VpL2dlbmVyaWMtZGlhbG9nL2dlbmVyaWMtZGlhbG9nLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRCxPQUFPLEVBQUUsZUFBZSxFQUFFLFlBQVksRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ3pFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDdkMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sMERBQTBELENBQUM7QUFHOUY7O0dBRUc7QUFNSCxNQUFNLE9BQU8sc0JBQXNCO0lBTS9CLFlBQ1csU0FBK0MsRUFDL0MsSUFBWSxFQUNhLElBQWdCO1FBRnpDLGNBQVMsR0FBVCxTQUFTLENBQXNDO1FBQy9DLFNBQUksR0FBSixJQUFJLENBQVE7UUFDYSxTQUFJLEdBQUosSUFBSSxDQUFZO1FBUHBELHVCQUFrQixHQUFHLGtCQUFrQixDQUFDO1FBU3BDLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUN2QixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUM7U0FDL0I7YUFBTTtZQUNILElBQUksQ0FBQyxPQUFPLEdBQUcsRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQXVCLENBQUM7U0FDM0U7SUFDTCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksYUFBYSxDQUFDLGFBQWlDO1FBQ2xELElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRTtZQUNmLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxDQUFDO1lBQ3BDLElBQUksQ0FBQyxTQUFTLENBQUMsV0FBVyxFQUFFLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtnQkFDeEMsTUFBTSxVQUFVLEdBQUcsUUFBUSxDQUFDLGdCQUFnQixDQUFDLCtCQUErQixDQUFDLENBQUM7Z0JBQzlFLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFDVixLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsVUFBVSxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRTtvQkFDaEMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUM7b0JBQzlDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLHFCQUFxQixDQUFDLENBQUM7aUJBQ3pEO1lBQ0wsQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7OztZQXZDSixTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLG9CQUFvQjtnQkFDOUIsNnJCQUE4Qzs7YUFFakQ7OztZQVp5QixZQUFZO1lBRFYsTUFBTTs0Q0F1QnpCLE1BQU0sU0FBQyxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAY29weXJpZ2h0IEtNUyBHbWJIXG4gKi9cblxuaW1wb3J0IHsgQ29tcG9uZW50LCBJbmplY3QsIE5nWm9uZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTUFUX0RJQUxPR19EQVRBLCBNYXREaWFsb2dSZWYgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHsgaXNWYWx1ZSB9IGZyb20gJy4uLy4uL21vZGVscyc7XG5pbXBvcnQgeyBCdXR0b25SZXNwb25zZVR5cGUgfSBmcm9tICcuLi9idXR0b24td2l0aC1jb25maXJtLWRpYWxvZy9idXR0b24tcmVzcG9uc2UtdHlwZXMuZW51bSc7XG5pbXBvcnQgeyBEaWFsb2dEYXRhLCBEaWFsb2dEYXRhQnV0dG9ucyB9IGZyb20gJy4uL2J1dHRvbi13aXRoLWNvbmZpcm0tZGlhbG9nL2RpYWxvZy1kYXRhLm1vZGVsJztcblxuLyoqXG4gKiBBIGdlbmVyaWMgZGlhbG9nIGNvbXBvbmVudFxuICovXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2ttcy1nZW5lcmljLWRpYWxvZycsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2dlbmVyaWMtZGlhbG9nLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9nZW5lcmljLWRpYWxvZy5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBHZW5lcmljRGlhbG9nQ29tcG9uZW50IHtcblxuICAgIEJ1dHRvblJlc3BvbnNlVHlwZSA9IEJ1dHRvblJlc3BvbnNlVHlwZTtcblxuICAgIHB1YmxpYyBidXR0b25zOiBEaWFsb2dEYXRhQnV0dG9uc1xuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKFxuICAgICAgICBwdWJsaWMgZGlhbG9nUmVmOiBNYXREaWFsb2dSZWY8R2VuZXJpY0RpYWxvZ0NvbXBvbmVudD4sXG4gICAgICAgIHB1YmxpYyB6b25lOiBOZ1pvbmUsXG4gICAgICAgIEBJbmplY3QoTUFUX0RJQUxPR19EQVRBKSBwdWJsaWMgZGF0YTogRGlhbG9nRGF0YVxuICAgICkge1xuICAgICAgICBpZiAoaXNWYWx1ZShkYXRhLmJ1dHRvbnMpKSB7XG4gICAgICAgICAgICB0aGlzLmJ1dHRvbnMgPSBkYXRhLmJ1dHRvbnM7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLmJ1dHRvbnMgPSB7IHByaW1hcnk6ICdZZXMnLCBzZWNvbmRhcnk6ICdObycgfSBhcyBEaWFsb2dEYXRhQnV0dG9ucztcbiAgICAgICAgfVxuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEFjdGlvbiBjYWxsZWQgd2hlbiBjbGlja2VkXG4gICAgICogQHBhcmFtIGNsaWNrZWRCdXR0b24gV2hldGhlciB0aGUgcHJpbWFyeSBvciBzZWNvbmRhcnkgYnV0dG9uIHdhcyBjbGlja2VkXG4gICAgICovXG4gICAgcHVibGljIG9uQ2xpY2tBY3Rpb24oY2xpY2tlZEJ1dHRvbjogQnV0dG9uUmVzcG9uc2VUeXBlKTogdm9pZCB7XG4gICAgICAgIHRoaXMuem9uZS5ydW4oKCkgPT4ge1xuICAgICAgICAgICAgdGhpcy5kaWFsb2dSZWYuY2xvc2UoY2xpY2tlZEJ1dHRvbik7XG4gICAgICAgICAgICB0aGlzLmRpYWxvZ1JlZi5hZnRlckNsb3NlZCgpLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICAgICAgICAgICAgY29uc3QgYnV0dG9uTGlzdCA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3JBbGwoJy5tYXQtZmxhdC1idXR0b24sIC5tYXQtYnV0dG9uJyk7XG4gICAgICAgICAgICAgICAgbGV0IGkgPSAwO1xuICAgICAgICAgICAgICAgIGZvciAoaTsgaSA8IGJ1dHRvbkxpc3QubGVuZ3RoOyBpKyspIHtcbiAgICAgICAgICAgICAgICAgICAgYnV0dG9uTGlzdFtpXS5jbGFzc0xpc3QucmVtb3ZlKCdjZGstZm9jdXNlZCcpO1xuICAgICAgICAgICAgICAgICAgICBidXR0b25MaXN0W2ldLmNsYXNzTGlzdC5yZW1vdmUoJ2Nkay1wcm9ncmFtLWZvY3VzZWQnKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfSk7XG4gICAgfVxufVxuIl19
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @copyright KMS GmbH
|
|
3
|
+
*/
|
|
4
|
+
import { Component, Input, VERSION } from '@angular/core';
|
|
5
|
+
import { DomSanitizer } from '@angular/platform-browser';
|
|
6
|
+
import { IconSize } from './iconSize.enum';
|
|
7
|
+
export class IconComponent {
|
|
8
|
+
constructor(sanitizer) {
|
|
9
|
+
this.sanitizer = sanitizer;
|
|
10
|
+
/**
|
|
11
|
+
* Optional: Different size via CSS inline style.
|
|
12
|
+
*/
|
|
13
|
+
this.iconSize = IconSize.FULLSIZE;
|
|
14
|
+
/**
|
|
15
|
+
* Dont use icon sprite
|
|
16
|
+
*/
|
|
17
|
+
this.dontUseSprite = false;
|
|
18
|
+
this.IconSize = IconSize;
|
|
19
|
+
this.Version = VERSION.full;
|
|
20
|
+
this.timestamp = 0;
|
|
21
|
+
this.iconToShow = this.icon;
|
|
22
|
+
}
|
|
23
|
+
ngOnInit() {
|
|
24
|
+
this.iconToShow = this.icon;
|
|
25
|
+
const d = new Date();
|
|
26
|
+
const n = d.getTime();
|
|
27
|
+
this.timestamp = n;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
IconComponent.decorators = [
|
|
31
|
+
{ type: Component, args: [{
|
|
32
|
+
selector: 'kms-icon',
|
|
33
|
+
template: "<ng-container *ngIf=\"icon !== 'none' && dontUseSprite === false\">\n <span class=\"icon {{ iconSize }}\" [ngClass]=\"iconClass\" [ngStyle]=\"iconStyle\">\n <svg>\n <use\n [attr.xlink:href]=\"\n 'assets/sprite.svg?Version=' + Version + '#' + iconToShow\n \"\n ></use>\n </svg>\n </span>\n</ng-container>\n<ng-container *ngIf=\"icon !== 'none' && dontUseSprite === true\">\n <object\n [data]=\"\n sanitizer.bypassSecurityTrustResourceUrl('assets/icons/' + icon + '')\n \"\n type=\"image/svg+xml\"\n class=\"icon {{ iconSize }}\"\n [ngClass]=\"iconClass\"\n [ngStyle]=\"iconStyle\"\n ></object>\n</ng-container>\n",
|
|
34
|
+
styles: [""]
|
|
35
|
+
},] }
|
|
36
|
+
];
|
|
37
|
+
IconComponent.ctorParameters = () => [
|
|
38
|
+
{ type: DomSanitizer }
|
|
39
|
+
];
|
|
40
|
+
IconComponent.propDecorators = {
|
|
41
|
+
icon: [{ type: Input }],
|
|
42
|
+
iconClass: [{ type: Input }],
|
|
43
|
+
iconStyle: [{ type: Input }],
|
|
44
|
+
iconSize: [{ type: Input }],
|
|
45
|
+
dontUseSprite: [{ type: Input }]
|
|
46
|
+
};
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rbXMtbmd4LXVpLXByZXNlbnRhdGlvbmFsL3NyYy9saWIvdWkvaWNvbi9pY29uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE9BQU8sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFekQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBUTNDLE1BQU0sT0FBTyxhQUFhO0lBd0N0QixZQUFtQixTQUF1QjtRQUF2QixjQUFTLEdBQVQsU0FBUyxDQUFjO1FBckIxQzs7V0FFRztRQUNNLGFBQVEsR0FBYSxRQUFRLENBQUMsUUFBUSxDQUFDO1FBRWhEOztXQUVHO1FBRU0sa0JBQWEsR0FBRyxLQUFLLENBQUM7UUFFL0IsYUFBUSxHQUFHLFFBQVEsQ0FBQztRQUNwQixZQUFPLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQztRQUVoQixjQUFTLEdBQUcsQ0FBQyxDQUFDO1FBUWpCLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQztJQUNoQyxDQUFDO0lBRUQsUUFBUTtRQUNKLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQztRQUM1QixNQUFNLENBQUMsR0FBRyxJQUFJLElBQUksRUFBRSxDQUFDO1FBQ3JCLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUN0QixJQUFJLENBQUMsU0FBUyxHQUFHLENBQUMsQ0FBQztJQUN2QixDQUFDOzs7WUF2REosU0FBUyxTQUFDO2dCQUVQLFFBQVEsRUFBRSxVQUFVO2dCQUNwQixpckJBQW9DOzthQUV2Qzs7O1lBVFEsWUFBWTs7O21CQWdCaEIsS0FBSzt3QkFLTCxLQUFLO3dCQU1MLEtBQUs7dUJBS0wsS0FBSzs0QkFNTCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAY29weXJpZ2h0IEtNUyBHbWJIXG4gKi9cblxuaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0LCBWRVJTSU9OIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEb21TYW5pdGl6ZXIgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcblxuaW1wb3J0IHsgSWNvblNpemUgfSBmcm9tICcuL2ljb25TaXplLmVudW0nO1xuXG5AQ29tcG9uZW50KHtcbiAgICBcbiAgICBzZWxlY3RvcjogJ2ttcy1pY29uJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vaWNvbi5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vaWNvbi5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBJY29uQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICAgIC8qKlxuICAgICAqIFJlcXVpcmVkOiBOYW1lIG9mIHRoZSBTVkcgaWNvbiBpbnNpZGUgeW91ciBzcHJpdGUgc2hlZXQgZmlsZSB3aXRoIG5hbWUgJ2ljb25zLnN2ZycuXG4gICAgICogUGFzcyAnbm9uZScgaWYgbm8gaWNvbiBzaG91bGQgYmUgcmVuZGVyZWQuXG4gICAgICovXG4gICAgQElucHV0KCkgaWNvbiE6IHN0cmluZyB8ICcnO1xuXG4gICAgLyoqXG4gICAgICogT3B0aW9uYWw6IERpZmZlcmVudCBhcHBlYXJhbmNlIHZpYSBDU1MgY2xhc3MgZGVmaW5lZCBpbiB0aGlzIGNvbXBvbmVudMK0cyBzdHlsZSBzaGVldC5cbiAgICAgKi9cbiAgICBASW5wdXQoKSBpY29uQ2xhc3MhOiBzdHJpbmcgfCAnJztcblxuICAgIC8qKlxuICAgICAqIE9wdGlvbmFsOiBEaWZmZXJlbnQgYXBwZWFyYW5jZSB2aWEgQ1NTIGlubGluZSBzdHlsZS5cbiAgICAgKi9cbiAgICBcbiAgICBASW5wdXQoKSBpY29uU3R5bGU6IGFueTtcblxuICAgIC8qKlxuICAgICAqIE9wdGlvbmFsOiBEaWZmZXJlbnQgc2l6ZSB2aWEgQ1NTIGlubGluZSBzdHlsZS5cbiAgICAgKi9cbiAgICBASW5wdXQoKSBpY29uU2l6ZTogSWNvblNpemUgPSBJY29uU2l6ZS5GVUxMU0laRTtcblxuICAgIC8qKlxuICAgICAqIERvbnQgdXNlIGljb24gc3ByaXRlXG4gICAgICovXG4gICAgXG4gICAgQElucHV0KCkgZG9udFVzZVNwcml0ZSA9IGZhbHNlO1xuXG4gICAgSWNvblNpemUgPSBJY29uU2l6ZTtcbiAgICBWZXJzaW9uID0gVkVSU0lPTi5mdWxsO1xuXG4gICAgcHVibGljIHRpbWVzdGFtcCA9IDA7XG5cbiAgICAvKipcbiAgICAgKiBSZW5kZXJzIHRoaXMgaWNvbiBmcm9tIFNWRyBzcHJpdGUgc2hlZXRcbiAgICAgKi9cbiAgICBwdWJsaWMgaWNvblRvU2hvdyE6IHN0cmluZyB8ICcnO1xuXG4gICAgY29uc3RydWN0b3IocHVibGljIHNhbml0aXplcjogRG9tU2FuaXRpemVyKSB7XG4gICAgICAgIHRoaXMuaWNvblRvU2hvdyA9IHRoaXMuaWNvbjtcbiAgICB9XG5cbiAgICBuZ09uSW5pdCgpIHtcbiAgICAgICAgdGhpcy5pY29uVG9TaG93ID0gdGhpcy5pY29uO1xuICAgICAgICBjb25zdCBkID0gbmV3IERhdGUoKTtcbiAgICAgICAgY29uc3QgbiA9IGQuZ2V0VGltZSgpO1xuICAgICAgICB0aGlzLnRpbWVzdGFtcCA9IG47XG4gICAgfVxuXG59XG4iXX0=
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* @copyright FLYACTS GmbH 2019
|
|
3
|
+
*/
|
|
4
|
+
export var IconSize;
|
|
5
|
+
(function (IconSize) {
|
|
6
|
+
IconSize["FULLSIZE"] = "size-full";
|
|
7
|
+
IconSize["TINY"] = "size-16";
|
|
8
|
+
IconSize["SMALLER"] = "size-20";
|
|
9
|
+
IconSize["SMALL"] = "size-32";
|
|
10
|
+
IconSize["MEDIUM"] = "size-64";
|
|
11
|
+
IconSize["LARGE"] = "size-128";
|
|
12
|
+
IconSize["XL"] = "size-256";
|
|
13
|
+
IconSize["XXL"] = "size-512";
|
|
14
|
+
IconSize["XXXL"] = "size-1024";
|
|
15
|
+
IconSize["NONE"] = "NONE";
|
|
16
|
+
})(IconSize || (IconSize = {}));
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvblNpemUuZW51bS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWwvc3JjL2xpYi91aS9pY29uL2ljb25TaXplLmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxNQUFNLENBQU4sSUFBWSxRQVdYO0FBWEQsV0FBWSxRQUFRO0lBQ2hCLGtDQUFzQixDQUFBO0lBQ3RCLDRCQUFnQixDQUFBO0lBQ2hCLCtCQUFtQixDQUFBO0lBQ25CLDZCQUFpQixDQUFBO0lBQ2pCLDhCQUFrQixDQUFBO0lBQ2xCLDhCQUFrQixDQUFBO0lBQ2xCLDJCQUFlLENBQUE7SUFDZiw0QkFBZ0IsQ0FBQTtJQUNoQiw4QkFBa0IsQ0FBQTtJQUNsQix5QkFBYSxDQUFBO0FBQ2pCLENBQUMsRUFYVyxRQUFRLEtBQVIsUUFBUSxRQVduQiIsInNvdXJjZXNDb250ZW50IjpbIi8qIVxuICogQGNvcHlyaWdodCBGTFlBQ1RTIEdtYkggMjAxOVxuICovXG5cbmV4cG9ydCBlbnVtIEljb25TaXplIHtcbiAgICBGVUxMU0laRSA9ICdzaXplLWZ1bGwnLFxuICAgIFRJTlkgPSAnc2l6ZS0xNicsXG4gICAgU01BTExFUiA9ICdzaXplLTIwJyxcbiAgICBTTUFMTCA9ICdzaXplLTMyJyxcbiAgICBNRURJVU0gPSAnc2l6ZS02NCcsXG4gICAgTEFSR0UgPSAnc2l6ZS0xMjgnLFxuICAgIFhMID0gJ3NpemUtMjU2JyxcbiAgICBYWEwgPSAnc2l6ZS01MTInLFxuICAgIFhYWEwgPSAnc2l6ZS0xMDI0JyxcbiAgICBOT05FID0gJ05PTkUnLFxufVxuXG4iXX0=
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* @copyright FLYACTS GmbH 2019
|
|
3
|
+
*/
|
|
4
|
+
import { Component, Input } from '@angular/core';
|
|
5
|
+
import { DomSanitizer } from '@angular/platform-browser';
|
|
6
|
+
/**
|
|
7
|
+
* A generic dialog component
|
|
8
|
+
*/
|
|
9
|
+
export class KMSAccordionItemComponent {
|
|
10
|
+
constructor(sanitizer) {
|
|
11
|
+
this.sanitizer = sanitizer;
|
|
12
|
+
this.itemTitle = '';
|
|
13
|
+
this.showAsCard = false;
|
|
14
|
+
this.isSmall = false;
|
|
15
|
+
this.panelOpenState = false;
|
|
16
|
+
}
|
|
17
|
+
ngOnInit() {
|
|
18
|
+
this.itemTitleTrustHtml = this.sanitizer.bypassSecurityTrustHtml(this.itemTitle);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
KMSAccordionItemComponent.decorators = [
|
|
22
|
+
{ type: Component, args: [{
|
|
23
|
+
selector: 'kms-accordion-item',
|
|
24
|
+
template: "<mat-expansion-panel\n class=\"accordion-item\" \n [ngClass]=\"{showAsCard: showAsCard, showFlat: !showAsCard, isSmall: isSmall}\"\n (opened)=\"panelOpenState = true\" \n (closed)=\"panelOpenState = false\"\n hideToggle=\"true\">\n <mat-expansion-panel-header class=\"accordion-item-header\">\n <mat-panel-title class=\"mat-subheading-2 accordion-item-title\">\n <div [innerHtml]=\"itemTitleTrustHtml\"></div>\n <ng-content select=\"[itemTitleElement]\"></ng-content> \n </mat-panel-title>\n <div class=\"accordion-item-header-icon-wrapper\">\n <kms-icon *ngIf=\"!panelOpenState\" icon=\"ic_plus\" iconClass=\"color-red\" class=\"accordion-item-header-icon-wrapper-desktop\"></kms-icon>\n <kms-icon *ngIf=\"panelOpenState\" icon=\"ic_minus\" iconClass=\"color-red\" class=\"accordion-item-header-icon-wrapper-desktop\"></kms-icon>\n\n <kms-icon *ngIf=\"!panelOpenState\" icon=\"chevron-down\" iconClass=\"color-red\" class=\"accordion-item-header-icon-wrapper-mobile\"></kms-icon>\n <kms-icon *ngIf=\"panelOpenState\" icon=\"chevron-top\" iconClass=\"color-red\" class=\"accordion-item-header-icon-wrapper-mobile\"></kms-icon>\n </div>\n </mat-expansion-panel-header>\n <ng-content></ng-content>\n</mat-expansion-panel>",
|
|
25
|
+
styles: [""]
|
|
26
|
+
},] }
|
|
27
|
+
];
|
|
28
|
+
KMSAccordionItemComponent.ctorParameters = () => [
|
|
29
|
+
{ type: DomSanitizer }
|
|
30
|
+
];
|
|
31
|
+
KMSAccordionItemComponent.propDecorators = {
|
|
32
|
+
itemTitle: [{ type: Input }],
|
|
33
|
+
showAsCard: [{ type: Input }],
|
|
34
|
+
isSmall: [{ type: Input }]
|
|
35
|
+
};
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia21zLWFjY29yZGlvbi1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWwvc3JjL2xpYi91aS9rbXMtYWNjb3JkaW9uLWl0ZW0va21zLWFjY29yZGlvbi1pdGVtLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBRSxZQUFZLEVBQVksTUFBTSwyQkFBMkIsQ0FBQztBQUVuRTs7R0FFRztBQU9ILE1BQU0sT0FBTyx5QkFBeUI7SUFRbEMsWUFBbUIsU0FBdUI7UUFBdkIsY0FBUyxHQUFULFNBQVMsQ0FBYztRQVAxQixjQUFTLEdBQUcsRUFBRSxDQUFDO1FBR2YsZUFBVSxHQUFHLEtBQUssQ0FBQztRQUNuQixZQUFPLEdBQUcsS0FBSyxDQUFDO1FBQ2hDLG1CQUFjLEdBQUcsS0FBSyxDQUFDO0lBSXZCLENBQUM7SUFFRCxRQUFRO1FBQ0osSUFBSSxDQUFDLGtCQUFrQixHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsdUJBQXVCLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ3JGLENBQUM7OztZQXBCSixTQUFTLFNBQUM7Z0JBRVAsUUFBUSxFQUFFLG9CQUFvQjtnQkFDOUIsdTFDQUFrRDs7YUFFckQ7OztZQVZRLFlBQVk7Ozt3QkFZaEIsS0FBSzt5QkFHTCxLQUFLO3NCQUNMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyIvKiFcbiAqIEBjb3B5cmlnaHQgRkxZQUNUUyBHbWJIIDIwMTlcbiAqL1xuXG5pbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERvbVNhbml0aXplciwgU2FmZUh0bWwgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcblxuLyoqXG4gKiBBIGdlbmVyaWMgZGlhbG9nIGNvbXBvbmVudFxuICovXG5AQ29tcG9uZW50KHtcbiAgICBcbiAgICBzZWxlY3RvcjogJ2ttcy1hY2NvcmRpb24taXRlbScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2ttcy1hY2NvcmRpb24taXRlbS5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4va21zLWFjY29yZGlvbi1pdGVtLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIEtNU0FjY29yZGlvbkl0ZW1Db21wb25lbnQgIGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBASW5wdXQoKSBwdWJsaWMgaXRlbVRpdGxlID0gJyc7XG4gICAgXG4gICAgcHVibGljIGl0ZW1UaXRsZVRydXN0SHRtbDogU2FmZUh0bWwgfCB1bmRlZmluZWQ7XG4gICAgQElucHV0KCkgcHVibGljIHNob3dBc0NhcmQgPSBmYWxzZTtcbiAgICBASW5wdXQoKSBwdWJsaWMgaXNTbWFsbCA9IGZhbHNlO1xuICAgIHBhbmVsT3BlblN0YXRlID0gZmFsc2U7XG5cbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgc2FuaXRpemVyOiBEb21TYW5pdGl6ZXIpIHtcblxuICAgIH1cblxuICAgIG5nT25Jbml0KCkge1xuICAgICAgICB0aGlzLml0ZW1UaXRsZVRydXN0SHRtbCA9IHRoaXMuc2FuaXRpemVyLmJ5cGFzc1NlY3VyaXR5VHJ1c3RIdG1sKHRoaXMuaXRlbVRpdGxlKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
export class LoaderComponent {
|
|
3
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
4
|
+
constructor() {
|
|
5
|
+
this.loading = false;
|
|
6
|
+
}
|
|
7
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
8
|
+
ngOnInit() { }
|
|
9
|
+
}
|
|
10
|
+
LoaderComponent.decorators = [
|
|
11
|
+
{ type: Component, args: [{
|
|
12
|
+
selector: 'kms-loader',
|
|
13
|
+
template: "<div class=\"loading-spinner-shade\" *ngIf=\"loading\">\n <mat-spinner class=\"spinnerMargin\" color=\"accent\" diameter=\"44\"></mat-spinner>\n</div>\n",
|
|
14
|
+
styles: [""]
|
|
15
|
+
},] }
|
|
16
|
+
];
|
|
17
|
+
LoaderComponent.ctorParameters = () => [];
|
|
18
|
+
LoaderComponent.propDecorators = {
|
|
19
|
+
loading: [{ type: Input }]
|
|
20
|
+
};
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWwvc3JjL2xpYi91aS9sb2FkZXIvbG9hZGVyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQU96RCxNQUFNLE9BQU8sZUFBZTtJQUd4QixnRUFBZ0U7SUFDaEU7UUFIUyxZQUFPLEdBQUMsS0FBSyxDQUFDO0lBR1IsQ0FBQztJQUVoQixnRUFBZ0U7SUFDaEUsUUFBUSxLQUFJLENBQUM7OztZQVpoQixTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLFlBQVk7Z0JBQ3RCLHVLQUFzQzs7YUFFekM7Ozs7c0JBRUksS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2ttcy1sb2FkZXInLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9sb2FkZXIuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2xvYWRlci5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBMb2FkZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIEBJbnB1dCgpIGxvYWRpbmc9ZmFsc2U7XG5cbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWVtcHR5LWZ1bmN0aW9uXG4gICAgY29uc3RydWN0b3IoKSB7fVxuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1lbXB0eS1mdW5jdGlvblxuICAgIG5nT25Jbml0KCkge31cbn1cbiJdfQ==
|