@simpleangularcontrols/sac-common 10.0.0-rc.2 → 10.0.0-rc.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/simpleangularcontrols-sac-common.umd.js +2232 -1604
- package/bundles/simpleangularcontrols-sac-common.umd.js.map +1 -1
- package/bundles/simpleangularcontrols-sac-common.umd.min.js +1 -1
- package/bundles/simpleangularcontrols-sac-common.umd.min.js.map +1 -1
- package/common/basedatetimecontrol.d.ts +100 -14
- package/common/baseinputcontrol.d.ts +0 -4
- package/common/basemodelcontrol.d.ts +55 -27
- package/common/baseuploadcontrol.d.ts +71 -55
- package/controls/checkbox/checkbox.d.ts +12 -3
- package/controls/checkbox/radiobutton.d.ts +61 -26
- package/controls/contextmenu/contextmenu.d.ts +26 -19
- package/controls/contextmenu/contextmenu.interface.d.ts +3 -0
- package/controls/contextmenu/contextmenuitem.d.ts +5 -0
- package/controls/contextmenu/contextmenuitembutton.d.ts +21 -20
- package/controls/datetime/date.d.ts +28 -31
- package/controls/datetime/datetime.d.ts +27 -31
- package/controls/datetime/time.d.ts +26 -30
- package/controls/dialog/dialog.d.ts +31 -43
- package/controls/grid/grid.d.ts +38 -36
- package/controls/grid/gridbutton.d.ts +13 -13
- package/controls/grid/gridcolumn.d.ts +8 -8
- package/controls/grid/gridcolumnaction.d.ts +3 -3
- package/controls/grid/gridcolumnbase.d.ts +45 -37
- package/controls/grid/gridimage.d.ts +2 -2
- package/controls/grid/model.d.ts +51 -42
- package/controls/grid/paging.d.ts +41 -43
- package/controls/input/input.d.ts +3 -3
- package/controls/input/inputarea.d.ts +5 -5
- package/controls/input/inputpassword.d.ts +7 -7
- package/controls/input/inputsearch.d.ts +13 -4
- package/controls/layout/formlayout.d.ts +17 -1
- package/controls/list/buildvaluestring.d.ts +6 -0
- package/controls/list/dropdown.d.ts +9 -51
- package/controls/list/dropdownoptions.d.ts +38 -0
- package/controls/multilanguage/multilanguageinput.d.ts +2 -2
- package/controls/multilanguage/multilanguageinputarea.d.ts +4 -4
- package/controls/static/formcontainer.d.ts +7 -3
- package/controls/tooltip/tooltip.d.ts +76 -69
- package/controls/treeview/treeview.d.ts +107 -107
- package/esm2015/common/basedatetimecontrol.js +185 -30
- package/esm2015/common/baseinputcontrol.js +2 -7
- package/esm2015/common/basemodelcontrol.js +109 -57
- package/esm2015/common/baseuploadcontrol.js +92 -59
- package/esm2015/controls/checkbox/checkbox.js +29 -6
- package/esm2015/controls/checkbox/radiobutton.js +94 -45
- package/esm2015/controls/contextmenu/contextmenu.interface.js +1 -0
- package/esm2015/controls/contextmenu/contextmenu.interface.ngfactory.js +7 -0
- package/esm2015/controls/contextmenu/contextmenu.js +22 -23
- package/esm2015/controls/contextmenu/contextmenuitem.js +13 -2
- package/esm2015/controls/contextmenu/contextmenuitembutton.js +34 -25
- package/esm2015/controls/datetime/date.js +44 -43
- package/esm2015/controls/datetime/datetime.js +43 -43
- package/esm2015/controls/datetime/time.js +43 -43
- package/esm2015/controls/dialog/dialog.js +41 -83
- package/esm2015/controls/grid/grid.js +21 -21
- package/esm2015/controls/grid/gridbutton.js +19 -13
- package/esm2015/controls/grid/gridcolumn.js +14 -7
- package/esm2015/controls/grid/gridcolumnaction.js +6 -5
- package/esm2015/controls/grid/gridcolumnbase.js +67 -55
- package/esm2015/controls/grid/gridimage.js +3 -3
- package/esm2015/controls/grid/model.js +51 -30
- package/esm2015/controls/grid/paging.js +40 -42
- package/esm2015/controls/input/input.js +6 -8
- package/esm2015/controls/input/inputarea.js +19 -12
- package/esm2015/controls/input/inputpassword.js +12 -12
- package/esm2015/controls/input/inputsearch.js +35 -6
- package/esm2015/controls/layout/formlayout.js +20 -8
- package/esm2015/controls/list/buildvaluestring.js +18 -0
- package/esm2015/controls/{treeview/ngtreeitemaction.ngfactory.js → list/buildvaluestring.ngfactory.js} +1 -1
- package/esm2015/controls/list/dropdown.js +16 -114
- package/esm2015/controls/list/dropdownoptions.js +72 -0
- package/esm2015/controls/{treeview/treeviewchild.ngfactory.js → list/dropdownoptions.ngfactory.js} +1 -1
- package/esm2015/controls/multilanguage/multilanguageinput.js +8 -14
- package/esm2015/controls/multilanguage/multilanguageinputarea.js +9 -15
- package/esm2015/controls/static/formcontainer.js +16 -5
- package/esm2015/controls/tooltip/tooltip.js +126 -245
- package/esm2015/controls/treeview/treeview.js +276 -231
- package/esm2015/interfaces/ISacConfigurationService.js +1 -1
- package/esm2015/interfaces/ISacIconService.js +1 -1
- package/esm2015/interfaces/ISacUploadEventCompleteState.js +1 -0
- package/esm2015/interfaces/ISacUploadEventCompleteState.ngfactory.js +7 -0
- package/esm2015/interfaces/ISacValidationKeyService.js +1 -1
- package/esm2015/interfaces/treeviewaction.interface.js +1 -0
- package/esm2015/interfaces/treeviewaction.interface.ngfactory.js +7 -0
- package/esm2015/public_api.js +15 -8
- package/esm2015/services/sac-configuration.service.js +31 -5
- package/esm2015/services/sac-icon.service.js +37 -1
- package/esm2015/services/sac-localisation.service.js +69 -180
- package/esm2015/services/sac-validationkey.service.js +12 -9
- package/esm2015/simpleangularcontrols-sac-common.js +1 -7
- package/esm2015/utilities/enums.js +5 -1
- package/esm2015/utilities/guid.js +4 -2
- package/esm2015/utilities/popuphelper.js +343 -0
- package/esm2015/utilities/popuphelper.ngfactory.js +7 -0
- package/esm2015/validation/equals.validator.js +14 -0
- package/esm2015/validation/equals.validator.ngfactory.js +7 -0
- package/esm2015/validation/isDateValid.js +9 -1
- package/esm2015/validation/mintextlength.validator.js +23 -0
- package/esm2015/validation/mintextlength.validator.ngfactory.js +7 -0
- package/esm2015/validation/notequals.validator.js +14 -0
- package/esm2015/validation/{minlength.validator.ngfactory.js → notequals.validator.ngfactory.js} +1 -1
- package/esm2015/validation/validation.class.js +35 -6
- package/fesm2015/simpleangularcontrols-sac-common.js +2070 -1498
- package/fesm2015/simpleangularcontrols-sac-common.js.map +1 -1
- package/interfaces/ISacConfigurationService.d.ts +20 -0
- package/interfaces/ISacIconService.d.ts +24 -0
- package/interfaces/ISacUploadEventCompleteState.d.ts +5 -0
- package/interfaces/ISacUploadEventCompleteState.ngfactory.d.ts +1 -0
- package/interfaces/ISacValidationKeyService.d.ts +2 -2
- package/interfaces/treeviewaction.interface.d.ts +4 -0
- package/interfaces/treeviewaction.interface.ngfactory.d.ts +1 -0
- package/package.json +2 -2
- package/public_api.d.ts +13 -6
- package/services/sac-configuration.service.d.ts +40 -0
- package/services/sac-icon.service.d.ts +49 -1
- package/services/sac-localisation.service.d.ts +10 -10
- package/services/sac-validationkey.service.d.ts +7 -7
- package/simpleangularcontrols-sac-common-10.0.0-rc.21.tgz +0 -0
- package/simpleangularcontrols-sac-common.d.ts +0 -6
- package/simpleangularcontrols-sac-common.metadata.json +1 -1
- package/utilities/enums.d.ts +3 -1
- package/utilities/popuphelper.d.ts +83 -0
- package/utilities/popuphelper.ngfactory.d.ts +1 -0
- package/validation/equals.validator.d.ts +2 -0
- package/validation/equals.validator.ngfactory.d.ts +1 -0
- package/validation/mintextlength.validator.d.ts +2 -0
- package/validation/mintextlength.validator.ngfactory.d.ts +1 -0
- package/validation/notequals.validator.d.ts +2 -0
- package/validation/notequals.validator.ngfactory.d.ts +1 -0
- package/validation/validation.class.d.ts +22 -3
- package/controls/treeview/ngtreeitemaction.d.ts +0 -40
- package/controls/treeview/treeviewchild.d.ts +0 -12
- package/esm2015/controls/treeview/ngtreeitemaction.js +0 -60
- package/esm2015/controls/treeview/treeviewchild.js +0 -18
- package/esm2015/validation/minlength.validator.js +0 -21
- package/simpleangularcontrols-sac-common-10.0.0-rc.2.tgz +0 -0
- package/validation/minlength.validator.d.ts +0 -2
- /package/controls/{treeview/ngtreeitemaction.ngfactory.d.ts → contextmenu/contextmenu.interface.ngfactory.d.ts} +0 -0
- /package/controls/{treeview/treeviewchild.ngfactory.d.ts → list/buildvaluestring.ngfactory.d.ts} +0 -0
- /package/{validation/minlength.validator.ngfactory.d.ts → controls/list/dropdownoptions.ngfactory.d.ts} +0 -0
|
@@ -1,322 +1,367 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { SacBaseModelControl } from '../../common/basemodelcontrol';
|
|
2
|
+
import { Validation } from '../../validation';
|
|
3
|
+
import { SacFormLayoutCommon } from '../layout/formlayout';
|
|
4
|
+
import { Directive, EventEmitter, Host, Injector, Input, Output, TemplateRef } from '@angular/core';
|
|
2
5
|
/**
|
|
3
6
|
* Basis Komponente für SacTreeView
|
|
4
7
|
*/
|
|
5
|
-
export class
|
|
6
|
-
|
|
8
|
+
export class SacTreeviewCommon extends SacBaseModelControl {
|
|
9
|
+
// #endregion Properties
|
|
10
|
+
// #region Constructors
|
|
11
|
+
/**
|
|
12
|
+
* Constructor
|
|
13
|
+
* @param injector Service Injector
|
|
14
|
+
*/
|
|
15
|
+
constructor(formlayout, injector) {
|
|
16
|
+
super(formlayout, injector);
|
|
17
|
+
// #region Properties
|
|
7
18
|
/**
|
|
8
|
-
*
|
|
19
|
+
* Event when Action is clicked on Node. An object of the type 'TreeviewAction' is returned. In the default case, 'action' in this object is always the value 'default'. The value can be changed via the 'templateaction'.
|
|
9
20
|
*/
|
|
10
|
-
this.
|
|
21
|
+
this.actionclicked = new EventEmitter();
|
|
11
22
|
/**
|
|
12
|
-
*
|
|
23
|
+
* Property on the data object that contains the children of the structure element. Must be an array of objects. The default value is 'children'
|
|
13
24
|
*/
|
|
14
|
-
this.
|
|
25
|
+
this.attrchildren = 'children';
|
|
15
26
|
/**
|
|
16
|
-
*
|
|
27
|
+
* Defines the property on the 'data' object with which the actions for a node can be deactivated. A 'disabled' property is used by default.
|
|
17
28
|
*/
|
|
18
|
-
this.
|
|
29
|
+
this.attrdisableaction = 'disabled';
|
|
19
30
|
/**
|
|
20
|
-
*
|
|
31
|
+
* Property on the 'data' object that stores the expanded state. Property must be of type boolean. Default is 'expanded'
|
|
21
32
|
*/
|
|
22
|
-
this.
|
|
33
|
+
this.attrexanded = 'expanded';
|
|
23
34
|
/**
|
|
24
|
-
*
|
|
35
|
+
* Property for saving the HoverState on the field. If the property is not present on the node, it is automatically created and removed again. The value can usually be left at the default value unless there is a conflict with a property on the node that is required for other purposes.
|
|
25
36
|
*/
|
|
26
|
-
this.
|
|
37
|
+
this.attrhoverstate = 'hoverstate';
|
|
27
38
|
/**
|
|
28
|
-
*
|
|
39
|
+
* Property on 'data' object, which contains the icon for the node. By default, the property is not set, which hides the icon in the node.
|
|
29
40
|
*/
|
|
30
|
-
this.
|
|
41
|
+
this.attricon = null;
|
|
31
42
|
/**
|
|
32
|
-
*
|
|
33
|
-
* is false).
|
|
43
|
+
* property on the 'data' object contains an ID of the node. The default is 'id'. If the property is set to NULL, the selectedId event is no longer triggered.
|
|
34
44
|
*/
|
|
35
|
-
this.
|
|
45
|
+
this.attrid = 'id';
|
|
36
46
|
/**
|
|
37
|
-
*
|
|
47
|
+
* Property on 'data' object, which contains the label for the node. Default is 'label'
|
|
38
48
|
*/
|
|
39
|
-
this.
|
|
49
|
+
this.attrlabel = 'label';
|
|
40
50
|
/**
|
|
41
|
-
*
|
|
51
|
+
* Property on 'data' object, which defines whether the node is selected or not. It should be ensured that only 1 node has the value for Selected set to true. Default is 'selected'.
|
|
42
52
|
*/
|
|
43
|
-
this.
|
|
53
|
+
this.attrselected = 'selected';
|
|
44
54
|
/**
|
|
45
|
-
*
|
|
55
|
+
* Event when a node is collapsed. Returns the node element as a parameter
|
|
46
56
|
*/
|
|
47
|
-
this.
|
|
57
|
+
this.collabsed = new EventEmitter();
|
|
48
58
|
/**
|
|
49
|
-
*
|
|
59
|
+
* The property contains an array of nodes. The data must already map the tree via child properties.
|
|
50
60
|
*/
|
|
51
|
-
this.
|
|
61
|
+
this.data = [];
|
|
52
62
|
/**
|
|
53
|
-
*
|
|
63
|
+
* Activates the 'expand' and 'collabse' event even if a node has no children. This is helpful if node elements are to be reloaded at runtime.
|
|
54
64
|
*/
|
|
55
|
-
this.
|
|
65
|
+
this.enableasynchload = false;
|
|
56
66
|
/**
|
|
57
|
-
*
|
|
67
|
+
* Activates Ellipsis on the node labels
|
|
58
68
|
*/
|
|
59
|
-
this.
|
|
69
|
+
this.enableellipsis = true;
|
|
60
70
|
/**
|
|
61
|
-
*
|
|
71
|
+
* Event when a node is expanded. Returns the node element as a parameter
|
|
62
72
|
*/
|
|
63
|
-
this.
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
73
|
+
this.expanded = new EventEmitter();
|
|
74
|
+
/**
|
|
75
|
+
* Defines whether an icon for the expanded/collapsed status should be displayed.
|
|
76
|
+
*/
|
|
77
|
+
this.expandedstate = true;
|
|
78
|
+
/**
|
|
79
|
+
* A node must be selected
|
|
80
|
+
*/
|
|
81
|
+
this.isrequired = false;
|
|
82
|
+
/**
|
|
83
|
+
* Name of the TreeView control
|
|
84
|
+
*/
|
|
85
|
+
this.name = '';
|
|
86
|
+
/**
|
|
87
|
+
* Event when a node is selected. Returns the id attribute as a parameter. The event is not triggered if 'attrid' is not set.
|
|
88
|
+
*/
|
|
89
|
+
this.selected = new EventEmitter();
|
|
90
|
+
/**
|
|
91
|
+
* Event when a node is selected. Returns the node element as a parameter.
|
|
92
|
+
*/
|
|
93
|
+
this.selectednode = new EventEmitter();
|
|
94
|
+
/**
|
|
95
|
+
* Resource Key für Validation Message Required bei Control
|
|
96
|
+
*/
|
|
97
|
+
this.validationmessagerequired = this.validationKeyService.ValidationErrorRequired;
|
|
98
|
+
/**
|
|
99
|
+
* Resource Key für Validation Message Required in Validation Summary
|
|
100
|
+
*/
|
|
101
|
+
this.validationmessagesummaryrequired = this.validationKeyService.ValidationErrorSummaryRequired;
|
|
70
102
|
}
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
this._data = value;
|
|
76
|
-
this.nodes = value;
|
|
77
|
-
// this.nodes.forEach(node => node["typeId"] = "13")
|
|
78
|
-
this.LoadTree();
|
|
79
|
-
if (this._collapseAll !== undefined) {
|
|
80
|
-
this.collapseAllNode(this._collapseAll);
|
|
81
|
-
}
|
|
103
|
+
// #endregion Constructors
|
|
104
|
+
// #region Public Getters And Setters
|
|
105
|
+
get iconAction() {
|
|
106
|
+
return this.iconService.TreeviewNodeActionIcon;
|
|
82
107
|
}
|
|
83
108
|
/**
|
|
84
|
-
*
|
|
109
|
+
* CSS icon for folders in tree there are collabsed
|
|
110
|
+
* @returns css class with icon
|
|
85
111
|
*/
|
|
86
|
-
|
|
87
|
-
this.
|
|
112
|
+
get iconFolderCollabsed() {
|
|
113
|
+
return this.iconService.TreeviewNodeClosedIcon;
|
|
88
114
|
}
|
|
89
115
|
/**
|
|
90
|
-
*
|
|
116
|
+
* CSS icon class for folders without subfolders
|
|
117
|
+
* @returns css class with icon
|
|
91
118
|
*/
|
|
92
|
-
get
|
|
93
|
-
return this.
|
|
119
|
+
get iconFolderEmpty() {
|
|
120
|
+
return this.iconService.TreeviewNodeEmptyIcon;
|
|
94
121
|
}
|
|
95
122
|
/**
|
|
96
|
-
*
|
|
123
|
+
* CSS icon for folders in tree there are expanded
|
|
124
|
+
* @returns css class with icon
|
|
97
125
|
*/
|
|
98
|
-
|
|
99
|
-
this.
|
|
126
|
+
get iconFolderOpen() {
|
|
127
|
+
return this.iconService.TreeviewNodeOpenIcon;
|
|
100
128
|
}
|
|
129
|
+
// #endregion Public Getters And Setters
|
|
130
|
+
// #region Public Methods
|
|
101
131
|
/**
|
|
102
|
-
*
|
|
132
|
+
* Creates an array of a certain size. Is required for a For in the UI, as Angular does not support counting loops
|
|
133
|
+
* @param size Size of the array
|
|
134
|
+
* @returns Array
|
|
103
135
|
*/
|
|
104
|
-
|
|
105
|
-
return
|
|
136
|
+
count(size) {
|
|
137
|
+
return new Array(size);
|
|
106
138
|
}
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
this.collapseAllNode(this._collapseAll);
|
|
139
|
+
getChildren(node) {
|
|
140
|
+
if (!node || !this.attrchildren) {
|
|
141
|
+
return [];
|
|
142
|
+
}
|
|
143
|
+
let children = node[this.attrchildren];
|
|
144
|
+
if (!Array.isArray(children)) {
|
|
145
|
+
return [];
|
|
115
146
|
}
|
|
116
|
-
|
|
117
|
-
// this.nodes, this.childrenAttr, this.collapseAttr, this._collapseAll);
|
|
118
|
-
// this.cd.detectChanges();
|
|
147
|
+
return children;
|
|
119
148
|
}
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
149
|
+
getStringField(node, fieldname) {
|
|
150
|
+
if (!node) {
|
|
151
|
+
return '';
|
|
152
|
+
}
|
|
153
|
+
if (!fieldname) {
|
|
154
|
+
return node;
|
|
155
|
+
}
|
|
156
|
+
let value = node[fieldname];
|
|
157
|
+
if (!value) {
|
|
158
|
+
return '';
|
|
159
|
+
}
|
|
160
|
+
return value;
|
|
125
161
|
}
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
*/
|
|
129
|
-
set selectall(value) {
|
|
130
|
-
this._selectAll = value;
|
|
131
|
-
this._recursiveEdit(this.nodes, this.childrenAttr, this.selectAttr, value);
|
|
132
|
-
this._recursiveEdit(this.nodes, this.childrenAttr, this.inDeterminateAttr, false);
|
|
162
|
+
hasChildren(node) {
|
|
163
|
+
return this.getChildren(node).length > 0;
|
|
133
164
|
}
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
// this.selectedIdEmitter.emit(this.selectedNode[this.idAttr]);
|
|
141
|
-
// this.selectedTextEmitter.emit(this.selectedNode[this.textAttr]);
|
|
142
|
-
// }
|
|
165
|
+
isDisabledState(node) {
|
|
166
|
+
if (!node || !this.attrdisableaction) {
|
|
167
|
+
return false;
|
|
168
|
+
}
|
|
169
|
+
let value = node[this.attrdisableaction];
|
|
170
|
+
return value === true || value === 'true';
|
|
143
171
|
}
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
172
|
+
isExpandedState(node) {
|
|
173
|
+
if (!node || !this.attrexanded) {
|
|
174
|
+
return false;
|
|
175
|
+
}
|
|
176
|
+
let value = node[this.attrexanded];
|
|
177
|
+
return value === true || value === 'true';
|
|
149
178
|
}
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
set selectedNode(v) {
|
|
154
|
-
this._selectedNode = v;
|
|
155
|
-
if (this._selectedNode) {
|
|
156
|
-
this.selectedidchange.emit(this.selectedId);
|
|
157
|
-
this.selectedtextchanged.emit(v[this.textAttr]);
|
|
179
|
+
isHoverState(node) {
|
|
180
|
+
if (!node || !this.attrhoverstate) {
|
|
181
|
+
return false;
|
|
158
182
|
}
|
|
183
|
+
let value = node[this.attrhoverstate];
|
|
184
|
+
return value === true || value === 'true';
|
|
159
185
|
}
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
186
|
+
isSelectedState(node) {
|
|
187
|
+
if (!node || !this.attrselected) {
|
|
188
|
+
return false;
|
|
189
|
+
}
|
|
190
|
+
let value = node[this.attrselected];
|
|
191
|
+
return value === true || value === 'true';
|
|
165
192
|
}
|
|
166
193
|
/**
|
|
167
|
-
*
|
|
168
|
-
*
|
|
194
|
+
* Method is called by clicking an action
|
|
195
|
+
* @param action action and node
|
|
169
196
|
*/
|
|
170
|
-
|
|
171
|
-
this.
|
|
172
|
-
if (this.selectedId)
|
|
173
|
-
this.openSelectedNode(this.nodes);
|
|
197
|
+
onActionClicked(action) {
|
|
198
|
+
this.actionclicked.emit(action);
|
|
174
199
|
}
|
|
175
200
|
/**
|
|
176
|
-
*
|
|
177
|
-
*
|
|
201
|
+
* Method is called when Node in Tree is clicked
|
|
202
|
+
* @param node Selected Node
|
|
178
203
|
*/
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
if (data[i][this.childrenAttr].length &&
|
|
183
|
-
data[i][this.idAttr] != this.selectedId)
|
|
184
|
-
result = this.openSelectedNode(data[i][this.childrenAttr]);
|
|
185
|
-
if (result || data[i][this.idAttr] == this.selectedId) {
|
|
186
|
-
data[i][this.collapseAttr] = false;
|
|
187
|
-
return true;
|
|
188
|
-
}
|
|
204
|
+
onNodeClicked(node) {
|
|
205
|
+
if (this.isDisabledState(node) || this.isSelectedState(node)) {
|
|
206
|
+
this.invertExpandedState(node);
|
|
189
207
|
}
|
|
190
|
-
|
|
208
|
+
this.setSelectedState(node);
|
|
191
209
|
}
|
|
192
210
|
/**
|
|
193
|
-
*
|
|
211
|
+
* Sets the hover state on a node
|
|
212
|
+
* @param node Node on which the status is set
|
|
213
|
+
* @param state Activate or deactivate HoverState
|
|
194
214
|
*/
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
* Die Methode collapse/expand den selectierten Node
|
|
203
|
-
*/
|
|
204
|
-
onCollapseClick(node) {
|
|
205
|
-
if (node[this.childrenAttr].length) {
|
|
206
|
-
node[this.collapseAttr] = !node[this.collapseAttr];
|
|
215
|
+
setHoverState(node, state) {
|
|
216
|
+
if (!node || !this.attrhoverstate) {
|
|
217
|
+
return;
|
|
218
|
+
}
|
|
219
|
+
if (state) {
|
|
220
|
+
node[this.attrhoverstate] = true;
|
|
221
|
+
return;
|
|
207
222
|
}
|
|
223
|
+
if (!node.hasOwnProperty(this.attrhoverstate)) {
|
|
224
|
+
return;
|
|
225
|
+
}
|
|
226
|
+
delete node[this.attrhoverstate];
|
|
208
227
|
}
|
|
209
228
|
/**
|
|
210
|
-
*
|
|
229
|
+
* Sets the selected state on a node
|
|
230
|
+
* @param node Node which is marked as Selected
|
|
211
231
|
*/
|
|
212
|
-
|
|
213
|
-
this.
|
|
214
|
-
|
|
215
|
-
|
|
232
|
+
setSelectedState(node) {
|
|
233
|
+
if (!node || !this.attrselected) {
|
|
234
|
+
return;
|
|
235
|
+
}
|
|
236
|
+
// reset selected state of any node
|
|
237
|
+
this.data.forEach((rootNode) => this.resetSelectedState(rootNode));
|
|
238
|
+
// set selected node as selected
|
|
239
|
+
node[this.attrselected] = true;
|
|
240
|
+
// Extract ID from Node
|
|
241
|
+
const idValue = node[this.attrid];
|
|
242
|
+
// Update ngModel
|
|
243
|
+
this.setValue(idValue);
|
|
244
|
+
// Raise Selected Events
|
|
245
|
+
this.selectednode.emit(node);
|
|
246
|
+
if (!this.attrid) {
|
|
247
|
+
return;
|
|
248
|
+
}
|
|
249
|
+
let id = this.getStringField(node, this.attrid);
|
|
250
|
+
this.selected.emit(id);
|
|
216
251
|
}
|
|
217
252
|
/**
|
|
218
|
-
*
|
|
253
|
+
* Validates the model state of the control
|
|
254
|
+
* @param c Control instance
|
|
255
|
+
* @returns Returns a validation error, if present. Otherwise, as Result is NULL
|
|
219
256
|
*/
|
|
220
|
-
|
|
221
|
-
|
|
257
|
+
validateData(c) {
|
|
258
|
+
let error = null;
|
|
259
|
+
if (this.isrequired) {
|
|
260
|
+
error = Validation.required(this.validationmessagerequired, this.validationmessagesummaryrequired)(c);
|
|
261
|
+
}
|
|
262
|
+
return error;
|
|
222
263
|
}
|
|
223
264
|
/**
|
|
224
|
-
*
|
|
265
|
+
* Saves the data from the model binding
|
|
266
|
+
* @param value Id of the selected node
|
|
225
267
|
*/
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
268
|
+
writeValue(value) {
|
|
269
|
+
super.writeValue(value);
|
|
270
|
+
// Do not preselct item when tree is empty
|
|
271
|
+
if (!this.data) {
|
|
272
|
+
return;
|
|
273
|
+
}
|
|
274
|
+
this.data.forEach((root) => {
|
|
275
|
+
const result = this.findNodeById(root, value);
|
|
276
|
+
if (result !== null) {
|
|
277
|
+
this.setSelectedState(result);
|
|
230
278
|
}
|
|
231
279
|
});
|
|
232
|
-
function collapseAllHIdden(node, collapseAttr, command, childrenAttr) {
|
|
233
|
-
node[collapseAttr] = command;
|
|
234
|
-
node.children.forEach((child) => {
|
|
235
|
-
if (child[childrenAttr].length) {
|
|
236
|
-
collapseAllHIdden(child, collapseAttr, command, childrenAttr);
|
|
237
|
-
}
|
|
238
|
-
});
|
|
239
|
-
}
|
|
240
280
|
}
|
|
281
|
+
// #endregion Public Methods
|
|
282
|
+
// #region Private Methods
|
|
241
283
|
/**
|
|
242
|
-
*
|
|
243
|
-
*
|
|
244
|
-
* @param
|
|
245
|
-
* @
|
|
246
|
-
* @param attr Der namen des Attributs auf dem das value gesucht wird
|
|
284
|
+
* Searches for a node based on the value in the ID attribute
|
|
285
|
+
* @param node Node
|
|
286
|
+
* @param value Value of the Id attribute
|
|
287
|
+
* @returns Returns the node if it is found. If not, NULL is returned.
|
|
247
288
|
*/
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
if (data[i][attr] == searchValue)
|
|
252
|
-
result = data[i];
|
|
253
|
-
else {
|
|
254
|
-
if (data[i][this.childrenAttr].length) {
|
|
255
|
-
let recursiveResult = this.findNode(data[i][this.childrenAttr], searchValue, attr);
|
|
256
|
-
if (recursiveResult)
|
|
257
|
-
result = recursiveResult;
|
|
258
|
-
}
|
|
259
|
-
}
|
|
289
|
+
findNodeById(node, value) {
|
|
290
|
+
if (!this.attrid || !node) {
|
|
291
|
+
return null;
|
|
260
292
|
}
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
list[i][attr] = value;
|
|
270
|
-
if (list[i][childrenAttr].length) {
|
|
271
|
-
this._recursiveEdit(list[i][childrenAttr], childrenAttr, attr, value);
|
|
272
|
-
}
|
|
293
|
+
if (node[this.attrid] === value) {
|
|
294
|
+
return node;
|
|
295
|
+
}
|
|
296
|
+
const children = this.getChildren(node);
|
|
297
|
+
for (let child of children) {
|
|
298
|
+
const result = this.findNodeById(child, value);
|
|
299
|
+
if (result !== null) {
|
|
300
|
+
return result;
|
|
273
301
|
}
|
|
274
302
|
}
|
|
303
|
+
return null;
|
|
275
304
|
}
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
_getPreparedData(list) {
|
|
280
|
-
const tree = [], lookup = {};
|
|
281
|
-
for (let i = 0, len = list.length; i < len; i++) {
|
|
282
|
-
lookup[list[i][this.idAttr]] = list[i];
|
|
283
|
-
list[i][this.childrenAttr] = [];
|
|
284
|
-
list[i][this.collapseAttr] = true;
|
|
285
|
-
list[i][this.selectAttr] = false;
|
|
286
|
-
list[i][this.inDeterminateAttr] = false;
|
|
305
|
+
invertExpandedState(node) {
|
|
306
|
+
if (!node || !this.attrexanded) {
|
|
307
|
+
return;
|
|
287
308
|
}
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
309
|
+
// Items with no children cannot be collabsed
|
|
310
|
+
if (!this.hasChildren(node) && !(this.enableasynchload === true || this.enableasynchload === 'true')) {
|
|
311
|
+
return;
|
|
312
|
+
}
|
|
313
|
+
let value = node[this.attrexanded];
|
|
314
|
+
if (value === true || value === 'true') {
|
|
315
|
+
this.collabsed.emit(node);
|
|
316
|
+
node[this.attrexanded] = false;
|
|
317
|
+
}
|
|
318
|
+
else {
|
|
319
|
+
this.expanded.emit(node);
|
|
320
|
+
node[this.attrexanded] = true;
|
|
295
321
|
}
|
|
296
|
-
|
|
322
|
+
}
|
|
323
|
+
resetSelectedState(node) {
|
|
324
|
+
if (!node || !this.attrselected) {
|
|
325
|
+
return;
|
|
326
|
+
}
|
|
327
|
+
node[this.attrselected] = false;
|
|
328
|
+
this.getChildren(node).forEach((child) => {
|
|
329
|
+
this.resetSelectedState(child);
|
|
330
|
+
});
|
|
297
331
|
}
|
|
298
332
|
}
|
|
299
|
-
|
|
333
|
+
SacTreeviewCommon.decorators = [
|
|
300
334
|
{ type: Directive }
|
|
301
335
|
];
|
|
302
|
-
|
|
336
|
+
SacTreeviewCommon.ctorParameters = () => [
|
|
337
|
+
{ type: SacFormLayoutCommon, decorators: [{ type: Host }] },
|
|
338
|
+
{ type: Injector }
|
|
339
|
+
];
|
|
340
|
+
SacTreeviewCommon.propDecorators = {
|
|
341
|
+
actionclicked: [{ type: Output }],
|
|
342
|
+
attrchildren: [{ type: Input }],
|
|
343
|
+
attrdisableaction: [{ type: Input }],
|
|
344
|
+
attrexanded: [{ type: Input }],
|
|
345
|
+
attrhoverstate: [{ type: Input }],
|
|
346
|
+
attricon: [{ type: Input }],
|
|
347
|
+
attrid: [{ type: Input }],
|
|
348
|
+
attrlabel: [{ type: Input }],
|
|
349
|
+
attrselected: [{ type: Input }],
|
|
350
|
+
collabsed: [{ type: Output }],
|
|
303
351
|
data: [{ type: Input }],
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
352
|
+
enableasynchload: [{ type: Input }],
|
|
353
|
+
enableellipsis: [{ type: Input }],
|
|
354
|
+
expanded: [{ type: Output }],
|
|
355
|
+
expandedstate: [{ type: Input }],
|
|
356
|
+
isrequired: [{ type: Input }],
|
|
308
357
|
name: [{ type: Input }],
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
selectedid: [{ type: Input }],
|
|
318
|
-
selectedidchange: [{ type: Output }],
|
|
319
|
-
selectedtextchanged: [{ type: Output }],
|
|
320
|
-
selecteditem: [{ type: Output }]
|
|
358
|
+
selected: [{ type: Output }],
|
|
359
|
+
selectednode: [{ type: Output }],
|
|
360
|
+
showactionalways: [{ type: Input }],
|
|
361
|
+
templateaction: [{ type: Input }],
|
|
362
|
+
templateicon: [{ type: Input }],
|
|
363
|
+
templatelabel: [{ type: Input }],
|
|
364
|
+
validationmessagerequired: [{ type: Input }],
|
|
365
|
+
validationmessagesummaryrequired: [{ type: Input }]
|
|
321
366
|
};
|
|
322
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"treeview.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/treeview/treeview.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,YAAY,EACZ,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,EACN,WAAW,GACZ,MAAM,eAAe,CAAC;AAEvB;;GAEG;AAEH,MAAM,OAAO,iBAAiB;IAD9B;QAYE;;WAEG;QACI,UAAK,GAAU,EAAE,CAAC;QAEzB;;WAEG;QACI,iBAAY,GAAG,aAAa,CAAC;QAEpC;;WAEG;QACI,eAAU,GAAG,YAAY,CAAC;QAEjC;;WAEG;QACI,sBAAiB,GAAG,iBAAiB,CAAC;QAE7C;;WAEG;QACK,UAAK,GAAU,EAAE,CAAC;QAoE1B;;WAEG;QAEH,SAAI,GAAW,EAAE,CAAC;QAElB;;;WAGG;QACM,gBAAW,GAAG,KAAK,CAAC;QAE7B;;WAEG;QACM,aAAQ,GAAG,MAAM,CAAC;QAE3B;;WAEG;QACM,WAAM,GAAG,IAAI,CAAC;QAEvB;;WAEG;QACM,eAAU,GAAG,WAAW,CAAC;QAElC;;WAEG;QACM,iBAAY,GAAG,UAAU,CAAC;QA2FnC;;WAEG;QAEH,qBAAgB,GAAsB,IAAI,YAAY,EAAO,CAAC;QAE9D;;WAEG;QAEH,wBAAmB,GAAyB,IAAI,YAAY,EAAU,CAAC;QAEvE;;WAEG;QAEH,iBAAY,GAAyB,IAAI,YAAY,EAAU,CAAC;IAqJlE,CAAC;IAhWC;;OAEG;IACH,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED;;OAEG;IACH,IACI,IAAI,CAAC,KAAY;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,oDAAoD;QAEpD,IAAI,CAAC,QAAQ,EAAE,CAAC;QAEhB,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS,EAAE;YACnC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SACzC;IACH,CAAC;IAQD;;OAEG;IACH,IACW,gBAAgB,CAAC,CAAmB;QAC7C,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC;IACpB,CAAC;IAED;;OAEG;IACH,IAAW,gBAAgB;QACzB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAQD;;OAEG;IACH,IACW,YAAY,CAAC,CAAmB;QACzC,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC;IAC5B,CAAC;IAED;;OAEG;IACH,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IAuCD,6CAA6C;IAE7C;;OAEG;IACH,IACI,WAAW,CAAC,KAAc;QAC5B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YAC5D,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SACzC;QAED,uBAAuB;QACvB,0EAA0E;QAE1E,2BAA2B;IAC7B,CAAC;IAED;;OAEG;IACH,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED;;OAEG;IACH,IACI,SAAS,CAAC,KAAc;QAC1B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;QAC3E,IAAI,CAAC,cAAc,CACjB,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,iBAAiB,EACtB,KAAK,CACN,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,IACI,UAAU,CAAC,CAAM;QACnB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAE9D,2BAA2B;QAC3B,iEAAiE;QACjE,qEAAqE;QACrE,IAAI;IACN,CAAC;IAED;;OAEG;IACH,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACnE,CAAC;IAOD;;OAEG;IACH,IAAI,YAAY,CAAC,CAAM;QACrB,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QAEvB,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC5C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;SACjD;IACH,CAAC;IAED;;OAEG;IACH,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAoBD;;;OAGG;IACH,QAAQ;QACN,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAExC,IAAI,IAAI,CAAC,UAAU;YAAE,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzD,CAAC;IAED;;;OAGG;IACK,gBAAgB,CAAC,IAAI;QAC3B,IAAI,MAAM,GAAY,KAAK,CAAC;QAC5B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACpC,IACE,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM;gBACjC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,UAAU;gBAEvC,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;YAC7D,IAAI,MAAM,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,UAAU,EAAE;gBACrD,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,KAAK,CAAC;gBACnC,OAAO,IAAI,CAAC;aACb;SACF;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;OAEG;IACK,QAAQ;QACd,0EAA0E;QAC1E,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;QAE3D,yDAAyD;QACzD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;IAC7E,CAAC;IAED;;OAEG;IACH,eAAe,CAAC,IAAI;QAClB,IAAI,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,EAAE;YAClC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SACpD;IACH,CAAC;IAED;;OAEG;IACH,OAAO,CAAC,IAAI;QACV,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC1C,2BAA2B;IAC7B,CAAC;IAED;;OAEG;IACH,eAAe,CAAC,GAAG;QACjB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC9B,CAAC;IAED;;OAEG;IACH,eAAe,CAAC,OAAO;QACrB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC1B,IAAI,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,EAAE;gBAClC,iBAAiB,CAAC,IAAI,EAAE,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;aACxE;QACH,CAAC,CAAC,CAAC;QACH,SAAS,iBAAiB,CAAC,IAAI,EAAE,YAAY,EAAE,OAAO,EAAE,YAAY;YAClE,IAAI,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC;YAC7B,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,KAAU,EAAE,EAAE;gBACnC,IAAI,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,EAAE;oBAC9B,iBAAiB,CAAC,KAAK,EAAE,YAAY,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC;iBAC/D;YACH,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED;;;;;;OAMG;IACK,QAAQ,CAAC,IAAI,EAAE,WAAW,EAAE,IAAI;QACtC,IAAI,MAAM,GAAQ,IAAI,CAAC;QACvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACpC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,WAAW;gBAAE,MAAM,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;iBAC9C;gBACH,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,EAAE;oBACrC,IAAI,eAAe,GAAG,IAAI,CAAC,QAAQ,CACjC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,EAC1B,WAAW,EACX,IAAI,CACL,CAAC;oBACF,IAAI,eAAe;wBAAE,MAAM,GAAG,eAAe,CAAC;iBAC/C;aACF;SACF;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;OAEG;IACK,cAAc,CAAC,IAAI,EAAE,YAAY,EAAE,IAAI,EAAE,KAAK;QACpD,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;gBAC/C,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC;gBACtB,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,EAAE;oBAChC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,EAAE,YAAY,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;iBACvE;aACF;SACF;IACH,CAAC;IAED;;OAEG;IACK,gBAAgB,CAAC,IAAI;QAC3B,MAAM,IAAI,GAAG,EAAE,EACb,MAAM,GAAG,EAAE,CAAC;QACd,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;YAC/C,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;YACvC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC;YAChC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC;YAClC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,KAAK,CAAC;YACjC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,KAAK,CAAC;SACzC;QACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;YAC/C,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;gBAC5B,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;aACnE;iBAAM;gBACL,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;aACpB;SACF;QAED,OAAO,IAAI,CAAC;IACd,CAAC;;;YApYF,SAAS;;;mBA+CP,KAAK;uBAiBL,KAAK;+BAML,YAAY,SAAC,SAAS,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;+BAexC,KAAK;2BAML,YAAY,SAAC,cAAc,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;mBAe7C,KAAK;0BAOL,KAAK;uBAKL,KAAK;qBAKL,KAAK;yBAKL,KAAK;2BAKL,KAAK;oBAKL,KAAK;0BAOL,KAAK;wBAuBL,KAAK;yBAeL,KAAK;+BA4CL,MAAM;kCAMN,MAAM;2BAMN,MAAM","sourcesContent":["import {\r\n  ContentChild,\r\n  Directive,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  TemplateRef,\r\n} from '@angular/core';\r\n\r\n/**\r\n * Basis Komponente für SacTreeView\r\n */\r\n@Directive()\r\nexport class SacTreeViewCommon implements OnInit {\r\n  /**\r\n   * Das Property enthielt boolean Wert und deffiniert, ob alle Items collapsed sind. Default value: undefined/null\r\n   */\r\n  public _collapseAll: boolean;\r\n\r\n  /**\r\n   * Das Property enthielt boolean Wert und deffiniert, ob alle Items selected sind. Default value: undefined/null\r\n   */\r\n  private _selectAll: boolean;\r\n\r\n  /**\r\n   * Das Property enthielt array of nodes. Default value: empty array [].\r\n   */\r\n  public nodes: any[] = [];\r\n\r\n  /**\r\n   * Das Property enthielt node attribute: 'isCollapsed'. Es wird benutzt beim rendering. Für Expand/Collapsed Sicht des Node(Wert)\r\n   */\r\n  public collapseAttr = 'isCollapsed';\r\n\r\n  /**\r\n   * Das Property enthielt node attribute: 'isSelected'. Es wird benutzt beim Vorbereitung des Data des TreeView\r\n   */\r\n  public selectAttr = 'isSelected';\r\n\r\n  /**\r\n   * Das Property enthielt node attribute: 'isIndeterminate'. Es wird benutzt beim Vorbereitung des Data des TreeView\r\n   */\r\n  public inDeterminateAttr = 'isIndeterminate';\r\n\r\n  /**\r\n   * Providen data for tree.\r\n   */\r\n  private _data: any[] = [];\r\n\r\n  /**\r\n   * Getter für Data des TreeView\r\n   */\r\n  get data(): any[] {\r\n    return this._data;\r\n  }\r\n\r\n  /**\r\n   * Input Property für Data des TreeView\r\n   */\r\n  @Input()\r\n  set data(value: any[]) {\r\n    this._data = value;\r\n    this.nodes = value;\r\n\r\n    // this.nodes.forEach(node => node[\"typeId\"] = \"13\")\r\n\r\n    this.LoadTree();\r\n\r\n    if (this._collapseAll !== undefined) {\r\n      this.collapseAllNode(this._collapseAll);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Input Property für template des TreeView. Type: TemplateRef<any>.\r\n   */\r\n  @Input()\r\n  template: TemplateRef<any>;\r\n\r\n  /**\r\n   * Die Directive erhält die actions für das TreeView\r\n   */\r\n  @ContentChild('actions', { static: true })\r\n  public set treeviewTemplate(v: TemplateRef<any>) {\r\n    this.template = v;\r\n  }\r\n\r\n  /**\r\n   * Getter für das TreeView Template\r\n   */\r\n  public get treeviewTemplate(): TemplateRef<any> {\r\n    return this.template;\r\n  }\r\n\r\n  /**\r\n   * Input property erhält Icon für das Template\r\n   */\r\n  @Input()\r\n  fileicontemplate: TemplateRef<any>;\r\n\r\n  /**\r\n   * Setter property. Deffiniert das FileIcon für das TreeView\r\n   */\r\n  @ContentChild('treefileicon', { static: true })\r\n  public set treefileicon(v: TemplateRef<any>) {\r\n    this.fileicontemplate = v;\r\n  }\r\n\r\n  /**\r\n   * Getter property. Ergibt das FileIcon für das TreeView\r\n   */\r\n  public get treefileicon(): TemplateRef<any> {\r\n    return this.fileicontemplate;\r\n  }\r\n\r\n  /**\r\n   * Input property für den Namen des TreeView. Type string. Default value: \"\"\r\n   */\r\n  @Input()\r\n  name: string = '';\r\n\r\n  /**\r\n   * A flag indicating data is flatten in array and prepare is required.(Default\r\n   * is false).\r\n   */\r\n  @Input() prepareData = false;\r\n\r\n  /**\r\n   * Attribute for Text in Tree\r\n   */\r\n  @Input() textAttr = 'data';\r\n\r\n  /**\r\n   * Name of ID property in input data.\r\n   */\r\n  @Input() idAttr = 'id';\r\n\r\n  /**\r\n   * Name of parent property in input data.\r\n   */\r\n  @Input() parentAttr = 'PARENT_ID';\r\n\r\n  /**\r\n   * Name of children list property in input data.\r\n   */\r\n  @Input() childrenAttr = 'children';\r\n\r\n  /**\r\n   * Title des Treeview\r\n   */\r\n  @Input() title;\r\n\r\n  // @Input(\"titleAction\") _titleAction: string\r\n\r\n  /**\r\n   * Collapse or expand all parent nodes.\r\n   */\r\n  @Input()\r\n  set collapseall(value: boolean) {\r\n    this._collapseAll = value;\r\n    if (this.nodes && this.nodes.length && this.nodes.length > 0) {\r\n      this.collapseAllNode(this._collapseAll);\r\n    }\r\n\r\n    // this._recursiveEdit(\r\n    //   this.nodes, this.childrenAttr, this.collapseAttr, this._collapseAll);\r\n\r\n    // this.cd.detectChanges();\r\n  }\r\n\r\n  /**\r\n   * Getter für das collapse property. Ergibt boolean Wert, ob die Items collapsed/expand sind.\r\n   */\r\n  get collapseall(): boolean {\r\n    return this._collapseAll;\r\n  }\r\n\r\n  /**\r\n   * Select or deselect all nodes.\r\n   */\r\n  @Input()\r\n  set selectall(value: boolean) {\r\n    this._selectAll = value;\r\n    this._recursiveEdit(this.nodes, this.childrenAttr, this.selectAttr, value);\r\n    this._recursiveEdit(\r\n      this.nodes,\r\n      this.childrenAttr,\r\n      this.inDeterminateAttr,\r\n      false\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Input property - setter. Deffiniert das ID des selektierten Item(node)\r\n   */\r\n  @Input()\r\n  set selectedid(v: any) {\r\n    this.selectedNode = this.findNode(this.nodes, v, this.idAttr);\r\n\r\n    // if (this.selectedNode) {\r\n    //   this.selectedIdEmitter.emit(this.selectedNode[this.idAttr]);\r\n    //   this.selectedTextEmitter.emit(this.selectedNode[this.textAttr]);\r\n    // }\r\n  }\r\n\r\n  /**\r\n   * Getter. Ergibt das ID des selektierten Item(node)\r\n   */\r\n  get selectedId(): any {\r\n    return this.selectedNode ? this.selectedNode[this.idAttr] : null;\r\n  }\r\n\r\n  /**\r\n   * Das Property erhält das selektierte Wert(node). Default value: undefined/null\r\n   */\r\n  private _selectedNode;\r\n\r\n  /**\r\n   * Setter für das selektierte Wert(node). Wenn aufgerufen das ID und TextAttr des selected Node wird emitted\r\n   */\r\n  set selectedNode(v: any) {\r\n    this._selectedNode = v;\r\n\r\n    if (this._selectedNode) {\r\n      this.selectedidchange.emit(this.selectedId);\r\n      this.selectedtextchanged.emit(v[this.textAttr]);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Getter für das selektierte Wert(node). Ergibt das selektierte Wert(node).\r\n   */\r\n  get selectedNode(): any {\r\n    return this._selectedNode;\r\n  }\r\n\r\n  /**\r\n   * Output Emitter. Emit das ID des selected Node.\r\n   */\r\n  @Output()\r\n  selectedidchange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  /**\r\n   * Output Emitter. Emit das TextAttr des selected Node.\r\n   */\r\n  @Output()\r\n  selectedtextchanged: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n  /**\r\n   * Output Emitter. Emit wenn ein Node selektiert wird.\r\n   */\r\n  @Output()\r\n  selecteditem: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n  /**\r\n   * A lifecycle hook that is called after Angular has initialized all data-bound properties of a directive.\r\n   * Define an ngOnInit() method to handle any additional initialization tasks.\r\n   */\r\n  ngOnInit() {\r\n    this.collapseAllNode(this._collapseAll);\r\n\r\n    if (this.selectedId) this.openSelectedNode(this.nodes);\r\n  }\r\n\r\n  /**\r\n   * Funktion setzt alle parent items recusiv zum selected node\r\n   * auf collapsed = false\r\n   */\r\n  private openSelectedNode(data): boolean {\r\n    let result: boolean = false;\r\n    for (let i = 0; i < data.length; i++) {\r\n      if (\r\n        data[i][this.childrenAttr].length &&\r\n        data[i][this.idAttr] != this.selectedId\r\n      )\r\n        result = this.openSelectedNode(data[i][this.childrenAttr]);\r\n      if (result || data[i][this.idAttr] == this.selectedId) {\r\n        data[i][this.collapseAttr] = false;\r\n        return true;\r\n      }\r\n    }\r\n    return false;\r\n  }\r\n\r\n  /**\r\n   * Die Methode vorbereitet die Daten für das TreeView. Die Funktion sollte geändert werden abhängig von dem kommenden Daten (wenn array)\r\n   */\r\n  private LoadTree() {\r\n    //if the tree structure require array the function below should be changed\r\n    const cloned = this._data.map((x) => Object.assign({}, x));\r\n\r\n    // If data is flat, prepare data with recursive function.\r\n    this.nodes = this.prepareData ? this._getPreparedData(cloned) : this._data;\r\n  }\r\n\r\n  /**\r\n   * Die Methode collapse/expand den selectierten Node\r\n   */\r\n  onCollapseClick(node) {\r\n    if (node[this.childrenAttr].length) {\r\n      node[this.collapseAttr] = !node[this.collapseAttr];\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Die Methode set den selektierten Node und emit es.\r\n   */\r\n  onClick(node) {\r\n    this.selectedNode = node;\r\n    this.selecteditem.emit(this.selectedNode);\r\n    // this.cd.detectChanges();\r\n  }\r\n\r\n  /**\r\n   * Die Methode wird ein event mit Meldung zu Parent emit-en.\r\n   */\r\n  sendMsgToParent(msg) {\r\n    this.selecteditem.emit(msg);\r\n  }\r\n\r\n  /**\r\n   * Die Methode wird alle Nodes collapse\r\n   */\r\n  collapseAllNode(command) {\r\n    this.nodes.forEach((node) => {\r\n      if (node[this.childrenAttr].length) {\r\n        collapseAllHIdden(node, this.collapseAttr, command, this.childrenAttr);\r\n      }\r\n    });\r\n    function collapseAllHIdden(node, collapseAttr, command, childrenAttr) {\r\n      node[collapseAttr] = command;\r\n      node.children.forEach((child: any) => {\r\n        if (child[childrenAttr].length) {\r\n          collapseAllHIdden(child, collapseAttr, command, childrenAttr);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Funktion gibt node aus der liste zurück, welches das Value auf dem gewünschten Attribut hat\r\n   * Wenn node nicht gefunden wird, wird null zurück gegeben\r\n   * @param data Liste der nodes\r\n   * @param searchValue Das gesuchte value\r\n   * @param attr Der namen des Attributs auf dem das value gesucht wird\r\n   */\r\n  private findNode(data, searchValue, attr): any {\r\n    let result: any = null;\r\n    for (let i = 0; i < data.length; i++) {\r\n      if (data[i][attr] == searchValue) result = data[i];\r\n      else {\r\n        if (data[i][this.childrenAttr].length) {\r\n          let recursiveResult = this.findNode(\r\n            data[i][this.childrenAttr],\r\n            searchValue,\r\n            attr\r\n          );\r\n          if (recursiveResult) result = recursiveResult;\r\n        }\r\n      }\r\n    }\r\n    return result;\r\n  }\r\n\r\n  /**\r\n   * Die Methode editiert (recursive) alle eingegebene Nodes abhängig von gegebenen Attibute und Value Kriterien.\r\n   */\r\n  private _recursiveEdit(list, childrenAttr, attr, value) {\r\n    if (Array.isArray(list)) {\r\n      for (let i = 0, len = list.length; i < len; i++) {\r\n        list[i][attr] = value;\r\n        if (list[i][childrenAttr].length) {\r\n          this._recursiveEdit(list[i][childrenAttr], childrenAttr, attr, value);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Die Methode erstellt eine standarte Sicht-Liste von Nodes\r\n   */\r\n  private _getPreparedData(list) {\r\n    const tree = [],\r\n      lookup = {};\r\n    for (let i = 0, len = list.length; i < len; i++) {\r\n      lookup[list[i][this.idAttr]] = list[i];\r\n      list[i][this.childrenAttr] = [];\r\n      list[i][this.collapseAttr] = true;\r\n      list[i][this.selectAttr] = false;\r\n      list[i][this.inDeterminateAttr] = false;\r\n    }\r\n    for (let i = 0, len = list.length; i < len; i++) {\r\n      if (list[i][this.parentAttr]) {\r\n        lookup[list[i][this.parentAttr]][this.childrenAttr].push(list[i]);\r\n      } else {\r\n        tree.push(list[i]);\r\n      }\r\n    }\r\n\r\n    return tree;\r\n  }\r\n}\r\n"]}
|
|
367
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"treeview.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/treeview/treeview.ts"],"names":[],"mappings":"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","sourcesContent":["import { SacBaseModelControl } from '../../common/basemodelcontrol';\r\nimport { TreeviewAction } from '../../interfaces/treeviewaction.interface';\r\nimport { Validation } from '../../validation';\r\nimport { SacFormLayoutCommon } from '../layout/formlayout';\r\nimport { Directive, EventEmitter, Host, Injector, Input, Output, TemplateRef } from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\n\r\n/**\r\n * Basis Komponente für SacTreeView\r\n */\r\n@Directive()\r\nexport class SacTreeviewCommon extends SacBaseModelControl<any> {\r\n    // #region Properties\r\n\r\n    /**\r\n     * Event when Action is clicked on Node.  An object of the type 'TreeviewAction' is returned. In the default case, 'action' in this object is always the value 'default'. The value can be changed via the 'templateaction'.\r\n     */\r\n    @Output()\r\n    public actionclicked: EventEmitter<TreeviewAction> = new EventEmitter<TreeviewAction>();\r\n\r\n    /**\r\n     * Property on the data object that contains the children of the structure element. Must be an array of objects. The default value is 'children'\r\n     */\r\n    @Input()\r\n    public attrchildren = 'children';\r\n\r\n    /**\r\n     * Defines the property on the 'data' object with which the actions for a node can be deactivated. A 'disabled' property is used by default.\r\n     */\r\n    @Input() public attrdisableaction = 'disabled';\r\n\r\n    /**\r\n     * Property on the 'data' object that stores the expanded state. Property must be of type boolean. Default is 'expanded'\r\n     */\r\n    @Input()\r\n    public attrexanded = 'expanded';\r\n\r\n    /**\r\n     * Property for saving the HoverState on the field. If the property is not present on the node, it is automatically created and removed again. The value can usually be left at the default value unless there is a conflict with a property on the node that is required for other purposes.\r\n     */\r\n    @Input()\r\n    public attrhoverstate = 'hoverstate';\r\n\r\n    /**\r\n     * Property on 'data' object, which contains the icon for the node. By default, the property is not set, which hides the icon in the node.\r\n     */\r\n    @Input()\r\n    public attricon: string | null = null;\r\n\r\n    /**\r\n     * property on the 'data' object contains an ID of the node. The default is 'id'. If the property is set to NULL, the selectedId event is no longer triggered.\r\n     */\r\n    @Input()\r\n    public attrid: string | null = 'id';\r\n\r\n    /**\r\n     * Property on 'data' object, which contains the label for the node. Default is 'label'\r\n     */\r\n    @Input()\r\n    public attrlabel = 'label';\r\n\r\n    /**\r\n     * Property on 'data' object, which defines whether the node is selected or not. It should be ensured that only 1 node has the value for Selected set to true. Default is 'selected'.\r\n     */\r\n    @Input()\r\n    public attrselected = 'selected';\r\n\r\n    /**\r\n     * Event when a node is collapsed. Returns the node element as a parameter\r\n     */\r\n    @Output()\r\n    public collabsed: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    /**\r\n     * The property contains an array of nodes. The data must already map the tree via child properties.\r\n     */\r\n    @Input()\r\n    public data: any[] = [];\r\n\r\n    /**\r\n     * Activates the 'expand' and 'collabse' event even if a node has no children. This is helpful if node elements are to be reloaded at runtime.\r\n     */\r\n    @Input()\r\n    public enableasynchload: boolean | string = false;\r\n\r\n    /**\r\n     * Activates Ellipsis on the node labels\r\n     */\r\n    @Input()\r\n    public enableellipsis = true;\r\n\r\n    /**\r\n     * Event when a node is expanded. Returns the node element as a parameter\r\n     */\r\n    @Output()\r\n    public expanded: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    /**\r\n     * Defines whether an icon for the expanded/collapsed status should be displayed.\r\n     */\r\n    @Input()\r\n    public expandedstate: boolean | string = true;\r\n\r\n    /**\r\n     * A node must be selected\r\n     */\r\n    @Input()\r\n    public isrequired: boolean = false;\r\n\r\n    /**\r\n     * Name of the TreeView control\r\n     */\r\n    @Input()\r\n    public name: string = '';\r\n\r\n    /**\r\n     * Event when a node is selected. Returns the id attribute as a parameter. The event is not triggered if 'attrid' is not set.\r\n     */\r\n    @Output()\r\n    public selected: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    /**\r\n     * Event when a node is selected. Returns the node element as a parameter.\r\n     */\r\n    @Output()\r\n    public selectednode: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    /**\r\n     * Defines that the action template is displayed independently of the selected state. If the value is 'true', the action template is displayed for every element.\r\n     */\r\n    @Input()\r\n    public showactionalways;\r\n\r\n    /**\r\n     * Custom template for actions per node. Template parameters are: 'node'\r\n     */\r\n    @Input()\r\n    public templateaction: TemplateRef<any>;\r\n\r\n    /**\r\n     * Custom template for icon per node. Template parameters are: 'node'\r\n     */\r\n    @Input()\r\n    public templateicon: TemplateRef<any>;\r\n\r\n    /**\r\n     * Custom template for the label area per node. Template parameters are: 'node' and 'label'\r\n     */\r\n    @Input()\r\n    public templatelabel: TemplateRef<any>;\r\n\r\n    /**\r\n     * Resource Key für Validation Message Required bei Control\r\n     */\r\n    @Input() public validationmessagerequired: string = this.validationKeyService.ValidationErrorRequired;\r\n\r\n    /**\r\n     * Resource Key für Validation Message Required in Validation Summary\r\n     */\r\n    @Input()\r\n    public validationmessagesummaryrequired: string = this.validationKeyService.ValidationErrorSummaryRequired;\r\n\r\n    // #endregion Properties\r\n\r\n    // #region Constructors\r\n\r\n    /**\r\n     * Constructor\r\n     * @param injector Service Injector\r\n     */\r\n    constructor(@Host() formlayout: SacFormLayoutCommon, injector: Injector) {\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    public get iconAction(): string {\r\n        return this.iconService.TreeviewNodeActionIcon;\r\n    }\r\n\r\n    /**\r\n     * CSS icon for folders in tree there are collabsed\r\n     * @returns css class with icon\r\n     */\r\n    public get iconFolderCollabsed(): string {\r\n        return this.iconService.TreeviewNodeClosedIcon;\r\n    }\r\n\r\n    /**\r\n     * CSS icon class for folders without subfolders\r\n     * @returns css class with icon\r\n     */\r\n    public get iconFolderEmpty(): string {\r\n        return this.iconService.TreeviewNodeEmptyIcon;\r\n    }\r\n\r\n    /**\r\n     * CSS icon for folders in tree there are expanded\r\n     * @returns css class with icon\r\n     */\r\n    public get iconFolderOpen(): string {\r\n        return this.iconService.TreeviewNodeOpenIcon;\r\n    }\r\n\r\n    // #endregion Public Getters And Setters\r\n\r\n    // #region Public Methods\r\n\r\n    /**\r\n     * Creates an array of a certain size. Is required for a For in the UI, as Angular does not support counting loops\r\n     * @param size Size of the array\r\n     * @returns Array\r\n     */\r\n    public count(size: number): Array<void> {\r\n        return new Array(size);\r\n    }\r\n\r\n    public getChildren(node: any): any[] {\r\n        if (!node || !this.attrchildren) {\r\n            return [];\r\n        }\r\n\r\n        let children = node[this.attrchildren];\r\n\r\n        if (!Array.isArray(children)) {\r\n            return [];\r\n        }\r\n\r\n        return children;\r\n    }\r\n\r\n    public getStringField(node: any, fieldname: string): any {\r\n        if (!node) {\r\n            return '';\r\n        }\r\n\r\n        if (!fieldname) {\r\n            return node;\r\n        }\r\n\r\n        let value = node[fieldname];\r\n\r\n        if (!value) {\r\n            return '';\r\n        }\r\n\r\n        return value;\r\n    }\r\n\r\n    public hasChildren(node: any): boolean {\r\n        return this.getChildren(node).length > 0;\r\n    }\r\n\r\n    public isDisabledState(node: any): boolean {\r\n        if (!node || !this.attrdisableaction) {\r\n            return false;\r\n        }\r\n\r\n        let value = node[this.attrdisableaction];\r\n        return value === true || value === 'true';\r\n    }\r\n\r\n    public isExpandedState(node: any): boolean {\r\n        if (!node || !this.attrexanded) {\r\n            return false;\r\n        }\r\n\r\n        let value = node[this.attrexanded];\r\n        return value === true || value === 'true';\r\n    }\r\n\r\n    public isHoverState(node: any): boolean {\r\n        if (!node || !this.attrhoverstate) {\r\n            return false;\r\n        }\r\n\r\n        let value = node[this.attrhoverstate];\r\n        return value === true || value === 'true';\r\n    }\r\n\r\n    public isSelectedState(node: any): boolean {\r\n        if (!node || !this.attrselected) {\r\n            return false;\r\n        }\r\n\r\n        let value = node[this.attrselected];\r\n        return value === true || value === 'true';\r\n    }\r\n\r\n    /**\r\n     * Method is called by clicking an action\r\n     * @param action action and node\r\n     */\r\n    public onActionClicked(action: TreeviewAction) {\r\n        this.actionclicked.emit(action);\r\n    }\r\n\r\n    /**\r\n     * Method is called when Node in Tree is clicked\r\n     * @param node Selected Node\r\n     */\r\n    public onNodeClicked(node: any): void {\r\n        if (this.isDisabledState(node) || this.isSelectedState(node)) {\r\n            this.invertExpandedState(node);\r\n        }\r\n\r\n        this.setSelectedState(node);\r\n    }\r\n\r\n    /**\r\n     * Sets the hover state on a node\r\n     * @param node Node on which the status is set\r\n     * @param state Activate or deactivate HoverState\r\n     */\r\n    public setHoverState(node: any, state: boolean) {\r\n        if (!node || !this.attrhoverstate) {\r\n            return;\r\n        }\r\n\r\n        if (state) {\r\n            node[this.attrhoverstate] = true;\r\n            return;\r\n        }\r\n\r\n        if (!node.hasOwnProperty(this.attrhoverstate)) {\r\n            return;\r\n        }\r\n\r\n        delete node[this.attrhoverstate];\r\n    }\r\n\r\n    /**\r\n     * Sets the selected state on a node\r\n     * @param node Node which is marked as Selected\r\n     */\r\n    public setSelectedState(node: any): void {\r\n        if (!node || !this.attrselected) {\r\n            return;\r\n        }\r\n\r\n        // reset selected state of any node\r\n        this.data.forEach((rootNode) => this.resetSelectedState(rootNode));\r\n\r\n        // set selected node as selected\r\n        node[this.attrselected] = true;\r\n\r\n        // Extract ID from Node\r\n        const idValue = node[this.attrid];\r\n\r\n        // Update ngModel\r\n        this.setValue(idValue);\r\n\r\n        // Raise Selected Events\r\n        this.selectednode.emit(node);\r\n\r\n        if (!this.attrid) {\r\n            return;\r\n        }\r\n\r\n        let id = this.getStringField(node, this.attrid);\r\n        this.selected.emit(id);\r\n    }\r\n\r\n    /**\r\n     * Validates the model state of the control\r\n     * @param c Control instance\r\n     * @returns Returns a validation error, if present. Otherwise, as Result is NULL\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(this.validationmessagerequired, this.validationmessagesummaryrequired)(c);\r\n        }\r\n\r\n        return error;\r\n    }\r\n\r\n    /**\r\n     * Saves the data from the model binding\r\n     * @param value Id of the selected node\r\n     */\r\n    public writeValue(value: any): void {\r\n        super.writeValue(value);\r\n\r\n        // Do not preselct item when tree is empty\r\n        if (!this.data) {\r\n            return;\r\n        }\r\n\r\n        this.data.forEach((root) => {\r\n            const result = this.findNodeById(root, value);\r\n\r\n            if (result !== null) {\r\n                this.setSelectedState(result);\r\n            }\r\n        });\r\n    }\r\n\r\n    // #endregion Public Methods\r\n\r\n    // #region Private Methods\r\n\r\n    /**\r\n     * Searches for a node based on the value in the ID attribute\r\n     * @param node Node\r\n     * @param value Value of the Id attribute\r\n     * @returns Returns the node if it is found. If not, NULL is returned.\r\n     */\r\n    private findNodeById(node: any, value: any): any {\r\n        if (!this.attrid || !node) {\r\n            return null;\r\n        }\r\n\r\n        if (node[this.attrid] === value) {\r\n            return node;\r\n        }\r\n\r\n        const children = this.getChildren(node);\r\n        for (let child of children) {\r\n            const result = this.findNodeById(child, value);\r\n            if (result !== null) {\r\n                return result;\r\n            }\r\n        }\r\n\r\n        return null;\r\n    }\r\n\r\n    private invertExpandedState(node: any) {\r\n        if (!node || !this.attrexanded) {\r\n            return;\r\n        }\r\n\r\n        // Items with no children cannot be collabsed\r\n        if (!this.hasChildren(node) && !(this.enableasynchload === true || this.enableasynchload === 'true')) {\r\n            return;\r\n        }\r\n\r\n        let value = node[this.attrexanded];\r\n\r\n        if (value === true || value === 'true') {\r\n            this.collabsed.emit(node);\r\n            node[this.attrexanded] = false;\r\n        } else {\r\n            this.expanded.emit(node);\r\n            node[this.attrexanded] = true;\r\n        }\r\n    }\r\n\r\n    private resetSelectedState(node: any) {\r\n        if (!node || !this.attrselected) {\r\n            return;\r\n        }\r\n\r\n        node[this.attrselected] = false;\r\n\r\n        this.getChildren(node).forEach((child) => {\r\n            this.resetSelectedState(child);\r\n        });\r\n    }\r\n\r\n    // #endregion Private Methods\r\n}\r\n"]}
|