barsa-tiles 1.0.307 → 1.0.309
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.
|
@@ -85,10 +85,10 @@ export class NotificationGroupComponent extends BaseComponent {
|
|
|
85
85
|
}
|
|
86
86
|
}
|
|
87
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\">\
|
|
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\">\n <ng-container>\n <fd-notification-group>\n <fd-tab-list size=\"s\">\n <fd-tab\n [title]=\"tab.title | bbbTranslate\"\n *ngFor=\"let tab of tabList; let index = index; trackBy: _trackByTitle\"\n >\n <fd-notification-group-list\n *ngFor=\"let groupItem of tab.groupByItems; let index = index; trackBy: _trackByKey\"\n >\n <fd-notification-group-header [(expanded)]=\"expanded[groupItem.key]\">\n <fd-notification-header>\n <bt-notification-group-header\n [notifications]=\"groupItem.value\"\n [title]=\"groupItem.key\"\n ></bt-notification-group-header>\n </fd-notification-header>\n <fd-notification-actions>\n <!-- <button fd-button label=\"Accept All\"></button> -->\n <button\n fd-button\n fdType=\"transparent\"\n [ariaLabel]=\"'DeleteAll' | bbbTranslate\"\n [title]=\"'DeleteAll' | bbbTranslate\"\n glyph=\"decline\"\n (click)=\"remove.emit({ items: groupItem.value, silent: false })\"\n ></button>\n </fd-notification-actions>\n </fd-notification-group-header>\n <ng-container\n *ngTemplateOutlet=\"\n notificationBody;\n context: { $implicit: groupItem.value, expanded: expanded[groupItem.key] }\n \"\n ></ng-container>\n <!-- <fd-notification-limit *ngIf=\"groupItem.value.length - 4 > 0\">\n <h1 fd-notification-limit-title>\n There are {{ groupItem.value.length - 4 }} more notifications\n </h1>\n <p fd-notification-limit-description>\n You need to close or take action on the listed notifications to display more.\n </p>\n </fd-notification-limit> -->\n </fd-notification-group-list>\n </fd-tab>\n </fd-tab-list>\n </fd-notification-group>\n </ng-container>\n</ng-container>\n<ng-template #noData>\n <bsu-no-data *ngIf=\"!loading; else loadingTpl\"></bsu-no-data>\n</ng-template>\n<ng-template #loadingTpl>\n <div style=\"height: 30px; position: relative\">\n <bsu-mask [marginTop]=\"'10px'\"></bsu-mask>\n </div>\n</ng-template>\n<ng-template #notificationItem> </ng-template>\n\n<ng-template #notificationBody let-notifications let-exapanded=\"expanded\">\n <div style=\"max-height: 346px; overflow-y: auto\">\n <ng-container *ngFor=\"let mo of notifications; trackBy: _trackMoById; let first = first; let last = last\">\n <bsu-notification-item\n [notificationItem]=\"mo\"\n (viewed)=\"viewed.emit($event)\"\n (remove)=\"remove.emit($event)\"\n (show)=\"show.emit($event)\"\n (actionClick)=\"actionClick.emit($event)\"\n intersectionObserver\n [intersectionThreshold]=\"0.5\"\n (visibilityChange)=\"onVisibilityChange($event, mo, last)\"\n ></bsu-notification-item>\n </ng-container>\n <ng-container *ngIf=\"loading\">\n <ng-container *ngTemplateOutlet=\"loadingTpl\"></ng-container>\n </ng-container>\n </div>\n</ng-template>\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 });
|
|
89
89
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: NotificationGroupComponent, decorators: [{
|
|
90
90
|
type: Component,
|
|
91
|
-
args: [{ selector: 'bt-notification-group', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"notifications && notifications.length > 0; else noData\">\
|
|
91
|
+
args: [{ selector: 'bt-notification-group', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"notifications && notifications.length > 0; else noData\">\n <ng-container>\n <fd-notification-group>\n <fd-tab-list size=\"s\">\n <fd-tab\n [title]=\"tab.title | bbbTranslate\"\n *ngFor=\"let tab of tabList; let index = index; trackBy: _trackByTitle\"\n >\n <fd-notification-group-list\n *ngFor=\"let groupItem of tab.groupByItems; let index = index; trackBy: _trackByKey\"\n >\n <fd-notification-group-header [(expanded)]=\"expanded[groupItem.key]\">\n <fd-notification-header>\n <bt-notification-group-header\n [notifications]=\"groupItem.value\"\n [title]=\"groupItem.key\"\n ></bt-notification-group-header>\n </fd-notification-header>\n <fd-notification-actions>\n <!-- <button fd-button label=\"Accept All\"></button> -->\n <button\n fd-button\n fdType=\"transparent\"\n [ariaLabel]=\"'DeleteAll' | bbbTranslate\"\n [title]=\"'DeleteAll' | bbbTranslate\"\n glyph=\"decline\"\n (click)=\"remove.emit({ items: groupItem.value, silent: false })\"\n ></button>\n </fd-notification-actions>\n </fd-notification-group-header>\n <ng-container\n *ngTemplateOutlet=\"\n notificationBody;\n context: { $implicit: groupItem.value, expanded: expanded[groupItem.key] }\n \"\n ></ng-container>\n <!-- <fd-notification-limit *ngIf=\"groupItem.value.length - 4 > 0\">\n <h1 fd-notification-limit-title>\n There are {{ groupItem.value.length - 4 }} more notifications\n </h1>\n <p fd-notification-limit-description>\n You need to close or take action on the listed notifications to display more.\n </p>\n </fd-notification-limit> -->\n </fd-notification-group-list>\n </fd-tab>\n </fd-tab-list>\n </fd-notification-group>\n </ng-container>\n</ng-container>\n<ng-template #noData>\n <bsu-no-data *ngIf=\"!loading; else loadingTpl\"></bsu-no-data>\n</ng-template>\n<ng-template #loadingTpl>\n <div style=\"height: 30px; position: relative\">\n <bsu-mask [marginTop]=\"'10px'\"></bsu-mask>\n </div>\n</ng-template>\n<ng-template #notificationItem> </ng-template>\n\n<ng-template #notificationBody let-notifications let-exapanded=\"expanded\">\n <div style=\"max-height: 346px; overflow-y: auto\">\n <ng-container *ngFor=\"let mo of notifications; trackBy: _trackMoById; let first = first; let last = last\">\n <bsu-notification-item\n [notificationItem]=\"mo\"\n (viewed)=\"viewed.emit($event)\"\n (remove)=\"remove.emit($event)\"\n (show)=\"show.emit($event)\"\n (actionClick)=\"actionClick.emit($event)\"\n intersectionObserver\n [intersectionThreshold]=\"0.5\"\n (visibilityChange)=\"onVisibilityChange($event, mo, last)\"\n ></bsu-notification-item>\n </ng-container>\n <ng-container *ngIf=\"loading\">\n <ng-container *ngTemplateOutlet=\"loadingTpl\"></ng-container>\n </ng-container>\n </div>\n</ng-template>\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
92
|
}], ctorParameters: function () { return [{ type: i1.GroupByPipe }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { notifications: [{
|
|
93
93
|
type: Input
|
|
94
94
|
}], loading: [{
|
|
@@ -106,4 +106,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
|
|
|
106
106
|
}], loadMore: [{
|
|
107
107
|
type: Output
|
|
108
108
|
}] } });
|
|
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"]}
|
|
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\">\n    <ng-container>\n        <fd-notification-group>\n            <fd-tab-list size=\"s\">\n                <fd-tab\n                    [title]=\"tab.title | bbbTranslate\"\n                    *ngFor=\"let tab of tabList; let index = index; trackBy: _trackByTitle\"\n                >\n                    <fd-notification-group-list\n                        *ngFor=\"let groupItem of tab.groupByItems; let index = index; trackBy: _trackByKey\"\n                    >\n                        <fd-notification-group-header [(expanded)]=\"expanded[groupItem.key]\">\n                            <fd-notification-header>\n                                <bt-notification-group-header\n                                    [notifications]=\"groupItem.value\"\n                                    [title]=\"groupItem.key\"\n                                ></bt-notification-group-header>\n                            </fd-notification-header>\n                            <fd-notification-actions>\n                                <!-- <button fd-button label=\"Accept All\"></button> -->\n                                <button\n                                    fd-button\n                                    fdType=\"transparent\"\n                                    [ariaLabel]=\"'DeleteAll' | bbbTranslate\"\n                                    [title]=\"'DeleteAll' | bbbTranslate\"\n                                    glyph=\"decline\"\n                                    (click)=\"remove.emit({ items: groupItem.value, silent: false })\"\n                                ></button>\n                            </fd-notification-actions>\n                        </fd-notification-group-header>\n                        <ng-container\n                            *ngTemplateOutlet=\"\n                                notificationBody;\n                                context: { $implicit: groupItem.value, expanded: expanded[groupItem.key] }\n                            \"\n                        ></ng-container>\n                        <!-- <fd-notification-limit *ngIf=\"groupItem.value.length - 4 > 0\">\n                            <h1 fd-notification-limit-title>\n                                There are {{ groupItem.value.length - 4 }} more notifications\n                            </h1>\n                            <p fd-notification-limit-description>\n                                You need to close or take action on the listed notifications to display more.\n                            </p>\n                        </fd-notification-limit> -->\n                    </fd-notification-group-list>\n                </fd-tab>\n            </fd-tab-list>\n        </fd-notification-group>\n    </ng-container>\n</ng-container>\n<ng-template #noData>\n    <bsu-no-data *ngIf=\"!loading; else loadingTpl\"></bsu-no-data>\n</ng-template>\n<ng-template #loadingTpl>\n    <div style=\"height: 30px; position: relative\">\n        <bsu-mask [marginTop]=\"'10px'\"></bsu-mask>\n    </div>\n</ng-template>\n<ng-template #notificationItem> </ng-template>\n\n<ng-template #notificationBody let-notifications let-exapanded=\"expanded\">\n    <div style=\"max-height: 346px; overflow-y: auto\">\n        <ng-container *ngFor=\"let mo of notifications; trackBy: _trackMoById; let first = first; let last = last\">\n            <bsu-notification-item\n                [notificationItem]=\"mo\"\n                (viewed)=\"viewed.emit($event)\"\n                (remove)=\"remove.emit($event)\"\n                (show)=\"show.emit($event)\"\n                (actionClick)=\"actionClick.emit($event)\"\n                intersectionObserver\n                [intersectionThreshold]=\"0.5\"\n                (visibilityChange)=\"onVisibilityChange($event, mo, last)\"\n            ></bsu-notification-item>\n        </ng-container>\n        <ng-container *ngIf=\"loading\">\n            <ng-container *ngTemplateOutlet=\"loadingTpl\"></ng-container>\n        </ng-container>\n    </div>\n</ng-template>\n"]}
|
package/fesm2015/barsa-tiles.mjs
CHANGED
|
@@ -2189,10 +2189,10 @@ class NotificationGroupComponent extends BaseComponent {
|
|
|
2189
2189
|
}
|
|
2190
2190
|
}
|
|
2191
2191
|
NotificationGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: NotificationGroupComponent, deps: [{ token: i1$2.GroupByPipe }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
2192
|
-
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\">\
|
|
2192
|
+
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\">\n <ng-container>\n <fd-notification-group>\n <fd-tab-list size=\"s\">\n <fd-tab\n [title]=\"tab.title | bbbTranslate\"\n *ngFor=\"let tab of tabList; let index = index; trackBy: _trackByTitle\"\n >\n <fd-notification-group-list\n *ngFor=\"let groupItem of tab.groupByItems; let index = index; trackBy: _trackByKey\"\n >\n <fd-notification-group-header [(expanded)]=\"expanded[groupItem.key]\">\n <fd-notification-header>\n <bt-notification-group-header\n [notifications]=\"groupItem.value\"\n [title]=\"groupItem.key\"\n ></bt-notification-group-header>\n </fd-notification-header>\n <fd-notification-actions>\n <!-- <button fd-button label=\"Accept All\"></button> -->\n <button\n fd-button\n fdType=\"transparent\"\n [ariaLabel]=\"'DeleteAll' | bbbTranslate\"\n [title]=\"'DeleteAll' | bbbTranslate\"\n glyph=\"decline\"\n (click)=\"remove.emit({ items: groupItem.value, silent: false })\"\n ></button>\n </fd-notification-actions>\n </fd-notification-group-header>\n <ng-container\n *ngTemplateOutlet=\"\n notificationBody;\n context: { $implicit: groupItem.value, expanded: expanded[groupItem.key] }\n \"\n ></ng-container>\n <!-- <fd-notification-limit *ngIf=\"groupItem.value.length - 4 > 0\">\n <h1 fd-notification-limit-title>\n There are {{ groupItem.value.length - 4 }} more notifications\n </h1>\n <p fd-notification-limit-description>\n You need to close or take action on the listed notifications to display more.\n </p>\n </fd-notification-limit> -->\n </fd-notification-group-list>\n </fd-tab>\n </fd-tab-list>\n </fd-notification-group>\n </ng-container>\n</ng-container>\n<ng-template #noData>\n <bsu-no-data *ngIf=\"!loading; else loadingTpl\"></bsu-no-data>\n</ng-template>\n<ng-template #loadingTpl>\n <div style=\"height: 30px; position: relative\">\n <bsu-mask [marginTop]=\"'10px'\"></bsu-mask>\n </div>\n</ng-template>\n<ng-template #notificationItem> </ng-template>\n\n<ng-template #notificationBody let-notifications let-exapanded=\"expanded\">\n <div style=\"max-height: 346px; overflow-y: auto\">\n <ng-container *ngFor=\"let mo of notifications; trackBy: _trackMoById; let first = first; let last = last\">\n <bsu-notification-item\n [notificationItem]=\"mo\"\n (viewed)=\"viewed.emit($event)\"\n (remove)=\"remove.emit($event)\"\n (show)=\"show.emit($event)\"\n (actionClick)=\"actionClick.emit($event)\"\n intersectionObserver\n [intersectionThreshold]=\"0.5\"\n (visibilityChange)=\"onVisibilityChange($event, mo, last)\"\n ></bsu-notification-item>\n </ng-container>\n <ng-container *ngIf=\"loading\">\n <ng-container *ngTemplateOutlet=\"loadingTpl\"></ng-container>\n </ng-container>\n </div>\n</ng-template>\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: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2$1.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i4$2.NotificationHeaderComponent, selector: "fd-notification-header", inputs: ["uniqueId"] }, { kind: "component", type: i4$2.NotificationActionsComponent, selector: "fd-notification-actions" }, { kind: "component", type: i4$2.NotificationGroupHeaderComponent, selector: "fd-notification-group-header", inputs: ["expandCompact", "expandAriaLabel", "expandAriaLabelledBy", "expanded"], outputs: ["expandedChange"] }, { kind: "component", type: i4$2.NotificationGroupComponent, selector: "fd-notification-group", inputs: ["class", "mobile", "width"] }, { kind: "component", type: i4$2.NotificationGroupListComponent, selector: "fd-notification-group-list" }, { kind: "component", type: i8$2.TabListComponent, selector: "fd-tab-list", inputs: ["size", "mode", "collapseOverflow", "maxVisibleTabs", "stackContent", "maxContentHeight", "collapsibleTabs", "expandOverflowText", "defaultTab", "selectDefaultOnTabsChange"], outputs: ["selectedTabChange", "visibleItemsCount", "hiddenItemsCount"] }, { kind: "component", type: i8$2.TabPanelComponent, selector: "fd-tab", inputs: ["id", "ariaLabel", "ariaLabelledBy", "title", "count", "glyph", "header", "disabled", "tabState"], outputs: ["opened", "closed"] }, { kind: "directive", type: i1$2.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: NotificationGroupHeaderComponent, selector: "bt-notification-group-header", inputs: ["notifications", "title"] }, { kind: "pipe", type: i1$2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
2193
2193
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: NotificationGroupComponent, decorators: [{
|
|
2194
2194
|
type: Component,
|
|
2195
|
-
args: [{ selector: 'bt-notification-group', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"notifications && notifications.length > 0; else noData\">\
|
|
2195
|
+
args: [{ selector: 'bt-notification-group', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"notifications && notifications.length > 0; else noData\">\n <ng-container>\n <fd-notification-group>\n <fd-tab-list size=\"s\">\n <fd-tab\n [title]=\"tab.title | bbbTranslate\"\n *ngFor=\"let tab of tabList; let index = index; trackBy: _trackByTitle\"\n >\n <fd-notification-group-list\n *ngFor=\"let groupItem of tab.groupByItems; let index = index; trackBy: _trackByKey\"\n >\n <fd-notification-group-header [(expanded)]=\"expanded[groupItem.key]\">\n <fd-notification-header>\n <bt-notification-group-header\n [notifications]=\"groupItem.value\"\n [title]=\"groupItem.key\"\n ></bt-notification-group-header>\n </fd-notification-header>\n <fd-notification-actions>\n <!-- <button fd-button label=\"Accept All\"></button> -->\n <button\n fd-button\n fdType=\"transparent\"\n [ariaLabel]=\"'DeleteAll' | bbbTranslate\"\n [title]=\"'DeleteAll' | bbbTranslate\"\n glyph=\"decline\"\n (click)=\"remove.emit({ items: groupItem.value, silent: false })\"\n ></button>\n </fd-notification-actions>\n </fd-notification-group-header>\n <ng-container\n *ngTemplateOutlet=\"\n notificationBody;\n context: { $implicit: groupItem.value, expanded: expanded[groupItem.key] }\n \"\n ></ng-container>\n <!-- <fd-notification-limit *ngIf=\"groupItem.value.length - 4 > 0\">\n <h1 fd-notification-limit-title>\n There are {{ groupItem.value.length - 4 }} more notifications\n </h1>\n <p fd-notification-limit-description>\n You need to close or take action on the listed notifications to display more.\n </p>\n </fd-notification-limit> -->\n </fd-notification-group-list>\n </fd-tab>\n </fd-tab-list>\n </fd-notification-group>\n </ng-container>\n</ng-container>\n<ng-template #noData>\n <bsu-no-data *ngIf=\"!loading; else loadingTpl\"></bsu-no-data>\n</ng-template>\n<ng-template #loadingTpl>\n <div style=\"height: 30px; position: relative\">\n <bsu-mask [marginTop]=\"'10px'\"></bsu-mask>\n </div>\n</ng-template>\n<ng-template #notificationItem> </ng-template>\n\n<ng-template #notificationBody let-notifications let-exapanded=\"expanded\">\n <div style=\"max-height: 346px; overflow-y: auto\">\n <ng-container *ngFor=\"let mo of notifications; trackBy: _trackMoById; let first = first; let last = last\">\n <bsu-notification-item\n [notificationItem]=\"mo\"\n (viewed)=\"viewed.emit($event)\"\n (remove)=\"remove.emit($event)\"\n (show)=\"show.emit($event)\"\n (actionClick)=\"actionClick.emit($event)\"\n intersectionObserver\n [intersectionThreshold]=\"0.5\"\n (visibilityChange)=\"onVisibilityChange($event, mo, last)\"\n ></bsu-notification-item>\n </ng-container>\n <ng-container *ngIf=\"loading\">\n <ng-container *ngTemplateOutlet=\"loadingTpl\"></ng-container>\n </ng-container>\n </div>\n</ng-template>\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"] }]
|
|
2196
2196
|
}], ctorParameters: function () { return [{ type: i1$2.GroupByPipe }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { notifications: [{
|
|
2197
2197
|
type: Input
|
|
2198
2198
|
}], loading: [{
|