@kms-ngx-ui/presentational 0.0.5 → 0.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/kms-ngx-ui-presentational.umd.js +820 -60
- package/bundles/kms-ngx-ui-presentational.umd.js.map +1 -1
- package/esm2015/kms-ngx-ui-presentational.js +36 -30
- package/esm2015/lib/directives/directives.module.js +29 -0
- package/esm2015/lib/directives/mousewheel.directive.js +46 -0
- package/esm2015/lib/directives/sum-of-height.directive.js +71 -0
- package/esm2015/lib/directives/swipe.directive.js +159 -0
- package/esm2015/lib/directives/swipe.model.js +5 -0
- package/esm2015/lib/directives/tooltip.directive.js +124 -0
- package/esm2015/lib/kms-ngx-ui-presentational.module.js +29 -23
- package/esm2015/lib/models/image-snippet.model.js +18 -0
- package/esm2015/lib/ui/checkbox/checkbox.component.js +1 -1
- package/esm2015/lib/ui/color-input/color-input.component.js +1 -1
- package/esm2015/lib/ui/dropdown-from-data/dropdown-from-data.component.js +145 -0
- package/esm2015/lib/ui/flyout/flyout.component.js +1 -1
- package/esm2015/lib/ui/image-slider/image-slider.component.js +177 -0
- package/esm2015/lib/ui/radiobutton/radiobutton.component.js +1 -1
- package/esm2015/lib/ui/time-input/time-input.component.js +1 -1
- package/esm2015/public-api.js +2 -1
- package/fesm2015/kms-ngx-ui-presentational.js +766 -29
- package/fesm2015/kms-ngx-ui-presentational.js.map +1 -1
- package/kms-ngx-ui-presentational.d.ts +36 -30
- package/kms-ngx-ui-presentational.metadata.json +1 -1
- package/lib/directives/directives.module.d.ts +5 -0
- package/lib/directives/mousewheel.directive.d.ts +12 -0
- package/lib/directives/sum-of-height.directive.d.ts +28 -0
- package/lib/directives/swipe.directive.d.ts +42 -0
- package/lib/directives/swipe.model.d.ts +49 -0
- package/lib/directives/tooltip.directive.d.ts +26 -0
- package/lib/models/image-snippet.model.d.ts +15 -0
- package/lib/ui/dropdown-from-data/dropdown-from-data.component.d.ts +51 -0
- package/lib/ui/image-slider/image-slider.component.d.ts +59 -0
- package/package.json +2 -1
- package/public-api.d.ts +1 -0
- package/src/lib/ui/back-to-top/back-to-top.component.scss +46 -46
- package/src/lib/ui/button-with-confirm-dialog/button-with-confirm-dialog.component.scss +3 -0
- package/src/lib/ui/checkbox/checkbox.component.scss +48 -56
- package/src/lib/ui/color-input/color-input.component.scss +39 -38
- package/src/lib/ui/file-input/file-input.component.scss +3 -0
- package/src/lib/ui/flyout/flyout.component.scss +35 -34
- package/src/lib/ui/generic-dialog/generic-dialog.component.scss +59 -59
- package/src/lib/ui/icon/icon.component.scss +148 -148
- package/src/lib/ui/image-slider/image-slider.component.scss +220 -0
- package/src/lib/ui/kms-accordion-item/kms-accordion-item.component.scss +95 -95
- package/src/lib/ui/radiobutton/radiobutton.component.scss +32 -30
- package/src/lib/ui/time-input/time-input.component.scss +11 -10
- package/src/lib/ui/tooltip/tooltip.component.scss +26 -26
- package/src/lib/ui/tooltip-icon/tooltip-icon.component.scss +2 -2
- package/src/styles/styles.scss +31 -23
|
@@ -30,34 +30,38 @@ import { MatButtonModule } from '@angular/material/button';
|
|
|
30
30
|
import { GenericDialogComponent } from './ui/generic-dialog/generic-dialog.component';
|
|
31
31
|
import { MatExpansionModule } from '@angular/material/expansion';
|
|
32
32
|
import { MatSelectModule } from '@angular/material/select';
|
|
33
|
-
import {
|
|
33
|
+
import { DropdownFromDataComponent } from './ui/dropdown-from-data/dropdown-from-data.component';
|
|
34
|
+
import { ImageSliderComponent } from './ui/image-slider/image-slider.component';
|
|
35
|
+
import { DirectivesModule } from './directives/directives.module';
|
|
34
36
|
export class KmsUiPresentationalModule {
|
|
35
37
|
}
|
|
36
38
|
KmsUiPresentationalModule.decorators = [
|
|
37
39
|
{ type: NgModule, args: [{
|
|
38
40
|
declarations: [
|
|
39
|
-
KmsUiPresentationalComponent,
|
|
40
41
|
ActionsParentComponent,
|
|
42
|
+
BackToTopComponent,
|
|
43
|
+
ButtonWithConfirmDialogComponent,
|
|
41
44
|
CheckboxComponent,
|
|
42
45
|
ColorInputComponent,
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
+
DropdownFromDataComponent,
|
|
47
|
+
EnumRadiogroupComponent,
|
|
48
|
+
EnumRadiogroupComponent,
|
|
46
49
|
FileInputComponent,
|
|
47
|
-
LoaderComponent,
|
|
48
50
|
FlyoutComponent,
|
|
51
|
+
GenericDialogComponent,
|
|
49
52
|
IconComponent,
|
|
50
|
-
|
|
53
|
+
ImageSliderComponent,
|
|
51
54
|
KMSAccordionItemComponent,
|
|
52
|
-
|
|
55
|
+
KmsUiPresentationalComponent,
|
|
56
|
+
LoaderComponent,
|
|
53
57
|
MapComponent,
|
|
58
|
+
RadioButtonComponent,
|
|
54
59
|
SalutationDropdownComponent,
|
|
55
60
|
SalutationRadiogroupComponent,
|
|
61
|
+
TimeInputComponent,
|
|
56
62
|
TooltipComponent,
|
|
57
63
|
TooltipIconComponent,
|
|
58
|
-
|
|
59
|
-
GenericDialogComponent,
|
|
60
|
-
ButtonWithConfirmDialogComponent,
|
|
64
|
+
YesNoRadiogroupComponent
|
|
61
65
|
],
|
|
62
66
|
imports: [
|
|
63
67
|
CommonModule,
|
|
@@ -71,32 +75,34 @@ KmsUiPresentationalModule.decorators = [
|
|
|
71
75
|
GoogleMapsModule,
|
|
72
76
|
MatExpansionModule,
|
|
73
77
|
MatSelectModule,
|
|
74
|
-
|
|
78
|
+
DirectivesModule
|
|
75
79
|
],
|
|
76
80
|
exports: [
|
|
77
|
-
KmsUiPresentationalComponent,
|
|
78
81
|
ActionsParentComponent,
|
|
82
|
+
BackToTopComponent,
|
|
83
|
+
ButtonWithConfirmDialogComponent,
|
|
79
84
|
CheckboxComponent,
|
|
80
85
|
ColorInputComponent,
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
86
|
+
DropdownFromDataComponent,
|
|
87
|
+
EnumRadiogroupComponent,
|
|
88
|
+
EnumRadiogroupComponent,
|
|
84
89
|
FileInputComponent,
|
|
85
|
-
LoaderComponent,
|
|
86
90
|
FlyoutComponent,
|
|
91
|
+
GenericDialogComponent,
|
|
87
92
|
IconComponent,
|
|
88
|
-
|
|
93
|
+
ImageSliderComponent,
|
|
89
94
|
KMSAccordionItemComponent,
|
|
90
|
-
|
|
95
|
+
KmsUiPresentationalComponent,
|
|
96
|
+
LoaderComponent,
|
|
91
97
|
MapComponent,
|
|
98
|
+
RadioButtonComponent,
|
|
92
99
|
SalutationDropdownComponent,
|
|
93
100
|
SalutationRadiogroupComponent,
|
|
101
|
+
TimeInputComponent,
|
|
94
102
|
TooltipComponent,
|
|
95
103
|
TooltipIconComponent,
|
|
96
|
-
|
|
97
|
-
GenericDialogComponent,
|
|
98
|
-
ButtonWithConfirmDialogComponent
|
|
104
|
+
YesNoRadiogroupComponent
|
|
99
105
|
]
|
|
100
106
|
},] }
|
|
101
107
|
];
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kms-ngx-ui-presentational.module.js","sourceRoot":"","sources":["../../../../../projects/kms-ngx-ui-presentational/src/lib/kms-ngx-ui-presentational.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule,  } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\n\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { KmsUiPresentationalComponent } from './kms-ngx-ui-presentational.component';\r\nimport { ActionsParentComponent } from './parent-components/actions.component';\r\nimport { CheckboxComponent } from './ui/checkbox/checkbox.component';\r\n\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatRadioModule } from '@angular/material/radio';\r\nimport { ColorInputComponent } from './ui/color-input/color-input.component';\r\nimport { RadioButtonComponent } from './ui/radiobutton/radiobutton.component';\r\nimport { TimeInputComponent } from './ui/time-input/time-input.component';\r\nimport { YesNoRadiogroupComponent } from './ui/yes-no-radiogroup/yes-no-radiogroup.component';\r\nimport { FileInputComponent } from './ui/file-input/file-input.component';\r\nimport { LoaderComponent } from './ui/loader/loader.component';\r\nimport { FlyoutComponent } from './ui/flyout/flyout.component';\r\nimport { CustomPipesModule } from './pipes/custom-pipes.module';\r\nimport { IconComponent } from './ui/icon/icon.component';\r\nimport { EnumRadiogroupComponent } from './ui/enum-radiogroup/enum-radiogroup.component';\r\nimport { KMSAccordionItemComponent } from './ui/kms-accordion-item/kms-accordion-item.component';\r\nimport { MapComponent } from './ui/map/map.component';\r\nimport { SalutationDropdownComponent } from './ui/salutation-dropdown/salutation-dropdown.component';\r\nimport { TooltipComponent } from './ui/tooltip/tooltip.component';\r\nimport { TooltipIconComponent } from './ui/tooltip-icon/tooltip-icon.component';\r\n\r\nimport { SalutationRadiogroupComponent } from './ui/salutation-radiogroup/salutation-radiogroup.component';\r\nimport { BackToTopComponent } from './ui/back-to-top/back-to-top.component';\r\nimport { ButtonWithConfirmDialogComponent } from './ui/button-with-confirm-dialog/button-with-confirm-dialog.component';\r\nimport { GoogleMapsModule } from '@angular/google-maps';\r\nimport { MatDialogModule } from '@angular/material/dialog';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { GenericDialogComponent } from './ui/generic-dialog/generic-dialog.component';\r\nimport { MatExpansionModule} from '@angular/material/expansion';\r\nimport { MatSelectModule } from '@angular/material/select';\r\nimport { DropdownFromDataComponent } from './ui/dropdown-from-data/dropdown-from-data.component';\r\nimport { ImageSliderComponent } from './ui/image-slider/image-slider.component';\r\nimport { DirectivesModule } from './directives/directives.module';\r\n\r\n@NgModule({\r\n  declarations: [\r\n    ActionsParentComponent,\r\n    BackToTopComponent,\r\n    ButtonWithConfirmDialogComponent,\r\n    CheckboxComponent,\r\n    ColorInputComponent,\r\n    DropdownFromDataComponent,\r\n    EnumRadiogroupComponent,\r\n    EnumRadiogroupComponent,\r\n    FileInputComponent,\r\n    FlyoutComponent,\r\n    GenericDialogComponent,\r\n    IconComponent,\r\n    ImageSliderComponent,\r\n    KMSAccordionItemComponent,\r\n    KmsUiPresentationalComponent,\r\n    LoaderComponent,\r\n    MapComponent,\r\n    RadioButtonComponent,\r\n    SalutationDropdownComponent,\r\n    SalutationRadiogroupComponent,\r\n    TimeInputComponent,\r\n    TooltipComponent,\r\n    TooltipIconComponent,\r\n    YesNoRadiogroupComponent\r\n  ],\r\n  imports: [\r\n    CommonModule,\r\n    MatCheckboxModule,\r\n    MatButtonModule,\r\n    MatRadioModule,\r\n    MatDialogModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    CustomPipesModule,\r\n    GoogleMapsModule,\r\n    MatExpansionModule,\r\n    MatSelectModule,\r\n    DirectivesModule\r\n  ],\r\n  exports: [\r\n    ActionsParentComponent,\r\n    BackToTopComponent,\r\n    ButtonWithConfirmDialogComponent,\r\n    CheckboxComponent,\r\n    ColorInputComponent,\r\n    DropdownFromDataComponent,\r\n    EnumRadiogroupComponent,\r\n    EnumRadiogroupComponent,\r\n    FileInputComponent,\r\n    FlyoutComponent,\r\n    GenericDialogComponent,\r\n    IconComponent,\r\n    ImageSliderComponent,\r\n    KMSAccordionItemComponent,\r\n    KmsUiPresentationalComponent,\r\n    LoaderComponent,\r\n    MapComponent,\r\n    RadioButtonComponent,\r\n    SalutationDropdownComponent,\r\n    SalutationRadiogroupComponent,\r\n    TimeInputComponent,\r\n    TooltipComponent,\r\n    TooltipIconComponent,\r\n    YesNoRadiogroupComponent\r\n  ]\r\n})\r\nexport class KmsUiPresentationalModule { }\r\n"]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* General Image Model
|
|
3
|
+
*/
|
|
4
|
+
export class ImageSnippet {
|
|
5
|
+
constructor(src, fileName, srcType = ImageSourceType.ByteArray) {
|
|
6
|
+
this.src = src;
|
|
7
|
+
this.fileName = fileName;
|
|
8
|
+
this.srcType = srcType;
|
|
9
|
+
this.status = 'init';
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
export var ImageSourceType;
|
|
13
|
+
(function (ImageSourceType) {
|
|
14
|
+
ImageSourceType["Ident"] = "Idnet";
|
|
15
|
+
ImageSourceType["ByteArray"] = "ByteArray";
|
|
16
|
+
ImageSourceType["URL"] = "URL";
|
|
17
|
+
})(ImageSourceType || (ImageSourceType = {}));
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2Utc25pcHBldC5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWwvc3JjL2xpYi9tb2RlbHMvaW1hZ2Utc25pcHBldC5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE1BQU0sT0FBTyxZQUFZO0lBRXJCLFlBQ1MsR0FBVyxFQUNYLFFBQWdCLEVBQ2hCLFVBQVUsZUFBZSxDQUFDLFNBQVM7UUFGbkMsUUFBRyxHQUFILEdBQUcsQ0FBUTtRQUNYLGFBQVEsR0FBUixRQUFRLENBQVE7UUFDaEIsWUFBTyxHQUFQLE9BQU8sQ0FBNEI7UUFKNUMsV0FBTSxHQUFHLE1BQU0sQ0FBQztJQUtYLENBQUM7Q0FDUDtBQUVILE1BQU0sQ0FBTixJQUFZLGVBSVg7QUFKRCxXQUFZLGVBQWU7SUFDekIsa0NBQWUsQ0FBQTtJQUNmLDBDQUF1QixDQUFBO0lBQ3ZCLDhCQUFXLENBQUE7QUFDYixDQUFDLEVBSlcsZUFBZSxLQUFmLGVBQWUsUUFJMUIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogR2VuZXJhbCBJbWFnZSBNb2RlbFxyXG4gKi9cclxuZXhwb3J0IGNsYXNzIEltYWdlU25pcHBldCB7XHJcbiAgICBzdGF0dXMgPSAnaW5pdCc7XHJcbiAgICBjb25zdHJ1Y3RvcihcclxuICAgICAgcHVibGljIHNyYzogc3RyaW5nLFxyXG4gICAgICBwdWJsaWMgZmlsZU5hbWU6IHN0cmluZyxcclxuICAgICAgcHVibGljIHNyY1R5cGUgPSBJbWFnZVNvdXJjZVR5cGUuQnl0ZUFycmF5LFxyXG4gICAgICApIHt9XHJcbiAgfVxyXG5cclxuZXhwb3J0IGVudW0gSW1hZ2VTb3VyY2VUeXBlIHtcclxuICBJZGVudCA9ICdJZG5ldCcsXHJcbiAgQnl0ZUFycmF5ID0gJ0J5dGVBcnJheScsXHJcbiAgVVJMID0gJ1VSTCdcclxufVxyXG4iXX0=
|
|
@@ -48,7 +48,7 @@ ColorInputComponent.decorators = [
|
|
|
48
48
|
multi: true,
|
|
49
49
|
},
|
|
50
50
|
],
|
|
51
|
-
styles: ["
|
|
51
|
+
styles: [""]
|
|
52
52
|
},] }
|
|
53
53
|
];
|
|
54
54
|
ColorInputComponent.ctorParameters = () => [
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
import { Component, forwardRef, Input, Renderer2 } from '@angular/core';
|
|
2
|
+
import { FormBuilder, NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { EnumValues } from 'enum-values/src/enumValues';
|
|
4
|
+
//import { EnumValues } from 'enum-values';
|
|
5
|
+
import { FormControlParentComponent } from '../../parent-components/form-control.component';
|
|
6
|
+
/**
|
|
7
|
+
* Dropdown from data component {@link https://leaseplan-dev.rentoffice.de/styleguide#ui-elements}
|
|
8
|
+
*/
|
|
9
|
+
export class DropdownFromDataComponent extends FormControlParentComponent {
|
|
10
|
+
constructor(formBuilder, renderer) {
|
|
11
|
+
super(formBuilder, renderer);
|
|
12
|
+
this.formBuilder = formBuilder;
|
|
13
|
+
this.renderer = renderer;
|
|
14
|
+
// options for the dropdown have a null value at the beginning of the array
|
|
15
|
+
this.hasNullOption = false;
|
|
16
|
+
this.placeholder = '';
|
|
17
|
+
this.label = '';
|
|
18
|
+
this.required = false;
|
|
19
|
+
this.useEnumIndexAsValue = false;
|
|
20
|
+
this.keys = [];
|
|
21
|
+
this.values = [];
|
|
22
|
+
this.Object = Object;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Hook used to sync changes on set Label and Type
|
|
26
|
+
* @param changes
|
|
27
|
+
*/
|
|
28
|
+
ngOnChanges(changes) {
|
|
29
|
+
if (changes.optionsPlainArray) {
|
|
30
|
+
this.keys = this.optionsPlainArray;
|
|
31
|
+
this.values = this.optionsPlainArray;
|
|
32
|
+
}
|
|
33
|
+
this.setKeyValues();
|
|
34
|
+
}
|
|
35
|
+
ngOnInit() {
|
|
36
|
+
this.form = this.formBuilder.group({
|
|
37
|
+
dropdownData: [],
|
|
38
|
+
});
|
|
39
|
+
this.formInitialized = true;
|
|
40
|
+
this.form.valueChanges.subscribe(value => {
|
|
41
|
+
this.internalValue = value.dropdownData;
|
|
42
|
+
this.onChange(value.dropdownData);
|
|
43
|
+
});
|
|
44
|
+
super.ngOnInit();
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* transofrms the data values to the correct format for be used by the template
|
|
48
|
+
* @param value
|
|
49
|
+
*/
|
|
50
|
+
setKeyValues() {
|
|
51
|
+
if (this.optionsObjArray && this.mapKey && this.mapValue) {
|
|
52
|
+
this.keys = this.optionsObjArray.map((obj) => obj[`${this.mapKey}`]);
|
|
53
|
+
this.values = this.optionsObjArray.map((obj) => obj[`${this.mapValue}`]);
|
|
54
|
+
}
|
|
55
|
+
else if (this.optionsObjArray && this.mapKey) {
|
|
56
|
+
this.keys = this.optionsObjArray.map((obj) => obj[`${this.mapKey}`]);
|
|
57
|
+
this.values = this.optionsObjArray.map((obj) => obj[`${this.mapKey}`]);
|
|
58
|
+
}
|
|
59
|
+
if (this.optionsEnum) {
|
|
60
|
+
this.keys = EnumValues.getNames(this.optionsEnum);
|
|
61
|
+
if (this.optionsPlainArray) {
|
|
62
|
+
this.values = this.optionsPlainArray;
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
const values = EnumValues.getValues(this.optionsEnum);
|
|
66
|
+
// 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' }
|
|
67
|
+
let keyValueEnum = false;
|
|
68
|
+
for (let i = 0; i < this.keys.length; i++) {
|
|
69
|
+
if (i !== values[i]) {
|
|
70
|
+
keyValueEnum = true;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
if (keyValueEnum || this.useEnumIndexAsValue) {
|
|
74
|
+
this.values = values;
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
this.values = EnumValues.getNames(this.optionsEnum);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
if (this.hasNullOption === true)
|
|
82
|
+
this.keys.unshift(null);
|
|
83
|
+
if (this.hasNullOption === true)
|
|
84
|
+
this.values.unshift(null);
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* set the value of the dropdown based if translation is set
|
|
88
|
+
* @param key
|
|
89
|
+
*/
|
|
90
|
+
setDisplayKey(key) {
|
|
91
|
+
/*
|
|
92
|
+
if (this.translation && key !== null) {
|
|
93
|
+
if (this.translation.isPrefix) {
|
|
94
|
+
return this.translationService.instant(this.translation.path + '.' + key);
|
|
95
|
+
} else if (this.translation.useKey) {
|
|
96
|
+
return this.translationService.instant(this.translation.path, { key: key });
|
|
97
|
+
} else if (!this.translation?.useKey && !this.translation?.isPrefix) {
|
|
98
|
+
return this.translationService.instant(this.translation.path);
|
|
99
|
+
}
|
|
100
|
+
} else if (key == null) {
|
|
101
|
+
return '';
|
|
102
|
+
} else if (!this.translation) {
|
|
103
|
+
return key;
|
|
104
|
+
}
|
|
105
|
+
*/
|
|
106
|
+
return key;
|
|
107
|
+
}
|
|
108
|
+
valueChanged(value) {
|
|
109
|
+
this.form.patchValue({
|
|
110
|
+
dropdownData: value,
|
|
111
|
+
});
|
|
112
|
+
this.onSelectItemEmitter.emit(value);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
DropdownFromDataComponent.decorators = [
|
|
116
|
+
{ type: Component, args: [{
|
|
117
|
+
selector: 'kms-dropdown-from-data',
|
|
118
|
+
template: "<form [formGroup]=\"form\">\n <mat-form-field [attr.required]=\"required\" [floatLabel]=\"placeholder ? 'always' : 'auto'\">\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 >\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",
|
|
119
|
+
providers: [
|
|
120
|
+
{
|
|
121
|
+
provide: NG_VALUE_ACCESSOR,
|
|
122
|
+
useExisting: forwardRef(() => DropdownFromDataComponent),
|
|
123
|
+
multi: true,
|
|
124
|
+
},
|
|
125
|
+
]
|
|
126
|
+
},] }
|
|
127
|
+
];
|
|
128
|
+
DropdownFromDataComponent.ctorParameters = () => [
|
|
129
|
+
{ type: FormBuilder },
|
|
130
|
+
{ type: Renderer2 }
|
|
131
|
+
];
|
|
132
|
+
DropdownFromDataComponent.propDecorators = {
|
|
133
|
+
optionsEnum: [{ type: Input }],
|
|
134
|
+
optionsPlainArray: [{ type: Input }],
|
|
135
|
+
optionsObjArray: [{ type: Input }],
|
|
136
|
+
mapKey: [{ type: Input }],
|
|
137
|
+
mapValue: [{ type: Input }],
|
|
138
|
+
hasNullOption: [{ type: Input }],
|
|
139
|
+
translation: [{ type: Input }],
|
|
140
|
+
placeholder: [{ type: Input }],
|
|
141
|
+
label: [{ type: Input }],
|
|
142
|
+
required: [{ type: Input }],
|
|
143
|
+
useEnumIndexAsValue: [{ type: Input }]
|
|
144
|
+
};
|
|
145
|
+
//# 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"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, OnInit, OnChanges, SimpleChanges, Renderer2 } from '@angular/core';\nimport { ControlValueAccessor, FormBuilder, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { EnumValues } from 'enum-values/src/enumValues';\n//import { EnumValues } from 'enum-values';\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 extends FormControlParentComponent\n    implements OnInit, ControlValueAccessor, OnChanges {\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    @Input() translation?: ITranslation;\n    @Input() placeholder = '';\n    @Input() label = '';\n    @Input() required = false;\n    @Input() useEnumIndexAsValue = false;\n\n    public keys: any[] = [];\n    public values: any[] = [];\n\n    Object = Object;\n\n    constructor(\n        public formBuilder: FormBuilder,\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.keys = this.optionsPlainArray;\n            this.values = 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((obj: any) => obj[`${this.mapValue}`]);\n        } else if (this.optionsObjArray && this.mapKey) {\n            this.keys = this.optionsObjArray.map((obj: any) => obj[`${this.mapKey}`]);\n            this.values = this.optionsObjArray.map((obj: any) => obj[`${this.mapKey}`]);\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        /*\n        if (this.translation && key !== null) {\n            if (this.translation.isPrefix) {\n                return this.translationService.instant(this.translation.path + '.' + key);\n            } else if (this.translation.useKey) {\n                return this.translationService.instant(this.translation.path, { key: key });\n            } else if (!this.translation?.useKey && !this.translation?.isPrefix) {\n                return this.translationService.instant(this.translation.path);\n            }\n        } else if (key == null) {\n            return '';\n        } else if (!this.translation) {\n            return key;\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    useKey?: boolean;\n    isPrefix?: boolean;\n}\n"]}
|
|
@@ -66,7 +66,7 @@ FlyoutComponent.decorators = [
|
|
|
66
66
|
}),
|
|
67
67
|
]),
|
|
68
68
|
],
|
|
69
|
-
styles: ["
|
|
69
|
+
styles: [""]
|
|
70
70
|
},] }
|
|
71
71
|
];
|
|
72
72
|
FlyoutComponent.propDecorators = {
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* @copyright FLYACTS GmbH 2019
|
|
3
|
+
*/
|
|
4
|
+
import { Component, EventEmitter, HostListener, Input, Output, ViewChild, } from '@angular/core';
|
|
5
|
+
import { DomSanitizer } from '@angular/platform-browser';
|
|
6
|
+
import { moveItemInArray } from '@angular/cdk/drag-drop';
|
|
7
|
+
export class ImageSliderComponent {
|
|
8
|
+
constructor(sanitizer) {
|
|
9
|
+
this.sanitizer = sanitizer;
|
|
10
|
+
this.editMode = false;
|
|
11
|
+
this.orderChanged = new EventEmitter();
|
|
12
|
+
this.deleteImageEvent = new EventEmitter();
|
|
13
|
+
/**
|
|
14
|
+
* Optional: Define Swipe behaviour configuration.
|
|
15
|
+
* Default is 10% for the threshold definition until a swipe triggers next/previous slide.
|
|
16
|
+
*/
|
|
17
|
+
this.swipeConfig = {
|
|
18
|
+
swipeThreshold: 5,
|
|
19
|
+
swipeThresholdType: '%',
|
|
20
|
+
swipeLocalPosition: true,
|
|
21
|
+
};
|
|
22
|
+
this.selectedSlide = 0;
|
|
23
|
+
this.isLastClickedInSliderImage = false;
|
|
24
|
+
this.config = {
|
|
25
|
+
initialSlide: 0,
|
|
26
|
+
slidesPerView: 3,
|
|
27
|
+
navigation: {
|
|
28
|
+
nextEl: '.swiper-button-next',
|
|
29
|
+
prevEl: '.swiper-button-prev',
|
|
30
|
+
},
|
|
31
|
+
watchOverflow: true,
|
|
32
|
+
autoHeight: true,
|
|
33
|
+
allowTouchMove: false,
|
|
34
|
+
spaceBetween: 30,
|
|
35
|
+
on: {
|
|
36
|
+
slideChange: () => {
|
|
37
|
+
// do something
|
|
38
|
+
},
|
|
39
|
+
slideChangeTransitionEnd: () => {
|
|
40
|
+
// do something
|
|
41
|
+
},
|
|
42
|
+
},
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
ngOnInit() {
|
|
46
|
+
if (this.slides) {
|
|
47
|
+
// TODO use Pipe safeStyle
|
|
48
|
+
this.selectedSlideImage = this.sanitizer.bypassSecurityTrustStyle('url(' + this.slides[0] + ')');
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
// !TODO
|
|
52
|
+
onKeydownHandler(event) {
|
|
53
|
+
if (event.key === 'ArrowRight') {
|
|
54
|
+
this.nextSlide();
|
|
55
|
+
}
|
|
56
|
+
if (event.key === 'ArrowLeft') {
|
|
57
|
+
this.previousSlide();
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Slide follows the finger or mouse according to it´s move delta.
|
|
62
|
+
* @param event SwipeMoveEvent
|
|
63
|
+
*/
|
|
64
|
+
handleMoveEvent(event) {
|
|
65
|
+
// certain move threshold needs to be reached
|
|
66
|
+
if (!event.thresholdWasReached) {
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
this.config.direction = event.direction === 1 ? 'horizontal' : 'vertical';
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Mouse up or slide container was left.
|
|
73
|
+
* @param event SwipeReleaseEvent
|
|
74
|
+
*/
|
|
75
|
+
handleReleaseEvent(event) {
|
|
76
|
+
if (!event.thresholdWasReached) {
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
// Just do if user clicked to slide on image and not on arrow or other element
|
|
80
|
+
if (!this.isLastClickedInSliderImage) {
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
83
|
+
if (event.direction === 1) {
|
|
84
|
+
this.previousSlide();
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
this.nextSlide();
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
lastClicked() {
|
|
91
|
+
this.isLastClickedInSliderImage = true;
|
|
92
|
+
}
|
|
93
|
+
noLastClicked() {
|
|
94
|
+
this.isLastClickedInSliderImage = false;
|
|
95
|
+
}
|
|
96
|
+
scrollLeft() {
|
|
97
|
+
this.previousSlide();
|
|
98
|
+
}
|
|
99
|
+
scrollRight() {
|
|
100
|
+
this.nextSlide();
|
|
101
|
+
}
|
|
102
|
+
nextSlide() {
|
|
103
|
+
if (this.slides && this.selectedSlide < this.slides.length - 1) {
|
|
104
|
+
if (this.usefulSwiper) {
|
|
105
|
+
this.usefulSwiper.swiper.slideNext();
|
|
106
|
+
}
|
|
107
|
+
this.openSlide(this.selectedSlide + 1);
|
|
108
|
+
}
|
|
109
|
+
this.isLastClickedInSliderImage = false;
|
|
110
|
+
}
|
|
111
|
+
previousSlide() {
|
|
112
|
+
if (this.selectedSlide > 0) {
|
|
113
|
+
if (this.usefulSwiper) {
|
|
114
|
+
this.usefulSwiper.swiper.slidePrev();
|
|
115
|
+
}
|
|
116
|
+
this.openSlide(this.selectedSlide - 1);
|
|
117
|
+
}
|
|
118
|
+
this.isLastClickedInSliderImage = false;
|
|
119
|
+
}
|
|
120
|
+
slideTo(index) {
|
|
121
|
+
if (this.usefulSwiper) {
|
|
122
|
+
this.usefulSwiper.swiper.slideTo(index);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
openSlide(number) {
|
|
126
|
+
if (this.slides && number < this.slides.length && number >= 0) {
|
|
127
|
+
this.selectedSlide = number;
|
|
128
|
+
// TODO use Pipe safeStyle
|
|
129
|
+
this.selectedSlideImage = this.sanitizer.bypassSecurityTrustStyle('url(' + this.slides[number] || ')');
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
ngOnChanges(_changes) {
|
|
133
|
+
if (_changes.slides) {
|
|
134
|
+
if (this.slides) {
|
|
135
|
+
// TODO use Pipe safeStyle
|
|
136
|
+
this.selectedSlideImage = this.sanitizer.bypassSecurityTrustStyle('url(' + this.slides[0] + ')');
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
/**
|
|
141
|
+
* Re-order slides and notify parent component
|
|
142
|
+
*/
|
|
143
|
+
drop(event) {
|
|
144
|
+
if (this.slides && this.imagesTOSave) {
|
|
145
|
+
moveItemInArray(this.slides, event.previousIndex, event.currentIndex);
|
|
146
|
+
moveItemInArray(this.imagesTOSave, event.previousIndex, event.currentIndex);
|
|
147
|
+
this.orderChanged.emit(this.imagesTOSave);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
/**
|
|
151
|
+
* Send image index to parent to perform delete
|
|
152
|
+
*/
|
|
153
|
+
deleteImage(index) {
|
|
154
|
+
this.deleteImageEvent.emit(index);
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
ImageSliderComponent.decorators = [
|
|
158
|
+
{ type: Component, args: [{
|
|
159
|
+
selector: 'kms-image-slider',
|
|
160
|
+
template: "<div class=\"all-wrapper\">\r\n <!--(swiperight)=\"previousSlide()\" (swipeleft)=\"nextSlide()\"-->\r\n <div \r\n class=\"swiper-bigImage\"\r\n [style.backgroundImage]=\"selectedSlideImage\"\r\n [swipeDirective]=\"swipeConfig\"\r\n (moveEvent)=\"handleMoveEvent($event)\"\r\n (releaseEvent)=\"handleReleaseEvent($event)\"\r\n (mouseup)=\"lastClicked()\"\r\n (mouseout)=\"noLastClicked()\" >\r\n </div>\r\n\r\n <ng-content select=\"[description]\"></ng-content>\r\n\r\n <div class=\"swiper-holder\">\r\n <!--\r\n (mouseWheelUp)=\"scrollLeft($event)\"\r\n (mouseWheelDown)=\"scrollRight($event)\"\r\n -->\r\n\r\n <swiper [config]=\"config\" #usefulSwiper>\r\n <div class=\"swiper-wrapper\" \r\n cdkDropList (cdkDropListDropped)=\"drop($event)\" \r\n cdkDropListOrientation=\"horizontal\"> \r\n <div class=\"swiper-slide\" \r\n *ngFor=\"let slide of slides; let index = index\" \r\n cdkDrag [cdkDragDisabled]=\"!editMode\">\r\n <button mat-menu-item *ngIf=\"editMode\" (click)=\"deleteImage(index)\"> \r\n <kms-icon icon=\"trash\"></kms-icon>\r\n </button>\r\n <div class=\"img\" (click)=\"openSlide(index)\"\r\n [style.backgroundImage]=\"sanitizer.bypassSecurityTrustStyle('url(' + slide + ')')\"\r\n [ngClass]=\"{'active': index === selectedSlide}\">\r\n </div>\r\n \r\n <div class=\"default-image\">{{\"common.defaultImage\" | translate}} </div>\r\n </div>\r\n </div>\r\n </swiper>\r\n\r\n <div class=\"swiper-button-next\" *ngIf=\"slides?.length > 3\"></div>\r\n <div class=\"swiper-button-prev\" *ngIf=\"slides?.length > 3\"></div>\r\n\r\n <div class=\"swiper-button-next2\" *ngIf=\"slides?.length > 1\" (click)=\"nextSlide()\">\r\n <kms-icon icon=\"chevron-right\" [iconClass]=\"{'color-disabled': selectedSlide == slides?.length - 1, 'color-primary': true}\"></kms-icon>\r\n </div>\r\n <div class=\"swiper-button-prev2\" *ngIf=\"slides?.length > 1\" (click)=\"previousSlide()\">\r\n <kms-icon icon=\"chevron-left\" [iconClass]=\"{'color-disabled': selectedSlide == 0, 'color-primary': true}\"></kms-icon>\r\n </div>\r\n\r\n </div>\r\n\r\n <ng-content></ng-content>\r\n</div>",
|
|
161
|
+
styles: [""]
|
|
162
|
+
},] }
|
|
163
|
+
];
|
|
164
|
+
ImageSliderComponent.ctorParameters = () => [
|
|
165
|
+
{ type: DomSanitizer }
|
|
166
|
+
];
|
|
167
|
+
ImageSliderComponent.propDecorators = {
|
|
168
|
+
slides: [{ type: Input }],
|
|
169
|
+
editMode: [{ type: Input }],
|
|
170
|
+
imagesTOSave: [{ type: Input }],
|
|
171
|
+
orderChanged: [{ type: Output }],
|
|
172
|
+
deleteImageEvent: [{ type: Output }],
|
|
173
|
+
swipeConfig: [{ type: Input }],
|
|
174
|
+
usefulSwiper: [{ type: ViewChild, args: ['usefulSwiper',] }],
|
|
175
|
+
onKeydownHandler: [{ type: HostListener, args: ['document:keydown', ['$event'],] }]
|
|
176
|
+
};
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-slider.component.js","sourceRoot":"","sources":["../../../../../../../projects/kms-ngx-ui-presentational/src/lib/ui/image-slider/image-slider.component.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EACH,SAAS,EACT,YAAY,EACZ,YAAY,EACZ,KAAK,EAGL,MAAM,EAEN,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAa,MAAM,2BAA2B,CAAC;AAIpE,OAAO,EAAe,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAUtE,MAAM,OAAO,oBAAoB;IA8C7B,YAAmB,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;QA5CjC,aAAQ,GAAG,KAAK,CAAC;QAEhB,iBAAY,GAAiC,IAAI,YAAY,EAAE,CAAC;QAChE,qBAAgB,GAAyB,IAAI,YAAY,EAAE,CAAC;QAEtE;;;WAGG;QACM,gBAAW,GAAiB;YACjC,cAAc,EAAE,CAAC;YACjB,kBAAkB,EAAE,GAAG;YACvB,kBAAkB,EAAE,IAAI;SAC3B,CAAC;QAEK,kBAAa,GAAG,CAAC,CAAC;QAIlB,+BAA0B,GAAG,KAAK,CAAC;QAI1C,WAAM,GAAkB;YACpB,YAAY,EAAE,CAAC;YACf,aAAa,EAAE,CAAC;YAChB,UAAU,EAAE;gBACR,MAAM,EAAE,qBAAqB;gBAC7B,MAAM,EAAE,qBAAqB;aAChC;YACD,aAAa,EAAE,IAAI;YACnB,UAAU,EAAE,IAAI;YAChB,cAAc,EAAE,KAAK;YACrB,YAAY,EAAE,EAAE;YAChB,EAAE,EAAE;gBACA,WAAW,EAAE,GAAG,EAAE;oBACd,eAAe;gBACnB,CAAC;gBACD,wBAAwB,EAAE,GAAG,EAAE;oBAC3B,eAAe;gBACnB,CAAC;aACJ;SACJ,CAAC;IAE2C,CAAC;IAE9C,QAAQ;QACJ,IAAI,IAAI,CAAC,MAAM,EAAE;YACb,0BAA0B;YAE1B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;SACpG;IACL,CAAC;IAED,QAAQ;IACsC,gBAAgB,CAAC,KAAoB;QAC/E,IAAI,KAAK,CAAC,GAAG,KAAK,YAAY,EAAE;YAC5B,IAAI,CAAC,SAAS,EAAE,CAAC;SACpB;QACD,IAAI,KAAK,CAAC,GAAG,KAAK,WAAW,EAAE;YAC3B,IAAI,CAAC,aAAa,EAAE,CAAC;SACxB;IACL,CAAC;IAED;;;OAGG;IACH,eAAe,CAAC,KAAqB;QACjC,6CAA6C;QAC7C,IAAI,CAAC,KAAK,CAAC,mBAAmB,EAAE;YAC5B,OAAO;SACV;QACD,IAAI,CAAC,MAAM,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,UAAU,CAAC;IAC9E,CAAC;IAED;;;OAGG;IACH,kBAAkB,CAAC,KAAwB;QACvC,IAAI,CAAC,KAAK,CAAC,mBAAmB,EAAE;YAC5B,OAAO;SACV;QACD,8EAA8E;QAC9E,IAAI,CAAC,IAAI,CAAC,0BAA0B,EAAE;YAClC,OAAO;SACV;QACD,IAAI,KAAK,CAAC,SAAS,KAAK,CAAC,EAAE;YACvB,IAAI,CAAC,aAAa,EAAE,CAAC;SACxB;aAAM;YACH,IAAI,CAAC,SAAS,EAAE,CAAC;SACpB;IACL,CAAC;IAED,WAAW;QACP,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC;IAC3C,CAAC;IAED,aAAa;QACT,IAAI,CAAC,0BAA0B,GAAG,KAAK,CAAC;IAC5C,CAAC;IAED,UAAU;QACN,IAAI,CAAC,aAAa,EAAE,CAAC;IACzB,CAAC;IAED,WAAW;QACP,IAAI,CAAC,SAAS,EAAE,CAAC;IACrB,CAAC;IAED,SAAS;QACL,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;YAC5D,IAAI,IAAI,CAAC,YAAY,EAAE;gBACnB,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;aACxC;YACD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC;SAC1C;QACD,IAAI,CAAC,0BAA0B,GAAG,KAAK,CAAC;IAC5C,CAAC;IAED,aAAa;QACT,IAAI,IAAI,CAAC,aAAa,GAAG,CAAC,EAAE;YACxB,IAAI,IAAI,CAAC,YAAY,EAAE;gBACnB,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;aACxC;YACD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC;SAC1C;QACD,IAAI,CAAC,0BAA0B,GAAG,KAAK,CAAC;IAC5C,CAAC;IAED,OAAO,CAAC,KAAa;QACjB,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;SAC3C;IACL,CAAC;IAED,SAAS,CAAC,MAAc;QACpB,IAAI,IAAI,CAAC,MAAM,IAAI,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,MAAM,IAAI,CAAC,EAAE;YAC3D,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC;YAC5B,0BAA0B;YAE1B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,GAAG,CAAC,CAAC;SAC1G;IACL,CAAC;IAED,WAAW,CAAC,QAAuB;QAC/B,IAAI,QAAQ,CAAC,MAAM,EAAE;YACjB,IAAI,IAAI,CAAC,MAAM,EAAE;gBACb,0BAA0B;gBAE1B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;aACpG;SACJ;IACL,CAAC;IAED;;OAEG;IACH,IAAI,CAAC,KAA4B;QAC7B,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,YAAY,EAAE;YAClC,eAAe,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC;YACtE,eAAe,CAAC,IAAI,CAAC,YAAY,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC;YAC5E,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SAC7C;IACL,CAAC;IAED;;OAEG;IACH,WAAW,CAAC,KAAa;QACrB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;;;YAnLJ,SAAS,SAAC;gBACP,QAAQ,EAAE,kBAAkB;gBAC5B,whFAA4C;;aAE/C;;;YAbQ,YAAY;;;qBAehB,KAAK;uBACL,KAAK;2BACL,KAAK;2BACL,MAAM;+BACN,MAAM;0BAMN,KAAK;2BAYL,SAAS,SAAC,cAAc;+BAkCxB,YAAY,SAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["/*!\r\n * @copyright FLYACTS GmbH 2019\r\n */\r\n\r\nimport {\r\n    Component,\r\n    EventEmitter,\r\n    HostListener,\r\n    Input,\r\n    OnChanges,\r\n    OnInit,\r\n    Output,\r\n    SimpleChanges,\r\n    ViewChild,\r\n} from '@angular/core';\r\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\r\n\r\nimport { SwiperComponent } from 'ngx-useful-swiper';\r\nimport { SwiperOptions } from 'swiper';\r\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\r\nimport { ImageSnippet } from '../../models/image-snippet.model';\r\nimport { SwipeMoveEvent, SwipeOptions, SwipeReleaseEvent } from '../../directives/swipe.model';\r\n\r\n\r\n@Component({\r\n    selector: 'kms-image-slider',\r\n    templateUrl: './image-slider.component.html',\r\n    styleUrls: ['./image-slider.component.scss'],\r\n})\r\nexport class ImageSliderComponent implements OnInit, OnChanges {\r\n    @Input() slides: string[] | undefined;\r\n    @Input() editMode = false;\r\n    @Input() imagesTOSave: ImageSnippet[] | undefined;\r\n    @Output() orderChanged: EventEmitter<ImageSnippet[]> = new EventEmitter();\r\n    @Output() deleteImageEvent: EventEmitter<number> = new EventEmitter();\r\n\r\n    /**\r\n     * Optional: Define Swipe behaviour configuration.\r\n     * Default is 10% for the threshold definition until a swipe triggers next/previous slide.\r\n     */\r\n    @Input() swipeConfig: SwipeOptions = {\r\n        swipeThreshold: 5,\r\n        swipeThresholdType: '%',\r\n        swipeLocalPosition: true,\r\n    };\r\n\r\n    public selectedSlide = 0;\r\n    public checkedImageIndex?: number;\r\n\r\n    public selectedSlideImage: SafeStyle | undefined;\r\n    public isLastClickedInSliderImage = false;\r\n\r\n    @ViewChild('usefulSwiper') usefulSwiper: SwiperComponent | undefined;\r\n\r\n    config: SwiperOptions = {\r\n        initialSlide: 0,\r\n        slidesPerView: 3,\r\n        navigation: {\r\n            nextEl: '.swiper-button-next',\r\n            prevEl: '.swiper-button-prev',\r\n        },\r\n        watchOverflow: true,\r\n        autoHeight: true,\r\n        allowTouchMove: false,\r\n        spaceBetween: 30,\r\n        on: {\r\n            slideChange: () => {\r\n                // do something\r\n            },\r\n            slideChangeTransitionEnd: () => {\r\n                // do something\r\n            },\r\n        },\r\n    };\r\n\r\n    constructor(public sanitizer: DomSanitizer) {}\r\n\r\n    ngOnInit() {\r\n        if (this.slides) {\r\n            // TODO use Pipe safeStyle\r\n\r\n            this.selectedSlideImage = this.sanitizer.bypassSecurityTrustStyle('url(' + this.slides[0] + ')');\r\n        }\r\n    }\r\n\r\n    // !TODO\r\n    @HostListener('document:keydown', ['$event']) onKeydownHandler(event: KeyboardEvent) {\r\n        if (event.key === 'ArrowRight') {\r\n            this.nextSlide();\r\n        }\r\n        if (event.key === 'ArrowLeft') {\r\n            this.previousSlide();\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Slide follows the finger or mouse according to it´s move delta.\r\n     * @param event SwipeMoveEvent\r\n     */\r\n    handleMoveEvent(event: SwipeMoveEvent) {\r\n        // certain move threshold needs to be reached\r\n        if (!event.thresholdWasReached) {\r\n            return;\r\n        }\r\n        this.config.direction = event.direction === 1 ? 'horizontal' : 'vertical';\r\n    }\r\n\r\n    /**\r\n     * Mouse up or slide container was left.\r\n     * @param event SwipeReleaseEvent\r\n     */\r\n    handleReleaseEvent(event: SwipeReleaseEvent) {\r\n        if (!event.thresholdWasReached) {\r\n            return;\r\n        }\r\n        // Just do if user clicked to slide on image and not on arrow or other element\r\n        if (!this.isLastClickedInSliderImage) {\r\n            return;\r\n        }\r\n        if (event.direction === 1) {\r\n            this.previousSlide();\r\n        } else {\r\n            this.nextSlide();\r\n        }\r\n    }\r\n\r\n    lastClicked() {\r\n        this.isLastClickedInSliderImage = true;\r\n    }\r\n\r\n    noLastClicked() {\r\n        this.isLastClickedInSliderImage = false;\r\n    }\r\n\r\n    scrollLeft() {\r\n        this.previousSlide();\r\n    }\r\n\r\n    scrollRight() {\r\n        this.nextSlide();\r\n    }\r\n\r\n    nextSlide() {\r\n        if (this.slides && this.selectedSlide < this.slides.length - 1) {\r\n            if (this.usefulSwiper) {\r\n                this.usefulSwiper.swiper.slideNext();\r\n            }\r\n            this.openSlide(this.selectedSlide + 1);\r\n        }\r\n        this.isLastClickedInSliderImage = false;\r\n    }\r\n\r\n    previousSlide() {\r\n        if (this.selectedSlide > 0) {\r\n            if (this.usefulSwiper) {\r\n                this.usefulSwiper.swiper.slidePrev();\r\n            }\r\n            this.openSlide(this.selectedSlide - 1);\r\n        }\r\n        this.isLastClickedInSliderImage = false;\r\n    }\r\n\r\n    slideTo(index: number) {\r\n        if (this.usefulSwiper) {\r\n            this.usefulSwiper.swiper.slideTo(index);\r\n        }\r\n    }\r\n\r\n    openSlide(number: number) {\r\n        if (this.slides && number < this.slides.length && number >= 0) {\r\n            this.selectedSlide = number;\r\n            // TODO use Pipe safeStyle\r\n\r\n            this.selectedSlideImage = this.sanitizer.bypassSecurityTrustStyle('url(' + this.slides[number] || ')');\r\n        }\r\n    }\r\n\r\n    ngOnChanges(_changes: SimpleChanges) {\r\n        if (_changes.slides) {\r\n            if (this.slides) {\r\n                // TODO use Pipe safeStyle\r\n\r\n                this.selectedSlideImage = this.sanitizer.bypassSecurityTrustStyle('url(' + this.slides[0] + ')');\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Re-order slides and notify parent component\r\n     */\r\n    drop(event: CdkDragDrop<string[]>) {\r\n        if (this.slides && this.imagesTOSave) {\r\n            moveItemInArray(this.slides, event.previousIndex, event.currentIndex);\r\n            moveItemInArray(this.imagesTOSave, event.previousIndex, event.currentIndex);\r\n            this.orderChanged.emit(this.imagesTOSave);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Send image index to parent to perform delete\r\n     */\r\n    deleteImage(index: number) {\r\n        this.deleteImageEvent.emit(index);\r\n    }\r\n}\r\n"]}
|
|
@@ -54,7 +54,7 @@ RadioButtonComponent.decorators = [
|
|
|
54
54
|
multi: true,
|
|
55
55
|
},
|
|
56
56
|
],
|
|
57
|
-
styles: ["
|
|
57
|
+
styles: [""]
|
|
58
58
|
},] }
|
|
59
59
|
];
|
|
60
60
|
RadioButtonComponent.ctorParameters = () => [];
|
package/esm2015/public-api.js
CHANGED
|
@@ -5,9 +5,10 @@ export * from './lib/kms-ngx-ui-presentational.service';
|
|
|
5
5
|
export * from './lib/kms-ngx-ui-presentational.component';
|
|
6
6
|
export * from './lib/kms-ngx-ui-presentational.module';
|
|
7
7
|
export * from './lib/pipes/custom-pipes.module';
|
|
8
|
+
export * from './lib/directives/directives.module';
|
|
8
9
|
export * from './lib/models/iconSize.enum';
|
|
9
10
|
export * from './lib/models/salutation.enum';
|
|
10
11
|
//export * from './lib/ui/checkbox/checkbox.component';
|
|
11
12
|
//export * from './lib/parent-components/actions.component';
|
|
12
13
|
export * from './lib/ui/generic-dialog/generic-dialog.component';
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2ttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWwvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsb0NBQW9DLENBQUM7QUFFbkQsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLHVEQUF1RDtBQUN2RCw0REFBNEQ7QUFDNUQsY0FBYyxrREFBa0QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBrbXMtbmd4LXVpLXByZXNlbnRhdGlvbmFsXHJcbiAqL1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIva21zLW5neC11aS1wcmVzZW50YXRpb25hbC5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIva21zLW5neC11aS1wcmVzZW50YXRpb25hbC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9rbXMtbmd4LXVpLXByZXNlbnRhdGlvbmFsLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BpcGVzL2N1c3RvbS1waXBlcy5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL2RpcmVjdGl2ZXMubW9kdWxlJztcclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9pY29uU2l6ZS5lbnVtJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL3NhbHV0YXRpb24uZW51bSc7XHJcbi8vZXhwb3J0ICogZnJvbSAnLi9saWIvdWkvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50JztcclxuLy9leHBvcnQgKiBmcm9tICcuL2xpYi9wYXJlbnQtY29tcG9uZW50cy9hY3Rpb25zLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VpL2dlbmVyaWMtZGlhbG9nL2dlbmVyaWMtZGlhbG9nLmNvbXBvbmVudCc7XHJcbiJdfQ==
|