nuxeo-development-framework 0.7.5 → 0.7.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 +688 -489
- package/bundles/nuxeo-development-framework.umd.js.map +1 -1
- package/esm2015/lib/components/documents/components/document-scan/document-scan.service.js +1 -1
- package/esm2015/lib/components/dynamic-form/components/form-wrappers/user-selector-wrapper/user-selector-wrapper.component.js +2 -2
- package/esm2015/lib/components/dynamic-search/dynamic-search/dynamic-search.component.js +2 -2
- package/esm2015/lib/components/dynamic-table/dynamic-table/dynamic-table.component.js +9 -3
- package/esm2015/lib/components/dynamic-view/custom-document-viewer/custom-document-viewer.component.js +27 -17
- package/esm2015/lib/components/dynamic-view/custom-pp-viewer/custom-pp-viewer.component.js +28 -18
- package/esm2015/lib/components/dynamic-view/cutome-voc-viewer/cutome-voc-viewer.component.js +2 -2
- package/esm2015/lib/components/dynamic-view/department-viewer/department-viewer.component.js +44 -26
- package/esm2015/lib/components/dynamic-view/dynamic-viewe.service.js +62 -0
- package/esm2015/lib/components/notifications/components/notifications-button/notifications-button.component.js +14 -4
- package/esm2015/lib/components/notifications/components/notifications-list/notifications-list.component.js +8 -4
- package/esm2015/lib/components/pdf-tron/pdftron/pdftron.component.js +84 -9
- package/esm2015/lib/directive/app-has-role/app-has-role.directive.js +1 -1
- package/fesm2015/nuxeo-development-framework.js +376 -185
- package/fesm2015/nuxeo-development-framework.js.map +1 -1
- package/lib/components/dynamic-table/dynamic-table/dynamic-table.component.d.ts +2 -1
- package/lib/components/dynamic-view/custom-document-viewer/custom-document-viewer.component.d.ts +3 -1
- package/lib/components/dynamic-view/custom-pp-viewer/custom-pp-viewer.component.d.ts +3 -1
- package/lib/components/dynamic-view/department-viewer/department-viewer.component.d.ts +4 -3
- package/lib/components/dynamic-view/dynamic-viewe.service.d.ts +15 -0
- package/lib/components/notifications/components/notifications-button/notifications-button.component.d.ts +5 -2
- package/lib/components/notifications/components/notifications-list/notifications-list.component.d.ts +3 -2
- package/lib/components/pdf-tron/pdftron/pdftron.component.d.ts +9 -1
- package/package.json +1 -1
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "
|
|
4
|
-
import * as i2 from "../../../Core/services/
|
|
5
|
-
import * as i3 from "
|
|
3
|
+
import * as i1 from "../dynamic-viewe.service";
|
|
4
|
+
import * as i2 from "../../../Core/services/callApi/call-api.service";
|
|
5
|
+
import * as i3 from "../../../Core/services/translation/translation.service";
|
|
6
|
+
import * as i4 from "@angular/common";
|
|
6
7
|
export class CustomPpViewerComponent {
|
|
7
|
-
constructor(callApi, translationService) {
|
|
8
|
+
constructor(dynamicViewService, callApi, translationService) {
|
|
9
|
+
this.dynamicViewService = dynamicViewService;
|
|
8
10
|
this.callApi = callApi;
|
|
9
11
|
this.translationService = translationService;
|
|
10
12
|
}
|
|
@@ -17,23 +19,31 @@ export class CustomPpViewerComponent {
|
|
|
17
19
|
});
|
|
18
20
|
}
|
|
19
21
|
getData() {
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
this.
|
|
29
|
-
|
|
22
|
+
if (this.dynamicViewService.getDataFromStoredAggregation(this.group.key)) {
|
|
23
|
+
let storedAggreg = this.dynamicViewService.getDataFromStoredAggregation(this.group.key);
|
|
24
|
+
this.data = storedAggreg ? storedAggreg['data'] : null;
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
let params = {
|
|
28
|
+
category_code: this.group.key
|
|
29
|
+
};
|
|
30
|
+
this.callApi.query(Object.assign({ pageProvider: this.pageProvider }, params), {
|
|
31
|
+
headers: {
|
|
32
|
+
"properties": "*",
|
|
33
|
+
},
|
|
34
|
+
}).subscribe(res => {
|
|
35
|
+
var _a, _b;
|
|
36
|
+
this.dynamicViewService.setDataToStorag(this.group.key, (_a = res === null || res === void 0 ? void 0 : res.entries[0]) === null || _a === void 0 ? void 0 : _a['properties']);
|
|
37
|
+
this.data = (_b = res === null || res === void 0 ? void 0 : res.entries[0]) === null || _b === void 0 ? void 0 : _b['properties'];
|
|
38
|
+
});
|
|
39
|
+
}
|
|
30
40
|
}
|
|
31
41
|
ngOnDestroy() {
|
|
32
42
|
this.langSubscription ? this.langSubscription.unsubscribe() : null;
|
|
33
43
|
}
|
|
34
44
|
}
|
|
35
|
-
CustomPpViewerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: CustomPpViewerComponent, deps: [{ token: i1.
|
|
36
|
-
CustomPpViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: CustomPpViewerComponent, selector: "lib-custom-pp-viewer", inputs: { pageProvider: "pageProvider", group: "group" }, ngImport: i0, template: "<span *ngIf=\"data\">\n {{isArabic ? data['category:arabicTitle'] : data['dc:title']}}\n</span>", styles: [""], directives: [{ type:
|
|
45
|
+
CustomPpViewerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: CustomPpViewerComponent, deps: [{ token: i1.DynamicVieweService }, { token: i2.CallApiService }, { token: i3.TranslationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
46
|
+
CustomPpViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: CustomPpViewerComponent, selector: "lib-custom-pp-viewer", inputs: { pageProvider: "pageProvider", group: "group" }, ngImport: i0, template: "<span *ngIf=\"data\">\r\n {{isArabic ? data['category:arabicTitle'] : data['dc:title']}}\r\n</span>", styles: [""], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
37
47
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: CustomPpViewerComponent, decorators: [{
|
|
38
48
|
type: Component,
|
|
39
49
|
args: [{
|
|
@@ -41,9 +51,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
41
51
|
templateUrl: './custom-pp-viewer.component.html',
|
|
42
52
|
styleUrls: ['./custom-pp-viewer.component.scss']
|
|
43
53
|
}]
|
|
44
|
-
}], ctorParameters: function () { return [{ type: i1.
|
|
54
|
+
}], ctorParameters: function () { return [{ type: i1.DynamicVieweService }, { type: i2.CallApiService }, { type: i3.TranslationService }]; }, propDecorators: { pageProvider: [{
|
|
45
55
|
type: Input
|
|
46
56
|
}], group: [{
|
|
47
57
|
type: Input
|
|
48
58
|
}] } });
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLXBwLXZpZXdlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL2R5bmFtaWMtdmlldy9jdXN0b20tcHAtdmlld2VyL2N1c3RvbS1wcC12aWV3ZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9keW5hbWljLXZpZXcvY3VzdG9tLXBwLXZpZXdlci9jdXN0b20tcHAtdmlld2VyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDOzs7Ozs7QUFXekQsTUFBTSxPQUFPLHVCQUF1QjtJQU1sQyxZQUFvQixrQkFBd0MsRUFBVyxPQUF3QixFQUFXLGtCQUF1QztRQUE3SCx1QkFBa0IsR0FBbEIsa0JBQWtCLENBQXNCO1FBQVcsWUFBTyxHQUFQLE9BQU8sQ0FBaUI7UUFBVyx1QkFBa0IsR0FBbEIsa0JBQWtCLENBQXFCO0lBQUksQ0FBQztJQUV0SixRQUFRO1FBQ04sT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDL0IsT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDeEIsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2YsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ3ZFLElBQUksQ0FBQyxRQUFRLEdBQUcsR0FBRyxDQUFDO1FBQ3RCLENBQUMsQ0FBQyxDQUFBO0lBQ0osQ0FBQztJQUVELE9BQU87UUFDTCxJQUFHLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyw0QkFBNEIsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxFQUFDO1lBQ3RFLElBQUksWUFBWSxHQUFHLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyw0QkFBNEIsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ3hGLElBQUksQ0FBQyxJQUFJLEdBQUcsWUFBWSxDQUFDLENBQUMsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztTQUN4RDthQUFJO1lBQ0gsSUFBSSxNQUFNLEdBQUc7Z0JBQ1gsYUFBYSxFQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRzthQUMvQixDQUFBO1lBQ0EsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLGlCQUNqQixZQUFZLEVBQUUsSUFBSSxDQUFDLFlBQVksSUFDNUIsTUFBTSxHQUVYO2dCQUNFLE9BQU8sRUFBRTtvQkFDUCxZQUFZLEVBQUUsR0FBRztpQkFDbEI7YUFDRixDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFOztnQkFDakIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRyxNQUFBLEdBQUcsYUFBSCxHQUFHLHVCQUFILEdBQUcsQ0FBRSxPQUFPLENBQUMsQ0FBQyxDQUFDLDBDQUFHLFlBQVksQ0FBQyxDQUFDLENBQUM7Z0JBQzFGLElBQUksQ0FBQyxJQUFJLEdBQUcsTUFBQSxHQUFHLGFBQUgsR0FBRyx1QkFBSCxHQUFHLENBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQywwQ0FBRyxZQUFZLENBQUMsQ0FBQztZQUU5QyxDQUFDLENBQUMsQ0FBQTtTQUNIO0lBQ0gsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBQ3JFLENBQUM7O29IQTNDVSx1QkFBdUI7d0dBQXZCLHVCQUF1QixzSENYcEMsd0dBRU87MkZEU00sdUJBQXVCO2tCQUxuQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQkFBc0I7b0JBQ2hDLFdBQVcsRUFBRSxtQ0FBbUM7b0JBQ2hELFNBQVMsRUFBRSxDQUFDLG1DQUFtQyxDQUFDO2lCQUNqRDt3S0FFVSxZQUFZO3NCQUFwQixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGlvblNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9Db3JlL3NlcnZpY2VzL3RyYW5zbGF0aW9uL3RyYW5zbGF0aW9uLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBTdWJzY3JpcHRpb24gfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQ2FsbEFwaVNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9Db3JlL3NlcnZpY2VzL2NhbGxBcGkvY2FsbC1hcGkuc2VydmljZSc7XHJcbmltcG9ydCB7IER5bmFtaWNWaWV3ZVNlcnZpY2UgfSBmcm9tICcuLi9keW5hbWljLXZpZXdlLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdsaWItY3VzdG9tLXBwLXZpZXdlcicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2N1c3RvbS1wcC12aWV3ZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2N1c3RvbS1wcC12aWV3ZXIuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ3VzdG9tUHBWaWV3ZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIEBJbnB1dCgpIHBhZ2VQcm92aWRlcjtcclxuICBASW5wdXQoKSBncm91cDtcclxuICBkYXRhO1xyXG4gIGxhbmdTdWJzY3JpcHRpb24gOiBTdWJzY3JpcHRpb247XHJcbiAgaXNBcmFiaWMgO1xyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZHluYW1pY1ZpZXdTZXJ2aWNlIDogRHluYW1pY1ZpZXdlU2VydmljZSAsIHByaXZhdGUgY2FsbEFwaSA6IENhbGxBcGlTZXJ2aWNlICwgcHJpdmF0ZSB0cmFuc2xhdGlvblNlcnZpY2UgOiBUcmFuc2xhdGlvblNlcnZpY2UpIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIGNvbnNvbGUubG9nKHRoaXMucGFnZVByb3ZpZGVyKTtcclxuICAgIGNvbnNvbGUubG9nKHRoaXMuZ3JvdXApO1xyXG4gICAgdGhpcy5nZXREYXRhKCk7XHJcbiAgICB0aGlzLmxhbmdTdWJzY3JpcHRpb24gPSB0aGlzLnRyYW5zbGF0aW9uU2VydmljZS5pc0FyYWJpYy5zdWJzY3JpYmUocmVzID0+IHtcclxuICAgICAgdGhpcy5pc0FyYWJpYyA9IHJlcztcclxuICAgIH0pXHJcbiAgfVxyXG5cclxuICBnZXREYXRhKCl7XHJcbiAgICBpZih0aGlzLmR5bmFtaWNWaWV3U2VydmljZS5nZXREYXRhRnJvbVN0b3JlZEFnZ3JlZ2F0aW9uKHRoaXMuZ3JvdXAua2V5KSl7XHJcbiAgICAgIGxldCBzdG9yZWRBZ2dyZWcgPSB0aGlzLmR5bmFtaWNWaWV3U2VydmljZS5nZXREYXRhRnJvbVN0b3JlZEFnZ3JlZ2F0aW9uKHRoaXMuZ3JvdXAua2V5KTtcclxuICAgICAgdGhpcy5kYXRhID0gc3RvcmVkQWdncmVnID8gc3RvcmVkQWdncmVnWydkYXRhJ10gOiBudWxsO1xyXG4gICAgfWVsc2V7XHJcbiAgICAgIGxldCBwYXJhbXMgPSB7XHJcbiAgICAgICAgY2F0ZWdvcnlfY29kZSA6IHRoaXMuZ3JvdXAua2V5XHJcbiAgICAgIH1cclxuICAgICAgIHRoaXMuY2FsbEFwaS5xdWVyeSh7XHJcbiAgICAgICAgcGFnZVByb3ZpZGVyOiB0aGlzLnBhZ2VQcm92aWRlcixcclxuICAgICAgICAuLi5wYXJhbXMsXHJcbiAgICAgIH0sXHJcbiAgICAgIHtcclxuICAgICAgICBoZWFkZXJzOiB7XHJcbiAgICAgICAgICBcInByb3BlcnRpZXNcIjogXCIqXCIsXHJcbiAgICAgICAgfSxcclxuICAgICAgfSkuc3Vic2NyaWJlKHJlcyA9PiB7XHJcbiAgICAgICAgdGhpcy5keW5hbWljVmlld1NlcnZpY2Uuc2V0RGF0YVRvU3RvcmFnKHRoaXMuZ3JvdXAua2V5ICwgcmVzPy5lbnRyaWVzWzBdPy5bJ3Byb3BlcnRpZXMnXSk7XHJcbiAgICAgICAgdGhpcy5kYXRhID0gcmVzPy5lbnRyaWVzWzBdPy5bJ3Byb3BlcnRpZXMnXTtcclxuICBcclxuICAgICAgfSlcclxuICAgIH1cclxuICB9XHJcblxyXG4gIG5nT25EZXN0cm95KCl7XHJcbiAgICB0aGlzLmxhbmdTdWJzY3JpcHRpb24gPyB0aGlzLmxhbmdTdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKSA6IG51bGw7XHJcbiAgfVxyXG59XHJcbiIsIjxzcGFuICpuZ0lmPVwiZGF0YVwiPlxyXG4gICAge3tpc0FyYWJpYyA/IGRhdGFbJ2NhdGVnb3J5OmFyYWJpY1RpdGxlJ10gOiBkYXRhWydkYzp0aXRsZSddfX1cclxuPC9zcGFuPiJdfQ==
|
package/esm2015/lib/components/dynamic-view/cutome-voc-viewer/cutome-voc-viewer.component.js
CHANGED
|
@@ -17,7 +17,7 @@ export class CutomeVocViewerComponent {
|
|
|
17
17
|
}
|
|
18
18
|
}
|
|
19
19
|
CutomeVocViewerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: CutomeVocViewerComponent, deps: [{ token: i1.TranslationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
20
|
-
CutomeVocViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: CutomeVocViewerComponent, selector: "lib-cutome-voc-viewer", inputs: { type: "type", group: "group" }, ngImport: i0, template: "<span *ngIf=\"group\">\n <span *ngIf=\"type === 'vocabulary'\">\n {{\n \"vocabulary.\" + group.fetchedKey.directoryName + \".\" + group.key | translate\n }}\n </span>\n <span *ngIf=\"type === 'custom-voc'\">\n {{\n isArabic\n ? group.fetchedKey.properties.label_ar\n : group.fetchedKey.properties.label_en\n }}\n </span>\n</span>\n", styles: [""], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i3.TranslatePipe } });
|
|
20
|
+
CutomeVocViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: CutomeVocViewerComponent, selector: "lib-cutome-voc-viewer", inputs: { type: "type", group: "group" }, ngImport: i0, template: "<span *ngIf=\"group\">\r\n <span *ngIf=\"type === 'vocabulary'\">\r\n {{\r\n \"vocabulary.\" + group.fetchedKey.directoryName + \".\" + group.key | translate\r\n }}\r\n </span>\r\n <span *ngIf=\"type === 'custom-voc'\">\r\n {{\r\n isArabic\r\n ? group.fetchedKey.properties.label_ar\r\n : group.fetchedKey.properties.label_en\r\n }}\r\n </span>\r\n</span>\r\n", styles: [""], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i3.TranslatePipe } });
|
|
21
21
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: CutomeVocViewerComponent, decorators: [{
|
|
22
22
|
type: Component,
|
|
23
23
|
args: [{
|
|
@@ -30,4 +30,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
30
30
|
}], group: [{
|
|
31
31
|
type: Input
|
|
32
32
|
}] } });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3V0b21lLXZvYy12aWV3ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9keW5hbWljLXZpZXcvY3V0b21lLXZvYy12aWV3ZXIvY3V0b21lLXZvYy12aWV3ZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9keW5hbWljLXZpZXcvY3V0b21lLXZvYy12aWV3ZXIvY3V0b21lLXZvYy12aWV3ZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7Ozs7O0FBU3pELE1BQU0sT0FBTyx3QkFBd0I7SUFNbkMsWUFBb0Isa0JBQXVDO1FBQXZDLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBcUI7SUFBSSxDQUFDO0lBRWhFLFFBQVE7UUFDTixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDdkUsSUFBSSxDQUFDLFFBQVEsR0FBRyxHQUFHLENBQUM7UUFDdEIsQ0FBQyxDQUFDLENBQUE7SUFDSixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDckUsQ0FBQzs7cUhBaEJVLHdCQUF3Qjt5R0FBeEIsd0JBQXdCLHVHQ1RyQyxnY0FjQTsyRkRMYSx3QkFBd0I7a0JBTHBDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHVCQUF1QjtvQkFDakMsV0FBVyxFQUFFLG9DQUFvQztvQkFDakQsU0FBUyxFQUFFLENBQUMsb0NBQW9DLENBQUM7aUJBQ2xEO3lHQUdVLElBQUk7c0JBQVosS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgVHJhbnNsYXRpb25TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vQ29yZS9zZXJ2aWNlcy90cmFuc2xhdGlvbi90cmFuc2xhdGlvbi5zZXJ2aWNlJztcclxuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2xpYi1jdXRvbWUtdm9jLXZpZXdlcicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2N1dG9tZS12b2Mtdmlld2VyLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9jdXRvbWUtdm9jLXZpZXdlci5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDdXRvbWVWb2NWaWV3ZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuICBASW5wdXQoKSB0eXBlO1xyXG4gIEBJbnB1dCgpIGdyb3VwO1xyXG4gIGxhbmdTdWJzY3JpcHRpb24gOiBTdWJzY3JpcHRpb247XHJcbiAgaXNBcmFiaWMgO1xyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdHJhbnNsYXRpb25TZXJ2aWNlIDogVHJhbnNsYXRpb25TZXJ2aWNlKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICB0aGlzLmxhbmdTdWJzY3JpcHRpb24gPSB0aGlzLnRyYW5zbGF0aW9uU2VydmljZS5pc0FyYWJpYy5zdWJzY3JpYmUocmVzID0+IHtcclxuICAgICAgdGhpcy5pc0FyYWJpYyA9IHJlcztcclxuICAgIH0pXHJcbiAgfVxyXG5cclxuICBuZ09uRGVzdHJveSgpe1xyXG4gICAgdGhpcy5sYW5nU3Vic2NyaXB0aW9uID8gdGhpcy5sYW5nU3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKCkgOiBudWxsO1xyXG4gIH1cclxuXHJcbn1cclxuIiwiPHNwYW4gKm5nSWY9XCJncm91cFwiPlxyXG4gICAgPHNwYW4gKm5nSWY9XCJ0eXBlID09PSAndm9jYWJ1bGFyeSdcIj5cclxuICAgICAgICB7e1xyXG4gICAgICAgICAgXCJ2b2NhYnVsYXJ5LlwiICsgZ3JvdXAuZmV0Y2hlZEtleS5kaXJlY3RvcnlOYW1lICsgXCIuXCIgKyBncm91cC5rZXkgfCB0cmFuc2xhdGVcclxuICAgICAgICB9fVxyXG4gICAgICA8L3NwYW4+XHJcbiAgICAgIDxzcGFuICAqbmdJZj1cInR5cGUgPT09ICdjdXN0b20tdm9jJ1wiPlxyXG4gICAgICAgIHt7XHJcbiAgICAgICAgICBpc0FyYWJpY1xyXG4gICAgICAgICAgICA/IGdyb3VwLmZldGNoZWRLZXkucHJvcGVydGllcy5sYWJlbF9hclxyXG4gICAgICAgICAgICA6IGdyb3VwLmZldGNoZWRLZXkucHJvcGVydGllcy5sYWJlbF9lblxyXG4gICAgICAgIH19XHJcbiAgICAgIDwvc3Bhbj5cclxuPC9zcGFuPlxyXG4iXX0=
|
package/esm2015/lib/components/dynamic-view/department-viewer/department-viewer.component.js
CHANGED
|
@@ -1,14 +1,15 @@
|
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
|
2
|
-
import { switchMap, tap } from 'rxjs/operators';
|
|
3
2
|
import * as i0 from "@angular/core";
|
|
4
3
|
import * as i1 from "../../../Core/services/translation/translation.service";
|
|
5
4
|
import * as i2 from "../../../components/dynamic-form/components/dynamic-form-department/services/department-api.service";
|
|
6
|
-
import * as i3 from "
|
|
7
|
-
import * as i4 from "@
|
|
5
|
+
import * as i3 from "../dynamic-viewe.service";
|
|
6
|
+
import * as i4 from "@angular/common";
|
|
7
|
+
import * as i5 from "@ngx-translate/core";
|
|
8
8
|
export class DepartmentViewerComponent {
|
|
9
|
-
constructor(translation, DepartmentApiService) {
|
|
9
|
+
constructor(translation, DepartmentApiService, dynamicViewService) {
|
|
10
10
|
this.translation = translation;
|
|
11
11
|
this.DepartmentApiService = DepartmentApiService;
|
|
12
|
+
this.dynamicViewService = dynamicViewService;
|
|
12
13
|
/** Label of field */
|
|
13
14
|
this.label = '';
|
|
14
15
|
/** Value of field */
|
|
@@ -23,31 +24,48 @@ export class DepartmentViewerComponent {
|
|
|
23
24
|
this.noStyle = false;
|
|
24
25
|
}
|
|
25
26
|
ngOnInit() {
|
|
26
|
-
this.translation.isArabic
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
}))
|
|
30
|
-
.subscribe((res) => {
|
|
31
|
-
console.log('results', res);
|
|
32
|
-
if (res.entries.length > 0) {
|
|
33
|
-
this.departmentName = this.isArabic
|
|
34
|
-
? res.entries[0].properties['dept:arabicName']
|
|
35
|
-
: res.entries[0].properties['dept:englishName'];
|
|
36
|
-
}
|
|
37
|
-
else {
|
|
38
|
-
this.departmentName = this.value;
|
|
39
|
-
}
|
|
40
|
-
}, (err) => {
|
|
41
|
-
this.departmentName = this.value;
|
|
27
|
+
this.translation.isArabic.subscribe(res => {
|
|
28
|
+
this.isArabic = res;
|
|
29
|
+
this.getDepartment(this.value);
|
|
42
30
|
});
|
|
43
31
|
}
|
|
44
32
|
getDepartment(id) {
|
|
45
|
-
|
|
46
|
-
|
|
33
|
+
if (this.dynamicViewService.getDataFromStoredAggregation(this.value)) {
|
|
34
|
+
let storedDepartmentName = this.dynamicViewService.getDataFromStoredAggregation(this.value);
|
|
35
|
+
this.departmentName = this.isArabic ? storedDepartmentName['data']['arabicName'] : storedDepartmentName['data']['englishName'];
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
this.DepartmentApiService.getDepartmentDetails(this.value).subscribe((res) => {
|
|
39
|
+
var _a, _b, _c, _d;
|
|
40
|
+
console.log('results', res);
|
|
41
|
+
if (res.entries.length > 0) {
|
|
42
|
+
this.departmentName = this.isArabic
|
|
43
|
+
? (_a = res === null || res === void 0 ? void 0 : res.entries[0]) === null || _a === void 0 ? void 0 : _a.properties['dept:arabicName']
|
|
44
|
+
: (_b = res === null || res === void 0 ? void 0 : res.entries[0]) === null || _b === void 0 ? void 0 : _b.properties['dept:englishName'];
|
|
45
|
+
this.dynamicViewService.setDataToStorag(this.value, {
|
|
46
|
+
arabicName: (_c = res === null || res === void 0 ? void 0 : res.entries[0]) === null || _c === void 0 ? void 0 : _c.properties['dept:arabicName'],
|
|
47
|
+
englishName: (_d = res === null || res === void 0 ? void 0 : res.entries[0]) === null || _d === void 0 ? void 0 : _d.properties['dept:englishName']
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
this.departmentName = this.value;
|
|
52
|
+
this.dynamicViewService.setDataToStorag(this.value, {
|
|
53
|
+
arabicName: this.departmentName,
|
|
54
|
+
englishName: this.departmentName
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
}, (err) => {
|
|
58
|
+
this.departmentName = this.value;
|
|
59
|
+
this.dynamicViewService.setDataToStorag(this.value, {
|
|
60
|
+
arabicName: this.departmentName,
|
|
61
|
+
englishName: this.departmentName
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
}
|
|
47
65
|
}
|
|
48
66
|
}
|
|
49
|
-
DepartmentViewerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DepartmentViewerComponent, deps: [{ token: i1.TranslationService }, { token: i2.DepartmentApiService }], target: i0.ɵɵFactoryTarget.Component });
|
|
50
|
-
DepartmentViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: DepartmentViewerComponent, selector: "cts-department-viewer", inputs: { label: "label", value: "value", dropdownId: "dropdownId", vertical: "vertical", withOutLabel: "withOutLabel", noStyle: "noStyle" }, ngImport: i0, template: "<ng-container *ngIf=\"!noStyle\">\r\n <div\r\n class=\"my-dynamic-viewer\"\r\n [ngClass]=\"{ vertical: vertical === true, 'with-out-label': withOutLabel }\"\r\n >\r\n <div class=\"my-label\" *ngIf=\"!withOutLabel\">{{ label | translate }}</div>\r\n <div *ngIf=\"departmentName\" class=\"my-value\">\r\n {{ departmentName }}\r\n </div>\r\n </div>\r\n</ng-container>\r\n<ng-container *ngIf=\"noStyle\">\r\n {{ departmentName }}\r\n</ng-container>\r\n", styles: [""], directives: [{ type:
|
|
67
|
+
DepartmentViewerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DepartmentViewerComponent, deps: [{ token: i1.TranslationService }, { token: i2.DepartmentApiService }, { token: i3.DynamicVieweService }], target: i0.ɵɵFactoryTarget.Component });
|
|
68
|
+
DepartmentViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: DepartmentViewerComponent, selector: "cts-department-viewer", inputs: { label: "label", value: "value", dropdownId: "dropdownId", vertical: "vertical", withOutLabel: "withOutLabel", noStyle: "noStyle" }, ngImport: i0, template: "<ng-container *ngIf=\"!noStyle\">\r\n <div\r\n class=\"my-dynamic-viewer\"\r\n [ngClass]=\"{ vertical: vertical === true, 'with-out-label': withOutLabel }\"\r\n >\r\n <div class=\"my-label\" *ngIf=\"!withOutLabel\">{{ label | translate }}</div>\r\n <div *ngIf=\"departmentName\" class=\"my-value\">\r\n {{ departmentName }}\r\n </div>\r\n </div>\r\n</ng-container>\r\n<ng-container *ngIf=\"noStyle\">\r\n {{ departmentName }}\r\n</ng-container>\r\n", styles: [""], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "translate": i5.TranslatePipe } });
|
|
51
69
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DepartmentViewerComponent, decorators: [{
|
|
52
70
|
type: Component,
|
|
53
71
|
args: [{
|
|
@@ -55,7 +73,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
55
73
|
templateUrl: './department-viewer.component.html',
|
|
56
74
|
styleUrls: ['./department-viewer.component.scss'],
|
|
57
75
|
}]
|
|
58
|
-
}], ctorParameters: function () { return [{ type: i1.TranslationService }, { type: i2.DepartmentApiService }]; }, propDecorators: { label: [{
|
|
76
|
+
}], ctorParameters: function () { return [{ type: i1.TranslationService }, { type: i2.DepartmentApiService }, { type: i3.DynamicVieweService }]; }, propDecorators: { label: [{
|
|
59
77
|
type: Input
|
|
60
78
|
}], value: [{
|
|
61
79
|
type: Input
|
|
@@ -68,4 +86,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
68
86
|
}], noStyle: [{
|
|
69
87
|
type: Input
|
|
70
88
|
}] } });
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"department-viewer.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-view/department-viewer/department-viewer.component.ts","../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-view/department-viewer/department-viewer.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;;;;;;;AAkBzD,MAAM,OAAO,yBAAyB;IAgBpC,YACU,WAA+B,EAC/B,oBAA0C,EAC1C,kBAAwC;QAFxC,gBAAW,GAAX,WAAW,CAAoB;QAC/B,yBAAoB,GAApB,oBAAoB,CAAsB;QAC1C,uBAAkB,GAAlB,kBAAkB,CAAsB;QAflD,qBAAqB;QACZ,UAAK,GAAG,EAAE,CAAC;QACpB,qBAAqB;QACZ,UAAK,GAAG,EAAE,CAAC;QACpB,qBAAqB;QACZ,eAAU,GAAG,EAAE,CAAC;QACzB,kBAAkB;QACT,aAAQ,GAAG,KAAK,CAAC;QAC1B,qBAAqB;QACZ,iBAAY,GAAG,KAAK,CAAC;QAC9B,cAAc;QACL,YAAO,GAAG,KAAK,CAAC;IAKtB,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YACxC,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC;YACpB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,aAAa,CAAC,EAAE;QACd,IAAG,IAAI,CAAC,kBAAkB,CAAC,4BAA4B,CAAC,IAAI,CAAC,KAAK,CAAC,EAAC;YAClE,IAAI,oBAAoB,GAAG,IAAI,CAAC,kBAAkB,CAAC,4BAA4B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC5F,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC,aAAa,CAAC,CAAA;SAC/H;aAAI;YACH,IAAI,CAAC,oBAAoB,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,SAAS,CAClE,CAAC,GAAG,EAAE,EAAE;;gBACN,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;gBAC5B,IAAI,GAAG,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;oBAC1B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ;wBACjC,CAAC,CAAC,MAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,OAAO,CAAC,CAAC,CAAC,0CAAE,UAAU,CAAC,iBAAiB,CAAC;wBAChD,CAAC,CAAC,MAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,OAAO,CAAC,CAAC,CAAC,0CAAE,UAAU,CAAC,kBAAkB,CAAC,CAAC;oBAClD,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,EAAG;wBACnD,UAAU,EAAG,MAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,OAAO,CAAC,CAAC,CAAC,0CAAE,UAAU,CAAC,iBAAiB,CAAC;wBAC3D,WAAW,EAAG,MAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,OAAO,CAAC,CAAC,CAAC,0CAAE,UAAU,CAAC,kBAAkB,CAAC;qBAC9D,CAAC,CAAA;iBACL;qBAAM;oBACL,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC;oBACjC,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,EAAE;wBAClD,UAAU,EAAG,IAAI,CAAC,cAAc;wBAChC,WAAW,EAAG,IAAI,CAAC,cAAc;qBAClC,CAAC,CAAA;iBACH;YAEH,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;gBACN,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC;gBACjC,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,EAAE;oBAClD,UAAU,EAAG,IAAI,CAAC,cAAc;oBAChC,WAAW,EAAG,IAAI,CAAC,cAAc;iBAClC,CAAC,CAAA;YAEJ,CAAC,CACF,CAAC;SACH;IACH,CAAC;;sHAhEU,yBAAyB;0GAAzB,yBAAyB,2MClBtC,0dAcA;2FDIa,yBAAyB;kBALrC,SAAS;mBAAC;oBACT,QAAQ,EAAE,uBAAuB;oBACjC,WAAW,EAAE,oCAAoC;oBACjD,SAAS,EAAE,CAAC,oCAAoC,CAAC;iBAClD;8KAMU,KAAK;sBAAb,KAAK;gBAEG,KAAK;sBAAb,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBAEG,YAAY;sBAApB,KAAK;gBAEG,OAAO;sBAAf,KAAK","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { switchMap, tap } from 'rxjs/operators';\r\nimport { TranslationService } from '../../../Core/services/translation/translation.service';\r\nimport { Cacheable, LocalStorageStrategy } from 'ts-cacheable';\r\nimport { DocumentsService } from '../../documents/services/documents.service';\r\nimport {\r\n  DepartmentApiService,\r\n  departmentCacheBuster$,\r\n  minute,\r\n} from '../../../components/dynamic-form/components/dynamic-form-department/services/department-api.service';\r\nimport { DynamicVieweService } from '../dynamic-viewe.service';\r\n\r\n@Component({\r\n  selector: 'cts-department-viewer',\r\n  templateUrl: './department-viewer.component.html',\r\n  styleUrls: ['./department-viewer.component.scss'],\r\n})\r\nexport class DepartmentViewerComponent implements OnInit {\r\n  departmentName: string;\r\n  isArabic: boolean;\r\n  loading: boolean;\r\n  /** Label of field */\r\n  @Input() label = '';\r\n  /** Value of field */\r\n  @Input() value = '';\r\n  /** Vocabulary Key */\r\n  @Input() dropdownId = '';\r\n  /** is vertical */\r\n  @Input() vertical = false;\r\n  /** hide the label */\r\n  @Input() withOutLabel = false;\r\n  /**only text*/\r\n  @Input() noStyle = false;\r\n  constructor(\r\n    private translation: TranslationService,\r\n    private DepartmentApiService: DepartmentApiService,\r\n    private dynamicViewService : DynamicVieweService\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.translation.isArabic.subscribe(res =>{\r\n      this.isArabic = res;\r\n      this.getDepartment(this.value);\r\n    })\r\n  }\r\n\r\n  getDepartment(id) {\r\n    if(this.dynamicViewService.getDataFromStoredAggregation(this.value)){\r\n      let storedDepartmentName = this.dynamicViewService.getDataFromStoredAggregation(this.value);\r\n      this.departmentName = this.isArabic ? storedDepartmentName['data']['arabicName'] : storedDepartmentName['data']['englishName']\r\n    }else{\r\n      this.DepartmentApiService.getDepartmentDetails(this.value).subscribe(\r\n        (res) => {\r\n          console.log('results', res);\r\n          if (res.entries.length > 0) {\r\n            this.departmentName = this.isArabic\r\n              ? res?.entries[0]?.properties['dept:arabicName']\r\n              : res?.entries[0]?.properties['dept:englishName'];\r\n              this.dynamicViewService.setDataToStorag(this.value , {\r\n                arabicName : res?.entries[0]?.properties['dept:arabicName'],\r\n                englishName : res?.entries[0]?.properties['dept:englishName']\r\n              })\r\n          } else {\r\n            this.departmentName = this.value;\r\n            this.dynamicViewService.setDataToStorag(this.value ,{\r\n              arabicName : this.departmentName,\r\n              englishName : this.departmentName\r\n            })\r\n          }\r\n  \r\n        },\r\n        (err) => {\r\n          this.departmentName = this.value;\r\n          this.dynamicViewService.setDataToStorag(this.value ,{\r\n            arabicName : this.departmentName,\r\n            englishName : this.departmentName\r\n          })\r\n  \r\n        }\r\n      );\r\n    }\r\n  }\r\n}\r\n","<ng-container *ngIf=\"!noStyle\">\r\n  <div\r\n    class=\"my-dynamic-viewer\"\r\n    [ngClass]=\"{ vertical: vertical === true, 'with-out-label': withOutLabel }\"\r\n  >\r\n    <div class=\"my-label\" *ngIf=\"!withOutLabel\">{{ label | translate }}</div>\r\n    <div *ngIf=\"departmentName\" class=\"my-value\">\r\n      {{ departmentName }}\r\n    </div>\r\n  </div>\r\n</ng-container>\r\n<ng-container *ngIf=\"noStyle\">\r\n  {{ departmentName }}\r\n</ng-container>\r\n"]}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class DynamicVieweService {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.storedAggregations = {};
|
|
6
|
+
this.loadStoredAggregations();
|
|
7
|
+
}
|
|
8
|
+
loadStoredAggregations() {
|
|
9
|
+
if (localStorage.getItem('storedAgregations')) {
|
|
10
|
+
this.storedAggregations = JSON.parse(localStorage.getItem('storedAgregations'));
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
this.storedAggregations = {};
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
addingTimeStamp(data) {
|
|
17
|
+
return {
|
|
18
|
+
data: data,
|
|
19
|
+
time: new Date()
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
checkTimeStamp(time) {
|
|
23
|
+
let now = new Date();
|
|
24
|
+
let oldTime = new Date(time);
|
|
25
|
+
let days = Math.floor((now - oldTime) / (1000 * 60 * 60 * 24));
|
|
26
|
+
if (days < 2) {
|
|
27
|
+
return true;
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
return false;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
getDataFromStoredAggregation(id) {
|
|
34
|
+
// check if there is data with certain id
|
|
35
|
+
if (this.storedAggregations[id]) {
|
|
36
|
+
// check if stored data dosn;t exceed 2 days of storing
|
|
37
|
+
if (this.checkTimeStamp(this.storedAggregations[id]['time'])) {
|
|
38
|
+
return this.storedAggregations[id];
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
return null;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
return null;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
setDataToStorag(id, data) {
|
|
49
|
+
let updatedData = this.addingTimeStamp(data);
|
|
50
|
+
this.storedAggregations[id] = Object.assign({}, updatedData);
|
|
51
|
+
localStorage.setItem('storedAgregations', JSON.stringify(this.storedAggregations));
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
DynamicVieweService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DynamicVieweService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
55
|
+
DynamicVieweService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DynamicVieweService, providedIn: 'root' });
|
|
56
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: DynamicVieweService, decorators: [{
|
|
57
|
+
type: Injectable,
|
|
58
|
+
args: [{
|
|
59
|
+
providedIn: 'root'
|
|
60
|
+
}]
|
|
61
|
+
}], ctorParameters: function () { return []; } });
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy12aWV3ZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9keW5hbWljLXZpZXcvZHluYW1pYy12aWV3ZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSzNDLE1BQU0sT0FBTyxtQkFBbUI7SUFHOUI7UUFEQSx1QkFBa0IsR0FBRyxFQUFFLENBQUE7UUFFckIsSUFBSSxDQUFDLHNCQUFzQixFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVELHNCQUFzQjtRQUNwQixJQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsbUJBQW1CLENBQUMsRUFBQztZQUMzQyxJQUFJLENBQUMsa0JBQWtCLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQztTQUNqRjthQUFJO1lBQ0gsSUFBSSxDQUFDLGtCQUFrQixHQUFHLEVBQUUsQ0FBQztTQUM5QjtJQUNILENBQUM7SUFFRCxlQUFlLENBQUMsSUFBSTtRQUNsQixPQUFPO1lBQ0wsSUFBSSxFQUFHLElBQUk7WUFDWCxJQUFJLEVBQUcsSUFBSSxJQUFJLEVBQUU7U0FDbEIsQ0FBQTtJQUNILENBQUM7SUFFRCxjQUFjLENBQUMsSUFBSTtRQUNqQixJQUFJLEdBQUcsR0FBUyxJQUFJLElBQUksRUFBRSxDQUFDO1FBQzNCLElBQUksT0FBTyxHQUFRLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2xDLElBQUksSUFBSSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQy9ELElBQUcsSUFBSSxHQUFFLENBQUMsRUFBQztZQUNULE9BQU8sSUFBSSxDQUFBO1NBQ1o7YUFBSTtZQUNILE9BQU8sS0FBSyxDQUFBO1NBQ2I7SUFDSCxDQUFDO0lBRUQsNEJBQTRCLENBQUMsRUFBRTtRQUM3Qix5Q0FBeUM7UUFDekMsSUFBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsRUFBRSxDQUFDLEVBQUM7WUFDN0IsdURBQXVEO1lBQ3ZELElBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBQztnQkFDMUQsT0FBTyxJQUFJLENBQUMsa0JBQWtCLENBQUMsRUFBRSxDQUFDLENBQUM7YUFDcEM7aUJBQUk7Z0JBQ0gsT0FBTyxJQUFJLENBQUE7YUFDWjtTQUNGO2FBQUk7WUFDSCxPQUFPLElBQUksQ0FBQTtTQUNaO0lBQ0gsQ0FBQztJQUVELGVBQWUsQ0FBQyxFQUFFLEVBQUcsSUFBSTtRQUN2QixJQUFJLFdBQVcsR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzdDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFLENBQUMscUJBQU8sV0FBVyxDQUFDLENBQUM7UUFDL0MsWUFBWSxDQUFDLE9BQU8sQ0FBQyxtQkFBbUIsRUFBRyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLENBQUE7SUFDckYsQ0FBQzs7Z0hBbkRVLG1CQUFtQjtvSEFBbkIsbUJBQW1CLGNBRmxCLE1BQU07MkZBRVAsbUJBQW1CO2tCQUgvQixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIER5bmFtaWNWaWV3ZVNlcnZpY2Uge1xyXG5cclxuICBzdG9yZWRBZ2dyZWdhdGlvbnMgPSB7fVxyXG4gIGNvbnN0cnVjdG9yKCkgeyBcclxuICAgIHRoaXMubG9hZFN0b3JlZEFnZ3JlZ2F0aW9ucygpO1xyXG4gIH1cclxuXHJcbiAgbG9hZFN0b3JlZEFnZ3JlZ2F0aW9ucygpe1xyXG4gICAgaWYobG9jYWxTdG9yYWdlLmdldEl0ZW0oJ3N0b3JlZEFncmVnYXRpb25zJykpe1xyXG4gICAgICB0aGlzLnN0b3JlZEFnZ3JlZ2F0aW9ucyA9IEpTT04ucGFyc2UobG9jYWxTdG9yYWdlLmdldEl0ZW0oJ3N0b3JlZEFncmVnYXRpb25zJykpOyBcclxuICAgIH1lbHNle1xyXG4gICAgICB0aGlzLnN0b3JlZEFnZ3JlZ2F0aW9ucyA9IHt9O1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgYWRkaW5nVGltZVN0YW1wKGRhdGEpe1xyXG4gICAgcmV0dXJuIHtcclxuICAgICAgZGF0YSA6IGRhdGEsXHJcbiAgICAgIHRpbWUgOiBuZXcgRGF0ZSgpXHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBjaGVja1RpbWVTdGFtcCh0aW1lKXtcclxuICAgIGxldCBub3cgOiBhbnkgPSBuZXcgRGF0ZSgpO1xyXG4gICAgbGV0IG9sZFRpbWU6IGFueSA9IG5ldyBEYXRlKHRpbWUpO1xyXG4gICAgbGV0IGRheXMgPSBNYXRoLmZsb29yKChub3cgLSBvbGRUaW1lKSAvICgxMDAwICogNjAgKiA2MCAqIDI0KSk7XHJcbiAgICBpZihkYXlzIDwyKXtcclxuICAgICAgcmV0dXJuIHRydWVcclxuICAgIH1lbHNle1xyXG4gICAgICByZXR1cm4gZmFsc2VcclxuICAgIH1cclxuICB9XHJcblxyXG4gIGdldERhdGFGcm9tU3RvcmVkQWdncmVnYXRpb24oaWQpe1xyXG4gICAgLy8gY2hlY2sgaWYgdGhlcmUgaXMgZGF0YSB3aXRoIGNlcnRhaW4gaWRcclxuICAgIGlmKHRoaXMuc3RvcmVkQWdncmVnYXRpb25zW2lkXSl7XHJcbiAgICAgIC8vIGNoZWNrIGlmIHN0b3JlZCBkYXRhIGRvc247dCBleGNlZWQgMiBkYXlzIG9mIHN0b3JpbmdcclxuICAgICAgaWYodGhpcy5jaGVja1RpbWVTdGFtcCh0aGlzLnN0b3JlZEFnZ3JlZ2F0aW9uc1tpZF1bJ3RpbWUnXSkpe1xyXG4gICAgICAgIHJldHVybiB0aGlzLnN0b3JlZEFnZ3JlZ2F0aW9uc1tpZF07XHJcbiAgICAgIH1lbHNle1xyXG4gICAgICAgIHJldHVybiBudWxsXHJcbiAgICAgIH1cclxuICAgIH1lbHNle1xyXG4gICAgICByZXR1cm4gbnVsbFxyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgc2V0RGF0YVRvU3RvcmFnKGlkICwgZGF0YSl7XHJcbiAgICBsZXQgdXBkYXRlZERhdGEgPSB0aGlzLmFkZGluZ1RpbWVTdGFtcChkYXRhKTtcclxuICAgIHRoaXMuc3RvcmVkQWdncmVnYXRpb25zW2lkXSA9IHsuLi51cGRhdGVkRGF0YX07XHJcbiAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbSgnc3RvcmVkQWdyZWdhdGlvbnMnICwgSlNPTi5zdHJpbmdpZnkodGhpcy5zdG9yZWRBZ2dyZWdhdGlvbnMpKVxyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { __awaiter } from "tslib";
|
|
2
|
-
import { Component, ViewEncapsulation, } from "@angular/core";
|
|
2
|
+
import { Component, EventEmitter, 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";
|
|
@@ -22,6 +22,8 @@ export class NotificationsButtonComponent {
|
|
|
22
22
|
this.router = router;
|
|
23
23
|
this.ref = ref;
|
|
24
24
|
this.translationService = translationService;
|
|
25
|
+
this.toastrClick = new EventEmitter();
|
|
26
|
+
this.listItemClick = new EventEmitter();
|
|
25
27
|
}
|
|
26
28
|
get notificationsCount() {
|
|
27
29
|
return this.notificationsService.notificationsCount;
|
|
@@ -84,6 +86,7 @@ export class NotificationsButtonComponent {
|
|
|
84
86
|
queryParams: { location: this.router.url },
|
|
85
87
|
});
|
|
86
88
|
}
|
|
89
|
+
this.toastrClick.next(activity);
|
|
87
90
|
});
|
|
88
91
|
this.ref.markForCheck();
|
|
89
92
|
}));
|
|
@@ -103,6 +106,9 @@ export class NotificationsButtonComponent {
|
|
|
103
106
|
// })
|
|
104
107
|
// }, 1000);
|
|
105
108
|
}
|
|
109
|
+
onListItemClick(event) {
|
|
110
|
+
this.listItemClick.next(event);
|
|
111
|
+
}
|
|
106
112
|
ngOnDestroy() {
|
|
107
113
|
this.subscription.unsubscribe();
|
|
108
114
|
this.updater.unsubscribe();
|
|
@@ -149,7 +155,7 @@ export class NotificationsButtonComponent {
|
|
|
149
155
|
}
|
|
150
156
|
}
|
|
151
157
|
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 });
|
|
152
|
-
NotificationsButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: NotificationsButtonComponent, selector: "app-notifications-button", ngImport: i0, template: "<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></app-notifications-list>\r\n</mat-menu>\r\n", 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" }], 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.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgePosition", "matBadgeSize", "matBadgeColor", "matBadgeOverlap", "matBadgeDescription", "matBadgeHidden", "matBadge"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
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 }}\" 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", 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.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgePosition", "matBadgeSize", "matBadgeColor", "matBadgeOverlap", "matBadgeDescription", "matBadgeHidden", "matBadge"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
153
159
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: NotificationsButtonComponent, decorators: [{
|
|
154
160
|
type: Component,
|
|
155
161
|
args: [{
|
|
@@ -158,5 +164,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
|
|
|
158
164
|
styleUrls: ["./notifications-button.component.scss"],
|
|
159
165
|
encapsulation: ViewEncapsulation.None,
|
|
160
166
|
}]
|
|
161
|
-
}], ctorParameters: function () { return [{ type: i1.NotificationsService }, { type: i2.TranslateService }, { type: i3.ToastrService }, { type: i4.TimeAgoPipe }, { type: i5.Router }, { type: i0.ChangeDetectorRef }, { type: i6.TranslationService }]; }
|
|
162
|
-
//# 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  OnDestroy,\r\n  OnInit,\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@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  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          });\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  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></app-notifications-list>\r\n</mat-menu>\r\n"]}
|
|
167
|
+
}], ctorParameters: function () { return [{ type: i1.NotificationsService }, { type: i2.TranslateService }, { type: i3.ToastrService }, { type: i4.TimeAgoPipe }, { type: i5.Router }, { type: i0.ChangeDetectorRef }, { type: i6.TranslationService }]; }, propDecorators: { toastrClick: [{
|
|
168
|
+
type: Output
|
|
169
|
+
}], listItemClick: [{
|
|
170
|
+
type: Output
|
|
171
|
+
}] } });
|
|
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"]}
|