nuxeo-development-framework 2.0.8 → 3.0.0
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/nuxeo-development-framework.umd.js +8335 -455
- package/bundles/nuxeo-development-framework.umd.js.map +1 -1
- package/esm2015/lib/components/activities-log/activities-log/activities-log.component.js +84 -0
- package/esm2015/lib/components/activities-log/activities-log/activities-log.service.js +35 -0
- package/esm2015/lib/components/activities-log/activities-log.module.js +30 -0
- package/esm2015/lib/components/attachment-item/attachment-item/attachment-item.component.js +54 -0
- package/esm2015/lib/components/attachment-item/attachment-item.module.js +44 -0
- package/esm2015/lib/components/attachment-modal/attachment-modal.module.js +40 -0
- package/esm2015/lib/components/attachment-modal/attachments/attachments.component.js +157 -0
- package/esm2015/lib/components/confirmation-dialog/confirmation-dialog/confirmation-dialog.component.js +30 -0
- package/esm2015/lib/components/confirmation-dialog/confirmation-dialog.module.js +30 -0
- package/esm2015/lib/components/display-suitable-icon/display-suitable-icon/display-suitable-icon.component.js +44 -0
- package/esm2015/lib/components/display-suitable-icon/display-suitable-icon/icon.service.js +140 -0
- package/esm2015/lib/components/display-suitable-icon/display-suitable-icon.module.js +24 -0
- package/esm2015/lib/components/dynamic-fields-renderer/dynamic-fields-renderer/dynamic-fields-renderer.component.js +177 -0
- package/esm2015/lib/components/dynamic-fields-renderer/dynamic-fields-renderer.module.js +43 -0
- package/esm2015/lib/components/dynamic-tabs/dynamic-tabs/dynamic-tabs.component.js +39 -0
- package/esm2015/lib/components/dynamic-tabs/dynamic-tabs.module.js +34 -0
- package/esm2015/lib/components/file-manger/components/add-to-collection/add-to-collection.component.js +132 -0
- package/esm2015/lib/components/file-manger/components/copy/copy.component.js +119 -0
- package/esm2015/lib/components/file-manger/components/create-directory/create-directory.component.js +91 -0
- package/esm2015/lib/components/file-manger/components/create-modal/create-modal.component.js +455 -0
- package/esm2015/lib/components/file-manger/components/creation-type/creation-type.component.js +26 -0
- package/esm2015/lib/components/file-manger/components/delete/delete.component.js +77 -0
- package/esm2015/lib/components/file-manger/components/folder-modal/folder-modal.component.js +114 -0
- package/esm2015/lib/components/file-manger/components/loan-request/loan-request.component.js +80 -0
- package/esm2015/lib/components/file-manger/components/move/move.component.js +108 -0
- package/esm2015/lib/components/file-manger/components/publish-dialog/publish-dialog.component.js +111 -0
- package/esm2015/lib/components/file-manger/components/rename/rename.component.js +86 -0
- package/esm2015/lib/components/file-manger/components/scan-modal/scan-modal.component.js +313 -0
- package/esm2015/lib/components/file-manger/components/share-dialog/share-dialog.component.js +294 -0
- package/esm2015/lib/components/file-manger/components/sidepanel/sidepanel.component.js +256 -0
- package/esm2015/lib/components/file-manger/components/template-modal/template-modal.component.js +64 -0
- package/esm2015/lib/components/file-manger/components/transfer-doc/transfer-doc.component.js +71 -0
- package/esm2015/lib/components/file-manger/components/update-modal/update-modal.component.js +358 -0
- package/esm2015/lib/components/file-manger/file-manager.abstract.js +1004 -0
- package/esm2015/lib/components/file-manger/file-manger.module.js +275 -0
- package/esm2015/lib/components/hijri-gregorian-datepicker/hijri-gregorian-datepicker/hijri-datepicker/hijri-datepicker.component.js +8 -2
- package/esm2015/lib/components/hijri-gregorian-datepicker/utils/IslamicI18n.js +2 -2
- package/esm2015/lib/components/mutiple-dynamic-form-viewer/multiple-dynamic-form-viewer/multiple-dynamic-form-viewer.component.js +51 -0
- package/esm2015/lib/components/mutiple-dynamic-form-viewer/mutiple-dynamic-form-viewer.module.js +30 -0
- package/esm2015/lib/components/permissions/add-permissions-dialog/add-permissions-dialog.component.js +177 -0
- package/esm2015/lib/components/permissions/permission.service.js +118 -0
- package/esm2015/lib/components/permissions/permissions/permissions.component.js +232 -0
- package/esm2015/lib/components/permissions/permissions-template/permissions-template.component.js +117 -0
- package/esm2015/lib/components/permissions/permissions.module.js +71 -0
- package/esm2015/lib/components/select-users-by-department/select-users-by-department.module.js +47 -0
- package/esm2015/lib/components/select-users-by-department/select-users-by-departments/department-management.service.js +27 -0
- package/esm2015/lib/components/select-users-by-department/select-users-by-departments/select-users-by-departments.component.js +116 -0
- package/esm2015/lib/components/user/user/user.component.js +29 -0
- package/esm2015/lib/components/user/user.module.js +30 -0
- package/esm2015/lib/directive/directive.module.js +9 -4
- package/esm2015/lib/directive/drag-and-drop/drag-and-drop.directive.js +46 -0
- package/esm2015/lib/shared/libraryShared.module.js +1 -4
- package/esm2015/lib/shared-services/dialog-mangment.service.js +61 -0
- package/esm2015/lib/shared-services/dynamic-form.service.js +241 -0
- package/esm2015/lib/shared-services/file-manager.adapter.js +74 -0
- package/esm2015/lib/shared-services/file-manager.service.js +741 -0
- package/esm2015/lib/shared-services/global-pdftron.service.js +46 -0
- package/esm2015/lib/shared-services/mainfolder.service.js +157 -0
- package/esm2015/lib/shared-services/publishing-document.service.js +202 -0
- package/esm2015/lib/shared-services/recently-viewed.service.js +57 -0
- package/esm2015/lib/shared-services/shared-docs.service.js +135 -0
- package/esm2015/lib/shared-services/shared-services.module.js +20 -0
- package/esm2015/lib/shared-services/upload-file.service.js +29 -0
- package/esm2015/lib/shared-services/upload-managment.service.js +151 -0
- package/esm2015/lib/shared-services/user.service.js +54 -0
- package/esm2015/public-api.js +64 -1
- package/fesm2015/nuxeo-development-framework.js +7628 -154
- package/fesm2015/nuxeo-development-framework.js.map +1 -1
- package/lib/components/activities-log/activities-log/activities-log.component.d.ts +23 -0
- package/lib/components/activities-log/activities-log/activities-log.service.d.ts +9 -0
- package/lib/components/activities-log/activities-log.module.d.ts +10 -0
- package/lib/components/attachment-item/attachment-item/attachment-item.component.d.ts +21 -0
- package/lib/components/attachment-item/attachment-item.module.d.ts +13 -0
- package/lib/components/attachment-modal/attachment-modal.module.d.ts +12 -0
- package/lib/components/attachment-modal/attachments/attachments.component.d.ts +50 -0
- package/lib/components/confirmation-dialog/confirmation-dialog/confirmation-dialog.component.d.ts +12 -0
- package/lib/components/confirmation-dialog/confirmation-dialog.module.d.ts +10 -0
- package/lib/components/display-suitable-icon/display-suitable-icon/display-suitable-icon.component.d.ts +17 -0
- package/lib/components/display-suitable-icon/display-suitable-icon/icon.service.d.ts +8 -0
- package/lib/components/display-suitable-icon/display-suitable-icon.module.d.ts +8 -0
- package/lib/components/dynamic-fields-renderer/dynamic-fields-renderer/dynamic-fields-renderer.component.d.ts +137 -0
- package/lib/components/dynamic-fields-renderer/dynamic-fields-renderer.module.d.ts +12 -0
- package/lib/components/dynamic-tabs/dynamic-tabs/dynamic-tabs.component.d.ts +13 -0
- package/lib/components/dynamic-tabs/dynamic-tabs.module.d.ts +11 -0
- package/lib/components/file-manger/components/add-to-collection/add-to-collection.component.d.ts +31 -0
- package/lib/components/file-manger/components/copy/copy.component.d.ts +32 -0
- package/lib/components/file-manger/components/create-directory/create-directory.component.d.ts +24 -0
- package/lib/components/file-manger/components/create-modal/create-modal.component.d.ts +108 -0
- package/lib/components/file-manger/components/creation-type/creation-type.component.d.ts +11 -0
- package/lib/components/file-manger/components/delete/delete.component.d.ts +30 -0
- package/lib/components/file-manger/components/folder-modal/folder-modal.component.d.ts +56 -0
- package/lib/components/file-manger/components/loan-request/loan-request.component.d.ts +23 -0
- package/lib/components/file-manger/components/move/move.component.d.ts +32 -0
- package/lib/components/file-manger/components/publish-dialog/publish-dialog.component.d.ts +32 -0
- package/lib/components/file-manger/components/rename/rename.component.d.ts +25 -0
- package/lib/components/file-manger/components/scan-modal/scan-modal.component.d.ts +95 -0
- package/lib/components/file-manger/components/share-dialog/share-dialog.component.d.ts +58 -0
- package/lib/components/file-manger/components/sidepanel/sidepanel.component.d.ts +62 -0
- package/lib/components/file-manger/components/template-modal/template-modal.component.d.ts +34 -0
- package/lib/components/file-manger/components/transfer-doc/transfer-doc.component.d.ts +24 -0
- package/lib/components/file-manger/components/update-modal/update-modal.component.d.ts +194 -0
- package/lib/components/file-manger/file-manager.abstract.d.ts +169 -0
- package/lib/components/file-manger/file-manger.module.d.ts +55 -0
- package/lib/components/hijri-gregorian-datepicker/hijri-gregorian-datepicker/hijri-datepicker/hijri-datepicker.component.d.ts +2 -0
- package/lib/components/mutiple-dynamic-form-viewer/multiple-dynamic-form-viewer/multiple-dynamic-form-viewer.component.d.ts +17 -0
- package/lib/components/mutiple-dynamic-form-viewer/mutiple-dynamic-form-viewer.module.d.ts +10 -0
- package/lib/components/permissions/add-permissions-dialog/add-permissions-dialog.component.d.ts +44 -0
- package/lib/components/permissions/permission.service.d.ts +21 -0
- package/lib/components/permissions/permissions/permissions.component.d.ts +48 -0
- package/lib/components/permissions/permissions-template/permissions-template.component.d.ts +22 -0
- package/lib/components/permissions/permissions.module.d.ts +21 -0
- package/lib/components/select-users-by-department/select-users-by-department.module.d.ts +13 -0
- package/lib/components/select-users-by-department/select-users-by-departments/department-management.service.d.ts +10 -0
- package/lib/components/select-users-by-department/select-users-by-departments/select-users-by-departments.component.d.ts +33 -0
- package/lib/components/user/user/user.component.d.ts +12 -0
- package/lib/components/user/user.module.d.ts +10 -0
- package/lib/directive/directive.module.d.ts +3 -2
- package/lib/directive/drag-and-drop/drag-and-drop.directive.d.ts +11 -0
- package/lib/shared/libraryShared.module.d.ts +1 -1
- package/lib/shared-services/dialog-mangment.service.d.ts +15 -0
- package/lib/shared-services/dynamic-form.service.d.ts +24 -0
- package/lib/shared-services/file-manager.adapter.d.ts +48 -0
- package/lib/shared-services/file-manager.service.d.ts +89 -0
- package/lib/shared-services/global-pdftron.service.d.ts +10 -0
- package/lib/shared-services/mainfolder.service.d.ts +29 -0
- package/lib/shared-services/publishing-document.service.d.ts +25 -0
- package/lib/shared-services/recently-viewed.service.d.ts +17 -0
- package/lib/shared-services/shared-docs.service.d.ts +21 -0
- package/lib/shared-services/shared-services.module.d.ts +7 -0
- package/lib/shared-services/upload-file.service.d.ts +10 -0
- package/lib/shared-services/upload-managment.service.d.ts +72 -0
- package/lib/shared-services/user.service.d.ts +12 -0
- package/package.json +7 -6
- package/public-api.d.ts +61 -0
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "./activities-log.service";
|
|
4
|
+
import * as i2 from "../../../configuration/app-config.service";
|
|
5
|
+
import * as i3 from "@angular/material/progress-bar";
|
|
6
|
+
import * as i4 from "../../latest-activity/components/single-activity/single-activity.component";
|
|
7
|
+
import * as i5 from "@angular/common";
|
|
8
|
+
export class ActivitiesLogComponent {
|
|
9
|
+
constructor(activitiesLogService, myConfigService) {
|
|
10
|
+
this.activitiesLogService = activitiesLogService;
|
|
11
|
+
this.myConfigService = myConfigService;
|
|
12
|
+
this.success = new EventEmitter();
|
|
13
|
+
this.p = 1;
|
|
14
|
+
this.count = 100;
|
|
15
|
+
this.isFetching = false;
|
|
16
|
+
this.activitylog = [];
|
|
17
|
+
}
|
|
18
|
+
ngOnInit() {
|
|
19
|
+
}
|
|
20
|
+
ngOnChanges(changes) {
|
|
21
|
+
this.activitylog = []; // rest for log befor getting activities again
|
|
22
|
+
this.getActivities();
|
|
23
|
+
}
|
|
24
|
+
getActivities() {
|
|
25
|
+
this.isFetching = true;
|
|
26
|
+
this.activitiesLogService.getLogs(this.documentId, this.p - 1, this.count)
|
|
27
|
+
.subscribe((res) => {
|
|
28
|
+
//console.log(res);
|
|
29
|
+
res.entries.filter(f => !this.myConfigService.myConfiguration.logs.excludedStates.includes(f.eventId))
|
|
30
|
+
.map(item => {
|
|
31
|
+
this.activitylog.push(
|
|
32
|
+
// {
|
|
33
|
+
// documentLifecycle : 'registered', //'doclifecycle'
|
|
34
|
+
// eventName:'incoming_register', //eventId
|
|
35
|
+
// eventDate: '2021-09-27T10:42:38.000Z', // eventDate
|
|
36
|
+
// creator:{
|
|
37
|
+
// properties : {
|
|
38
|
+
// firstName: "Cts",
|
|
39
|
+
// lastName: "Sec"
|
|
40
|
+
// }
|
|
41
|
+
// },
|
|
42
|
+
// documentName:'edge incoming 4 ' // pass from outside
|
|
43
|
+
// }
|
|
44
|
+
{
|
|
45
|
+
documentLifecycle: item.docLifeCycle,
|
|
46
|
+
eventName: item.eventId,
|
|
47
|
+
eventDate: item.eventDate,
|
|
48
|
+
creator: {
|
|
49
|
+
properties: {
|
|
50
|
+
firstName: item.principalName,
|
|
51
|
+
lastName: ''
|
|
52
|
+
}
|
|
53
|
+
},
|
|
54
|
+
documentName: this.documentTitle
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
this.isFetching = false;
|
|
58
|
+
this.success.emit(true);
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
onScroll() {
|
|
62
|
+
this.p++;
|
|
63
|
+
this.getActivities();
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
ActivitiesLogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: ActivitiesLogComponent, deps: [{ token: i1.ActivitiesLogService }, { token: i2.AppConfigService }], target: i0.ɵɵFactoryTarget.Component });
|
|
67
|
+
ActivitiesLogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: ActivitiesLogComponent, selector: "app-activities-log", inputs: { documentId: "documentId", file: "file", documentTitle: "documentTitle" }, outputs: { success: "success" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"viewer-loader pb-2\">\r\n <mat-progress-bar *ngIf=\"isFetching\" mode=\"indeterminate\"></mat-progress-bar>\r\n</div>\r\n<div class=\"activity-body\">\r\n <div class=\"activity-area\">\r\n <div *ngFor=\"let item of activitylog; let i = index\">\r\n <cts-single-activity [item]=\"item\" [documentTitle]=\"documentTitle\">\r\n </cts-single-activity>\r\n </div>\r\n </div>\r\n</div>", styles: [".activity-body{padding:14px 10px;overflow:auto;height:100%;overflow-x:hidden}.activity-body .activity-area{padding-inline-start:20px;padding-inline-end:12px;border-inline-start:2px solid #d9dce2}\n"], components: [{ type: i3.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "mode", "value", "bufferValue"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { type: i4.SingleActivityComponent, selector: "cts-single-activity", inputs: ["item", "documentTitle"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
68
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: ActivitiesLogComponent, decorators: [{
|
|
69
|
+
type: Component,
|
|
70
|
+
args: [{
|
|
71
|
+
selector: 'app-activities-log',
|
|
72
|
+
templateUrl: './activities-log.component.html',
|
|
73
|
+
styleUrls: ['./activities-log.component.scss']
|
|
74
|
+
}]
|
|
75
|
+
}], ctorParameters: function () { return [{ type: i1.ActivitiesLogService }, { type: i2.AppConfigService }]; }, propDecorators: { documentId: [{
|
|
76
|
+
type: Input
|
|
77
|
+
}], file: [{
|
|
78
|
+
type: Input
|
|
79
|
+
}], documentTitle: [{
|
|
80
|
+
type: Input
|
|
81
|
+
}], success: [{
|
|
82
|
+
type: Output
|
|
83
|
+
}] } });
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aXZpdGllcy1sb2cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9hY3Rpdml0aWVzLWxvZy9hY3Rpdml0aWVzLWxvZy9hY3Rpdml0aWVzLWxvZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL2FjdGl2aXRpZXMtbG9nL2FjdGl2aXRpZXMtbG9nL2FjdGl2aXRpZXMtbG9nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQWlCLE1BQU0sZUFBZSxDQUFDOzs7Ozs7O0FBUzlGLE1BQU0sT0FBTyxzQkFBc0I7SUFhakMsWUFBb0Isb0JBQTJDLEVBQVUsZUFBaUM7UUFBdEYseUJBQW9CLEdBQXBCLG9CQUFvQixDQUF1QjtRQUFVLG9CQUFlLEdBQWYsZUFBZSxDQUFrQjtRQU4xRyxZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUU3QixNQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ04sVUFBSyxHQUFHLEdBQUcsQ0FBQztRQUNaLGVBQVUsR0FBRyxLQUFLLENBQUM7UUFDbkIsZ0JBQVcsR0FBRyxFQUFFLENBQUM7SUFDNkYsQ0FBQztJQUUvRyxRQUFRO0lBQ1IsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLENBQUMsV0FBVyxHQUFHLEVBQUUsQ0FBQyxDQUFDLDhDQUE4QztRQUNyRSxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUVELGFBQWE7UUFDWCxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztRQUN2QixJQUFJLENBQUMsb0JBQW9CLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUMsR0FBRyxDQUFDLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQzthQUN2RSxTQUFTLENBQUMsQ0FBQyxHQUFRLEVBQUUsRUFBRTtZQUN0QixtQkFBbUI7WUFDbkIsR0FBRyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQztpQkFDckcsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFO2dCQUNWLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSTtnQkFDbkIsSUFBSTtnQkFDSix1REFBdUQ7Z0JBQ3ZELDZDQUE2QztnQkFDN0Msd0RBQXdEO2dCQUN4RCxjQUFjO2dCQUNkLHFCQUFxQjtnQkFDckIsMEJBQTBCO2dCQUMxQix3QkFBd0I7Z0JBQ3hCLFFBQVE7Z0JBQ1IsT0FBTztnQkFDUCx5REFBeUQ7Z0JBQ3pELElBQUk7Z0JBQ0o7b0JBQ0UsaUJBQWlCLEVBQUUsSUFBSSxDQUFDLFlBQVk7b0JBQ3BDLFNBQVMsRUFBRSxJQUFJLENBQUMsT0FBTztvQkFDdkIsU0FBUyxFQUFFLElBQUksQ0FBQyxTQUFTO29CQUN6QixPQUFPLEVBQUU7d0JBQ1AsVUFBVSxFQUFFOzRCQUNWLFNBQVMsRUFBRSxJQUFJLENBQUMsYUFBYTs0QkFDN0IsUUFBUSxFQUFFLEVBQUU7eUJBQ2I7cUJBQ0Y7b0JBQ0QsWUFBWSxFQUFFLElBQUksQ0FBQyxhQUFhO2lCQUNqQyxDQUNGLENBQUM7WUFDSixDQUFDLENBQUMsQ0FBQTtZQUNGLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO1lBQ3hCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzFCLENBQUMsQ0FBQyxDQUFBO0lBQ04sQ0FBQztJQUVELFFBQVE7UUFDTixJQUFJLENBQUMsQ0FBQyxFQUFFLENBQUE7UUFDUixJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDdkIsQ0FBQzs7bUhBakVVLHNCQUFzQjt1R0FBdEIsc0JBQXNCLG9NQ1RuQyw2WkFVTTsyRkRETyxzQkFBc0I7a0JBTGxDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG9CQUFvQjtvQkFDOUIsV0FBVyxFQUFFLGlDQUFpQztvQkFDOUMsU0FBUyxFQUFFLENBQUMsaUNBQWlDLENBQUM7aUJBQy9DOzBJQUdDLFVBQVU7c0JBRFQsS0FBSztnQkFHTixJQUFJO3NCQURILEtBQUs7Z0JBRUcsYUFBYTtzQkFBckIsS0FBSztnQkFFTixPQUFPO3NCQUROLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0LCBTaW1wbGVDaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFwcENvbmZpZ1NlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9jb25maWd1cmF0aW9uL2FwcC1jb25maWcuc2VydmljZSc7XHJcbmltcG9ydCB7IEFjdGl2aXRpZXNMb2dTZXJ2aWNlIH0gZnJvbSAnLi9hY3Rpdml0aWVzLWxvZy5zZXJ2aWNlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXBwLWFjdGl2aXRpZXMtbG9nJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vYWN0aXZpdGllcy1sb2cuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2FjdGl2aXRpZXMtbG9nLmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIEFjdGl2aXRpZXNMb2dDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIEBJbnB1dCgpXHJcbiAgZG9jdW1lbnRJZDtcclxuICBASW5wdXQoKVxyXG4gIGZpbGU7XHJcbiAgQElucHV0KCkgZG9jdW1lbnRUaXRsZTtcclxuICBAT3V0cHV0KClcclxuICBzdWNjZXNzID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG5cclxuICBwID0gMTtcclxuICBjb3VudCA9IDEwMDtcclxuICBpc0ZldGNoaW5nID0gZmFsc2U7XHJcbiAgYWN0aXZpdHlsb2cgPSBbXTtcclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGFjdGl2aXRpZXNMb2dTZXJ2aWNlIDogQWN0aXZpdGllc0xvZ1NlcnZpY2UsIHByaXZhdGUgbXlDb25maWdTZXJ2aWNlOiBBcHBDb25maWdTZXJ2aWNlKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgfVxyXG5cclxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XHJcbiAgICB0aGlzLmFjdGl2aXR5bG9nID0gW107IC8vIHJlc3QgZm9yIGxvZyBiZWZvciBnZXR0aW5nIGFjdGl2aXRpZXMgYWdhaW5cclxuICAgIHRoaXMuZ2V0QWN0aXZpdGllcygpO1xyXG4gIH1cclxuXHJcbiAgZ2V0QWN0aXZpdGllcygpIHtcclxuICAgIHRoaXMuaXNGZXRjaGluZyA9IHRydWU7XHJcbiAgICB0aGlzLmFjdGl2aXRpZXNMb2dTZXJ2aWNlLmdldExvZ3ModGhpcy5kb2N1bWVudElkLCB0aGlzLnAgLSAxLCB0aGlzLmNvdW50KVxyXG4gICAgICAuc3Vic2NyaWJlKChyZXM6IGFueSkgPT4ge1xyXG4gICAgICAgIC8vY29uc29sZS5sb2cocmVzKTtcclxuICAgICAgICByZXMuZW50cmllcy5maWx0ZXIoZiA9PiAhdGhpcy5teUNvbmZpZ1NlcnZpY2UubXlDb25maWd1cmF0aW9uLmxvZ3MuZXhjbHVkZWRTdGF0ZXMuaW5jbHVkZXMoZi5ldmVudElkKSlcclxuICAgICAgICAubWFwKGl0ZW0gPT4ge1xyXG4gICAgICAgICAgdGhpcy5hY3Rpdml0eWxvZy5wdXNoKFxyXG4gICAgICAgICAgICAvLyB7XHJcbiAgICAgICAgICAgIC8vICAgZG9jdW1lbnRMaWZlY3ljbGUgOiAncmVnaXN0ZXJlZCcsIC8vJ2RvY2xpZmVjeWNsZSdcclxuICAgICAgICAgICAgLy8gICBldmVudE5hbWU6J2luY29taW5nX3JlZ2lzdGVyJywgLy9ldmVudElkXHJcbiAgICAgICAgICAgIC8vICAgZXZlbnREYXRlOiAnMjAyMS0wOS0yN1QxMDo0MjozOC4wMDBaJywgLy8gZXZlbnREYXRlXHJcbiAgICAgICAgICAgIC8vICAgY3JlYXRvcjp7XHJcbiAgICAgICAgICAgIC8vICAgICBwcm9wZXJ0aWVzIDoge1xyXG4gICAgICAgICAgICAvLyAgICAgICBmaXJzdE5hbWU6IFwiQ3RzXCIsXHJcbiAgICAgICAgICAgIC8vICAgICAgIGxhc3ROYW1lOiBcIlNlY1wiXHJcbiAgICAgICAgICAgIC8vICAgICB9XHJcbiAgICAgICAgICAgIC8vICAgfSxcclxuICAgICAgICAgICAgLy8gICBkb2N1bWVudE5hbWU6J2VkZ2UgaW5jb21pbmcgNCAnIC8vIHBhc3MgZnJvbSBvdXRzaWRlXHJcbiAgICAgICAgICAgIC8vIH1cclxuICAgICAgICAgICAge1xyXG4gICAgICAgICAgICAgIGRvY3VtZW50TGlmZWN5Y2xlOiBpdGVtLmRvY0xpZmVDeWNsZSxcclxuICAgICAgICAgICAgICBldmVudE5hbWU6IGl0ZW0uZXZlbnRJZCxcclxuICAgICAgICAgICAgICBldmVudERhdGU6IGl0ZW0uZXZlbnREYXRlLFxyXG4gICAgICAgICAgICAgIGNyZWF0b3I6IHtcclxuICAgICAgICAgICAgICAgIHByb3BlcnRpZXM6IHtcclxuICAgICAgICAgICAgICAgICAgZmlyc3ROYW1lOiBpdGVtLnByaW5jaXBhbE5hbWUsXHJcbiAgICAgICAgICAgICAgICAgIGxhc3ROYW1lOiAnJ1xyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgIH0sXHJcbiAgICAgICAgICAgICAgZG9jdW1lbnROYW1lOiB0aGlzLmRvY3VtZW50VGl0bGVcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgKTtcclxuICAgICAgICB9KVxyXG4gICAgICAgIHRoaXMuaXNGZXRjaGluZyA9IGZhbHNlO1xyXG4gICAgICAgIHRoaXMuc3VjY2Vzcy5lbWl0KHRydWUpO1xyXG4gICAgICB9KVxyXG4gIH1cclxuXHJcbiAgb25TY3JvbGwoKSB7XHJcbiAgICB0aGlzLnArK1xyXG4gICAgdGhpcy5nZXRBY3Rpdml0aWVzKCk7XHJcbiAgfVxyXG5cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwidmlld2VyLWxvYWRlciBwYi0yXCI+XHJcbiAgPG1hdC1wcm9ncmVzcy1iYXIgKm5nSWY9XCJpc0ZldGNoaW5nXCIgbW9kZT1cImluZGV0ZXJtaW5hdGVcIj48L21hdC1wcm9ncmVzcy1iYXI+XHJcbjwvZGl2PlxyXG48ZGl2IGNsYXNzPVwiYWN0aXZpdHktYm9keVwiPlxyXG4gIDxkaXYgY2xhc3M9XCJhY3Rpdml0eS1hcmVhXCI+XHJcbiAgICA8ZGl2ICpuZ0Zvcj1cImxldCBpdGVtIG9mIGFjdGl2aXR5bG9nOyBsZXQgaSA9IGluZGV4XCI+XHJcbiAgICAgIDxjdHMtc2luZ2xlLWFjdGl2aXR5IFtpdGVtXT1cIml0ZW1cIiBbZG9jdW1lbnRUaXRsZV09XCJkb2N1bWVudFRpdGxlXCI+XHJcbiAgICAgIDwvY3RzLXNpbmdsZS1hY3Rpdml0eT5cclxuICAgIDwvZGl2PlxyXG4gIDwvZGl2PlxyXG48L2Rpdj4iXX0=
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { from } from 'rxjs';
|
|
3
|
+
import { catchError } from 'rxjs/operators';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../../../Core/services/nuxeo/nuxeo.service";
|
|
6
|
+
export class ActivitiesLogService {
|
|
7
|
+
constructor(nuxeoService) {
|
|
8
|
+
this.nuxeoService = nuxeoService;
|
|
9
|
+
}
|
|
10
|
+
getLogs(id, pageIndex = 0, pageSize = 5) {
|
|
11
|
+
const path = 'id/' + id + '/@audit';
|
|
12
|
+
return from(this.nuxeoService.nuxeoClient.request(path)
|
|
13
|
+
.queryParams({
|
|
14
|
+
currentPageIndex: pageIndex,
|
|
15
|
+
pageSize: pageSize
|
|
16
|
+
})
|
|
17
|
+
.get({
|
|
18
|
+
headers: {
|
|
19
|
+
"properties": "*"
|
|
20
|
+
}
|
|
21
|
+
}))
|
|
22
|
+
.pipe(catchError((err) => {
|
|
23
|
+
throw err;
|
|
24
|
+
}));
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
ActivitiesLogService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: ActivitiesLogService, deps: [{ token: i1.NuxeoService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
28
|
+
ActivitiesLogService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: ActivitiesLogService, providedIn: 'root' });
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: ActivitiesLogService, decorators: [{
|
|
30
|
+
type: Injectable,
|
|
31
|
+
args: [{
|
|
32
|
+
providedIn: 'root'
|
|
33
|
+
}]
|
|
34
|
+
}], ctorParameters: function () { return [{ type: i1.NuxeoService }]; } });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aXZpdGllcy1sb2cuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvYWN0aXZpdGllcy1sb2cvYWN0aXZpdGllcy1sb2cvYWN0aXZpdGllcy1sb2cuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDNUIsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7QUFNNUMsTUFBTSxPQUFPLG9CQUFvQjtJQUUvQixZQUFvQixZQUEyQjtRQUEzQixpQkFBWSxHQUFaLFlBQVksQ0FBZTtJQUFJLENBQUM7SUFFcEQsT0FBTyxDQUFDLEVBQUUsRUFBRSxTQUFTLEdBQUcsQ0FBQyxFQUFFLFFBQVEsR0FBRyxDQUFDO1FBQ3JDLE1BQU0sSUFBSSxHQUFHLEtBQUssR0FBRyxFQUFFLEdBQUcsU0FBUyxDQUFDO1FBQ3BDLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7YUFDcEQsV0FBVyxDQUFDO1lBQ1gsZ0JBQWdCLEVBQUUsU0FBUztZQUMzQixRQUFRLEVBQUUsUUFBUTtTQUNuQixDQUFDO2FBQ0QsR0FBRyxDQUFDO1lBQ0gsT0FBTyxFQUFFO2dCQUNQLFlBQVksRUFBRSxHQUFHO2FBQ2xCO1NBQ0YsQ0FBQyxDQUFDO2FBQ0YsSUFBSSxDQUNILFVBQVUsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ2pCLE1BQU0sR0FBRyxDQUFDO1FBQ1osQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNWLENBQUM7O2lIQXBCVSxvQkFBb0I7cUhBQXBCLG9CQUFvQixjQUZuQixNQUFNOzJGQUVQLG9CQUFvQjtrQkFIaEMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IGZyb20gfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgY2F0Y2hFcnJvciB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuaW1wb3J0IHsgTnV4ZW9TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vQ29yZS9zZXJ2aWNlcy9udXhlby9udXhlby5zZXJ2aWNlJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIEFjdGl2aXRpZXNMb2dTZXJ2aWNlIHtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBudXhlb1NlcnZpY2UgOiBOdXhlb1NlcnZpY2UpIHsgfVxyXG5cclxuICBnZXRMb2dzKGlkLCBwYWdlSW5kZXggPSAwLCBwYWdlU2l6ZSA9IDUpIHtcclxuICAgIGNvbnN0IHBhdGggPSAnaWQvJyArIGlkICsgJy9AYXVkaXQnO1xyXG4gICAgcmV0dXJuIGZyb20odGhpcy5udXhlb1NlcnZpY2UubnV4ZW9DbGllbnQucmVxdWVzdChwYXRoKVxyXG4gICAgICAucXVlcnlQYXJhbXMoe1xyXG4gICAgICAgIGN1cnJlbnRQYWdlSW5kZXg6IHBhZ2VJbmRleCxcclxuICAgICAgICBwYWdlU2l6ZTogcGFnZVNpemVcclxuICAgICAgfSlcclxuICAgICAgLmdldCh7XHJcbiAgICAgICAgaGVhZGVyczoge1xyXG4gICAgICAgICAgXCJwcm9wZXJ0aWVzXCI6IFwiKlwiXHJcbiAgICAgICAgfVxyXG4gICAgICB9KSlcclxuICAgICAgLnBpcGUoXHJcbiAgICAgICAgY2F0Y2hFcnJvcigoZXJyKSA9PiB7XHJcbiAgICAgICAgICB0aHJvdyBlcnI7XHJcbiAgICAgICAgfSkpO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { ActivitiesLogComponent } from './activities-log/activities-log.component';
|
|
4
|
+
import { MatProgressBarModule } from '@angular/material/progress-bar';
|
|
5
|
+
import { LatestActivityModule } from '../latest-activity/latest-activity.module';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class ActivitiesLogModule {
|
|
8
|
+
}
|
|
9
|
+
ActivitiesLogModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: ActivitiesLogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
|
+
ActivitiesLogModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: ActivitiesLogModule, declarations: [ActivitiesLogComponent], imports: [CommonModule,
|
|
11
|
+
MatProgressBarModule,
|
|
12
|
+
LatestActivityModule], exports: [ActivitiesLogComponent] });
|
|
13
|
+
ActivitiesLogModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: ActivitiesLogModule, imports: [[
|
|
14
|
+
CommonModule,
|
|
15
|
+
MatProgressBarModule,
|
|
16
|
+
LatestActivityModule
|
|
17
|
+
]] });
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: ActivitiesLogModule, decorators: [{
|
|
19
|
+
type: NgModule,
|
|
20
|
+
args: [{
|
|
21
|
+
declarations: [ActivitiesLogComponent],
|
|
22
|
+
imports: [
|
|
23
|
+
CommonModule,
|
|
24
|
+
MatProgressBarModule,
|
|
25
|
+
LatestActivityModule
|
|
26
|
+
],
|
|
27
|
+
exports: [ActivitiesLogComponent]
|
|
28
|
+
}]
|
|
29
|
+
}] });
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aXZpdGllcy1sb2cubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9hY3Rpdml0aWVzLWxvZy9hY3Rpdml0aWVzLWxvZy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDbkYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDdEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7O0FBYWpGLE1BQU0sT0FBTyxtQkFBbUI7O2dIQUFuQixtQkFBbUI7aUhBQW5CLG1CQUFtQixpQkFSZixzQkFBc0IsYUFFbkMsWUFBWTtRQUNaLG9CQUFvQjtRQUNwQixvQkFBb0IsYUFFYixzQkFBc0I7aUhBRXBCLG1CQUFtQixZQVByQjtZQUNQLFlBQVk7WUFDWixvQkFBb0I7WUFDcEIsb0JBQW9CO1NBQ3JCOzJGQUdVLG1CQUFtQjtrQkFUL0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztvQkFDdEMsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osb0JBQW9CO3dCQUNwQixvQkFBb0I7cUJBQ3JCO29CQUNELE9BQU8sRUFBQyxDQUFDLHNCQUFzQixDQUFDO2lCQUNqQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IEFjdGl2aXRpZXNMb2dDb21wb25lbnQgfSBmcm9tICcuL2FjdGl2aXRpZXMtbG9nL2FjdGl2aXRpZXMtbG9nLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE1hdFByb2dyZXNzQmFyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcHJvZ3Jlc3MtYmFyJztcclxuaW1wb3J0IHsgTGF0ZXN0QWN0aXZpdHlNb2R1bGUgfSBmcm9tICcuLi9sYXRlc3QtYWN0aXZpdHkvbGF0ZXN0LWFjdGl2aXR5Lm1vZHVsZSc7XHJcblxyXG5cclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbQWN0aXZpdGllc0xvZ0NvbXBvbmVudF0sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgTWF0UHJvZ3Jlc3NCYXJNb2R1bGUsXHJcbiAgICBMYXRlc3RBY3Rpdml0eU1vZHVsZVxyXG4gIF0sXHJcbiAgZXhwb3J0czpbQWN0aXZpdGllc0xvZ0NvbXBvbmVudF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEFjdGl2aXRpZXNMb2dNb2R1bGUgeyB9XHJcbiJdfQ==
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../../../Core/services/translation/translation.service";
|
|
4
|
+
import * as i2 from "@angular/material/icon";
|
|
5
|
+
import * as i3 from "../../display-suitable-icon/display-suitable-icon/display-suitable-icon.component";
|
|
6
|
+
import * as i4 from "@angular/material/progress-bar";
|
|
7
|
+
import * as i5 from "@angular/common";
|
|
8
|
+
import * as i6 from "../../../directive/rtl/set-rtl.directive";
|
|
9
|
+
import * as i7 from "@angular/material/tooltip";
|
|
10
|
+
export class AttachmentItemComponent {
|
|
11
|
+
constructor(translationService) {
|
|
12
|
+
this.translationService = translationService;
|
|
13
|
+
this.type = 'batch';
|
|
14
|
+
this.showRemoveButton = true;
|
|
15
|
+
this.source = '';
|
|
16
|
+
this.personImageLink = '';
|
|
17
|
+
this.onRemovingItem = new EventEmitter();
|
|
18
|
+
this.isArabic = false;
|
|
19
|
+
}
|
|
20
|
+
ngOnInit() {
|
|
21
|
+
this.translationSubscription = this.translationService.isArabic.subscribe(res => {
|
|
22
|
+
this.isArabic = res;
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
removeItem() {
|
|
26
|
+
this.onRemovingItem.emit(this.item);
|
|
27
|
+
}
|
|
28
|
+
ngOnDestroy() {
|
|
29
|
+
this.translationSubscription ? this.translationSubscription.unsubscribe() : null;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
AttachmentItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: AttachmentItemComponent, deps: [{ token: i1.TranslationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
+
AttachmentItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: AttachmentItemComponent, selector: "app-attachment-item", inputs: { item: "item", type: "type", showRemoveButton: "showRemoveButton", source: "source", personImageLink: "personImageLink" }, outputs: { onRemovingItem: "onRemovingItem" }, ngImport: i0, template: "<ng-container *ngIf=\"source != 'faceRecognition'\">\r\n <div SetRtl class=\"p-2 w-72 h-15 relative border-2 flex items-center text-lg cursor-pointer hover:bg-primary-100\" \r\n [ngClass]=\"{'border-gray-200': item.progress === undefined , \r\n 'border-primary-300': (item.progress === 'done' && item['generalValidationValid'] !== false) , \r\n 'border-red-500': (item.progress === 'error' || item['generalValidationValid'] === false) }\">\r\n <mat-icon class=\"cursor-pointer top-1 absolute text-gray-900 text-xl\" \r\n [ngClass]=\"{'left-1' : isArabic , 'right-1' : !isArabic}\" (click)=\"removeItem()\" \r\n *ngIf=\"showRemoveButton\">close</mat-icon>\r\n <span class=\"my-icon-wrap\">\r\n <app-display-suitable-icon [data]=\"item\" [dataType]=\"'file'\"></app-display-suitable-icon>\r\n </span>\r\n <div class=\"file-title mx-2 whitespace-nowrap overflow-hidden overflow-ellipsis text-lg\" matTooltip=\"{{item.batch.title ? item.batch.title : item.title}}\" *ngIf=\"type === 'batch'\">{{item.batch.title ? item.batch.title : item.title}}</div>\r\n <div class=\"file-title mx-2 whitespace-nowrap overflow-hidden overflow-ellipsis text-lg\" matTooltip=\"{{item.name}}\" *ngIf=\"type === 'file'\">{{item.name}}</div>\r\n <div class=\"viewer-loader absolute bottom-0 w-11/12\">\r\n <mat-progress-bar *ngIf=\"item.progress === 'inProgress'\" mode=\"indeterminate\"></mat-progress-bar>\r\n </div>\r\n </div>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"source == 'faceRecognition'\">\r\n <div class=\"w-52 h-52 relative border flex flex-col items-center cursor-pointer hover:bg-primary-100\" \r\n [ngClass]=\"{'border-gray-200': item.progress === undefined, 'border-primary-300': item.progress === 'done', 'border-red-500': item.progress === 'error'}\">\r\n \r\n <div class=\"flex items-center justify-center opacity-70 cursor-pointer bg-accent-100 rounded-full top-1 absolute text-gray-900 text-xl\" \r\n [ngClass]=\"{'left-1' : isArabic , 'right-1' : !isArabic}\" (click)=\"removeItem()\">\r\n <mat-icon class=\"icon-size-5\">close</mat-icon>\r\n </div>\r\n <span class=\"h-3/4 w-full\">\r\n <img [src]=\"personImageLink || './assets/images/Photos/loadingImg.png'\" class=\"w-full h-full\" alt=\"personPhoto\">\r\n </span>\r\n <div class=\"w-full h-1/4 overflow-hidden text-lg\" [ngClass]=\"{'shortTitle': item.name.length < 25,'longTitle': item.name.length > 25}\">{{item.name}}</div>\r\n <div class=\"viewer-loader absolute bottom-0 w-full\">\r\n <mat-progress-bar *ngIf=\"item.progress === 'inProgress'\" mode=\"indeterminate\"></mat-progress-bar>\r\n </div>\r\n </div>\r\n</ng-container>", styles: [".my-icon-wrap{width:40px;height:40px}.file-title{width:calc(100% - 60px)}.shortTitle{display:flex;align-items:center;justify-content:center;text-overflow:ellipsis}.longTitle{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;text-align:center}\n"], components: [{ type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i3.DisplaySuitableIconComponent, selector: "app-display-suitable-icon", inputs: ["data", "size", "dataType", "archive"] }, { type: i4.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "mode", "value", "bufferValue"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.SetRtlDirective, selector: "[SetRtl]" }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltipPosition", "matTooltipDisabled", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }] });
|
|
34
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: AttachmentItemComponent, decorators: [{
|
|
35
|
+
type: Component,
|
|
36
|
+
args: [{
|
|
37
|
+
selector: 'app-attachment-item',
|
|
38
|
+
templateUrl: './attachment-item.component.html',
|
|
39
|
+
styleUrls: ['./attachment-item.component.scss']
|
|
40
|
+
}]
|
|
41
|
+
}], ctorParameters: function () { return [{ type: i1.TranslationService }]; }, propDecorators: { item: [{
|
|
42
|
+
type: Input
|
|
43
|
+
}], type: [{
|
|
44
|
+
type: Input
|
|
45
|
+
}], showRemoveButton: [{
|
|
46
|
+
type: Input
|
|
47
|
+
}], source: [{
|
|
48
|
+
type: Input
|
|
49
|
+
}], personImageLink: [{
|
|
50
|
+
type: Input
|
|
51
|
+
}], onRemovingItem: [{
|
|
52
|
+
type: Output
|
|
53
|
+
}] } });
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXR0YWNobWVudC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvYXR0YWNobWVudC1pdGVtL2F0dGFjaG1lbnQtaXRlbS9hdHRhY2htZW50LWl0ZW0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9hdHRhY2htZW50LWl0ZW0vYXR0YWNobWVudC1pdGVtL2F0dGFjaG1lbnQtaXRlbS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7Ozs7Ozs7QUFTL0UsTUFBTSxPQUFPLHVCQUF1QjtJQVVsQyxZQUFvQixrQkFBdUM7UUFBdkMsdUJBQWtCLEdBQWxCLGtCQUFrQixDQUFxQjtRQVBsRCxTQUFJLEdBQUMsT0FBTyxDQUFDO1FBQ2IscUJBQWdCLEdBQUcsSUFBSSxDQUFDO1FBQ3hCLFdBQU0sR0FBRyxFQUFFLENBQUM7UUFDWixvQkFBZSxHQUFHLEVBQUUsQ0FBQztRQUNwQixtQkFBYyxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7UUFFOUMsYUFBUSxHQUFHLEtBQUssQ0FBQztJQUM4QyxDQUFDO0lBRWhFLFFBQVE7UUFDTixJQUFJLENBQUMsdUJBQXVCLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDOUUsSUFBSSxDQUFDLFFBQVEsR0FBRyxHQUFHLENBQUU7UUFDdkIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsVUFBVTtRQUNSLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN0QyxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLHVCQUF1QixDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDbkYsQ0FBQzs7b0hBeEJVLHVCQUF1Qjt3R0FBdkIsdUJBQXVCLDhPQ1RwQyxvdkZBbUNlOzJGRDFCRix1QkFBdUI7a0JBTG5DLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHFCQUFxQjtvQkFDL0IsV0FBVyxFQUFFLGtDQUFrQztvQkFDL0MsU0FBUyxFQUFFLENBQUMsa0NBQWtDLENBQUM7aUJBQ2hEO3lHQUdVLElBQUk7c0JBQVosS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csZ0JBQWdCO3NCQUF4QixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxlQUFlO3NCQUF2QixLQUFLO2dCQUNJLGNBQWM7c0JBQXZCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGlvblNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9Db3JlL3NlcnZpY2VzL3RyYW5zbGF0aW9uL3RyYW5zbGF0aW9uLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtYXR0YWNobWVudC1pdGVtJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vYXR0YWNobWVudC1pdGVtLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9hdHRhY2htZW50LWl0ZW0uY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQXR0YWNobWVudEl0ZW1Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuICBASW5wdXQoKSBpdGVtO1xyXG4gIEBJbnB1dCgpIHR5cGU9J2JhdGNoJztcclxuICBASW5wdXQoKSBzaG93UmVtb3ZlQnV0dG9uID0gdHJ1ZTtcclxuICBASW5wdXQoKSBzb3VyY2UgPSAnJztcclxuICBASW5wdXQoKSBwZXJzb25JbWFnZUxpbmsgPSAnJztcclxuICBAT3V0cHV0KCkgb25SZW1vdmluZ0l0ZW0gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcbiAgdHJhbnNsYXRpb25TdWJzY3JpcHRpb24gOiBTdWJzY3JpcHRpb247XHJcbiAgaXNBcmFiaWMgPSBmYWxzZTtcclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHRyYW5zbGF0aW9uU2VydmljZSA6IFRyYW5zbGF0aW9uU2VydmljZSkgeyB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy50cmFuc2xhdGlvblN1YnNjcmlwdGlvbiA9IHRoaXMudHJhbnNsYXRpb25TZXJ2aWNlLmlzQXJhYmljLnN1YnNjcmliZShyZXMgPT4ge1xyXG4gICAgICB0aGlzLmlzQXJhYmljID0gcmVzIDtcclxuICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgcmVtb3ZlSXRlbSgpe1xyXG4gICAgdGhpcy5vblJlbW92aW5nSXRlbS5lbWl0KHRoaXMuaXRlbSk7XHJcbiAgfVxyXG5cclxuICBuZ09uRGVzdHJveSgpe1xyXG4gICAgdGhpcy50cmFuc2xhdGlvblN1YnNjcmlwdGlvbiA/IHRoaXMudHJhbnNsYXRpb25TdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKSA6IG51bGw7XHJcbiAgfVxyXG59XHJcbiIsIjxuZy1jb250YWluZXIgKm5nSWY9XCJzb3VyY2UgIT0gJ2ZhY2VSZWNvZ25pdGlvbidcIj5cclxuICAgIDxkaXYgU2V0UnRsIGNsYXNzPVwicC0yIHctNzIgaC0xNSByZWxhdGl2ZSBib3JkZXItMiBmbGV4IGl0ZW1zLWNlbnRlciB0ZXh0LWxnIGN1cnNvci1wb2ludGVyIGhvdmVyOmJnLXByaW1hcnktMTAwXCIgXHJcbiAgICBbbmdDbGFzc109XCJ7J2JvcmRlci1ncmF5LTIwMCc6IGl0ZW0ucHJvZ3Jlc3MgPT09IHVuZGVmaW5lZCAsIFxyXG4gICAgJ2JvcmRlci1wcmltYXJ5LTMwMCc6IChpdGVtLnByb2dyZXNzID09PSAnZG9uZScgJiYgaXRlbVsnZ2VuZXJhbFZhbGlkYXRpb25WYWxpZCddICE9PSBmYWxzZSkgLCBcclxuICAgICdib3JkZXItcmVkLTUwMCc6IChpdGVtLnByb2dyZXNzID09PSAnZXJyb3InIHx8IGl0ZW1bJ2dlbmVyYWxWYWxpZGF0aW9uVmFsaWQnXSA9PT0gZmFsc2UpIH1cIj5cclxuICAgICAgICA8bWF0LWljb24gY2xhc3M9XCJjdXJzb3ItcG9pbnRlciAgdG9wLTEgIGFic29sdXRlIHRleHQtZ3JheS05MDAgdGV4dC14bFwiIFxyXG4gICAgICAgIFtuZ0NsYXNzXT1cInsnbGVmdC0xJyA6IGlzQXJhYmljICwgJ3JpZ2h0LTEnIDogIWlzQXJhYmljfVwiIChjbGljayk9XCJyZW1vdmVJdGVtKClcIiBcclxuICAgICAgICAqbmdJZj1cInNob3dSZW1vdmVCdXR0b25cIj5jbG9zZTwvbWF0LWljb24+XHJcbiAgICAgICAgPHNwYW4gY2xhc3M9XCJteS1pY29uLXdyYXBcIj5cclxuICAgICAgICAgICAgPGFwcC1kaXNwbGF5LXN1aXRhYmxlLWljb24gW2RhdGFdPVwiaXRlbVwiIFtkYXRhVHlwZV09XCInZmlsZSdcIj48L2FwcC1kaXNwbGF5LXN1aXRhYmxlLWljb24+XHJcbiAgICAgICAgPC9zcGFuPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJmaWxlLXRpdGxlIG14LTIgd2hpdGVzcGFjZS1ub3dyYXAgb3ZlcmZsb3ctaGlkZGVuIG92ZXJmbG93LWVsbGlwc2lzIHRleHQtbGdcIiBtYXRUb29sdGlwPVwie3tpdGVtLmJhdGNoLnRpdGxlID8gaXRlbS5iYXRjaC50aXRsZSA6IGl0ZW0udGl0bGV9fVwiICpuZ0lmPVwidHlwZSA9PT0gJ2JhdGNoJ1wiPnt7aXRlbS5iYXRjaC50aXRsZSA/IGl0ZW0uYmF0Y2gudGl0bGUgOiBpdGVtLnRpdGxlfX08L2Rpdj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiZmlsZS10aXRsZSBteC0yIHdoaXRlc3BhY2Utbm93cmFwIG92ZXJmbG93LWhpZGRlbiBvdmVyZmxvdy1lbGxpcHNpcyB0ZXh0LWxnXCIgbWF0VG9vbHRpcD1cInt7aXRlbS5uYW1lfX1cIiAqbmdJZj1cInR5cGUgPT09ICdmaWxlJ1wiPnt7aXRlbS5uYW1lfX08L2Rpdj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwidmlld2VyLWxvYWRlciBhYnNvbHV0ZSBib3R0b20tMCB3LTExLzEyXCI+XHJcbiAgICAgICAgICAgIDxtYXQtcHJvZ3Jlc3MtYmFyICpuZ0lmPVwiaXRlbS5wcm9ncmVzcyA9PT0gJ2luUHJvZ3Jlc3MnXCIgbW9kZT1cImluZGV0ZXJtaW5hdGVcIj48L21hdC1wcm9ncmVzcy1iYXI+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuPC9uZy1jb250YWluZXI+XHJcblxyXG48bmctY29udGFpbmVyICpuZ0lmPVwic291cmNlID09ICdmYWNlUmVjb2duaXRpb24nXCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwidy01MiBoLTUyIHJlbGF0aXZlIGJvcmRlciBmbGV4IGZsZXgtY29sIGl0ZW1zLWNlbnRlciBjdXJzb3ItcG9pbnRlciBob3ZlcjpiZy1wcmltYXJ5LTEwMFwiIFxyXG4gICAgW25nQ2xhc3NdPVwieydib3JkZXItZ3JheS0yMDAnOiBpdGVtLnByb2dyZXNzID09PSB1bmRlZmluZWQsICdib3JkZXItcHJpbWFyeS0zMDAnOiBpdGVtLnByb2dyZXNzID09PSAnZG9uZScsICdib3JkZXItcmVkLTUwMCc6IGl0ZW0ucHJvZ3Jlc3MgPT09ICdlcnJvcid9XCI+XHJcbiAgICAgICAgXHJcbiAgICAgICAgPGRpdiBjbGFzcz1cImZsZXggaXRlbXMtY2VudGVyIGp1c3RpZnktY2VudGVyIG9wYWNpdHktNzAgY3Vyc29yLXBvaW50ZXIgYmctYWNjZW50LTEwMCByb3VuZGVkLWZ1bGwgdG9wLTEgIGFic29sdXRlIHRleHQtZ3JheS05MDAgdGV4dC14bFwiIFxyXG4gICAgICAgIFtuZ0NsYXNzXT1cInsnbGVmdC0xJyA6IGlzQXJhYmljICwgJ3JpZ2h0LTEnIDogIWlzQXJhYmljfVwiIChjbGljayk9XCJyZW1vdmVJdGVtKClcIj5cclxuICAgICAgICAgICAgPG1hdC1pY29uIGNsYXNzPVwiaWNvbi1zaXplLTVcIj5jbG9zZTwvbWF0LWljb24+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPHNwYW4gY2xhc3M9XCJoLTMvNCB3LWZ1bGxcIj5cclxuICAgICAgICAgICAgPGltZyBbc3JjXT1cInBlcnNvbkltYWdlTGluayB8fCAnLi9hc3NldHMvaW1hZ2VzL1Bob3Rvcy9sb2FkaW5nSW1nLnBuZydcIiBjbGFzcz1cInctZnVsbCBoLWZ1bGxcIiBhbHQ9XCJwZXJzb25QaG90b1wiPlxyXG4gICAgICAgIDwvc3Bhbj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwidy1mdWxsIGgtMS80IG92ZXJmbG93LWhpZGRlbiB0ZXh0LWxnXCIgW25nQ2xhc3NdPVwieydzaG9ydFRpdGxlJzogaXRlbS5uYW1lLmxlbmd0aCA8IDI1LCdsb25nVGl0bGUnOiBpdGVtLm5hbWUubGVuZ3RoID4gMjV9XCI+e3tpdGVtLm5hbWV9fTwvZGl2PlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJ2aWV3ZXItbG9hZGVyIGFic29sdXRlIGJvdHRvbS0wIHctZnVsbFwiPlxyXG4gICAgICAgICAgICA8bWF0LXByb2dyZXNzLWJhciAqbmdJZj1cIml0ZW0ucHJvZ3Jlc3MgPT09ICdpblByb2dyZXNzJ1wiIG1vZGU9XCJpbmRldGVybWluYXRlXCI+PC9tYXQtcHJvZ3Jlc3MtYmFyPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbjwvbmctY29udGFpbmVyPiJdfQ==
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { DirectiveModule } from '../../directive/directive.module';
|
|
4
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
5
|
+
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
6
|
+
import { DisplaySuitableIconModule } from '../display-suitable-icon/display-suitable-icon.module';
|
|
7
|
+
import { AttachmentItemComponent } from './attachment-item/attachment-item.component';
|
|
8
|
+
import { MatProgressBarModule } from '@angular/material/progress-bar';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
export class AttachmentItemModule {
|
|
11
|
+
}
|
|
12
|
+
AttachmentItemModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: AttachmentItemModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
+
AttachmentItemModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: AttachmentItemModule, declarations: [AttachmentItemComponent], imports: [CommonModule,
|
|
14
|
+
DirectiveModule,
|
|
15
|
+
MatProgressBarModule,
|
|
16
|
+
MatIconModule,
|
|
17
|
+
MatTooltipModule,
|
|
18
|
+
DisplaySuitableIconModule], exports: [AttachmentItemComponent] });
|
|
19
|
+
AttachmentItemModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: AttachmentItemModule, imports: [[
|
|
20
|
+
CommonModule,
|
|
21
|
+
DirectiveModule,
|
|
22
|
+
MatProgressBarModule,
|
|
23
|
+
MatIconModule,
|
|
24
|
+
MatTooltipModule,
|
|
25
|
+
DisplaySuitableIconModule
|
|
26
|
+
]] });
|
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: AttachmentItemModule, decorators: [{
|
|
28
|
+
type: NgModule,
|
|
29
|
+
args: [{
|
|
30
|
+
declarations: [AttachmentItemComponent],
|
|
31
|
+
imports: [
|
|
32
|
+
CommonModule,
|
|
33
|
+
DirectiveModule,
|
|
34
|
+
MatProgressBarModule,
|
|
35
|
+
MatIconModule,
|
|
36
|
+
MatTooltipModule,
|
|
37
|
+
DisplaySuitableIconModule
|
|
38
|
+
],
|
|
39
|
+
exports: [
|
|
40
|
+
AttachmentItemComponent
|
|
41
|
+
]
|
|
42
|
+
}]
|
|
43
|
+
}] });
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXR0YWNobWVudC1pdGVtLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvYXR0YWNobWVudC1pdGVtL2F0dGFjaG1lbnQtaXRlbS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ25FLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM3RCxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSx1REFBdUQsQ0FBQztBQUNsRyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQUN0RixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7QUFrQnRFLE1BQU0sT0FBTyxvQkFBb0I7O2lIQUFwQixvQkFBb0I7a0hBQXBCLG9CQUFvQixpQkFiaEIsdUJBQXVCLGFBRXBDLFlBQVk7UUFDWixlQUFlO1FBQ2Ysb0JBQW9CO1FBQ3BCLGFBQWE7UUFDYixnQkFBZ0I7UUFDaEIseUJBQXlCLGFBR3pCLHVCQUF1QjtrSEFHZCxvQkFBb0IsWUFadEI7WUFDUCxZQUFZO1lBQ1osZUFBZTtZQUNmLG9CQUFvQjtZQUNwQixhQUFhO1lBQ2IsZ0JBQWdCO1lBQ2hCLHlCQUF5QjtTQUMxQjsyRkFLVSxvQkFBb0I7a0JBZGhDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsdUJBQXVCLENBQUM7b0JBQ3ZDLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGVBQWU7d0JBQ2Ysb0JBQW9CO3dCQUNwQixhQUFhO3dCQUNiLGdCQUFnQjt3QkFDaEIseUJBQXlCO3FCQUMxQjtvQkFDRCxPQUFPLEVBQUM7d0JBQ04sdUJBQXVCO3FCQUN4QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IERpcmVjdGl2ZU1vZHVsZSB9IGZyb20gJy4uLy4uL2RpcmVjdGl2ZS9kaXJlY3RpdmUubW9kdWxlJztcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQgeyBNYXRUb29sdGlwTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbHRpcCc7XHJcbmltcG9ydCB7IERpc3BsYXlTdWl0YWJsZUljb25Nb2R1bGUgfSBmcm9tICcuLi9kaXNwbGF5LXN1aXRhYmxlLWljb24vZGlzcGxheS1zdWl0YWJsZS1pY29uLm1vZHVsZSc7XHJcbmltcG9ydCB7IEF0dGFjaG1lbnRJdGVtQ29tcG9uZW50IH0gZnJvbSAnLi9hdHRhY2htZW50LWl0ZW0vYXR0YWNobWVudC1pdGVtLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE1hdFByb2dyZXNzQmFyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcHJvZ3Jlc3MtYmFyJztcclxuXHJcblxyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtBdHRhY2htZW50SXRlbUNvbXBvbmVudF0sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgRGlyZWN0aXZlTW9kdWxlLFxyXG4gICAgTWF0UHJvZ3Jlc3NCYXJNb2R1bGUsXHJcbiAgICBNYXRJY29uTW9kdWxlLFxyXG4gICAgTWF0VG9vbHRpcE1vZHVsZSxcclxuICAgIERpc3BsYXlTdWl0YWJsZUljb25Nb2R1bGVcclxuICBdLFxyXG4gIGV4cG9ydHM6W1xyXG4gICAgQXR0YWNobWVudEl0ZW1Db21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBdHRhY2htZW50SXRlbU1vZHVsZSB7IH1cclxuIl19
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { AttachmentsComponent } from './attachments/attachments.component';
|
|
4
|
+
import { AttachmentItemModule } from '../attachment-item/attachment-item.module';
|
|
5
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
6
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
7
|
+
import { DirectiveModule } from '../../directive/directive.module';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export class AttachmentModalModule {
|
|
10
|
+
}
|
|
11
|
+
AttachmentModalModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: AttachmentModalModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
12
|
+
AttachmentModalModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: AttachmentModalModule, declarations: [AttachmentsComponent], imports: [CommonModule,
|
|
13
|
+
AttachmentItemModule,
|
|
14
|
+
MatIconModule,
|
|
15
|
+
TranslateModule,
|
|
16
|
+
DirectiveModule], exports: [AttachmentsComponent] });
|
|
17
|
+
AttachmentModalModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: AttachmentModalModule, imports: [[
|
|
18
|
+
CommonModule,
|
|
19
|
+
AttachmentItemModule,
|
|
20
|
+
MatIconModule,
|
|
21
|
+
TranslateModule,
|
|
22
|
+
DirectiveModule
|
|
23
|
+
]] });
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: AttachmentModalModule, decorators: [{
|
|
25
|
+
type: NgModule,
|
|
26
|
+
args: [{
|
|
27
|
+
declarations: [AttachmentsComponent],
|
|
28
|
+
imports: [
|
|
29
|
+
CommonModule,
|
|
30
|
+
AttachmentItemModule,
|
|
31
|
+
MatIconModule,
|
|
32
|
+
TranslateModule,
|
|
33
|
+
DirectiveModule
|
|
34
|
+
],
|
|
35
|
+
exports: [
|
|
36
|
+
AttachmentsComponent
|
|
37
|
+
]
|
|
38
|
+
}]
|
|
39
|
+
}] });
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXR0YWNobWVudC1tb2RhbC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL2F0dGFjaG1lbnQtbW9kYWwvYXR0YWNobWVudC1tb2RhbC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDM0UsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDakYsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sa0NBQWtDLENBQUM7O0FBaUJuRSxNQUFNLE9BQU8scUJBQXFCOztrSEFBckIscUJBQXFCO21IQUFyQixxQkFBcUIsaUJBWmpCLG9CQUFvQixhQUVqQyxZQUFZO1FBQ1osb0JBQW9CO1FBQ3BCLGFBQWE7UUFDYixlQUFlO1FBQ2YsZUFBZSxhQUdmLG9CQUFvQjttSEFHWCxxQkFBcUIsWUFYdkI7WUFDUCxZQUFZO1lBQ1osb0JBQW9CO1lBQ3BCLGFBQWE7WUFDYixlQUFlO1lBQ2YsZUFBZTtTQUNoQjsyRkFLVSxxQkFBcUI7a0JBYmpDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsb0JBQW9CLENBQUM7b0JBQ3BDLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLG9CQUFvQjt3QkFDcEIsYUFBYTt3QkFDYixlQUFlO3dCQUNmLGVBQWU7cUJBQ2hCO29CQUNELE9BQU8sRUFBQzt3QkFDTixvQkFBb0I7cUJBQ3JCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgQXR0YWNobWVudHNDb21wb25lbnQgfSBmcm9tICcuL2F0dGFjaG1lbnRzL2F0dGFjaG1lbnRzLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEF0dGFjaG1lbnRJdGVtTW9kdWxlIH0gZnJvbSAnLi4vYXR0YWNobWVudC1pdGVtL2F0dGFjaG1lbnQtaXRlbS5tb2R1bGUnO1xyXG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XHJcbmltcG9ydCB7IFRyYW5zbGF0ZU1vZHVsZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xyXG5pbXBvcnQgeyBEaXJlY3RpdmVNb2R1bGUgfSBmcm9tICcuLi8uLi9kaXJlY3RpdmUvZGlyZWN0aXZlLm1vZHVsZSc7XHJcblxyXG5cclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbQXR0YWNobWVudHNDb21wb25lbnRdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEF0dGFjaG1lbnRJdGVtTW9kdWxlLFxyXG4gICAgTWF0SWNvbk1vZHVsZSxcclxuICAgIFRyYW5zbGF0ZU1vZHVsZSxcclxuICAgIERpcmVjdGl2ZU1vZHVsZVxyXG4gIF0sXHJcbiAgZXhwb3J0czpbXHJcbiAgICBBdHRhY2htZW50c0NvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEF0dGFjaG1lbnRNb2RhbE1vZHVsZSB7IH1cclxuIl19
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
import { Component, EventEmitter, Inject, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../../../shared-services/upload-managment.service";
|
|
4
|
+
import * as i2 from "../../custom-toastr/services/custom-toastr.service";
|
|
5
|
+
import * as i3 from "../../../configuration/app-config.service";
|
|
6
|
+
import * as i4 from "../../attachment-item/attachment-item/attachment-item.component";
|
|
7
|
+
import * as i5 from "@angular/material/icon";
|
|
8
|
+
import * as i6 from "../../../directive/drag-and-drop/drag-and-drop.directive";
|
|
9
|
+
import * as i7 from "@angular/common";
|
|
10
|
+
import * as i8 from "@ngx-translate/core";
|
|
11
|
+
export class AttachmentsComponent {
|
|
12
|
+
constructor(uploadMangmentService, environment, customToastrService, AppConfigService) {
|
|
13
|
+
this.uploadMangmentService = uploadMangmentService;
|
|
14
|
+
this.environment = environment;
|
|
15
|
+
this.customToastrService = customToastrService;
|
|
16
|
+
this.AppConfigService = AppConfigService;
|
|
17
|
+
/** Allowed Upload Types */
|
|
18
|
+
this.allowedTypes = 'image/png,video/mp4,video/webm,application/pdf,application/vnd.ms-powerpoint,application/vnd.openxmlformats-officedocument.presentationml.presentation';
|
|
19
|
+
/** Params to be sent with properties when creating a document */
|
|
20
|
+
this.params = {};
|
|
21
|
+
/** Max allowed upload size */
|
|
22
|
+
this.maxSize = 104857600; // 1145728;
|
|
23
|
+
/** Params to be sent with body when creating a document */
|
|
24
|
+
this.docParams = {};
|
|
25
|
+
/** Can upload multiple files at once */
|
|
26
|
+
this.multiple = false;
|
|
27
|
+
/** should create document after batch upload */
|
|
28
|
+
this.createDocument = true;
|
|
29
|
+
/** Max allowed number of files size */
|
|
30
|
+
this.allowedMaxNumberOfFiles = 10;
|
|
31
|
+
// to do extra logic when source is new person dialog
|
|
32
|
+
this.source = '';
|
|
33
|
+
/** Event emitted on document upload success, it will have document or batch object based on configuration */
|
|
34
|
+
this.uploadSuccess = new EventEmitter();
|
|
35
|
+
/** Event emitted when an error occurs while attempting upload */
|
|
36
|
+
this.uploadError = new EventEmitter();
|
|
37
|
+
this.onSelectingItem = new EventEmitter();
|
|
38
|
+
this.uploading = false;
|
|
39
|
+
this.itemRemoved = new EventEmitter();
|
|
40
|
+
this.activeFile = {
|
|
41
|
+
name: ''
|
|
42
|
+
};
|
|
43
|
+
this.maxSize = this.environment.maxFileSize;
|
|
44
|
+
this.allowedTypes = this.environment.allowedFileTypes;
|
|
45
|
+
}
|
|
46
|
+
ngOnInit() {
|
|
47
|
+
}
|
|
48
|
+
triggerUpload() {
|
|
49
|
+
this.fileInput.nativeElement.click();
|
|
50
|
+
}
|
|
51
|
+
isSizeChecked(file) {
|
|
52
|
+
if (file.size <= this.maxSize) {
|
|
53
|
+
return true;
|
|
54
|
+
}
|
|
55
|
+
else
|
|
56
|
+
this.customToastrService.show('error', 'error', 'ERRORS.SIZE', {}, `${(this.maxSize / (1024 * 1024)).toFixed(2)}MB`);
|
|
57
|
+
this.uploadError.next('errors.size');
|
|
58
|
+
return false;
|
|
59
|
+
}
|
|
60
|
+
isTypeChecked(file) {
|
|
61
|
+
let myAttachmentNameSections = file.name.split('.');
|
|
62
|
+
let fileType = myAttachmentNameSections[myAttachmentNameSections.length - 1];
|
|
63
|
+
if (this.allowedTypes.includes(fileType.toLowerCase())) {
|
|
64
|
+
return true;
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
this.customToastrService.show('error', 'error', 'ERRORS.TYPE', {}, this.allowedTypes.replace(/./gi, '').toUpperCase());
|
|
68
|
+
this.uploadError.next('errors.type');
|
|
69
|
+
return false;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
isMaxNumberOfFiles(selectedFiles) {
|
|
73
|
+
if (selectedFiles.length <= this.allowedMaxNumberOfFiles)
|
|
74
|
+
return true;
|
|
75
|
+
else {
|
|
76
|
+
this.customToastrService.show('error', 'error', 'ERRORS.MAX_NUMBER_OF_FILES', {}, this.allowedMaxNumberOfFiles);
|
|
77
|
+
this.uploadError.next('errors.maxNumberOfFiles');
|
|
78
|
+
return false;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
uploadingFiles(files) {
|
|
82
|
+
let selectedFiles = Object.keys(files).map(key => files[key]);
|
|
83
|
+
selectedFiles = selectedFiles.filter(file => {
|
|
84
|
+
//if (this.isMaxNumberOfFiles(selectedFiles)) {
|
|
85
|
+
if (this.isSizeChecked(file)
|
|
86
|
+
&& this.isTypeChecked(file)) {
|
|
87
|
+
return file;
|
|
88
|
+
}
|
|
89
|
+
// }
|
|
90
|
+
});
|
|
91
|
+
if (selectedFiles.length) {
|
|
92
|
+
if (this.source == 'faceRecognition') {
|
|
93
|
+
selectedFiles.forEach(e => {
|
|
94
|
+
let reader = new FileReader();
|
|
95
|
+
reader.readAsDataURL(e);
|
|
96
|
+
reader.onload = (_event) => {
|
|
97
|
+
e['previewLink'] = reader.result;
|
|
98
|
+
};
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
this.uploading = true;
|
|
102
|
+
this.uploadMangmentService.uploadFilesMangment(selectedFiles);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
removeItem(item, listofFiles) {
|
|
106
|
+
const removeIndex = listofFiles.findIndex(file => file.name === item.name);
|
|
107
|
+
listofFiles.splice(removeIndex, 1);
|
|
108
|
+
this.itemRemoved.emit(true);
|
|
109
|
+
}
|
|
110
|
+
selectItem(file) {
|
|
111
|
+
this.activeFile = file;
|
|
112
|
+
this.onSelectingItem.emit(file);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
AttachmentsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: AttachmentsComponent, deps: [{ token: i1.UploadManagmentService }, { token: 'environment' }, { token: i2.CustomToastrService }, { token: i3.AppConfigService }], target: i0.ɵɵFactoryTarget.Component });
|
|
116
|
+
AttachmentsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: AttachmentsComponent, selector: "app-attachments", inputs: { allowedTypes: "allowedTypes", params: "params", path: "path", maxSize: "maxSize", docParams: "docParams", multiple: "multiple", createDocument: "createDocument", allowedMaxNumberOfFiles: "allowedMaxNumberOfFiles", source: "source" }, outputs: { uploadSuccess: "uploadSuccess", uploadError: "uploadError", onSelectingItem: "onSelectingItem", itemRemoved: "itemRemoved" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], ngImport: i0, template: "<div id=\"anything\"></div>\r\n<div class=\"iner-wrapping border drop-zone w-full p-5 border-solid relative\" \r\n appDragAndDrop (fileDroped)=\"uploadingFiles($event)\"\r\n [ngClass]=\"{'border-accent-200 bg-accent-50 hover:bg-accent-100' : AppConfigService.theme === 'ksreleif' , 'border-primary-200 bg-primary-50 hover:bg-primary-200' : AppConfigService.theme === 'dgda',\r\n 'flex justify-center items-center': source != 'faceRecognition'}\">\r\n\r\n <div class=\"flex flex-wrap mt-3 w-full justify-start \"\r\n [ngClass]=\"{'absolute top-2 left-3 right-3': source != 'faceRecognition'}\">\r\n <div class=\"mx-2 mb-2 z-50\" *ngFor=\"let file of uploadMangmentService.uploadedFilesStatus.uploadedFiles\"\r\n [ngClass]=\"{'bg-primary-100' : file.name === activeFile.name, 'h-15': source != 'faceRecognition', \r\n 'h-52': source == 'faceRecognition'}\">\r\n <app-attachment-item [item]=\"file\" [type]=\"'batch'\" [source]=\"source\" [personImageLink]=\"file?.previewLink\"\r\n (onRemovingItem)=\"removeItem($event , uploadMangmentService.uploadedFilesStatus.uploadedFiles)\" \r\n (click)=\"selectItem(file)\"></app-attachment-item>\r\n </div>\r\n \r\n <div class=\"mx-2 mb-2 z-50\" *ngFor=\"let file of uploadMangmentService.uploadedFilesStatus.allfiles\"\r\n [ngClass]=\"{'bg-primary-100' : file.name === activeFile.name,'h-15': source != 'faceRecognition', \r\n 'h-52': source == 'faceRecognition'}\">\r\n <app-attachment-item [item]=\"file\" [type]=\"'file'\" [source]=\"source\" [personImageLink]=\"file?.previewLink\"\r\n (onRemovingItem)=\"removeItem($event , uploadMangmentService.uploadedFilesStatus.allfiles)\" \r\n (click)=\"selectItem(file)\"></app-attachment-item>\r\n </div>\r\n </div>\r\n\r\n <input class=\"opacity-0 absolute -inset-0 w-full cursor-pointer\" type=\"file\" #fileInput id=\"fileInput\" [accept]=\"allowedTypes\" [multiple]=\"multiple\" (change)=\"uploadingFiles($event.target.files)\" >\r\n <div class=\"flex justify-center items-center flex-col\" *ngIf=\"uploadMangmentService.uploadedFilesStatus.numberOfFilesToBeUploaded === 0 || (source == 'faceRecognition' && !uploadMangmentService.uploadedFilesStatus.uploadedFiles.length && !uploadMangmentService.uploadedFilesStatus.allfiles.length)\"\r\n [ngClass]=\"{'mt-44': source == 'faceRecognition'}\">\r\n <mat-icon class=\"text-primary mb-2 w-auto h-auto text-7xl\">file_upload</mat-icon>\r\n <h3 class=\"text-center text-lg mb-2 font-bold text-primary\" *ngIf=\"source != 'faceRecognition'\">{{'DRAGE_DROP' | translate}}</h3>\r\n <h3 class=\"text-center text-lg mb-2 font-bold text-primary\" *ngIf=\"source == 'faceRecognition'\">{{'faceRecognition.dragDropPhotos' | translate}}</h3>\r\n <h3 class=\"text-center text-lg mb-2 font-bold text-primary\">{{'OR' | translate}}</h3>\r\n <label class=\"cursor-pointer flex justify-center items-center bg-primary rounded-3xl text-white w-36 h-10\" (click)=\"triggerUpload()\">{{'BROSE_FILES' | translate}}</label>\r\n </div>\r\n</div>\r\n\r\n<!-- -->\r\n<div class=\"mt-2 text-lg text-primary font-bold flex justify-center items-center\" *ngIf=\"uploadMangmentService.uploadedFilesStatus.uploadInProgress\">\r\n <div>{{'UPLOADING' | translate}} {{uploadMangmentService.uploadedFilesStatus.numberOfUploadedFiles}}/{{uploadMangmentService.uploadedFilesStatus.numberOfFilesToBeUploaded}}</div>\r\n</div>\r\n<!-- showing uploading files progress -->\r\n", styles: [".iner-wrapping{height:calc(100% - 35px);overflow-y:auto;overflow-x:hidden}\n"], components: [{ type: i4.AttachmentItemComponent, selector: "app-attachment-item", inputs: ["item", "type", "showRemoveButton", "source", "personImageLink"], outputs: ["onRemovingItem"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i6.DragAndDropDirective, selector: "[appDragAndDrop]", outputs: ["fileDroped"] }, { type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i8.TranslatePipe } });
|
|
117
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: AttachmentsComponent, decorators: [{
|
|
118
|
+
type: Component,
|
|
119
|
+
args: [{
|
|
120
|
+
selector: 'app-attachments',
|
|
121
|
+
templateUrl: './attachments.component.html',
|
|
122
|
+
styleUrls: ['./attachments.component.scss']
|
|
123
|
+
}]
|
|
124
|
+
}], ctorParameters: function () { return [{ type: i1.UploadManagmentService }, { type: undefined, decorators: [{
|
|
125
|
+
type: Inject,
|
|
126
|
+
args: ['environment']
|
|
127
|
+
}] }, { type: i2.CustomToastrService }, { type: i3.AppConfigService }]; }, propDecorators: { allowedTypes: [{
|
|
128
|
+
type: Input
|
|
129
|
+
}], params: [{
|
|
130
|
+
type: Input
|
|
131
|
+
}], path: [{
|
|
132
|
+
type: Input
|
|
133
|
+
}], maxSize: [{
|
|
134
|
+
type: Input
|
|
135
|
+
}], docParams: [{
|
|
136
|
+
type: Input
|
|
137
|
+
}], multiple: [{
|
|
138
|
+
type: Input
|
|
139
|
+
}], createDocument: [{
|
|
140
|
+
type: Input
|
|
141
|
+
}], allowedMaxNumberOfFiles: [{
|
|
142
|
+
type: Input
|
|
143
|
+
}], source: [{
|
|
144
|
+
type: Input
|
|
145
|
+
}], uploadSuccess: [{
|
|
146
|
+
type: Output
|
|
147
|
+
}], uploadError: [{
|
|
148
|
+
type: Output
|
|
149
|
+
}], onSelectingItem: [{
|
|
150
|
+
type: Output
|
|
151
|
+
}], itemRemoved: [{
|
|
152
|
+
type: Output
|
|
153
|
+
}], fileInput: [{
|
|
154
|
+
type: ViewChild,
|
|
155
|
+
args: ['fileInput']
|
|
156
|
+
}] } });
|
|
157
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachments.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/attachment-modal/attachments/attachments.component.ts","../../../../../../../projects/nuxeo-development-framework/src/lib/components/attachment-modal/attachments/attachments.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { UploadManagmentService } from '../../../shared-services/upload-managment.service'\r\nimport { CustomToastrService } from '../../custom-toastr/services/custom-toastr.service';\r\nimport { AppConfigService } from '../../../configuration/app-config.service';\r\n\r\n@Component({\r\n  selector: 'app-attachments',\r\n  templateUrl: './attachments.component.html',\r\n  styleUrls: ['./attachments.component.scss']\r\n})\r\nexport class AttachmentsComponent implements OnInit {\r\n\r\n    /** Allowed Upload Types */\r\n    @Input()\r\n    allowedTypes = 'image/png,video/mp4,video/webm,application/pdf,application/vnd.ms-powerpoint,application/vnd.openxmlformats-officedocument.presentationml.presentation';\r\n    /** Params to be sent with properties when creating a document */\r\n    @Input()\r\n    params = {};\r\n    /** Path in witch a document will be created */\r\n    @Input()\r\n    path;\r\n    /** Max allowed upload size */\r\n    @Input()\r\n    maxSize = 104857600; // 1145728;\r\n    /** Params to be sent with body when creating a document */\r\n    @Input()\r\n    docParams = {};\r\n    /** Can upload multiple files at once */\r\n    @Input()\r\n    multiple = false;\r\n    /** should create document after batch upload */\r\n    @Input()\r\n    createDocument = true;\r\n    /** Max allowed number of files size */\r\n    @Input()\r\n    allowedMaxNumberOfFiles = 10;\r\n    // to do extra logic when source is new person dialog\r\n    @Input() source = '';\r\n    /** Event emitted on document upload success, it will have document or batch object based on configuration */\r\n    @Output()\r\n    uploadSuccess = new EventEmitter();\r\n    /** Event emitted when an error occurs while attempting upload */\r\n    @Output()\r\n    uploadError = new EventEmitter();\r\n\r\n    @Output() onSelectingItem = new EventEmitter();\r\n    uploading = false;\r\n\r\n    @Output() itemRemoved = new EventEmitter();\r\n    @ViewChild('fileInput') fileInput;\r\n  \r\n    activeFile={\r\n      name : ''\r\n    };\r\n  constructor(\r\n    public uploadMangmentService : UploadManagmentService ,\r\n    @Inject('environment') private environment, \r\n    private customToastrService : CustomToastrService , \r\n    public AppConfigService : AppConfigService) { \r\n    this.maxSize = this.environment.maxFileSize;\r\n    this.allowedTypes = this.environment.allowedFileTypes;\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  triggerUpload(): void {\r\n    this.fileInput.nativeElement.click();\r\n  }\r\n\r\n  isSizeChecked(file) {\r\n    if (file.size <= this.maxSize) {\r\n      return true;\r\n    }\r\n    else\r\n      this.customToastrService.show(\r\n        'error',\r\n        'error',\r\n        'ERRORS.SIZE',\r\n        {},\r\n        `${(this.maxSize / (1024 * 1024)).toFixed(2)}MB` \r\n      );\r\n    this.uploadError.next('errors.size');\r\n    return false;\r\n  }\r\n\r\n  isTypeChecked(file) {\r\n    let myAttachmentNameSections = file.name.split('.');\r\n    let fileType = myAttachmentNameSections[myAttachmentNameSections.length-1];\r\n    if(this.allowedTypes.includes(fileType.toLowerCase())){\r\n      return true\r\n    }\r\n    else {\r\n      this.customToastrService.show(\r\n        'error',\r\n        'error',\r\n        'ERRORS.TYPE',\r\n        {},\r\n        this.allowedTypes.replace(/./gi, '').toUpperCase()\r\n      );\r\n      this.uploadError.next('errors.type');\r\n      return false;\r\n    }\r\n  }\r\n\r\n  isMaxNumberOfFiles(selectedFiles) {\r\n    if (selectedFiles.length <= this.allowedMaxNumberOfFiles)\r\n      return true\r\n    else {\r\n      this.customToastrService.show(\r\n        'error',\r\n        'error',\r\n        'ERRORS.MAX_NUMBER_OF_FILES',\r\n        {},\r\n        this.allowedMaxNumberOfFiles\r\n      );\r\n      this.uploadError.next('errors.maxNumberOfFiles');\r\n      return false;\r\n    }\r\n  }\r\n\r\n  uploadingFiles(files): void {\r\n    let selectedFiles = Object.keys(files).map(key => files[key]);\r\n    selectedFiles = selectedFiles.filter(file => {\r\n      //if (this.isMaxNumberOfFiles(selectedFiles)) {\r\n        if (this.isSizeChecked(file)\r\n        && this.isTypeChecked(file)\r\n        ) {\r\n          return file;\r\n        }\r\n     // }\r\n    });\r\n    if (selectedFiles.length) {\r\n      if(this.source == 'faceRecognition') {\r\n        selectedFiles.forEach(e => {\r\n          let reader = new FileReader();\r\n          reader.readAsDataURL(e);\r\n          reader.onload = (_event) => {\r\n            e['previewLink'] = reader.result\r\n          }\r\n        })\r\n\r\n      }\r\n      this.uploading = true;\r\n      this.uploadMangmentService.uploadFilesMangment(selectedFiles);\r\n    }\r\n  }\r\n\r\n  removeItem(item , listofFiles){\r\n    const removeIndex = listofFiles.findIndex(file => file.name === item.name);\r\n    listofFiles.splice( removeIndex, 1 );\r\n    this.itemRemoved.emit(true);\r\n  }\r\n\r\n  selectItem(file){\r\n    this.activeFile = file;\r\n    this.onSelectingItem.emit(file);\r\n  }\r\n\r\n}\r\n","<div id=\"anything\"></div>\r\n<div class=\"iner-wrapping  border drop-zone w-full p-5  border-solid  relative\" \r\n     appDragAndDrop (fileDroped)=\"uploadingFiles($event)\"\r\n    [ngClass]=\"{'border-accent-200 bg-accent-50  hover:bg-accent-100' : AppConfigService.theme === 'ksreleif' , 'border-primary-200 bg-primary-50 hover:bg-primary-200' : AppConfigService.theme === 'dgda',\r\n    'flex justify-center items-center': source != 'faceRecognition'}\">\r\n\r\n    <div class=\"flex flex-wrap mt-3 w-full justify-start \"\r\n    [ngClass]=\"{'absolute top-2 left-3 right-3': source != 'faceRecognition'}\">\r\n        <div class=\"mx-2 mb-2 z-50\"  *ngFor=\"let file of uploadMangmentService.uploadedFilesStatus.uploadedFiles\"\r\n        [ngClass]=\"{'bg-primary-100' : file.name === activeFile.name, 'h-15': source != 'faceRecognition', \r\n        'h-52': source == 'faceRecognition'}\">\r\n            <app-attachment-item [item]=\"file\"  [type]=\"'batch'\" [source]=\"source\" [personImageLink]=\"file?.previewLink\"\r\n            (onRemovingItem)=\"removeItem($event , uploadMangmentService.uploadedFilesStatus.uploadedFiles)\" \r\n            (click)=\"selectItem(file)\"></app-attachment-item>\r\n        </div>\r\n    \r\n        <div class=\"mx-2 mb-2 z-50\"  *ngFor=\"let file of uploadMangmentService.uploadedFilesStatus.allfiles\"\r\n        [ngClass]=\"{'bg-primary-100' : file.name === activeFile.name,'h-15': source != 'faceRecognition', \r\n        'h-52': source == 'faceRecognition'}\">\r\n            <app-attachment-item [item]=\"file\" [type]=\"'file'\" [source]=\"source\" [personImageLink]=\"file?.previewLink\"\r\n            (onRemovingItem)=\"removeItem($event , uploadMangmentService.uploadedFilesStatus.allfiles)\" \r\n            (click)=\"selectItem(file)\"></app-attachment-item>\r\n        </div>\r\n    </div>\r\n\r\n    <input class=\"opacity-0 absolute -inset-0 w-full cursor-pointer\" type=\"file\" #fileInput id=\"fileInput\" [accept]=\"allowedTypes\" [multiple]=\"multiple\" (change)=\"uploadingFiles($event.target.files)\" >\r\n    <div class=\"flex justify-center items-center flex-col\" *ngIf=\"uploadMangmentService.uploadedFilesStatus.numberOfFilesToBeUploaded === 0 || (source == 'faceRecognition' && !uploadMangmentService.uploadedFilesStatus.uploadedFiles.length && !uploadMangmentService.uploadedFilesStatus.allfiles.length)\"\r\n    [ngClass]=\"{'mt-44': source == 'faceRecognition'}\">\r\n        <mat-icon class=\"text-primary mb-2 w-auto h-auto text-7xl\">file_upload</mat-icon>\r\n        <h3 class=\"text-center text-lg mb-2 font-bold text-primary\" *ngIf=\"source != 'faceRecognition'\">{{'DRAGE_DROP' | translate}}</h3>\r\n        <h3 class=\"text-center text-lg mb-2 font-bold text-primary\" *ngIf=\"source == 'faceRecognition'\">{{'faceRecognition.dragDropPhotos' | translate}}</h3>\r\n        <h3 class=\"text-center text-lg mb-2 font-bold text-primary\">{{'OR' | translate}}</h3>\r\n        <label class=\"cursor-pointer flex justify-center items-center bg-primary rounded-3xl text-white w-36 h-10\" (click)=\"triggerUpload()\">{{'BROSE_FILES' | translate}}</label>\r\n    </div>\r\n</div>\r\n\r\n<!--  -->\r\n<div class=\"mt-2 text-lg text-primary font-bold flex justify-center items-center\" *ngIf=\"uploadMangmentService.uploadedFilesStatus.uploadInProgress\">\r\n    <div>{{'UPLOADING' | translate}} {{uploadMangmentService.uploadedFilesStatus.numberOfUploadedFiles}}/{{uploadMangmentService.uploadedFilesStatus.numberOfFilesToBeUploaded}}</div>\r\n</div>\r\n<!-- showing uploading files progress  -->\r\n"]}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
|
+
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/material/dialog";
|
|
5
|
+
import * as i2 from "@ngx-translate/core";
|
|
6
|
+
export class ConfirmationDialogComponent {
|
|
7
|
+
constructor(data, dialofRef) {
|
|
8
|
+
this.data = data;
|
|
9
|
+
this.dialofRef = dialofRef;
|
|
10
|
+
}
|
|
11
|
+
ngOnInit() {
|
|
12
|
+
}
|
|
13
|
+
executeFunction(answer) {
|
|
14
|
+
this.dialofRef.close(answer);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
ConfirmationDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: ConfirmationDialogComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
18
|
+
ConfirmationDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: ConfirmationDialogComponent, selector: "app-confirmation-dialog", ngImport: i0, template: "<!-- <div class=\"confirmation-dialog-contianer\">\r\n <div class=\"conf-title text-center text-gray-900 text-xl mb-5\">\r\n {{data.title | translate}}\r\n </div>\r\n <div class=\"conf-message text-center text-gray-900 text-lg mb-5\">\r\n {{data.message | translate}}\r\n </div>\r\n <div class=\"conf-actions d-flex justify-around items-center\">\r\n <button class=\"hover:text-gray-900 border-2 hover:border-gray-900 hover:bg-white w-30 bg-gray-900 text-white h-10 rounded-lg\" (click)=\"executeFunction(false)\">{{'BUTTONS.No' | translate}}</button>\r\n <button class=\"hover:text-gray-900 border-2 hover:border-gray-900 hover:bg-white w-30 bg-gray-900 text-white h-10 rounded-lg\" (click)=\"executeFunction(true)\">{{'BUTTONS.Yes' | translate}}</button>\r\n </div>\r\n</div> -->\r\n\r\n<div class=\"d-flex px-0 mb-5 h-24\">\r\n <img class=\"w-14 h-14\" src=\"assets/images/thumbnails/warning.png\">\r\n <div class=\"px-3 mt-3\">\r\n <span class=\"text-xl font-medium \">{{data.title | translate}}</span>\r\n <div class=\"text-lg text-secondary text-base mt-2 sub-title\">{{data.message | translate}}</div>\r\n </div>\r\n </div> \r\n<div class=\"conf-actions d-flex justify-end items-center px-0\">\r\n <button class=\"mx-2 cancelation-button w-1/3\" (click)=\"executeFunction(false)\">{{data.cancelButton | translate}}</button>\r\n <button class=\"mx-2 submission-button w-1/3\" (click)=\"executeFunction(true)\">{{data.confirmButton | translate}}</button>\r\n</div>", styles: [""], pipes: { "translate": i2.TranslatePipe } });
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: ConfirmationDialogComponent, decorators: [{
|
|
20
|
+
type: Component,
|
|
21
|
+
args: [{
|
|
22
|
+
selector: 'app-confirmation-dialog',
|
|
23
|
+
templateUrl: './confirmation-dialog.component.html',
|
|
24
|
+
styleUrls: ['./confirmation-dialog.component.scss']
|
|
25
|
+
}]
|
|
26
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
27
|
+
type: Inject,
|
|
28
|
+
args: [MAT_DIALOG_DATA]
|
|
29
|
+
}] }, { type: i1.MatDialogRef }]; } });
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybWF0aW9uLWRpYWxvZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL2NvbmZpcm1hdGlvbi1kaWFsb2cvY29uZmlybWF0aW9uLWRpYWxvZy9jb25maXJtYXRpb24tZGlhbG9nLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvY29uZmlybWF0aW9uLWRpYWxvZy9jb25maXJtYXRpb24tZGlhbG9nL2NvbmZpcm1hdGlvbi1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDMUQsT0FBTyxFQUFFLGVBQWUsRUFBZ0IsTUFBTSwwQkFBMEIsQ0FBQzs7OztBQU96RSxNQUFNLE9BQU8sMkJBQTJCO0lBRXRDLFlBQTRDLElBQUksRUFBVyxTQUFxRDtRQUFwRSxTQUFJLEdBQUosSUFBSSxDQUFBO1FBQVcsY0FBUyxHQUFULFNBQVMsQ0FBNEM7SUFBSSxDQUFDO0lBRXJILFFBQVE7SUFDUixDQUFDO0lBRUQsZUFBZSxDQUFDLE1BQU07UUFDcEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDL0IsQ0FBQzs7d0hBVFUsMkJBQTJCLGtCQUVsQixlQUFlOzRHQUZ4QiwyQkFBMkIsK0RDUnhDLHNnREF1Qk07MkZEZk8sMkJBQTJCO2tCQUx2QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx5QkFBeUI7b0JBQ25DLFdBQVcsRUFBRSxzQ0FBc0M7b0JBQ25ELFNBQVMsRUFBRSxDQUFDLHNDQUFzQyxDQUFDO2lCQUNwRDs7MEJBR2MsTUFBTTsyQkFBQyxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbmplY3QsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNQVRfRElBTE9HX0RBVEEsIE1hdERpYWxvZ1JlZiB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC1jb25maXJtYXRpb24tZGlhbG9nJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vY29uZmlybWF0aW9uLWRpYWxvZy5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vY29uZmlybWF0aW9uLWRpYWxvZy5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDb25maXJtYXRpb25EaWFsb2dDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuICBjb25zdHJ1Y3RvcihASW5qZWN0KE1BVF9ESUFMT0dfREFUQSkgcHVibGljIGRhdGEgLCBwcml2YXRlIGRpYWxvZlJlZiA6IE1hdERpYWxvZ1JlZjxDb25maXJtYXRpb25EaWFsb2dDb21wb25lbnQ+KSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgfVxyXG5cclxuICBleGVjdXRlRnVuY3Rpb24oYW5zd2VyKXtcclxuICAgIHRoaXMuZGlhbG9mUmVmLmNsb3NlKGFuc3dlcik7XHJcbiAgfVxyXG59XHJcbiIsIjwhLS0gPGRpdiBjbGFzcz1cImNvbmZpcm1hdGlvbi1kaWFsb2ctY29udGlhbmVyXCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwiY29uZi10aXRsZSB0ZXh0LWNlbnRlciB0ZXh0LWdyYXktOTAwIHRleHQteGwgbWItNVwiPlxyXG4gICAgICAgIHt7ZGF0YS50aXRsZSB8IHRyYW5zbGF0ZX19XHJcbiAgICA8L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJjb25mLW1lc3NhZ2UgdGV4dC1jZW50ZXIgdGV4dC1ncmF5LTkwMCB0ZXh0LWxnIG1iLTVcIj5cclxuICAgICAgICB7e2RhdGEubWVzc2FnZSB8IHRyYW5zbGF0ZX19XHJcbiAgICA8L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJjb25mLWFjdGlvbnMgZC1mbGV4IGp1c3RpZnktYXJvdW5kIGl0ZW1zLWNlbnRlclwiPlxyXG4gICAgICAgIDxidXR0b24gY2xhc3M9XCJob3Zlcjp0ZXh0LWdyYXktOTAwIGJvcmRlci0yIGhvdmVyOmJvcmRlci1ncmF5LTkwMCBob3ZlcjpiZy13aGl0ZSB3LTMwIGJnLWdyYXktOTAwIHRleHQtd2hpdGUgaC0xMCByb3VuZGVkLWxnXCIgKGNsaWNrKT1cImV4ZWN1dGVGdW5jdGlvbihmYWxzZSlcIj57eydCVVRUT05TLk5vJyB8IHRyYW5zbGF0ZX19PC9idXR0b24+XHJcbiAgICAgICAgPGJ1dHRvbiBjbGFzcz1cImhvdmVyOnRleHQtZ3JheS05MDAgYm9yZGVyLTIgaG92ZXI6Ym9yZGVyLWdyYXktOTAwIGhvdmVyOmJnLXdoaXRlIHctMzAgYmctZ3JheS05MDAgdGV4dC13aGl0ZSBoLTEwIHJvdW5kZWQtbGdcIiAoY2xpY2spPVwiZXhlY3V0ZUZ1bmN0aW9uKHRydWUpXCI+e3snQlVUVE9OUy5ZZXMnIHwgdHJhbnNsYXRlfX08L2J1dHRvbj5cclxuICAgIDwvZGl2PlxyXG48L2Rpdj4gLS0+XHJcblxyXG48ZGl2IGNsYXNzPVwiZC1mbGV4IHB4LTAgbWItNSBoLTI0XCI+XHJcbiAgICA8aW1nIGNsYXNzPVwidy0xNCBoLTE0XCIgc3JjPVwiYXNzZXRzL2ltYWdlcy90aHVtYm5haWxzL3dhcm5pbmcucG5nXCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwicHgtMyBtdC0zXCI+XHJcbiAgICAgICA8c3BhbiBjbGFzcz1cInRleHQteGwgZm9udC1tZWRpdW0gXCI+e3tkYXRhLnRpdGxlIHwgdHJhbnNsYXRlfX08L3NwYW4+XHJcbiAgICAgICA8ZGl2IGNsYXNzPVwidGV4dC1sZyB0ZXh0LXNlY29uZGFyeSB0ZXh0LWJhc2UgbXQtMiBzdWItdGl0bGVcIj57e2RhdGEubWVzc2FnZSB8IHRyYW5zbGF0ZX19PC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuIDwvZGl2PiBcclxuPGRpdiBjbGFzcz1cImNvbmYtYWN0aW9ucyBkLWZsZXgganVzdGlmeS1lbmQgaXRlbXMtY2VudGVyIHB4LTBcIj5cclxuICAgPGJ1dHRvbiBjbGFzcz1cIm14LTIgY2FuY2VsYXRpb24tYnV0dG9uIHctMS8zXCIgKGNsaWNrKT1cImV4ZWN1dGVGdW5jdGlvbihmYWxzZSlcIj57e2RhdGEuY2FuY2VsQnV0dG9uIHwgdHJhbnNsYXRlfX08L2J1dHRvbj5cclxuICAgPGJ1dHRvbiBjbGFzcz1cIm14LTIgc3VibWlzc2lvbi1idXR0b24gdy0xLzNcIiAoY2xpY2spPVwiZXhlY3V0ZUZ1bmN0aW9uKHRydWUpXCI+e3tkYXRhLmNvbmZpcm1CdXR0b24gfCB0cmFuc2xhdGV9fTwvYnV0dG9uPlxyXG48L2Rpdj4iXX0=
|