@simpleangularcontrols/sac-common 10.0.0-rc.14 → 10.0.0-rc.16
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 +177 -67
- 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/baseuploadcontrol.d.ts +73 -52
- package/controls/treeview/treeview.d.ts +34 -0
- package/esm2015/common/baseuploadcontrol.js +92 -58
- package/esm2015/controls/treeview/treeview.js +62 -2
- package/esm2015/interfaces/ISacUploadEventCompleteState.js +1 -0
- package/esm2015/interfaces/ISacUploadEventCompleteState.ngfactory.js +7 -0
- package/fesm2015/simpleangularcontrols-sac-common.js +147 -53
- package/fesm2015/simpleangularcontrols-sac-common.js.map +1 -1
- package/interfaces/ISacUploadEventCompleteState.d.ts +5 -0
- package/interfaces/ISacUploadEventCompleteState.ngfactory.d.ts +1 -0
- package/package.json +1 -1
- package/simpleangularcontrols-sac-common-10.0.0-rc.16.tgz +0 -0
- package/simpleangularcontrols-sac-common.metadata.json +1 -1
- package/simpleangularcontrols-sac-common-10.0.0-rc.14.tgz +0 -0
|
@@ -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(
|
|
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"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSVNhY1VwbG9hZEV2ZW50Q29tcGxldGVTdGF0ZS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Qcm9qZWt0ZS9zaW1wbGVhbmd1bGFyY29udHJvbHMtbmcxMC9jaC5qbmV0d29yay5zYWMtY29udHJvbHMvcHJvamVjdHMvc2FjLWNvbW1vbi9zcmMvIiwic291cmNlcyI6WyJpbnRlcmZhY2VzL0lTYWNVcGxvYWRFdmVudENvbXBsZXRlU3RhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSVNhY1VwbG9hZEV2ZW50Q29tcGxldGVTdGF0ZSB7XHJcbiAgICAvLyAjcmVnaW9uIFByb3BlcnRpZXNcclxuXHJcbiAgICBuYW1lOiBzdHJpbmc7XHJcbiAgICBzaXplOiBudW1iZXI7XHJcbiAgICB1cGxvYWRpZDogc3RyaW5nO1xyXG5cclxuICAgIC8vICNlbmRyZWdpb24gUHJvcGVydGllc1xyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview This file was generated by the Angular template compiler. Do not edit.
|
|
3
|
+
*
|
|
4
|
+
* @suppress {suspiciousCode,uselessCode,missingProperties,missingOverride,checkTypes,extraRequire}
|
|
5
|
+
* tslint:disable
|
|
6
|
+
*/
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSVNhY1VwbG9hZEV2ZW50Q29tcGxldGVTdGF0ZS5uZ2ZhY3RvcnkuanMiLCJzb3VyY2VSb290IjoiQzovUHJvamVrdGUvc2ltcGxlYW5ndWxhcmNvbnRyb2xzLW5nMTAvY2guam5ldHdvcmsuc2FjLWNvbnRyb2xzL3Byb2plY3RzL3NhYy1jb21tb24vc3JjLyIsInNvdXJjZXMiOlsiaW50ZXJmYWNlcy9JU2FjVXBsb2FkRXZlbnRDb21wbGV0ZVN0YXRlLm5nZmFjdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgaTAgZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pMC5Db21wb25lbnRGYWN0b3J5O1xuIl19
|
|
@@ -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(
|
|
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
|
*/
|
|
@@ -8194,25 +8267,21 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
8194
8267
|
*/
|
|
8195
8268
|
this.maxfilesize = 0;
|
|
8196
8269
|
/**
|
|
8197
|
-
*
|
|
8270
|
+
* Event when an error is triggered in the component.
|
|
8198
8271
|
*/
|
|
8199
|
-
this.
|
|
8272
|
+
this.onfileerror = new EventEmitter();
|
|
8200
8273
|
/**
|
|
8201
|
-
*
|
|
8274
|
+
* Event when a file has been uploaded. The event is triggered for multiple uploads per file.
|
|
8202
8275
|
*/
|
|
8203
|
-
this.
|
|
8276
|
+
this.onuploadcomplete = new EventEmitter();
|
|
8204
8277
|
/**
|
|
8205
|
-
*
|
|
8278
|
+
* Resource Key für Validation Message Required bei Control
|
|
8206
8279
|
*/
|
|
8207
|
-
this.
|
|
8280
|
+
this.validationmessagerequired = this.validationKeyService.ValidationErrorRequired;
|
|
8208
8281
|
/**
|
|
8209
|
-
*
|
|
8282
|
+
* Resource Key für Validation Message Required in Validation Summary
|
|
8210
8283
|
*/
|
|
8211
|
-
this.
|
|
8212
|
-
if (this.uploadInput.nativeElement.files) {
|
|
8213
|
-
this.uploadService.handleFileList(this.uploadInput.nativeElement.files);
|
|
8214
|
-
}
|
|
8215
|
-
};
|
|
8284
|
+
this.validationmessagesummaryrequired = this.validationKeyService.ValidationErrorSummaryRequired;
|
|
8216
8285
|
this.validationKeyService = injector.get(SACVALIDATIONKEY_SERVICE, new SacDefaultValidationKeyService());
|
|
8217
8286
|
this.lngResourceService = injector.get(SACLOCALISATION_SERVICE, new SacDefaultLocalisationService(this.validationKeyService));
|
|
8218
8287
|
this.uploads = [];
|
|
@@ -8233,34 +8302,6 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
8233
8302
|
}
|
|
8234
8303
|
// #endregion Constructors
|
|
8235
8304
|
// #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
8305
|
/**
|
|
8265
8306
|
* Icon for browse button
|
|
8266
8307
|
*/
|
|
@@ -8294,17 +8335,56 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
8294
8335
|
get allowedtypes() {
|
|
8295
8336
|
return this._allowedtypes;
|
|
8296
8337
|
}
|
|
8338
|
+
/**
|
|
8339
|
+
* Erlaubte Dateitypen für den Upload. Format: ".xxx,.yyy,.zzz"
|
|
8340
|
+
*/
|
|
8341
|
+
set allowedtypes(types) {
|
|
8342
|
+
this._allowedtypes = types;
|
|
8343
|
+
this.setAllowedTypes(types);
|
|
8344
|
+
}
|
|
8297
8345
|
get autoupload() {
|
|
8298
8346
|
return this._autoupload;
|
|
8299
8347
|
}
|
|
8348
|
+
/**
|
|
8349
|
+
* Files nach der Auswahl automatisch hochladen
|
|
8350
|
+
*/
|
|
8351
|
+
set autoupload(v) {
|
|
8352
|
+
this._autoupload = v;
|
|
8353
|
+
this.options.autoUpload = v;
|
|
8354
|
+
this.uploadService.connect(this.options);
|
|
8355
|
+
}
|
|
8300
8356
|
get enablepause() {
|
|
8301
8357
|
return this._enablepause;
|
|
8302
8358
|
}
|
|
8359
|
+
/**
|
|
8360
|
+
* Uploads können unterbrochen werden
|
|
8361
|
+
*/
|
|
8362
|
+
set enablepause(v) {
|
|
8363
|
+
this._enablepause = v;
|
|
8364
|
+
}
|
|
8303
8365
|
get endpoint() {
|
|
8304
8366
|
return this._endpoint;
|
|
8305
8367
|
}
|
|
8306
|
-
|
|
8307
|
-
|
|
8368
|
+
/**
|
|
8369
|
+
* Definiert den Registration Endpoint für Uploads.
|
|
8370
|
+
*/
|
|
8371
|
+
set endpoint(v) {
|
|
8372
|
+
this._endpoint = v;
|
|
8373
|
+
this.setEndpoint(v);
|
|
8374
|
+
}
|
|
8375
|
+
/**
|
|
8376
|
+
* Token for Bearer Authentication
|
|
8377
|
+
*/
|
|
8378
|
+
get token() {
|
|
8379
|
+
return this._token;
|
|
8380
|
+
}
|
|
8381
|
+
/**
|
|
8382
|
+
* Token for Bearer Authentication
|
|
8383
|
+
*/
|
|
8384
|
+
set token(v) {
|
|
8385
|
+
this._token = v;
|
|
8386
|
+
this.setToken(v);
|
|
8387
|
+
}
|
|
8308
8388
|
/**
|
|
8309
8389
|
* Name der Datei die Hochgeladen wird
|
|
8310
8390
|
* @returns Observable des Dateinamens.
|
|
@@ -8330,7 +8410,7 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
8330
8410
|
*/
|
|
8331
8411
|
HasSuccessUpload() {
|
|
8332
8412
|
if (this.uploads.length > 0) {
|
|
8333
|
-
return
|
|
8413
|
+
return this.uploads.filter((itm) => itm.status !== 'complete').length === 0;
|
|
8334
8414
|
}
|
|
8335
8415
|
else {
|
|
8336
8416
|
return false;
|
|
@@ -8348,7 +8428,7 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
8348
8428
|
* @returns Elemente für Upload vorhanden
|
|
8349
8429
|
*/
|
|
8350
8430
|
IsStateToUpload() {
|
|
8351
|
-
return
|
|
8431
|
+
return this.uploads.filter((itm) => itm.status === 'added' || itm.status === 'paused').length > 0;
|
|
8352
8432
|
}
|
|
8353
8433
|
/**
|
|
8354
8434
|
* Prüft ob ein Upload eines Files am laufen ist
|
|
@@ -8393,7 +8473,7 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
8393
8473
|
}
|
|
8394
8474
|
}
|
|
8395
8475
|
/**
|
|
8396
|
-
*
|
|
8476
|
+
* Initializes the control
|
|
8397
8477
|
*/
|
|
8398
8478
|
ngOnInit() {
|
|
8399
8479
|
super.ngOnInit();
|
|
@@ -8401,6 +8481,7 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
8401
8481
|
this.listenerFn = this.renderer.listen(this.uploadInput.nativeElement, 'change', this.fileListener);
|
|
8402
8482
|
this.setAllowedTypes(this._allowedtypes);
|
|
8403
8483
|
this.setEndpoint(this._endpoint);
|
|
8484
|
+
this.setToken(this._token);
|
|
8404
8485
|
if (this._endpoint === null) {
|
|
8405
8486
|
throw new Error('endpoint is not defined!');
|
|
8406
8487
|
}
|
|
@@ -8439,6 +8520,12 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
8439
8520
|
this.uploads[index].progress = ufile.progress;
|
|
8440
8521
|
this.uploads[index].status = ufile.status;
|
|
8441
8522
|
this.SetUploadValue(ufile);
|
|
8523
|
+
const uploadState = {
|
|
8524
|
+
name: ufile.name,
|
|
8525
|
+
size: ufile.size,
|
|
8526
|
+
uploadid: this.uploads[index].uploadId,
|
|
8527
|
+
};
|
|
8528
|
+
this.onuploadcomplete.emit(uploadState);
|
|
8442
8529
|
}
|
|
8443
8530
|
else {
|
|
8444
8531
|
if (index >= 0) {
|
|
@@ -8463,6 +8550,12 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
8463
8550
|
this.uploadService.control({ action: 'pause' });
|
|
8464
8551
|
}
|
|
8465
8552
|
}
|
|
8553
|
+
/**
|
|
8554
|
+
* Sets the bearer token in the upload service
|
|
8555
|
+
*/
|
|
8556
|
+
setToken(value) {
|
|
8557
|
+
this.options.token = value;
|
|
8558
|
+
}
|
|
8466
8559
|
/**
|
|
8467
8560
|
* Upload Single File
|
|
8468
8561
|
*
|
|
@@ -8490,13 +8583,12 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
8490
8583
|
}
|
|
8491
8584
|
return error;
|
|
8492
8585
|
}
|
|
8493
|
-
// #endregion Public
|
|
8586
|
+
// #endregion Public Methods
|
|
8494
8587
|
// #region Private Methods
|
|
8495
8588
|
UpdateFileCount() {
|
|
8496
8589
|
// HACK: Add addition property to FormControl. Can be fixed if solution for ticket: https://github.com/angular/angular/issues/19686
|
|
8497
8590
|
if (this.ngControl) {
|
|
8498
|
-
this.ngControl.uploadedfilecount =
|
|
8499
|
-
this.UploadedFileCount();
|
|
8591
|
+
this.ngControl.uploadedfilecount = this.UploadedFileCount();
|
|
8500
8592
|
}
|
|
8501
8593
|
}
|
|
8502
8594
|
/**
|
|
@@ -8567,13 +8659,15 @@ SacUploadBase.propDecorators = {
|
|
|
8567
8659
|
uploadInput: [{ type: ViewChild, args: ['files', { static: true },] }],
|
|
8568
8660
|
isrequired: [{ type: Input }],
|
|
8569
8661
|
maxfilesize: [{ type: Input }],
|
|
8662
|
+
onfileerror: [{ type: Output }],
|
|
8663
|
+
onuploadcomplete: [{ type: Output }],
|
|
8570
8664
|
validationmessagerequired: [{ type: Input }],
|
|
8571
8665
|
validationmessagesummaryrequired: [{ type: Input }],
|
|
8572
|
-
onfileerror: [{ type: Output }],
|
|
8573
8666
|
allowedtypes: [{ type: Input }],
|
|
8574
8667
|
autoupload: [{ type: Input }],
|
|
8575
8668
|
enablepause: [{ type: Input }],
|
|
8576
|
-
endpoint: [{ type: Input }]
|
|
8669
|
+
endpoint: [{ type: Input }],
|
|
8670
|
+
token: [{ type: Input }]
|
|
8577
8671
|
};
|
|
8578
8672
|
/**
|
|
8579
8673
|
* Klasse für den Upload einer Datei in der Upload Component
|
|
@@ -8593,7 +8687,7 @@ class SacUploadFile {
|
|
|
8593
8687
|
this.documentid = null;
|
|
8594
8688
|
}
|
|
8595
8689
|
}
|
|
8596
|
-
// #endregion Classes
|
|
8690
|
+
// #endregion Exported Classes
|
|
8597
8691
|
|
|
8598
8692
|
/**
|
|
8599
8693
|
* Upload Komponente für ein einzelnes File
|