barsa-tiles 2.0.11 → 2.0.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/barsa-shellbar/barsa-shellbar.component.mjs +1 -1
- package/esm2022/lib/popover-app-finder/popover-app-finder.component.mjs +3 -13
- package/esm2022/lib/shellbar/shellbar.component.mjs +17 -8
- package/fesm2022/barsa-tiles.mjs +156 -147
- package/fesm2022/barsa-tiles.mjs.map +1 -1
- package/lib/barsa-shellbar/barsa-shellbar.component.d.ts +1 -1
- package/lib/shellbar/shellbar.component.d.ts +2 -0
- package/package.json +1 -1
|
@@ -195,4 +195,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
|
|
|
195
195
|
type: ViewChild,
|
|
196
196
|
args: ['notificationsDialog', { static: true, read: TemplateRef }]
|
|
197
197
|
}] } });
|
|
198
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-shellbar.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-tiles/src/lib/barsa-shellbar/barsa-shellbar.component.ts","../../../../../projects/barsa-tiles/src/lib/barsa-shellbar/barsa-shellbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    inject,\n    Inject,\n    Input,\n    OnInit,\n    Output,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { Observable, Subject } from 'rxjs';\nimport {\n    ComboboxComponent,\n    DialogService,\n    PopoverComponent,\n    ProductSwitchItem,\n    ShellbarMenuItem,\n    ShellbarUser\n} from '@fundamental-ngx/core';\n\nimport {\n    BaseComponent,\n    MetaobjectDataModel,\n    FilePictureInfoModel,\n    MoForReportModel,\n    APP_VERSION,\n    NotificationService,\n    NotificationItem,\n    NotificationAction,\n    AbbrevationDeviceSize\n} from 'barsa-novin-ray-core';\nimport { SafeResourceUrl } from '@angular/platform-browser';\ninterface ShellbarSetting extends MetaobjectDataModel {\n    subtitle: string;\n    calcSubtitle: string;\n    logo: FilePictureInfoModel;\n    ProductSwitchItems: MoForReportModel;\n    ProductMenuItems: MoForReportModel;\n    UserMenuItems: MoForReportModel;\n    ActionItems: MoForReportModel;\n}\n\n@Component({\n    selector: 'bt-barsa-shellbar',\n    templateUrl: './barsa-shellbar.component.html',\n    styleUrls: ['./barsa-shellbar.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BarsaShellbarComponent extends BaseComponent implements OnInit {\n    @Input() cssCustomUrl: SafeResourceUrl | null;\n    @Input() cssUrl: SafeResourceUrl | null;\n    @Input() allowAnonymous: boolean;\n    @Input() multiLanguages: boolean;\n    @Input() userLoggedIn: boolean;\n    @Input() settings: MetaobjectDataModel;\n    @Input() productMenuControl: string;\n    @Input() deviceSize: AbbrevationDeviceSize;\n    @Input() cultures: Record<string, any>;\n    @Input() shellbarData: ShellbarSetting;\n    @Input() notificationCount: { unread: number; all: number };\n    @Input() notifcationLoaded: boolean;\n    @Input() notificationLoading: boolean;\n    @Input() notifications: NotificationItem[];\n    @Input() productMenuItems1: ShellbarMenuItem[];\n    @Input() bodyClick: string;\n    @Input() logo: { FileId: string };\n    @Input() actions: Array<MetaobjectDataModel>;\n    @Input() userMenu: { text: string; callback: () => void }[];\n    @Input() productSwitcher: ProductSwitchItem[];\n    @Input() subtitle: string;\n    @Input() isMobile: boolean;\n    @Input() hideShellbarActions: boolean;\n    @Input() showExtraButton: boolean;\n    @Input() isTablet: boolean;\n    @Input() isDesktop: boolean;\n    @Input() isServiceDesk = false;\n    @Input() isOpenQuickAccess;\n    @Input() sideMenuTemplate: TemplateRef<any>;\n\n    @Output() isOpenQuickAccessChanged = new EventEmitter<boolean>(false);\n    @Output() openNotificationPanel = new EventEmitter<void>();\n    @Output() openQuickAccessPanel = new EventEmitter<void>();\n    @Output() cultureChanged = new EventEmitter<string>();\n    @Output() notificationLoadMore = new EventEmitter<void>();\n    @Output() removeNotification = new EventEmitter<{ items: MetaobjectDataModel[]; silent: boolean }>();\n    @Output() notifiationActionClick = new EventEmitter<{ item: NotificationItem; btn: NotificationAction }>();\n    @Output() notificationViewed = new EventEmitter<NotificationItem>();\n\n    @ViewChild(ComboboxComponent) comboboxComponent: ComboboxComponent;\n    @ViewChild('popoverComponent', { static: false }) popoverComponent: PopoverComponent;\n    @ViewChild('notificationsDialog', { static: true, read: TemplateRef }) _notificationsDialog: TemplateRef<any>;\n\n    private _cdr = inject(ChangeDetectorRef);\n\n    Array = Array;\n    isOpenNotificatoin = false;\n\n    user: ShellbarUser = {\n        initials: 'WW',\n        colorAccent: 1\n    };\n    searchTerms = ['مرخصی', 'ماموریت', 'تیکت', 'پروژه'];\n    searchTerm: string;\n    actions$: Observable<ShellbarMenuItem[]>;\n\n    showVersion = false;\n\n    _viewedNotifications$ = new Subject<NotificationItem>();\n    onBellNotification = (): void => {\n        this._document?.body && this._document.body.click();\n        this._dialogService\n            .open(this._notificationsDialog, {\n                mobile: true,\n                verticalPadding: false,\n                closeOnNavigation: true\n            })\n            .afterLoaded.subscribe(() => {\n                this.openNotificationPanel.emit();\n            });\n    };\n    _viewedNotifications: NotificationItem[] = [];\n    constructor(\n        private _notificationService: NotificationService,\n        private _dialogService: DialogService,\n        @Inject(DOCUMENT) private _document: Document,\n        @Inject(APP_VERSION) public appVersion: string\n    ) {\n        super();\n        this.showVersion = false;\n        document.body.addEventListener('click', () => {\n            this.isOpenQuickAccessChanged.emit(false);\n            this._cdr.detectChanges();\n        });\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n    }\n\n    onCultureChange(culture): void {\n        this._changeCulture(culture);\n    }\n    onShowNotification(e: { tag: string; mo: MetaobjectDataModel; nama: string }): void {\n        this.isOpenNotificatoin = false;\n        this._notificationService.ShowNotificationRelatedMo(e);\n    }\n    onNotificationItemViewed(viewedMo: NotificationItem): void {\n        this.notificationViewed.emit(viewedMo);\n    }\n\n    onRemoveNotifications(e: { items: MetaobjectDataModel[]; silent: boolean }): void {\n        this.removeNotification.emit(e);\n    }\n    onOpenQuickAccess = (): void => {\n        this.isOpenQuickAccessChanged.emit(true);\n        this.openQuickAccessPanel.emit();\n    };\n    onOpenNotification = (): void => {\n        this.isOpenNotificatoin = true;\n        this.openNotificationPanel.emit();\n    };\n    onNotificationAction(e: { item: NotificationItem; btn: NotificationAction }): void {\n        this.notifiationActionClick.emit(e);\n    }\n    onLanguage = (e): void => {\n        const culture = e.currentTarget.textContent.trim();\n        this._changeCulture(culture);\n    };\n    onNotificationLoadMore(): void {\n        this.notificationLoadMore.emit();\n    }\n\n    private _changeCulture(culture: string): void {\n        this.cultureChanged.emit(culture);\n    }\n}\n","@if (cssUrl) {\n<link type=\"text/css\" rel=\"stylesheet\" [href]=\"cssUrl\" />\n} @if (cssCustomUrl) {\n<link type=\"text/css\" rel=\"stylesheet\" [href]=\"cssCustomUrl\" />\n} @if (userLoggedIn || allowAnonymous) {\n<fd-shellbar [size]=\"deviceSize\" [ngClass]=\"deviceSize\">\n    @if (sideMenuTemplate) {\n    <fd-shellbar-action\n        [glyph]=\"'apps'\"\n        [label]=\"'Quick Access' | bbbTranslate\"\n        [notificationCount]=\"notificationCount.unread ?? 0\"\n        [notificationLabel]=\"'Quick Access' | bbbTranslate\"\n        [callback]=\"onOpenQuickAccess\"\n    >\n    </fd-shellbar-action>\n    } @if (sideMenuTemplate) {\n    <button\n        fd-shellbar-side-nav\n        fd-button\n        fdType=\"transparent\"\n        glyph=\"menu2\"\n        style=\"width: 2.75rem\"\n        (click)=\"$event.stopPropagation(); isOpenQuickAccessChanged.emit(!isOpenQuickAccess)\"\n    ></button>\n    } @if (logo) {\n    <fd-shellbar-logo>\n        <a\n            [style.backgroundImage]=\"'url(' + (logo?.FileId | picFieldSrc: 'GetPictureFromFileInfo':null) + ')'\"\n            href=\"/\"\n            class=\"fd-shellbar__logo fd-shellbar__logo--image-replaced\"\n            aria-label=\"Barsa Novin Ray\"\n        ></a>\n    </fd-shellbar-logo>\n    } @if (!settings?.HideProductMenu && productMenuItems1 && productMenuItems1.length > 0) {\n    <fd-product-menu [control]=\"productMenuControl\" [closePopoverOnSelect]=\"true\" [items]=\"productMenuItems1\">\n    </fd-product-menu>\n    }\n    <fd-shellbar-subtitle> {{ subtitle | bbbTranslate }}{{ showVersion ? appVersion : '' }}</fd-shellbar-subtitle>\n    @if (!hideShellbarActions&& user && (userMenu?.length || !settings?.HideLanguage)) {\n    <fd-shellbar-actions [user]=\"user\" [userMenu]=\"userMenu\" #langRef>\n        @for (action of actions; track action) {\n        <fd-shellbar-action\n            [glyph]=\"action.Icon\"\n            [callback]=\"action.Callback\"\n            [label]=\"action.Label\"\n            notificationLabel=\"login\"\n        >\n        </fd-shellbar-action>\n        } @if (deviceSize === 's' && userLoggedIn && !settings?.HideNotifications) {\n        <fd-shellbar-action\n            [glyph]=\"'bell'\"\n            [label]=\"'Notifications' | bbbTranslate\"\n            [notificationCount]=\"notificationCount.unread ?? 0\"\n            [notificationLabel]=\"'Notifications' | bbbTranslate\"\n            [callback]=\"onBellNotification\"\n        >\n        </fd-shellbar-action>\n        } @if (!settings?.HideNotifications && userLoggedIn) {\n        <fd-popover\n            [(isOpen)]=\"isOpenNotificatoin\"\n            [triggers]=\"[]\"\n            [focusTrapped]=\"true\"\n            [noArrow]=\"true\"\n            placement=\"bottom\"\n            title=\"Notification Popover\"\n            [focusAutoCapture]=\"true\"\n            [mobile]=\"deviceSize === 's'\"\n            #popoverComponent\n        >\n            <fd-popover-control>\n                <fd-shellbar-action\n                    [glyph]=\"'bell'\"\n                    [label]=\"'Notification'\"\n                    [notificationCount]=\"notificationCount.unread\"\n                    [notificationLabel]=\"'Notification Label'\"\n                    [callback]=\"onOpenNotification\"\n                >\n                </fd-shellbar-action>\n            </fd-popover-control>\n            <fd-popover-body style=\"min-width: 320px; overflow-x: auto; box-shadow: var(--sapContent_Shadow0)\">\n                <ng-container\n                    *ngTemplateOutlet=\"notificationGroupTpl; context: { notificationCount: notificationCount }\"\n                ></ng-container>\n            </fd-popover-body>\n        </fd-popover>\n        } @if (!settings?.HideLanguage && deviceSize !== 's' && multiLanguages) {\n        <fd-shellbar-action [glyph]=\"'world'\" [label]=\"'language'\" [fdMenuTrigger]=\"menu\" (callback)=\"(onLanguage)\">\n        </fd-shellbar-action>\n        } @if (!settings?.HideLanguage && deviceSize === 's' && multiLanguages) { @for (culture of cultures | keyvalue;\n        track culture) {\n        <fd-shellbar-action\n            [label]=\"culture.value\"\n            [callback]=\"onLanguage\"\n            class=\"culture-abbrivation\"\n            [glyph]=\"culture.key\"\n            [ngClass]=\"'flags'\"\n        >\n        </fd-shellbar-action>\n        } } @if (productSwitcher?.length) {\n        <fd-product-switch>\n            <fd-product-switch-body [products]=\"productSwitcher\" [forceListMode]=\"deviceSize === 's'\">\n            </fd-product-switch-body>\n        </fd-product-switch>\n        }\n    </fd-shellbar-actions>\n    }\n</fd-shellbar>\n} @if(showExtraButton){\n<div\n    [class.fd-shellbar--xl]=\"isDesktop\"\n    [class.fd-shellbar--m]=\"isTablet\"\n    [class.fd-shellbar--s]=\"isMobile\"\n    class=\"extra-button-wrapper\"\n    [class.service-desk]=\"isServiceDesk\"\n>\n    <ng-content select=\"button\"></ng-content>\n</div>\n}\n<ng-template #loading>\n    <bsu-mask></bsu-mask>\n</ng-template>\n\n<div\n    *ngIf=\"sideMenuTemplate\"\n    class=\"tw-fixed tw-top-[38.5px] tw-h-[calc(100vh-38.5px)] tw-bg-white tw-transition-all tw-z-[100] tw-shadow-2xl tw-overflow-auto\"\n    [class.tw-w-screen]=\"isMobile\"\n    [class.-tw-right-full]=\"isMobile\"\n    [class.tw-w-96]=\"!isMobile\"\n    [class.-tw-right-96]=\"!isMobile\"\n    [class.!tw-right-0]=\"isOpenQuickAccess\"\n    (click)=\"$event.stopPropagation()\"\n>\n    <ng-container *ngTemplateOutlet=\"sideMenuTemplate\"></ng-container>\n</div>\n\n@if(isOpenQuickAccess) {\n<div\n    class=\"tw-fixed tw-right-0 tw-top-[38.5px] tw-h-[calc(100vh-38.5px)] tw-bg-slate-800/[.5] tw-z-[90] tw-w-screen tw-backdrop-blur-sm\"\n    (click)=\"isOpenQuickAccessChanged.emit(false)\"\n></div>\n}\n<fd-menu #menu>\n    <ul fd-list>\n        @for (culture of cultures | keyvalue; track culture) {\n        <li fd-list-item>\n            <a fd-list-link (click)=\"onCultureChange(culture.value)\">\n                <span fd-list-title>\n                    <img width=\"14px\" height=\"12px\" [src]=\"'/assets/flags/' + culture.key + '.png'\" />\n                    <span class=\"culture-abbrivation\" [ngClass]=\"culture.key\"> {{ culture.key }}</span>\n                </span>\n            </a>\n        </li>\n        }\n    </ul>\n</fd-menu>\n<ng-template #notificationGroupTpl let-notificationCount=\"notificationCount\">\n    @if (!notifcationLoaded && notificationLoading === true) {\n    <div style=\"position: relative; height: 100px\">\n        <bsu-mask size=\"s\"></bsu-mask>\n    </div>\n    }\n    <bt-notification-group\n        [notifications]=\"notifications\"\n        [notificationCount]=\"notificationCount\"\n        [loading]=\"notificationLoading === true\"\n        (viewed)=\"onNotificationItemViewed($event)\"\n        (remove)=\"onRemoveNotifications($event)\"\n        (showEvent)=\"popoverComponent.close(); onShowNotification($event)\"\n        (actionClick)=\"popoverComponent.close(); onNotificationAction($event)\"\n        (loadMore)=\"onNotificationLoadMore()\"\n        [deviceSize]=\"deviceSize\"\n    ></bt-notification-group>\n</ng-template>\n\n<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #notificationsDialog>\n    <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\">\n        <fd-dialog-header>\n            <h1 id=\"fd-dialog-header-10\" fd-title>{{ 'Notification' | bbbTranslate }}</h1>\n            <button fd-dialog-close-button (click)=\"dialog.dismiss()\"></button>\n        </fd-dialog-header>\n        <fd-dialog-body class=\"mobile\">\n            <ng-container\n                *ngTemplateOutlet=\"notificationGroupTpl; context: { notificationCount: notificationCount }\"\n            ></ng-container>\n        </fd-dialog-body>\n    </fd-dialog>\n</ng-template>\n"]}
|
|
198
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-shellbar.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-tiles/src/lib/barsa-shellbar/barsa-shellbar.component.ts","../../../../../projects/barsa-tiles/src/lib/barsa-shellbar/barsa-shellbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    inject,\n    Inject,\n    Input,\n    OnInit,\n    Output,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { Observable, Subject } from 'rxjs';\nimport {\n    ComboboxComponent,\n    DialogService,\n    PopoverComponent,\n    ProductSwitchItem,\n    ShellbarMenuItem,\n    ShellbarUser\n} from '@fundamental-ngx/core';\n\nimport {\n    BaseComponent,\n    MetaobjectDataModel,\n    FilePictureInfoModel,\n    MoForReportModel,\n    APP_VERSION,\n    NotificationService,\n    NotificationItem,\n    NotificationAction,\n    AbbrevationDeviceSize\n} from 'barsa-novin-ray-core';\nimport { SafeResourceUrl } from '@angular/platform-browser';\ninterface ShellbarSetting extends MetaobjectDataModel {\n    subtitle: string;\n    calcSubtitle: string;\n    logo: FilePictureInfoModel;\n    ProductSwitchItems: MoForReportModel;\n    ProductMenuItems: MoForReportModel;\n    UserMenuItems: MoForReportModel;\n    ActionItems: MoForReportModel;\n}\n\n@Component({\n    selector: 'bt-barsa-shellbar',\n    templateUrl: './barsa-shellbar.component.html',\n    styleUrls: ['./barsa-shellbar.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BarsaShellbarComponent extends BaseComponent implements OnInit {\n    @Input() cssCustomUrl: SafeResourceUrl | null;\n    @Input() cssUrl: SafeResourceUrl | null;\n    @Input() allowAnonymous: boolean;\n    @Input() multiLanguages: boolean;\n    @Input() userLoggedIn: boolean;\n    @Input() settings: MetaobjectDataModel;\n    @Input() productMenuControl: string;\n    @Input() deviceSize: AbbrevationDeviceSize;\n    @Input() cultures: Record<string, any>;\n    @Input() shellbarData: ShellbarSetting;\n    @Input() notificationCount: { unread: number; all: number };\n    @Input() notifcationLoaded: boolean;\n    @Input() notificationLoading: boolean;\n    @Input() notifications: NotificationItem[];\n    @Input() productMenuItems1: ShellbarMenuItem[];\n    @Input() bodyClick: string;\n    @Input() logo: { FileId: string };\n    @Input() actions: Array<MetaobjectDataModel>;\n    @Input() userMenu: { text: string; callback: () => void }[];\n    @Input() productSwitcher: ProductSwitchItem[];\n    @Input() subtitle: string;\n    @Input() isMobile: boolean;\n    @Input() hideShellbarActions: boolean;\n    @Input() showExtraButton: boolean;\n    @Input() isTablet: boolean;\n    @Input() isDesktop: boolean;\n    @Input() isServiceDesk = false;\n    @Input() isOpenQuickAccess;\n    @Input() sideMenuTemplate: TemplateRef<any> | null;\n\n    @Output() isOpenQuickAccessChanged = new EventEmitter<boolean>(false);\n    @Output() openNotificationPanel = new EventEmitter<void>();\n    @Output() openQuickAccessPanel = new EventEmitter<void>();\n    @Output() cultureChanged = new EventEmitter<string>();\n    @Output() notificationLoadMore = new EventEmitter<void>();\n    @Output() removeNotification = new EventEmitter<{ items: MetaobjectDataModel[]; silent: boolean }>();\n    @Output() notifiationActionClick = new EventEmitter<{ item: NotificationItem; btn: NotificationAction }>();\n    @Output() notificationViewed = new EventEmitter<NotificationItem>();\n\n    @ViewChild(ComboboxComponent) comboboxComponent: ComboboxComponent;\n    @ViewChild('popoverComponent', { static: false }) popoverComponent: PopoverComponent;\n    @ViewChild('notificationsDialog', { static: true, read: TemplateRef }) _notificationsDialog: TemplateRef<any>;\n\n    private _cdr = inject(ChangeDetectorRef);\n\n    Array = Array;\n    isOpenNotificatoin = false;\n\n    user: ShellbarUser = {\n        initials: 'WW',\n        colorAccent: 1\n    };\n    searchTerms = ['مرخصی', 'ماموریت', 'تیکت', 'پروژه'];\n    searchTerm: string;\n    actions$: Observable<ShellbarMenuItem[]>;\n\n    showVersion = false;\n\n    _viewedNotifications$ = new Subject<NotificationItem>();\n    onBellNotification = (): void => {\n        this._document?.body && this._document.body.click();\n        this._dialogService\n            .open(this._notificationsDialog, {\n                mobile: true,\n                verticalPadding: false,\n                closeOnNavigation: true\n            })\n            .afterLoaded.subscribe(() => {\n                this.openNotificationPanel.emit();\n            });\n    };\n    _viewedNotifications: NotificationItem[] = [];\n    constructor(\n        private _notificationService: NotificationService,\n        private _dialogService: DialogService,\n        @Inject(DOCUMENT) private _document: Document,\n        @Inject(APP_VERSION) public appVersion: string\n    ) {\n        super();\n        this.showVersion = false;\n        document.body.addEventListener('click', () => {\n            this.isOpenQuickAccessChanged.emit(false);\n            this._cdr.detectChanges();\n        });\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n    }\n\n    onCultureChange(culture): void {\n        this._changeCulture(culture);\n    }\n    onShowNotification(e: { tag: string; mo: MetaobjectDataModel; nama: string }): void {\n        this.isOpenNotificatoin = false;\n        this._notificationService.ShowNotificationRelatedMo(e);\n    }\n    onNotificationItemViewed(viewedMo: NotificationItem): void {\n        this.notificationViewed.emit(viewedMo);\n    }\n\n    onRemoveNotifications(e: { items: MetaobjectDataModel[]; silent: boolean }): void {\n        this.removeNotification.emit(e);\n    }\n    onOpenQuickAccess = (): void => {\n        this.isOpenQuickAccessChanged.emit(true);\n        this.openQuickAccessPanel.emit();\n    };\n    onOpenNotification = (): void => {\n        this.isOpenNotificatoin = true;\n        this.openNotificationPanel.emit();\n    };\n    onNotificationAction(e: { item: NotificationItem; btn: NotificationAction }): void {\n        this.notifiationActionClick.emit(e);\n    }\n    onLanguage = (e): void => {\n        const culture = e.currentTarget.textContent.trim();\n        this._changeCulture(culture);\n    };\n    onNotificationLoadMore(): void {\n        this.notificationLoadMore.emit();\n    }\n\n    private _changeCulture(culture: string): void {\n        this.cultureChanged.emit(culture);\n    }\n}\n","@if (cssUrl) {\n<link type=\"text/css\" rel=\"stylesheet\" [href]=\"cssUrl\" />\n} @if (cssCustomUrl) {\n<link type=\"text/css\" rel=\"stylesheet\" [href]=\"cssCustomUrl\" />\n} @if (userLoggedIn || allowAnonymous) {\n<fd-shellbar [size]=\"deviceSize\" [ngClass]=\"deviceSize\">\n    @if (sideMenuTemplate) {\n    <fd-shellbar-action\n        [glyph]=\"'apps'\"\n        [label]=\"'Quick Access' | bbbTranslate\"\n        [notificationCount]=\"notificationCount.unread ?? 0\"\n        [notificationLabel]=\"'Quick Access' | bbbTranslate\"\n        [callback]=\"onOpenQuickAccess\"\n    >\n    </fd-shellbar-action>\n    } @if (sideMenuTemplate) {\n    <button\n        fd-shellbar-side-nav\n        fd-button\n        fdType=\"transparent\"\n        glyph=\"menu2\"\n        style=\"width: 2.75rem\"\n        (click)=\"$event.stopPropagation(); isOpenQuickAccessChanged.emit(!isOpenQuickAccess)\"\n    ></button>\n    } @if (logo) {\n    <fd-shellbar-logo>\n        <a\n            [style.backgroundImage]=\"'url(' + (logo?.FileId | picFieldSrc: 'GetPictureFromFileInfo':null) + ')'\"\n            href=\"/\"\n            class=\"fd-shellbar__logo fd-shellbar__logo--image-replaced\"\n            aria-label=\"Barsa Novin Ray\"\n        ></a>\n    </fd-shellbar-logo>\n    } @if (!settings?.HideProductMenu && productMenuItems1 && productMenuItems1.length > 0) {\n    <fd-product-menu [control]=\"productMenuControl\" [closePopoverOnSelect]=\"true\" [items]=\"productMenuItems1\">\n    </fd-product-menu>\n    }\n    <fd-shellbar-subtitle> {{ subtitle | bbbTranslate }}{{ showVersion ? appVersion : '' }}</fd-shellbar-subtitle>\n    @if (!hideShellbarActions&& user && (userMenu?.length || !settings?.HideLanguage)) {\n    <fd-shellbar-actions [user]=\"user\" [userMenu]=\"userMenu\" #langRef>\n        @for (action of actions; track action) {\n        <fd-shellbar-action\n            [glyph]=\"action.Icon\"\n            [callback]=\"action.Callback\"\n            [label]=\"action.Label\"\n            notificationLabel=\"login\"\n        >\n        </fd-shellbar-action>\n        } @if (deviceSize === 's' && userLoggedIn && !settings?.HideNotifications) {\n        <fd-shellbar-action\n            [glyph]=\"'bell'\"\n            [label]=\"'Notifications' | bbbTranslate\"\n            [notificationCount]=\"notificationCount.unread ?? 0\"\n            [notificationLabel]=\"'Notifications' | bbbTranslate\"\n            [callback]=\"onBellNotification\"\n        >\n        </fd-shellbar-action>\n        } @if (!settings?.HideNotifications && userLoggedIn) {\n        <fd-popover\n            [(isOpen)]=\"isOpenNotificatoin\"\n            [triggers]=\"[]\"\n            [focusTrapped]=\"true\"\n            [noArrow]=\"true\"\n            placement=\"bottom\"\n            title=\"Notification Popover\"\n            [focusAutoCapture]=\"true\"\n            [mobile]=\"deviceSize === 's'\"\n            #popoverComponent\n        >\n            <fd-popover-control>\n                <fd-shellbar-action\n                    [glyph]=\"'bell'\"\n                    [label]=\"'Notification'\"\n                    [notificationCount]=\"notificationCount.unread\"\n                    [notificationLabel]=\"'Notification Label'\"\n                    [callback]=\"onOpenNotification\"\n                >\n                </fd-shellbar-action>\n            </fd-popover-control>\n            <fd-popover-body style=\"min-width: 320px; overflow-x: auto; box-shadow: var(--sapContent_Shadow0)\">\n                <ng-container\n                    *ngTemplateOutlet=\"notificationGroupTpl; context: { notificationCount: notificationCount }\"\n                ></ng-container>\n            </fd-popover-body>\n        </fd-popover>\n        } @if (!settings?.HideLanguage && deviceSize !== 's' && multiLanguages) {\n        <fd-shellbar-action [glyph]=\"'world'\" [label]=\"'language'\" [fdMenuTrigger]=\"menu\" (callback)=\"(onLanguage)\">\n        </fd-shellbar-action>\n        } @if (!settings?.HideLanguage && deviceSize === 's' && multiLanguages) { @for (culture of cultures | keyvalue;\n        track culture) {\n        <fd-shellbar-action\n            [label]=\"culture.value\"\n            [callback]=\"onLanguage\"\n            class=\"culture-abbrivation\"\n            [glyph]=\"culture.key\"\n            [ngClass]=\"'flags'\"\n        >\n        </fd-shellbar-action>\n        } } @if (productSwitcher?.length) {\n        <fd-product-switch>\n            <fd-product-switch-body [products]=\"productSwitcher\" [forceListMode]=\"deviceSize === 's'\">\n            </fd-product-switch-body>\n        </fd-product-switch>\n        }\n    </fd-shellbar-actions>\n    }\n</fd-shellbar>\n} @if(showExtraButton){\n<div\n    [class.fd-shellbar--xl]=\"isDesktop\"\n    [class.fd-shellbar--m]=\"isTablet\"\n    [class.fd-shellbar--s]=\"isMobile\"\n    class=\"extra-button-wrapper\"\n    [class.service-desk]=\"isServiceDesk\"\n>\n    <ng-content select=\"button\"></ng-content>\n</div>\n}\n<ng-template #loading>\n    <bsu-mask></bsu-mask>\n</ng-template>\n\n<div\n    *ngIf=\"sideMenuTemplate\"\n    class=\"tw-fixed tw-top-[38.5px] tw-h-[calc(100vh-38.5px)] tw-bg-white tw-transition-all tw-z-[100] tw-shadow-2xl tw-overflow-auto\"\n    [class.tw-w-screen]=\"isMobile\"\n    [class.-tw-right-full]=\"isMobile\"\n    [class.tw-w-96]=\"!isMobile\"\n    [class.-tw-right-96]=\"!isMobile\"\n    [class.!tw-right-0]=\"isOpenQuickAccess\"\n    (click)=\"$event.stopPropagation()\"\n>\n    <ng-container *ngTemplateOutlet=\"sideMenuTemplate\"></ng-container>\n</div>\n\n@if(isOpenQuickAccess) {\n<div\n    class=\"tw-fixed tw-right-0 tw-top-[38.5px] tw-h-[calc(100vh-38.5px)] tw-bg-slate-800/[.5] tw-z-[90] tw-w-screen tw-backdrop-blur-sm\"\n    (click)=\"isOpenQuickAccessChanged.emit(false)\"\n></div>\n}\n<fd-menu #menu>\n    <ul fd-list>\n        @for (culture of cultures | keyvalue; track culture) {\n        <li fd-list-item>\n            <a fd-list-link (click)=\"onCultureChange(culture.value)\">\n                <span fd-list-title>\n                    <img width=\"14px\" height=\"12px\" [src]=\"'/assets/flags/' + culture.key + '.png'\" />\n                    <span class=\"culture-abbrivation\" [ngClass]=\"culture.key\"> {{ culture.key }}</span>\n                </span>\n            </a>\n        </li>\n        }\n    </ul>\n</fd-menu>\n<ng-template #notificationGroupTpl let-notificationCount=\"notificationCount\">\n    @if (!notifcationLoaded && notificationLoading === true) {\n    <div style=\"position: relative; height: 100px\">\n        <bsu-mask size=\"s\"></bsu-mask>\n    </div>\n    }\n    <bt-notification-group\n        [notifications]=\"notifications\"\n        [notificationCount]=\"notificationCount\"\n        [loading]=\"notificationLoading === true\"\n        (viewed)=\"onNotificationItemViewed($event)\"\n        (remove)=\"onRemoveNotifications($event)\"\n        (showEvent)=\"popoverComponent.close(); onShowNotification($event)\"\n        (actionClick)=\"popoverComponent.close(); onNotificationAction($event)\"\n        (loadMore)=\"onNotificationLoadMore()\"\n        [deviceSize]=\"deviceSize\"\n    ></bt-notification-group>\n</ng-template>\n\n<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #notificationsDialog>\n    <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\">\n        <fd-dialog-header>\n            <h1 id=\"fd-dialog-header-10\" fd-title>{{ 'Notification' | bbbTranslate }}</h1>\n            <button fd-dialog-close-button (click)=\"dialog.dismiss()\"></button>\n        </fd-dialog-header>\n        <fd-dialog-body class=\"mobile\">\n            <ng-container\n                *ngTemplateOutlet=\"notificationGroupTpl; context: { notificationCount: notificationCount }\"\n            ></ng-container>\n        </fd-dialog-body>\n    </fd-dialog>\n</ng-template>\n"]}
|
|
@@ -5,16 +5,6 @@ import { PinTileComponent } from '../pin-tile/pin-tile.component';
|
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@fundamental-ngx/core";
|
|
7
7
|
import * as i2 from "../app-finder.service";
|
|
8
|
-
import * as i3 from "@angular/forms";
|
|
9
|
-
import * as i4 from "@fundamental-ngx/core/content-density";
|
|
10
|
-
import * as i5 from "@fundamental-ngx/core/button";
|
|
11
|
-
import * as i6 from "@fundamental-ngx/core/form";
|
|
12
|
-
import * as i7 from "@fundamental-ngx/core/input-group";
|
|
13
|
-
import * as i8 from "@fundamental-ngx/core/list";
|
|
14
|
-
import * as i9 from "@fundamental-ngx/core/panel";
|
|
15
|
-
import * as i10 from "barsa-novin-ray-core";
|
|
16
|
-
import * as i11 from "@angular/common";
|
|
17
|
-
import * as i12 from "./filter-apps-grouped.pipe";
|
|
18
8
|
export class PopoverAppFinderComponent extends BaseComponent {
|
|
19
9
|
constructor(_cdr, _dialogService, _appFinderService, _el, _contentDensityService) {
|
|
20
10
|
super();
|
|
@@ -99,14 +89,14 @@ export class PopoverAppFinderComponent extends BaseComponent {
|
|
|
99
89
|
this._cdr.detectChanges();
|
|
100
90
|
}
|
|
101
91
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: PopoverAppFinderComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.DialogService }, { token: i2.AppFinderService }, { token: i0.ElementRef }, { token: i1.ContentDensityService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
102
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
92
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.5", type: PopoverAppFinderComponent, selector: "bt-popover-app-finder", outputs: { closeMenu: "closeMenu" }, host: { classAttribute: "!tw-min-h-min" }, usesInheritance: true, ngImport: i0, template: "<!-- \n<div>\n <div class=\"!tw-px-4 !tw-pt-2\" fd-form-item>\n <fd-input-group\n glyph=\"decline\"\n glyphAriaLabel=\"Clear\"\n placeholder=\"\u062C\u0633\u062A\u062C\u0648\"\n [button]=\"true\"\n [disabled]=\"false\"\n [(ngModel)]=\"searchTerm\"\n (addOnButtonClicked)=\"searchTerm = ''\"\n >\n </fd-input-group>\n </div>\n @for (cat of appGroups$ | async | filterAppsGrouped:searchTerm; track cat.Id) {\n <fd-panel\n fdCompact\n expandAriaLabel=\"Panel Expand\"\n expandAriaLabelledBy=\"panel-compact-1\"\n [expanded]=\"!!searchTerm?.length\"\n >\n <h5 fd-panel-title id=\"panel-compact-1\">{{ cat.Title }}</h5>\n <div fd-panel-content ariaLabel=\"Panel Content\" id=\"panel-content-3\" class=\"!p-0\">\n <ul fd-list [noBorder]=\"false\">\n @for (app of cat.Apps | filterApps:searchTerm; track app.Id) {\n <li fd-list-item>\n <a fd-list-link [navigated]=\"true\" [dynCommand]=\"app.DynamicCommand\" (click)=\"closeMenu.emit()\">\n <i fd-list-icon glyph=\"history\"></i>\n <span fd-list-title>{{ app.Title }}</span>\n <span fd-list-secondary>\n @if(pinnedAppInAppTileGroups$ | async; as pinnedAppInAppTileGroups) {\n <button\n ariaLabel=\"Bookmark\"\n fdType=\"transparent\"\n title=\"Bookmark\"\n fd-button\n [glyph]=\"'pushpin-off'\"\n [fdType]=\"\n pinnedAppInAppTileGroups[app.Id]\n ? pinnedAppInAppTileGroups[app.Id].length\n ? 'emphasized'\n : 'transparent'\n : app.$HasPinned\n ? 'emphasized'\n : 'transparent'\n \"\n (click)=\"$event.stopPropagation(); onPinClick(app)\"\n ></button>\n }\n </span>\n </a>\n </li>\n }\n </ul>\n </div>\n </fd-panel>\n }\n</div> -->\n", styles: [":host{display:block;min-height:100vh}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
103
93
|
}
|
|
104
94
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: PopoverAppFinderComponent, decorators: [{
|
|
105
95
|
type: Component,
|
|
106
96
|
args: [{ selector: 'bt-popover-app-finder', changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
107
97
|
class: '!tw-min-h-min'
|
|
108
|
-
}, template: "
|
|
98
|
+
}, template: "<!-- \n<div>\n <div class=\"!tw-px-4 !tw-pt-2\" fd-form-item>\n <fd-input-group\n glyph=\"decline\"\n glyphAriaLabel=\"Clear\"\n placeholder=\"\u062C\u0633\u062A\u062C\u0648\"\n [button]=\"true\"\n [disabled]=\"false\"\n [(ngModel)]=\"searchTerm\"\n (addOnButtonClicked)=\"searchTerm = ''\"\n >\n </fd-input-group>\n </div>\n @for (cat of appGroups$ | async | filterAppsGrouped:searchTerm; track cat.Id) {\n <fd-panel\n fdCompact\n expandAriaLabel=\"Panel Expand\"\n expandAriaLabelledBy=\"panel-compact-1\"\n [expanded]=\"!!searchTerm?.length\"\n >\n <h5 fd-panel-title id=\"panel-compact-1\">{{ cat.Title }}</h5>\n <div fd-panel-content ariaLabel=\"Panel Content\" id=\"panel-content-3\" class=\"!p-0\">\n <ul fd-list [noBorder]=\"false\">\n @for (app of cat.Apps | filterApps:searchTerm; track app.Id) {\n <li fd-list-item>\n <a fd-list-link [navigated]=\"true\" [dynCommand]=\"app.DynamicCommand\" (click)=\"closeMenu.emit()\">\n <i fd-list-icon glyph=\"history\"></i>\n <span fd-list-title>{{ app.Title }}</span>\n <span fd-list-secondary>\n @if(pinnedAppInAppTileGroups$ | async; as pinnedAppInAppTileGroups) {\n <button\n ariaLabel=\"Bookmark\"\n fdType=\"transparent\"\n title=\"Bookmark\"\n fd-button\n [glyph]=\"'pushpin-off'\"\n [fdType]=\"\n pinnedAppInAppTileGroups[app.Id]\n ? pinnedAppInAppTileGroups[app.Id].length\n ? 'emphasized'\n : 'transparent'\n : app.$HasPinned\n ? 'emphasized'\n : 'transparent'\n \"\n (click)=\"$event.stopPropagation(); onPinClick(app)\"\n ></button>\n }\n </span>\n </a>\n </li>\n }\n </ul>\n </div>\n </fd-panel>\n }\n</div> -->\n", styles: [":host{display:block;min-height:100vh}\n"] }]
|
|
109
99
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.DialogService }, { type: i2.AppFinderService }, { type: i0.ElementRef }, { type: i1.ContentDensityService }], propDecorators: { closeMenu: [{
|
|
110
100
|
type: Output
|
|
111
101
|
}] } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover-app-finder.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-tiles/src/lib/popover-app-finder/popover-app-finder.component.ts","../../../../../projects/barsa-tiles/src/lib/popover-app-finder/popover-app-finder.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    OnInit,\n    Output\n} from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { map, takeUntil } from 'rxjs/operators';\nimport { ContentDensity, ContentDensityService, DialogService } from '@fundamental-ngx/core';\n\nimport { BaseComponent, MetaobjectDataModel, AbbrevationDeviceSize } from 'barsa-novin-ray-core';\nimport { AppFinderService } from '../app-finder.service';\nimport { AppTileGroupPin } from '../models';\nimport { PinTileComponent } from '../pin-tile/pin-tile.component';\n\n@Component({\n    selector: 'bt-popover-app-finder',\n    templateUrl: './popover-app-finder.component.html',\n    styleUrls: ['./popover-app-finder.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: '!tw-min-h-min'\n    }\n})\nexport class PopoverAppFinderComponent extends BaseComponent implements OnInit {\n    @Output() closeMenu = new EventEmitter<void>();\n    selectedGroups: MetaobjectDataModel[];\n    isAllSelected = true;\n    appGroups$: Observable<MetaobjectDataModel[] | undefined>;\n    appTileGroups$: Observable<MetaobjectDataModel[]>;\n    searchTerm: string;\n    deviceSize$: Observable<AbbrevationDeviceSize>;\n    sideContentSize$: Observable<string>;\n    contentDensity$: Observable<ContentDensity>;\n    selectedAppGroup$: Observable<MetaobjectDataModel | undefined>;\n    selectedAppGroupId$: Observable<string>;\n    mobile$: Observable<boolean>;\n    contentHeight: string;\n    pinnedAppInAppTileGroups$: Observable<Record<string, string[]>>;\n\n    constructor(\n        private _cdr: ChangeDetectorRef,\n        private _dialogService: DialogService,\n        private _appFinderService: AppFinderService,\n        private _el: ElementRef,\n        _contentDensityService: ContentDensityService\n    ) {\n        super();\n        this.contentDensity$ = _contentDensityService.contentDensity.asObservable();\n        this.appGroups$ = this._appFinderService.appGroups$.pipe(\n            map((appGroups) => {\n                appGroups.forEach((cat) => {\n                    this._appFinderService.loadAppsByAppGroup(appGroups, cat);\n                });\n                return appGroups;\n            })\n        );\n        this.selectedAppGroup$ = this._appFinderService.selectedAppGroup$;\n        this.selectedAppGroupId$ = this._appFinderService.selectedAppGroupId$;\n        this.deviceSize$ = this._appFinderService.deviceSize$;\n        this.pinnedAppInAppTileGroups$ = this._appFinderService.pinnedAppInAppTileGroups$;\n        this.mobile$ = this.deviceSize$.pipe(map((c) => c === 's'));\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n\n        this.contentHeight = 'calc(' + this._el.nativeElement.offsetHeight + 'px - 2.75rem)';\n\n        this.sideContentSize$ = this.deviceSize$.pipe(\n            takeUntil(this._onDestroy$),\n            map((deviceSize) => {\n                switch (deviceSize) {\n                    case 's':\n                        return 'sm';\n                    case 'm':\n                        return 'md';\n                    case 'l':\n                        return 'lg';\n                    case 'xl':\n                        return 'xl';\n                    default:\n                        return 'l';\n                }\n            })\n        );\n    }\n\n    onSelectedAppGroupChange(appGroupId: string): void {\n        this._changeGroup(appGroupId);\n    }\n\n    onPinClick(app: MetaobjectDataModel): void {\n        const pinnedAppInTileGroups = this._appFinderService.loadPinnedAppInTileGroups(app);\n        const appTileGroups = this._appFinderService.appTileGroups;\n        const deviceSize = this._appFinderService.deviceSize;\n        const mobile = deviceSize === 's';\n        this._dialogService\n            .open(PinTileComponent, {\n                data: { app, pinnedAppInTileGroups, appTileGroups },\n                minWidth: '350px',\n                minHeight: '420px',\n                draggable: false,\n                mobile,\n                resizable: false,\n                verticalPadding: false,\n                backdropClickCloseable: false\n            })\n            .afterClosed.subscribe((result) => {\n                this._appTileGroupsPinChange(result);\n            });\n    }\n    onRefresh(): void {}\n    async _appTileGroupsPinChange(result: {\n        appTileGroupsPin: AppTileGroupPin[];\n        app: MetaobjectDataModel;\n    }): Promise<void> {\n        try {\n            // Will try to ask for permission\n            this._appFinderService.pinTileChanged(result.appTileGroupsPin, result.app, () => {\n                this._cdr.detectChanges();\n            });\n        } catch (err) {\n            // show msg error\n        } finally {\n            // show toast successful\n        }\n    }\n    private _changeGroup(appGroupId: string): void {\n        this.isAllSelected = false;\n        this._appFinderService.selectAppGroup(appGroupId);\n        this._cdr.detectChanges();\n    }\n}\n","<!--@for (cat of appGroups$ | async; track cat.Id) {-->\n<!--    <div class=\"px-4 py-2 font-lg\">-->\n<!--        <p class=\"font-bold\">{{ cat.$Caption }}</p>-->\n<!--    </div>-->\n<!--    <div class=\"grid grid-cols-4 gap-2 p-2\">-->\n<!--        @for (app of cat.Apps; track app.Id) {-->\n<!--            <div class=\"flex flex-col items-center w-24 gap-1 border border-transparent hover:border-gray-300 bg-transparent hover:bg-gray-100 transition-all rounded-lg p-2 cursor-pointer\">-->\n<!--                <div class=\"size-12 rounded-full bg-gray-300\"></div>-->\n<!--                <span class=\"truncate w-20 text-center\">-->\n<!--                {{ app.$Caption }}</span>-->\n<!--            </div>-->\n<!--        }-->\n<!--    </div>-->\n<!--}-->\n<div>\n    <div class=\"!tw-px-4 !tw-pt-2\" fd-form-item>\n        <fd-input-group\n            glyph=\"decline\"\n            glyphAriaLabel=\"Clear\"\n            placeholder=\"جستجو\"\n            [button]=\"true\"\n            [disabled]=\"false\"\n            [(ngModel)]=\"searchTerm\"\n            (addOnButtonClicked)=\"searchTerm = ''\"\n        >\n        </fd-input-group>\n    </div>\n    @for (cat of appGroups$ | async | filterAppsGrouped:searchTerm; track cat.Id) {\n    <fd-panel\n        fdCompact\n        expandAriaLabel=\"Panel Expand\"\n        expandAriaLabelledBy=\"panel-compact-1\"\n        [expanded]=\"!!searchTerm?.length\"\n    >\n        <h5 fd-panel-title id=\"panel-compact-1\">{{ cat.Title }}</h5>\n        <div fd-panel-content ariaLabel=\"Panel Content\" id=\"panel-content-3\" class=\"!p-0\">\n            <ul fd-list [noBorder]=\"false\">\n                @for (app of cat.Apps | filterApps:searchTerm; track app.Id) {\n                <li fd-list-item>\n                    <a fd-list-link [navigated]=\"true\" [dynCommand]=\"app.DynamicCommand\" (click)=\"closeMenu.emit()\">\n                        <i fd-list-icon glyph=\"history\"></i>\n                        <span fd-list-title>{{ app.Title }}</span>\n                        <span fd-list-secondary>\n                            @if(pinnedAppInAppTileGroups$ | async; as pinnedAppInAppTileGroups) {\n                            <button\n                                ariaLabel=\"Bookmark\"\n                                fdType=\"transparent\"\n                                title=\"Bookmark\"\n                                fd-button\n                                [glyph]=\"'pushpin-off'\"\n                                [fdType]=\"\n                                    pinnedAppInAppTileGroups[app.Id]\n                                        ? pinnedAppInAppTileGroups[app.Id].length\n                                            ? 'emphasized'\n                                            : 'transparent'\n                                        : app.$HasPinned\n                                        ? 'emphasized'\n                                        : 'transparent'\n                                \"\n                                (click)=\"$event.stopPropagation(); onPinClick(app)\"\n                            ></button>\n                            }\n                        </span>\n                    </a>\n                </li>\n                }\n            </ul>\n        </div>\n    </fd-panel>\n    }\n</div>\n"]}
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover-app-finder.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-tiles/src/lib/popover-app-finder/popover-app-finder.component.ts","../../../../../projects/barsa-tiles/src/lib/popover-app-finder/popover-app-finder.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    OnInit,\n    Output\n} from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { map, takeUntil } from 'rxjs/operators';\nimport { ContentDensity, ContentDensityService, DialogService } from '@fundamental-ngx/core';\n\nimport { BaseComponent, MetaobjectDataModel, AbbrevationDeviceSize } from 'barsa-novin-ray-core';\nimport { AppFinderService } from '../app-finder.service';\nimport { AppTileGroupPin } from '../models';\nimport { PinTileComponent } from '../pin-tile/pin-tile.component';\n\n@Component({\n    selector: 'bt-popover-app-finder',\n    templateUrl: './popover-app-finder.component.html',\n    styleUrls: ['./popover-app-finder.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: '!tw-min-h-min'\n    }\n})\nexport class PopoverAppFinderComponent extends BaseComponent implements OnInit {\n    @Output() closeMenu = new EventEmitter<void>();\n    selectedGroups: MetaobjectDataModel[];\n    isAllSelected = true;\n    appGroups$: Observable<MetaobjectDataModel[] | undefined>;\n    appTileGroups$: Observable<MetaobjectDataModel[]>;\n    searchTerm: string;\n    deviceSize$: Observable<AbbrevationDeviceSize>;\n    sideContentSize$: Observable<string>;\n    contentDensity$: Observable<ContentDensity>;\n    selectedAppGroup$: Observable<MetaobjectDataModel | undefined>;\n    selectedAppGroupId$: Observable<string>;\n    mobile$: Observable<boolean>;\n    contentHeight: string;\n    pinnedAppInAppTileGroups$: Observable<Record<string, string[]>>;\n\n    constructor(\n        private _cdr: ChangeDetectorRef,\n        private _dialogService: DialogService,\n        private _appFinderService: AppFinderService,\n        private _el: ElementRef,\n        _contentDensityService: ContentDensityService\n    ) {\n        super();\n        this.contentDensity$ = _contentDensityService.contentDensity.asObservable();\n        this.appGroups$ = this._appFinderService.appGroups$.pipe(\n            map((appGroups) => {\n                appGroups.forEach((cat) => {\n                    this._appFinderService.loadAppsByAppGroup(appGroups, cat);\n                });\n                return appGroups;\n            })\n        );\n        this.selectedAppGroup$ = this._appFinderService.selectedAppGroup$;\n        this.selectedAppGroupId$ = this._appFinderService.selectedAppGroupId$;\n        this.deviceSize$ = this._appFinderService.deviceSize$;\n        this.pinnedAppInAppTileGroups$ = this._appFinderService.pinnedAppInAppTileGroups$;\n        this.mobile$ = this.deviceSize$.pipe(map((c) => c === 's'));\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n\n        this.contentHeight = 'calc(' + this._el.nativeElement.offsetHeight + 'px - 2.75rem)';\n\n        this.sideContentSize$ = this.deviceSize$.pipe(\n            takeUntil(this._onDestroy$),\n            map((deviceSize) => {\n                switch (deviceSize) {\n                    case 's':\n                        return 'sm';\n                    case 'm':\n                        return 'md';\n                    case 'l':\n                        return 'lg';\n                    case 'xl':\n                        return 'xl';\n                    default:\n                        return 'l';\n                }\n            })\n        );\n    }\n\n    onSelectedAppGroupChange(appGroupId: string): void {\n        this._changeGroup(appGroupId);\n    }\n\n    onPinClick(app: MetaobjectDataModel): void {\n        const pinnedAppInTileGroups = this._appFinderService.loadPinnedAppInTileGroups(app);\n        const appTileGroups = this._appFinderService.appTileGroups;\n        const deviceSize = this._appFinderService.deviceSize;\n        const mobile = deviceSize === 's';\n        this._dialogService\n            .open(PinTileComponent, {\n                data: { app, pinnedAppInTileGroups, appTileGroups },\n                minWidth: '350px',\n                minHeight: '420px',\n                draggable: false,\n                mobile,\n                resizable: false,\n                verticalPadding: false,\n                backdropClickCloseable: false\n            })\n            .afterClosed.subscribe((result) => {\n                this._appTileGroupsPinChange(result);\n            });\n    }\n    onRefresh(): void {}\n    async _appTileGroupsPinChange(result: {\n        appTileGroupsPin: AppTileGroupPin[];\n        app: MetaobjectDataModel;\n    }): Promise<void> {\n        try {\n            // Will try to ask for permission\n            this._appFinderService.pinTileChanged(result.appTileGroupsPin, result.app, () => {\n                this._cdr.detectChanges();\n            });\n        } catch (err) {\n            // show msg error\n        } finally {\n            // show toast successful\n        }\n    }\n    private _changeGroup(appGroupId: string): void {\n        this.isAllSelected = false;\n        this._appFinderService.selectAppGroup(appGroupId);\n        this._cdr.detectChanges();\n    }\n}\n","<!-- \n<div>\n    <div class=\"!tw-px-4 !tw-pt-2\" fd-form-item>\n        <fd-input-group\n            glyph=\"decline\"\n            glyphAriaLabel=\"Clear\"\n            placeholder=\"جستجو\"\n            [button]=\"true\"\n            [disabled]=\"false\"\n            [(ngModel)]=\"searchTerm\"\n            (addOnButtonClicked)=\"searchTerm = ''\"\n        >\n        </fd-input-group>\n    </div>\n    @for (cat of appGroups$ | async | filterAppsGrouped:searchTerm; track cat.Id) {\n    <fd-panel\n        fdCompact\n        expandAriaLabel=\"Panel Expand\"\n        expandAriaLabelledBy=\"panel-compact-1\"\n        [expanded]=\"!!searchTerm?.length\"\n    >\n        <h5 fd-panel-title id=\"panel-compact-1\">{{ cat.Title }}</h5>\n        <div fd-panel-content ariaLabel=\"Panel Content\" id=\"panel-content-3\" class=\"!p-0\">\n            <ul fd-list [noBorder]=\"false\">\n                @for (app of cat.Apps | filterApps:searchTerm; track app.Id) {\n                <li fd-list-item>\n                    <a fd-list-link [navigated]=\"true\" [dynCommand]=\"app.DynamicCommand\" (click)=\"closeMenu.emit()\">\n                        <i fd-list-icon glyph=\"history\"></i>\n                        <span fd-list-title>{{ app.Title }}</span>\n                        <span fd-list-secondary>\n                            @if(pinnedAppInAppTileGroups$ | async; as pinnedAppInAppTileGroups) {\n                            <button\n                                ariaLabel=\"Bookmark\"\n                                fdType=\"transparent\"\n                                title=\"Bookmark\"\n                                fd-button\n                                [glyph]=\"'pushpin-off'\"\n                                [fdType]=\"\n                                    pinnedAppInAppTileGroups[app.Id]\n                                        ? pinnedAppInAppTileGroups[app.Id].length\n                                            ? 'emphasized'\n                                            : 'transparent'\n                                        : app.$HasPinned\n                                        ? 'emphasized'\n                                        : 'transparent'\n                                \"\n                                (click)=\"$event.stopPropagation(); onPinClick(app)\"\n                            ></button>\n                            }\n                        </span>\n                    </a>\n                </li>\n                }\n            </ul>\n        </div>\n    </fd-panel>\n    }\n</div> -->\n"]}
|
|
@@ -7,11 +7,10 @@ import * as i0 from "@angular/core";
|
|
|
7
7
|
import * as i1 from "barsa-novin-ray-core";
|
|
8
8
|
import * as i2 from "../tiles.service";
|
|
9
9
|
import * as i3 from "@angular/platform-browser";
|
|
10
|
-
import * as i4 from "@
|
|
11
|
-
import * as i5 from "
|
|
12
|
-
import * as i6 from "
|
|
13
|
-
import * as i7 from "../
|
|
14
|
-
import * as i8 from "@angular/common";
|
|
10
|
+
import * as i4 from "@angular/common";
|
|
11
|
+
import * as i5 from "@fundamental-ngx/core/button";
|
|
12
|
+
import * as i6 from "barsa-sap-ui";
|
|
13
|
+
import * as i7 from "../barsa-shellbar/barsa-shellbar.component";
|
|
15
14
|
export class ShellbarComponent extends BaseComponent {
|
|
16
15
|
get subtitle() {
|
|
17
16
|
if (!this.shellbarData) {
|
|
@@ -32,6 +31,16 @@ export class ShellbarComponent extends BaseComponent {
|
|
|
32
31
|
get actions() {
|
|
33
32
|
return this.settings?.HideUserMenu ? [] : this.shellbarData?.ActionItems?.MoDataList ?? [];
|
|
34
33
|
}
|
|
34
|
+
get sidebarSettings() {
|
|
35
|
+
if (!this.shellbarData?.SidebarReport?.Id) {
|
|
36
|
+
return null;
|
|
37
|
+
}
|
|
38
|
+
return {
|
|
39
|
+
RelatedReport: { Id: this.shellbarData?.SidebarReport?.Id, $Caption: '' },
|
|
40
|
+
RowClick: '',
|
|
41
|
+
DataOnly: false
|
|
42
|
+
};
|
|
43
|
+
}
|
|
35
44
|
get userMenu() {
|
|
36
45
|
const moDataList = BarsaApi.Common.Util.TryGetValue(this.shellbarData, 'UserMenuItems.MoDataList');
|
|
37
46
|
const items = moDataList ? [...moDataList] : [];
|
|
@@ -189,11 +198,11 @@ export class ShellbarComponent extends BaseComponent {
|
|
|
189
198
|
BarsaApi.Bw.NavigateTo('/');
|
|
190
199
|
}
|
|
191
200
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: ShellbarComponent, deps: [{ token: i1.BbbTranslatePipe }, { token: i1.PortalService }, { token: i1.BreadcrumbService }, { token: i2.TilesService }, { token: i0.ChangeDetectorRef }, { token: i3.DomSanitizer }, { token: i1.NotificationService }, { token: APP_VERSION }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
192
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: ShellbarComponent, selector: "bt-shellbar", viewQueries: [{ propertyName: "comboboxComponent", first: true, predicate: ComboboxComponent, descendants: true }, { propertyName: "popoverComponent", first: true, predicate: ["popoverComponent"], descendants: true }, { propertyName: "_notificationsDialog", first: true, predicate: ["notificationsDialog"], descendants: true, read: TemplateRef, static: true }], usesInheritance: true, ngImport: i0, template: "@if (userLoggedIn$ | async; as userloggend) { @if (notifiationCountLoaded$ | async; as notifiationCountLoaded) { @if\n(deviceSize$ | async; as deviceSize) { @if (shellbarData) {\n<bt-barsa-shellbar\n [class.service-desk]=\"isServiceDesk\"\n [cssUrl]=\"cssUrl$ | async\"\n [cssCustomUrl]=\"cssCustomUrl$ | async\"\n [userLoggedIn]=\"true\"\n [allowAnonymous]=\"allowAnonymous\"\n [deviceSize]=\"deviceSize\"\n [shellbarData]=\"shellbarData\"\n [productMenuControl]=\"productMenuControl\"\n [settings]=\"settings\"\n [isMobile]=\"isMobile\"\n [isTablet]=\"isTablet\"\n [isDesktop]=\"isDesktop\"\n [multiLanguages]=\"multiLanguages\"\n [notificationCount]=\"(notificationsCount$ | async)!!\"\n [notifications]=\"(notifications$ | async) ?? []\"\n [notifcationLoaded]=\"notifcationLoaded\"\n [notificationLoading]=\"(notificationLoading$ | async) === true\"\n [cultures]=\"cultures\"\n [logo]=\"logo\"\n [actions]=\"actions\"\n [userMenu]=\"userMenu\"\n [productSwitcher]=\"productSwitcher\"\n [subtitle]=\"subtitle\"\n [isServiceDesk]=\"isServiceDesk\"\n [sideMenuTemplate]=\"QuickAccessTemplate\"\n [productMenuItems1]=\"productMenuItems1\"\n [isOpenQuickAccess]=\"isOpenQuickAccess\"\n (isOpenQuickAccessChanged)=\"isOpenQuickAccess = $event\"\n (cultureChanged)=\"onCultureChanged($event)\"\n (notificationViewed)=\"onNotificationItemViewed($event)\"\n (notifiationActionClick)=\"onNotificationAction($event)\"\n (removeNotification)=\"onRemoveNotifications($event)\"\n (notificationLoadMore)=\"onNotificationLoadMore()\"\n (openNotificationPanel)=\"onHandleOpenNotificationPanel()\"\n>\n</bt-barsa-shellbar>\n} } } } @else { @if (notificationsCount$ | async; as notificationCount) {\n<bt-barsa-shellbar\n [class.service-desk]=\"isServiceDesk\"\n [cssUrl]=\"''\"\n [cssCustomUr]=\"''\"\n [userLoggedIn]=\"false\"\n [multiLanguages]=\"multiLanguages\"\n [userMenu]=\"userMenu\"\n [logo]=\"logo\"\n [productMenuItems1]=\"productMenuItems1\"\n [allowAnonymous]=\"allowAnonymous\"\n [deviceSize]=\"(deviceSize$ | async)!!\"\n [shellbarData]=\"shellbarData\"\n [cultures]=\"cultures\"\n [logo]=\"logo\"\n [isMobile]=\"isMobile\"\n [isTablet]=\"isTablet\"\n [isDesktop]=\"isDesktop\"\n [isServiceDesk]=\"isServiceDesk\"\n [actions]=\"actions\"\n [userMenu]=\"userMenu\"\n [productMenuControl]=\"productMenuControl\"\n [productSwitcher]=\"productSwitcher\"\n [subtitle]=\"subtitle\"\n [settings]=\"settings\"\n [notificationCount]=\"{ unread: 0, all: 0 }\"\n [notifications]=\"[]\"\n [notifcationLoaded]=\"true\"\n [notificationLoading]=\"false\"\n [hideShellbarActions]=\"true\"\n [cultures]=\"cultures\"\n [productMenuItems1]=\"productMenuItems1\"\n (cultureChanged)=\"onCultureChanged($event)\"\n>\n <button\n id=\"login_btn\"\n fd-button\n [label]=\"'\u0648\u0631\u0648\u062F' | bbbTranslate\"\n glyph=\"person-placeholder\"\n [routerLink]=\"[loginRouterLink$ | async]\"\n fdType=\"emphasized\"\n ></button>\n</bt-barsa-shellbar>\n} }\n<ng-template #QuickAccessTemplate>\n @if ((notificationLoading$ | async) === true) {\n <div style=\"position: relative; height: 100px\">\n <bsu-mask size=\"s\"></bsu-mask>\n </div>\n }\n <bt-popover-app-finder (closeMenu)=\"isOpenQuickAccess = false\"></bt-popover-app-finder
|
|
201
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: ShellbarComponent, selector: "bt-shellbar", viewQueries: [{ propertyName: "comboboxComponent", first: true, predicate: ComboboxComponent, descendants: true }, { propertyName: "popoverComponent", first: true, predicate: ["popoverComponent"], descendants: true }, { propertyName: "_notificationsDialog", first: true, predicate: ["notificationsDialog"], descendants: true, read: TemplateRef, static: true }], usesInheritance: true, ngImport: i0, template: "@if (userLoggedIn$ | async; as userloggend) { @if (notifiationCountLoaded$ | async; as notifiationCountLoaded) { @if\n(deviceSize$ | async; as deviceSize) { @if (shellbarData) {\n<bt-barsa-shellbar\n [class.service-desk]=\"isServiceDesk\"\n [cssUrl]=\"cssUrl$ | async\"\n [cssCustomUrl]=\"cssCustomUrl$ | async\"\n [userLoggedIn]=\"true\"\n [allowAnonymous]=\"allowAnonymous\"\n [deviceSize]=\"deviceSize\"\n [shellbarData]=\"shellbarData\"\n [productMenuControl]=\"productMenuControl\"\n [settings]=\"settings\"\n [isMobile]=\"isMobile\"\n [isTablet]=\"isTablet\"\n [isDesktop]=\"isDesktop\"\n [multiLanguages]=\"multiLanguages\"\n [notificationCount]=\"(notificationsCount$ | async)!!\"\n [notifications]=\"(notifications$ | async) ?? []\"\n [notifcationLoaded]=\"notifcationLoaded\"\n [notificationLoading]=\"(notificationLoading$ | async) === true\"\n [cultures]=\"cultures\"\n [logo]=\"logo\"\n [actions]=\"actions\"\n [userMenu]=\"userMenu\"\n [productSwitcher]=\"productSwitcher\"\n [subtitle]=\"subtitle\"\n [isServiceDesk]=\"isServiceDesk\"\n [sideMenuTemplate]=\"QuickAccessTemplate\"\n [productMenuItems1]=\"productMenuItems1\"\n [isOpenQuickAccess]=\"isOpenQuickAccess\"\n (isOpenQuickAccessChanged)=\"isOpenQuickAccess = $event\"\n (cultureChanged)=\"onCultureChanged($event)\"\n (notificationViewed)=\"onNotificationItemViewed($event)\"\n (notifiationActionClick)=\"onNotificationAction($event)\"\n (removeNotification)=\"onRemoveNotifications($event)\"\n (notificationLoadMore)=\"onNotificationLoadMore()\"\n (openNotificationPanel)=\"onHandleOpenNotificationPanel()\"\n>\n</bt-barsa-shellbar>\n} } } } @else { @if (notificationsCount$ | async; as notificationCount) {\n<bt-barsa-shellbar\n [class.service-desk]=\"isServiceDesk\"\n [cssUrl]=\"''\"\n [cssCustomUr]=\"''\"\n [userLoggedIn]=\"false\"\n [multiLanguages]=\"multiLanguages\"\n [userMenu]=\"userMenu\"\n [logo]=\"logo\"\n [productMenuItems1]=\"productMenuItems1\"\n [allowAnonymous]=\"allowAnonymous\"\n [deviceSize]=\"(deviceSize$ | async)!!\"\n [shellbarData]=\"shellbarData\"\n [cultures]=\"cultures\"\n [logo]=\"logo\"\n [isMobile]=\"isMobile\"\n [isTablet]=\"isTablet\"\n [isDesktop]=\"isDesktop\"\n [isServiceDesk]=\"isServiceDesk\"\n [actions]=\"actions\"\n [userMenu]=\"userMenu\"\n [productMenuControl]=\"productMenuControl\"\n [productSwitcher]=\"productSwitcher\"\n [subtitle]=\"subtitle\"\n [settings]=\"settings\"\n [notificationCount]=\"{ unread: 0, all: 0 }\"\n [notifications]=\"[]\"\n [notifcationLoaded]=\"true\"\n [notificationLoading]=\"false\"\n [hideShellbarActions]=\"true\"\n [cultures]=\"cultures\"\n [productMenuItems1]=\"productMenuItems1\"\n (cultureChanged)=\"onCultureChanged($event)\"\n>\n <button\n id=\"login_btn\"\n fd-button\n [label]=\"'\u0648\u0631\u0648\u062F' | bbbTranslate\"\n glyph=\"person-placeholder\"\n [routerLink]=\"[loginRouterLink$ | async]\"\n fdType=\"emphasized\"\n ></button>\n</bt-barsa-shellbar>\n} }\n<ng-template #QuickAccessTemplate>\n @if ((notificationLoading$ | async) === true) {\n <div style=\"position: relative; height: 100px\">\n <bsu-mask size=\"s\"></bsu-mask>\n </div>\n }\n <bnrc-report-container *ngIf=\"sidebarSettings\" [settings]=\"sidebarSettings\"> </bnrc-report-container>\n <!-- <bt-popover-app-finder (closeMenu)=\"isOpenQuickAccess = false\"></bt-popover-app-finder> -->\n</ng-template>\n", styles: [":host{display:block;position:relative}:host #login_btn{background-color:transparent;border-color:transparent}:host #menu_btn{background-color:transparent;border-color:transparent}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i1.ReportContainerComponent, selector: "bnrc-report-container", inputs: ["settings"] }, { kind: "component", type: i6.MaskComponent, selector: "bsu-mask", inputs: ["size", "top"] }, { kind: "component", type: i7.BarsaShellbarComponent, selector: "bt-barsa-shellbar", inputs: ["cssCustomUrl", "cssUrl", "allowAnonymous", "multiLanguages", "userLoggedIn", "settings", "productMenuControl", "deviceSize", "cultures", "shellbarData", "notificationCount", "notifcationLoaded", "notificationLoading", "notifications", "productMenuItems1", "bodyClick", "logo", "actions", "userMenu", "productSwitcher", "subtitle", "isMobile", "hideShellbarActions", "showExtraButton", "isTablet", "isDesktop", "isServiceDesk", "isOpenQuickAccess", "sideMenuTemplate"], outputs: ["isOpenQuickAccessChanged", "openNotificationPanel", "openQuickAccessPanel", "cultureChanged", "notificationLoadMore", "removeNotification", "notifiationActionClick", "notificationViewed"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
193
202
|
}
|
|
194
203
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: ShellbarComponent, decorators: [{
|
|
195
204
|
type: Component,
|
|
196
|
-
args: [{ selector: 'bt-shellbar', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (userLoggedIn$ | async; as userloggend) { @if (notifiationCountLoaded$ | async; as notifiationCountLoaded) { @if\n(deviceSize$ | async; as deviceSize) { @if (shellbarData) {\n<bt-barsa-shellbar\n [class.service-desk]=\"isServiceDesk\"\n [cssUrl]=\"cssUrl$ | async\"\n [cssCustomUrl]=\"cssCustomUrl$ | async\"\n [userLoggedIn]=\"true\"\n [allowAnonymous]=\"allowAnonymous\"\n [deviceSize]=\"deviceSize\"\n [shellbarData]=\"shellbarData\"\n [productMenuControl]=\"productMenuControl\"\n [settings]=\"settings\"\n [isMobile]=\"isMobile\"\n [isTablet]=\"isTablet\"\n [isDesktop]=\"isDesktop\"\n [multiLanguages]=\"multiLanguages\"\n [notificationCount]=\"(notificationsCount$ | async)!!\"\n [notifications]=\"(notifications$ | async) ?? []\"\n [notifcationLoaded]=\"notifcationLoaded\"\n [notificationLoading]=\"(notificationLoading$ | async) === true\"\n [cultures]=\"cultures\"\n [logo]=\"logo\"\n [actions]=\"actions\"\n [userMenu]=\"userMenu\"\n [productSwitcher]=\"productSwitcher\"\n [subtitle]=\"subtitle\"\n [isServiceDesk]=\"isServiceDesk\"\n [sideMenuTemplate]=\"QuickAccessTemplate\"\n [productMenuItems1]=\"productMenuItems1\"\n [isOpenQuickAccess]=\"isOpenQuickAccess\"\n (isOpenQuickAccessChanged)=\"isOpenQuickAccess = $event\"\n (cultureChanged)=\"onCultureChanged($event)\"\n (notificationViewed)=\"onNotificationItemViewed($event)\"\n (notifiationActionClick)=\"onNotificationAction($event)\"\n (removeNotification)=\"onRemoveNotifications($event)\"\n (notificationLoadMore)=\"onNotificationLoadMore()\"\n (openNotificationPanel)=\"onHandleOpenNotificationPanel()\"\n>\n</bt-barsa-shellbar>\n} } } } @else { @if (notificationsCount$ | async; as notificationCount) {\n<bt-barsa-shellbar\n [class.service-desk]=\"isServiceDesk\"\n [cssUrl]=\"''\"\n [cssCustomUr]=\"''\"\n [userLoggedIn]=\"false\"\n [multiLanguages]=\"multiLanguages\"\n [userMenu]=\"userMenu\"\n [logo]=\"logo\"\n [productMenuItems1]=\"productMenuItems1\"\n [allowAnonymous]=\"allowAnonymous\"\n [deviceSize]=\"(deviceSize$ | async)!!\"\n [shellbarData]=\"shellbarData\"\n [cultures]=\"cultures\"\n [logo]=\"logo\"\n [isMobile]=\"isMobile\"\n [isTablet]=\"isTablet\"\n [isDesktop]=\"isDesktop\"\n [isServiceDesk]=\"isServiceDesk\"\n [actions]=\"actions\"\n [userMenu]=\"userMenu\"\n [productMenuControl]=\"productMenuControl\"\n [productSwitcher]=\"productSwitcher\"\n [subtitle]=\"subtitle\"\n [settings]=\"settings\"\n [notificationCount]=\"{ unread: 0, all: 0 }\"\n [notifications]=\"[]\"\n [notifcationLoaded]=\"true\"\n [notificationLoading]=\"false\"\n [hideShellbarActions]=\"true\"\n [cultures]=\"cultures\"\n [productMenuItems1]=\"productMenuItems1\"\n (cultureChanged)=\"onCultureChanged($event)\"\n>\n <button\n id=\"login_btn\"\n fd-button\n [label]=\"'\u0648\u0631\u0648\u062F' | bbbTranslate\"\n glyph=\"person-placeholder\"\n [routerLink]=\"[loginRouterLink$ | async]\"\n fdType=\"emphasized\"\n ></button>\n</bt-barsa-shellbar>\n} }\n<ng-template #QuickAccessTemplate>\n @if ((notificationLoading$ | async) === true) {\n <div style=\"position: relative; height: 100px\">\n <bsu-mask size=\"s\"></bsu-mask>\n </div>\n }\n <bt-popover-app-finder (closeMenu)=\"isOpenQuickAccess = false\"></bt-popover-app-finder
|
|
205
|
+
args: [{ selector: 'bt-shellbar', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (userLoggedIn$ | async; as userloggend) { @if (notifiationCountLoaded$ | async; as notifiationCountLoaded) { @if\n(deviceSize$ | async; as deviceSize) { @if (shellbarData) {\n<bt-barsa-shellbar\n [class.service-desk]=\"isServiceDesk\"\n [cssUrl]=\"cssUrl$ | async\"\n [cssCustomUrl]=\"cssCustomUrl$ | async\"\n [userLoggedIn]=\"true\"\n [allowAnonymous]=\"allowAnonymous\"\n [deviceSize]=\"deviceSize\"\n [shellbarData]=\"shellbarData\"\n [productMenuControl]=\"productMenuControl\"\n [settings]=\"settings\"\n [isMobile]=\"isMobile\"\n [isTablet]=\"isTablet\"\n [isDesktop]=\"isDesktop\"\n [multiLanguages]=\"multiLanguages\"\n [notificationCount]=\"(notificationsCount$ | async)!!\"\n [notifications]=\"(notifications$ | async) ?? []\"\n [notifcationLoaded]=\"notifcationLoaded\"\n [notificationLoading]=\"(notificationLoading$ | async) === true\"\n [cultures]=\"cultures\"\n [logo]=\"logo\"\n [actions]=\"actions\"\n [userMenu]=\"userMenu\"\n [productSwitcher]=\"productSwitcher\"\n [subtitle]=\"subtitle\"\n [isServiceDesk]=\"isServiceDesk\"\n [sideMenuTemplate]=\"QuickAccessTemplate\"\n [productMenuItems1]=\"productMenuItems1\"\n [isOpenQuickAccess]=\"isOpenQuickAccess\"\n (isOpenQuickAccessChanged)=\"isOpenQuickAccess = $event\"\n (cultureChanged)=\"onCultureChanged($event)\"\n (notificationViewed)=\"onNotificationItemViewed($event)\"\n (notifiationActionClick)=\"onNotificationAction($event)\"\n (removeNotification)=\"onRemoveNotifications($event)\"\n (notificationLoadMore)=\"onNotificationLoadMore()\"\n (openNotificationPanel)=\"onHandleOpenNotificationPanel()\"\n>\n</bt-barsa-shellbar>\n} } } } @else { @if (notificationsCount$ | async; as notificationCount) {\n<bt-barsa-shellbar\n [class.service-desk]=\"isServiceDesk\"\n [cssUrl]=\"''\"\n [cssCustomUr]=\"''\"\n [userLoggedIn]=\"false\"\n [multiLanguages]=\"multiLanguages\"\n [userMenu]=\"userMenu\"\n [logo]=\"logo\"\n [productMenuItems1]=\"productMenuItems1\"\n [allowAnonymous]=\"allowAnonymous\"\n [deviceSize]=\"(deviceSize$ | async)!!\"\n [shellbarData]=\"shellbarData\"\n [cultures]=\"cultures\"\n [logo]=\"logo\"\n [isMobile]=\"isMobile\"\n [isTablet]=\"isTablet\"\n [isDesktop]=\"isDesktop\"\n [isServiceDesk]=\"isServiceDesk\"\n [actions]=\"actions\"\n [userMenu]=\"userMenu\"\n [productMenuControl]=\"productMenuControl\"\n [productSwitcher]=\"productSwitcher\"\n [subtitle]=\"subtitle\"\n [settings]=\"settings\"\n [notificationCount]=\"{ unread: 0, all: 0 }\"\n [notifications]=\"[]\"\n [notifcationLoaded]=\"true\"\n [notificationLoading]=\"false\"\n [hideShellbarActions]=\"true\"\n [cultures]=\"cultures\"\n [productMenuItems1]=\"productMenuItems1\"\n (cultureChanged)=\"onCultureChanged($event)\"\n>\n <button\n id=\"login_btn\"\n fd-button\n [label]=\"'\u0648\u0631\u0648\u062F' | bbbTranslate\"\n glyph=\"person-placeholder\"\n [routerLink]=\"[loginRouterLink$ | async]\"\n fdType=\"emphasized\"\n ></button>\n</bt-barsa-shellbar>\n} }\n<ng-template #QuickAccessTemplate>\n @if ((notificationLoading$ | async) === true) {\n <div style=\"position: relative; height: 100px\">\n <bsu-mask size=\"s\"></bsu-mask>\n </div>\n }\n <bnrc-report-container *ngIf=\"sidebarSettings\" [settings]=\"sidebarSettings\"> </bnrc-report-container>\n <!-- <bt-popover-app-finder (closeMenu)=\"isOpenQuickAccess = false\"></bt-popover-app-finder> -->\n</ng-template>\n", styles: [":host{display:block;position:relative}:host #login_btn{background-color:transparent;border-color:transparent}:host #menu_btn{background-color:transparent;border-color:transparent}\n"] }]
|
|
197
206
|
}], ctorParameters: () => [{ type: i1.BbbTranslatePipe }, { type: i1.PortalService }, { type: i1.BreadcrumbService }, { type: i2.TilesService }, { type: i0.ChangeDetectorRef }, { type: i3.DomSanitizer }, { type: i1.NotificationService }, { type: undefined, decorators: [{
|
|
198
207
|
type: Inject,
|
|
199
208
|
args: [APP_VERSION]
|
|
@@ -207,4 +216,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
|
|
|
207
216
|
type: ViewChild,
|
|
208
217
|
args: ['notificationsDialog', { static: true, read: TemplateRef }]
|
|
209
218
|
}] } });
|
|
210
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shellbar.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-tiles/src/lib/shellbar/shellbar.component.ts","../../../../../projects/barsa-tiles/src/lib/shellbar/shellbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Inject,\n    OnInit,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\nimport { forkJoin, Observable, of, Subject } from 'rxjs';\nimport { debounceTime, map, takeUntil, tap } from 'rxjs/operators';\nimport {\n    ComboboxComponent,\n    PopoverComponent,\n    ProductSwitchItem,\n    ShellbarMenuItem,\n    ShellbarUser\n} from '@fundamental-ngx/core';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\n\nimport {\n    BaseComponent,\n    BarsaApi,\n    MetaobjectDataModel,\n    FilePictureInfoModel,\n    MoForReportModel,\n    PortalService,\n    BreadcrumbService,\n    APP_VERSION,\n    NotificationService,\n    NotificationItem,\n    NotificationAction,\n    BbbTranslatePipe,\n    AbbrevationDeviceSize,\n    getDeviceIsMobile,\n    getDeviceIsDesktop,\n    getDeviceIsTablet\n} from 'barsa-novin-ray-core';\n\nimport { TilesService } from '../tiles.service';\n\ninterface ShellbarSetting extends MetaobjectDataModel {\n    subtitle: string;\n    calcSubtitle: string;\n    logo: FilePictureInfoModel;\n    ProductSwitchItems: MoForReportModel;\n    ProductMenuItems: MoForReportModel;\n    UserMenuItems: MoForReportModel;\n    ActionItems: MoForReportModel;\n}\n\n@Component({\n    selector: 'bt-shellbar',\n    templateUrl: './shellbar.component.html',\n    styleUrls: ['./shellbar.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ShellbarComponent extends BaseComponent implements OnInit {\n    @ViewChild(ComboboxComponent) comboboxComponent: ComboboxComponent;\n    @ViewChild('popoverComponent', { static: false }) popoverComponent: PopoverComponent;\n    @ViewChild('notificationsDialog', { static: true, read: TemplateRef }) _notificationsDialog: TemplateRef<any>;\n    shellbarData: ShellbarSetting;\n    settings: MetaobjectDataModel;\n    isOpenNotificatoin = false;\n    deviceSize$: Observable<AbbrevationDeviceSize>;\n    productMenuControl: string;\n    user: ShellbarUser = {\n        initials: 'WW',\n        colorAccent: 1\n    };\n\n    productMenuItems1: ShellbarMenuItem[];\n    userLoggedIn$: Observable<boolean>;\n    cssUrl$: Observable<SafeResourceUrl | null>;\n    cssCustomUrl$: Observable<SafeResourceUrl | null>;\n    allowAnonymous = true;\n    cultures: Record<string, any>;\n    notificationsCount$: Observable<{ unread: number; all: number }>;\n    notifications$: Observable<NotificationItem[]>;\n    notificationLoading$: Observable<boolean>;\n    notifcationLoaded = false;\n    notifiationCountLoaded$: Observable<boolean>;\n    _viewedNotifications$ = new Subject<NotificationItem>();\n    _viewedNotifications: NotificationItem[] = [];\n    bodyClick = ';$(\"body\").click()';\n    isMobile = getDeviceIsMobile();\n    isDesktop = getDeviceIsDesktop();\n    isTablet = getDeviceIsTablet();\n    loginRouterLink$: Observable<string>;\n    isServiceDesk = false;\n    isOpenQuickAccess = false;\n    get subtitle(): string {\n        if (!this.shellbarData) {\n            return '';\n        }\n        if (this._portalService.deviceSize === 's' && this.shellbarData.MobileSubtitle) {\n            return this.shellbarData.MobileSubtitle\n                ? `${this.shellbarData.MobileSubtitle} ${\n                      typeof this.shellbarData?.calcSubtitle === 'string' ? this.shellbarData.calcSubtitle : ''\n                  }`\n                : '';\n        }\n        return this.shellbarData.Subtitle\n            ? `${this.shellbarData?.Subtitle} ${\n                  typeof this.shellbarData?.calcSubtitle === 'string' ? this.shellbarData.calcSubtitle : ''\n              }`\n            : '';\n    }\n    get logo(): { FileId: string } {\n        return this.shellbarData?.Logo;\n    }\n    get actions(): Array<MetaobjectDataModel> {\n        return this.settings?.HideUserMenu ? [] : this.shellbarData?.ActionItems?.MoDataList ?? [];\n    }\n    get userMenu(): { text: string; callback: () => void }[] {\n        const moDataList = BarsaApi.Common.Util.TryGetValue(this.shellbarData, 'UserMenuItems.MoDataList');\n        const items = moDataList ? [...moDataList] : [];\n        if (!items.length) {\n            return [];\n        }\n        items.forEach((c) => {\n            c.text = this._bbbTranslatePipe.transform(c.text);\n            c.callback = new Function(c.Code + this.bodyClick);\n        });\n        if (!BarsaApi.LoginFormData.IsAnonymous && BarsaApi.LoginFormData.IsUserLoggedIn) {\n            items.splice(0, 0, { Id: '-1', $Caption: '', text: BarsaApi.LoginFormData.UserDisplayName });\n        }\n        return this.settings?.HideUserMenu ? [] : (items as any);\n    }\n    get productSwitcher(): ProductSwitchItem[] {\n        return (this.shellbarData?.ProductSwitchItems?.MoDataList ?? []) as unknown as ProductSwitchItem[];\n    }\n    get multiLanguages(): boolean {\n        return this.shellbarData?.MultiLanguages;\n    }\n    get productMenuItems(): ShellbarMenuItem[] {\n        const items = this.shellbarData?.ProductMenuItems?.MoDataList ?? [];\n        items.forEach((c) => (c.callback = new Function(c.Code + this.bodyClick)));\n        return items as unknown as ShellbarMenuItem[];\n    }\n\n    constructor(\n        private _bbbTranslatePipe: BbbTranslatePipe,\n        private _portalService: PortalService,\n        private _breadCrumbService: BreadcrumbService,\n        private _tilesService: TilesService,\n        private _cdr: ChangeDetectorRef,\n        private _domSanitizer: DomSanitizer,\n        private _notificationService: NotificationService,\n        @Inject(APP_VERSION) public appVersion: string\n    ) {\n        super();\n\n        this.userLoggedIn$ = this._portalService.userLoggedIn$;\n        this.notifiationCountLoaded$ = this._notificationService.notificationCountLoaded$;\n        this._viewedNotifications$\n            .pipe(\n                takeUntil(this._onDestroy$),\n                tap((item) => this._viewedNotifications.push(item)),\n                map((item) => this._viewedNotifications),\n                debounceTime(2000),\n                map((items) => items.map((item) => item.Tag))\n            )\n            .subscribe((tags) => {\n                this._viewedNotifications = [];\n                this._notificationService.setNotificationViewed(tags);\n            });\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.isServiceDesk = BarsaApi.LoginFormData.IsServiceDesk;\n\n        this.cultures = BarsaApi.LoginFormData.Cultures;\n        this.cssUrl$ = this._portalService.cssUrl$;\n        this.cssCustomUrl$ = this._portalService.cssCustomUrl$;\n        this.loginRouterLink$ = this._portalService.loginRoute$;\n        this.notificationsCount$ = this._notificationService.notificationCount$;\n        this._notificationService.notificationCount$.subscribe(() => this._cdr.detectChanges());\n        this.notificationLoading$ = this._notificationService.notificationLoading$;\n        this.notifications$ = this._notificationService.notifications$.pipe(\n            takeUntil(this._onDestroy$),\n            map((notifications) => this._mapNotifications(notifications))\n        );\n        BarsaApi.Bw.SetUserPortalSettings = (userPortalSettings: MetaobjectDataModel): void => {\n            this._portalService.setUserPortalSettings(userPortalSettings);\n        };\n        BarsaApi.Bw.SetShellbarSubtitle = (calcSubtitle: string): void => {\n            this.shellbarData.calcSubtitle = calcSubtitle;\n            this._cdr.detectChanges();\n        };\n        this.deviceSize$ = this._portalService.deviceSize$.pipe(takeUntil(this._onDestroy$));\n\n        this._breadCrumbService.breadcrumbs$.pipe(takeUntil(this._onDestroy$)).subscribe((breadCrumbs) => {\n            if (breadCrumbs.length > 0) {\n                this.productMenuControl = breadCrumbs[breadCrumbs.length - 1].label;\n            }\n            this._cdr.detectChanges();\n        });\n\n        this._tilesService.shellbar$.pipe(takeUntil(this._onDestroy$)).subscribe((mo) => {\n            this.shellbarData = mo as ShellbarSetting;\n            // this._cdr.detectChanges();\n            forkJoin([of(this.productMenuItems), of([])]) // to append user defined\n                .pipe(\n                    takeUntil(this._onDestroy$),\n                    map(([s1, s2]) => [...s1, ...s2])\n                )\n                .subscribe((c) => {\n                    this.productMenuItems1 = c;\n                    this._cdr.detectChanges();\n                });\n        });\n        if (this.allowAnonymous) {\n            this._tilesService.loadShellbar();\n        }\n        this._portalService.userLoggedIn$.pipe(takeUntil(this._onDestroy$)).subscribe((loggedIn) => {\n            if (!loggedIn) {\n                return;\n            }\n            this._tilesService.loadShellbar();\n            this._notificationService.loadUnreadNotificationCount();\n        });\n    }\n\n    onCultureChange(culture): void {\n        this._changeCulture(culture);\n    }\n    onShowNotification(e: { tag: string; mo: MetaobjectDataModel; nama: string }): void {\n        this.isOpenNotificatoin = false;\n        this._notificationService.ShowNotificationRelatedMo(e);\n    }\n    onNotificationItemViewed(viewedMo: NotificationItem): void {\n        this._viewedNotifications$.next(viewedMo);\n    }\n\n    onRemoveNotifications(e: { items: MetaobjectDataModel[]; silent: boolean }): void {\n        this._notificationService.removeNotification(e.items);\n    }\n    onOpenNotification = (): void => {\n        this.isOpenNotificatoin = true;\n        this._handleOpenNotificationPanel();\n    };\n    onNotificationAction(e: { item: NotificationItem; btn: NotificationAction }): void {\n        this._portalService.ExecuteNotificationAction(e.item.Tag, e.btn.Title);\n    }\n    onCultureChanged = (culture: string): void => {\n        this._changeCulture(culture);\n    };\n    onNotificationLoadMore(): void {\n        this._notificationService.loadMore();\n    }\n    onNotificationWorkflowChoiceSuccess(result): void {}\n    onNotificationWorkflowChoiceFailed(err): void {}\n\n    onHandleOpenNotificationPanel(): void {\n        this._handleOpenNotificationPanel();\n    }\n\n    private _handleOpenNotificationPanel(): void {\n        if (this.notifcationLoaded) {\n            return;\n        }\n        this.notifcationLoaded = true;\n        this._notificationService.loadNotifications();\n    }\n    private _mapNotifications(notifications): NotificationItem[] {\n        return notifications.map((notification) => ({\n            ...notification,\n            contentSafeHtml: notification.Content\n                ? this._domSanitizer.bypassSecurityTrustHtml(notification.Content)\n                : ''\n        }));\n    }\n    private _changeCulture(culture: string /* culture sample :English */): void {\n        BarsaApi.Bw.SetCultureByDisplayName(culture);\n        BarsaApi.Bw.NavigateTo('/');\n    }\n}\n","@if (userLoggedIn$ | async; as userloggend) { @if (notifiationCountLoaded$ | async; as notifiationCountLoaded) { @if\n(deviceSize$ | async; as deviceSize) { @if (shellbarData) {\n<bt-barsa-shellbar\n    [class.service-desk]=\"isServiceDesk\"\n    [cssUrl]=\"cssUrl$ | async\"\n    [cssCustomUrl]=\"cssCustomUrl$ | async\"\n    [userLoggedIn]=\"true\"\n    [allowAnonymous]=\"allowAnonymous\"\n    [deviceSize]=\"deviceSize\"\n    [shellbarData]=\"shellbarData\"\n    [productMenuControl]=\"productMenuControl\"\n    [settings]=\"settings\"\n    [isMobile]=\"isMobile\"\n    [isTablet]=\"isTablet\"\n    [isDesktop]=\"isDesktop\"\n    [multiLanguages]=\"multiLanguages\"\n    [notificationCount]=\"(notificationsCount$ | async)!!\"\n    [notifications]=\"(notifications$ | async) ?? []\"\n    [notifcationLoaded]=\"notifcationLoaded\"\n    [notificationLoading]=\"(notificationLoading$ | async) === true\"\n    [cultures]=\"cultures\"\n    [logo]=\"logo\"\n    [actions]=\"actions\"\n    [userMenu]=\"userMenu\"\n    [productSwitcher]=\"productSwitcher\"\n    [subtitle]=\"subtitle\"\n    [isServiceDesk]=\"isServiceDesk\"\n    [sideMenuTemplate]=\"QuickAccessTemplate\"\n    [productMenuItems1]=\"productMenuItems1\"\n    [isOpenQuickAccess]=\"isOpenQuickAccess\"\n    (isOpenQuickAccessChanged)=\"isOpenQuickAccess = $event\"\n    (cultureChanged)=\"onCultureChanged($event)\"\n    (notificationViewed)=\"onNotificationItemViewed($event)\"\n    (notifiationActionClick)=\"onNotificationAction($event)\"\n    (removeNotification)=\"onRemoveNotifications($event)\"\n    (notificationLoadMore)=\"onNotificationLoadMore()\"\n    (openNotificationPanel)=\"onHandleOpenNotificationPanel()\"\n>\n</bt-barsa-shellbar>\n} } } } @else { @if (notificationsCount$ | async; as notificationCount) {\n<bt-barsa-shellbar\n    [class.service-desk]=\"isServiceDesk\"\n    [cssUrl]=\"''\"\n    [cssCustomUr]=\"''\"\n    [userLoggedIn]=\"false\"\n    [multiLanguages]=\"multiLanguages\"\n    [userMenu]=\"userMenu\"\n    [logo]=\"logo\"\n    [productMenuItems1]=\"productMenuItems1\"\n    [allowAnonymous]=\"allowAnonymous\"\n    [deviceSize]=\"(deviceSize$ | async)!!\"\n    [shellbarData]=\"shellbarData\"\n    [cultures]=\"cultures\"\n    [logo]=\"logo\"\n    [isMobile]=\"isMobile\"\n    [isTablet]=\"isTablet\"\n    [isDesktop]=\"isDesktop\"\n    [isServiceDesk]=\"isServiceDesk\"\n    [actions]=\"actions\"\n    [userMenu]=\"userMenu\"\n    [productMenuControl]=\"productMenuControl\"\n    [productSwitcher]=\"productSwitcher\"\n    [subtitle]=\"subtitle\"\n    [settings]=\"settings\"\n    [notificationCount]=\"{ unread: 0, all: 0 }\"\n    [notifications]=\"[]\"\n    [notifcationLoaded]=\"true\"\n    [notificationLoading]=\"false\"\n    [hideShellbarActions]=\"true\"\n    [cultures]=\"cultures\"\n    [productMenuItems1]=\"productMenuItems1\"\n    (cultureChanged)=\"onCultureChanged($event)\"\n>\n    <button\n        id=\"login_btn\"\n        fd-button\n        [label]=\"'ورود' | bbbTranslate\"\n        glyph=\"person-placeholder\"\n        [routerLink]=\"[loginRouterLink$ | async]\"\n        fdType=\"emphasized\"\n    ></button>\n</bt-barsa-shellbar>\n} }\n<ng-template #QuickAccessTemplate>\n    @if ((notificationLoading$ | async) === true) {\n    <div style=\"position: relative; height: 100px\">\n        <bsu-mask size=\"s\"></bsu-mask>\n    </div>\n    }\n    <bt-popover-app-finder (closeMenu)=\"isOpenQuickAccess = false\"></bt-popover-app-finder>\n</ng-template>\n"]}
|
|
219
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shellbar.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-tiles/src/lib/shellbar/shellbar.component.ts","../../../../../projects/barsa-tiles/src/lib/shellbar/shellbar.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,uBAAuB,EAEvB,SAAS,EACT,MAAM,EAEN,WAAW,EACX,SAAS,EACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAAc,EAAE,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACnE,OAAO,EACH,iBAAiB,EAKpB,MAAM,uBAAuB,CAAC;AAG/B,OAAO,EACH,aAAa,EACb,QAAQ,EAMR,WAAW,EAMX,iBAAiB,EACjB,kBAAkB,EAClB,iBAAiB,EACpB,MAAM,sBAAsB,CAAC;;;;;;;;;AAqB9B,MAAM,OAAO,iBAAkB,SAAQ,aAAa;IAkChD,IAAI,QAAQ;QACR,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACrB,OAAO,EAAE,CAAC;QACd,CAAC;QACD,IAAI,IAAI,CAAC,cAAc,CAAC,UAAU,KAAK,GAAG,IAAI,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,CAAC;YAC7E,OAAO,IAAI,CAAC,YAAY,CAAC,cAAc;gBACnC,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,cAAc,IAC/B,OAAO,IAAI,CAAC,YAAY,EAAE,YAAY,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC,CAAC,EAC3F,EAAE;gBACJ,CAAC,CAAC,EAAE,CAAC;QACb,CAAC;QACD,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ;YAC7B,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,EAAE,QAAQ,IAC1B,OAAO,IAAI,CAAC,YAAY,EAAE,YAAY,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC,CAAC,EAC3F,EAAE;YACJ,CAAC,CAAC,EAAE,CAAC;IACb,CAAC;IACD,IAAI,IAAI;QACJ,OAAO,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC;IACnC,CAAC;IACD,IAAI,OAAO;QACP,OAAO,IAAI,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,WAAW,EAAE,UAAU,IAAI,EAAE,CAAC;IAC/F,CAAC;IACD,IAAI,eAAe;QACf,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,aAAa,EAAE,EAAE,EAAE,CAAC;YACxC,OAAO,IAAI,CAAC;QAChB,CAAC;QACD,OAAO;YACH,aAAa,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,YAAY,EAAE,aAAa,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE;YACzE,QAAQ,EAAE,EAAE;YACZ,QAAQ,EAAE,KAAK;SAClB,CAAC;IACN,CAAC;IACD,IAAI,QAAQ;QACR,MAAM,UAAU,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,EAAE,0BAA0B,CAAC,CAAC;QACnG,MAAM,KAAK,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAChD,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;YAChB,OAAO,EAAE,CAAC;QACd,CAAC;QACD,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;YAChB,CAAC,CAAC,IAAI,GAAG,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;YAClD,CAAC,CAAC,QAAQ,GAAG,IAAI,QAAQ,CAAC,CAAC,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;QACvD,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,WAAW,IAAI,QAAQ,CAAC,aAAa,CAAC,cAAc,EAAE,CAAC;YAC/E,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,QAAQ,CAAC,aAAa,CAAC,eAAe,EAAE,CAAC,CAAC;QACjG,CAAC;QACD,OAAO,IAAI,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAE,KAAa,CAAC;IAC7D,CAAC;IACD,IAAI,eAAe;QACf,OAAO,CAAC,IAAI,CAAC,YAAY,EAAE,kBAAkB,EAAE,UAAU,IAAI,EAAE,CAAmC,CAAC;IACvG,CAAC;IACD,IAAI,cAAc;QACd,OAAO,IAAI,CAAC,YAAY,EAAE,cAAc,CAAC;IAC7C,CAAC;IACD,IAAI,gBAAgB;QAChB,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,gBAAgB,EAAE,UAAU,IAAI,EAAE,CAAC;QACpE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,GAAG,IAAI,QAAQ,CAAC,CAAC,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QAC3E,OAAO,KAAsC,CAAC;IAClD,CAAC;IAED,YACY,iBAAmC,EACnC,cAA6B,EAC7B,kBAAqC,EACrC,aAA2B,EAC3B,IAAuB,EACvB,aAA2B,EAC3B,oBAAyC,EACrB,UAAkB;QAE9C,KAAK,EAAE,CAAC;QATA,sBAAiB,GAAjB,iBAAiB,CAAkB;QACnC,mBAAc,GAAd,cAAc,CAAe;QAC7B,uBAAkB,GAAlB,kBAAkB,CAAmB;QACrC,kBAAa,GAAb,aAAa,CAAc;QAC3B,SAAI,GAAJ,IAAI,CAAmB;QACvB,kBAAa,GAAb,aAAa,CAAc;QAC3B,yBAAoB,GAApB,oBAAoB,CAAqB;QACrB,eAAU,GAAV,UAAU,CAAQ;QAhGlD,uBAAkB,GAAG,KAAK,CAAC;QAG3B,SAAI,GAAiB;YACjB,QAAQ,EAAE,IAAI;YACd,WAAW,EAAE,CAAC;SACjB,CAAC;QAMF,mBAAc,GAAG,IAAI,CAAC;QAKtB,sBAAiB,GAAG,KAAK,CAAC;QAE1B,0BAAqB,GAAG,IAAI,OAAO,EAAoB,CAAC;QACxD,yBAAoB,GAAuB,EAAE,CAAC;QAC9C,cAAS,GAAG,oBAAoB,CAAC;QACjC,aAAQ,GAAG,iBAAiB,EAAE,CAAC;QAC/B,cAAS,GAAG,kBAAkB,EAAE,CAAC;QACjC,aAAQ,GAAG,iBAAiB,EAAE,CAAC;QAE/B,kBAAa,GAAG,KAAK,CAAC;QACtB,sBAAiB,GAAG,KAAK,CAAC;QAgK1B,uBAAkB,GAAG,GAAS,EAAE;YAC5B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;YAC/B,IAAI,CAAC,4BAA4B,EAAE,CAAC;QACxC,CAAC,CAAC;QAIF,qBAAgB,GAAG,CAAC,OAAe,EAAQ,EAAE;YACzC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;QACjC,CAAC,CAAC;QAhGE,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC;QACvD,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,oBAAoB,CAAC,wBAAwB,CAAC;QAClF,IAAI,CAAC,qBAAqB;aACrB,IAAI,CACD,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,EAC3B,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,EACnD,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,EACxC,YAAY,CAAC,IAAI,CAAC,EAClB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAChD;aACA,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YAChB,IAAI,CAAC,oBAAoB,GAAG,EAAE,CAAC;YAC/B,IAAI,CAAC,oBAAoB,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;IACX,CAAC;IAED,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;QAEjB,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC;QAE1D,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC;QAChD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;QAC3C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC;QACvD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC;QACxD,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,oBAAoB,CAAC,kBAAkB,CAAC;QACxE,IAAI,CAAC,oBAAoB,CAAC,kBAAkB,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;QACxF,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,oBAAoB,CAAC,oBAAoB,CAAC;QAC3E,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,oBAAoB,CAAC,cAAc,CAAC,IAAI,CAC/D,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,EAC3B,GAAG,CAAC,CAAC,aAAa,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC,CAChE,CAAC;QACF,QAAQ,CAAC,EAAE,CAAC,qBAAqB,GAAG,CAAC,kBAAuC,EAAQ,EAAE;YAClF,IAAI,CAAC,cAAc,CAAC,qBAAqB,CAAC,kBAAkB,CAAC,CAAC;QAClE,CAAC,CAAC;QACF,QAAQ,CAAC,EAAE,CAAC,mBAAmB,GAAG,CAAC,YAAoB,EAAQ,EAAE;YAC7D,IAAI,CAAC,YAAY,CAAC,YAAY,GAAG,YAAY,CAAC;YAC9C,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;QAC9B,CAAC,CAAC;QACF,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;QAErF,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,EAAE;YAC7F,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACzB,IAAI,CAAC,kBAAkB,GAAG,WAAW,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC;YACxE,CAAC;YACD,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;QAC9B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,EAAE;YAC5E,IAAI,CAAC,YAAY,GAAG,EAAqB,CAAC;YAC1C,6BAA6B;YAC7B,QAAQ,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,yBAAyB;iBAClE,IAAI,CACD,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,EAC3B,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC,CACpC;iBACA,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;gBACb,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;gBAC3B,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YAC9B,CAAC,CAAC,CAAC;QACX,CAAC,CAAC,CAAC;QACH,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;QACtC,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YACvF,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACZ,OAAO;YACX,CAAC;YACD,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;YAClC,IAAI,CAAC,oBAAoB,CAAC,2BAA2B,EAAE,CAAC;QAC5D,CAAC,CAAC,CAAC;IACP,CAAC;IAED,eAAe,CAAC,OAAO;QACnB,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;IACD,kBAAkB,CAAC,CAAyD;QACxE,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;QAChC,IAAI,CAAC,oBAAoB,CAAC,yBAAyB,CAAC,CAAC,CAAC,CAAC;IAC3D,CAAC;IACD,wBAAwB,CAAC,QAA0B;QAC/C,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC9C,CAAC;IAED,qBAAqB,CAAC,CAAoD;QACtE,IAAI,CAAC,oBAAoB,CAAC,kBAAkB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IAC1D,CAAC;IAKD,oBAAoB,CAAC,CAAsD;QACvE,IAAI,CAAC,cAAc,CAAC,yBAAyB,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAC3E,CAAC;IAID,sBAAsB;QAClB,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,CAAC;IACzC,CAAC;IACD,mCAAmC,CAAC,MAAM,IAAS,CAAC;IACpD,kCAAkC,CAAC,GAAG,IAAS,CAAC;IAEhD,6BAA6B;QACzB,IAAI,CAAC,4BAA4B,EAAE,CAAC;IACxC,CAAC;IAEO,4BAA4B;QAChC,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,OAAO;QACX,CAAC;QACD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,oBAAoB,CAAC,iBAAiB,EAAE,CAAC;IAClD,CAAC;IACO,iBAAiB,CAAC,aAAa;QACnC,OAAO,aAAa,CAAC,GAAG,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;YACxC,GAAG,YAAY;YACf,eAAe,EAAE,YAAY,CAAC,OAAO;gBACjC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,uBAAuB,CAAC,YAAY,CAAC,OAAO,CAAC;gBAClE,CAAC,CAAC,EAAE;SACX,CAAC,CAAC,CAAC;IACR,CAAC;IACO,cAAc,CAAC,OAAe,CAAC,6BAA6B;QAChE,QAAQ,CAAC,EAAE,CAAC,uBAAuB,CAAC,OAAO,CAAC,CAAC;QAC7C,QAAQ,CAAC,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;IAChC,CAAC;8GAvOQ,iBAAiB,4OAsGd,WAAW;kGAtGd,iBAAiB,sGACf,iBAAiB,gPAE4B,WAAW,kEC7DvE,8hHA4FA;;2FDlCa,iBAAiB;kBAN7B,SAAS;+BACI,aAAa,mBAGN,uBAAuB,CAAC,MAAM;;0BAwG1C,MAAM;2BAAC,WAAW;yCArGO,iBAAiB;sBAA9C,SAAS;uBAAC,iBAAiB;gBACsB,gBAAgB;sBAAjE,SAAS;uBAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBACuB,oBAAoB;sBAA1F,SAAS;uBAAC,qBAAqB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,WAAW,EAAE","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Inject,\n    OnInit,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\nimport { forkJoin, Observable, of, Subject } from 'rxjs';\nimport { debounceTime, map, takeUntil, tap } from 'rxjs/operators';\nimport {\n    ComboboxComponent,\n    PopoverComponent,\n    ProductSwitchItem,\n    ShellbarMenuItem,\n    ShellbarUser\n} from '@fundamental-ngx/core';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\n\nimport {\n    BaseComponent,\n    BarsaApi,\n    MetaobjectDataModel,\n    FilePictureInfoModel,\n    MoForReportModel,\n    PortalService,\n    BreadcrumbService,\n    APP_VERSION,\n    NotificationService,\n    NotificationItem,\n    NotificationAction,\n    BbbTranslatePipe,\n    AbbrevationDeviceSize,\n    getDeviceIsMobile,\n    getDeviceIsDesktop,\n    getDeviceIsTablet\n} from 'barsa-novin-ray-core';\n\nimport { TilesService } from '../tiles.service';\n\ninterface ShellbarSetting extends MetaobjectDataModel {\n    subtitle: string;\n    calcSubtitle: string;\n    logo: FilePictureInfoModel;\n    ProductSwitchItems: MoForReportModel;\n    ProductMenuItems: MoForReportModel;\n    UserMenuItems: MoForReportModel;\n    ActionItems: MoForReportModel;\n    SidebarReport: MetaobjectDataModel;\n}\n\n@Component({\n    selector: 'bt-shellbar',\n    templateUrl: './shellbar.component.html',\n    styleUrls: ['./shellbar.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ShellbarComponent extends BaseComponent implements OnInit {\n    @ViewChild(ComboboxComponent) comboboxComponent: ComboboxComponent;\n    @ViewChild('popoverComponent', { static: false }) popoverComponent: PopoverComponent;\n    @ViewChild('notificationsDialog', { static: true, read: TemplateRef }) _notificationsDialog: TemplateRef<any>;\n    shellbarData: ShellbarSetting;\n    settings: MetaobjectDataModel;\n    isOpenNotificatoin = false;\n    deviceSize$: Observable<AbbrevationDeviceSize>;\n    productMenuControl: string;\n    user: ShellbarUser = {\n        initials: 'WW',\n        colorAccent: 1\n    };\n\n    productMenuItems1: ShellbarMenuItem[];\n    userLoggedIn$: Observable<boolean>;\n    cssUrl$: Observable<SafeResourceUrl | null>;\n    cssCustomUrl$: Observable<SafeResourceUrl | null>;\n    allowAnonymous = true;\n    cultures: Record<string, any>;\n    notificationsCount$: Observable<{ unread: number; all: number }>;\n    notifications$: Observable<NotificationItem[]>;\n    notificationLoading$: Observable<boolean>;\n    notifcationLoaded = false;\n    notifiationCountLoaded$: Observable<boolean>;\n    _viewedNotifications$ = new Subject<NotificationItem>();\n    _viewedNotifications: NotificationItem[] = [];\n    bodyClick = ';$(\"body\").click()';\n    isMobile = getDeviceIsMobile();\n    isDesktop = getDeviceIsDesktop();\n    isTablet = getDeviceIsTablet();\n    loginRouterLink$: Observable<string>;\n    isServiceDesk = false;\n    isOpenQuickAccess = false;\n    get subtitle(): string {\n        if (!this.shellbarData) {\n            return '';\n        }\n        if (this._portalService.deviceSize === 's' && this.shellbarData.MobileSubtitle) {\n            return this.shellbarData.MobileSubtitle\n                ? `${this.shellbarData.MobileSubtitle} ${\n                      typeof this.shellbarData?.calcSubtitle === 'string' ? this.shellbarData.calcSubtitle : ''\n                  }`\n                : '';\n        }\n        return this.shellbarData.Subtitle\n            ? `${this.shellbarData?.Subtitle} ${\n                  typeof this.shellbarData?.calcSubtitle === 'string' ? this.shellbarData.calcSubtitle : ''\n              }`\n            : '';\n    }\n    get logo(): { FileId: string } {\n        return this.shellbarData?.Logo;\n    }\n    get actions(): Array<MetaobjectDataModel> {\n        return this.settings?.HideUserMenu ? [] : this.shellbarData?.ActionItems?.MoDataList ?? [];\n    }\n    get sidebarSettings(): null | any {\n        if (!this.shellbarData?.SidebarReport?.Id) {\n            return null;\n        }\n        return {\n            RelatedReport: { Id: this.shellbarData?.SidebarReport?.Id, $Caption: '' },\n            RowClick: '',\n            DataOnly: false\n        };\n    }\n    get userMenu(): { text: string; callback: () => void }[] {\n        const moDataList = BarsaApi.Common.Util.TryGetValue(this.shellbarData, 'UserMenuItems.MoDataList');\n        const items = moDataList ? [...moDataList] : [];\n        if (!items.length) {\n            return [];\n        }\n        items.forEach((c) => {\n            c.text = this._bbbTranslatePipe.transform(c.text);\n            c.callback = new Function(c.Code + this.bodyClick);\n        });\n        if (!BarsaApi.LoginFormData.IsAnonymous && BarsaApi.LoginFormData.IsUserLoggedIn) {\n            items.splice(0, 0, { Id: '-1', $Caption: '', text: BarsaApi.LoginFormData.UserDisplayName });\n        }\n        return this.settings?.HideUserMenu ? [] : (items as any);\n    }\n    get productSwitcher(): ProductSwitchItem[] {\n        return (this.shellbarData?.ProductSwitchItems?.MoDataList ?? []) as unknown as ProductSwitchItem[];\n    }\n    get multiLanguages(): boolean {\n        return this.shellbarData?.MultiLanguages;\n    }\n    get productMenuItems(): ShellbarMenuItem[] {\n        const items = this.shellbarData?.ProductMenuItems?.MoDataList ?? [];\n        items.forEach((c) => (c.callback = new Function(c.Code + this.bodyClick)));\n        return items as unknown as ShellbarMenuItem[];\n    }\n\n    constructor(\n        private _bbbTranslatePipe: BbbTranslatePipe,\n        private _portalService: PortalService,\n        private _breadCrumbService: BreadcrumbService,\n        private _tilesService: TilesService,\n        private _cdr: ChangeDetectorRef,\n        private _domSanitizer: DomSanitizer,\n        private _notificationService: NotificationService,\n        @Inject(APP_VERSION) public appVersion: string\n    ) {\n        super();\n\n        this.userLoggedIn$ = this._portalService.userLoggedIn$;\n        this.notifiationCountLoaded$ = this._notificationService.notificationCountLoaded$;\n        this._viewedNotifications$\n            .pipe(\n                takeUntil(this._onDestroy$),\n                tap((item) => this._viewedNotifications.push(item)),\n                map((item) => this._viewedNotifications),\n                debounceTime(2000),\n                map((items) => items.map((item) => item.Tag))\n            )\n            .subscribe((tags) => {\n                this._viewedNotifications = [];\n                this._notificationService.setNotificationViewed(tags);\n            });\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n\n        this.isServiceDesk = BarsaApi.LoginFormData.IsServiceDesk;\n\n        this.cultures = BarsaApi.LoginFormData.Cultures;\n        this.cssUrl$ = this._portalService.cssUrl$;\n        this.cssCustomUrl$ = this._portalService.cssCustomUrl$;\n        this.loginRouterLink$ = this._portalService.loginRoute$;\n        this.notificationsCount$ = this._notificationService.notificationCount$;\n        this._notificationService.notificationCount$.subscribe(() => this._cdr.detectChanges());\n        this.notificationLoading$ = this._notificationService.notificationLoading$;\n        this.notifications$ = this._notificationService.notifications$.pipe(\n            takeUntil(this._onDestroy$),\n            map((notifications) => this._mapNotifications(notifications))\n        );\n        BarsaApi.Bw.SetUserPortalSettings = (userPortalSettings: MetaobjectDataModel): void => {\n            this._portalService.setUserPortalSettings(userPortalSettings);\n        };\n        BarsaApi.Bw.SetShellbarSubtitle = (calcSubtitle: string): void => {\n            this.shellbarData.calcSubtitle = calcSubtitle;\n            this._cdr.detectChanges();\n        };\n        this.deviceSize$ = this._portalService.deviceSize$.pipe(takeUntil(this._onDestroy$));\n\n        this._breadCrumbService.breadcrumbs$.pipe(takeUntil(this._onDestroy$)).subscribe((breadCrumbs) => {\n            if (breadCrumbs.length > 0) {\n                this.productMenuControl = breadCrumbs[breadCrumbs.length - 1].label;\n            }\n            this._cdr.detectChanges();\n        });\n\n        this._tilesService.shellbar$.pipe(takeUntil(this._onDestroy$)).subscribe((mo) => {\n            this.shellbarData = mo as ShellbarSetting;\n            // this._cdr.detectChanges();\n            forkJoin([of(this.productMenuItems), of([])]) // to append user defined\n                .pipe(\n                    takeUntil(this._onDestroy$),\n                    map(([s1, s2]) => [...s1, ...s2])\n                )\n                .subscribe((c) => {\n                    this.productMenuItems1 = c;\n                    this._cdr.detectChanges();\n                });\n        });\n        if (this.allowAnonymous) {\n            this._tilesService.loadShellbar();\n        }\n        this._portalService.userLoggedIn$.pipe(takeUntil(this._onDestroy$)).subscribe((loggedIn) => {\n            if (!loggedIn) {\n                return;\n            }\n            this._tilesService.loadShellbar();\n            this._notificationService.loadUnreadNotificationCount();\n        });\n    }\n\n    onCultureChange(culture): void {\n        this._changeCulture(culture);\n    }\n    onShowNotification(e: { tag: string; mo: MetaobjectDataModel; nama: string }): void {\n        this.isOpenNotificatoin = false;\n        this._notificationService.ShowNotificationRelatedMo(e);\n    }\n    onNotificationItemViewed(viewedMo: NotificationItem): void {\n        this._viewedNotifications$.next(viewedMo);\n    }\n\n    onRemoveNotifications(e: { items: MetaobjectDataModel[]; silent: boolean }): void {\n        this._notificationService.removeNotification(e.items);\n    }\n    onOpenNotification = (): void => {\n        this.isOpenNotificatoin = true;\n        this._handleOpenNotificationPanel();\n    };\n    onNotificationAction(e: { item: NotificationItem; btn: NotificationAction }): void {\n        this._portalService.ExecuteNotificationAction(e.item.Tag, e.btn.Title);\n    }\n    onCultureChanged = (culture: string): void => {\n        this._changeCulture(culture);\n    };\n    onNotificationLoadMore(): void {\n        this._notificationService.loadMore();\n    }\n    onNotificationWorkflowChoiceSuccess(result): void {}\n    onNotificationWorkflowChoiceFailed(err): void {}\n\n    onHandleOpenNotificationPanel(): void {\n        this._handleOpenNotificationPanel();\n    }\n\n    private _handleOpenNotificationPanel(): void {\n        if (this.notifcationLoaded) {\n            return;\n        }\n        this.notifcationLoaded = true;\n        this._notificationService.loadNotifications();\n    }\n    private _mapNotifications(notifications): NotificationItem[] {\n        return notifications.map((notification) => ({\n            ...notification,\n            contentSafeHtml: notification.Content\n                ? this._domSanitizer.bypassSecurityTrustHtml(notification.Content)\n                : ''\n        }));\n    }\n    private _changeCulture(culture: string /* culture sample :English */): void {\n        BarsaApi.Bw.SetCultureByDisplayName(culture);\n        BarsaApi.Bw.NavigateTo('/');\n    }\n}\n","@if (userLoggedIn$ | async; as userloggend) { @if (notifiationCountLoaded$ | async; as notifiationCountLoaded) { @if\n(deviceSize$ | async; as deviceSize) { @if (shellbarData) {\n<bt-barsa-shellbar\n    [class.service-desk]=\"isServiceDesk\"\n    [cssUrl]=\"cssUrl$ | async\"\n    [cssCustomUrl]=\"cssCustomUrl$ | async\"\n    [userLoggedIn]=\"true\"\n    [allowAnonymous]=\"allowAnonymous\"\n    [deviceSize]=\"deviceSize\"\n    [shellbarData]=\"shellbarData\"\n    [productMenuControl]=\"productMenuControl\"\n    [settings]=\"settings\"\n    [isMobile]=\"isMobile\"\n    [isTablet]=\"isTablet\"\n    [isDesktop]=\"isDesktop\"\n    [multiLanguages]=\"multiLanguages\"\n    [notificationCount]=\"(notificationsCount$ | async)!!\"\n    [notifications]=\"(notifications$ | async) ?? []\"\n    [notifcationLoaded]=\"notifcationLoaded\"\n    [notificationLoading]=\"(notificationLoading$ | async) === true\"\n    [cultures]=\"cultures\"\n    [logo]=\"logo\"\n    [actions]=\"actions\"\n    [userMenu]=\"userMenu\"\n    [productSwitcher]=\"productSwitcher\"\n    [subtitle]=\"subtitle\"\n    [isServiceDesk]=\"isServiceDesk\"\n    [sideMenuTemplate]=\"QuickAccessTemplate\"\n    [productMenuItems1]=\"productMenuItems1\"\n    [isOpenQuickAccess]=\"isOpenQuickAccess\"\n    (isOpenQuickAccessChanged)=\"isOpenQuickAccess = $event\"\n    (cultureChanged)=\"onCultureChanged($event)\"\n    (notificationViewed)=\"onNotificationItemViewed($event)\"\n    (notifiationActionClick)=\"onNotificationAction($event)\"\n    (removeNotification)=\"onRemoveNotifications($event)\"\n    (notificationLoadMore)=\"onNotificationLoadMore()\"\n    (openNotificationPanel)=\"onHandleOpenNotificationPanel()\"\n>\n</bt-barsa-shellbar>\n} } } } @else { @if (notificationsCount$ | async; as notificationCount) {\n<bt-barsa-shellbar\n    [class.service-desk]=\"isServiceDesk\"\n    [cssUrl]=\"''\"\n    [cssCustomUr]=\"''\"\n    [userLoggedIn]=\"false\"\n    [multiLanguages]=\"multiLanguages\"\n    [userMenu]=\"userMenu\"\n    [logo]=\"logo\"\n    [productMenuItems1]=\"productMenuItems1\"\n    [allowAnonymous]=\"allowAnonymous\"\n    [deviceSize]=\"(deviceSize$ | async)!!\"\n    [shellbarData]=\"shellbarData\"\n    [cultures]=\"cultures\"\n    [logo]=\"logo\"\n    [isMobile]=\"isMobile\"\n    [isTablet]=\"isTablet\"\n    [isDesktop]=\"isDesktop\"\n    [isServiceDesk]=\"isServiceDesk\"\n    [actions]=\"actions\"\n    [userMenu]=\"userMenu\"\n    [productMenuControl]=\"productMenuControl\"\n    [productSwitcher]=\"productSwitcher\"\n    [subtitle]=\"subtitle\"\n    [settings]=\"settings\"\n    [notificationCount]=\"{ unread: 0, all: 0 }\"\n    [notifications]=\"[]\"\n    [notifcationLoaded]=\"true\"\n    [notificationLoading]=\"false\"\n    [hideShellbarActions]=\"true\"\n    [cultures]=\"cultures\"\n    [productMenuItems1]=\"productMenuItems1\"\n    (cultureChanged)=\"onCultureChanged($event)\"\n>\n    <button\n        id=\"login_btn\"\n        fd-button\n        [label]=\"'ورود' | bbbTranslate\"\n        glyph=\"person-placeholder\"\n        [routerLink]=\"[loginRouterLink$ | async]\"\n        fdType=\"emphasized\"\n    ></button>\n</bt-barsa-shellbar>\n} }\n<ng-template #QuickAccessTemplate>\n    @if ((notificationLoading$ | async) === true) {\n    <div style=\"position: relative; height: 100px\">\n        <bsu-mask size=\"s\"></bsu-mask>\n    </div>\n    }\n    <bnrc-report-container *ngIf=\"sidebarSettings\" [settings]=\"sidebarSettings\"> </bnrc-report-container>\n    <!-- <bt-popover-app-finder (closeMenu)=\"isOpenQuickAccess = false\"></bt-popover-app-finder> -->\n</ng-template>\n"]}
|