����JFIF��x�x����'
Server IP : 78.140.185.180 / Your IP : 216.73.216.170 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 : /home/builderbox/./././www/public/client/ |
Upload File : |
{"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/notifications-routing.module.ts","webpack:///src/common/notifications/notification-page/notification-page.component.ts","webpack:///src/common/notifications/notification-page/notification-page.component.html","webpack:///src/common/shared/pagination-widget/pagination-widget.module.ts","webpack:///src/common/notifications/notifications.module.ts"],"names":["NotificationSubscriptionsService","http","userId","this","get","selections","put","$event","stopPropagation","NotificationSubscriptionsComponent","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","NotificationSubscriptionsResolverService","router","state","getAll","catchError","navigate","mergeMap","response","of","PaginationWidgetComponent","pageChanged","disabled","numberOfPages","value","last_page","iterator","Array","from","map","n","currentPage","current_page","page","queryParams","replaceUrl","newPage","selectPage","prevPage","nextPage","routes","path","component","NotificationPageComponent","notifications","breakpoints","pagination$","loadPage","snapshot","load","perPage","pagination","markedNotif","find","id","read_at","markAsRead","resolve","permissions","NotificationsRoutingModule","forChild","PaginationWidgetModule","NotificationsModule"],"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 {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 {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","<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","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","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"]}