@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.
- package/bundles/simpleangularcontrols-sac-common.umd.js +1425 -1088
- package/bundles/simpleangularcontrols-sac-common.umd.js.map +1 -1
- package/bundles/simpleangularcontrols-sac-common.umd.min.js +1 -1
- package/bundles/simpleangularcontrols-sac-common.umd.min.js.map +1 -1
- package/common/basedatetimecontrol.d.ts +99 -13
- package/common/basemodelcontrol.d.ts +33 -29
- package/controls/checkbox/radiobutton.d.ts +61 -26
- package/controls/contextmenu/contextmenu.d.ts +26 -19
- package/controls/contextmenu/contextmenu.interface.d.ts +3 -0
- package/controls/contextmenu/contextmenuitem.d.ts +5 -0
- package/controls/contextmenu/contextmenuitembutton.d.ts +21 -20
- package/controls/datetime/date.d.ts +28 -27
- package/controls/datetime/datetime.d.ts +27 -27
- package/controls/datetime/time.d.ts +26 -26
- package/controls/dialog/dialog.d.ts +31 -43
- package/controls/layout/formlayout.d.ts +4 -0
- package/controls/list/buildvaluestring.d.ts +6 -0
- package/controls/list/dropdown.d.ts +9 -51
- package/controls/list/dropdownoptions.d.ts +38 -0
- package/controls/list/dropdownoptions.ngfactory.d.ts +1 -0
- package/controls/static/formcontainer.d.ts +11 -3
- package/controls/tooltip/tooltip.d.ts +33 -51
- package/controls/treeview/treeview.d.ts +87 -121
- package/esm2015/common/basedatetimecontrol.js +178 -30
- package/esm2015/common/basemodelcontrol.js +71 -56
- package/esm2015/controls/checkbox/radiobutton.js +94 -45
- package/esm2015/controls/contextmenu/contextmenu.interface.js +1 -0
- package/esm2015/controls/contextmenu/contextmenu.interface.ngfactory.js +7 -0
- package/esm2015/controls/contextmenu/contextmenu.js +22 -23
- package/esm2015/controls/contextmenu/contextmenuitem.js +13 -2
- package/esm2015/controls/contextmenu/contextmenuitembutton.js +34 -25
- package/esm2015/controls/datetime/date.js +43 -41
- package/esm2015/controls/datetime/datetime.js +42 -41
- package/esm2015/controls/datetime/time.js +42 -41
- package/esm2015/controls/dialog/dialog.js +41 -83
- package/esm2015/controls/layout/formlayout.js +7 -6
- package/esm2015/controls/list/buildvaluestring.js +18 -0
- package/esm2015/controls/{treeview/ngtreeitemaction.ngfactory.js → list/buildvaluestring.ngfactory.js} +1 -1
- package/esm2015/controls/list/dropdown.js +16 -114
- package/esm2015/controls/list/dropdownoptions.js +72 -0
- package/esm2015/controls/{treeview/treeviewchild.ngfactory.js → list/dropdownoptions.ngfactory.js} +1 -1
- package/esm2015/controls/static/formcontainer.js +16 -6
- package/esm2015/controls/tooltip/tooltip.js +60 -250
- package/esm2015/controls/treeview/treeview.js +232 -247
- package/esm2015/interfaces/ISacConfigurationService.js +1 -1
- package/esm2015/interfaces/ISacIconService.js +1 -1
- package/esm2015/interfaces/treeviewaction.interface.js +1 -0
- package/esm2015/interfaces/treeviewaction.interface.ngfactory.js +7 -0
- package/esm2015/public_api.js +6 -6
- package/esm2015/services/sac-configuration.service.js +7 -5
- package/esm2015/services/sac-icon.service.js +25 -1
- package/esm2015/utilities/enums.js +5 -1
- package/esm2015/utilities/popuphelper.js +343 -0
- package/esm2015/utilities/popuphelper.ngfactory.js +7 -0
- package/esm2015/validation/equals.validator.js +14 -0
- package/esm2015/validation/equals.validator.ngfactory.js +7 -0
- package/esm2015/validation/notequals.validator.js +14 -0
- package/esm2015/validation/notequals.validator.ngfactory.js +7 -0
- package/esm2015/validation/validation.class.js +30 -6
- package/fesm2015/simpleangularcontrols-sac-common.js +1398 -1075
- package/fesm2015/simpleangularcontrols-sac-common.js.map +1 -1
- package/interfaces/ISacConfigurationService.d.ts +4 -0
- package/interfaces/ISacIconService.d.ts +16 -0
- package/interfaces/treeviewaction.interface.d.ts +4 -0
- package/interfaces/treeviewaction.interface.ngfactory.d.ts +1 -0
- package/package.json +1 -1
- package/public_api.d.ts +5 -5
- package/services/sac-configuration.service.d.ts +8 -0
- package/services/sac-icon.service.d.ts +33 -1
- package/simpleangularcontrols-sac-common-10.0.0-rc.13.tgz +0 -0
- package/simpleangularcontrols-sac-common.metadata.json +1 -1
- package/utilities/enums.d.ts +3 -1
- package/utilities/popuphelper.d.ts +83 -0
- package/utilities/popuphelper.ngfactory.d.ts +1 -0
- package/validation/equals.validator.d.ts +2 -0
- package/validation/equals.validator.ngfactory.d.ts +1 -0
- package/validation/notequals.validator.d.ts +2 -0
- package/validation/notequals.validator.ngfactory.d.ts +1 -0
- package/validation/validation.class.d.ts +19 -0
- package/controls/treeview/ngtreeitemaction.d.ts +0 -40
- package/controls/treeview/treeviewchild.d.ts +0 -12
- package/esm2015/controls/treeview/ngtreeitemaction.js +0 -60
- package/esm2015/controls/treeview/treeviewchild.js +0 -18
- package/simpleangularcontrols-sac-common-10.0.0-rc.11.tgz +0 -0
- /package/controls/{treeview/ngtreeitemaction.ngfactory.d.ts → contextmenu/contextmenu.interface.ngfactory.d.ts} +0 -0
- /package/controls/{treeview/treeviewchild.ngfactory.d.ts → list/buildvaluestring.ngfactory.d.ts} +0 -0
|
@@ -1,13 +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
2
|
import { Validation } from '../../validation';
|
|
6
3
|
import { SacFormLayoutCommon } from '../layout/formlayout';
|
|
7
|
-
|
|
8
|
-
*
|
|
9
|
-
|
|
10
|
-
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';
|
|
11
7
|
/**
|
|
12
8
|
* Komponente für SacDateCommon. Extends SacBaseDateTimeControl
|
|
13
9
|
*/
|
|
@@ -19,9 +15,10 @@ export class SacDateCommon extends SacBaseDateTimeControl {
|
|
|
19
15
|
* @param formlayout SacFormLayoutCommon to define scoped layout settings
|
|
20
16
|
* @param injector Injector for injecting services
|
|
21
17
|
* @param elementRef reference to html element
|
|
18
|
+
* @param cdRef Change Dectection Servie
|
|
22
19
|
*/
|
|
23
|
-
constructor(formlayout, injector, elementRef) {
|
|
24
|
-
super(formlayout, injector, elementRef);
|
|
20
|
+
constructor(formlayout, injector, elementRef, cdRef) {
|
|
21
|
+
super(formlayout, injector, elementRef, cdRef);
|
|
25
22
|
this.elementRef = elementRef;
|
|
26
23
|
// #region Properties
|
|
27
24
|
/**
|
|
@@ -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,26 +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
85
|
}
|
|
89
86
|
// #endregion Constructors
|
|
90
87
|
// #region Public Getters And Setters
|
|
88
|
+
/**
|
|
89
|
+
* icon for date selector button
|
|
90
|
+
*/
|
|
91
|
+
get IconSelector() {
|
|
92
|
+
return this.iconService.DateComponentSelectorIcon;
|
|
93
|
+
}
|
|
91
94
|
/**
|
|
92
95
|
* Min Date
|
|
93
96
|
*/
|
|
94
97
|
set maxdate(v) {
|
|
95
|
-
const date = moment(v, [this.DATEFORMAT], true);
|
|
98
|
+
const date = this.moment(v, [this.DATEFORMAT], true);
|
|
96
99
|
if (date.isValid()) {
|
|
97
100
|
this._maxdate = super.getDate(date).toDate();
|
|
98
101
|
}
|
|
@@ -104,7 +107,7 @@ export class SacDateCommon extends SacBaseDateTimeControl {
|
|
|
104
107
|
* Min Date
|
|
105
108
|
*/
|
|
106
109
|
set mindate(v) {
|
|
107
|
-
const date = moment(v, [this.DATEFORMAT], true);
|
|
110
|
+
const date = this.moment(v, [this.DATEFORMAT], true);
|
|
108
111
|
if (date.isValid()) {
|
|
109
112
|
this._mindate = super.getDate(date).toDate();
|
|
110
113
|
}
|
|
@@ -112,23 +115,8 @@ export class SacDateCommon extends SacBaseDateTimeControl {
|
|
|
112
115
|
this._mindate = null;
|
|
113
116
|
}
|
|
114
117
|
}
|
|
115
|
-
/**
|
|
116
|
-
* icon for date selector button
|
|
117
|
-
*/
|
|
118
|
-
get IconSelector() {
|
|
119
|
-
return this.iconService.DateComponentSelectorIcon;
|
|
120
|
-
}
|
|
121
118
|
// #endregion Public Getters And Setters
|
|
122
119
|
// #region Public Methods
|
|
123
|
-
/**
|
|
124
|
-
* HostListener
|
|
125
|
-
*/
|
|
126
|
-
onClick(targetElement) {
|
|
127
|
-
const clickedInside = this.elementRef.nativeElement.contains(targetElement);
|
|
128
|
-
if (!clickedInside) {
|
|
129
|
-
this._showselector = false;
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
120
|
/**
|
|
133
121
|
* Methode ergibt Datum-Format vom String
|
|
134
122
|
*/
|
|
@@ -149,10 +137,23 @@ export class SacDateCommon extends SacBaseDateTimeControl {
|
|
|
149
137
|
this.setValueString('');
|
|
150
138
|
}
|
|
151
139
|
else {
|
|
152
|
-
this.value = moment(v.date).utc().toDate();
|
|
140
|
+
this.value = this.moment(v.date).utc().toDate();
|
|
153
141
|
}
|
|
154
142
|
this._showselector = false;
|
|
155
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
|
+
}
|
|
156
157
|
/**
|
|
157
158
|
* Zeigt Date Selector an
|
|
158
159
|
*/
|
|
@@ -197,7 +198,8 @@ SacDateCommon.decorators = [
|
|
|
197
198
|
SacDateCommon.ctorParameters = () => [
|
|
198
199
|
{ type: SacFormLayoutCommon },
|
|
199
200
|
{ type: Injector },
|
|
200
|
-
{ type: ElementRef }
|
|
201
|
+
{ type: ElementRef },
|
|
202
|
+
{ type: ChangeDetectorRef }
|
|
201
203
|
];
|
|
202
204
|
SacDateCommon.propDecorators = {
|
|
203
205
|
validationmessagemaxdate: [{ type: Input }],
|
|
@@ -208,4 +210,4 @@ SacDateCommon.propDecorators = {
|
|
|
208
210
|
mindate: [{ type: Input }],
|
|
209
211
|
onClick: [{ type: HostListener, args: ['document:click', ['$event.target'],] }]
|
|
210
212
|
};
|
|
211
|
-
//# 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 { 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   * 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\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,13 +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
2
|
import { Validation } from '../../validation';
|
|
6
3
|
import { SacFormLayoutCommon } from '../layout/formlayout';
|
|
7
|
-
|
|
8
|
-
*
|
|
9
|
-
|
|
10
|
-
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';
|
|
11
7
|
/**
|
|
12
8
|
* Komponente für SacDateTimeCommon. Extends SacBaseDateTimeControl
|
|
13
9
|
*/
|
|
@@ -20,8 +16,8 @@ export class SacDateTimeCommon extends SacBaseDateTimeControl {
|
|
|
20
16
|
* @param injector Injector for injecting services
|
|
21
17
|
* @param elementRef reference to html element
|
|
22
18
|
*/
|
|
23
|
-
constructor(formlayout, injector, elementRef) {
|
|
24
|
-
super(formlayout, injector, elementRef);
|
|
19
|
+
constructor(formlayout, injector, elementRef, cdRef) {
|
|
20
|
+
super(formlayout, injector, elementRef, cdRef);
|
|
25
21
|
this.elementRef = elementRef;
|
|
26
22
|
// #region Properties
|
|
27
23
|
/**
|
|
@@ -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,26 +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
99
|
}
|
|
104
100
|
// #endregion Constructors
|
|
105
101
|
// #region Public Getters And Setters
|
|
102
|
+
/**
|
|
103
|
+
* icon for date selector button
|
|
104
|
+
*/
|
|
105
|
+
get IconSelector() {
|
|
106
|
+
return this.iconService.DateTimeComponentSelectorIcon;
|
|
107
|
+
}
|
|
106
108
|
/**
|
|
107
109
|
* Max Date
|
|
108
110
|
*/
|
|
109
111
|
set maxdate(v) {
|
|
110
|
-
const date = moment(v, [this.DATEFORMAT], true);
|
|
112
|
+
const date = this.moment(v, [this.DATEFORMAT], true);
|
|
111
113
|
if (date.isValid()) {
|
|
112
114
|
this._maxdate = super.getDate(date).toDate();
|
|
113
115
|
}
|
|
@@ -119,7 +121,7 @@ export class SacDateTimeCommon extends SacBaseDateTimeControl {
|
|
|
119
121
|
* Min Date
|
|
120
122
|
*/
|
|
121
123
|
set mindate(v) {
|
|
122
|
-
const date = moment(v, [this.DATEFORMAT], true);
|
|
124
|
+
const date = this.moment(v, [this.DATEFORMAT], true);
|
|
123
125
|
if (date.isValid()) {
|
|
124
126
|
this._mindate = super.getDate(date).toDate();
|
|
125
127
|
}
|
|
@@ -127,23 +129,8 @@ export class SacDateTimeCommon extends SacBaseDateTimeControl {
|
|
|
127
129
|
this._mindate = null;
|
|
128
130
|
}
|
|
129
131
|
}
|
|
130
|
-
/**
|
|
131
|
-
* icon for date selector button
|
|
132
|
-
*/
|
|
133
|
-
get IconSelector() {
|
|
134
|
-
return this.iconService.DateTimeComponentSelectorIcon;
|
|
135
|
-
}
|
|
136
132
|
// #endregion Public Getters And Setters
|
|
137
133
|
// #region Public Methods
|
|
138
|
-
/**
|
|
139
|
-
* HostListener
|
|
140
|
-
*/
|
|
141
|
-
onClick(targetElement) {
|
|
142
|
-
const clickedInside = this.elementRef.nativeElement.contains(targetElement);
|
|
143
|
-
if (!clickedInside) {
|
|
144
|
-
this._showselector = false;
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
134
|
/**
|
|
148
135
|
* Methode ergibt Datum-Format vom String
|
|
149
136
|
*/
|
|
@@ -164,10 +151,23 @@ export class SacDateTimeCommon extends SacBaseDateTimeControl {
|
|
|
164
151
|
this.setValueString('');
|
|
165
152
|
}
|
|
166
153
|
else {
|
|
167
|
-
this.value = moment(v.date).utc().toDate();
|
|
154
|
+
this.value = this.moment(v.date).utc().toDate();
|
|
168
155
|
}
|
|
169
156
|
this._showselector = false;
|
|
170
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
|
+
}
|
|
171
171
|
/**
|
|
172
172
|
* DateSelector wird beim Click-Event angezeigt
|
|
173
173
|
*/
|
|
@@ -214,7 +214,8 @@ SacDateTimeCommon.decorators = [
|
|
|
214
214
|
SacDateTimeCommon.ctorParameters = () => [
|
|
215
215
|
{ type: SacFormLayoutCommon },
|
|
216
216
|
{ type: Injector },
|
|
217
|
-
{ type: ElementRef }
|
|
217
|
+
{ type: ElementRef },
|
|
218
|
+
{ type: ChangeDetectorRef }
|
|
218
219
|
];
|
|
219
220
|
SacDateTimeCommon.propDecorators = {
|
|
220
221
|
validationmessagemaxdate: [{ type: Input }],
|
|
@@ -225,4 +226,4 @@ SacDateTimeCommon.propDecorators = {
|
|
|
225
226
|
mindate: [{ type: Input }],
|
|
226
227
|
onClick: [{ type: HostListener, args: ['document:click', ['$event.target'],] }]
|
|
227
228
|
};
|
|
228
|
-
//# 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,EACL,SAAS,EACT,UAAU,EACV,YAAY,EACZ,QAAQ,EACR,KAAK,GACN,MAAM,eAAe,CAAC;AAEvB,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,KAAK,OAAO,MAAM,QAAQ,CAAC;AAGlC,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAC1E,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAE3D;;GAEG;AACH,MAAM,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC;AAElC;;GAEG;AAEH,MAAM,OAAO,iBAAkB,SAAQ,sBAAsB;IAsF3D,wBAAwB;IAExB,uBAAuB;IAEvB;;;;;OAKG;IACH,YACE,UAA+B,EAC/B,QAAkB,EACR,UAAsB;QAEhC,KAAK,CAAC,UAAU,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;QAF9B,eAAU,GAAV,UAAU,CAAY;QAlGlC,qBAAqB;QAErB;;WAEG;QACa,eAAU,GAAW,kBAAkB,CAAC;QACxD;;WAEG;QACH;;WAEG;QACa,cAAS,GAAG;YAC1B,IAAI,EAAE,IAAI,CAAC,UAAU;YACrB,MAAM,EAAE;gBACN,EAAE,EAAE;oBACF,IAAI,EAAE,KAAK,CAAC,WAAW;oBACvB,IAAI,EAAE,CAAC;oBACP,EAAE,EAAE,EAAE;oBACN,SAAS,EAAE,CAAC;iBACb;gBACD,EAAE,EAAE;oBACF,IAAI,EAAE,KAAK,CAAC,WAAW;oBACvB,IAAI,EAAE,CAAC;oBACP,EAAE,EAAE,EAAE;oBACN,SAAS,EAAE,CAAC;iBACb;gBACD,IAAI,EAAE;oBACJ,IAAI,EAAE,KAAK,CAAC,WAAW;oBACvB,IAAI,EAAE,CAAC;oBACP,EAAE,EAAE,IAAI;iBACT;gBACD,EAAE,EAAE;oBACF,IAAI,EAAE,KAAK,CAAC,WAAW;oBACvB,IAAI,EAAE,CAAC;oBACP,EAAE,EAAE,EAAE;oBACN,SAAS,EAAE,CAAC;iBACb;gBACD,EAAE,EAAE;oBACF,IAAI,EAAE,KAAK,CAAC,WAAW;oBACvB,IAAI,EAAE,CAAC;oBACP,EAAE,EAAE,EAAE;oBACN,SAAS,EAAE,CAAC;iBACb;aACF;YACD,eAAe,EAAE,GAAG;YACpB,OAAO,EAAE,IAAI;YACb,IAAI,EAAE,KAAK;YACX,SAAS,EAAE,IAAI;SAChB,CAAC;QAEF;;WAEG;QACa,6BAAwB,GACtC,IAAI,CAAC,oBAAoB,CAAC,sBAAsB,CAAC;QACnD;;WAEG;QACa,6BAAwB,GACtC,IAAI,CAAC,oBAAoB,CAAC,sBAAsB,CAAC;QACnD;;WAEG;QACa,oCAA+B,GAC7C,IAAI,CAAC,oBAAoB,CAAC,6BAA6B,CAAC;QAC1D;;WAEG;QACa,oCAA+B,GAC7C,IAAI,CAAC,oBAAoB,CAAC,6BAA6B,CAAC;QAE1D;;WAEG;QACI,aAAQ,GAAS,IAAI,CAAC;QAC7B;;WAEG;QACI,aAAQ,GAAS,IAAI,CAAC;QAC7B;;WAEG;QACI,kBAAa,GAAY,KAAK,CAAC;IAkBtC,CAAC;IAED,0BAA0B;IAE1B,qCAAqC;IAErC;;OAEG;IACH,IACW,OAAO,CAAC,CAAuB;QACxC,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,CAAC;QAEhD,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE;YAClB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;SAC9C;aAAM;YACL,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACtB;IACH,CAAC;IAED;;OAEG;IACH,IACW,OAAO,CAAC,CAAuB;QACxC,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,CAAC;QAEhD,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE;YAClB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;SAC9C;aAAM;YACL,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACtB;IACH,CAAC;IAED;;OAEG;IACH,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,WAAW,CAAC,6BAA6B,CAAC;IACxD,CAAC;IAED,wCAAwC;IAExC,yBAAyB;IAEzB;;OAEG;IAKI,OAAO,CAAC,aAAa;QAC1B,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;QAC5E,IAAI,CAAC,aAAa,EAAE;YAClB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;SAC5B;IACH,CAAC;IAED;;OAEG;IACI,uBAAuB;QAC5B,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;OAEG;IACI,yBAAyB,CAAC,CAAS;QACxC,OAAO,CAAC,CAAC;IACX,CAAC;IAED;;OAEG;IACI,UAAU,CAAC,CAAM;QACtB,IAAI,CAAC,CAAC,IAAI,KAAK,IAAI,EAAE;YACnB,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;SACzB;aAAM;YACL,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC;SAC5C;QAED,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC7B,CAAC;IAED;;OAEG;IACI,gBAAgB;QACrB;;WAEG;QACH,IAAI,CAAC,OAAO,EAAE,CAAC;QAEf,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;SAC5B;aAAM;YACL,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC3B;IACH,CAAC;IAED;;OAEG;IACI,YAAY,CAAC,CAAkB;QACpC,IAAI,KAAK,GAA4B,IAAI,CAAC;QAE1C,KAAK,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAE9B,IACE,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,EACtB;YACA,KAAK,GAAG,UAAU,CAAC,OAAO,CACxB,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,wBAAwB,EAC7B,IAAI,CAAC,+BAA+B,CACrC,CAAC,CAAC,CAAC,CAAC;SACN;QAED,IACE,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,EACtB;YACA,KAAK,GAAG,UAAU,CAAC,OAAO,CACxB,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,wBAAwB,EAC7B,IAAI,CAAC,+BAA+B,CACrC,CAAC,CAAC,CAAC,CAAC;SACN;QAED,OAAO,KAAK,CAAC;IACf,CAAC;;;YApPF,SAAS;;;YAVD,mBAAmB;YAV1B,QAAQ;YAFR,UAAU;;;uCA8ET,KAAK;uCAKL,KAAK;8CAKL,KAAK;8CAKL,KAAK;sBAyCL,KAAK;sBAcL,KAAK;sBAyBL,YAAY,SAAC,gBAAgB,EAAE,CAAC,eAAe,CAAC","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 { 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   * 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\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":"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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 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"]}
|
|
@@ -1,13 +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
2
|
import { Validation } from '../../validation';
|
|
6
3
|
import { SacFormLayoutCommon } from '../layout/formlayout';
|
|
7
|
-
|
|
8
|
-
*
|
|
9
|
-
|
|
10
|
-
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';
|
|
11
7
|
/**
|
|
12
8
|
* Komponente für SacTimeCommon. Extends SacBaseDateTimeControl
|
|
13
9
|
*/
|
|
@@ -20,8 +16,8 @@ export class SacTimeCommon extends SacBaseDateTimeControl {
|
|
|
20
16
|
* @param injector Injector for injecting services
|
|
21
17
|
* @param elementRef reference to html element
|
|
22
18
|
*/
|
|
23
|
-
constructor(formlayout, injector, elementRef) {
|
|
24
|
-
super(formlayout, injector, elementRef);
|
|
19
|
+
constructor(formlayout, injector, elementRef, cdRef) {
|
|
20
|
+
super(formlayout, injector, elementRef, cdRef);
|
|
25
21
|
this.elementRef = elementRef;
|
|
26
22
|
// #region Properties
|
|
27
23
|
/**
|
|
@@ -52,6 +48,18 @@ export class SacTimeCommon extends SacBaseDateTimeControl {
|
|
|
52
48
|
lazy: false,
|
|
53
49
|
overwrite: true,
|
|
54
50
|
};
|
|
51
|
+
/**
|
|
52
|
+
* Max Time
|
|
53
|
+
*/
|
|
54
|
+
this._maxtime = null;
|
|
55
|
+
/**
|
|
56
|
+
* Min Time
|
|
57
|
+
*/
|
|
58
|
+
this._mintime = null;
|
|
59
|
+
/**
|
|
60
|
+
* Moment JS module instance
|
|
61
|
+
*/
|
|
62
|
+
this.moment = moment_['default'];
|
|
55
63
|
/**
|
|
56
64
|
* Resource Key für Validation Message MinTime bei Control
|
|
57
65
|
*/
|
|
@@ -68,26 +76,20 @@ export class SacTimeCommon extends SacBaseDateTimeControl {
|
|
|
68
76
|
* Resource Key für Validation Message MinTime in Validation Summary
|
|
69
77
|
*/
|
|
70
78
|
this.validationmessagesummarymintime = this.validationKeyService.ValidationErrorSummaryMinTime;
|
|
71
|
-
/**
|
|
72
|
-
* Max Time
|
|
73
|
-
*/
|
|
74
|
-
this._maxtime = null;
|
|
75
|
-
/**
|
|
76
|
-
* Min Time
|
|
77
|
-
*/
|
|
78
|
-
this._mintime = null;
|
|
79
|
-
/**
|
|
80
|
-
* Definiert ob der Date Selector angezeigt wird
|
|
81
|
-
*/
|
|
82
|
-
this._showselector = false;
|
|
83
79
|
}
|
|
84
80
|
// #endregion Constructors
|
|
85
81
|
// #region Public Getters And Setters
|
|
82
|
+
/**
|
|
83
|
+
* icon for date selector button
|
|
84
|
+
*/
|
|
85
|
+
get IconSelector() {
|
|
86
|
+
return this.iconService.TimeComponentSelectorIcon;
|
|
87
|
+
}
|
|
86
88
|
/**
|
|
87
89
|
* Max Time
|
|
88
90
|
*/
|
|
89
91
|
set maxtime(v) {
|
|
90
|
-
let time = moment(v, [this.TIMEFORMAT], true);
|
|
92
|
+
let time = this.moment(v, [this.TIMEFORMAT], true);
|
|
91
93
|
time = this.ModifyParsedDateTimeValue(time);
|
|
92
94
|
if (time.isValid()) {
|
|
93
95
|
this._maxtime = super.getDate(time).toDate();
|
|
@@ -100,7 +102,7 @@ export class SacTimeCommon extends SacBaseDateTimeControl {
|
|
|
100
102
|
* Min Time
|
|
101
103
|
*/
|
|
102
104
|
set mintime(v) {
|
|
103
|
-
let time = moment(v, [this.TIMEFORMAT], true);
|
|
105
|
+
let time = this.moment(v, [this.TIMEFORMAT], true);
|
|
104
106
|
time = this.ModifyParsedDateTimeValue(time);
|
|
105
107
|
if (time.isValid()) {
|
|
106
108
|
this._mintime = super.getDate(time).toDate();
|
|
@@ -109,23 +111,8 @@ export class SacTimeCommon extends SacBaseDateTimeControl {
|
|
|
109
111
|
this._mintime = null;
|
|
110
112
|
}
|
|
111
113
|
}
|
|
112
|
-
/**
|
|
113
|
-
* icon for date selector button
|
|
114
|
-
*/
|
|
115
|
-
get IconSelector() {
|
|
116
|
-
return this.iconService.TimeComponentSelectorIcon;
|
|
117
|
-
}
|
|
118
114
|
// #endregion Public Getters And Setters
|
|
119
115
|
// #region Public Methods
|
|
120
|
-
/**
|
|
121
|
-
* HostListener
|
|
122
|
-
*/
|
|
123
|
-
onClick(targetElement) {
|
|
124
|
-
const clickedInside = this.elementRef.nativeElement.contains(targetElement);
|
|
125
|
-
if (!clickedInside) {
|
|
126
|
-
this._showselector = false;
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
116
|
/**
|
|
130
117
|
* Methode ergibt Datum-Format vom String
|
|
131
118
|
*/
|
|
@@ -141,6 +128,19 @@ export class SacTimeCommon extends SacBaseDateTimeControl {
|
|
|
141
128
|
v.year(1900);
|
|
142
129
|
return v;
|
|
143
130
|
}
|
|
131
|
+
/**
|
|
132
|
+
* HostListener
|
|
133
|
+
*/
|
|
134
|
+
onClick(targetElement) {
|
|
135
|
+
if (!this.pickercontainer) {
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
const clickedInsideContainer = this.pickercontainer.nativeElement.contains(targetElement);
|
|
139
|
+
const clickedInsideReference = this.pickerbutton.nativeElement.contains(targetElement);
|
|
140
|
+
if (!clickedInsideContainer && !clickedInsideReference) {
|
|
141
|
+
this._showselector = false;
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
144
|
/**
|
|
145
145
|
* Zeigt Date Selector an
|
|
146
146
|
*/
|
|
@@ -162,7 +162,7 @@ export class SacTimeCommon extends SacBaseDateTimeControl {
|
|
|
162
162
|
this.setValueString('');
|
|
163
163
|
}
|
|
164
164
|
else {
|
|
165
|
-
this.value = moment(v.date).utc().toDate();
|
|
165
|
+
this.value = this.moment(v.date).utc().toDate();
|
|
166
166
|
}
|
|
167
167
|
this._showselector = false;
|
|
168
168
|
}
|
|
@@ -197,7 +197,8 @@ SacTimeCommon.decorators = [
|
|
|
197
197
|
SacTimeCommon.ctorParameters = () => [
|
|
198
198
|
{ type: SacFormLayoutCommon },
|
|
199
199
|
{ type: Injector },
|
|
200
|
-
{ type: ElementRef }
|
|
200
|
+
{ type: ElementRef },
|
|
201
|
+
{ type: ChangeDetectorRef }
|
|
201
202
|
];
|
|
202
203
|
SacTimeCommon.propDecorators = {
|
|
203
204
|
validationmessagemaxtime: [{ type: Input }],
|
|
@@ -208,4 +209,4 @@ SacTimeCommon.propDecorators = {
|
|
|
208
209
|
mintime: [{ type: Input }],
|
|
209
210
|
onClick: [{ type: HostListener, args: ['document:click', ['$event.target'],] }]
|
|
210
211
|
};
|
|
211
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/datetime/time.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 { 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 SacTimeCommon. Extends SacBaseDateTimeControl\r\n */\r\n@Directive()\r\nexport class SacTimeCommon extends SacBaseDateTimeControl {\r\n  // #region Properties\r\n\r\n  /**\r\n   * Format des Datums\r\n   */\r\n  public readonly TIMEFORMAT: string = 'HH:mm';\r\n  /**\r\n   * Maske\r\n   */\r\n  public readonly imaskDate = {\r\n    mask: this.TIMEFORMAT,\r\n    blocks: {\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 MinTime bei Control\r\n   */\r\n  @Input() public validationmessagemaxtime: string =\r\n    this.validationKeyService.ValidationErrorMaxTime;\r\n  /**\r\n   * Resource Key für Validation Message MinTime bei Control\r\n   */\r\n  @Input() public validationmessagemintime: string =\r\n    this.validationKeyService.ValidationErrorMinTime;\r\n  /**\r\n   * Resource Key für Validation Message MinTime in Validation Summary\r\n   */\r\n  @Input() public validationmessagesummarymaxtime: string =\r\n    this.validationKeyService.ValidationErrorSummaryMaxTime;\r\n  /**\r\n   * Resource Key für Validation Message MinTime in Validation Summary\r\n   */\r\n  @Input() public validationmessagesummarymintime: string =\r\n    this.validationKeyService.ValidationErrorSummaryMinTime;\r\n\r\n  /**\r\n   * Max Time\r\n   */\r\n  public _maxtime: Date = null;\r\n  /**\r\n   * Min Time\r\n   */\r\n  public _mintime: 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\r\n  // #endregion Constructors\r\n\r\n  // #region Public Getters And Setters\r\n\r\n  /**\r\n   * Max Time\r\n   */\r\n  @Input()\r\n  public set maxtime(v: string | Date | null) {\r\n    let time = moment(v, [this.TIMEFORMAT], true);\r\n\r\n    time = this.ModifyParsedDateTimeValue(time);\r\n\r\n    if (time.isValid()) {\r\n      this._maxtime = super.getDate(time).toDate();\r\n    } else {\r\n      this._maxtime = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Min Time\r\n   */\r\n  @Input()\r\n  public set mintime(v: string | Date | null) {\r\n    let time = moment(v, [this.TIMEFORMAT], true);\r\n\r\n    time = this.ModifyParsedDateTimeValue(time);\r\n\r\n    if (time.isValid()) {\r\n      this._mintime = super.getDate(time).toDate();\r\n    } else {\r\n      this._mintime = 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.TimeComponentSelectorIcon;\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.TIMEFORMAT;\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt Datum - Moment\r\n   */\r\n  public ModifyParsedDateTimeValue(v: Moment): Moment {\r\n    v.date(1);\r\n    v.month(0);\r\n    v.year(1900);\r\n    return v;\r\n  }\r\n\r\n  /**\r\n   * Zeigt Date Selector an\r\n   */\r\n  public showTimeSelector(): 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   * Time Selector\r\n   */\r\n  public timeselect(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   * 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._mintime !== undefined &&\r\n      this._mintime !== null\r\n    ) {\r\n      error = Validation.minTime(\r\n        this._mintime,\r\n        this.validationmessagemintime,\r\n        this.validationmessagesummarymintime\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._maxtime !== undefined &&\r\n      this._maxtime !== null\r\n    ) {\r\n      error = Validation.maxTime(\r\n        this._maxtime,\r\n        this.validationmessagemaxtime,\r\n        this.validationmessagesummarymaxtime\r\n      )(c);\r\n    }\r\n\r\n    return error;\r\n  }\r\n\r\n  // #endregion Public Methods\r\n}\r\n"]}
|
|
212
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/datetime/time.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 SacTimeCommon. Extends SacBaseDateTimeControl\r\n */\r\n@Directive()\r\nexport class SacTimeCommon extends SacBaseDateTimeControl {\r\n    // #region Properties\r\n\r\n    /**\r\n     * Format des Datums\r\n     */\r\n    public readonly TIMEFORMAT: string = 'HH:mm';\r\n\r\n    /**\r\n     * Maske\r\n     */\r\n    public readonly imaskDate = {\r\n        mask: this.TIMEFORMAT,\r\n        blocks: {\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     * Max Time\r\n     */\r\n    public _maxtime: Date = null;\r\n\r\n    /**\r\n     * Min Time\r\n     */\r\n    public _mintime: 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 MinTime bei Control\r\n     */\r\n    @Input() public validationmessagemaxtime: string = this.validationKeyService.ValidationErrorMaxTime;\r\n\r\n    /**\r\n     * Resource Key für Validation Message MinTime bei Control\r\n     */\r\n    @Input() public validationmessagemintime: string = this.validationKeyService.ValidationErrorMinTime;\r\n\r\n    /**\r\n     * Resource Key für Validation Message MinTime in Validation Summary\r\n     */\r\n    @Input() public validationmessagesummarymaxtime: string = this.validationKeyService.ValidationErrorSummaryMaxTime;\r\n\r\n    /**\r\n     * Resource Key für Validation Message MinTime in Validation Summary\r\n     */\r\n    @Input() public validationmessagesummarymintime: string = this.validationKeyService.ValidationErrorSummaryMinTime;\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.TimeComponentSelectorIcon;\r\n    }\r\n\r\n    /**\r\n     * Max Time\r\n     */\r\n    @Input()\r\n    public set maxtime(v: string | Date | null) {\r\n        let time = this.moment(v, [this.TIMEFORMAT], true);\r\n\r\n        time = this.ModifyParsedDateTimeValue(time);\r\n\r\n        if (time.isValid()) {\r\n            this._maxtime = super.getDate(time).toDate();\r\n        } else {\r\n            this._maxtime = null;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Min Time\r\n     */\r\n    @Input()\r\n    public set mintime(v: string | Date | null) {\r\n        let time = this.moment(v, [this.TIMEFORMAT], true);\r\n\r\n        time = this.ModifyParsedDateTimeValue(time);\r\n\r\n        if (time.isValid()) {\r\n            this._mintime = super.getDate(time).toDate();\r\n        } else {\r\n            this._mintime = 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.TIMEFORMAT;\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        v.date(1);\r\n        v.month(0);\r\n        v.year(1900);\r\n        return v;\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 showTimeSelector(): 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     * Time Selector\r\n     */\r\n    public timeselect(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     * 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._mintime !== undefined &&\r\n            this._mintime !== null\r\n        ) {\r\n            error = Validation.minTime(\r\n                this._mintime,\r\n                this.validationmessagemintime,\r\n                this.validationmessagesummarymintime\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._maxtime !== undefined &&\r\n            this._maxtime !== null\r\n        ) {\r\n            error = Validation.maxTime(\r\n                this._maxtime,\r\n                this.validationmessagemaxtime,\r\n                this.validationmessagesummarymaxtime\r\n            )(c);\r\n        }\r\n\r\n        return error;\r\n    }\r\n\r\n    // #endregion Public Methods\r\n}\r\n"]}
|