@simpleangularcontrols/sac-common 16.0.0-rc.1 → 16.0.0-rc.3
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/README.md +8 -16
- package/common/basedatetimecontrol.d.ts +33 -33
- package/common/basedatetimecontrol.d.ts.map +1 -1
- package/common/baseinputcontrol.d.ts +9 -9
- package/common/baseinputcontrol.d.ts.map +1 -1
- package/common/basemodelcontrol.d.ts +117 -89
- package/common/basemodelcontrol.d.ts.map +1 -1
- package/common/baseuploadcontrol.d.ts +140 -140
- package/common/baseuploadcontrol.d.ts.map +1 -1
- package/controls/checkbox/checkbox.d.ts +7 -3
- package/controls/checkbox/checkbox.d.ts.map +1 -1
- package/controls/checkbox/radiobuttons.d.ts +5 -4
- package/controls/checkbox/radiobuttons.d.ts.map +1 -1
- package/controls/contextmenu/contextmenu.d.ts +42 -42
- package/controls/contextmenu/contextmenu.d.ts.map +1 -1
- package/controls/contextmenu/contextmenuanchor.d.ts +2 -2
- package/controls/contextmenu/contextmenuanchor.d.ts.map +1 -1
- package/controls/contextmenu/contextmenucontainer.d.ts +2 -2
- package/controls/contextmenu/contextmenucontainer.d.ts.map +1 -1
- package/controls/datetime/date.d.ts +7 -7
- package/controls/datetime/date.d.ts.map +1 -1
- package/controls/datetime/datetime.d.ts +7 -7
- package/controls/datetime/datetime.d.ts.map +1 -1
- package/controls/datetime/time.d.ts +7 -7
- package/controls/datetime/time.d.ts.map +1 -1
- package/controls/form/form.d.ts +7 -43
- package/controls/form/form.d.ts.map +1 -1
- package/controls/input/inputdecimal.d.ts +21 -21
- package/controls/input/inputdecimal.d.ts.map +1 -1
- package/controls/layout/formlayout.d.ts +45 -0
- package/controls/layout/formlayout.d.ts.map +1 -0
- package/controls/list/dropdown.d.ts +45 -45
- package/controls/list/dropdown.d.ts.map +1 -1
- package/controls/multilanguage/multilanguageinput.d.ts +5 -4
- package/controls/multilanguage/multilanguageinput.d.ts.map +1 -1
- package/controls/multilanguage/multilanguageinputarea.d.ts +5 -4
- package/controls/multilanguage/multilanguageinputarea.d.ts.map +1 -1
- package/controls/tinymce/tinymce.d.ts +63 -63
- package/controls/tinymce/tinymce.d.ts.map +1 -1
- package/esm2022/common/basedatetimecontrol.mjs +75 -81
- package/esm2022/common/baseinputcontrol.mjs +20 -20
- package/esm2022/common/basemodelcontrol.mjs +280 -202
- package/esm2022/common/baseuploadcontrol.mjs +225 -224
- package/esm2022/controls/checkbox/checkbox.mjs +11 -5
- package/esm2022/controls/checkbox/radiobuttons.mjs +13 -12
- package/esm2022/controls/contextmenu/contextmenu.mjs +85 -75
- package/esm2022/controls/contextmenu/contextmenuanchor.mjs +6 -4
- package/esm2022/controls/contextmenu/contextmenucontainer.mjs +6 -4
- package/esm2022/controls/datetime/date.mjs +12 -12
- package/esm2022/controls/datetime/datetime.mjs +15 -15
- package/esm2022/controls/datetime/time.mjs +15 -15
- package/esm2022/controls/form/form.mjs +26 -80
- package/esm2022/controls/input/inputdecimal.mjs +58 -53
- package/esm2022/controls/layout/formlayout.mjs +73 -0
- package/esm2022/controls/list/dropdown.mjs +110 -91
- package/esm2022/controls/multilanguage/multilanguageinput.mjs +10 -9
- package/esm2022/controls/multilanguage/multilanguageinputarea.mjs +10 -9
- package/esm2022/controls/tinymce/tinymce.mjs +102 -95
- package/esm2022/interfaces/ISacLabelSizes.mjs +2 -0
- package/esm2022/public_api.mjs +20 -18
- package/fesm2022/simpleangularcontrols-sac-common.mjs +1958 -1814
- package/fesm2022/simpleangularcontrols-sac-common.mjs.map +1 -1
- package/interfaces/ISacLabelSizes.d.ts +27 -0
- package/interfaces/ISacLabelSizes.d.ts.map +1 -0
- package/package.json +1 -1
- package/public_api.d.ts +19 -17
- package/public_api.d.ts.map +1 -1
- package/simpleangularcontrols-sac-common-16.0.0-rc.3.tgz +0 -0
- package/simpleangularcontrols-sac-common-13.0.0-rc.1.tgz +0 -0
- package/simpleangularcontrols-sac-common-16.0.0-rc.1.tgz +0 -0
|
@@ -1,92 +1,93 @@
|
|
|
1
1
|
import { Directive, Host, Input } from '@angular/core';
|
|
2
2
|
import { FormControlName, FormGroupDirective, NgControl, } from '@angular/forms';
|
|
3
3
|
import { Observable } from 'rxjs';
|
|
4
|
-
import {
|
|
4
|
+
import { SACLOCALISATION_SERVICE, SacDefaultLocalisationService, } from '../services/sac-localisation.service';
|
|
5
5
|
import { convertToBoolean } from '../utilities/convertion';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "../controls/
|
|
7
|
+
import * as i1 from "../controls/layout/formlayout";
|
|
8
8
|
/**
|
|
9
9
|
* Abstract Klasse für SacBaseModelControl. Implements ControlValueAccessor, Validator, OnInit
|
|
10
10
|
*/
|
|
11
11
|
class SacBaseModelControl {
|
|
12
|
+
// #endregion Properties
|
|
13
|
+
// #region Constructors
|
|
12
14
|
/**
|
|
13
|
-
*
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
this._label = v;
|
|
17
|
-
this.UpdateLabelToControl();
|
|
18
|
-
}
|
|
19
|
-
/**
|
|
20
|
-
* Definiert den Label Text
|
|
21
|
-
*/
|
|
22
|
-
get label() {
|
|
23
|
-
return this._label;
|
|
24
|
-
}
|
|
25
|
-
/**
|
|
26
|
-
* Definiert ob das Control disabled ist
|
|
27
|
-
*/
|
|
28
|
-
get isdisabled() {
|
|
29
|
-
return this._disabledForm || this.disabled;
|
|
30
|
-
}
|
|
31
|
-
// #endregion
|
|
32
|
-
// #region Constructor
|
|
33
|
-
/**
|
|
34
|
-
* Konstruktor
|
|
35
|
-
* Inject des Formulars
|
|
36
|
-
* @parent SacFormCommon
|
|
37
|
-
* @injector Injector
|
|
15
|
+
* Constructor
|
|
16
|
+
* @param formlayout SacFormLayoutCommon to define scoped layout settings
|
|
17
|
+
* @param injector Injector for injecting services
|
|
38
18
|
*/
|
|
39
|
-
constructor(
|
|
19
|
+
constructor(formlayout, injector) {
|
|
40
20
|
this.injector = injector;
|
|
21
|
+
// #region Properties
|
|
22
|
+
/**
|
|
23
|
+
* Inline Errors für das Control
|
|
24
|
+
*/
|
|
25
|
+
this._inlineerrorenabled = null;
|
|
26
|
+
this._label = '';
|
|
27
|
+
/**
|
|
28
|
+
* Boolean Property dirty; default Wert - false
|
|
29
|
+
*/
|
|
30
|
+
this._dirty = false;
|
|
41
31
|
/**
|
|
42
32
|
* SacModel Form ist disabled
|
|
43
33
|
*/
|
|
44
34
|
this._disabledForm = false;
|
|
45
|
-
this._label = '';
|
|
46
|
-
// #endregion
|
|
47
|
-
// #region Properties
|
|
48
35
|
/**
|
|
49
|
-
*
|
|
36
|
+
* Boolean Property touched; default Wert - false
|
|
50
37
|
*/
|
|
51
|
-
this.
|
|
38
|
+
this._touched = false;
|
|
52
39
|
/**
|
|
53
|
-
*
|
|
40
|
+
* Interne Variable, die den Wert des Controls hält
|
|
54
41
|
*/
|
|
55
|
-
this.
|
|
42
|
+
this._value = null;
|
|
56
43
|
/**
|
|
57
|
-
*
|
|
44
|
+
* Form layout instance if exists
|
|
58
45
|
*/
|
|
59
|
-
this.
|
|
46
|
+
this.formlayout = null;
|
|
60
47
|
/**
|
|
61
48
|
* Deaktiviert das Input Control
|
|
62
49
|
*/
|
|
63
50
|
this.disabled = false;
|
|
64
51
|
/**
|
|
65
|
-
*
|
|
52
|
+
* Deaktiviert das Label im Template
|
|
53
|
+
*/
|
|
54
|
+
this.disablelabel = false;
|
|
55
|
+
/**
|
|
56
|
+
* defines that error messages are displayed under the controls
|
|
66
57
|
*/
|
|
67
|
-
this.
|
|
58
|
+
this.inlineError = true;
|
|
68
59
|
/**
|
|
69
|
-
*
|
|
60
|
+
* defines that the labels are displayed as adaptive labels
|
|
70
61
|
*/
|
|
71
|
-
this.
|
|
62
|
+
this.isAdaptiveLabel = false;
|
|
72
63
|
/**
|
|
73
|
-
*
|
|
64
|
+
* default labe size for large devices
|
|
74
65
|
*/
|
|
75
|
-
this.
|
|
66
|
+
this.labelSizeLg = null;
|
|
76
67
|
/**
|
|
77
|
-
*
|
|
68
|
+
* default label size for medium devices
|
|
78
69
|
*/
|
|
79
|
-
this.
|
|
70
|
+
this.labelSizeMd = null;
|
|
80
71
|
/**
|
|
81
|
-
*
|
|
72
|
+
* default label size for small devices
|
|
82
73
|
*/
|
|
83
|
-
this.
|
|
74
|
+
this.labelSizeSm = null;
|
|
84
75
|
/**
|
|
85
|
-
*
|
|
76
|
+
* default label size for extra large devices
|
|
86
77
|
*/
|
|
87
|
-
this.
|
|
88
|
-
|
|
89
|
-
|
|
78
|
+
this.labelSizeXl = null;
|
|
79
|
+
/**
|
|
80
|
+
* default label column size
|
|
81
|
+
*/
|
|
82
|
+
this.labelSizeXs = null;
|
|
83
|
+
/**
|
|
84
|
+
* default label size for extra extra large devices
|
|
85
|
+
*/
|
|
86
|
+
this.labelSizeXxl = null;
|
|
87
|
+
/**
|
|
88
|
+
* Name des Controls
|
|
89
|
+
*/
|
|
90
|
+
this.name = '';
|
|
90
91
|
/**
|
|
91
92
|
* Leere Implementation von "propagateChange". Muss gemacht werden, damit kein Fehler entsteht
|
|
92
93
|
*/
|
|
@@ -95,76 +96,29 @@ class SacBaseModelControl {
|
|
|
95
96
|
* Leere Implementation von "propagateTouch". Muss gemacht werden, damit kein Fehler entsteht
|
|
96
97
|
*/
|
|
97
98
|
this.propagateTouch = () => { };
|
|
98
|
-
this.
|
|
99
|
+
this.formlayout = formlayout;
|
|
99
100
|
this.lngResourceService = injector.get(SACLOCALISATION_SERVICE, new SacDefaultLocalisationService());
|
|
100
101
|
}
|
|
101
|
-
// #endregion
|
|
102
|
-
// #region
|
|
102
|
+
// #endregion Constructors
|
|
103
|
+
// #region Public Getters And Setters
|
|
103
104
|
/**
|
|
104
|
-
*
|
|
105
|
+
* Aktiviert oder Deaktiviert die Inline Errors für das Control
|
|
105
106
|
*/
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
if (formControl instanceof FormControlName) {
|
|
110
|
-
const form = this.injector.get(FormGroupDirective, null);
|
|
111
|
-
this.ngControl = form.getControl(formControl);
|
|
107
|
+
set inlineerrorenabled(value) {
|
|
108
|
+
if (value === null || value === undefined) {
|
|
109
|
+
this._inlineerrorenabled = null;
|
|
112
110
|
}
|
|
113
111
|
else {
|
|
114
|
-
this.
|
|
115
|
-
}
|
|
116
|
-
this.UpdateLabelToControl();
|
|
117
|
-
/**
|
|
118
|
-
* Label Size von Formular lesen
|
|
119
|
-
*/
|
|
120
|
-
if (this.labelsize === undefined) {
|
|
121
|
-
if (this.parent?.labelsize !== undefined) {
|
|
122
|
-
this.labelsize = this.parent.labelsize;
|
|
123
|
-
}
|
|
124
|
-
else {
|
|
125
|
-
this.labelsize = 4;
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
/**
|
|
129
|
-
* Adaptive Label from Form
|
|
130
|
-
*/
|
|
131
|
-
if (this.isadaptivelabel === undefined) {
|
|
132
|
-
if (this.parent?.isadaptivelabel !== undefined) {
|
|
133
|
-
this.isadaptivelabel = this.parent.isadaptivelabel;
|
|
134
|
-
}
|
|
135
|
-
else {
|
|
136
|
-
this.isadaptivelabel = false;
|
|
137
|
-
}
|
|
112
|
+
this._inlineerrorenabled = convertToBoolean(value);
|
|
138
113
|
}
|
|
139
|
-
this.OnClassInit();
|
|
140
|
-
}
|
|
141
|
-
/**
|
|
142
|
-
* Methode, damit andere Controls änderungen im Control mitbekommen können
|
|
143
|
-
* Zur Änderungsinfo die Methode propagateChange aufrufen.
|
|
144
|
-
*/
|
|
145
|
-
registerOnChange(fn) {
|
|
146
|
-
this.propagateChange = (obj) => fn(obj);
|
|
147
|
-
}
|
|
148
|
-
/**
|
|
149
|
-
* Methode, damit andere Controls änderungen mitbekommen, wenn das Control aktiviert (Focus) wird.
|
|
150
|
-
*/
|
|
151
|
-
registerOnTouched(fn) {
|
|
152
|
-
this.propagateTouch = (obj) => fn(obj);
|
|
153
|
-
}
|
|
154
|
-
/**
|
|
155
|
-
* Methode zum schreiben von Werten aus dem Model in das Control
|
|
156
|
-
*/
|
|
157
|
-
writeValue(value) {
|
|
158
|
-
this._value = value;
|
|
159
114
|
}
|
|
160
115
|
/**
|
|
161
|
-
*
|
|
116
|
+
* Definiert den Label Text
|
|
162
117
|
*/
|
|
163
|
-
|
|
164
|
-
this.
|
|
118
|
+
set label(v) {
|
|
119
|
+
this._label = v;
|
|
120
|
+
this.UpdateLabelToControl();
|
|
165
121
|
}
|
|
166
|
-
// #endregion
|
|
167
|
-
// #region Control Value
|
|
168
122
|
/**
|
|
169
123
|
* Set Methode für NgModel Binding in Html Markup
|
|
170
124
|
* Input wird benötigt, damit der Wert auch über das Markup gesetzt werden kann.
|
|
@@ -177,74 +131,60 @@ class SacBaseModelControl {
|
|
|
177
131
|
this.propagateChange(this._value);
|
|
178
132
|
}
|
|
179
133
|
/**
|
|
180
|
-
*
|
|
134
|
+
* Methode ergibt Boolean Wert für dirty
|
|
181
135
|
*/
|
|
182
|
-
get
|
|
183
|
-
|
|
136
|
+
get dirty() {
|
|
137
|
+
if (this.ngControl !== null) {
|
|
138
|
+
this._dirty = this.ngControl.dirty;
|
|
139
|
+
}
|
|
140
|
+
return this._dirty;
|
|
184
141
|
}
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
*/
|
|
188
|
-
setValue(v) {
|
|
189
|
-
this.value = v;
|
|
142
|
+
get inlineerrorenabled() {
|
|
143
|
+
return this._inlineerrorenabled;
|
|
190
144
|
}
|
|
191
|
-
// #endregion
|
|
192
|
-
// #region Internal Properties
|
|
193
145
|
/**
|
|
194
|
-
*
|
|
146
|
+
* Methode ergibt boolean Wert wenn Form invalid oder nicht invalid ist
|
|
195
147
|
*/
|
|
196
|
-
get
|
|
197
|
-
return
|
|
148
|
+
get invalid() {
|
|
149
|
+
return (this.ngControl !== undefined &&
|
|
150
|
+
this.ngControl !== null &&
|
|
151
|
+
this.ngControl.invalid);
|
|
198
152
|
}
|
|
199
|
-
// #endregion
|
|
200
|
-
// #region Protected Helper Methods
|
|
201
|
-
/**
|
|
202
|
-
* Method can be used to Set Properties at Class Init
|
|
203
|
-
*/
|
|
204
|
-
OnClassInit() { }
|
|
205
153
|
/**
|
|
206
|
-
*
|
|
154
|
+
* Definiert ob das Control disabled ist
|
|
207
155
|
*/
|
|
208
|
-
|
|
209
|
-
return
|
|
156
|
+
get isdisabled() {
|
|
157
|
+
return this._disabledForm || this.disabled;
|
|
210
158
|
}
|
|
211
159
|
/**
|
|
212
|
-
*
|
|
213
|
-
* @param value Wert welcher in den korrekten Typ konvertiert werden soll
|
|
214
|
-
* @returns Wert im korrekten Typ
|
|
160
|
+
* Returns whether the inline error messages are active for this control.
|
|
215
161
|
*/
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
// HACK: Add addition property to FormControl. Can be fixed if solution for ticket: https://github.com/angular/angular/issues/19686
|
|
221
|
-
if (this.ngControl) {
|
|
222
|
-
this.ngControl.controllabel = this.label;
|
|
162
|
+
get isinlineerrorenabled() {
|
|
163
|
+
if (this.formlayout?.IsInlineErrorEnabled === null ||
|
|
164
|
+
this.formlayout?.IsInlineErrorEnabled === undefined) {
|
|
165
|
+
return this._inlineerrorenabled;
|
|
223
166
|
}
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
//#region Validation Base
|
|
227
|
-
/**
|
|
228
|
-
* Validator Methode
|
|
229
|
-
*/
|
|
230
|
-
validate(c) {
|
|
231
|
-
const error = this.validateData(c);
|
|
232
|
-
return error;
|
|
167
|
+
return (this.formlayout.IsInlineErrorEnabled !== false &&
|
|
168
|
+
this._inlineerrorenabled !== false);
|
|
233
169
|
}
|
|
234
170
|
/**
|
|
235
|
-
*
|
|
171
|
+
* Definiert den Label Text
|
|
236
172
|
*/
|
|
237
|
-
|
|
238
|
-
this.
|
|
173
|
+
get label() {
|
|
174
|
+
return this._label;
|
|
239
175
|
}
|
|
240
176
|
/**
|
|
241
|
-
*
|
|
177
|
+
* returns an object with all label sizes. These values can then be transferred to corresponding CSS classes using a pipe
|
|
242
178
|
*/
|
|
243
|
-
get
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
179
|
+
get labelSizes() {
|
|
180
|
+
return {
|
|
181
|
+
labelSizeSm: this.labelSizeSm,
|
|
182
|
+
labelSizeMd: this.labelSizeMd,
|
|
183
|
+
labelSizeXs: this.labelSizeXs,
|
|
184
|
+
labelSizeXl: this.labelSizeXl,
|
|
185
|
+
labelSizeXxl: this.labelSizeXxl,
|
|
186
|
+
labelSizeLg: this.labelSizeLg,
|
|
187
|
+
};
|
|
248
188
|
}
|
|
249
189
|
/**
|
|
250
190
|
* Methode ergibt Boolean Wert für touched
|
|
@@ -256,20 +196,13 @@ class SacBaseModelControl {
|
|
|
256
196
|
return this._touched;
|
|
257
197
|
}
|
|
258
198
|
/**
|
|
259
|
-
* Methode
|
|
260
|
-
*/
|
|
261
|
-
get invalid() {
|
|
262
|
-
return (this.ngControl !== undefined &&
|
|
263
|
-
this.ngControl !== null &&
|
|
264
|
-
this.ngControl.invalid);
|
|
265
|
-
}
|
|
266
|
-
/**
|
|
267
|
-
* Methode ergibt boolean touched = true
|
|
199
|
+
* Get Methode für NgModel Binding in Html Markup
|
|
268
200
|
*/
|
|
269
|
-
|
|
270
|
-
this.
|
|
271
|
-
this.propagateTouch();
|
|
201
|
+
get value() {
|
|
202
|
+
return this._value;
|
|
272
203
|
}
|
|
204
|
+
// #endregion Public Getters And Setters
|
|
205
|
+
// #region Public Methods
|
|
273
206
|
/**
|
|
274
207
|
* Methode ergibt Error anhand von gegebenen Kriterien
|
|
275
208
|
*/
|
|
@@ -294,7 +227,6 @@ class SacBaseModelControl {
|
|
|
294
227
|
observer.complete();
|
|
295
228
|
});
|
|
296
229
|
}
|
|
297
|
-
console.log('Step4: ' + JSON.stringify(errors));
|
|
298
230
|
const errorItem = errors[keys[0]];
|
|
299
231
|
// Validation Parameters
|
|
300
232
|
const parameters = {};
|
|
@@ -306,6 +238,99 @@ class SacBaseModelControl {
|
|
|
306
238
|
parameters['FIELD'] = errorItem.fieldName;
|
|
307
239
|
return this.lngResourceService.GetString(errorItem.errorMessageKey, parameters);
|
|
308
240
|
}
|
|
241
|
+
/**
|
|
242
|
+
* Init Event
|
|
243
|
+
*/
|
|
244
|
+
ngOnInit() {
|
|
245
|
+
// receive form via formcontrolname or formcontrol instance
|
|
246
|
+
const formControl = this.injector.get(NgControl, null);
|
|
247
|
+
if (formControl instanceof FormControlName) {
|
|
248
|
+
const form = this.injector.get(FormGroupDirective, null);
|
|
249
|
+
this.ngControl = form.getControl(formControl);
|
|
250
|
+
}
|
|
251
|
+
else {
|
|
252
|
+
if (formControl) {
|
|
253
|
+
this.ngControl = formControl.control;
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
this.UpdateLabelToControl();
|
|
257
|
+
// set label sizes from formlayout directive
|
|
258
|
+
this.setLabelSizes();
|
|
259
|
+
// set adaptive label property from formlayout directive
|
|
260
|
+
this.setIsAdaptiveLabel();
|
|
261
|
+
this.OnClassInit();
|
|
262
|
+
}
|
|
263
|
+
/**
|
|
264
|
+
* Methode ergibt boolean touched = true
|
|
265
|
+
*/
|
|
266
|
+
onTouch() {
|
|
267
|
+
this._touched = true;
|
|
268
|
+
this.propagateTouch();
|
|
269
|
+
}
|
|
270
|
+
/**
|
|
271
|
+
* Methode, damit andere Controls änderungen im Control mitbekommen können
|
|
272
|
+
* Zur Änderungsinfo die Methode propagateChange aufrufen.
|
|
273
|
+
*/
|
|
274
|
+
registerOnChange(fn) {
|
|
275
|
+
this.propagateChange = (obj) => fn(obj);
|
|
276
|
+
}
|
|
277
|
+
/**
|
|
278
|
+
* Methode, damit andere Controls änderungen mitbekommen, wenn das Control aktiviert (Focus) wird.
|
|
279
|
+
*/
|
|
280
|
+
registerOnTouched(fn) {
|
|
281
|
+
this.propagateTouch = (obj) => fn(obj);
|
|
282
|
+
}
|
|
283
|
+
/**
|
|
284
|
+
* Methode registriert Änderungen bei der Validierung
|
|
285
|
+
*/
|
|
286
|
+
registerOnValidatorChange(fn) {
|
|
287
|
+
this._onChange = fn;
|
|
288
|
+
}
|
|
289
|
+
/**
|
|
290
|
+
* Setzt das Control auf Disabled
|
|
291
|
+
*/
|
|
292
|
+
setDisabledState(isDisabled) {
|
|
293
|
+
this._disabledForm = isDisabled;
|
|
294
|
+
}
|
|
295
|
+
/**
|
|
296
|
+
* Methode die den Wert des Inputs setzt
|
|
297
|
+
*/
|
|
298
|
+
setValue(v) {
|
|
299
|
+
this.value = v;
|
|
300
|
+
}
|
|
301
|
+
/**
|
|
302
|
+
* Validator Methode
|
|
303
|
+
*/
|
|
304
|
+
validate(c) {
|
|
305
|
+
const error = this.validateData(c);
|
|
306
|
+
return error;
|
|
307
|
+
}
|
|
308
|
+
/**
|
|
309
|
+
* Methode zum schreiben von Werten aus dem Model in das Control
|
|
310
|
+
*/
|
|
311
|
+
writeValue(value) {
|
|
312
|
+
this._value = value;
|
|
313
|
+
}
|
|
314
|
+
// #endregion Public Abstract Methods
|
|
315
|
+
// #region Protected Methods
|
|
316
|
+
/**
|
|
317
|
+
* Method can Overwriten in Parent Classes
|
|
318
|
+
* @param value Wert welcher in den korrekten Typ konvertiert werden soll
|
|
319
|
+
* @returns Wert im korrekten Typ
|
|
320
|
+
*/
|
|
321
|
+
ConvertInputValue(value) {
|
|
322
|
+
return value;
|
|
323
|
+
}
|
|
324
|
+
/**
|
|
325
|
+
* Methode ergibt Decimal Symbol
|
|
326
|
+
*/
|
|
327
|
+
GetDecimalSymbol() {
|
|
328
|
+
return '.';
|
|
329
|
+
}
|
|
330
|
+
/**
|
|
331
|
+
* Method can be used to Set Properties at Class Init
|
|
332
|
+
*/
|
|
333
|
+
OnClassInit() { }
|
|
309
334
|
/**
|
|
310
335
|
* Aktualisiert den NgModel Wert und die Gültigkeit des Validators des Controls
|
|
311
336
|
*/
|
|
@@ -314,56 +339,109 @@ class SacBaseModelControl {
|
|
|
314
339
|
this.ngControl.updateValueAndValidity({ onlySelf: true });
|
|
315
340
|
}
|
|
316
341
|
}
|
|
342
|
+
// #endregion Protected Methods
|
|
343
|
+
// #region Private Methods
|
|
344
|
+
UpdateLabelToControl() {
|
|
345
|
+
// HACK: Add addition property to FormControl. Can be fixed if solution for ticket: https://github.com/angular/angular/issues/19686
|
|
346
|
+
if (this.ngControl) {
|
|
347
|
+
this.ngControl.controllabel = this.label;
|
|
348
|
+
}
|
|
349
|
+
}
|
|
317
350
|
/**
|
|
318
|
-
*
|
|
351
|
+
* Set adaptive label property from parent layout control
|
|
319
352
|
*/
|
|
320
|
-
|
|
321
|
-
if (
|
|
322
|
-
this.
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
353
|
+
setIsAdaptiveLabel() {
|
|
354
|
+
if (!this.isAdaptiveLabel) {
|
|
355
|
+
if (this.formlayout?.isAdaptiveLabel !== undefined) {
|
|
356
|
+
this.isAdaptiveLabel = this.formlayout.isAdaptiveLabel;
|
|
357
|
+
}
|
|
358
|
+
else {
|
|
359
|
+
this.isAdaptiveLabel = false;
|
|
360
|
+
}
|
|
326
361
|
}
|
|
327
362
|
}
|
|
328
|
-
get inlineerrorenabled() {
|
|
329
|
-
return this._inlineerrorenabled;
|
|
330
|
-
}
|
|
331
363
|
/**
|
|
332
|
-
*
|
|
364
|
+
* Set label sizes from property or parent layout control
|
|
333
365
|
*/
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
366
|
+
setLabelSizes() {
|
|
367
|
+
// set size extra small
|
|
368
|
+
if (!this.labelSizeXs) {
|
|
369
|
+
if (this.formlayout?.labelSizeXs) {
|
|
370
|
+
this.labelSizeXs = this.formlayout.labelSizeXs;
|
|
371
|
+
}
|
|
372
|
+
else {
|
|
373
|
+
this.labelSizeXs = 12;
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
// set size small
|
|
377
|
+
if (!this.labelSizeSm) {
|
|
378
|
+
if (this.formlayout?.labelSizeSm) {
|
|
379
|
+
this.labelSizeSm = this.formlayout.labelSizeSm;
|
|
380
|
+
}
|
|
381
|
+
else {
|
|
382
|
+
this.labelSizeSm = 4;
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
// set size medium
|
|
386
|
+
if (!this.labelSizeMd) {
|
|
387
|
+
if (this.formlayout?.labelSizeMd) {
|
|
388
|
+
this.labelSizeMd = this.formlayout.labelSizeMd;
|
|
389
|
+
}
|
|
390
|
+
}
|
|
391
|
+
// set size large
|
|
392
|
+
if (!this.labelSizeLg) {
|
|
393
|
+
if (this.formlayout?.labelSizeLg) {
|
|
394
|
+
this.labelSizeLg = this.formlayout.labelSizeLg;
|
|
395
|
+
}
|
|
396
|
+
}
|
|
397
|
+
// set size extra large
|
|
398
|
+
if (!this.labelSizeXl) {
|
|
399
|
+
if (this.formlayout?.labelSizeXl) {
|
|
400
|
+
this.labelSizeXl = this.formlayout.labelSizeXl;
|
|
401
|
+
}
|
|
402
|
+
}
|
|
403
|
+
// set size extra extra large
|
|
404
|
+
if (!this.labelSizeXxl) {
|
|
405
|
+
if (this.formlayout?.labelSizeXxl) {
|
|
406
|
+
this.labelSizeXxl = this.formlayout.labelSizeXxl;
|
|
407
|
+
}
|
|
338
408
|
}
|
|
339
|
-
return (this.parent.IsInlineErrorEnabled !== false &&
|
|
340
|
-
this._inlineerrorenabled !== false);
|
|
341
409
|
}
|
|
342
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacBaseModelControl, deps: [{ token: i1.
|
|
343
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacBaseModelControl, inputs: {
|
|
410
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacBaseModelControl, deps: [{ token: i1.SacFormLayoutCommon, host: true }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
411
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacBaseModelControl, inputs: { disabled: "disabled", disablelabel: "disablelabel", inlineError: "inlineError", isAdaptiveLabel: "isAdaptiveLabel", labelSizeLg: "labelSizeLg", labelSizeMd: "labelSizeMd", labelSizeSm: "labelSizeSm", labelSizeXl: "labelSizeXl", labelSizeXs: "labelSizeXs", labelSizeXxl: "labelSizeXxl", name: "name", inlineerrorenabled: "inlineerrorenabled", label: "label", value: "value" }, ngImport: i0 }); }
|
|
344
412
|
}
|
|
345
413
|
export { SacBaseModelControl };
|
|
346
414
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacBaseModelControl, decorators: [{
|
|
347
415
|
type: Directive
|
|
348
|
-
}], ctorParameters: function () { return [{ type: i1.
|
|
416
|
+
}], ctorParameters: function () { return [{ type: i1.SacFormLayoutCommon, decorators: [{
|
|
349
417
|
type: Host
|
|
350
|
-
}] }, { type: i0.Injector }]; }, propDecorators: {
|
|
418
|
+
}] }, { type: i0.Injector }]; }, propDecorators: { disabled: [{
|
|
351
419
|
type: Input
|
|
352
|
-
}],
|
|
420
|
+
}], disablelabel: [{
|
|
353
421
|
type: Input
|
|
354
|
-
}],
|
|
422
|
+
}], inlineError: [{
|
|
355
423
|
type: Input
|
|
356
|
-
}],
|
|
424
|
+
}], isAdaptiveLabel: [{
|
|
357
425
|
type: Input
|
|
358
|
-
}],
|
|
426
|
+
}], labelSizeLg: [{
|
|
359
427
|
type: Input
|
|
360
|
-
}],
|
|
428
|
+
}], labelSizeMd: [{
|
|
361
429
|
type: Input
|
|
362
|
-
}],
|
|
430
|
+
}], labelSizeSm: [{
|
|
363
431
|
type: Input
|
|
364
|
-
}],
|
|
432
|
+
}], labelSizeXl: [{
|
|
433
|
+
type: Input
|
|
434
|
+
}], labelSizeXs: [{
|
|
435
|
+
type: Input
|
|
436
|
+
}], labelSizeXxl: [{
|
|
437
|
+
type: Input
|
|
438
|
+
}], name: [{
|
|
365
439
|
type: Input
|
|
366
440
|
}], inlineerrorenabled: [{
|
|
367
441
|
type: Input
|
|
442
|
+
}], label: [{
|
|
443
|
+
type: Input
|
|
444
|
+
}], value: [{
|
|
445
|
+
type: Input
|
|
368
446
|
}] } });
|
|
369
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basemodelcontrol.js","sourceRoot":"","sources":["../../../../projects/sac-common/src/common/basemodelcontrol.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Host, Injector, Input, OnInit } from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  UntypedFormControl,\r\n  FormControlName,\r\n  FormGroupDirective,\r\n  NgControl,\r\n  ValidationErrors,\r\n  Validator,\r\n} from '@angular/forms';\r\nimport { Observable } from 'rxjs';\r\nimport { SacFormCommon } from '../controls/form/form';\r\nimport { ISacLocalisationService } from '../interfaces/ISacLocalisationService';\r\nimport { IAbstractControlLabelExtension } from '../public_api';\r\nimport {\r\n  SacDefaultLocalisationService,\r\n  SACLOCALISATION_SERVICE,\r\n} from '../services/sac-localisation.service';\r\nimport { convertToBoolean } from '../utilities/convertion';\r\nimport { ValidationErrorItem } from '../validation';\r\n\r\n/**\r\n * Abstract Klasse für SacBaseModelControl. Implements ControlValueAccessor, Validator, OnInit\r\n */\r\n@Directive()\r\nexport abstract class SacBaseModelControl<VALUE>\r\n  implements ControlValueAccessor, Validator, OnInit\r\n{\r\n  // #region Private Variables\r\n\r\n  /**\r\n   * Parent Formular\r\n   */\r\n  protected parent: SacFormCommon;\r\n  /**\r\n   * SacModel Form ist disabled\r\n   */\r\n  protected _disabledForm: boolean = false;\r\n  /**\r\n   * ngControl\r\n   */\r\n  protected ngControl: UntypedFormControl;\r\n  /**\r\n   * Service für Error Localisation\r\n   */\r\n  protected lngResourceService: ISacLocalisationService;\r\n\r\n  private _label: string = '';\r\n\r\n  // #endregion\r\n\r\n  // #region Properties\r\n\r\n  /**\r\n   * Name des Controls\r\n   */\r\n  @Input() name: string = '';\r\n  /**\r\n   * Definiert den Label Text\r\n   */\r\n  @Input() set label(v: string) {\r\n    this._label = v;\r\n    this.UpdateLabelToControl();\r\n  }\r\n  /**\r\n   * Definiert den Label Text\r\n   */\r\n  get label(): string {\r\n    return this._label;\r\n  }\r\n\r\n  /**\r\n   * Definiert die Labelgröse\r\n   */\r\n  @Input() labelsize: number = undefined;\r\n  /**\r\n   * Deaktiviert das Label im Template\r\n   */\r\n  @Input() disablelabel: boolean = false;\r\n  /**\r\n   * Deaktiviert das Input Control\r\n   */\r\n  @Input() disabled: boolean = false;\r\n  /**\r\n   * Kontroliert, ob das Label adaptive ist\r\n   */\r\n  @Input() isadaptivelabel: boolean = undefined;\r\n  /**\r\n   * Definiert, ob das Control Sprachspezifisch ist\r\n   */\r\n  @Input() islanguagespecific: boolean = false;\r\n\r\n  /**\r\n   * Definiert ob das Control disabled ist\r\n   */\r\n  get isdisabled(): boolean {\r\n    return this._disabledForm || this.disabled;\r\n  }\r\n\r\n  // #endregion\r\n\r\n  // #region Constructor\r\n\r\n  /**\r\n   * Konstruktor\r\n   * Inject des Formulars\r\n   * @parent SacFormCommon\r\n   * @injector Injector\r\n   */\r\n  constructor(@Host() parent: SacFormCommon, private injector: Injector) {\r\n    this.parent = parent;\r\n    this.lngResourceService = injector.get(\r\n      SACLOCALISATION_SERVICE,\r\n      new SacDefaultLocalisationService()\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Interne Variable, die den Wert des Controls hält\r\n   */\r\n  protected _value: VALUE = null;\r\n\r\n  /**\r\n   * Validator\r\n   */\r\n  protected _onChange: () => void;\r\n\r\n  /**\r\n   * Boolean Property dirty; default Wert - false\r\n   */\r\n  protected _dirty: boolean = false;\r\n\r\n  /**\r\n   * Boolean Property touched; default Wert - false\r\n   */\r\n  protected _touched: boolean = false;\r\n\r\n  /**\r\n   * Inline Errors für das Control\r\n   */\r\n  private _inlineerrorenabled: boolean | null = null;\r\n\r\n  // #endregion\r\n\r\n  // #region Control Events\r\n\r\n  /**\r\n   * Init Event\r\n   */\r\n  ngOnInit() {\r\n    // receive form via formcontrolname or formcontrol instance\r\n    const formControl = this.injector.get(NgControl, null);\r\n    if (formControl instanceof FormControlName) {\r\n      const form = this.injector.get(FormGroupDirective, null);\r\n      this.ngControl = form.getControl(formControl);\r\n    } else {\r\n      this.ngControl = formControl.control as UntypedFormControl;\r\n    }\r\n\r\n    this.UpdateLabelToControl();\r\n\r\n    /**\r\n     * Label Size von Formular lesen\r\n     */\r\n    if (this.labelsize === undefined) {\r\n      if (this.parent?.labelsize !== undefined) {\r\n        this.labelsize = this.parent.labelsize;\r\n      } else {\r\n        this.labelsize = 4;\r\n      }\r\n    }\r\n\r\n    /**\r\n     * Adaptive Label from Form\r\n     */\r\n    if (this.isadaptivelabel === undefined) {\r\n      if (this.parent?.isadaptivelabel !== undefined) {\r\n        this.isadaptivelabel = this.parent.isadaptivelabel;\r\n      } else {\r\n        this.isadaptivelabel = false;\r\n      }\r\n    }\r\n\r\n    this.OnClassInit();\r\n  }\r\n\r\n  // #endregion\r\n\r\n  // #region Implementation ControlValueAccessor\r\n\r\n  /**\r\n   * Leere Implementation von \"propagateChange\". Muss gemacht werden, damit kein Fehler entsteht\r\n   */\r\n  propagateChange: any = () => {};\r\n  /**\r\n   * Leere Implementation von \"propagateTouch\". Muss gemacht werden, damit kein Fehler entsteht\r\n   */\r\n  propagateTouch: any = () => {};\r\n\r\n  /**\r\n   * Methode, damit andere Controls änderungen im Control mitbekommen können\r\n   * Zur Änderungsinfo die Methode propagateChange aufrufen.\r\n   */\r\n  registerOnChange(fn: any): void {\r\n    this.propagateChange = (obj) => fn(obj);\r\n  }\r\n\r\n  /**\r\n   * Methode, damit andere Controls änderungen mitbekommen, wenn das Control aktiviert (Focus) wird.\r\n   */\r\n  registerOnTouched(fn: any): void {\r\n    this.propagateTouch = (obj) => fn(obj);\r\n  }\r\n\r\n  /**\r\n   * Methode zum schreiben von Werten aus dem Model in das Control\r\n   */\r\n  writeValue(value: VALUE) {\r\n    this._value = value;\r\n  }\r\n\r\n  /**\r\n   * Setzt das Control auf Disabled\r\n   */\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this._disabledForm = isDisabled;\r\n  }\r\n\r\n  // #endregion\r\n\r\n  // #region Control Value\r\n\r\n  /**\r\n   * Set Methode für NgModel Binding in Html Markup\r\n   * Input wird benötigt, damit der Wert auch über das Markup gesetzt werden kann.\r\n   */\r\n  @Input()\r\n  set value(v: VALUE) {\r\n    if (this.disabled) {\r\n      return;\r\n    }\r\n\r\n    this._value = this.ConvertInputValue(v);\r\n    this.propagateChange(this._value);\r\n  }\r\n\r\n  /**\r\n   * Get Methode für NgModel Binding in Html Markup\r\n   */\r\n  get value(): VALUE {\r\n    return this._value;\r\n  }\r\n\r\n  /**\r\n   * Methode die den Wert des Inputs setzt\r\n   */\r\n  setValue(v: VALUE): void {\r\n    this.value = v;\r\n  }\r\n\r\n  // #endregion\r\n\r\n  // #region Internal Properties\r\n\r\n  /**\r\n   * Berechnet die Breite des Labels\r\n   */\r\n  get _inputsize(): number {\r\n    return 12 - this.labelsize;\r\n  }\r\n\r\n  // #endregion\r\n\r\n  // #region Protected Helper Methods\r\n\r\n  /**\r\n   * Method can be used to Set Properties at Class Init\r\n   */\r\n  protected OnClassInit(): void {}\r\n\r\n  /**\r\n   * Methode ergibt Decimal Symbol\r\n   */\r\n  protected GetDecimalSymbol(): string {\r\n    return '.';\r\n  }\r\n\r\n  /**\r\n   * Method can Overwriten in Parent Classes\r\n   * @param value Wert welcher in den korrekten Typ konvertiert werden soll\r\n   * @returns Wert im korrekten Typ\r\n   */\r\n  protected ConvertInputValue(value: VALUE): VALUE {\r\n    return value;\r\n  }\r\n\r\n  private UpdateLabelToControl(): 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      (\r\n        this.ngControl as unknown as IAbstractControlLabelExtension\r\n      ).controllabel = this.label;\r\n    }\r\n  }\r\n\r\n  // #endregion\r\n\r\n  //#region Validation Base\r\n\r\n  /**\r\n   * Validator Methode\r\n   */\r\n  validate(c: AbstractControl): ValidationErrors | null {\r\n    const error: ValidationErrors | null = this.validateData(c);\r\n    return error;\r\n  }\r\n\r\n  /**\r\n   * Abstrakte Validator Methode\r\n   */\r\n  abstract validateData(c: AbstractControl): ValidationErrors | null;\r\n\r\n  /**\r\n   * Methode registriert Änderungen bei der Validierung\r\n   */\r\n  registerOnValidatorChange(fn: () => void): void {\r\n    this._onChange = fn;\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt Boolean Wert für dirty\r\n   */\r\n  public get dirty(): boolean {\r\n    if (this.ngControl !== null) {\r\n      this._dirty = this.ngControl.dirty;\r\n    }\r\n\r\n    return this._dirty;\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt Boolean Wert für touched\r\n   */\r\n  public get touched(): boolean {\r\n    if (this.ngControl !== null) {\r\n      this._touched = this.ngControl.touched;\r\n    }\r\n\r\n    return this._touched;\r\n  }\r\n  /**\r\n   * Methode ergibt boolean Wert wenn Form invalid oder nicht invalid ist\r\n   */\r\n  public get invalid(): boolean {\r\n    return (\r\n      this.ngControl !== undefined &&\r\n      this.ngControl !== null &&\r\n      this.ngControl.invalid\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt boolean touched = true\r\n   */\r\n  onTouch(): void {\r\n    this._touched = true;\r\n    this.propagateTouch();\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt Error anhand von gegebenen Kriterien\r\n   */\r\n  GetErrorMessage(): Observable<string> {\r\n    if (this.ngControl.errors === undefined || this.ngControl.errors === null) {\r\n      return new Observable<string>((observer) => {\r\n        observer.next('');\r\n        observer.complete();\r\n      });\r\n    }\r\n\r\n    const errors: ValidationErrors = this.ngControl.errors;\r\n\r\n    if (errors.length === 0) {\r\n      return new Observable<string>((observer) => {\r\n        observer.next('');\r\n        observer.complete();\r\n      });\r\n    }\r\n\r\n    const keys: string[] = Object.keys(errors);\r\n\r\n    if (keys.length <= 0) {\r\n      return new Observable<string>((observer) => {\r\n        observer.next('');\r\n        observer.complete();\r\n      });\r\n    }\r\n\r\n    console.log('Step4: ' + JSON.stringify(errors));\r\n\r\n    const errorItem: ValidationErrorItem = errors[keys[0]];\r\n\r\n    // Validation Parameters\r\n    const parameters = {};\r\n    if (errorItem.parameters !== null && errorItem.parameters !== undefined) {\r\n      errorItem.parameters.forEach((v, k) => {\r\n        parameters[k] = v;\r\n      });\r\n    }\r\n    parameters['FIELD'] = errorItem.fieldName;\r\n\r\n    return this.lngResourceService.GetString(\r\n      errorItem.errorMessageKey,\r\n      parameters\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Aktualisiert den NgModel Wert und die Gültigkeit des Validators des Controls\r\n   */\r\n  protected UpdateValueAndValidity(): void {\r\n    if (this.ngControl) {\r\n      this.ngControl.updateValueAndValidity({ onlySelf: true });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Aktiviert oder Deaktiviert die Inline Errors für das Control\r\n   */\r\n  @Input()\r\n  set inlineerrorenabled(value: boolean | null) {\r\n    if (value === null || value === undefined) {\r\n      this._inlineerrorenabled = null;\r\n    } else {\r\n      this._inlineerrorenabled = convertToBoolean(value);\r\n    }\r\n  }\r\n  get inlineerrorenabled(): boolean | null {\r\n    return this._inlineerrorenabled;\r\n  }\r\n\r\n  /**\r\n   * Gibt zurück, ob die Inline Error Meldungen für diesem Control aktiv sind.\r\n   */\r\n  get IsInlineErrorEnabled(): boolean {\r\n    if (\r\n      this.parent?.IsInlineErrorEnabled === null ||\r\n      this.parent?.IsInlineErrorEnabled === undefined\r\n    ) {\r\n      return this._inlineerrorenabled;\r\n    }\r\n\r\n    return (\r\n      this.parent.IsInlineErrorEnabled !== false &&\r\n      this._inlineerrorenabled !== false\r\n    );\r\n  }\r\n\r\n  //#endregion\r\n}\r\n"]}
|
|
447
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basemodelcontrol.js","sourceRoot":"","sources":["../../../../projects/sac-common/src/common/basemodelcontrol.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Host, Injector, Input, OnInit } from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  FormControlName,\r\n  FormGroupDirective,\r\n  NgControl,\r\n  UntypedFormControl,\r\n  ValidationErrors,\r\n  Validator,\r\n} from '@angular/forms';\r\nimport { Observable } from 'rxjs';\r\nimport { SacFormLayoutCommon } from '../controls/layout/formlayout';\r\nimport { ISacLabelSizes } from '../interfaces/ISacLabelSizes';\r\nimport { ISacLocalisationService } from '../interfaces/ISacLocalisationService';\r\nimport { IAbstractControlLabelExtension } from '../public_api';\r\nimport {\r\n  SACLOCALISATION_SERVICE,\r\n  SacDefaultLocalisationService,\r\n} from '../services/sac-localisation.service';\r\nimport { convertToBoolean } from '../utilities/convertion';\r\nimport { ValidationErrorItem } from '../validation';\r\n\r\n/**\r\n * Abstract Klasse für SacBaseModelControl. Implements ControlValueAccessor, Validator, OnInit\r\n */\r\n@Directive()\r\nexport abstract class SacBaseModelControl<VALUE>\r\n  implements ControlValueAccessor, Validator, OnInit\r\n{\r\n  // #region Properties\r\n\r\n  /**\r\n   * Inline Errors für das Control\r\n   */\r\n  private _inlineerrorenabled: boolean | null = null;\r\n  private _label: string = '';\r\n\r\n  /**\r\n   * Boolean Property dirty; default Wert - false\r\n   */\r\n  protected _dirty: boolean = false;\r\n  /**\r\n   * SacModel Form ist disabled\r\n   */\r\n  protected _disabledForm: boolean = false;\r\n  /**\r\n   * Validator\r\n   */\r\n  protected _onChange: () => void;\r\n  /**\r\n   * Boolean Property touched; default Wert - false\r\n   */\r\n  protected _touched: boolean = false;\r\n  /**\r\n   * Interne Variable, die den Wert des Controls hält\r\n   */\r\n  protected _value: VALUE = null;\r\n  /**\r\n   * Form layout instance if exists\r\n   */\r\n  protected formlayout: SacFormLayoutCommon = null;\r\n  /**\r\n   * Service für Error Localisation\r\n   */\r\n  protected lngResourceService: ISacLocalisationService;\r\n  /**\r\n   * ngControl\r\n   */\r\n  protected ngControl: UntypedFormControl;\r\n\r\n  /**\r\n   * Deaktiviert das Input Control\r\n   */\r\n  @Input() public disabled: boolean = false;\r\n  /**\r\n   * Deaktiviert das Label im Template\r\n   */\r\n  @Input() public disablelabel: boolean = false;\r\n  /**\r\n   * defines that error messages are displayed under the controls\r\n   */\r\n  @Input() public inlineError: boolean = true;\r\n  /**\r\n   * defines that the labels are displayed as adaptive labels\r\n   */\r\n  @Input() public isAdaptiveLabel: boolean = false;\r\n  /**\r\n   * default labe size for large devices\r\n   */\r\n  @Input()\r\n  public labelSizeLg: number | null = null;\r\n  /**\r\n   * default label size for medium devices\r\n   */\r\n  @Input()\r\n  public labelSizeMd: number | null = null;\r\n  /**\r\n   * default label size for small devices\r\n   */\r\n  @Input()\r\n  public labelSizeSm: number | null = null;\r\n  /**\r\n   * default label size for extra large devices\r\n   */\r\n  @Input()\r\n  public labelSizeXl: number | null = null;\r\n  /**\r\n   * default label column size\r\n   */\r\n  @Input()\r\n  public labelSizeXs: number | null = null;\r\n  /**\r\n   * default label size for extra extra large devices\r\n   */\r\n  @Input()\r\n  public labelSizeXxl: number | null = null;\r\n  /**\r\n   * Name des Controls\r\n   */\r\n  @Input() public name: string = '';\r\n\r\n  /**\r\n   * Leere Implementation von \"propagateChange\". Muss gemacht werden, damit kein Fehler entsteht\r\n   */\r\n  public propagateChange: any = () => {};\r\n  /**\r\n   * Leere Implementation von \"propagateTouch\". Muss gemacht werden, damit kein Fehler entsteht\r\n   */\r\n  public propagateTouch: any = () => {};\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   */\r\n  constructor(\r\n    @Host() formlayout: SacFormLayoutCommon,\r\n    private injector: Injector\r\n  ) {\r\n    this.formlayout = formlayout;\r\n    this.lngResourceService = injector.get(\r\n      SACLOCALISATION_SERVICE,\r\n      new SacDefaultLocalisationService()\r\n    );\r\n  }\r\n\r\n  // #endregion Constructors\r\n\r\n  // #region Public Getters And Setters\r\n\r\n  /**\r\n   * Aktiviert oder Deaktiviert die Inline Errors für das Control\r\n   */\r\n  @Input()\r\n  public set inlineerrorenabled(value: boolean | null) {\r\n    if (value === null || value === undefined) {\r\n      this._inlineerrorenabled = null;\r\n    } else {\r\n      this._inlineerrorenabled = convertToBoolean(value);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Definiert den Label Text\r\n   */\r\n  @Input() public set label(v: string) {\r\n    this._label = v;\r\n    this.UpdateLabelToControl();\r\n  }\r\n\r\n  /**\r\n   * Set Methode für NgModel Binding in Html Markup\r\n   * Input wird benötigt, damit der Wert auch über das Markup gesetzt werden kann.\r\n   */\r\n  @Input()\r\n  public set value(v: VALUE) {\r\n    if (this.disabled) {\r\n      return;\r\n    }\r\n\r\n    this._value = this.ConvertInputValue(v);\r\n    this.propagateChange(this._value);\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt Boolean Wert für dirty\r\n   */\r\n  public get dirty(): boolean {\r\n    if (this.ngControl !== null) {\r\n      this._dirty = this.ngControl.dirty;\r\n    }\r\n\r\n    return this._dirty;\r\n  }\r\n\r\n  public get inlineerrorenabled(): boolean | null {\r\n    return this._inlineerrorenabled;\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt boolean Wert wenn Form invalid oder nicht invalid ist\r\n   */\r\n  public get invalid(): boolean {\r\n    return (\r\n      this.ngControl !== undefined &&\r\n      this.ngControl !== null &&\r\n      this.ngControl.invalid\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Definiert ob das Control disabled ist\r\n   */\r\n  public get isdisabled(): boolean {\r\n    return this._disabledForm || this.disabled;\r\n  }\r\n\r\n  /**\r\n   * Returns whether the inline error messages are active for this control.\r\n   */\r\n  public get isinlineerrorenabled(): boolean {\r\n    if (\r\n      this.formlayout?.IsInlineErrorEnabled === null ||\r\n      this.formlayout?.IsInlineErrorEnabled === undefined\r\n    ) {\r\n      return this._inlineerrorenabled;\r\n    }\r\n\r\n    return (\r\n      this.formlayout.IsInlineErrorEnabled !== false &&\r\n      this._inlineerrorenabled !== false\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Definiert den Label Text\r\n   */\r\n  public get label(): string {\r\n    return this._label;\r\n  }\r\n\r\n  /**\r\n   * returns an object with all label sizes. These values can then be transferred to corresponding CSS classes using a pipe\r\n   */\r\n  public get labelSizes(): ISacLabelSizes {\r\n    return {\r\n      labelSizeSm: this.labelSizeSm,\r\n      labelSizeMd: this.labelSizeMd,\r\n      labelSizeXs: this.labelSizeXs,\r\n      labelSizeXl: this.labelSizeXl,\r\n      labelSizeXxl: this.labelSizeXxl,\r\n      labelSizeLg: this.labelSizeLg,\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt Boolean Wert für touched\r\n   */\r\n  public get touched(): boolean {\r\n    if (this.ngControl !== null) {\r\n      this._touched = this.ngControl.touched;\r\n    }\r\n\r\n    return this._touched;\r\n  }\r\n\r\n  /**\r\n   * Get Methode für NgModel Binding in Html Markup\r\n   */\r\n  public get value(): VALUE {\r\n    return this._value;\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 Error anhand von gegebenen Kriterien\r\n   */\r\n  public GetErrorMessage(): Observable<string> {\r\n    if (this.ngControl.errors === undefined || this.ngControl.errors === null) {\r\n      return new Observable<string>((observer) => {\r\n        observer.next('');\r\n        observer.complete();\r\n      });\r\n    }\r\n\r\n    const errors: ValidationErrors = this.ngControl.errors;\r\n\r\n    if (errors.length === 0) {\r\n      return new Observable<string>((observer) => {\r\n        observer.next('');\r\n        observer.complete();\r\n      });\r\n    }\r\n\r\n    const keys: string[] = Object.keys(errors);\r\n\r\n    if (keys.length <= 0) {\r\n      return new Observable<string>((observer) => {\r\n        observer.next('');\r\n        observer.complete();\r\n      });\r\n    }\r\n\r\n    const errorItem: ValidationErrorItem = errors[keys[0]];\r\n\r\n    // Validation Parameters\r\n    const parameters = {};\r\n    if (errorItem.parameters !== null && errorItem.parameters !== undefined) {\r\n      errorItem.parameters.forEach((v, k) => {\r\n        parameters[k] = v;\r\n      });\r\n    }\r\n    parameters['FIELD'] = errorItem.fieldName;\r\n\r\n    return this.lngResourceService.GetString(\r\n      errorItem.errorMessageKey,\r\n      parameters\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Init Event\r\n   */\r\n  public ngOnInit() {\r\n    // receive form via formcontrolname or formcontrol instance\r\n    const formControl = this.injector.get(NgControl, null);\r\n    if (formControl instanceof FormControlName) {\r\n      const form = this.injector.get(FormGroupDirective, null);\r\n      this.ngControl = form.getControl(formControl);\r\n    } else {\r\n        if (formControl) {\r\n            this.ngControl = formControl.control as UntypedFormControl;\r\n        }\r\n    }\r\n\r\n    this.UpdateLabelToControl();\r\n\r\n    // set label sizes from formlayout directive\r\n    this.setLabelSizes();\r\n\r\n    // set adaptive label property from formlayout directive\r\n    this.setIsAdaptiveLabel();\r\n\r\n    this.OnClassInit();\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt boolean touched = true\r\n   */\r\n  public onTouch(): void {\r\n    this._touched = true;\r\n    this.propagateTouch();\r\n  }\r\n\r\n  /**\r\n   * Methode, damit andere Controls änderungen im Control mitbekommen können\r\n   * Zur Änderungsinfo die Methode propagateChange aufrufen.\r\n   */\r\n  public registerOnChange(fn: any): void {\r\n    this.propagateChange = (obj) => fn(obj);\r\n  }\r\n\r\n  /**\r\n   * Methode, damit andere Controls änderungen mitbekommen, wenn das Control aktiviert (Focus) wird.\r\n   */\r\n  public registerOnTouched(fn: any): void {\r\n    this.propagateTouch = (obj) => fn(obj);\r\n  }\r\n\r\n  /**\r\n   * Methode registriert Änderungen bei der Validierung\r\n   */\r\n  public registerOnValidatorChange(fn: () => void): void {\r\n    this._onChange = fn;\r\n  }\r\n\r\n  /**\r\n   * Setzt das Control auf Disabled\r\n   */\r\n  public setDisabledState(isDisabled: boolean): void {\r\n    this._disabledForm = isDisabled;\r\n  }\r\n\r\n  /**\r\n   * Methode die den Wert des Inputs setzt\r\n   */\r\n  public setValue(v: VALUE): void {\r\n    this.value = v;\r\n  }\r\n\r\n  /**\r\n   * Validator Methode\r\n   */\r\n  public validate(c: AbstractControl): ValidationErrors | null {\r\n    const error: ValidationErrors | null = this.validateData(c);\r\n    return error;\r\n  }\r\n\r\n  /**\r\n   * Methode zum schreiben von Werten aus dem Model in das Control\r\n   */\r\n  public writeValue(value: VALUE) {\r\n    this._value = value;\r\n  }\r\n\r\n  // #endregion Public Methods\r\n\r\n  // #region Public Abstract Methods\r\n\r\n  /**\r\n   * Abstrakte Validator Methode\r\n   */\r\n  public abstract validateData(c: AbstractControl): ValidationErrors | null;\r\n\r\n  // #endregion Public Abstract Methods\r\n\r\n  // #region Protected Methods\r\n\r\n  /**\r\n   * Method can Overwriten in Parent Classes\r\n   * @param value Wert welcher in den korrekten Typ konvertiert werden soll\r\n   * @returns Wert im korrekten Typ\r\n   */\r\n  protected ConvertInputValue(value: VALUE): VALUE {\r\n    return value;\r\n  }\r\n\r\n  /**\r\n   * Methode ergibt Decimal Symbol\r\n   */\r\n  protected GetDecimalSymbol(): string {\r\n    return '.';\r\n  }\r\n\r\n  /**\r\n   * Method can be used to Set Properties at Class Init\r\n   */\r\n  protected OnClassInit(): void {}\r\n\r\n  /**\r\n   * Aktualisiert den NgModel Wert und die Gültigkeit des Validators des Controls\r\n   */\r\n  protected UpdateValueAndValidity(): void {\r\n    if (this.ngControl) {\r\n      this.ngControl.updateValueAndValidity({ onlySelf: true });\r\n    }\r\n  }\r\n\r\n  // #endregion Protected Methods\r\n\r\n  // #region Private Methods\r\n\r\n  private UpdateLabelToControl(): 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      (\r\n        this.ngControl as unknown as IAbstractControlLabelExtension\r\n      ).controllabel = this.label;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Set adaptive label property from parent layout control\r\n   */\r\n  private setIsAdaptiveLabel() {\r\n    if (!this.isAdaptiveLabel) {\r\n      if (this.formlayout?.isAdaptiveLabel !== undefined) {\r\n        this.isAdaptiveLabel = this.formlayout.isAdaptiveLabel;\r\n      } else {\r\n        this.isAdaptiveLabel = false;\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Set label sizes from property or parent layout control\r\n   */\r\n  private setLabelSizes() {\r\n    // set size extra small\r\n    if (!this.labelSizeXs) {\r\n      if (this.formlayout?.labelSizeXs) {\r\n        this.labelSizeXs = this.formlayout.labelSizeXs;\r\n      } else {\r\n        this.labelSizeXs = 12;\r\n      }\r\n    }\r\n\r\n    // set size small\r\n    if (!this.labelSizeSm) {\r\n      if (this.formlayout?.labelSizeSm) {\r\n        this.labelSizeSm = this.formlayout.labelSizeSm;\r\n      } else {\r\n        this.labelSizeSm = 4;\r\n      }\r\n    }\r\n\r\n    // set size medium\r\n    if (!this.labelSizeMd) {\r\n      if (this.formlayout?.labelSizeMd) {\r\n        this.labelSizeMd = this.formlayout.labelSizeMd;\r\n      }\r\n    }\r\n\r\n    // set size large\r\n    if (!this.labelSizeLg) {\r\n      if (this.formlayout?.labelSizeLg) {\r\n        this.labelSizeLg = this.formlayout.labelSizeLg;\r\n      }\r\n    }\r\n\r\n    // set size extra large\r\n    if (!this.labelSizeXl) {\r\n      if (this.formlayout?.labelSizeXl) {\r\n        this.labelSizeXl = this.formlayout.labelSizeXl;\r\n      }\r\n    }\r\n\r\n    // set size extra extra large\r\n    if (!this.labelSizeXxl) {\r\n      if (this.formlayout?.labelSizeXxl) {\r\n        this.labelSizeXxl = this.formlayout.labelSizeXxl;\r\n      }\r\n    }\r\n  }\r\n\r\n  // #endregion Private Methods\r\n}\r\n"]}
|