@simpleangularcontrols/sac-common 16.0.0-rc.2 → 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.
Files changed (68) hide show
  1. package/common/basedatetimecontrol.d.ts +33 -33
  2. package/common/basedatetimecontrol.d.ts.map +1 -1
  3. package/common/baseinputcontrol.d.ts +9 -9
  4. package/common/baseinputcontrol.d.ts.map +1 -1
  5. package/common/basemodelcontrol.d.ts +117 -89
  6. package/common/basemodelcontrol.d.ts.map +1 -1
  7. package/common/baseuploadcontrol.d.ts +140 -140
  8. package/common/baseuploadcontrol.d.ts.map +1 -1
  9. package/controls/checkbox/checkbox.d.ts +7 -3
  10. package/controls/checkbox/checkbox.d.ts.map +1 -1
  11. package/controls/checkbox/radiobuttons.d.ts +5 -4
  12. package/controls/checkbox/radiobuttons.d.ts.map +1 -1
  13. package/controls/contextmenu/contextmenu.d.ts +42 -42
  14. package/controls/contextmenu/contextmenu.d.ts.map +1 -1
  15. package/controls/contextmenu/contextmenuanchor.d.ts +2 -2
  16. package/controls/contextmenu/contextmenuanchor.d.ts.map +1 -1
  17. package/controls/contextmenu/contextmenucontainer.d.ts +2 -2
  18. package/controls/contextmenu/contextmenucontainer.d.ts.map +1 -1
  19. package/controls/datetime/date.d.ts +7 -7
  20. package/controls/datetime/date.d.ts.map +1 -1
  21. package/controls/datetime/datetime.d.ts +7 -7
  22. package/controls/datetime/datetime.d.ts.map +1 -1
  23. package/controls/datetime/time.d.ts +7 -7
  24. package/controls/datetime/time.d.ts.map +1 -1
  25. package/controls/form/form.d.ts +7 -43
  26. package/controls/form/form.d.ts.map +1 -1
  27. package/controls/input/inputdecimal.d.ts +21 -21
  28. package/controls/input/inputdecimal.d.ts.map +1 -1
  29. package/controls/layout/formlayout.d.ts +45 -0
  30. package/controls/layout/formlayout.d.ts.map +1 -0
  31. package/controls/list/dropdown.d.ts +45 -45
  32. package/controls/list/dropdown.d.ts.map +1 -1
  33. package/controls/multilanguage/multilanguageinput.d.ts +5 -4
  34. package/controls/multilanguage/multilanguageinput.d.ts.map +1 -1
  35. package/controls/multilanguage/multilanguageinputarea.d.ts +5 -4
  36. package/controls/multilanguage/multilanguageinputarea.d.ts.map +1 -1
  37. package/controls/tinymce/tinymce.d.ts +63 -63
  38. package/controls/tinymce/tinymce.d.ts.map +1 -1
  39. package/esm2022/common/basedatetimecontrol.mjs +75 -81
  40. package/esm2022/common/baseinputcontrol.mjs +20 -20
  41. package/esm2022/common/basemodelcontrol.mjs +280 -201
  42. package/esm2022/common/baseuploadcontrol.mjs +225 -224
  43. package/esm2022/controls/checkbox/checkbox.mjs +11 -5
  44. package/esm2022/controls/checkbox/radiobuttons.mjs +13 -12
  45. package/esm2022/controls/contextmenu/contextmenu.mjs +85 -75
  46. package/esm2022/controls/contextmenu/contextmenuanchor.mjs +6 -4
  47. package/esm2022/controls/contextmenu/contextmenucontainer.mjs +6 -4
  48. package/esm2022/controls/datetime/date.mjs +12 -12
  49. package/esm2022/controls/datetime/datetime.mjs +15 -15
  50. package/esm2022/controls/datetime/time.mjs +15 -15
  51. package/esm2022/controls/form/form.mjs +26 -80
  52. package/esm2022/controls/input/inputdecimal.mjs +58 -53
  53. package/esm2022/controls/layout/formlayout.mjs +73 -0
  54. package/esm2022/controls/list/dropdown.mjs +110 -91
  55. package/esm2022/controls/multilanguage/multilanguageinput.mjs +10 -9
  56. package/esm2022/controls/multilanguage/multilanguageinputarea.mjs +10 -9
  57. package/esm2022/controls/tinymce/tinymce.mjs +102 -95
  58. package/esm2022/interfaces/ISacLabelSizes.mjs +2 -0
  59. package/esm2022/public_api.mjs +20 -18
  60. package/fesm2022/simpleangularcontrols-sac-common.mjs +1958 -1813
  61. package/fesm2022/simpleangularcontrols-sac-common.mjs.map +1 -1
  62. package/interfaces/ISacLabelSizes.d.ts +27 -0
  63. package/interfaces/ISacLabelSizes.d.ts.map +1 -0
  64. package/package.json +1 -1
  65. package/public_api.d.ts +19 -17
  66. package/public_api.d.ts.map +1 -1
  67. package/simpleangularcontrols-sac-common-16.0.0-rc.3.tgz +0 -0
  68. 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
- * Resource Key für Validation Message Required bei Control
21
+ * Definiert den minimalen Wert
25
22
  */
26
- this.validationmessagerequired = 'VALIDATION_ERROR_REQUIRED';
23
+ this.minvalue = undefined;
27
24
  /**
28
- * Resource Key für Validation Message Required in Validation Summary
25
+ * Resource Key für Validation Message MaxValue bei Control
29
26
  */
30
- this.validationmessagesummaryrequired = 'VALIDATION_ERROR_SUMMARY_REQUIRED';
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 MinValue in Validation Summary
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.validationmessagemaxvalue = 'VALIDATION_ERROR_MAXVALUE';
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 die erzeugt den Control in Abhängigkeit davon, ob negative Were erlaubt sing oder nicht
52
+ * Methode validiert ob der Wert entspricht den gegebenen Kriterien
50
53
  */
51
- OnClassInit() {
52
- super.OnClassInit();
54
+ validateData(c) {
53
55
  /**
54
- * Definiert die Werte die erlaubt sind
56
+ * Error Meldung, die angezeigt wird, wenn die Kriterien nicht erfüllt sind
55
57
  */
56
- this.allowedchars = '0123456789' + this.GetDecimalSymbol();
57
- if (this.allownegativ) {
58
- this.allowedchars = this.allowedchars + '-';
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", minvalue: "minvalue", maxvalue: "maxvalue", validationmessagerequired: "validationmessagerequired", validationmessagesummaryrequired: "validationmessagesummaryrequired", validationmessageminvalue: "validationmessageminvalue", validationmessagesummaryminvalue: "validationmessagesummaryminvalue", validationmessagemaxvalue: "validationmessagemaxvalue", validationmessagesummarymaxvalue: "validationmessagesummarymaxvalue" }, usesInheritance: true, ngImport: i0 }); }
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
- }], validationmessagerequired: [{
141
+ }], minvalue: [{
139
142
  type: Input
140
- }], validationmessagesummaryrequired: [{
143
+ }], validationmessagemaxvalue: [{
141
144
  type: Input
142
145
  }], validationmessageminvalue: [{
143
146
  type: Input
144
- }], validationmessagesummaryminvalue: [{
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 "../form/form";
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
- * compareWith-Funktion
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
- set comparewith(fn) {
31
- if (typeof fn !== 'function') {
32
- throw new Error(`compareWith must be a function, but received ${JSON.stringify(fn)}`);
33
- }
34
- this._compareWith = fn;
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
- * Wert einstellen
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
- writeValue(value) {
88
- this.setSelectedValue(value);
89
- super.writeValue(value);
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
- * Setzt den Selected Value auf dem Control
111
- * @param value Value
86
+ * Wert einstellen
87
+ * @param value - Wert
112
88
  */
113
- setSelectedValue(value) {
114
- // Select Item aus Control lesen
115
- const selectItem = this._elementRef.nativeElement.getElementsByTagName('select')[0];
116
- /**
117
- * Id vom Select Item
118
- */
119
- const id = this.getOptionId(value);
120
- /**
121
- * Value String
122
- */
123
- const valueString = _buildValueString(id, value);
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
- * ID extrahieren
150
- * @param valueString String bei welchem die ID Extrahiert werden soll
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
- validateData(c) {
160
- let error = null;
161
- if (this.isrequired) {
162
- error = Validation.required(this.validationmessagerequired, this.validationmessagesummaryrequired)(c);
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.SacFormCommon, host: true }, { token: i0.Injector }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
167
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacDropdownCommon, inputs: { emptylabel: "emptylabel", emptyvalue: "emptyvalue", comparewith: "comparewith", validationmessagerequired: "validationmessagerequired", validationmessagesummaryrequired: "validationmessagesummaryrequired" }, usesInheritance: true, ngImport: i0 }); }
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.SacFormCommon, decorators: [{
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"]}