barsa-tiles 1.0.256 → 1.0.258
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/esm2020/lib/barsa-tiles.module.mjs +4 -4
- package/esm2020/lib/notification-group/notification-group.component.mjs +34 -18
- package/esm2020/lib/notification-group-header/notification-group-header.component.mjs +1 -1
- package/esm2020/lib/shellbar/shellbar.component.mjs +34 -25
- package/fesm2015/barsa-tiles.mjs +91 -64
- package/fesm2015/barsa-tiles.mjs.map +1 -1
- package/fesm2020/barsa-tiles.mjs +90 -64
- package/fesm2020/barsa-tiles.mjs.map +1 -1
- package/lib/notification-group/notification-group.component.d.ts +15 -8
- package/lib/notification-group-header/notification-group-header.component.d.ts +1 -2
- package/lib/shellbar/shellbar.component.d.ts +14 -6
- package/package.json +1 -1
- package/esm2020/lib/models/notification-item.mjs +0 -2
- package/lib/models/notification-item.d.ts +0 -5
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { NgModule, NO_ERRORS_SCHEMA } from '@angular/core';
|
|
2
2
|
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
3
|
-
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { CommonModule, LowerCasePipe } from '@angular/common';
|
|
4
4
|
import { DragDropModule } from '@angular/cdk/drag-drop';
|
|
5
5
|
import { CdkTableModule } from '@angular/cdk/table';
|
|
6
6
|
import { FundamentalNgxCoreModule, GridListModule } from '@fundamental-ngx/core';
|
|
@@ -163,7 +163,7 @@ BarsaTilesModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", versio
|
|
|
163
163
|
AppFinderAppListComponent,
|
|
164
164
|
TilesViewerGroupComponent,
|
|
165
165
|
FormTileComponent] });
|
|
166
|
-
BarsaTilesModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaTilesModule, providers: [TilesService, AppFinderService], imports: [CommonModule,
|
|
166
|
+
BarsaTilesModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaTilesModule, providers: [TilesService, AppFinderService, LowerCasePipe], imports: [CommonModule,
|
|
167
167
|
FormsModule,
|
|
168
168
|
DragDropModule,
|
|
169
169
|
CdkTableModule,
|
|
@@ -191,7 +191,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
|
|
|
191
191
|
BarsaSapUiModule,
|
|
192
192
|
BarsaEchartsModule
|
|
193
193
|
],
|
|
194
|
-
providers: [TilesService, AppFinderService],
|
|
194
|
+
providers: [TilesService, AppFinderService, LowerCasePipe],
|
|
195
195
|
declarations: [
|
|
196
196
|
...components,
|
|
197
197
|
...pipes,
|
|
@@ -202,4 +202,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
|
|
|
202
202
|
exports: [...components]
|
|
203
203
|
}]
|
|
204
204
|
}], ctorParameters: function () { return [{ type: i1.DynamicComponentService }, { type: i0.ComponentFactoryResolver }]; } });
|
|
205
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-tiles.module.js","sourceRoot":"","sources":["../../../../projects/barsa-tiles/src/lib/barsa-tiles.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentFactoryResolver, NgModule, NO_ERRORS_SCHEMA } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { CommonModule } from '@angular/common';\r\nimport { DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { CdkTableModule } from '@angular/cdk/table';\r\nimport { FundamentalNgxCoreModule, GridListModule } from '@fundamental-ngx/core';\r\nimport { FundamentalNgxPlatformModule } from '@fundamental-ngx/platform';\r\n\r\nimport { BarsaNovinRayCoreModule, BaseModule, DynamicComponentService } from 'barsa-novin-ray-core';\r\nimport { BarsaSapUiModule } from 'barsa-sap-ui';\r\nimport { BarsaEchartsModule } from 'barsa-echarts';\r\n\r\nimport { ShellbarComponent } from './shellbar/shellbar.component';\r\nimport { TilesViewerComponent } from './tiles-viewer/tiles-viewer.component';\r\nimport { ProfileTileComponent } from './profile-tile/profile-tile.component';\r\nimport { SimpleTileComponent } from './simple-tile/simple-tile.component';\r\nimport { FeedTileComponent } from './feed-tile/feed-tile.component';\r\nimport { FooterTileComponent } from './footer-tile/footer-tile.component';\r\nimport { TileComponent } from './tile/tile.component';\r\nimport { LogoTileComponent } from './logo-tile/logo-tile.component';\r\nimport { NumericTileComponent } from './numeric-tile/numeric-tile.component';\r\nimport { TileHomeFilterPipe } from './pipes/tile-home-filter.pipe';\r\nimport { FooterEditTileComponent } from './footer-edit-tile/footer-edit-tile.component';\r\nimport { FormAppFinderComponent } from './form-app-finder/form-app-finder.component';\r\nimport { PinTileComponent } from './pin-tile/pin-tile.component';\r\nimport { GroupTilesPipe } from './pipes/group-tiles.pipe';\r\nimport { HomeGroupPipe } from './pipes/home-group.pipe';\r\nimport { TilesService } from './tiles.service';\r\nimport { EmptyListDirective } from './directives/emptylist.directive';\r\nimport { ChangeAppTileComponent } from './change-app-tile/change-app-tile.component';\r\nimport { CreateAppGroupComponent } from './create-app-group/create-app-group.component';\r\n\r\nimport { MicroTileChartBarComponent } from './micro-tile-chart-bar/micro-tile-chart-bar.component';\r\nimport { MicroTileChartAreaComponent } from './micro-tile-chart-area/micro-tile-chart-area.component';\r\nimport { MicroTileChartCircularComponent } from './micro-tile-chart-circular/micro-tile-chart-circular.component';\r\nimport { MicroTileChartLineComponent } from './micro-tile-chart-line/micro-tile-chart-line.component';\r\nimport { MicroTileChartStackbarComponent } from './micro-tile-chart-stackbar/micro-tile-chart-stackbar.component';\r\nimport { MicroTileChartComparisonComponent } from './micro-tile-chart-comparison/micro-tile-chart-comparison.component';\r\nimport { NewsTileComponent } from './news-tile/news-tile.component';\r\nimport { ActionsLinkComponent } from './actions-link/actions-link.component';\r\nimport { ActionItemComponent } from './action-item/action-item.component';\r\nimport { MicroTileChartBulletComponent } from './micro-tile-chart-bullet/micro-tile-chart-bullet.component';\r\nimport { ActionLinksPipe } from './action-links.pipe';\r\nimport { AppFinderService } from './app-finder.service';\r\nimport { TilesViewerContainerComponent } from './tiles-viewer-container/tiles-viewer-container.component';\r\nimport { AppFinderComponent } from './app-finder/app-finder.component';\r\nimport { AppFinderGroupComponent } from './app-finder-group/app-finder-group.component';\r\nimport { AppFinderAppListComponent } from './app-finder-app-list/app-finder-app-list.component';\r\nimport { TileRendererDirective } from './tile-renderer.directive';\r\nimport { TilesViewerGroupComponent } from './tiles-viewer-group/tiles-viewer-group.component';\r\nimport { FormTileComponent } from './form-tile/form-tile.component';\r\nimport { NotificationGroupComponent } from './notification-group/notification-group.component';\r\nimport { NotificationGroupHeaderComponent } from './notification-group-header/notification-group-header.component';\r\n\r\nconst components = [\r\n    ShellbarComponent,\r\n    SimpleTileComponent,\r\n    TilesViewerComponent,\r\n    ProfileTileComponent,\r\n    FeedTileComponent,\r\n    FooterTileComponent,\r\n    TileComponent,\r\n    LogoTileComponent,\r\n    NumericTileComponent,\r\n    FooterEditTileComponent,\r\n    FormAppFinderComponent,\r\n    PinTileComponent,\r\n    ChangeAppTileComponent,\r\n    CreateAppGroupComponent,\r\n    MicroTileChartAreaComponent,\r\n    MicroTileChartCircularComponent,\r\n    MicroTileChartLineComponent,\r\n    MicroTileChartStackbarComponent,\r\n    MicroTileChartComparisonComponent,\r\n    MicroTileChartBarComponent,\r\n    MicroTileChartBulletComponent,\r\n    TilesViewerContainerComponent,\r\n    NewsTileComponent,\r\n    ActionsLinkComponent,\r\n    ActionItemComponent,\r\n    AppFinderComponent,\r\n    AppFinderGroupComponent,\r\n    AppFinderAppListComponent,\r\n    TilesViewerGroupComponent,\r\n    FormTileComponent\r\n];\r\nconst pipes = [GroupTilesPipe, TileHomeFilterPipe, HomeGroupPipe, ActionLinksPipe];\r\nconst directives = [EmptyListDirective, TileRendererDirective];\r\n\r\n@NgModule({\r\n    schemas: [NO_ERRORS_SCHEMA],\r\n    imports: [\r\n        CommonModule,\r\n        FormsModule,\r\n        DragDropModule,\r\n        CdkTableModule,\r\n        FundamentalNgxCoreModule,\r\n        GridListModule,\r\n        FundamentalNgxPlatformModule,\r\n        ReactiveFormsModule,\r\n        BarsaNovinRayCoreModule,\r\n        BarsaSapUiModule,\r\n        BarsaEchartsModule\r\n    ],\r\n    providers: [TilesService, AppFinderService],\r\n    declarations: [\r\n        ...components,\r\n        ...pipes,\r\n        ...directives,\r\n        NotificationGroupComponent,\r\n        NotificationGroupHeaderComponent\r\n    ],\r\n    exports: [...components]\r\n})\r\nexport class BarsaTilesModule extends BaseModule {\r\n    protected dynamicComponents = [...components];\r\n\r\n    constructor(protected dcm: DynamicComponentService, protected componentFactoryResolver: ComponentFactoryResolver) {\r\n        super(dcm, componentFactoryResolver, 'BarsaTilesModule');\r\n    }\r\n}\r\n"]}
|
|
205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-tiles.module.js","sourceRoot":"","sources":["../../../../projects/barsa-tiles/src/lib/barsa-tiles.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentFactoryResolver, NgModule, NO_ERRORS_SCHEMA } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { CommonModule, LowerCasePipe } from '@angular/common';\r\nimport { DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { CdkTableModule } from '@angular/cdk/table';\r\nimport { FundamentalNgxCoreModule, GridListModule } from '@fundamental-ngx/core';\r\nimport { FundamentalNgxPlatformModule } from '@fundamental-ngx/platform';\r\n\r\nimport { BarsaNovinRayCoreModule, BaseModule, DynamicComponentService } from 'barsa-novin-ray-core';\r\nimport { BarsaSapUiModule } from 'barsa-sap-ui';\r\nimport { BarsaEchartsModule } from 'barsa-echarts';\r\n\r\nimport { ShellbarComponent } from './shellbar/shellbar.component';\r\nimport { TilesViewerComponent } from './tiles-viewer/tiles-viewer.component';\r\nimport { ProfileTileComponent } from './profile-tile/profile-tile.component';\r\nimport { SimpleTileComponent } from './simple-tile/simple-tile.component';\r\nimport { FeedTileComponent } from './feed-tile/feed-tile.component';\r\nimport { FooterTileComponent } from './footer-tile/footer-tile.component';\r\nimport { TileComponent } from './tile/tile.component';\r\nimport { LogoTileComponent } from './logo-tile/logo-tile.component';\r\nimport { NumericTileComponent } from './numeric-tile/numeric-tile.component';\r\nimport { TileHomeFilterPipe } from './pipes/tile-home-filter.pipe';\r\nimport { FooterEditTileComponent } from './footer-edit-tile/footer-edit-tile.component';\r\nimport { FormAppFinderComponent } from './form-app-finder/form-app-finder.component';\r\nimport { PinTileComponent } from './pin-tile/pin-tile.component';\r\nimport { GroupTilesPipe } from './pipes/group-tiles.pipe';\r\nimport { HomeGroupPipe } from './pipes/home-group.pipe';\r\nimport { TilesService } from './tiles.service';\r\nimport { EmptyListDirective } from './directives/emptylist.directive';\r\nimport { ChangeAppTileComponent } from './change-app-tile/change-app-tile.component';\r\nimport { CreateAppGroupComponent } from './create-app-group/create-app-group.component';\r\n\r\nimport { MicroTileChartBarComponent } from './micro-tile-chart-bar/micro-tile-chart-bar.component';\r\nimport { MicroTileChartAreaComponent } from './micro-tile-chart-area/micro-tile-chart-area.component';\r\nimport { MicroTileChartCircularComponent } from './micro-tile-chart-circular/micro-tile-chart-circular.component';\r\nimport { MicroTileChartLineComponent } from './micro-tile-chart-line/micro-tile-chart-line.component';\r\nimport { MicroTileChartStackbarComponent } from './micro-tile-chart-stackbar/micro-tile-chart-stackbar.component';\r\nimport { MicroTileChartComparisonComponent } from './micro-tile-chart-comparison/micro-tile-chart-comparison.component';\r\nimport { NewsTileComponent } from './news-tile/news-tile.component';\r\nimport { ActionsLinkComponent } from './actions-link/actions-link.component';\r\nimport { ActionItemComponent } from './action-item/action-item.component';\r\nimport { MicroTileChartBulletComponent } from './micro-tile-chart-bullet/micro-tile-chart-bullet.component';\r\nimport { ActionLinksPipe } from './action-links.pipe';\r\nimport { AppFinderService } from './app-finder.service';\r\nimport { TilesViewerContainerComponent } from './tiles-viewer-container/tiles-viewer-container.component';\r\nimport { AppFinderComponent } from './app-finder/app-finder.component';\r\nimport { AppFinderGroupComponent } from './app-finder-group/app-finder-group.component';\r\nimport { AppFinderAppListComponent } from './app-finder-app-list/app-finder-app-list.component';\r\nimport { TileRendererDirective } from './tile-renderer.directive';\r\nimport { TilesViewerGroupComponent } from './tiles-viewer-group/tiles-viewer-group.component';\r\nimport { FormTileComponent } from './form-tile/form-tile.component';\r\nimport { NotificationGroupComponent } from './notification-group/notification-group.component';\r\nimport { NotificationGroupHeaderComponent } from './notification-group-header/notification-group-header.component';\r\n\r\nconst components = [\r\n    ShellbarComponent,\r\n    SimpleTileComponent,\r\n    TilesViewerComponent,\r\n    ProfileTileComponent,\r\n    FeedTileComponent,\r\n    FooterTileComponent,\r\n    TileComponent,\r\n    LogoTileComponent,\r\n    NumericTileComponent,\r\n    FooterEditTileComponent,\r\n    FormAppFinderComponent,\r\n    PinTileComponent,\r\n    ChangeAppTileComponent,\r\n    CreateAppGroupComponent,\r\n    MicroTileChartAreaComponent,\r\n    MicroTileChartCircularComponent,\r\n    MicroTileChartLineComponent,\r\n    MicroTileChartStackbarComponent,\r\n    MicroTileChartComparisonComponent,\r\n    MicroTileChartBarComponent,\r\n    MicroTileChartBulletComponent,\r\n    TilesViewerContainerComponent,\r\n    NewsTileComponent,\r\n    ActionsLinkComponent,\r\n    ActionItemComponent,\r\n    AppFinderComponent,\r\n    AppFinderGroupComponent,\r\n    AppFinderAppListComponent,\r\n    TilesViewerGroupComponent,\r\n    FormTileComponent\r\n];\r\nconst pipes = [GroupTilesPipe, TileHomeFilterPipe, HomeGroupPipe, ActionLinksPipe];\r\nconst directives = [EmptyListDirective, TileRendererDirective];\r\n\r\n@NgModule({\r\n    schemas: [NO_ERRORS_SCHEMA],\r\n    imports: [\r\n        CommonModule,\r\n        FormsModule,\r\n        DragDropModule,\r\n        CdkTableModule,\r\n        FundamentalNgxCoreModule,\r\n        GridListModule,\r\n        FundamentalNgxPlatformModule,\r\n        ReactiveFormsModule,\r\n        BarsaNovinRayCoreModule,\r\n        BarsaSapUiModule,\r\n        BarsaEchartsModule\r\n    ],\r\n    providers: [TilesService, AppFinderService, LowerCasePipe],\r\n    declarations: [\r\n        ...components,\r\n        ...pipes,\r\n        ...directives,\r\n        NotificationGroupComponent,\r\n        NotificationGroupHeaderComponent\r\n    ],\r\n    exports: [...components]\r\n})\r\nexport class BarsaTilesModule extends BaseModule {\r\n    protected dynamicComponents = [...components];\r\n\r\n    constructor(protected dcm: DynamicComponentService, protected componentFactoryResolver: ComponentFactoryResolver) {\r\n        super(dcm, componentFactoryResolver, 'BarsaTilesModule');\r\n    }\r\n}\r\n"]}
|
|
@@ -1,19 +1,18 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
-
import { BaseComponent, IntersectionStatus } from 'barsa-novin-ray-core';
|
|
2
|
+
import { BaseComponent, IntersectionStatus, BarsaApi } from 'barsa-novin-ray-core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "barsa-novin-ray-core";
|
|
5
5
|
import * as i2 from "@angular/common";
|
|
6
|
-
import * as i3 from "@fundamental-ngx/core/
|
|
7
|
-
import * as i4 from "@fundamental-ngx/core/
|
|
8
|
-
import * as i5 from "@fundamental-ngx/core/
|
|
9
|
-
import * as i6 from "
|
|
10
|
-
import * as i7 from "
|
|
11
|
-
import * as i8 from "barsa-sap-ui";
|
|
12
|
-
import * as i9 from "../notification-group-header/notification-group-header.component";
|
|
6
|
+
import * as i3 from "@fundamental-ngx/core/button";
|
|
7
|
+
import * as i4 from "@fundamental-ngx/core/notification";
|
|
8
|
+
import * as i5 from "@fundamental-ngx/core/tabs";
|
|
9
|
+
import * as i6 from "barsa-sap-ui";
|
|
10
|
+
import * as i7 from "../notification-group-header/notification-group-header.component";
|
|
13
11
|
export class NotificationGroupComponent extends BaseComponent {
|
|
14
|
-
constructor(_groupByPipe) {
|
|
12
|
+
constructor(_groupByPipe, _cdr) {
|
|
15
13
|
super();
|
|
16
14
|
this._groupByPipe = _groupByPipe;
|
|
15
|
+
this._cdr = _cdr;
|
|
17
16
|
this.viewed = new EventEmitter();
|
|
18
17
|
this.remove = new EventEmitter();
|
|
19
18
|
this.actionClick = new EventEmitter();
|
|
@@ -36,6 +35,7 @@ export class NotificationGroupComponent extends BaseComponent {
|
|
|
36
35
|
const { notifications } = changes;
|
|
37
36
|
if (notifications && !notifications.firstChange) {
|
|
38
37
|
this.applyGroupByItems(notifications.currentValue);
|
|
38
|
+
this._cdr.detectChanges();
|
|
39
39
|
}
|
|
40
40
|
}
|
|
41
41
|
applyGroupByItems(notifications) {
|
|
@@ -45,9 +45,17 @@ export class NotificationGroupComponent extends BaseComponent {
|
|
|
45
45
|
this.tabList[0].groupByItems = this._groupByPipe.transform(notifications, 'CreationDate');
|
|
46
46
|
this.tabList[1].groupByItems = this._groupByPipe.transform(notifications, 'Subject');
|
|
47
47
|
this.tabList[2].groupByItems = this._groupByPipe.transform(notifications, 'Priority');
|
|
48
|
+
for (let i = 0; i < this.tabList.length; i++) {
|
|
49
|
+
if (this.tabList[i].groupByItems.length) {
|
|
50
|
+
const firstKey = this.tabList[i].groupByItems[0].key;
|
|
51
|
+
if (firstKey && typeof this.expanded[firstKey] === 'undefined') {
|
|
52
|
+
this.expanded[firstKey] = true;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
48
56
|
}
|
|
49
|
-
_trackByTitle(_index,
|
|
50
|
-
return
|
|
57
|
+
_trackByTitle(_index, _) {
|
|
58
|
+
return _index;
|
|
51
59
|
}
|
|
52
60
|
_trackByKey(_index, item) {
|
|
53
61
|
return item.key;
|
|
@@ -56,24 +64,32 @@ export class NotificationGroupComponent extends BaseComponent {
|
|
|
56
64
|
return mo.Id;
|
|
57
65
|
}
|
|
58
66
|
onVisibilityChange(e, mo, isLast) {
|
|
59
|
-
console.log(e, this.viewedNotifications);
|
|
60
67
|
if (e === IntersectionStatus.Visible) {
|
|
61
68
|
if (mo.Unread) {
|
|
62
69
|
this.viewedNotifications = [...this.viewedNotifications.filter((c) => c.Unread), mo];
|
|
63
|
-
this.viewed.emit(
|
|
70
|
+
this.viewed.emit(mo);
|
|
64
71
|
}
|
|
65
72
|
if (isLast) {
|
|
66
73
|
this.loadMore.emit();
|
|
67
74
|
}
|
|
68
75
|
}
|
|
69
76
|
}
|
|
77
|
+
onWorkflowExecuteChoiceStatusChanged(e, mo) {
|
|
78
|
+
if (e.result && !e.error) {
|
|
79
|
+
this.remove.emit({ items: [mo], silent: true });
|
|
80
|
+
BarsaApi.Bw.Toast.Success(`${e.choice?.Title} ${BarsaApi.BBB.Action}`);
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
83
|
+
mo.$ChoiceDefStatus = e;
|
|
84
|
+
this._cdr.detectChanges();
|
|
85
|
+
}
|
|
70
86
|
}
|
|
71
|
-
NotificationGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: NotificationGroupComponent, deps: [{ token: i1.GroupByPipe }], target: i0.ɵɵFactoryTarget.Component });
|
|
72
|
-
NotificationGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: NotificationGroupComponent, selector: "bt-notification-group", inputs: { notifications: "notifications", loading: "loading", notificationCount: "notificationCount" }, outputs: { viewed: "viewed", remove: "remove", actionClick: "actionClick", show: "show", loadMore: "loadMore" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"notifications && notifications.length > 0; else noData\">\r\n <ng-container>\r\n <fd-notification-group width=\"40rem\" style=\"display: block\">\r\n <fd-tab-list size=\"s\">\r\n <fd-tab [title]=\"tab.title\" *ngFor=\"let tab of tabList; let index = index; trackBy: _trackByTitle\">\r\n <fd-notification-group-list\r\n *ngFor=\"let groupItem of tab.groupByItems; let index = index; trackBy: _trackByKey\"\r\n >\r\n <fd-notification-group-header [(expanded)]=\"expanded[groupItem.key]\">\r\n <fd-notification-header>\r\n <bt-notification-group-header\r\n [notifications]=\"groupItem.value\"\r\n [title]=\"groupItem.key\"\r\n ></bt-notification-group-header>\r\n </fd-notification-header>\r\n <fd-notification-actions>\r\n <!-- <button fd-button label=\"Accept All\"></button> -->\r\n <button\r\n fd-button\r\n fdType=\"transparent\"\r\n ariaLabel=\"Close\"\r\n glyph=\"decline\"\r\n title=\"close\"\r\n (click)=\"remove.emit(groupItem.value)\"\r\n ></button>\r\n </fd-notification-actions>\r\n </fd-notification-group-header>\r\n <ng-container\r\n *ngTemplateOutlet=\"notificationBody; context: { $implicit: groupItem.value }\"\r\n ></ng-container>\r\n <!-- <fd-notification-limit *ngIf=\"groupItem.value.length - 4 > 0\">\r\n <h1 fd-notification-limit-title>\r\n There are {{ groupItem.value.length - 4 }} more notifications\r\n </h1>\r\n <p fd-notification-limit-description>\r\n You need to close or take action on the listed notifications to display more.\r\n </p>\r\n </fd-notification-limit> -->\r\n </fd-notification-group-list>\r\n </fd-tab>\r\n </fd-tab-list>\r\n </fd-notification-group>\r\n </ng-container>\r\n</ng-container>\r\n<ng-template #noData>\r\n <bsu-no-data *ngIf=\"!loading; else loadingTpl\"></bsu-no-data>\r\n</ng-template>\r\n<ng-template #loadingTpl>\r\n <div style=\"height: 30px; position: relative\">\r\n <bsu-mask [marginTop]=\"'10px'\"></bsu-mask>\r\n </div>\r\n</ng-template>\r\n<ng-template #notificationItem> </ng-template>\r\n\r\n<ng-template #notificationBody let-notifications>\r\n <div style=\"max-height: 346px; overflow: auto\">\r\n <fd-notification *ngFor=\"let mo of notifications; trackBy: _trackMoById; let first = first; let last = last\">\r\n <fd-notification-body>\r\n <ng-container *ngIf=\"mo.$NotificatoinLoading\">\r\n <bsu-mask [marginTop]=\"'10px'\"></bsu-mask>\r\n </ng-container>\r\n\r\n <fd-avatar\r\n [circle]=\"true\"\r\n size=\"xs\"\r\n [glyph]=\"mo.Icon ? mo.Icon : 'bell'\"\r\n [image]=\"mo.Picture ? mo.Picture : null\"\r\n ></fd-avatar>\r\n <fd-notification-content style=\"min-width: 320px; overflow: hidden\">\r\n <fd-notification-header>\r\n <div fd-notification-indicator [type]=\"mo.Status$Caption\"></div>\r\n <h2 fd-notification-title [unread]=\"mo.Unread\">{{ mo.Title }}</h2>\r\n </fd-notification-header>\r\n <p\r\n #content\r\n fd-notification-paragraph\r\n intersectionObserver\r\n [intersectionThreshold]=\"0.1\"\r\n (visibilityChange)=\"onVisibilityChange($event, mo, last)\"\r\n >\r\n {{ mo.IMessage?.Content }}\r\n </p>\r\n <fd-notification-footer>\r\n <span fd-notification-footer-content>{{ mo.IMessage?.CreatorUser$Caption }}</span>\r\n <span fd-notification-separator></span>\r\n <span fd-notification-footer-content>{{ mo.IMessage?.CreationDate$Caption }}</span>\r\n </fd-notification-footer>\r\n </fd-notification-content>\r\n <fd-notification-actions>\r\n <button\r\n *ngFor=\"let btn of mo.Actions?.MoDataList\"\r\n [dynCommand]=\"btn\"\r\n [mo]=\"mo.RelatedMo\"\r\n fd-button\r\n [label]=\"btn.$Caption | bbbTranslate\"\r\n fdCompact\r\n (click)=\"actionClick.emit(btn)\"\r\n ></button>\r\n <!-- <button\r\n *ngIf=\"mo.RelatedMo\"\r\n fd-button\r\n (click)=\"show.emit({ mo: mo.RelatedMo, nama: mo.NamaRelatedMo })\"\r\n [label]=\"'View' | bbbTranslate\"\r\n fdCompact\r\n ></button> -->\r\n <button\r\n fd-button\r\n fdType=\"transparent\"\r\n ariaLabel=\"Close\"\r\n glyph=\"decline\"\r\n title=\"close\"\r\n (click)=\"remove.emit([mo])\"\r\n fdCompact\r\n ></button>\r\n </fd-notification-actions>\r\n </fd-notification-body>\r\n </fd-notification>\r\n <ng-container *ngIf=\"loading\">\r\n <ng-container *ngTemplateOutlet=\"loadingTpl\"></ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{display:block}:host ::ng-deep .fd-tabs__content{overflow:hidden}:host ::ng-deep .fd-notification{padding:0;box-shadow:none}fd-notification{margin:0}fd-notification-body{position:relative}.noloading{visibility:hidden;height:0;width:0}.loading{visibility:visible;height:100%;width:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.ContentDensityDirective, selector: "[fdContentDensity]:not([fdCompact]):not([fdCondensed]):not([fdCozy]), [fdCompact]:not([fdContentDensity]):not([fdCondensed]):not([fdCozy]), [fdCondensed]:not([fdContentDensity]):not([fdCompact]):not([fdCozy]), [fdCozy]:not([fdContentDensity]):not([fdCompact]):not([fdCondensed])", inputs: ["fdContentDensity", "fdCompact", "fdCondensed", "fdCozy"], exportAs: ["fdContentDensity"] }, { kind: "component", type: i4.AvatarComponent, selector: "fd-avatar", inputs: ["class", "id", "ariaLabel", "ariaLabelledby", "label", "size", "glyph", "zoomGlyph", "circle", "transparent", "contain", "placeholder", "tile", "border", "colorAccent", "random", "clickable", "backgroundImage", "image", "alterIcon", "backupImage"], outputs: ["avatarClicked", "zoomGlyphClicked"] }, { kind: "component", type: i5.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i6.NotificationComponent, selector: "fd-notification", inputs: ["width", "mobile"] }, { kind: "component", type: i6.NotificationHeaderComponent, selector: "fd-notification-header", inputs: ["uniqueId"] }, { kind: "component", type: i6.NotificationFooterComponent, selector: "fd-notification-footer" }, { kind: "component", type: i6.NotificationBodyComponent, selector: "fd-notification-body" }, { kind: "component", type: i6.NotificationActionsComponent, selector: "fd-notification-actions" }, { kind: "component", type: i6.NotificationContentComponent, selector: "fd-notification-content" }, { kind: "component", type: i6.NotificationGroupHeaderComponent, selector: "fd-notification-group-header", inputs: ["expandCompact", "expandAriaLabel", "expandAriaLabelledBy", "expanded"], outputs: ["expandedChange"] }, { kind: "component", type: i6.NotificationGroupComponent, selector: "fd-notification-group", inputs: ["class", "mobile", "width"] }, { kind: "component", type: i6.NotificationGroupListComponent, selector: "fd-notification-group-list" }, { kind: "directive", type: i6.NotificationTitleDirective, selector: "[fdNotificationTitle], [fd-notification-title]", inputs: ["unread"] }, { kind: "directive", type: i6.NotificationIndicatorDirective, selector: "[fdNotificationIndicator], [fd-notification-indicator]", inputs: ["type", "class"] }, { kind: "directive", type: i6.NotificationParagraphDirective, selector: "[fdNotificationParagraph], [fd-notification-paragraph]" }, { kind: "directive", type: i6.NotificationFooterContentDirective, selector: "[fdNotificationFooterContent], [fd-notification-footer-content]" }, { kind: "directive", type: i6.NotificationSeparatorDirective, selector: "[fdNotificationSeparator], [fd-notification-separator]" }, { kind: "component", type: i7.TabListComponent, selector: "fd-tab-list", inputs: ["size", "mode", "collapseOverflow", "maxVisibleTabs", "stackContent", "maxContentHeight", "collapsibleTabs", "expandOverflowText", "defaultTab", "selectDefaultOnTabsChange"], outputs: ["selectedTabChange", "visibleItemsCount", "hiddenItemsCount"] }, { kind: "component", type: i7.TabPanelComponent, selector: "fd-tab", inputs: ["id", "ariaLabel", "ariaLabelledBy", "title", "count", "glyph", "header", "disabled", "tabState"], outputs: ["opened", "closed"] }, { kind: "directive", type: i1.DynamicCommandDirective, selector: "[dynCommand]", inputs: ["dynCommand", "mo", "enableCommand"], outputs: ["commandClick"] }, { kind: "directive", type: i1.IntersectionObserverDirective, selector: "[intersectionObserver]", inputs: ["intersectionDebounce", "intersectionRootMargin", "intersectionRoot", "intersectionThreshold"], outputs: ["visibilityChange"] }, { kind: "component", type: i8.MaskComponent, selector: "bsu-mask", inputs: ["size", "marginTop"] }, { kind: "component", type: i8.NoDataComponent, selector: "bsu-no-data" }, { kind: "component", type: i9.NotificationGroupHeaderComponent, selector: "bt-notification-group-header", inputs: ["notifications", "title"] }, { kind: "pipe", type: i1.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
87
|
+
NotificationGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: NotificationGroupComponent, deps: [{ token: i1.GroupByPipe }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
88
|
+
NotificationGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: NotificationGroupComponent, selector: "bt-notification-group", inputs: { notifications: "notifications", loading: "loading", notificationCount: "notificationCount" }, outputs: { viewed: "viewed", remove: "remove", actionClick: "actionClick", show: "show", loadMore: "loadMore" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"notifications && notifications.length > 0; else noData\">\r\n <ng-container>\r\n <fd-notification-group>\r\n <fd-tab-list size=\"s\">\r\n <fd-tab\r\n [title]=\"tab.title | bbbTranslate\"\r\n *ngFor=\"let tab of tabList; let index = index; trackBy: _trackByTitle\"\r\n >\r\n <fd-notification-group-list\r\n *ngFor=\"let groupItem of tab.groupByItems; let index = index; trackBy: _trackByKey\"\r\n >\r\n <fd-notification-group-header [(expanded)]=\"expanded[groupItem.key]\">\r\n <fd-notification-header>\r\n <bt-notification-group-header\r\n [notifications]=\"groupItem.value\"\r\n [title]=\"groupItem.key\"\r\n ></bt-notification-group-header>\r\n </fd-notification-header>\r\n <fd-notification-actions>\r\n <!-- <button fd-button label=\"Accept All\"></button> -->\r\n <button\r\n fd-button\r\n fdType=\"transparent\"\r\n [ariaLabel]=\"'DeleteAll' | bbbTranslate\"\r\n [title]=\"'DeleteAll' | bbbTranslate\"\r\n glyph=\"decline\"\r\n (click)=\"remove.emit({ items: groupItem.value, silent: false })\"\r\n ></button>\r\n </fd-notification-actions>\r\n </fd-notification-group-header>\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n notificationBody;\r\n context: { $implicit: groupItem.value, expanded: expanded[groupItem.key] }\r\n \"\r\n ></ng-container>\r\n <!-- <fd-notification-limit *ngIf=\"groupItem.value.length - 4 > 0\">\r\n <h1 fd-notification-limit-title>\r\n There are {{ groupItem.value.length - 4 }} more notifications\r\n </h1>\r\n <p fd-notification-limit-description>\r\n You need to close or take action on the listed notifications to display more.\r\n </p>\r\n </fd-notification-limit> -->\r\n </fd-notification-group-list>\r\n </fd-tab>\r\n </fd-tab-list>\r\n </fd-notification-group>\r\n </ng-container>\r\n</ng-container>\r\n<ng-template #noData>\r\n <bsu-no-data *ngIf=\"!loading; else loadingTpl\"></bsu-no-data>\r\n</ng-template>\r\n<ng-template #loadingTpl>\r\n <div style=\"height: 30px; position: relative\">\r\n <bsu-mask [marginTop]=\"'10px'\"></bsu-mask>\r\n </div>\r\n</ng-template>\r\n<ng-template #notificationItem> </ng-template>\r\n\r\n<ng-template #notificationBody let-notifications let-exapanded=\"expanded\">\r\n <div style=\"max-height: 346px; overflow: auto\">\r\n <ng-container *ngFor=\"let mo of notifications; trackBy: _trackMoById; let first = first; let last = last\">\r\n <bsu-notification-item\r\n [notificationItem]=\"mo\"\r\n (viewed)=\"viewed.emit($event)\"\r\n (remove)=\"remove.emit($event)\"\r\n (show)=\"show.emit($event)\"\r\n (actionClick)=\"actionClick.emit($event)\"\r\n intersectionObserver\r\n [intersectionThreshold]=\"0.5\"\r\n (visibilityChange)=\"onVisibilityChange($event, mo, last)\"\r\n ></bsu-notification-item>\r\n </ng-container>\r\n <ng-container *ngIf=\"loading\">\r\n <ng-container *ngTemplateOutlet=\"loadingTpl\"></ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{display:block;min-width:600px}:host ::ng-deep .fd-tabs__content{overflow:hidden}:host ::ng-deep .fd-notification{padding:0;box-shadow:none}fd-notification{margin:0;padding-left:0rem!important;padding-right:0rem!important}fd-notification-body{position:relative}.noloading{visibility:hidden;height:0;width:0}.loading{visibility:visible;height:100%;width:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i4.NotificationHeaderComponent, selector: "fd-notification-header", inputs: ["uniqueId"] }, { kind: "component", type: i4.NotificationActionsComponent, selector: "fd-notification-actions" }, { kind: "component", type: i4.NotificationGroupHeaderComponent, selector: "fd-notification-group-header", inputs: ["expandCompact", "expandAriaLabel", "expandAriaLabelledBy", "expanded"], outputs: ["expandedChange"] }, { kind: "component", type: i4.NotificationGroupComponent, selector: "fd-notification-group", inputs: ["class", "mobile", "width"] }, { kind: "component", type: i4.NotificationGroupListComponent, selector: "fd-notification-group-list" }, { kind: "component", type: i5.TabListComponent, selector: "fd-tab-list", inputs: ["size", "mode", "collapseOverflow", "maxVisibleTabs", "stackContent", "maxContentHeight", "collapsibleTabs", "expandOverflowText", "defaultTab", "selectDefaultOnTabsChange"], outputs: ["selectedTabChange", "visibleItemsCount", "hiddenItemsCount"] }, { kind: "component", type: i5.TabPanelComponent, selector: "fd-tab", inputs: ["id", "ariaLabel", "ariaLabelledBy", "title", "count", "glyph", "header", "disabled", "tabState"], outputs: ["opened", "closed"] }, { kind: "directive", type: i1.IntersectionObserverDirective, selector: "[intersectionObserver]", inputs: ["intersectionDebounce", "intersectionRootMargin", "intersectionRoot", "intersectionThreshold"], outputs: ["visibilityChange"] }, { kind: "component", type: i6.MaskComponent, selector: "bsu-mask", inputs: ["size", "marginTop"] }, { kind: "component", type: i6.NoDataComponent, selector: "bsu-no-data" }, { kind: "component", type: i6.NotificationItemComponent, selector: "bsu-notification-item", inputs: ["option", "notificationItem", "showCloseButton"], outputs: ["viewed", "remove", "actionClick", "show", "close"] }, { kind: "component", type: i7.NotificationGroupHeaderComponent, selector: "bt-notification-group-header", inputs: ["notifications", "title"] }, { kind: "pipe", type: i1.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
73
89
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: NotificationGroupComponent, decorators: [{
|
|
74
90
|
type: Component,
|
|
75
|
-
args: [{ selector: 'bt-notification-group', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"notifications && notifications.length > 0; else noData\">\r\n <ng-container>\r\n <fd-notification-group
|
|
76
|
-
}], ctorParameters: function () { return [{ type: i1.GroupByPipe }]; }, propDecorators: { notifications: [{
|
|
91
|
+
args: [{ selector: 'bt-notification-group', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"notifications && notifications.length > 0; else noData\">\r\n <ng-container>\r\n <fd-notification-group>\r\n <fd-tab-list size=\"s\">\r\n <fd-tab\r\n [title]=\"tab.title | bbbTranslate\"\r\n *ngFor=\"let tab of tabList; let index = index; trackBy: _trackByTitle\"\r\n >\r\n <fd-notification-group-list\r\n *ngFor=\"let groupItem of tab.groupByItems; let index = index; trackBy: _trackByKey\"\r\n >\r\n <fd-notification-group-header [(expanded)]=\"expanded[groupItem.key]\">\r\n <fd-notification-header>\r\n <bt-notification-group-header\r\n [notifications]=\"groupItem.value\"\r\n [title]=\"groupItem.key\"\r\n ></bt-notification-group-header>\r\n </fd-notification-header>\r\n <fd-notification-actions>\r\n <!-- <button fd-button label=\"Accept All\"></button> -->\r\n <button\r\n fd-button\r\n fdType=\"transparent\"\r\n [ariaLabel]=\"'DeleteAll' | bbbTranslate\"\r\n [title]=\"'DeleteAll' | bbbTranslate\"\r\n glyph=\"decline\"\r\n (click)=\"remove.emit({ items: groupItem.value, silent: false })\"\r\n ></button>\r\n </fd-notification-actions>\r\n </fd-notification-group-header>\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n notificationBody;\r\n context: { $implicit: groupItem.value, expanded: expanded[groupItem.key] }\r\n \"\r\n ></ng-container>\r\n <!-- <fd-notification-limit *ngIf=\"groupItem.value.length - 4 > 0\">\r\n <h1 fd-notification-limit-title>\r\n There are {{ groupItem.value.length - 4 }} more notifications\r\n </h1>\r\n <p fd-notification-limit-description>\r\n You need to close or take action on the listed notifications to display more.\r\n </p>\r\n </fd-notification-limit> -->\r\n </fd-notification-group-list>\r\n </fd-tab>\r\n </fd-tab-list>\r\n </fd-notification-group>\r\n </ng-container>\r\n</ng-container>\r\n<ng-template #noData>\r\n <bsu-no-data *ngIf=\"!loading; else loadingTpl\"></bsu-no-data>\r\n</ng-template>\r\n<ng-template #loadingTpl>\r\n <div style=\"height: 30px; position: relative\">\r\n <bsu-mask [marginTop]=\"'10px'\"></bsu-mask>\r\n </div>\r\n</ng-template>\r\n<ng-template #notificationItem> </ng-template>\r\n\r\n<ng-template #notificationBody let-notifications let-exapanded=\"expanded\">\r\n <div style=\"max-height: 346px; overflow: auto\">\r\n <ng-container *ngFor=\"let mo of notifications; trackBy: _trackMoById; let first = first; let last = last\">\r\n <bsu-notification-item\r\n [notificationItem]=\"mo\"\r\n (viewed)=\"viewed.emit($event)\"\r\n (remove)=\"remove.emit($event)\"\r\n (show)=\"show.emit($event)\"\r\n (actionClick)=\"actionClick.emit($event)\"\r\n intersectionObserver\r\n [intersectionThreshold]=\"0.5\"\r\n (visibilityChange)=\"onVisibilityChange($event, mo, last)\"\r\n ></bsu-notification-item>\r\n </ng-container>\r\n <ng-container *ngIf=\"loading\">\r\n <ng-container *ngTemplateOutlet=\"loadingTpl\"></ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{display:block;min-width:600px}:host ::ng-deep .fd-tabs__content{overflow:hidden}:host ::ng-deep .fd-notification{padding:0;box-shadow:none}fd-notification{margin:0;padding-left:0rem!important;padding-right:0rem!important}fd-notification-body{position:relative}.noloading{visibility:hidden;height:0;width:0}.loading{visibility:visible;height:100%;width:100%}\n"] }]
|
|
92
|
+
}], ctorParameters: function () { return [{ type: i1.GroupByPipe }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { notifications: [{
|
|
77
93
|
type: Input
|
|
78
94
|
}], loading: [{
|
|
79
95
|
type: Input
|
|
@@ -90,4 +106,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
|
|
|
90
106
|
}], loadMore: [{
|
|
91
107
|
type: Output
|
|
92
108
|
}] } });
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification-group.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-tiles/src/lib/notification-group/notification-group.component.ts","../../../../../projects/barsa-tiles/src/lib/notification-group/notification-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    EventEmitter,\r\n    Input,\r\n    OnChanges,\r\n    OnInit,\r\n    Output,\r\n    SimpleChanges\r\n} from '@angular/core';\r\nimport { BaseComponent, GroupByItem, GroupByPipe, IntersectionStatus, MetaobjectDataModel } from 'barsa-novin-ray-core';\r\nimport { NotificationItem } from '../models/notification-item';\r\n\r\n@Component({\r\n    selector: 'bt-notification-group',\r\n    templateUrl: './notification-group.component.html',\r\n    styleUrls: ['./notification-group.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class NotificationGroupComponent extends BaseComponent implements OnInit, OnChanges {\r\n    @Input() notifications: NotificationItem[] | null;\r\n    @Input() loading: boolean;\r\n    @Input() notificationCount: { unread: number; all: number };\r\n\r\n    @Output() viewed = new EventEmitter<NotificationItem[]>();\r\n    @Output() remove = new EventEmitter<NotificationItem[]>();\r\n    @Output() actionClick = new EventEmitter<MetaobjectDataModel>();\r\n    @Output() show = new EventEmitter<{ mo: MetaobjectDataModel; nama: string }>();\r\n    @Output() loadMore = new EventEmitter<void>();\r\n    expanded: Record<string, boolean> = {};\r\n\r\n    tabList: { title: string; groupByItems: GroupByItem[] }[] = [\r\n        { title: 'By Date', groupByItems: [] },\r\n        { title: 'By Type', groupByItems: [] },\r\n        { title: 'By Priority', groupByItems: [] }\r\n    ];\r\n    viewedNotifications: NotificationItem[] = [];\r\n    constructor(private _groupByPipe: GroupByPipe) {\r\n        super();\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.applyGroupByItems(this.notifications);\r\n    }\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        super.ngOnChanges(changes);\r\n        const { notifications } = changes;\r\n        if (notifications && !notifications.firstChange) {\r\n            this.applyGroupByItems(notifications.currentValue);\r\n        }\r\n    }\r\n    applyGroupByItems(notifications: NotificationItem[] | null): void {\r\n        if (!notifications?.length) {\r\n            return;\r\n        }\r\n        this.tabList[0].groupByItems = this._groupByPipe.transform(notifications, 'CreationDate');\r\n        this.tabList[1].groupByItems = this._groupByPipe.transform(notifications, 'Subject');\r\n        this.tabList[2].groupByItems = this._groupByPipe.transform(notifications, 'Priority');\r\n    }\r\n    _trackByTitle(_index: number, tab: { title: string; groupByItems: GroupByItem[] }): number | string {\r\n        return tab.title;\r\n    }\r\n    _trackByKey(_index: number, item: { id: string; key: string; value: any }): number | string {\r\n        return item.key;\r\n    }\r\n    _trackMoById(_index: number, mo: MetaobjectDataModel): number | string {\r\n        return mo.Id;\r\n    }\r\n    onVisibilityChange(e: IntersectionStatus, mo: NotificationItem, isLast: boolean): void {\r\n        console.log(e, this.viewedNotifications);\r\n        if (e === IntersectionStatus.Visible) {\r\n            if (mo.Unread) {\r\n                this.viewedNotifications = [...this.viewedNotifications.filter((c) => c.Unread), mo];\r\n                this.viewed.emit(this.viewedNotifications);\r\n            }\r\n            if (isLast) {\r\n                this.loadMore.emit();\r\n            }\r\n        }\r\n    }\r\n}\r\n","<ng-container *ngIf=\"notifications && notifications.length > 0; else noData\">\r\n    <ng-container>\r\n        <fd-notification-group width=\"40rem\" style=\"display: block\">\r\n            <fd-tab-list size=\"s\">\r\n                <fd-tab [title]=\"tab.title\" *ngFor=\"let tab of tabList; let index = index; trackBy: _trackByTitle\">\r\n                    <fd-notification-group-list\r\n                        *ngFor=\"let groupItem of tab.groupByItems; let index = index; trackBy: _trackByKey\"\r\n                    >\r\n                        <fd-notification-group-header [(expanded)]=\"expanded[groupItem.key]\">\r\n                            <fd-notification-header>\r\n                                <bt-notification-group-header\r\n                                    [notifications]=\"groupItem.value\"\r\n                                    [title]=\"groupItem.key\"\r\n                                ></bt-notification-group-header>\r\n                            </fd-notification-header>\r\n                            <fd-notification-actions>\r\n                                <!-- <button fd-button label=\"Accept All\"></button> -->\r\n                                <button\r\n                                    fd-button\r\n                                    fdType=\"transparent\"\r\n                                    ariaLabel=\"Close\"\r\n                                    glyph=\"decline\"\r\n                                    title=\"close\"\r\n                                    (click)=\"remove.emit(groupItem.value)\"\r\n                                ></button>\r\n                            </fd-notification-actions>\r\n                        </fd-notification-group-header>\r\n                        <ng-container\r\n                            *ngTemplateOutlet=\"notificationBody; context: { $implicit: groupItem.value }\"\r\n                        ></ng-container>\r\n                        <!-- <fd-notification-limit *ngIf=\"groupItem.value.length - 4 > 0\">\r\n                            <h1 fd-notification-limit-title>\r\n                                There are {{ groupItem.value.length - 4 }} more notifications\r\n                            </h1>\r\n                            <p fd-notification-limit-description>\r\n                                You need to close or take action on the listed notifications to display more.\r\n                            </p>\r\n                        </fd-notification-limit> -->\r\n                    </fd-notification-group-list>\r\n                </fd-tab>\r\n            </fd-tab-list>\r\n        </fd-notification-group>\r\n    </ng-container>\r\n</ng-container>\r\n<ng-template #noData>\r\n    <bsu-no-data *ngIf=\"!loading; else loadingTpl\"></bsu-no-data>\r\n</ng-template>\r\n<ng-template #loadingTpl>\r\n    <div style=\"height: 30px; position: relative\">\r\n        <bsu-mask [marginTop]=\"'10px'\"></bsu-mask>\r\n    </div>\r\n</ng-template>\r\n<ng-template #notificationItem> </ng-template>\r\n\r\n<ng-template #notificationBody let-notifications>\r\n    <div style=\"max-height: 346px; overflow: auto\">\r\n        <fd-notification *ngFor=\"let mo of notifications; trackBy: _trackMoById; let first = first; let last = last\">\r\n            <fd-notification-body>\r\n                <ng-container *ngIf=\"mo.$NotificatoinLoading\">\r\n                    <bsu-mask [marginTop]=\"'10px'\"></bsu-mask>\r\n                </ng-container>\r\n\r\n                <fd-avatar\r\n                    [circle]=\"true\"\r\n                    size=\"xs\"\r\n                    [glyph]=\"mo.Icon ? mo.Icon : 'bell'\"\r\n                    [image]=\"mo.Picture ? mo.Picture : null\"\r\n                ></fd-avatar>\r\n                <fd-notification-content style=\"min-width: 320px; overflow: hidden\">\r\n                    <fd-notification-header>\r\n                        <div fd-notification-indicator [type]=\"mo.Status$Caption\"></div>\r\n                        <h2 fd-notification-title [unread]=\"mo.Unread\">{{ mo.Title }}</h2>\r\n                    </fd-notification-header>\r\n                    <p\r\n                        #content\r\n                        fd-notification-paragraph\r\n                        intersectionObserver\r\n                        [intersectionThreshold]=\"0.1\"\r\n                        (visibilityChange)=\"onVisibilityChange($event, mo, last)\"\r\n                    >\r\n                        {{ mo.IMessage?.Content }}\r\n                    </p>\r\n                    <fd-notification-footer>\r\n                        <span fd-notification-footer-content>{{ mo.IMessage?.CreatorUser$Caption }}</span>\r\n                        <span fd-notification-separator></span>\r\n                        <span fd-notification-footer-content>{{ mo.IMessage?.CreationDate$Caption }}</span>\r\n                    </fd-notification-footer>\r\n                </fd-notification-content>\r\n                <fd-notification-actions>\r\n                    <button\r\n                        *ngFor=\"let btn of mo.Actions?.MoDataList\"\r\n                        [dynCommand]=\"btn\"\r\n                        [mo]=\"mo.RelatedMo\"\r\n                        fd-button\r\n                        [label]=\"btn.$Caption | bbbTranslate\"\r\n                        fdCompact\r\n                        (click)=\"actionClick.emit(btn)\"\r\n                    ></button>\r\n                    <!-- <button\r\n                        *ngIf=\"mo.RelatedMo\"\r\n                        fd-button\r\n                        (click)=\"show.emit({ mo: mo.RelatedMo, nama: mo.NamaRelatedMo })\"\r\n                        [label]=\"'View' | bbbTranslate\"\r\n                        fdCompact\r\n                    ></button> -->\r\n                    <button\r\n                        fd-button\r\n                        fdType=\"transparent\"\r\n                        ariaLabel=\"Close\"\r\n                        glyph=\"decline\"\r\n                        title=\"close\"\r\n                        (click)=\"remove.emit([mo])\"\r\n                        fdCompact\r\n                    ></button>\r\n                </fd-notification-actions>\r\n            </fd-notification-body>\r\n        </fd-notification>\r\n        <ng-container *ngIf=\"loading\">\r\n            <ng-container *ngTemplateOutlet=\"loadingTpl\"></ng-container>\r\n        </ng-container>\r\n    </div>\r\n</ng-template>\r\n"]}
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification-group.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-tiles/src/lib/notification-group/notification-group.component.ts","../../../../../projects/barsa-tiles/src/lib/notification-group/notification-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    EventEmitter,\r\n    Input,\r\n    OnChanges,\r\n    OnInit,\r\n    Output,\r\n    SimpleChanges\r\n} from '@angular/core';\r\nimport {\r\n    BaseComponent,\r\n    GroupByItem,\r\n    GroupByPipe,\r\n    IntersectionStatus,\r\n    MetaobjectDataModel,\r\n    WorkflowExecuteChoiceStatus,\r\n    BarsaApi,\r\n    NotificationItem,\r\n    NotificationAction\r\n} from 'barsa-novin-ray-core';\r\n\r\n@Component({\r\n    selector: 'bt-notification-group',\r\n    templateUrl: './notification-group.component.html',\r\n    styleUrls: ['./notification-group.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class NotificationGroupComponent extends BaseComponent implements OnInit, OnChanges {\r\n    @Input() notifications: NotificationItem[] | null;\r\n    @Input() loading: boolean;\r\n    @Input() notificationCount: { unread: number; all: number };\r\n\r\n    @Output() viewed = new EventEmitter<NotificationItem>();\r\n    @Output() remove = new EventEmitter<{ items: NotificationItem[]; silent: boolean }>();\r\n    @Output() actionClick = new EventEmitter<{ item: NotificationItem; btn: NotificationAction }>();\r\n    @Output() show = new EventEmitter<{ mo: MetaobjectDataModel; nama: string }>();\r\n    @Output() loadMore = new EventEmitter<void>();\r\n    expanded: Record<string, boolean> = {};\r\n\r\n    tabList: { title: string; groupByItems: GroupByItem[] }[] = [\r\n        { title: 'By Date', groupByItems: [] },\r\n        { title: 'By Type', groupByItems: [] },\r\n        { title: 'By Priority', groupByItems: [] }\r\n    ];\r\n    viewedNotifications: NotificationItem[] = [];\r\n    constructor(private _groupByPipe: GroupByPipe, private _cdr: ChangeDetectorRef) {\r\n        super();\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.applyGroupByItems(this.notifications);\r\n    }\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        super.ngOnChanges(changes);\r\n        const { notifications } = changes;\r\n        if (notifications && !notifications.firstChange) {\r\n            this.applyGroupByItems(notifications.currentValue);\r\n            this._cdr.detectChanges();\r\n        }\r\n    }\r\n    applyGroupByItems(notifications: NotificationItem[] | null): void {\r\n        if (!notifications?.length) {\r\n            return;\r\n        }\r\n        this.tabList[0].groupByItems = this._groupByPipe.transform(notifications, 'CreationDate');\r\n        this.tabList[1].groupByItems = this._groupByPipe.transform(notifications, 'Subject');\r\n        this.tabList[2].groupByItems = this._groupByPipe.transform(notifications, 'Priority');\r\n        for (let i = 0; i < this.tabList.length; i++) {\r\n            if (this.tabList[i].groupByItems.length) {\r\n                const firstKey = this.tabList[i].groupByItems[0].key;\r\n                if (firstKey && typeof this.expanded[firstKey] === 'undefined') {\r\n                    this.expanded[firstKey] = true;\r\n                }\r\n            }\r\n        }\r\n    }\r\n    _trackByTitle(_index: number, _: { title: string; groupByItems: GroupByItem[] }): number | string {\r\n        return _index;\r\n    }\r\n    _trackByKey(_index: number, item: { id: string; key: string; value: any }): number | string {\r\n        return item.key;\r\n    }\r\n    _trackMoById(_index: number, mo: MetaobjectDataModel): number | string {\r\n        return mo.Id;\r\n    }\r\n    onVisibilityChange(e: IntersectionStatus, mo: NotificationItem, isLast: boolean): void {\r\n        if (e === IntersectionStatus.Visible) {\r\n            if (mo.Unread) {\r\n                this.viewedNotifications = [...this.viewedNotifications.filter((c) => c.Unread), mo];\r\n                this.viewed.emit(mo);\r\n            }\r\n            if (isLast) {\r\n                this.loadMore.emit();\r\n            }\r\n        }\r\n    }\r\n    onWorkflowExecuteChoiceStatusChanged(e: WorkflowExecuteChoiceStatus, mo: NotificationItem): void {\r\n        if (e.result && !e.error) {\r\n            this.remove.emit({ items: [mo], silent: true });\r\n            BarsaApi.Bw.Toast.Success(`${e.choice?.Title} ${BarsaApi.BBB.Action}`);\r\n            return;\r\n        }\r\n        mo.$ChoiceDefStatus = e;\r\n        this._cdr.detectChanges();\r\n    }\r\n}\r\n","<ng-container *ngIf=\"notifications && notifications.length > 0; else noData\">\r\n    <ng-container>\r\n        <fd-notification-group>\r\n            <fd-tab-list size=\"s\">\r\n                <fd-tab\r\n                    [title]=\"tab.title | bbbTranslate\"\r\n                    *ngFor=\"let tab of tabList; let index = index; trackBy: _trackByTitle\"\r\n                >\r\n                    <fd-notification-group-list\r\n                        *ngFor=\"let groupItem of tab.groupByItems; let index = index; trackBy: _trackByKey\"\r\n                    >\r\n                        <fd-notification-group-header [(expanded)]=\"expanded[groupItem.key]\">\r\n                            <fd-notification-header>\r\n                                <bt-notification-group-header\r\n                                    [notifications]=\"groupItem.value\"\r\n                                    [title]=\"groupItem.key\"\r\n                                ></bt-notification-group-header>\r\n                            </fd-notification-header>\r\n                            <fd-notification-actions>\r\n                                <!-- <button fd-button label=\"Accept All\"></button> -->\r\n                                <button\r\n                                    fd-button\r\n                                    fdType=\"transparent\"\r\n                                    [ariaLabel]=\"'DeleteAll' | bbbTranslate\"\r\n                                    [title]=\"'DeleteAll' | bbbTranslate\"\r\n                                    glyph=\"decline\"\r\n                                    (click)=\"remove.emit({ items: groupItem.value, silent: false })\"\r\n                                ></button>\r\n                            </fd-notification-actions>\r\n                        </fd-notification-group-header>\r\n                        <ng-container\r\n                            *ngTemplateOutlet=\"\r\n                                notificationBody;\r\n                                context: { $implicit: groupItem.value, expanded: expanded[groupItem.key] }\r\n                            \"\r\n                        ></ng-container>\r\n                        <!-- <fd-notification-limit *ngIf=\"groupItem.value.length - 4 > 0\">\r\n                            <h1 fd-notification-limit-title>\r\n                                There are {{ groupItem.value.length - 4 }} more notifications\r\n                            </h1>\r\n                            <p fd-notification-limit-description>\r\n                                You need to close or take action on the listed notifications to display more.\r\n                            </p>\r\n                        </fd-notification-limit> -->\r\n                    </fd-notification-group-list>\r\n                </fd-tab>\r\n            </fd-tab-list>\r\n        </fd-notification-group>\r\n    </ng-container>\r\n</ng-container>\r\n<ng-template #noData>\r\n    <bsu-no-data *ngIf=\"!loading; else loadingTpl\"></bsu-no-data>\r\n</ng-template>\r\n<ng-template #loadingTpl>\r\n    <div style=\"height: 30px; position: relative\">\r\n        <bsu-mask [marginTop]=\"'10px'\"></bsu-mask>\r\n    </div>\r\n</ng-template>\r\n<ng-template #notificationItem> </ng-template>\r\n\r\n<ng-template #notificationBody let-notifications let-exapanded=\"expanded\">\r\n    <div style=\"max-height: 346px; overflow: auto\">\r\n        <ng-container *ngFor=\"let mo of notifications; trackBy: _trackMoById; let first = first; let last = last\">\r\n            <bsu-notification-item\r\n                [notificationItem]=\"mo\"\r\n                (viewed)=\"viewed.emit($event)\"\r\n                (remove)=\"remove.emit($event)\"\r\n                (show)=\"show.emit($event)\"\r\n                (actionClick)=\"actionClick.emit($event)\"\r\n                intersectionObserver\r\n                [intersectionThreshold]=\"0.5\"\r\n                (visibilityChange)=\"onVisibilityChange($event, mo, last)\"\r\n            ></bsu-notification-item>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"loading\">\r\n            <ng-container *ngTemplateOutlet=\"loadingTpl\"></ng-container>\r\n        </ng-container>\r\n    </div>\r\n</ng-template>\r\n"]}
|
|
@@ -36,4 +36,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
|
|
|
36
36
|
}], title: [{
|
|
37
37
|
type: Input
|
|
38
38
|
}] } });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9uLWdyb3VwLWhlYWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS10aWxlcy9zcmMvbGliL25vdGlmaWNhdGlvbi1ncm91cC1oZWFkZXIvbm90aWZpY2F0aW9uLWdyb3VwLWhlYWRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS10aWxlcy9zcmMvbGliL25vdGlmaWNhdGlvbi1ncm91cC1oZWFkZXIvbm90aWZpY2F0aW9uLWdyb3VwLWhlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsdUJBQXVCLEVBRXZCLFNBQVMsRUFDVCxLQUFLLEVBSVIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGFBQWEsRUFBb0IsTUFBTSxzQkFBc0IsQ0FBQzs7Ozs7QUFRdkUsTUFBTSxPQUFPLGdDQUFpQyxTQUFRLGFBQWE7SUFJL0QsWUFBb0IsSUFBdUI7UUFDdkMsS0FBSyxFQUFFLENBQUM7UUFEUSxTQUFJLEdBQUosSUFBSSxDQUFtQjtRQUQzQyxnQkFBVyxHQUFHLENBQUMsQ0FBQztJQUdoQixDQUFDO0lBRUQsUUFBUTtRQUNKLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUM1QyxDQUFDO0lBQ0QsV0FBVyxDQUFDLE9BQXNCO1FBQzlCLEtBQUssQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDM0IsTUFBTSxFQUFFLGFBQWEsRUFBRSxHQUFHLE9BQU8sQ0FBQztRQUNsQyxJQUFJLGFBQWEsSUFBSSxDQUFDLGFBQWEsQ0FBQyxXQUFXLEVBQUU7WUFDN0MsSUFBSSxDQUFDLGNBQWMsQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUFDLENBQUM7WUFDaEQsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztTQUM3QjtJQUNMLENBQUM7SUFDTyxjQUFjLENBQUMsYUFBaUM7UUFDcEQsSUFBSSxDQUFDLFdBQVcsR0FBRyxhQUFhLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsTUFBTSxDQUFDO0lBQ3BFLENBQUM7OzZIQXRCUSxnQ0FBZ0M7aUhBQWhDLGdDQUFnQyw0S0NqQjdDLDhOQUlBOzJGRGFhLGdDQUFnQztrQkFONUMsU0FBUzsrQkFDSSw4QkFBOEIsbUJBR3ZCLHVCQUF1QixDQUFDLE1BQU07d0dBR3RDLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICAgIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxyXG4gICAgQ2hhbmdlRGV0ZWN0b3JSZWYsXHJcbiAgICBDb21wb25lbnQsXHJcbiAgICBJbnB1dCxcclxuICAgIE9uQ2hhbmdlcyxcclxuICAgIE9uSW5pdCxcclxuICAgIFNpbXBsZUNoYW5nZXNcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQmFzZUNvbXBvbmVudCwgTm90aWZpY2F0aW9uSXRlbSB9IGZyb20gJ2JhcnNhLW5vdmluLXJheS1jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdidC1ub3RpZmljYXRpb24tZ3JvdXAtaGVhZGVyJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9ub3RpZmljYXRpb24tZ3JvdXAtaGVhZGVyLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL25vdGlmaWNhdGlvbi1ncm91cC1oZWFkZXIuY29tcG9uZW50LnNjc3MnXSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBOb3RpZmljYXRpb25Hcm91cEhlYWRlckNvbXBvbmVudCBleHRlbmRzIEJhc2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uQ2hhbmdlcyB7XHJcbiAgICBASW5wdXQoKSBub3RpZmljYXRpb25zOiBOb3RpZmljYXRpb25JdGVtW107XHJcbiAgICBASW5wdXQoKSB0aXRsZTogc3RyaW5nO1xyXG4gICAgdW5yZWFkQ291bnQgPSAwO1xyXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBfY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge1xyXG4gICAgICAgIHN1cGVyKCk7XHJcbiAgICB9XHJcblxyXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcclxuICAgICAgICB0aGlzLnNldFVucmVhZENvdW50KHRoaXMubm90aWZpY2F0aW9ucyk7XHJcbiAgICB9XHJcbiAgICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XHJcbiAgICAgICAgc3VwZXIubmdPbkNoYW5nZXMoY2hhbmdlcyk7XHJcbiAgICAgICAgY29uc3QgeyBub3RpZmljYXRpb25zIH0gPSBjaGFuZ2VzO1xyXG4gICAgICAgIGlmIChub3RpZmljYXRpb25zICYmICFub3RpZmljYXRpb25zLmZpcnN0Q2hhbmdlKSB7XHJcbiAgICAgICAgICAgIHRoaXMuc2V0VW5yZWFkQ291bnQobm90aWZpY2F0aW9ucy5jdXJyZW50VmFsdWUpO1xyXG4gICAgICAgICAgICB0aGlzLl9jZHIuZGV0ZWN0Q2hhbmdlcygpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIHByaXZhdGUgc2V0VW5yZWFkQ291bnQobm90aWZpY2F0aW9uczogTm90aWZpY2F0aW9uSXRlbVtdKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy51bnJlYWRDb3VudCA9IG5vdGlmaWNhdGlvbnMuZmlsdGVyKChjKSA9PiBjLlVucmVhZCkubGVuZ3RoO1xyXG4gICAgfVxyXG59XHJcbiIsIjxoMiBmZC1ub3RpZmljYXRpb24tdGl0bGUgW3VucmVhZF09XCJmYWxzZVwiPlxyXG4gICAge3sgdGl0bGUgfCBiYmJUcmFuc2xhdGUgfX0gKHt7IG5vdGlmaWNhdGlvbnMubGVuZ3RoIH19KVxyXG4gICAgPHN0cm9uZyAqbmdJZj1cInVucmVhZENvdW50ICE9PSAwXCI+e3sgJ05ldycgfCBiYmJUcmFuc2xhdGUgfX0gKHt7IHVucmVhZENvdW50IH19KTwvc3Ryb25nPlxyXG48L2gyPlxyXG4iXX0=
|