@simpleangularcontrols/sac-common 10.0.0-rc.11 → 10.0.0-rc.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/simpleangularcontrols-sac-common.umd.js +1425 -1088
- package/bundles/simpleangularcontrols-sac-common.umd.js.map +1 -1
- package/bundles/simpleangularcontrols-sac-common.umd.min.js +1 -1
- package/bundles/simpleangularcontrols-sac-common.umd.min.js.map +1 -1
- package/common/basedatetimecontrol.d.ts +99 -13
- package/common/basemodelcontrol.d.ts +33 -29
- package/controls/checkbox/radiobutton.d.ts +61 -26
- package/controls/contextmenu/contextmenu.d.ts +26 -19
- package/controls/contextmenu/contextmenu.interface.d.ts +3 -0
- package/controls/contextmenu/contextmenuitem.d.ts +5 -0
- package/controls/contextmenu/contextmenuitembutton.d.ts +21 -20
- package/controls/datetime/date.d.ts +28 -27
- package/controls/datetime/datetime.d.ts +27 -27
- package/controls/datetime/time.d.ts +26 -26
- package/controls/dialog/dialog.d.ts +31 -43
- package/controls/layout/formlayout.d.ts +4 -0
- package/controls/list/buildvaluestring.d.ts +6 -0
- package/controls/list/dropdown.d.ts +9 -51
- package/controls/list/dropdownoptions.d.ts +38 -0
- package/controls/list/dropdownoptions.ngfactory.d.ts +1 -0
- package/controls/static/formcontainer.d.ts +11 -3
- package/controls/tooltip/tooltip.d.ts +33 -51
- package/controls/treeview/treeview.d.ts +87 -121
- package/esm2015/common/basedatetimecontrol.js +178 -30
- package/esm2015/common/basemodelcontrol.js +71 -56
- package/esm2015/controls/checkbox/radiobutton.js +94 -45
- package/esm2015/controls/contextmenu/contextmenu.interface.js +1 -0
- package/esm2015/controls/contextmenu/contextmenu.interface.ngfactory.js +7 -0
- package/esm2015/controls/contextmenu/contextmenu.js +22 -23
- package/esm2015/controls/contextmenu/contextmenuitem.js +13 -2
- package/esm2015/controls/contextmenu/contextmenuitembutton.js +34 -25
- package/esm2015/controls/datetime/date.js +43 -41
- package/esm2015/controls/datetime/datetime.js +42 -41
- package/esm2015/controls/datetime/time.js +42 -41
- package/esm2015/controls/dialog/dialog.js +41 -83
- package/esm2015/controls/layout/formlayout.js +7 -6
- package/esm2015/controls/list/buildvaluestring.js +18 -0
- package/esm2015/controls/{treeview/ngtreeitemaction.ngfactory.js → list/buildvaluestring.ngfactory.js} +1 -1
- package/esm2015/controls/list/dropdown.js +16 -114
- package/esm2015/controls/list/dropdownoptions.js +72 -0
- package/esm2015/controls/{treeview/treeviewchild.ngfactory.js → list/dropdownoptions.ngfactory.js} +1 -1
- package/esm2015/controls/static/formcontainer.js +16 -6
- package/esm2015/controls/tooltip/tooltip.js +60 -250
- package/esm2015/controls/treeview/treeview.js +232 -247
- package/esm2015/interfaces/ISacConfigurationService.js +1 -1
- package/esm2015/interfaces/ISacIconService.js +1 -1
- package/esm2015/interfaces/treeviewaction.interface.js +1 -0
- package/esm2015/interfaces/treeviewaction.interface.ngfactory.js +7 -0
- package/esm2015/public_api.js +6 -6
- package/esm2015/services/sac-configuration.service.js +7 -5
- package/esm2015/services/sac-icon.service.js +25 -1
- package/esm2015/utilities/enums.js +5 -1
- package/esm2015/utilities/popuphelper.js +343 -0
- package/esm2015/utilities/popuphelper.ngfactory.js +7 -0
- package/esm2015/validation/equals.validator.js +14 -0
- package/esm2015/validation/equals.validator.ngfactory.js +7 -0
- package/esm2015/validation/notequals.validator.js +14 -0
- package/esm2015/validation/notequals.validator.ngfactory.js +7 -0
- package/esm2015/validation/validation.class.js +30 -6
- package/fesm2015/simpleangularcontrols-sac-common.js +1398 -1075
- package/fesm2015/simpleangularcontrols-sac-common.js.map +1 -1
- package/interfaces/ISacConfigurationService.d.ts +4 -0
- package/interfaces/ISacIconService.d.ts +16 -0
- package/interfaces/treeviewaction.interface.d.ts +4 -0
- package/interfaces/treeviewaction.interface.ngfactory.d.ts +1 -0
- package/package.json +1 -1
- package/public_api.d.ts +5 -5
- package/services/sac-configuration.service.d.ts +8 -0
- package/services/sac-icon.service.d.ts +33 -1
- package/simpleangularcontrols-sac-common-10.0.0-rc.13.tgz +0 -0
- package/simpleangularcontrols-sac-common.metadata.json +1 -1
- package/utilities/enums.d.ts +3 -1
- package/utilities/popuphelper.d.ts +83 -0
- package/utilities/popuphelper.ngfactory.d.ts +1 -0
- package/validation/equals.validator.d.ts +2 -0
- package/validation/equals.validator.ngfactory.d.ts +1 -0
- package/validation/notequals.validator.d.ts +2 -0
- package/validation/notequals.validator.ngfactory.d.ts +1 -0
- package/validation/validation.class.d.ts +19 -0
- package/controls/treeview/ngtreeitemaction.d.ts +0 -40
- package/controls/treeview/treeviewchild.d.ts +0 -12
- package/esm2015/controls/treeview/ngtreeitemaction.js +0 -60
- package/esm2015/controls/treeview/treeviewchild.js +0 -18
- package/simpleangularcontrols-sac-common-10.0.0-rc.11.tgz +0 -0
- /package/controls/{treeview/ngtreeitemaction.ngfactory.d.ts → contextmenu/contextmenu.interface.ngfactory.d.ts} +0 -0
- /package/controls/{treeview/treeviewchild.ngfactory.d.ts → list/buildvaluestring.ngfactory.d.ts} +0 -0
|
@@ -1,10 +1,8 @@
|
|
|
1
|
-
import { ChangeDetectorRef, ElementRef, EventEmitter, HostListener, Input, Output, ViewChild,
|
|
1
|
+
import { ChangeDetectorRef, Directive, ElementRef, EventEmitter, HostListener, Input, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
/**
|
|
3
3
|
* Base Komponente für Dialog
|
|
4
4
|
*/
|
|
5
5
|
export class SacDialogCommon {
|
|
6
|
-
// #endregion
|
|
7
|
-
// #region Constructor
|
|
8
6
|
/**
|
|
9
7
|
* Konstruktor
|
|
10
8
|
* Inject des Formulars
|
|
@@ -21,11 +19,6 @@ export class SacDialogCommon {
|
|
|
21
19
|
* Die akzeptabel keywordssind: 'small', 'large', 'extralarge', 'medium', ''.
|
|
22
20
|
*/
|
|
23
21
|
this._size = '';
|
|
24
|
-
// #region Properties
|
|
25
|
-
/**
|
|
26
|
-
* Input Property. Erhält den Title des Dialog. Default Value: 'Dialog'.
|
|
27
|
-
*/
|
|
28
|
-
this.title = 'Dialog';
|
|
29
22
|
/**
|
|
30
23
|
* Das input property akzeptiert boolen Wert. Definiert ob das Dialog darf durch ESC geschlossen werden. Default ist true.
|
|
31
24
|
*/
|
|
@@ -34,26 +27,22 @@ export class SacDialogCommon {
|
|
|
34
27
|
* Das input property akzeptiert boolen Wert. Definiert ob das Dialog darf durch click außerhalb des Dialog-Fenster geschlossen werden. Default ist true.
|
|
35
28
|
*/
|
|
36
29
|
this.backdrop = true;
|
|
37
|
-
/**
|
|
38
|
-
* Input Property. Erhält den Namen des Dialog - benutzt für das ID. Default Value: ''
|
|
39
|
-
*/
|
|
40
|
-
this.name = '';
|
|
41
30
|
/**
|
|
42
31
|
* Steuert ob im Header des Dialogs ein Button angezeigt wird.
|
|
43
32
|
*/
|
|
44
33
|
this.closebutton = true;
|
|
45
34
|
/**
|
|
46
|
-
*
|
|
35
|
+
* Output Emitter. Wird aufgerufen, wenn das Wert des _show property geändert ist - damait das Dialog geöfnet/geschlossen wird.
|
|
47
36
|
*/
|
|
48
|
-
this.
|
|
37
|
+
this.isvisibleChange = new EventEmitter();
|
|
49
38
|
/**
|
|
50
|
-
*
|
|
39
|
+
* Input Property. Erhält den Namen des Dialog - benutzt für das ID. Default Value: ''
|
|
51
40
|
*/
|
|
52
|
-
this.
|
|
41
|
+
this.name = '';
|
|
53
42
|
/**
|
|
54
|
-
*
|
|
43
|
+
* Input Property. Erhält den Title des Dialog. Default Value: 'Dialog'.
|
|
55
44
|
*/
|
|
56
|
-
this.
|
|
45
|
+
this.title = 'Dialog';
|
|
57
46
|
}
|
|
58
47
|
/**
|
|
59
48
|
* Implementation als Setter, da mit ngIf das Element bei Unsichtbarkeit UNDEFINED ist.
|
|
@@ -62,14 +51,10 @@ export class SacDialogCommon {
|
|
|
62
51
|
this.dialogElement = content;
|
|
63
52
|
}
|
|
64
53
|
/**
|
|
65
|
-
*
|
|
66
|
-
* case insensitive.
|
|
67
|
-
* Die akzeptabel default-size-Klassen sind: 'small', 'large', 'extralarge', 'medium', ''.
|
|
68
|
-
* Wenn size ist NICHT gesetzt (oder 'medium' oder ''), default ist in medium size: max-width 500px.
|
|
54
|
+
* Getter. Ergibt das boolen Wert des _show property
|
|
69
55
|
*/
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
this._size = v;
|
|
56
|
+
get isvisible() {
|
|
57
|
+
return this._show;
|
|
73
58
|
}
|
|
74
59
|
/**
|
|
75
60
|
* Setter. Erhält das boolen Wert des _show property
|
|
@@ -90,77 +75,40 @@ export class SacDialogCommon {
|
|
|
90
75
|
this._show = v;
|
|
91
76
|
}
|
|
92
77
|
/**
|
|
93
|
-
*
|
|
78
|
+
* Das Input akzeptiert sowohl default size-css-Klassen als auch custom Klassen.
|
|
79
|
+
* case insensitive.
|
|
80
|
+
* Die akzeptabel default-size-Klassen sind: 'small', 'large', 'extralarge', 'medium', ''.
|
|
81
|
+
* Wenn size ist NICHT gesetzt (oder 'medium' oder ''), default ist in medium size: max-width 500px.
|
|
94
82
|
*/
|
|
95
|
-
|
|
96
|
-
|
|
83
|
+
set size(v) {
|
|
84
|
+
this._size = v;
|
|
97
85
|
}
|
|
98
86
|
/**
|
|
99
|
-
*
|
|
87
|
+
* Getter for ChangeDetector.
|
|
100
88
|
*/
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
switch (this._size) {
|
|
104
|
-
case 'small':
|
|
105
|
-
result = true;
|
|
106
|
-
break;
|
|
107
|
-
case 'medium':
|
|
108
|
-
result = true;
|
|
109
|
-
break;
|
|
110
|
-
case 'large':
|
|
111
|
-
result = true;
|
|
112
|
-
break;
|
|
113
|
-
case 'extralarge':
|
|
114
|
-
result = true;
|
|
115
|
-
break;
|
|
116
|
-
case '':
|
|
117
|
-
result = true;
|
|
118
|
-
break;
|
|
119
|
-
}
|
|
120
|
-
return result;
|
|
89
|
+
get ChangeDetector() {
|
|
90
|
+
return this.cdRef;
|
|
121
91
|
}
|
|
122
|
-
// #endregion
|
|
123
92
|
/**
|
|
124
|
-
* Methode
|
|
93
|
+
* Die Methode setz den Wert des _show property auf false
|
|
125
94
|
*/
|
|
126
|
-
|
|
95
|
+
hide() {
|
|
127
96
|
if (this.hasSetBodyTag && document.body.classList.contains('modal-open')) {
|
|
128
97
|
document.body.classList.remove('modal-open');
|
|
129
98
|
this.hasSetBodyTag = false;
|
|
130
99
|
}
|
|
131
|
-
|
|
132
|
-
// #region Methods
|
|
133
|
-
/**
|
|
134
|
-
* Die Methode setz den Wert des _show property auf true
|
|
135
|
-
*/
|
|
136
|
-
show() {
|
|
137
|
-
this._show = true;
|
|
138
|
-
if (!this.hasSetBodyTag &&
|
|
139
|
-
!document.body.classList.contains('modal-open')) {
|
|
140
|
-
document.body.classList.add('modal-open');
|
|
141
|
-
this.hasSetBodyTag = true;
|
|
142
|
-
}
|
|
100
|
+
this._show = false;
|
|
143
101
|
this.isvisibleChange.emit(this._show);
|
|
144
102
|
}
|
|
145
103
|
/**
|
|
146
|
-
*
|
|
104
|
+
* Methode wenn Componente entfernt wird
|
|
147
105
|
*/
|
|
148
|
-
|
|
106
|
+
ngOnDestroy() {
|
|
149
107
|
if (this.hasSetBodyTag && document.body.classList.contains('modal-open')) {
|
|
150
108
|
document.body.classList.remove('modal-open');
|
|
151
109
|
this.hasSetBodyTag = false;
|
|
152
110
|
}
|
|
153
|
-
this._show = false;
|
|
154
|
-
this.isvisibleChange.emit(this._show);
|
|
155
111
|
}
|
|
156
|
-
/**
|
|
157
|
-
* Getter for ChangeDetector.
|
|
158
|
-
*/
|
|
159
|
-
get ChangeDetector() {
|
|
160
|
-
return this.cdRef;
|
|
161
|
-
}
|
|
162
|
-
// #endregion
|
|
163
|
-
// #region Host Actions
|
|
164
112
|
/**
|
|
165
113
|
* Allow Close by Click outside Dialog
|
|
166
114
|
*/
|
|
@@ -182,6 +130,18 @@ export class SacDialogCommon {
|
|
|
182
130
|
this.hide();
|
|
183
131
|
}
|
|
184
132
|
}
|
|
133
|
+
/**
|
|
134
|
+
* Die Methode setz den Wert des _show property auf true
|
|
135
|
+
*/
|
|
136
|
+
show() {
|
|
137
|
+
this._show = true;
|
|
138
|
+
if (!this.hasSetBodyTag &&
|
|
139
|
+
!document.body.classList.contains('modal-open')) {
|
|
140
|
+
document.body.classList.add('modal-open');
|
|
141
|
+
this.hasSetBodyTag = true;
|
|
142
|
+
}
|
|
143
|
+
this.isvisibleChange.emit(this._show);
|
|
144
|
+
}
|
|
185
145
|
}
|
|
186
146
|
SacDialogCommon.decorators = [
|
|
187
147
|
{ type: Directive }
|
|
@@ -190,18 +150,16 @@ SacDialogCommon.ctorParameters = () => [
|
|
|
190
150
|
{ type: ChangeDetectorRef }
|
|
191
151
|
];
|
|
192
152
|
SacDialogCommon.propDecorators = {
|
|
193
|
-
dialogElementSetter: [{ type: ViewChild, args: ['dialog', { static: false },] }],
|
|
194
|
-
title: [{ type: Input }],
|
|
195
153
|
allowesc: [{ type: Input }],
|
|
196
154
|
backdrop: [{ type: Input }],
|
|
197
|
-
name: [{ type: Input }],
|
|
198
155
|
closebutton: [{ type: Input }],
|
|
199
|
-
width: [{ type: Input }],
|
|
200
|
-
height: [{ type: Input }],
|
|
201
|
-
size: [{ type: Input }],
|
|
202
156
|
isvisibleChange: [{ type: Output }],
|
|
157
|
+
name: [{ type: Input }],
|
|
158
|
+
title: [{ type: Input }],
|
|
159
|
+
dialogElementSetter: [{ type: ViewChild, args: ['dialog', { static: false },] }],
|
|
203
160
|
isvisible: [{ type: Input }],
|
|
161
|
+
size: [{ type: Input }],
|
|
204
162
|
onClick: [{ type: HostListener, args: ['click', ['$event'],] }],
|
|
205
163
|
onKeydownHandler: [{ type: HostListener, args: ['document:keydown', ['$event'],] }]
|
|
206
164
|
};
|
|
207
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/dialog/dialog.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n  Directive,\r\n  OnDestroy,\r\n} from '@angular/core';\r\n\r\n/**\r\n * Base Komponente für Dialog\r\n */\r\n@Directive()\r\nexport class SacDialogCommon implements OnDestroy {\r\n  /**\r\n   * Name des Containers für den Dialog\r\n   */\r\n  dialogElement: ElementRef;\r\n\r\n  private hasSetBodyTag = false;\r\n\r\n  /**\r\n   * Implementation als Setter, da mit ngIf das Element bei Unsichtbarkeit UNDEFINED ist.\r\n   */\r\n  @ViewChild('dialog', { static: false })\r\n  set dialogElementSetter(content: ElementRef) {\r\n    this.dialogElement = content;\r\n  }\r\n\r\n  /**\r\n   * Boolean Property definiert ob das Dialog angezeigt wird\r\n   */\r\n  _show: boolean = false;\r\n\r\n  /**\r\n   * Das property enthielt (wenn überhaupt gesetzt) entweder keywords für sizing oder custom css Klassen.\r\n   * Die akzeptabel keywordssind: 'small', 'large', 'extralarge', 'medium', ''.\r\n   */\r\n  _size: string = '';\r\n\r\n  // #region Properties\r\n\r\n  /**\r\n   * Input Property. Erhält den Title des Dialog. Default Value: 'Dialog'.\r\n   */\r\n  @Input()\r\n  public title: string = 'Dialog';\r\n\r\n  /**\r\n   * Das input property akzeptiert boolen Wert. Definiert ob das Dialog darf durch ESC geschlossen werden. Default ist true.\r\n   */\r\n  @Input()\r\n  public allowesc: boolean = true;\r\n\r\n  /**\r\n   * Das input property akzeptiert boolen Wert. Definiert ob das Dialog darf durch click außerhalb des Dialog-Fenster geschlossen werden. Default ist true.\r\n   */\r\n  @Input()\r\n  public backdrop: boolean = true;\r\n\r\n  /**\r\n   * Input Property. Erhält den Namen des Dialog - benutzt für das ID. Default Value: ''\r\n   */\r\n  @Input()\r\n  public name: string = '';\r\n\r\n  /**\r\n   * Steuert ob im Header des Dialogs ein Button angezeigt wird.\r\n   */\r\n  @Input()\r\n  public closebutton: boolean = true;\r\n\r\n  /**\r\n   * Input Property. Erhält die Breite des Dialog\r\n   */\r\n  @Input()\r\n  public width: string = null;\r\n\r\n  /**\r\n   * Definiert eine feste Höhe beim Dialog.\r\n   */\r\n  @Input()\r\n  public height: string = null;\r\n\r\n  /**\r\n   * Das Input akzeptiert sowohl default size-css-Klassen als auch custom Klassen.\r\n   * case insensitive.\r\n   * Die akzeptabel default-size-Klassen sind: 'small', 'large', 'extralarge', 'medium', ''.\r\n   * Wenn size ist NICHT gesetzt (oder 'medium' oder ''), default ist in medium size: max-width 500px.\r\n   */\r\n  @Input()\r\n  set size(v: string) {\r\n    v = v.toLowerCase();\r\n    this._size = v;\r\n  }\r\n\r\n  /**\r\n   * Output Emitter. Wird aufgerufen, wenn das Wert des _show property geändert ist - damait das Dialog geöfnet/geschlossen wird.\r\n   */\r\n  @Output()\r\n  isvisibleChange: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n  /**\r\n   * Setter. Erhält das boolen Wert des _show property\r\n   */\r\n  @Input()\r\n  set isvisible(v: boolean) {\r\n    if (\r\n      v &&\r\n      !this.hasSetBodyTag &&\r\n      !document.body.classList.contains('modal-open')\r\n    ) {\r\n      document.body.classList.add('modal-open');\r\n      this.hasSetBodyTag = true;\r\n    }\r\n\r\n    if (\r\n      !v &&\r\n      this.hasSetBodyTag &&\r\n      document.body.classList.contains('modal-open')\r\n    ) {\r\n      document.body.classList.remove('modal-open');\r\n      this.hasSetBodyTag = false;\r\n    }\r\n\r\n    this._show = v;\r\n  }\r\n\r\n  /**\r\n   * Getter. Ergibt das boolen Wert des _show property\r\n   */\r\n  get isvisible(): boolean {\r\n    return this._show;\r\n  }\r\n\r\n  /**\r\n   * Die Funktion prüft ob es ein default css classe für Size des Dialog durch den size Input gesetzt wurde.\r\n   */\r\n  issetdefaultsize(): boolean {\r\n    let result: boolean = false;\r\n\r\n    switch (this._size) {\r\n      case 'small':\r\n        result = true;\r\n        break;\r\n      case 'medium':\r\n        result = true;\r\n        break;\r\n      case 'large':\r\n        result = true;\r\n        break;\r\n      case 'extralarge':\r\n        result = true;\r\n        break;\r\n      case '':\r\n        result = true;\r\n        break;\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  // #endregion\r\n\r\n  // #region Constructor\r\n\r\n  /**\r\n   * Konstruktor\r\n   * Inject des Formulars\r\n   */\r\n  constructor(private cdRef: ChangeDetectorRef) {}\r\n\r\n  // #endregion\r\n\r\n  /**\r\n   * Methode wenn Componente entfernt wird\r\n   */\r\n  ngOnDestroy(): void {\r\n    if (this.hasSetBodyTag && document.body.classList.contains('modal-open')) {\r\n      document.body.classList.remove('modal-open');\r\n      this.hasSetBodyTag = false;\r\n    }\r\n  }\r\n\r\n  // #region Methods\r\n\r\n  /**\r\n   * Die Methode setz den Wert des _show property auf true\r\n   */\r\n  public show(): void {\r\n    this._show = true;\r\n\r\n    if (\r\n      !this.hasSetBodyTag &&\r\n      !document.body.classList.contains('modal-open')\r\n    ) {\r\n      document.body.classList.add('modal-open');\r\n      this.hasSetBodyTag = true;\r\n    }\r\n\r\n    this.isvisibleChange.emit(this._show);\r\n  }\r\n\r\n  /**\r\n   * Die Methode setz den Wert des _show property auf false\r\n   */\r\n  public hide(): void {\r\n    if (this.hasSetBodyTag && document.body.classList.contains('modal-open')) {\r\n      document.body.classList.remove('modal-open');\r\n      this.hasSetBodyTag = false;\r\n    }\r\n\r\n    this._show = false;\r\n    this.isvisibleChange.emit(this._show);\r\n  }\r\n\r\n  /**\r\n   * Getter for ChangeDetector.\r\n   */\r\n  protected get ChangeDetector(): ChangeDetectorRef {\r\n    return this.cdRef;\r\n  }\r\n\r\n  // #endregion\r\n\r\n  // #region Host Actions\r\n\r\n  /**\r\n   * Allow Close by Click outside Dialog\r\n   */\r\n  @HostListener('click', ['$event'])\r\n  onClick(event: any): void {\r\n    if (\r\n      this.allowesc === false ||\r\n      (this.dialogElement !== null &&\r\n        this.dialogElement !== undefined &&\r\n        event.target !== this.dialogElement.nativeElement)\r\n    ) {\r\n      return;\r\n    }\r\n    this.hide();\r\n  }\r\n\r\n  /**\r\n   * Allow Close by ESC\r\n   */\r\n  @HostListener('document:keydown', ['$event'])\r\n  onKeydownHandler(event: KeyboardEvent) {\r\n    const ESCAPE_KEYCODE = 'Escape';\r\n\r\n    if (this.allowesc === true && event.key === ESCAPE_KEYCODE) {\r\n      this.hide();\r\n    }\r\n  }\r\n\r\n  // #endregion\r\n}\r\n"]}
|
|
165
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/dialog/dialog.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Directive,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnDestroy,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\n\r\n/**\r\n * Base Komponente für Dialog\r\n */\r\n@Directive()\r\nexport class SacDialogCommon implements OnDestroy {\r\n  private hasSetBodyTag = false;\r\n\r\n  /**\r\n   * Boolean Property definiert ob das Dialog angezeigt wird\r\n   */\r\n  public _show: boolean = false;\r\n\r\n  /**\r\n   * Das property enthielt (wenn überhaupt gesetzt) entweder keywords für sizing oder custom css Klassen.\r\n   * Die akzeptabel keywordssind: 'small', 'large', 'extralarge', 'medium', ''.\r\n   */\r\n  public _size: 'small' | 'large' | 'extralarge' | 'medium' | '' = '';\r\n\r\n  /**\r\n   * Das input property akzeptiert boolen Wert. Definiert ob das Dialog darf durch ESC geschlossen werden. Default ist true.\r\n   */\r\n  @Input()\r\n  public allowesc: boolean = true;\r\n\r\n  /**\r\n   * Das input property akzeptiert boolen Wert. Definiert ob das Dialog darf durch click außerhalb des Dialog-Fenster geschlossen werden. Default ist true.\r\n   */\r\n  @Input()\r\n  public backdrop: boolean = true;\r\n\r\n  /**\r\n   * Steuert ob im Header des Dialogs ein Button angezeigt wird.\r\n   */\r\n  @Input()\r\n  public closebutton: boolean = true;\r\n\r\n  /**\r\n   * Name des Containers für den Dialog\r\n   */\r\n  public dialogElement: ElementRef;\r\n\r\n  /**\r\n   * Output Emitter. Wird aufgerufen, wenn das Wert des _show property geändert ist - damait das Dialog geöfnet/geschlossen wird.\r\n   */\r\n  @Output()\r\n  public isvisibleChange: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n  /**\r\n   * Input Property. Erhält den Namen des Dialog - benutzt für das ID. Default Value: ''\r\n   */\r\n  @Input()\r\n  public name: string = '';\r\n\r\n  /**\r\n   * Input Property. Erhält den Title des Dialog. Default Value: 'Dialog'.\r\n   */\r\n  @Input()\r\n  public title: string = 'Dialog';\r\n\r\n  /**\r\n   * Konstruktor\r\n   * Inject des Formulars\r\n   */\r\n  constructor(private cdRef: ChangeDetectorRef) {}\r\n\r\n  /**\r\n   * Implementation als Setter, da mit ngIf das Element bei Unsichtbarkeit UNDEFINED ist.\r\n   */\r\n  @ViewChild('dialog', { static: false })\r\n  public set dialogElementSetter(content: ElementRef) {\r\n    this.dialogElement = content;\r\n  }\r\n\r\n  /**\r\n   * Getter. Ergibt das boolen Wert des _show property\r\n   */\r\n  public get isvisible(): boolean {\r\n    return this._show;\r\n  }\r\n\r\n  /**\r\n   * Setter. Erhält das boolen Wert des _show property\r\n   */\r\n  @Input()\r\n  public set isvisible(v: boolean) {\r\n    if (\r\n      v &&\r\n      !this.hasSetBodyTag &&\r\n      !document.body.classList.contains('modal-open')\r\n    ) {\r\n      document.body.classList.add('modal-open');\r\n      this.hasSetBodyTag = true;\r\n    }\r\n\r\n    if (\r\n      !v &&\r\n      this.hasSetBodyTag &&\r\n      document.body.classList.contains('modal-open')\r\n    ) {\r\n      document.body.classList.remove('modal-open');\r\n      this.hasSetBodyTag = false;\r\n    }\r\n\r\n    this._show = v;\r\n  }\r\n\r\n  /**\r\n   * Das Input akzeptiert sowohl default size-css-Klassen als auch custom Klassen.\r\n   * case insensitive.\r\n   * Die akzeptabel default-size-Klassen sind: 'small', 'large', 'extralarge', 'medium', ''.\r\n   * Wenn size ist NICHT gesetzt (oder 'medium' oder ''), default ist in medium size: max-width 500px.\r\n   */\r\n  @Input()\r\n  public set size(v: 'small' | 'large' | 'extralarge' | 'medium' | '') {\r\n    this._size = v;\r\n  }\r\n\r\n  /**\r\n   * Getter for ChangeDetector.\r\n   */\r\n  protected get ChangeDetector(): ChangeDetectorRef {\r\n    return this.cdRef;\r\n  }\r\n\r\n  /**\r\n   * Die Methode setz den Wert des _show property auf false\r\n   */\r\n  public hide(): void {\r\n    if (this.hasSetBodyTag && document.body.classList.contains('modal-open')) {\r\n      document.body.classList.remove('modal-open');\r\n      this.hasSetBodyTag = false;\r\n    }\r\n\r\n    this._show = false;\r\n    this.isvisibleChange.emit(this._show);\r\n  }\r\n\r\n  /**\r\n   * Methode wenn Componente entfernt wird\r\n   */\r\n  public ngOnDestroy(): void {\r\n    if (this.hasSetBodyTag && document.body.classList.contains('modal-open')) {\r\n      document.body.classList.remove('modal-open');\r\n      this.hasSetBodyTag = false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Allow Close by Click outside Dialog\r\n   */\r\n  @HostListener('click', ['$event'])\r\n  public onClick(event: any): void {\r\n    if (\r\n      this.allowesc === false ||\r\n      (this.dialogElement !== null &&\r\n        this.dialogElement !== undefined &&\r\n        event.target !== this.dialogElement.nativeElement)\r\n    ) {\r\n      return;\r\n    }\r\n    this.hide();\r\n  }\r\n\r\n  /**\r\n   * Allow Close by ESC\r\n   */\r\n  @HostListener('document:keydown', ['$event'])\r\n  public onKeydownHandler(event: KeyboardEvent) {\r\n    const ESCAPE_KEYCODE = 'Escape';\r\n\r\n    if (this.allowesc === true && event.key === ESCAPE_KEYCODE) {\r\n      this.hide();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Die Methode setz den Wert des _show property auf true\r\n   */\r\n  public show(): void {\r\n    this._show = true;\r\n\r\n    if (\r\n      !this.hasSetBodyTag &&\r\n      !document.body.classList.contains('modal-open')\r\n    ) {\r\n      document.body.classList.add('modal-open');\r\n      this.hasSetBodyTag = true;\r\n    }\r\n\r\n    this.isvisibleChange.emit(this._show);\r\n  }\r\n}\r\n"]}
|
|
@@ -5,7 +5,6 @@ import { ControlHeight } from '../../enums/ControlHeight';
|
|
|
5
5
|
*/
|
|
6
6
|
export class SacFormLayoutCommon {
|
|
7
7
|
constructor() {
|
|
8
|
-
// #region Properties
|
|
9
8
|
/**
|
|
10
9
|
* Defines the default display for a checkbox. You can choose between a checkbox and a switch. If no style is defined, the global style or the style on the control is used.
|
|
11
10
|
*/
|
|
@@ -50,10 +49,11 @@ export class SacFormLayoutCommon {
|
|
|
50
49
|
* default label size for extra extra large devices
|
|
51
50
|
*/
|
|
52
51
|
this.labelSizeXxl = null;
|
|
53
|
-
|
|
52
|
+
/**
|
|
53
|
+
* Detach label text and tooltip from each other in Label so that label and tooltip can be aligned differently. This is in Bootstrap 3 not supported!
|
|
54
|
+
*/
|
|
55
|
+
this.splitlabelandhelptext = null;
|
|
54
56
|
}
|
|
55
|
-
// #endregion Properties
|
|
56
|
-
// #region Public Getters And Setters
|
|
57
57
|
/**
|
|
58
58
|
* Returns whether the inline error messages for the form are active.
|
|
59
59
|
*/
|
|
@@ -76,6 +76,7 @@ SacFormLayoutCommon.propDecorators = {
|
|
|
76
76
|
labelSizeSm: [{ type: Input }],
|
|
77
77
|
labelSizeXl: [{ type: Input }],
|
|
78
78
|
labelSizeXs: [{ type: Input }],
|
|
79
|
-
labelSizeXxl: [{ type: Input }]
|
|
79
|
+
labelSizeXxl: [{ type: Input }],
|
|
80
|
+
splitlabelandhelptext: [{ type: Input }]
|
|
80
81
|
};
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWxheW91dC5qcyIsInNvdXJjZVJvb3QiOiJDOi9Qcm9qZWt0ZS9zaW1wbGVhbmd1bGFyY29udHJvbHMtbmcxMC9jaC5qbmV0d29yay5zYWMtY29udHJvbHMvcHJvamVjdHMvc2FjLWNvbW1vbi9zcmMvIiwic291cmNlcyI6WyJjb250cm9scy9sYXlvdXQvZm9ybWxheW91dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFMUQ7O0dBRUc7QUFFSCxNQUFNLE9BQU8sbUJBQW1CO0lBRGhDO1FBRUU7O1dBRUc7UUFFSSxrQkFBYSxHQUFpQyxJQUFJLENBQUM7UUFFMUQ7O1dBRUc7UUFDYSxvQkFBZSxHQUF5QixJQUFJLENBQUM7UUFRN0Q7O1dBRUc7UUFDYSxnQkFBVyxHQUFtQixJQUFJLENBQUM7UUFFbkQ7O1dBRUc7UUFFSSx3QkFBbUIsR0FBcUMsSUFBSSxDQUFDO1FBRXBFOztXQUVHO1FBQ2Esb0JBQWUsR0FBWSxLQUFLLENBQUM7UUFFakQ7O1dBRUc7UUFFSSxnQkFBVyxHQUFrQixJQUFJLENBQUM7UUFFekM7O1dBRUc7UUFFSSxnQkFBVyxHQUFrQixJQUFJLENBQUM7UUFFekM7O1dBRUc7UUFFSSxnQkFBVyxHQUFrQixJQUFJLENBQUM7UUFFekM7O1dBRUc7UUFFSSxnQkFBVyxHQUFrQixJQUFJLENBQUM7UUFFekM7O1dBRUc7UUFFSSxnQkFBVyxHQUFrQixJQUFJLENBQUM7UUFFekM7O1dBRUc7UUFFSSxpQkFBWSxHQUFrQixJQUFJLENBQUM7UUFFMUM7O1dBRUc7UUFFSSwwQkFBcUIsR0FBbUIsSUFBSSxDQUFDO0lBUXRELENBQUM7SUFOQzs7T0FFRztJQUNILElBQVcsb0JBQW9CO1FBQzdCLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUMxQixDQUFDOzs7WUFsRkYsU0FBUzs7OzRCQUtQLEtBQUs7OEJBTUwsS0FBSzsyQkFLTCxLQUFLOzBCQU1MLEtBQUs7a0NBS0wsS0FBSzs4QkFNTCxLQUFLOzBCQUtMLEtBQUs7MEJBTUwsS0FBSzswQkFNTCxLQUFLOzBCQU1MLEtBQUs7MEJBTUwsS0FBSzsyQkFNTCxLQUFLO29DQU1MLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbnRyb2xIZWlnaHQgfSBmcm9tICcuLi8uLi9lbnVtcy9Db250cm9sSGVpZ2h0JztcclxuXHJcbi8qKipcclxuICogYmFzZSBjb21wb25lbnQgZm9yIGZvcm0gb3B0aW9uc1xyXG4gKi9cclxuQERpcmVjdGl2ZSgpXHJcbmV4cG9ydCBjbGFzcyBTYWNGb3JtTGF5b3V0Q29tbW9uIHtcclxuICAvKipcclxuICAgKiBEZWZpbmVzIHRoZSBkZWZhdWx0IGRpc3BsYXkgZm9yIGEgY2hlY2tib3guIFlvdSBjYW4gY2hvb3NlIGJldHdlZW4gYSBjaGVja2JveCBhbmQgYSBzd2l0Y2guIElmIG5vIHN0eWxlIGlzIGRlZmluZWQsIHRoZSBnbG9iYWwgc3R5bGUgb3IgdGhlIHN0eWxlIG9uIHRoZSBjb250cm9sIGlzIHVzZWQuXHJcbiAgICovXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgY2hlY2tib3hzdHlsZTogJ2NoZWNrYm94JyB8ICdzd2l0Y2gnIHwgbnVsbCA9IG51bGw7XHJcblxyXG4gIC8qKlxyXG4gICAqIERlZmluZXMgdGhlIHN0YW5kYXJkIGhlaWdodCBvZiB0aGUgY29tcG9uZW50c1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHB1YmxpYyBjb21wb25lbnRIZWlnaHQ6IENvbnRyb2xIZWlnaHQgfCBudWxsID0gbnVsbDtcclxuXHJcbiAgLyoqXHJcbiAgICogTW9kZSBmb3IgZGlzcGxheSBoZWxwdGV4dFxyXG4gICAqL1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGhlbHB0ZXh0bW9kZTogJ3Rvb2x0aXAnIHwgJ3RleHQnIHwgbnVsbDtcclxuXHJcbiAgLyoqXHJcbiAgICogZGVmaW5lcyB0aGF0IGVycm9yIG1lc3NhZ2VzIGFyZSBkaXNwbGF5ZWQgdW5kZXIgdGhlIGNvbnRyb2xzXHJcbiAgICovXHJcbiAgQElucHV0KCkgcHVibGljIGlubGluZUVycm9yOiBib29sZWFuIHwgbnVsbCA9IG51bGw7XHJcblxyXG4gIC8qKlxyXG4gICAqIERlZmluZXMgaWYgSW5wdXRTZWFyY2ggdXNlcyBhbiBpY29uIGF0IHRoZSBidXR0b24gb3IgdGhlIHRleHRcclxuICAgKi9cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBpbnB1dHNlYXJjaGljb25tb2RlOiAndGV4dCcgfCAnaWNvbicgfCAnbWl4ZWQnIHwgbnVsbCA9IG51bGw7XHJcblxyXG4gIC8qKlxyXG4gICAqIGRlZmluZXMgdGhhdCB0aGUgbGFiZWxzIGFyZSBkaXNwbGF5ZWQgYXMgYWRhcHRpdmUgbGFiZWxzXHJcbiAgICovXHJcbiAgQElucHV0KCkgcHVibGljIGlzQWRhcHRpdmVMYWJlbDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICAvKipcclxuICAgKiBkZWZhdWx0IGxhYmUgc2l6ZSBmb3IgbGFyZ2UgZGV2aWNlc1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGxhYmVsU2l6ZUxnOiBudW1iZXIgfCBudWxsID0gbnVsbDtcclxuXHJcbiAgLyoqXHJcbiAgICogZGVmYXVsdCBsYWJlbCBzaXplIGZvciBtZWRpdW0gZGV2aWNlc1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGxhYmVsU2l6ZU1kOiBudW1iZXIgfCBudWxsID0gbnVsbDtcclxuXHJcbiAgLyoqXHJcbiAgICogZGVmYXVsdCBsYWJlbCBzaXplIGZvciBzbWFsbCBkZXZpY2VzXHJcbiAgICovXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgbGFiZWxTaXplU206IG51bWJlciB8IG51bGwgPSBudWxsO1xyXG5cclxuICAvKipcclxuICAgKiBkZWZhdWx0IGxhYmVsIHNpemUgZm9yIGV4dHJhIGxhcmdlIGRldmljZXNcclxuICAgKi9cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBsYWJlbFNpemVYbDogbnVtYmVyIHwgbnVsbCA9IG51bGw7XHJcblxyXG4gIC8qKlxyXG4gICAqIGRlZmF1bHQgbGFiZWwgY29sdW1uIHNpemVcclxuICAgKi9cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBsYWJlbFNpemVYczogbnVtYmVyIHwgbnVsbCA9IG51bGw7XHJcblxyXG4gIC8qKlxyXG4gICAqIGRlZmF1bHQgbGFiZWwgc2l6ZSBmb3IgZXh0cmEgZXh0cmEgbGFyZ2UgZGV2aWNlc1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGxhYmVsU2l6ZVh4bDogbnVtYmVyIHwgbnVsbCA9IG51bGw7XHJcblxyXG4gIC8qKlxyXG4gICAqIERldGFjaCBsYWJlbCB0ZXh0IGFuZCB0b29sdGlwIGZyb20gZWFjaCBvdGhlciBpbiBMYWJlbCBzbyB0aGF0IGxhYmVsIGFuZCB0b29sdGlwIGNhbiBiZSBhbGlnbmVkIGRpZmZlcmVudGx5LiBUaGlzIGlzIGluIEJvb3RzdHJhcCAzIG5vdCBzdXBwb3J0ZWQhXHJcbiAgICovXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgc3BsaXRsYWJlbGFuZGhlbHB0ZXh0OiBib29sZWFuIHwgbnVsbCA9IG51bGw7XHJcblxyXG4gIC8qKlxyXG4gICAqIFJldHVybnMgd2hldGhlciB0aGUgaW5saW5lIGVycm9yIG1lc3NhZ2VzIGZvciB0aGUgZm9ybSBhcmUgYWN0aXZlLlxyXG4gICAqL1xyXG4gIHB1YmxpYyBnZXQgSXNJbmxpbmVFcnJvckVuYWJsZWQoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5pbmxpbmVFcnJvcjtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Function um ein Key Value Pair für das Dropdown zu erzeugen
|
|
3
|
+
* @param id ID
|
|
4
|
+
* @param value Wert der an das Element gebunden werden soll
|
|
5
|
+
*/
|
|
6
|
+
export function _buildValueString(id, value) {
|
|
7
|
+
// Wenn ID null ist Object zurückgeben
|
|
8
|
+
if (id == null) {
|
|
9
|
+
return `${value}`;
|
|
10
|
+
}
|
|
11
|
+
// Mapping Objekt zu String
|
|
12
|
+
if (value && typeof value === 'object') {
|
|
13
|
+
value = 'Object';
|
|
14
|
+
}
|
|
15
|
+
// String als ID
|
|
16
|
+
return `${id}: ${value}`.slice(0, 50);
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVpbGR2YWx1ZXN0cmluZy5qcyIsInNvdXJjZVJvb3QiOiJDOi9Qcm9qZWt0ZS9zaW1wbGVhbmd1bGFyY29udHJvbHMtbmcxMC9jaC5qbmV0d29yay5zYWMtY29udHJvbHMvcHJvamVjdHMvc2FjLWNvbW1vbi9zcmMvIiwic291cmNlcyI6WyJjb250cm9scy9saXN0L2J1aWxkdmFsdWVzdHJpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUNILE1BQU0sVUFBVSxpQkFBaUIsQ0FBQyxFQUFpQixFQUFFLEtBQVU7SUFDN0Qsc0NBQXNDO0lBQ3RDLElBQUksRUFBRSxJQUFJLElBQUksRUFBRTtRQUNkLE9BQU8sR0FBRyxLQUFLLEVBQUUsQ0FBQztLQUNuQjtJQUVELDJCQUEyQjtJQUMzQixJQUFJLEtBQUssSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUU7UUFDdEMsS0FBSyxHQUFHLFFBQVEsQ0FBQztLQUNsQjtJQUVELGdCQUFnQjtJQUNoQixPQUFPLEdBQUcsRUFBRSxLQUFLLEtBQUssRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7QUFDeEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBGdW5jdGlvbiB1bSBlaW4gS2V5IFZhbHVlIFBhaXIgZsO8ciBkYXMgRHJvcGRvd24genUgZXJ6ZXVnZW5cclxuICogQHBhcmFtIGlkIElEXHJcbiAqIEBwYXJhbSB2YWx1ZSBXZXJ0IGRlciBhbiBkYXMgRWxlbWVudCBnZWJ1bmRlbiB3ZXJkZW4gc29sbFxyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIF9idWlsZFZhbHVlU3RyaW5nKGlkOiBzdHJpbmcgfCBudWxsLCB2YWx1ZTogYW55KTogc3RyaW5nIHtcclxuICAvLyBXZW5uIElEIG51bGwgaXN0IE9iamVjdCB6dXLDvGNrZ2ViZW5cclxuICBpZiAoaWQgPT0gbnVsbCkge1xyXG4gICAgcmV0dXJuIGAke3ZhbHVlfWA7XHJcbiAgfVxyXG5cclxuICAvLyBNYXBwaW5nIE9iamVrdCB6dSBTdHJpbmdcclxuICBpZiAodmFsdWUgJiYgdHlwZW9mIHZhbHVlID09PSAnb2JqZWN0Jykge1xyXG4gICAgdmFsdWUgPSAnT2JqZWN0JztcclxuICB9XHJcblxyXG4gIC8vIFN0cmluZyBhbHMgSURcclxuICByZXR1cm4gYCR7aWR9OiAke3ZhbHVlfWAuc2xpY2UoMCwgNTApO1xyXG59XHJcbiJdfQ==
|
|
@@ -4,4 +4,4 @@
|
|
|
4
4
|
* @suppress {suspiciousCode,uselessCode,missingProperties,missingOverride,checkTypes,extraRequire}
|
|
5
5
|
* tslint:disable
|
|
6
6
|
*/
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVpbGR2YWx1ZXN0cmluZy5uZ2ZhY3RvcnkuanMiLCJzb3VyY2VSb290IjoiQzovUHJvamVrdGUvc2ltcGxlYW5ndWxhcmNvbnRyb2xzLW5nMTAvY2guam5ldHdvcmsuc2FjLWNvbnRyb2xzL3Byb2plY3RzL3NhYy1jb21tb24vc3JjLyIsInNvdXJjZXMiOlsiY29udHJvbHMvbGlzdC9idWlsZHZhbHVlc3RyaW5nLm5nZmFjdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgaTAgZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pMC5Db21wb25lbnRGYWN0b3J5O1xuIl19
|
|
@@ -2,13 +2,11 @@ import { Directive, ElementRef, Host, Injector, Input, Renderer2, } from '@angul
|
|
|
2
2
|
import { SacBaseSelectControl } from '../../common/baseselectcontrol';
|
|
3
3
|
import { Validation } from '../../validation';
|
|
4
4
|
import { SacFormLayoutCommon } from '../layout/formlayout';
|
|
5
|
-
|
|
5
|
+
import { _buildValueString } from './buildvaluestring';
|
|
6
6
|
/**
|
|
7
7
|
* Base Dropdown Komponente
|
|
8
8
|
*/
|
|
9
9
|
export class SacDropdownCommon extends SacBaseSelectControl {
|
|
10
|
-
// #endregion Properties
|
|
11
|
-
// #region Constructors
|
|
12
10
|
/**
|
|
13
11
|
* Constructor
|
|
14
12
|
* @param formlayout SacFormLayoutCommon to define scoped layout settings
|
|
@@ -20,11 +18,18 @@ export class SacDropdownCommon extends SacBaseSelectControl {
|
|
|
20
18
|
super(formlayout, injector);
|
|
21
19
|
this.renderer = renderer;
|
|
22
20
|
this.elementRef = elementRef;
|
|
23
|
-
// #region Properties
|
|
24
21
|
/**
|
|
25
22
|
* compareWith-Funktion
|
|
26
23
|
*/
|
|
27
24
|
this._compareWith = Object.is;
|
|
25
|
+
/**
|
|
26
|
+
* Counter vom OptionID; default Wert = 0
|
|
27
|
+
*/
|
|
28
|
+
this._optionIdCounter = 0;
|
|
29
|
+
/**
|
|
30
|
+
* OptionMap
|
|
31
|
+
*/
|
|
32
|
+
this._optionMap = new Map();
|
|
28
33
|
/**
|
|
29
34
|
* Label Text für Empty Item
|
|
30
35
|
*/
|
|
@@ -41,17 +46,7 @@ export class SacDropdownCommon extends SacBaseSelectControl {
|
|
|
41
46
|
* Resource Key für Validation Message Required in Validation Summary
|
|
42
47
|
*/
|
|
43
48
|
this.validationmessagesummaryrequired = this.validationKeyService.ValidationErrorSummaryRequired;
|
|
44
|
-
/**
|
|
45
|
-
* Counter vom OptionID; default Wert = 0
|
|
46
|
-
*/
|
|
47
|
-
this._optionIdCounter = 0;
|
|
48
|
-
/**
|
|
49
|
-
* OptionMap
|
|
50
|
-
*/
|
|
51
|
-
this._optionMap = new Map();
|
|
52
49
|
}
|
|
53
|
-
// #endregion Constructors
|
|
54
|
-
// #region Public Getters And Setters
|
|
55
50
|
/**
|
|
56
51
|
* compareWith-Funktion
|
|
57
52
|
*/
|
|
@@ -61,8 +56,6 @@ export class SacDropdownCommon extends SacBaseSelectControl {
|
|
|
61
56
|
}
|
|
62
57
|
this._compareWith = fn;
|
|
63
58
|
}
|
|
64
|
-
// #endregion Public Getters And Setters
|
|
65
|
-
// #region Public Methods
|
|
66
59
|
/**
|
|
67
60
|
* Registriert das OptionID-Counter als String
|
|
68
61
|
*/
|
|
@@ -97,6 +90,12 @@ export class SacDropdownCommon extends SacBaseSelectControl {
|
|
|
97
90
|
if (this.isrequired) {
|
|
98
91
|
error = Validation.required(this.validationmessagerequired, this.validationmessagesummaryrequired)(c);
|
|
99
92
|
}
|
|
93
|
+
if (error) {
|
|
94
|
+
return error;
|
|
95
|
+
}
|
|
96
|
+
if (this.isrequired && this.emptyvalue !== null) {
|
|
97
|
+
error = Validation.notequals(this.emptyvalue, this.validationmessagerequired, this.validationmessagesummaryrequired)(c);
|
|
98
|
+
}
|
|
100
99
|
return error;
|
|
101
100
|
}
|
|
102
101
|
/**
|
|
@@ -107,8 +106,6 @@ export class SacDropdownCommon extends SacBaseSelectControl {
|
|
|
107
106
|
this.setSelectedValue(value);
|
|
108
107
|
super.writeValue(value);
|
|
109
108
|
}
|
|
110
|
-
// #endregion Public Methods
|
|
111
|
-
// #region Private Methods
|
|
112
109
|
/**
|
|
113
110
|
* ID extrahieren
|
|
114
111
|
* @param valueString String bei welchem die ID Extrahiert werden soll
|
|
@@ -172,99 +169,4 @@ SacDropdownCommon.propDecorators = {
|
|
|
172
169
|
validationmessagesummaryrequired: [{ type: Input }],
|
|
173
170
|
comparewith: [{ type: Input }]
|
|
174
171
|
};
|
|
175
|
-
/**
|
|
176
|
-
* SacDropdownOption-Klasse
|
|
177
|
-
*/
|
|
178
|
-
export class SacDropdownOptionCommon {
|
|
179
|
-
// #endregion Properties
|
|
180
|
-
// #region Constructors
|
|
181
|
-
/**
|
|
182
|
-
* Konstruktor
|
|
183
|
-
* @param _element Referenz auf HTML Element
|
|
184
|
-
* @param _renderer Render Engine
|
|
185
|
-
* @param _dropdown Dropdown Instanz
|
|
186
|
-
*/
|
|
187
|
-
constructor(_element, _renderer, _dropdown) {
|
|
188
|
-
this._element = _element;
|
|
189
|
-
this._renderer = _renderer;
|
|
190
|
-
this._dropdown = _dropdown;
|
|
191
|
-
// #region Properties
|
|
192
|
-
/**
|
|
193
|
-
* ID-String
|
|
194
|
-
*/
|
|
195
|
-
this.id = null;
|
|
196
|
-
if (this._dropdown) {
|
|
197
|
-
this.id = this._dropdown.registerOption();
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
// #endregion Constructors
|
|
201
|
-
// #region Public Getters And Setters
|
|
202
|
-
/**
|
|
203
|
-
* Option ngValue
|
|
204
|
-
*/
|
|
205
|
-
set ngValue(value) {
|
|
206
|
-
// Cancel wenn kein Parent Dropdown vorhanden
|
|
207
|
-
if (this._dropdown == null) {
|
|
208
|
-
return;
|
|
209
|
-
}
|
|
210
|
-
this._dropdown.setOptionMap(this.id, value);
|
|
211
|
-
this._setElementValue(_buildValueString(this.id, value));
|
|
212
|
-
this._dropdown.writeValue(this._dropdown.value);
|
|
213
|
-
}
|
|
214
|
-
/**
|
|
215
|
-
* Wert-Setter
|
|
216
|
-
*/
|
|
217
|
-
set value(value) {
|
|
218
|
-
this._setElementValue(value);
|
|
219
|
-
}
|
|
220
|
-
// #endregion Public Getters And Setters
|
|
221
|
-
// #region Public Methods
|
|
222
|
-
/**
|
|
223
|
-
* Den Wert vom Option-Element einstellen
|
|
224
|
-
* @param value Wert
|
|
225
|
-
*/
|
|
226
|
-
_setElementValue(value) {
|
|
227
|
-
this._renderer.setProperty(this._element.nativeElement, 'value', value);
|
|
228
|
-
}
|
|
229
|
-
/**
|
|
230
|
-
* OnDestroy Event
|
|
231
|
-
*/
|
|
232
|
-
ngOnDestroy() {
|
|
233
|
-
if (this._dropdown) {
|
|
234
|
-
this._dropdown._optionMap.delete(this.id);
|
|
235
|
-
}
|
|
236
|
-
}
|
|
237
|
-
}
|
|
238
|
-
SacDropdownOptionCommon.decorators = [
|
|
239
|
-
{ type: Directive }
|
|
240
|
-
];
|
|
241
|
-
SacDropdownOptionCommon.ctorParameters = () => [
|
|
242
|
-
{ type: ElementRef },
|
|
243
|
-
{ type: Renderer2 },
|
|
244
|
-
{ type: SacDropdownCommon }
|
|
245
|
-
];
|
|
246
|
-
SacDropdownOptionCommon.propDecorators = {
|
|
247
|
-
ngValue: [{ type: Input }],
|
|
248
|
-
value: [{ type: Input }]
|
|
249
|
-
};
|
|
250
|
-
// #endregion Classes
|
|
251
|
-
// #region Functions
|
|
252
|
-
/**
|
|
253
|
-
* Function um ein Key Value Pair für das Dropdown zu erzeugen
|
|
254
|
-
* @param id ID
|
|
255
|
-
* @param value Wert der an das Element gebunden werden soll
|
|
256
|
-
*/
|
|
257
|
-
export function _buildValueString(id, value) {
|
|
258
|
-
// Wenn ID null ist Object zurückgeben
|
|
259
|
-
if (id == null) {
|
|
260
|
-
return `${value}`;
|
|
261
|
-
}
|
|
262
|
-
// Mapping Objekt zu String
|
|
263
|
-
if (value && typeof value === 'object') {
|
|
264
|
-
value = 'Object';
|
|
265
|
-
}
|
|
266
|
-
// String als ID
|
|
267
|
-
return `${id}: ${value}`.slice(0, 50);
|
|
268
|
-
}
|
|
269
|
-
// #endregion Functions
|
|
270
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["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    this.validationKeyService.ValidationErrorRequired;\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    this.validationKeyService.ValidationErrorSummaryRequired;\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"]}
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["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  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\nimport { _buildValueString } from './buildvaluestring';\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   * compareWith-Funktion\r\n   */\r\n  private _compareWith: (o1: any, o2: any) => boolean = Object.is;\r\n\r\n  /**\r\n   * Counter vom OptionID; default Wert = 0\r\n   */\r\n  public _optionIdCounter: number = 0;\r\n\r\n  /**\r\n   * OptionMap\r\n   */\r\n  public _optionMap: Map<string, any> = new Map<string, any>();\r\n\r\n  /**\r\n   * Label Text für Empty Item\r\n   */\r\n  @Input() public emptylabel: string = '';\r\n\r\n  /**\r\n   * Option Value für Empty Item\r\n   */\r\n  @Input() public emptyvalue: string = null;\r\n\r\n  /**\r\n   * Resource Key für Validation Message Required bei Control\r\n   */\r\n  @Input() public validationmessagerequired: string =\r\n    this.validationKeyService.ValidationErrorRequired;\r\n\r\n  /**\r\n   * Resource Key für Validation Message Required in Validation Summary\r\n   */\r\n  @Input()\r\n  public validationmessagesummaryrequired: string =\r\n    this.validationKeyService.ValidationErrorSummaryRequired;\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  /**\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  /**\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\r\n    if (error) {\r\n      return error;\r\n    }\r\n\r\n    if (this.isrequired && this.emptyvalue !== null) {\r\n      error = Validation.notequals(\r\n        this.emptyvalue,\r\n        this.validationmessagerequired,\r\n        this.validationmessagesummaryrequired\r\n      )(c);\r\n    }\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  /**\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"]}
|