nuxeo-development-framework 3.6.7 → 3.6.9
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 +22 -10
- package/bundles/nuxeo-development-framework.umd.js.map +1 -1
- package/esm2015/lib/components/correspondence-relation/components/versions/versions.component.js +22 -13
- package/esm2015/lib/components/notifications/components/notifications-button/notifications-button.component.js +8 -4
- package/fesm2015/nuxeo-development-framework.js +17 -6
- package/fesm2015/nuxeo-development-framework.js.map +1 -1
- package/lib/components/correspondence-relation/components/versions/versions.component.d.ts +9 -3
- package/lib/components/notifications/components/notifications-button/notifications-button.component.d.ts +2 -1
- package/package.json +1 -1
package/esm2015/lib/components/correspondence-relation/components/versions/versions.component.js
CHANGED
|
@@ -1,14 +1,15 @@
|
|
|
1
1
|
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "../../services/viewer-files.service";
|
|
4
|
-
import * as i2 from "
|
|
5
|
-
import * as i3 from "
|
|
6
|
-
import * as i4 from "
|
|
7
|
-
import * as i5 from "../../../../shared/components/
|
|
8
|
-
import * as i6 from "
|
|
9
|
-
import * as i7 from "
|
|
10
|
-
import * as i8 from "
|
|
11
|
-
import * as i9 from "
|
|
4
|
+
import * as i2 from "../../../../Core/services/translation/translation.service";
|
|
5
|
+
import * as i3 from "../../../documents/services/documents.service";
|
|
6
|
+
import * as i4 from "@angular/material/list";
|
|
7
|
+
import * as i5 from "../../../../shared/components/item-list/item-list.component";
|
|
8
|
+
import * as i6 from "../../../../shared/components/no-data/no-data.component";
|
|
9
|
+
import * as i7 from "@angular/common";
|
|
10
|
+
import * as i8 from "../../../../directive/permissions/permissions.directive";
|
|
11
|
+
import * as i9 from "@ngx-translate/core";
|
|
12
|
+
import * as i10 from "../../../../pipes/localized-date.pipe";
|
|
12
13
|
/**
|
|
13
14
|
* A component that views document versions
|
|
14
15
|
* @title
|
|
@@ -23,11 +24,13 @@ import * as i9 from "../../../../pipes/localized-date.pipe";
|
|
|
23
24
|
* ></cts-versions>
|
|
24
25
|
*/
|
|
25
26
|
export class VersionsComponent {
|
|
26
|
-
constructor(viewerFilesService, documentsApi) {
|
|
27
|
+
constructor(viewerFilesService, trnaslationService, documentsApi) {
|
|
27
28
|
this.viewerFilesService = viewerFilesService;
|
|
29
|
+
this.trnaslationService = trnaslationService;
|
|
28
30
|
this.documentsApi = documentsApi;
|
|
29
31
|
this.handleActions = new EventEmitter();
|
|
30
32
|
this.versions = [];
|
|
33
|
+
this.isArabic = false;
|
|
31
34
|
}
|
|
32
35
|
ngOnChanges(changes) {
|
|
33
36
|
if (changes.file && changes.file.currentValue &&
|
|
@@ -36,6 +39,9 @@ export class VersionsComponent {
|
|
|
36
39
|
}
|
|
37
40
|
}
|
|
38
41
|
ngOnInit() {
|
|
42
|
+
this.langSubscription = this.trnaslationService.isArabic$.subscribe(res => {
|
|
43
|
+
this.isArabic = res;
|
|
44
|
+
});
|
|
39
45
|
this.getVersions();
|
|
40
46
|
}
|
|
41
47
|
getVersion(version) {
|
|
@@ -55,9 +61,12 @@ export class VersionsComponent {
|
|
|
55
61
|
handleAction(event) {
|
|
56
62
|
this.handleActions.emit(event);
|
|
57
63
|
}
|
|
64
|
+
ngOnDestroy() {
|
|
65
|
+
this.langSubscription ? this.langSubscription.unsubscribe() : null;
|
|
66
|
+
}
|
|
58
67
|
}
|
|
59
|
-
VersionsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: VersionsComponent, deps: [{ token: i1.ViewerFilesService }, { token: i2.DocumentsService }], target: i0.ɵɵFactoryTarget.Component });
|
|
60
|
-
VersionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: VersionsComponent, selector: "cts-versions", inputs: { selectedVersion: "selectedVersion", file: "file", actions: "actions" }, outputs: { handleActions: "handleActions" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"flex flex-col\">\r\n<div class=\"viewer-attachments\">\r\n <div class=\"subheader\">\r\n <div> {{ \"viewer.current\" | translate }}</div>\r\n\r\n </div>\r\n <div class=\"attachments-list\">\r\n <mat-list>\r\n <div class=\"mat-list-items\">\r\n <cts-item-list [item]=\"file\" [title]=\"file.title\" [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\"\r\n [actions]=\"actions\" (itemClicked)=\"showVersion(file)\" (actionclicked)=\"handleAction($event)\">\r\n <div class=\"description\">\r\n {{getVersion(file)}}\r\n -\r\n {{ file.lastModified | localizedDate }}\r\n </div>\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments original-section\" *ngIf=\"versions.length > 0\">\r\n <div class=\"subheader\">\r\n <div>{{ \"viewer.origin\" | translate }}</div>\r\n </div>\r\n <div class=\"attachments-list\">\r\n <mat-list>\r\n <div class=\"mat-list-items\">\r\n <cts-item-list [item]=\"versions[versions.length -1]\" [title]=\"versions[versions.length -1].title\"\r\n [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\" [actions]=\"actions\"\r\n (itemClicked)=\"showVersion(versions[versions.length -1])\" (actionclicked)=\"handleAction($event)\">\r\n\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments\" *permission=\"{name: 'viewVersions', entity: file}\">\r\n <div class=\"subheader\">\r\n <div> {{ \"viewer.history\" | translate }}</div>\r\n\r\n </div>\r\n <div class=\"attachments-list\" *ngIf=\"versions.length > 0\">\r\n <ng-container>\r\n\r\n\r\n <mat-list>\r\n <div class=\"mat-list-items\" *ngFor=\"let version of versions ;let cnt = count; let i = index\">\r\n <cts-item-list [item]=\"version\" [title]=\"version.title + '-' + getVersion(version)\" [iconname]=\"'description'\"\r\n [moreclasses]=\"'text-danger'\" (itemClicked)=\"showVersion(version)\" [actions]=\"actions\" (actionclicked)=\"handleAction($event)\">\r\n <div class=\"description\">\r\n {{getVersion(version)}}\r\n -\r\n {{ version.lastModified | localizedDate }}\r\n <span class=\"font-weight-bold\">\r\n\r\n {{\r\n version.properties.lastContributor.id === 'system' ?\r\n ('SYSTEM_ADMIN' | translate) :\r\n version.properties.lastContributor.properties.firstName +\r\n \" \" +\r\n version.properties.lastContributor.properties.lastName\r\n }}\r\n </span>\r\n </div>\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </ng-container>\r\n </div>\r\n <div *ngIf=\"versions.length === 0\">\r\n <cts-no-data></cts-no-data>\r\n </div>\r\n</div>\r\n</div>\r\n<ng-template #noEntry>\r\n\r\n</ng-template>", styles: [""], components: [{ type:
|
|
68
|
+
VersionsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: VersionsComponent, deps: [{ token: i1.ViewerFilesService }, { token: i2.TranslationService }, { token: i3.DocumentsService }], target: i0.ɵɵFactoryTarget.Component });
|
|
69
|
+
VersionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: VersionsComponent, selector: "cts-versions", inputs: { selectedVersion: "selectedVersion", file: "file", actions: "actions" }, outputs: { handleActions: "handleActions" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"flex flex-col\">\r\n<div class=\"viewer-attachments\">\r\n <div class=\"subheader\">\r\n <div> {{ \"viewer.current\" | translate }}</div>\r\n\r\n </div>\r\n <div class=\"attachments-list\">\r\n <mat-list>\r\n <div class=\"mat-list-items\">\r\n <cts-item-list [item]=\"file\" [title]=\"file.title\" [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\"\r\n [actions]=\"actions\" (itemClicked)=\"showVersion(file)\" (actionclicked)=\"handleAction($event)\">\r\n <div class=\"description\">\r\n {{getVersion(file)}}\r\n -\r\n {{ file.lastModified | localizedDate : '' : (isArabic? 'ar-AR' : 'en-US') }}\r\n </div>\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments original-section\" *ngIf=\"versions.length > 0\">\r\n <div class=\"subheader\">\r\n <div>{{ \"viewer.origin\" | translate }}</div>\r\n </div>\r\n <div class=\"attachments-list\">\r\n <mat-list>\r\n <div class=\"mat-list-items\">\r\n <cts-item-list [item]=\"versions[versions.length -1]\" [title]=\"versions[versions.length -1].title\"\r\n [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\" [actions]=\"actions\"\r\n (itemClicked)=\"showVersion(versions[versions.length -1])\" (actionclicked)=\"handleAction($event)\">\r\n\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments\" *permission=\"{name: 'viewVersions', entity: file}\">\r\n <div class=\"subheader\">\r\n <div> {{ \"viewer.history\" | translate }}</div>\r\n\r\n </div>\r\n <div class=\"attachments-list\" *ngIf=\"versions.length > 0\">\r\n <ng-container>\r\n\r\n\r\n <mat-list>\r\n <div class=\"mat-list-items\" *ngFor=\"let version of versions ;let cnt = count; let i = index\">\r\n <cts-item-list [item]=\"version\" [title]=\"version.title + '-' + getVersion(version)\" [iconname]=\"'description'\"\r\n [moreclasses]=\"'text-danger'\" (itemClicked)=\"showVersion(version)\" [actions]=\"actions\" (actionclicked)=\"handleAction($event)\">\r\n <div class=\"description\">\r\n {{getVersion(version)}}\r\n -\r\n {{ version.lastModified | localizedDate : '' : (isArabic? 'ar-AR' : 'en-US') }}\r\n <span class=\"font-weight-bold\">\r\n\r\n {{\r\n version.properties.lastContributor.id === 'system' ?\r\n ('SYSTEM_ADMIN' | translate) :\r\n version.properties.lastContributor.properties.firstName +\r\n \" \" +\r\n version.properties.lastContributor.properties.lastName\r\n }}\r\n </span>\r\n </div>\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </ng-container>\r\n </div>\r\n <div *ngIf=\"versions.length === 0\">\r\n <cts-no-data></cts-no-data>\r\n </div>\r\n</div>\r\n</div>\r\n<ng-template #noEntry>\r\n\r\n</ng-template>", styles: [""], components: [{ type: i4.MatList, selector: "mat-list, mat-action-list", inputs: ["disableRipple", "disabled"], exportAs: ["matList"] }, { type: i5.ItemListComponent, selector: "cts-item-list", inputs: ["item", "iconname", "title", "actions", "isselected", "moreclasses"], outputs: ["itemClicked", "actionclicked"] }, { type: i6.NoDataComponent, selector: "cts-no-data", inputs: ["message", "border", "img"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.PermissionsDirective, selector: "[permission]", inputs: ["permission"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i9.TranslatePipe, "localizedDate": i10.LocalizedDatePipe } });
|
|
61
70
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: VersionsComponent, decorators: [{
|
|
62
71
|
type: Component,
|
|
63
72
|
args: [{
|
|
@@ -65,7 +74,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
65
74
|
templateUrl: './versions.component.html',
|
|
66
75
|
styleUrls: ['./versions.component.scss']
|
|
67
76
|
}]
|
|
68
|
-
}], ctorParameters: function () { return [{ type: i1.ViewerFilesService }, { type: i2.DocumentsService }]; }, propDecorators: { selectedVersion: [{
|
|
77
|
+
}], ctorParameters: function () { return [{ type: i1.ViewerFilesService }, { type: i2.TranslationService }, { type: i3.DocumentsService }]; }, propDecorators: { selectedVersion: [{
|
|
69
78
|
type: Input
|
|
70
79
|
}], file: [{
|
|
71
80
|
type: Input
|
|
@@ -74,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
74
83
|
}], handleActions: [{
|
|
75
84
|
type: Output
|
|
76
85
|
}] } });
|
|
77
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"versions.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/versions/versions.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/versions/versions.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAoC,YAAY,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;;AAKzG;;;;;;;;;;;;GAYG;AAMH,MAAM,OAAO,iBAAiB;IAa5B,YACU,kBAAsC,EACtC,YAA8B;QAD9B,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,iBAAY,GAAZ,YAAY,CAAkB;QAJxC,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QACnC,aAAQ,GAAG,EAAE,CAAC;IAKV,CAAC;IACL,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,YAAY;YAC3C,OAAO,CAAC,IAAI,CAAC,aAAa,EAAE;YAC5B,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,UAAU,CAAC,OAAO;QAChB,IAAI,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7K,IAAI,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7K,OAAO,GAAG,MAAM,IAAI,MAAM,EAAE,CAAC;IAC/B,CAAC;IACD,WAAW;QACT,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YAC9D,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACvC,yBAAyB;QAE3B,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW,CAAC,OAAO;QACjB,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACrD,CAAC;IAED,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAChC,CAAC;;8GAhDU,iBAAiB;kGAAjB,iBAAiB,wMCvB9B,w9FA+Ec;2FDxDD,iBAAiB;kBAL7B,SAAS;mBAAC;oBACT,QAAQ,EAAE,cAAc;oBACxB,WAAW,EAAE,2BAA2B;oBACxC,SAAS,EAAE,CAAC,2BAA2B,CAAC;iBACzC;wIAIC,eAAe;sBADd,KAAK;gBAIN,IAAI;sBADH,KAAK;gBAIN,OAAO;sBADN,KAAK;gBAGN,aAAa;sBADZ,MAAM","sourcesContent":["import { Component, Input, Output, OnChanges, OnInit, SimpleChanges, EventEmitter } from '@angular/core';\r\nimport { DocumentsService } from '../../../documents/services/documents.service';\r\nimport { ViewerFilesService } from '../../services/viewer-files.service';\r\n\r\n\r\n/**\r\n * A component that views document versions\r\n * @title\r\n * Viewer Versions\r\n *\r\n * @example\r\n *\r\n * <cts-versions\r\n *   [file]=\"file\"\r\n *   [actions]=\"menu_actions\"\r\n *   (handleActions)=\"handleActionOnVersion($event)\"\r\n * ></cts-versions>\r\n */\r\n@Component({\r\n  selector: 'cts-versions',\r\n  templateUrl: './versions.component.html',\r\n  styleUrls: ['./versions.component.scss']\r\n})\r\nexport class VersionsComponent implements OnInit, OnChanges {\r\n  /** Current selected version (in viewer) */\r\n  @Input()\r\n  selectedVersion;\r\n  /** Document object */\r\n  @Input()\r\n  file;\r\n/** Actions on Version */\r\n  @Input()\r\n  actions?: string[];\r\n  @Output()\r\n  handleActions = new EventEmitter();\r\n  versions = [];\r\n  constructor(\r\n    private viewerFilesService: ViewerFilesService,\r\n    private documentsApi: DocumentsService\r\n\r\n  ) { }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.file && changes.file.currentValue &&\r\n      changes.file.previousValue) {\r\n      this.getVersions();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.getVersions();\r\n  }\r\n\r\n  getVersion(version) {\r\n    let majVer = version.properties.major_version ? version.properties.major_version : ( version.properties['uid:major_version'] ?  version.properties['uid:major_version'] : 0);\r\n    let minVer = version.properties.minor_version ? version.properties.minor_version : ( version.properties['uid:minor_version'] ?  version.properties['uid:minor_version'] : 0);\r\n    return `${majVer}.${minVer}`;\r\n  }\r\n  getVersions() {\r\n    this.documentsApi.getVersions(this.file.uid).subscribe((data) => {\r\n      this.versions = data.entries.reverse();\r\n      // this.versions.shift();\r\n\r\n    });\r\n  }\r\n\r\n  showVersion(version) {\r\n    this.viewerFilesService.updateViewer.next(version);\r\n  }\r\n\r\n  handleAction(event) {\r\n    this.handleActions.emit(event)\r\n  }\r\n}\r\n","<div class=\"flex flex-col\">\r\n<div class=\"viewer-attachments\">\r\n  <div class=\"subheader\">\r\n    <div> {{ \"viewer.current\" | translate }}</div>\r\n\r\n  </div>\r\n  <div class=\"attachments-list\">\r\n    <mat-list>\r\n      <div class=\"mat-list-items\">\r\n        <cts-item-list [item]=\"file\" [title]=\"file.title\" [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\"\r\n          [actions]=\"actions\" (itemClicked)=\"showVersion(file)\" (actionclicked)=\"handleAction($event)\">\r\n          <div class=\"description\">\r\n            {{getVersion(file)}}\r\n            -\r\n            {{ file.lastModified | localizedDate }}\r\n          </div>\r\n        </cts-item-list>\r\n      </div>\r\n    </mat-list>\r\n  </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments original-section\" *ngIf=\"versions.length > 0\">\r\n  <div class=\"subheader\">\r\n    <div>{{ \"viewer.origin\" | translate }}</div>\r\n  </div>\r\n  <div class=\"attachments-list\">\r\n    <mat-list>\r\n      <div class=\"mat-list-items\">\r\n        <cts-item-list [item]=\"versions[versions.length -1]\" [title]=\"versions[versions.length -1].title\"\r\n          [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\" [actions]=\"actions\"\r\n          (itemClicked)=\"showVersion(versions[versions.length -1])\" (actionclicked)=\"handleAction($event)\">\r\n\r\n        </cts-item-list>\r\n      </div>\r\n    </mat-list>\r\n  </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments\" *permission=\"{name: 'viewVersions', entity: file}\">\r\n  <div class=\"subheader\">\r\n    <div> {{ \"viewer.history\" | translate }}</div>\r\n\r\n  </div>\r\n  <div class=\"attachments-list\" *ngIf=\"versions.length > 0\">\r\n    <ng-container>\r\n\r\n\r\n      <mat-list>\r\n        <div class=\"mat-list-items\" *ngFor=\"let version of versions ;let cnt = count; let i = index\">\r\n          <cts-item-list [item]=\"version\" [title]=\"version.title + '-' + getVersion(version)\" [iconname]=\"'description'\"\r\n            [moreclasses]=\"'text-danger'\" (itemClicked)=\"showVersion(version)\" [actions]=\"actions\" (actionclicked)=\"handleAction($event)\">\r\n            <div class=\"description\">\r\n              {{getVersion(version)}}\r\n              -\r\n              {{ version.lastModified | localizedDate }}\r\n              <span class=\"font-weight-bold\">\r\n\r\n                {{\r\n                version.properties.lastContributor.id === 'system' ?\r\n                ('SYSTEM_ADMIN' | translate) :\r\n                version.properties.lastContributor.properties.firstName +\r\n                \" \" +\r\n                version.properties.lastContributor.properties.lastName\r\n                }}\r\n              </span>\r\n            </div>\r\n          </cts-item-list>\r\n        </div>\r\n      </mat-list>\r\n    </ng-container>\r\n  </div>\r\n  <div *ngIf=\"versions.length === 0\">\r\n    <cts-no-data></cts-no-data>\r\n  </div>\r\n</div>\r\n</div>\r\n<ng-template #noEntry>\r\n\r\n</ng-template>"]}
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"versions.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/versions/versions.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/correspondence-relation/components/versions/versions.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAoC,YAAY,EAAa,MAAM,eAAe,CAAC;;;;;;;;;;;;AAOpH;;;;;;;;;;;;GAYG;AAMH,MAAM,OAAO,iBAAiB;IAe5B,YACU,kBAAsC,EACtC,kBAAuC,EACvC,YAA8B;QAF9B,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,uBAAkB,GAAlB,kBAAkB,CAAqB;QACvC,iBAAY,GAAZ,YAAY,CAAkB;QAPxC,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QACnC,aAAQ,GAAG,EAAE,CAAC;QACd,aAAQ,GAAG,KAAK,CAAC;IAOb,CAAC;IACL,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,YAAY;YAC3C,OAAO,CAAC,IAAI,CAAC,aAAa,EAAE;YAC5B,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,gBAAgB,GAAI,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YACzE,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC;QACtB,CAAC,CAAC,CAAA;QACF,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,UAAU,CAAC,OAAO;QAChB,IAAI,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7K,IAAI,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7K,OAAO,GAAG,MAAM,IAAI,MAAM,EAAE,CAAC;IAC/B,CAAC;IACD,WAAW;QACT,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YAC9D,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACvC,yBAAyB;QAE3B,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW,CAAC,OAAO;QACjB,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACrD,CAAC;IAED,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAChC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;IACrE,CAAC;;8GA1DU,iBAAiB;kGAAjB,iBAAiB,wMCzB9B,kiGA+Ec;2FDtDD,iBAAiB;kBAL7B,SAAS;mBAAC;oBACT,QAAQ,EAAE,cAAc;oBACxB,WAAW,EAAE,2BAA2B;oBACxC,SAAS,EAAE,CAAC,2BAA2B,CAAC;iBACzC;yKAIC,eAAe;sBADd,KAAK;gBAIN,IAAI;sBADH,KAAK;gBAIN,OAAO;sBADN,KAAK;gBAGN,aAAa;sBADZ,MAAM","sourcesContent":["import { Component, Input, Output, OnChanges, OnInit, SimpleChanges, EventEmitter, OnDestroy } from '@angular/core';\r\nimport { DocumentsService } from '../../../documents/services/documents.service';\r\nimport { ViewerFilesService } from '../../services/viewer-files.service';\r\nimport { TranslationService } from '../../../../Core/services/translation/translation.service';\r\nimport { Subscription } from 'rxjs';\r\n\r\n\r\n/**\r\n * A component that views document versions\r\n * @title\r\n * Viewer Versions\r\n *\r\n * @example\r\n *\r\n * <cts-versions\r\n *   [file]=\"file\"\r\n *   [actions]=\"menu_actions\"\r\n *   (handleActions)=\"handleActionOnVersion($event)\"\r\n * ></cts-versions>\r\n */\r\n@Component({\r\n  selector: 'cts-versions',\r\n  templateUrl: './versions.component.html',\r\n  styleUrls: ['./versions.component.scss']\r\n})\r\nexport class VersionsComponent implements OnInit, OnChanges , OnDestroy {\r\n  /** Current selected version (in viewer) */\r\n  @Input()\r\n  selectedVersion;\r\n  /** Document object */\r\n  @Input()\r\n  file;\r\n/** Actions on Version */\r\n  @Input()\r\n  actions?: string[];\r\n  @Output()\r\n  handleActions = new EventEmitter();\r\n  versions = [];\r\n  isArabic = false;\r\n  langSubscription : Subscription;\r\n  constructor(\r\n    private viewerFilesService: ViewerFilesService,\r\n    private trnaslationService : TranslationService,\r\n    private documentsApi: DocumentsService\r\n\r\n  ) { }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.file && changes.file.currentValue &&\r\n      changes.file.previousValue) {\r\n      this.getVersions();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.langSubscription =  this.trnaslationService.isArabic$.subscribe(res => {\r\n      this.isArabic = res;\r\n    })\r\n    this.getVersions();\r\n  }\r\n\r\n  getVersion(version) {\r\n    let majVer = version.properties.major_version ? version.properties.major_version : ( version.properties['uid:major_version'] ?  version.properties['uid:major_version'] : 0);\r\n    let minVer = version.properties.minor_version ? version.properties.minor_version : ( version.properties['uid:minor_version'] ?  version.properties['uid:minor_version'] : 0);\r\n    return `${majVer}.${minVer}`;\r\n  }\r\n  getVersions() {\r\n    this.documentsApi.getVersions(this.file.uid).subscribe((data) => {\r\n      this.versions = data.entries.reverse();\r\n      // this.versions.shift();\r\n\r\n    });\r\n  }\r\n\r\n  showVersion(version) {\r\n    this.viewerFilesService.updateViewer.next(version);\r\n  }\r\n\r\n  handleAction(event) {\r\n    this.handleActions.emit(event)\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.langSubscription ? this.langSubscription.unsubscribe() : null;\r\n  }\r\n}\r\n","<div class=\"flex flex-col\">\r\n<div class=\"viewer-attachments\">\r\n  <div class=\"subheader\">\r\n    <div> {{ \"viewer.current\" | translate }}</div>\r\n\r\n  </div>\r\n  <div class=\"attachments-list\">\r\n    <mat-list>\r\n      <div class=\"mat-list-items\">\r\n        <cts-item-list [item]=\"file\" [title]=\"file.title\" [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\"\r\n          [actions]=\"actions\" (itemClicked)=\"showVersion(file)\" (actionclicked)=\"handleAction($event)\">\r\n          <div class=\"description\">\r\n            {{getVersion(file)}}\r\n            -\r\n            {{ file.lastModified | localizedDate : '' : (isArabic? 'ar-AR' : 'en-US') }}\r\n          </div>\r\n        </cts-item-list>\r\n      </div>\r\n    </mat-list>\r\n  </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments original-section\" *ngIf=\"versions.length > 0\">\r\n  <div class=\"subheader\">\r\n    <div>{{ \"viewer.origin\" | translate }}</div>\r\n  </div>\r\n  <div class=\"attachments-list\">\r\n    <mat-list>\r\n      <div class=\"mat-list-items\">\r\n        <cts-item-list [item]=\"versions[versions.length -1]\" [title]=\"versions[versions.length -1].title\"\r\n          [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\" [actions]=\"actions\"\r\n          (itemClicked)=\"showVersion(versions[versions.length -1])\" (actionclicked)=\"handleAction($event)\">\r\n\r\n        </cts-item-list>\r\n      </div>\r\n    </mat-list>\r\n  </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments\" *permission=\"{name: 'viewVersions', entity: file}\">\r\n  <div class=\"subheader\">\r\n    <div> {{ \"viewer.history\" | translate }}</div>\r\n\r\n  </div>\r\n  <div class=\"attachments-list\" *ngIf=\"versions.length > 0\">\r\n    <ng-container>\r\n\r\n\r\n      <mat-list>\r\n        <div class=\"mat-list-items\" *ngFor=\"let version of versions ;let cnt = count; let i = index\">\r\n          <cts-item-list [item]=\"version\" [title]=\"version.title + '-' + getVersion(version)\" [iconname]=\"'description'\"\r\n            [moreclasses]=\"'text-danger'\" (itemClicked)=\"showVersion(version)\" [actions]=\"actions\" (actionclicked)=\"handleAction($event)\">\r\n            <div class=\"description\">\r\n              {{getVersion(version)}}\r\n              -\r\n              {{ version.lastModified | localizedDate : '' : (isArabic? 'ar-AR' : 'en-US') }}\r\n              <span class=\"font-weight-bold\">\r\n\r\n                {{\r\n                version.properties.lastContributor.id === 'system' ?\r\n                ('SYSTEM_ADMIN' | translate) :\r\n                version.properties.lastContributor.properties.firstName +\r\n                \" \" +\r\n                version.properties.lastContributor.properties.lastName\r\n                }}\r\n              </span>\r\n            </div>\r\n          </cts-item-list>\r\n        </div>\r\n      </mat-list>\r\n    </ng-container>\r\n  </div>\r\n  <div *ngIf=\"versions.length === 0\">\r\n    <cts-no-data></cts-no-data>\r\n  </div>\r\n</div>\r\n</div>\r\n<ng-template #noEntry>\r\n\r\n</ng-template>"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { __awaiter } from "tslib";
|
|
2
|
-
import { Component, EventEmitter, Output, ViewEncapsulation, } from "@angular/core";
|
|
2
|
+
import { Component, EventEmitter, Input, Output, ViewEncapsulation, } from "@angular/core";
|
|
3
3
|
import { take } from "rxjs/internal/operators/take";
|
|
4
4
|
import { NotificationToastComponent } from "../notification-toast/notification-toast.component";
|
|
5
5
|
import { first } from "rxjs/operators";
|
|
@@ -12,7 +12,8 @@ import * as i5 from "@angular/router";
|
|
|
12
12
|
import * as i6 from "../../../../Core/services/translation/translation.service";
|
|
13
13
|
import * as i7 from "@angular/material/menu";
|
|
14
14
|
import * as i8 from "../notifications-list/notifications-list.component";
|
|
15
|
-
import * as i9 from "@angular/
|
|
15
|
+
import * as i9 from "@angular/common";
|
|
16
|
+
import * as i10 from "@angular/material/badge";
|
|
16
17
|
export class NotificationsButtonComponent {
|
|
17
18
|
constructor(notificationsService, translate, toastr, TimeAgo, router, ref, translationService) {
|
|
18
19
|
this.notificationsService = notificationsService;
|
|
@@ -24,6 +25,7 @@ export class NotificationsButtonComponent {
|
|
|
24
25
|
this.translationService = translationService;
|
|
25
26
|
this.toastrClick = new EventEmitter();
|
|
26
27
|
this.listItemClick = new EventEmitter();
|
|
28
|
+
this.customNotificationIcon = null;
|
|
27
29
|
}
|
|
28
30
|
get notificationsCount() {
|
|
29
31
|
return this.notificationsService.notificationsCount;
|
|
@@ -155,7 +157,7 @@ export class NotificationsButtonComponent {
|
|
|
155
157
|
}
|
|
156
158
|
}
|
|
157
159
|
NotificationsButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: NotificationsButtonComponent, deps: [{ token: i1.NotificationsService }, { token: i2.TranslateService }, { token: i3.ToastrService }, { token: i4.TimeAgoPipe }, { token: i5.Router }, { token: i0.ChangeDetectorRef }, { token: i6.TranslationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
158
|
-
NotificationsButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: NotificationsButtonComponent, selector: "app-notifications-button", outputs: { toastrClick: "toastrClick", listItemClick: "listItemClick" }, ngImport: i0, template: "<div [matMenuTriggerFor]=\"langMenu\" class=\"notification\" (click)=\"getNotifications()\" class=\"search-wrapper\">\r\n <span matBadgeSize=\"small\" matBadge=\"{{ notificationsCount }}\"
|
|
160
|
+
NotificationsButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: NotificationsButtonComponent, selector: "app-notifications-button", inputs: { customNotificationIcon: "customNotificationIcon" }, outputs: { toastrClick: "toastrClick", listItemClick: "listItemClick" }, ngImport: i0, template: "<div [matMenuTriggerFor]=\"langMenu\" class=\"notification\" (click)=\"getNotifications()\" class=\"search-wrapper\">\r\n <span *ngIf=\"!customNotificationIcon;else customIcon\" matBadgeSize=\"small\" matBadge=\"{{ notificationsCount }}\"\r\n matBadgeColor=\"warn\" matbadgeposition=\"before\" class=\"bi bi-bell bell\"></span>\r\n</div>\r\n<mat-menu class=\"mat-menu-panel myMenu notification-list\" #langMenu=\"matMenu\">\r\n <app-notifications-list (listItemClick)=\"onListItemClick($event)\"></app-notifications-list>\r\n</mat-menu>\r\n\r\n<ng-template #customIcon>\r\n <ng-container *ngTemplateOutlet=\"customNotificationIcon\"></ng-container>\r\n</ng-template>", styles: [".notifications-count{background-color:#eee;border-radius:5px;color:#333;font-size:11px;padding:0 6px;box-sizing:border-box}.notification-list{max-width:450px!important;width:450px;height:66vh}.notification-list .mat-menu-content{padding:0!important;position:relative;height:calc(100% - 29px)}.notification-list .mat-menu-content .mat-toolbar{margin:0 0 -10px}.mat-menu-panel.myMenu{border-radius:5px!important;overflow:hidden}.notification .mat-icon{margin-right:0!important;vertical-align:middle}.toast-container{right:12px!important;bottom:12px!important;pointer-events:all}.toast-container .ngx-toastr{padding:25px!important;background-position:263px center;border-radius:5px!important;box-shadow:none!important}.toast-container .toast-title{font-weight:normal}.wrap{white-space:normal!important;font-size:14px!important;margin-bottom:8px!important}.mat-menu-content:not(:empty){padding-top:0;padding-bottom:0}[dir=rtl] .toast-container{left:12px!important;right:auto!important;direction:rtl;text-align:right}[dir=rtl] .toast-container .ngx-toastr{background-position:10px center}[dir=rtl] .toast-container .toast-close-button{float:left}.mat-badge-content{right:-4px!important;top:-1px!important}.rtl .mat-badge-content{font-weight:600;right:-6px!important;top:-5px!important}\n"], components: [{ type: i7.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i8.NotificationsListComponent, selector: "app-notifications-list", outputs: ["listItemClick"] }], directives: [{ type: i7.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["matMenuTriggerRestoreFocus", "mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i10.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgePosition", "matBadgeSize", "matBadgeColor", "matBadgeOverlap", "matBadgeDescription", "matBadgeHidden", "matBadge"] }, { type: i9.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
159
161
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: NotificationsButtonComponent, decorators: [{
|
|
160
162
|
type: Component,
|
|
161
163
|
args: [{
|
|
@@ -168,5 +170,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
168
170
|
type: Output
|
|
169
171
|
}], listItemClick: [{
|
|
170
172
|
type: Output
|
|
173
|
+
}], customNotificationIcon: [{
|
|
174
|
+
type: Input
|
|
171
175
|
}] } });
|
|
172
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifications-button.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-button/notifications-button.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-button/notifications-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewEncapsulation,\r\n} from \"@angular/core\";\r\nimport { Router } from \"@angular/router\";\r\nimport { TranslateService } from \"@ngx-translate/core\";\r\nimport { ActiveToast, ToastrService } from \"ngx-toastr\";\r\nimport { take } from \"rxjs/internal/operators/take\";\r\nimport { TimeAgoPipe } from \"../../../../pipes/time-ago.pipe\";\r\nimport { NotificationsService } from \"../../notifications.service\";\r\nimport { NotificationToastComponent } from \"../notification-toast/notification-toast.component\";\r\nimport { TranslationService } from \"../../../../Core/services/translation/translation.service\";\r\nimport { first } from \"rxjs/operators\";\r\n\r\n\r\n@Component({\r\n  selector: \"app-notifications-button\",\r\n  templateUrl: \"./notifications-button.component.html\",\r\n  styleUrls: [\"./notifications-button.component.scss\"],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class NotificationsButtonComponent implements OnInit, OnDestroy {\r\n  get notificationsCount() {\r\n    return this.notificationsService.notificationsCount;\r\n  }\r\n\r\n  subscription;\r\n  updater;\r\n  @Output()\r\n  toastrClick = new EventEmitter();\r\n  @Output()\r\n  listItemClick = new EventEmitter();\r\n  constructor(\r\n    public notificationsService: NotificationsService,\r\n    public translate: TranslateService,\r\n    public toastr: ToastrService,\r\n    public TimeAgo: TimeAgoPipe,\r\n    public router: Router,\r\n    private ref: ChangeDetectorRef,\r\n    private translationService: TranslationService\r\n  ) {}\r\n  /*\r\n  async openNotifications(event) {\r\n    const dir = this.translate.instant('dir');\r\n    const notificationsModal = await this.modalController.create({\r\n      cssClass: 'side-modal notifications',\r\n      enterAnimation: dir === 'rtl' ? slideInRtl : slideIn,\r\n      leaveAnimation: dir === 'rtl' ? slideOutRtl : slideOut,\r\n      component: NotificationsModalComponent,\r\n      showBackdrop: false\r\n    });\r\n    return await notificationsModal.present().then(() => {\r\n      this.notificationsService.resetCount();\r\n\r\n    });\r\n  }\r\n  */\r\n  getNotifications() {\r\n    this.notificationsService.resetNotifications()\r\n    this.notificationsService.fetchNotifications().subscribe(() => {\r\n      this.notificationsService.resetCount();\r\n    });\r\n  }\r\n  ngOnInit() {\r\n    this.subscription = this.notificationsService.listenerObserver.subscribe(\r\n      async (activity) => {\r\n        let ar = await this.translationService.isArabic\r\n          .pipe(first())\r\n          .toPromise();\r\n        let sourceType = activity.sourceType;\r\n        const isAssignmentOrApproval: boolean =\r\n          sourceType === \"approval\" || sourceType === \"assignment\";\r\n        const correspondence = sourceType === \"correspondence\";\r\n        const assignment = sourceType === \"assignment\";\r\n        const approval = sourceType === \"approval\";\r\n        const memo = sourceType === \"memo\";\r\n        const general = sourceType === \"general\";\r\n        const id = memo ? activity.sourceId : activity.data.correspondenceId;\r\n\r\n        this.showToastr(activity, ar)\r\n          .onTap.pipe(take(1))\r\n          .subscribe(() => {\r\n            this.notificationsService.updateStatus(activity, true);\r\n            if (activity.data?.correspondenceId) {\r\n              this.router.navigate(\r\n                [\r\n                  {\r\n                    outlets: {\r\n                      viewer: [\"view\", id],\r\n                    },\r\n                  },\r\n                ],\r\n                {\r\n                  queryParams: {\r\n                    location: this.router.url,\r\n                    ...(isAssignmentOrApproval && { approvalMode: true }),\r\n                    ...(assignment && {\r\n                      assignmentId: activity.data.assignmentId,\r\n                    }),\r\n                  },\r\n                }\r\n              );\r\n            }\r\n            if (memo) {\r\n              this.router.navigate([{ outlets: { viewer: [\"memo\", id] } }], {\r\n                queryParams: { location: this.router.url },\r\n              });\r\n            }\r\n            this.toastrClick.next(activity);\r\n          });\r\n        this.ref.markForCheck();\r\n      }\r\n    );\r\n\r\n    this.updater = this.notificationsService.update.subscribe((data) => {\r\n      this.ref.detectChanges();\r\n    });\r\n    // setTimeout(() => {\r\n    //   this.showToastr({\r\n    //     sendDate:\"111\",\r\n    //     content:\"test\",\r\n    //     data:{\r\n    //       correspondenceId:\"f9c36fe1-7054-4f81-a89b-096ad24a03b5\"\r\n    //     }\r\n    //   }).onTap.pipe(take(1)).subscribe(() => {\r\n    //     // this.notificationsService.updateStatus(activity, true);\r\n    //     console.log(\"here\")\r\n    //   })\r\n    // }, 1000);\r\n  }\r\n  onListItemClick(event){\r\n    this.listItemClick.next(event);\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.subscription.unsubscribe();\r\n    this.updater.unsubscribe();\r\n    this.notificationsService.unsubscribe();\r\n  }\r\n  // test() {\r\n  //   this.toastr.show(`dsssdsds`, 'here is the content of the notification ', {\r\n  //     toastComponent: NotificationToastComponent,\r\n  //     closeButton: true,\r\n  //     // extendedTimeOut: 0,\r\n  //     timeOut: 10000,\r\n  //     // tapToDismiss: false,\r\n  //     enableHtml: true,\r\n  //     positionClass:\r\n  //       this.translate.instant('dir') === 'rtl'\r\n  //         ? 'toast-bottom-left'\r\n  //         : 'toast-bottom-right',\r\n  //     toastClass: 'notification-toast',\r\n  //   });\r\n  // }\r\n\r\n  showToastr(activity, ar): ActiveToast<any> {\r\n    let arContent;\r\n    let enContent;\r\n    activity.notificationContents.forEach((res) => {\r\n      if (res.lang === \"AR\") {\r\n        arContent = res.message;\r\n      }\r\n      if (res.lang === \"EN\") {\r\n        enContent = res.message;\r\n      }\r\n    });\r\n    const activeToast = this.toastr.show(\r\n      `${this.TimeAgo.transform(activity.sendDate)}`,\r\n      ar ? arContent : enContent,\r\n      {\r\n        toastComponent: NotificationToastComponent,\r\n        closeButton: true,\r\n        timeOut: 10000,\r\n        enableHtml: true,\r\n        positionClass:\r\n          this.translate.instant(\"dir\") === \"rtl\"\r\n            ? \"toast-bottom-left\"\r\n            : \"toast-bottom-right\",\r\n        toastClass: \"notification-toast\",\r\n      }\r\n    );\r\n    activeToast.toastRef.componentInstance.id = activity.data.correspondenceId;\r\n\r\n    return activeToast;\r\n  }\r\n}\r\n","<div [matMenuTriggerFor]=\"langMenu\" class=\"notification\" (click)=\"getNotifications()\" class=\"search-wrapper\">\r\n  <span matBadgeSize=\"small\" matBadge=\"{{ notificationsCount }}\" matBadgeColor=\"warn\" matbadgeposition=\"before\"\r\n    class=\"bi bi-bell bell\"></span>\r\n</div>\r\n<mat-menu class=\"mat-menu-panel myMenu notification-list\" #langMenu=\"matMenu\">\r\n  <app-notifications-list (listItemClick)=\"onListItemClick($event)\"></app-notifications-list>\r\n</mat-menu>\r\n"]}
|
|
176
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifications-button.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-button/notifications-button.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-button/notifications-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewEncapsulation,\r\n} from \"@angular/core\";\r\nimport { Router } from \"@angular/router\";\r\nimport { TranslateService } from \"@ngx-translate/core\";\r\nimport { ActiveToast, ToastrService } from \"ngx-toastr\";\r\nimport { take } from \"rxjs/internal/operators/take\";\r\nimport { TimeAgoPipe } from \"../../../../pipes/time-ago.pipe\";\r\nimport { NotificationsService } from \"../../notifications.service\";\r\nimport { NotificationToastComponent } from \"../notification-toast/notification-toast.component\";\r\nimport { TranslationService } from \"../../../../Core/services/translation/translation.service\";\r\nimport { first } from \"rxjs/operators\";\r\n\r\n\r\n@Component({\r\n  selector: \"app-notifications-button\",\r\n  templateUrl: \"./notifications-button.component.html\",\r\n  styleUrls: [\"./notifications-button.component.scss\"],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class NotificationsButtonComponent implements OnInit, OnDestroy {\r\n  get notificationsCount() {\r\n    return this.notificationsService.notificationsCount;\r\n  }\r\n\r\n  subscription;\r\n  updater;\r\n  @Output()\r\n  toastrClick = new EventEmitter();\r\n  @Output()\r\n  listItemClick = new EventEmitter();\r\n  @Input() customNotificationIcon = null;\r\n  constructor(\r\n    public notificationsService: NotificationsService,\r\n    public translate: TranslateService,\r\n    public toastr: ToastrService,\r\n    public TimeAgo: TimeAgoPipe,\r\n    public router: Router,\r\n    private ref: ChangeDetectorRef,\r\n    private translationService: TranslationService\r\n  ) {}\r\n  /*\r\n  async openNotifications(event) {\r\n    const dir = this.translate.instant('dir');\r\n    const notificationsModal = await this.modalController.create({\r\n      cssClass: 'side-modal notifications',\r\n      enterAnimation: dir === 'rtl' ? slideInRtl : slideIn,\r\n      leaveAnimation: dir === 'rtl' ? slideOutRtl : slideOut,\r\n      component: NotificationsModalComponent,\r\n      showBackdrop: false\r\n    });\r\n    return await notificationsModal.present().then(() => {\r\n      this.notificationsService.resetCount();\r\n\r\n    });\r\n  }\r\n  */\r\n  getNotifications() {\r\n    this.notificationsService.resetNotifications()\r\n    this.notificationsService.fetchNotifications().subscribe(() => {\r\n      this.notificationsService.resetCount();\r\n    });\r\n  }\r\n  ngOnInit() {\r\n    this.subscription = this.notificationsService.listenerObserver.subscribe(\r\n      async (activity) => {\r\n        let ar = await this.translationService.isArabic\r\n          .pipe(first())\r\n          .toPromise();\r\n        let sourceType = activity.sourceType;\r\n        const isAssignmentOrApproval: boolean =\r\n          sourceType === \"approval\" || sourceType === \"assignment\";\r\n        const correspondence = sourceType === \"correspondence\";\r\n        const assignment = sourceType === \"assignment\";\r\n        const approval = sourceType === \"approval\";\r\n        const memo = sourceType === \"memo\";\r\n        const general = sourceType === \"general\";\r\n        const id = memo ? activity.sourceId : activity.data.correspondenceId;\r\n\r\n        this.showToastr(activity, ar)\r\n          .onTap.pipe(take(1))\r\n          .subscribe(() => {\r\n            this.notificationsService.updateStatus(activity, true);\r\n            if (activity.data?.correspondenceId) {\r\n              this.router.navigate(\r\n                [\r\n                  {\r\n                    outlets: {\r\n                      viewer: [\"view\", id],\r\n                    },\r\n                  },\r\n                ],\r\n                {\r\n                  queryParams: {\r\n                    location: this.router.url,\r\n                    ...(isAssignmentOrApproval && { approvalMode: true }),\r\n                    ...(assignment && {\r\n                      assignmentId: activity.data.assignmentId,\r\n                    }),\r\n                  },\r\n                }\r\n              );\r\n            }\r\n            if (memo) {\r\n              this.router.navigate([{ outlets: { viewer: [\"memo\", id] } }], {\r\n                queryParams: { location: this.router.url },\r\n              });\r\n            }\r\n            this.toastrClick.next(activity);\r\n          });\r\n        this.ref.markForCheck();\r\n      }\r\n    );\r\n\r\n    this.updater = this.notificationsService.update.subscribe((data) => {\r\n      this.ref.detectChanges();\r\n    });\r\n    // setTimeout(() => {\r\n    //   this.showToastr({\r\n    //     sendDate:\"111\",\r\n    //     content:\"test\",\r\n    //     data:{\r\n    //       correspondenceId:\"f9c36fe1-7054-4f81-a89b-096ad24a03b5\"\r\n    //     }\r\n    //   }).onTap.pipe(take(1)).subscribe(() => {\r\n    //     // this.notificationsService.updateStatus(activity, true);\r\n    //     console.log(\"here\")\r\n    //   })\r\n    // }, 1000);\r\n  }\r\n  onListItemClick(event){\r\n    this.listItemClick.next(event);\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.subscription.unsubscribe();\r\n    this.updater.unsubscribe();\r\n    this.notificationsService.unsubscribe();\r\n  }\r\n  // test() {\r\n  //   this.toastr.show(`dsssdsds`, 'here is the content of the notification ', {\r\n  //     toastComponent: NotificationToastComponent,\r\n  //     closeButton: true,\r\n  //     // extendedTimeOut: 0,\r\n  //     timeOut: 10000,\r\n  //     // tapToDismiss: false,\r\n  //     enableHtml: true,\r\n  //     positionClass:\r\n  //       this.translate.instant('dir') === 'rtl'\r\n  //         ? 'toast-bottom-left'\r\n  //         : 'toast-bottom-right',\r\n  //     toastClass: 'notification-toast',\r\n  //   });\r\n  // }\r\n\r\n  showToastr(activity, ar): ActiveToast<any> {\r\n    let arContent;\r\n    let enContent;\r\n    activity.notificationContents.forEach((res) => {\r\n      if (res.lang === \"AR\") {\r\n        arContent = res.message;\r\n      }\r\n      if (res.lang === \"EN\") {\r\n        enContent = res.message;\r\n      }\r\n    });\r\n    const activeToast = this.toastr.show(\r\n      `${this.TimeAgo.transform(activity.sendDate)}`,\r\n      ar ? arContent : enContent,\r\n      {\r\n        toastComponent: NotificationToastComponent,\r\n        closeButton: true,\r\n        timeOut: 10000,\r\n        enableHtml: true,\r\n        positionClass:\r\n          this.translate.instant(\"dir\") === \"rtl\"\r\n            ? \"toast-bottom-left\"\r\n            : \"toast-bottom-right\",\r\n        toastClass: \"notification-toast\",\r\n      }\r\n    );\r\n    activeToast.toastRef.componentInstance.id = activity.data.correspondenceId;\r\n\r\n    return activeToast;\r\n  }\r\n}\r\n","<div [matMenuTriggerFor]=\"langMenu\" class=\"notification\" (click)=\"getNotifications()\" class=\"search-wrapper\">\r\n  <span *ngIf=\"!customNotificationIcon;else customIcon\" matBadgeSize=\"small\" matBadge=\"{{ notificationsCount }}\"\r\n    matBadgeColor=\"warn\" matbadgeposition=\"before\" class=\"bi bi-bell bell\"></span>\r\n</div>\r\n<mat-menu class=\"mat-menu-panel myMenu notification-list\" #langMenu=\"matMenu\">\r\n  <app-notifications-list (listItemClick)=\"onListItemClick($event)\"></app-notifications-list>\r\n</mat-menu>\r\n\r\n<ng-template #customIcon>\r\n  <ng-container *ngTemplateOutlet=\"customNotificationIcon\"></ng-container>\r\n</ng-template>"]}
|
|
@@ -88,7 +88,7 @@ import { InfiniteScrollModule } from 'ngx-infinite-scroll';
|
|
|
88
88
|
import { take as take$1 } from 'rxjs/internal/operators/take';
|
|
89
89
|
import * as SockJS from 'sockjs-client';
|
|
90
90
|
import * as Stomp from 'webstomp-client';
|
|
91
|
-
import * as
|
|
91
|
+
import * as i10 from '@angular/material/badge';
|
|
92
92
|
import { MatBadgeModule } from '@angular/material/badge';
|
|
93
93
|
import { MatToolbarModule } from '@angular/material/toolbar';
|
|
94
94
|
import * as i7$3 from '@angular/material/chips';
|
|
@@ -17116,6 +17116,7 @@ class NotificationsButtonComponent {
|
|
|
17116
17116
|
this.translationService = translationService;
|
|
17117
17117
|
this.toastrClick = new EventEmitter();
|
|
17118
17118
|
this.listItemClick = new EventEmitter();
|
|
17119
|
+
this.customNotificationIcon = null;
|
|
17119
17120
|
}
|
|
17120
17121
|
get notificationsCount() {
|
|
17121
17122
|
return this.notificationsService.notificationsCount;
|
|
@@ -17247,7 +17248,7 @@ class NotificationsButtonComponent {
|
|
|
17247
17248
|
}
|
|
17248
17249
|
}
|
|
17249
17250
|
NotificationsButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: NotificationsButtonComponent, deps: [{ token: NotificationsService }, { token: i1$1.TranslateService }, { token: i1$3.ToastrService }, { token: TimeAgoPipe }, { token: i2$2.Router }, { token: i0.ChangeDetectorRef }, { token: TranslationService$1 }], target: i0.ɵɵFactoryTarget.Component });
|
|
17250
|
-
NotificationsButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: NotificationsButtonComponent, selector: "app-notifications-button", outputs: { toastrClick: "toastrClick", listItemClick: "listItemClick" }, ngImport: i0, template: "<div [matMenuTriggerFor]=\"langMenu\" class=\"notification\" (click)=\"getNotifications()\" class=\"search-wrapper\">\r\n <span matBadgeSize=\"small\" matBadge=\"{{ notificationsCount }}\"
|
|
17251
|
+
NotificationsButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: NotificationsButtonComponent, selector: "app-notifications-button", inputs: { customNotificationIcon: "customNotificationIcon" }, outputs: { toastrClick: "toastrClick", listItemClick: "listItemClick" }, ngImport: i0, template: "<div [matMenuTriggerFor]=\"langMenu\" class=\"notification\" (click)=\"getNotifications()\" class=\"search-wrapper\">\r\n <span *ngIf=\"!customNotificationIcon;else customIcon\" matBadgeSize=\"small\" matBadge=\"{{ notificationsCount }}\"\r\n matBadgeColor=\"warn\" matbadgeposition=\"before\" class=\"bi bi-bell bell\"></span>\r\n</div>\r\n<mat-menu class=\"mat-menu-panel myMenu notification-list\" #langMenu=\"matMenu\">\r\n <app-notifications-list (listItemClick)=\"onListItemClick($event)\"></app-notifications-list>\r\n</mat-menu>\r\n\r\n<ng-template #customIcon>\r\n <ng-container *ngTemplateOutlet=\"customNotificationIcon\"></ng-container>\r\n</ng-template>", styles: [".notifications-count{background-color:#eee;border-radius:5px;color:#333;font-size:11px;padding:0 6px;box-sizing:border-box}.notification-list{max-width:450px!important;width:450px;height:66vh}.notification-list .mat-menu-content{padding:0!important;position:relative;height:calc(100% - 29px)}.notification-list .mat-menu-content .mat-toolbar{margin:0 0 -10px}.mat-menu-panel.myMenu{border-radius:5px!important;overflow:hidden}.notification .mat-icon{margin-right:0!important;vertical-align:middle}.toast-container{right:12px!important;bottom:12px!important;pointer-events:all}.toast-container .ngx-toastr{padding:25px!important;background-position:263px center;border-radius:5px!important;box-shadow:none!important}.toast-container .toast-title{font-weight:normal}.wrap{white-space:normal!important;font-size:14px!important;margin-bottom:8px!important}.mat-menu-content:not(:empty){padding-top:0;padding-bottom:0}[dir=rtl] .toast-container{left:12px!important;right:auto!important;direction:rtl;text-align:right}[dir=rtl] .toast-container .ngx-toastr{background-position:10px center}[dir=rtl] .toast-container .toast-close-button{float:left}.mat-badge-content{right:-4px!important;top:-1px!important}.rtl .mat-badge-content{font-weight:600;right:-6px!important;top:-5px!important}\n"], components: [{ type: i4$1.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: NotificationsListComponent, selector: "app-notifications-list", outputs: ["listItemClick"] }], directives: [{ type: i4$1.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["matMenuTriggerRestoreFocus", "mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i10.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgePosition", "matBadgeSize", "matBadgeColor", "matBadgeOverlap", "matBadgeDescription", "matBadgeHidden", "matBadge"] }, { type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
17251
17252
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: NotificationsButtonComponent, decorators: [{
|
|
17252
17253
|
type: Component,
|
|
17253
17254
|
args: [{
|
|
@@ -17260,6 +17261,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
17260
17261
|
type: Output
|
|
17261
17262
|
}], listItemClick: [{
|
|
17262
17263
|
type: Output
|
|
17264
|
+
}], customNotificationIcon: [{
|
|
17265
|
+
type: Input
|
|
17263
17266
|
}] } });
|
|
17264
17267
|
|
|
17265
17268
|
/** @ignore */
|
|
@@ -19041,11 +19044,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
19041
19044
|
* ></cts-versions>
|
|
19042
19045
|
*/
|
|
19043
19046
|
class VersionsComponent {
|
|
19044
|
-
constructor(viewerFilesService, documentsApi) {
|
|
19047
|
+
constructor(viewerFilesService, trnaslationService, documentsApi) {
|
|
19045
19048
|
this.viewerFilesService = viewerFilesService;
|
|
19049
|
+
this.trnaslationService = trnaslationService;
|
|
19046
19050
|
this.documentsApi = documentsApi;
|
|
19047
19051
|
this.handleActions = new EventEmitter();
|
|
19048
19052
|
this.versions = [];
|
|
19053
|
+
this.isArabic = false;
|
|
19049
19054
|
}
|
|
19050
19055
|
ngOnChanges(changes) {
|
|
19051
19056
|
if (changes.file && changes.file.currentValue &&
|
|
@@ -19054,6 +19059,9 @@ class VersionsComponent {
|
|
|
19054
19059
|
}
|
|
19055
19060
|
}
|
|
19056
19061
|
ngOnInit() {
|
|
19062
|
+
this.langSubscription = this.trnaslationService.isArabic$.subscribe(res => {
|
|
19063
|
+
this.isArabic = res;
|
|
19064
|
+
});
|
|
19057
19065
|
this.getVersions();
|
|
19058
19066
|
}
|
|
19059
19067
|
getVersion(version) {
|
|
@@ -19073,9 +19081,12 @@ class VersionsComponent {
|
|
|
19073
19081
|
handleAction(event) {
|
|
19074
19082
|
this.handleActions.emit(event);
|
|
19075
19083
|
}
|
|
19084
|
+
ngOnDestroy() {
|
|
19085
|
+
this.langSubscription ? this.langSubscription.unsubscribe() : null;
|
|
19086
|
+
}
|
|
19076
19087
|
}
|
|
19077
|
-
VersionsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: VersionsComponent, deps: [{ token: ViewerFilesService }, { token: DocumentsService }], target: i0.ɵɵFactoryTarget.Component });
|
|
19078
|
-
VersionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: VersionsComponent, selector: "cts-versions", inputs: { selectedVersion: "selectedVersion", file: "file", actions: "actions" }, outputs: { handleActions: "handleActions" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"flex flex-col\">\r\n<div class=\"viewer-attachments\">\r\n <div class=\"subheader\">\r\n <div> {{ \"viewer.current\" | translate }}</div>\r\n\r\n </div>\r\n <div class=\"attachments-list\">\r\n <mat-list>\r\n <div class=\"mat-list-items\">\r\n <cts-item-list [item]=\"file\" [title]=\"file.title\" [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\"\r\n [actions]=\"actions\" (itemClicked)=\"showVersion(file)\" (actionclicked)=\"handleAction($event)\">\r\n <div class=\"description\">\r\n {{getVersion(file)}}\r\n -\r\n {{ file.lastModified | localizedDate }}\r\n </div>\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments original-section\" *ngIf=\"versions.length > 0\">\r\n <div class=\"subheader\">\r\n <div>{{ \"viewer.origin\" | translate }}</div>\r\n </div>\r\n <div class=\"attachments-list\">\r\n <mat-list>\r\n <div class=\"mat-list-items\">\r\n <cts-item-list [item]=\"versions[versions.length -1]\" [title]=\"versions[versions.length -1].title\"\r\n [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\" [actions]=\"actions\"\r\n (itemClicked)=\"showVersion(versions[versions.length -1])\" (actionclicked)=\"handleAction($event)\">\r\n\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments\" *permission=\"{name: 'viewVersions', entity: file}\">\r\n <div class=\"subheader\">\r\n <div> {{ \"viewer.history\" | translate }}</div>\r\n\r\n </div>\r\n <div class=\"attachments-list\" *ngIf=\"versions.length > 0\">\r\n <ng-container>\r\n\r\n\r\n <mat-list>\r\n <div class=\"mat-list-items\" *ngFor=\"let version of versions ;let cnt = count; let i = index\">\r\n <cts-item-list [item]=\"version\" [title]=\"version.title + '-' + getVersion(version)\" [iconname]=\"'description'\"\r\n [moreclasses]=\"'text-danger'\" (itemClicked)=\"showVersion(version)\" [actions]=\"actions\" (actionclicked)=\"handleAction($event)\">\r\n <div class=\"description\">\r\n {{getVersion(version)}}\r\n -\r\n {{ version.lastModified | localizedDate }}\r\n <span class=\"font-weight-bold\">\r\n\r\n {{\r\n version.properties.lastContributor.id === 'system' ?\r\n ('SYSTEM_ADMIN' | translate) :\r\n version.properties.lastContributor.properties.firstName +\r\n \" \" +\r\n version.properties.lastContributor.properties.lastName\r\n }}\r\n </span>\r\n </div>\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </ng-container>\r\n </div>\r\n <div *ngIf=\"versions.length === 0\">\r\n <cts-no-data></cts-no-data>\r\n </div>\r\n</div>\r\n</div>\r\n<ng-template #noEntry>\r\n\r\n</ng-template>", styles: [""], components: [{ type: i2$3.MatList, selector: "mat-list, mat-action-list", inputs: ["disableRipple", "disabled"], exportAs: ["matList"] }, { type: ItemListComponent, selector: "cts-item-list", inputs: ["item", "iconname", "title", "actions", "isselected", "moreclasses"], outputs: ["itemClicked", "actionclicked"] }, { type: NoDataComponent, selector: "cts-no-data", inputs: ["message", "border", "img"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: PermissionsDirective, selector: "[permission]", inputs: ["permission"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i1$1.TranslatePipe, "localizedDate": LocalizedDatePipe } });
|
|
19088
|
+
VersionsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: VersionsComponent, deps: [{ token: ViewerFilesService }, { token: TranslationService$1 }, { token: DocumentsService }], target: i0.ɵɵFactoryTarget.Component });
|
|
19089
|
+
VersionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: VersionsComponent, selector: "cts-versions", inputs: { selectedVersion: "selectedVersion", file: "file", actions: "actions" }, outputs: { handleActions: "handleActions" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"flex flex-col\">\r\n<div class=\"viewer-attachments\">\r\n <div class=\"subheader\">\r\n <div> {{ \"viewer.current\" | translate }}</div>\r\n\r\n </div>\r\n <div class=\"attachments-list\">\r\n <mat-list>\r\n <div class=\"mat-list-items\">\r\n <cts-item-list [item]=\"file\" [title]=\"file.title\" [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\"\r\n [actions]=\"actions\" (itemClicked)=\"showVersion(file)\" (actionclicked)=\"handleAction($event)\">\r\n <div class=\"description\">\r\n {{getVersion(file)}}\r\n -\r\n {{ file.lastModified | localizedDate : '' : (isArabic? 'ar-AR' : 'en-US') }}\r\n </div>\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments original-section\" *ngIf=\"versions.length > 0\">\r\n <div class=\"subheader\">\r\n <div>{{ \"viewer.origin\" | translate }}</div>\r\n </div>\r\n <div class=\"attachments-list\">\r\n <mat-list>\r\n <div class=\"mat-list-items\">\r\n <cts-item-list [item]=\"versions[versions.length -1]\" [title]=\"versions[versions.length -1].title\"\r\n [iconname]=\"'description'\" [moreclasses]=\"'text-danger'\" [actions]=\"actions\"\r\n (itemClicked)=\"showVersion(versions[versions.length -1])\" (actionclicked)=\"handleAction($event)\">\r\n\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </div>\r\n</div>\r\n\r\n<div class=\"viewer-attachments\" *permission=\"{name: 'viewVersions', entity: file}\">\r\n <div class=\"subheader\">\r\n <div> {{ \"viewer.history\" | translate }}</div>\r\n\r\n </div>\r\n <div class=\"attachments-list\" *ngIf=\"versions.length > 0\">\r\n <ng-container>\r\n\r\n\r\n <mat-list>\r\n <div class=\"mat-list-items\" *ngFor=\"let version of versions ;let cnt = count; let i = index\">\r\n <cts-item-list [item]=\"version\" [title]=\"version.title + '-' + getVersion(version)\" [iconname]=\"'description'\"\r\n [moreclasses]=\"'text-danger'\" (itemClicked)=\"showVersion(version)\" [actions]=\"actions\" (actionclicked)=\"handleAction($event)\">\r\n <div class=\"description\">\r\n {{getVersion(version)}}\r\n -\r\n {{ version.lastModified | localizedDate : '' : (isArabic? 'ar-AR' : 'en-US') }}\r\n <span class=\"font-weight-bold\">\r\n\r\n {{\r\n version.properties.lastContributor.id === 'system' ?\r\n ('SYSTEM_ADMIN' | translate) :\r\n version.properties.lastContributor.properties.firstName +\r\n \" \" +\r\n version.properties.lastContributor.properties.lastName\r\n }}\r\n </span>\r\n </div>\r\n </cts-item-list>\r\n </div>\r\n </mat-list>\r\n </ng-container>\r\n </div>\r\n <div *ngIf=\"versions.length === 0\">\r\n <cts-no-data></cts-no-data>\r\n </div>\r\n</div>\r\n</div>\r\n<ng-template #noEntry>\r\n\r\n</ng-template>", styles: [""], components: [{ type: i2$3.MatList, selector: "mat-list, mat-action-list", inputs: ["disableRipple", "disabled"], exportAs: ["matList"] }, { type: ItemListComponent, selector: "cts-item-list", inputs: ["item", "iconname", "title", "actions", "isselected", "moreclasses"], outputs: ["itemClicked", "actionclicked"] }, { type: NoDataComponent, selector: "cts-no-data", inputs: ["message", "border", "img"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: PermissionsDirective, selector: "[permission]", inputs: ["permission"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i1$1.TranslatePipe, "localizedDate": LocalizedDatePipe } });
|
|
19079
19090
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: VersionsComponent, decorators: [{
|
|
19080
19091
|
type: Component,
|
|
19081
19092
|
args: [{
|
|
@@ -19083,7 +19094,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
19083
19094
|
templateUrl: './versions.component.html',
|
|
19084
19095
|
styleUrls: ['./versions.component.scss']
|
|
19085
19096
|
}]
|
|
19086
|
-
}], ctorParameters: function () { return [{ type: ViewerFilesService }, { type: DocumentsService }]; }, propDecorators: { selectedVersion: [{
|
|
19097
|
+
}], ctorParameters: function () { return [{ type: ViewerFilesService }, { type: TranslationService$1 }, { type: DocumentsService }]; }, propDecorators: { selectedVersion: [{
|
|
19087
19098
|
type: Input
|
|
19088
19099
|
}], file: [{
|
|
19089
19100
|
type: Input
|