@colijnit/sharedcomponents 254.1.6 → 254.1.8
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 +35 -28
- package/bundles/colijnit-sharedcomponents.umd.js.map +1 -1
- package/colijnit-sharedcomponents.metadata.json +1 -1
- package/esm2015/lib/components/activity-list/activity-list.component.js +15 -11
- package/esm2015/lib/components/file-upload/file-upload.component.js +9 -8
- package/fesm2015/colijnit-sharedcomponents.js +21 -17
- package/fesm2015/colijnit-sharedcomponents.js.map +1 -1
- package/index.html +2 -2
- package/lib/components/activity-list/style/_layout.scss +30 -5
- package/lib/components/file-upload/file-upload.component.d.ts +3 -1
- package/lib/style/_variables.scss +1 -1
- package/{main.a153b9974c5f3e2988db.js → main.c58564f9965eba887216.js} +1 -1
- package/package.json +2 -2
- package/{styles.ba4c8c9a3a37cb1c0c3a.css → styles.089aaa872e2614a9b432.css} +1 -1
|
@@ -111,23 +111,27 @@ ActivityListComponent.decorators = [
|
|
|
111
111
|
<span *ngIf="activity.activityType === ActivityType.StateChange">{{activity.activityTitle}}</span>
|
|
112
112
|
</div>
|
|
113
113
|
<div class="activity-display-footer">
|
|
114
|
-
|
|
115
|
-
|
|
114
|
+
<div class="activity-fired-triggers" *ngIf="activity.activityType === ActivityType.StateChange && activity.stateChange.firedTriggerNames &&
|
|
115
|
+
activity.stateChange.firedTriggerNames.length > 0" >
|
|
116
|
+
<div class="activity-fired-trigger" *ngFor="let triggerName of activity.stateChange?.firedTriggerNames">
|
|
117
|
+
<span>{{triggerName}}</span>
|
|
118
|
+
</div>
|
|
119
|
+
</div>
|
|
120
|
+
<div class="icon-indicators">
|
|
121
|
+
<co-icon *ngIf="showAttachments(activity)" [iconData]="iconCacheService.getIcon(Icon.PaperclipRegular)" (click)="openActivityPopup(activity)"></co-icon>
|
|
116
122
|
<span *ngIf="showAttachments(activity)">{{activity.documents.length}}</span>
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
<span *ngIf="showWorkedTime(activity)" >
|
|
123
|
-
{{TimeUtils.ConvertToDuration(getWorkedTime(activity))}}</span>
|
|
123
|
+
<co-icon *ngIf="showWorkedTime(activity)"
|
|
124
|
+
[iconData]="iconCacheService.getIcon(Icon.ClockRegular)"></co-icon>
|
|
125
|
+
<span *ngIf="showWorkedTime(activity)" >
|
|
126
|
+
{{TimeUtils.ConvertToDuration(getWorkedTime(activity))}}</span>
|
|
127
|
+
</div>
|
|
124
128
|
</div>
|
|
125
129
|
</div>
|
|
126
130
|
</div>
|
|
127
131
|
</div>
|
|
128
132
|
</div>
|
|
129
133
|
<co-dialog *ngIf="showActivityPopup" (closeClick)="showActivityPopup = false">
|
|
130
|
-
<co-files-upload [documents]="currentActivityDocuments">
|
|
134
|
+
<co-files-upload [readonly]="true" [documents]="currentActivityDocuments">
|
|
131
135
|
</co-files-upload>
|
|
132
136
|
</co-dialog>
|
|
133
137
|
`,
|
|
@@ -146,4 +150,4 @@ ActivityListComponent.propDecorators = {
|
|
|
146
150
|
statusIcon: [{ type: Input }],
|
|
147
151
|
taskIcon: [{ type: Input }]
|
|
148
152
|
};
|
|
149
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity-list.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/activity-list/activity-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  HostBinding,\r\n  Input,\r\n  OnInit,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {Icon} from \"../../enum/icon.enum\";\r\nimport {RelationKind} from \"@colijnit/articleapi/build/enum/relation-kind.enum\";\r\nimport {Activity} from \"@colijnit/mainapi/build/model/activity.bo\";\r\nimport {ActivityType} from \"@colijnit/mainapi/build/enum/activity-type\";\r\nimport {IconCacheService} from \"../../service/icon-cache.service\";\r\nimport {ALL_MONTHS} from \"../../model/constant/all-months\";\r\nimport {DictionaryService} from \"../../service/dictionary.service\";\r\nimport {TimeUtils} from \"@colijnit/mainapi/build/utils/time-utils\";\r\nimport {RelationSmallObject} from \"@colijnit/mainapi/build/model/relation-small-object.bo\";\r\nimport {CoDocument} from \"@colijnit/mainapi/build/model/co-document\";\r\n\r\n@Component({\r\n  selector: \"co-activity-list\",\r\n  template: `\r\n    <div class=\"activity-list-wrapper\">\r\n      <div class=\"activity-wrapper\" [class.customer-reply-wrapper]=\"(getRelationKind(activity.author) === RelationKind.Customer)\" *ngFor=\"let activity of activities\" >\r\n        <div class=\"activity-display\">\r\n          <div class=\"activity-display-title\">\r\n            <span>{{activity.author && (activity.author.initials || activity.author.familyName) ? (activity.author.initials || '') + ' ' + (activity.author.familyName || '') : ''}}</span>\r\n            <span>{{getDateString(activity.lastActionDateTime)}}</span>\r\n            <co-icon [iconData]=\"iconCacheService.getIcon(getActivityIcon(activity))\"></co-icon>\r\n          </div>\r\n          <div class=\"activity-display-content\" [class.customer-reply-content]=\"(getRelationKind(activity.author) === RelationKind.Customer)\">\r\n            <div class=\"activity-display-body\">\r\n              <span *ngIf=\"activity.activityType !== ActivityType.StateChange\">{{activity.subDescription}}</span>\r\n              <span *ngIf=\"activity.activityType === ActivityType.StateChange\">{{activity.activityTitle}}</span>\r\n            </div>\r\n            <div class=\"activity-display-footer\">\r\n              <!--TODO discuss with Rob is we can gather the info needed to see which workflow triggers have previously been activated for this trigger-->\r\n              <!--<div *ngIf=\"showState(activity)\" class=\"activity-state\">\r\n                <span *ngIf=\"showAttachments(activity)\">{{activity.documents.length}}</span>\r\n              </div>-->\r\n              <co-icon *ngIf=\"showAttachments(activity)\" [iconData]=\"iconCacheService.getIcon(Icon.PaperclipRegular)\" (click)=\"openActivityPopup(activity)\"></co-icon>\r\n              <span *ngIf=\"showAttachments(activity)\">{{activity.documents.length}}</span>\r\n              <co-icon *ngIf=\"showWorkedTime(activity)\"\r\n                       [iconData]=\"iconCacheService.getIcon(Icon.ClockRegular)\"></co-icon>\r\n              <span *ngIf=\"showWorkedTime(activity)\" >\r\n                     {{TimeUtils.ConvertToDuration(getWorkedTime(activity))}}</span>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <co-dialog *ngIf=\"showActivityPopup\" (closeClick)=\"showActivityPopup = false\">\r\n      <co-files-upload [documents]=\"currentActivityDocuments\">\r\n      </co-files-upload>\r\n    </co-dialog>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class ActivityListComponent implements OnInit {\r\n  public readonly Icon = Icon;\r\n  public readonly RelationKind = RelationKind;\r\n  public readonly ActivityType = ActivityType;\r\n  public readonly TimeUtils = TimeUtils;\r\n\r\n  @HostBinding(\"class.co-activity-list\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  @Input()\r\n  public set activities(value: Activity[]) {\r\n    if (value && value.length > 0) {\r\n      value.sort((a: Activity, b: Activity) => a.lastActionDateTime < b.lastActionDateTime ? 1: -1);\r\n    }\r\n    this._activities = value;\r\n  }\r\n\r\n  public get activities(): Activity[] {\r\n    return this._activities;\r\n  }\r\n\r\n  @Input()\r\n  public remarkIcon: Icon = Icon.CommentRegular;\r\n\r\n  @Input()\r\n  public workIcon: Icon = Icon.PersonDiggingRegular;\r\n\r\n  @Input()\r\n  public statusIcon: Icon = Icon.DiagramProjectRegular;\r\n\r\n  @Input()\r\n  public taskIcon: Icon = Icon.Task;\r\n\r\n  public showActivityPopup: Boolean;\r\n  public currentActivityDocuments: CoDocument[];\r\n\r\n  private _activities: Activity[]\r\n\r\n  constructor(public iconCacheService: IconCacheService,\r\n              private _dictionaryService: DictionaryService\r\n  ) {\r\n  }\r\n\r\n  public async ngOnInit(): Promise<void> {\r\n  }\r\n\r\n  public getRelationKind(author: RelationSmallObject): RelationKind {\r\n    if (author) {\r\n      return author.relationType;\r\n    } else {\r\n      return null\r\n    }\r\n  }\r\n\r\n  public getDateString(date: Date): string {\r\n    const day = date.getDate();\r\n    const month = this._dictionaryService.get(ALL_MONTHS[date.getMonth()]);\r\n    const hours = date.getHours().toString().padStart(2, '0');\r\n    const minutes = date.getMinutes().toString().padStart(2, '0');\r\n    return `${day} ${month} ${hours}:${minutes}`;\r\n  }\r\n\r\n  public getActivityIcon(activity: Activity): Icon {\r\n    switch (activity.activityType) {\r\n      case ActivityType.Remark:\r\n        return this.remarkIcon;\r\n      case ActivityType.WorkflowStatus:\r\n      case ActivityType.Work:\r\n      case ActivityType.WorkflowTask:\r\n      case ActivityType.Form:\r\n        return this.workIcon;\r\n      case ActivityType.StateChange:\r\n        return this.statusIcon;\r\n      case ActivityType.Task:\r\n        return this.taskIcon;\r\n    }\r\n  }\r\n\r\n  public showAttachments(activity: Activity): boolean {\r\n    if (activity.documents && activity.documents.length > 0) {\r\n      return true\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public showWorkedTime(activity: Activity): boolean {\r\n    if ((activity.IsWork && activity.work && activity.work.workedTime) ||\r\n      (activity.IsTask && activity.task && activity.task.workedTime)) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public getWorkedTime(activity: Activity): number {\r\n    if (activity.IsWork && activity.work && activity.work.workedTime) {\r\n      return activity.work.workedTime;\r\n    } else if (activity.IsTask && activity.task && activity.task.workedTime) {\r\n      return activity.task.workedTime;\r\n    }\r\n    return 0;\r\n  }\r\n\r\n  public openActivityPopup(activity: Activity): void {\r\n    this.showActivityPopup = true;\r\n    this.currentActivityDocuments = activity.documents;\r\n  }\r\n}\r\n"]}
|
|
153
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity-list.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/activity-list/activity-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  HostBinding,\r\n  Input,\r\n  OnInit,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {Icon} from \"../../enum/icon.enum\";\r\nimport {RelationKind} from \"@colijnit/articleapi/build/enum/relation-kind.enum\";\r\nimport {Activity} from \"@colijnit/mainapi/build/model/activity.bo\";\r\nimport {ActivityType} from \"@colijnit/mainapi/build/enum/activity-type\";\r\nimport {IconCacheService} from \"../../service/icon-cache.service\";\r\nimport {ALL_MONTHS} from \"../../model/constant/all-months\";\r\nimport {DictionaryService} from \"../../service/dictionary.service\";\r\nimport {TimeUtils} from \"@colijnit/mainapi/build/utils/time-utils\";\r\nimport {RelationSmallObject} from \"@colijnit/mainapi/build/model/relation-small-object.bo\";\r\nimport {CoDocument} from \"@colijnit/mainapi/build/model/co-document\";\r\n\r\n@Component({\r\n  selector: \"co-activity-list\",\r\n  template: `\r\n    <div class=\"activity-list-wrapper\">\r\n      <div class=\"activity-wrapper\" [class.customer-reply-wrapper]=\"(getRelationKind(activity.author) === RelationKind.Customer)\" *ngFor=\"let activity of activities\" >\r\n        <div class=\"activity-display\">\r\n          <div class=\"activity-display-title\">\r\n            <span>{{activity.author && (activity.author.initials || activity.author.familyName) ? (activity.author.initials || '') + ' ' + (activity.author.familyName || '') : ''}}</span>\r\n            <span>{{getDateString(activity.lastActionDateTime)}}</span>\r\n            <co-icon [iconData]=\"iconCacheService.getIcon(getActivityIcon(activity))\"></co-icon>\r\n          </div>\r\n          <div class=\"activity-display-content\" [class.customer-reply-content]=\"(getRelationKind(activity.author) === RelationKind.Customer)\">\r\n            <div class=\"activity-display-body\">\r\n              <span *ngIf=\"activity.activityType !== ActivityType.StateChange\">{{activity.subDescription}}</span>\r\n              <span *ngIf=\"activity.activityType === ActivityType.StateChange\">{{activity.activityTitle}}</span>\r\n            </div>\r\n            <div class=\"activity-display-footer\">\r\n              <div class=\"activity-fired-triggers\" *ngIf=\"activity.activityType === ActivityType.StateChange && activity.stateChange.firedTriggerNames &&\r\n                                                                    activity.stateChange.firedTriggerNames.length > 0\" >\r\n                <div class=\"activity-fired-trigger\" *ngFor=\"let triggerName of activity.stateChange?.firedTriggerNames\">\r\n                  <span>{{triggerName}}</span>\r\n                </div>\r\n              </div>\r\n              <div class=\"icon-indicators\">\r\n                <co-icon *ngIf=\"showAttachments(activity)\" [iconData]=\"iconCacheService.getIcon(Icon.PaperclipRegular)\" (click)=\"openActivityPopup(activity)\"></co-icon>\r\n                <span *ngIf=\"showAttachments(activity)\">{{activity.documents.length}}</span>\r\n                <co-icon *ngIf=\"showWorkedTime(activity)\"\r\n                         [iconData]=\"iconCacheService.getIcon(Icon.ClockRegular)\"></co-icon>\r\n                <span *ngIf=\"showWorkedTime(activity)\" >\r\n                       {{TimeUtils.ConvertToDuration(getWorkedTime(activity))}}</span>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <co-dialog *ngIf=\"showActivityPopup\" (closeClick)=\"showActivityPopup = false\">\r\n      <co-files-upload [readonly]=\"true\"  [documents]=\"currentActivityDocuments\">\r\n      </co-files-upload>\r\n    </co-dialog>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class ActivityListComponent implements OnInit {\r\n  public readonly Icon = Icon;\r\n  public readonly RelationKind = RelationKind;\r\n  public readonly ActivityType = ActivityType;\r\n  public readonly TimeUtils = TimeUtils;\r\n\r\n  @HostBinding(\"class.co-activity-list\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  @Input()\r\n  public set activities(value: Activity[]) {\r\n    if (value && value.length > 0) {\r\n      value.sort((a: Activity, b: Activity) => a.lastActionDateTime < b.lastActionDateTime ? 1: -1);\r\n    }\r\n    this._activities = value;\r\n  }\r\n\r\n  public get activities(): Activity[] {\r\n    return this._activities;\r\n  }\r\n\r\n  @Input()\r\n  public remarkIcon: Icon = Icon.CommentRegular;\r\n\r\n  @Input()\r\n  public workIcon: Icon = Icon.PersonDiggingRegular;\r\n\r\n  @Input()\r\n  public statusIcon: Icon = Icon.DiagramProjectRegular;\r\n\r\n  @Input()\r\n  public taskIcon: Icon = Icon.Task;\r\n\r\n  public showActivityPopup: Boolean;\r\n  public currentActivityDocuments: CoDocument[];\r\n\r\n  private _activities: Activity[]\r\n\r\n  constructor(public iconCacheService: IconCacheService,\r\n              private _dictionaryService: DictionaryService\r\n  ) {\r\n  }\r\n\r\n  public async ngOnInit(): Promise<void> {\r\n  }\r\n\r\n  public getRelationKind(author: RelationSmallObject): RelationKind {\r\n    if (author) {\r\n      return author.relationType;\r\n    } else {\r\n      return null\r\n    }\r\n  }\r\n\r\n  public getDateString(date: Date): string {\r\n    const day = date.getDate();\r\n    const month = this._dictionaryService.get(ALL_MONTHS[date.getMonth()]);\r\n    const hours = date.getHours().toString().padStart(2, '0');\r\n    const minutes = date.getMinutes().toString().padStart(2, '0');\r\n    return `${day} ${month} ${hours}:${minutes}`;\r\n  }\r\n\r\n  public getActivityIcon(activity: Activity): Icon {\r\n    switch (activity.activityType) {\r\n      case ActivityType.Remark:\r\n        return this.remarkIcon;\r\n      case ActivityType.WorkflowStatus:\r\n      case ActivityType.Work:\r\n      case ActivityType.WorkflowTask:\r\n      case ActivityType.Form:\r\n        return this.workIcon;\r\n      case ActivityType.StateChange:\r\n        return this.statusIcon;\r\n      case ActivityType.Task:\r\n        return this.taskIcon;\r\n    }\r\n  }\r\n\r\n  public showAttachments(activity: Activity): boolean {\r\n    if (activity.documents && activity.documents.length > 0) {\r\n      return true\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public showWorkedTime(activity: Activity): boolean {\r\n    if ((activity.IsWork && activity.work && activity.work.workedTime) ||\r\n      (activity.IsTask && activity.task && activity.task.workedTime)) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public getWorkedTime(activity: Activity): number {\r\n    if (activity.IsWork && activity.work && activity.work.workedTime) {\r\n      return activity.work.workedTime;\r\n    } else if (activity.IsTask && activity.task && activity.task.workedTime) {\r\n      return activity.task.workedTime;\r\n    }\r\n    return 0;\r\n  }\r\n\r\n  public openActivityPopup(activity: Activity): void {\r\n    this.showActivityPopup = true;\r\n    this.currentActivityDocuments = activity.documents;\r\n  }\r\n}\r\n"]}
|
|
@@ -5,12 +5,14 @@ import { Icon } from "../../enum/icon.enum";
|
|
|
5
5
|
import { InputBoolean } from "../../decorator/input-boolean.decorator";
|
|
6
6
|
import { FileTypeImagePipe } from "../../pipe/file-type-image.pipe";
|
|
7
7
|
import { IconCacheService } from "../../service/icon-cache.service";
|
|
8
|
+
import { SharedService } from "../../service/shared.service";
|
|
8
9
|
// The GUI part of the files-upload component. Not a standalone component.
|
|
9
10
|
export class FileUploadComponent {
|
|
10
|
-
constructor(_promptService, _fileTypeImgPipe, iconService) {
|
|
11
|
+
constructor(_promptService, _fileTypeImgPipe, iconService, _sharedService) {
|
|
11
12
|
this._promptService = _promptService;
|
|
12
13
|
this._fileTypeImgPipe = _fileTypeImgPipe;
|
|
13
14
|
this.iconService = iconService;
|
|
15
|
+
this._sharedService = _sharedService;
|
|
14
16
|
this.icons = Icon;
|
|
15
17
|
// Element clickable
|
|
16
18
|
this.link = false;
|
|
@@ -76,10 +78,9 @@ export class FileUploadComponent {
|
|
|
76
78
|
this.imageClick.next(this._file);
|
|
77
79
|
return;
|
|
78
80
|
}
|
|
79
|
-
//todo fix methods
|
|
80
81
|
//first download document body if it is stored in a private cdn directory
|
|
81
82
|
if (!this._file.documentBody) {
|
|
82
|
-
|
|
83
|
+
yield this._sharedService.getDocumentContent(this._file.documentId).then(documentBody => this._file.documentBody = documentBody);
|
|
83
84
|
}
|
|
84
85
|
if (this._file.isImageDocument()) { //preview image
|
|
85
86
|
this._promptService.showImage(this.file.documentBodyAsDataUri, "Preview");
|
|
@@ -126,9 +127,8 @@ export class FileUploadComponent {
|
|
|
126
127
|
if (this._file.isImageDocument()) {
|
|
127
128
|
this.previewImage = this._file.documentBodyAsDataUri;
|
|
128
129
|
if (this.previewImage === "") {
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
//this.previewImage = this._file.documentBody;
|
|
130
|
+
this._sharedService.getDocumentContent(this._file.documentId).then(documentBody => this._file.documentBody = documentBody);
|
|
131
|
+
this.previewImage = this._file.documentBody;
|
|
132
132
|
}
|
|
133
133
|
}
|
|
134
134
|
else {
|
|
@@ -156,7 +156,8 @@ FileUploadComponent.decorators = [
|
|
|
156
156
|
FileUploadComponent.ctorParameters = () => [
|
|
157
157
|
{ type: PromptService },
|
|
158
158
|
{ type: FileTypeImagePipe },
|
|
159
|
-
{ type: IconCacheService }
|
|
159
|
+
{ type: IconCacheService },
|
|
160
|
+
{ type: SharedService }
|
|
160
161
|
];
|
|
161
162
|
FileUploadComponent.propDecorators = {
|
|
162
163
|
form: [{ type: ViewChild, args: [FormComponent,] }],
|
|
@@ -186,4 +187,4 @@ __decorate([
|
|
|
186
187
|
__decorate([
|
|
187
188
|
InputBoolean()
|
|
188
189
|
], 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"]}
|
|
190
|
+
//# 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\nimport {SharedService} from \"../../service/shared.service\";\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 _sharedService: SharedService\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        //first download document body if it is stored in a private cdn directory\r\n        if (!this._file.documentBody) {\r\n            await this._sharedService.getDocumentContent(this._file.documentId).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                    this._sharedService.getDocumentContent(this._file.documentId).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"]}
|
|
@@ -10842,10 +10842,11 @@ ImageDisplayModule.decorators = [
|
|
|
10842
10842
|
|
|
10843
10843
|
// The GUI part of the files-upload component. Not a standalone component.
|
|
10844
10844
|
class FileUploadComponent {
|
|
10845
|
-
constructor(_promptService, _fileTypeImgPipe, iconService) {
|
|
10845
|
+
constructor(_promptService, _fileTypeImgPipe, iconService, _sharedService) {
|
|
10846
10846
|
this._promptService = _promptService;
|
|
10847
10847
|
this._fileTypeImgPipe = _fileTypeImgPipe;
|
|
10848
10848
|
this.iconService = iconService;
|
|
10849
|
+
this._sharedService = _sharedService;
|
|
10849
10850
|
this.icons = Icon;
|
|
10850
10851
|
// Element clickable
|
|
10851
10852
|
this.link = false;
|
|
@@ -10911,10 +10912,9 @@ class FileUploadComponent {
|
|
|
10911
10912
|
this.imageClick.next(this._file);
|
|
10912
10913
|
return;
|
|
10913
10914
|
}
|
|
10914
|
-
//todo fix methods
|
|
10915
10915
|
//first download document body if it is stored in a private cdn directory
|
|
10916
10916
|
if (!this._file.documentBody) {
|
|
10917
|
-
|
|
10917
|
+
yield this._sharedService.getDocumentContent(this._file.documentId).then(documentBody => this._file.documentBody = documentBody);
|
|
10918
10918
|
}
|
|
10919
10919
|
if (this._file.isImageDocument()) { //preview image
|
|
10920
10920
|
this._promptService.showImage(this.file.documentBodyAsDataUri, "Preview");
|
|
@@ -10961,9 +10961,8 @@ class FileUploadComponent {
|
|
|
10961
10961
|
if (this._file.isImageDocument()) {
|
|
10962
10962
|
this.previewImage = this._file.documentBodyAsDataUri;
|
|
10963
10963
|
if (this.previewImage === "") {
|
|
10964
|
-
|
|
10965
|
-
|
|
10966
|
-
//this.previewImage = this._file.documentBody;
|
|
10964
|
+
this._sharedService.getDocumentContent(this._file.documentId).then(documentBody => this._file.documentBody = documentBody);
|
|
10965
|
+
this.previewImage = this._file.documentBody;
|
|
10967
10966
|
}
|
|
10968
10967
|
}
|
|
10969
10968
|
else {
|
|
@@ -10991,7 +10990,8 @@ FileUploadComponent.decorators = [
|
|
|
10991
10990
|
FileUploadComponent.ctorParameters = () => [
|
|
10992
10991
|
{ type: PromptService },
|
|
10993
10992
|
{ type: FileTypeImagePipe },
|
|
10994
|
-
{ type: IconCacheService }
|
|
10993
|
+
{ type: IconCacheService },
|
|
10994
|
+
{ type: SharedService }
|
|
10995
10995
|
];
|
|
10996
10996
|
FileUploadComponent.propDecorators = {
|
|
10997
10997
|
form: [{ type: ViewChild, args: [FormComponent,] }],
|
|
@@ -11553,23 +11553,27 @@ ActivityListComponent.decorators = [
|
|
|
11553
11553
|
<span *ngIf="activity.activityType === ActivityType.StateChange">{{activity.activityTitle}}</span>
|
|
11554
11554
|
</div>
|
|
11555
11555
|
<div class="activity-display-footer">
|
|
11556
|
-
|
|
11557
|
-
|
|
11556
|
+
<div class="activity-fired-triggers" *ngIf="activity.activityType === ActivityType.StateChange && activity.stateChange.firedTriggerNames &&
|
|
11557
|
+
activity.stateChange.firedTriggerNames.length > 0" >
|
|
11558
|
+
<div class="activity-fired-trigger" *ngFor="let triggerName of activity.stateChange?.firedTriggerNames">
|
|
11559
|
+
<span>{{triggerName}}</span>
|
|
11560
|
+
</div>
|
|
11561
|
+
</div>
|
|
11562
|
+
<div class="icon-indicators">
|
|
11563
|
+
<co-icon *ngIf="showAttachments(activity)" [iconData]="iconCacheService.getIcon(Icon.PaperclipRegular)" (click)="openActivityPopup(activity)"></co-icon>
|
|
11558
11564
|
<span *ngIf="showAttachments(activity)">{{activity.documents.length}}</span>
|
|
11559
|
-
|
|
11560
|
-
|
|
11561
|
-
|
|
11562
|
-
|
|
11563
|
-
|
|
11564
|
-
<span *ngIf="showWorkedTime(activity)" >
|
|
11565
|
-
{{TimeUtils.ConvertToDuration(getWorkedTime(activity))}}</span>
|
|
11565
|
+
<co-icon *ngIf="showWorkedTime(activity)"
|
|
11566
|
+
[iconData]="iconCacheService.getIcon(Icon.ClockRegular)"></co-icon>
|
|
11567
|
+
<span *ngIf="showWorkedTime(activity)" >
|
|
11568
|
+
{{TimeUtils.ConvertToDuration(getWorkedTime(activity))}}</span>
|
|
11569
|
+
</div>
|
|
11566
11570
|
</div>
|
|
11567
11571
|
</div>
|
|
11568
11572
|
</div>
|
|
11569
11573
|
</div>
|
|
11570
11574
|
</div>
|
|
11571
11575
|
<co-dialog *ngIf="showActivityPopup" (closeClick)="showActivityPopup = false">
|
|
11572
|
-
<co-files-upload [documents]="currentActivityDocuments">
|
|
11576
|
+
<co-files-upload [readonly]="true" [documents]="currentActivityDocuments">
|
|
11573
11577
|
</co-files-upload>
|
|
11574
11578
|
</co-dialog>
|
|
11575
11579
|
`,
|