@simpleangularcontrols/sac-common 10.0.0-rc.2 → 10.0.0-rc.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/simpleangularcontrols-sac-common.umd.js +2232 -1604
- 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 +100 -14
- package/common/baseinputcontrol.d.ts +0 -4
- package/common/basemodelcontrol.d.ts +55 -27
- package/common/baseuploadcontrol.d.ts +71 -55
- package/controls/checkbox/checkbox.d.ts +12 -3
- 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 -31
- package/controls/datetime/datetime.d.ts +27 -31
- package/controls/datetime/time.d.ts +26 -30
- package/controls/dialog/dialog.d.ts +31 -43
- package/controls/grid/grid.d.ts +38 -36
- package/controls/grid/gridbutton.d.ts +13 -13
- package/controls/grid/gridcolumn.d.ts +8 -8
- package/controls/grid/gridcolumnaction.d.ts +3 -3
- package/controls/grid/gridcolumnbase.d.ts +45 -37
- package/controls/grid/gridimage.d.ts +2 -2
- package/controls/grid/model.d.ts +51 -42
- package/controls/grid/paging.d.ts +41 -43
- package/controls/input/input.d.ts +3 -3
- package/controls/input/inputarea.d.ts +5 -5
- package/controls/input/inputpassword.d.ts +7 -7
- package/controls/input/inputsearch.d.ts +13 -4
- package/controls/layout/formlayout.d.ts +17 -1
- 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/multilanguage/multilanguageinput.d.ts +2 -2
- package/controls/multilanguage/multilanguageinputarea.d.ts +4 -4
- package/controls/static/formcontainer.d.ts +7 -3
- package/controls/tooltip/tooltip.d.ts +76 -69
- package/controls/treeview/treeview.d.ts +107 -107
- package/esm2015/common/basedatetimecontrol.js +185 -30
- package/esm2015/common/baseinputcontrol.js +2 -7
- package/esm2015/common/basemodelcontrol.js +109 -57
- package/esm2015/common/baseuploadcontrol.js +92 -59
- package/esm2015/controls/checkbox/checkbox.js +29 -6
- 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 +44 -43
- package/esm2015/controls/datetime/datetime.js +43 -43
- package/esm2015/controls/datetime/time.js +43 -43
- package/esm2015/controls/dialog/dialog.js +41 -83
- package/esm2015/controls/grid/grid.js +21 -21
- package/esm2015/controls/grid/gridbutton.js +19 -13
- package/esm2015/controls/grid/gridcolumn.js +14 -7
- package/esm2015/controls/grid/gridcolumnaction.js +6 -5
- package/esm2015/controls/grid/gridcolumnbase.js +67 -55
- package/esm2015/controls/grid/gridimage.js +3 -3
- package/esm2015/controls/grid/model.js +51 -30
- package/esm2015/controls/grid/paging.js +40 -42
- package/esm2015/controls/input/input.js +6 -8
- package/esm2015/controls/input/inputarea.js +19 -12
- package/esm2015/controls/input/inputpassword.js +12 -12
- package/esm2015/controls/input/inputsearch.js +35 -6
- package/esm2015/controls/layout/formlayout.js +20 -8
- 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/multilanguage/multilanguageinput.js +8 -14
- package/esm2015/controls/multilanguage/multilanguageinputarea.js +9 -15
- package/esm2015/controls/static/formcontainer.js +16 -5
- package/esm2015/controls/tooltip/tooltip.js +126 -245
- package/esm2015/controls/treeview/treeview.js +276 -231
- package/esm2015/interfaces/ISacConfigurationService.js +1 -1
- package/esm2015/interfaces/ISacIconService.js +1 -1
- package/esm2015/interfaces/ISacUploadEventCompleteState.js +1 -0
- package/esm2015/interfaces/ISacUploadEventCompleteState.ngfactory.js +7 -0
- package/esm2015/interfaces/ISacValidationKeyService.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 +15 -8
- package/esm2015/services/sac-configuration.service.js +31 -5
- package/esm2015/services/sac-icon.service.js +37 -1
- package/esm2015/services/sac-localisation.service.js +69 -180
- package/esm2015/services/sac-validationkey.service.js +12 -9
- package/esm2015/simpleangularcontrols-sac-common.js +1 -7
- package/esm2015/utilities/enums.js +5 -1
- package/esm2015/utilities/guid.js +4 -2
- 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/isDateValid.js +9 -1
- package/esm2015/validation/mintextlength.validator.js +23 -0
- package/esm2015/validation/mintextlength.validator.ngfactory.js +7 -0
- package/esm2015/validation/notequals.validator.js +14 -0
- package/esm2015/validation/{minlength.validator.ngfactory.js → notequals.validator.ngfactory.js} +1 -1
- package/esm2015/validation/validation.class.js +35 -6
- package/fesm2015/simpleangularcontrols-sac-common.js +2070 -1498
- package/fesm2015/simpleangularcontrols-sac-common.js.map +1 -1
- package/interfaces/ISacConfigurationService.d.ts +20 -0
- package/interfaces/ISacIconService.d.ts +24 -0
- package/interfaces/ISacUploadEventCompleteState.d.ts +5 -0
- package/interfaces/ISacUploadEventCompleteState.ngfactory.d.ts +1 -0
- package/interfaces/ISacValidationKeyService.d.ts +2 -2
- package/interfaces/treeviewaction.interface.d.ts +4 -0
- package/interfaces/treeviewaction.interface.ngfactory.d.ts +1 -0
- package/package.json +2 -2
- package/public_api.d.ts +13 -6
- package/services/sac-configuration.service.d.ts +40 -0
- package/services/sac-icon.service.d.ts +49 -1
- package/services/sac-localisation.service.d.ts +10 -10
- package/services/sac-validationkey.service.d.ts +7 -7
- package/simpleangularcontrols-sac-common-10.0.0-rc.21.tgz +0 -0
- package/simpleangularcontrols-sac-common.d.ts +0 -6
- 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/mintextlength.validator.d.ts +2 -0
- package/validation/mintextlength.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 +22 -3
- 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/esm2015/validation/minlength.validator.js +0 -21
- package/simpleangularcontrols-sac-common-10.0.0-rc.2.tgz +0 -0
- package/validation/minlength.validator.d.ts +0 -2
- /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
- /package/{validation/minlength.validator.ngfactory.d.ts → controls/list/dropdownoptions.ngfactory.d.ts} +0 -0
|
@@ -1,12 +1,11 @@
|
|
|
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
|
+
import { CreateValidationError } from '../validation/validationerrorcreator';
|
|
5
6
|
import { SacBaseModelControl } from './basemodelcontrol';
|
|
6
|
-
|
|
7
|
-
*
|
|
8
|
-
*/
|
|
9
|
-
const moment = moment_['default'];
|
|
7
|
+
import { ChangeDetectorRef, Directive, ElementRef, Injector, Input, ViewChild, } from '@angular/core';
|
|
8
|
+
import * as moment_ from 'moment';
|
|
10
9
|
/**
|
|
11
10
|
* Base Klasse für Date/Time Controls
|
|
12
11
|
*/
|
|
@@ -19,22 +18,65 @@ export class SacBaseDateTimeControl extends SacBaseModelControl {
|
|
|
19
18
|
* @param injector Injector for injecting services
|
|
20
19
|
* @param elementRef reference to html element
|
|
21
20
|
*/
|
|
22
|
-
constructor(formlayout, injector, elementRef) {
|
|
21
|
+
constructor(formlayout, injector, elementRef, cdRef) {
|
|
23
22
|
super(formlayout, injector);
|
|
24
23
|
this.elementRef = elementRef;
|
|
24
|
+
this.cdRef = cdRef;
|
|
25
25
|
// #region Properties
|
|
26
|
+
/**
|
|
27
|
+
* Helper class to display tooltip on correct position
|
|
28
|
+
*/
|
|
29
|
+
this.popupHelper = new PopUpHelper();
|
|
26
30
|
/**
|
|
27
31
|
* das property enthielt das Value als string. Default ist ''
|
|
28
32
|
*/
|
|
29
33
|
this._valueAsString = '';
|
|
34
|
+
/**
|
|
35
|
+
* Property for enum in Angular HTML template
|
|
36
|
+
*/
|
|
37
|
+
this.TooltipPosition = TooltipPosition;
|
|
38
|
+
/**
|
|
39
|
+
* Definiert ob der Date Selector angezeigt wird
|
|
40
|
+
*/
|
|
41
|
+
this._showselector = false;
|
|
30
42
|
/**
|
|
31
43
|
* Definiert das Control als Required
|
|
32
44
|
*/
|
|
33
45
|
this.isrequired = false;
|
|
46
|
+
/**
|
|
47
|
+
* Moment JS Instance
|
|
48
|
+
*/
|
|
49
|
+
this.moment = moment_['default'];
|
|
50
|
+
/**
|
|
51
|
+
* Arrow Item of Picker Element. Required to set the position of arrow correctly
|
|
52
|
+
*/
|
|
53
|
+
this.pickerPosition = TooltipPosition;
|
|
34
54
|
/**
|
|
35
55
|
* TextBox Placeholder
|
|
36
56
|
*/
|
|
37
57
|
this.placeholder = null;
|
|
58
|
+
/**
|
|
59
|
+
* Position of the picker arrow at the left
|
|
60
|
+
*/
|
|
61
|
+
this.posArrowLeft = null;
|
|
62
|
+
/**
|
|
63
|
+
* Position of the picker arrow at the top
|
|
64
|
+
*/
|
|
65
|
+
this.posArrowTop = null;
|
|
66
|
+
/**
|
|
67
|
+
* Position of the picker at the left
|
|
68
|
+
*/
|
|
69
|
+
this.posPopupLeft = 0;
|
|
70
|
+
/**
|
|
71
|
+
* Position of the picker at the top
|
|
72
|
+
*/
|
|
73
|
+
this.posPopupTop = 0;
|
|
74
|
+
/**
|
|
75
|
+
* Position of the datetime picker. Values: left|top|right|bottom|auto
|
|
76
|
+
*
|
|
77
|
+
* Value 'auto' can be combined with another value.
|
|
78
|
+
*/
|
|
79
|
+
this.position = 'bottomend|topend';
|
|
38
80
|
/**
|
|
39
81
|
* Resource Key für Validation Message DateTimeFormat bei Control
|
|
40
82
|
*/
|
|
@@ -51,15 +93,56 @@ export class SacBaseDateTimeControl extends SacBaseModelControl {
|
|
|
51
93
|
* Resource Key für Validation Message Required in Validation Summary
|
|
52
94
|
*/
|
|
53
95
|
this.validationmessagerequiredsummary = this.validationKeyService.ValidationErrorSummaryRequired;
|
|
96
|
+
// #endregion Protected Methods
|
|
97
|
+
// #region Private Methods
|
|
98
|
+
/**
|
|
99
|
+
* method if content has changed and proportions need to be reset in the UI.
|
|
100
|
+
*/
|
|
101
|
+
this.onContentChange = () => {
|
|
102
|
+
// Do nothing if is not visible
|
|
103
|
+
if (!this._showselector) {
|
|
104
|
+
return;
|
|
105
|
+
}
|
|
106
|
+
setTimeout(() => {
|
|
107
|
+
this.getPositionLeft();
|
|
108
|
+
this.getPositionTop();
|
|
109
|
+
});
|
|
110
|
+
};
|
|
54
111
|
}
|
|
55
112
|
// #endregion Constructors
|
|
56
113
|
// #region Public Getters And Setters
|
|
114
|
+
/**
|
|
115
|
+
* Setter for the name of the container for the tooltip. Is required as the tooltip can be hidden via ngIf.
|
|
116
|
+
*/
|
|
117
|
+
set picker(picker) {
|
|
118
|
+
if (picker !== undefined) {
|
|
119
|
+
document.body.appendChild(picker.nativeElement);
|
|
120
|
+
}
|
|
121
|
+
this.pickercontainer = picker;
|
|
122
|
+
this.onContentChange();
|
|
123
|
+
this.cdRef.detectChanges();
|
|
124
|
+
}
|
|
125
|
+
get tooltop() {
|
|
126
|
+
return this.pickercontainer;
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* getter für valuestring
|
|
130
|
+
*/
|
|
131
|
+
get valuestring() {
|
|
132
|
+
if (this.value === null) {
|
|
133
|
+
return this._valueAsString;
|
|
134
|
+
}
|
|
135
|
+
else {
|
|
136
|
+
const date = this.moment.utc(this.value);
|
|
137
|
+
return date.local().format(this.GetDateTimeFormatString());
|
|
138
|
+
}
|
|
139
|
+
}
|
|
57
140
|
/**
|
|
58
141
|
* Das Input bekommt das value von typ string
|
|
59
142
|
*/
|
|
60
143
|
set valuestring(v) {
|
|
61
144
|
this._valueAsString = v;
|
|
62
|
-
let date = moment(v, [this.GetDateTimeFormatString()], true);
|
|
145
|
+
let date = this.moment(v, [this.GetDateTimeFormatString()], true);
|
|
63
146
|
date = this.ModifyParsedDateTimeValue(date).utc();
|
|
64
147
|
if (date.isValid()) {
|
|
65
148
|
this.value = date.toDate();
|
|
@@ -69,19 +152,11 @@ export class SacBaseDateTimeControl extends SacBaseModelControl {
|
|
|
69
152
|
}
|
|
70
153
|
}
|
|
71
154
|
/**
|
|
72
|
-
*
|
|
155
|
+
* Returns the position of the tooltip
|
|
73
156
|
*/
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
return this._valueAsString;
|
|
77
|
-
}
|
|
78
|
-
else {
|
|
79
|
-
const date = moment.utc(this.value);
|
|
80
|
-
return date.local().format(this.GetDateTimeFormatString());
|
|
81
|
-
}
|
|
157
|
+
GetPickerPosition() {
|
|
158
|
+
return this.popupHelper.getDisplayPosition(this.pickerbutton, this.pickercontainer, this.getArrowWidth(), this.getArrowHeight(), this.position, false);
|
|
82
159
|
}
|
|
83
|
-
// #endregion Public Getters And Setters
|
|
84
|
-
// #region Public Methods
|
|
85
160
|
/**
|
|
86
161
|
* JSON Date String in ein UTC DateTime Object konvertieren, welches vom Control verwendete werden kann
|
|
87
162
|
*/
|
|
@@ -93,14 +168,37 @@ export class SacBaseDateTimeControl extends SacBaseModelControl {
|
|
|
93
168
|
const hours = date.getUTCHours();
|
|
94
169
|
const minutes = date.getUTCMinutes();
|
|
95
170
|
const seconds = date.getUTCSeconds();
|
|
96
|
-
return moment(Date.UTC(year, month, day, hours, minutes, seconds));
|
|
171
|
+
return this.moment(Date.UTC(year, month, day, hours, minutes, seconds));
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* Calculates the height of the tooltip
|
|
175
|
+
*/
|
|
176
|
+
getPickerHeight() {
|
|
177
|
+
return this.popupHelper.getPopupHeight(this.pickercontainer);
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
180
|
+
* Calculates the width of the picker
|
|
181
|
+
*/
|
|
182
|
+
getPickerWidth() {
|
|
183
|
+
return this.popupHelper.getPopupWidth(this.pickercontainer);
|
|
184
|
+
}
|
|
185
|
+
ngDoCheck() {
|
|
186
|
+
// this.onContentChange();
|
|
187
|
+
}
|
|
188
|
+
ngOnDestroy() {
|
|
189
|
+
// Unregister Event Listener
|
|
190
|
+
window.removeEventListener('scroll', this.onContentChange, true);
|
|
191
|
+
window.removeEventListener('resize', this.onContentChange, true);
|
|
97
192
|
}
|
|
98
193
|
/**
|
|
99
194
|
* Init Event
|
|
100
195
|
*/
|
|
101
|
-
|
|
102
|
-
super.
|
|
103
|
-
this.
|
|
196
|
+
ngOnInit() {
|
|
197
|
+
super.ngOnInit();
|
|
198
|
+
this.setDateTimeFormat();
|
|
199
|
+
// Register Event Listener
|
|
200
|
+
window.addEventListener('scroll', this.onContentChange, true);
|
|
201
|
+
window.addEventListener('resize', this.onContentChange, true);
|
|
104
202
|
}
|
|
105
203
|
/**
|
|
106
204
|
* setzt das value von typ string zu property valuestring
|
|
@@ -113,6 +211,12 @@ export class SacBaseDateTimeControl extends SacBaseModelControl {
|
|
|
113
211
|
*/
|
|
114
212
|
validateData(c) {
|
|
115
213
|
let error = null;
|
|
214
|
+
if (this.valuestring !== null && this.valuestring.indexOf('_') >= 0) {
|
|
215
|
+
error = CreateValidationError('invalidtype', this.validationmessagedatetimeformat, this.validationmessagedatetimeformatsummary);
|
|
216
|
+
if (error) {
|
|
217
|
+
return error;
|
|
218
|
+
}
|
|
219
|
+
}
|
|
116
220
|
error = Validation.isValidDate(this.validationmessagedatetimeformat, this.validationmessagedatetimeformatsummary)(c);
|
|
117
221
|
if (this.isrequired) {
|
|
118
222
|
error = Validation.required(this.validationmessagerequired, this.validationmessagerequiredsummary)(c);
|
|
@@ -134,13 +238,59 @@ export class SacBaseDateTimeControl extends SacBaseModelControl {
|
|
|
134
238
|
}
|
|
135
239
|
super.writeValue(this._value);
|
|
136
240
|
}
|
|
137
|
-
// #endregion Public
|
|
138
|
-
// #region
|
|
139
|
-
|
|
241
|
+
// #endregion Public Methods
|
|
242
|
+
// #region Protected Methods
|
|
243
|
+
getArrowHeight() {
|
|
244
|
+
return this.pickerarrow ? this.pickerarrow.nativeElement.offsetHeight : 0;
|
|
245
|
+
}
|
|
246
|
+
getArrowWidth() {
|
|
247
|
+
return this.pickerarrow ? this.pickerarrow.nativeElement.offsetWidth : 0;
|
|
248
|
+
}
|
|
249
|
+
/**
|
|
250
|
+
* Calculates the position of the tooltip from links
|
|
251
|
+
*/
|
|
252
|
+
getPositionLeft() {
|
|
253
|
+
const value = this.popupHelper.getPositionLeft(this.pickerbutton, this.pickercontainer, this.elementRef, this.getArrowWidth(), this.getArrowHeight(), this.position, false);
|
|
254
|
+
this.posPopupLeft = value;
|
|
255
|
+
switch (this.GetPickerPosition()) {
|
|
256
|
+
case TooltipPosition.top:
|
|
257
|
+
case TooltipPosition.bottom:
|
|
258
|
+
this.posArrowLeft = this.getPickerWidth() / 2 - -this.getArrowWidth();
|
|
259
|
+
break;
|
|
260
|
+
case TooltipPosition.topend:
|
|
261
|
+
case TooltipPosition.bottomend:
|
|
262
|
+
this.posArrowLeft =
|
|
263
|
+
this.getPickerWidth() -
|
|
264
|
+
this.getArrowWidth() / 2 -
|
|
265
|
+
this.popupHelper.getContainerWidth(this.pickerbutton, false) / 2;
|
|
266
|
+
break;
|
|
267
|
+
default:
|
|
268
|
+
this.posArrowLeft = null;
|
|
269
|
+
break;
|
|
270
|
+
}
|
|
271
|
+
return value;
|
|
272
|
+
}
|
|
273
|
+
/**
|
|
274
|
+
* Calculates the position of the tooltip from the top
|
|
275
|
+
*/
|
|
276
|
+
getPositionTop() {
|
|
277
|
+
const value = this.popupHelper.getPositionTop(this.pickerbutton, this.pickercontainer, this.elementRef, this.getArrowWidth(), this.getArrowHeight(), this.position, false);
|
|
278
|
+
this.posPopupTop = value;
|
|
279
|
+
switch (this.GetPickerPosition()) {
|
|
280
|
+
case TooltipPosition.left:
|
|
281
|
+
case TooltipPosition.right:
|
|
282
|
+
this.posArrowTop = this.getPickerHeight() / 2 - 6.5;
|
|
283
|
+
break;
|
|
284
|
+
default:
|
|
285
|
+
this.posArrowTop = null;
|
|
286
|
+
break;
|
|
287
|
+
}
|
|
288
|
+
return value;
|
|
289
|
+
}
|
|
290
|
+
setDateTimeFormat() {
|
|
140
291
|
// HACK: Add addition property to FormControl. Can be fixed if solution for ticket: https://github.com/angular/angular/issues/19686
|
|
141
292
|
if (this.ngControl) {
|
|
142
|
-
this.ngControl.datetimeformatstring =
|
|
143
|
-
this.GetDateTimeFormatString();
|
|
293
|
+
this.ngControl.datetimeformatstring = this.GetDateTimeFormatString();
|
|
144
294
|
}
|
|
145
295
|
}
|
|
146
296
|
}
|
|
@@ -150,15 +300,20 @@ SacBaseDateTimeControl.decorators = [
|
|
|
150
300
|
SacBaseDateTimeControl.ctorParameters = () => [
|
|
151
301
|
{ type: SacFormLayoutCommon },
|
|
152
302
|
{ type: Injector },
|
|
153
|
-
{ type: ElementRef }
|
|
303
|
+
{ type: ElementRef },
|
|
304
|
+
{ type: ChangeDetectorRef }
|
|
154
305
|
];
|
|
155
306
|
SacBaseDateTimeControl.propDecorators = {
|
|
156
307
|
isrequired: [{ type: Input }],
|
|
308
|
+
pickerarrow: [{ type: ViewChild, args: ['pickerarrow', { static: false },] }],
|
|
309
|
+
pickerbutton: [{ type: ViewChild, args: ['pickerbutton', { static: true },] }],
|
|
157
310
|
placeholder: [{ type: Input }],
|
|
311
|
+
position: [{ type: Input }],
|
|
158
312
|
validationmessagedatetimeformat: [{ type: Input }],
|
|
159
313
|
validationmessagedatetimeformatsummary: [{ type: Input }],
|
|
160
314
|
validationmessagerequired: [{ type: Input }],
|
|
161
315
|
validationmessagerequiredsummary: [{ type: Input }],
|
|
316
|
+
picker: [{ type: ViewChild, args: ['picker', { static: false },] }],
|
|
162
317
|
valuestring: [{ type: Input }]
|
|
163
318
|
};
|
|
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) {\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"]}
|
|
319
|
+
//# 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 { 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 { CreateValidationError } from '../validation/validationerrorcreator';\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    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        if (this.valuestring !== null && this.valuestring.indexOf('_') >= 0) {\r\n            error = CreateValidationError(\r\n                'invalidtype',\r\n                this.validationmessagedatetimeformat,\r\n                this.validationmessagedatetimeformatsummary\r\n            );\r\n\r\n            if (error) {\r\n                return error;\r\n            }\r\n        }\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"]}
|
|
@@ -27,10 +27,6 @@ export class SacInputBase extends SacBaseModelControl {
|
|
|
27
27
|
* Macht das Input readonly
|
|
28
28
|
*/
|
|
29
29
|
this.readonly = false;
|
|
30
|
-
/**
|
|
31
|
-
* Text welcher als Tooltip angezeigt wird.
|
|
32
|
-
*/
|
|
33
|
-
this.tooltiptext = '';
|
|
34
30
|
// #endregion Protected Methods
|
|
35
31
|
}
|
|
36
32
|
// #endregion Properties
|
|
@@ -72,7 +68,6 @@ SacInputBase.propDecorators = {
|
|
|
72
68
|
isrequired: [{ type: Input }],
|
|
73
69
|
placeholder: [{ type: Input }],
|
|
74
70
|
readonly: [{ type: Input }],
|
|
75
|
-
regexvalidation: [{ type: Input }]
|
|
76
|
-
tooltiptext: [{ type: Input }]
|
|
71
|
+
regexvalidation: [{ type: Input }]
|
|
77
72
|
};
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZWlucHV0Y29udHJvbC5qcyIsInNvdXJjZVJvb3QiOiJDOi9Qcm9qZWt0ZS9zaW1wbGVhbmd1bGFyY29udHJvbHMtbmcxMC9jaC5qbmV0d29yay5zYWMtY29udHJvbHMvcHJvamVjdHMvc2FjLWNvbW1vbi9zcmMvIiwic291cmNlcyI6WyJjb21tb24vYmFzZWlucHV0Y29udHJvbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUV6RDs7R0FFRztBQUVILE1BQU0sT0FBZ0IsWUFBb0IsU0FBUSxtQkFBMEI7SUFENUU7UUFFRSxxQkFBcUI7O1FBRXJCOztXQUVHO1FBQ2EsaUJBQVksR0FBVyxFQUFFLENBQUM7UUFDMUM7O1dBRUc7UUFDYSx3QkFBbUIsR0FBWSxLQUFLLENBQUM7UUFDckQ7O1dBRUc7UUFDYSxlQUFVLEdBQVksS0FBSyxDQUFDO1FBQzVDOztXQUVHO1FBQ2EsZ0JBQVcsR0FBVyxJQUFJLENBQUM7UUFDM0M7O1dBRUc7UUFDYSxhQUFRLEdBQVksS0FBSyxDQUFDO1FBNEMxQywrQkFBK0I7SUFDakMsQ0FBQztJQXZDQyx3QkFBd0I7SUFFeEIseUJBQXlCO0lBRXpCOztPQUVHO0lBQ0ksVUFBVSxDQUFDLEtBQW9CO1FBQ3BDLHNDQUFzQztRQUN0QyxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtZQUNsQyxPQUFPLElBQUksQ0FBQztTQUNiO1FBRUQsaUJBQWlCO1FBQ2pCLE1BQU0sU0FBUyxHQUFHLEtBQUssQ0FBQyxHQUFHLENBQUM7UUFDNUIsbUVBQW1FO1FBQ25FLElBQUksSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQzVDLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztTQUN4QjtRQUVELE1BQU0sWUFBWSxHQUFHLEtBQUssQ0FBQyxNQUEwQixDQUFDO1FBRXRELElBQUksQ0FBQyxJQUFJLENBQUMsb0JBQW9CLENBQUMsWUFBWSxDQUFDLGNBQWMsRUFBRSxTQUFTLENBQUMsRUFBRTtZQUN0RSxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7U0FDeEI7SUFDSCxDQUFDO0lBRUQsNEJBQTRCO0lBRTVCLDRCQUE0QjtJQUU1Qjs7T0FFRztJQUNPLG9CQUFvQixDQUFDLFFBQWdCLEVBQUUsU0FBaUI7UUFDaEUsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDOzs7WUFqRUYsU0FBUzs7OzJCQU9QLEtBQUs7a0NBSUwsS0FBSzt5QkFJTCxLQUFLOzBCQUlMLEtBQUs7dUJBSUwsS0FBSzs4QkFJTCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBTYWNCYXNlTW9kZWxDb250cm9sIH0gZnJvbSAnLi9iYXNlbW9kZWxjb250cm9sJztcclxuXHJcbi8qKlxyXG4gKiBBYnN0cmFjdCBLbGFzc2UgZsO8ciBTYWNJbnB1dEJhc2UuIEV4dGVuZGVzIFNhY0Jhc2VNb2RlbENvbnRyb2xcclxuICovXHJcbkBEaXJlY3RpdmUoKVxyXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgU2FjSW5wdXRCYXNlPFZBTFVFPiBleHRlbmRzIFNhY0Jhc2VNb2RlbENvbnRyb2w8VkFMVUU+IHtcclxuICAvLyAjcmVnaW9uIFByb3BlcnRpZXNcclxuXHJcbiAgLyoqXHJcbiAgICogRXJsYXVidGUgWmVpY2hlbiBiZWkgZGVyIEVpbmdhYmVcclxuICAgKi9cclxuICBASW5wdXQoKSBwdWJsaWMgYWxsb3dlZGNoYXJzOiBzdHJpbmcgPSAnJztcclxuICAvKipcclxuICAgKiBBdXRvZmlsbCBha3RpdmllcmVuIG9kZXIgZGVha3RpdmllcmVuXHJcbiAgICovXHJcbiAgQElucHV0KCkgcHVibGljIGRpc2FibGVhdXRvY29tcGxldGU6IGJvb2xlYW4gPSBmYWxzZTtcclxuICAvKipcclxuICAgKiBEZWZpbmllcnQgZGFzIENvbnRyb2wgYWxzIFJlcXVpcmVkXHJcbiAgICovXHJcbiAgQElucHV0KCkgcHVibGljIGlzcmVxdWlyZWQ6IGJvb2xlYW4gPSBmYWxzZTtcclxuICAvKipcclxuICAgKiBUZXh0Qm94IFBsYWNlaG9sZGVyXHJcbiAgICovXHJcbiAgQElucHV0KCkgcHVibGljIHBsYWNlaG9sZGVyOiBzdHJpbmcgPSBudWxsO1xyXG4gIC8qKlxyXG4gICAqIE1hY2h0IGRhcyBJbnB1dCByZWFkb25seVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHB1YmxpYyByZWFkb25seTogYm9vbGVhbiA9IGZhbHNlO1xyXG4gIC8qKlxyXG4gICAqIERlZmluaWVydCBkYXMgRmVsZCBhbHMgdmFsaWQvaW52YWxpZCB2b24gZWluZ2VnZWJlbmVuIHJlZ2V4LXBhdHRlcm5cclxuICAgKi9cclxuICBASW5wdXQoKSBwdWJsaWMgcmVnZXh2YWxpZGF0aW9uOiBzdHJpbmc7XHJcblxyXG4gIC8vICNlbmRyZWdpb24gUHJvcGVydGllc1xyXG5cclxuICAvLyAjcmVnaW9uIFB1YmxpYyBNZXRob2RzXHJcblxyXG4gIC8qKlxyXG4gICAqIE1ldGhvZGUgdmFsaWRpZXJ0IElucHV0IHdlbm4gS2V5UHJlc3MtRXZlbnQgcGFzc2llcnRcclxuICAgKi9cclxuICBwdWJsaWMgb25LZXlQcmVzcyhldmVudDogS2V5Ym9hcmRFdmVudCk6IEJvb2xlYW4ge1xyXG4gICAgLy8gQ2FuY2VsIHdlbm4gX2FsbG93ZWRDaGFycyBsZWVyIGlzdC5cclxuICAgIGlmICh0aGlzLmFsbG93ZWRjaGFycy5sZW5ndGggPT09IDApIHtcclxuICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICB9XHJcblxyXG4gICAgLy8gVmFsaWRhdGUgSW5wdXRcclxuICAgIGNvbnN0IGNoYXJhY3RlciA9IGV2ZW50LmtleTtcclxuICAgIC8vIFplaWNoZW4gaW4gQWxsb3dlZCBDaGFycyBuaWNodCBnZWZ1bmRlbiwgRXZlbnQgbmljaHQgd2VpdGVyZ2ViZW5cclxuICAgIGlmICh0aGlzLmFsbG93ZWRjaGFycy5pbmRleE9mKGNoYXJhY3RlcikgPCAwKSB7XHJcbiAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XHJcbiAgICB9XHJcblxyXG4gICAgY29uc3QgaW5wdXRDb250cm9sID0gZXZlbnQudGFyZ2V0IGFzIEhUTUxJbnB1dEVsZW1lbnQ7XHJcblxyXG4gICAgaWYgKCF0aGlzLk9uS2V5UHJlc3NWYWxpZGF0aW9uKGlucHV0Q29udHJvbC5zZWxlY3Rpb25TdGFydCwgY2hhcmFjdGVyKSkge1xyXG4gICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgLy8gI2VuZHJlZ2lvbiBQdWJsaWMgTWV0aG9kc1xyXG5cclxuICAvLyAjcmVnaW9uIFByb3RlY3RlZCBNZXRob2RzXHJcblxyXG4gIC8qKlxyXG4gICAqIE1ldGhvZGUgdmFsaWRpZXJ0IHdlbm4gZWluIERyw7xjay1FdmVudCBwYXNzaWVydFxyXG4gICAqL1xyXG4gIHByb3RlY3RlZCBPbktleVByZXNzVmFsaWRhdGlvbihwb3NpdGlvbjogbnVtYmVyLCBjaGFyYWN0ZXI6IHN0cmluZyk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRydWU7XHJcbiAgfVxyXG5cclxuICAvLyAjZW5kcmVnaW9uIFByb3RlY3RlZCBNZXRob2RzXHJcbn1cclxuIl19
|