@simpleangularcontrols/sac-common 10.0.0-rc.13 → 10.0.0-rc.15

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.
@@ -197,12 +197,21 @@ export class SacTreeviewCommon extends SacBaseModelControl {
197
197
  onActionClicked(action) {
198
198
  this.actionclicked.emit(action);
199
199
  }
200
+ /**
201
+ * Method is called when Node in Tree is clicked
202
+ * @param node Selected Node
203
+ */
200
204
  onNodeClicked(node) {
201
205
  if (this.isDisabledState(node) || this.isSelectedState(node)) {
202
206
  this.invertExpandedState(node);
203
207
  }
204
208
  this.setSelectedState(node);
205
209
  }
210
+ /**
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
214
+ */
206
215
  setHoverState(node, state) {
207
216
  if (!node || !this.attrhoverstate) {
208
217
  return;
@@ -216,6 +225,10 @@ export class SacTreeviewCommon extends SacBaseModelControl {
216
225
  }
217
226
  delete node[this.attrhoverstate];
218
227
  }
228
+ /**
229
+ * Sets the selected state on a node
230
+ * @param node Node which is marked as Selected
231
+ */
219
232
  setSelectedState(node) {
220
233
  if (!node || !this.attrselected) {
221
234
  return;
@@ -224,8 +237,10 @@ export class SacTreeviewCommon extends SacBaseModelControl {
224
237
  this.data.forEach((rootNode) => this.resetSelectedState(rootNode));
225
238
  // set selected node as selected
226
239
  node[this.attrselected] = true;
240
+ // Extract ID from Node
241
+ const idValue = node[this.attrid];
227
242
  // Update ngModel
228
- this.setValue(node);
243
+ this.setValue(idValue);
229
244
  // Raise Selected Events
230
245
  this.selectednode.emit(node);
231
246
  if (!this.attrid) {
@@ -234,6 +249,11 @@ export class SacTreeviewCommon extends SacBaseModelControl {
234
249
  let id = this.getStringField(node, this.attrid);
235
250
  this.selected.emit(id);
236
251
  }
252
+ /**
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
256
+ */
237
257
  validateData(c) {
238
258
  let error = null;
239
259
  if (this.isrequired) {
@@ -241,8 +261,47 @@ export class SacTreeviewCommon extends SacBaseModelControl {
241
261
  }
242
262
  return error;
243
263
  }
264
+ /**
265
+ * Saves the data from the model binding
266
+ * @param value Id of the selected node
267
+ */
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);
278
+ }
279
+ });
280
+ }
244
281
  // #endregion Public Methods
245
282
  // #region Private Methods
283
+ /**
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.
288
+ */
289
+ findNodeById(node, value) {
290
+ if (!this.attrid || !node) {
291
+ return null;
292
+ }
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;
301
+ }
302
+ }
303
+ return null;
304
+ }
246
305
  invertExpandedState(node) {
247
306
  if (!node || !this.attrexanded) {
248
307
  return;
@@ -300,8 +359,9 @@ SacTreeviewCommon.propDecorators = {
300
359
  selectednode: [{ type: Output }],
301
360
  showactionalways: [{ type: Input }],
302
361
  templateaction: [{ type: Input }],
362
+ templateicon: [{ type: Input }],
303
363
  templatelabel: [{ type: Input }],
304
364
  validationmessagerequired: [{ type: Input }],
305
365
  validationmessagesummaryrequired: [{ type: Input }]
306
366
  };
307
- //# 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 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    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    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    public setSelectedState(node: any) {\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        // Update ngModel\r\n        this.setValue(node);\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    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    // #endregion Public Methods\r\n\r\n    // #region Private Methods\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"]}
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"]}
@@ -1,4 +1,4 @@
1
- import { EventEmitter, Directive, Input, Output, ɵɵdefineInjectable, Injectable, InjectionToken, ɵɵinject, Inject, Host, Injector, ChangeDetectorRef, ViewChild, HostListener, Renderer2, ElementRef, ViewChildren, ContentChild, TemplateRef, NgZone, ContentChildren, forwardRef, NgModule } from '@angular/core';
1
+ import { EventEmitter, Directive, Input, Output, ɵɵdefineInjectable, Injectable, InjectionToken, ɵɵinject, Inject, Host, Injector, ChangeDetectorRef, ViewChild, HostListener, Renderer2, ElementRef, ViewChildren, ContentChild, TemplateRef, NgZone, ContentChildren, NgModule } from '@angular/core';
2
2
  import { HttpClient } from '@angular/common/http';
3
3
  import { Observable, of } from 'rxjs';
4
4
  import { NgControl, FormControlName, FormGroupDirective, Validators, FormGroup, NgForm } from '@angular/forms';
@@ -7801,12 +7801,21 @@ class SacTreeviewCommon extends SacBaseModelControl {
7801
7801
  onActionClicked(action) {
7802
7802
  this.actionclicked.emit(action);
7803
7803
  }
7804
+ /**
7805
+ * Method is called when Node in Tree is clicked
7806
+ * @param node Selected Node
7807
+ */
7804
7808
  onNodeClicked(node) {
7805
7809
  if (this.isDisabledState(node) || this.isSelectedState(node)) {
7806
7810
  this.invertExpandedState(node);
7807
7811
  }
7808
7812
  this.setSelectedState(node);
7809
7813
  }
7814
+ /**
7815
+ * Sets the hover state on a node
7816
+ * @param node Node on which the status is set
7817
+ * @param state Activate or deactivate HoverState
7818
+ */
7810
7819
  setHoverState(node, state) {
7811
7820
  if (!node || !this.attrhoverstate) {
7812
7821
  return;
@@ -7820,6 +7829,10 @@ class SacTreeviewCommon extends SacBaseModelControl {
7820
7829
  }
7821
7830
  delete node[this.attrhoverstate];
7822
7831
  }
7832
+ /**
7833
+ * Sets the selected state on a node
7834
+ * @param node Node which is marked as Selected
7835
+ */
7823
7836
  setSelectedState(node) {
7824
7837
  if (!node || !this.attrselected) {
7825
7838
  return;
@@ -7828,8 +7841,10 @@ class SacTreeviewCommon extends SacBaseModelControl {
7828
7841
  this.data.forEach((rootNode) => this.resetSelectedState(rootNode));
7829
7842
  // set selected node as selected
7830
7843
  node[this.attrselected] = true;
7844
+ // Extract ID from Node
7845
+ const idValue = node[this.attrid];
7831
7846
  // Update ngModel
7832
- this.setValue(node);
7847
+ this.setValue(idValue);
7833
7848
  // Raise Selected Events
7834
7849
  this.selectednode.emit(node);
7835
7850
  if (!this.attrid) {
@@ -7838,6 +7853,11 @@ class SacTreeviewCommon extends SacBaseModelControl {
7838
7853
  let id = this.getStringField(node, this.attrid);
7839
7854
  this.selected.emit(id);
7840
7855
  }
7856
+ /**
7857
+ * Validates the model state of the control
7858
+ * @param c Control instance
7859
+ * @returns Returns a validation error, if present. Otherwise, as Result is NULL
7860
+ */
7841
7861
  validateData(c) {
7842
7862
  let error = null;
7843
7863
  if (this.isrequired) {
@@ -7845,8 +7865,47 @@ class SacTreeviewCommon extends SacBaseModelControl {
7845
7865
  }
7846
7866
  return error;
7847
7867
  }
7868
+ /**
7869
+ * Saves the data from the model binding
7870
+ * @param value Id of the selected node
7871
+ */
7872
+ writeValue(value) {
7873
+ super.writeValue(value);
7874
+ // Do not preselct item when tree is empty
7875
+ if (!this.data) {
7876
+ return;
7877
+ }
7878
+ this.data.forEach((root) => {
7879
+ const result = this.findNodeById(root, value);
7880
+ if (result !== null) {
7881
+ this.setSelectedState(result);
7882
+ }
7883
+ });
7884
+ }
7848
7885
  // #endregion Public Methods
7849
7886
  // #region Private Methods
7887
+ /**
7888
+ * Searches for a node based on the value in the ID attribute
7889
+ * @param node Node
7890
+ * @param value Value of the Id attribute
7891
+ * @returns Returns the node if it is found. If not, NULL is returned.
7892
+ */
7893
+ findNodeById(node, value) {
7894
+ if (!this.attrid || !node) {
7895
+ return null;
7896
+ }
7897
+ if (node[this.attrid] === value) {
7898
+ return node;
7899
+ }
7900
+ const children = this.getChildren(node);
7901
+ for (let child of children) {
7902
+ const result = this.findNodeById(child, value);
7903
+ if (result !== null) {
7904
+ return result;
7905
+ }
7906
+ }
7907
+ return null;
7908
+ }
7850
7909
  invertExpandedState(node) {
7851
7910
  if (!node || !this.attrexanded) {
7852
7911
  return;
@@ -7904,6 +7963,7 @@ SacTreeviewCommon.propDecorators = {
7904
7963
  selectednode: [{ type: Output }],
7905
7964
  showactionalways: [{ type: Input }],
7906
7965
  templateaction: [{ type: Input }],
7966
+ templateicon: [{ type: Input }],
7907
7967
  templatelabel: [{ type: Input }],
7908
7968
  validationmessagerequired: [{ type: Input }],
7909
7969
  validationmessagesummaryrequired: [{ type: Input }]
@@ -8147,7 +8207,7 @@ SacTooltipCommon.propDecorators = {
8147
8207
  tooltip: [{ type: ViewChild, args: ['tooltip', { static: false },] }]
8148
8208
  };
8149
8209
 
8150
- // #region Classes
8210
+ // #region Exported Classes
8151
8211
  /**
8152
8212
  * Base Klasse für Uploader Control
8153
8213
  */
@@ -8165,6 +8225,7 @@ class SacUploadBase extends SacBaseModelControl {
8165
8225
  super(formlayout, injector);
8166
8226
  this.renderer = renderer;
8167
8227
  this.ngZone = ngZone;
8228
+ // #region Properties
8168
8229
  /**
8169
8230
  * Erlaubte Dateitypen
8170
8231
  */
@@ -8181,10 +8242,22 @@ class SacUploadBase extends SacBaseModelControl {
8181
8242
  * API Endpoint
8182
8243
  */
8183
8244
  this._endpoint = null;
8245
+ /**
8246
+ * Token for Bearer Authentication
8247
+ */
8248
+ this._token = null;
8184
8249
  /**
8185
8250
  * Upload Settings
8186
8251
  */
8187
8252
  this.options = {};
8253
+ /**
8254
+ * Handling von neuen Files im Input Control
8255
+ */
8256
+ this.fileListener = () => {
8257
+ if (this.uploadInput.nativeElement.files) {
8258
+ this.uploadService.handleFileList(this.uploadInput.nativeElement.files);
8259
+ }
8260
+ };
8188
8261
  /**
8189
8262
  * Definiert das Control als Required
8190
8263
  */
@@ -8193,6 +8266,10 @@ class SacUploadBase extends SacBaseModelControl {
8193
8266
  * Max. Dateigrösse für Files die hochgeladen werden können. 0 deaktiviert den Filter
8194
8267
  */
8195
8268
  this.maxfilesize = 0;
8269
+ /**
8270
+ * Event wenn ein Error in der Komponente ausgelöst wird.
8271
+ */
8272
+ this.onfileerror = new EventEmitter();
8196
8273
  /**
8197
8274
  * Resource Key für Validation Message Required bei Control
8198
8275
  */
@@ -8201,18 +8278,6 @@ class SacUploadBase extends SacBaseModelControl {
8201
8278
  * Resource Key für Validation Message Required in Validation Summary
8202
8279
  */
8203
8280
  this.validationmessagesummaryrequired = this.validationKeyService.ValidationErrorSummaryRequired;
8204
- /**
8205
- * Event wenn ein Error in der Komponente ausgelöst wird.
8206
- */
8207
- this.onfileerror = new EventEmitter();
8208
- /**
8209
- * Handling von neuen Files im Input Control
8210
- */
8211
- this.fileListener = () => {
8212
- if (this.uploadInput.nativeElement.files) {
8213
- this.uploadService.handleFileList(this.uploadInput.nativeElement.files);
8214
- }
8215
- };
8216
8281
  this.validationKeyService = injector.get(SACVALIDATIONKEY_SERVICE, new SacDefaultValidationKeyService());
8217
8282
  this.lngResourceService = injector.get(SACLOCALISATION_SERVICE, new SacDefaultLocalisationService(this.validationKeyService));
8218
8283
  this.uploads = [];
@@ -8233,34 +8298,6 @@ class SacUploadBase extends SacBaseModelControl {
8233
8298
  }
8234
8299
  // #endregion Constructors
8235
8300
  // #region Public Getters And Setters
8236
- /**
8237
- * Erlaubte Dateitypen für den Upload. Format: ".xxx,.yyy,.zzz"
8238
- */
8239
- set allowedtypes(types) {
8240
- this._allowedtypes = types;
8241
- this.setAllowedTypes(types);
8242
- }
8243
- /**
8244
- * Files nach der Auswahl automatisch hochladen
8245
- */
8246
- set autoupload(v) {
8247
- this._autoupload = v;
8248
- this.options.autoUpload = v;
8249
- this.uploadService.connect(this.options);
8250
- }
8251
- /**
8252
- * Uploads können unterbrochen werden
8253
- */
8254
- set enablepause(v) {
8255
- this._enablepause = v;
8256
- }
8257
- /**
8258
- * Definiert den Registration Endpoint für Uploads.
8259
- */
8260
- set endpoint(v) {
8261
- this._endpoint = v;
8262
- this.setEndpoint(v);
8263
- }
8264
8301
  /**
8265
8302
  * Icon for browse button
8266
8303
  */
@@ -8294,17 +8331,56 @@ class SacUploadBase extends SacBaseModelControl {
8294
8331
  get allowedtypes() {
8295
8332
  return this._allowedtypes;
8296
8333
  }
8334
+ /**
8335
+ * Erlaubte Dateitypen für den Upload. Format: ".xxx,.yyy,.zzz"
8336
+ */
8337
+ set allowedtypes(types) {
8338
+ this._allowedtypes = types;
8339
+ this.setAllowedTypes(types);
8340
+ }
8297
8341
  get autoupload() {
8298
8342
  return this._autoupload;
8299
8343
  }
8344
+ /**
8345
+ * Files nach der Auswahl automatisch hochladen
8346
+ */
8347
+ set autoupload(v) {
8348
+ this._autoupload = v;
8349
+ this.options.autoUpload = v;
8350
+ this.uploadService.connect(this.options);
8351
+ }
8300
8352
  get enablepause() {
8301
8353
  return this._enablepause;
8302
8354
  }
8355
+ /**
8356
+ * Uploads können unterbrochen werden
8357
+ */
8358
+ set enablepause(v) {
8359
+ this._enablepause = v;
8360
+ }
8303
8361
  get endpoint() {
8304
8362
  return this._endpoint;
8305
8363
  }
8306
- // #endregion Public Getters And Setters
8307
- // #region Public Methods
8364
+ /**
8365
+ * Definiert den Registration Endpoint für Uploads.
8366
+ */
8367
+ set endpoint(v) {
8368
+ this._endpoint = v;
8369
+ this.setEndpoint(v);
8370
+ }
8371
+ /**
8372
+ * Token for Bearer Authentication
8373
+ */
8374
+ get token() {
8375
+ return this._token;
8376
+ }
8377
+ /**
8378
+ * Token for Bearer Authentication
8379
+ */
8380
+ set token(v) {
8381
+ this._token = v;
8382
+ this.setToken(v);
8383
+ }
8308
8384
  /**
8309
8385
  * Name der Datei die Hochgeladen wird
8310
8386
  * @returns Observable des Dateinamens.
@@ -8330,7 +8406,7 @@ class SacUploadBase extends SacBaseModelControl {
8330
8406
  */
8331
8407
  HasSuccessUpload() {
8332
8408
  if (this.uploads.length > 0) {
8333
- return (this.uploads.filter((itm) => itm.status !== 'complete').length === 0);
8409
+ return this.uploads.filter((itm) => itm.status !== 'complete').length === 0;
8334
8410
  }
8335
8411
  else {
8336
8412
  return false;
@@ -8348,7 +8424,7 @@ class SacUploadBase extends SacBaseModelControl {
8348
8424
  * @returns Elemente für Upload vorhanden
8349
8425
  */
8350
8426
  IsStateToUpload() {
8351
- return (this.uploads.filter((itm) => itm.status === 'added' || itm.status === 'paused').length > 0);
8427
+ return this.uploads.filter((itm) => itm.status === 'added' || itm.status === 'paused').length > 0;
8352
8428
  }
8353
8429
  /**
8354
8430
  * Prüft ob ein Upload eines Files am laufen ist
@@ -8393,7 +8469,7 @@ class SacUploadBase extends SacBaseModelControl {
8393
8469
  }
8394
8470
  }
8395
8471
  /**
8396
- * Initialisiert das Control
8472
+ * Initializes the control
8397
8473
  */
8398
8474
  ngOnInit() {
8399
8475
  super.ngOnInit();
@@ -8401,6 +8477,7 @@ class SacUploadBase extends SacBaseModelControl {
8401
8477
  this.listenerFn = this.renderer.listen(this.uploadInput.nativeElement, 'change', this.fileListener);
8402
8478
  this.setAllowedTypes(this._allowedtypes);
8403
8479
  this.setEndpoint(this._endpoint);
8480
+ this.setToken(this._token);
8404
8481
  if (this._endpoint === null) {
8405
8482
  throw new Error('endpoint is not defined!');
8406
8483
  }
@@ -8463,6 +8540,12 @@ class SacUploadBase extends SacBaseModelControl {
8463
8540
  this.uploadService.control({ action: 'pause' });
8464
8541
  }
8465
8542
  }
8543
+ /**
8544
+ * Sets the bearer token in the upload service
8545
+ */
8546
+ setToken(value) {
8547
+ this.options.token = value;
8548
+ }
8466
8549
  /**
8467
8550
  * Upload Single File
8468
8551
  *
@@ -8490,13 +8573,12 @@ class SacUploadBase extends SacBaseModelControl {
8490
8573
  }
8491
8574
  return error;
8492
8575
  }
8493
- // #endregion Public Abstract Methods
8576
+ // #endregion Public Methods
8494
8577
  // #region Private Methods
8495
8578
  UpdateFileCount() {
8496
8579
  // HACK: Add addition property to FormControl. Can be fixed if solution for ticket: https://github.com/angular/angular/issues/19686
8497
8580
  if (this.ngControl) {
8498
- this.ngControl.uploadedfilecount =
8499
- this.UploadedFileCount();
8581
+ this.ngControl.uploadedfilecount = this.UploadedFileCount();
8500
8582
  }
8501
8583
  }
8502
8584
  /**
@@ -8567,13 +8649,14 @@ SacUploadBase.propDecorators = {
8567
8649
  uploadInput: [{ type: ViewChild, args: ['files', { static: true },] }],
8568
8650
  isrequired: [{ type: Input }],
8569
8651
  maxfilesize: [{ type: Input }],
8652
+ onfileerror: [{ type: Output }],
8570
8653
  validationmessagerequired: [{ type: Input }],
8571
8654
  validationmessagesummaryrequired: [{ type: Input }],
8572
- onfileerror: [{ type: Output }],
8573
8655
  allowedtypes: [{ type: Input }],
8574
8656
  autoupload: [{ type: Input }],
8575
8657
  enablepause: [{ type: Input }],
8576
- endpoint: [{ type: Input }]
8658
+ endpoint: [{ type: Input }],
8659
+ token: [{ type: Input }]
8577
8660
  };
8578
8661
  /**
8579
8662
  * Klasse für den Upload einer Datei in der Upload Component
@@ -8593,7 +8676,7 @@ class SacUploadFile {
8593
8676
  this.documentid = null;
8594
8677
  }
8595
8678
  }
8596
- // #endregion Classes
8679
+ // #endregion Exported Classes
8597
8680
 
8598
8681
  /**
8599
8682
  * Upload Komponente für ein einzelnes File
@@ -10216,7 +10299,7 @@ SacContextmenuCommon.propDecorators = {
10216
10299
  container: [{ type: Input }],
10217
10300
  cssclass: [{ type: Input }],
10218
10301
  isopen: [{ type: Input }],
10219
- menuitems: [{ type: ContentChildren, args: [forwardRef(() => SacContextmenuItemCommon),] }],
10302
+ menuitems: [{ type: ContentChildren, args: [SacContextmenuItemCommon,] }],
10220
10303
  placement: [{ type: Input }],
10221
10304
  onClick: [{ type: HostListener, args: ['document:click', ['$event.target'],] }]
10222
10305
  };