@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.
Files changed (49) hide show
  1. package/bundles/kms-ngx-ui-presentational.umd.js +820 -60
  2. package/bundles/kms-ngx-ui-presentational.umd.js.map +1 -1
  3. package/esm2015/kms-ngx-ui-presentational.js +36 -30
  4. package/esm2015/lib/directives/directives.module.js +29 -0
  5. package/esm2015/lib/directives/mousewheel.directive.js +46 -0
  6. package/esm2015/lib/directives/sum-of-height.directive.js +71 -0
  7. package/esm2015/lib/directives/swipe.directive.js +159 -0
  8. package/esm2015/lib/directives/swipe.model.js +5 -0
  9. package/esm2015/lib/directives/tooltip.directive.js +124 -0
  10. package/esm2015/lib/kms-ngx-ui-presentational.module.js +29 -23
  11. package/esm2015/lib/models/image-snippet.model.js +18 -0
  12. package/esm2015/lib/ui/checkbox/checkbox.component.js +1 -1
  13. package/esm2015/lib/ui/color-input/color-input.component.js +1 -1
  14. package/esm2015/lib/ui/dropdown-from-data/dropdown-from-data.component.js +145 -0
  15. package/esm2015/lib/ui/flyout/flyout.component.js +1 -1
  16. package/esm2015/lib/ui/image-slider/image-slider.component.js +177 -0
  17. package/esm2015/lib/ui/radiobutton/radiobutton.component.js +1 -1
  18. package/esm2015/lib/ui/time-input/time-input.component.js +1 -1
  19. package/esm2015/public-api.js +2 -1
  20. package/fesm2015/kms-ngx-ui-presentational.js +766 -29
  21. package/fesm2015/kms-ngx-ui-presentational.js.map +1 -1
  22. package/kms-ngx-ui-presentational.d.ts +36 -30
  23. package/kms-ngx-ui-presentational.metadata.json +1 -1
  24. package/lib/directives/directives.module.d.ts +5 -0
  25. package/lib/directives/mousewheel.directive.d.ts +12 -0
  26. package/lib/directives/sum-of-height.directive.d.ts +28 -0
  27. package/lib/directives/swipe.directive.d.ts +42 -0
  28. package/lib/directives/swipe.model.d.ts +49 -0
  29. package/lib/directives/tooltip.directive.d.ts +26 -0
  30. package/lib/models/image-snippet.model.d.ts +15 -0
  31. package/lib/ui/dropdown-from-data/dropdown-from-data.component.d.ts +51 -0
  32. package/lib/ui/image-slider/image-slider.component.d.ts +59 -0
  33. package/package.json +2 -1
  34. package/public-api.d.ts +1 -0
  35. package/src/lib/ui/back-to-top/back-to-top.component.scss +46 -46
  36. package/src/lib/ui/button-with-confirm-dialog/button-with-confirm-dialog.component.scss +3 -0
  37. package/src/lib/ui/checkbox/checkbox.component.scss +48 -56
  38. package/src/lib/ui/color-input/color-input.component.scss +39 -38
  39. package/src/lib/ui/file-input/file-input.component.scss +3 -0
  40. package/src/lib/ui/flyout/flyout.component.scss +35 -34
  41. package/src/lib/ui/generic-dialog/generic-dialog.component.scss +59 -59
  42. package/src/lib/ui/icon/icon.component.scss +148 -148
  43. package/src/lib/ui/image-slider/image-slider.component.scss +220 -0
  44. package/src/lib/ui/kms-accordion-item/kms-accordion-item.component.scss +95 -95
  45. package/src/lib/ui/radiobutton/radiobutton.component.scss +32 -30
  46. package/src/lib/ui/time-input/time-input.component.scss +11 -10
  47. package/src/lib/ui/tooltip/tooltip.component.scss +26 -26
  48. package/src/lib/ui/tooltip-icon/tooltip-icon.component.scss +2 -2
  49. 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 { TranslateModule } from '@ngx-translate/core';
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
- RadioButtonComponent,
44
- TimeInputComponent,
45
- YesNoRadiogroupComponent,
46
+ DropdownFromDataComponent,
47
+ EnumRadiogroupComponent,
48
+ EnumRadiogroupComponent,
46
49
  FileInputComponent,
47
- LoaderComponent,
48
50
  FlyoutComponent,
51
+ GenericDialogComponent,
49
52
  IconComponent,
50
- EnumRadiogroupComponent,
53
+ ImageSliderComponent,
51
54
  KMSAccordionItemComponent,
52
- EnumRadiogroupComponent,
55
+ KmsUiPresentationalComponent,
56
+ LoaderComponent,
53
57
  MapComponent,
58
+ RadioButtonComponent,
54
59
  SalutationDropdownComponent,
55
60
  SalutationRadiogroupComponent,
61
+ TimeInputComponent,
56
62
  TooltipComponent,
57
63
  TooltipIconComponent,
58
- BackToTopComponent,
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
- TranslateModule
78
+ DirectivesModule
75
79
  ],
76
80
  exports: [
77
- KmsUiPresentationalComponent,
78
81
  ActionsParentComponent,
82
+ BackToTopComponent,
83
+ ButtonWithConfirmDialogComponent,
79
84
  CheckboxComponent,
80
85
  ColorInputComponent,
81
- RadioButtonComponent,
82
- TimeInputComponent,
83
- YesNoRadiogroupComponent,
86
+ DropdownFromDataComponent,
87
+ EnumRadiogroupComponent,
88
+ EnumRadiogroupComponent,
84
89
  FileInputComponent,
85
- LoaderComponent,
86
90
  FlyoutComponent,
91
+ GenericDialogComponent,
87
92
  IconComponent,
88
- EnumRadiogroupComponent,
93
+ ImageSliderComponent,
89
94
  KMSAccordionItemComponent,
90
- EnumRadiogroupComponent,
95
+ KmsUiPresentationalComponent,
96
+ LoaderComponent,
91
97
  MapComponent,
98
+ RadioButtonComponent,
92
99
  SalutationDropdownComponent,
93
100
  SalutationRadiogroupComponent,
101
+ TimeInputComponent,
94
102
  TooltipComponent,
95
103
  TooltipIconComponent,
96
- BackToTopComponent,
97
- GenericDialogComponent,
98
- ButtonWithConfirmDialogComponent
104
+ YesNoRadiogroupComponent
99
105
  ]
100
106
  },] }
101
107
  ];
102
- //# 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';\nimport { CommonModule } from '@angular/common';\n\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { KmsUiPresentationalComponent } from './kms-ngx-ui-presentational.component';\nimport { ActionsParentComponent } from './parent-components/actions.component';\nimport { CheckboxComponent } from './ui/checkbox/checkbox.component';\n\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatRadioModule } from '@angular/material/radio';\nimport { ColorInputComponent } from './ui/color-input/color-input.component';\nimport { RadioButtonComponent } from './ui/radiobutton/radiobutton.component';\nimport { TimeInputComponent } from './ui/time-input/time-input.component';\nimport { YesNoRadiogroupComponent } from './ui/yes-no-radiogroup/yes-no-radiogroup.component';\nimport { FileInputComponent } from './ui/file-input/file-input.component';\nimport { LoaderComponent } from './ui/loader/loader.component';\nimport { FlyoutComponent } from './ui/flyout/flyout.component';\nimport { CustomPipesModule } from './pipes/custom-pipes.module';\nimport { IconComponent } from './ui/icon/icon.component';\nimport { EnumRadiogroupComponent } from './ui/enum-radiogroup/enum-radiogroup.component';\nimport { KMSAccordionItemComponent } from './ui/kms-accordion-item/kms-accordion-item.component';\nimport { MapComponent } from './ui/map/map.component';\nimport { SalutationDropdownComponent } from './ui/salutation-dropdown/salutation-dropdown.component';\nimport { TooltipComponent } from './ui/tooltip/tooltip.component';\nimport { TooltipIconComponent } from './ui/tooltip-icon/tooltip-icon.component';\n\nimport { SalutationRadiogroupComponent } from './ui/salutation-radiogroup/salutation-radiogroup.component';\nimport { BackToTopComponent } from './ui/back-to-top/back-to-top.component';\nimport { ButtonWithConfirmDialogComponent } from './ui/button-with-confirm-dialog/button-with-confirm-dialog.component';\nimport { GoogleMapsModule } from '@angular/google-maps';\nimport { MatDialogModule } from '@angular/material/dialog';\nimport { MatButtonModule } from '@angular/material/button';\nimport { GenericDialogComponent } from './ui/generic-dialog/generic-dialog.component';\nimport { MatExpansionModule} from '@angular/material/expansion';\nimport { MatSelectModule } from '@angular/material/select';\nimport { TranslateModule } from '@ngx-translate/core';\n\n@NgModule({\n  declarations: [\n    KmsUiPresentationalComponent,\n    ActionsParentComponent,\n    CheckboxComponent,\n    ColorInputComponent,\n    RadioButtonComponent,\n    TimeInputComponent,\n    YesNoRadiogroupComponent,\n    FileInputComponent,\n    LoaderComponent,\n    FlyoutComponent,\n    IconComponent,\n    EnumRadiogroupComponent,\n    KMSAccordionItemComponent,\n    EnumRadiogroupComponent,\n    MapComponent,\n    SalutationDropdownComponent,\n    SalutationRadiogroupComponent,\n    TooltipComponent,\n    TooltipIconComponent,\n    BackToTopComponent,\n    GenericDialogComponent,\n    ButtonWithConfirmDialogComponent,\n  ],\n  imports: [\n    CommonModule,\n    MatCheckboxModule,\n    MatButtonModule,\n    MatRadioModule,\n    MatDialogModule,\n    FormsModule,\n    ReactiveFormsModule,\n    CustomPipesModule,\n    GoogleMapsModule,\n    MatExpansionModule,\n    MatSelectModule,\n    TranslateModule\n  ],\n  exports: [\n    KmsUiPresentationalComponent,\n    ActionsParentComponent,\n    CheckboxComponent,\n    ColorInputComponent,\n    RadioButtonComponent,\n    TimeInputComponent,\n    YesNoRadiogroupComponent,\n    FileInputComponent,\n    LoaderComponent,\n    FlyoutComponent,\n    IconComponent,\n    EnumRadiogroupComponent,\n    KMSAccordionItemComponent,\n    EnumRadiogroupComponent,\n    MapComponent,\n    SalutationDropdownComponent,\n    SalutationRadiogroupComponent,\n    TooltipComponent,\n    TooltipIconComponent,\n    BackToTopComponent,\n    GenericDialogComponent,\n    ButtonWithConfirmDialogComponent\n  ]\n})\nexport class KmsUiPresentationalModule { }\n"]}
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=
@@ -51,7 +51,7 @@ CheckboxComponent.decorators = [
51
51
  multi: true,
52
52
  },
53
53
  ],
54
- styles: [".test{color:#0000cd}\n"]
54
+ styles: [""]
55
55
  },] }
56
56
  ];
57
57
  CheckboxComponent.ctorParameters = () => [];
@@ -48,7 +48,7 @@ ColorInputComponent.decorators = [
48
48
  multi: true,
49
49
  },
50
50
  ],
51
- styles: [".colorInput{position:relative}.colorInput input[type=color]{display:block;position:absolute;width:20px;height:20px;left:0;bottom:10px;padding:0;margin:0;border:1px solid transparent}.colorInput input.my-inValid[type=color]{border:1px dotted red}.colorInput input[type=text]{padding-left:30px}.colorInput input.my-inValid[type=text]{color:red}.colorInput kms-tooltip-icon{position:absolute;right:0;top:-10px}.colorInput .mat-form-field-label{padding-left:30px}.colorInput .mat-form-field-can-float.mat-focused .mat-form-label{padding-left:0}\n"]
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: [".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{width:16px!important;height:20px!important}.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}\n"]
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":"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","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: [".wrapper{position:relative;display:inline-block;padding-left:35px;cursor:pointer}.wrapper input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.wrapper.disabled{cursor:default}\n"]
57
+ styles: [""]
58
58
  },] }
59
59
  ];
60
60
  RadioButtonComponent.ctorParameters = () => [];
@@ -71,7 +71,7 @@ TimeInputComponent.decorators = [
71
71
  multi: true,
72
72
  },
73
73
  ],
74
- styles: [".timeInput{display:inline}.timeInput input{width:2em;margin-right:4px;margin-left:4px;font-size:16px}\n"]
74
+ styles: [""]
75
75
  },] }
76
76
  ];
77
77
  TimeInputComponent.ctorParameters = () => [
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2ttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWwvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLGlDQUFpQyxDQUFDO0FBRWhELGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyw4QkFBOEIsQ0FBQztBQUM3Qyx1REFBdUQ7QUFDdkQsNERBQTREO0FBQzVELGNBQWMsa0RBQWtELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWxcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9rbXMtbmd4LXVpLXByZXNlbnRhdGlvbmFsLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIva21zLW5neC11aS1wcmVzZW50YXRpb25hbC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIva21zLW5neC11aS1wcmVzZW50YXRpb25hbC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZXMvY3VzdG9tLXBpcGVzLm1vZHVsZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9pY29uU2l6ZS5lbnVtJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9zYWx1dGF0aW9uLmVudW0nO1xuLy9leHBvcnQgKiBmcm9tICcuL2xpYi91aS9jaGVja2JveC9jaGVja2JveC5jb21wb25lbnQnO1xuLy9leHBvcnQgKiBmcm9tICcuL2xpYi9wYXJlbnQtY29tcG9uZW50cy9hY3Rpb25zLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91aS9nZW5lcmljLWRpYWxvZy9nZW5lcmljLWRpYWxvZy5jb21wb25lbnQnO1xuIl19
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2ttcy1uZ3gtdWktcHJlc2VudGF0aW9uYWwvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsb0NBQW9DLENBQUM7QUFFbkQsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLHVEQUF1RDtBQUN2RCw0REFBNEQ7QUFDNUQsY0FBYyxrREFBa0QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBrbXMtbmd4LXVpLXByZXNlbnRhdGlvbmFsXHJcbiAqL1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIva21zLW5neC11aS1wcmVzZW50YXRpb25hbC5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIva21zLW5neC11aS1wcmVzZW50YXRpb25hbC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9rbXMtbmd4LXVpLXByZXNlbnRhdGlvbmFsLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BpcGVzL2N1c3RvbS1waXBlcy5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL2RpcmVjdGl2ZXMubW9kdWxlJztcclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9pY29uU2l6ZS5lbnVtJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL3NhbHV0YXRpb24uZW51bSc7XHJcbi8vZXhwb3J0ICogZnJvbSAnLi9saWIvdWkvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50JztcclxuLy9leHBvcnQgKiBmcm9tICcuL2xpYi9wYXJlbnQtY29tcG9uZW50cy9hY3Rpb25zLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VpL2dlbmVyaWMtZGlhbG9nL2dlbmVyaWMtZGlhbG9nLmNvbXBvbmVudCc7XHJcbiJdfQ==