barsa-tiles 1.0.250 → 1.0.253
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/actions-link/actions-link.component.mjs +2 -2
- package/esm2020/lib/barsa-tiles.module.mjs +12 -3
- package/esm2020/lib/models/notification-item.mjs +2 -0
- package/esm2020/lib/notification-group/notification-group.component.mjs +93 -0
- package/esm2020/lib/notification-group-header/notification-group-header.component.mjs +39 -0
- package/esm2020/lib/shellbar/shellbar.component.mjs +68 -28
- package/esm2020/lib/tiles-viewer-group/tiles-viewer-group.component.mjs +3 -3
- package/fesm2015/barsa-tiles.mjs +199 -38
- package/fesm2015/barsa-tiles.mjs.map +1 -1
- package/fesm2020/barsa-tiles.mjs +202 -38
- package/fesm2020/barsa-tiles.mjs.map +1 -1
- package/lib/barsa-tiles.module.d.ts +12 -10
- package/lib/models/notification-item.d.ts +5 -0
- package/lib/notification-group/notification-group.component.d.ts +44 -0
- package/lib/notification-group-header/notification-group-header.component.d.ts +16 -0
- package/lib/shellbar/shellbar.component.d.ts +25 -8
- package/package.json +1 -1
|
@@ -7,10 +7,10 @@ import * as i3 from "../action-item/action-item.component";
|
|
|
7
7
|
export class ActionsLinkComponent extends BaseComponent {
|
|
8
8
|
}
|
|
9
9
|
ActionsLinkComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: ActionsLinkComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
10
|
-
ActionsLinkComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: ActionsLinkComponent, selector: "bt-actions-link", inputs: { actionsLink: "actionsLink", editHome: "editHome" }, usesInheritance: true, ngImport: i0, template: "<bt-action-item\r\n *ngFor=\"let actionItem of actionsLink\"\r\n cdkDrag\r\n [data]=\"actionItem\"\r\n [editHome]=\"editHome\"\r\n [cdkDragDisabled]=\"!actionItem || actionItem.Locked\"\r\n [mo]=\"actionItem\"\r\n>\r\n</bt-action-item>\r\n", styles: [":host{display:flex;width:100%;row-gap:
|
|
10
|
+
ActionsLinkComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: ActionsLinkComponent, selector: "bt-actions-link", inputs: { actionsLink: "actionsLink", editHome: "editHome" }, usesInheritance: true, ngImport: i0, template: "<bt-action-item\r\n *ngFor=\"let actionItem of actionsLink\"\r\n cdkDrag\r\n [data]=\"actionItem\"\r\n [editHome]=\"editHome\"\r\n [cdkDragDisabled]=\"!actionItem || actionItem.Locked\"\r\n [mo]=\"actionItem\"\r\n>\r\n</bt-action-item>\r\n", styles: [":host{display:flex;width:100%;row-gap:3px;flex-wrap:wrap;border-radius:var(--sapElement_BorderCornerRadius, .25rem);column-gap:3px;padding:1rem 0}bt-action-item{margin-top:auto;margin-bottom:auto}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "component", type: i3.ActionItemComponent, selector: "bt-action-item" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
11
11
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: ActionsLinkComponent, decorators: [{
|
|
12
12
|
type: Component,
|
|
13
|
-
args: [{ selector: 'bt-actions-link', changeDetection: ChangeDetectionStrategy.OnPush, template: "<bt-action-item\r\n *ngFor=\"let actionItem of actionsLink\"\r\n cdkDrag\r\n [data]=\"actionItem\"\r\n [editHome]=\"editHome\"\r\n [cdkDragDisabled]=\"!actionItem || actionItem.Locked\"\r\n [mo]=\"actionItem\"\r\n>\r\n</bt-action-item>\r\n", styles: [":host{display:flex;width:100%;row-gap:
|
|
13
|
+
args: [{ selector: 'bt-actions-link', changeDetection: ChangeDetectionStrategy.OnPush, template: "<bt-action-item\r\n *ngFor=\"let actionItem of actionsLink\"\r\n cdkDrag\r\n [data]=\"actionItem\"\r\n [editHome]=\"editHome\"\r\n [cdkDragDisabled]=\"!actionItem || actionItem.Locked\"\r\n [mo]=\"actionItem\"\r\n>\r\n</bt-action-item>\r\n", styles: [":host{display:flex;width:100%;row-gap:3px;flex-wrap:wrap;border-radius:var(--sapElement_BorderCornerRadius, .25rem);column-gap:3px;padding:1rem 0}bt-action-item{margin-top:auto;margin-bottom:auto}\n"] }]
|
|
14
14
|
}], propDecorators: { actionsLink: [{
|
|
15
15
|
type: Input
|
|
16
16
|
}], editHome: [{
|
|
@@ -46,6 +46,8 @@ import { AppFinderAppListComponent } from './app-finder-app-list/app-finder-app-
|
|
|
46
46
|
import { TileRendererDirective } from './tile-renderer.directive';
|
|
47
47
|
import { TilesViewerGroupComponent } from './tiles-viewer-group/tiles-viewer-group.component';
|
|
48
48
|
import { FormTileComponent } from './form-tile/form-tile.component';
|
|
49
|
+
import { NotificationGroupComponent } from './notification-group/notification-group.component';
|
|
50
|
+
import { NotificationGroupHeaderComponent } from './notification-group-header/notification-group-header.component';
|
|
49
51
|
import * as i0 from "@angular/core";
|
|
50
52
|
import * as i1 from "barsa-novin-ray-core";
|
|
51
53
|
const components = [
|
|
@@ -120,7 +122,8 @@ BarsaTilesModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", versio
|
|
|
120
122
|
AppFinderGroupComponent,
|
|
121
123
|
AppFinderAppListComponent,
|
|
122
124
|
TilesViewerGroupComponent,
|
|
123
|
-
FormTileComponent, GroupTilesPipe, TileHomeFilterPipe, HomeGroupPipe, ActionLinksPipe, EmptyListDirective, TileRendererDirective
|
|
125
|
+
FormTileComponent, GroupTilesPipe, TileHomeFilterPipe, HomeGroupPipe, ActionLinksPipe, EmptyListDirective, TileRendererDirective, NotificationGroupComponent,
|
|
126
|
+
NotificationGroupHeaderComponent], imports: [CommonModule,
|
|
124
127
|
FormsModule,
|
|
125
128
|
DragDropModule,
|
|
126
129
|
CdkTableModule,
|
|
@@ -189,8 +192,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
|
|
|
189
192
|
BarsaEchartsModule
|
|
190
193
|
],
|
|
191
194
|
providers: [TilesService, AppFinderService],
|
|
192
|
-
declarations: [
|
|
195
|
+
declarations: [
|
|
196
|
+
...components,
|
|
197
|
+
...pipes,
|
|
198
|
+
...directives,
|
|
199
|
+
NotificationGroupComponent,
|
|
200
|
+
NotificationGroupHeaderComponent
|
|
201
|
+
],
|
|
193
202
|
exports: [...components]
|
|
194
203
|
}]
|
|
195
204
|
}], ctorParameters: function () { return [{ type: i1.DynamicComponentService }, { type: i0.ComponentFactoryResolver }]; } });
|
|
196
|
-
//# 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\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: [...components, ...pipes, ...directives],\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 } 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"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9uLWl0ZW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS10aWxlcy9zcmMvbGliL21vZGVscy9ub3RpZmljYXRpb24taXRlbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2FmZUh0bWwgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcbmltcG9ydCB7IE1ldGFvYmplY3REYXRhTW9kZWwgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XG5cbmV4cG9ydCB0eXBlIE5vdGlmaWNhdGlvbkl0ZW0gPSBNZXRhb2JqZWN0RGF0YU1vZGVsICYgeyBjb250ZW50U2FmZUh0bWw6IFNhZmVIdG1sIH07XG4iXX0=
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { BaseComponent, IntersectionStatus } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "barsa-novin-ray-core";
|
|
5
|
+
import * as i2 from "@angular/common";
|
|
6
|
+
import * as i3 from "@fundamental-ngx/core/content-density";
|
|
7
|
+
import * as i4 from "@fundamental-ngx/core/avatar";
|
|
8
|
+
import * as i5 from "@fundamental-ngx/core/button";
|
|
9
|
+
import * as i6 from "@fundamental-ngx/core/notification";
|
|
10
|
+
import * as i7 from "@fundamental-ngx/core/tabs";
|
|
11
|
+
import * as i8 from "barsa-sap-ui";
|
|
12
|
+
import * as i9 from "../notification-group-header/notification-group-header.component";
|
|
13
|
+
export class NotificationGroupComponent extends BaseComponent {
|
|
14
|
+
constructor(_groupByPipe) {
|
|
15
|
+
super();
|
|
16
|
+
this._groupByPipe = _groupByPipe;
|
|
17
|
+
this.viewed = new EventEmitter();
|
|
18
|
+
this.remove = new EventEmitter();
|
|
19
|
+
this.actionClick = new EventEmitter();
|
|
20
|
+
this.show = new EventEmitter();
|
|
21
|
+
this.loadMore = new EventEmitter();
|
|
22
|
+
this.expanded = {};
|
|
23
|
+
this.tabList = [
|
|
24
|
+
{ title: 'By Date', groupByItems: [] },
|
|
25
|
+
{ title: 'By Type', groupByItems: [] },
|
|
26
|
+
{ title: 'By Priority', groupByItems: [] }
|
|
27
|
+
];
|
|
28
|
+
this.viewedNotifications = [];
|
|
29
|
+
}
|
|
30
|
+
ngOnInit() {
|
|
31
|
+
super.ngOnInit();
|
|
32
|
+
this.applyGroupByItems(this.notifications);
|
|
33
|
+
}
|
|
34
|
+
ngOnChanges(changes) {
|
|
35
|
+
super.ngOnChanges(changes);
|
|
36
|
+
const { notifications } = changes;
|
|
37
|
+
if (notifications && !notifications.firstChange) {
|
|
38
|
+
this.applyGroupByItems(notifications.currentValue);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
applyGroupByItems(notifications) {
|
|
42
|
+
if (!notifications?.length) {
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
this.tabList[0].groupByItems = this._groupByPipe.transform(notifications, 'CreationDate');
|
|
46
|
+
this.tabList[1].groupByItems = this._groupByPipe.transform(notifications, 'Subject');
|
|
47
|
+
this.tabList[2].groupByItems = this._groupByPipe.transform(notifications, 'Priority');
|
|
48
|
+
}
|
|
49
|
+
_trackByTitle(_index, tab) {
|
|
50
|
+
return tab.title;
|
|
51
|
+
}
|
|
52
|
+
_trackByKey(_index, item) {
|
|
53
|
+
return item.key;
|
|
54
|
+
}
|
|
55
|
+
_trackMoById(_index, mo) {
|
|
56
|
+
return mo.Id;
|
|
57
|
+
}
|
|
58
|
+
onVisibilityChange(e, mo, isLast) {
|
|
59
|
+
console.log(e, this.viewedNotifications);
|
|
60
|
+
if (e === IntersectionStatus.Visible) {
|
|
61
|
+
if (mo.Unread) {
|
|
62
|
+
this.viewedNotifications = [...this.viewedNotifications.filter((c) => c.Unread), mo];
|
|
63
|
+
this.viewed.emit(this.viewedNotifications);
|
|
64
|
+
}
|
|
65
|
+
if (isLast) {
|
|
66
|
+
this.loadMore.emit();
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
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 });
|
|
73
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: NotificationGroupComponent, decorators: [{
|
|
74
|
+
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 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"] }]
|
|
76
|
+
}], ctorParameters: function () { return [{ type: i1.GroupByPipe }]; }, propDecorators: { notifications: [{
|
|
77
|
+
type: Input
|
|
78
|
+
}], loading: [{
|
|
79
|
+
type: Input
|
|
80
|
+
}], notificationCount: [{
|
|
81
|
+
type: Input
|
|
82
|
+
}], viewed: [{
|
|
83
|
+
type: Output
|
|
84
|
+
}], remove: [{
|
|
85
|
+
type: Output
|
|
86
|
+
}], actionClick: [{
|
|
87
|
+
type: Output
|
|
88
|
+
}], show: [{
|
|
89
|
+
type: Output
|
|
90
|
+
}], loadMore: [{
|
|
91
|
+
type: Output
|
|
92
|
+
}] } });
|
|
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"]}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import { BaseComponent } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "@fundamental-ngx/core/notification";
|
|
6
|
+
import * as i3 from "barsa-novin-ray-core";
|
|
7
|
+
export class NotificationGroupHeaderComponent extends BaseComponent {
|
|
8
|
+
constructor(_cdr) {
|
|
9
|
+
super();
|
|
10
|
+
this._cdr = _cdr;
|
|
11
|
+
this.unreadCount = 0;
|
|
12
|
+
}
|
|
13
|
+
ngOnInit() {
|
|
14
|
+
super.ngOnInit();
|
|
15
|
+
this.setUnreadCount(this.notifications);
|
|
16
|
+
}
|
|
17
|
+
ngOnChanges(changes) {
|
|
18
|
+
super.ngOnChanges(changes);
|
|
19
|
+
const { notifications } = changes;
|
|
20
|
+
if (notifications && !notifications.firstChange) {
|
|
21
|
+
this.setUnreadCount(notifications.currentValue);
|
|
22
|
+
this._cdr.detectChanges();
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
setUnreadCount(notifications) {
|
|
26
|
+
this.unreadCount = notifications.filter((c) => c.Unread).length;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
NotificationGroupHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: NotificationGroupHeaderComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
30
|
+
NotificationGroupHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: NotificationGroupHeaderComponent, selector: "bt-notification-group-header", inputs: { notifications: "notifications", title: "title" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<h2 fd-notification-title [unread]=\"false\">\r\n {{ title | bbbTranslate }} ({{ notifications.length }})\r\n <strong *ngIf=\"unreadCount !== 0\">{{ 'New' | bbbTranslate }} ({{ unreadCount }})</strong>\r\n</h2>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NotificationTitleDirective, selector: "[fdNotificationTitle], [fd-notification-title]", inputs: ["unread"] }, { kind: "pipe", type: i3.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: NotificationGroupHeaderComponent, decorators: [{
|
|
32
|
+
type: Component,
|
|
33
|
+
args: [{ selector: 'bt-notification-group-header', changeDetection: ChangeDetectionStrategy.OnPush, template: "<h2 fd-notification-title [unread]=\"false\">\r\n {{ title | bbbTranslate }} ({{ notifications.length }})\r\n <strong *ngIf=\"unreadCount !== 0\">{{ 'New' | bbbTranslate }} ({{ unreadCount }})</strong>\r\n</h2>\r\n" }]
|
|
34
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { notifications: [{
|
|
35
|
+
type: Input
|
|
36
|
+
}], title: [{
|
|
37
|
+
type: Input
|
|
38
|
+
}] } });
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9uLWdyb3VwLWhlYWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS10aWxlcy9zcmMvbGliL25vdGlmaWNhdGlvbi1ncm91cC1oZWFkZXIvbm90aWZpY2F0aW9uLWdyb3VwLWhlYWRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS10aWxlcy9zcmMvbGliL25vdGlmaWNhdGlvbi1ncm91cC1oZWFkZXIvbm90aWZpY2F0aW9uLWdyb3VwLWhlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsdUJBQXVCLEVBRXZCLFNBQVMsRUFDVCxLQUFLLEVBSVIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDOzs7OztBQVNyRCxNQUFNLE9BQU8sZ0NBQWlDLFNBQVEsYUFBYTtJQUkvRCxZQUFvQixJQUF1QjtRQUN2QyxLQUFLLEVBQUUsQ0FBQztRQURRLFNBQUksR0FBSixJQUFJLENBQW1CO1FBRDNDLGdCQUFXLEdBQUcsQ0FBQyxDQUFDO0lBR2hCLENBQUM7SUFFRCxRQUFRO1FBQ0osS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFDRCxXQUFXLENBQUMsT0FBc0I7UUFDOUIsS0FBSyxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUMzQixNQUFNLEVBQUUsYUFBYSxFQUFFLEdBQUcsT0FBTyxDQUFDO1FBQ2xDLElBQUksYUFBYSxJQUFJLENBQUMsYUFBYSxDQUFDLFdBQVcsRUFBRTtZQUM3QyxJQUFJLENBQUMsY0FBYyxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUNoRCxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1NBQzdCO0lBQ0wsQ0FBQztJQUNPLGNBQWMsQ0FBQyxhQUFpQztRQUNwRCxJQUFJLENBQUMsV0FBVyxHQUFHLGFBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxNQUFNLENBQUM7SUFDcEUsQ0FBQzs7NkhBdEJRLGdDQUFnQztpSEFBaEMsZ0NBQWdDLDRLQ2xCN0MsOE5BSUE7MkZEY2EsZ0NBQWdDO2tCQU41QyxTQUFTOytCQUNJLDhCQUE4QixtQkFHdkIsdUJBQXVCLENBQUMsTUFBTTt3R0FHdEMsYUFBYTtzQkFBckIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXHJcbiAgICBDaGFuZ2VEZXRlY3RvclJlZixcclxuICAgIENvbXBvbmVudCxcclxuICAgIElucHV0LFxyXG4gICAgT25DaGFuZ2VzLFxyXG4gICAgT25Jbml0LFxyXG4gICAgU2ltcGxlQ2hhbmdlc1xyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBCYXNlQ29tcG9uZW50IH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xyXG5pbXBvcnQgeyBOb3RpZmljYXRpb25JdGVtIH0gZnJvbSAnLi4vbW9kZWxzL25vdGlmaWNhdGlvbi1pdGVtJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdidC1ub3RpZmljYXRpb24tZ3JvdXAtaGVhZGVyJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9ub3RpZmljYXRpb24tZ3JvdXAtaGVhZGVyLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL25vdGlmaWNhdGlvbi1ncm91cC1oZWFkZXIuY29tcG9uZW50LnNjc3MnXSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBOb3RpZmljYXRpb25Hcm91cEhlYWRlckNvbXBvbmVudCBleHRlbmRzIEJhc2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uQ2hhbmdlcyB7XHJcbiAgICBASW5wdXQoKSBub3RpZmljYXRpb25zOiBOb3RpZmljYXRpb25JdGVtW107XHJcbiAgICBASW5wdXQoKSB0aXRsZTogc3RyaW5nO1xyXG4gICAgdW5yZWFkQ291bnQgPSAwO1xyXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBfY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge1xyXG4gICAgICAgIHN1cGVyKCk7XHJcbiAgICB9XHJcblxyXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcclxuICAgICAgICB0aGlzLnNldFVucmVhZENvdW50KHRoaXMubm90aWZpY2F0aW9ucyk7XHJcbiAgICB9XHJcbiAgICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XHJcbiAgICAgICAgc3VwZXIubmdPbkNoYW5nZXMoY2hhbmdlcyk7XHJcbiAgICAgICAgY29uc3QgeyBub3RpZmljYXRpb25zIH0gPSBjaGFuZ2VzO1xyXG4gICAgICAgIGlmIChub3RpZmljYXRpb25zICYmICFub3RpZmljYXRpb25zLmZpcnN0Q2hhbmdlKSB7XHJcbiAgICAgICAgICAgIHRoaXMuc2V0VW5yZWFkQ291bnQobm90aWZpY2F0aW9ucy5jdXJyZW50VmFsdWUpO1xyXG4gICAgICAgICAgICB0aGlzLl9jZHIuZGV0ZWN0Q2hhbmdlcygpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIHByaXZhdGUgc2V0VW5yZWFkQ291bnQobm90aWZpY2F0aW9uczogTm90aWZpY2F0aW9uSXRlbVtdKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy51bnJlYWRDb3VudCA9IG5vdGlmaWNhdGlvbnMuZmlsdGVyKChjKSA9PiBjLlVucmVhZCkubGVuZ3RoO1xyXG4gICAgfVxyXG59XHJcbiIsIjxoMiBmZC1ub3RpZmljYXRpb24tdGl0bGUgW3VucmVhZF09XCJmYWxzZVwiPlxyXG4gICAge3sgdGl0bGUgfCBiYmJUcmFuc2xhdGUgfX0gKHt7IG5vdGlmaWNhdGlvbnMubGVuZ3RoIH19KVxyXG4gICAgPHN0cm9uZyAqbmdJZj1cInVucmVhZENvdW50ICE9PSAwXCI+e3sgJ05ldycgfCBiYmJUcmFuc2xhdGUgfX0gKHt7IHVucmVhZENvdW50IH19KTwvc3Ryb25nPlxyXG48L2gyPlxyXG4iXX0=
|