nuxeo-development-framework 3.8.3 → 3.8.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/nuxeo-development-framework.umd.js +308 -1354
- package/bundles/nuxeo-development-framework.umd.js.map +1 -1
- package/esm2015/lib/components/notifications/components/base-list-notfications.component.js +3 -1
- package/esm2015/lib/components/notifications/components/base-notifications.component.js +1 -5
- package/esm2015/lib/components/notifications/components/notification-source-select/notification-source-select.component.js +5 -1
- package/esm2015/lib/components/notifications/components/notifications-button/notifications-button.component.js +13 -11
- package/esm2015/lib/components/notifications/components/notifications-date-select/notifications-date-select.component.js +5 -1
- package/esm2015/lib/components/notifications/components/notifications-settings/notifications-settings.component.js +2 -2
- package/esm2015/lib/components/notifications/containers/notifications-settings-container/notifications-settings-container.component.js +2 -2
- package/esm2015/lib/components/notifications/models/common.js +1 -1
- package/esm2015/lib/components/notifications/services/notifications.service.js +5 -4
- package/esm2015/lib/components/notifications/utilities/response.adapter.js +1 -1
- package/esm2015/lib/core/models/api-response.model.js +1 -1
- package/esm2015/lib/core/models/automation-response.model.js +1 -1
- package/esm2015/lib/core/models/base-response.models.js +1 -1
- package/esm2015/lib/core/models/index.js +1 -1
- package/fesm2015/nuxeo-development-framework.js +298 -1253
- package/fesm2015/nuxeo-development-framework.js.map +1 -1
- package/lib/components/notifications/components/base-list-notfications.component.d.ts +6 -4
- package/lib/components/notifications/components/base-notifications.component.d.ts +0 -3
- package/lib/components/notifications/components/notification-source-select/notification-source-select.component.d.ts +3 -0
- package/lib/components/notifications/components/notifications-button/notifications-button.component.d.ts +4 -2
- package/lib/components/notifications/components/notifications-date-select/notifications-date-select.component.d.ts +3 -0
- package/lib/components/notifications/components/notifications-settings/notifications-settings.component.d.ts +1 -1
- package/lib/components/notifications/containers/notifications-settings-container/notifications-settings-container.component.d.ts +1 -1
- package/lib/components/notifications/models/common.d.ts +1 -1
- package/lib/components/notifications/services/notifications.service.d.ts +5 -4
- package/lib/components/notifications/utilities/response.adapter.d.ts +1 -1
- package/package.json +1 -1
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { ChangeDetectorRef, Directive, EventEmitter, Output, } from '@angular/core';
|
|
2
2
|
import { finalize, map, switchMap, takeUntil, tap } from 'rxjs/operators';
|
|
3
|
+
import { TranslationService } from '../../../core/services/translation/translation.service';
|
|
3
4
|
import { NOTIFICATION_STATUS, PAGINATION_MODE } from '../constants';
|
|
4
5
|
import { ListenerService } from '../services/listener.service';
|
|
5
6
|
import { ParamsService } from '../services/params.service';
|
|
@@ -15,6 +16,7 @@ export class BaseListNotifications extends BaseNotification {
|
|
|
15
16
|
this._paramsService = this.inject.get(ParamsService);
|
|
16
17
|
this._responseService = this.inject.get(ResponseService);
|
|
17
18
|
this._listenerService = this.inject.get(ListenerService);
|
|
19
|
+
this._translationService = this.inject.get(TranslationService);
|
|
18
20
|
this._cdr = this.inject.get(ChangeDetectorRef);
|
|
19
21
|
this.response$ = this._responseService.response$;
|
|
20
22
|
this.trackByFn = (_, item) => item.uid;
|
|
@@ -151,4 +153,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
151
153
|
}], itemClicked: [{
|
|
152
154
|
type: Output
|
|
153
155
|
}] } });
|
|
154
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-list-notfications.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/base-list-notfications.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Directive,\r\n  EventEmitter,\r\n  Injector,\r\n  Output,\r\n} from '@angular/core';\r\nimport { finalize, map, switchMap, takeUntil, tap } from 'rxjs/operators';\r\nimport { NOTIFICATION_STATUS, PAGINATION_MODE } from '../constants';\r\nimport {\r\n  NotificationModel,\r\n  NotificationsListOptions,\r\n  PayloadParamsModel,\r\n} from '../models';\r\nimport { ListenerService } from '../services/listener.service';\r\nimport { ParamsService } from '../services/params.service';\r\nimport { ResponseService } from '../services/response.service';\r\nimport { BaseNotification } from './base-notifications.component';\r\n\r\n@Directive()\r\nexport class BaseListNotifications extends BaseNotification {\r\n  @Output() markAllRead = new EventEmitter<Event>();\r\n  @Output() itemClicked = new EventEmitter<NotificationModel>();\r\n\r\n  protected _paramsService = this.inject.get(ParamsService);\r\n  protected _responseService = this.inject.get(ResponseService);\r\n  protected _listenerService = this.inject.get(ListenerService);\r\n\r\n  protected _cdr = this.inject.get(ChangeDetectorRef);\r\n\r\n  readonly response$ = this._responseService.response$;\r\n\r\n  trackByFn = (_: number, item: NotificationModel) => item.uid;\r\n\r\n  isLoadingResult = false;\r\n\r\n  currentLang: string;\r\n\r\n  direction$ = this._translationService.isArabic$.pipe(\r\n    map((isArabic) => (isArabic ? 'rtl' : 'ltr'))\r\n  );\r\n\r\n  options: NotificationsListOptions;\r\n  paginationModeEnum = PAGINATION_MODE;\r\n  constructor(protected inject: Injector) {\r\n    super(inject);\r\n\r\n    this._listenerService.onUpdate$\r\n      .pipe(\r\n        switchMap((data) => this._updateList()),\r\n        takeUntil(this.destroy$)\r\n      )\r\n      .subscribe((res) => {\r\n        this._responseService.setResponse(res, true);\r\n      });\r\n  }\r\n\r\n  markAllAsRead(event) {\r\n    this.notificationsService\r\n      .markAllAsRead()\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res) => {\r\n        this._listenerService.triggerUpdate('markAllAsRead');\r\n        this.markAllRead.emit(event);\r\n        this._responseService.resetPagination();\r\n        this._paramsService.applyParams({\r\n          override: true,\r\n          params: {\r\n            currentPageIndex: 0,\r\n          },\r\n        });\r\n      });\r\n  }\r\n\r\n  onScrollDown() {\r\n    if (\r\n      this._responseService.totalItems > this._responseService.itemsLength &&\r\n      !this.isLoadingResult\r\n    ) {\r\n      this._responseService.increasePage();\r\n      this._paramsService.applyParams({\r\n        override: false,\r\n        params: {\r\n          ...this._paramsService.activatedQuery.params,\r\n          currentPageIndex: this._responseService.selectedPage,\r\n        },\r\n      });\r\n    }\r\n  }\r\n\r\n  changePage(page: number) {\r\n    this._responseService.setPage(page);\r\n    this._paramsService.applyParams({\r\n      override: true,\r\n      params: {\r\n        ...this._paramsService.activatedQuery.params,\r\n        currentPageIndex: this._responseService.selectedPage,\r\n      },\r\n    });\r\n  }\r\n\r\n  onItemClick(notification: NotificationModel) {\r\n    this.itemClicked.emit(notification);\r\n    if (notification.properties?.['notif_cnt:status'] !== NOTIFICATION_STATUS.read) {\r\n      this.markAsRead(notification);\r\n    }\r\n  }\r\n\r\n  markAsRead(notification: NotificationModel) {\r\n    this.notificationsService\r\n      .markAsRead(notification.uid)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res) => {\r\n        this._listenerService.triggerUpdate('markAsRead');\r\n      });\r\n  }\r\n\r\n  markAsUnread(notification: NotificationModel) {\r\n    this.notificationsService\r\n      .markAsUnread(notification.uid)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res) => {\r\n        this._listenerService.triggerUpdate('markAsUnread');\r\n      });\r\n  }\r\n\r\n  markAsDeleted(notification: NotificationModel) {\r\n    this.notificationsService\r\n      .markAsDeleted(notification.uid)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res) => {\r\n        this._listenerService.triggerUpdate('markAsDeleted');\r\n      });\r\n  }\r\n\r\n  protected _applyFilter(params: Record<string, any>) {\r\n    this._responseService.resetPagination();\r\n    this._paramsService.applyParams({\r\n      override: true,\r\n      params,\r\n    });\r\n  }\r\n\r\n  protected _prepareData() {\r\n    let isOverride = false;\r\n    this._paramsService.params$\r\n      .pipe(\r\n        tap((query) => {\r\n          isOverride = query.override;\r\n          this.isLoadingResult = true;\r\n          this._cdr.detectChanges();\r\n        }),\r\n        switchMap((query) => {\r\n          return this.notificationsService.getNotifications(query.params).pipe(\r\n            finalize(() => {\r\n              this.isLoadingResult = false;\r\n              this._cdr.detectChanges();\r\n            })\r\n          );\r\n        }),\r\n        takeUntil(this.destroy$)\r\n      )\r\n      .subscribe((res) => {\r\n        this._responseService.setResponse(res, isOverride);\r\n      });\r\n  }\r\n\r\n  protected _prepareLanguage() {\r\n    this._translationService.isArabic$\r\n      .pipe(\r\n        map((data) => (data ? 'ar-AR' : 'en-US')),\r\n        takeUntil(this.destroy$)\r\n      )\r\n      .subscribe((res) => {\r\n        this.currentLang = res;\r\n      });\r\n  }\r\n\r\n  protected _updateList() {\r\n    const query = this._paramsService.activatedQuery;\r\n\r\n    const payload: PayloadParamsModel = { ...query, currentPageIndex: 0 };\r\n\r\n    if (!this.options) {\r\n      return this.notificationsService.getNotificationsMongo(payload);\r\n    }\r\n\r\n    if (this.options.paginationMode === PAGINATION_MODE.navigator) {\r\n      Object.assign(payload, {\r\n        currentPageIndex: this._responseService.selectedPage,\r\n      });\r\n    }\r\n\r\n    if (this.options.paginationMode === PAGINATION_MODE.scroll) {\r\n      const page = this._responseService.selectedPage + 1;\r\n      Object.assign(payload, {\r\n        pageSize: Math.floor(page * (query?.pageSize || 20)),\r\n      });\r\n    }\r\n\r\n    return this.notificationsService.getNotificationsMongo(payload);\r\n  }\r\n}\r\n"]}
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-list-notfications.component.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/base-list-notfications.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Directive,\r\n  EventEmitter,\r\n  Injector,\r\n  Output,\r\n} from '@angular/core';\r\nimport { finalize, map, switchMap, takeUntil, tap } from 'rxjs/operators';\r\nimport { TranslationService } from '../../../core/services/translation/translation.service';\r\nimport { NOTIFICATION_STATUS, PAGINATION_MODE } from '../constants';\r\nimport {\r\n  NotificationModel,\r\n  NotificationsListOptions,\r\n  PayloadParamsModel,\r\n} from '../models';\r\nimport { ListenerService } from '../services/listener.service';\r\nimport { ParamsService } from '../services/params.service';\r\nimport { ResponseService } from '../services/response.service';\r\nimport { BaseNotification } from './base-notifications.component';\r\n\r\n@Directive()\r\nexport class BaseListNotifications extends BaseNotification {\r\n  @Output() markAllRead = new EventEmitter<Event>();\r\n  @Output() itemClicked = new EventEmitter<NotificationModel>();\r\n\r\n  protected readonly _paramsService = this.inject.get(ParamsService);\r\n  protected readonly _responseService = this.inject.get(ResponseService);\r\n  protected readonly _listenerService = this.inject.get(ListenerService);\r\n  protected readonly _translationService = this.inject.get(TranslationService);\r\n\r\n  protected _cdr = this.inject.get(ChangeDetectorRef);\r\n\r\n  readonly response$ = this._responseService.response$;\r\n\r\n  trackByFn = (_: number, item: NotificationModel) => item.uid;\r\n\r\n  isLoadingResult = false;\r\n\r\n  currentLang: string;\r\n  readonly direction$ = this._translationService.isArabic$.pipe(\r\n    map((isArabic) => (isArabic ? 'rtl' : 'ltr'))\r\n  );\r\n\r\n  options: NotificationsListOptions;\r\n  paginationModeEnum = PAGINATION_MODE;\r\n  constructor(protected inject: Injector) {\r\n    super(inject);\r\n\r\n    this._listenerService.onUpdate$\r\n      .pipe(\r\n        switchMap((data) => this._updateList()),\r\n        takeUntil(this.destroy$)\r\n      )\r\n      .subscribe((res) => {\r\n        this._responseService.setResponse(res, true);\r\n      });\r\n  }\r\n\r\n  markAllAsRead(event) {\r\n    this.notificationsService\r\n      .markAllAsRead()\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res) => {\r\n        this._listenerService.triggerUpdate('markAllAsRead');\r\n        this.markAllRead.emit(event);\r\n        this._responseService.resetPagination();\r\n        this._paramsService.applyParams({\r\n          override: true,\r\n          params: {\r\n            currentPageIndex: 0,\r\n          },\r\n        });\r\n      });\r\n  }\r\n\r\n  onScrollDown() {\r\n    if (\r\n      this._responseService.totalItems > this._responseService.itemsLength &&\r\n      !this.isLoadingResult\r\n    ) {\r\n      this._responseService.increasePage();\r\n      this._paramsService.applyParams({\r\n        override: false,\r\n        params: {\r\n          ...this._paramsService.activatedQuery.params,\r\n          currentPageIndex: this._responseService.selectedPage,\r\n        },\r\n      });\r\n    }\r\n  }\r\n\r\n  changePage(page: number) {\r\n    this._responseService.setPage(page);\r\n    this._paramsService.applyParams({\r\n      override: true,\r\n      params: {\r\n        ...this._paramsService.activatedQuery.params,\r\n        currentPageIndex: this._responseService.selectedPage,\r\n      },\r\n    });\r\n  }\r\n\r\n  onItemClick(notification: NotificationModel) {\r\n    this.itemClicked.emit(notification);\r\n    if (notification.properties?.['notif_cnt:status'] !== NOTIFICATION_STATUS.read) {\r\n      this.markAsRead(notification);\r\n    }\r\n  }\r\n\r\n  markAsRead(notification: NotificationModel) {\r\n    this.notificationsService\r\n      .markAsRead(notification.uid)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res) => {\r\n        this._listenerService.triggerUpdate('markAsRead');\r\n      });\r\n  }\r\n\r\n  markAsUnread(notification: NotificationModel) {\r\n    this.notificationsService\r\n      .markAsUnread(notification.uid)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res) => {\r\n        this._listenerService.triggerUpdate('markAsUnread');\r\n      });\r\n  }\r\n\r\n  markAsDeleted(notification: NotificationModel) {\r\n    this.notificationsService\r\n      .markAsDeleted(notification.uid)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res) => {\r\n        this._listenerService.triggerUpdate('markAsDeleted');\r\n      });\r\n  }\r\n\r\n  protected _applyFilter(params: Record<string, any>) {\r\n    this._responseService.resetPagination();\r\n    this._paramsService.applyParams({\r\n      override: true,\r\n      params,\r\n    });\r\n  }\r\n\r\n  protected _prepareData() {\r\n    let isOverride = false;\r\n    this._paramsService.params$\r\n      .pipe(\r\n        tap((query) => {\r\n          isOverride = query.override;\r\n          this.isLoadingResult = true;\r\n          this._cdr.detectChanges();\r\n        }),\r\n        switchMap((query) => {\r\n          return this.notificationsService.getNotifications(query.params).pipe(\r\n            finalize(() => {\r\n              this.isLoadingResult = false;\r\n              this._cdr.detectChanges();\r\n            })\r\n          );\r\n        }),\r\n        takeUntil(this.destroy$)\r\n      )\r\n      .subscribe((res) => {\r\n        this._responseService.setResponse(res, isOverride);\r\n      });\r\n  }\r\n\r\n  protected _prepareLanguage() {\r\n    this._translationService.isArabic$\r\n      .pipe(\r\n        map((data) => (data ? 'ar-AR' : 'en-US')),\r\n        takeUntil(this.destroy$)\r\n      )\r\n      .subscribe((res) => {\r\n        this.currentLang = res;\r\n      });\r\n  }\r\n\r\n  protected _updateList() {\r\n    const query = this._paramsService.activatedQuery;\r\n\r\n    const payload: PayloadParamsModel = { ...query, currentPageIndex: 0 };\r\n\r\n    if (!this.options) {\r\n      return this.notificationsService.getNotificationsMongo(payload);\r\n    }\r\n\r\n    if (this.options.paginationMode === PAGINATION_MODE.navigator) {\r\n      Object.assign(payload, {\r\n        currentPageIndex: this._responseService.selectedPage,\r\n      });\r\n    }\r\n\r\n    if (this.options.paginationMode === PAGINATION_MODE.scroll) {\r\n      const page = this._responseService.selectedPage + 1;\r\n      Object.assign(payload, {\r\n        pageSize: Math.floor(page * (query?.pageSize || 20)),\r\n      });\r\n    }\r\n\r\n    return this.notificationsService.getNotificationsMongo(payload);\r\n  }\r\n}\r\n"]}
|
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
import { Directive } from '@angular/core';
|
|
2
2
|
import { Subject } from 'rxjs';
|
|
3
|
-
import { map } from 'rxjs/operators';
|
|
4
|
-
import { TranslationService } from '../../../Core/services/translation/translation.service';
|
|
5
3
|
import { NotificationsService } from '../services/notifications.service';
|
|
6
4
|
import * as i0 from "@angular/core";
|
|
7
5
|
export class DestroySubject {
|
|
@@ -23,8 +21,6 @@ export class BaseNotification extends DestroySubject {
|
|
|
23
21
|
super();
|
|
24
22
|
this.inject = inject;
|
|
25
23
|
this.notificationsService = this.inject.get(NotificationsService);
|
|
26
|
-
this._translationService = this.inject.get(TranslationService);
|
|
27
|
-
this.direction$ = this._translationService.isArabic$.pipe(map((isArabic) => (isArabic ? 'rtl' : 'ltr')));
|
|
28
24
|
}
|
|
29
25
|
}
|
|
30
26
|
BaseNotification.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: BaseNotification, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive });
|
|
@@ -32,4 +28,4 @@ BaseNotification.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", versi
|
|
|
32
28
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: BaseNotification, decorators: [{
|
|
33
29
|
type: Directive
|
|
34
30
|
}], ctorParameters: function () { return [{ type: i0.Injector }]; } });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1ub3RpZmljYXRpb25zLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL2NvbXBvbmVudHMvbm90aWZpY2F0aW9ucy9jb21wb25lbnRzL2Jhc2Utbm90aWZpY2F0aW9ucy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBdUIsTUFBTSxlQUFlLENBQUM7QUFDL0QsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUMvQixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7QUFHekUsTUFBTSxPQUFnQixjQUFjO0lBRHBDO1FBRUUsYUFBUSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7S0FLaEM7SUFKQyxXQUFXO1FBQ1QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNyQixJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQzNCLENBQUM7OzRHQUxtQixjQUFjO2dHQUFkLGNBQWM7NEZBQWQsY0FBYztrQkFEbkMsU0FBUzs7QUFVVixNQUFNLE9BQWdCLGdCQUFpQixTQUFRLGNBQWM7SUFHM0QsWUFBc0IsTUFBZ0I7UUFDcEMsS0FBSyxFQUFFLENBQUM7UUFEWSxXQUFNLEdBQU4sTUFBTSxDQUFVO1FBRnRCLHlCQUFvQixHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLG9CQUFvQixDQUFDLENBQUM7SUFJN0UsQ0FBQzs7OEdBTG1CLGdCQUFnQjtrR0FBaEIsZ0JBQWdCOzRGQUFoQixnQkFBZ0I7a0JBRHJDLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEluamVjdG9yLCBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBOb3RpZmljYXRpb25zU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL25vdGlmaWNhdGlvbnMuc2VydmljZSc7XHJcblxyXG5ARGlyZWN0aXZlKClcclxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIERlc3Ryb3lTdWJqZWN0IGltcGxlbWVudHMgT25EZXN0cm95IHtcclxuICBkZXN0cm95JCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcbiAgbmdPbkRlc3Ryb3koKSB7XHJcbiAgICB0aGlzLmRlc3Ryb3kkLm5leHQoKTtcclxuICAgIHRoaXMuZGVzdHJveSQuY29tcGxldGUoKTtcclxuICB9XHJcbn1cclxuXHJcbkBEaXJlY3RpdmUoKVxyXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQmFzZU5vdGlmaWNhdGlvbiBleHRlbmRzIERlc3Ryb3lTdWJqZWN0IHtcclxuICBwdWJsaWMgcmVhZG9ubHkgbm90aWZpY2F0aW9uc1NlcnZpY2UgPSB0aGlzLmluamVjdC5nZXQoTm90aWZpY2F0aW9uc1NlcnZpY2UpO1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcm90ZWN0ZWQgaW5qZWN0OiBJbmplY3Rvcikge1xyXG4gICAgc3VwZXIoKTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, EventEmitter, Output, ViewEncapsulation, } from '@angular/core';
|
|
2
|
+
import { map } from 'rxjs/operators';
|
|
3
|
+
import { TranslationService } from '../../../../core/services/translation/translation.service';
|
|
2
4
|
import { BaseNotification } from '../base-notifications.component';
|
|
3
5
|
import * as i0 from "@angular/core";
|
|
4
6
|
import * as i1 from "@angular/material/button";
|
|
@@ -9,8 +11,10 @@ import * as i5 from "@ngx-translate/core";
|
|
|
9
11
|
export class NotificationSourceSelectComponent extends BaseNotification {
|
|
10
12
|
constructor() {
|
|
11
13
|
super(...arguments);
|
|
14
|
+
this._translationService = this.inject.get(TranslationService);
|
|
12
15
|
this.sourceTypes$ = this.notificationsService.getSourceTypes();
|
|
13
16
|
this.typeChanged = new EventEmitter();
|
|
17
|
+
this.direction$ = this._translationService.isArabic$.pipe(map((isArabic) => (isArabic ? 'rtl' : 'ltr')));
|
|
14
18
|
}
|
|
15
19
|
selectFilterType(type) {
|
|
16
20
|
this.selectedFilterType = type;
|
|
@@ -31,4 +35,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
31
35
|
}], propDecorators: { typeChanged: [{
|
|
32
36
|
type: Output
|
|
33
37
|
}] } });
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9uLXNvdXJjZS1zZWxlY3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9ub3RpZmljYXRpb25zL2NvbXBvbmVudHMvbm90aWZpY2F0aW9uLXNvdXJjZS1zZWxlY3Qvbm90aWZpY2F0aW9uLXNvdXJjZS1zZWxlY3QuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9ub3RpZmljYXRpb25zL2NvbXBvbmVudHMvbm90aWZpY2F0aW9uLXNvdXJjZS1zZWxlY3Qvbm90aWZpY2F0aW9uLXNvdXJjZS1zZWxlY3QuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLE1BQU0sRUFDTixpQkFBaUIsR0FDbEIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3JDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDJEQUEyRCxDQUFDO0FBRS9GLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOzs7Ozs7O0FBU25FLE1BQU0sT0FBTyxpQ0FBa0MsU0FBUSxnQkFBZ0I7SUFQdkU7O1FBUXFCLHdCQUFtQixHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLENBQUM7UUFDN0UsaUJBQVksR0FBRyxJQUFJLENBQUMsb0JBQW9CLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDaEQsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO1FBSTFDLGVBQVUsR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUMsU0FBUyxDQUFDLElBQUksQ0FDM0QsR0FBRyxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUM5QyxDQUFDO0tBTUg7SUFKQyxnQkFBZ0IsQ0FBQyxJQUFvQjtRQUNuQyxJQUFJLENBQUMsa0JBQWtCLEdBQUcsSUFBSSxDQUFDO1FBQy9CLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksYUFBSixJQUFJLHVCQUFKLElBQUksQ0FBRSxFQUFFLENBQUMsQ0FBQztJQUNsQyxDQUFDOzsrSEFkVSxpQ0FBaUM7bUhBQWpDLGlDQUFpQyxzSUNuQjlDLGc0Q0FzQ0E7NEZEbkJhLGlDQUFpQztrQkFQN0MsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsZ0NBQWdDO29CQUMxQyxXQUFXLEVBQUUsNkNBQTZDO29CQUMxRCxTQUFTLEVBQUUsQ0FBQyw2Q0FBNkMsQ0FBQztvQkFDMUQsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2lCQUN0Qzs4QkFJVyxXQUFXO3NCQUFwQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICBDb21wb25lbnQsXHJcbiAgRXZlbnRFbWl0dGVyLFxyXG4gIE91dHB1dCxcclxuICBWaWV3RW5jYXBzdWxhdGlvbixcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgbWFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGlvblNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi8uLi9jb3JlL3NlcnZpY2VzL3RyYW5zbGF0aW9uL3RyYW5zbGF0aW9uLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBWb2NhYnVsYXJ5VHlwZSB9IGZyb20gJy4uLy4uL21vZGVscyc7XHJcbmltcG9ydCB7IEJhc2VOb3RpZmljYXRpb24gfSBmcm9tICcuLi9iYXNlLW5vdGlmaWNhdGlvbnMuY29tcG9uZW50JztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXBwLW5vdGlmaWNhdGlvbi1zb3VyY2Utc2VsZWN0JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vbm90aWZpY2F0aW9uLXNvdXJjZS1zZWxlY3QuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL25vdGlmaWNhdGlvbi1zb3VyY2Utc2VsZWN0LmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxufSlcclxuZXhwb3J0IGNsYXNzIE5vdGlmaWNhdGlvblNvdXJjZVNlbGVjdENvbXBvbmVudCBleHRlbmRzIEJhc2VOb3RpZmljYXRpb24ge1xyXG4gIHByb3RlY3RlZCByZWFkb25seSBfdHJhbnNsYXRpb25TZXJ2aWNlID0gdGhpcy5pbmplY3QuZ2V0KFRyYW5zbGF0aW9uU2VydmljZSk7XHJcbiAgc291cmNlVHlwZXMkID0gdGhpcy5ub3RpZmljYXRpb25zU2VydmljZS5nZXRTb3VyY2VUeXBlcygpO1xyXG4gIEBPdXRwdXQoKSB0eXBlQ2hhbmdlZCA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpO1xyXG5cclxuICBzZWxlY3RlZEZpbHRlclR5cGU6IFZvY2FidWxhcnlUeXBlIHwgbnVsbDtcclxuXHJcbiAgcmVhZG9ubHkgZGlyZWN0aW9uJCA9IHRoaXMuX3RyYW5zbGF0aW9uU2VydmljZS5pc0FyYWJpYyQucGlwZShcclxuICAgIG1hcCgoaXNBcmFiaWMpID0+IChpc0FyYWJpYyA/ICdydGwnIDogJ2x0cicpKVxyXG4gICk7XHJcblxyXG4gIHNlbGVjdEZpbHRlclR5cGUodHlwZTogVm9jYWJ1bGFyeVR5cGUpIHtcclxuICAgIHRoaXMuc2VsZWN0ZWRGaWx0ZXJUeXBlID0gdHlwZTtcclxuICAgIHRoaXMudHlwZUNoYW5nZWQuZW1pdCh0eXBlPy5pZCk7XHJcbiAgfVxyXG59XHJcbiIsIjxzcGFuIFtkaXJdPVwiZGlyZWN0aW9uJCB8IGFzeW5jXCIgKm5nSWY9XCJzb3VyY2VUeXBlcyQgfCBhc3luYyBhcyBzb3VyY2VUeXBlc1wiPlxyXG4gIDxidXR0b25cclxuICAgIChjbGljayk9XCIkZXZlbnQuc3RvcFByb3BhZ2F0aW9uKClcIlxyXG4gICAgY2xhc3M9XCJ0eXBlLWZpbHRlci10cmlnZ2VyIHB4LTJcIlxyXG4gICAgW21hdE1lbnVUcmlnZ2VyRm9yXT1cImZpbHRlclR5cGVNZW51XCJcclxuICAgICNmaWx0ZXJUeXBlTWVudVRyaWdnZXI9XCJtYXRNZW51VHJpZ2dlclwiXHJcbiAgICBtYXQtc3Ryb2tlZC1idXR0b25cclxuICA+XHJcbiAgICA8c3Bhbj57e1xyXG4gICAgICAoc2VsZWN0ZWRGaWx0ZXJUeXBlXHJcbiAgICAgICAgPyAndm9jYWJ1bGFyeS5WT0NfTm90Zl9Tb3VyY2VUeXBlcy4nICsgc2VsZWN0ZWRGaWx0ZXJUeXBlLnByb3BlcnRpZXMuaWRcclxuICAgICAgICA6ICdub3RpZmljYXRpb25zLmFsbFR5cGVzJ1xyXG4gICAgICApIHwgdHJhbnNsYXRlXHJcbiAgICB9fTwvc3Bhbj5cclxuICAgIDxzcGFuIGNsYXNzPVwiaWNvbiBpY29uLWNoZXZyb24tZG93blwiPjwvc3Bhbj5cclxuICA8L2J1dHRvbj5cclxuICA8bWF0LW1lbnUgY2xhc3M9XCJzb3VyY2UtdHlwZS1zZWxlY3QtbWVudVwiICNmaWx0ZXJUeXBlTWVudT1cIm1hdE1lbnVcIj5cclxuICAgIDxzcGFuIChjbGljayk9XCIkZXZlbnQuc3RvcFByb3BhZ2F0aW9uKClcIj5cclxuICAgICAgPGJ1dHRvblxyXG4gICAgICAgIG1hdC1tZW51LWl0ZW1cclxuICAgICAgICBjbGFzcz1cInNvdXJjZS10eXBlLXNlbGVjdC1tZW51X19vcHRpb25cIlxyXG4gICAgICAgIChjbGljayk9XCJzZWxlY3RGaWx0ZXJUeXBlKG51bGwpOyBmaWx0ZXJUeXBlTWVudVRyaWdnZXIuY2xvc2VkLmVtaXQoKVwiXHJcbiAgICAgID5cclxuICAgICAgICA8c3Bhbj57eyAnbm90aWZpY2F0aW9ucy5hbGwnIHwgdHJhbnNsYXRlIH19PC9zcGFuPlxyXG4gICAgICA8L2J1dHRvbj5cclxuICAgICAgPGJ1dHRvblxyXG4gICAgICAgIG1hdC1tZW51LWl0ZW1cclxuICAgICAgICBjbGFzcz1cInNvdXJjZS10eXBlLXNlbGVjdC1tZW51X19vcHRpb25cIlxyXG4gICAgICAgICpuZ0Zvcj1cImxldCB0eXBlIG9mIHNvdXJjZVR5cGVzXCJcclxuICAgICAgICAoY2xpY2spPVwic2VsZWN0RmlsdGVyVHlwZSh0eXBlKTsgZmlsdGVyVHlwZU1lbnVUcmlnZ2VyLmNsb3NlZC5lbWl0KClcIlxyXG4gICAgICA+XHJcbiAgICAgICAgPHNwYW4+e3tcclxuICAgICAgICAgICd2b2NhYnVsYXJ5LlZPQ19Ob3RmX1NvdXJjZVR5cGVzLicgKyB0eXBlPy5wcm9wZXJ0aWVzLmlkIHwgdHJhbnNsYXRlXHJcbiAgICAgICAgfX08L3NwYW4+XHJcbiAgICAgIDwvYnV0dG9uPlxyXG4gICAgPC9zcGFuPlxyXG4gIDwvbWF0LW1lbnU+XHJcbjwvc3Bhbj5cclxuIl19
|
|
@@ -6,16 +6,18 @@ import { NOTIFICATION_ICON } from '../../directives';
|
|
|
6
6
|
import { NOTIFICATIONS_LIST_OPTIONS, } from '../../models';
|
|
7
7
|
import { BaseNotification } from '../base-notifications.component';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "
|
|
10
|
-
import * as i2 from "
|
|
11
|
-
import * as i3 from "../notifications-
|
|
12
|
-
import * as i4 from "
|
|
13
|
-
import * as i5 from "@angular/
|
|
14
|
-
import * as i6 from "
|
|
9
|
+
import * as i1 from "../../../../core/services/translation/translation.service";
|
|
10
|
+
import * as i2 from "@angular/material/menu";
|
|
11
|
+
import * as i3 from "../notifications-list/notifications-list.component";
|
|
12
|
+
import * as i4 from "../notifications-sidebar/notifications-sidebar.component";
|
|
13
|
+
import * as i5 from "@angular/common";
|
|
14
|
+
import * as i6 from "@angular/material/badge";
|
|
15
|
+
import * as i7 from "../notifications-sidebar/notifications-sidebar-content";
|
|
15
16
|
export class NotificationsButtonComponent extends BaseNotification {
|
|
16
|
-
constructor(inject, _options) {
|
|
17
|
+
constructor(inject, _translationService, _options) {
|
|
17
18
|
super(inject);
|
|
18
19
|
this.inject = inject;
|
|
20
|
+
this._translationService = _translationService;
|
|
19
21
|
this._getCountSub = new BehaviorSubject(null);
|
|
20
22
|
this._showBadgeSub = new BehaviorSubject(false);
|
|
21
23
|
this.showBadge$ = this._showBadgeSub.asObservable();
|
|
@@ -55,8 +57,8 @@ export class NotificationsButtonComponent extends BaseNotification {
|
|
|
55
57
|
this.isSidebarOpened = value;
|
|
56
58
|
}
|
|
57
59
|
}
|
|
58
|
-
NotificationsButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NotificationsButtonComponent, deps: [{ token: i0.Injector }, { token: NOTIFICATIONS_LIST_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
59
|
-
NotificationsButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: NotificationsButtonComponent, selector: "app-notifications-button", inputs: { styleClass: "styleClass", badgeOptions: "badgeOptions" }, outputs: { listItemClick: "listItemClick", openSettings: "openSettings", openNotifications: "openNotifications" }, host: { classAttribute: "inline-flex justify-center items-center notification-button" }, queries: [{ propertyName: "customIconTemplate", first: true, predicate: NOTIFICATION_ICON, descendants: true, read: TemplateRef, static: true }], usesInheritance: true, ngImport: i0, template: "<button\r\n *ngIf=\"panelMode === panelModeEnum.panel\"\r\n [matMenuTriggerFor]=\"notifications\"\r\n [matBadge]=\"newNotificationCount$ | async\"\r\n [matBadgeHidden]=\"!(showBadge$ | async)\"\r\n [matBadgeSize]=\"badgeOptions.size\"\r\n [matBadgeColor]=\"badgeOptions.color\"\r\n [matBadgePosition]=\"badgeOptions.position\"\r\n [class]=\"styleClass\"\r\n (menuOpened)=\"markAllAsUnread()\"\r\n>\r\n <ng-container [ngTemplateOutlet]=\"customIconTemplate || defaultIconTemplate\">\r\n </ng-container>\r\n</button>\r\n\r\n<mat-menu #notifications=\"matMenu\" class=\"notification-list-panel\">\r\n <ng-template matMenuContent>\r\n <app-notifications-list\r\n (itemClicked)=\"listItemClick.emit($event); notifications.closed.emit()\"\r\n (openSettings)=\"openSettings.emit($event); notifications.closed.emit()\"\r\n (openNotifications)=\"openNotifications.emit($event); notifications.closed.emit()\"\r\n (markAllRead)=\"hideBadgeCount()\"\r\n ></app-notifications-list>\r\n </ng-template>\r\n <div class=\"notification-list-panel__footer flex justify-center\">\r\n <ng-content select=\"[notifications-footer]\"></ng-content>\r\n </div>\r\n</mat-menu>\r\n\r\n<ng-container *ngIf=\"panelMode === panelModeEnum.sidebar\">\r\n <button\r\n [matBadge]=\"newNotificationCount$ | async\"\r\n [matBadgeHidden]=\"!(showBadge$ | async)\"\r\n [matBadgeSize]=\"badgeOptions.size\"\r\n [matBadgeColor]=\"badgeOptions.color\"\r\n [matBadgePosition]=\"badgeOptions.position\"\r\n [class]=\"styleClass\"\r\n (click)=\"toggleSideBar();markAllAsUnread()\"\r\n >\r\n <ng-container [ngTemplateOutlet]=\"customIconTemplate || defaultIconTemplate\">\r\n </ng-container>\r\n </button>\r\n <app-notifications-sidebar [(visible)]=\"isSidebarOpened\" [position]=\"sidebarPosition$ | async\">\r\n <ng-template appNotificationSidebarContent>\r\n <app-notifications-list\r\n class=\"notifications-sidebar\"\r\n (itemClicked)=\"listItemClick.emit($event);toggleSideBar(false)\"\r\n (openSettings)=\"openSettings.emit($event);toggleSideBar(false)\"\r\n (openNotifications)=\"openNotifications.emit($event);toggleSideBar(false)\"\r\n (markAllRead)=\"hideBadgeCount()\"\r\n ></app-notifications-list>\r\n </ng-template>\r\n </app-notifications-sidebar>\r\n</ng-container>\r\n\r\n<ng-template #defaultIconTemplate>\r\n <i class=\"bi bi-bell bell\"></i>\r\n</ng-template>\r\n", styles: [".notification-button{font-size:var(--not-btn-font-size, 1.5rem);width:var(--not-btn-width, 40px)}.notification-list-panel{--width: var(--nos-panel-width, min(80vw, 450px));width:var(--width);border-radius:var(--nos-panel-radius, 5px);overflow:hidden;-webkit-overflow-scrolling:touch;outline:0;background:var(--nos-panel-background, #fff)}.notification-list-panel.mat-menu-panel{max-width:var(--width);max-height:var(--nos-panel-max-height, var(--height))}.notification-list-panel__navigate-btn{background:var(--not-btn-background, transparent);border-radius:var(--not-btn-radius, 5px);padding:var(--not-btn-padding, .5rem 1rem);margin:var(--not-btn-margin, .5rem 0);color:var(--not-btn-color, currentColor);width:var(--not-btn-width, 90%)}.notification-list-panel__navigate-btn:hover{--not-btn-background: var(--not-btn-hover-background, #f0f0f0);--not-btn-color: var(--not-btn-hover-color);-webkit-text-decoration:var(--not-btn-decoration, none);text-decoration:var(--not-btn-decoration, none)}.notification-list-panel__navigate-btn:active{--not-btn-background: var(--not-btn-active-background, #e2e2e2);--not-btn-color: var(--not-btn-active-color)}.notifications-sidebar{--nto-list-header-padding: var(--sidebar-list-header-padding , 1rem);--nto-list-height: var(--sidebar-list-height , calc(100vh - 100px))}\n"], components: [{ type:
|
|
60
|
+
NotificationsButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NotificationsButtonComponent, deps: [{ token: i0.Injector }, { token: i1.TranslationService }, { token: NOTIFICATIONS_LIST_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
61
|
+
NotificationsButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: NotificationsButtonComponent, selector: "app-notifications-button", inputs: { styleClass: "styleClass", badgeOptions: "badgeOptions" }, outputs: { listItemClick: "listItemClick", openSettings: "openSettings", openNotifications: "openNotifications" }, host: { classAttribute: "inline-flex justify-center items-center notification-button" }, queries: [{ propertyName: "customIconTemplate", first: true, predicate: NOTIFICATION_ICON, descendants: true, read: TemplateRef, static: true }], usesInheritance: true, ngImport: i0, template: "<button\r\n *ngIf=\"panelMode === panelModeEnum.panel\"\r\n [matMenuTriggerFor]=\"notifications\"\r\n [matBadge]=\"newNotificationCount$ | async\"\r\n [matBadgeHidden]=\"!(showBadge$ | async)\"\r\n [matBadgeSize]=\"badgeOptions.size\"\r\n [matBadgeColor]=\"badgeOptions.color\"\r\n [matBadgePosition]=\"badgeOptions.position\"\r\n [class]=\"styleClass\"\r\n (menuOpened)=\"markAllAsUnread()\"\r\n>\r\n <ng-container [ngTemplateOutlet]=\"customIconTemplate || defaultIconTemplate\">\r\n </ng-container>\r\n</button>\r\n\r\n<mat-menu #notifications=\"matMenu\" class=\"notification-list-panel\">\r\n <ng-template matMenuContent>\r\n <app-notifications-list\r\n (itemClicked)=\"listItemClick.emit($event); notifications.closed.emit()\"\r\n (openSettings)=\"openSettings.emit($event); notifications.closed.emit()\"\r\n (openNotifications)=\"openNotifications.emit($event); notifications.closed.emit()\"\r\n (markAllRead)=\"hideBadgeCount()\"\r\n ></app-notifications-list>\r\n </ng-template>\r\n <div class=\"notification-list-panel__footer flex justify-center\">\r\n <ng-content select=\"[notifications-footer]\"></ng-content>\r\n </div>\r\n</mat-menu>\r\n\r\n<ng-container *ngIf=\"panelMode === panelModeEnum.sidebar\">\r\n <button\r\n [matBadge]=\"newNotificationCount$ | async\"\r\n [matBadgeHidden]=\"!(showBadge$ | async)\"\r\n [matBadgeSize]=\"badgeOptions.size\"\r\n [matBadgeColor]=\"badgeOptions.color\"\r\n [matBadgePosition]=\"badgeOptions.position\"\r\n [class]=\"styleClass\"\r\n (click)=\"toggleSideBar();markAllAsUnread()\"\r\n >\r\n <ng-container [ngTemplateOutlet]=\"customIconTemplate || defaultIconTemplate\">\r\n </ng-container>\r\n </button>\r\n <app-notifications-sidebar [(visible)]=\"isSidebarOpened\" [position]=\"sidebarPosition$ | async\">\r\n <ng-template appNotificationSidebarContent>\r\n <app-notifications-list\r\n class=\"notifications-sidebar\"\r\n (itemClicked)=\"listItemClick.emit($event);toggleSideBar(false)\"\r\n (openSettings)=\"openSettings.emit($event);toggleSideBar(false)\"\r\n (openNotifications)=\"openNotifications.emit($event);toggleSideBar(false)\"\r\n (markAllRead)=\"hideBadgeCount()\"\r\n ></app-notifications-list>\r\n </ng-template>\r\n </app-notifications-sidebar>\r\n</ng-container>\r\n\r\n<ng-template #defaultIconTemplate>\r\n <i class=\"bi bi-bell bell\"></i>\r\n</ng-template>\r\n", styles: [".notification-button{font-size:var(--not-btn-font-size, 1.5rem);width:var(--not-btn-width, 40px)}.notification-list-panel{--width: var(--nos-panel-width, min(80vw, 450px));width:var(--width);border-radius:var(--nos-panel-radius, 5px);overflow:hidden;-webkit-overflow-scrolling:touch;outline:0;background:var(--nos-panel-background, #fff)}.notification-list-panel.mat-menu-panel{max-width:var(--width);max-height:var(--nos-panel-max-height, var(--height))}.notification-list-panel__navigate-btn{background:var(--not-btn-background, transparent);border-radius:var(--not-btn-radius, 5px);padding:var(--not-btn-padding, .5rem 1rem);margin:var(--not-btn-margin, .5rem 0);color:var(--not-btn-color, currentColor);width:var(--not-btn-width, 90%)}.notification-list-panel__navigate-btn:hover{--not-btn-background: var(--not-btn-hover-background, #f0f0f0);--not-btn-color: var(--not-btn-hover-color);-webkit-text-decoration:var(--not-btn-decoration, none);text-decoration:var(--not-btn-decoration, none)}.notification-list-panel__navigate-btn:active{--not-btn-background: var(--not-btn-active-background, #e2e2e2);--not-btn-color: var(--not-btn-active-color)}.notifications-sidebar{--nto-list-header-padding: var(--sidebar-list-header-padding , 1rem);--nto-list-height: var(--sidebar-list-height , calc(100vh - 100px))}\n"], components: [{ type: i2.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i3.NotificationsListComponent, selector: "app-notifications-list", outputs: ["openSettings", "openNotifications"] }, { type: i4.NotificationsSidebarComponent, selector: "app-notifications-sidebar", inputs: ["appendToBody", "clearOnCLose", "visible", "position"], outputs: ["visibleChange", "onShow", "onHide"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["matMenuTriggerRestoreFocus", "mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { type: i6.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgePosition", "matBadgeSize", "matBadgeColor", "matBadgeOverlap", "matBadgeDescription", "matBadgeHidden", "matBadge"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i2.MatMenuContent, selector: "ng-template[matMenuContent]" }, { type: i7.NotificationSidebarContentDirective, selector: "[appNotificationSidebarContent]" }], pipes: { "async": i5.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
60
62
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: NotificationsButtonComponent, decorators: [{
|
|
61
63
|
type: Component,
|
|
62
64
|
args: [{
|
|
@@ -69,7 +71,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
69
71
|
class: 'inline-flex justify-center items-center notification-button',
|
|
70
72
|
},
|
|
71
73
|
}]
|
|
72
|
-
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: undefined, decorators: [{
|
|
74
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.TranslationService }, { type: undefined, decorators: [{
|
|
73
75
|
type: Optional
|
|
74
76
|
}, {
|
|
75
77
|
type: Inject,
|
|
@@ -88,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
88
90
|
type: ContentChild,
|
|
89
91
|
args: [NOTIFICATION_ICON, { read: TemplateRef, static: true }]
|
|
90
92
|
}] } });
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifications-button.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-button/notifications-button.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-button/notifications-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ContentChild,\r\n  EventEmitter,\r\n  Inject,\r\n  Injector,\r\n  Input,\r\n  Optional,\r\n  Output,\r\n  TemplateRef,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { map, switchMap, takeUntil, tap } from 'rxjs/operators';\r\nimport { PANEL_MODE } from '../../constants';\r\nimport { NOTIFICATION_ICON } from '../../directives';\r\nimport {\r\n  BadgeOptions,\r\n  NotificationModel,\r\n  NotificationPanelMode,\r\n  NOTIFICATIONS_LIST_OPTIONS,\r\n  NotificationsListOptions,\r\n} from '../../models';\r\nimport { BaseNotification } from '../base-notifications.component';\r\n\r\n@Component({\r\n  selector: 'app-notifications-button',\r\n  templateUrl: './notifications-button.component.html',\r\n  styleUrls: ['./notifications-button.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  host: {\r\n    class: 'inline-flex justify-center items-center notification-button',\r\n  },\r\n})\r\nexport class NotificationsButtonComponent extends BaseNotification {\r\n  private readonly _getCountSub = new BehaviorSubject(null);\r\n  private readonly _showBadgeSub = new BehaviorSubject(false);\r\n  readonly showBadge$ = this._showBadgeSub.asObservable();\r\n\r\n  isSidebarOpened = false;\r\n\r\n  @Input() styleClass: string = '';\r\n\r\n  @Input() badgeOptions: BadgeOptions = {\r\n    size: 'small',\r\n    color: 'warn',\r\n    position: 'before',\r\n  };\r\n\r\n  direction$ = this._translationService.isArabic$.pipe(\r\n    map((isArabic) => (isArabic ? 'rtl' : 'ltr'))\r\n  );\r\n\r\n  sidebarPosition$ = this._translationService.isArabic$.pipe(\r\n    map((isArabic) => (isArabic ? 'left' : 'right'))\r\n  );\r\n\r\n  @Output() listItemClick = new EventEmitter<NotificationModel>();\r\n  @Output() openSettings = new EventEmitter<Event>();\r\n  @Output() openNotifications = new EventEmitter<Event>();\r\n\r\n  @ContentChild(NOTIFICATION_ICON, { read: TemplateRef, static: true })\r\n  customIconTemplate: TemplateRef<any> | undefined;\r\n\r\n  readonly newNotificationCount$ = this._getCountSub.pipe(\r\n    switchMap((_) => this.notificationsService.getUnReadCount()),\r\n    tap((count) => {\r\n      this._showBadgeSub.next(count > 0);\r\n    }),\r\n    map((count) => (count >= 100 ? '99+' : count))\r\n  );\r\n\r\n  panelMode: NotificationPanelMode = PANEL_MODE.sidebar;\r\n  panelModeEnum = PANEL_MODE;\r\n  constructor(\r\n    protected inject: Injector,\r\n    @Optional()\r\n    @Inject(NOTIFICATIONS_LIST_OPTIONS)\r\n    _options?: NotificationsListOptions\r\n  ) {\r\n    super(inject);\r\n    if (_options?.panelMode) {\r\n      this.panelMode = _options.panelMode;\r\n    }\r\n  }\r\n\r\n  hideBadgeCount() {\r\n    this._showBadgeSub.next(false);\r\n  }\r\n\r\n  markAllAsUnread() {\r\n    this.notificationsService\r\n      .markAllNewAsUnread()\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res) => {\r\n        this.hideBadgeCount();\r\n      });\r\n  }\r\n\r\n\r\n  toggleSideBar(value = !this.isSidebarOpened){\r\n    this.isSidebarOpened = value;\r\n  }\r\n}\r\n","<button\r\n  *ngIf=\"panelMode === panelModeEnum.panel\"\r\n  [matMenuTriggerFor]=\"notifications\"\r\n  [matBadge]=\"newNotificationCount$ | async\"\r\n  [matBadgeHidden]=\"!(showBadge$ | async)\"\r\n  [matBadgeSize]=\"badgeOptions.size\"\r\n  [matBadgeColor]=\"badgeOptions.color\"\r\n  [matBadgePosition]=\"badgeOptions.position\"\r\n  [class]=\"styleClass\"\r\n  (menuOpened)=\"markAllAsUnread()\"\r\n>\r\n  <ng-container [ngTemplateOutlet]=\"customIconTemplate || defaultIconTemplate\">\r\n  </ng-container>\r\n</button>\r\n\r\n<mat-menu #notifications=\"matMenu\" class=\"notification-list-panel\">\r\n  <ng-template matMenuContent>\r\n    <app-notifications-list\r\n      (itemClicked)=\"listItemClick.emit($event); notifications.closed.emit()\"\r\n      (openSettings)=\"openSettings.emit($event); notifications.closed.emit()\"\r\n      (openNotifications)=\"openNotifications.emit($event); notifications.closed.emit()\"\r\n      (markAllRead)=\"hideBadgeCount()\"\r\n    ></app-notifications-list>\r\n  </ng-template>\r\n  <div class=\"notification-list-panel__footer flex justify-center\">\r\n    <ng-content select=\"[notifications-footer]\"></ng-content>\r\n  </div>\r\n</mat-menu>\r\n\r\n<ng-container *ngIf=\"panelMode === panelModeEnum.sidebar\">\r\n  <button\r\n    [matBadge]=\"newNotificationCount$ | async\"\r\n    [matBadgeHidden]=\"!(showBadge$ | async)\"\r\n    [matBadgeSize]=\"badgeOptions.size\"\r\n    [matBadgeColor]=\"badgeOptions.color\"\r\n    [matBadgePosition]=\"badgeOptions.position\"\r\n    [class]=\"styleClass\"\r\n    (click)=\"toggleSideBar();markAllAsUnread()\"\r\n  >\r\n    <ng-container [ngTemplateOutlet]=\"customIconTemplate || defaultIconTemplate\">\r\n    </ng-container>\r\n  </button>\r\n  <app-notifications-sidebar [(visible)]=\"isSidebarOpened\" [position]=\"sidebarPosition$ | async\">\r\n    <ng-template appNotificationSidebarContent>\r\n      <app-notifications-list\r\n        class=\"notifications-sidebar\"\r\n        (itemClicked)=\"listItemClick.emit($event);toggleSideBar(false)\"\r\n        (openSettings)=\"openSettings.emit($event);toggleSideBar(false)\"\r\n        (openNotifications)=\"openNotifications.emit($event);toggleSideBar(false)\"\r\n        (markAllRead)=\"hideBadgeCount()\"\r\n      ></app-notifications-list>\r\n    </ng-template>\r\n  </app-notifications-sidebar>\r\n</ng-container>\r\n\r\n<ng-template #defaultIconTemplate>\r\n  <i class=\"bi bi-bell bell\"></i>\r\n</ng-template>\r\n"]}
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifications-button.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-button/notifications-button.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-button/notifications-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ContentChild,\r\n  EventEmitter,\r\n  Inject,\r\n  Injector,\r\n  Input,\r\n  Optional,\r\n  Output,\r\n  TemplateRef,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { map, switchMap, takeUntil, tap } from 'rxjs/operators';\r\nimport { TranslationService } from '../../../../core/services/translation/translation.service';\r\nimport { PANEL_MODE } from '../../constants';\r\nimport { NOTIFICATION_ICON } from '../../directives';\r\nimport {\r\n  BadgeOptions,\r\n  NotificationModel,\r\n  NotificationPanelMode,\r\n  NOTIFICATIONS_LIST_OPTIONS,\r\n  NotificationsListOptions,\r\n} from '../../models';\r\nimport { BaseNotification } from '../base-notifications.component';\r\n\r\n@Component({\r\n  selector: 'app-notifications-button',\r\n  templateUrl: './notifications-button.component.html',\r\n  styleUrls: ['./notifications-button.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  host: {\r\n    class: 'inline-flex justify-center items-center notification-button',\r\n  },\r\n})\r\nexport class NotificationsButtonComponent extends BaseNotification {\r\n  private readonly _getCountSub = new BehaviorSubject(null);\r\n  private readonly _showBadgeSub = new BehaviorSubject(false);\r\n  readonly showBadge$ = this._showBadgeSub.asObservable();\r\n\r\n  isSidebarOpened = false;\r\n\r\n  @Input() styleClass: string = '';\r\n\r\n  @Input() badgeOptions: BadgeOptions = {\r\n    size: 'small',\r\n    color: 'warn',\r\n    position: 'before',\r\n  };\r\n\r\n  direction$ = this._translationService.isArabic$.pipe(\r\n    map((isArabic) => (isArabic ? 'rtl' : 'ltr'))\r\n  );\r\n\r\n  sidebarPosition$ = this._translationService.isArabic$.pipe(\r\n    map((isArabic) => (isArabic ? 'left' : 'right'))\r\n  );\r\n\r\n  @Output() listItemClick = new EventEmitter<NotificationModel>();\r\n  @Output() openSettings = new EventEmitter<Event>();\r\n  @Output() openNotifications = new EventEmitter<Event>();\r\n\r\n  @ContentChild(NOTIFICATION_ICON, { read: TemplateRef, static: true })\r\n  customIconTemplate: TemplateRef<any> | undefined;\r\n\r\n  readonly newNotificationCount$ = this._getCountSub.pipe(\r\n    switchMap((_) => this.notificationsService.getUnReadCount()),\r\n    tap((count) => {\r\n      this._showBadgeSub.next(count > 0);\r\n    }),\r\n    map((count) => (count >= 100 ? '99+' : count))\r\n  );\r\n\r\n  panelMode: NotificationPanelMode = PANEL_MODE.sidebar;\r\n  panelModeEnum = PANEL_MODE;\r\n  constructor(\r\n    protected inject: Injector,\r\n    private _translationService: TranslationService,\r\n    @Optional()\r\n    @Inject(NOTIFICATIONS_LIST_OPTIONS)\r\n    _options?: NotificationsListOptions\r\n  ) {\r\n    super(inject);\r\n    if (_options?.panelMode) {\r\n      this.panelMode = _options.panelMode;\r\n    }\r\n  }\r\n\r\n  hideBadgeCount() {\r\n    this._showBadgeSub.next(false);\r\n  }\r\n\r\n  markAllAsUnread() {\r\n    this.notificationsService\r\n      .markAllNewAsUnread()\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((res) => {\r\n        this.hideBadgeCount();\r\n      });\r\n  }\r\n\r\n  toggleSideBar(value = !this.isSidebarOpened) {\r\n    this.isSidebarOpened = value;\r\n  }\r\n}\r\n","<button\r\n  *ngIf=\"panelMode === panelModeEnum.panel\"\r\n  [matMenuTriggerFor]=\"notifications\"\r\n  [matBadge]=\"newNotificationCount$ | async\"\r\n  [matBadgeHidden]=\"!(showBadge$ | async)\"\r\n  [matBadgeSize]=\"badgeOptions.size\"\r\n  [matBadgeColor]=\"badgeOptions.color\"\r\n  [matBadgePosition]=\"badgeOptions.position\"\r\n  [class]=\"styleClass\"\r\n  (menuOpened)=\"markAllAsUnread()\"\r\n>\r\n  <ng-container [ngTemplateOutlet]=\"customIconTemplate || defaultIconTemplate\">\r\n  </ng-container>\r\n</button>\r\n\r\n<mat-menu #notifications=\"matMenu\" class=\"notification-list-panel\">\r\n  <ng-template matMenuContent>\r\n    <app-notifications-list\r\n      (itemClicked)=\"listItemClick.emit($event); notifications.closed.emit()\"\r\n      (openSettings)=\"openSettings.emit($event); notifications.closed.emit()\"\r\n      (openNotifications)=\"openNotifications.emit($event); notifications.closed.emit()\"\r\n      (markAllRead)=\"hideBadgeCount()\"\r\n    ></app-notifications-list>\r\n  </ng-template>\r\n  <div class=\"notification-list-panel__footer flex justify-center\">\r\n    <ng-content select=\"[notifications-footer]\"></ng-content>\r\n  </div>\r\n</mat-menu>\r\n\r\n<ng-container *ngIf=\"panelMode === panelModeEnum.sidebar\">\r\n  <button\r\n    [matBadge]=\"newNotificationCount$ | async\"\r\n    [matBadgeHidden]=\"!(showBadge$ | async)\"\r\n    [matBadgeSize]=\"badgeOptions.size\"\r\n    [matBadgeColor]=\"badgeOptions.color\"\r\n    [matBadgePosition]=\"badgeOptions.position\"\r\n    [class]=\"styleClass\"\r\n    (click)=\"toggleSideBar();markAllAsUnread()\"\r\n  >\r\n    <ng-container [ngTemplateOutlet]=\"customIconTemplate || defaultIconTemplate\">\r\n    </ng-container>\r\n  </button>\r\n  <app-notifications-sidebar [(visible)]=\"isSidebarOpened\" [position]=\"sidebarPosition$ | async\">\r\n    <ng-template appNotificationSidebarContent>\r\n      <app-notifications-list\r\n        class=\"notifications-sidebar\"\r\n        (itemClicked)=\"listItemClick.emit($event);toggleSideBar(false)\"\r\n        (openSettings)=\"openSettings.emit($event);toggleSideBar(false)\"\r\n        (openNotifications)=\"openNotifications.emit($event);toggleSideBar(false)\"\r\n        (markAllRead)=\"hideBadgeCount()\"\r\n      ></app-notifications-list>\r\n    </ng-template>\r\n  </app-notifications-sidebar>\r\n</ng-container>\r\n\r\n<ng-template #defaultIconTemplate>\r\n  <i class=\"bi bi-bell bell\"></i>\r\n</ng-template>\r\n"]}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, EventEmitter, Output, ViewEncapsulation, } from '@angular/core';
|
|
2
2
|
import * as moment from 'moment';
|
|
3
|
+
import { map } from 'rxjs/operators';
|
|
4
|
+
import { TranslationService } from '../../../../core/services/translation/translation.service';
|
|
3
5
|
import { FILTER_DATES_TYPE } from '../../constants';
|
|
4
6
|
import { BaseNotification } from '../base-notifications.component';
|
|
5
7
|
import * as i0 from "@angular/core";
|
|
@@ -11,6 +13,8 @@ import * as i5 from "@ngx-translate/core";
|
|
|
11
13
|
export class NotificationsDateSelectComponent extends BaseNotification {
|
|
12
14
|
constructor() {
|
|
13
15
|
super(...arguments);
|
|
16
|
+
this._translationService = this.inject.get(TranslationService);
|
|
17
|
+
this.direction$ = this._translationService.isArabic$.pipe(map((isArabic) => (isArabic ? 'rtl' : 'ltr')));
|
|
14
18
|
this.dateChanged = new EventEmitter();
|
|
15
19
|
this.dates = this._prepareDateList();
|
|
16
20
|
}
|
|
@@ -56,4 +60,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
56
60
|
}], propDecorators: { dateChanged: [{
|
|
57
61
|
type: Output
|
|
58
62
|
}] } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9ucy1kYXRlLXNlbGVjdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL25vdGlmaWNhdGlvbnMvY29tcG9uZW50cy9ub3RpZmljYXRpb25zLWRhdGUtc2VsZWN0L25vdGlmaWNhdGlvbnMtZGF0ZS1zZWxlY3QuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9ub3RpZmljYXRpb25zL2NvbXBvbmVudHMvbm90aWZpY2F0aW9ucy1kYXRlLXNlbGVjdC9ub3RpZmljYXRpb25zLWRhdGUtc2VsZWN0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFlBQVksRUFDWixNQUFNLEVBQ04saUJBQWlCLEdBQ2xCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sS0FBSyxNQUFNLE1BQU0sUUFBUSxDQUFDO0FBQ2pDLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwyREFBMkQsQ0FBQztBQUMvRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUVwRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQzs7Ozs7OztBQVFuRSxNQUFNLE9BQU8sZ0NBQWlDLFNBQVEsZ0JBQWdCO0lBUHRFOztRQVFxQix3QkFBbUIsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBRXBFLGVBQVUsR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUMsU0FBUyxDQUFDLElBQUksQ0FDM0QsR0FBRyxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUM5QyxDQUFDO1FBRVEsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBZ0MsQ0FBQztRQUV6RSxVQUFLLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7S0FzQ2pDO0lBbENTLGdCQUFnQjtRQUN0QixPQUFPLE1BQU0sQ0FBQyxPQUFPLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDbkYsQ0FBQztJQUVELFVBQVUsQ0FBQyxJQUE4RDtRQUN2RSxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQztRQUN6QixNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3BCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUNuQixJQUFJO1lBQ0YsQ0FBQyxDQUFDO2dCQUNFLEdBQUcsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7Z0JBQy9CLEdBQUcsRUFBRSxNQUFNLEVBQUUsQ0FBQyxNQUFNLEVBQUU7YUFDdkI7WUFDSCxDQUFDLENBQUMsSUFBSSxDQUNULENBQUM7SUFDSixDQUFDO0lBRU8sV0FBVyxDQUFDLElBQW9DO1FBQ3RELElBQUksQ0FBQyxJQUFJLEVBQUU7WUFDVCxPQUFPO1NBQ1I7UUFDRCxNQUFNLEtBQUssR0FHUDtZQUNGLE9BQU8sRUFBRSxDQUFDLENBQUMsRUFBRSxNQUFNLENBQUM7WUFDcEIsUUFBUSxFQUFFLENBQUMsQ0FBQyxFQUFFLE9BQU8sQ0FBQztZQUN0QixTQUFTLEVBQUUsQ0FBQyxDQUFDLEVBQUUsUUFBUSxDQUFDO1lBQ3hCLFlBQVksRUFBRSxDQUFDLENBQUMsRUFBRSxRQUFRLENBQUM7WUFDM0IsUUFBUSxFQUFFLENBQUMsQ0FBQyxFQUFFLE9BQU8sQ0FBQztTQUN2QixDQUFDO1FBQ0YsTUFBTSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDbkMsT0FBTyxNQUFNLEVBQUUsQ0FBQyxRQUFRLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUNqRSxDQUFDOzs4SEE5Q1UsZ0NBQWdDO2tIQUFoQyxnQ0FBZ0MscUlDckI3Qyx3dENBc0NBOzRGRGpCYSxnQ0FBZ0M7a0JBUDVDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLCtCQUErQjtvQkFDekMsV0FBVyxFQUFFLDRDQUE0QztvQkFDekQsU0FBUyxFQUFFLENBQUMsNENBQTRDLENBQUM7b0JBQ3pELGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO29CQUNyQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQ7OEJBUVcsV0FBVztzQkFBcEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEtleVZhbHVlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHtcclxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICBDb21wb25lbnQsXHJcbiAgRXZlbnRFbWl0dGVyLFxyXG4gIE91dHB1dCxcclxuICBWaWV3RW5jYXBzdWxhdGlvbixcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0ICogYXMgbW9tZW50IGZyb20gJ21vbWVudCc7XHJcbmltcG9ydCB7IG1hcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuaW1wb3J0IHsgVHJhbnNsYXRpb25TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vLi4vY29yZS9zZXJ2aWNlcy90cmFuc2xhdGlvbi90cmFuc2xhdGlvbi5zZXJ2aWNlJztcclxuaW1wb3J0IHsgRklMVEVSX0RBVEVTX1RZUEUgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xyXG5pbXBvcnQgeyBGaWx0ZXJEYXRlVHlwZSB9IGZyb20gJy4uLy4uL21vZGVscyc7XHJcbmltcG9ydCB7IEJhc2VOb3RpZmljYXRpb24gfSBmcm9tICcuLi9iYXNlLW5vdGlmaWNhdGlvbnMuY29tcG9uZW50JztcclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtbm90aWZpY2F0aW9ucy1kYXRlLXNlbGVjdCcsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL25vdGlmaWNhdGlvbnMtZGF0ZS1zZWxlY3QuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL25vdGlmaWNhdGlvbnMtZGF0ZS1zZWxlY3QuY29tcG9uZW50LnNjc3MnXSxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgTm90aWZpY2F0aW9uc0RhdGVTZWxlY3RDb21wb25lbnQgZXh0ZW5kcyBCYXNlTm90aWZpY2F0aW9uIHtcclxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgX3RyYW5zbGF0aW9uU2VydmljZSA9IHRoaXMuaW5qZWN0LmdldChUcmFuc2xhdGlvblNlcnZpY2UpO1xyXG5cclxuICByZWFkb25seSBkaXJlY3Rpb24kID0gdGhpcy5fdHJhbnNsYXRpb25TZXJ2aWNlLmlzQXJhYmljJC5waXBlKFxyXG4gICAgbWFwKChpc0FyYWJpYykgPT4gKGlzQXJhYmljID8gJ3J0bCcgOiAnbHRyJykpXHJcbiAgKTtcclxuXHJcbiAgQE91dHB1dCgpIGRhdGVDaGFuZ2VkID0gbmV3IEV2ZW50RW1pdHRlcjx7IG1pbjogc3RyaW5nOyBtYXg6IHN0cmluZyB9PigpO1xyXG5cclxuICBkYXRlcyA9IHRoaXMuX3ByZXBhcmVEYXRlTGlzdCgpO1xyXG5cclxuICBzZWxlY3RlZERhdGU6IEtleVZhbHVlPHN0cmluZywgRmlsdGVyRGF0ZVR5cGU+O1xyXG5cclxuICBwcml2YXRlIF9wcmVwYXJlRGF0ZUxpc3QoKTogS2V5VmFsdWU8c3RyaW5nLCBGaWx0ZXJEYXRlVHlwZT5bXSB7XHJcbiAgICByZXR1cm4gT2JqZWN0LmVudHJpZXMoRklMVEVSX0RBVEVTX1RZUEUpLm1hcCgoW2tleSwgdmFsdWVdKSA9PiAoeyBrZXksIHZhbHVlIH0pKTtcclxuICB9XHJcblxyXG4gIHNlbGVjdERhdGUoZGF0ZTogS2V5VmFsdWU8a2V5b2YgdHlwZW9mIEZJTFRFUl9EQVRFU19UWVBFLCBGaWx0ZXJEYXRlVHlwZT4pIHtcclxuICAgIHRoaXMuc2VsZWN0ZWREYXRlID0gZGF0ZTtcclxuICAgIG1vbWVudC5sb2NhbGUoJ2VuJyk7XHJcbiAgICB0aGlzLmRhdGVDaGFuZ2VkLmVtaXQoXHJcbiAgICAgIGRhdGVcclxuICAgICAgICA/IHtcclxuICAgICAgICAgICAgbWluOiB0aGlzLl9nZXRNaW5EYXRlKGRhdGUua2V5KSxcclxuICAgICAgICAgICAgbWF4OiBtb21lbnQoKS5mb3JtYXQoKSxcclxuICAgICAgICAgIH1cclxuICAgICAgICA6IG51bGxcclxuICAgICk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIF9nZXRNaW5EYXRlKGRhdGU6IGtleW9mIHR5cGVvZiBGSUxURVJfREFURVNfVFlQRSkge1xyXG4gICAgaWYgKCFkYXRlKSB7XHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuICAgIGNvbnN0IGRhdGVzOiBSZWNvcmQ8XHJcbiAgICAgIGtleW9mIHR5cGVvZiBGSUxURVJfREFURVNfVFlQRSxcclxuICAgICAgW251bWJlciwgbW9tZW50LkR1cmF0aW9uSW5wdXRBcmcyXVxyXG4gICAgPiA9IHtcclxuICAgICAgbGFzdERheTogWzEsICdkYXlzJ10sXHJcbiAgICAgIGxhc3RXZWVrOiBbMSwgJ3dlZWtzJ10sXHJcbiAgICAgIGxhc3RNb250aDogWzEsICdtb250aHMnXSxcclxuICAgICAgbGFzdEhhbGZZZWFyOiBbNiwgJ21vbnRocyddLFxyXG4gICAgICBsYXN0WWVhcjogWzEsICd5ZWFycyddLFxyXG4gICAgfTtcclxuICAgIGNvbnN0IFthbW91bnQsIHVuaXRdID0gZGF0ZXNbZGF0ZV07XHJcbiAgICByZXR1cm4gbW9tZW50KCkuc3VidHJhY3QoYW1vdW50LCB1bml0KS5zdGFydE9mKCdkYXknKS5mb3JtYXQoKTtcclxuICB9XHJcbn1cclxuIiwiPHNwYW4gW2Rpcl09XCJkaXJlY3Rpb24kIHwgYXN5bmNcIj5cclxuICA8YnV0dG9uXHJcbiAgICAoY2xpY2spPVwiJGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXCJcclxuICAgIGNsYXNzPVwiZGF0ZS1zZWxlY3QtYnV0dG9uXCJcclxuICAgIG1hdC1zdHJva2VkLWJ1dHRvblxyXG4gICAgW21hdE1lbnVUcmlnZ2VyRm9yXT1cImRhdGVzTWVudVwiXHJcbiAgICAjZmlsdGVyVHlwZU1lbnVUcmlnZ2VyPVwibWF0TWVudVRyaWdnZXJcIlxyXG4gID5cclxuICAgIDxzcGFuPlxyXG4gICAgICB7e1xyXG4gICAgICAgIChzZWxlY3RlZERhdGVcclxuICAgICAgICAgID8gJ25vdGlmaWNhdGlvbnMuZGF0ZXMuJyArIHNlbGVjdGVkRGF0ZS5rZXlcclxuICAgICAgICAgIDogJ25vdGlmaWNhdGlvbnMuZGF0ZXMuYWxsJ1xyXG4gICAgICAgICkgfCB0cmFuc2xhdGVcclxuICAgICAgfX1cclxuICAgIDwvc3Bhbj5cclxuICAgIDxzcGFuIGNsYXNzPVwiaWNvbiBpY29uLWNoZXZyb24tZG93blwiPjwvc3Bhbj5cclxuICA8L2J1dHRvbj5cclxuICA8bWF0LW1lbnUgY2xhc3M9XCJkYXRlcy1zZWxlY3QtbWVudVwiICNkYXRlc01lbnU9XCJtYXRNZW51XCI+XHJcbiAgICA8c3BhbiAoY2xpY2spPVwiJGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXCI+XHJcbiAgICAgIDxidXR0b25cclxuICAgICAgICBtYXQtbWVudS1pdGVtXHJcbiAgICAgICAgY2xhc3M9XCJkYXRlcy1zZWxlY3QtbWVudV9fb3B0aW9uXCJcclxuICAgICAgICAoY2xpY2spPVwic2VsZWN0RGF0ZShudWxsKTsgZGF0ZXNNZW51LmNsb3NlZC5lbWl0KClcIlxyXG4gICAgICA+XHJcbiAgICAgICAgPHNwYW4+e3sgJ25vdGlmaWNhdGlvbnMuZGF0ZXMuYWxsJyB8IHRyYW5zbGF0ZSB9fTwvc3Bhbj5cclxuICAgICAgPC9idXR0b24+XHJcbiAgICAgIDxidXR0b25cclxuICAgICAgICBtYXQtbWVudS1pdGVtXHJcbiAgICAgICAgKm5nRm9yPVwibGV0IGRhdGUgb2YgZGF0ZXNcIlxyXG4gICAgICAgIGNsYXNzPVwiZGF0ZXMtc2VsZWN0LW1lbnVfX29wdGlvblwiXHJcbiAgICAgICAgKGNsaWNrKT1cInNlbGVjdERhdGUoZGF0ZSk7IGRhdGVzTWVudS5jbG9zZWQuZW1pdCgpXCJcclxuICAgICAgPlxyXG4gICAgICAgIDxzcGFuPnt7ICdub3RpZmljYXRpb25zLmRhdGVzLicgKyBkYXRlLmtleSB8IHRyYW5zbGF0ZSB9fTwvc3Bhbj5cclxuICAgICAgPC9idXR0b24+XHJcbiAgICA8L3NwYW4+XHJcbiAgPC9tYXQtbWVudT5cclxuPC9zcGFuPlxyXG4iXX0=
|
|
@@ -4,7 +4,7 @@ import { finalize, map, switchMap, takeUntil, tap } from 'rxjs/operators';
|
|
|
4
4
|
import { BaseNotification } from '../base-notifications.component';
|
|
5
5
|
import { mapDefinitionToPresenter, mapSubscriptionToPresenter, } from './notifications-settings.adapter';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "../../../../
|
|
7
|
+
import * as i1 from "../../../../core/services/translation/translation.service";
|
|
8
8
|
import * as i2 from "../../../custom-toastr/services/custom-toastr.service";
|
|
9
9
|
import * as i3 from "@angular/material/progress-spinner";
|
|
10
10
|
import * as i4 from "@angular/material/icon";
|
|
@@ -160,4 +160,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
160
160
|
}], channel: [{
|
|
161
161
|
type: Input
|
|
162
162
|
}] } });
|
|
163
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifications-settings.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-settings/notifications-settings.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-settings/notifications-settings.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Inject,\r\n  Injector,\r\n  Input,\r\n  Output,\r\n} from '@angular/core';\r\nimport { MatSlideToggleChange } from '@angular/material/slide-toggle';\r\nimport { BehaviorSubject, combineLatest, ReplaySubject } from 'rxjs';\r\nimport { finalize, map, switchMap, takeUntil, tap } from 'rxjs/operators';\r\nimport { TranslationService } from '../../../../Core/services/translation/translation.service';\r\nimport { CustomToastrService } from '../../../custom-toastr/services/custom-toastr.service';\r\nimport {\r\n  NotificationDefinitionModel,\r\n  NotificationDefinitionPresenter,\r\n  NotificationSubscriptionPresenter,\r\n  VocabularyType,\r\n} from '../../models';\r\nimport { BaseNotification } from '../base-notifications.component';\r\nimport {\r\n  mapDefinitionToPresenter,\r\n  mapSubscriptionToPresenter,\r\n} from './notifications-settings.adapter';\r\n\r\n@Component({\r\n  selector: 'app-notifications-settings',\r\n  templateUrl: './notifications-settings.component.html',\r\n  styleUrls: ['./notifications-settings.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class NotificationsSettingsComponent extends BaseNotification {\r\n  @Output() onSubscribe = new EventEmitter<NotificationDefinitionPresenter>();\r\n  @Output() onUnsubscribe = new EventEmitter<Record<string, any>>();\r\n\r\n  private readonly _channelSub = new ReplaySubject<VocabularyType>();\r\n\r\n  changingItemId: string;\r\n  isLoadingResult = false;\r\n  private _channel: VocabularyType;\r\n  @Input() set channel(value: VocabularyType) {\r\n    this._channel = value;\r\n    if (value) {\r\n      this._channelSub.next(value);\r\n    }\r\n  }\r\n\r\n  get currentLang() {\r\n    return this._translateService.userLang;\r\n  }\r\n  private get _appKey() {\r\n    return this._environment?.appKey;\r\n  }\r\n\r\n  private readonly _subscriptionsSub = new BehaviorSubject<\r\n    NotificationSubscriptionPresenter[]\r\n  >([]);\r\n\r\n  readonly settings$ = this._prepareSettings();\r\n\r\n  constructor(\r\n    protected inject: Injector,\r\n    private _translateService: TranslationService,\r\n    private _cdr: ChangeDetectorRef,\r\n    private _toastrService: CustomToastrService,\r\n    @Inject('environment') private _environment: Record<string, any>\r\n  ) {\r\n    super(inject);\r\n  }\r\n\r\n  getSubscriptionsByChannel(channel: string) {\r\n    return this.notificationsService\r\n      .getSubscriptions({\r\n        notfsubscription_channel: channel,\r\n      })\r\n      .pipe(map((data) => data.map(mapSubscriptionToPresenter)));\r\n  }\r\n\r\n  getDefinitionsByChannel(channel: string) {\r\n    return this.notificationsService\r\n      .getDefinitions({\r\n        notfnotificationdef_channel: channel,\r\n      })\r\n      .pipe(\r\n        map((response) => {\r\n          return response.reduce((group, item) => {\r\n            if (!this._matchItem(item, channel)) {\r\n              return group;\r\n            }\r\n            const _data = mapDefinitionToPresenter(item);\r\n            return this._groupBy(group, _data);\r\n          }, {} as Record<string, NotificationDefinitionPresenter[]>);\r\n        })\r\n      );\r\n  }\r\n\r\n  settingChanged(\r\n    definition: NotificationDefinitionPresenter,\r\n    state: MatSlideToggleChange\r\n  ) {\r\n    if (state.checked) {\r\n      this._handleSubscribe(definition);\r\n    } else {\r\n      this._handleUnsubscribe(definition);\r\n    }\r\n  }\r\n\r\n  private _prepareSettings() {\r\n    return this._channelSub.pipe(\r\n      tap(() => {\r\n        this.isLoadingResult = true;\r\n      }),\r\n      switchMap((channel) => {\r\n        const definition = this.getDefinitionsByChannel(channel.id);\r\n        const subscriptions = this.getSubscriptionsByChannel(channel.id).pipe(\r\n          switchMap((data) => {\r\n            this._subscriptionsSub.next(data);\r\n            return this._subscriptionsSub.asObservable();\r\n          })\r\n        );\r\n        return combineLatest([definition, subscriptions]).pipe(\r\n          map(([definitions, subscriptions]) => ({ definitions, subscriptions })),\r\n          tap(() => {\r\n            this.isLoadingResult = false;\r\n            this._cdr.detectChanges();\r\n          })\r\n        );\r\n      })\r\n    );\r\n  }\r\n\r\n  private _handleSubscribe(definition: NotificationDefinitionPresenter) {\r\n    this.changingItemId = definition.uid;\r\n    this.notificationsService\r\n      .subscribe(definition.uid)\r\n      .pipe(\r\n        switchMap(() =>\r\n          this.getSubscriptionsByChannel(this._channel.id).pipe(\r\n            finalize(() => {\r\n              this.changingItemId = null;\r\n              this._cdr.detectChanges();\r\n            })\r\n          )\r\n        ),\r\n        takeUntil(this.destroy$)\r\n      )\r\n      .subscribe((res) => {\r\n        this.onSubscribe.emit(definition);\r\n        this._subscriptionsSub.next(res);\r\n        this._toastrService.show(\r\n          'success',\r\n          'notifications.notifications',\r\n          'notifications.subscribedDone'\r\n        );\r\n      });\r\n  }\r\n\r\n  private _handleUnsubscribe(definition: NotificationDefinitionPresenter) {\r\n    const subscriptions = this._subscriptionsSub.getValue();\r\n    const _subscription = this._findSubscription(subscriptions, definition);\r\n    if (!_subscription) {\r\n      return;\r\n    }\r\n\r\n    this.changingItemId = definition.uid;\r\n    this.notificationsService\r\n      .unsubscribe(_subscription.uid)\r\n      .pipe(\r\n        switchMap(() =>\r\n          this.getSubscriptionsByChannel(this._channel.id).pipe(\r\n            finalize(() => {\r\n              this.changingItemId = null;\r\n              this._cdr.detectChanges();\r\n            })\r\n          )\r\n        ),\r\n        finalize(() => {\r\n          this.changingItemId = null;\r\n          this._cdr.detectChanges();\r\n        }),\r\n        takeUntil(this.destroy$)\r\n      )\r\n      .subscribe((res) => {\r\n        this._subscriptionsSub.next(res);\r\n        this.onUnsubscribe.emit(_subscription);\r\n        this._toastrService.show(\r\n          'success',\r\n          'notifications.notifications',\r\n          'notifications.unsubscribedDone'\r\n        );\r\n      });\r\n  }\r\n\r\n  private _findSubscription(\r\n    subscriptions: NotificationSubscriptionPresenter[],\r\n    definition: NotificationDefinitionPresenter\r\n  ) {\r\n    return subscriptions.find((sub) => {\r\n      return (\r\n        sub.channel == definition.channel &&\r\n        sub.applicationKey == definition.applicationKey &&\r\n        sub.notificationKey == definition.notificationKey\r\n      );\r\n    });\r\n  }\r\n\r\n  private _matchItem(def: NotificationDefinitionModel, channel: string) {\r\n    return (\r\n      def.properties['notif_def:applicationKey'] == this._appKey &&\r\n      def.properties['notif_def:channel'] == channel\r\n    );\r\n  }\r\n\r\n  private _groupBy(group: Record<string, any>, item: NotificationDefinitionPresenter) {\r\n    const key = item['sourceType'];\r\n    group[key] = group[key] ?? [];\r\n    group[key].push(item);\r\n    return group;\r\n  }\r\n}\r\n","<mat-spinner *ngIf=\"isLoadingResult\" class=\"mt-4 mx-auto\" [diameter]=\"48\"></mat-spinner>\r\n<div *ngIf=\"settings$ | async as settings\" class=\"notifications-settings\">\r\n  <ng-container *ngIf=\"!isLoadingResult && settings.definitions\">\r\n    <div\r\n      *ngFor=\"let group of settings.definitions | keyvalue\"\r\n      class=\"notifications-settings__section notifications-settings__section--{{\r\n        group.key\r\n      }}\"\r\n    >\r\n      <div class=\"notifications-settings__section__title\">\r\n        <mat-icon> tune </mat-icon>\r\n        <strong> {{ 'vocabulary.VOC_Notf_SourceTypes.' + group.key | translate }}</strong>\r\n      </div>\r\n      <div class=\"notifications-settings__section__content\">\r\n        <div *ngFor=\"let definition of group.value\" class=\"notifications-settings__group\">\r\n          <mat-slide-toggle\r\n            [name]=\"definition.title\"\r\n            [checked]=\"\r\n              definition.autoSubscription\r\n                ? true\r\n                : (definition | checkIfSubscribed : settings.subscriptions)\r\n            \"\r\n            class=\"notifications-settings__group__toggle\"\r\n            [class.is-loading]=\"changingItemId === definition.uid\"\r\n            [disabled]=\"definition.autoSubscription\"\r\n            (change)=\"settingChanged(definition, $event)\"\r\n          >\r\n          </mat-slide-toggle>\r\n          <span class=\"notifications-settings__group__title\"\r\n            >{{ currentLang == 'ar' ? definition?.arTitle : definition?.enTitle }}\r\n          </span>\r\n\r\n          <p class=\"notifications-settings__group__description\">\r\n            {{\r\n              currentLang == 'ar' ? definition?.arDescription : definition?.enDescription\r\n            }}\r\n          </p>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </ng-container>\r\n</div>\r\n"]}
|
|
163
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifications-settings.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-settings/notifications-settings.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/components/notifications-settings/notifications-settings.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Inject,\r\n  Injector,\r\n  Input,\r\n  Output,\r\n} from '@angular/core';\r\nimport { MatSlideToggleChange } from '@angular/material/slide-toggle';\r\nimport { BehaviorSubject, combineLatest, ReplaySubject } from 'rxjs';\r\nimport { finalize, map, switchMap, takeUntil, tap } from 'rxjs/operators';\r\nimport { TranslationService } from '../../../../core/services/translation/translation.service';\r\nimport { CustomToastrService } from '../../../custom-toastr/services/custom-toastr.service';\r\nimport {\r\n  NotificationDefinitionModel,\r\n  NotificationDefinitionPresenter,\r\n  NotificationSubscriptionPresenter,\r\n  VocabularyType,\r\n} from '../../models';\r\nimport { BaseNotification } from '../base-notifications.component';\r\nimport {\r\n  mapDefinitionToPresenter,\r\n  mapSubscriptionToPresenter,\r\n} from './notifications-settings.adapter';\r\n\r\n@Component({\r\n  selector: 'app-notifications-settings',\r\n  templateUrl: './notifications-settings.component.html',\r\n  styleUrls: ['./notifications-settings.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class NotificationsSettingsComponent extends BaseNotification {\r\n  @Output() onSubscribe = new EventEmitter<NotificationDefinitionPresenter>();\r\n  @Output() onUnsubscribe = new EventEmitter<Record<string, any>>();\r\n\r\n  private readonly _channelSub = new ReplaySubject<VocabularyType>();\r\n\r\n  changingItemId: string;\r\n  isLoadingResult = false;\r\n  private _channel: VocabularyType;\r\n  @Input() set channel(value: VocabularyType) {\r\n    this._channel = value;\r\n    if (value) {\r\n      this._channelSub.next(value);\r\n    }\r\n  }\r\n\r\n  get currentLang() {\r\n    return this._translateService.userLang;\r\n  }\r\n  private get _appKey() {\r\n    return this._environment?.appKey;\r\n  }\r\n\r\n  private readonly _subscriptionsSub = new BehaviorSubject<\r\n    NotificationSubscriptionPresenter[]\r\n  >([]);\r\n\r\n  readonly settings$ = this._prepareSettings();\r\n\r\n  constructor(\r\n    protected inject: Injector,\r\n    private _translateService: TranslationService,\r\n    private _cdr: ChangeDetectorRef,\r\n    private _toastrService: CustomToastrService,\r\n    @Inject('environment') private _environment: Record<string, any>\r\n  ) {\r\n    super(inject);\r\n  }\r\n\r\n  getSubscriptionsByChannel(channel: string) {\r\n    return this.notificationsService\r\n      .getSubscriptions({\r\n        notfsubscription_channel: channel,\r\n      })\r\n      .pipe(map((data) => data.map(mapSubscriptionToPresenter)));\r\n  }\r\n\r\n  getDefinitionsByChannel(channel: string) {\r\n    return this.notificationsService\r\n      .getDefinitions({\r\n        notfnotificationdef_channel: channel,\r\n      })\r\n      .pipe(\r\n        map((response) => {\r\n          return response.reduce((group, item) => {\r\n            if (!this._matchItem(item, channel)) {\r\n              return group;\r\n            }\r\n            const _data = mapDefinitionToPresenter(item);\r\n            return this._groupBy(group, _data);\r\n          }, {} as Record<string, NotificationDefinitionPresenter[]>);\r\n        })\r\n      );\r\n  }\r\n\r\n  settingChanged(\r\n    definition: NotificationDefinitionPresenter,\r\n    state: MatSlideToggleChange\r\n  ) {\r\n    if (state.checked) {\r\n      this._handleSubscribe(definition);\r\n    } else {\r\n      this._handleUnsubscribe(definition);\r\n    }\r\n  }\r\n\r\n  private _prepareSettings() {\r\n    return this._channelSub.pipe(\r\n      tap(() => {\r\n        this.isLoadingResult = true;\r\n      }),\r\n      switchMap((channel) => {\r\n        const definition = this.getDefinitionsByChannel(channel.id);\r\n        const subscriptions = this.getSubscriptionsByChannel(channel.id).pipe(\r\n          switchMap((data) => {\r\n            this._subscriptionsSub.next(data);\r\n            return this._subscriptionsSub.asObservable();\r\n          })\r\n        );\r\n        return combineLatest([definition, subscriptions]).pipe(\r\n          map(([definitions, subscriptions]) => ({ definitions, subscriptions })),\r\n          tap(() => {\r\n            this.isLoadingResult = false;\r\n            this._cdr.detectChanges();\r\n          })\r\n        );\r\n      })\r\n    );\r\n  }\r\n\r\n  private _handleSubscribe(definition: NotificationDefinitionPresenter) {\r\n    this.changingItemId = definition.uid;\r\n    this.notificationsService\r\n      .subscribe(definition.uid)\r\n      .pipe(\r\n        switchMap(() =>\r\n          this.getSubscriptionsByChannel(this._channel.id).pipe(\r\n            finalize(() => {\r\n              this.changingItemId = null;\r\n              this._cdr.detectChanges();\r\n            })\r\n          )\r\n        ),\r\n        takeUntil(this.destroy$)\r\n      )\r\n      .subscribe((res) => {\r\n        this.onSubscribe.emit(definition);\r\n        this._subscriptionsSub.next(res);\r\n        this._toastrService.show(\r\n          'success',\r\n          'notifications.notifications',\r\n          'notifications.subscribedDone'\r\n        );\r\n      });\r\n  }\r\n\r\n  private _handleUnsubscribe(definition: NotificationDefinitionPresenter) {\r\n    const subscriptions = this._subscriptionsSub.getValue();\r\n    const _subscription = this._findSubscription(subscriptions, definition);\r\n    if (!_subscription) {\r\n      return;\r\n    }\r\n\r\n    this.changingItemId = definition.uid;\r\n    this.notificationsService\r\n      .unsubscribe(_subscription.uid)\r\n      .pipe(\r\n        switchMap(() =>\r\n          this.getSubscriptionsByChannel(this._channel.id).pipe(\r\n            finalize(() => {\r\n              this.changingItemId = null;\r\n              this._cdr.detectChanges();\r\n            })\r\n          )\r\n        ),\r\n        finalize(() => {\r\n          this.changingItemId = null;\r\n          this._cdr.detectChanges();\r\n        }),\r\n        takeUntil(this.destroy$)\r\n      )\r\n      .subscribe((res) => {\r\n        this._subscriptionsSub.next(res);\r\n        this.onUnsubscribe.emit(_subscription);\r\n        this._toastrService.show(\r\n          'success',\r\n          'notifications.notifications',\r\n          'notifications.unsubscribedDone'\r\n        );\r\n      });\r\n  }\r\n\r\n  private _findSubscription(\r\n    subscriptions: NotificationSubscriptionPresenter[],\r\n    definition: NotificationDefinitionPresenter\r\n  ) {\r\n    return subscriptions.find((sub) => {\r\n      return (\r\n        sub.channel == definition.channel &&\r\n        sub.applicationKey == definition.applicationKey &&\r\n        sub.notificationKey == definition.notificationKey\r\n      );\r\n    });\r\n  }\r\n\r\n  private _matchItem(def: NotificationDefinitionModel, channel: string) {\r\n    return (\r\n      def.properties['notif_def:applicationKey'] == this._appKey &&\r\n      def.properties['notif_def:channel'] == channel\r\n    );\r\n  }\r\n\r\n  private _groupBy(group: Record<string, any>, item: NotificationDefinitionPresenter) {\r\n    const key = item['sourceType'];\r\n    group[key] = group[key] ?? [];\r\n    group[key].push(item);\r\n    return group;\r\n  }\r\n}\r\n","<mat-spinner *ngIf=\"isLoadingResult\" class=\"mt-4 mx-auto\" [diameter]=\"48\"></mat-spinner>\r\n<div *ngIf=\"settings$ | async as settings\" class=\"notifications-settings\">\r\n  <ng-container *ngIf=\"!isLoadingResult && settings.definitions\">\r\n    <div\r\n      *ngFor=\"let group of settings.definitions | keyvalue\"\r\n      class=\"notifications-settings__section notifications-settings__section--{{\r\n        group.key\r\n      }}\"\r\n    >\r\n      <div class=\"notifications-settings__section__title\">\r\n        <mat-icon> tune </mat-icon>\r\n        <strong> {{ 'vocabulary.VOC_Notf_SourceTypes.' + group.key | translate }}</strong>\r\n      </div>\r\n      <div class=\"notifications-settings__section__content\">\r\n        <div *ngFor=\"let definition of group.value\" class=\"notifications-settings__group\">\r\n          <mat-slide-toggle\r\n            [name]=\"definition.title\"\r\n            [checked]=\"\r\n              definition.autoSubscription\r\n                ? true\r\n                : (definition | checkIfSubscribed : settings.subscriptions)\r\n            \"\r\n            class=\"notifications-settings__group__toggle\"\r\n            [class.is-loading]=\"changingItemId === definition.uid\"\r\n            [disabled]=\"definition.autoSubscription\"\r\n            (change)=\"settingChanged(definition, $event)\"\r\n          >\r\n          </mat-slide-toggle>\r\n          <span class=\"notifications-settings__group__title\"\r\n            >{{ currentLang == 'ar' ? definition?.arTitle : definition?.enTitle }}\r\n          </span>\r\n\r\n          <p class=\"notifications-settings__group__description\">\r\n            {{\r\n              currentLang == 'ar' ? definition?.arDescription : definition?.enDescription\r\n            }}\r\n          </p>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </ng-container>\r\n</div>\r\n"]}
|
|
@@ -3,7 +3,7 @@ import { filter, switchMap, take, tap } from 'rxjs/operators';
|
|
|
3
3
|
import { ConfirmationDialogComponent } from '../../../confirmation-dialog/confirmation-dialog/confirmation-dialog.component';
|
|
4
4
|
import { BaseNotification } from '../../components/base-notifications.component';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "../../../../
|
|
6
|
+
import * as i1 from "../../../../core/services/translation/translation.service";
|
|
7
7
|
import * as i2 from "ngx-toastr";
|
|
8
8
|
import * as i3 from "@angular/material/dialog";
|
|
9
9
|
import * as i4 from "@angular/material/tabs";
|
|
@@ -64,4 +64,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
64
64
|
}], onUnsubscribe: [{
|
|
65
65
|
type: Output
|
|
66
66
|
}] } });
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifications-settings-container.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/containers/notifications-settings-container/notifications-settings-container.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/notifications/containers/notifications-settings-container/notifications-settings-container.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EAEZ,MAAM,EACP,MAAM,eAAe,CAAC;AAIvB,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAE9D,OAAO,EAAE,2BAA2B,EAAE,MAAM,gFAAgF,CAAC;AAC7H,OAAO,EAAE,gBAAgB,EAAE,MAAM,+CAA+C,CAAC;;;;;;;;;;;AASjF,MAAM,OAAO,uCAAwC,SAAQ,gBAAgB;IAI3E,YACY,MAAgB,EAClB,iBAAqC,EACrC,cAA6B,EAC7B,UAAqB;QAE7B,KAAK,CAAC,MAAM,CAAC,CAAC;QALJ,WAAM,GAAN,MAAM,CAAU;QAClB,sBAAiB,GAAjB,iBAAiB,CAAoB;QACrC,mBAAc,GAAd,cAAc,CAAe;QAC7B,eAAU,GAAV,UAAU,CAAW;QAPrB,gBAAW,GAAG,IAAI,YAAY,EAAmC,CAAC;QAClE,kBAAa,GAAG,IAAI,YAAY,EAAuB,CAAC;QAWlE,cAAS,GAAG,IAAI,CAAC,oBAAoB,CAAC,WAAW,EAAE,CAAC,IAAI,CACtD,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;YACV,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;gBAC/C,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;aAC5B;QACH,CAAC,CAAC,CACH,CAAC;IARF,CAAC;IAWD,aAAa,CAAC,OAAuB;QACnC,IAAI,CAAC,eAAe,GAAG,OAAO,CAAC;IACjC,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,UAAU;aACZ,IAAI,CAAC,2BAA2B,EAAE;YACjC,IAAI,EAAE;gBACJ,KAAK,EAAE,2CAA2C;gBAClD,OAAO,EAAE,kDAAkD;gBAC3D,YAAY,EAAE,gBAAgB;gBAC9B,aAAa,EAAE,oCAAoC;aACpD;YACD,YAAY,EAAE,KAAK;SACpB,CAAC;aACD,WAAW,EAAE;aACb,IAAI,CACH,MAAM,CAAC,OAAO,CAAC,EACf,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,kBAAkB,EAAE,CAAC,EAC/D,IAAI,CAAC,CAAC,CAAC,CACR;aACA,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YACjB,IAAI,CAAC,aAAa,CAAC,kBAAK,IAAI,CAAC,eAAe,CAAoB,CAAC,CAAC;YAClE,IAAI,CAAC,cAAc,CAAC,OAAO,CACzB,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,wCAAwC,CAAC,EACxE,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,6BAA6B,CAAC,CAC9D,CAAC;QACJ,CAAC,CAAC,CAAC;IACP,CAAC;;qIAlDU,uCAAuC;yHAAvC,uCAAuC,4KCtBpD,u/CA6CA;4FDvBa,uCAAuC;kBANnD,SAAS;mBAAC;oBACT,QAAQ,EAAE,sCAAsC;oBAChD,WAAW,EAAE,mDAAmD;oBAChE,SAAS,EAAE,CAAC,mDAAmD,CAAC;oBAChE,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;oLAEW,WAAW;sBAApB,MAAM;gBACG,aAAa;sBAAtB,MAAM","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  EventEmitter,\r\n  Injector,\r\n  Output\r\n} from '@angular/core';\r\n\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { ToastrService } from 'ngx-toastr';\r\nimport { filter, switchMap, take, tap } from 'rxjs/operators';\r\nimport { TranslationService } from '../../../../core/services/translation/translation.service';\r\nimport { ConfirmationDialogComponent } from '../../../confirmation-dialog/confirmation-dialog/confirmation-dialog.component';\r\nimport { BaseNotification } from '../../components/base-notifications.component';\r\nimport { NotificationDefinitionPresenter, VocabularyType } from '../../models';\r\n\r\n@Component({\r\n  selector: 'app-notifications-settings-container',\r\n  templateUrl: './notifications-settings-container.component.html',\r\n  styleUrls: ['./notifications-settings-container.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class NotificationsSettingsContainerComponent extends BaseNotification {\r\n  @Output() onSubscribe = new EventEmitter<NotificationDefinitionPresenter>();\r\n  @Output() onUnsubscribe = new EventEmitter<Record<string, any>>();\r\n\r\n  constructor(\r\n    protected inject: Injector,\r\n    private _translateService: TranslationService,\r\n    private _toastrService: ToastrService,\r\n    private _matDialog: MatDialog\r\n  ) {\r\n    super(inject);\r\n  }\r\n\r\n  channels$ = this.notificationsService.getChannels().pipe(\r\n    tap((res) => {\r\n      if (Array.isArray(res) && !this.selectedChannel) {\r\n        this.selectChannel(res[0]);\r\n      }\r\n    })\r\n  );\r\n\r\n  selectedChannel: VocabularyType | null;\r\n  selectChannel(channel: VocabularyType) {\r\n    this.selectedChannel = channel;\r\n  }\r\n\r\n  resetSubscriptions() {\r\n    this._matDialog\r\n      .open(ConfirmationDialogComponent, {\r\n        data: {\r\n          title: 'notifications.resetToDefault.resetConfirm',\r\n          message: 'notifications.resetToDefault.resetConfirmMessage',\r\n          cancelButton: 'BUTTONS.CANCEL',\r\n          confirmButton: 'notifications.resetToDefault.reset',\r\n        },\r\n        restoreFocus: false,\r\n      })\r\n      .afterClosed()\r\n      .pipe(\r\n        filter(Boolean),\r\n        switchMap(() => this.notificationsService.resetSubscriptions()),\r\n        take(1)\r\n      )\r\n      .subscribe((res) => {\r\n        this.selectChannel({ ...this.selectedChannel } as VocabularyType);\r\n        this._toastrService.success(\r\n          this._translateService.instant('notifications.resetToDefault.resetDone'),\r\n          this._translateService.instant('notifications.notifications')\r\n        );\r\n      });\r\n  }\r\n}\r\n","<div class=\"notifications-settings\">\r\n  <nav\r\n    mat-tab-nav-bar\r\n    *ngIf=\"channels$ | async as channels\"\r\n    class=\"notifications-settings__links\"\r\n  >\r\n    <a\r\n      *ngFor=\"let channel of channels\"\r\n      mat-tab-link\r\n      (click)=\"selectChannel(channel)\"\r\n      [active]=\"selectedChannel?.id == channel.id\"\r\n      class=\"notifications-settings__link\"\r\n    >\r\n      {{\r\n        'vocabulary.VOC_Notf_NotificationChannels.' + channel.properties.label | translate\r\n      }}\r\n    </a>\r\n  </nav>\r\n\r\n  <app-notifications-settings\r\n    *ngIf=\"selectedChannel\"\r\n    [channel]=\"selectedChannel\"\r\n    (onSubscribe)=\"onSubscribe.emit($event)\"\r\n    (onUnsubscribe)=\"onUnsubscribe.emit($event)\"\r\n  ></app-notifications-settings>\r\n\r\n  <div class=\"notifications-reset\">\r\n    <h6 class=\"notifications-reset__title\">\r\n      <mat-icon> restore </mat-icon>\r\n      <strong>{{ 'notifications.resetToDefault.title' | translate }}</strong>\r\n    </h6>\r\n    <span class=\"notifications-reset__container\">\r\n      <p class=\"notifications-reset__description\">\r\n        {{ 'notifications.resetToDefault.description' | translate }}\r\n      </p>\r\n      <button\r\n        mat-stroked-button\r\n        class=\"notifications-reset__button\"\r\n        (click)=\"resetSubscriptions()\"\r\n      >\r\n        <span class=\"px-4\"> {{ 'notifications.resetToDefault.reset' | translate }}</span>\r\n      </button>\r\n    </span>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9ub3RpZmljYXRpb25zL21vZGVscy9jb21tb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNjaGVtYU1vZGVsIH0gZnJvbSAnLi4vLi4vLi4vY29yZS9tb2RlbHMnO1xyXG5pbXBvcnQgeyBGSUxURVJfREFURVNfVFlQRSB9IGZyb20gJy4uL2NvbnN0YW50cyc7XHJcblxyXG5leHBvcnQgdHlwZSBUcmFuc2xhdGVkS2V5ID0gc3RyaW5nO1xyXG5cclxuZXhwb3J0IHR5cGUgRmlsdGVyRGF0ZVR5cGUgPSAodHlwZW9mIEZJTFRFUl9EQVRFU19UWVBFKVtrZXlvZiB0eXBlb2YgRklMVEVSX0RBVEVTX1RZUEVdO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBCYXNlTm90aWZpY2F0aW9uRW50cnkge1xyXG4gICdlbnRpdHktdHlwZSc6IHN0cmluZztcclxuICByZXBvc2l0b3J5OiBzdHJpbmc7XHJcbiAgdWlkOiBzdHJpbmc7XHJcbiAgcGF0aDogc3RyaW5nO1xyXG4gIHR5cGU6IHN0cmluZztcclxuICBzdGF0ZTogc3RyaW5nO1xyXG4gIHBhcmVudFJlZjogc3RyaW5nO1xyXG4gIGlzQ2hlY2tlZE91dDogYm9vbGVhbjtcclxuICBpc1JlY29yZDogYm9vbGVhbjtcclxuICByZXRhaW5VbnRpbDogYW55O1xyXG4gIGhhc0xlZ2FsSG9sZDogYm9vbGVhbjtcclxuICBpc1VuZGVyUmV0ZW50aW9uT3JMZWdhbEhvbGQ6IGJvb2xlYW47XHJcbiAgaXNWZXJzaW9uOiBib29sZWFuO1xyXG4gIGlzUHJveHk6IGJvb2xlYW47XHJcbiAgY2hhbmdlVG9rZW46IHN0cmluZztcclxuICBpc1RyYXNoZWQ6IGJvb2xlYW47XHJcbiAgdGl0bGU6IHN0cmluZztcclxuICBsYXN0TW9kaWZpZWQ6IHN0cmluZztcclxuICBmYWNldHM6IGFueVtdO1xyXG4gIHNjaGVtYXM6IFNjaGVtYU1vZGVsW107XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQmFzZU5vdGlmaWNhdGlvblByb3BlcnRpZXMge1xyXG4gICdub3RmX250OmNhdGVnb3J5Jzogc3RyaW5nO1xyXG4gICdub3RmX250OmlzQ2xpY2thYmxlJzogYm9vbGVhbjtcclxuICAnbm90Zl9udDpzb3VyY2VUeXBlZSc6IHN0cmluZztcclxuICAnbm90Zl9udDprZXknOiBzdHJpbmc7XHJcbiAgJ2RjOmRlc2NyaXB0aW9uJzogYW55O1xyXG4gICdkYzpsYW5ndWFnZSc6IGFueTtcclxuICAnZGM6Y292ZXJhZ2UnOiBhbnk7XHJcbiAgJ2RjOnZhbGlkJzogYW55O1xyXG4gICdkYzpjcmVhdG9yJzogc3RyaW5nO1xyXG4gICdkYzptb2RpZmllZCc6IHN0cmluZztcclxuICAnZGM6bGFzdENvbnRyaWJ1dG9yJzogc3RyaW5nO1xyXG4gICdkYzpyaWdodHMnOiBhbnk7XHJcbiAgJ2RjOmV4cGlyZWQnOiBhbnk7XHJcbiAgJ2RjOmZvcm1hdCc6IGFueTtcclxuICAnZGM6Y3JlYXRlZCc6IHN0cmluZztcclxuICAnZGM6dGl0bGUnOiBzdHJpbmc7XHJcbiAgJ2RjOmlzc3VlZCc6IGFueTtcclxuICAnZGM6bmF0dXJlJzogYW55O1xyXG4gICdkYzpzdWJqZWN0cyc6IGFueVtdO1xyXG4gICdkYzpjb250cmlidXRvcnMnOiBzdHJpbmdbXTtcclxuICAnZGM6c291cmNlJzogYW55O1xyXG4gICdkYzpwdWJsaXNoZXInOiBhbnk7XHJcbiAgJ3VpZDp1aWQnOiBhbnk7XHJcbiAgJ3VpZDptYWpvcl92ZXJzaW9uJzogbnVtYmVyO1xyXG4gICd1aWQ6bWlub3JfdmVyc2lvbic6IG51bWJlcjtcclxuICAnY29tbW9uOmljb24tZXhwYW5kZWQnOiBhbnk7XHJcbiAgJ2NvbW1vbjppY29uJzogYW55O1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIE5vdGlmaWNhdGlvbkJhc2VPcHRpb25zIHtcclxuICBzY2hlbWFzOiBhbnlbXTtcclxuICBlbnJpY2hlcnM6IFJlY29yZDxzdHJpbmcsIGFueT47XHJcbiAgZmV0Y2hQcm9wZXJ0aWVzOiBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xyXG4gIHRyYW5zbGF0ZVByb3BlcnRpZXM6IFJlY29yZDxzdHJpbmcsIGFueT47XHJcbiAgaGVhZGVyczogSGVhZGVycztcclxuICB0aW1lb3V0OiBudW1iZXI7XHJcbiAgaHR0cFRpbWVvdXQ6IG51bWJlcjtcclxufVxyXG4iXX0=
|