@colijnit/sharedcomponents 1.0.57 → 1.0.58
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/colijnit-sharedcomponents.umd.js +3555 -6
- package/bundles/colijnit-sharedcomponents.umd.js.map +1 -1
- package/colijnit-sharedcomponents.d.ts +17 -0
- package/colijnit-sharedcomponents.metadata.json +1 -1
- package/esm2015/colijnit-sharedcomponents.js +18 -1
- package/esm2015/lib/businessobject/build-images-and-documentation-result.js +2 -0
- package/esm2015/lib/businessobject/co-document-right.bo.js +3 -0
- package/esm2015/lib/businessobject/drag-drop-container-element.js +2 -0
- package/esm2015/lib/businessobject/drag-drop-container.js +7 -0
- package/esm2015/lib/components/activity-list/activity-list.component.js +130 -0
- package/esm2015/lib/components/activity-list/activity-list.module.js +24 -0
- package/esm2015/lib/components/app-file-dropzone/app-file-dropzone.component.js +47 -0
- package/esm2015/lib/components/app-file-dropzone/app-file-dropzone.module.js +20 -0
- package/esm2015/lib/components/file-upload/file-upload.component.js +189 -0
- package/esm2015/lib/components/file-upload/file-upload.module.js +25 -0
- package/esm2015/lib/components/file-upload-popup/file-upload-popup.component.js +397 -0
- package/esm2015/lib/components/file-upload-popup/file-upload-popup.module.js +30 -0
- package/esm2015/lib/components/files-upload/components/base-file-upload.component.js +469 -0
- package/esm2015/lib/components/files-upload/components/drag-drop-container.component.js +115 -0
- package/esm2015/lib/components/files-upload/files-upload.component.js +131 -0
- package/esm2015/lib/components/files-upload/files-upload.module.js +47 -0
- package/esm2015/lib/components/image-display/image-display.component.js +36 -0
- package/esm2015/lib/components/image-display/image-display.module.js +23 -0
- package/esm2015/lib/components/multi-property-toggler/multiple-property-toggler.component.js +89 -0
- package/esm2015/lib/components/multi-property-toggler/multiple-property-toggler.module.js +21 -0
- package/esm2015/lib/components/tile-renderer/tile-render.component.js +80 -0
- package/esm2015/lib/components/tile-renderer/tile-render.module.js +26 -0
- package/esm2015/lib/decorator/input-boolean.decorator.js +34 -0
- package/esm2015/lib/enum/document-email-report.enum.js +18 -0
- package/esm2015/lib/enum/domain-multiple-name.enum.js +13 -0
- package/esm2015/lib/enum/file-type.js +14 -0
- package/esm2015/lib/enum/files-upload-config-objects.js +3 -0
- package/esm2015/lib/enum/icon.enum.js +7 -1
- package/esm2015/lib/enum/internal-param.enum.js +38 -0
- package/esm2015/lib/enum/read-write-access-config-names.enum.js +2 -0
- package/esm2015/lib/enum/table-name.enum.js +86 -0
- package/esm2015/lib/enum/tag-category.enum.js +22 -0
- package/esm2015/lib/enum/tags-component-config-names.js +2 -0
- package/esm2015/lib/enum/tile-size-type.js +7 -0
- package/esm2015/lib/event/co-drag-event.js +2 -0
- package/esm2015/lib/event/co-drop-event.js +2 -0
- package/esm2015/lib/interface/key-value-pair.js +2 -0
- package/esm2015/lib/interface/operation-callback-simple-function.js +4 -0
- package/esm2015/lib/model/icon-svg.js +7 -1
- package/esm2015/lib/model/tag-tree-item.bo.js +16 -0
- package/esm2015/lib/model/tree-object.js +15 -0
- package/esm2015/lib/pipe/file-type-image.pipe.js +51 -0
- package/esm2015/lib/pipe/master-pipes.js +4 -2
- package/esm2015/lib/service/drag-drop.service.js +365 -0
- package/esm2015/lib/service/shared-connector.service.js +10 -1
- package/esm2015/lib/service/shared.service.js +2 -2
- package/esm2015/lib/utils/array-utils.js +202 -0
- package/esm2015/lib/utils/check-precision-and-scale-result.js +2 -0
- package/esm2015/lib/utils/check-within-stepped-bounds-result.js +2 -0
- package/esm2015/lib/utils/co-document-shared-field-logic.js +50 -0
- package/esm2015/lib/utils/enum-utils.js +128 -0
- package/esm2015/lib/utils/is-nill.function.js +5 -0
- package/esm2015/lib/utils/number-utils.js +390 -0
- package/esm2015/lib/utils/object-utils.js +278 -0
- package/esm2015/lib/utils/ref-code-utils.js +49 -0
- package/esm2015/lib/utils/string-utils.js +30 -1
- package/esm2015/public-api.js +5 -1
- package/fesm2015/colijnit-sharedcomponents.js +3528 -6
- package/fesm2015/colijnit-sharedcomponents.js.map +1 -1
- package/lib/businessobject/build-images-and-documentation-result.d.ts +5 -0
- package/lib/businessobject/co-document-right.bo.d.ts +6 -0
- package/lib/businessobject/drag-drop-container-element.d.ts +6 -0
- package/lib/businessobject/drag-drop-container.d.ts +6 -0
- package/lib/components/access/read-write-access.scss +25 -0
- package/lib/components/access/style/_layout.scss +23 -0
- package/lib/components/access/style/_material-definition.scss +12 -0
- package/lib/components/access/style/_theme.scss +4 -0
- package/lib/components/access/style/material.scss +4 -0
- package/lib/components/activity-list/activity-list.component.d.ts +33 -0
- package/lib/components/activity-list/activity-list.module.d.ts +2 -0
- package/lib/components/activity-list/style/_layout.scss +68 -0
- package/lib/components/activity-list/style/_material-definition.scss +0 -0
- package/lib/components/activity-list/style/_theme.scss +4 -0
- package/lib/components/activity-list/style/material.scss +4 -0
- package/lib/components/app-file-dropzone/app-file-dropzone.component.d.ts +14 -0
- package/lib/components/app-file-dropzone/app-file-dropzone.module.d.ts +2 -0
- package/lib/components/app-file-dropzone/style/_layout.scss +61 -0
- package/lib/components/app-file-dropzone/style/_material-definition.scss +0 -0
- package/lib/components/app-file-dropzone/style/_theme.scss +4 -0
- package/lib/components/app-file-dropzone/style/material.scss +4 -0
- package/lib/components/file-upload/file-upload.component.d.ts +42 -0
- package/lib/components/file-upload/file-upload.module.d.ts +2 -0
- package/lib/components/file-upload/style/_layout.scss +59 -0
- package/lib/components/file-upload/style/_material-definition.scss +2 -0
- package/lib/components/file-upload/style/_theme.scss +4 -0
- package/lib/components/file-upload/style/material.scss +4 -0
- package/lib/components/file-upload-popup/file-upload-popup.component.d.ts +75 -0
- package/lib/components/file-upload-popup/file-upload-popup.module.d.ts +2 -0
- package/lib/components/file-upload-popup/style/_layout.scss +48 -0
- package/lib/components/file-upload-popup/style/_material-definition.scss +2 -0
- package/lib/components/file-upload-popup/style/_theme.scss +5 -0
- package/lib/components/file-upload-popup/style/material.scss +4 -0
- package/lib/components/files-upload/components/base-file-upload.component.d.ts +98 -0
- package/lib/components/files-upload/components/drag-drop-container.component.d.ts +34 -0
- package/lib/components/files-upload/files-upload.component.d.ts +32 -0
- package/lib/components/files-upload/files-upload.module.d.ts +2 -0
- package/lib/components/files-upload/style/_layout.scss +49 -0
- package/lib/components/files-upload/style/_material-definition.scss +0 -0
- package/lib/components/files-upload/style/_theme.scss +5 -0
- package/lib/components/files-upload/style/material.scss +4 -0
- package/lib/components/image-display/image-display.component.d.ts +14 -0
- package/lib/components/image-display/image-display.module.d.ts +2 -0
- package/lib/components/image-display/style/_layout.scss +56 -0
- package/lib/components/image-display/style/_material-definition.scss +4 -0
- package/lib/components/image-display/style/_theme.scss +6 -0
- package/lib/components/image-display/style/material.scss +3 -0
- package/lib/components/multi-property-toggler/multiple-property-toggler.component.d.ts +27 -0
- package/lib/components/multi-property-toggler/multiple-property-toggler.module.d.ts +2 -0
- package/lib/components/multi-property-toggler/style/_layout.scss +24 -0
- package/lib/components/multi-property-toggler/style/_material-definition.scss +0 -0
- package/lib/components/multi-property-toggler/style/_theme.scss +4 -0
- package/lib/components/multi-property-toggler/style/material.scss +4 -0
- package/lib/components/tile-renderer/style/_layout.scss +90 -0
- package/lib/components/tile-renderer/style/_material-definition.scss +0 -0
- package/lib/components/tile-renderer/style/_theme.scss +4 -0
- package/lib/components/tile-renderer/style/material.scss +4 -0
- package/lib/components/tile-renderer/tile-render.component.d.ts +31 -0
- package/lib/components/tile-renderer/tile-render.module.d.ts +2 -0
- package/lib/decorator/input-boolean.decorator.d.ts +8 -0
- package/lib/enum/document-email-report.enum.d.ts +15 -0
- package/lib/enum/domain-multiple-name.enum.d.ts +10 -0
- package/lib/enum/file-type.d.ts +7 -0
- package/lib/enum/files-upload-config-objects.d.ts +22 -0
- package/lib/enum/icon.enum.d.ts +6 -0
- package/lib/enum/internal-param.enum.d.ts +34 -0
- package/lib/enum/read-write-access-config-names.enum.d.ts +4 -0
- package/lib/enum/table-name.enum.d.ts +84 -0
- package/lib/enum/tag-category.enum.d.ts +19 -0
- package/lib/enum/tags-component-config-names.d.ts +4 -0
- package/lib/enum/tile-size-type.d.ts +4 -0
- package/lib/event/co-drag-event.d.ts +5 -0
- package/lib/event/co-drop-event.d.ts +8 -0
- package/lib/interface/key-value-pair.d.ts +4 -0
- package/lib/interface/operation-callback-simple-function.d.ts +4 -0
- package/lib/model/tag-tree-item.bo.d.ts +18 -0
- package/lib/model/tree-object.d.ts +8 -0
- package/lib/pipe/file-type-image.pipe.d.ts +12 -0
- package/lib/service/drag-drop.service.d.ts +86 -0
- package/lib/service/shared-connector.service.d.ts +2 -0
- package/lib/style/_variables.scss +1 -1
- package/lib/utils/array-utils.d.ts +63 -0
- package/lib/utils/check-precision-and-scale-result.d.ts +4 -0
- package/lib/utils/check-within-stepped-bounds-result.d.ts +8 -0
- package/lib/utils/co-document-shared-field-logic.d.ts +7 -0
- package/lib/utils/enum-utils.d.ts +31 -0
- package/lib/utils/is-nill.function.d.ts +1 -0
- package/lib/utils/number-utils.d.ts +125 -0
- package/lib/utils/object-utils.d.ts +40 -0
- package/lib/utils/ref-code-utils.d.ts +10 -0
- package/lib/utils/string-utils.d.ts +16 -0
- package/package.json +1 -1
- package/public-api.d.ts +4 -0
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { ElementRef, Input, Directive, Renderer2, Output, EventEmitter, HostBinding } from "@angular/core";
|
|
3
|
+
import { InputBoolean } from "../../../decorator/input-boolean.decorator";
|
|
4
|
+
import { DragDropContainer } from "../../../businessobject/drag-drop-container";
|
|
5
|
+
import { CoOrientation } from "@colijnit/corecomponents_v12";
|
|
6
|
+
import { ArrayUtils } from "@colijnit/sharedapi/build/utils/array-utils";
|
|
7
|
+
import { DragDropService } from "../../../service/drag-drop.service";
|
|
8
|
+
export class DragDropContainerComponent {
|
|
9
|
+
constructor(_elementRef, _renderer, _dragDropService) {
|
|
10
|
+
this._elementRef = _elementRef;
|
|
11
|
+
this._renderer = _renderer;
|
|
12
|
+
this._dragDropService = _dragDropService;
|
|
13
|
+
this.handleSort = false;
|
|
14
|
+
/**
|
|
15
|
+
* Class of the handle to drag operations
|
|
16
|
+
*/
|
|
17
|
+
this.dragHandle = "";
|
|
18
|
+
// Emits when the order of sortableList items changed after a drag-drop action.
|
|
19
|
+
this.sortingChange = new EventEmitter();
|
|
20
|
+
this.showClass = true;
|
|
21
|
+
this._enabled = true;
|
|
22
|
+
this._initialized = false;
|
|
23
|
+
this._dragDropService.renderer = this._renderer;
|
|
24
|
+
this._container = new DragDropContainer(_elementRef.nativeElement, CoOrientation.Vertical);
|
|
25
|
+
}
|
|
26
|
+
set enabled(value) {
|
|
27
|
+
this._enabled = value;
|
|
28
|
+
this.handleEnabledChange();
|
|
29
|
+
}
|
|
30
|
+
ngAfterViewInit() {
|
|
31
|
+
this._initialized = true;
|
|
32
|
+
this._createDragDrop();
|
|
33
|
+
if (this._initialized) {
|
|
34
|
+
this._updateEnableDisableContainer();
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Cleanup...
|
|
39
|
+
*/
|
|
40
|
+
ngOnDestroy() {
|
|
41
|
+
this._removeDragDrop();
|
|
42
|
+
this._elementRef = undefined;
|
|
43
|
+
}
|
|
44
|
+
handleEnabledChange() {
|
|
45
|
+
if (!this._initialized) {
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
if (this._enabled) {
|
|
49
|
+
this._dragDropService.enableContainer(this._container);
|
|
50
|
+
this._createDragDrop();
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
this._dragDropService.disableContainer(this._container);
|
|
54
|
+
this._removeDragDrop();
|
|
55
|
+
this._initialized = false;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
_createDragDrop() {
|
|
59
|
+
this._dragDropService.addContainer(this._container);
|
|
60
|
+
this._dragDropService.addDragHandle(this.dragHandle);
|
|
61
|
+
if (this.handleSort) { // subscribe drop event to be able to adapt the order of dropped items
|
|
62
|
+
this._handleOrderSub = this._dragDropService.drop.subscribe((event) => {
|
|
63
|
+
this._handleOrder(event.container, event.elementIndex, event.targetIndex);
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
this._initialized = true;
|
|
67
|
+
}
|
|
68
|
+
_removeDragDrop() {
|
|
69
|
+
this._dragDropService.removeContainer(this._container);
|
|
70
|
+
this._dragDropService.removeDragHandle(this.dragHandle);
|
|
71
|
+
if (this._handleOrderSub) {
|
|
72
|
+
this._handleOrderSub.unsubscribe();
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
_handleOrder(container, oldIndex, newIndex) {
|
|
76
|
+
if (container !== this._container) {
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
if (newIndex === -1) {
|
|
80
|
+
newIndex = this.sortableList.length;
|
|
81
|
+
}
|
|
82
|
+
ArrayUtils.MoveElement(this.sortableList[oldIndex], newIndex, this.sortableList);
|
|
83
|
+
this.sortingChange.emit(this.sortableList);
|
|
84
|
+
}
|
|
85
|
+
_updateEnableDisableContainer() {
|
|
86
|
+
if (this._enabled) {
|
|
87
|
+
this._dragDropService.enableContainer(this._container);
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
this._dragDropService.disableContainer(this._container);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
DragDropContainerComponent.decorators = [
|
|
95
|
+
{ type: Directive, args: [{
|
|
96
|
+
selector: "drag-drop-container"
|
|
97
|
+
},] }
|
|
98
|
+
];
|
|
99
|
+
DragDropContainerComponent.ctorParameters = () => [
|
|
100
|
+
{ type: ElementRef },
|
|
101
|
+
{ type: Renderer2 },
|
|
102
|
+
{ type: DragDropService }
|
|
103
|
+
];
|
|
104
|
+
DragDropContainerComponent.propDecorators = {
|
|
105
|
+
sortableList: [{ type: Input }],
|
|
106
|
+
handleSort: [{ type: Input }],
|
|
107
|
+
enabled: [{ type: Input }],
|
|
108
|
+
dragHandle: [{ type: Input }],
|
|
109
|
+
sortingChange: [{ type: Output }],
|
|
110
|
+
showClass: [{ type: HostBinding, args: ["class.co-drag-drop-container",] }]
|
|
111
|
+
};
|
|
112
|
+
__decorate([
|
|
113
|
+
InputBoolean()
|
|
114
|
+
], DragDropContainerComponent.prototype, "handleSort", void 0);
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drag-drop-container.component.js","sourceRoot":"","sources":["../../../../../../../projects/sharedcomponents/src/lib/components/files-upload/components/drag-drop-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ElementRef,\r\n  Input,\r\n  Directive,\r\n  AfterViewInit,\r\n  OnDestroy,\r\n  Renderer2,\r\n  Output,\r\n  EventEmitter,\r\n  HostBinding\r\n} from \"@angular/core\";\r\nimport {Subscription} from \"rxjs\";\r\nimport {InputBoolean} from \"../../../decorator/input-boolean.decorator\";\r\nimport {DragDropContainer} from \"../../../businessobject/drag-drop-container\";\r\nimport {CoOrientation} from \"@colijnit/corecomponents_v12\";\r\nimport {ArrayUtils} from \"@colijnit/sharedapi/build/utils/array-utils\";\r\nimport {CoDropEvent} from \"../../../event/co-drop-event\";\r\nimport {DragDropService} from \"../../../service/drag-drop.service\";\r\n\r\n@Directive({\r\n  selector: \"drag-drop-container\"\r\n})\r\nexport class DragDropContainerComponent implements AfterViewInit, OnDestroy {\r\n\r\n    /**\r\n     * Model of list containing draggable items\r\n     */\r\n    @Input()\r\n    public sortableList: any[];\r\n\r\n    @Input()\r\n    @InputBoolean()\r\n    public handleSort: boolean = false;\r\n\r\n    @Input()\r\n    public set enabled(value: boolean) {\r\n        this._enabled = value;\r\n        this.handleEnabledChange();\r\n    }\r\n\r\n    /**\r\n     * Class of the handle to drag operations\r\n     */\r\n    @Input()\r\n    public dragHandle: string = \"\";\r\n\r\n    // Emits when the order of sortableList items changed after a drag-drop action.\r\n    @Output()\r\n    public sortingChange: EventEmitter<any[]> = new EventEmitter<any[]>();\r\n\r\n    @HostBinding(\"class.co-drag-drop-container\")\r\n    public showClass: boolean = true;\r\n\r\n    private _container: DragDropContainer;\r\n    private _enabled: boolean = true;\r\n    private _handleOrderSub: Subscription;\r\n    private _initialized: boolean = false;\r\n\r\n    constructor(private _elementRef: ElementRef, private _renderer: Renderer2, private _dragDropService: DragDropService) {\r\n        this._dragDropService.renderer = this._renderer;\r\n        this._container = new DragDropContainer(_elementRef.nativeElement, CoOrientation.Vertical);\r\n    }\r\n\r\n    ngAfterViewInit(): void {\r\n        this._initialized = true;\r\n        this._createDragDrop();\r\n        if (this._initialized) {\r\n            this._updateEnableDisableContainer();\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Cleanup...\r\n     */\r\n    ngOnDestroy(): void {\r\n        this._removeDragDrop();\r\n        this._elementRef = undefined;\r\n    }\r\n\r\n    public handleEnabledChange(): void {\r\n        if (!this._initialized) {\r\n            return;\r\n        }\r\n        if (this._enabled) {\r\n            this._dragDropService.enableContainer(this._container);\r\n            this._createDragDrop();\r\n        } else {\r\n            this._dragDropService.disableContainer(this._container);\r\n            this._removeDragDrop();\r\n            this._initialized = false;\r\n        }\r\n    }\r\n\r\n    private _createDragDrop(): void {\r\n        this._dragDropService.addContainer(this._container);\r\n        this._dragDropService.addDragHandle(this.dragHandle);\r\n        if (this.handleSort) { // subscribe drop event to be able to adapt the order of dropped items\r\n            this._handleOrderSub = this._dragDropService.drop.subscribe((event: CoDropEvent) => {\r\n                this._handleOrder(event.container, event.elementIndex, event.targetIndex);\r\n            });\r\n        }\r\n        this._initialized = true;\r\n    }\r\n\r\n    private _removeDragDrop(): void {\r\n        this._dragDropService.removeContainer(this._container);\r\n        this._dragDropService.removeDragHandle(this.dragHandle);\r\n        if (this._handleOrderSub) {\r\n            this._handleOrderSub.unsubscribe();\r\n        }\r\n    }\r\n\r\n    private _handleOrder(container: DragDropContainer, oldIndex: number, newIndex: number): void {\r\n        if (container !== this._container) {\r\n            return;\r\n        }\r\n        if (newIndex === -1) {\r\n            newIndex = this.sortableList.length;\r\n        }\r\n        ArrayUtils.MoveElement(this.sortableList[oldIndex], newIndex, this.sortableList);\r\n        this.sortingChange.emit(this.sortableList);\r\n    }\r\n\r\n    private _updateEnableDisableContainer(): void {\r\n        if (this._enabled) {\r\n            this._dragDropService.enableContainer(this._container);\r\n        } else {\r\n            this._dragDropService.disableContainer(this._container);\r\n        }\r\n    }\r\n}\r\n"]}
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
import { __awaiter, __decorate } from "tslib";
|
|
2
|
+
import { Component, ComponentFactoryResolver, ContentChild, EventEmitter, forwardRef, HostBinding, Input, Output, ViewChild, ViewContainerRef, ViewEncapsulation } from "@angular/core";
|
|
3
|
+
import { BaseFileUploadComponent } from "./components/base-file-upload.component";
|
|
4
|
+
import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from "@colijnit/corecomponents_v12";
|
|
5
|
+
import { DictionaryService } from "../../service/dictionary.service";
|
|
6
|
+
import { InputBoolean } from "../../decorator/input-boolean.decorator";
|
|
7
|
+
// A component that lets the user make a list of files from its device. Doesn't actually upload, but outputs chosen files as filesChanged.
|
|
8
|
+
export class FilesUploadComponent extends BaseFileUploadComponent {
|
|
9
|
+
constructor(
|
|
10
|
+
//promptService: PromptService,
|
|
11
|
+
dictionaryService,
|
|
12
|
+
//userService: UserService,
|
|
13
|
+
_container, _factory) {
|
|
14
|
+
super(dictionaryService, _container, _factory);
|
|
15
|
+
this._container = _container;
|
|
16
|
+
this._factory = _factory;
|
|
17
|
+
// Input button label
|
|
18
|
+
this.label = "UPLOAD_FILE";
|
|
19
|
+
this.customImageClick = false;
|
|
20
|
+
this.isEditable = false;
|
|
21
|
+
this.hideAvatars = false;
|
|
22
|
+
this.editSlideoutSubmit = new EventEmitter();
|
|
23
|
+
this.tagsChangeEvent = new EventEmitter();
|
|
24
|
+
this.imageClick = new EventEmitter();
|
|
25
|
+
this.slideoutShown = false;
|
|
26
|
+
this.isDropzone = false;
|
|
27
|
+
}
|
|
28
|
+
set dropzone(value) {
|
|
29
|
+
this.isDropzone = value;
|
|
30
|
+
}
|
|
31
|
+
showClass() {
|
|
32
|
+
return true;
|
|
33
|
+
}
|
|
34
|
+
get editable() {
|
|
35
|
+
return this.canAdd;
|
|
36
|
+
}
|
|
37
|
+
get empty() {
|
|
38
|
+
return !this.documents || this.documents.length === 0;
|
|
39
|
+
}
|
|
40
|
+
ngOnDestroy() {
|
|
41
|
+
this.slideoutTemplate = undefined;
|
|
42
|
+
this.input = undefined;
|
|
43
|
+
super.ngOnDestroy();
|
|
44
|
+
}
|
|
45
|
+
openFileBrowser() {
|
|
46
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
47
|
+
if (this.input && this.input.nativeElement) {
|
|
48
|
+
this.input.nativeElement.click();
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
handleAddClick() {
|
|
53
|
+
this.openFileBrowser();
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
FilesUploadComponent.decorators = [
|
|
57
|
+
{ type: Component, args: [{
|
|
58
|
+
selector: "co-files-upload",
|
|
59
|
+
template: `
|
|
60
|
+
<div class="files-upload-wrapper">
|
|
61
|
+
<drag-drop-container
|
|
62
|
+
[sortableList]="documents"
|
|
63
|
+
(sortingChange)="handleSortingChange($event)"
|
|
64
|
+
[handleSort]="true"
|
|
65
|
+
dragHandle="tile"
|
|
66
|
+
[enabled]="!noDragDropOrdering">
|
|
67
|
+
<co-file-upload *ngIf="canAdd && addWithButton" class="add-file"
|
|
68
|
+
isAddingTile
|
|
69
|
+
icon="plus_round_open"
|
|
70
|
+
[link]="true"
|
|
71
|
+
[label]="label | localize"
|
|
72
|
+
(mouseover)="mouseOverAdd = true"
|
|
73
|
+
(mouseout)="mouseOverAdd = false"
|
|
74
|
+
(click)="handleAddClick()"></co-file-upload> <!-- (click)="handleAddClick()" -->
|
|
75
|
+
<co-file-upload *ngFor="let file of documents" class="tile"
|
|
76
|
+
[readonly]="file.readonly || readonly"
|
|
77
|
+
[class.hidden]="hideAvatars ? file.isAvatar : false"
|
|
78
|
+
[file]="file"
|
|
79
|
+
[label]="file.fileName"
|
|
80
|
+
[showTrashCan]="canDelete"
|
|
81
|
+
[fileSavesOnPopupOkClick]="fileSavesOnPopupOkClick"
|
|
82
|
+
[isEditable]="isEditable"
|
|
83
|
+
[customImageClick]="customImageClick"
|
|
84
|
+
(imageClick)="imageClick.emit($event)"
|
|
85
|
+
(deleteClick)="handleDelete(file)"
|
|
86
|
+
(editClick)="handleEditDocumentClick($event)"></co-file-upload>
|
|
87
|
+
</drag-drop-container>
|
|
88
|
+
<span class="maxuploadsize" textContent="getMaxFileSizeNotition()" [class.show]="mouseOverAdd"></span>
|
|
89
|
+
<input #inputFile [accept]="acceptedUploadFormats" (change)="handleFileChange($event)" type="file" hidden multiple/>
|
|
90
|
+
</div>
|
|
91
|
+
`,
|
|
92
|
+
encapsulation: ViewEncapsulation.None,
|
|
93
|
+
providers: [
|
|
94
|
+
{
|
|
95
|
+
provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,
|
|
96
|
+
useExisting: forwardRef(() => FilesUploadComponent)
|
|
97
|
+
}
|
|
98
|
+
]
|
|
99
|
+
},] }
|
|
100
|
+
];
|
|
101
|
+
FilesUploadComponent.ctorParameters = () => [
|
|
102
|
+
{ type: DictionaryService },
|
|
103
|
+
{ type: ViewContainerRef },
|
|
104
|
+
{ type: ComponentFactoryResolver }
|
|
105
|
+
];
|
|
106
|
+
FilesUploadComponent.propDecorators = {
|
|
107
|
+
dropzone: [{ type: Input }],
|
|
108
|
+
slideoutTemplate: [{ type: ContentChild, args: ["slideoutTemplate", { static: true },] }],
|
|
109
|
+
input: [{ type: ViewChild, args: ["inputFile", { static: true },] }],
|
|
110
|
+
label: [{ type: Input }],
|
|
111
|
+
cfgNames: [{ type: Input }],
|
|
112
|
+
customImageClick: [{ type: Input }],
|
|
113
|
+
isEditable: [{ type: Input }],
|
|
114
|
+
hideAvatars: [{ type: Input }],
|
|
115
|
+
fileSavesOnPopupOkClick: [{ type: Input }],
|
|
116
|
+
selected: [{ type: Input }],
|
|
117
|
+
editSlideoutSubmit: [{ type: Output }],
|
|
118
|
+
tagsChangeEvent: [{ type: Output }],
|
|
119
|
+
imageClick: [{ type: Output }],
|
|
120
|
+
showClass: [{ type: HostBinding, args: ['class.co-files-upload',] }],
|
|
121
|
+
editable: [{ type: HostBinding, args: ["class.editable",] }],
|
|
122
|
+
empty: [{ type: HostBinding, args: ["class.empty",] }],
|
|
123
|
+
isDropzone: [{ type: HostBinding, args: ['class.dropzone',] }]
|
|
124
|
+
};
|
|
125
|
+
__decorate([
|
|
126
|
+
InputBoolean()
|
|
127
|
+
], FilesUploadComponent.prototype, "isEditable", void 0);
|
|
128
|
+
__decorate([
|
|
129
|
+
InputBoolean()
|
|
130
|
+
], FilesUploadComponent.prototype, "hideAvatars", void 0);
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"files-upload.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/files-upload/files-upload.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ComponentFactoryResolver,\r\n  ContentChild,\r\n  ElementRef,\r\n  EventEmitter, forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  OnDestroy,\r\n  Output,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewContainerRef,\r\n  ViewEncapsulation\r\n} from \"@angular/core\";\r\nimport {BaseFileUploadComponent} from \"./components/base-file-upload.component\";\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from \"@colijnit/corecomponents_v12\";\r\nimport {DictionaryService} from \"../../service/dictionary.service\";\r\nimport {CoDocument} from \"@colijnit/mainapi/build/model/co-document\";\r\nimport {TagTreeItem} from \"@colijnit/mainapi/build/model/tag-tree-item.bo\";\r\nimport {InputBoolean} from \"../../decorator/input-boolean.decorator\";\r\n\r\n@Component({\r\n    selector: \"co-files-upload\",\r\n    template: `\r\n        <div class=\"files-upload-wrapper\">\r\n            <drag-drop-container\r\n                                 [sortableList]=\"documents\"\r\n                                 (sortingChange)=\"handleSortingChange($event)\"\r\n                                 [handleSort]=\"true\"\r\n                                 dragHandle=\"tile\"\r\n                                 [enabled]=\"!noDragDropOrdering\">\r\n                <co-file-upload *ngIf=\"canAdd && addWithButton\" class=\"add-file\"\r\n                             isAddingTile\r\n                             icon=\"plus_round_open\"\r\n                             [link]=\"true\"\r\n                             [label]=\"label | localize\"\r\n                             (mouseover)=\"mouseOverAdd = true\"\r\n                             (mouseout)=\"mouseOverAdd = false\"\r\n                             (click)=\"handleAddClick()\"></co-file-upload> <!-- (click)=\"handleAddClick()\" -->\r\n                <co-file-upload *ngFor=\"let file of documents\" class=\"tile\"\r\n                             [readonly]=\"file.readonly || readonly\"\r\n                             [class.hidden]=\"hideAvatars ? file.isAvatar : false\"\r\n                             [file]=\"file\"\r\n                             [label]=\"file.fileName\"\r\n                             [showTrashCan]=\"canDelete\"\r\n                             [fileSavesOnPopupOkClick]=\"fileSavesOnPopupOkClick\"\r\n                             [isEditable]=\"isEditable\"\r\n                             [customImageClick]=\"customImageClick\"\r\n                             (imageClick)=\"imageClick.emit($event)\"\r\n                             (deleteClick)=\"handleDelete(file)\"\r\n                             (editClick)=\"handleEditDocumentClick($event)\"></co-file-upload>\r\n            </drag-drop-container>\r\n            <span class=\"maxuploadsize\" textContent=\"getMaxFileSizeNotition()\" [class.show]=\"mouseOverAdd\"></span>\r\n            <input #inputFile [accept]=\"acceptedUploadFormats\" (change)=\"handleFileChange($event)\" type=\"file\" hidden multiple/>\r\n        </div>\r\n    `,\r\n    encapsulation: ViewEncapsulation.None,\r\n    providers: [\r\n        {\r\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n            useExisting: forwardRef(() => FilesUploadComponent)\r\n        }\r\n    ]\r\n})\r\n// A component that lets the user make a list of files from its device. Doesn't actually upload, but outputs chosen files as filesChanged.\r\nexport class FilesUploadComponent extends BaseFileUploadComponent implements OnDestroy {\r\n\r\n    @Input()\r\n    public set dropzone(value: boolean) {\r\n        this.isDropzone = value;\r\n    }\r\n\r\n    //todo see if this is used anywhere if not, remove\r\n    @ContentChild(\"slideoutTemplate\", {static: true})\r\n    public slideoutTemplate: TemplateRef<any>;\r\n\r\n    // (Hidden) input for file upload facilities\r\n    @ViewChild(\"inputFile\", {static: true})\r\n    public input: ElementRef;\r\n\r\n    // Input button label\r\n    @Input()\r\n    public label: string = \"UPLOAD_FILE\";\r\n\r\n    @Input()\r\n    public cfgNames: any;\r\n\r\n    @Input()\r\n    public customImageClick: boolean = false;\r\n\r\n    @Input()\r\n    @InputBoolean()\r\n    public isEditable: boolean = false;\r\n\r\n    @Input() @InputBoolean()\r\n    public hideAvatars: boolean = false;\r\n\r\n    @Input()\r\n    public fileSavesOnPopupOkClick: string;\r\n\r\n    @Input()\r\n    public selected: string;\r\n\r\n    @Output()\r\n    public readonly editSlideoutSubmit: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n    @Output()\r\n    public tagsChangeEvent: EventEmitter<TagTreeItem[]> = new EventEmitter<TagTreeItem[]>();\r\n\r\n    @Output()\r\n    public imageClick: EventEmitter<CoDocument> = new EventEmitter<CoDocument>();\r\n\r\n\r\n    @HostBinding('class.co-files-upload')\r\n    public showClass() {\r\n      return true;\r\n    }\r\n\r\n    @HostBinding(\"class.editable\")\r\n    public get editable(): boolean {\r\n        return this.canAdd;\r\n    }\r\n\r\n    @HostBinding(\"class.empty\")\r\n    public get empty(): boolean {\r\n        return !this.documents || this.documents.length === 0;\r\n    }\r\n\r\n    public mouseOverAdd: boolean;\r\n    public slideoutShown: boolean = false;\r\n    @HostBinding('class.dropzone')\r\n    public isDropzone: boolean = false;\r\n\r\n    constructor(\r\n        //promptService: PromptService,\r\n        dictionaryService: DictionaryService,\r\n        //userService: UserService,\r\n        protected _container: ViewContainerRef,\r\n        protected _factory: ComponentFactoryResolver,\r\n        //protected _dataService: DataService,\r\n        //protected _baseDataDalRepository: BaseDataDalRepository,\r\n       // protected _generalDalRepository: GeneralDalRepository,\r\n        //protected _coDocumentDataLoader: CoDocumentDataLoaderService,\r\n        //private _workability: AppWorkabilityService,\r\n        //private _fileTypeImgPipe: FileTypeImagePipe\r\n    ) {\r\n        super(dictionaryService, _container, _factory);\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.slideoutTemplate = undefined;\r\n        this.input = undefined;\r\n        super.ngOnDestroy();\r\n    }\r\n\r\n    public async openFileBrowser(): Promise<void> {\r\n        if (this.input && this.input.nativeElement) {\r\n            this.input.nativeElement.click();\r\n        }\r\n    }\r\n\r\n    public handleAddClick(): void {\r\n        this.openFileBrowser();\r\n    }\r\n\r\n    //todo check if this can be removed at the end of the run\r\n    /*public onCustomClose(): void {\r\n        this.documentUnderEdit = undefined;\r\n    }*/\r\n}\r\n"]}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { ButtonModule, CoDialogModule, FormModule, IconModule, InputCheckboxModule, InputTextModule, ScreenConfigurationModule } from "@colijnit/corecomponents_v12";
|
|
3
|
+
import { LocalizationModule } from "../../localization/localization.module";
|
|
4
|
+
import { DragDropContainerComponent } from "./components/drag-drop-container.component";
|
|
5
|
+
import { ImageDisplayModule } from "../image-display/image-display.module";
|
|
6
|
+
import { CommonModule } from "@angular/common";
|
|
7
|
+
import { Overlay } from "@angular/cdk/overlay";
|
|
8
|
+
import { FileTypeImagePipe } from "../../pipe/file-type-image.pipe";
|
|
9
|
+
import { FilesUploadComponent } from "./files-upload.component";
|
|
10
|
+
import { FileUploadModule } from "../file-upload/file-upload.module";
|
|
11
|
+
import { FileUploadPopupModule } from "../file-upload-popup/file-upload-popup.module";
|
|
12
|
+
import { AppFileDropzoneModule } from "../app-file-dropzone/app-file-dropzone.module";
|
|
13
|
+
export class FilesUploadModule {
|
|
14
|
+
}
|
|
15
|
+
FilesUploadModule.decorators = [
|
|
16
|
+
{ type: NgModule, args: [{
|
|
17
|
+
imports: [
|
|
18
|
+
CoDialogModule,
|
|
19
|
+
FormModule,
|
|
20
|
+
InputTextModule,
|
|
21
|
+
ScreenConfigurationModule,
|
|
22
|
+
ButtonModule,
|
|
23
|
+
LocalizationModule,
|
|
24
|
+
IconModule,
|
|
25
|
+
ImageDisplayModule,
|
|
26
|
+
CommonModule,
|
|
27
|
+
// TagsModule,
|
|
28
|
+
InputCheckboxModule,
|
|
29
|
+
FileUploadModule,
|
|
30
|
+
FileUploadPopupModule,
|
|
31
|
+
AppFileDropzoneModule
|
|
32
|
+
],
|
|
33
|
+
declarations: [
|
|
34
|
+
FilesUploadComponent,
|
|
35
|
+
DragDropContainerComponent
|
|
36
|
+
],
|
|
37
|
+
exports: [
|
|
38
|
+
FilesUploadComponent,
|
|
39
|
+
DragDropContainerComponent
|
|
40
|
+
],
|
|
41
|
+
providers: [
|
|
42
|
+
Overlay,
|
|
43
|
+
FileTypeImagePipe
|
|
44
|
+
]
|
|
45
|
+
},] }
|
|
46
|
+
];
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZXMtdXBsb2FkLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NoYXJlZGNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2ZpbGVzLXVwbG9hZC9maWxlcy11cGxvYWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUNMLFlBQVksRUFDWixjQUFjLEVBQ2QsVUFBVSxFQUNWLFVBQVUsRUFBRSxtQkFBbUIsRUFDL0IsZUFBZSxFQUNmLHlCQUF5QixFQUMxQixNQUFNLDhCQUE4QixDQUFDO0FBQ3RDLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLHdDQUF3QyxDQUFDO0FBQzFFLE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBQ3RGLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQ3pFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDN0MsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFDbEUsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDOUQsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDbkUsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFDcEYsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFnQ3BGLE1BQU0sT0FBTyxpQkFBaUI7OztZQTlCN0IsUUFBUSxTQUFDO2dCQUNSLE9BQU8sRUFBRTtvQkFDUCxjQUFjO29CQUNkLFVBQVU7b0JBQ1YsZUFBZTtvQkFDZix5QkFBeUI7b0JBQ3pCLFlBQVk7b0JBQ1osa0JBQWtCO29CQUNsQixVQUFVO29CQUNWLGtCQUFrQjtvQkFDbEIsWUFBWTtvQkFDWixjQUFjO29CQUNkLG1CQUFtQjtvQkFDbkIsZ0JBQWdCO29CQUNoQixxQkFBcUI7b0JBQ3JCLHFCQUFxQjtpQkFDdEI7Z0JBQ0QsWUFBWSxFQUFFO29CQUNaLG9CQUFvQjtvQkFDcEIsMEJBQTBCO2lCQUMzQjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1Asb0JBQW9CO29CQUNwQiwwQkFBMEI7aUJBQzNCO2dCQUNELFNBQVMsRUFBRTtvQkFDVCxPQUFPO29CQUNQLGlCQUFpQjtpQkFDbEI7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7XHJcbiAgQnV0dG9uTW9kdWxlLFxyXG4gIENvRGlhbG9nTW9kdWxlLFxyXG4gIEZvcm1Nb2R1bGUsXHJcbiAgSWNvbk1vZHVsZSwgSW5wdXRDaGVja2JveE1vZHVsZSxcclxuICBJbnB1dFRleHRNb2R1bGUsXHJcbiAgU2NyZWVuQ29uZmlndXJhdGlvbk1vZHVsZVxyXG59IGZyb20gXCJAY29saWpuaXQvY29yZWNvbXBvbmVudHNfdjEyXCI7XHJcbmltcG9ydCB7TG9jYWxpemF0aW9uTW9kdWxlfSBmcm9tIFwiLi4vLi4vbG9jYWxpemF0aW9uL2xvY2FsaXphdGlvbi5tb2R1bGVcIjtcclxuaW1wb3J0IHtEcmFnRHJvcENvbnRhaW5lckNvbXBvbmVudH0gZnJvbSBcIi4vY29tcG9uZW50cy9kcmFnLWRyb3AtY29udGFpbmVyLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0ltYWdlRGlzcGxheU1vZHVsZX0gZnJvbSBcIi4uL2ltYWdlLWRpc3BsYXkvaW1hZ2UtZGlzcGxheS5tb2R1bGVcIjtcclxuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHtPdmVybGF5fSBmcm9tIFwiQGFuZ3VsYXIvY2RrL292ZXJsYXlcIjtcclxuaW1wb3J0IHtGaWxlVHlwZUltYWdlUGlwZX0gZnJvbSBcIi4uLy4uL3BpcGUvZmlsZS10eXBlLWltYWdlLnBpcGVcIjtcclxuaW1wb3J0IHtGaWxlc1VwbG9hZENvbXBvbmVudH0gZnJvbSBcIi4vZmlsZXMtdXBsb2FkLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0ZpbGVVcGxvYWRNb2R1bGV9IGZyb20gXCIuLi9maWxlLXVwbG9hZC9maWxlLXVwbG9hZC5tb2R1bGVcIjtcclxuaW1wb3J0IHtGaWxlVXBsb2FkUG9wdXBNb2R1bGV9IGZyb20gXCIuLi9maWxlLXVwbG9hZC1wb3B1cC9maWxlLXVwbG9hZC1wb3B1cC5tb2R1bGVcIjtcclxuaW1wb3J0IHtBcHBGaWxlRHJvcHpvbmVNb2R1bGV9IGZyb20gXCIuLi9hcHAtZmlsZS1kcm9wem9uZS9hcHAtZmlsZS1kcm9wem9uZS5tb2R1bGVcIjtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29EaWFsb2dNb2R1bGUsXHJcbiAgICBGb3JtTW9kdWxlLFxyXG4gICAgSW5wdXRUZXh0TW9kdWxlLFxyXG4gICAgU2NyZWVuQ29uZmlndXJhdGlvbk1vZHVsZSxcclxuICAgIEJ1dHRvbk1vZHVsZSxcclxuICAgIExvY2FsaXphdGlvbk1vZHVsZSxcclxuICAgIEljb25Nb2R1bGUsXHJcbiAgICBJbWFnZURpc3BsYXlNb2R1bGUsXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICAvLyBUYWdzTW9kdWxlLFxyXG4gICAgSW5wdXRDaGVja2JveE1vZHVsZSxcclxuICAgIEZpbGVVcGxvYWRNb2R1bGUsXHJcbiAgICBGaWxlVXBsb2FkUG9wdXBNb2R1bGUsXHJcbiAgICBBcHBGaWxlRHJvcHpvbmVNb2R1bGVcclxuICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgRmlsZXNVcGxvYWRDb21wb25lbnQsXHJcbiAgICBEcmFnRHJvcENvbnRhaW5lckNvbXBvbmVudFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgRmlsZXNVcGxvYWRDb21wb25lbnQsXHJcbiAgICBEcmFnRHJvcENvbnRhaW5lckNvbXBvbmVudFxyXG4gIF0sXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICBPdmVybGF5LFxyXG4gICAgRmlsZVR5cGVJbWFnZVBpcGVcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBGaWxlc1VwbG9hZE1vZHVsZSB7XHJcblxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { Component, forwardRef, HostBinding, Input, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME } from '@colijnit/corecomponents_v12';
|
|
3
|
+
export class ImageDisplayComponent {
|
|
4
|
+
constructor() {
|
|
5
|
+
// The (localized) text to show when there is no image. Defaults to 'NO_IMAGE'.
|
|
6
|
+
this.label = "NO_IMAGE";
|
|
7
|
+
}
|
|
8
|
+
showClass() {
|
|
9
|
+
return true;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
ImageDisplayComponent.decorators = [
|
|
13
|
+
{ type: Component, args: [{
|
|
14
|
+
selector: "co-image-display",
|
|
15
|
+
template: `
|
|
16
|
+
<img class="image" *ngIf="!!model" [src]="model">
|
|
17
|
+
<div class="no-image" *ngIf="!model">
|
|
18
|
+
<div class="img"></div>
|
|
19
|
+
<div class="no-image-label" [textContent]="label | localize"></div>
|
|
20
|
+
</div>
|
|
21
|
+
`,
|
|
22
|
+
providers: [{
|
|
23
|
+
provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,
|
|
24
|
+
useExisting: forwardRef(() => ImageDisplayComponent)
|
|
25
|
+
}
|
|
26
|
+
],
|
|
27
|
+
encapsulation: ViewEncapsulation.None
|
|
28
|
+
},] }
|
|
29
|
+
];
|
|
30
|
+
ImageDisplayComponent.propDecorators = {
|
|
31
|
+
model: [{ type: Input }],
|
|
32
|
+
label: [{ type: Input }],
|
|
33
|
+
showClass: [{ type: HostBinding, args: ['class.co-image-display',] }],
|
|
34
|
+
hidden: [{ type: HostBinding, args: ["class.co-transaction-hidden",] }]
|
|
35
|
+
};
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtZGlzcGxheS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaGFyZWRjb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9pbWFnZS1kaXNwbGF5L2ltYWdlLWRpc3BsYXkuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDM0YsT0FBTyxFQUFDLDhDQUE4QyxFQUErQixNQUFNLDhCQUE4QixDQUFDO0FBaUIxSCxNQUFNLE9BQU8scUJBQXFCO0lBZmxDO1FBb0JFLCtFQUErRTtRQUV4RSxVQUFLLEdBQVcsVUFBVSxDQUFDO0lBZ0JwQyxDQUFDO0lBYlEsU0FBUztRQUNkLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQzs7O1lBM0JGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsa0JBQWtCO2dCQUM1QixRQUFRLEVBQUU7Ozs7OztHQU1UO2dCQUNELFNBQVMsRUFBRSxDQUFDO3dCQUNWLE9BQU8sRUFBRSw4Q0FBOEM7d0JBQ3ZELFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMscUJBQXFCLENBQUM7cUJBQUM7aUJBQ3REO2dCQUNELGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2FBQ3RDOzs7b0JBR0UsS0FBSztvQkFJTCxLQUFLO3dCQUdMLFdBQVcsU0FBQyx3QkFBd0I7cUJBTXBDLFdBQVcsU0FBQyw2QkFBNkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgZm9yd2FyZFJlZiwgSG9zdEJpbmRpbmcsIElucHV0LCBWaWV3RW5jYXBzdWxhdGlvbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1NDUkVFTl9DT05GSUdfQURBUFRFUl9DT01QT05FTlRfSU5URVJGQUNFX05BTUUsIFNjcmVlbkNvbmZpZ0FkYXB0ZXJDb21wb25lbnR9IGZyb20gJ0Bjb2xpam5pdC9jb3JlY29tcG9uZW50c192MTInO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6IFwiY28taW1hZ2UtZGlzcGxheVwiLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxpbWcgY2xhc3M9XCJpbWFnZVwiICpuZ0lmPVwiISFtb2RlbFwiIFtzcmNdPVwibW9kZWxcIj5cbiAgICA8ZGl2IGNsYXNzPVwibm8taW1hZ2VcIiAqbmdJZj1cIiFtb2RlbFwiPlxuICAgICAgPGRpdiBjbGFzcz1cImltZ1wiPjwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cIm5vLWltYWdlLWxhYmVsXCIgW3RleHRDb250ZW50XT1cImxhYmVsIHwgbG9jYWxpemVcIj48L2Rpdj5cbiAgICA8L2Rpdj5cbiAgYCxcbiAgcHJvdmlkZXJzOiBbe1xuICAgIHByb3ZpZGU6IFNDUkVFTl9DT05GSUdfQURBUFRFUl9DT01QT05FTlRfSU5URVJGQUNFX05BTUUsXG4gICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gSW1hZ2VEaXNwbGF5Q29tcG9uZW50KX1cbiAgXSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZVxufSlcbmV4cG9ydCBjbGFzcyBJbWFnZURpc3BsYXlDb21wb25lbnQgaW1wbGVtZW50cyBTY3JlZW5Db25maWdBZGFwdGVyQ29tcG9uZW50IHtcbiAgLy8gSW1hZ2UgZGF0YSBVUkkgc3RyaW5nLiBNZWFudCBmb3IgZGlyZWN0IHVzZSBpbiBbc3JjXSBhdHRyaWJ1dGUgb2YgYW4gPGltZz4gdGFnLlxuICBASW5wdXQoKVxuICBwdWJsaWMgbW9kZWw6IHN0cmluZztcblxuICAvLyBUaGUgKGxvY2FsaXplZCkgdGV4dCB0byBzaG93IHdoZW4gdGhlcmUgaXMgbm8gaW1hZ2UuIERlZmF1bHRzIHRvICdOT19JTUFHRScuXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBsYWJlbDogc3RyaW5nID0gXCJOT19JTUFHRVwiO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MuY28taW1hZ2UtZGlzcGxheScpXG4gIHB1YmxpYyBzaG93Q2xhc3MoKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBwdWJsaWMgb2JqZWN0Q29uZmlnTmFtZTogc3RyaW5nO1xuICBASG9zdEJpbmRpbmcoXCJjbGFzcy5jby10cmFuc2FjdGlvbi1oaWRkZW5cIilcbiAgcHVibGljIGhpZGRlbjogYm9vbGVhbjtcbiAgcHVibGljIHJlcXVpcmVkOiBib29sZWFuO1xuICBwdWJsaWMgZm9yY2VSZWFkb25seTogYm9vbGVhbjtcbiAgcHVibGljIHJlYWRvbmx5OiBib29sZWFuO1xuICBwdWJsaWMgbWF4TGVuZ3RoOiBudW1iZXI7XG4gIHB1YmxpYyBkZWNpbWFsczogbnVtYmVyO1xuICBwdWJsaWMgcmVkRXJyb3JCYWNrZ3JvdW5kOiBib29sZWFuO1xufVxuIl19
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { ImageDisplayComponent } from "./image-display.component";
|
|
3
|
+
import { CoreComponentsTranslationModule } from "@colijnit/corecomponents_v12";
|
|
4
|
+
import { CommonModule } from "@angular/common";
|
|
5
|
+
import { LocalizationModule } from "../../localization/localization.module";
|
|
6
|
+
export class ImageDisplayModule {
|
|
7
|
+
}
|
|
8
|
+
ImageDisplayModule.decorators = [
|
|
9
|
+
{ type: NgModule, args: [{
|
|
10
|
+
imports: [
|
|
11
|
+
CoreComponentsTranslationModule,
|
|
12
|
+
CommonModule,
|
|
13
|
+
LocalizationModule
|
|
14
|
+
],
|
|
15
|
+
declarations: [
|
|
16
|
+
ImageDisplayComponent
|
|
17
|
+
],
|
|
18
|
+
exports: [
|
|
19
|
+
ImageDisplayComponent
|
|
20
|
+
]
|
|
21
|
+
},] }
|
|
22
|
+
];
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtZGlzcGxheS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaGFyZWRjb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9pbWFnZS1kaXNwbGF5L2ltYWdlLWRpc3BsYXkubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDaEUsT0FBTyxFQUFDLCtCQUErQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDN0UsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLHdDQUF3QyxDQUFDO0FBZTFFLE1BQU0sT0FBTyxrQkFBa0I7OztZQWI5QixRQUFRLFNBQUM7Z0JBQ04sT0FBTyxFQUFFO29CQUNMLCtCQUErQjtvQkFDL0IsWUFBWTtvQkFDWixrQkFBa0I7aUJBQ3JCO2dCQUNILFlBQVksRUFBRTtvQkFDWixxQkFBcUI7aUJBQ3RCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCxxQkFBcUI7aUJBQ3RCO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0ltYWdlRGlzcGxheUNvbXBvbmVudH0gZnJvbSBcIi4vaW1hZ2UtZGlzcGxheS5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtDb3JlQ29tcG9uZW50c1RyYW5zbGF0aW9uTW9kdWxlfSBmcm9tIFwiQGNvbGlqbml0L2NvcmVjb21wb25lbnRzX3YxMlwiO1xyXG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQge0xvY2FsaXphdGlvbk1vZHVsZX0gZnJvbSBcIi4uLy4uL2xvY2FsaXphdGlvbi9sb2NhbGl6YXRpb24ubW9kdWxlXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvcmVDb21wb25lbnRzVHJhbnNsYXRpb25Nb2R1bGUsXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIExvY2FsaXphdGlvbk1vZHVsZVxyXG4gICAgXSxcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIEltYWdlRGlzcGxheUNvbXBvbmVudFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgSW1hZ2VEaXNwbGF5Q29tcG9uZW50XHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgSW1hZ2VEaXNwbGF5TW9kdWxlIHtcclxuXHJcbn1cclxuIl19
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Custom component for enabling and disabling multiple items based on an input enum
|
|
3
|
+
* For the component to work, an enum is required and a list of enabled items so that
|
|
4
|
+
* the component knows which items from the enum are already enabled
|
|
5
|
+
*
|
|
6
|
+
* Note: can be improved by not only accepting a string array of enabledItemProperties but also a full cgref number because that will save one conversion step as
|
|
7
|
+
* BO's already contain these numbers.
|
|
8
|
+
*/
|
|
9
|
+
import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from "@angular/core";
|
|
10
|
+
import { Icon } from "../../enum/icon.enum";
|
|
11
|
+
import { RefCodeUtils } from "../../utils/ref-code-utils";
|
|
12
|
+
import { EnumUtils } from "../../utils/enum-utils";
|
|
13
|
+
export class MultiplePropertyTogglerComponent {
|
|
14
|
+
constructor() {
|
|
15
|
+
this.label = "";
|
|
16
|
+
this.readonly = false;
|
|
17
|
+
this.enableditemsChange = new EventEmitter();
|
|
18
|
+
// Outputs the sum of cgrefkeys of all newly enabled items
|
|
19
|
+
this.onPropertyItemChange = new EventEmitter();
|
|
20
|
+
this.Icons = Icon;
|
|
21
|
+
this.objectifiedEnum = [];
|
|
22
|
+
this.enabledItemNumberList = [];
|
|
23
|
+
}
|
|
24
|
+
showClass() {
|
|
25
|
+
return true;
|
|
26
|
+
}
|
|
27
|
+
ngAfterViewInit() {
|
|
28
|
+
if (this.propertyNamesToToggle) {
|
|
29
|
+
this.objectifiedEnum = EnumUtils.createObjectFromEnum(this.propertyNamesToToggle);
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
// PropertytogglerItems is empty
|
|
33
|
+
}
|
|
34
|
+
this.makeNumberArrayFromCgRefCodeSum();
|
|
35
|
+
}
|
|
36
|
+
isValueActive(propertyToCheck) {
|
|
37
|
+
return this.enabledItemNumberList.includes(propertyToCheck.key);
|
|
38
|
+
}
|
|
39
|
+
clickToToggleProperty(target) {
|
|
40
|
+
let newRefNumberSum = 0;
|
|
41
|
+
if (this.enabledItemNumberList.includes(target.key)) {
|
|
42
|
+
this.enabledItemNumberList.splice(this.enabledItemNumberList.indexOf(target.key), 1);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
this.enabledItemNumberList.push(target.key);
|
|
46
|
+
}
|
|
47
|
+
this.enabledItemNumberList.forEach(enabledItem => {
|
|
48
|
+
newRefNumberSum += this.objectifiedEnum.find(x => x.key === enabledItem).key;
|
|
49
|
+
});
|
|
50
|
+
this.onPropertyItemChange.emit(newRefNumberSum);
|
|
51
|
+
}
|
|
52
|
+
makeNumberArrayFromCgRefCodeSum() {
|
|
53
|
+
if (this.enableditems) {
|
|
54
|
+
this.enabledItemNumberList = RefCodeUtils.GetMultiRefCodeChoices(this.enableditems);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
MultiplePropertyTogglerComponent.decorators = [
|
|
59
|
+
{ type: Component, args: [{
|
|
60
|
+
selector: "co-multiple-property-toggler",
|
|
61
|
+
template: `
|
|
62
|
+
<div class="input-text-content-wrapper">
|
|
63
|
+
<h3 [textContent]="label"></h3> <!-- | localize-->
|
|
64
|
+
|
|
65
|
+
<div class="property-toggling-container">
|
|
66
|
+
|
|
67
|
+
<div class="row" *ngFor="let propertyTogglerItem of objectifiedEnum | keyvalue">
|
|
68
|
+
|
|
69
|
+
<co-input-checkbox [model]="isValueActive(propertyTogglerItem.value)"
|
|
70
|
+
(click)="clickToToggleProperty(propertyTogglerItem.value)"></co-input-checkbox>
|
|
71
|
+
|
|
72
|
+
<label [textContent]="propertyTogglerItem.value.value"></label>
|
|
73
|
+
</div>
|
|
74
|
+
</div>
|
|
75
|
+
</div>
|
|
76
|
+
`,
|
|
77
|
+
encapsulation: ViewEncapsulation.None
|
|
78
|
+
},] }
|
|
79
|
+
];
|
|
80
|
+
MultiplePropertyTogglerComponent.propDecorators = {
|
|
81
|
+
label: [{ type: Input }],
|
|
82
|
+
propertyNamesToToggle: [{ type: Input }],
|
|
83
|
+
readonly: [{ type: Input }],
|
|
84
|
+
enableditems: [{ type: Input }],
|
|
85
|
+
enableditemsChange: [{ type: Output }],
|
|
86
|
+
onPropertyItemChange: [{ type: Output }],
|
|
87
|
+
showClass: [{ type: HostBinding, args: ["class.co-multiple-property-toggler",] }]
|
|
88
|
+
};
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multiple-property-toggler.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/multi-property-toggler/multiple-property-toggler.component.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAgB,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AAGpH,OAAO,EAAC,IAAI,EAAC,MAAM,sBAAsB,CAAC;AAC1C,OAAO,EAAC,YAAY,EAAC,MAAM,4BAA4B,CAAC;AACxD,OAAO,EAAC,SAAS,EAAC,MAAM,wBAAwB,CAAC;AAsBjD,MAAM,OAAO,gCAAgC;IApB7C;QAsBW,UAAK,GAAW,EAAE,CAAC;QAOnB,aAAQ,GAAa,KAAK,CAAC;QAO3B,uBAAkB,GAAyB,IAAI,YAAY,EAAU,CAAC;QAE7E,0DAA0D;QAE1C,yBAAoB,GAAyB,IAAI,YAAY,EAAU,CAAC;QAOxE,UAAK,GAAgB,IAAI,CAAC;QAEnC,oBAAe,GAAmB,EAAE,CAAC;QAErC,0BAAqB,GAAa,EAAE,CAAC;IAsChD,CAAC;IA9CU,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAQD,eAAe;QACX,IAAI,IAAI,CAAC,qBAAqB,EAAE;YAC5B,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC,oBAAoB,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;SACrF;aAAM;YACH,gCAAgC;SACnC;QACD,IAAI,CAAC,+BAA+B,EAAE,CAAC;IAC3C,CAAC;IAEM,aAAa,CAAC,eAAoB;QACrC,OAAO,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;IACpE,CAAC;IAEM,qBAAqB,CAAC,MAAW;QACpC,IAAI,eAAe,GAAW,CAAC,CAAC;QAEhC,IAAI,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE;YACjD,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;SACxF;aAAM;YACH,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;SAC/C;QAED,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAC9B,WAAW,CAAC,EAAE;YACV,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,WAAW,CAAC,CAAC,GAAG,CAAC;QACjF,CAAC,CACJ,CAAC;QAEF,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACpD,CAAC;IAEM,+BAA+B;QAClC,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,IAAI,CAAC,qBAAqB,GAAG,YAAY,CAAC,sBAAsB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SACvF;IACL,CAAC;;;YAxFJ,SAAS,SAAC;gBACP,QAAQ,EAAE,8BAA8B;gBACxC,QAAQ,EAAE;;;;;;;;;;;;;;;KAeT;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACxC;;;oBAEI,KAAK;oCAIL,KAAK;uBAGL,KAAK;2BAIL,KAAK;iCAGL,MAAM;mCAIN,MAAM;wBAGN,WAAW,SAAC,oCAAoC","sourcesContent":["/**\r\n * Custom component for enabling and disabling multiple items based on an input enum\r\n * For the component to work, an enum is required and a list of enabled items so that\r\n * the component knows which items from the enum are already enabled\r\n *\r\n * Note: can be improved by not only accepting a string array of enabledItemProperties but also a full cgref number because that will save one conversion step as\r\n * BO's already contain these numbers.\r\n */\r\n\r\nimport {AfterViewInit, Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation} from \"@angular/core\";\r\n//import {EnumUtils} from \"../../utils/enum-utils\";\r\nimport {KeyValuePair} from \"../../interface/key-value-pair\";\r\nimport {Icon} from \"../../enum/icon.enum\";\r\nimport {RefCodeUtils} from \"../../utils/ref-code-utils\";\r\nimport {EnumUtils} from \"../../utils/enum-utils\";\r\n\r\n@Component({\r\n    selector: \"co-multiple-property-toggler\",\r\n    template: `\r\n        <div class=\"input-text-content-wrapper\">\r\n            <h3 [textContent]=\"label\"></h3> <!-- | localize-->\r\n\r\n            <div class=\"property-toggling-container\">\r\n\r\n                <div class=\"row\" *ngFor=\"let propertyTogglerItem of objectifiedEnum | keyvalue\">\r\n\r\n                    <co-input-checkbox [model]=\"isValueActive(propertyTogglerItem.value)\"\r\n                                     (click)=\"clickToToggleProperty(propertyTogglerItem.value)\"></co-input-checkbox>\r\n\r\n                    <label [textContent]=\"propertyTogglerItem.value.value\"></label>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    `,\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class MultiplePropertyTogglerComponent implements AfterViewInit {\r\n    @Input()\r\n    public label: string = \"\";\r\n\r\n    // Input an Enum with names and properties and it will be converted\r\n    @Input()\r\n    public propertyNamesToToggle: any;\r\n\r\n    @Input()\r\n    public readonly : boolean = false;\r\n\r\n    // Input the cgrefcode sum so it knows which items will be enabled\r\n    @Input()\r\n    public enableditems: number;\r\n\r\n    @Output()\r\n    public enableditemsChange: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n    // Outputs the sum of cgrefkeys of all newly enabled items\r\n    @Output()\r\n    public readonly onPropertyItemChange: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n    @HostBinding(\"class.co-multiple-property-toggler\")\r\n    public showClass(): boolean {\r\n      return true;\r\n    }\r\n\r\n    public readonly Icons: typeof Icon = Icon;\r\n\r\n    public objectifiedEnum: KeyValuePair[] = [];\r\n\r\n    public enabledItemNumberList: number[] = [];\r\n\r\n    ngAfterViewInit(): void {\r\n        if (this.propertyNamesToToggle) {\r\n            this.objectifiedEnum = EnumUtils.createObjectFromEnum(this.propertyNamesToToggle);\r\n        } else {\r\n            // PropertytogglerItems is empty\r\n        }\r\n        this.makeNumberArrayFromCgRefCodeSum();\r\n    }\r\n\r\n    public isValueActive(propertyToCheck: any): boolean {\r\n        return this.enabledItemNumberList.includes(propertyToCheck.key);\r\n    }\r\n\r\n    public clickToToggleProperty(target: any): void {\r\n        let newRefNumberSum: number = 0;\r\n\r\n        if (this.enabledItemNumberList.includes(target.key)) {\r\n            this.enabledItemNumberList.splice(this.enabledItemNumberList.indexOf(target.key), 1);\r\n        } else {\r\n            this.enabledItemNumberList.push(target.key);\r\n        }\r\n\r\n        this.enabledItemNumberList.forEach(\r\n            enabledItem => {\r\n                newRefNumberSum += this.objectifiedEnum.find(x => x.key === enabledItem).key;\r\n            }\r\n        );\r\n\r\n        this.onPropertyItemChange.emit(newRefNumberSum);\r\n    }\r\n\r\n    public makeNumberArrayFromCgRefCodeSum(): void {\r\n        if (this.enableditems) {\r\n            this.enabledItemNumberList = RefCodeUtils.GetMultiRefCodeChoices(this.enableditems);\r\n        }\r\n    }\r\n}\r\n"]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { MultiplePropertyTogglerComponent } from "./multiple-property-toggler.component";
|
|
3
|
+
import { InputCheckboxModule } from "@colijnit/corecomponents_v12";
|
|
4
|
+
import { CommonModule } from "@angular/common";
|
|
5
|
+
export class MultiplePropertyTogglerModule {
|
|
6
|
+
}
|
|
7
|
+
MultiplePropertyTogglerModule.decorators = [
|
|
8
|
+
{ type: NgModule, args: [{
|
|
9
|
+
imports: [
|
|
10
|
+
InputCheckboxModule,
|
|
11
|
+
CommonModule
|
|
12
|
+
],
|
|
13
|
+
declarations: [
|
|
14
|
+
MultiplePropertyTogglerComponent
|
|
15
|
+
],
|
|
16
|
+
exports: [
|
|
17
|
+
MultiplePropertyTogglerComponent
|
|
18
|
+
]
|
|
19
|
+
},] }
|
|
20
|
+
];
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXVsdGlwbGUtcHJvcGVydHktdG9nZ2xlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaGFyZWRjb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9tdWx0aS1wcm9wZXJ0eS10b2dnbGVyL211bHRpcGxlLXByb3BlcnR5LXRvZ2dsZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLGdDQUFnQyxFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDdkYsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDakUsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBYzdDLE1BQU0sT0FBTyw2QkFBNkI7OztZQVp6QyxRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLG1CQUFtQjtvQkFDbkIsWUFBWTtpQkFDYjtnQkFDRCxZQUFZLEVBQUU7b0JBQ2QsZ0NBQWdDO2lCQUMvQjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1QsZ0NBQWdDO2lCQUMvQjthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtNdWx0aXBsZVByb3BlcnR5VG9nZ2xlckNvbXBvbmVudH0gZnJvbSBcIi4vbXVsdGlwbGUtcHJvcGVydHktdG9nZ2xlci5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtJbnB1dENoZWNrYm94TW9kdWxlfSBmcm9tIFwiQGNvbGlqbml0L2NvcmVjb21wb25lbnRzX3YxMlwiO1xyXG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbXHJcbiAgICBJbnB1dENoZWNrYm94TW9kdWxlLFxyXG4gICAgQ29tbW9uTW9kdWxlXHJcbiAgXSxcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICBNdWx0aXBsZVByb3BlcnR5VG9nZ2xlckNvbXBvbmVudFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gIE11bHRpcGxlUHJvcGVydHlUb2dnbGVyQ29tcG9uZW50XHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTXVsdGlwbGVQcm9wZXJ0eVRvZ2dsZXJNb2R1bGUge1xyXG5cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { Component, ContentChild, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from "@angular/core";
|
|
2
|
+
import { TileSizeType } from "../../enum/tile-size-type";
|
|
3
|
+
import { Icon } from "../../enum/icon.enum";
|
|
4
|
+
import { IconCacheService } from "../../service/icon-cache.service";
|
|
5
|
+
/**
|
|
6
|
+
* A generic component that shows a collection of simple inputs (description, image, price, etc.) as a tile-shaped graphic with an image
|
|
7
|
+
* part (upper) and an info part (lower).
|
|
8
|
+
*/
|
|
9
|
+
export class TileRenderComponent {
|
|
10
|
+
constructor(iconCacheService) {
|
|
11
|
+
this.iconCacheService = iconCacheService;
|
|
12
|
+
this.icons = Icon;
|
|
13
|
+
// Render a large or small tile.
|
|
14
|
+
this.tileSize = TileSizeType.Large;
|
|
15
|
+
// When this tile is selected, this icon will be shown green in the upper-left corner (defaults to 'check').
|
|
16
|
+
this.iconWhenSelected = "check";
|
|
17
|
+
// Emits when the image wrapper was clicked (top half of this component) .
|
|
18
|
+
this.imageClick = new EventEmitter();
|
|
19
|
+
// Emits when the info wrapper was clicked (bottom half of this component).
|
|
20
|
+
this.infoClick = new EventEmitter();
|
|
21
|
+
this.Icon = Icon;
|
|
22
|
+
}
|
|
23
|
+
get inSmallTileMode() {
|
|
24
|
+
return this.tileSize === TileSizeType.Small;
|
|
25
|
+
}
|
|
26
|
+
showClass() {
|
|
27
|
+
return true;
|
|
28
|
+
}
|
|
29
|
+
get inLargeTileMode() {
|
|
30
|
+
return this.tileSize === TileSizeType.Large;
|
|
31
|
+
}
|
|
32
|
+
ngOnDestroy() {
|
|
33
|
+
this.infoTemplate = undefined;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
TileRenderComponent.decorators = [
|
|
37
|
+
{ type: Component, args: [{
|
|
38
|
+
selector: "co-tile-render",
|
|
39
|
+
template: `
|
|
40
|
+
<div class="image" (click)="imageClick.emit()">
|
|
41
|
+
<label *ngIf="inLargeTileMode && tagDescription" [textContent]="tagDescription"></label>
|
|
42
|
+
<co-icon *ngIf="selected" class="selected small light circle" [iconData]="iconCacheService.getIcon(iconWhenSelected)" ></co-icon>
|
|
43
|
+
<co-image [source]="imageDataUri" [class.hidden]="(inSmallTileMode || hideImageDisplayWhenNoImage) && !imageDataUri"
|
|
44
|
+
></co-image>
|
|
45
|
+
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
<ng-content select="[tile-render-image-content]"></ng-content>
|
|
49
|
+
</div>
|
|
50
|
+
<div class="info" (click)="infoClick.emit()">
|
|
51
|
+
<ng-container *ngIf="infoTemplate" [templateWrapper]="infoTemplate"></ng-container>
|
|
52
|
+
<span *ngIf="inLargeTileMode && label" class="label" [textContent]="label"></span>
|
|
53
|
+
<span *ngIf="inLargeTileMode && description" class="description" [textContent]="description"></span>
|
|
54
|
+
</div>
|
|
55
|
+
<ng-content></ng-content>
|
|
56
|
+
`,
|
|
57
|
+
encapsulation: ViewEncapsulation.None
|
|
58
|
+
},] }
|
|
59
|
+
];
|
|
60
|
+
TileRenderComponent.ctorParameters = () => [
|
|
61
|
+
{ type: IconCacheService }
|
|
62
|
+
];
|
|
63
|
+
TileRenderComponent.propDecorators = {
|
|
64
|
+
infoTemplate: [{ type: ContentChild, args: ["infoTemplate", { static: true },] }],
|
|
65
|
+
imageDataUri: [{ type: Input }],
|
|
66
|
+
tagDescription: [{ type: Input }],
|
|
67
|
+
label: [{ type: Input }],
|
|
68
|
+
description: [{ type: Input }],
|
|
69
|
+
tileSize: [{ type: Input }],
|
|
70
|
+
price: [{ type: Input }],
|
|
71
|
+
hidePrice: [{ type: Input }],
|
|
72
|
+
iconWhenSelected: [{ type: Input }],
|
|
73
|
+
hideImageDisplayWhenNoImage: [{ type: Input }],
|
|
74
|
+
selected: [{ type: Input }, { type: HostBinding, args: ["class.selected",] }],
|
|
75
|
+
imageClick: [{ type: Output }],
|
|
76
|
+
infoClick: [{ type: Output }],
|
|
77
|
+
inSmallTileMode: [{ type: HostBinding, args: ["class.small-size",] }],
|
|
78
|
+
showClass: [{ type: HostBinding, args: ["class.co-tile-render",] }]
|
|
79
|
+
};
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlsZS1yZW5kZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2hhcmVkY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvdGlsZS1yZW5kZXJlci90aWxlLXJlbmRlci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxZQUFZLEVBQ1osWUFBWSxFQUNaLFdBQVcsRUFDWCxLQUFLLEVBRUwsTUFBTSxFQUVOLGlCQUFpQixFQUNsQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDdkQsT0FBTyxFQUFDLElBQUksRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQzFDLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBd0JsRTs7O0dBR0c7QUFDSCxNQUFNLE9BQU8sbUJBQW1CO0lBd0U1QixZQUFtQixnQkFBa0M7UUFBbEMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQXZFckMsVUFBSyxHQUFnQixJQUFJLENBQUM7UUFxQjFDLGdDQUFnQztRQUV6QixhQUFRLEdBQWlCLFlBQVksQ0FBQyxLQUFLLENBQUM7UUFVbkQsNEdBQTRHO1FBRXJHLHFCQUFnQixHQUFXLE9BQU8sQ0FBQztRQWMxQywwRUFBMEU7UUFFbkUsZUFBVSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBRS9ELDJFQUEyRTtRQUVwRSxjQUFTLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7UUFzQjdDLFNBQUksR0FBRyxJQUFJLENBQUM7SUFMN0IsQ0FBQztJQWZELElBQ1csZUFBZTtRQUN0QixPQUFPLElBQUksQ0FBQyxRQUFRLEtBQUssWUFBWSxDQUFDLEtBQUssQ0FBQztJQUNoRCxDQUFDO0lBR00sU0FBUztRQUNkLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELElBQVcsZUFBZTtRQUN4QixPQUFPLElBQUksQ0FBQyxRQUFRLEtBQUssWUFBWSxDQUFDLEtBQUssQ0FBQztJQUM5QyxDQUFDO0lBSUQsV0FBVztRQUNQLElBQUksQ0FBQyxZQUFZLEdBQUcsU0FBUyxDQUFDO0lBQ2xDLENBQUM7OztZQXRHSixTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLGdCQUFnQjtnQkFDMUIsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7OztLQWlCVDtnQkFDRCxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTthQUN4Qzs7O1lBdkJPLGdCQUFnQjs7OzJCQStCbkIsWUFBWSxTQUFDLGNBQWMsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUU7MkJBSTdDLEtBQUs7NkJBSUwsS0FBSztvQkFJTCxLQUFLOzBCQUlMLEtBQUs7dUJBSUwsS0FBSztvQkFJTCxLQUFLO3dCQUlMLEtBQUs7K0JBSUwsS0FBSzswQ0FPTCxLQUFLO3VCQUlMLEtBQUssWUFDTCxXQUFXLFNBQUMsZ0JBQWdCO3lCQUk1QixNQUFNO3dCQUlOLE1BQU07OEJBR04sV0FBVyxTQUFDLGtCQUFrQjt3QkFLOUIsV0FBVyxTQUFDLHNCQUFzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIENvbnRlbnRDaGlsZCxcclxuICBFdmVudEVtaXR0ZXIsXHJcbiAgSG9zdEJpbmRpbmcsXHJcbiAgSW5wdXQsXHJcbiAgT25EZXN0cm95LFxyXG4gIE91dHB1dCxcclxuICBUZW1wbGF0ZVJlZixcclxuICBWaWV3RW5jYXBzdWxhdGlvblxyXG59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7VGlsZVNpemVUeXBlfSBmcm9tIFwiLi4vLi4vZW51bS90aWxlLXNpemUtdHlwZVwiO1xyXG5pbXBvcnQge0ljb259IGZyb20gXCIuLi8uLi9lbnVtL2ljb24uZW51bVwiO1xyXG5pbXBvcnQge0ljb25DYWNoZVNlcnZpY2V9IGZyb20gXCIuLi8uLi9zZXJ2aWNlL2ljb24tY2FjaGUuc2VydmljZVwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogXCJjby10aWxlLXJlbmRlclwiLFxyXG4gICAgdGVtcGxhdGU6IGBcclxuICAgICAgICA8ZGl2IGNsYXNzPVwiaW1hZ2VcIiAoY2xpY2spPVwiaW1hZ2VDbGljay5lbWl0KClcIj5cclxuICAgICAgICAgICAgPGxhYmVsICpuZ0lmPVwiaW5MYXJnZVRpbGVNb2RlICYmIHRhZ0Rlc2NyaXB0aW9uXCIgW3RleHRDb250ZW50XT1cInRhZ0Rlc2NyaXB0aW9uXCI+PC9sYWJlbD5cclxuICAgICAgICAgICAgPGNvLWljb24gKm5nSWY9XCJzZWxlY3RlZFwiIGNsYXNzPVwic2VsZWN0ZWQgc21hbGwgbGlnaHQgY2lyY2xlXCIgW2ljb25EYXRhXT1cImljb25DYWNoZVNlcnZpY2UuZ2V0SWNvbihpY29uV2hlblNlbGVjdGVkKVwiID48L2NvLWljb24+XHJcbiAgICAgICAgICAgIDxjby1pbWFnZSBbc291cmNlXT1cImltYWdlRGF0YVVyaVwiIFtjbGFzcy5oaWRkZW5dPVwiKGluU21hbGxUaWxlTW9kZSB8fCBoaWRlSW1hZ2VEaXNwbGF5V2hlbk5vSW1hZ2UpICYmICFpbWFnZURhdGFVcmlcIlxyXG4gICAgICAgICAgICA+PC9jby1pbWFnZT5cclxuXHJcblxyXG5cclxuICAgICAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW3RpbGUtcmVuZGVyLWltYWdlLWNvbnRlbnRdXCI+PC9uZy1jb250ZW50PlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJpbmZvXCIgKGNsaWNrKT1cImluZm9DbGljay5lbWl0KClcIj5cclxuICAgICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImluZm9UZW1wbGF0ZVwiIFt0ZW1wbGF0ZVdyYXBwZXJdPVwiaW5mb1RlbXBsYXRlXCI+PC9uZy1jb250YWluZXI+XHJcbiAgICAgICAgICAgIDxzcGFuICpuZ0lmPVwiaW5MYXJnZVRpbGVNb2RlICYmIGxhYmVsXCIgY2xhc3M9XCJsYWJlbFwiIFt0ZXh0Q29udGVudF09XCJsYWJlbFwiPjwvc3Bhbj5cclxuICAgICAgICAgICAgPHNwYW4gKm5nSWY9XCJpbkxhcmdlVGlsZU1vZGUgJiYgZGVzY3JpcHRpb25cIiBjbGFzcz1cImRlc2NyaXB0aW9uXCIgW3RleHRDb250ZW50XT1cImRlc2NyaXB0aW9uXCI+PC9zcGFuPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuICAgIGAsXHJcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG59KVxyXG4vKipcclxuICogQSBnZW5lcmljIGNvbXBvbmVudCB0aGF0IHNob3dzIGEgY29sbGVjdGlvbiBvZiBzaW1wbGUgaW5wdXRzIChkZXNjcmlwdGlvbiwgaW1hZ2UsIHByaWNlLCBldGMuKSBhcyBhIHRpbGUtc2hhcGVkIGdyYXBoaWMgd2l0aCBhbiBpbWFnZVxyXG4gKiBwYXJ0ICh1cHBlcikgYW5kIGFuIGluZm8gcGFydCAobG93ZXIpLlxyXG4gKi9cclxuZXhwb3J0IGNsYXNzIFRpbGVSZW5kZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xyXG4gICAgcHVibGljIHJlYWRvbmx5IGljb25zOiB0eXBlb2YgSWNvbiA9IEljb247XHJcblxyXG4gICAgQENvbnRlbnRDaGlsZChcImluZm9UZW1wbGF0ZVwiLCB7IHN0YXRpYzogdHJ1ZSB9KVxyXG4gICAgcHVibGljIGluZm9UZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PjtcclxuXHJcbiAgICAvLyBJbWFnZSBkYXRhIHRvIHNob3cgaW4gYW4gPGltYWdlLWRpc3BsYXk+IGNvbXBvbmVudC5cclxuICAgIEBJbnB1dCgpXHJcbiAgICBwdWJsaWMgaW1hZ2VEYXRhVXJpOiBzdHJpbmc7XHJcblxyXG4gICAgLy8gVGFnIHRleHQgdG8gc2hvdyBpbiBhIDx0YWItbGFiZWw+IGNvbXBvbmVudC5cclxuICAgIEBJbnB1dCgpXHJcbiAgICBwdWJsaWMgdGFnRGVzY3JpcHRpb246IHN0cmluZztcclxuXHJcbiAgICAvLyBMYWJlbCB0ZXh0LCBub3QgbG9jYWxpemVkLlxyXG4gICAgQElucHV0KClcclxuICAgIHB1YmxpYyBsYWJlbDogc3RyaW5nO1xyXG5cclxuICAgIC8vIE1haW4gZGVzY3JpcHRpb24gdGV4dC5cclxuICAgIEBJbnB1dCgpXHJcbiAgICBwdWJsaWMgZGVzY3JpcHRpb246IHN0cmluZztcclxuXHJcbiAgICAvLyBSZW5kZXIgYSBsYXJnZSBvciBzbWFsbCB0aWxlLlxyXG4gICAgQElucHV0KClcclxuICAgIHB1YmxpYyB0aWxlU2l6ZTogVGlsZVNpemVUeXBlID0gVGlsZVNpemVUeXBlLkxhcmdlO1xyXG5cclxuICAgIC8vIFRoZSBwcmljZSBmb3IgZGlzcGxheS5cclxuICAgIEBJbnB1dCgpXHJcbiAgICBwdWJsaWMgcHJpY2U6IG51bWJlcjtcclxuXHJcbiAgICAvLyBUaGUgcHJpY2UgY2FuIGJlIGhpZGRlbiBieSBzZXR0aW5nIHRoaXMgdG8gdHJ1ZS5cclxuICAgIEBJbnB1dCgpXHJcbiAgICBwdWJsaWMgaGlkZVByaWNlOiBib29sZWFuO1xyXG5cclxuICAgIC8vIFdoZW4gdGhpcyB0aWxlIGlzIHNlbGVjdGVkLCB0aGlzIGljb24gd2lsbCBiZSBzaG93biBncmVlbiBpbiB0aGUgdXBwZXItbGVmdCBjb3JuZXIgKGRlZmF1bHRzIHRvICdjaGVjaycpLlxyXG4gICAgQElucHV0KClcclxuICAgIHB1YmxpYyBpY29uV2hlblNlbGVjdGVkOiBzdHJpbmcgPSBcImNoZWNrXCI7XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBCeSBkZWZhdWx0LCB0aGlzIGNvbXBvbmVudCBzaG93cyBhIHNwZWNpYWwgaWNvbiBhbmQgbWlzc2luZy1pbWFnZSB0ZXh0IGZvciB0aGUgaW1hZ2Ugd2hlbiBpdCdzIGVtcHR5LiBTZXQgdGhpcyB0byB0cnVlXHJcbiAgICAgKiB0byBoaWRlIHRoZSB3aG9sZSBpbWFnZS1kaXNwbGF5IGluc3RlYWQsIHdoZW4gdGhlcmUgd2FzIG5vIGltYWdlIGdpdmVuLlxyXG4gICAgICovXHJcbiAgICBASW5wdXQoKVxyXG4gICAgcHVibGljIGhpZGVJbWFnZURpc3BsYXlXaGVuTm9JbWFnZTogYm9vbGVhbjtcclxuXHJcbiAgICAvLyBTZWxlY3RlZCB0aWxlcyBoYXZlIGEgZ3JlZW4gYm9yZGVyIGFyb3VuZCB0aGVtLlxyXG4gICAgQElucHV0KClcclxuICAgIEBIb3N0QmluZGluZyhcImNsYXNzLnNlbGVjdGVkXCIpXHJcbiAgICBwdWJsaWMgc2VsZWN0ZWQ6IGJvb2xlYW47XHJcblxyXG4gICAgLy8gRW1pdHMgd2hlbiB0aGUgaW1hZ2Ugd3JhcHBlciB3YXMgY2xpY2tlZCAodG9wIGhhbGYgb2YgdGhpcyBjb21wb25lbnQpIC5cclxuICAgIEBPdXRwdXQoKVxyXG4gICAgcHVibGljIGltYWdlQ2xpY2s6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcblxyXG4gICAgLy8gRW1pdHMgd2hlbiB0aGUgaW5mbyB3cmFwcGVyIHdhcyBjbGlja2VkIChib3R0b20gaGFsZiBvZiB0aGlzIGNvbXBvbmVudCkuXHJcbiAgICBAT3V0cHV0KClcclxuICAgIHB1YmxpYyBpbmZvQ2xpY2s6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcblxyXG4gICAgQEhvc3RCaW5kaW5nKFwiY2xhc3Muc21hbGwtc2l6ZVwiKVxyXG4gICAgcHVibGljIGdldCBpblNtYWxsVGlsZU1vZGUoKTogYm9vbGVhbiB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMudGlsZVNpemUgPT09IFRpbGVTaXplVHlwZS5TbWFsbDtcclxuICAgIH1cclxuXHJcbiAgICBASG9zdEJpbmRpbmcoXCJjbGFzcy5jby10aWxlLXJlbmRlclwiKVxyXG4gICAgcHVibGljIHNob3dDbGFzcygpOiBib29sZWFuIHtcclxuICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIGdldCBpbkxhcmdlVGlsZU1vZGUoKTogYm9vbGVhbiB7XHJcbiAgICAgIHJldHVybiB0aGlzLnRpbGVTaXplID09PSBUaWxlU2l6ZVR5cGUuTGFyZ2U7XHJcbiAgICB9XHJcblxyXG4gICAgY29uc3RydWN0b3IocHVibGljIGljb25DYWNoZVNlcnZpY2U6IEljb25DYWNoZVNlcnZpY2UpIHtcclxuICAgIH1cclxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuaW5mb1RlbXBsYXRlID0gdW5kZWZpbmVkO1xyXG4gICAgfVxyXG5cclxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgSWNvbiA9IEljb247XHJcbn1cclxuIl19
|