@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,189 @@
1
+ import { __awaiter, __decorate } from "tslib";
2
+ import { Component, EventEmitter, HostBinding, Input, Output, ViewChild, ViewEncapsulation } from "@angular/core";
3
+ import { FormComponent, PromptService } from "@colijnit/corecomponents_v12";
4
+ import { Icon } from "../../enum/icon.enum";
5
+ import { InputBoolean } from "../../decorator/input-boolean.decorator";
6
+ import { FileTypeImagePipe } from "../../pipe/file-type-image.pipe";
7
+ import { IconCacheService } from "../../service/icon-cache.service";
8
+ // The GUI part of the files-upload component. Not a standalone component.
9
+ export class FileUploadComponent {
10
+ constructor(_promptService, _fileTypeImgPipe, iconService) {
11
+ this._promptService = _promptService;
12
+ this._fileTypeImgPipe = _fileTypeImgPipe;
13
+ this.iconService = iconService;
14
+ this.icons = Icon;
15
+ // Element clickable
16
+ this.link = false;
17
+ this.readonly = false;
18
+ // Is tile an 'adding' tile
19
+ this.isAddingTile = false;
20
+ // Set this parameter to false if clicking ok on the document edit popup does not save the document
21
+ // so that refreshing of content on file open works correctly
22
+ this.fileSavesOnPopupOkClick = true;
23
+ this.isEditable = false;
24
+ // Show a trashcan icon
25
+ this.showTrashCan = false;
26
+ // Show an image as placeholder
27
+ this.showImage = false;
28
+ this.customImageClick = false;
29
+ this.deleteClick = new EventEmitter();
30
+ this.editClick = new EventEmitter();
31
+ this.imageClick = new EventEmitter();
32
+ this.previewImage = "";
33
+ this._label = "";
34
+ }
35
+ // Input file to upload.
36
+ set file(document) {
37
+ this._file = document;
38
+ this._updatePreviewImage();
39
+ // we should produce a preview image from given document, but its contents might not yet have been loaded:
40
+ this._listenForDocumentBodyChanges();
41
+ }
42
+ get file() {
43
+ return this._file;
44
+ }
45
+ set label(value) {
46
+ this._label = value;
47
+ }
48
+ get label() {
49
+ if (this._file && this._file.description) {
50
+ return this._file.description;
51
+ }
52
+ else {
53
+ return this._label;
54
+ }
55
+ }
56
+ showClass() {
57
+ return true;
58
+ }
59
+ get isLink() {
60
+ return this.link;
61
+ }
62
+ ngOnDestroy() {
63
+ if (this._docBodyChangeSub) {
64
+ this._docBodyChangeSub.unsubscribe();
65
+ }
66
+ }
67
+ onDeleteClick() {
68
+ this.deleteClick.emit();
69
+ }
70
+ onImageClick() {
71
+ return __awaiter(this, void 0, void 0, function* () {
72
+ if (this.isAddingTile) {
73
+ return;
74
+ }
75
+ if (this.customImageClick) {
76
+ this.imageClick.next(this._file);
77
+ return;
78
+ }
79
+ //todo fix methods
80
+ //first download document body if it is stored in a private cdn directory
81
+ if (!this._file.documentBody) {
82
+ //await this._generalDal.getDocumentContent(this._file).then(documentBody => this._file.documentBody = documentBody);
83
+ }
84
+ if (this._file.isImageDocument()) { //preview image
85
+ this._promptService.showImage(this.file.documentBodyAsDataUri, "Preview");
86
+ }
87
+ else { //download document
88
+ try {
89
+ //FileUtils.DownloadFromDataUri(this._file.bodyAsDataUri, this._file.fileName);
90
+ }
91
+ catch (e) {
92
+ }
93
+ }
94
+ });
95
+ }
96
+ onPencilClick() {
97
+ return __awaiter(this, void 0, void 0, function* () {
98
+ // refresh file content if files are saved individually
99
+ if (this._file.hasId() && this.fileSavesOnPopupOkClick) {
100
+ let idForLink;
101
+ if (this._file.idForLink) {
102
+ idForLink = this._file.idForLink;
103
+ }
104
+ // Get most recent version of this file if it has an id and therefore has been saved in the db
105
+ //TODO fix fetch
106
+ // this._file = await this._generalDal.getDocumentFromTable(this._file.documentId);
107
+ //this._file.idForLink = idForLink; // Restore the idForLink
108
+ }
109
+ this.editClick.emit(this._file);
110
+ });
111
+ }
112
+ // updates this.previewImage when doc body changes
113
+ _listenForDocumentBodyChanges() {
114
+ if (this._file) {
115
+ if (this._docBodyChangeSub) {
116
+ this._docBodyChangeSub.unsubscribe();
117
+ }
118
+ // @ts-ignore
119
+ this._docBodyChangeSub = this._file.documentBodyChange.subscribe(() => {
120
+ this._updatePreviewImage();
121
+ });
122
+ }
123
+ }
124
+ _updatePreviewImage() {
125
+ if (this._file) {
126
+ if (this._file.isImageDocument()) {
127
+ this.previewImage = this._file.documentBodyAsDataUri;
128
+ if (this.previewImage === "") {
129
+ //TODO fix fetch
130
+ //this._generalDal.getDocumentContent(this._file).then(documentBody => this._file.documentBody = documentBody);
131
+ //this.previewImage = this._file.documentBody;
132
+ }
133
+ }
134
+ else {
135
+ this.previewImage = this._fileTypeImgPipe.transform(this.file.fileTypeInternal);
136
+ }
137
+ }
138
+ }
139
+ }
140
+ FileUploadComponent.decorators = [
141
+ { type: Component, args: [{
142
+ selector: "co-file-upload",
143
+ template: `
144
+ <co-tile-render [hideImageDisplayWhenNoImage]="true" [imageDataUri]="previewImage" [description]="label" (imageClick)="onImageClick()">
145
+ <ng-template #infoTemplate>
146
+ <co-button *ngIf="isEditable && !readonly" class="edit-file" [iconData]="iconService.getIcon(icons.Account)"
147
+ (click)="onPencilClick()"></co-button>
148
+ </ng-template>
149
+ <co-icon *ngIf="showTrashCan && !readonly" [iconData]="iconService.getIcon(icons.Trashbin)" class="trash" (click)="onDeleteClick()"></co-icon>
150
+ <co-icon tile-render-image-content *ngIf="icon" class="dark add-button" [icon]="icon"></co-icon>
151
+ </co-tile-render>
152
+ `,
153
+ encapsulation: ViewEncapsulation.None
154
+ },] }
155
+ ];
156
+ FileUploadComponent.ctorParameters = () => [
157
+ { type: PromptService },
158
+ { type: FileTypeImagePipe },
159
+ { type: IconCacheService }
160
+ ];
161
+ FileUploadComponent.propDecorators = {
162
+ form: [{ type: ViewChild, args: [FormComponent,] }],
163
+ file: [{ type: Input }],
164
+ icon: [{ type: Input }],
165
+ link: [{ type: Input }],
166
+ readonly: [{ type: Input }],
167
+ isAddingTile: [{ type: Input }],
168
+ fileSavesOnPopupOkClick: [{ type: Input }],
169
+ isEditable: [{ type: Input }],
170
+ label: [{ type: Input }],
171
+ showTrashCan: [{ type: Input }],
172
+ showImage: [{ type: Input }],
173
+ customImageClick: [{ type: Input }],
174
+ deleteClick: [{ type: Output }],
175
+ editClick: [{ type: Output }],
176
+ imageClick: [{ type: Output }],
177
+ showClass: [{ type: HostBinding, args: ['class.co-file-upload',] }],
178
+ isLink: [{ type: HostBinding, args: ["class.link",] }]
179
+ };
180
+ __decorate([
181
+ InputBoolean()
182
+ ], FileUploadComponent.prototype, "isAddingTile", void 0);
183
+ __decorate([
184
+ InputBoolean()
185
+ ], FileUploadComponent.prototype, "fileSavesOnPopupOkClick", void 0);
186
+ __decorate([
187
+ InputBoolean()
188
+ ], FileUploadComponent.prototype, "isEditable", void 0);
189
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/file-upload/file-upload.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnDestroy,\r\n  Output,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from \"@angular/core\";\r\nimport {FormComponent, PromptService} from \"@colijnit/corecomponents_v12\";\r\nimport {CoDocument} from \"@colijnit/mainapi/build/model/co-document\";\r\nimport {Icon} from \"../../enum/icon.enum\";\r\nimport {InputBoolean} from \"../../decorator/input-boolean.decorator\";\r\nimport {FileTypeImagePipe} from \"../../pipe/file-type-image.pipe\";\r\nimport {IconCacheService} from \"../../service/icon-cache.service\";\r\nimport {Subscription} from \"rxjs\";\r\n\r\n@Component({\r\n    selector: \"co-file-upload\",\r\n    template: `\r\n        <co-tile-render [hideImageDisplayWhenNoImage]=\"true\" [imageDataUri]=\"previewImage\" [description]=\"label\" (imageClick)=\"onImageClick()\">\r\n            <ng-template #infoTemplate>\r\n                <co-button *ngIf=\"isEditable && !readonly\" class=\"edit-file\" [iconData]=\"iconService.getIcon(icons.Account)\"\r\n                               (click)=\"onPencilClick()\"></co-button>\r\n            </ng-template>\r\n            <co-icon *ngIf=\"showTrashCan && !readonly\" [iconData]=\"iconService.getIcon(icons.Trashbin)\" class=\"trash\" (click)=\"onDeleteClick()\"></co-icon>\r\n            <co-icon tile-render-image-content *ngIf=\"icon\" class=\"dark add-button\" [icon]=\"icon\"></co-icon>\r\n        </co-tile-render>\r\n    `,\r\n    encapsulation: ViewEncapsulation.None,\r\n})\r\n// The GUI part of the files-upload component. Not a standalone component.\r\nexport class FileUploadComponent implements OnDestroy {\r\n    public readonly icons: typeof Icon = Icon;\r\n\r\n    @ViewChild(FormComponent)\r\n    public form: FormComponent;\r\n\r\n    // Input file to upload.\r\n    @Input()\r\n    public set file(document: CoDocument) {\r\n        this._file = document;\r\n        this._updatePreviewImage();\r\n        // we should produce a preview image from given document, but its contents might not yet have been loaded:\r\n        this._listenForDocumentBodyChanges();\r\n    }\r\n\r\n    public get file(): CoDocument {\r\n        return this._file;\r\n    }\r\n\r\n    // Show icon as placeholder\r\n    @Input()\r\n    public icon: Icon;\r\n\r\n    // Element clickable\r\n    @Input()\r\n    public link: boolean = false;\r\n\r\n    @Input()\r\n    public readonly: boolean = false;\r\n\r\n    // Is tile an 'adding' tile\r\n    @Input()\r\n    @InputBoolean()\r\n    public isAddingTile: boolean = false;\r\n\r\n    // Set this parameter to false if clicking ok on the document edit popup does not save the document\r\n    // so that refreshing of content on file open works correctly\r\n    @Input()\r\n    @InputBoolean()\r\n    public fileSavesOnPopupOkClick: boolean = true;\r\n\r\n    @Input()\r\n    @InputBoolean()\r\n    public isEditable: boolean = false;\r\n\r\n    @Input()\r\n    set label(value: string) {\r\n        this._label = value;\r\n    }\r\n\r\n    get label(): string {\r\n        if (this._file && this._file.description) {\r\n            return this._file.description;\r\n        } else {\r\n            return this._label;\r\n        }\r\n    }\r\n\r\n    // Show a trashcan icon\r\n    @Input()\r\n    public showTrashCan: boolean = false;\r\n\r\n    // Show an image as placeholder\r\n    @Input()\r\n    public showImage: boolean = false;\r\n\r\n    @Input()\r\n    public customImageClick: boolean = false;\r\n\r\n    @Output()\r\n    public deleteClick: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    @Output()\r\n    public editClick: EventEmitter<CoDocument> = new EventEmitter<CoDocument>();\r\n\r\n    @Output()\r\n    public imageClick: EventEmitter<CoDocument> = new EventEmitter<CoDocument>();\r\n\r\n    @HostBinding('class.co-file-upload')\r\n    public showClass(): boolean {\r\n      return true;\r\n    }\r\n\r\n    @HostBinding(\"class.link\")\r\n    public get isLink(): boolean {\r\n        return this.link;\r\n    }\r\n\r\n    public previewImage: string = \"\";\r\n\r\n    private _file: CoDocument;\r\n    private _docBodyChangeSub: Subscription;\r\n    private _label: string = \"\";\r\n\r\n    constructor(\r\n        private _promptService: PromptService,\r\n        private _fileTypeImgPipe: FileTypeImagePipe,\r\n        public iconService: IconCacheService,\r\n        //private _generalDal: GeneralDalRepository\r\n        ) {\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        if (this._docBodyChangeSub) {\r\n            this._docBodyChangeSub.unsubscribe();\r\n        }\r\n    }\r\n\r\n    public onDeleteClick(): void {\r\n        this.deleteClick.emit();\r\n    }\r\n\r\n    public async  onImageClick(): Promise<void> {\r\n        if (this.isAddingTile) {\r\n            return;\r\n        }\r\n        if (this.customImageClick) {\r\n            this.imageClick.next(this._file);\r\n            return;\r\n        }\r\n        //todo fix methods\r\n        //first download document body if it is stored in a private cdn directory\r\n        if (!this._file.documentBody) {\r\n            //await this._generalDal.getDocumentContent(this._file).then(documentBody => this._file.documentBody = documentBody);\r\n        }\r\n        if (this._file.isImageDocument()) { //preview image\r\n            this._promptService.showImage(this.file.documentBodyAsDataUri, \"Preview\");\r\n        } else { //download document\r\n            try {\r\n                //FileUtils.DownloadFromDataUri(this._file.bodyAsDataUri, this._file.fileName);\r\n            } catch (e) {\r\n\r\n            }\r\n        }\r\n    }\r\n\r\n    public async onPencilClick(): Promise<void> {\r\n        // refresh file content if files are saved individually\r\n        if (this._file.hasId() && this.fileSavesOnPopupOkClick) {\r\n            let idForLink: number;\r\n            if (this._file.idForLink) {\r\n                idForLink = this._file.idForLink;\r\n            }\r\n            // Get most recent version of this file if it has an id and therefore has been saved in the db\r\n            //TODO fix fetch\r\n           // this._file = await this._generalDal.getDocumentFromTable(this._file.documentId);\r\n            //this._file.idForLink = idForLink; // Restore the idForLink\r\n        }\r\n\r\n        this.editClick.emit(this._file);\r\n    }\r\n\r\n    // updates this.previewImage when doc body changes\r\n    private _listenForDocumentBodyChanges(): void {\r\n        if (this._file) {\r\n            if (this._docBodyChangeSub) {\r\n                this._docBodyChangeSub.unsubscribe();\r\n            }\r\n\r\n            // @ts-ignore\r\n          this._docBodyChangeSub = this._file.documentBodyChange.subscribe(() => {\r\n                this._updatePreviewImage();\r\n            });\r\n        }\r\n    }\r\n\r\n    private _updatePreviewImage(): void {\r\n        if (this._file) {\r\n            if (this._file.isImageDocument()) {\r\n                this.previewImage = this._file.documentBodyAsDataUri;\r\n                if (this.previewImage === \"\") {\r\n                    //TODO fix fetch\r\n                    //this._generalDal.getDocumentContent(this._file).then(documentBody => this._file.documentBody = documentBody);\r\n                    //this.previewImage = this._file.documentBody;\r\n                }\r\n            } else {\r\n                this.previewImage = this._fileTypeImgPipe.transform(this.file.fileTypeInternal);\r\n            }\r\n        }\r\n    }\r\n\r\n}\r\n"]}
@@ -0,0 +1,25 @@
1
+ import { NgModule } from "@angular/core";
2
+ import { FileUploadComponent } from "./file-upload.component";
3
+ import { ButtonModule, IconModule } from "@colijnit/corecomponents_v12";
4
+ import { TileRenderModule } from "../tile-renderer/tile-render.module";
5
+ import { CommonModule } from "@angular/common";
6
+ export class FileUploadModule {
7
+ }
8
+ FileUploadModule.decorators = [
9
+ { type: NgModule, args: [{
10
+ imports: [
11
+ IconModule,
12
+ TileRenderModule,
13
+ CommonModule,
14
+ ButtonModule
15
+ ],
16
+ declarations: [
17
+ FileUploadComponent
18
+ ],
19
+ exports: [
20
+ FileUploadComponent
21
+ ],
22
+ providers: []
23
+ },] }
24
+ ];
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2hhcmVkY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvZmlsZS11cGxvYWQvZmlsZS11cGxvYWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDNUQsT0FBTyxFQUFDLFlBQVksRUFBRSxVQUFVLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUN0RSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUNyRSxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFtQjdDLE1BQU0sT0FBTyxnQkFBZ0I7OztZQWhCNUIsUUFBUSxTQUFDO2dCQUNSLE9BQU8sRUFBRTtvQkFDUCxVQUFVO29CQUNWLGdCQUFnQjtvQkFDaEIsWUFBWTtvQkFDWixZQUFZO2lCQUNiO2dCQUNELFlBQVksRUFBRTtvQkFDWixtQkFBbUI7aUJBQ3BCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCxtQkFBbUI7aUJBQ3BCO2dCQUNELFNBQVMsRUFBRSxFQUNWO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0ZpbGVVcGxvYWRDb21wb25lbnR9IGZyb20gXCIuL2ZpbGUtdXBsb2FkLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0J1dHRvbk1vZHVsZSwgSWNvbk1vZHVsZX0gZnJvbSBcIkBjb2xpam5pdC9jb3JlY29tcG9uZW50c192MTJcIjtcclxuaW1wb3J0IHtUaWxlUmVuZGVyTW9kdWxlfSBmcm9tIFwiLi4vdGlsZS1yZW5kZXJlci90aWxlLXJlbmRlci5tb2R1bGVcIjtcclxuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuXHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtcclxuICAgIEljb25Nb2R1bGUsXHJcbiAgICBUaWxlUmVuZGVyTW9kdWxlLFxyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgQnV0dG9uTW9kdWxlXHJcbiAgXSxcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIEZpbGVVcGxvYWRDb21wb25lbnRcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIEZpbGVVcGxvYWRDb21wb25lbnRcclxuICBdLFxyXG4gIHByb3ZpZGVyczogW1xyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEZpbGVVcGxvYWRNb2R1bGUge1xyXG5cclxufVxyXG4iXX0=