@colijnit/sharedcomponents 1.0.57 → 1.0.58
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/colijnit-sharedcomponents.umd.js +3555 -6
- package/bundles/colijnit-sharedcomponents.umd.js.map +1 -1
- package/colijnit-sharedcomponents.d.ts +17 -0
- package/colijnit-sharedcomponents.metadata.json +1 -1
- package/esm2015/colijnit-sharedcomponents.js +18 -1
- package/esm2015/lib/businessobject/build-images-and-documentation-result.js +2 -0
- package/esm2015/lib/businessobject/co-document-right.bo.js +3 -0
- package/esm2015/lib/businessobject/drag-drop-container-element.js +2 -0
- package/esm2015/lib/businessobject/drag-drop-container.js +7 -0
- package/esm2015/lib/components/activity-list/activity-list.component.js +130 -0
- package/esm2015/lib/components/activity-list/activity-list.module.js +24 -0
- package/esm2015/lib/components/app-file-dropzone/app-file-dropzone.component.js +47 -0
- package/esm2015/lib/components/app-file-dropzone/app-file-dropzone.module.js +20 -0
- package/esm2015/lib/components/file-upload/file-upload.component.js +189 -0
- package/esm2015/lib/components/file-upload/file-upload.module.js +25 -0
- package/esm2015/lib/components/file-upload-popup/file-upload-popup.component.js +397 -0
- package/esm2015/lib/components/file-upload-popup/file-upload-popup.module.js +30 -0
- package/esm2015/lib/components/files-upload/components/base-file-upload.component.js +469 -0
- package/esm2015/lib/components/files-upload/components/drag-drop-container.component.js +115 -0
- package/esm2015/lib/components/files-upload/files-upload.component.js +131 -0
- package/esm2015/lib/components/files-upload/files-upload.module.js +47 -0
- package/esm2015/lib/components/image-display/image-display.component.js +36 -0
- package/esm2015/lib/components/image-display/image-display.module.js +23 -0
- package/esm2015/lib/components/multi-property-toggler/multiple-property-toggler.component.js +89 -0
- package/esm2015/lib/components/multi-property-toggler/multiple-property-toggler.module.js +21 -0
- package/esm2015/lib/components/tile-renderer/tile-render.component.js +80 -0
- package/esm2015/lib/components/tile-renderer/tile-render.module.js +26 -0
- package/esm2015/lib/decorator/input-boolean.decorator.js +34 -0
- package/esm2015/lib/enum/document-email-report.enum.js +18 -0
- package/esm2015/lib/enum/domain-multiple-name.enum.js +13 -0
- package/esm2015/lib/enum/file-type.js +14 -0
- package/esm2015/lib/enum/files-upload-config-objects.js +3 -0
- package/esm2015/lib/enum/icon.enum.js +7 -1
- package/esm2015/lib/enum/internal-param.enum.js +38 -0
- package/esm2015/lib/enum/read-write-access-config-names.enum.js +2 -0
- package/esm2015/lib/enum/table-name.enum.js +86 -0
- package/esm2015/lib/enum/tag-category.enum.js +22 -0
- package/esm2015/lib/enum/tags-component-config-names.js +2 -0
- package/esm2015/lib/enum/tile-size-type.js +7 -0
- package/esm2015/lib/event/co-drag-event.js +2 -0
- package/esm2015/lib/event/co-drop-event.js +2 -0
- package/esm2015/lib/interface/key-value-pair.js +2 -0
- package/esm2015/lib/interface/operation-callback-simple-function.js +4 -0
- package/esm2015/lib/model/icon-svg.js +7 -1
- package/esm2015/lib/model/tag-tree-item.bo.js +16 -0
- package/esm2015/lib/model/tree-object.js +15 -0
- package/esm2015/lib/pipe/file-type-image.pipe.js +51 -0
- package/esm2015/lib/pipe/master-pipes.js +4 -2
- package/esm2015/lib/service/drag-drop.service.js +365 -0
- package/esm2015/lib/service/shared-connector.service.js +10 -1
- package/esm2015/lib/service/shared.service.js +2 -2
- package/esm2015/lib/utils/array-utils.js +202 -0
- package/esm2015/lib/utils/check-precision-and-scale-result.js +2 -0
- package/esm2015/lib/utils/check-within-stepped-bounds-result.js +2 -0
- package/esm2015/lib/utils/co-document-shared-field-logic.js +50 -0
- package/esm2015/lib/utils/enum-utils.js +128 -0
- package/esm2015/lib/utils/is-nill.function.js +5 -0
- package/esm2015/lib/utils/number-utils.js +390 -0
- package/esm2015/lib/utils/object-utils.js +278 -0
- package/esm2015/lib/utils/ref-code-utils.js +49 -0
- package/esm2015/lib/utils/string-utils.js +30 -1
- package/esm2015/public-api.js +5 -1
- package/fesm2015/colijnit-sharedcomponents.js +3528 -6
- package/fesm2015/colijnit-sharedcomponents.js.map +1 -1
- package/lib/businessobject/build-images-and-documentation-result.d.ts +5 -0
- package/lib/businessobject/co-document-right.bo.d.ts +6 -0
- package/lib/businessobject/drag-drop-container-element.d.ts +6 -0
- package/lib/businessobject/drag-drop-container.d.ts +6 -0
- package/lib/components/access/read-write-access.scss +25 -0
- package/lib/components/access/style/_layout.scss +23 -0
- package/lib/components/access/style/_material-definition.scss +12 -0
- package/lib/components/access/style/_theme.scss +4 -0
- package/lib/components/access/style/material.scss +4 -0
- package/lib/components/activity-list/activity-list.component.d.ts +33 -0
- package/lib/components/activity-list/activity-list.module.d.ts +2 -0
- package/lib/components/activity-list/style/_layout.scss +68 -0
- package/lib/components/activity-list/style/_material-definition.scss +0 -0
- package/lib/components/activity-list/style/_theme.scss +4 -0
- package/lib/components/activity-list/style/material.scss +4 -0
- package/lib/components/app-file-dropzone/app-file-dropzone.component.d.ts +14 -0
- package/lib/components/app-file-dropzone/app-file-dropzone.module.d.ts +2 -0
- package/lib/components/app-file-dropzone/style/_layout.scss +61 -0
- package/lib/components/app-file-dropzone/style/_material-definition.scss +0 -0
- package/lib/components/app-file-dropzone/style/_theme.scss +4 -0
- package/lib/components/app-file-dropzone/style/material.scss +4 -0
- package/lib/components/file-upload/file-upload.component.d.ts +42 -0
- package/lib/components/file-upload/file-upload.module.d.ts +2 -0
- package/lib/components/file-upload/style/_layout.scss +59 -0
- package/lib/components/file-upload/style/_material-definition.scss +2 -0
- package/lib/components/file-upload/style/_theme.scss +4 -0
- package/lib/components/file-upload/style/material.scss +4 -0
- package/lib/components/file-upload-popup/file-upload-popup.component.d.ts +75 -0
- package/lib/components/file-upload-popup/file-upload-popup.module.d.ts +2 -0
- package/lib/components/file-upload-popup/style/_layout.scss +48 -0
- package/lib/components/file-upload-popup/style/_material-definition.scss +2 -0
- package/lib/components/file-upload-popup/style/_theme.scss +5 -0
- package/lib/components/file-upload-popup/style/material.scss +4 -0
- package/lib/components/files-upload/components/base-file-upload.component.d.ts +98 -0
- package/lib/components/files-upload/components/drag-drop-container.component.d.ts +34 -0
- package/lib/components/files-upload/files-upload.component.d.ts +32 -0
- package/lib/components/files-upload/files-upload.module.d.ts +2 -0
- package/lib/components/files-upload/style/_layout.scss +49 -0
- package/lib/components/files-upload/style/_material-definition.scss +0 -0
- package/lib/components/files-upload/style/_theme.scss +5 -0
- package/lib/components/files-upload/style/material.scss +4 -0
- package/lib/components/image-display/image-display.component.d.ts +14 -0
- package/lib/components/image-display/image-display.module.d.ts +2 -0
- package/lib/components/image-display/style/_layout.scss +56 -0
- package/lib/components/image-display/style/_material-definition.scss +4 -0
- package/lib/components/image-display/style/_theme.scss +6 -0
- package/lib/components/image-display/style/material.scss +3 -0
- package/lib/components/multi-property-toggler/multiple-property-toggler.component.d.ts +27 -0
- package/lib/components/multi-property-toggler/multiple-property-toggler.module.d.ts +2 -0
- package/lib/components/multi-property-toggler/style/_layout.scss +24 -0
- package/lib/components/multi-property-toggler/style/_material-definition.scss +0 -0
- package/lib/components/multi-property-toggler/style/_theme.scss +4 -0
- package/lib/components/multi-property-toggler/style/material.scss +4 -0
- package/lib/components/tile-renderer/style/_layout.scss +90 -0
- package/lib/components/tile-renderer/style/_material-definition.scss +0 -0
- package/lib/components/tile-renderer/style/_theme.scss +4 -0
- package/lib/components/tile-renderer/style/material.scss +4 -0
- package/lib/components/tile-renderer/tile-render.component.d.ts +31 -0
- package/lib/components/tile-renderer/tile-render.module.d.ts +2 -0
- package/lib/decorator/input-boolean.decorator.d.ts +8 -0
- package/lib/enum/document-email-report.enum.d.ts +15 -0
- package/lib/enum/domain-multiple-name.enum.d.ts +10 -0
- package/lib/enum/file-type.d.ts +7 -0
- package/lib/enum/files-upload-config-objects.d.ts +22 -0
- package/lib/enum/icon.enum.d.ts +6 -0
- package/lib/enum/internal-param.enum.d.ts +34 -0
- package/lib/enum/read-write-access-config-names.enum.d.ts +4 -0
- package/lib/enum/table-name.enum.d.ts +84 -0
- package/lib/enum/tag-category.enum.d.ts +19 -0
- package/lib/enum/tags-component-config-names.d.ts +4 -0
- package/lib/enum/tile-size-type.d.ts +4 -0
- package/lib/event/co-drag-event.d.ts +5 -0
- package/lib/event/co-drop-event.d.ts +8 -0
- package/lib/interface/key-value-pair.d.ts +4 -0
- package/lib/interface/operation-callback-simple-function.d.ts +4 -0
- package/lib/model/tag-tree-item.bo.d.ts +18 -0
- package/lib/model/tree-object.d.ts +8 -0
- package/lib/pipe/file-type-image.pipe.d.ts +12 -0
- package/lib/service/drag-drop.service.d.ts +86 -0
- package/lib/service/shared-connector.service.d.ts +2 -0
- package/lib/style/_variables.scss +1 -1
- package/lib/utils/array-utils.d.ts +63 -0
- package/lib/utils/check-precision-and-scale-result.d.ts +4 -0
- package/lib/utils/check-within-stepped-bounds-result.d.ts +8 -0
- package/lib/utils/co-document-shared-field-logic.d.ts +7 -0
- package/lib/utils/enum-utils.d.ts +31 -0
- package/lib/utils/is-nill.function.d.ts +1 -0
- package/lib/utils/number-utils.d.ts +125 -0
- package/lib/utils/object-utils.d.ts +40 -0
- package/lib/utils/ref-code-utils.d.ts +10 -0
- package/lib/utils/string-utils.d.ts +16 -0
- package/package.json +1 -1
- package/public-api.d.ts +4 -0
|
@@ -0,0 +1,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=
|