@simpleangularcontrols/sac-common 10.0.0-rc.2 → 10.0.0-rc.21

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 (140) hide show
  1. package/bundles/simpleangularcontrols-sac-common.umd.js +2232 -1604
  2. package/bundles/simpleangularcontrols-sac-common.umd.js.map +1 -1
  3. package/bundles/simpleangularcontrols-sac-common.umd.min.js +1 -1
  4. package/bundles/simpleangularcontrols-sac-common.umd.min.js.map +1 -1
  5. package/common/basedatetimecontrol.d.ts +100 -14
  6. package/common/baseinputcontrol.d.ts +0 -4
  7. package/common/basemodelcontrol.d.ts +55 -27
  8. package/common/baseuploadcontrol.d.ts +71 -55
  9. package/controls/checkbox/checkbox.d.ts +12 -3
  10. package/controls/checkbox/radiobutton.d.ts +61 -26
  11. package/controls/contextmenu/contextmenu.d.ts +26 -19
  12. package/controls/contextmenu/contextmenu.interface.d.ts +3 -0
  13. package/controls/contextmenu/contextmenuitem.d.ts +5 -0
  14. package/controls/contextmenu/contextmenuitembutton.d.ts +21 -20
  15. package/controls/datetime/date.d.ts +28 -31
  16. package/controls/datetime/datetime.d.ts +27 -31
  17. package/controls/datetime/time.d.ts +26 -30
  18. package/controls/dialog/dialog.d.ts +31 -43
  19. package/controls/grid/grid.d.ts +38 -36
  20. package/controls/grid/gridbutton.d.ts +13 -13
  21. package/controls/grid/gridcolumn.d.ts +8 -8
  22. package/controls/grid/gridcolumnaction.d.ts +3 -3
  23. package/controls/grid/gridcolumnbase.d.ts +45 -37
  24. package/controls/grid/gridimage.d.ts +2 -2
  25. package/controls/grid/model.d.ts +51 -42
  26. package/controls/grid/paging.d.ts +41 -43
  27. package/controls/input/input.d.ts +3 -3
  28. package/controls/input/inputarea.d.ts +5 -5
  29. package/controls/input/inputpassword.d.ts +7 -7
  30. package/controls/input/inputsearch.d.ts +13 -4
  31. package/controls/layout/formlayout.d.ts +17 -1
  32. package/controls/list/buildvaluestring.d.ts +6 -0
  33. package/controls/list/dropdown.d.ts +9 -51
  34. package/controls/list/dropdownoptions.d.ts +38 -0
  35. package/controls/multilanguage/multilanguageinput.d.ts +2 -2
  36. package/controls/multilanguage/multilanguageinputarea.d.ts +4 -4
  37. package/controls/static/formcontainer.d.ts +7 -3
  38. package/controls/tooltip/tooltip.d.ts +76 -69
  39. package/controls/treeview/treeview.d.ts +107 -107
  40. package/esm2015/common/basedatetimecontrol.js +185 -30
  41. package/esm2015/common/baseinputcontrol.js +2 -7
  42. package/esm2015/common/basemodelcontrol.js +109 -57
  43. package/esm2015/common/baseuploadcontrol.js +92 -59
  44. package/esm2015/controls/checkbox/checkbox.js +29 -6
  45. package/esm2015/controls/checkbox/radiobutton.js +94 -45
  46. package/esm2015/controls/contextmenu/contextmenu.interface.js +1 -0
  47. package/esm2015/controls/contextmenu/contextmenu.interface.ngfactory.js +7 -0
  48. package/esm2015/controls/contextmenu/contextmenu.js +22 -23
  49. package/esm2015/controls/contextmenu/contextmenuitem.js +13 -2
  50. package/esm2015/controls/contextmenu/contextmenuitembutton.js +34 -25
  51. package/esm2015/controls/datetime/date.js +44 -43
  52. package/esm2015/controls/datetime/datetime.js +43 -43
  53. package/esm2015/controls/datetime/time.js +43 -43
  54. package/esm2015/controls/dialog/dialog.js +41 -83
  55. package/esm2015/controls/grid/grid.js +21 -21
  56. package/esm2015/controls/grid/gridbutton.js +19 -13
  57. package/esm2015/controls/grid/gridcolumn.js +14 -7
  58. package/esm2015/controls/grid/gridcolumnaction.js +6 -5
  59. package/esm2015/controls/grid/gridcolumnbase.js +67 -55
  60. package/esm2015/controls/grid/gridimage.js +3 -3
  61. package/esm2015/controls/grid/model.js +51 -30
  62. package/esm2015/controls/grid/paging.js +40 -42
  63. package/esm2015/controls/input/input.js +6 -8
  64. package/esm2015/controls/input/inputarea.js +19 -12
  65. package/esm2015/controls/input/inputpassword.js +12 -12
  66. package/esm2015/controls/input/inputsearch.js +35 -6
  67. package/esm2015/controls/layout/formlayout.js +20 -8
  68. package/esm2015/controls/list/buildvaluestring.js +18 -0
  69. package/esm2015/controls/{treeview/ngtreeitemaction.ngfactory.js → list/buildvaluestring.ngfactory.js} +1 -1
  70. package/esm2015/controls/list/dropdown.js +16 -114
  71. package/esm2015/controls/list/dropdownoptions.js +72 -0
  72. package/esm2015/controls/{treeview/treeviewchild.ngfactory.js → list/dropdownoptions.ngfactory.js} +1 -1
  73. package/esm2015/controls/multilanguage/multilanguageinput.js +8 -14
  74. package/esm2015/controls/multilanguage/multilanguageinputarea.js +9 -15
  75. package/esm2015/controls/static/formcontainer.js +16 -5
  76. package/esm2015/controls/tooltip/tooltip.js +126 -245
  77. package/esm2015/controls/treeview/treeview.js +276 -231
  78. package/esm2015/interfaces/ISacConfigurationService.js +1 -1
  79. package/esm2015/interfaces/ISacIconService.js +1 -1
  80. package/esm2015/interfaces/ISacUploadEventCompleteState.js +1 -0
  81. package/esm2015/interfaces/ISacUploadEventCompleteState.ngfactory.js +7 -0
  82. package/esm2015/interfaces/ISacValidationKeyService.js +1 -1
  83. package/esm2015/interfaces/treeviewaction.interface.js +1 -0
  84. package/esm2015/interfaces/treeviewaction.interface.ngfactory.js +7 -0
  85. package/esm2015/public_api.js +15 -8
  86. package/esm2015/services/sac-configuration.service.js +31 -5
  87. package/esm2015/services/sac-icon.service.js +37 -1
  88. package/esm2015/services/sac-localisation.service.js +69 -180
  89. package/esm2015/services/sac-validationkey.service.js +12 -9
  90. package/esm2015/simpleangularcontrols-sac-common.js +1 -7
  91. package/esm2015/utilities/enums.js +5 -1
  92. package/esm2015/utilities/guid.js +4 -2
  93. package/esm2015/utilities/popuphelper.js +343 -0
  94. package/esm2015/utilities/popuphelper.ngfactory.js +7 -0
  95. package/esm2015/validation/equals.validator.js +14 -0
  96. package/esm2015/validation/equals.validator.ngfactory.js +7 -0
  97. package/esm2015/validation/isDateValid.js +9 -1
  98. package/esm2015/validation/mintextlength.validator.js +23 -0
  99. package/esm2015/validation/mintextlength.validator.ngfactory.js +7 -0
  100. package/esm2015/validation/notequals.validator.js +14 -0
  101. package/esm2015/validation/{minlength.validator.ngfactory.js → notequals.validator.ngfactory.js} +1 -1
  102. package/esm2015/validation/validation.class.js +35 -6
  103. package/fesm2015/simpleangularcontrols-sac-common.js +2070 -1498
  104. package/fesm2015/simpleangularcontrols-sac-common.js.map +1 -1
  105. package/interfaces/ISacConfigurationService.d.ts +20 -0
  106. package/interfaces/ISacIconService.d.ts +24 -0
  107. package/interfaces/ISacUploadEventCompleteState.d.ts +5 -0
  108. package/interfaces/ISacUploadEventCompleteState.ngfactory.d.ts +1 -0
  109. package/interfaces/ISacValidationKeyService.d.ts +2 -2
  110. package/interfaces/treeviewaction.interface.d.ts +4 -0
  111. package/interfaces/treeviewaction.interface.ngfactory.d.ts +1 -0
  112. package/package.json +2 -2
  113. package/public_api.d.ts +13 -6
  114. package/services/sac-configuration.service.d.ts +40 -0
  115. package/services/sac-icon.service.d.ts +49 -1
  116. package/services/sac-localisation.service.d.ts +10 -10
  117. package/services/sac-validationkey.service.d.ts +7 -7
  118. package/simpleangularcontrols-sac-common-10.0.0-rc.21.tgz +0 -0
  119. package/simpleangularcontrols-sac-common.d.ts +0 -6
  120. package/simpleangularcontrols-sac-common.metadata.json +1 -1
  121. package/utilities/enums.d.ts +3 -1
  122. package/utilities/popuphelper.d.ts +83 -0
  123. package/utilities/popuphelper.ngfactory.d.ts +1 -0
  124. package/validation/equals.validator.d.ts +2 -0
  125. package/validation/equals.validator.ngfactory.d.ts +1 -0
  126. package/validation/mintextlength.validator.d.ts +2 -0
  127. package/validation/mintextlength.validator.ngfactory.d.ts +1 -0
  128. package/validation/notequals.validator.d.ts +2 -0
  129. package/validation/notequals.validator.ngfactory.d.ts +1 -0
  130. package/validation/validation.class.d.ts +22 -3
  131. package/controls/treeview/ngtreeitemaction.d.ts +0 -40
  132. package/controls/treeview/treeviewchild.d.ts +0 -12
  133. package/esm2015/controls/treeview/ngtreeitemaction.js +0 -60
  134. package/esm2015/controls/treeview/treeviewchild.js +0 -18
  135. package/esm2015/validation/minlength.validator.js +0 -21
  136. package/simpleangularcontrols-sac-common-10.0.0-rc.2.tgz +0 -0
  137. package/validation/minlength.validator.d.ts +0 -2
  138. /package/controls/{treeview/ngtreeitemaction.ngfactory.d.ts → contextmenu/contextmenu.interface.ngfactory.d.ts} +0 -0
  139. /package/controls/{treeview/treeviewchild.ngfactory.d.ts → list/buildvaluestring.ngfactory.d.ts} +0 -0
  140. /package/{validation/minlength.validator.ngfactory.d.ts → controls/list/dropdownoptions.ngfactory.d.ts} +0 -0
@@ -1,14 +1,9 @@
1
- import { Directive, ElementRef, HostListener, Injector, Input, } from '@angular/core';
2
- import * as IMask from 'imask';
3
- import * as moment_ from 'moment';
4
1
  import { SacBaseDateTimeControl } from '../../common/basedatetimecontrol';
5
- import { SACICON_SERVICE, SacDefaultIconService } from '../../services';
6
2
  import { Validation } from '../../validation';
7
3
  import { SacFormLayoutCommon } from '../layout/formlayout';
8
- /**
9
- * Moment
10
- */
11
- const moment = moment_['default'];
4
+ import { ChangeDetectorRef, Directive, ElementRef, HostListener, Injector, Input } from '@angular/core';
5
+ import * as IMask from 'imask';
6
+ import * as moment_ from 'moment';
12
7
  /**
13
8
  * Komponente für SacDateCommon. Extends SacBaseDateTimeControl
14
9
  */
@@ -20,10 +15,12 @@ export class SacDateCommon extends SacBaseDateTimeControl {
20
15
  * @param formlayout SacFormLayoutCommon to define scoped layout settings
21
16
  * @param injector Injector for injecting services
22
17
  * @param elementRef reference to html element
18
+ * @param cdRef Change Dectection Servie
23
19
  */
24
- constructor(formlayout, injector, elementRef) {
25
- super(formlayout, injector, elementRef);
20
+ constructor(formlayout, injector, elementRef, cdRef) {
21
+ super(formlayout, injector, elementRef, cdRef);
26
22
  this.elementRef = elementRef;
23
+ // #region Properties
27
24
  /**
28
25
  * Format des Datums
29
26
  */
@@ -57,6 +54,18 @@ export class SacDateCommon extends SacBaseDateTimeControl {
57
54
  lazy: false,
58
55
  overwrite: true,
59
56
  };
57
+ /**
58
+ * Min Date
59
+ */
60
+ this._maxdate = null;
61
+ /**
62
+ * Min Date
63
+ */
64
+ this._mindate = null;
65
+ /**
66
+ * Moment JS module instance
67
+ */
68
+ this.moment = moment_['default'];
60
69
  /**
61
70
  * Resource Key für Validation Message MaxDate bei Control
62
71
  */
@@ -73,27 +82,20 @@ export class SacDateCommon extends SacBaseDateTimeControl {
73
82
  * Resource Key für Validation Message MinDate in Validation Summary
74
83
  */
75
84
  this.validationmessagesummarymindate = this.validationKeyService.ValidationErrorSummaryMinDate;
76
- /**
77
- * Min Date
78
- */
79
- this._maxdate = null;
80
- /**
81
- * Min Date
82
- */
83
- this._mindate = null;
84
- /**
85
- * Definiert ob der Date Selector angezeigt wird
86
- */
87
- this._showselector = false;
88
- this.iconService = injector.get(SACICON_SERVICE, new SacDefaultIconService());
89
85
  }
90
86
  // #endregion Constructors
91
87
  // #region Public Getters And Setters
88
+ /**
89
+ * icon for date selector button
90
+ */
91
+ get IconSelector() {
92
+ return this.iconService.DateComponentSelectorIcon;
93
+ }
92
94
  /**
93
95
  * Min Date
94
96
  */
95
97
  set maxdate(v) {
96
- const date = moment(v, [this.DATEFORMAT], true);
98
+ const date = this.moment(v, [this.DATEFORMAT], true);
97
99
  if (date.isValid()) {
98
100
  this._maxdate = super.getDate(date).toDate();
99
101
  }
@@ -105,7 +107,7 @@ export class SacDateCommon extends SacBaseDateTimeControl {
105
107
  * Min Date
106
108
  */
107
109
  set mindate(v) {
108
- const date = moment(v, [this.DATEFORMAT], true);
110
+ const date = this.moment(v, [this.DATEFORMAT], true);
109
111
  if (date.isValid()) {
110
112
  this._mindate = super.getDate(date).toDate();
111
113
  }
@@ -113,23 +115,8 @@ export class SacDateCommon extends SacBaseDateTimeControl {
113
115
  this._mindate = null;
114
116
  }
115
117
  }
116
- /**
117
- * icon for date selector button
118
- */
119
- get IconSelector() {
120
- return this.iconService.DateComponentSelectorIcon;
121
- }
122
118
  // #endregion Public Getters And Setters
123
119
  // #region Public Methods
124
- /**
125
- * HostListener
126
- */
127
- onClick(targetElement) {
128
- const clickedInside = this.elementRef.nativeElement.contains(targetElement);
129
- if (!clickedInside) {
130
- this._showselector = false;
131
- }
132
- }
133
120
  /**
134
121
  * Methode ergibt Datum-Format vom String
135
122
  */
@@ -150,10 +137,23 @@ export class SacDateCommon extends SacBaseDateTimeControl {
150
137
  this.setValueString('');
151
138
  }
152
139
  else {
153
- this.value = moment(v.date).utc().toDate();
140
+ this.value = this.moment(v.date).utc().toDate();
154
141
  }
155
142
  this._showselector = false;
156
143
  }
144
+ /**
145
+ * HostListener
146
+ */
147
+ onClick(targetElement) {
148
+ if (!this.pickercontainer) {
149
+ return;
150
+ }
151
+ const clickedInsideContainer = this.pickercontainer.nativeElement.contains(targetElement);
152
+ const clickedInsideReference = this.pickerbutton.nativeElement.contains(targetElement);
153
+ if (!clickedInsideContainer && !clickedInsideReference) {
154
+ this._showselector = false;
155
+ }
156
+ }
157
157
  /**
158
158
  * Zeigt Date Selector an
159
159
  */
@@ -198,7 +198,8 @@ SacDateCommon.decorators = [
198
198
  SacDateCommon.ctorParameters = () => [
199
199
  { type: SacFormLayoutCommon },
200
200
  { type: Injector },
201
- { type: ElementRef }
201
+ { type: ElementRef },
202
+ { type: ChangeDetectorRef }
202
203
  ];
203
204
  SacDateCommon.propDecorators = {
204
205
  validationmessagemaxdate: [{ type: Input }],
@@ -209,4 +210,4 @@ SacDateCommon.propDecorators = {
209
210
  mindate: [{ type: Input }],
210
211
  onClick: [{ type: HostListener, args: ['document:click', ['$event.target'],] }]
211
212
  };
212
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/datetime/date.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  HostListener,\r\n  Injector,\r\n  Input,\r\n} from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport * as IMask from 'imask';\r\nimport * as moment_ from 'moment';\r\n\r\n// Import Moment.JS\r\nimport { Moment } from 'moment';\r\nimport { SacBaseDateTimeControl } from '../../common/basedatetimecontrol';\r\nimport { ISacIconService } from '../../interfaces/ISacIconService';\r\nimport { SACICON_SERVICE, SacDefaultIconService } from '../../services';\r\nimport { Validation } from '../../validation';\r\nimport { SacFormLayoutCommon } from '../layout/formlayout';\r\n/**\r\n * Moment\r\n */\r\nconst moment = moment_['default'];\r\n\r\n/**\r\n * Komponente für SacDateCommon. Extends SacBaseDateTimeControl\r\n */\r\n@Directive()\r\nexport class SacDateCommon extends SacBaseDateTimeControl {\r\n  // #region Properties\r\n\r\n  /**\r\n   * icon service\r\n   */\r\n  private iconService: ISacIconService;\r\n\r\n  /**\r\n   * Format des Datums\r\n   */\r\n  public readonly DATEFORMAT: string = 'DD.MM.YYYY';\r\n  /**\r\n   * Maske\r\n   */\r\n  public readonly imaskDate = {\r\n    mask: this.DATEFORMAT,\r\n    blocks: {\r\n      DD: {\r\n        mask: IMask.MaskedRange,\r\n        from: 1,\r\n        to: 31,\r\n        maxLength: 2,\r\n      },\r\n      MM: {\r\n        mask: IMask.MaskedRange,\r\n        from: 1,\r\n        to: 12,\r\n        maxLength: 2,\r\n      },\r\n      YYYY: {\r\n        mask: IMask.MaskedRange,\r\n        from: 1,\r\n        to: 9999,\r\n      },\r\n    },\r\n    placeholderChar: '_',\r\n    autofix: true,\r\n    lazy: false,\r\n    overwrite: true,\r\n  };\r\n\r\n  /**\r\n   * Resource Key für Validation Message MaxDate bei Control\r\n   */\r\n  @Input() public validationmessagemaxdate: string =\r\n    this.validationKeyService.ValidationErrorMaxDate;\r\n  /**\r\n   * Resource Key für Validation Message MinDate bei Control\r\n   */\r\n  @Input() public validationmessagemindate: string =\r\n    this.validationKeyService.ValidationErrorMinDate;\r\n  /**\r\n   * Resource Key für Validation Message MaxDate in Validation Summary\r\n   */\r\n  @Input() public validationmessagesummarymaxdate: string =\r\n    this.validationKeyService.ValidationErrorSummaryMaxDate;\r\n  /**\r\n   * Resource Key für Validation Message MinDate in Validation Summary\r\n   */\r\n  @Input() public validationmessagesummarymindate: string =\r\n    this.validationKeyService.ValidationErrorSummaryMinDate;\r\n\r\n  /**\r\n   * Min Date\r\n   */\r\n  public _maxdate: Date = null;\r\n  /**\r\n   * Min Date\r\n   */\r\n  public _mindate: Date = null;\r\n  /**\r\n   * Definiert ob der Date Selector angezeigt wird\r\n   */\r\n  public _showselector: boolean = false;\r\n\r\n  // #endregion Properties\r\n\r\n  // #region Constructors\r\n\r\n  /**\r\n   * Constructor\r\n   * @param formlayout SacFormLayoutCommon to define scoped layout settings\r\n   * @param injector Injector for injecting services\r\n   * @param elementRef reference to html element\r\n   */\r\n  constructor(\r\n    formlayout: SacFormLayoutCommon,\r\n    injector: Injector,\r\n    protected elementRef: ElementRef\r\n  ) {\r\n    super(formlayout, injector, elementRef);\r\n\r\n    this.iconService = injector.get(\r\n      SACICON_SERVICE,\r\n      new SacDefaultIconService()\r\n    );\r\n  }\r\n\r\n  // #endregion Constructors\r\n\r\n  // #region Public Getters And Setters\r\n\r\n  /**\r\n   * Min Date\r\n   */\r\n  @Input()\r\n  public set maxdate(v: string | Date | null) {\r\n    const date = moment(v, [this.DATEFORMAT], true);\r\n\r\n    if (date.isValid()) {\r\n      this._maxdate = super.getDate(date).toDate();\r\n    } else {\r\n      this._maxdate = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Min Date\r\n   */\r\n  @Input()\r\n  public set mindate(v: string | Date | null) {\r\n    const date = moment(v, [this.DATEFORMAT], true);\r\n\r\n    if (date.isValid()) {\r\n      this._mindate = super.getDate(date).toDate();\r\n    } else {\r\n      this._mindate = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * icon for date selector button\r\n   */\r\n  public get IconSelector(): string {\r\n    return this.iconService.DateComponentSelectorIcon;\r\n  }\r\n\r\n  // #endregion Public Getters And Setters\r\n\r\n  // #region Public Methods\r\n\r\n  /**\r\n   * HostListener\r\n   */\r\n  @HostListener('document:click', ['$event.target'])\r\n  /**\r\n   * Click Event\r\n   */\r\n  public onClick(targetElement) {\r\n    const clickedInside = this.elementRef.nativeElement.contains(targetElement);\r\n    if (!clickedInside) {\r\n      this._showselector = false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt Datum-Format vom String\r\n   */\r\n  public GetDateTimeFormatString(): string {\r\n    return this.DATEFORMAT;\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt Datum - Moment\r\n   */\r\n  public ModifyParsedDateTimeValue(v: Moment): Moment {\r\n    return v;\r\n  }\r\n\r\n  /**\r\n   * Date Selector\r\n   */\r\n  public dateselect(v: any) {\r\n    if (v.date === null) {\r\n      this.setValueString('');\r\n    } else {\r\n      this.value = moment(v.date).utc().toDate();\r\n    }\r\n\r\n    this._showselector = false;\r\n  }\r\n\r\n  /**\r\n   * Zeigt Date Selector an\r\n   */\r\n  public showDateSelector(): void {\r\n    // Touch Event auslösen\r\n    this.onTouch();\r\n\r\n    if (this._showselector) {\r\n      this._showselector = false;\r\n    } else {\r\n      this._showselector = true;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Validator\r\n   */\r\n  public validateData(c: AbstractControl): ValidationErrors | null {\r\n    let error: ValidationErrors | null = null;\r\n\r\n    error = super.validateData(c);\r\n\r\n    if (\r\n      error === null &&\r\n      c.value !== null &&\r\n      c.value !== undefined &&\r\n      c.value !== '' &&\r\n      this._mindate !== undefined &&\r\n      this._mindate !== null\r\n    ) {\r\n      error = Validation.minDate(\r\n        this._mindate,\r\n        this.validationmessagemindate,\r\n        this.validationmessagesummarymindate\r\n      )(c);\r\n    }\r\n\r\n    if (\r\n      error === null &&\r\n      c.value !== null &&\r\n      c.value !== undefined &&\r\n      c.value !== '' &&\r\n      this._maxdate !== undefined &&\r\n      this._maxdate !== null\r\n    ) {\r\n      error = Validation.maxDate(\r\n        this._maxdate,\r\n        this.validationmessagemaxdate,\r\n        this.validationmessagesummarymaxdate\r\n      )(c);\r\n    }\r\n\r\n    return error;\r\n  }\r\n\r\n  // #endregion Public Methods\r\n}\r\n"]}
213
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/datetime/date.ts"],"names":[],"mappings":"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","sourcesContent":["import { SacBaseDateTimeControl } from '../../common/basedatetimecontrol';\r\nimport { Validation } from '../../validation';\r\nimport { SacFormLayoutCommon } from '../layout/formlayout';\r\nimport { ChangeDetectorRef, Directive, ElementRef, HostListener, Injector, Input } from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport * as IMask from 'imask';\r\nimport * as moment_ from 'moment';\r\n\r\n/**\r\n * Komponente für SacDateCommon. Extends SacBaseDateTimeControl\r\n */\r\n@Directive()\r\nexport abstract class SacDateCommon extends SacBaseDateTimeControl {\r\n    // #region Properties\r\n\r\n    /**\r\n     * Format des Datums\r\n     */\r\n    public readonly DATEFORMAT: string = 'DD.MM.YYYY';\r\n\r\n    /**\r\n     * Maske\r\n     */\r\n    public readonly imaskDate = {\r\n        mask: this.DATEFORMAT,\r\n        blocks: {\r\n            DD: {\r\n                mask: IMask.MaskedRange,\r\n                from: 1,\r\n                to: 31,\r\n                maxLength: 2,\r\n            },\r\n            MM: {\r\n                mask: IMask.MaskedRange,\r\n                from: 1,\r\n                to: 12,\r\n                maxLength: 2,\r\n            },\r\n            YYYY: {\r\n                mask: IMask.MaskedRange,\r\n                from: 1,\r\n                to: 9999,\r\n            },\r\n        },\r\n        placeholderChar: '_',\r\n        autofix: true,\r\n        lazy: false,\r\n        overwrite: true,\r\n    };\r\n\r\n    /**\r\n     * Min Date\r\n     */\r\n    public _maxdate: Date = null;\r\n\r\n    /**\r\n     * Min Date\r\n     */\r\n    public _mindate: Date = null;\r\n\r\n    /**\r\n     * Moment JS module instance\r\n     */\r\n    public moment = moment_['default'];\r\n\r\n    /**\r\n     * Resource Key für Validation Message MaxDate bei Control\r\n     */\r\n    @Input() public validationmessagemaxdate: string = this.validationKeyService.ValidationErrorMaxDate;\r\n\r\n    /**\r\n     * Resource Key für Validation Message MinDate bei Control\r\n     */\r\n    @Input() public validationmessagemindate: string = this.validationKeyService.ValidationErrorMinDate;\r\n\r\n    /**\r\n     * Resource Key für Validation Message MaxDate in Validation Summary\r\n     */\r\n    @Input() public validationmessagesummarymaxdate: string = this.validationKeyService.ValidationErrorSummaryMaxDate;\r\n\r\n    /**\r\n     * Resource Key für Validation Message MinDate in Validation Summary\r\n     */\r\n    @Input() public validationmessagesummarymindate: string = this.validationKeyService.ValidationErrorSummaryMinDate;\r\n\r\n    // #endregion Properties\r\n\r\n    // #region Constructors\r\n\r\n    /**\r\n     * Constructor\r\n     * @param formlayout SacFormLayoutCommon to define scoped layout settings\r\n     * @param injector Injector for injecting services\r\n     * @param elementRef reference to html element\r\n     * @param cdRef  Change Dectection Servie\r\n     */\r\n    constructor(\r\n        formlayout: SacFormLayoutCommon,\r\n        injector: Injector,\r\n        protected elementRef: ElementRef,\r\n        cdRef: ChangeDetectorRef\r\n    ) {\r\n        super(formlayout, injector, elementRef, cdRef);\r\n    }\r\n\r\n    // #endregion Constructors\r\n\r\n    // #region Public Getters And Setters\r\n\r\n    /**\r\n     * icon for date selector button\r\n     */\r\n    public get IconSelector(): string {\r\n        return this.iconService.DateComponentSelectorIcon;\r\n    }\r\n\r\n    /**\r\n     * Min Date\r\n     */\r\n    @Input()\r\n    public set maxdate(v: string | Date | null) {\r\n        const date = this.moment(v, [this.DATEFORMAT], true);\r\n\r\n        if (date.isValid()) {\r\n            this._maxdate = super.getDate(date).toDate();\r\n        } else {\r\n            this._maxdate = null;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Min Date\r\n     */\r\n    @Input()\r\n    public set mindate(v: string | Date | null) {\r\n        const date = this.moment(v, [this.DATEFORMAT], true);\r\n\r\n        if (date.isValid()) {\r\n            this._mindate = super.getDate(date).toDate();\r\n        } else {\r\n            this._mindate = null;\r\n        }\r\n    }\r\n\r\n    // #endregion Public Getters And Setters\r\n\r\n    // #region Public Methods\r\n\r\n    /**\r\n     * Methode ergibt Datum-Format vom String\r\n     */\r\n    public GetDateTimeFormatString(): string {\r\n        return this.DATEFORMAT;\r\n    }\r\n\r\n    /**\r\n     * Methode ergibt Datum - Moment\r\n     */\r\n    public ModifyParsedDateTimeValue(v: moment_.Moment): moment_.Moment {\r\n        return v;\r\n    }\r\n\r\n    /**\r\n     * Date Selector\r\n     */\r\n    public dateselect(v: any) {\r\n        if (v.date === null) {\r\n            this.setValueString('');\r\n        } else {\r\n            this.value = this.moment(v.date).utc().toDate();\r\n        }\r\n\r\n        this._showselector = false;\r\n    }\r\n\r\n    /**\r\n     * HostListener\r\n     */\r\n    @HostListener('document:click', ['$event.target'])\r\n    /**\r\n     * Click Event\r\n     */\r\n    public onClick(targetElement) {\r\n        if (!this.pickercontainer) {\r\n            return;\r\n        }\r\n\r\n        const clickedInsideContainer = this.pickercontainer.nativeElement.contains(targetElement);\r\n        const clickedInsideReference = this.pickerbutton.nativeElement.contains(targetElement);\r\n        if (!clickedInsideContainer && !clickedInsideReference) {\r\n            this._showselector = false;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Zeigt Date Selector an\r\n     */\r\n    public showDateSelector(): void {\r\n        // Touch Event auslösen\r\n        this.onTouch();\r\n\r\n        if (this._showselector) {\r\n            this._showselector = false;\r\n        } else {\r\n            this._showselector = true;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Validator\r\n     */\r\n    public validateData(c: AbstractControl): ValidationErrors | null {\r\n        let error: ValidationErrors | null = null;\r\n\r\n        error = super.validateData(c);\r\n\r\n        if (\r\n            error === null &&\r\n            c.value !== null &&\r\n            c.value !== undefined &&\r\n            c.value !== '' &&\r\n            this._mindate !== undefined &&\r\n            this._mindate !== null\r\n        ) {\r\n            error = Validation.minDate(\r\n                this._mindate,\r\n                this.validationmessagemindate,\r\n                this.validationmessagesummarymindate\r\n            )(c);\r\n        }\r\n\r\n        if (\r\n            error === null &&\r\n            c.value !== null &&\r\n            c.value !== undefined &&\r\n            c.value !== '' &&\r\n            this._maxdate !== undefined &&\r\n            this._maxdate !== null\r\n        ) {\r\n            error = Validation.maxDate(\r\n                this._maxdate,\r\n                this.validationmessagemaxdate,\r\n                this.validationmessagesummarymaxdate\r\n            )(c);\r\n        }\r\n\r\n        return error;\r\n    }\r\n\r\n    // #endregion Public Methods\r\n}\r\n"]}
@@ -1,14 +1,9 @@
1
- import { Directive, ElementRef, HostListener, Injector, Input, } from '@angular/core';
2
- import * as IMask from 'imask';
3
- import * as moment_ from 'moment';
4
1
  import { SacBaseDateTimeControl } from '../../common/basedatetimecontrol';
5
- import { SACICON_SERVICE, SacDefaultIconService } from '../../services';
6
2
  import { Validation } from '../../validation';
7
3
  import { SacFormLayoutCommon } from '../layout/formlayout';
8
- /**
9
- * Moment
10
- */
11
- const moment = moment_['default'];
4
+ import { ChangeDetectorRef, Directive, ElementRef, HostListener, Injector, Input } from '@angular/core';
5
+ import * as IMask from 'imask';
6
+ import * as moment_ from 'moment';
12
7
  /**
13
8
  * Komponente für SacDateTimeCommon. Extends SacBaseDateTimeControl
14
9
  */
@@ -21,9 +16,10 @@ export class SacDateTimeCommon extends SacBaseDateTimeControl {
21
16
  * @param injector Injector for injecting services
22
17
  * @param elementRef reference to html element
23
18
  */
24
- constructor(formlayout, injector, elementRef) {
25
- super(formlayout, injector, elementRef);
19
+ constructor(formlayout, injector, elementRef, cdRef) {
20
+ super(formlayout, injector, elementRef, cdRef);
26
21
  this.elementRef = elementRef;
22
+ // #region Properties
27
23
  /**
28
24
  * Format des Datums
29
25
  */
@@ -72,6 +68,18 @@ export class SacDateTimeCommon extends SacBaseDateTimeControl {
72
68
  lazy: false,
73
69
  overwrite: true,
74
70
  };
71
+ /**
72
+ * Maximaler Wert des Datums
73
+ */
74
+ this._maxdate = null;
75
+ /**
76
+ * Minimaler Wert des Datums
77
+ */
78
+ this._mindate = null;
79
+ /**
80
+ * Moment JS module instance
81
+ */
82
+ this.moment = moment_['default'];
75
83
  /**
76
84
  * Resource Key für Validation Message MaxDate bei Control
77
85
  */
@@ -88,27 +96,20 @@ export class SacDateTimeCommon extends SacBaseDateTimeControl {
88
96
  * Resource Key für Validation Message MinDate in Validation Summary
89
97
  */
90
98
  this.validationmessagesummarymindate = this.validationKeyService.ValidationErrorSummaryMinDate;
91
- /**
92
- * Maximaler Wert des Datums
93
- */
94
- this._maxdate = null;
95
- /**
96
- * Minimaler Wert des Datums
97
- */
98
- this._mindate = null;
99
- /**
100
- * Definiert ob der Date Selector angezeigt wird
101
- */
102
- this._showselector = false;
103
- this.iconService = injector.get(SACICON_SERVICE, new SacDefaultIconService());
104
99
  }
105
100
  // #endregion Constructors
106
101
  // #region Public Getters And Setters
102
+ /**
103
+ * icon for date selector button
104
+ */
105
+ get IconSelector() {
106
+ return this.iconService.DateTimeComponentSelectorIcon;
107
+ }
107
108
  /**
108
109
  * Max Date
109
110
  */
110
111
  set maxdate(v) {
111
- const date = moment(v, [this.DATEFORMAT], true);
112
+ const date = this.moment(v, [this.DATEFORMAT], true);
112
113
  if (date.isValid()) {
113
114
  this._maxdate = super.getDate(date).toDate();
114
115
  }
@@ -120,7 +121,7 @@ export class SacDateTimeCommon extends SacBaseDateTimeControl {
120
121
  * Min Date
121
122
  */
122
123
  set mindate(v) {
123
- const date = moment(v, [this.DATEFORMAT], true);
124
+ const date = this.moment(v, [this.DATEFORMAT], true);
124
125
  if (date.isValid()) {
125
126
  this._mindate = super.getDate(date).toDate();
126
127
  }
@@ -128,23 +129,8 @@ export class SacDateTimeCommon extends SacBaseDateTimeControl {
128
129
  this._mindate = null;
129
130
  }
130
131
  }
131
- /**
132
- * icon for date selector button
133
- */
134
- get IconSelector() {
135
- return this.iconService.DateTimeComponentSelectorIcon;
136
- }
137
132
  // #endregion Public Getters And Setters
138
133
  // #region Public Methods
139
- /**
140
- * HostListener
141
- */
142
- onClick(targetElement) {
143
- const clickedInside = this.elementRef.nativeElement.contains(targetElement);
144
- if (!clickedInside) {
145
- this._showselector = false;
146
- }
147
- }
148
134
  /**
149
135
  * Methode ergibt Datum-Format vom String
150
136
  */
@@ -165,10 +151,23 @@ export class SacDateTimeCommon extends SacBaseDateTimeControl {
165
151
  this.setValueString('');
166
152
  }
167
153
  else {
168
- this.value = moment(v.date).utc().toDate();
154
+ this.value = this.moment(v.date).utc().toDate();
169
155
  }
170
156
  this._showselector = false;
171
157
  }
158
+ /**
159
+ * HostListener
160
+ */
161
+ onClick(targetElement) {
162
+ if (!this.pickercontainer) {
163
+ return;
164
+ }
165
+ const clickedInsideContainer = this.pickercontainer.nativeElement.contains(targetElement);
166
+ const clickedInsideReference = this.pickerbutton.nativeElement.contains(targetElement);
167
+ if (!clickedInsideContainer && !clickedInsideReference) {
168
+ this._showselector = false;
169
+ }
170
+ }
172
171
  /**
173
172
  * DateSelector wird beim Click-Event angezeigt
174
173
  */
@@ -215,7 +214,8 @@ SacDateTimeCommon.decorators = [
215
214
  SacDateTimeCommon.ctorParameters = () => [
216
215
  { type: SacFormLayoutCommon },
217
216
  { type: Injector },
218
- { type: ElementRef }
217
+ { type: ElementRef },
218
+ { type: ChangeDetectorRef }
219
219
  ];
220
220
  SacDateTimeCommon.propDecorators = {
221
221
  validationmessagemaxdate: [{ type: Input }],
@@ -226,4 +226,4 @@ SacDateTimeCommon.propDecorators = {
226
226
  mindate: [{ type: Input }],
227
227
  onClick: [{ type: HostListener, args: ['document:click', ['$event.target'],] }]
228
228
  };
229
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/datetime/datetime.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  HostListener,\r\n  Injector,\r\n  Input,\r\n} from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport * as IMask from 'imask';\r\nimport * as moment_ from 'moment';\r\n// Import Moment.JS\r\nimport { Moment } from 'moment';\r\nimport { SacBaseDateTimeControl } from '../../common/basedatetimecontrol';\r\nimport { ISacIconService } from '../../public_api';\r\nimport { SACICON_SERVICE, SacDefaultIconService } from '../../services';\r\nimport { Validation } from '../../validation';\r\nimport { SacFormLayoutCommon } from '../layout/formlayout';\r\n\r\n/**\r\n * Moment\r\n */\r\nconst moment = moment_['default'];\r\n\r\n/**\r\n * Komponente für SacDateTimeCommon. Extends SacBaseDateTimeControl\r\n */\r\n@Directive()\r\nexport class SacDateTimeCommon extends SacBaseDateTimeControl {\r\n  // #region Properties\r\n\r\n  /**\r\n   * icon service\r\n   */\r\n  private iconService: ISacIconService;\r\n\r\n  /**\r\n   * Format des Datums\r\n   */\r\n  public readonly DATEFORMAT: string = 'DD.MM.YYYY HH:mm';\r\n  /**\r\n   * Maske\r\n   */\r\n  /**\r\n   * Maske\r\n   */\r\n  public readonly imaskDate = {\r\n    mask: this.DATEFORMAT,\r\n    blocks: {\r\n      DD: {\r\n        mask: IMask.MaskedRange,\r\n        from: 1,\r\n        to: 31,\r\n        maxLength: 2,\r\n      },\r\n      MM: {\r\n        mask: IMask.MaskedRange,\r\n        from: 1,\r\n        to: 12,\r\n        maxLength: 2,\r\n      },\r\n      YYYY: {\r\n        mask: IMask.MaskedRange,\r\n        from: 1,\r\n        to: 9999,\r\n      },\r\n      HH: {\r\n        mask: IMask.MaskedRange,\r\n        from: 0,\r\n        to: 23,\r\n        maxLength: 2,\r\n      },\r\n      mm: {\r\n        mask: IMask.MaskedRange,\r\n        from: 0,\r\n        to: 59,\r\n        maxLength: 2,\r\n      },\r\n    },\r\n    placeholderChar: '_',\r\n    autofix: true,\r\n    lazy: false,\r\n    overwrite: true,\r\n  };\r\n\r\n  /**\r\n   * Resource Key für Validation Message MaxDate bei Control\r\n   */\r\n  @Input() public validationmessagemaxdate: string =\r\n    this.validationKeyService.ValidationErrorMaxDate;\r\n  /**\r\n   * Resource Key für Validation Message MinDate bei Control\r\n   */\r\n  @Input() public validationmessagemindate: string =\r\n    this.validationKeyService.ValidationErrorMinDate;\r\n  /**\r\n   * Resource Key für Validation Message MaxDate in Validation Summary\r\n   */\r\n  @Input() public validationmessagesummarymaxdate: string =\r\n    this.validationKeyService.ValidationErrorSummaryMaxDate;\r\n  /**\r\n   * Resource Key für Validation Message MinDate in Validation Summary\r\n   */\r\n  @Input() public validationmessagesummarymindate: string =\r\n    this.validationKeyService.ValidationErrorSummaryMinDate;\r\n\r\n  /**\r\n   * Maximaler Wert des Datums\r\n   */\r\n  public _maxdate: Date = null;\r\n  /**\r\n   * Minimaler Wert des Datums\r\n   */\r\n  public _mindate: Date = null;\r\n  /**\r\n   * Definiert ob der Date Selector angezeigt wird\r\n   */\r\n  public _showselector: boolean = false;\r\n\r\n  // #endregion Properties\r\n\r\n  // #region Constructors\r\n\r\n  /**\r\n   * Constructor\r\n   * @param formlayout SacFormLayoutCommon to define scoped layout settings\r\n   * @param injector Injector for injecting services\r\n   * @param elementRef reference to html element\r\n   */\r\n  constructor(\r\n    formlayout: SacFormLayoutCommon,\r\n    injector: Injector,\r\n    protected elementRef: ElementRef\r\n  ) {\r\n    super(formlayout, injector, elementRef);\r\n\r\n    this.iconService = injector.get(\r\n      SACICON_SERVICE,\r\n      new SacDefaultIconService()\r\n    );\r\n  }\r\n\r\n  // #endregion Constructors\r\n\r\n  // #region Public Getters And Setters\r\n\r\n  /**\r\n   * Max Date\r\n   */\r\n  @Input()\r\n  public set maxdate(v: string | Date | null) {\r\n    const date = moment(v, [this.DATEFORMAT], true);\r\n\r\n    if (date.isValid()) {\r\n      this._maxdate = super.getDate(date).toDate();\r\n    } else {\r\n      this._maxdate = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Min Date\r\n   */\r\n  @Input()\r\n  public set mindate(v: string | Date | null) {\r\n    const date = moment(v, [this.DATEFORMAT], true);\r\n\r\n    if (date.isValid()) {\r\n      this._mindate = super.getDate(date).toDate();\r\n    } else {\r\n      this._mindate = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * icon for date selector button\r\n   */\r\n  public get IconSelector(): string {\r\n    return this.iconService.DateTimeComponentSelectorIcon;\r\n  }\r\n\r\n  // #endregion Public Getters And Setters\r\n\r\n  // #region Public Methods\r\n\r\n  /**\r\n   * HostListener\r\n   */\r\n  @HostListener('document:click', ['$event.target'])\r\n  /**\r\n   * Click Event\r\n   */\r\n  public onClick(targetElement) {\r\n    const clickedInside = this.elementRef.nativeElement.contains(targetElement);\r\n    if (!clickedInside) {\r\n      this._showselector = false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt Datum-Format vom String\r\n   */\r\n  public GetDateTimeFormatString(): string {\r\n    return this.DATEFORMAT;\r\n  }\r\n\r\n  /**\r\n   * Methode modifiziert den parsed Wert des Datums\r\n   */\r\n  public ModifyParsedDateTimeValue(v: Moment): Moment {\r\n    return v;\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt das selektierte Datum\r\n   */\r\n  public dateselect(v: any) {\r\n    if (v.date === null) {\r\n      this.setValueString('');\r\n    } else {\r\n      this.value = moment(v.date).utc().toDate();\r\n    }\r\n\r\n    this._showselector = false;\r\n  }\r\n\r\n  /**\r\n   * DateSelector wird beim Click-Event angezeigt\r\n   */\r\n  public showDateSelector(): void {\r\n    /**\r\n     * Touch Event auslösen\r\n     */\r\n    this.onTouch();\r\n\r\n    if (this._showselector) {\r\n      this._showselector = false;\r\n    } else {\r\n      this._showselector = true;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Validator\r\n   */\r\n  public validateData(c: AbstractControl): ValidationErrors | null {\r\n    let error: ValidationErrors | null = null;\r\n\r\n    error = super.validateData(c);\r\n\r\n    if (\r\n      error === null &&\r\n      c.value !== null &&\r\n      c.value !== undefined &&\r\n      c.value !== '' &&\r\n      this._mindate !== undefined &&\r\n      this._mindate !== null\r\n    ) {\r\n      error = Validation.minDate(\r\n        this._mindate,\r\n        this.validationmessagemindate,\r\n        this.validationmessagesummarymindate\r\n      )(c);\r\n    }\r\n\r\n    if (\r\n      error === null &&\r\n      c.value !== null &&\r\n      c.value !== undefined &&\r\n      c.value !== '' &&\r\n      this._maxdate !== undefined &&\r\n      this._maxdate !== null\r\n    ) {\r\n      error = Validation.maxDate(\r\n        this._maxdate,\r\n        this.validationmessagemaxdate,\r\n        this.validationmessagesummarymaxdate\r\n      )(c);\r\n    }\r\n\r\n    return error;\r\n  }\r\n\r\n  // #endregion Public Methods\r\n}\r\n"]}
229
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/datetime/datetime.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAC1E,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAExG,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,OAAO,MAAM,QAAQ,CAAC;AAElC;;GAEG;AAEH,MAAM,OAAgB,iBAAkB,SAAQ,sBAAsB;IAwFlE,wBAAwB;IAExB,uBAAuB;IAEvB;;;;;OAKG;IACH,YACI,UAA+B,EAC/B,QAAkB,EACR,UAAsB,EAChC,KAAwB;QAExB,KAAK,CAAC,UAAU,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;QAHrC,eAAU,GAAV,UAAU,CAAY;QApGpC,qBAAqB;QAErB;;WAEG;QACa,eAAU,GAAW,kBAAkB,CAAC;QAExD;;WAEG;QACH;;WAEG;QACa,cAAS,GAAG;YACxB,IAAI,EAAE,IAAI,CAAC,UAAU;YACrB,MAAM,EAAE;gBACJ,EAAE,EAAE;oBACA,IAAI,EAAE,KAAK,CAAC,WAAW;oBACvB,IAAI,EAAE,CAAC;oBACP,EAAE,EAAE,EAAE;oBACN,SAAS,EAAE,CAAC;iBACf;gBACD,EAAE,EAAE;oBACA,IAAI,EAAE,KAAK,CAAC,WAAW;oBACvB,IAAI,EAAE,CAAC;oBACP,EAAE,EAAE,EAAE;oBACN,SAAS,EAAE,CAAC;iBACf;gBACD,IAAI,EAAE;oBACF,IAAI,EAAE,KAAK,CAAC,WAAW;oBACvB,IAAI,EAAE,CAAC;oBACP,EAAE,EAAE,IAAI;iBACX;gBACD,EAAE,EAAE;oBACA,IAAI,EAAE,KAAK,CAAC,WAAW;oBACvB,IAAI,EAAE,CAAC;oBACP,EAAE,EAAE,EAAE;oBACN,SAAS,EAAE,CAAC;iBACf;gBACD,EAAE,EAAE;oBACA,IAAI,EAAE,KAAK,CAAC,WAAW;oBACvB,IAAI,EAAE,CAAC;oBACP,EAAE,EAAE,EAAE;oBACN,SAAS,EAAE,CAAC;iBACf;aACJ;YACD,eAAe,EAAE,GAAG;YACpB,OAAO,EAAE,IAAI;YACb,IAAI,EAAE,KAAK;YACX,SAAS,EAAE,IAAI;SAClB,CAAC;QAEF;;WAEG;QACI,aAAQ,GAAS,IAAI,CAAC;QAE7B;;WAEG;QACI,aAAQ,GAAS,IAAI,CAAC;QAE7B;;WAEG;QACI,WAAM,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC;QAEnC;;WAEG;QACa,6BAAwB,GAAW,IAAI,CAAC,oBAAoB,CAAC,sBAAsB,CAAC;QAEpG;;WAEG;QACa,6BAAwB,GAAW,IAAI,CAAC,oBAAoB,CAAC,sBAAsB,CAAC;QAEpG;;WAEG;QACa,oCAA+B,GAAW,IAAI,CAAC,oBAAoB,CAAC,6BAA6B,CAAC;QAElH;;WAEG;QACa,oCAA+B,GAAW,IAAI,CAAC,oBAAoB,CAAC,6BAA6B,CAAC;IAmBlH,CAAC;IAED,0BAA0B;IAE1B,qCAAqC;IAErC;;OAEG;IACH,IAAW,YAAY;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,6BAA6B,CAAC;IAC1D,CAAC;IAED;;OAEG;IACH,IACW,OAAO,CAAC,CAAuB;QACtC,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,CAAC;QAErD,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE;YAChB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;SAChD;aAAM;YACH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACxB;IACL,CAAC;IAED;;OAEG;IACH,IACW,OAAO,CAAC,CAAuB;QACtC,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,CAAC;QAErD,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE;YAChB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;SAChD;aAAM;YACH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACxB;IACL,CAAC;IAED,wCAAwC;IAExC,yBAAyB;IAEzB;;OAEG;IACI,uBAAuB;QAC1B,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAED;;OAEG;IACI,yBAAyB,CAAC,CAAiB;QAC9C,OAAO,CAAC,CAAC;IACb,CAAC;IAED;;OAEG;IACI,UAAU,CAAC,CAAM;QACpB,IAAI,CAAC,CAAC,IAAI,KAAK,IAAI,EAAE;YACjB,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;SAC3B;aAAM;YACH,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC;SACnD;QAED,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC/B,CAAC;IAED;;OAEG;IAKI,OAAO,CAAC,aAAa;QACxB,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;YACvB,OAAO;SACV;QAED,MAAM,sBAAsB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;QAC1F,MAAM,sBAAsB,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;QACvF,IAAI,CAAC,sBAAsB,IAAI,CAAC,sBAAsB,EAAE;YACpD,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;SAC9B;IACL,CAAC;IAED;;OAEG;IACI,gBAAgB;QACnB;;WAEG;QACH,IAAI,CAAC,OAAO,EAAE,CAAC;QAEf,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;SAC9B;aAAM;YACH,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC7B;IACL,CAAC;IAED;;OAEG;IACI,YAAY,CAAC,CAAkB;QAClC,IAAI,KAAK,GAA4B,IAAI,CAAC;QAE1C,KAAK,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAE9B,IACI,KAAK,KAAK,IAAI;YACd,CAAC,CAAC,KAAK,KAAK,IAAI;YAChB,CAAC,CAAC,KAAK,KAAK,SAAS;YACrB,CAAC,CAAC,KAAK,KAAK,EAAE;YACd,IAAI,CAAC,QAAQ,KAAK,SAAS;YAC3B,IAAI,CAAC,QAAQ,KAAK,IAAI,EACxB;YACE,KAAK,GAAG,UAAU,CAAC,OAAO,CACtB,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,wBAAwB,EAC7B,IAAI,CAAC,+BAA+B,CACvC,CAAC,CAAC,CAAC,CAAC;SACR;QAED,IACI,KAAK,KAAK,IAAI;YACd,CAAC,CAAC,KAAK,KAAK,IAAI;YAChB,CAAC,CAAC,KAAK,KAAK,SAAS;YACrB,CAAC,CAAC,KAAK,KAAK,EAAE;YACd,IAAI,CAAC,QAAQ,KAAK,SAAS;YAC3B,IAAI,CAAC,QAAQ,KAAK,IAAI,EACxB;YACE,KAAK,GAAG,UAAU,CAAC,OAAO,CACtB,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,wBAAwB,EAC7B,IAAI,CAAC,+BAA+B,CACvC,CAAC,CAAC,CAAC,CAAC;SACR;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;;;YA5PJ,SAAS;;;YATD,mBAAmB;YACqC,QAAQ;YAAlC,UAAU;YAAxC,iBAAiB;;;uCAgFrB,KAAK;uCAKL,KAAK;8CAKL,KAAK;8CAKL,KAAK;sBAmCL,KAAK;sBAcL,KAAK;sBA6CL,YAAY,SAAC,gBAAgB,EAAE,CAAC,eAAe,CAAC","sourcesContent":["import { SacBaseDateTimeControl } from '../../common/basedatetimecontrol';\r\nimport { Validation } from '../../validation';\r\nimport { SacFormLayoutCommon } from '../layout/formlayout';\r\nimport { ChangeDetectorRef, Directive, ElementRef, HostListener, Injector, Input } from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport * as IMask from 'imask';\r\nimport * as moment_ from 'moment';\r\n\r\n/**\r\n * Komponente für SacDateTimeCommon. Extends SacBaseDateTimeControl\r\n */\r\n@Directive()\r\nexport abstract class SacDateTimeCommon extends SacBaseDateTimeControl {\r\n    // #region Properties\r\n\r\n    /**\r\n     * Format des Datums\r\n     */\r\n    public readonly DATEFORMAT: string = 'DD.MM.YYYY HH:mm';\r\n\r\n    /**\r\n     * Maske\r\n     */\r\n    /**\r\n     * Maske\r\n     */\r\n    public readonly imaskDate = {\r\n        mask: this.DATEFORMAT,\r\n        blocks: {\r\n            DD: {\r\n                mask: IMask.MaskedRange,\r\n                from: 1,\r\n                to: 31,\r\n                maxLength: 2,\r\n            },\r\n            MM: {\r\n                mask: IMask.MaskedRange,\r\n                from: 1,\r\n                to: 12,\r\n                maxLength: 2,\r\n            },\r\n            YYYY: {\r\n                mask: IMask.MaskedRange,\r\n                from: 1,\r\n                to: 9999,\r\n            },\r\n            HH: {\r\n                mask: IMask.MaskedRange,\r\n                from: 0,\r\n                to: 23,\r\n                maxLength: 2,\r\n            },\r\n            mm: {\r\n                mask: IMask.MaskedRange,\r\n                from: 0,\r\n                to: 59,\r\n                maxLength: 2,\r\n            },\r\n        },\r\n        placeholderChar: '_',\r\n        autofix: true,\r\n        lazy: false,\r\n        overwrite: true,\r\n    };\r\n\r\n    /**\r\n     * Maximaler Wert des Datums\r\n     */\r\n    public _maxdate: Date = null;\r\n\r\n    /**\r\n     * Minimaler Wert des Datums\r\n     */\r\n    public _mindate: Date = null;\r\n\r\n    /**\r\n     * Moment JS module instance\r\n     */\r\n    public moment = moment_['default'];\r\n\r\n    /**\r\n     * Resource Key für Validation Message MaxDate bei Control\r\n     */\r\n    @Input() public validationmessagemaxdate: string = this.validationKeyService.ValidationErrorMaxDate;\r\n\r\n    /**\r\n     * Resource Key für Validation Message MinDate bei Control\r\n     */\r\n    @Input() public validationmessagemindate: string = this.validationKeyService.ValidationErrorMinDate;\r\n\r\n    /**\r\n     * Resource Key für Validation Message MaxDate in Validation Summary\r\n     */\r\n    @Input() public validationmessagesummarymaxdate: string = this.validationKeyService.ValidationErrorSummaryMaxDate;\r\n\r\n    /**\r\n     * Resource Key für Validation Message MinDate in Validation Summary\r\n     */\r\n    @Input() public validationmessagesummarymindate: string = this.validationKeyService.ValidationErrorSummaryMinDate;\r\n\r\n    // #endregion Properties\r\n\r\n    // #region Constructors\r\n\r\n    /**\r\n     * Constructor\r\n     * @param formlayout SacFormLayoutCommon to define scoped layout settings\r\n     * @param injector Injector for injecting services\r\n     * @param elementRef reference to html element\r\n     */\r\n    constructor(\r\n        formlayout: SacFormLayoutCommon,\r\n        injector: Injector,\r\n        protected elementRef: ElementRef,\r\n        cdRef: ChangeDetectorRef\r\n    ) {\r\n        super(formlayout, injector, elementRef, cdRef);\r\n    }\r\n\r\n    // #endregion Constructors\r\n\r\n    // #region Public Getters And Setters\r\n\r\n    /**\r\n     * icon for date selector button\r\n     */\r\n    public get IconSelector(): string {\r\n        return this.iconService.DateTimeComponentSelectorIcon;\r\n    }\r\n\r\n    /**\r\n     * Max Date\r\n     */\r\n    @Input()\r\n    public set maxdate(v: string | Date | null) {\r\n        const date = this.moment(v, [this.DATEFORMAT], true);\r\n\r\n        if (date.isValid()) {\r\n            this._maxdate = super.getDate(date).toDate();\r\n        } else {\r\n            this._maxdate = null;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Min Date\r\n     */\r\n    @Input()\r\n    public set mindate(v: string | Date | null) {\r\n        const date = this.moment(v, [this.DATEFORMAT], true);\r\n\r\n        if (date.isValid()) {\r\n            this._mindate = super.getDate(date).toDate();\r\n        } else {\r\n            this._mindate = null;\r\n        }\r\n    }\r\n\r\n    // #endregion Public Getters And Setters\r\n\r\n    // #region Public Methods\r\n\r\n    /**\r\n     * Methode ergibt Datum-Format vom String\r\n     */\r\n    public GetDateTimeFormatString(): string {\r\n        return this.DATEFORMAT;\r\n    }\r\n\r\n    /**\r\n     * Methode modifiziert den parsed Wert des Datums\r\n     */\r\n    public ModifyParsedDateTimeValue(v: moment_.Moment): moment_.Moment {\r\n        return v;\r\n    }\r\n\r\n    /**\r\n     * Methode ergibt das selektierte Datum\r\n     */\r\n    public dateselect(v: any) {\r\n        if (v.date === null) {\r\n            this.setValueString('');\r\n        } else {\r\n            this.value = this.moment(v.date).utc().toDate();\r\n        }\r\n\r\n        this._showselector = false;\r\n    }\r\n\r\n    /**\r\n     * HostListener\r\n     */\r\n    @HostListener('document:click', ['$event.target'])\r\n    /**\r\n     * Click Event\r\n     */\r\n    public onClick(targetElement) {\r\n        if (!this.pickercontainer) {\r\n            return;\r\n        }\r\n\r\n        const clickedInsideContainer = this.pickercontainer.nativeElement.contains(targetElement);\r\n        const clickedInsideReference = this.pickerbutton.nativeElement.contains(targetElement);\r\n        if (!clickedInsideContainer && !clickedInsideReference) {\r\n            this._showselector = false;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * DateSelector wird beim Click-Event angezeigt\r\n     */\r\n    public showDateSelector(): void {\r\n        /**\r\n         * Touch Event auslösen\r\n         */\r\n        this.onTouch();\r\n\r\n        if (this._showselector) {\r\n            this._showselector = false;\r\n        } else {\r\n            this._showselector = true;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Validator\r\n     */\r\n    public validateData(c: AbstractControl): ValidationErrors | null {\r\n        let error: ValidationErrors | null = null;\r\n\r\n        error = super.validateData(c);\r\n\r\n        if (\r\n            error === null &&\r\n            c.value !== null &&\r\n            c.value !== undefined &&\r\n            c.value !== '' &&\r\n            this._mindate !== undefined &&\r\n            this._mindate !== null\r\n        ) {\r\n            error = Validation.minDate(\r\n                this._mindate,\r\n                this.validationmessagemindate,\r\n                this.validationmessagesummarymindate\r\n            )(c);\r\n        }\r\n\r\n        if (\r\n            error === null &&\r\n            c.value !== null &&\r\n            c.value !== undefined &&\r\n            c.value !== '' &&\r\n            this._maxdate !== undefined &&\r\n            this._maxdate !== null\r\n        ) {\r\n            error = Validation.maxDate(\r\n                this._maxdate,\r\n                this.validationmessagemaxdate,\r\n                this.validationmessagesummarymaxdate\r\n            )(c);\r\n        }\r\n\r\n        return error;\r\n    }\r\n\r\n    // #endregion Public Methods\r\n}\r\n"]}