@simpleangularcontrols/sac-common 10.0.0-rc.11 → 10.0.0-rc.13

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 (86) hide show
  1. package/bundles/simpleangularcontrols-sac-common.umd.js +1425 -1088
  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 +99 -13
  6. package/common/basemodelcontrol.d.ts +33 -29
  7. package/controls/checkbox/radiobutton.d.ts +61 -26
  8. package/controls/contextmenu/contextmenu.d.ts +26 -19
  9. package/controls/contextmenu/contextmenu.interface.d.ts +3 -0
  10. package/controls/contextmenu/contextmenuitem.d.ts +5 -0
  11. package/controls/contextmenu/contextmenuitembutton.d.ts +21 -20
  12. package/controls/datetime/date.d.ts +28 -27
  13. package/controls/datetime/datetime.d.ts +27 -27
  14. package/controls/datetime/time.d.ts +26 -26
  15. package/controls/dialog/dialog.d.ts +31 -43
  16. package/controls/layout/formlayout.d.ts +4 -0
  17. package/controls/list/buildvaluestring.d.ts +6 -0
  18. package/controls/list/dropdown.d.ts +9 -51
  19. package/controls/list/dropdownoptions.d.ts +38 -0
  20. package/controls/list/dropdownoptions.ngfactory.d.ts +1 -0
  21. package/controls/static/formcontainer.d.ts +11 -3
  22. package/controls/tooltip/tooltip.d.ts +33 -51
  23. package/controls/treeview/treeview.d.ts +87 -121
  24. package/esm2015/common/basedatetimecontrol.js +178 -30
  25. package/esm2015/common/basemodelcontrol.js +71 -56
  26. package/esm2015/controls/checkbox/radiobutton.js +94 -45
  27. package/esm2015/controls/contextmenu/contextmenu.interface.js +1 -0
  28. package/esm2015/controls/contextmenu/contextmenu.interface.ngfactory.js +7 -0
  29. package/esm2015/controls/contextmenu/contextmenu.js +22 -23
  30. package/esm2015/controls/contextmenu/contextmenuitem.js +13 -2
  31. package/esm2015/controls/contextmenu/contextmenuitembutton.js +34 -25
  32. package/esm2015/controls/datetime/date.js +43 -41
  33. package/esm2015/controls/datetime/datetime.js +42 -41
  34. package/esm2015/controls/datetime/time.js +42 -41
  35. package/esm2015/controls/dialog/dialog.js +41 -83
  36. package/esm2015/controls/layout/formlayout.js +7 -6
  37. package/esm2015/controls/list/buildvaluestring.js +18 -0
  38. package/esm2015/controls/{treeview/ngtreeitemaction.ngfactory.js → list/buildvaluestring.ngfactory.js} +1 -1
  39. package/esm2015/controls/list/dropdown.js +16 -114
  40. package/esm2015/controls/list/dropdownoptions.js +72 -0
  41. package/esm2015/controls/{treeview/treeviewchild.ngfactory.js → list/dropdownoptions.ngfactory.js} +1 -1
  42. package/esm2015/controls/static/formcontainer.js +16 -6
  43. package/esm2015/controls/tooltip/tooltip.js +60 -250
  44. package/esm2015/controls/treeview/treeview.js +232 -247
  45. package/esm2015/interfaces/ISacConfigurationService.js +1 -1
  46. package/esm2015/interfaces/ISacIconService.js +1 -1
  47. package/esm2015/interfaces/treeviewaction.interface.js +1 -0
  48. package/esm2015/interfaces/treeviewaction.interface.ngfactory.js +7 -0
  49. package/esm2015/public_api.js +6 -6
  50. package/esm2015/services/sac-configuration.service.js +7 -5
  51. package/esm2015/services/sac-icon.service.js +25 -1
  52. package/esm2015/utilities/enums.js +5 -1
  53. package/esm2015/utilities/popuphelper.js +343 -0
  54. package/esm2015/utilities/popuphelper.ngfactory.js +7 -0
  55. package/esm2015/validation/equals.validator.js +14 -0
  56. package/esm2015/validation/equals.validator.ngfactory.js +7 -0
  57. package/esm2015/validation/notequals.validator.js +14 -0
  58. package/esm2015/validation/notequals.validator.ngfactory.js +7 -0
  59. package/esm2015/validation/validation.class.js +30 -6
  60. package/fesm2015/simpleangularcontrols-sac-common.js +1398 -1075
  61. package/fesm2015/simpleangularcontrols-sac-common.js.map +1 -1
  62. package/interfaces/ISacConfigurationService.d.ts +4 -0
  63. package/interfaces/ISacIconService.d.ts +16 -0
  64. package/interfaces/treeviewaction.interface.d.ts +4 -0
  65. package/interfaces/treeviewaction.interface.ngfactory.d.ts +1 -0
  66. package/package.json +1 -1
  67. package/public_api.d.ts +5 -5
  68. package/services/sac-configuration.service.d.ts +8 -0
  69. package/services/sac-icon.service.d.ts +33 -1
  70. package/simpleangularcontrols-sac-common-10.0.0-rc.13.tgz +0 -0
  71. package/simpleangularcontrols-sac-common.metadata.json +1 -1
  72. package/utilities/enums.d.ts +3 -1
  73. package/utilities/popuphelper.d.ts +83 -0
  74. package/utilities/popuphelper.ngfactory.d.ts +1 -0
  75. package/validation/equals.validator.d.ts +2 -0
  76. package/validation/equals.validator.ngfactory.d.ts +1 -0
  77. package/validation/notequals.validator.d.ts +2 -0
  78. package/validation/notequals.validator.ngfactory.d.ts +1 -0
  79. package/validation/validation.class.d.ts +19 -0
  80. package/controls/treeview/ngtreeitemaction.d.ts +0 -40
  81. package/controls/treeview/treeviewchild.d.ts +0 -12
  82. package/esm2015/controls/treeview/ngtreeitemaction.js +0 -60
  83. package/esm2015/controls/treeview/treeviewchild.js +0 -18
  84. package/simpleangularcontrols-sac-common-10.0.0-rc.11.tgz +0 -0
  85. /package/controls/{treeview/ngtreeitemaction.ngfactory.d.ts → contextmenu/contextmenu.interface.ngfactory.d.ts} +0 -0
  86. /package/controls/{treeview/treeviewchild.ngfactory.d.ts → list/buildvaluestring.ngfactory.d.ts} +0 -0
@@ -1,12 +1,10 @@
1
- import { Directive, ElementRef, Injector, Input, } from '@angular/core';
2
- import * as moment_ from 'moment';
3
1
  import { SacFormLayoutCommon } from '../controls/layout/formlayout';
2
+ import { TooltipPosition } from '../utilities/enums';
3
+ import { PopUpHelper } from '../utilities/popuphelper';
4
4
  import { Validation } from '../validation';
5
5
  import { SacBaseModelControl } from './basemodelcontrol';
6
- /**
7
- * Moment
8
- */
9
- const moment = moment_['default'];
6
+ import { ChangeDetectorRef, Directive, ElementRef, Injector, Input, ViewChild, } from '@angular/core';
7
+ import * as moment_ from 'moment';
10
8
  /**
11
9
  * Base Klasse für Date/Time Controls
12
10
  */
@@ -19,22 +17,65 @@ export class SacBaseDateTimeControl extends SacBaseModelControl {
19
17
  * @param injector Injector for injecting services
20
18
  * @param elementRef reference to html element
21
19
  */
22
- constructor(formlayout, injector, elementRef) {
20
+ constructor(formlayout, injector, elementRef, cdRef) {
23
21
  super(formlayout, injector);
24
22
  this.elementRef = elementRef;
23
+ this.cdRef = cdRef;
25
24
  // #region Properties
25
+ /**
26
+ * Helper class to display tooltip on correct position
27
+ */
28
+ this.popupHelper = new PopUpHelper();
26
29
  /**
27
30
  * das property enthielt das Value als string. Default ist ''
28
31
  */
29
32
  this._valueAsString = '';
33
+ /**
34
+ * Property for enum in Angular HTML template
35
+ */
36
+ this.TooltipPosition = TooltipPosition;
37
+ /**
38
+ * Definiert ob der Date Selector angezeigt wird
39
+ */
40
+ this._showselector = false;
30
41
  /**
31
42
  * Definiert das Control als Required
32
43
  */
33
44
  this.isrequired = false;
45
+ /**
46
+ * Moment JS Instance
47
+ */
48
+ this.moment = moment_['default'];
49
+ /**
50
+ * Arrow Item of Picker Element. Required to set the position of arrow correctly
51
+ */
52
+ this.pickerPosition = TooltipPosition;
34
53
  /**
35
54
  * TextBox Placeholder
36
55
  */
37
56
  this.placeholder = null;
57
+ /**
58
+ * Position of the picker arrow at the left
59
+ */
60
+ this.posArrowLeft = null;
61
+ /**
62
+ * Position of the picker arrow at the top
63
+ */
64
+ this.posArrowTop = null;
65
+ /**
66
+ * Position of the picker at the left
67
+ */
68
+ this.posPopupLeft = 0;
69
+ /**
70
+ * Position of the picker at the top
71
+ */
72
+ this.posPopupTop = 0;
73
+ /**
74
+ * Position of the datetime picker. Values: left|top|right|bottom|auto
75
+ *
76
+ * Value 'auto' can be combined with another value.
77
+ */
78
+ this.position = 'bottomend|topend';
38
79
  /**
39
80
  * Resource Key für Validation Message DateTimeFormat bei Control
40
81
  */
@@ -51,15 +92,56 @@ export class SacBaseDateTimeControl extends SacBaseModelControl {
51
92
  * Resource Key für Validation Message Required in Validation Summary
52
93
  */
53
94
  this.validationmessagerequiredsummary = this.validationKeyService.ValidationErrorSummaryRequired;
95
+ // #endregion Protected Methods
96
+ // #region Private Methods
97
+ /**
98
+ * method if content has changed and proportions need to be reset in the UI.
99
+ */
100
+ this.onContentChange = () => {
101
+ // Do nothing if is not visible
102
+ if (!this._showselector) {
103
+ return;
104
+ }
105
+ setTimeout(() => {
106
+ this.getPositionLeft();
107
+ this.getPositionTop();
108
+ });
109
+ };
54
110
  }
55
111
  // #endregion Constructors
56
112
  // #region Public Getters And Setters
113
+ /**
114
+ * Setter for the name of the container for the tooltip. Is required as the tooltip can be hidden via ngIf.
115
+ */
116
+ set picker(picker) {
117
+ if (picker !== undefined) {
118
+ document.body.appendChild(picker.nativeElement);
119
+ }
120
+ this.pickercontainer = picker;
121
+ this.onContentChange();
122
+ this.cdRef.detectChanges();
123
+ }
124
+ get tooltop() {
125
+ return this.pickercontainer;
126
+ }
127
+ /**
128
+ * getter für valuestring
129
+ */
130
+ get valuestring() {
131
+ if (this.value === null) {
132
+ return this._valueAsString;
133
+ }
134
+ else {
135
+ const date = this.moment.utc(this.value);
136
+ return date.local().format(this.GetDateTimeFormatString());
137
+ }
138
+ }
57
139
  /**
58
140
  * Das Input bekommt das value von typ string
59
141
  */
60
142
  set valuestring(v) {
61
143
  this._valueAsString = v;
62
- let date = moment(v, [this.GetDateTimeFormatString()], true);
144
+ let date = this.moment(v, [this.GetDateTimeFormatString()], true);
63
145
  date = this.ModifyParsedDateTimeValue(date).utc();
64
146
  if (date.isValid()) {
65
147
  this.value = date.toDate();
@@ -69,19 +151,11 @@ export class SacBaseDateTimeControl extends SacBaseModelControl {
69
151
  }
70
152
  }
71
153
  /**
72
- * getter für valuestring
154
+ * Returns the position of the tooltip
73
155
  */
74
- get valuestring() {
75
- if (this.value === null) {
76
- return this._valueAsString;
77
- }
78
- else {
79
- const date = moment.utc(this.value);
80
- return date.local().format(this.GetDateTimeFormatString());
81
- }
156
+ GetPickerPosition() {
157
+ return this.popupHelper.getDisplayPosition(this.pickerbutton, this.pickercontainer, this.getArrowWidth(), this.getArrowHeight(), this.position, false);
82
158
  }
83
- // #endregion Public Getters And Setters
84
- // #region Public Methods
85
159
  /**
86
160
  * JSON Date String in ein UTC DateTime Object konvertieren, welches vom Control verwendete werden kann
87
161
  */
@@ -93,14 +167,37 @@ export class SacBaseDateTimeControl extends SacBaseModelControl {
93
167
  const hours = date.getUTCHours();
94
168
  const minutes = date.getUTCMinutes();
95
169
  const seconds = date.getUTCSeconds();
96
- return moment(Date.UTC(year, month, day, hours, minutes, seconds));
170
+ return this.moment(Date.UTC(year, month, day, hours, minutes, seconds));
171
+ }
172
+ /**
173
+ * Calculates the height of the tooltip
174
+ */
175
+ getPickerHeight() {
176
+ return this.popupHelper.getPopupHeight(this.pickercontainer);
177
+ }
178
+ /**
179
+ * Calculates the width of the picker
180
+ */
181
+ getPickerWidth() {
182
+ return this.popupHelper.getPopupWidth(this.pickercontainer);
183
+ }
184
+ ngDoCheck() {
185
+ // this.onContentChange();
186
+ }
187
+ ngOnDestroy() {
188
+ // Unregister Event Listener
189
+ window.removeEventListener('scroll', this.onContentChange, true);
190
+ window.removeEventListener('resize', this.onContentChange, true);
97
191
  }
98
192
  /**
99
193
  * Init Event
100
194
  */
101
- ngAfterViewInit() {
102
- super.ngAfterViewInit();
103
- this.SetDateTimeFormat();
195
+ ngOnInit() {
196
+ super.ngOnInit();
197
+ this.setDateTimeFormat();
198
+ // Register Event Listener
199
+ window.addEventListener('scroll', this.onContentChange, true);
200
+ window.addEventListener('resize', this.onContentChange, true);
104
201
  }
105
202
  /**
106
203
  * setzt das value von typ string zu property valuestring
@@ -134,13 +231,59 @@ export class SacBaseDateTimeControl extends SacBaseModelControl {
134
231
  }
135
232
  super.writeValue(this._value);
136
233
  }
137
- // #endregion Public Abstract Methods
138
- // #region Private Methods
139
- SetDateTimeFormat() {
234
+ // #endregion Public Methods
235
+ // #region Protected Methods
236
+ getArrowHeight() {
237
+ return this.pickerarrow ? this.pickerarrow.nativeElement.offsetHeight : 0;
238
+ }
239
+ getArrowWidth() {
240
+ return this.pickerarrow ? this.pickerarrow.nativeElement.offsetWidth : 0;
241
+ }
242
+ /**
243
+ * Calculates the position of the tooltip from links
244
+ */
245
+ getPositionLeft() {
246
+ const value = this.popupHelper.getPositionLeft(this.pickerbutton, this.pickercontainer, this.elementRef, this.getArrowWidth(), this.getArrowHeight(), this.position, false);
247
+ this.posPopupLeft = value;
248
+ switch (this.GetPickerPosition()) {
249
+ case TooltipPosition.top:
250
+ case TooltipPosition.bottom:
251
+ this.posArrowLeft = this.getPickerWidth() / 2 - -this.getArrowWidth();
252
+ break;
253
+ case TooltipPosition.topend:
254
+ case TooltipPosition.bottomend:
255
+ this.posArrowLeft =
256
+ this.getPickerWidth() -
257
+ this.getArrowWidth() / 2 -
258
+ this.popupHelper.getContainerWidth(this.pickerbutton, false) / 2;
259
+ break;
260
+ default:
261
+ this.posArrowLeft = null;
262
+ break;
263
+ }
264
+ return value;
265
+ }
266
+ /**
267
+ * Calculates the position of the tooltip from the top
268
+ */
269
+ getPositionTop() {
270
+ const value = this.popupHelper.getPositionTop(this.pickerbutton, this.pickercontainer, this.elementRef, this.getArrowWidth(), this.getArrowHeight(), this.position, false);
271
+ this.posPopupTop = value;
272
+ switch (this.GetPickerPosition()) {
273
+ case TooltipPosition.left:
274
+ case TooltipPosition.right:
275
+ this.posArrowTop = this.getPickerHeight() / 2 - 6.5;
276
+ break;
277
+ default:
278
+ this.posArrowTop = null;
279
+ break;
280
+ }
281
+ return value;
282
+ }
283
+ setDateTimeFormat() {
140
284
  // HACK: Add addition property to FormControl. Can be fixed if solution for ticket: https://github.com/angular/angular/issues/19686
141
285
  if (this.ngControl) {
142
- this.ngControl.datetimeformatstring =
143
- this.GetDateTimeFormatString();
286
+ this.ngControl.datetimeformatstring = this.GetDateTimeFormatString();
144
287
  }
145
288
  }
146
289
  }
@@ -150,15 +293,20 @@ SacBaseDateTimeControl.decorators = [
150
293
  SacBaseDateTimeControl.ctorParameters = () => [
151
294
  { type: SacFormLayoutCommon },
152
295
  { type: Injector },
153
- { type: ElementRef }
296
+ { type: ElementRef },
297
+ { type: ChangeDetectorRef }
154
298
  ];
155
299
  SacBaseDateTimeControl.propDecorators = {
156
300
  isrequired: [{ type: Input }],
301
+ pickerarrow: [{ type: ViewChild, args: ['pickerarrow', { static: false },] }],
302
+ pickerbutton: [{ type: ViewChild, args: ['pickerbutton', { static: true },] }],
157
303
  placeholder: [{ type: Input }],
304
+ position: [{ type: Input }],
158
305
  validationmessagedatetimeformat: [{ type: Input }],
159
306
  validationmessagedatetimeformatsummary: [{ type: Input }],
160
307
  validationmessagerequired: [{ type: Input }],
161
308
  validationmessagerequiredsummary: [{ type: Input }],
309
+ picker: [{ type: ViewChild, args: ['picker', { static: false },] }],
162
310
  valuestring: [{ type: Input }]
163
311
  };
164
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basedatetimecontrol.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["common/basedatetimecontrol.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Directive,\r\n  ElementRef,\r\n  Injector,\r\n  Input,\r\n} from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport * as moment_ from 'moment';\r\nimport { Moment } from 'moment';\r\nimport { SacFormLayoutCommon } from '../controls/layout/formlayout';\r\nimport { IDateTimeControl } from '../interfaces/idatetimecontrol';\r\nimport { Validation } from '../validation';\r\nimport { SacBaseModelControl } from './basemodelcontrol';\r\n/**\r\n * Moment\r\n */\r\nconst moment = moment_['default'];\r\n/**\r\n * Base Klasse für Date/Time Controls\r\n */\r\n@Directive()\r\nexport abstract class SacBaseDateTimeControl\r\n  extends SacBaseModelControl<Date>\r\n  implements AfterViewInit\r\n{\r\n  // #region Properties\r\n\r\n  /**\r\n   * das property enthielt das Value als string. Default ist ''\r\n   */\r\n  protected _valueAsString = '';\r\n\r\n  /**\r\n   * Definiert das Control als Required\r\n   */\r\n  @Input() public isrequired: boolean = false;\r\n  /**\r\n   * TextBox Placeholder\r\n   */\r\n  @Input() public placeholder: string = null;\r\n  /**\r\n   * Resource Key für Validation Message DateTimeFormat bei Control\r\n   */\r\n  @Input() public validationmessagedatetimeformat: string =\r\n    this.validationKeyService.ValidationErrorDatetimeFormat;\r\n  /**\r\n   * Resource Key für Validation Message DateTimeFormat in Validation Summary\r\n   */\r\n  @Input() public validationmessagedatetimeformatsummary: string =\r\n    this.validationKeyService.ValidationErrorSummaryDatetimeFormat;\r\n  /**\r\n   * Resource Key für Validation Message Required bei Control\r\n   */\r\n  @Input() public validationmessagerequired: string =\r\n    this.validationKeyService.ValidationErrorRequired;\r\n  /**\r\n   * Resource Key für Validation Message Required in Validation Summary\r\n   */\r\n  @Input() public validationmessagerequiredsummary: string =\r\n    this.validationKeyService.ValidationErrorSummaryRequired;\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);\r\n  }\r\n\r\n  // #endregion Constructors\r\n\r\n  // #region Public Getters And Setters\r\n\r\n  /**\r\n   * Das Input bekommt das value von typ string\r\n   */\r\n  @Input()\r\n  public set valuestring(v: string) {\r\n    this._valueAsString = v;\r\n    let date: Moment = moment(v, [this.GetDateTimeFormatString()], true);\r\n\r\n    date = this.ModifyParsedDateTimeValue(date).utc();\r\n\r\n    if (date.isValid()) {\r\n      this.value = date.toDate();\r\n    } else {\r\n      this.value = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * getter für valuestring\r\n   */\r\n  public get valuestring(): string {\r\n    if (this.value === null) {\r\n      return this._valueAsString;\r\n    } else {\r\n      const date = moment.utc(this.value);\r\n      return date.local().format(this.GetDateTimeFormatString());\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   * JSON Date String in ein UTC DateTime Object konvertieren, welches vom Control verwendete werden kann\r\n   */\r\n  public getDate(timestamp): moment.Moment {\r\n    const date = new Date(timestamp);\r\n    const year = date.getUTCFullYear();\r\n    const month = date.getUTCMonth();\r\n    const day = date.getUTCDate();\r\n    const hours = date.getUTCHours();\r\n    const minutes = date.getUTCMinutes();\r\n    const seconds = date.getUTCSeconds();\r\n\r\n    return moment(Date.UTC(year, month, day, hours, minutes, seconds));\r\n  }\r\n\r\n  /**\r\n   * Init Event\r\n   */\r\n  public ngAfterViewInit(): void {\r\n    super.ngAfterViewInit();\r\n    this.SetDateTimeFormat();\r\n  }\r\n\r\n  /**\r\n   * setzt das value von typ string zu property valuestring\r\n   */\r\n  public setValueString(v: string) {\r\n    this.valuestring = v;\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 = Validation.isValidDate(\r\n      this.validationmessagedatetimeformat,\r\n      this.validationmessagedatetimeformatsummary\r\n    )(c);\r\n\r\n    if (this.isrequired) {\r\n      error = Validation.required(\r\n        this.validationmessagerequired,\r\n        this.validationmessagerequiredsummary\r\n      )(c);\r\n    }\r\n\r\n    return error;\r\n  }\r\n\r\n  /**\r\n   * Overwrite WriteValue to Set correct Date Object\r\n   */\r\n  public writeValue(value: Date | string) {\r\n    if (value === '' || value === null || value === undefined) {\r\n      // Reset Value String, damit beim Update des Models auch das Input Feld geleert wird.\r\n      this._valueAsString = '';\r\n      // Set Internal Property\r\n      this._value = null;\r\n    } else {\r\n      this._value = this.getDate(value).toDate();\r\n    }\r\n\r\n    super.writeValue(this._value);\r\n  }\r\n\r\n  // #endregion Public Methods\r\n\r\n  // #region Public Abstract Methods\r\n\r\n  /**\r\n   * Die methode returns dateTime in string\r\n   */\r\n  public abstract GetDateTimeFormatString(): string;\r\n  /**\r\n   * Die methode modifiziert das eingegebene Value von typ Moment\r\n   */\r\n  public abstract ModifyParsedDateTimeValue(v: Moment): Moment;\r\n\r\n  // #endregion Public Abstract Methods\r\n\r\n  // #region Private Methods\r\n\r\n  private SetDateTimeFormat(): void {\r\n    // HACK: Add addition property to FormControl. Can be fixed if solution for ticket: https://github.com/angular/angular/issues/19686\r\n    if (this.ngControl) {\r\n      (this.ngControl as unknown as IDateTimeControl).datetimeformatstring =\r\n        this.GetDateTimeFormatString();\r\n    }\r\n  }\r\n\r\n  // #endregion Private Methods\r\n}\r\n"]}
312
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basedatetimecontrol.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["common/basedatetimecontrol.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AAEpE,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EACH,iBAAiB,EACjB,SAAS,EAET,UAAU,EACV,QAAQ,EACR,KAAK,EAGL,SAAS,GACZ,MAAM,eAAe,CAAC;AAEvB,OAAO,KAAK,OAAO,MAAM,QAAQ,CAAC;AAElC;;GAEG;AAEH,MAAM,OAAgB,sBAAuB,SAAQ,mBAAyB;IA0G1E,wBAAwB;IAExB,uBAAuB;IAEvB;;;;;OAKG;IACH,YACI,UAA+B,EAC/B,QAAkB,EACR,UAAsB,EACf,KAAwB;QAEzC,KAAK,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;QAHlB,eAAU,GAAV,UAAU,CAAY;QACf,UAAK,GAAL,KAAK,CAAmB;QAvH7C,qBAAqB;QAErB;;WAEG;QACc,gBAAW,GAAgB,IAAI,WAAW,EAAE,CAAC;QAE9D;;WAEG;QACO,mBAAc,GAAG,EAAE,CAAC;QAQ9B;;WAEG;QACI,oBAAe,GAAG,eAAe,CAAC;QAEzC;;WAEG;QACI,kBAAa,GAAY,KAAK,CAAC;QAEtC;;WAEG;QACa,eAAU,GAAY,KAAK,CAAC;QAE5C;;WAEG;QACI,WAAM,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC;QAEnC;;WAEG;QACI,mBAAc,GAAG,eAAe,CAAC;QAUxC;;WAEG;QACa,gBAAW,GAAW,IAAI,CAAC;QAE3C;;WAEG;QACI,iBAAY,GAAkB,IAAI,CAAC;QAE1C;;WAEG;QACI,gBAAW,GAAkB,IAAI,CAAC;QAEzC;;WAEG;QACI,iBAAY,GAAW,CAAC,CAAC;QAEhC;;WAEG;QACI,gBAAW,GAAW,CAAC,CAAC;QAE/B;;;;WAIG;QAEI,aAAQ,GAAW,kBAAkB,CAAC;QAE7C;;WAEG;QACa,oCAA+B,GAAW,IAAI,CAAC,oBAAoB,CAAC,6BAA6B,CAAC;QAElH;;WAEG;QACa,2CAAsC,GAClD,IAAI,CAAC,oBAAoB,CAAC,oCAAoC,CAAC;QAEnE;;WAEG;QACa,8BAAyB,GAAW,IAAI,CAAC,oBAAoB,CAAC,uBAAuB,CAAC;QAEtG;;WAEG;QACa,qCAAgC,GAAW,IAAI,CAAC,oBAAoB,CAAC,8BAA8B,CAAC;QA2QpH,+BAA+B;QAE/B,0BAA0B;QAE1B;;WAEG;QACc,oBAAe,GAAG,GAAS,EAAE;YAC1C,+BAA+B;YAC/B,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;gBACrB,OAAO;aACV;YAED,UAAU,CAAC,GAAG,EAAE;gBACZ,IAAI,CAAC,eAAe,EAAE,CAAC;gBACvB,IAAI,CAAC,cAAc,EAAE,CAAC;YAC1B,CAAC,CAAC,CAAC;QACP,CAAC,CAAC;IAzQF,CAAC;IAED,0BAA0B;IAE1B,qCAAqC;IAErC;;OAEG;IACH,IACW,MAAM,CAAC,MAAkB;QAChC,IAAI,MAAM,KAAK,SAAS,EAAE;YACtB,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;SACnD;QAED,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC;QAC9B,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;IAC/B,CAAC;IAED,IAAW,OAAO;QACd,OAAO,IAAI,CAAC,eAAe,CAAC;IAChC,CAAC;IAED;;OAEG;IACH,IAAW,WAAW;QAClB,IAAI,IAAI,CAAC,KAAK,KAAK,IAAI,EAAE;YACrB,OAAO,IAAI,CAAC,cAAc,CAAC;SAC9B;aAAM;YACH,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACzC,OAAO,IAAI,CAAC,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;SAC9D;IACL,CAAC;IAED;;OAEG;IACH,IACW,WAAW,CAAC,CAAS;QAC5B,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;QACxB,IAAI,IAAI,GAAmB,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,uBAAuB,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;QAElF,IAAI,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC;QAElD,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE;YAChB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;SAC9B;aAAM;YACH,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;SACrB;IACL,CAAC;IAWD;;OAEG;IACI,iBAAiB;QACpB,OAAO,IAAI,CAAC,WAAW,CAAC,kBAAkB,CACtC,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,aAAa,EAAE,EACpB,IAAI,CAAC,cAAc,EAAE,EACrB,IAAI,CAAC,QAAQ,EACb,KAAK,CACR,CAAC;IACN,CAAC;IAOD;;OAEG;IACI,OAAO,CAAC,SAAS;QACpB,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC;QACjC,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QACnC,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QACjC,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAC9B,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QACjC,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QACrC,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QAErC,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IAC5E,CAAC;IAED;;OAEG;IACI,eAAe;QAClB,OAAO,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACjE,CAAC;IAED;;OAEG;IACI,cAAc;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAChE,CAAC;IAEM,SAAS;QACZ,0BAA0B;IAC9B,CAAC;IAEM,WAAW;QACd,4BAA4B;QAC5B,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;QACjE,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;IACrE,CAAC;IAED;;OAEG;IACI,QAAQ;QACX,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzB,0BAA0B;QAC1B,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;QAC9D,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;IAClE,CAAC;IAED;;OAEG;IACI,cAAc,CAAC,CAAS;QAC3B,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;IACzB,CAAC;IAED;;OAEG;IACI,YAAY,CAAC,CAAkB;QAClC,IAAI,KAAK,GAA4B,IAAI,CAAC;QAE1C,KAAK,GAAG,UAAU,CAAC,WAAW,CAC1B,IAAI,CAAC,+BAA+B,EACpC,IAAI,CAAC,sCAAsC,CAC9C,CAAC,CAAC,CAAC,CAAC;QAEL,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,yBAAyB,EAAE,IAAI,CAAC,gCAAgC,CAAC,CAAC,CAAC,CAAC,CAAC;SACzG;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;IAED;;OAEG;IACI,UAAU,CAAC,KAAoB;QAClC,IAAI,KAAK,KAAK,EAAE,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE;YACvD,qFAAqF;YACrF,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;YACzB,wBAAwB;YACxB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;SACtB;aAAM;YACH,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,EAAE,CAAC;SAC9C;QAED,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;IAED,4BAA4B;IAE5B,4BAA4B;IAElB,cAAc;QACpB,OAAO,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;IAC9E,CAAC;IAES,aAAa;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7E,CAAC;IAED;;OAEG;IACO,eAAe;QACrB,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,eAAe,CAC1C,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,aAAa,EAAE,EACpB,IAAI,CAAC,cAAc,EAAE,EACrB,IAAI,CAAC,QAAQ,EACb,KAAK,CACR,CAAC;QACF,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAE1B,QAAQ,IAAI,CAAC,iBAAiB,EAAE,EAAE;YAC9B,KAAK,eAAe,CAAC,GAAG,CAAC;YACzB,KAAK,eAAe,CAAC,MAAM;gBACvB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,cAAc,EAAE,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;gBACtE,MAAM;YACV,KAAK,eAAe,CAAC,MAAM,CAAC;YAC5B,KAAK,eAAe,CAAC,SAAS;gBAC1B,IAAI,CAAC,YAAY;oBACb,IAAI,CAAC,cAAc,EAAE;wBACrB,IAAI,CAAC,aAAa,EAAE,GAAG,CAAC;wBACxB,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,IAAI,CAAC,YAAY,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;gBACrE,MAAM;YACV;gBACI,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;gBACzB,MAAM;SACb;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;IAED;;OAEG;IACO,cAAc;QACpB,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CACzC,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,aAAa,EAAE,EACpB,IAAI,CAAC,cAAc,EAAE,EACrB,IAAI,CAAC,QAAQ,EACb,KAAK,CACR,CAAC;QACF,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QAEzB,QAAQ,IAAI,CAAC,iBAAiB,EAAE,EAAE;YAC9B,KAAK,eAAe,CAAC,IAAI,CAAC;YAC1B,KAAK,eAAe,CAAC,KAAK;gBACtB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,eAAe,EAAE,GAAG,CAAC,GAAG,GAAG,CAAC;gBACpD,MAAM;YACV;gBACI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;gBACxB,MAAM;SACb;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;IAqBO,iBAAiB;QACrB,mIAAmI;QACnI,IAAI,IAAI,CAAC,SAAS,EAAE;YACf,IAAI,CAAC,SAAyC,CAAC,oBAAoB,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAC;SACzG;IACL,CAAC;;;YA5YJ,SAAS;;;YAvBD,mBAAmB;YAWxB,QAAQ;YADR,UAAU;YAHV,iBAAiB;;;yBAiDhB,KAAK;0BAWL,SAAS,SAAC,aAAa,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;2BAM1C,SAAS,SAAC,cAAc,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;0BAM1C,KAAK;uBA2BL,KAAK;8CAML,KAAK;qDAKL,KAAK;wCAML,KAAK;+CAKL,KAAK;qBA4BL,SAAS,SAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;0BA8BrC,KAAK","sourcesContent":["import { SacFormLayoutCommon } from '../controls/layout/formlayout';\r\nimport { IDateTimeControl } from '../interfaces/idatetimecontrol';\r\nimport { TooltipPosition } from '../utilities/enums';\r\nimport { PopUpHelper } from '../utilities/popuphelper';\r\nimport { Validation } from '../validation';\r\nimport { SacBaseModelControl } from './basemodelcontrol';\r\nimport {\r\n    ChangeDetectorRef,\r\n    Directive,\r\n    DoCheck,\r\n    ElementRef,\r\n    Injector,\r\n    Input,\r\n    OnDestroy,\r\n    OnInit,\r\n    ViewChild,\r\n} from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport * as moment_ from 'moment';\r\n\r\n/**\r\n * Base Klasse für Date/Time Controls\r\n */\r\n@Directive()\r\nexport abstract class SacBaseDateTimeControl extends SacBaseModelControl<Date> implements OnInit, OnDestroy, DoCheck {\r\n    // #region Properties\r\n\r\n    /**\r\n     * Helper class to display tooltip on correct position\r\n     */\r\n    private readonly popupHelper: PopUpHelper = new PopUpHelper();\r\n\r\n    /**\r\n     * das property enthielt das Value als string. Default ist ''\r\n     */\r\n    protected _valueAsString = '';\r\n\r\n    /**\r\n     * Containers for the datetime picker\r\n     */\r\n\r\n    protected pickercontainer: ElementRef<HTMLElement>;\r\n\r\n    /**\r\n     * Property for enum in Angular HTML template\r\n     */\r\n    public TooltipPosition = TooltipPosition;\r\n\r\n    /**\r\n     * Definiert ob der Date Selector angezeigt wird\r\n     */\r\n    public _showselector: boolean = false;\r\n\r\n    /**\r\n     * Definiert das Control als Required\r\n     */\r\n    @Input() public isrequired: boolean = false;\r\n\r\n    /**\r\n     * Moment JS Instance\r\n     */\r\n    public moment = moment_['default'];\r\n\r\n    /**\r\n     * Arrow Item of Picker Element. Required to set the position of arrow correctly\r\n     */\r\n    public pickerPosition = TooltipPosition;\r\n    @ViewChild('pickerarrow', { static: false })\r\n    public pickerarrow: ElementRef<HTMLElement> | null;\r\n\r\n    /**\r\n     * Name of the container for content (e.g. icon) on which the tooltip is displayed.\r\n     */\r\n    @ViewChild('pickerbutton', { static: true })\r\n    public pickerbutton: ElementRef<HTMLElement>;\r\n\r\n    /**\r\n     * TextBox Placeholder\r\n     */\r\n    @Input() public placeholder: string = null;\r\n\r\n    /**\r\n     * Position of the picker arrow at the left\r\n     */\r\n    public posArrowLeft: number | null = null;\r\n\r\n    /**\r\n     * Position of the picker arrow at the top\r\n     */\r\n    public posArrowTop: number | null = null;\r\n\r\n    /**\r\n     * Position of the picker at the left\r\n     */\r\n    public posPopupLeft: number = 0;\r\n\r\n    /**\r\n     * Position of the picker at the top\r\n     */\r\n    public posPopupTop: number = 0;\r\n\r\n    /**\r\n     * Position of the datetime picker. Values: left|top|right|bottom|auto\r\n     *\r\n     * Value 'auto' can be combined with another value.\r\n     */\r\n    @Input()\r\n    public position: string = 'bottomend|topend';\r\n\r\n    /**\r\n     * Resource Key für Validation Message DateTimeFormat bei Control\r\n     */\r\n    @Input() public validationmessagedatetimeformat: string = this.validationKeyService.ValidationErrorDatetimeFormat;\r\n\r\n    /**\r\n     * Resource Key für Validation Message DateTimeFormat in Validation Summary\r\n     */\r\n    @Input() public validationmessagedatetimeformatsummary: string =\r\n        this.validationKeyService.ValidationErrorSummaryDatetimeFormat;\r\n\r\n    /**\r\n     * Resource Key für Validation Message Required bei Control\r\n     */\r\n    @Input() public validationmessagerequired: string = this.validationKeyService.ValidationErrorRequired;\r\n\r\n    /**\r\n     * Resource Key für Validation Message Required in Validation Summary\r\n     */\r\n    @Input() public validationmessagerequiredsummary: string = this.validationKeyService.ValidationErrorSummaryRequired;\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        private readonly cdRef: ChangeDetectorRef\r\n    ) {\r\n        super(formlayout, injector);\r\n    }\r\n\r\n    // #endregion Constructors\r\n\r\n    // #region Public Getters And Setters\r\n\r\n    /**\r\n     * Setter for the name of the container for the tooltip. Is required as the tooltip can be hidden via ngIf.\r\n     */\r\n    @ViewChild('picker', { static: false })\r\n    public set picker(picker: ElementRef) {\r\n        if (picker !== undefined) {\r\n            document.body.appendChild(picker.nativeElement);\r\n        }\r\n\r\n        this.pickercontainer = picker;\r\n        this.onContentChange();\r\n        this.cdRef.detectChanges();\r\n    }\r\n\r\n    public get tooltop(): ElementRef {\r\n        return this.pickercontainer;\r\n    }\r\n\r\n    /**\r\n     * getter für valuestring\r\n     */\r\n    public get valuestring(): string {\r\n        if (this.value === null) {\r\n            return this._valueAsString;\r\n        } else {\r\n            const date = this.moment.utc(this.value);\r\n            return date.local().format(this.GetDateTimeFormatString());\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Das Input bekommt das value von typ string\r\n     */\r\n    @Input()\r\n    public set valuestring(v: string) {\r\n        this._valueAsString = v;\r\n        let date: moment_.Moment = this.moment(v, [this.GetDateTimeFormatString()], true);\r\n\r\n        date = this.ModifyParsedDateTimeValue(date).utc();\r\n\r\n        if (date.isValid()) {\r\n            this.value = date.toDate();\r\n        } else {\r\n            this.value = 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     * Die methode returns dateTime in string\r\n     */\r\n    public abstract GetDateTimeFormatString(): string;\r\n\r\n    /**\r\n     * Returns the position of the tooltip\r\n     */\r\n    public GetPickerPosition(): TooltipPosition {\r\n        return this.popupHelper.getDisplayPosition(\r\n            this.pickerbutton,\r\n            this.pickercontainer,\r\n            this.getArrowWidth(),\r\n            this.getArrowHeight(),\r\n            this.position,\r\n            false\r\n        );\r\n    }\r\n\r\n    /**\r\n     * Die methode modifiziert das eingegebene Value von typ Moment\r\n     */\r\n    public abstract ModifyParsedDateTimeValue(v: moment_.Moment): moment_.Moment;\r\n\r\n    /**\r\n     * JSON Date String in ein UTC DateTime Object konvertieren, welches vom Control verwendete werden kann\r\n     */\r\n    public getDate(timestamp): moment.Moment {\r\n        const date = new Date(timestamp);\r\n        const year = date.getUTCFullYear();\r\n        const month = date.getUTCMonth();\r\n        const day = date.getUTCDate();\r\n        const hours = date.getUTCHours();\r\n        const minutes = date.getUTCMinutes();\r\n        const seconds = date.getUTCSeconds();\r\n\r\n        return this.moment(Date.UTC(year, month, day, hours, minutes, seconds));\r\n    }\r\n\r\n    /**\r\n     * Calculates the height of the tooltip\r\n     */\r\n    public getPickerHeight(): number {\r\n        return this.popupHelper.getPopupHeight(this.pickercontainer);\r\n    }\r\n\r\n    /**\r\n     * Calculates the width of the picker\r\n     */\r\n    public getPickerWidth(): number {\r\n        return this.popupHelper.getPopupWidth(this.pickercontainer);\r\n    }\r\n\r\n    public ngDoCheck(): void {\r\n        // this.onContentChange();\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        // Unregister Event Listener\r\n        window.removeEventListener('scroll', this.onContentChange, true);\r\n        window.removeEventListener('resize', this.onContentChange, true);\r\n    }\r\n\r\n    /**\r\n     * Init Event\r\n     */\r\n    public ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.setDateTimeFormat();\r\n\r\n        // Register Event Listener\r\n        window.addEventListener('scroll', this.onContentChange, true);\r\n        window.addEventListener('resize', this.onContentChange, true);\r\n    }\r\n\r\n    /**\r\n     * setzt das value von typ string zu property valuestring\r\n     */\r\n    public setValueString(v: string) {\r\n        this.valuestring = v;\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 = Validation.isValidDate(\r\n            this.validationmessagedatetimeformat,\r\n            this.validationmessagedatetimeformatsummary\r\n        )(c);\r\n\r\n        if (this.isrequired) {\r\n            error = Validation.required(this.validationmessagerequired, this.validationmessagerequiredsummary)(c);\r\n        }\r\n\r\n        return error;\r\n    }\r\n\r\n    /**\r\n     * Overwrite WriteValue to Set correct Date Object\r\n     */\r\n    public writeValue(value: Date | string) {\r\n        if (value === '' || value === null || value === undefined) {\r\n            // Reset Value String, damit beim Update des Models auch das Input Feld geleert wird.\r\n            this._valueAsString = '';\r\n            // Set Internal Property\r\n            this._value = null;\r\n        } else {\r\n            this._value = this.getDate(value).toDate();\r\n        }\r\n\r\n        super.writeValue(this._value);\r\n    }\r\n\r\n    // #endregion Public Methods\r\n\r\n    // #region Protected Methods\r\n\r\n    protected getArrowHeight(): number {\r\n        return this.pickerarrow ? this.pickerarrow.nativeElement.offsetHeight : 0;\r\n    }\r\n\r\n    protected getArrowWidth(): number {\r\n        return this.pickerarrow ? this.pickerarrow.nativeElement.offsetWidth : 0;\r\n    }\r\n\r\n    /**\r\n     * Calculates the position of the tooltip from links\r\n     */\r\n    protected getPositionLeft(): number {\r\n        const value = this.popupHelper.getPositionLeft(\r\n            this.pickerbutton,\r\n            this.pickercontainer,\r\n            this.elementRef,\r\n            this.getArrowWidth(),\r\n            this.getArrowHeight(),\r\n            this.position,\r\n            false\r\n        );\r\n        this.posPopupLeft = value;\r\n\r\n        switch (this.GetPickerPosition()) {\r\n            case TooltipPosition.top:\r\n            case TooltipPosition.bottom:\r\n                this.posArrowLeft = this.getPickerWidth() / 2 - -this.getArrowWidth();\r\n                break;\r\n            case TooltipPosition.topend:\r\n            case TooltipPosition.bottomend:\r\n                this.posArrowLeft =\r\n                    this.getPickerWidth() -\r\n                    this.getArrowWidth() / 2 -\r\n                    this.popupHelper.getContainerWidth(this.pickerbutton, false) / 2;\r\n                break;\r\n            default:\r\n                this.posArrowLeft = null;\r\n                break;\r\n        }\r\n\r\n        return value;\r\n    }\r\n\r\n    /**\r\n     * Calculates the position of the tooltip from the top\r\n     */\r\n    protected getPositionTop(): number {\r\n        const value = this.popupHelper.getPositionTop(\r\n            this.pickerbutton,\r\n            this.pickercontainer,\r\n            this.elementRef,\r\n            this.getArrowWidth(),\r\n            this.getArrowHeight(),\r\n            this.position,\r\n            false\r\n        );\r\n        this.posPopupTop = value;\r\n\r\n        switch (this.GetPickerPosition()) {\r\n            case TooltipPosition.left:\r\n            case TooltipPosition.right:\r\n                this.posArrowTop = this.getPickerHeight() / 2 - 6.5;\r\n                break;\r\n            default:\r\n                this.posArrowTop = null;\r\n                break;\r\n        }\r\n\r\n        return value;\r\n    }\r\n\r\n    // #endregion Protected Methods\r\n\r\n    // #region Private Methods\r\n\r\n    /**\r\n     * method if content has changed and proportions need to be reset in the UI.\r\n     */\r\n    private readonly onContentChange = (): void => {\r\n        // Do nothing if is not visible\r\n        if (!this._showselector) {\r\n            return;\r\n        }\r\n\r\n        setTimeout(() => {\r\n            this.getPositionLeft();\r\n            this.getPositionTop();\r\n        });\r\n    };\r\n\r\n    private setDateTimeFormat(): void {\r\n        // HACK: Add addition property to FormControl. Can be fixed if solution for ticket: https://github.com/angular/angular/issues/19686\r\n        if (this.ngControl) {\r\n            (this.ngControl as unknown as IDateTimeControl).datetimeformatstring = this.GetDateTimeFormatString();\r\n        }\r\n    }\r\n\r\n    // #endregion Private Methods\r\n}\r\n"]}