@simpleangularcontrols/sac-common 16.0.0-rc.2 → 16.0.0-rc.4
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/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 +122 -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 +295 -201
- 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/ISacConfigurationService.mjs +2 -0
- package/esm2022/interfaces/ISacIconService.mjs +1 -1
- package/esm2022/interfaces/ISacLabelSizes.mjs +2 -0
- package/esm2022/public_api.mjs +20 -18
- package/esm2022/services/index.mjs +6 -5
- package/esm2022/services/sac-configuration.service.mjs +71 -0
- package/esm2022/utilities/guid.mjs +16 -0
- package/fesm2022/simpleangularcontrols-sac-common.mjs +2157 -1916
- package/fesm2022/simpleangularcontrols-sac-common.mjs.map +1 -1
- package/interfaces/ISacConfigurationService.d.ts +30 -0
- package/interfaces/ISacConfigurationService.d.ts.map +1 -0
- package/interfaces/ISacIconService.d.ts +2 -2
- package/interfaces/ISacIconService.d.ts.map +1 -1
- package/interfaces/ISacLabelSizes.d.ts +27 -0
- package/interfaces/ISacLabelSizes.d.ts.map +1 -0
- package/package.json +2 -2
- package/public_api.d.ts +19 -17
- package/public_api.d.ts.map +1 -1
- package/services/index.d.ts +5 -4
- package/services/index.d.ts.map +1 -1
- package/services/sac-configuration.service.d.ts +70 -0
- package/services/sac-configuration.service.d.ts.map +1 -0
- package/simpleangularcontrols-sac-common-16.0.0-rc.4.tgz +0 -0
- package/utilities/guid.d.ts +5 -0
- package/utilities/guid.d.ts.map +1 -0
- package/simpleangularcontrols-sac-common-16.0.0-rc.2.tgz +0 -0
|
@@ -8,56 +8,71 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
class SacInputDecimalCommon extends SacInputBase {
|
|
9
9
|
constructor() {
|
|
10
10
|
super(...arguments);
|
|
11
|
+
// #region Properties
|
|
11
12
|
/**
|
|
12
13
|
* Definiert das Negative Werte erlaubt sind
|
|
13
14
|
*/
|
|
14
15
|
this.allownegativ = false;
|
|
15
|
-
/**
|
|
16
|
-
* Definiert den minimalen Wert
|
|
17
|
-
*/
|
|
18
|
-
this.minvalue = undefined;
|
|
19
16
|
/**
|
|
20
17
|
* Definiert den maximalen Wert
|
|
21
18
|
*/
|
|
22
19
|
this.maxvalue = undefined;
|
|
23
20
|
/**
|
|
24
|
-
*
|
|
21
|
+
* Definiert den minimalen Wert
|
|
25
22
|
*/
|
|
26
|
-
this.
|
|
23
|
+
this.minvalue = undefined;
|
|
27
24
|
/**
|
|
28
|
-
* Resource Key für Validation Message
|
|
25
|
+
* Resource Key für Validation Message MaxValue bei Control
|
|
29
26
|
*/
|
|
30
|
-
this.
|
|
27
|
+
this.validationmessagemaxvalue = 'VALIDATION_ERROR_MAXVALUE';
|
|
31
28
|
/**
|
|
32
29
|
* Resource Key für Validation Message MinValue bei Control
|
|
33
30
|
*/
|
|
34
31
|
this.validationmessageminvalue = 'VALIDATION_ERROR_MINVALUE';
|
|
35
32
|
/**
|
|
36
|
-
* Resource Key für Validation Message
|
|
37
|
-
*/
|
|
38
|
-
this.validationmessagesummaryminvalue = 'VALIDATION_ERROR_SUMMARY_MINVALUE';
|
|
39
|
-
/**
|
|
40
|
-
* Resource Key für Validation Message MaxValue bei Control
|
|
33
|
+
* Resource Key für Validation Message Required bei Control
|
|
41
34
|
*/
|
|
42
|
-
this.
|
|
35
|
+
this.validationmessagerequired = 'VALIDATION_ERROR_REQUIRED';
|
|
43
36
|
/**
|
|
44
37
|
* Resource Key für Validation Message MaxValue in Validation Summary
|
|
45
38
|
*/
|
|
46
39
|
this.validationmessagesummarymaxvalue = 'VALIDATION_ERROR_SUMMARY_MAXVALUE';
|
|
40
|
+
/**
|
|
41
|
+
* Resource Key für Validation Message MinValue in Validation Summary
|
|
42
|
+
*/
|
|
43
|
+
this.validationmessagesummaryminvalue = 'VALIDATION_ERROR_SUMMARY_MINVALUE';
|
|
44
|
+
/**
|
|
45
|
+
* Resource Key für Validation Message Required in Validation Summary
|
|
46
|
+
*/
|
|
47
|
+
this.validationmessagesummaryrequired = 'VALIDATION_ERROR_SUMMARY_REQUIRED';
|
|
47
48
|
}
|
|
49
|
+
// #endregion Properties
|
|
50
|
+
// #region Public Methods
|
|
48
51
|
/**
|
|
49
|
-
* Methode
|
|
52
|
+
* Methode validiert ob der Wert entspricht den gegebenen Kriterien
|
|
50
53
|
*/
|
|
51
|
-
|
|
52
|
-
super.OnClassInit();
|
|
54
|
+
validateData(c) {
|
|
53
55
|
/**
|
|
54
|
-
*
|
|
56
|
+
* Error Meldung, die angezeigt wird, wenn die Kriterien nicht erfüllt sind
|
|
55
57
|
*/
|
|
56
|
-
|
|
57
|
-
if (this.
|
|
58
|
-
|
|
58
|
+
let error = null;
|
|
59
|
+
if (this.isrequired) {
|
|
60
|
+
error = Validation.required(this.validationmessagerequired, this.validationmessagesummaryrequired)(c);
|
|
61
|
+
}
|
|
62
|
+
if (error === null &&
|
|
63
|
+
this.minvalue !== undefined &&
|
|
64
|
+
this.minvalue !== null) {
|
|
65
|
+
error = Validation.minValue(this.minvalue, this.validationmessageminvalue, this.validationmessagesummaryminvalue)(c);
|
|
66
|
+
}
|
|
67
|
+
if (error === null &&
|
|
68
|
+
this.maxvalue !== undefined &&
|
|
69
|
+
this.maxvalue !== null) {
|
|
70
|
+
error = Validation.maxValue(this.maxvalue, this.validationmessagemaxvalue, this.validationmessagesummarymaxvalue)(c);
|
|
59
71
|
}
|
|
72
|
+
return error;
|
|
60
73
|
}
|
|
74
|
+
// #endregion Public Methods
|
|
75
|
+
// #region Protected Methods
|
|
61
76
|
/**
|
|
62
77
|
* Konvertiert den Wert des Inputs
|
|
63
78
|
*/
|
|
@@ -77,6 +92,19 @@ class SacInputDecimalCommon extends SacInputBase {
|
|
|
77
92
|
}
|
|
78
93
|
}
|
|
79
94
|
}
|
|
95
|
+
/**
|
|
96
|
+
* Methode die erzeugt den Control in Abhängigkeit davon, ob negative Were erlaubt sing oder nicht
|
|
97
|
+
*/
|
|
98
|
+
OnClassInit() {
|
|
99
|
+
super.OnClassInit();
|
|
100
|
+
/**
|
|
101
|
+
* Definiert die Werte die erlaubt sind
|
|
102
|
+
*/
|
|
103
|
+
this.allowedchars = '0123456789' + this.GetDecimalSymbol();
|
|
104
|
+
if (this.allownegativ) {
|
|
105
|
+
this.allowedchars = this.allowedchars + '-';
|
|
106
|
+
}
|
|
107
|
+
}
|
|
80
108
|
/**
|
|
81
109
|
* Methode validiert ob der Wert entspricht den gegebenen Kriterien wenn ein Key gedrückt wird
|
|
82
110
|
*/
|
|
@@ -100,52 +128,29 @@ class SacInputDecimalCommon extends SacInputBase {
|
|
|
100
128
|
return true;
|
|
101
129
|
}
|
|
102
130
|
}
|
|
103
|
-
/**
|
|
104
|
-
* Methode validiert ob der Wert entspricht den gegebenen Kriterien
|
|
105
|
-
*/
|
|
106
|
-
validateData(c) {
|
|
107
|
-
/**
|
|
108
|
-
* Error Meldung, die angezeigt wird, wenn die Kriterien nicht erfüllt sind
|
|
109
|
-
*/
|
|
110
|
-
let error = null;
|
|
111
|
-
if (this.isrequired) {
|
|
112
|
-
error = Validation.required(this.validationmessagerequired, this.validationmessagesummaryrequired)(c);
|
|
113
|
-
}
|
|
114
|
-
if (error === null &&
|
|
115
|
-
this.minvalue !== undefined &&
|
|
116
|
-
this.minvalue !== null) {
|
|
117
|
-
error = Validation.minValue(this.minvalue, this.validationmessageminvalue, this.validationmessagesummaryminvalue)(c);
|
|
118
|
-
}
|
|
119
|
-
if (error === null &&
|
|
120
|
-
this.maxvalue !== undefined &&
|
|
121
|
-
this.maxvalue !== null) {
|
|
122
|
-
error = Validation.maxValue(this.maxvalue, this.validationmessagemaxvalue, this.validationmessagesummarymaxvalue)(c);
|
|
123
|
-
}
|
|
124
|
-
return error;
|
|
125
|
-
}
|
|
126
131
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacInputDecimalCommon, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
127
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacInputDecimalCommon, inputs: { allownegativ: "allownegativ",
|
|
132
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacInputDecimalCommon, inputs: { allownegativ: "allownegativ", maxvalue: "maxvalue", minvalue: "minvalue", validationmessagemaxvalue: "validationmessagemaxvalue", validationmessageminvalue: "validationmessageminvalue", validationmessagerequired: "validationmessagerequired", validationmessagesummarymaxvalue: "validationmessagesummarymaxvalue", validationmessagesummaryminvalue: "validationmessagesummaryminvalue", validationmessagesummaryrequired: "validationmessagesummaryrequired" }, usesInheritance: true, ngImport: i0 }); }
|
|
128
133
|
}
|
|
129
134
|
export { SacInputDecimalCommon };
|
|
130
135
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacInputDecimalCommon, decorators: [{
|
|
131
136
|
type: Directive
|
|
132
137
|
}], propDecorators: { allownegativ: [{
|
|
133
138
|
type: Input
|
|
134
|
-
}], minvalue: [{
|
|
135
|
-
type: Input
|
|
136
139
|
}], maxvalue: [{
|
|
137
140
|
type: Input
|
|
138
|
-
}],
|
|
141
|
+
}], minvalue: [{
|
|
139
142
|
type: Input
|
|
140
|
-
}],
|
|
143
|
+
}], validationmessagemaxvalue: [{
|
|
141
144
|
type: Input
|
|
142
145
|
}], validationmessageminvalue: [{
|
|
143
146
|
type: Input
|
|
144
|
-
}],
|
|
145
|
-
type: Input
|
|
146
|
-
}], validationmessagemaxvalue: [{
|
|
147
|
+
}], validationmessagerequired: [{
|
|
147
148
|
type: Input
|
|
148
149
|
}], validationmessagesummarymaxvalue: [{
|
|
149
150
|
type: Input
|
|
151
|
+
}], validationmessagesummaryminvalue: [{
|
|
152
|
+
type: Input
|
|
153
|
+
}], validationmessagesummaryrequired: [{
|
|
154
|
+
type: Input
|
|
150
155
|
}] } });
|
|
151
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inputdecimal.js","sourceRoot":"","sources":["../../../../../projects/sac-common/src/controls/input/inputdecimal.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input } from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport { SacInputBase } from '../../common/baseinputcontrol';\r\nimport { Validation } from '../../validation';\r\n\r\n/**\r\n * Basis Komponente für SacInputDecimal\r\n */\r\n@Directive()\r\nexport class SacInputDecimalCommon extends SacInputBase<number> {\r\n  /**\r\n   * Definiert das Negative Werte erlaubt sind\r\n   */\r\n  @Input() allownegativ: boolean = false;\r\n  /**\r\n   * Definiert den minimalen Wert\r\n   */\r\n  @Input() minvalue: number = undefined;\r\n  /**\r\n   * Definiert den maximalen Wert\r\n   */\r\n  @Input() maxvalue: number = undefined;\r\n\r\n  /**\r\n   * Resource Key für Validation Message Required bei Control\r\n   */\r\n  @Input() validationmessagerequired: string = 'VALIDATION_ERROR_REQUIRED';\r\n  /**\r\n   * Resource Key für Validation Message Required in Validation Summary\r\n   */\r\n  @Input() validationmessagesummaryrequired: string =\r\n    'VALIDATION_ERROR_SUMMARY_REQUIRED';\r\n\r\n  /**\r\n   * Resource Key für Validation Message MinValue bei Control\r\n   */\r\n  @Input() validationmessageminvalue: string = 'VALIDATION_ERROR_MINVALUE';\r\n  /**\r\n   * Resource Key für Validation Message MinValue in Validation Summary\r\n   */\r\n  @Input() validationmessagesummaryminvalue: string =\r\n    'VALIDATION_ERROR_SUMMARY_MINVALUE';\r\n\r\n  /**\r\n   * Resource Key für Validation Message MaxValue bei Control\r\n   */\r\n  @Input() validationmessagemaxvalue: string = 'VALIDATION_ERROR_MAXVALUE';\r\n  /**\r\n   * Resource Key für Validation Message MaxValue in Validation Summary\r\n   */\r\n  @Input() validationmessagesummarymaxvalue: string =\r\n    'VALIDATION_ERROR_SUMMARY_MAXVALUE';\r\n\r\n  /**\r\n   * Methode die erzeugt den Control in Abhängigkeit davon, ob negative Were erlaubt sing oder nicht\r\n   */\r\n  protected OnClassInit(): void {\r\n    super.OnClassInit();\r\n\r\n    /**\r\n     * Definiert die Werte die erlaubt sind\r\n     */\r\n    this.allowedchars = '0123456789' + this.GetDecimalSymbol();\r\n\r\n    if (this.allownegativ) {\r\n      this.allowedchars = this.allowedchars + '-';\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Konvertiert den Wert des Inputs\r\n   */\r\n  protected ConvertInputValue(value: any): any {\r\n    if (value === '' || value === null) {\r\n      return null;\r\n    } else {\r\n      if (this.allownegativ === true && value === '-') {\r\n        return '-';\r\n      } else if (value === '.') {\r\n        return '0.';\r\n      } else {\r\n        return parseFloat(value);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Methode validiert ob der Wert entspricht den gegebenen Kriterien wenn ein Key gedrückt wird\r\n   */\r\n  protected OnKeyPressValidation(position: number, character: string): boolean {\r\n    if (\r\n      (this.allownegativ === false && character === '-') ||\r\n      (this.allownegativ === true && position > 0 && character === '-')\r\n    ) {\r\n      return false;\r\n    }\r\n\r\n    // Verhindern von Doppelpunkt Eingabe (45..545)\r\n    if (\r\n      this._value !== null &&\r\n      this._value.toString().length < position &&\r\n      character === '.'\r\n    ) {\r\n      return false;\r\n    }\r\n\r\n    if (\r\n      character === this.GetDecimalSymbol() &&\r\n      this._value !== null &&\r\n      this._value.toString().indexOf(this.GetDecimalSymbol()) >= 0\r\n    ) {\r\n      return false;\r\n    } else {\r\n      return true;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Methode validiert ob der Wert entspricht den gegebenen Kriterien\r\n   */\r\n  validateData(c: AbstractControl): ValidationErrors | null {\r\n    /**\r\n     * Error Meldung, die angezeigt wird, wenn die Kriterien nicht erfüllt sind\r\n     */\r\n    let error: ValidationErrors | null = null;\r\n\r\n    if (this.isrequired) {\r\n      error = Validation.required(\r\n        this.validationmessagerequired,\r\n        this.validationmessagesummaryrequired\r\n      )(c);\r\n    }\r\n\r\n    if (\r\n      error === null &&\r\n      this.minvalue !== undefined &&\r\n      this.minvalue !== null\r\n    ) {\r\n      error = Validation.minValue(\r\n        this.minvalue,\r\n        this.validationmessageminvalue,\r\n        this.validationmessagesummaryminvalue\r\n      )(c);\r\n    }\r\n\r\n    if (\r\n      error === null &&\r\n      this.maxvalue !== undefined &&\r\n      this.maxvalue !== null\r\n    ) {\r\n      error = Validation.maxValue(\r\n        this.maxvalue,\r\n        this.validationmessagemaxvalue,\r\n        this.validationmessagesummarymaxvalue\r\n      )(c);\r\n    }\r\n\r\n    return error;\r\n  }\r\n}\r\n"]}
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inputdecimal.js","sourceRoot":"","sources":["../../../../../projects/sac-common/src/controls/input/inputdecimal.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input } from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport { SacInputBase } from '../../common/baseinputcontrol';\r\nimport { Validation } from '../../validation';\r\n\r\n/**\r\n * Basis Komponente für SacInputDecimal\r\n */\r\n@Directive()\r\nexport class SacInputDecimalCommon extends SacInputBase<number> {\r\n  // #region Properties\r\n\r\n  /**\r\n   * Definiert das Negative Werte erlaubt sind\r\n   */\r\n  @Input() public allownegativ: boolean = false;\r\n  /**\r\n   * Definiert den maximalen Wert\r\n   */\r\n  @Input() public maxvalue: number = undefined;\r\n  /**\r\n   * Definiert den minimalen Wert\r\n   */\r\n  @Input() public minvalue: number = undefined;\r\n  /**\r\n   * Resource Key für Validation Message MaxValue bei Control\r\n   */\r\n  @Input() public validationmessagemaxvalue: string =\r\n    'VALIDATION_ERROR_MAXVALUE';\r\n  /**\r\n   * Resource Key für Validation Message MinValue bei Control\r\n   */\r\n  @Input() public validationmessageminvalue: string =\r\n    'VALIDATION_ERROR_MINVALUE';\r\n  /**\r\n   * Resource Key für Validation Message Required bei Control\r\n   */\r\n  @Input() public validationmessagerequired: string =\r\n    'VALIDATION_ERROR_REQUIRED';\r\n  /**\r\n   * Resource Key für Validation Message MaxValue in Validation Summary\r\n   */\r\n  @Input() public validationmessagesummarymaxvalue: string =\r\n    'VALIDATION_ERROR_SUMMARY_MAXVALUE';\r\n  /**\r\n   * Resource Key für Validation Message MinValue in Validation Summary\r\n   */\r\n  @Input() public validationmessagesummaryminvalue: string =\r\n    'VALIDATION_ERROR_SUMMARY_MINVALUE';\r\n  /**\r\n   * Resource Key für Validation Message Required in Validation Summary\r\n   */\r\n  @Input() public validationmessagesummaryrequired: string =\r\n    'VALIDATION_ERROR_SUMMARY_REQUIRED';\r\n\r\n  // #endregion Properties\r\n\r\n  // #region Public Methods\r\n\r\n  /**\r\n   * Methode validiert ob der Wert entspricht den gegebenen Kriterien\r\n   */\r\n  public validateData(c: AbstractControl): ValidationErrors | null {\r\n    /**\r\n     * Error Meldung, die angezeigt wird, wenn die Kriterien nicht erfüllt sind\r\n     */\r\n    let error: ValidationErrors | null = null;\r\n\r\n    if (this.isrequired) {\r\n      error = Validation.required(\r\n        this.validationmessagerequired,\r\n        this.validationmessagesummaryrequired\r\n      )(c);\r\n    }\r\n\r\n    if (\r\n      error === null &&\r\n      this.minvalue !== undefined &&\r\n      this.minvalue !== null\r\n    ) {\r\n      error = Validation.minValue(\r\n        this.minvalue,\r\n        this.validationmessageminvalue,\r\n        this.validationmessagesummaryminvalue\r\n      )(c);\r\n    }\r\n\r\n    if (\r\n      error === null &&\r\n      this.maxvalue !== undefined &&\r\n      this.maxvalue !== null\r\n    ) {\r\n      error = Validation.maxValue(\r\n        this.maxvalue,\r\n        this.validationmessagemaxvalue,\r\n        this.validationmessagesummarymaxvalue\r\n      )(c);\r\n    }\r\n\r\n    return error;\r\n  }\r\n\r\n  // #endregion Public Methods\r\n\r\n  // #region Protected Methods\r\n\r\n  /**\r\n   * Konvertiert den Wert des Inputs\r\n   */\r\n  protected ConvertInputValue(value: any): any {\r\n    if (value === '' || value === null) {\r\n      return null;\r\n    } else {\r\n      if (this.allownegativ === true && value === '-') {\r\n        return '-';\r\n      } else if (value === '.') {\r\n        return '0.';\r\n      } else {\r\n        return parseFloat(value);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Methode die erzeugt den Control in Abhängigkeit davon, ob negative Were erlaubt sing oder nicht\r\n   */\r\n  protected OnClassInit(): void {\r\n    super.OnClassInit();\r\n\r\n    /**\r\n     * Definiert die Werte die erlaubt sind\r\n     */\r\n    this.allowedchars = '0123456789' + this.GetDecimalSymbol();\r\n\r\n    if (this.allownegativ) {\r\n      this.allowedchars = this.allowedchars + '-';\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Methode validiert ob der Wert entspricht den gegebenen Kriterien wenn ein Key gedrückt wird\r\n   */\r\n  protected OnKeyPressValidation(position: number, character: string): boolean {\r\n    if (\r\n      (this.allownegativ === false && character === '-') ||\r\n      (this.allownegativ === true && position > 0 && character === '-')\r\n    ) {\r\n      return false;\r\n    }\r\n\r\n    // Verhindern von Doppelpunkt Eingabe (45..545)\r\n    if (\r\n      this._value !== null &&\r\n      this._value.toString().length < position &&\r\n      character === '.'\r\n    ) {\r\n      return false;\r\n    }\r\n\r\n    if (\r\n      character === this.GetDecimalSymbol() &&\r\n      this._value !== null &&\r\n      this._value.toString().indexOf(this.GetDecimalSymbol()) >= 0\r\n    ) {\r\n      return false;\r\n    } else {\r\n      return true;\r\n    }\r\n  }\r\n\r\n  // #endregion Protected Methods\r\n}\r\n"]}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
/***
|
|
4
|
+
* base component for form options
|
|
5
|
+
*/
|
|
6
|
+
class SacFormLayoutCommon {
|
|
7
|
+
constructor() {
|
|
8
|
+
// #region Properties
|
|
9
|
+
/**
|
|
10
|
+
* defines that error messages are displayed under the controls
|
|
11
|
+
*/
|
|
12
|
+
this.inlineError = true;
|
|
13
|
+
/**
|
|
14
|
+
* defines that the labels are displayed as adaptive labels
|
|
15
|
+
*/
|
|
16
|
+
this.isAdaptiveLabel = false;
|
|
17
|
+
/**
|
|
18
|
+
* default label size for medium devices
|
|
19
|
+
*/
|
|
20
|
+
this.labelSizeMd = null;
|
|
21
|
+
/**
|
|
22
|
+
* default label size for small devices
|
|
23
|
+
*/
|
|
24
|
+
this.labelSizeSm = null;
|
|
25
|
+
/**
|
|
26
|
+
* default label column size
|
|
27
|
+
*/
|
|
28
|
+
this.labelSizeXs = null;
|
|
29
|
+
/**
|
|
30
|
+
* default label size for extra extra large devices
|
|
31
|
+
*/
|
|
32
|
+
this.labelSizeXxl = null;
|
|
33
|
+
/**
|
|
34
|
+
* default labe size for large devices
|
|
35
|
+
*/
|
|
36
|
+
this.labelSizeLg = null;
|
|
37
|
+
/**
|
|
38
|
+
* default label size for extra large devices
|
|
39
|
+
*/
|
|
40
|
+
this.labelSizeXl = null;
|
|
41
|
+
}
|
|
42
|
+
// #endregion Properties
|
|
43
|
+
// #region Public Getters And Setters
|
|
44
|
+
/**
|
|
45
|
+
* Returns whether the inline error messages for the form are active.
|
|
46
|
+
*/
|
|
47
|
+
get IsInlineErrorEnabled() {
|
|
48
|
+
return this.inlineError !== false;
|
|
49
|
+
}
|
|
50
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacFormLayoutCommon, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
51
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacFormLayoutCommon, inputs: { inlineError: "inlineError", isAdaptiveLabel: "isAdaptiveLabel", labelSizeMd: "labelSizeMd", labelSizeSm: "labelSizeSm", labelSizeXs: "labelSizeXs", labelSizeXxl: "labelSizeXxl", labelSizeLg: "labelSizeLg", labelSizeXl: "labelSizeXl" }, ngImport: i0 }); }
|
|
52
|
+
}
|
|
53
|
+
export { SacFormLayoutCommon };
|
|
54
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacFormLayoutCommon, decorators: [{
|
|
55
|
+
type: Directive
|
|
56
|
+
}], propDecorators: { inlineError: [{
|
|
57
|
+
type: Input
|
|
58
|
+
}], isAdaptiveLabel: [{
|
|
59
|
+
type: Input
|
|
60
|
+
}], labelSizeMd: [{
|
|
61
|
+
type: Input
|
|
62
|
+
}], labelSizeSm: [{
|
|
63
|
+
type: Input
|
|
64
|
+
}], labelSizeXs: [{
|
|
65
|
+
type: Input
|
|
66
|
+
}], labelSizeXxl: [{
|
|
67
|
+
type: Input
|
|
68
|
+
}], labelSizeLg: [{
|
|
69
|
+
type: Input
|
|
70
|
+
}], labelSizeXl: [{
|
|
71
|
+
type: Input
|
|
72
|
+
}] } });
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWxheW91dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NhYy1jb21tb24vc3JjL2NvbnRyb2xzL2xheW91dC9mb3JtbGF5b3V0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUVqRDs7R0FFRztBQUNILE1BQ2EsbUJBQW1CO0lBRGhDO1FBRUUscUJBQXFCO1FBRXJCOztXQUVHO1FBQ2EsZ0JBQVcsR0FBWSxJQUFJLENBQUM7UUFDNUM7O1dBRUc7UUFDYSxvQkFBZSxHQUFZLEtBQUssQ0FBQztRQUNqRDs7V0FFRztRQUVJLGdCQUFXLEdBQWtCLElBQUksQ0FBQztRQUN6Qzs7V0FFRztRQUVJLGdCQUFXLEdBQWtCLElBQUksQ0FBQztRQUN6Qzs7V0FFRztRQUVJLGdCQUFXLEdBQWtCLElBQUksQ0FBQztRQUN6Qzs7V0FFRztRQUVJLGlCQUFZLEdBQWtCLElBQUksQ0FBQztRQUMxQzs7V0FFRztRQUVJLGdCQUFXLEdBQWtCLElBQUksQ0FBQztRQUN6Qzs7V0FFRztRQUVJLGdCQUFXLEdBQWtCLElBQUksQ0FBQztLQWMxQztJQVpDLHdCQUF3QjtJQUV4QixxQ0FBcUM7SUFFckM7O09BRUc7SUFDSCxJQUFXLG9CQUFvQjtRQUM3QixPQUFPLElBQUksQ0FBQyxXQUFXLEtBQUssS0FBSyxDQUFDO0lBQ3BDLENBQUM7K0dBbkRVLG1CQUFtQjttR0FBbkIsbUJBQW1COztTQUFuQixtQkFBbUI7NEZBQW5CLG1CQUFtQjtrQkFEL0IsU0FBUzs4QkFPUSxXQUFXO3NCQUExQixLQUFLO2dCQUlVLGVBQWU7c0JBQTlCLEtBQUs7Z0JBS0MsV0FBVztzQkFEakIsS0FBSztnQkFNQyxXQUFXO3NCQURqQixLQUFLO2dCQU1DLFdBQVc7c0JBRGpCLEtBQUs7Z0JBTUMsWUFBWTtzQkFEbEIsS0FBSztnQkFNQyxXQUFXO3NCQURqQixLQUFLO2dCQU1DLFdBQVc7c0JBRGpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG4vKioqXHJcbiAqIGJhc2UgY29tcG9uZW50IGZvciBmb3JtIG9wdGlvbnNcclxuICovXHJcbkBEaXJlY3RpdmUoKVxyXG5leHBvcnQgY2xhc3MgU2FjRm9ybUxheW91dENvbW1vbiB7XHJcbiAgLy8gI3JlZ2lvbiBQcm9wZXJ0aWVzXHJcblxyXG4gIC8qKlxyXG4gICAqIGRlZmluZXMgdGhhdCBlcnJvciBtZXNzYWdlcyBhcmUgZGlzcGxheWVkIHVuZGVyIHRoZSBjb250cm9sc1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHB1YmxpYyBpbmxpbmVFcnJvcjogYm9vbGVhbiA9IHRydWU7XHJcbiAgLyoqXHJcbiAgICogZGVmaW5lcyB0aGF0IHRoZSBsYWJlbHMgYXJlIGRpc3BsYXllZCBhcyBhZGFwdGl2ZSBsYWJlbHNcclxuICAgKi9cclxuICBASW5wdXQoKSBwdWJsaWMgaXNBZGFwdGl2ZUxhYmVsOiBib29sZWFuID0gZmFsc2U7XHJcbiAgLyoqXHJcbiAgICogZGVmYXVsdCBsYWJlbCBzaXplIGZvciBtZWRpdW0gZGV2aWNlc1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGxhYmVsU2l6ZU1kOiBudW1iZXIgfCBudWxsID0gbnVsbDtcclxuICAvKipcclxuICAgKiBkZWZhdWx0IGxhYmVsIHNpemUgZm9yIHNtYWxsIGRldmljZXNcclxuICAgKi9cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBsYWJlbFNpemVTbTogbnVtYmVyIHwgbnVsbCA9IG51bGw7XHJcbiAgLyoqXHJcbiAgICogZGVmYXVsdCBsYWJlbCBjb2x1bW4gc2l6ZVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGxhYmVsU2l6ZVhzOiBudW1iZXIgfCBudWxsID0gbnVsbDtcclxuICAvKipcclxuICAgKiBkZWZhdWx0IGxhYmVsIHNpemUgZm9yIGV4dHJhIGV4dHJhIGxhcmdlIGRldmljZXNcclxuICAgKi9cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBsYWJlbFNpemVYeGw6IG51bWJlciB8IG51bGwgPSBudWxsO1xyXG4gIC8qKlxyXG4gICAqIGRlZmF1bHQgbGFiZSBzaXplIGZvciBsYXJnZSBkZXZpY2VzXHJcbiAgICovXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgbGFiZWxTaXplTGc6IG51bWJlciB8IG51bGwgPSBudWxsO1xyXG4gIC8qKlxyXG4gICAqIGRlZmF1bHQgbGFiZWwgc2l6ZSBmb3IgZXh0cmEgbGFyZ2UgZGV2aWNlc1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGxhYmVsU2l6ZVhsOiBudW1iZXIgfCBudWxsID0gbnVsbDtcclxuXHJcbiAgLy8gI2VuZHJlZ2lvbiBQcm9wZXJ0aWVzXHJcblxyXG4gIC8vICNyZWdpb24gUHVibGljIEdldHRlcnMgQW5kIFNldHRlcnNcclxuXHJcbiAgLyoqXHJcbiAgICogUmV0dXJucyB3aGV0aGVyIHRoZSBpbmxpbmUgZXJyb3IgbWVzc2FnZXMgZm9yIHRoZSBmb3JtIGFyZSBhY3RpdmUuXHJcbiAgICovXHJcbiAgcHVibGljIGdldCBJc0lubGluZUVycm9yRW5hYmxlZCgpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0aGlzLmlubGluZUVycm9yICE9PSBmYWxzZTtcclxuICB9XHJcblxyXG4gIC8vICNlbmRyZWdpb24gUHVibGljIEdldHRlcnMgQW5kIFNldHRlcnNcclxufVxyXG4iXX0=
|
|
@@ -2,56 +2,26 @@ import { Directive, Host, Input, } from '@angular/core';
|
|
|
2
2
|
import { SacBaseSelectControl } from '../../common/baseselectcontrol';
|
|
3
3
|
import { Validation } from '../../validation';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "../
|
|
6
|
-
|
|
7
|
-
* Function um ein Key Value Pair für das Dropdown zu erzeugen
|
|
8
|
-
* @param id ID
|
|
9
|
-
* @param value Wert der an das Element gebunden werden soll
|
|
10
|
-
*/
|
|
11
|
-
export function _buildValueString(id, value) {
|
|
12
|
-
// Wenn ID null ist Object zurückgeben
|
|
13
|
-
if (id == null) {
|
|
14
|
-
return `${value}`;
|
|
15
|
-
}
|
|
16
|
-
// Mapping Objekt zu String
|
|
17
|
-
if (value && typeof value === 'object') {
|
|
18
|
-
value = 'Object';
|
|
19
|
-
}
|
|
20
|
-
// String als ID
|
|
21
|
-
return `${id}: ${value}`.slice(0, 50);
|
|
22
|
-
}
|
|
5
|
+
import * as i1 from "../layout/formlayout";
|
|
6
|
+
// #region Classes
|
|
23
7
|
/**
|
|
24
8
|
* Base Dropdown Komponente
|
|
25
9
|
*/
|
|
26
10
|
class SacDropdownCommon extends SacBaseSelectControl {
|
|
11
|
+
// #endregion Properties
|
|
12
|
+
// #region Constructors
|
|
27
13
|
/**
|
|
28
|
-
*
|
|
14
|
+
* Constructor
|
|
15
|
+
* @param formlayout SacFormLayoutCommon to define scoped layout settings
|
|
16
|
+
* @param injector Injector for injecting services
|
|
17
|
+
* @param renderer html rendering engine
|
|
18
|
+
* @param elementRef reference to html element
|
|
29
19
|
*/
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
}
|
|
36
|
-
/**
|
|
37
|
-
* Konstruktor
|
|
38
|
-
* @param parent Übergeordnetes HTML Element
|
|
39
|
-
* @param injector Injector für Services
|
|
40
|
-
* @param _renderer Render Engine
|
|
41
|
-
* @param _elementRef Referenz von HTML Element
|
|
42
|
-
*/
|
|
43
|
-
constructor(parent, injector, _renderer, _elementRef) {
|
|
44
|
-
super(parent, injector);
|
|
45
|
-
this._renderer = _renderer;
|
|
46
|
-
this._elementRef = _elementRef;
|
|
47
|
-
/**
|
|
48
|
-
* Counter vom OptionID; default Wert = 0
|
|
49
|
-
*/
|
|
50
|
-
this._optionIdCounter = 0;
|
|
51
|
-
/**
|
|
52
|
-
* OptionMap
|
|
53
|
-
*/
|
|
54
|
-
this._optionMap = new Map();
|
|
20
|
+
constructor(formlayout, injector, renderer, elementRef) {
|
|
21
|
+
super(formlayout, injector);
|
|
22
|
+
this.renderer = renderer;
|
|
23
|
+
this.elementRef = elementRef;
|
|
24
|
+
// #region Properties
|
|
55
25
|
/**
|
|
56
26
|
* compareWith-Funktion
|
|
57
27
|
*/
|
|
@@ -72,22 +42,28 @@ class SacDropdownCommon extends SacBaseSelectControl {
|
|
|
72
42
|
* Resource Key für Validation Message Required in Validation Summary
|
|
73
43
|
*/
|
|
74
44
|
this.validationmessagesummaryrequired = 'VALIDATION_ERROR_SUMMARY_REQUIRED';
|
|
45
|
+
/**
|
|
46
|
+
* Counter vom OptionID; default Wert = 0
|
|
47
|
+
*/
|
|
48
|
+
this._optionIdCounter = 0;
|
|
49
|
+
/**
|
|
50
|
+
* OptionMap
|
|
51
|
+
*/
|
|
52
|
+
this._optionMap = new Map();
|
|
75
53
|
}
|
|
54
|
+
// #endregion Constructors
|
|
55
|
+
// #region Public Getters And Setters
|
|
76
56
|
/**
|
|
77
|
-
*
|
|
78
|
-
* @param value - Wert
|
|
79
|
-
*/
|
|
80
|
-
setValue(value) {
|
|
81
|
-
super.setValue(this.getOptionValue(value));
|
|
82
|
-
}
|
|
83
|
-
/**
|
|
84
|
-
* Wert schreiben
|
|
85
|
-
* @param value - Wert
|
|
57
|
+
* compareWith-Funktion
|
|
86
58
|
*/
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
59
|
+
set comparewith(fn) {
|
|
60
|
+
if (typeof fn !== 'function') {
|
|
61
|
+
throw new Error(`compareWith must be a function, but received ${JSON.stringify(fn)}`);
|
|
62
|
+
}
|
|
63
|
+
this._compareWith = fn;
|
|
90
64
|
}
|
|
65
|
+
// #endregion Public Getters And Setters
|
|
66
|
+
// #region Public Methods
|
|
91
67
|
/**
|
|
92
68
|
* Registriert das OptionID-Counter als String
|
|
93
69
|
*/
|
|
@@ -107,23 +83,39 @@ class SacDropdownCommon extends SacBaseSelectControl {
|
|
|
107
83
|
}
|
|
108
84
|
}
|
|
109
85
|
/**
|
|
110
|
-
*
|
|
111
|
-
* @param value
|
|
86
|
+
* Wert einstellen
|
|
87
|
+
* @param value - Wert
|
|
112
88
|
*/
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
if (selectItem !== undefined) {
|
|
125
|
-
this._renderer.setProperty(selectItem, 'value', valueString);
|
|
89
|
+
setValue(value) {
|
|
90
|
+
super.setValue(this.getOptionValue(value));
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Validator
|
|
94
|
+
* @param c Control Instanz
|
|
95
|
+
*/
|
|
96
|
+
validateData(c) {
|
|
97
|
+
let error = null;
|
|
98
|
+
if (this.isrequired) {
|
|
99
|
+
error = Validation.required(this.validationmessagerequired, this.validationmessagesummaryrequired)(c);
|
|
126
100
|
}
|
|
101
|
+
return error;
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Wert schreiben
|
|
105
|
+
* @param value - Wert
|
|
106
|
+
*/
|
|
107
|
+
writeValue(value) {
|
|
108
|
+
this.setSelectedValue(value);
|
|
109
|
+
super.writeValue(value);
|
|
110
|
+
}
|
|
111
|
+
// #endregion Public Methods
|
|
112
|
+
// #region Private Methods
|
|
113
|
+
/**
|
|
114
|
+
* ID extrahieren
|
|
115
|
+
* @param valueString String bei welchem die ID Extrahiert werden soll
|
|
116
|
+
*/
|
|
117
|
+
extractId(valueString) {
|
|
118
|
+
return valueString.split(':')[0];
|
|
127
119
|
}
|
|
128
120
|
/**
|
|
129
121
|
* Nimmt das ID vom Option
|
|
@@ -146,46 +138,49 @@ class SacDropdownCommon extends SacBaseSelectControl {
|
|
|
146
138
|
return this._optionMap.has(id) ? this._optionMap.get(id) : valueString;
|
|
147
139
|
}
|
|
148
140
|
/**
|
|
149
|
-
*
|
|
150
|
-
* @param
|
|
151
|
-
*/
|
|
152
|
-
extractId(valueString) {
|
|
153
|
-
return valueString.split(':')[0];
|
|
154
|
-
}
|
|
155
|
-
/**
|
|
156
|
-
* Validator
|
|
157
|
-
* @param c Control Instanz
|
|
141
|
+
* Setzt den Selected Value auf dem Control
|
|
142
|
+
* @param value Value
|
|
158
143
|
*/
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
144
|
+
setSelectedValue(value) {
|
|
145
|
+
// Select Item aus Control lesen
|
|
146
|
+
const selectItem = this.elementRef.nativeElement.getElementsByTagName('select')[0];
|
|
147
|
+
/**
|
|
148
|
+
* Id vom Select Item
|
|
149
|
+
*/
|
|
150
|
+
const id = this.getOptionId(value);
|
|
151
|
+
/**
|
|
152
|
+
* Value String
|
|
153
|
+
*/
|
|
154
|
+
const valueString = _buildValueString(id, value);
|
|
155
|
+
if (selectItem !== undefined) {
|
|
156
|
+
this.renderer.setProperty(selectItem, 'value', valueString);
|
|
163
157
|
}
|
|
164
|
-
return error;
|
|
165
158
|
}
|
|
166
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacDropdownCommon, deps: [{ token: i1.
|
|
167
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacDropdownCommon, inputs: { emptylabel: "emptylabel", emptyvalue: "emptyvalue",
|
|
159
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacDropdownCommon, deps: [{ token: i1.SacFormLayoutCommon, host: true }, { token: i0.Injector }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
160
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacDropdownCommon, inputs: { emptylabel: "emptylabel", emptyvalue: "emptyvalue", validationmessagerequired: "validationmessagerequired", validationmessagesummaryrequired: "validationmessagesummaryrequired", comparewith: "comparewith" }, usesInheritance: true, ngImport: i0 }); }
|
|
168
161
|
}
|
|
169
162
|
export { SacDropdownCommon };
|
|
170
163
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacDropdownCommon, decorators: [{
|
|
171
164
|
type: Directive
|
|
172
|
-
}], ctorParameters: function () { return [{ type: i1.
|
|
165
|
+
}], ctorParameters: function () { return [{ type: i1.SacFormLayoutCommon, decorators: [{
|
|
173
166
|
type: Host
|
|
174
167
|
}] }, { type: i0.Injector }, { type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { emptylabel: [{
|
|
175
168
|
type: Input
|
|
176
169
|
}], emptyvalue: [{
|
|
177
170
|
type: Input
|
|
178
|
-
}], comparewith: [{
|
|
179
|
-
type: Input
|
|
180
171
|
}], validationmessagerequired: [{
|
|
181
172
|
type: Input
|
|
182
173
|
}], validationmessagesummaryrequired: [{
|
|
183
174
|
type: Input
|
|
175
|
+
}], comparewith: [{
|
|
176
|
+
type: Input
|
|
184
177
|
}] } });
|
|
185
178
|
/**
|
|
186
179
|
* SacDropdownOption-Klasse
|
|
187
180
|
*/
|
|
188
181
|
class SacDropdownOptionCommon {
|
|
182
|
+
// #endregion Properties
|
|
183
|
+
// #region Constructors
|
|
189
184
|
/**
|
|
190
185
|
* Konstruktor
|
|
191
186
|
* @param _element Referenz auf HTML Element
|
|
@@ -196,6 +191,7 @@ class SacDropdownOptionCommon {
|
|
|
196
191
|
this._element = _element;
|
|
197
192
|
this._renderer = _renderer;
|
|
198
193
|
this._dropdown = _dropdown;
|
|
194
|
+
// #region Properties
|
|
199
195
|
/**
|
|
200
196
|
* ID-String
|
|
201
197
|
*/
|
|
@@ -204,6 +200,8 @@ class SacDropdownOptionCommon {
|
|
|
204
200
|
this.id = this._dropdown.registerOption();
|
|
205
201
|
}
|
|
206
202
|
}
|
|
203
|
+
// #endregion Constructors
|
|
204
|
+
// #region Public Getters And Setters
|
|
207
205
|
/**
|
|
208
206
|
* Option ngValue
|
|
209
207
|
*/
|
|
@@ -222,6 +220,8 @@ class SacDropdownOptionCommon {
|
|
|
222
220
|
set value(value) {
|
|
223
221
|
this._setElementValue(value);
|
|
224
222
|
}
|
|
223
|
+
// #endregion Public Getters And Setters
|
|
224
|
+
// #region Public Methods
|
|
225
225
|
/**
|
|
226
226
|
* Den Wert vom Option-Element einstellen
|
|
227
227
|
* @param value Wert
|
|
@@ -248,4 +248,23 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
248
248
|
}], value: [{
|
|
249
249
|
type: Input
|
|
250
250
|
}] } });
|
|
251
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.js","sourceRoot":"","sources":["../../../../../projects/sac-common/src/controls/list/dropdown.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  Host,\r\n  Injector,\r\n  Input,\r\n  OnDestroy,\r\n  Renderer2,\r\n} from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport { SacBaseSelectControl } from '../../common/baseselectcontrol';\r\nimport { Validation } from '../../validation';\r\nimport { SacFormCommon } from '../form/form';\r\n\r\n/**\r\n * Function um ein Key Value Pair für das Dropdown zu erzeugen\r\n * @param id ID\r\n * @param value Wert der an das Element gebunden werden soll\r\n */\r\nexport function _buildValueString(id: string | null, value: any): string {\r\n  // Wenn ID null ist Object zurückgeben\r\n  if (id == null) {\r\n    return `${value}`;\r\n  }\r\n\r\n  // Mapping Objekt zu String\r\n  if (value && typeof value === 'object') {\r\n    value = 'Object';\r\n  }\r\n\r\n  // String als ID\r\n  return `${id}: ${value}`.slice(0, 50);\r\n}\r\n\r\n/**\r\n * Base Dropdown Komponente\r\n */\r\n@Directive()\r\nexport class SacDropdownCommon extends SacBaseSelectControl<any> {\r\n  /**\r\n   * Counter vom OptionID; default Wert = 0\r\n   */\r\n  _optionIdCounter: number = 0;\r\n  /**\r\n   * OptionMap\r\n   */\r\n  _optionMap: Map<string, any> = new Map<string, any>();\r\n  /**\r\n   * compareWith-Funktion\r\n   */\r\n  private _compareWith: (o1: any, o2: any) => boolean = Object.is;\r\n\r\n  /**\r\n   * Label Text für Empty Item\r\n   */\r\n  @Input() emptylabel: string = '';\r\n  /**\r\n   * Option Value für Empty Item\r\n   */\r\n  @Input() emptyvalue: string = null;\r\n  /**\r\n   * compareWith-Funktion\r\n   */\r\n  @Input()\r\n  set comparewith(fn: (o1: any, o2: any) => boolean) {\r\n    if (typeof fn !== 'function') {\r\n      throw new Error(\r\n        `compareWith must be a function, but received ${JSON.stringify(fn)}`\r\n      );\r\n    }\r\n    this._compareWith = fn;\r\n  }\r\n\r\n  /**\r\n   * Resource Key für Validation Message Required bei Control\r\n   */\r\n  @Input() validationmessagerequired: string = 'VALIDATION_ERROR_REQUIRED';\r\n  /**\r\n   * Resource Key für Validation Message Required in Validation Summary\r\n   */\r\n  @Input()\r\n  validationmessagesummaryrequired: string =\r\n    'VALIDATION_ERROR_SUMMARY_REQUIRED';\r\n\r\n  /**\r\n   * Konstruktor\r\n   * @param parent Übergeordnetes HTML Element\r\n   * @param injector Injector für Services\r\n   * @param _renderer Render Engine\r\n   * @param _elementRef Referenz von HTML Element\r\n   */\r\n  constructor(\r\n    @Host() parent: SacFormCommon,\r\n    injector: Injector,\r\n    private _renderer: Renderer2,\r\n    private _elementRef: ElementRef\r\n  ) {\r\n    super(parent, injector);\r\n  }\r\n\r\n  /**\r\n   * Wert einstellen\r\n   * @param value - Wert\r\n   */\r\n  setValue(value: string) {\r\n    super.setValue(this.getOptionValue(value));\r\n  }\r\n\r\n  /**\r\n   * Wert schreiben\r\n   * @param value - Wert\r\n   */\r\n  writeValue(value: any) {\r\n    this.setSelectedValue(value);\r\n    super.writeValue(value);\r\n  }\r\n  /**\r\n   * Registriert das OptionID-Counter als String\r\n   */\r\n  registerOption(): string {\r\n    return (this._optionIdCounter++).toString();\r\n  }\r\n\r\n  /**\r\n   * Methode die von Options aufgerufen wird, um das Mapping zwischen Dropdown Value und Value herzustellen.\r\n   * @param id: Id aus Options\r\n   * @param value: Value\r\n   */\r\n  public setOptionMap(id: string, value: any): void {\r\n    this._optionMap.set(id, value);\r\n\r\n    // Selected Value auf Control aktualisieren, wenn Value dem SelectedValue entspricht\r\n    if (this.value === value) {\r\n      this.setSelectedValue(value);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Setzt den Selected Value auf dem Control\r\n   * @param value Value\r\n   */\r\n  private setSelectedValue(value: any): void {\r\n    // Select Item aus Control lesen\r\n    const selectItem: any =\r\n      this._elementRef.nativeElement.getElementsByTagName('select')[0];\r\n    /**\r\n     * Id vom Select Item\r\n     */\r\n    const id: string | null = this.getOptionId(value);\r\n    /**\r\n     * Value String\r\n     */\r\n    const valueString = _buildValueString(id, value);\r\n\r\n    if (selectItem !== undefined) {\r\n      this._renderer.setProperty(selectItem, 'value', valueString);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Nimmt das ID vom Option\r\n   * @param value\r\n   */\r\n  private getOptionId(value: any): string | null {\r\n    for (const id of Array.from(this._optionMap.keys())) {\r\n      if (this._compareWith(this._optionMap.get(id), value)) {\r\n        return id;\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n  /**\r\n   * Nimmt den String-Wert vom Option\r\n   * @param valueString\r\n   */\r\n  private getOptionValue(valueString: string): any {\r\n    const id: string = this.extractId(valueString);\r\n    return this._optionMap.has(id) ? this._optionMap.get(id) : valueString;\r\n  }\r\n  /**\r\n   * ID extrahieren\r\n   * @param valueString String bei welchem die ID Extrahiert werden soll\r\n   */\r\n  private extractId(valueString: string): string {\r\n    return valueString.split(':')[0];\r\n  }\r\n  /**\r\n   * Validator\r\n   * @param c Control Instanz\r\n   */\r\n  validateData(c: AbstractControl): ValidationErrors | null {\r\n    let error: ValidationErrors | null = null;\r\n\r\n    if (this.isrequired) {\r\n      error = Validation.required(\r\n        this.validationmessagerequired,\r\n        this.validationmessagesummaryrequired\r\n      )(c);\r\n    }\r\n    return error;\r\n  }\r\n}\r\n\r\n/**\r\n * SacDropdownOption-Klasse\r\n */\r\n@Directive()\r\nexport class SacDropdownOptionCommon implements OnDestroy {\r\n  /**\r\n   * ID-String\r\n   */\r\n  private id: string = null;\r\n  /**\r\n   * Konstruktor\r\n   * @param _element Referenz auf HTML Element\r\n   * @param _renderer Render Engine\r\n   * @param _dropdown Dropdown Instanz\r\n   */\r\n  constructor(\r\n    private _element: ElementRef,\r\n    private _renderer: Renderer2,\r\n    private _dropdown: SacDropdownCommon\r\n  ) {\r\n    if (this._dropdown) {\r\n      this.id = this._dropdown.registerOption();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Option ngValue\r\n   */\r\n  @Input()\r\n  set ngValue(value: any) {\r\n    // Cancel wenn kein Parent Dropdown vorhanden\r\n    if (this._dropdown == null) {\r\n      return;\r\n    }\r\n\r\n    this._dropdown.setOptionMap(this.id, value);\r\n    this._setElementValue(_buildValueString(this.id, value));\r\n\r\n    this._dropdown.writeValue(this._dropdown.value);\r\n  }\r\n  /**\r\n   * Wert-Setter\r\n   */\r\n  @Input()\r\n  set value(value: any) {\r\n    this._setElementValue(value);\r\n  }\r\n  /**\r\n   * Den Wert vom Option-Element einstellen\r\n   * @param value Wert\r\n   */\r\n  _setElementValue(value: string): void {\r\n    this._renderer.setProperty(this._element.nativeElement, 'value', value);\r\n  }\r\n  /**\r\n   * OnDestroy Event\r\n   */\r\n  ngOnDestroy(): void {\r\n    if (this._dropdown) {\r\n      this._dropdown._optionMap.delete(this.id);\r\n    }\r\n  }\r\n}\r\n"]}
|
|
251
|
+
// #endregion Classes
|
|
252
|
+
// #region Functions
|
|
253
|
+
/**
|
|
254
|
+
* Function um ein Key Value Pair für das Dropdown zu erzeugen
|
|
255
|
+
* @param id ID
|
|
256
|
+
* @param value Wert der an das Element gebunden werden soll
|
|
257
|
+
*/
|
|
258
|
+
export function _buildValueString(id, value) {
|
|
259
|
+
// Wenn ID null ist Object zurückgeben
|
|
260
|
+
if (id == null) {
|
|
261
|
+
return `${value}`;
|
|
262
|
+
}
|
|
263
|
+
// Mapping Objekt zu String
|
|
264
|
+
if (value && typeof value === 'object') {
|
|
265
|
+
value = 'Object';
|
|
266
|
+
}
|
|
267
|
+
// String als ID
|
|
268
|
+
return `${id}: ${value}`.slice(0, 50);
|
|
269
|
+
}
|
|
270
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.js","sourceRoot":"","sources":["../../../../../projects/sac-common/src/controls/list/dropdown.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  Host,\r\n  Injector,\r\n  Input,\r\n  OnDestroy,\r\n  Renderer2,\r\n} from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport { SacBaseSelectControl } from '../../common/baseselectcontrol';\r\nimport { Validation } from '../../validation';\r\nimport { SacFormLayoutCommon } from '../layout/formlayout';\r\n\r\n// #region Classes\r\n\r\n/**\r\n * Base Dropdown Komponente\r\n */\r\n@Directive()\r\nexport class SacDropdownCommon extends SacBaseSelectControl<any> {\r\n  // #region Properties\r\n\r\n  /**\r\n   * compareWith-Funktion\r\n   */\r\n  private _compareWith: (o1: any, o2: any) => boolean = Object.is;\r\n\r\n  /**\r\n   * Label Text für Empty Item\r\n   */\r\n  @Input() public emptylabel: string = '';\r\n  /**\r\n   * Option Value für Empty Item\r\n   */\r\n  @Input() public emptyvalue: string = null;\r\n  /**\r\n   * Resource Key für Validation Message Required bei Control\r\n   */\r\n  @Input() public validationmessagerequired: string =\r\n    'VALIDATION_ERROR_REQUIRED';\r\n  /**\r\n   * Resource Key für Validation Message Required in Validation Summary\r\n   */\r\n  @Input()\r\n  public validationmessagesummaryrequired: string =\r\n    'VALIDATION_ERROR_SUMMARY_REQUIRED';\r\n\r\n  /**\r\n   * Counter vom OptionID; default Wert = 0\r\n   */\r\n  public _optionIdCounter: number = 0;\r\n  /**\r\n   * OptionMap\r\n   */\r\n  public _optionMap: Map<string, any> = new Map<string, 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   * @param renderer html rendering engine\r\n   * @param elementRef reference to html element\r\n   */\r\n  constructor(\r\n    @Host() formlayout: SacFormLayoutCommon,\r\n    injector: Injector,\r\n    private renderer: Renderer2,\r\n    private 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   * compareWith-Funktion\r\n   */\r\n  @Input()\r\n  public set comparewith(fn: (o1: any, o2: any) => boolean) {\r\n    if (typeof fn !== 'function') {\r\n      throw new Error(\r\n        `compareWith must be a function, but received ${JSON.stringify(fn)}`\r\n      );\r\n    }\r\n    this._compareWith = fn;\r\n  }\r\n\r\n  // #endregion Public Getters And Setters\r\n\r\n  // #region Public Methods\r\n\r\n  /**\r\n   * Registriert das OptionID-Counter als String\r\n   */\r\n  public registerOption(): string {\r\n    return (this._optionIdCounter++).toString();\r\n  }\r\n\r\n  /**\r\n   * Methode die von Options aufgerufen wird, um das Mapping zwischen Dropdown Value und Value herzustellen.\r\n   * @param id: Id aus Options\r\n   * @param value: Value\r\n   */\r\n  public setOptionMap(id: string, value: any): void {\r\n    this._optionMap.set(id, value);\r\n\r\n    // Selected Value auf Control aktualisieren, wenn Value dem SelectedValue entspricht\r\n    if (this.value === value) {\r\n      this.setSelectedValue(value);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Wert einstellen\r\n   * @param value - Wert\r\n   */\r\n  public setValue(value: string) {\r\n    super.setValue(this.getOptionValue(value));\r\n  }\r\n\r\n  /**\r\n   * Validator\r\n   * @param c Control Instanz\r\n   */\r\n  public validateData(c: AbstractControl): ValidationErrors | null {\r\n    let error: ValidationErrors | null = null;\r\n\r\n    if (this.isrequired) {\r\n      error = Validation.required(\r\n        this.validationmessagerequired,\r\n        this.validationmessagesummaryrequired\r\n      )(c);\r\n    }\r\n    return error;\r\n  }\r\n\r\n  /**\r\n   * Wert schreiben\r\n   * @param value - Wert\r\n   */\r\n  public writeValue(value: any) {\r\n    this.setSelectedValue(value);\r\n    super.writeValue(value);\r\n  }\r\n\r\n  // #endregion Public Methods\r\n\r\n  // #region Private Methods\r\n\r\n  /**\r\n   * ID extrahieren\r\n   * @param valueString String bei welchem die ID Extrahiert werden soll\r\n   */\r\n  private extractId(valueString: string): string {\r\n    return valueString.split(':')[0];\r\n  }\r\n\r\n  /**\r\n   * Nimmt das ID vom Option\r\n   * @param value\r\n   */\r\n  private getOptionId(value: any): string | null {\r\n    for (const id of Array.from(this._optionMap.keys())) {\r\n      if (this._compareWith(this._optionMap.get(id), value)) {\r\n        return id;\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n  /**\r\n   * Nimmt den String-Wert vom Option\r\n   * @param valueString\r\n   */\r\n  private getOptionValue(valueString: string): any {\r\n    const id: string = this.extractId(valueString);\r\n    return this._optionMap.has(id) ? this._optionMap.get(id) : valueString;\r\n  }\r\n\r\n  /**\r\n   * Setzt den Selected Value auf dem Control\r\n   * @param value Value\r\n   */\r\n  private setSelectedValue(value: any): void {\r\n    // Select Item aus Control lesen\r\n    const selectItem: any =\r\n      this.elementRef.nativeElement.getElementsByTagName('select')[0];\r\n    /**\r\n     * Id vom Select Item\r\n     */\r\n    const id: string | null = this.getOptionId(value);\r\n    /**\r\n     * Value String\r\n     */\r\n    const valueString = _buildValueString(id, value);\r\n\r\n    if (selectItem !== undefined) {\r\n      this.renderer.setProperty(selectItem, 'value', valueString);\r\n    }\r\n  }\r\n\r\n  // #endregion Private Methods\r\n}\r\n\r\n/**\r\n * SacDropdownOption-Klasse\r\n */\r\n@Directive()\r\nexport class SacDropdownOptionCommon implements OnDestroy {\r\n  // #region Properties\r\n\r\n  /**\r\n   * ID-String\r\n   */\r\n  private id: string = null;\r\n\r\n  // #endregion Properties\r\n\r\n  // #region Constructors\r\n\r\n  /**\r\n   * Konstruktor\r\n   * @param _element Referenz auf HTML Element\r\n   * @param _renderer Render Engine\r\n   * @param _dropdown Dropdown Instanz\r\n   */\r\n  constructor(\r\n    private _element: ElementRef,\r\n    private _renderer: Renderer2,\r\n    private _dropdown: SacDropdownCommon\r\n  ) {\r\n    if (this._dropdown) {\r\n      this.id = this._dropdown.registerOption();\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   * Option ngValue\r\n   */\r\n  @Input()\r\n  public set ngValue(value: any) {\r\n    // Cancel wenn kein Parent Dropdown vorhanden\r\n    if (this._dropdown == null) {\r\n      return;\r\n    }\r\n\r\n    this._dropdown.setOptionMap(this.id, value);\r\n    this._setElementValue(_buildValueString(this.id, value));\r\n\r\n    this._dropdown.writeValue(this._dropdown.value);\r\n  }\r\n\r\n  /**\r\n   * Wert-Setter\r\n   */\r\n  @Input()\r\n  public set value(value: any) {\r\n    this._setElementValue(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   * Den Wert vom Option-Element einstellen\r\n   * @param value Wert\r\n   */\r\n  public _setElementValue(value: string): void {\r\n    this._renderer.setProperty(this._element.nativeElement, 'value', value);\r\n  }\r\n\r\n  /**\r\n   * OnDestroy Event\r\n   */\r\n  public ngOnDestroy(): void {\r\n    if (this._dropdown) {\r\n      this._dropdown._optionMap.delete(this.id);\r\n    }\r\n  }\r\n\r\n  // #endregion Public Methods\r\n}\r\n\r\n// #endregion Classes\r\n\r\n// #region Functions\r\n\r\n/**\r\n * Function um ein Key Value Pair für das Dropdown zu erzeugen\r\n * @param id ID\r\n * @param value Wert der an das Element gebunden werden soll\r\n */\r\nexport function _buildValueString(id: string | null, value: any): string {\r\n  // Wenn ID null ist Object zurückgeben\r\n  if (id == null) {\r\n    return `${value}`;\r\n  }\r\n\r\n  // Mapping Objekt zu String\r\n  if (value && typeof value === 'object') {\r\n    value = 'Object';\r\n  }\r\n\r\n  // String als ID\r\n  return `${id}: ${value}`.slice(0, 50);\r\n}\r\n\r\n// #endregion Functions\r\n"]}
|