@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.
Files changed (157) hide show
  1. package/bundles/colijnit-sharedcomponents.umd.js +3555 -6
  2. package/bundles/colijnit-sharedcomponents.umd.js.map +1 -1
  3. package/colijnit-sharedcomponents.d.ts +17 -0
  4. package/colijnit-sharedcomponents.metadata.json +1 -1
  5. package/esm2015/colijnit-sharedcomponents.js +18 -1
  6. package/esm2015/lib/businessobject/build-images-and-documentation-result.js +2 -0
  7. package/esm2015/lib/businessobject/co-document-right.bo.js +3 -0
  8. package/esm2015/lib/businessobject/drag-drop-container-element.js +2 -0
  9. package/esm2015/lib/businessobject/drag-drop-container.js +7 -0
  10. package/esm2015/lib/components/activity-list/activity-list.component.js +130 -0
  11. package/esm2015/lib/components/activity-list/activity-list.module.js +24 -0
  12. package/esm2015/lib/components/app-file-dropzone/app-file-dropzone.component.js +47 -0
  13. package/esm2015/lib/components/app-file-dropzone/app-file-dropzone.module.js +20 -0
  14. package/esm2015/lib/components/file-upload/file-upload.component.js +189 -0
  15. package/esm2015/lib/components/file-upload/file-upload.module.js +25 -0
  16. package/esm2015/lib/components/file-upload-popup/file-upload-popup.component.js +397 -0
  17. package/esm2015/lib/components/file-upload-popup/file-upload-popup.module.js +30 -0
  18. package/esm2015/lib/components/files-upload/components/base-file-upload.component.js +469 -0
  19. package/esm2015/lib/components/files-upload/components/drag-drop-container.component.js +115 -0
  20. package/esm2015/lib/components/files-upload/files-upload.component.js +131 -0
  21. package/esm2015/lib/components/files-upload/files-upload.module.js +47 -0
  22. package/esm2015/lib/components/image-display/image-display.component.js +36 -0
  23. package/esm2015/lib/components/image-display/image-display.module.js +23 -0
  24. package/esm2015/lib/components/multi-property-toggler/multiple-property-toggler.component.js +89 -0
  25. package/esm2015/lib/components/multi-property-toggler/multiple-property-toggler.module.js +21 -0
  26. package/esm2015/lib/components/tile-renderer/tile-render.component.js +80 -0
  27. package/esm2015/lib/components/tile-renderer/tile-render.module.js +26 -0
  28. package/esm2015/lib/decorator/input-boolean.decorator.js +34 -0
  29. package/esm2015/lib/enum/document-email-report.enum.js +18 -0
  30. package/esm2015/lib/enum/domain-multiple-name.enum.js +13 -0
  31. package/esm2015/lib/enum/file-type.js +14 -0
  32. package/esm2015/lib/enum/files-upload-config-objects.js +3 -0
  33. package/esm2015/lib/enum/icon.enum.js +7 -1
  34. package/esm2015/lib/enum/internal-param.enum.js +38 -0
  35. package/esm2015/lib/enum/read-write-access-config-names.enum.js +2 -0
  36. package/esm2015/lib/enum/table-name.enum.js +86 -0
  37. package/esm2015/lib/enum/tag-category.enum.js +22 -0
  38. package/esm2015/lib/enum/tags-component-config-names.js +2 -0
  39. package/esm2015/lib/enum/tile-size-type.js +7 -0
  40. package/esm2015/lib/event/co-drag-event.js +2 -0
  41. package/esm2015/lib/event/co-drop-event.js +2 -0
  42. package/esm2015/lib/interface/key-value-pair.js +2 -0
  43. package/esm2015/lib/interface/operation-callback-simple-function.js +4 -0
  44. package/esm2015/lib/model/icon-svg.js +7 -1
  45. package/esm2015/lib/model/tag-tree-item.bo.js +16 -0
  46. package/esm2015/lib/model/tree-object.js +15 -0
  47. package/esm2015/lib/pipe/file-type-image.pipe.js +51 -0
  48. package/esm2015/lib/pipe/master-pipes.js +4 -2
  49. package/esm2015/lib/service/drag-drop.service.js +365 -0
  50. package/esm2015/lib/service/shared-connector.service.js +10 -1
  51. package/esm2015/lib/service/shared.service.js +2 -2
  52. package/esm2015/lib/utils/array-utils.js +202 -0
  53. package/esm2015/lib/utils/check-precision-and-scale-result.js +2 -0
  54. package/esm2015/lib/utils/check-within-stepped-bounds-result.js +2 -0
  55. package/esm2015/lib/utils/co-document-shared-field-logic.js +50 -0
  56. package/esm2015/lib/utils/enum-utils.js +128 -0
  57. package/esm2015/lib/utils/is-nill.function.js +5 -0
  58. package/esm2015/lib/utils/number-utils.js +390 -0
  59. package/esm2015/lib/utils/object-utils.js +278 -0
  60. package/esm2015/lib/utils/ref-code-utils.js +49 -0
  61. package/esm2015/lib/utils/string-utils.js +30 -1
  62. package/esm2015/public-api.js +5 -1
  63. package/fesm2015/colijnit-sharedcomponents.js +3528 -6
  64. package/fesm2015/colijnit-sharedcomponents.js.map +1 -1
  65. package/lib/businessobject/build-images-and-documentation-result.d.ts +5 -0
  66. package/lib/businessobject/co-document-right.bo.d.ts +6 -0
  67. package/lib/businessobject/drag-drop-container-element.d.ts +6 -0
  68. package/lib/businessobject/drag-drop-container.d.ts +6 -0
  69. package/lib/components/access/read-write-access.scss +25 -0
  70. package/lib/components/access/style/_layout.scss +23 -0
  71. package/lib/components/access/style/_material-definition.scss +12 -0
  72. package/lib/components/access/style/_theme.scss +4 -0
  73. package/lib/components/access/style/material.scss +4 -0
  74. package/lib/components/activity-list/activity-list.component.d.ts +33 -0
  75. package/lib/components/activity-list/activity-list.module.d.ts +2 -0
  76. package/lib/components/activity-list/style/_layout.scss +68 -0
  77. package/lib/components/activity-list/style/_material-definition.scss +0 -0
  78. package/lib/components/activity-list/style/_theme.scss +4 -0
  79. package/lib/components/activity-list/style/material.scss +4 -0
  80. package/lib/components/app-file-dropzone/app-file-dropzone.component.d.ts +14 -0
  81. package/lib/components/app-file-dropzone/app-file-dropzone.module.d.ts +2 -0
  82. package/lib/components/app-file-dropzone/style/_layout.scss +61 -0
  83. package/lib/components/app-file-dropzone/style/_material-definition.scss +0 -0
  84. package/lib/components/app-file-dropzone/style/_theme.scss +4 -0
  85. package/lib/components/app-file-dropzone/style/material.scss +4 -0
  86. package/lib/components/file-upload/file-upload.component.d.ts +42 -0
  87. package/lib/components/file-upload/file-upload.module.d.ts +2 -0
  88. package/lib/components/file-upload/style/_layout.scss +59 -0
  89. package/lib/components/file-upload/style/_material-definition.scss +2 -0
  90. package/lib/components/file-upload/style/_theme.scss +4 -0
  91. package/lib/components/file-upload/style/material.scss +4 -0
  92. package/lib/components/file-upload-popup/file-upload-popup.component.d.ts +75 -0
  93. package/lib/components/file-upload-popup/file-upload-popup.module.d.ts +2 -0
  94. package/lib/components/file-upload-popup/style/_layout.scss +48 -0
  95. package/lib/components/file-upload-popup/style/_material-definition.scss +2 -0
  96. package/lib/components/file-upload-popup/style/_theme.scss +5 -0
  97. package/lib/components/file-upload-popup/style/material.scss +4 -0
  98. package/lib/components/files-upload/components/base-file-upload.component.d.ts +98 -0
  99. package/lib/components/files-upload/components/drag-drop-container.component.d.ts +34 -0
  100. package/lib/components/files-upload/files-upload.component.d.ts +32 -0
  101. package/lib/components/files-upload/files-upload.module.d.ts +2 -0
  102. package/lib/components/files-upload/style/_layout.scss +49 -0
  103. package/lib/components/files-upload/style/_material-definition.scss +0 -0
  104. package/lib/components/files-upload/style/_theme.scss +5 -0
  105. package/lib/components/files-upload/style/material.scss +4 -0
  106. package/lib/components/image-display/image-display.component.d.ts +14 -0
  107. package/lib/components/image-display/image-display.module.d.ts +2 -0
  108. package/lib/components/image-display/style/_layout.scss +56 -0
  109. package/lib/components/image-display/style/_material-definition.scss +4 -0
  110. package/lib/components/image-display/style/_theme.scss +6 -0
  111. package/lib/components/image-display/style/material.scss +3 -0
  112. package/lib/components/multi-property-toggler/multiple-property-toggler.component.d.ts +27 -0
  113. package/lib/components/multi-property-toggler/multiple-property-toggler.module.d.ts +2 -0
  114. package/lib/components/multi-property-toggler/style/_layout.scss +24 -0
  115. package/lib/components/multi-property-toggler/style/_material-definition.scss +0 -0
  116. package/lib/components/multi-property-toggler/style/_theme.scss +4 -0
  117. package/lib/components/multi-property-toggler/style/material.scss +4 -0
  118. package/lib/components/tile-renderer/style/_layout.scss +90 -0
  119. package/lib/components/tile-renderer/style/_material-definition.scss +0 -0
  120. package/lib/components/tile-renderer/style/_theme.scss +4 -0
  121. package/lib/components/tile-renderer/style/material.scss +4 -0
  122. package/lib/components/tile-renderer/tile-render.component.d.ts +31 -0
  123. package/lib/components/tile-renderer/tile-render.module.d.ts +2 -0
  124. package/lib/decorator/input-boolean.decorator.d.ts +8 -0
  125. package/lib/enum/document-email-report.enum.d.ts +15 -0
  126. package/lib/enum/domain-multiple-name.enum.d.ts +10 -0
  127. package/lib/enum/file-type.d.ts +7 -0
  128. package/lib/enum/files-upload-config-objects.d.ts +22 -0
  129. package/lib/enum/icon.enum.d.ts +6 -0
  130. package/lib/enum/internal-param.enum.d.ts +34 -0
  131. package/lib/enum/read-write-access-config-names.enum.d.ts +4 -0
  132. package/lib/enum/table-name.enum.d.ts +84 -0
  133. package/lib/enum/tag-category.enum.d.ts +19 -0
  134. package/lib/enum/tags-component-config-names.d.ts +4 -0
  135. package/lib/enum/tile-size-type.d.ts +4 -0
  136. package/lib/event/co-drag-event.d.ts +5 -0
  137. package/lib/event/co-drop-event.d.ts +8 -0
  138. package/lib/interface/key-value-pair.d.ts +4 -0
  139. package/lib/interface/operation-callback-simple-function.d.ts +4 -0
  140. package/lib/model/tag-tree-item.bo.d.ts +18 -0
  141. package/lib/model/tree-object.d.ts +8 -0
  142. package/lib/pipe/file-type-image.pipe.d.ts +12 -0
  143. package/lib/service/drag-drop.service.d.ts +86 -0
  144. package/lib/service/shared-connector.service.d.ts +2 -0
  145. package/lib/style/_variables.scss +1 -1
  146. package/lib/utils/array-utils.d.ts +63 -0
  147. package/lib/utils/check-precision-and-scale-result.d.ts +4 -0
  148. package/lib/utils/check-within-stepped-bounds-result.d.ts +8 -0
  149. package/lib/utils/co-document-shared-field-logic.d.ts +7 -0
  150. package/lib/utils/enum-utils.d.ts +31 -0
  151. package/lib/utils/is-nill.function.d.ts +1 -0
  152. package/lib/utils/number-utils.d.ts +125 -0
  153. package/lib/utils/object-utils.d.ts +40 -0
  154. package/lib/utils/ref-code-utils.d.ts +10 -0
  155. package/lib/utils/string-utils.d.ts +16 -0
  156. package/package.json +1 -1
  157. 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":";AAAA,OAAO,EACL,SAAS,EACT,wBAAwB,EACxB,YAAY,EAEZ,YAAY,EAAE,UAAU,EACxB,WAAW,EACX,KAAK,EAEL,MAAM,EAEN,SAAS,EACT,gBAAgB,EAChB,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,uBAAuB,EAAC,MAAM,yCAAyC,CAAC;AAChF,OAAO,EAAC,8CAA8C,EAAC,MAAM,8BAA8B,CAAC;AAC5F,OAAO,EAAC,iBAAiB,EAAC,MAAM,kCAAkC,CAAC;AAGnE,OAAO,EAAC,YAAY,EAAC,MAAM,yCAAyC,CAAC;AA6CrE,0IAA0I;AAC1I,MAAM,OAAO,oBAAqB,SAAQ,uBAAuB;IAoE7D;IACI,+BAA+B;IAC/B,iBAAoC;IACpC,2BAA2B;IACjB,UAA4B,EAC5B,QAAkC;QAQ5C,KAAK,CAAC,iBAAiB,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;QATrC,eAAU,GAAV,UAAU,CAAkB;QAC5B,aAAQ,GAAR,QAAQ,CAA0B;QA1DhD,qBAAqB;QAEd,UAAK,GAAW,aAAa,CAAC;QAM9B,qBAAgB,GAAY,KAAK,CAAC;QAIlC,eAAU,GAAY,KAAK,CAAC;QAG5B,gBAAW,GAAY,KAAK,CAAC;QASpB,uBAAkB,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAG3E,oBAAe,GAAgC,IAAI,YAAY,EAAiB,CAAC;QAGjF,eAAU,GAA6B,IAAI,YAAY,EAAc,CAAC;QAmBtE,kBAAa,GAAY,KAAK,CAAC;QAE/B,eAAU,GAAY,KAAK,CAAC;IAgBnC,CAAC;IAhFD,IACW,QAAQ,CAAC,KAAc;QAC9B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC5B,CAAC;IA4CM,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IACW,QAAQ;QACf,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,IACW,KAAK;QACZ,OAAO,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,CAAC;IAC1D,CAAC;IAuBD,WAAW;QACP,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAC;QAClC,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;QACvB,KAAK,CAAC,WAAW,EAAE,CAAC;IACxB,CAAC;IAEY,eAAe;;YACxB,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE;gBACxC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;aACpC;QACL,CAAC;KAAA;IAEM,cAAc;QACjB,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;;;YA9IJ,SAAS,SAAC;gBACP,QAAQ,EAAE,iBAAiB;gBAC3B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAgCT;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;gBACrC,SAAS,EAAE;oBACP;wBACI,OAAO,EAAE,8CAA8C;wBACvD,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,oBAAoB,CAAC;qBACtD;iBACJ;aACJ;;;YA/CO,iBAAiB;YALvB,gBAAgB;YAVhB,wBAAwB;;;uBAkErB,KAAK;+BAML,YAAY,SAAC,kBAAkB,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;oBAI/C,SAAS,SAAC,WAAW,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;oBAIrC,KAAK;uBAGL,KAAK;+BAGL,KAAK;yBAGL,KAAK;0BAIL,KAAK;sCAGL,KAAK;uBAGL,KAAK;iCAGL,MAAM;8BAGN,MAAM;yBAGN,MAAM;wBAIN,WAAW,SAAC,uBAAuB;uBAKnC,WAAW,SAAC,gBAAgB;oBAK5B,WAAW,SAAC,aAAa;yBAOzB,WAAW,SAAC,gBAAgB;;AAtC7B;IADC,YAAY,EAAE;wDACoB;AAGnC;IADU,YAAY,EAAE;yDACY","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