@alfresco/adf-core 8.1.0-15865093855 → 8.1.0-15928551305
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/breadcrumbs/components/breadcrumb/breadcrumb.component.mjs +5 -6
- package/esm2022/feature-flags/lib/components/flags/flags.component.mjs +4 -5
- package/esm2022/lib/about/about-extension-list/about-extension-list.component.mjs +4 -5
- package/esm2022/lib/about/about-license-list/about-license-list.component.mjs +5 -6
- package/esm2022/lib/about/about-module-list/module-list.component.mjs +5 -6
- package/esm2022/lib/about/about-package/package-list.component.mjs +5 -6
- package/esm2022/lib/about/about-repository-info/about-repository-info.component.mjs +4 -5
- package/esm2022/lib/about/about-server-settings/about-server-settings.component.mjs +5 -6
- package/esm2022/lib/about/about-status-list/about-status-list.component.mjs +5 -6
- package/esm2022/lib/card-view/components/card-view-arrayitem/card-view-arrayitem.component.mjs +8 -9
- package/esm2022/lib/card-view/components/card-view-boolitem/card-view-boolitem.component.mjs +4 -5
- package/esm2022/lib/card-view/components/card-view-dateitem/card-view-dateitem.component.mjs +9 -10
- package/esm2022/lib/card-view/components/card-view-keyvaluepairsitem/card-view-keyvaluepairsitem.component.mjs +9 -10
- package/esm2022/lib/card-view/components/card-view-mapitem/card-view-mapitem.component.mjs +4 -5
- package/esm2022/lib/card-view/components/card-view-selectitem/card-view-selectitem.component.mjs +10 -11
- package/esm2022/lib/card-view/components/card-view-selectitem/select-filter-input/select-filter-input.component.mjs +6 -7
- package/esm2022/lib/card-view/components/card-view-textitem/card-view-textitem.component.mjs +10 -11
- package/esm2022/lib/clipboard/clipboard.directive.mjs +4 -5
- package/esm2022/lib/clipboard/clipboard.module.mjs +2 -2
- package/esm2022/lib/comments/comment-list/comment-list.component.mjs +4 -5
- package/esm2022/lib/comments/comments.component.mjs +8 -9
- package/esm2022/lib/context-menu/context-menu-list.component.mjs +6 -7
- package/esm2022/lib/core.module.mjs +3 -3
- package/esm2022/lib/datatable/components/columns-selector/columns-selector.component.mjs +9 -10
- package/esm2022/lib/datatable/components/datatable/datatable.component.mjs +7 -8
- package/esm2022/lib/dialogs/dialog/dialog.component.mjs +6 -7
- package/esm2022/lib/dialogs/edit-json/edit-json.dialog.mjs +9 -8
- package/esm2022/lib/dialogs/edit-json/edit-json.dialog.module.mjs +6 -10
- package/esm2022/lib/dialogs/unsaved-changes-dialog/unsaved-changes-dialog.component.mjs +8 -9
- package/esm2022/lib/dynamic-chip-list/dynamic-chip-list.component.mjs +6 -7
- package/esm2022/lib/form/components/form-renderer.component.mjs +4 -5
- package/esm2022/lib/form/components/widgets/amount/amount.widget.mjs +4 -5
- package/esm2022/lib/form/components/widgets/base-viewer/base-viewer.widget.mjs +4 -5
- package/esm2022/lib/form/components/widgets/checkbox/checkbox.widget.mjs +4 -5
- package/esm2022/lib/form/components/widgets/date/date.widget.mjs +7 -8
- package/esm2022/lib/form/components/widgets/date-time/date-time.widget.mjs +9 -10
- package/esm2022/lib/form/components/widgets/decimal/decimal.component.mjs +7 -8
- package/esm2022/lib/form/components/widgets/display-text/display-text.widget.mjs +4 -5
- package/esm2022/lib/form/components/widgets/error/error.component.mjs +4 -5
- package/esm2022/lib/form/components/widgets/header/header.widget.mjs +5 -6
- package/esm2022/lib/form/components/widgets/hyperlink/hyperlink.widget.mjs +4 -6
- package/esm2022/lib/form/components/widgets/json/json.widget.mjs +5 -6
- package/esm2022/lib/form/components/widgets/multiline-text/multiline-text.widget.mjs +7 -8
- package/esm2022/lib/form/components/widgets/number/number.widget.mjs +7 -8
- package/esm2022/lib/form/components/widgets/text/text.widget.mjs +7 -8
- package/esm2022/lib/form/form-base.module.mjs +2 -2
- package/esm2022/lib/identity-user-info/identity-user-info.component.mjs +4 -5
- package/esm2022/lib/info-drawer/info-drawer.component.mjs +6 -7
- package/esm2022/lib/language-menu/language-picker.component.mjs +5 -6
- package/esm2022/lib/layout/components/header/header.component.mjs +4 -5
- package/esm2022/lib/login/components/login/login.component.mjs +10 -11
- package/esm2022/lib/login/components/login-dialog/login-dialog.component.mjs +5 -6
- package/esm2022/lib/notifications/components/notification-history.component.mjs +7 -8
- package/esm2022/lib/notifications/services/notification.service.mjs +1 -1
- package/esm2022/lib/pagination/infinite-pagination.component.mjs +4 -5
- package/esm2022/lib/pagination/pagination.component.mjs +4 -4
- package/esm2022/lib/search-text/search-text-input.component.mjs +7 -18
- package/esm2022/lib/snackbar-content/snackbar-content.component.mjs +9 -8
- package/esm2022/lib/snackbar-content/snackbar-content.module.mjs +5 -10
- package/esm2022/lib/sorting-picker/sorting-picker.component.mjs +9 -10
- package/esm2022/lib/templates/empty-content/empty-content.component.mjs +4 -5
- package/esm2022/lib/templates/error-content/error-content.component.mjs +4 -5
- package/esm2022/lib/toolbar/toolbar.component.mjs +4 -5
- package/esm2022/lib/viewer/components/download-prompt-dialog/download-prompt-dialog.component.mjs +5 -6
- package/esm2022/lib/viewer/components/img-viewer/img-viewer.component.mjs +6 -7
- package/esm2022/lib/viewer/components/pdf-viewer/pdf-viewer.component.mjs +5 -6
- package/esm2022/lib/viewer/components/pdf-viewer-password-dialog/pdf-viewer-password-dialog.mjs +5 -6
- package/esm2022/lib/viewer/components/pdf-viewer-thumb/pdf-viewer-thumb.component.mjs +4 -5
- package/esm2022/lib/viewer/components/unknown-format/unknown-format.component.mjs +4 -5
- package/esm2022/lib/viewer/components/viewer-render/viewer-render.component.mjs +5 -6
- package/esm2022/lib/viewer/components/viewer.component.mjs +6 -7
- package/esm2022/lib/viewer/viewer.module.mjs +1 -3
- package/fesm2022/adf-core.mjs +273 -284
- package/fesm2022/adf-core.mjs.map +1 -1
- package/fesm2022/alfresco-adf-core-breadcrumbs.mjs +4 -5
- package/fesm2022/alfresco-adf-core-breadcrumbs.mjs.map +1 -1
- package/fesm2022/alfresco-adf-core-feature-flags.mjs +3 -4
- package/fesm2022/alfresco-adf-core-feature-flags.mjs.map +1 -1
- package/lib/dialogs/edit-json/edit-json.dialog.d.ts +1 -1
- package/lib/dialogs/edit-json/edit-json.dialog.module.d.ts +1 -6
- package/lib/form/components/widgets/hyperlink/hyperlink.widget.d.ts +16 -0
- package/lib/notifications/services/notification.service.d.ts +1 -1
- package/lib/snackbar-content/snackbar-content.component.d.ts +1 -1
- package/lib/snackbar-content/snackbar-content.module.d.ts +2 -6
- package/package.json +4 -4
|
@@ -17,12 +17,11 @@
|
|
|
17
17
|
import { Component, Inject, ViewChild, ViewEncapsulation } from '@angular/core';
|
|
18
18
|
import { MatButtonModule } from '@angular/material/button';
|
|
19
19
|
import { MAT_DIALOG_DATA, MatDialogModule } from '@angular/material/dialog';
|
|
20
|
-
import {
|
|
20
|
+
import { TranslatePipe } from '@ngx-translate/core';
|
|
21
21
|
import { LoginDialogPanelComponent } from '../login-dialog-panel/login-dialog-panel.component';
|
|
22
22
|
import * as i0 from "@angular/core";
|
|
23
23
|
import * as i1 from "@angular/material/dialog";
|
|
24
|
-
import * as i2 from "@
|
|
25
|
-
import * as i3 from "@angular/material/button";
|
|
24
|
+
import * as i2 from "@angular/material/button";
|
|
26
25
|
export class LoginDialogComponent {
|
|
27
26
|
constructor(data) {
|
|
28
27
|
this.data = data;
|
|
@@ -43,11 +42,11 @@ export class LoginDialogComponent {
|
|
|
43
42
|
return this.loginPanel ? this.loginPanel.isValid() : false;
|
|
44
43
|
}
|
|
45
44
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LoginDialogComponent, deps: [{ token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
46
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: LoginDialogComponent, isStandalone: true, selector: "adf-login-dialog", viewQueries: [{ propertyName: "loginPanel", first: true, predicate: ["adfLoginPanel"], descendants: true, static: true }], ngImport: i0, template: "<header mat-dialog-title\n data-automation-id=\"login-dialog-title\">\n {{ data?.title }}\n</header>\n\n<mat-dialog-content class=\"adf-login-dialog-content\">\n <adf-login-dialog-panel #adfLoginPanel (success)=\"onLoginSuccess($event)\" />\n</mat-dialog-content>\n\n<mat-dialog-actions class=\"adf-login-dialog-content-actions\" align=\"end\">\n <button mat-button (click)=\"close()\"\n data-automation-id=\"login-dialog-actions-cancel\">\n {{ 'LOGIN.DIALOG.CANCEL' | translate }}\n </button>\n\n <button mat-button\n class=\"choose-action\"\n data-automation-id=\"login-dialog-actions-perform\"\n [disabled]=\"!isFormValid()\"\n (click)=\"submitForm()\">\n {{ buttonActionName | translate }}\n </button>\n</mat-dialog-actions>\n", styles: [".adf-login-dialog-content adf-login .adf-login-content .adf-login-card-wide{padding:0;box-shadow:none}\n"], dependencies: [{ kind: "ngmodule", type: MatDialogModule }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: LoginDialogPanelComponent, selector: "adf-login-dialog-panel", outputs: ["success"] }, { kind: "
|
|
45
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: LoginDialogComponent, isStandalone: true, selector: "adf-login-dialog", viewQueries: [{ propertyName: "loginPanel", first: true, predicate: ["adfLoginPanel"], descendants: true, static: true }], ngImport: i0, template: "<header mat-dialog-title\n data-automation-id=\"login-dialog-title\">\n {{ data?.title }}\n</header>\n\n<mat-dialog-content class=\"adf-login-dialog-content\">\n <adf-login-dialog-panel #adfLoginPanel (success)=\"onLoginSuccess($event)\" />\n</mat-dialog-content>\n\n<mat-dialog-actions class=\"adf-login-dialog-content-actions\" align=\"end\">\n <button mat-button (click)=\"close()\"\n data-automation-id=\"login-dialog-actions-cancel\">\n {{ 'LOGIN.DIALOG.CANCEL' | translate }}\n </button>\n\n <button mat-button\n class=\"choose-action\"\n data-automation-id=\"login-dialog-actions-perform\"\n [disabled]=\"!isFormValid()\"\n (click)=\"submitForm()\">\n {{ buttonActionName | translate }}\n </button>\n</mat-dialog-actions>\n", styles: [".adf-login-dialog-content adf-login .adf-login-content .adf-login-card-wide{padding:0;box-shadow:none}\n"], dependencies: [{ kind: "ngmodule", type: MatDialogModule }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: LoginDialogPanelComponent, selector: "adf-login-dialog-panel", outputs: ["success"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
47
46
|
}
|
|
48
47
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LoginDialogComponent, decorators: [{
|
|
49
48
|
type: Component,
|
|
50
|
-
args: [{ selector: 'adf-login-dialog', standalone: true, imports: [MatDialogModule, LoginDialogPanelComponent,
|
|
49
|
+
args: [{ selector: 'adf-login-dialog', standalone: true, imports: [MatDialogModule, LoginDialogPanelComponent, TranslatePipe, MatButtonModule], encapsulation: ViewEncapsulation.None, template: "<header mat-dialog-title\n data-automation-id=\"login-dialog-title\">\n {{ data?.title }}\n</header>\n\n<mat-dialog-content class=\"adf-login-dialog-content\">\n <adf-login-dialog-panel #adfLoginPanel (success)=\"onLoginSuccess($event)\" />\n</mat-dialog-content>\n\n<mat-dialog-actions class=\"adf-login-dialog-content-actions\" align=\"end\">\n <button mat-button (click)=\"close()\"\n data-automation-id=\"login-dialog-actions-cancel\">\n {{ 'LOGIN.DIALOG.CANCEL' | translate }}\n </button>\n\n <button mat-button\n class=\"choose-action\"\n data-automation-id=\"login-dialog-actions-perform\"\n [disabled]=\"!isFormValid()\"\n (click)=\"submitForm()\">\n {{ buttonActionName | translate }}\n </button>\n</mat-dialog-actions>\n", styles: [".adf-login-dialog-content adf-login .adf-login-content .adf-login-card-wide{padding:0;box-shadow:none}\n"] }]
|
|
51
50
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
52
51
|
type: Inject,
|
|
53
52
|
args: [MAT_DIALOG_DATA]
|
|
@@ -55,4 +54,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
55
54
|
type: ViewChild,
|
|
56
55
|
args: ['adfLoginPanel', { static: true }]
|
|
57
56
|
}] } });
|
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naW4tZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYi9jb3JlL3NyYy9saWIvbG9naW4vY29tcG9uZW50cy9sb2dpbi1kaWFsb2cvbG9naW4tZGlhbG9nLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYi9jb3JlL3NyYy9saWIvbG9naW4vY29tcG9uZW50cy9sb2dpbi1kaWFsb2cvbG9naW4tZGlhbG9nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7Ozs7R0FlRztBQUVILE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUM1RSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDcEQsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sb0RBQW9ELENBQUM7Ozs7QUFXL0YsTUFBTSxPQUFPLG9CQUFvQjtJQU03QixZQUE0QyxJQUE4QjtRQUE5QixTQUFJLEdBQUosSUFBSSxDQUEwQjtRQUYxRSxxQkFBZ0IsR0FBRyxFQUFFLENBQUM7UUFHbEIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLGdCQUFnQixJQUFJLENBQUMsVUFBVSxDQUFDLFdBQVcsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLHFCQUFxQixDQUFDO0lBQ3RILENBQUM7SUFFRCxLQUFLO1FBQ0QsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVELFVBQVU7UUFDTixJQUFJLENBQUMsVUFBVSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQ2pDLENBQUM7SUFFRCxjQUFjLENBQUMsS0FBVTtRQUNyQixJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDN0IsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ2pCLENBQUM7SUFFRCxXQUFXO1FBQ1AsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7SUFDL0QsQ0FBQzsrR0F6QlEsb0JBQW9CLGtCQU1ULGVBQWU7bUdBTjFCLG9CQUFvQix1TUNoQ2pDLDB6QkF1QkEsaUtETWMsZUFBZSwwYkFBRSx5QkFBeUIsb0ZBQUUsYUFBYSxpREFBRSxlQUFlOzs0RkFHM0Usb0JBQW9CO2tCQVJoQyxTQUFTOytCQUNJLGtCQUFrQixjQUNoQixJQUFJLFdBR1AsQ0FBQyxlQUFlLEVBQUUseUJBQXlCLEVBQUUsYUFBYSxFQUFFLGVBQWUsQ0FBQyxpQkFDdEUsaUJBQWlCLENBQUMsSUFBSTs7MEJBUXhCLE1BQU07MkJBQUMsZUFBZTt5Q0FKbkMsVUFBVTtzQkFEVCxTQUFTO3VCQUFDLGVBQWUsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyIvKiFcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgwqkgMjAwNS0yMDI1IEh5bGFuZCBTb2Z0d2FyZSwgSW5jLiBhbmQgaXRzIGFmZmlsaWF0ZXMuIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKlxuICogTGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMCAodGhlIFwiTGljZW5zZVwiKTtcbiAqIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbiAqIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuICpcbiAqICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbiAqXG4gKiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgQkFTSVMsXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAqIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbmltcG9ydCB7IENvbXBvbmVudCwgSW5qZWN0LCBWaWV3Q2hpbGQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTUFUX0RJQUxPR19EQVRBLCBNYXREaWFsb2dNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHsgVHJhbnNsYXRlUGlwZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHsgTG9naW5EaWFsb2dQYW5lbENvbXBvbmVudCB9IGZyb20gJy4uL2xvZ2luLWRpYWxvZy1wYW5lbC9sb2dpbi1kaWFsb2ctcGFuZWwuY29tcG9uZW50JztcbmltcG9ydCB7IExvZ2luRGlhbG9nQ29tcG9uZW50RGF0YSB9IGZyb20gJy4vbG9naW4tZGlhbG9nLWNvbXBvbmVudC1kYXRhLmludGVyZmFjZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnYWRmLWxvZ2luLWRpYWxvZycsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vbG9naW4tZGlhbG9nLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9sb2dpbi1kaWFsb2cuY29tcG9uZW50LnNjc3MnXSxcbiAgICBpbXBvcnRzOiBbTWF0RGlhbG9nTW9kdWxlLCBMb2dpbkRpYWxvZ1BhbmVsQ29tcG9uZW50LCBUcmFuc2xhdGVQaXBlLCBNYXRCdXR0b25Nb2R1bGVdLFxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcbn0pXG5leHBvcnQgY2xhc3MgTG9naW5EaWFsb2dDb21wb25lbnQge1xuICAgIEBWaWV3Q2hpbGQoJ2FkZkxvZ2luUGFuZWwnLCB7IHN0YXRpYzogdHJ1ZSB9KVxuICAgIGxvZ2luUGFuZWw6IExvZ2luRGlhbG9nUGFuZWxDb21wb25lbnQ7XG5cbiAgICBidXR0b25BY3Rpb25OYW1lID0gJyc7XG5cbiAgICBjb25zdHJ1Y3RvcihASW5qZWN0KE1BVF9ESUFMT0dfREFUQSkgcHVibGljIGRhdGE6IExvZ2luRGlhbG9nQ29tcG9uZW50RGF0YSkge1xuICAgICAgICB0aGlzLmJ1dHRvbkFjdGlvbk5hbWUgPSBkYXRhLmFjdGlvbk5hbWUgPyBgTE9HSU4uRElBTE9HLiR7ZGF0YS5hY3Rpb25OYW1lLnRvVXBwZXJDYXNlKCl9YCA6ICdMT0dJTi5ESUFMT0cuQ0hPT1NFJztcbiAgICB9XG5cbiAgICBjbG9zZSgpIHtcbiAgICAgICAgdGhpcy5kYXRhLmxvZ2dlZC5jb21wbGV0ZSgpO1xuICAgIH1cblxuICAgIHN1Ym1pdEZvcm0oKTogdm9pZCB7XG4gICAgICAgIHRoaXMubG9naW5QYW5lbC5zdWJtaXRGb3JtKCk7XG4gICAgfVxuXG4gICAgb25Mb2dpblN1Y2Nlc3MoZXZlbnQ6IGFueSkge1xuICAgICAgICB0aGlzLmRhdGEubG9nZ2VkLm5leHQoZXZlbnQpO1xuICAgICAgICB0aGlzLmNsb3NlKCk7XG4gICAgfVxuXG4gICAgaXNGb3JtVmFsaWQoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmxvZ2luUGFuZWwgPyB0aGlzLmxvZ2luUGFuZWwuaXNWYWxpZCgpIDogZmFsc2U7XG4gICAgfVxufVxuIiwiPGhlYWRlciBtYXQtZGlhbG9nLXRpdGxlXG4gICAgICAgIGRhdGEtYXV0b21hdGlvbi1pZD1cImxvZ2luLWRpYWxvZy10aXRsZVwiPlxuICAgIHt7IGRhdGE/LnRpdGxlIH19XG48L2hlYWRlcj5cblxuPG1hdC1kaWFsb2ctY29udGVudCBjbGFzcz1cImFkZi1sb2dpbi1kaWFsb2ctY29udGVudFwiPlxuICAgIDxhZGYtbG9naW4tZGlhbG9nLXBhbmVsICNhZGZMb2dpblBhbmVsIChzdWNjZXNzKT1cIm9uTG9naW5TdWNjZXNzKCRldmVudClcIiAvPlxuPC9tYXQtZGlhbG9nLWNvbnRlbnQ+XG5cbjxtYXQtZGlhbG9nLWFjdGlvbnMgY2xhc3M9XCJhZGYtbG9naW4tZGlhbG9nLWNvbnRlbnQtYWN0aW9uc1wiIGFsaWduPVwiZW5kXCI+XG4gICAgPGJ1dHRvbiBtYXQtYnV0dG9uIChjbGljayk9XCJjbG9zZSgpXCJcbiAgICAgICAgICAgIGRhdGEtYXV0b21hdGlvbi1pZD1cImxvZ2luLWRpYWxvZy1hY3Rpb25zLWNhbmNlbFwiPlxuICAgICAgICB7eyAnTE9HSU4uRElBTE9HLkNBTkNFTCcgfCB0cmFuc2xhdGUgfX1cbiAgICA8L2J1dHRvbj5cblxuICAgIDxidXR0b24gbWF0LWJ1dHRvblxuICAgICAgICAgICAgY2xhc3M9XCJjaG9vc2UtYWN0aW9uXCJcbiAgICAgICAgICAgIGRhdGEtYXV0b21hdGlvbi1pZD1cImxvZ2luLWRpYWxvZy1hY3Rpb25zLXBlcmZvcm1cIlxuICAgICAgICAgICAgW2Rpc2FibGVkXT1cIiFpc0Zvcm1WYWxpZCgpXCJcbiAgICAgICAgICAgIChjbGljayk9XCJzdWJtaXRGb3JtKClcIj5cbiAgICAgICAge3sgYnV0dG9uQWN0aW9uTmFtZSB8IHRyYW5zbGF0ZSB9fVxuICAgIDwvYnV0dG9uPlxuPC9tYXQtZGlhbG9nLWFjdGlvbnM+XG4iXX0=
|
|
@@ -20,7 +20,7 @@ import { NOTIFICATION_TYPE } from '../models/notification.model';
|
|
|
20
20
|
import { MatMenuModule, MatMenuTrigger } from '@angular/material/menu';
|
|
21
21
|
import { StorageService } from '../../common/services/storage.service';
|
|
22
22
|
import { MatButtonModule } from '@angular/material/button';
|
|
23
|
-
import {
|
|
23
|
+
import { TranslatePipe } from '@ngx-translate/core';
|
|
24
24
|
import { MatIconModule } from '@angular/material/icon';
|
|
25
25
|
import { MatBadgeModule } from '@angular/material/badge';
|
|
26
26
|
import { MatListModule } from '@angular/material/list';
|
|
@@ -33,10 +33,9 @@ import * as i1 from "../services/notification.service";
|
|
|
33
33
|
import * as i2 from "../../common/services/storage.service";
|
|
34
34
|
import * as i3 from "@angular/material/button";
|
|
35
35
|
import * as i4 from "@angular/material/menu";
|
|
36
|
-
import * as i5 from "@
|
|
37
|
-
import * as i6 from "@angular/material/
|
|
38
|
-
import * as i7 from "@angular/material/
|
|
39
|
-
import * as i8 from "@angular/material/divider";
|
|
36
|
+
import * as i5 from "@angular/material/icon";
|
|
37
|
+
import * as i6 from "@angular/material/badge";
|
|
38
|
+
import * as i7 from "@angular/material/divider";
|
|
40
39
|
export class NotificationHistoryComponent {
|
|
41
40
|
static { this.MAX_NOTIFICATION_STACK_LENGTH = 100; }
|
|
42
41
|
static { this.NOTIFICATION_STORAGE = 'notification-history'; }
|
|
@@ -109,14 +108,14 @@ export class NotificationHistoryComponent {
|
|
|
109
108
|
}
|
|
110
109
|
}
|
|
111
110
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NotificationHistoryComponent, deps: [{ token: i1.NotificationService }, { token: i2.StorageService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
112
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", 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 }); }
|
|
111
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", 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: "pipe", type: TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatBadgeModule }, { kind: "directive", type: i6.MatBadge, selector: "[matBadge]", inputs: ["matBadgeColor", "matBadgeOverlap", "matBadgeDisabled", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "ngmodule", type: MatListModule }, { kind: "component", type: i7.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 }); }
|
|
113
112
|
}
|
|
114
113
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NotificationHistoryComponent, decorators: [{
|
|
115
114
|
type: Component,
|
|
116
115
|
args: [{ selector: 'adf-notification-history', standalone: true, imports: [
|
|
117
116
|
MatButtonModule,
|
|
118
117
|
MatMenuModule,
|
|
119
|
-
|
|
118
|
+
TranslatePipe,
|
|
120
119
|
MatIconModule,
|
|
121
120
|
MatBadgeModule,
|
|
122
121
|
MatListModule,
|
|
@@ -136,4 +135,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
136
135
|
}], maxNotifications: [{
|
|
137
136
|
type: Input
|
|
138
137
|
}] } });
|
|
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"]}
|
|
138
|
+
//# 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 { TranslatePipe } 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        TranslatePipe,\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"]}
|
|
@@ -163,4 +163,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
163
163
|
providedIn: 'root'
|
|
164
164
|
}]
|
|
165
165
|
}], ctorParameters: () => [{ type: i1.MatSnackBar }, { type: i2.TranslationService }] });
|
|
166
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.service.js","sourceRoot":"","sources":["../../../../../../../lib/core/src/lib/notifications/services/notification.service.ts"],"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 { Injectable } from '@angular/core';\nimport { MatSnackBar, MatSnackBarRef, MatSnackBarConfig } from '@angular/material/snack-bar';\nimport { TranslationService } from '../../translation/translation.service';\nimport { Subject } from 'rxjs';\nimport { NotificationModel } from '../models/notification.model';\nimport { info, warning, error } from '../helpers/notification.factory';\nimport { SnackbarContentComponent } from '../../snackbar-content';\nimport { SnackBarData } from '../../snackbar-content/snack-bar-data';\n\nconst INFO_SNACK_CLASS = 'adf-info-snackbar';\nconst WARN_SNACK_CLASS = 'adf-warning-snackbar';\nconst ERROR_SNACK_CLASS = 'adf-error-snackbar';\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class NotificationService {\n    notifications$: Subject<NotificationModel> = new Subject();\n\n    constructor(private snackBar: MatSnackBar, private translationService: TranslationService) {}\n\n    /**\n     * Opens a SnackBar notification to show a message.\n     *\n     * @param message The message (or resource key) to show.\n     * @param config Time before notification disappears after being shown or MatSnackBarConfig object\n     * @param interpolateArgs The interpolation parameters to add for the translation\n     * @returns Information/control object for the SnackBar\n     */\n    openSnackMessage(\n        message: string,\n        config?: number | MatSnackBarConfig<Omit<SnackBarData, 'actionLabel' | 'message'>>,\n        interpolateArgs?: any\n    ): MatSnackBarRef<any> {\n        return this.dispatchNotification(message, null, config, interpolateArgs);\n    }\n\n    /**\n     * Opens a SnackBar notification with a message and a response button.\n     *\n     * @param message The message (or resource key) to show.\n     * @param action Caption for the response button\n     * @param config Time before notification disappears after being shown or MatSnackBarConfig object\n     * @param interpolateArgs The interpolation parameters to add for the translation\n     * @returns Information/control object for the SnackBar\n     */\n    openSnackMessageAction(\n        message: string,\n        action: string,\n        config?: number | MatSnackBarConfig<Omit<SnackBarData, 'actionLabel' | 'message'>>,\n        interpolateArgs?: any\n    ): MatSnackBarRef<any> {\n        return this.dispatchNotification(message, action, config, interpolateArgs);\n    }\n\n    /**\n     * Rase error message\n     *\n     * @param message Text message or translation key for the message.\n     * @param action Action name\n     * @param interpolateArgs The interpolation parameters to add for the translation\n     * @param showAction True if action should be visible, false if not. Default: true.\n     * @returns snackbar reference\n     */\n    showError(message: string, action?: string, interpolateArgs?: any, showAction = true): MatSnackBarRef<any> {\n        return this.dispatchNotification(\n            message,\n            action,\n            {\n                panelClass: ERROR_SNACK_CLASS,\n                data: {\n                    showAction\n                }\n            },\n            interpolateArgs\n        );\n    }\n\n    /**\n     * Rase info message\n     *\n     * @param message Text message or translation key for the message.\n     * @param action Action name\n     * @param interpolateArgs The interpolation parameters to add for the translation\n     * @param showAction True if action should be visible, false if not. Default: true.\n     * @returns snackbar reference\n     */\n    showInfo(message: string, action?: string, interpolateArgs?: any, showAction = true): MatSnackBarRef<any> {\n        return this.dispatchNotification(\n            message,\n            action,\n            {\n                panelClass: INFO_SNACK_CLASS,\n                data: {\n                    showAction\n                }\n            },\n            interpolateArgs\n        );\n    }\n\n    /**\n     * Rase warning message\n     *\n     * @param message Text message or translation key for the message.\n     * @param action Action name\n     * @param interpolateArgs The interpolation parameters to add for the translation\n     * @param showAction True if action should be visible, false if not. Default: true.\n     * @returns snackbar reference\n     */\n    showWarning(message: string, action?: string, interpolateArgs?: any, showAction = true): MatSnackBarRef<any> {\n        return this.dispatchNotification(\n            message,\n            action,\n            {\n                panelClass: WARN_SNACK_CLASS,\n                data: {\n                    showAction\n                }\n            },\n            interpolateArgs\n        );\n    }\n\n    /**\n     *  dismiss the notification snackbar\n     */\n    dismissSnackMessageAction(): void {\n        this.snackBar.dismiss();\n    }\n\n    /**\n     * Push new notification to Notification History\n     *\n     * @param notification - Notification model to be pushed.\n     */\n    pushToNotificationHistory(notification: NotificationModel) {\n        this.notifications$.next(notification);\n    }\n\n    private dispatchNotification(\n        message: string,\n        action?: string,\n        config?: number | MatSnackBarConfig<Omit<SnackBarData, 'actionLabel' | 'message'>>,\n        interpolateArgs?: any\n    ): MatSnackBarRef<any> {\n        const translatedMessage: string = this.translationService.instant(message, interpolateArgs);\n        const translatedAction: string = this.translationService.instant(action, interpolateArgs);\n        const createNotification = this.getNotificationCreator(config);\n        this.notifications$.next(createNotification(translatedMessage));\n        return this.snackBar.openFromComponent<SnackbarContentComponent, SnackBarData>(SnackbarContentComponent, {\n            ...(typeof config === 'number' && { duration: config }),\n            panelClass: INFO_SNACK_CLASS,\n            ...(typeof config === 'object' ? config : {}),\n            data: {\n                actionLabel: translatedAction,\n                actionIcon: 'close',\n                actionIconAriaLabel: 'CLOSE',\n                message: translatedMessage,\n                showAction: true,\n                callActionOnIconClick: false,\n                ...(typeof config === 'object' ? config.data : {})\n            }\n        });\n    }\n\n    private getNotificationCreator(config?: number | MatSnackBarConfig<Omit<SnackBarData, 'actionLabel' | 'message'>>) {\n        let panelClass: string = null;\n        if (typeof config === 'object') {\n            panelClass = Array.isArray(config.panelClass) ? config.panelClass[0] : config.panelClass;\n        }\n\n        switch (panelClass) {\n            case ERROR_SNACK_CLASS:\n                return error;\n            case WARN_SNACK_CLASS:\n                return warning;\n            default:\n                return info;\n        }\n    }\n}\n"]}
|
|
166
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.service.js","sourceRoot":"","sources":["../../../../../../../lib/core/src/lib/notifications/services/notification.service.ts"],"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 { Injectable } from '@angular/core';\nimport { MatSnackBar, MatSnackBarRef, MatSnackBarConfig } from '@angular/material/snack-bar';\nimport { TranslationService } from '../../translation/translation.service';\nimport { Subject } from 'rxjs';\nimport { NotificationModel } from '../models/notification.model';\nimport { info, warning, error } from '../helpers/notification.factory';\nimport { SnackbarContentComponent } from '../../snackbar-content';\nimport type { SnackBarData } from '../../snackbar-content/snack-bar-data';\n\nconst INFO_SNACK_CLASS = 'adf-info-snackbar';\nconst WARN_SNACK_CLASS = 'adf-warning-snackbar';\nconst ERROR_SNACK_CLASS = 'adf-error-snackbar';\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class NotificationService {\n    notifications$: Subject<NotificationModel> = new Subject();\n\n    constructor(private snackBar: MatSnackBar, private translationService: TranslationService) {}\n\n    /**\n     * Opens a SnackBar notification to show a message.\n     *\n     * @param message The message (or resource key) to show.\n     * @param config Time before notification disappears after being shown or MatSnackBarConfig object\n     * @param interpolateArgs The interpolation parameters to add for the translation\n     * @returns Information/control object for the SnackBar\n     */\n    openSnackMessage(\n        message: string,\n        config?: number | MatSnackBarConfig<Omit<SnackBarData, 'actionLabel' | 'message'>>,\n        interpolateArgs?: any\n    ): MatSnackBarRef<any> {\n        return this.dispatchNotification(message, null, config, interpolateArgs);\n    }\n\n    /**\n     * Opens a SnackBar notification with a message and a response button.\n     *\n     * @param message The message (or resource key) to show.\n     * @param action Caption for the response button\n     * @param config Time before notification disappears after being shown or MatSnackBarConfig object\n     * @param interpolateArgs The interpolation parameters to add for the translation\n     * @returns Information/control object for the SnackBar\n     */\n    openSnackMessageAction(\n        message: string,\n        action: string,\n        config?: number | MatSnackBarConfig<Omit<SnackBarData, 'actionLabel' | 'message'>>,\n        interpolateArgs?: any\n    ): MatSnackBarRef<any> {\n        return this.dispatchNotification(message, action, config, interpolateArgs);\n    }\n\n    /**\n     * Rase error message\n     *\n     * @param message Text message or translation key for the message.\n     * @param action Action name\n     * @param interpolateArgs The interpolation parameters to add for the translation\n     * @param showAction True if action should be visible, false if not. Default: true.\n     * @returns snackbar reference\n     */\n    showError(message: string, action?: string, interpolateArgs?: any, showAction = true): MatSnackBarRef<any> {\n        return this.dispatchNotification(\n            message,\n            action,\n            {\n                panelClass: ERROR_SNACK_CLASS,\n                data: {\n                    showAction\n                }\n            },\n            interpolateArgs\n        );\n    }\n\n    /**\n     * Rase info message\n     *\n     * @param message Text message or translation key for the message.\n     * @param action Action name\n     * @param interpolateArgs The interpolation parameters to add for the translation\n     * @param showAction True if action should be visible, false if not. Default: true.\n     * @returns snackbar reference\n     */\n    showInfo(message: string, action?: string, interpolateArgs?: any, showAction = true): MatSnackBarRef<any> {\n        return this.dispatchNotification(\n            message,\n            action,\n            {\n                panelClass: INFO_SNACK_CLASS,\n                data: {\n                    showAction\n                }\n            },\n            interpolateArgs\n        );\n    }\n\n    /**\n     * Rase warning message\n     *\n     * @param message Text message or translation key for the message.\n     * @param action Action name\n     * @param interpolateArgs The interpolation parameters to add for the translation\n     * @param showAction True if action should be visible, false if not. Default: true.\n     * @returns snackbar reference\n     */\n    showWarning(message: string, action?: string, interpolateArgs?: any, showAction = true): MatSnackBarRef<any> {\n        return this.dispatchNotification(\n            message,\n            action,\n            {\n                panelClass: WARN_SNACK_CLASS,\n                data: {\n                    showAction\n                }\n            },\n            interpolateArgs\n        );\n    }\n\n    /**\n     *  dismiss the notification snackbar\n     */\n    dismissSnackMessageAction(): void {\n        this.snackBar.dismiss();\n    }\n\n    /**\n     * Push new notification to Notification History\n     *\n     * @param notification - Notification model to be pushed.\n     */\n    pushToNotificationHistory(notification: NotificationModel) {\n        this.notifications$.next(notification);\n    }\n\n    private dispatchNotification(\n        message: string,\n        action?: string,\n        config?: number | MatSnackBarConfig<Omit<SnackBarData, 'actionLabel' | 'message'>>,\n        interpolateArgs?: any\n    ): MatSnackBarRef<any> {\n        const translatedMessage: string = this.translationService.instant(message, interpolateArgs);\n        const translatedAction: string = this.translationService.instant(action, interpolateArgs);\n        const createNotification = this.getNotificationCreator(config);\n        this.notifications$.next(createNotification(translatedMessage));\n        return this.snackBar.openFromComponent<SnackbarContentComponent, SnackBarData>(SnackbarContentComponent, {\n            ...(typeof config === 'number' && { duration: config }),\n            panelClass: INFO_SNACK_CLASS,\n            ...(typeof config === 'object' ? config : {}),\n            data: {\n                actionLabel: translatedAction,\n                actionIcon: 'close',\n                actionIconAriaLabel: 'CLOSE',\n                message: translatedMessage,\n                showAction: true,\n                callActionOnIconClick: false,\n                ...(typeof config === 'object' ? config.data : {})\n            }\n        });\n    }\n\n    private getNotificationCreator(config?: number | MatSnackBarConfig<Omit<SnackBarData, 'actionLabel' | 'message'>>) {\n        let panelClass: string = null;\n        if (typeof config === 'object') {\n            panelClass = Array.isArray(config.panelClass) ? config.panelClass[0] : config.panelClass;\n        }\n\n        switch (panelClass) {\n            case ERROR_SNACK_CLASS:\n                return error;\n            case WARN_SNACK_CLASS:\n                return warning;\n            default:\n                return info;\n        }\n    }\n}\n"]}
|
|
@@ -22,14 +22,13 @@ import { PaginationModel } from '../models/pagination.model';
|
|
|
22
22
|
import { CommonModule } from '@angular/common';
|
|
23
23
|
import { MatButtonModule } from '@angular/material/button';
|
|
24
24
|
import { MatProgressBarModule } from '@angular/material/progress-bar';
|
|
25
|
-
import {
|
|
25
|
+
import { TranslatePipe } from '@ngx-translate/core';
|
|
26
26
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
27
27
|
import * as i0 from "@angular/core";
|
|
28
28
|
import * as i1 from "../common/services/user-preferences.service";
|
|
29
29
|
import * as i2 from "@angular/common";
|
|
30
30
|
import * as i3 from "@angular/material/button";
|
|
31
31
|
import * as i4 from "@angular/material/progress-bar";
|
|
32
|
-
import * as i5 from "@ngx-translate/core";
|
|
33
32
|
export class InfinitePaginationComponent {
|
|
34
33
|
static { this.DEFAULT_PAGINATION = new PaginationModel({
|
|
35
34
|
skipCount: 0,
|
|
@@ -94,11 +93,11 @@ export class InfinitePaginationComponent {
|
|
|
94
93
|
}
|
|
95
94
|
}
|
|
96
95
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: InfinitePaginationComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.UserPreferencesService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
97
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: InfinitePaginationComponent, isStandalone: true, selector: "adf-infinite-pagination", inputs: { target: "target", pageSize: "pageSize", isLoading: ["loading", "isLoading"] }, outputs: { loadMore: "loadMore" }, host: { classAttribute: "infinite-adf-pagination" }, ngImport: i0, template: "<div *ngIf=\"pagination?.hasMoreItems || isLoading\" class=\"adf-infinite-pagination\">\n\n <button mat-button\n *ngIf=\"!isLoading\"\n class=\"adf-infinite-pagination-load-more\"\n (click)=\"onLoadMore()\"\n data-automation-id=\"adf-infinite-pagination-button\">\n <ng-content />\n </button>\n\n <mat-progress-bar *ngIf=\"isLoading\"\n mode=\"indeterminate\"\n class=\"adf-infinite-pagination-spinner\"\n data-automation-id=\"adf-infinite-pagination-spinner\"\n [attr.aria-label]=\"'DATA_LOADING' | translate\" />\n</div>\n", styles: [".adf-infinite-pagination{display:flex;justify-content:space-around;min-height:56px}.adf-infinite-pagination-load-more{margin-bottom:10px;margin-top:10px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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: MatProgressBarModule }, { kind: "component", type: i4.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "
|
|
96
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: InfinitePaginationComponent, isStandalone: true, selector: "adf-infinite-pagination", inputs: { target: "target", pageSize: "pageSize", isLoading: ["loading", "isLoading"] }, outputs: { loadMore: "loadMore" }, host: { classAttribute: "infinite-adf-pagination" }, ngImport: i0, template: "<div *ngIf=\"pagination?.hasMoreItems || isLoading\" class=\"adf-infinite-pagination\">\n\n <button mat-button\n *ngIf=\"!isLoading\"\n class=\"adf-infinite-pagination-load-more\"\n (click)=\"onLoadMore()\"\n data-automation-id=\"adf-infinite-pagination-button\">\n <ng-content />\n </button>\n\n <mat-progress-bar *ngIf=\"isLoading\"\n mode=\"indeterminate\"\n class=\"adf-infinite-pagination-spinner\"\n data-automation-id=\"adf-infinite-pagination-spinner\"\n [attr.aria-label]=\"'DATA_LOADING' | translate\" />\n</div>\n", styles: [".adf-infinite-pagination{display:flex;justify-content:space-around;min-height:56px}.adf-infinite-pagination-load-more{margin-bottom:10px;margin-top:10px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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: MatProgressBarModule }, { kind: "component", type: i4.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
98
97
|
}
|
|
99
98
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: InfinitePaginationComponent, decorators: [{
|
|
100
99
|
type: Component,
|
|
101
|
-
args: [{ selector: 'adf-infinite-pagination', host: { class: 'infinite-adf-pagination' }, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [CommonModule, MatButtonModule, MatProgressBarModule,
|
|
100
|
+
args: [{ selector: 'adf-infinite-pagination', host: { class: 'infinite-adf-pagination' }, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [CommonModule, MatButtonModule, MatProgressBarModule, TranslatePipe], template: "<div *ngIf=\"pagination?.hasMoreItems || isLoading\" class=\"adf-infinite-pagination\">\n\n <button mat-button\n *ngIf=\"!isLoading\"\n class=\"adf-infinite-pagination-load-more\"\n (click)=\"onLoadMore()\"\n data-automation-id=\"adf-infinite-pagination-button\">\n <ng-content />\n </button>\n\n <mat-progress-bar *ngIf=\"isLoading\"\n mode=\"indeterminate\"\n class=\"adf-infinite-pagination-spinner\"\n data-automation-id=\"adf-infinite-pagination-spinner\"\n [attr.aria-label]=\"'DATA_LOADING' | translate\" />\n</div>\n", styles: [".adf-infinite-pagination{display:flex;justify-content:space-around;min-height:56px}.adf-infinite-pagination-load-more{margin-bottom:10px;margin-top:10px}\n"] }]
|
|
102
101
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.UserPreferencesService }], propDecorators: { target: [{
|
|
103
102
|
type: Input
|
|
104
103
|
}], pageSize: [{
|
|
@@ -109,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
109
108
|
}], loadMore: [{
|
|
110
109
|
type: Output
|
|
111
110
|
}] } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"infinite-pagination.component.js","sourceRoot":"","sources":["../../../../../../lib/core/src/lib/pagination/infinite-pagination.component.ts","../../../../../../lib/core/src/lib/pagination/infinite-pagination.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\n/* eslint-disable @angular-eslint/no-input-rename */\n/* eslint-disable rxjs/no-subject-value */\n\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    DestroyRef,\n    EventEmitter,\n    inject,\n    Input,\n    OnInit,\n    Output,\n    ViewEncapsulation\n} from '@angular/core';\n\nimport { PaginatedComponent } from './paginated-component.interface';\nimport { PaginationComponentInterface } from './pagination-component.interface';\nimport { RequestPaginationModel } from '../models/request-pagination.model';\nimport { UserPreferencesService, UserPreferenceValues } from '../common/services/user-preferences.service';\nimport { PaginationModel } from '../models/pagination.model';\nimport { CommonModule } from '@angular/common';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatProgressBarModule } from '@angular/material/progress-bar';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\n@Component({\n    selector: 'adf-infinite-pagination',\n    host: { class: 'infinite-adf-pagination' },\n    templateUrl: './infinite-pagination.component.html',\n    styleUrls: ['./infinite-pagination.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    standalone: true,\n    imports: [CommonModule, MatButtonModule, MatProgressBarModule, TranslateModule]\n})\nexport class InfinitePaginationComponent implements OnInit, PaginationComponentInterface {\n    static DEFAULT_PAGINATION: PaginationModel = new PaginationModel({\n        skipCount: 0,\n        maxItems: 25,\n        totalItems: 0\n    });\n\n    _target: PaginatedComponent;\n\n    /** Component that provides custom pagination support. */\n    @Input()\n    set target(target: PaginatedComponent) {\n        if (target) {\n            this._target = target;\n            target.pagination.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((pagination) => {\n                this.isLoading = false;\n                this.pagination = pagination;\n\n                if (!this.pagination.hasMoreItems) {\n                    this.pagination.hasMoreItems = false;\n                }\n\n                this.cdr.detectChanges();\n            });\n        }\n    }\n\n    get target() {\n        return this._target;\n    }\n\n    /** Number of items that are added with each \"load more\" event. */\n    @Input()\n    pageSize: number;\n\n    /** Is a new page loading? */\n    @Input('loading')\n    isLoading: boolean = false;\n\n    /** Emitted when the \"Load More\" button is clicked. */\n    @Output()\n    loadMore: EventEmitter<RequestPaginationModel> = new EventEmitter<RequestPaginationModel>();\n\n    pagination: PaginationModel = InfinitePaginationComponent.DEFAULT_PAGINATION;\n\n    requestPaginationModel: RequestPaginationModel = {\n        skipCount: 0,\n        merge: true\n    };\n\n    private readonly destroyRef = inject(DestroyRef);\n\n    constructor(private cdr: ChangeDetectorRef, private userPreferencesService: UserPreferencesService) {}\n\n    ngOnInit() {\n        this.userPreferencesService\n            .select(UserPreferenceValues.PaginationSize)\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((pageSize: number) => {\n                this.pageSize = this.pageSize || pageSize;\n                this.requestPaginationModel.maxItems = this.pageSize;\n            });\n    }\n\n    onLoadMore() {\n        this.requestPaginationModel.skipCount = 0;\n        this.requestPaginationModel.merge = true;\n\n        this.requestPaginationModel.maxItems += this.pageSize;\n\n        this.loadMore.next(this.requestPaginationModel);\n\n        if (this._target) {\n            this.isLoading = true;\n            this._target.updatePagination(this.requestPaginationModel);\n        }\n    }\n\n    reset() {\n        this.pagination.skipCount = 0;\n        this.pagination.maxItems = this.pageSize;\n\n        if (this._target) {\n            this._target.updatePagination(this.pagination);\n        }\n    }\n}\n","<div *ngIf=\"pagination?.hasMoreItems || isLoading\" class=\"adf-infinite-pagination\">\n\n    <button mat-button\n        *ngIf=\"!isLoading\"\n        class=\"adf-infinite-pagination-load-more\"\n        (click)=\"onLoadMore()\"\n        data-automation-id=\"adf-infinite-pagination-button\">\n            <ng-content />\n    </button>\n\n    <mat-progress-bar *ngIf=\"isLoading\"\n        mode=\"indeterminate\"\n        class=\"adf-infinite-pagination-spinner\"\n        data-automation-id=\"adf-infinite-pagination-spinner\"\n        [attr.aria-label]=\"'DATA_LOADING' | translate\" />\n</div>\n"]}
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"infinite-pagination.component.js","sourceRoot":"","sources":["../../../../../../lib/core/src/lib/pagination/infinite-pagination.component.ts","../../../../../../lib/core/src/lib/pagination/infinite-pagination.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\n/* eslint-disable @angular-eslint/no-input-rename */\n/* eslint-disable rxjs/no-subject-value */\n\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    DestroyRef,\n    EventEmitter,\n    inject,\n    Input,\n    OnInit,\n    Output,\n    ViewEncapsulation\n} from '@angular/core';\n\nimport { PaginatedComponent } from './paginated-component.interface';\nimport { PaginationComponentInterface } from './pagination-component.interface';\nimport { RequestPaginationModel } from '../models/request-pagination.model';\nimport { UserPreferencesService, UserPreferenceValues } from '../common/services/user-preferences.service';\nimport { PaginationModel } from '../models/pagination.model';\nimport { CommonModule } from '@angular/common';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatProgressBarModule } from '@angular/material/progress-bar';\nimport { TranslatePipe } from '@ngx-translate/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\n@Component({\n    selector: 'adf-infinite-pagination',\n    host: { class: 'infinite-adf-pagination' },\n    templateUrl: './infinite-pagination.component.html',\n    styleUrls: ['./infinite-pagination.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    standalone: true,\n    imports: [CommonModule, MatButtonModule, MatProgressBarModule, TranslatePipe]\n})\nexport class InfinitePaginationComponent implements OnInit, PaginationComponentInterface {\n    static DEFAULT_PAGINATION: PaginationModel = new PaginationModel({\n        skipCount: 0,\n        maxItems: 25,\n        totalItems: 0\n    });\n\n    _target: PaginatedComponent;\n\n    /** Component that provides custom pagination support. */\n    @Input()\n    set target(target: PaginatedComponent) {\n        if (target) {\n            this._target = target;\n            target.pagination.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((pagination) => {\n                this.isLoading = false;\n                this.pagination = pagination;\n\n                if (!this.pagination.hasMoreItems) {\n                    this.pagination.hasMoreItems = false;\n                }\n\n                this.cdr.detectChanges();\n            });\n        }\n    }\n\n    get target() {\n        return this._target;\n    }\n\n    /** Number of items that are added with each \"load more\" event. */\n    @Input()\n    pageSize: number;\n\n    /** Is a new page loading? */\n    @Input('loading')\n    isLoading: boolean = false;\n\n    /** Emitted when the \"Load More\" button is clicked. */\n    @Output()\n    loadMore: EventEmitter<RequestPaginationModel> = new EventEmitter<RequestPaginationModel>();\n\n    pagination: PaginationModel = InfinitePaginationComponent.DEFAULT_PAGINATION;\n\n    requestPaginationModel: RequestPaginationModel = {\n        skipCount: 0,\n        merge: true\n    };\n\n    private readonly destroyRef = inject(DestroyRef);\n\n    constructor(private cdr: ChangeDetectorRef, private userPreferencesService: UserPreferencesService) {}\n\n    ngOnInit() {\n        this.userPreferencesService\n            .select(UserPreferenceValues.PaginationSize)\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((pageSize: number) => {\n                this.pageSize = this.pageSize || pageSize;\n                this.requestPaginationModel.maxItems = this.pageSize;\n            });\n    }\n\n    onLoadMore() {\n        this.requestPaginationModel.skipCount = 0;\n        this.requestPaginationModel.merge = true;\n\n        this.requestPaginationModel.maxItems += this.pageSize;\n\n        this.loadMore.next(this.requestPaginationModel);\n\n        if (this._target) {\n            this.isLoading = true;\n            this._target.updatePagination(this.requestPaginationModel);\n        }\n    }\n\n    reset() {\n        this.pagination.skipCount = 0;\n        this.pagination.maxItems = this.pageSize;\n\n        if (this._target) {\n            this._target.updatePagination(this.pagination);\n        }\n    }\n}\n","<div *ngIf=\"pagination?.hasMoreItems || isLoading\" class=\"adf-infinite-pagination\">\n\n    <button mat-button\n        *ngIf=\"!isLoading\"\n        class=\"adf-infinite-pagination-load-more\"\n        (click)=\"onLoadMore()\"\n        data-automation-id=\"adf-infinite-pagination-button\">\n            <ng-content />\n    </button>\n\n    <mat-progress-bar *ngIf=\"isLoading\"\n        mode=\"indeterminate\"\n        class=\"adf-infinite-pagination-spinner\"\n        data-automation-id=\"adf-infinite-pagination-spinner\"\n        [attr.aria-label]=\"'DATA_LOADING' | translate\" />\n</div>\n"]}
|