@alfresco/adf-core 7.0.0-alpha.9-13357533609 → 7.0.0-alpha.9-13367447514
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/esm2022/lib/language-menu/language-menu.component.mjs +7 -4
- package/esm2022/lib/language-menu/language-picker.component.mjs +21 -4
- package/esm2022/lib/notifications/components/notification-history.component.mjs +8 -16
- package/fesm2022/adf-core.mjs +33 -20
- package/fesm2022/adf-core.mjs.map +1 -1
- package/lib/language-menu/language-menu.component.d.ts +3 -1
- package/lib/language-menu/language-picker.component.d.ts +8 -2
- package/lib/notifications/components/notification-history.component.d.ts +2 -4
- package/lib/notifications/components/notification-history.component.scss +78 -65
- package/lib/styles/_mat-selectors.scss +0 -1
- package/package.json +3 -3
- package/schematics/migrations/schematics/migrations/collection.json +8 -8
|
@@ -14,10 +14,10 @@
|
|
|
14
14
|
* See the License for the specific language governing permissions and
|
|
15
15
|
* limitations under the License.
|
|
16
16
|
*/
|
|
17
|
-
import { Component, EventEmitter, Output } from '@angular/core';
|
|
17
|
+
import { Component, EventEmitter, Output, QueryList, ViewChildren } from '@angular/core';
|
|
18
18
|
import { LanguageService } from './service/language.service';
|
|
19
19
|
import { CommonModule } from '@angular/common';
|
|
20
|
-
import { MatMenuModule } from '@angular/material/menu';
|
|
20
|
+
import { MatMenuItem, MatMenuModule } from '@angular/material/menu';
|
|
21
21
|
import * as i0 from "@angular/core";
|
|
22
22
|
import * as i1 from "./service/language.service";
|
|
23
23
|
import * as i2 from "@angular/common";
|
|
@@ -34,7 +34,7 @@ export class LanguageMenuComponent {
|
|
|
34
34
|
this.languageService.changeLanguage(language);
|
|
35
35
|
}
|
|
36
36
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: LanguageMenuComponent, deps: [{ token: i1.LanguageService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
37
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: LanguageMenuComponent, isStandalone: true, selector: "adf-language-menu", outputs: { changedLanguage: "changedLanguage" }, ngImport: i0, template: `
|
|
37
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: LanguageMenuComponent, isStandalone: true, selector: "adf-language-menu", outputs: { changedLanguage: "changedLanguage" }, viewQueries: [{ propertyName: "menuItems", predicate: MatMenuItem, descendants: true }], ngImport: i0, template: `
|
|
38
38
|
<button mat-menu-item *ngFor="let language of languages$ | async" [attr.lang]="language.key" (click)="changeLanguage(language)">
|
|
39
39
|
{{ language.label }}
|
|
40
40
|
</button>
|
|
@@ -54,5 +54,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
54
54
|
}]
|
|
55
55
|
}], ctorParameters: () => [{ type: i1.LanguageService }], propDecorators: { changedLanguage: [{
|
|
56
56
|
type: Output
|
|
57
|
+
}], menuItems: [{
|
|
58
|
+
type: ViewChildren,
|
|
59
|
+
args: [MatMenuItem]
|
|
57
60
|
}] } });
|
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFuZ3VhZ2UtbWVudS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWIvY29yZS9zcmMvbGliL2xhbmd1YWdlLW1lbnUvbGFuZ3VhZ2UtbWVudS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7OztHQWVHO0FBRUgsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekYsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBRzdELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7OztBQVlwRSxNQUFNLE9BQU8scUJBQXFCO0lBVTlCLFlBQW9CLGVBQWdDO1FBQWhDLG9CQUFlLEdBQWYsZUFBZSxDQUFpQjtRQVRwRCx1Q0FBdUM7UUFFdkMsb0JBQWUsR0FBK0IsSUFBSSxZQUFZLEVBQWdCLENBQUM7UUFRM0UsSUFBSSxDQUFDLFVBQVUsR0FBRyxlQUFlLENBQUMsVUFBVSxDQUFDO0lBQ2pELENBQUM7SUFFRCxjQUFjLENBQUMsUUFBc0I7UUFDakMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDcEMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDbEQsQ0FBQzs4R0FqQlEscUJBQXFCO2tHQUFyQixxQkFBcUIsNEpBS2hCLFdBQVcsZ0RBWGY7Ozs7S0FJVCwyREFMUyxZQUFZLGdOQUFFLGFBQWE7OzJGQU81QixxQkFBcUI7a0JBVmpDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLG1CQUFtQjtvQkFDN0IsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxhQUFhLENBQUM7b0JBQ3RDLFFBQVEsRUFBRTs7OztLQUlUO2lCQUNKO29GQUlHLGVBQWU7c0JBRGQsTUFBTTtnQkFJUCxTQUFTO3NCQURSLFlBQVk7dUJBQUMsV0FBVyIsInNvdXJjZXNDb250ZW50IjpbIi8qIVxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCDCqSAyMDA1LTIwMjUgSHlsYW5kIFNvZnR3YXJlLCBJbmMuIGFuZCBpdHMgYWZmaWxpYXRlcy4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxuICpcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAqIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBCQVNJUyxcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICogbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cblxuaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIE91dHB1dCwgUXVlcnlMaXN0LCBWaWV3Q2hpbGRyZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IExhbmd1YWdlU2VydmljZSB9IGZyb20gJy4vc2VydmljZS9sYW5ndWFnZS5zZXJ2aWNlJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IExhbmd1YWdlSXRlbSB9IGZyb20gJy4uL2NvbW1vbi9zZXJ2aWNlcy9sYW5ndWFnZS1pdGVtLmludGVyZmFjZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTWF0TWVudUl0ZW0sIE1hdE1lbnVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9tZW51JztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdhZGYtbGFuZ3VhZ2UtbWVudScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBNYXRNZW51TW9kdWxlXSxcbiAgICB0ZW1wbGF0ZTogYFxuICAgICAgICA8YnV0dG9uIG1hdC1tZW51LWl0ZW0gKm5nRm9yPVwibGV0IGxhbmd1YWdlIG9mIGxhbmd1YWdlcyQgfCBhc3luY1wiIFthdHRyLmxhbmddPVwibGFuZ3VhZ2Uua2V5XCIgKGNsaWNrKT1cImNoYW5nZUxhbmd1YWdlKGxhbmd1YWdlKVwiPlxuICAgICAgICAgICAge3sgbGFuZ3VhZ2UubGFiZWwgfX1cbiAgICAgICAgPC9idXR0b24+XG4gICAgYFxufSlcbmV4cG9ydCBjbGFzcyBMYW5ndWFnZU1lbnVDb21wb25lbnQge1xuICAgIC8qKiBFbWl0dGVkIHdoZW4gdGhlIGxhbmd1YWdlIGNoYW5nZSAqL1xuICAgIEBPdXRwdXQoKVxuICAgIGNoYW5nZWRMYW5ndWFnZTogRXZlbnRFbWl0dGVyPExhbmd1YWdlSXRlbT4gPSBuZXcgRXZlbnRFbWl0dGVyPExhbmd1YWdlSXRlbT4oKTtcblxuICAgIEBWaWV3Q2hpbGRyZW4oTWF0TWVudUl0ZW0pXG4gICAgbWVudUl0ZW1zOiBRdWVyeUxpc3Q8TWF0TWVudUl0ZW0+O1xuXG4gICAgbGFuZ3VhZ2VzJDogT2JzZXJ2YWJsZTxMYW5ndWFnZUl0ZW1bXT47XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGxhbmd1YWdlU2VydmljZTogTGFuZ3VhZ2VTZXJ2aWNlKSB7XG4gICAgICAgIHRoaXMubGFuZ3VhZ2VzJCA9IGxhbmd1YWdlU2VydmljZS5sYW5ndWFnZXMkO1xuICAgIH1cblxuICAgIGNoYW5nZUxhbmd1YWdlKGxhbmd1YWdlOiBMYW5ndWFnZUl0ZW0pIHtcbiAgICAgICAgdGhpcy5jaGFuZ2VkTGFuZ3VhZ2UuZW1pdChsYW5ndWFnZSk7XG4gICAgICAgIHRoaXMubGFuZ3VhZ2VTZXJ2aWNlLmNoYW5nZUxhbmd1YWdlKGxhbmd1YWdlKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -14,9 +14,9 @@
|
|
|
14
14
|
* See the License for the specific language governing permissions and
|
|
15
15
|
* limitations under the License.
|
|
16
16
|
*/
|
|
17
|
-
import { Component, EventEmitter, Output } from '@angular/core';
|
|
17
|
+
import { Component, EventEmitter, Output, QueryList, ViewChild } from '@angular/core';
|
|
18
18
|
import { CommonModule } from '@angular/common';
|
|
19
|
-
import { MatMenuModule } from '@angular/material/menu';
|
|
19
|
+
import { MatMenu, MatMenuItem, MatMenuModule } from '@angular/material/menu';
|
|
20
20
|
import { TranslateModule } from '@ngx-translate/core';
|
|
21
21
|
import { LanguageMenuComponent } from './language-menu.component';
|
|
22
22
|
import { MatIconModule } from '@angular/material/icon';
|
|
@@ -28,8 +28,16 @@ export class LanguagePickerComponent {
|
|
|
28
28
|
constructor() {
|
|
29
29
|
this.changedLanguage = new EventEmitter();
|
|
30
30
|
}
|
|
31
|
+
ngAfterViewInit() {
|
|
32
|
+
const menuItems = this.languageMenuComponent.menuItems.filter((menuItem) => menuItem !== undefined);
|
|
33
|
+
const menuItemsQueryList = new QueryList();
|
|
34
|
+
menuItemsQueryList.reset(menuItems);
|
|
35
|
+
// eslint-disable-next-line no-underscore-dangle
|
|
36
|
+
this.menu._allItems = menuItemsQueryList;
|
|
37
|
+
this.menu.ngAfterContentInit();
|
|
38
|
+
}
|
|
31
39
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: LanguagePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
32
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: LanguagePickerComponent, isStandalone: true, selector: "adf-picker-button", outputs: { changedLanguage: "changedLanguage" }, ngImport: i0, template: `
|
|
40
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: LanguagePickerComponent, isStandalone: true, selector: "adf-picker-button", outputs: { changedLanguage: "changedLanguage" }, viewQueries: [{ propertyName: "menu", first: true, predicate: ["langMenu"], descendants: true }, { propertyName: "menuItem", first: true, predicate: MatMenuItem, descendants: true }, { propertyName: "languageMenuComponent", first: true, predicate: LanguageMenuComponent, descendants: true }], ngImport: i0, template: `
|
|
33
41
|
<button mat-menu-item [matMenuTriggerFor]="langMenu">
|
|
34
42
|
<mat-icon>language</mat-icon>
|
|
35
43
|
{{ 'ADF.LANGUAGE' | translate }}
|
|
@@ -57,5 +65,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
57
65
|
}]
|
|
58
66
|
}], propDecorators: { changedLanguage: [{
|
|
59
67
|
type: Output
|
|
68
|
+
}], menu: [{
|
|
69
|
+
type: ViewChild,
|
|
70
|
+
args: ['langMenu']
|
|
71
|
+
}], menuItem: [{
|
|
72
|
+
type: ViewChild,
|
|
73
|
+
args: [MatMenuItem]
|
|
74
|
+
}], languageMenuComponent: [{
|
|
75
|
+
type: ViewChild,
|
|
76
|
+
args: [LanguageMenuComponent]
|
|
60
77
|
}] } });
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFuZ3VhZ2UtcGlja2VyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYi9jb3JlL3NyYy9saWIvbGFuZ3VhZ2UtbWVudS9sYW5ndWFnZS1waWNrZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7Ozs7R0FlRztBQUVILE9BQU8sRUFBaUIsU0FBUyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVyRyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDN0UsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7Ozs7QUFnQnZELE1BQU0sT0FBTyx1QkFBdUI7SUFkcEM7UUFnQlcsb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBZ0IsQ0FBQztLQW1CN0Q7SUFSRyxlQUFlO1FBQ1gsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLHFCQUFxQixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLFFBQVEsS0FBSyxTQUFTLENBQUMsQ0FBQztRQUNwRyxNQUFNLGtCQUFrQixHQUFHLElBQUksU0FBUyxFQUFlLENBQUM7UUFDeEQsa0JBQWtCLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ3BDLGdEQUFnRDtRQUNoRCxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsR0FBRyxrQkFBa0IsQ0FBQztRQUN6QyxJQUFJLENBQUMsSUFBSSxDQUFDLGtCQUFrQixFQUFFLENBQUM7SUFDbkMsQ0FBQzs4R0FwQlEsdUJBQXVCO2tHQUF2Qix1QkFBdUIsMlBBT3JCLFdBQVcsd0ZBR1gscUJBQXFCLGdEQXBCdEI7Ozs7Ozs7O0tBUVQsMkRBVFMsWUFBWSw4QkFBRSxhQUFhLDZ2QkFBRSxlQUFlLDRGQUFFLHFCQUFxQiwyRkFBRSxhQUFhOzsyRkFXbkYsdUJBQXVCO2tCQWRuQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxtQkFBbUI7b0JBQzdCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsYUFBYSxFQUFFLGVBQWUsRUFBRSxxQkFBcUIsRUFBRSxhQUFhLENBQUM7b0JBQzdGLFFBQVEsRUFBRTs7Ozs7Ozs7S0FRVDtpQkFDSjs4QkFHVSxlQUFlO3NCQURyQixNQUFNO2dCQUlQLElBQUk7c0JBREgsU0FBUzt1QkFBQyxVQUFVO2dCQUlyQixRQUFRO3NCQURQLFNBQVM7dUJBQUMsV0FBVztnQkFJdEIscUJBQXFCO3NCQURwQixTQUFTO3VCQUFDLHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbIi8qIVxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCDCqSAyMDA1LTIwMjUgSHlsYW5kIFNvZnR3YXJlLCBJbmMuIGFuZCBpdHMgYWZmaWxpYXRlcy4gQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxuICpcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAqIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBCQVNJUyxcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICogbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cblxuaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIE91dHB1dCwgUXVlcnlMaXN0LCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IExhbmd1YWdlSXRlbSB9IGZyb20gJy4uL2NvbW1vbi9zZXJ2aWNlcy9sYW5ndWFnZS1pdGVtLmludGVyZmFjZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTWF0TWVudSwgTWF0TWVudUl0ZW0sIE1hdE1lbnVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9tZW51JztcbmltcG9ydCB7IFRyYW5zbGF0ZU1vZHVsZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHsgTGFuZ3VhZ2VNZW51Q29tcG9uZW50IH0gZnJvbSAnLi9sYW5ndWFnZS1tZW51LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnYWRmLXBpY2tlci1idXR0b24nLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgTWF0TWVudU1vZHVsZSwgVHJhbnNsYXRlTW9kdWxlLCBMYW5ndWFnZU1lbnVDb21wb25lbnQsIE1hdEljb25Nb2R1bGVdLFxuICAgIHRlbXBsYXRlOiBgXG4gICAgICAgIDxidXR0b24gbWF0LW1lbnUtaXRlbSBbbWF0TWVudVRyaWdnZXJGb3JdPVwibGFuZ01lbnVcIj5cbiAgICAgICAgICAgIDxtYXQtaWNvbj5sYW5ndWFnZTwvbWF0LWljb24+XG4gICAgICAgICAgICB7eyAnQURGLkxBTkdVQUdFJyB8IHRyYW5zbGF0ZSB9fVxuICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgPG1hdC1tZW51ICNsYW5nTWVudT1cIm1hdE1lbnVcIj5cbiAgICAgICAgICAgIDxhZGYtbGFuZ3VhZ2UtbWVudSAoY2hhbmdlZExhbmd1YWdlKT1cImNoYW5nZWRMYW5ndWFnZS5lbWl0KCRldmVudClcIiAvPlxuICAgICAgICA8L21hdC1tZW51PlxuICAgIGBcbn0pXG5leHBvcnQgY2xhc3MgTGFuZ3VhZ2VQaWNrZXJDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0IHtcbiAgICBAT3V0cHV0KClcbiAgICBwdWJsaWMgY2hhbmdlZExhbmd1YWdlID0gbmV3IEV2ZW50RW1pdHRlcjxMYW5ndWFnZUl0ZW0+KCk7XG5cbiAgICBAVmlld0NoaWxkKCdsYW5nTWVudScpXG4gICAgbWVudTogTWF0TWVudTtcblxuICAgIEBWaWV3Q2hpbGQoTWF0TWVudUl0ZW0pXG4gICAgbWVudUl0ZW06IE1hdE1lbnVJdGVtO1xuXG4gICAgQFZpZXdDaGlsZChMYW5ndWFnZU1lbnVDb21wb25lbnQpXG4gICAgbGFuZ3VhZ2VNZW51Q29tcG9uZW50OiBMYW5ndWFnZU1lbnVDb21wb25lbnQ7XG5cbiAgICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgICAgIGNvbnN0IG1lbnVJdGVtcyA9IHRoaXMubGFuZ3VhZ2VNZW51Q29tcG9uZW50Lm1lbnVJdGVtcy5maWx0ZXIoKG1lbnVJdGVtKSA9PiBtZW51SXRlbSAhPT0gdW5kZWZpbmVkKTtcbiAgICAgICAgY29uc3QgbWVudUl0ZW1zUXVlcnlMaXN0ID0gbmV3IFF1ZXJ5TGlzdDxNYXRNZW51SXRlbT4oKTtcbiAgICAgICAgbWVudUl0ZW1zUXVlcnlMaXN0LnJlc2V0KG1lbnVJdGVtcyk7XG4gICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby11bmRlcnNjb3JlLWRhbmdsZVxuICAgICAgICB0aGlzLm1lbnUuX2FsbEl0ZW1zID0gbWVudUl0ZW1zUXVlcnlMaXN0O1xuICAgICAgICB0aGlzLm1lbnUubmdBZnRlckNvbnRlbnRJbml0KCk7XG4gICAgfVxufVxuIl19
|
|
@@ -36,8 +36,7 @@ import * as i4 from "@angular/material/menu";
|
|
|
36
36
|
import * as i5 from "@ngx-translate/core";
|
|
37
37
|
import * as i6 from "@angular/material/icon";
|
|
38
38
|
import * as i7 from "@angular/material/badge";
|
|
39
|
-
import * as i8 from "@angular/material/
|
|
40
|
-
import * as i9 from "@angular/material/divider";
|
|
39
|
+
import * as i8 from "@angular/material/divider";
|
|
41
40
|
export class NotificationHistoryComponent {
|
|
42
41
|
static { this.MAX_NOTIFICATION_STACK_LENGTH = 100; }
|
|
43
42
|
static { this.NOTIFICATION_STORAGE = 'notification-history'; }
|
|
@@ -78,20 +77,11 @@ export class NotificationHistoryComponent {
|
|
|
78
77
|
onMenuOpened() {
|
|
79
78
|
this.createPagination();
|
|
80
79
|
}
|
|
81
|
-
onKeyPress(event) {
|
|
82
|
-
this.closeUserModal(event);
|
|
83
|
-
}
|
|
84
|
-
closeUserModal($event) {
|
|
85
|
-
if ($event.keyCode === 27) {
|
|
86
|
-
this.trigger.closeMenu();
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
80
|
markAsRead() {
|
|
90
81
|
this.notifications = [];
|
|
91
82
|
this.paginatedNotifications = [];
|
|
92
83
|
this.storageService.removeItem(NotificationHistoryComponent.NOTIFICATION_STORAGE);
|
|
93
84
|
this.createPagination();
|
|
94
|
-
this.trigger.closeMenu();
|
|
95
85
|
}
|
|
96
86
|
createPagination() {
|
|
97
87
|
this.pagination = {
|
|
@@ -102,7 +92,8 @@ export class NotificationHistoryComponent {
|
|
|
102
92
|
};
|
|
103
93
|
this.paginatedNotifications = this.notifications.slice(0, this.pagination.skipCount);
|
|
104
94
|
}
|
|
105
|
-
loadMore() {
|
|
95
|
+
loadMore($event) {
|
|
96
|
+
$event.stopPropagation();
|
|
106
97
|
this.pagination.skipCount = this.pagination.maxItems + this.pagination.skipCount;
|
|
107
98
|
this.pagination.hasMoreItems = this.notifications.length > this.pagination.skipCount;
|
|
108
99
|
this.paginatedNotifications = this.notifications.slice(0, this.pagination.skipCount);
|
|
@@ -110,14 +101,15 @@ export class NotificationHistoryComponent {
|
|
|
110
101
|
hasMoreNotifications() {
|
|
111
102
|
return this.pagination?.hasMoreItems;
|
|
112
103
|
}
|
|
113
|
-
onNotificationClick(notification) {
|
|
104
|
+
onNotificationClick(notification, $event) {
|
|
105
|
+
$event.stopPropagation();
|
|
114
106
|
if (notification.clickCallBack) {
|
|
115
107
|
notification.clickCallBack(notification.args);
|
|
116
108
|
this.trigger.closeMenu();
|
|
117
109
|
}
|
|
118
110
|
}
|
|
119
111
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: NotificationHistoryComponent, deps: [{ token: i1.NotificationService }, { token: i2.StorageService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
120
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: NotificationHistoryComponent, isStandalone: true, selector: "adf-notification-history", inputs: { menuPositionX: "menuPositionX", menuPositionY: "menuPositionY", maxNotifications: "maxNotifications" }, viewQueries: [{ propertyName: "trigger", first: true, predicate: MatMenuTrigger, descendants: true, static: true }], ngImport: i0, template: "<div (keyup)=\"onKeyPress($event)\" tabindex=\"-1\" role=\"button\" class=\"adf-notification-history-container\">\n <button mat-button\n [matMenuTriggerFor]=\"menu\"\n aria-hidden=\"false\"\n [attr.aria-label]=\"'NOTIFICATIONS.OPEN_HISTORY' | translate\"\n title=\"{{ 'NOTIFICATIONS.OPEN_HISTORY' | translate }}\"\n class=\"adf-notification-history-menu_button\"\n id=\"adf-notification-history-open-button\"\n (menuOpened)=\"onMenuOpened()\">\n <mat-icon matBadge=\"⁠\"\n [matBadgeHidden]=\"!notifications.length\"\n class=\"adf-notification-history-menu_button-icon\"\n matBadgeColor=\"accent\"\n matBadgeSize=\"small\">notifications\n </mat-icon>\n </button>\n <mat-menu #menu=\"matMenu\"\n [xPosition]=\"menuPositionX\"\n [yPosition]=\"menuPositionY\"\n id=\"adf-notification-history-menu\"\n class=\"adf-notification-history-menu adf-notification-history-menu-panel\">\n <div class=\"adf-notification-history-list\"\n role=\"button\"\n tabindex=\"0\"\n (keyup.enter)=\"$event.stopPropagation()\"\n (click)=\"$event.stopPropagation()\">\n <div mat-subheader role=\"menuitem\">\n <span class=\"adf-notification-history-menu-title\">{{ 'NOTIFICATIONS.TITLE' | translate }}</span>\n <button *ngIf=\"notifications.length\"\n id=\"adf-notification-history-mark-as-read\"\n class=\"adf-notification-history-mark-as-read\"\n mat-icon-button\n title=\"{{ 'NOTIFICATIONS.MARK_AS_READ' | translate }}\"\n (click)=\"markAsRead()\">\n <mat-icon>done_all</mat-icon>\n </button>\n </div>\n\n <mat-divider />\n\n <mat-list role=\"menuitem\">\n <ng-container *ngIf=\"notifications.length; else empty_list_template\">\n <mat-list-item *ngFor=\"let notification of paginatedNotifications\"\n class=\"adf-notification-history-menu-item\"\n (click)=\"onNotificationClick(notification)\">\n <div *ngIf=\"notification.initiator; else no_avatar\"\n matListItemAvatar\n [outerHTML]=\"notification.initiator | usernameInitials : 'adf-notification-initiator-pic'\"></div>\n <ng-template #no_avatar>\n <mat-icon matListItemLine\n class=\"adf-notification-history-menu-initiator\">{{notification.icon}}</mat-icon>\n </ng-template>\n <div class=\"adf-notification-history-menu-item-content\">\n <p class=\"adf-notification-history-menu-text adf-notification-history-menu-message\"\n *ngFor=\"let message of notification.messages\"\n matListItemLine [title]=\"message\">{{ message }}</p>\n <p class=\"adf-notification-history-menu-text adf-notification-history-menu-date\"\n matListItemLine> {{notification.datetime | adfTimeAgo}} </p>\n </div>\n </mat-list-item>\n </ng-container>\n <ng-template #empty_list_template>\n <mat-list-item id=\"adf-notification-history-component-no-message\"\n class=\"adf-notification-history-menu-no-message\">\n <p class=\"adf-notification-history-menu-no-message-text\" matListItemLine>{{ 'NOTIFICATIONS.NO_MESSAGE' | translate }}</p>\n </mat-list-item>\n </ng-template>\n </mat-list>\n\n <mat-divider />\n\n <div class=\"adf-notification-history-load-more\" role=\"menuitem\" *ngIf=\"hasMoreNotifications()\">\n <button mat-button (click)=\"loadMore()\">\n {{ 'NOTIFICATIONS.LOAD_MORE' | translate }}\n </button>\n </div>\n </div>\n </mat-menu>\n</div>\n", styles: [".adf-notification-history-container{margin-top:1px}.adf-notification-history-list .adf-notification-history-menu-item-content-wrapper{height:100%;display:flex;align-items:center}.adf-notification-history-list .mdc-list-item__secondary-text:before{height:auto}.adf-notification-history-menu-item-content{display:flex;flex-direction:column;box-sizing:border-box;overflow:hidden;padding:0 0 0 16px}.adf-notification-history-menu-item-content p{line-height:16px;margin-bottom:0;color:var(--theme-sidenav-user-menu-color)}.adf-notification-history-menu-title{font-size:14px;-webkit-font-smoothing:subpixel-antialiased}.adf-notification-history-menu_button.mat-mdc-button{border-radius:90%;padding:0;min-width:40px;height:40px}.adf-notification-history-menu_button.mat-mdc-button .adf-notification-history-menu_button-icon{margin-right:0;font-size:24px;height:24px;width:24px;color:var(--theme-text-color)}.adf-notification-history-list .mat-mdc-subheader{display:flex;justify-content:space-between;align-items:center}.adf-notification-history-menu:has(.adf-notification-history-list) .adf-notification-history-menu-item{cursor:pointer;height:72px;align-items:center;padding-left:16px}.adf-notification-history-menu:has(.adf-notification-history-list) .adf-notification-history-menu-item:focus{outline:none;background:var(--adf-theme-background-hover-color)}.adf-notification-history-menu:has(.adf-notification-history-list) .adf-notification-history-menu-item:hover{background-color:var(--adf-theme-background-hover-color)}.adf-notification-history-menu:has(.adf-notification-history-list) .adf-notification-history-menu-message:is(p),.adf-notification-history-menu:has(.adf-notification-history-list) .adf-notification-history-menu-no-message:is(p){font-size:var(--theme-body-1-font-size)}.adf-notification-history-menu:has(.adf-notification-history-list) .adf-notification-history-menu-no-message-text{font-size:16px;color:var(--theme-sidenav-user-menu-color);margin-bottom:0;-webkit-font-smoothing:subpixel-antialiased}.adf-notification-history-menu:has(.adf-notification-history-list) .adf-notification-history-menu-date.adf-notification-history-menu-text:is(p){font-size:var(--theme-caption-font-size)}.adf-notification-history-menu:has(.adf-notification-history-list) .adf-notification-history-menu-initiator{margin:4px}.adf-notification-initiator-pic{min-width:40px;background:var(--theme-accent-color);display:inline-block;height:40px;border-radius:100px;text-align:center;font-weight:bolder;font-size:var(--theme-adf-picture-1-font-size);text-transform:uppercase;vertical-align:middle;line-height:40px;color:var(--adf-theme-mat-grey-color-a200)}.adf-notification-history-load-more{display:flex;justify-content:center;padding:10px}.adf-notification-history-load-more button{width:100%}.adf-notification-history-mark-as-read{margin:4px 0}.mat-mdc-menu-panel.adf-notification-history-menu.adf-notification-history-menu-panel{min-width:320px;max-height:500px}.mat-mdc-menu-panel.adf-notification-history-menu.adf-notification-history-menu-panel .mat-mdc-menu-content{padding:0}.mat-mdc-menu-panel.adf-notification-history-menu.adf-notification-history-menu-panel .mat-mdc-menu-content .mat-mdc-list{padding:8px 0 0}.mat-mdc-menu-panel.adf-notification-history-menu.adf-notification-history-menu-panel .mat-mdc-menu-content .mat-mdc-list .mat-mdc-list-item-unscoped-content{display:flex}.mat-mdc-menu-panel.adf-notification-history-menu.adf-notification-history-menu-panel .mat-mdc-menu-content .mat-mdc-list .mdc-list-item__content{display:flex;align-items:center}\n"], dependencies: [{ kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i3.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i4.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "directive", type: i4.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatBadgeModule }, { kind: "directive", type: i7.MatBadge, selector: "[matBadge]", inputs: ["matBadgeColor", "matBadgeOverlap", "matBadgeDisabled", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "ngmodule", type: MatListModule }, { kind: "component", type: i8.MatList, selector: "mat-list", exportAs: ["matList"] }, { kind: "component", type: i8.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }, { kind: "directive", type: i8.MatListItemAvatar, selector: "[matListItemAvatar]" }, { kind: "directive", type: i8.MatListSubheaderCssMatStyler, selector: "[mat-subheader], [matSubheader]" }, { kind: "component", type: i9.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "directive", type: i8.MatListItemLine, selector: "[matListItemLine]" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "pipe", type: TimeAgoPipe, name: "adfTimeAgo" }, { kind: "pipe", type: InitialUsernamePipe, name: "usernameInitials" }, { kind: "ngmodule", type: MatSnackBarModule }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
112
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: NotificationHistoryComponent, isStandalone: true, selector: "adf-notification-history", inputs: { menuPositionX: "menuPositionX", menuPositionY: "menuPositionY", maxNotifications: "maxNotifications" }, viewQueries: [{ propertyName: "trigger", first: true, predicate: MatMenuTrigger, descendants: true, static: true }], ngImport: i0, template: "<button mat-button\n [matMenuTriggerFor]=\"menu\"\n aria-hidden=\"false\"\n [attr.aria-label]=\"'NOTIFICATIONS.OPEN_HISTORY' | translate\"\n title=\"{{ 'NOTIFICATIONS.OPEN_HISTORY' | translate }}\"\n class=\"adf-notification-history-menu_button\"\n id=\"adf-notification-history-open-button\"\n (menuOpened)=\"onMenuOpened()\">\n <mat-icon matBadge=\"⁠\"\n [matBadgeHidden]=\"!notifications.length\"\n class=\"adf-notification-history-menu_button-icon\"\n matBadgeColor=\"accent\"\n matBadgeSize=\"small\">notifications\n </mat-icon>\n</button>\n\n<mat-menu #menu=\"matMenu\"\n [xPosition]=\"menuPositionX\"\n [yPosition]=\"menuPositionY\"\n id=\"adf-notification-history-menu\"\n class=\"adf-notification-history-menu adf-notification-history-menu-panel\">\n <div class=\"adf-notification-history-list-header\">\n <span class=\"adf-notification-history-menu-title\">{{ 'NOTIFICATIONS.TITLE' | translate }}</span>\n <button mat-menu-item\n *ngIf=\"notifications.length\"\n id=\"adf-notification-history-mark-as-read\"\n class=\"adf-notification-history-mark-as-read\"\n title=\"{{ 'NOTIFICATIONS.MARK_AS_READ' | translate }}\"\n (click)=\"markAsRead()\">\n <mat-icon class=\"adf-notification-history-mark-as-read-icon\">done_all</mat-icon>\n </button>\n </div>\n\n <mat-divider/>\n\n <div class=\"adf-notification-history-item-list\">\n <ng-container *ngIf=\"notifications.length; else empty_list_template\">\n <button mat-menu-item\n *ngFor=\"let notification of paginatedNotifications\"\n (click)=\"onNotificationClick(notification, $event)\"\n class=\"adf-notification-history-menu-item\">\n <div class=\"adf-notification-history-menu-item-content\">\n <div *ngIf=\"notification.initiator; else no_avatar\"\n [outerHTML]=\"notification.initiator | usernameInitials : 'adf-notification-initiator-pic'\"></div>\n <ng-template #no_avatar>\n <mat-icon class=\"adf-notification-history-menu-initiator\">\n {{ notification.icon }}\n </mat-icon>\n </ng-template>\n <div class=\"adf-notification-history-menu-item-content-message\">\n <p class=\"adf-notification-history-menu-text adf-notification-history-menu-message\"\n *ngFor=\"let message of notification.messages\"\n [title]=\"message\">{{ message }}</p>\n <p class=\"adf-notification-history-menu-text adf-notification-history-menu-date\"\n > {{ notification.datetime | adfTimeAgo }} </p>\n </div>\n </div>\n </button>\n </ng-container>\n <ng-template #empty_list_template>\n <p mat-menu-item id=\"adf-notification-history-component-no-message\"\n class=\"adf-notification-history-menu-no-message-text\">\n {{ 'NOTIFICATIONS.NO_MESSAGE' | translate }}\n </p>\n </ng-template>\n </div>\n\n <mat-divider/>\n\n <div class=\"adf-notification-history-load-more\" *ngIf=\"hasMoreNotifications()\">\n <button mat-menu-item (click)=\"loadMore($event)\">\n {{ 'NOTIFICATIONS.LOAD_MORE' | translate }}\n </button>\n </div>\n</mat-menu>\n", styles: [".adf-notification-history-menu-title{font-size:14px;-webkit-font-smoothing:subpixel-antialiased}.adf-notification-history-menu_button.mat-mdc-button{border-radius:90%;padding:0;min-width:40px;height:40px;margin-top:1px}.adf-notification-history-menu_button.mat-mdc-button .adf-notification-history-menu_button-icon{margin-right:0;font-size:24px;height:24px;width:24px;color:var(--theme-text-color)}.adf-notification-history-menu .adf-notification-history-list-header{padding:10.5px 16px;display:flex;justify-content:space-between;align-items:center}.adf-notification-history-menu .adf-notification-history-list-header .adf-notification-history-mark-as-read{display:flex;padding:10px;width:auto;margin:4px 0}.adf-notification-history-menu .adf-notification-history-list-header .adf-notification-history-mark-as-read:hover,.adf-notification-history-menu .adf-notification-history-list-header .adf-notification-history-mark-as-read:focus,.adf-notification-history-menu .adf-notification-history-list-header .adf-notification-history-mark-as-read:active{background:none}.adf-notification-history-menu .adf-notification-history-list-header .adf-notification-history-mark-as-read-icon{margin:0;color:inherit}.adf-notification-history-menu .adf-notification-history-menu-title{line-height:28px}.adf-notification-history-menu .adf-notification-history-item-list{padding-top:8px}.adf-notification-history-menu .adf-notification-history-item-list .adf-notification-history-menu-item{cursor:pointer;height:72px;align-items:center;display:block;padding:0 14px}.adf-notification-history-menu .adf-notification-history-item-list .adf-notification-history-menu-item-content{height:100%;display:flex;align-items:center}.adf-notification-history-menu .adf-notification-history-item-list .adf-notification-history-menu-item-content-message{display:flex;flex-direction:column;justify-content:center;box-sizing:border-box;overflow:hidden;padding:0 0 0 16px}.adf-notification-history-menu .adf-notification-history-item-list .adf-notification-history-menu-item-content-message p{line-height:normal;margin:0;color:var(--theme-sidenav-user-menu-color)}.adf-notification-history-menu .adf-notification-history-menu-item:focus{outline:none;background:var(--adf-theme-background-hover-color)}.adf-notification-history-menu .adf-notification-history-menu-item:hover{background-color:var(--adf-theme-background-hover-color)}.adf-notification-history-menu .adf-notification-history-menu-message:is(p){white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:var(--theme-body-1-font-size)}.adf-notification-history-menu .adf-notification-history-item-list .adf-notification-history-menu-no-message-text{color:var(--theme-sidenav-user-menu-color);margin:0;padding:12px 16px;opacity:inherit;border:none}.adf-notification-history-menu .adf-notification-history-item-list .adf-notification-history-menu-no-message-text span{font-size:16px;-webkit-font-smoothing:subpixel-antialiased}.adf-notification-history-menu .adf-notification-history-menu-date.adf-notification-history-menu-text:is(p){font-size:var(--theme-caption-font-size);text-indent:3px}.adf-notification-history-menu .adf-notification-history-menu-initiator{margin:4px}.adf-notification-initiator-pic{min-width:40px;background:var(--theme-accent-color);display:inline-block;height:40px;border-radius:100px;text-align:center;font-weight:bolder;font-size:var(--theme-adf-picture-1-font-size);text-transform:uppercase;vertical-align:middle;line-height:40px;color:var(--adf-theme-mat-grey-color-a200)}.adf-notification-history-load-more{display:flex;justify-content:center;padding:10px}.adf-notification-history-load-more button{justify-content:center;width:100%;min-height:36px}.mat-mdc-menu-panel.adf-notification-history-menu.adf-notification-history-menu-panel{min-width:320px;max-height:500px}.mat-mdc-menu-panel.adf-notification-history-menu.adf-notification-history-menu-panel .mat-mdc-menu-content{padding:0}\n"], dependencies: [{ kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i3.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i4.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i4.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i4.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatBadgeModule }, { kind: "directive", type: i7.MatBadge, selector: "[matBadge]", inputs: ["matBadgeColor", "matBadgeOverlap", "matBadgeDisabled", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "ngmodule", type: MatListModule }, { kind: "component", type: i8.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "pipe", type: TimeAgoPipe, name: "adfTimeAgo" }, { kind: "pipe", type: InitialUsernamePipe, name: "usernameInitials" }, { kind: "ngmodule", type: MatSnackBarModule }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
121
113
|
}
|
|
122
114
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: NotificationHistoryComponent, decorators: [{
|
|
123
115
|
type: Component,
|
|
@@ -133,7 +125,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
133
125
|
TimeAgoPipe,
|
|
134
126
|
InitialUsernamePipe,
|
|
135
127
|
MatSnackBarModule
|
|
136
|
-
], encapsulation: ViewEncapsulation.None, template: "<
|
|
128
|
+
], encapsulation: ViewEncapsulation.None, template: "<button mat-button\n [matMenuTriggerFor]=\"menu\"\n aria-hidden=\"false\"\n [attr.aria-label]=\"'NOTIFICATIONS.OPEN_HISTORY' | translate\"\n title=\"{{ 'NOTIFICATIONS.OPEN_HISTORY' | translate }}\"\n class=\"adf-notification-history-menu_button\"\n id=\"adf-notification-history-open-button\"\n (menuOpened)=\"onMenuOpened()\">\n <mat-icon matBadge=\"⁠\"\n [matBadgeHidden]=\"!notifications.length\"\n class=\"adf-notification-history-menu_button-icon\"\n matBadgeColor=\"accent\"\n matBadgeSize=\"small\">notifications\n </mat-icon>\n</button>\n\n<mat-menu #menu=\"matMenu\"\n [xPosition]=\"menuPositionX\"\n [yPosition]=\"menuPositionY\"\n id=\"adf-notification-history-menu\"\n class=\"adf-notification-history-menu adf-notification-history-menu-panel\">\n <div class=\"adf-notification-history-list-header\">\n <span class=\"adf-notification-history-menu-title\">{{ 'NOTIFICATIONS.TITLE' | translate }}</span>\n <button mat-menu-item\n *ngIf=\"notifications.length\"\n id=\"adf-notification-history-mark-as-read\"\n class=\"adf-notification-history-mark-as-read\"\n title=\"{{ 'NOTIFICATIONS.MARK_AS_READ' | translate }}\"\n (click)=\"markAsRead()\">\n <mat-icon class=\"adf-notification-history-mark-as-read-icon\">done_all</mat-icon>\n </button>\n </div>\n\n <mat-divider/>\n\n <div class=\"adf-notification-history-item-list\">\n <ng-container *ngIf=\"notifications.length; else empty_list_template\">\n <button mat-menu-item\n *ngFor=\"let notification of paginatedNotifications\"\n (click)=\"onNotificationClick(notification, $event)\"\n class=\"adf-notification-history-menu-item\">\n <div class=\"adf-notification-history-menu-item-content\">\n <div *ngIf=\"notification.initiator; else no_avatar\"\n [outerHTML]=\"notification.initiator | usernameInitials : 'adf-notification-initiator-pic'\"></div>\n <ng-template #no_avatar>\n <mat-icon class=\"adf-notification-history-menu-initiator\">\n {{ notification.icon }}\n </mat-icon>\n </ng-template>\n <div class=\"adf-notification-history-menu-item-content-message\">\n <p class=\"adf-notification-history-menu-text adf-notification-history-menu-message\"\n *ngFor=\"let message of notification.messages\"\n [title]=\"message\">{{ message }}</p>\n <p class=\"adf-notification-history-menu-text adf-notification-history-menu-date\"\n > {{ notification.datetime | adfTimeAgo }} </p>\n </div>\n </div>\n </button>\n </ng-container>\n <ng-template #empty_list_template>\n <p mat-menu-item id=\"adf-notification-history-component-no-message\"\n class=\"adf-notification-history-menu-no-message-text\">\n {{ 'NOTIFICATIONS.NO_MESSAGE' | translate }}\n </p>\n </ng-template>\n </div>\n\n <mat-divider/>\n\n <div class=\"adf-notification-history-load-more\" *ngIf=\"hasMoreNotifications()\">\n <button mat-menu-item (click)=\"loadMore($event)\">\n {{ 'NOTIFICATIONS.LOAD_MORE' | translate }}\n </button>\n </div>\n</mat-menu>\n", styles: [".adf-notification-history-menu-title{font-size:14px;-webkit-font-smoothing:subpixel-antialiased}.adf-notification-history-menu_button.mat-mdc-button{border-radius:90%;padding:0;min-width:40px;height:40px;margin-top:1px}.adf-notification-history-menu_button.mat-mdc-button .adf-notification-history-menu_button-icon{margin-right:0;font-size:24px;height:24px;width:24px;color:var(--theme-text-color)}.adf-notification-history-menu .adf-notification-history-list-header{padding:10.5px 16px;display:flex;justify-content:space-between;align-items:center}.adf-notification-history-menu .adf-notification-history-list-header .adf-notification-history-mark-as-read{display:flex;padding:10px;width:auto;margin:4px 0}.adf-notification-history-menu .adf-notification-history-list-header .adf-notification-history-mark-as-read:hover,.adf-notification-history-menu .adf-notification-history-list-header .adf-notification-history-mark-as-read:focus,.adf-notification-history-menu .adf-notification-history-list-header .adf-notification-history-mark-as-read:active{background:none}.adf-notification-history-menu .adf-notification-history-list-header .adf-notification-history-mark-as-read-icon{margin:0;color:inherit}.adf-notification-history-menu .adf-notification-history-menu-title{line-height:28px}.adf-notification-history-menu .adf-notification-history-item-list{padding-top:8px}.adf-notification-history-menu .adf-notification-history-item-list .adf-notification-history-menu-item{cursor:pointer;height:72px;align-items:center;display:block;padding:0 14px}.adf-notification-history-menu .adf-notification-history-item-list .adf-notification-history-menu-item-content{height:100%;display:flex;align-items:center}.adf-notification-history-menu .adf-notification-history-item-list .adf-notification-history-menu-item-content-message{display:flex;flex-direction:column;justify-content:center;box-sizing:border-box;overflow:hidden;padding:0 0 0 16px}.adf-notification-history-menu .adf-notification-history-item-list .adf-notification-history-menu-item-content-message p{line-height:normal;margin:0;color:var(--theme-sidenav-user-menu-color)}.adf-notification-history-menu .adf-notification-history-menu-item:focus{outline:none;background:var(--adf-theme-background-hover-color)}.adf-notification-history-menu .adf-notification-history-menu-item:hover{background-color:var(--adf-theme-background-hover-color)}.adf-notification-history-menu .adf-notification-history-menu-message:is(p){white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:var(--theme-body-1-font-size)}.adf-notification-history-menu .adf-notification-history-item-list .adf-notification-history-menu-no-message-text{color:var(--theme-sidenav-user-menu-color);margin:0;padding:12px 16px;opacity:inherit;border:none}.adf-notification-history-menu .adf-notification-history-item-list .adf-notification-history-menu-no-message-text span{font-size:16px;-webkit-font-smoothing:subpixel-antialiased}.adf-notification-history-menu .adf-notification-history-menu-date.adf-notification-history-menu-text:is(p){font-size:var(--theme-caption-font-size);text-indent:3px}.adf-notification-history-menu .adf-notification-history-menu-initiator{margin:4px}.adf-notification-initiator-pic{min-width:40px;background:var(--theme-accent-color);display:inline-block;height:40px;border-radius:100px;text-align:center;font-weight:bolder;font-size:var(--theme-adf-picture-1-font-size);text-transform:uppercase;vertical-align:middle;line-height:40px;color:var(--adf-theme-mat-grey-color-a200)}.adf-notification-history-load-more{display:flex;justify-content:center;padding:10px}.adf-notification-history-load-more button{justify-content:center;width:100%;min-height:36px}.mat-mdc-menu-panel.adf-notification-history-menu.adf-notification-history-menu-panel{min-width:320px;max-height:500px}.mat-mdc-menu-panel.adf-notification-history-menu.adf-notification-history-menu-panel .mat-mdc-menu-content{padding:0}\n"] }]
|
|
137
129
|
}], ctorParameters: () => [{ type: i1.NotificationService }, { type: i2.StorageService }, { type: i0.ChangeDetectorRef }], propDecorators: { trigger: [{
|
|
138
130
|
type: ViewChild,
|
|
139
131
|
args: [MatMenuTrigger, { static: true }]
|
|
@@ -144,4 +136,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
144
136
|
}], maxNotifications: [{
|
|
145
137
|
type: Input
|
|
146
138
|
}] } });
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification-history.component.js","sourceRoot":"","sources":["../../../../../../../lib/core/src/lib/notifications/components/notification-history.component.ts","../../../../../../../lib/core/src/lib/notifications/components/notification-history.component.html"],"names":[],"mappings":"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","sourcesContent":["/*!\n * @license\n * Copyright © 2005-2025 Hyland Software, Inc. and its affiliates. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    DestroyRef,\n    inject,\n    Input,\n    OnInit,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport { NotificationService } from '../services/notification.service';\nimport { NOTIFICATION_TYPE, NotificationModel } from '../models/notification.model';\nimport { MatMenuModule, MatMenuTrigger, MenuPositionX, MenuPositionY } from '@angular/material/menu';\nimport { StorageService } from '../../common/services/storage.service';\nimport { PaginationModel } from '../../models/pagination.model';\nimport { MatButtonModule } from '@angular/material/button';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatBadgeModule } from '@angular/material/badge';\nimport { MatListModule } from '@angular/material/list';\nimport { NgForOf, NgIf } from '@angular/common';\nimport { InitialUsernamePipe, TimeAgoPipe } from '../../pipes';\nimport { MatSnackBarModule } from '@angular/material/snack-bar';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\n@Component({\n    selector: 'adf-notification-history',\n    standalone: true,\n    templateUrl: 'notification-history.component.html',\n    styleUrls: ['./notification-history.component.scss'],\n    imports: [\n        MatButtonModule,\n        MatMenuModule,\n        TranslateModule,\n        MatIconModule,\n        MatBadgeModule,\n        MatListModule,\n        NgIf,\n        NgForOf,\n        TimeAgoPipe,\n        InitialUsernamePipe,\n        MatSnackBarModule\n    ],\n    encapsulation: ViewEncapsulation.None\n})\nexport class NotificationHistoryComponent implements OnInit, AfterViewInit {\n    public static MAX_NOTIFICATION_STACK_LENGTH = 100;\n    public static NOTIFICATION_STORAGE = 'notification-history';\n\n    @ViewChild(MatMenuTrigger, { static: true })\n    trigger: MatMenuTrigger;\n\n    /** Custom choice for opening the menu at the bottom. Can be `before` or `after`. */\n    @Input()\n    menuPositionX: MenuPositionX = 'after';\n\n    /** Custom choice for opening the menu at the bottom. Can be `above` or `below`. */\n    @Input()\n    menuPositionY: MenuPositionY = 'below';\n\n    /** Maximum number of notifications to display. The rest will remain hidden until load more is clicked */\n    @Input()\n    maxNotifications: number = 5;\n\n    notifications: NotificationModel[] = [];\n    paginatedNotifications: NotificationModel[] = [];\n    pagination: PaginationModel;\n\n    private readonly destroyRef = inject(DestroyRef);\n\n    constructor(private notificationService: NotificationService, public storageService: StorageService, public cd: ChangeDetectorRef) {}\n\n    ngOnInit() {\n        this.notifications = JSON.parse(this.storageService.getItem(NotificationHistoryComponent.NOTIFICATION_STORAGE)) || [];\n    }\n\n    ngAfterViewInit(): void {\n        this.notificationService.notifications$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((notification: NotificationModel) => {\n            this.addNewNotification(notification);\n            this.cd.detectChanges();\n        });\n    }\n\n    addNewNotification(notification: NotificationModel) {\n        this.notifications.unshift(notification);\n\n        if (this.notifications.length > NotificationHistoryComponent.MAX_NOTIFICATION_STACK_LENGTH) {\n            this.notifications.shift();\n        }\n\n        this.saveNotifications();\n        this.createPagination();\n    }\n\n    saveNotifications() {\n        this.storageService.setItem(\n            NotificationHistoryComponent.NOTIFICATION_STORAGE,\n            JSON.stringify(this.notifications.filter((notification) => notification.type !== NOTIFICATION_TYPE.RECURSIVE))\n        );\n    }\n\n    onMenuOpened() {\n        this.createPagination();\n    }\n\n    onKeyPress(event: KeyboardEvent) {\n        this.closeUserModal(event);\n    }\n\n    private closeUserModal($event: KeyboardEvent) {\n        if ($event.keyCode === 27) {\n            this.trigger.closeMenu();\n        }\n    }\n\n    markAsRead() {\n        this.notifications = [];\n        this.paginatedNotifications = [];\n        this.storageService.removeItem(NotificationHistoryComponent.NOTIFICATION_STORAGE);\n        this.createPagination();\n        this.trigger.closeMenu();\n    }\n\n    createPagination() {\n        this.pagination = {\n            skipCount: this.maxNotifications,\n            maxItems: this.maxNotifications,\n            totalItems: this.notifications.length,\n            hasMoreItems: this.notifications.length > this.maxNotifications\n        };\n        this.paginatedNotifications = this.notifications.slice(0, this.pagination.skipCount);\n    }\n\n    loadMore() {\n        this.pagination.skipCount = this.pagination.maxItems + this.pagination.skipCount;\n        this.pagination.hasMoreItems = this.notifications.length > this.pagination.skipCount;\n        this.paginatedNotifications = this.notifications.slice(0, this.pagination.skipCount);\n    }\n\n    hasMoreNotifications(): boolean {\n        return this.pagination?.hasMoreItems;\n    }\n\n    onNotificationClick(notification: NotificationModel) {\n        if (notification.clickCallBack) {\n            notification.clickCallBack(notification.args);\n            this.trigger.closeMenu();\n        }\n    }\n}\n","<div (keyup)=\"onKeyPress($event)\" tabindex=\"-1\" role=\"button\" class=\"adf-notification-history-container\">\n    <button mat-button\n            [matMenuTriggerFor]=\"menu\"\n            aria-hidden=\"false\"\n            [attr.aria-label]=\"'NOTIFICATIONS.OPEN_HISTORY' | translate\"\n            title=\"{{ 'NOTIFICATIONS.OPEN_HISTORY' | translate }}\"\n            class=\"adf-notification-history-menu_button\"\n            id=\"adf-notification-history-open-button\"\n            (menuOpened)=\"onMenuOpened()\">\n        <mat-icon matBadge=\"&#8288;\"\n                  [matBadgeHidden]=\"!notifications.length\"\n                  class=\"adf-notification-history-menu_button-icon\"\n                  matBadgeColor=\"accent\"\n                  matBadgeSize=\"small\">notifications\n        </mat-icon>\n    </button>\n    <mat-menu #menu=\"matMenu\"\n              [xPosition]=\"menuPositionX\"\n              [yPosition]=\"menuPositionY\"\n              id=\"adf-notification-history-menu\"\n              class=\"adf-notification-history-menu adf-notification-history-menu-panel\">\n        <div class=\"adf-notification-history-list\"\n             role=\"button\"\n             tabindex=\"0\"\n             (keyup.enter)=\"$event.stopPropagation()\"\n             (click)=\"$event.stopPropagation()\">\n            <div mat-subheader role=\"menuitem\">\n                <span class=\"adf-notification-history-menu-title\">{{ 'NOTIFICATIONS.TITLE' | translate }}</span>\n                <button *ngIf=\"notifications.length\"\n                        id=\"adf-notification-history-mark-as-read\"\n                        class=\"adf-notification-history-mark-as-read\"\n                        mat-icon-button\n                        title=\"{{ 'NOTIFICATIONS.MARK_AS_READ' | translate }}\"\n                        (click)=\"markAsRead()\">\n                    <mat-icon>done_all</mat-icon>\n                </button>\n            </div>\n\n            <mat-divider />\n\n            <mat-list role=\"menuitem\">\n                <ng-container *ngIf=\"notifications.length; else empty_list_template\">\n                    <mat-list-item *ngFor=\"let notification of paginatedNotifications\"\n                                   class=\"adf-notification-history-menu-item\"\n                                   (click)=\"onNotificationClick(notification)\">\n                        <div *ngIf=\"notification.initiator; else no_avatar\"\n                             matListItemAvatar\n                             [outerHTML]=\"notification.initiator | usernameInitials : 'adf-notification-initiator-pic'\"></div>\n                        <ng-template #no_avatar>\n                            <mat-icon matListItemLine\n                                      class=\"adf-notification-history-menu-initiator\">{{notification.icon}}</mat-icon>\n                        </ng-template>\n                        <div class=\"adf-notification-history-menu-item-content\">\n                            <p class=\"adf-notification-history-menu-text adf-notification-history-menu-message\"\n                               *ngFor=\"let message of notification.messages\"\n                               matListItemLine [title]=\"message\">{{ message }}</p>\n                            <p class=\"adf-notification-history-menu-text adf-notification-history-menu-date\"\n                               matListItemLine> {{notification.datetime | adfTimeAgo}} </p>\n                        </div>\n                    </mat-list-item>\n                </ng-container>\n                <ng-template #empty_list_template>\n                    <mat-list-item id=\"adf-notification-history-component-no-message\"\n                                   class=\"adf-notification-history-menu-no-message\">\n                        <p class=\"adf-notification-history-menu-no-message-text\" matListItemLine>{{ 'NOTIFICATIONS.NO_MESSAGE' | translate }}</p>\n                    </mat-list-item>\n                </ng-template>\n            </mat-list>\n\n            <mat-divider />\n\n            <div class=\"adf-notification-history-load-more\" role=\"menuitem\" *ngIf=\"hasMoreNotifications()\">\n                <button mat-button (click)=\"loadMore()\">\n                    {{ 'NOTIFICATIONS.LOAD_MORE' | translate }}\n                </button>\n            </div>\n        </div>\n    </mat-menu>\n</div>\n"]}
|
|
139
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification-history.component.js","sourceRoot":"","sources":["../../../../../../../lib/core/src/lib/notifications/components/notification-history.component.ts","../../../../../../../lib/core/src/lib/notifications/components/notification-history.component.html"],"names":[],"mappings":"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","sourcesContent":["/*!\n * @license\n * Copyright © 2005-2025 Hyland Software, Inc. and its affiliates. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { AfterViewInit, ChangeDetectorRef, Component, DestroyRef, inject, Input, OnInit, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { NotificationService } from '../services/notification.service';\nimport { NOTIFICATION_TYPE, NotificationModel } from '../models/notification.model';\nimport { MatMenuModule, MatMenuTrigger, MenuPositionX, MenuPositionY } from '@angular/material/menu';\nimport { StorageService } from '../../common/services/storage.service';\nimport { PaginationModel } from '../../models/pagination.model';\nimport { MatButtonModule } from '@angular/material/button';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatBadgeModule } from '@angular/material/badge';\nimport { MatListModule } from '@angular/material/list';\nimport { NgForOf, NgIf } from '@angular/common';\nimport { InitialUsernamePipe, TimeAgoPipe } from '../../pipes';\nimport { MatSnackBarModule } from '@angular/material/snack-bar';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\n@Component({\n    selector: 'adf-notification-history',\n    standalone: true,\n    templateUrl: 'notification-history.component.html',\n    styleUrls: ['./notification-history.component.scss'],\n    imports: [\n        MatButtonModule,\n        MatMenuModule,\n        TranslateModule,\n        MatIconModule,\n        MatBadgeModule,\n        MatListModule,\n        NgIf,\n        NgForOf,\n        TimeAgoPipe,\n        InitialUsernamePipe,\n        MatSnackBarModule\n    ],\n    encapsulation: ViewEncapsulation.None\n})\nexport class NotificationHistoryComponent implements OnInit, AfterViewInit {\n    public static MAX_NOTIFICATION_STACK_LENGTH = 100;\n    public static NOTIFICATION_STORAGE = 'notification-history';\n\n    @ViewChild(MatMenuTrigger, { static: true })\n    trigger: MatMenuTrigger;\n\n    /** Custom choice for opening the menu at the bottom. Can be `before` or `after`. */\n    @Input()\n    menuPositionX: MenuPositionX = 'after';\n\n    /** Custom choice for opening the menu at the bottom. Can be `above` or `below`. */\n    @Input()\n    menuPositionY: MenuPositionY = 'below';\n\n    /** Maximum number of notifications to display. The rest will remain hidden until load more is clicked */\n    @Input()\n    maxNotifications: number = 5;\n\n    notifications: NotificationModel[] = [];\n    paginatedNotifications: NotificationModel[] = [];\n    pagination: PaginationModel;\n\n    private readonly destroyRef = inject(DestroyRef);\n\n    constructor(private notificationService: NotificationService, public storageService: StorageService, public cd: ChangeDetectorRef) {}\n\n    ngOnInit() {\n        this.notifications = JSON.parse(this.storageService.getItem(NotificationHistoryComponent.NOTIFICATION_STORAGE)) || [];\n    }\n\n    ngAfterViewInit(): void {\n        this.notificationService.notifications$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((notification: NotificationModel) => {\n            this.addNewNotification(notification);\n            this.cd.detectChanges();\n        });\n    }\n\n    addNewNotification(notification: NotificationModel) {\n        this.notifications.unshift(notification);\n\n        if (this.notifications.length > NotificationHistoryComponent.MAX_NOTIFICATION_STACK_LENGTH) {\n            this.notifications.shift();\n        }\n\n        this.saveNotifications();\n        this.createPagination();\n    }\n\n    saveNotifications() {\n        this.storageService.setItem(\n            NotificationHistoryComponent.NOTIFICATION_STORAGE,\n            JSON.stringify(this.notifications.filter((notification) => notification.type !== NOTIFICATION_TYPE.RECURSIVE))\n        );\n    }\n\n    onMenuOpened() {\n        this.createPagination();\n    }\n\n    markAsRead() {\n        this.notifications = [];\n        this.paginatedNotifications = [];\n        this.storageService.removeItem(NotificationHistoryComponent.NOTIFICATION_STORAGE);\n        this.createPagination();\n    }\n\n    createPagination() {\n        this.pagination = {\n            skipCount: this.maxNotifications,\n            maxItems: this.maxNotifications,\n            totalItems: this.notifications.length,\n            hasMoreItems: this.notifications.length > this.maxNotifications\n        };\n        this.paginatedNotifications = this.notifications.slice(0, this.pagination.skipCount);\n    }\n\n    loadMore($event: MouseEvent) {\n        $event.stopPropagation();\n        this.pagination.skipCount = this.pagination.maxItems + this.pagination.skipCount;\n        this.pagination.hasMoreItems = this.notifications.length > this.pagination.skipCount;\n        this.paginatedNotifications = this.notifications.slice(0, this.pagination.skipCount);\n    }\n\n    hasMoreNotifications(): boolean {\n        return this.pagination?.hasMoreItems;\n    }\n\n    onNotificationClick(notification: NotificationModel, $event: MouseEvent) {\n        $event.stopPropagation();\n        if (notification.clickCallBack) {\n            notification.clickCallBack(notification.args);\n            this.trigger.closeMenu();\n        }\n    }\n}\n","<button mat-button\n        [matMenuTriggerFor]=\"menu\"\n        aria-hidden=\"false\"\n        [attr.aria-label]=\"'NOTIFICATIONS.OPEN_HISTORY' | translate\"\n        title=\"{{ 'NOTIFICATIONS.OPEN_HISTORY' | translate }}\"\n        class=\"adf-notification-history-menu_button\"\n        id=\"adf-notification-history-open-button\"\n        (menuOpened)=\"onMenuOpened()\">\n    <mat-icon matBadge=\"&#8288;\"\n              [matBadgeHidden]=\"!notifications.length\"\n              class=\"adf-notification-history-menu_button-icon\"\n              matBadgeColor=\"accent\"\n              matBadgeSize=\"small\">notifications\n    </mat-icon>\n</button>\n\n<mat-menu #menu=\"matMenu\"\n          [xPosition]=\"menuPositionX\"\n          [yPosition]=\"menuPositionY\"\n          id=\"adf-notification-history-menu\"\n          class=\"adf-notification-history-menu adf-notification-history-menu-panel\">\n    <div class=\"adf-notification-history-list-header\">\n        <span class=\"adf-notification-history-menu-title\">{{ 'NOTIFICATIONS.TITLE' | translate }}</span>\n        <button mat-menu-item\n                *ngIf=\"notifications.length\"\n                id=\"adf-notification-history-mark-as-read\"\n                class=\"adf-notification-history-mark-as-read\"\n                title=\"{{ 'NOTIFICATIONS.MARK_AS_READ' | translate }}\"\n                (click)=\"markAsRead()\">\n            <mat-icon class=\"adf-notification-history-mark-as-read-icon\">done_all</mat-icon>\n        </button>\n    </div>\n\n    <mat-divider/>\n\n    <div class=\"adf-notification-history-item-list\">\n        <ng-container *ngIf=\"notifications.length; else empty_list_template\">\n            <button mat-menu-item\n                    *ngFor=\"let notification of paginatedNotifications\"\n                    (click)=\"onNotificationClick(notification, $event)\"\n                    class=\"adf-notification-history-menu-item\">\n                <div class=\"adf-notification-history-menu-item-content\">\n                    <div *ngIf=\"notification.initiator; else no_avatar\"\n                         [outerHTML]=\"notification.initiator | usernameInitials : 'adf-notification-initiator-pic'\"></div>\n                    <ng-template #no_avatar>\n                        <mat-icon class=\"adf-notification-history-menu-initiator\">\n                            {{ notification.icon }}\n                        </mat-icon>\n                    </ng-template>\n                    <div class=\"adf-notification-history-menu-item-content-message\">\n                        <p class=\"adf-notification-history-menu-text adf-notification-history-menu-message\"\n                           *ngFor=\"let message of notification.messages\"\n                           [title]=\"message\">{{ message }}</p>\n                        <p class=\"adf-notification-history-menu-text adf-notification-history-menu-date\"\n                        > {{ notification.datetime | adfTimeAgo }} </p>\n                    </div>\n                </div>\n            </button>\n        </ng-container>\n        <ng-template #empty_list_template>\n            <p mat-menu-item id=\"adf-notification-history-component-no-message\"\n               class=\"adf-notification-history-menu-no-message-text\">\n                {{ 'NOTIFICATIONS.NO_MESSAGE' | translate }}\n            </p>\n        </ng-template>\n    </div>\n\n    <mat-divider/>\n\n    <div class=\"adf-notification-history-load-more\" *ngIf=\"hasMoreNotifications()\">\n        <button mat-menu-item (click)=\"loadMore($event)\">\n            {{ 'NOTIFICATIONS.LOAD_MORE' | translate }}\n        </button>\n    </div>\n</mat-menu>\n"]}
|