import { Component, OnDestroy, OnInit } from '@angular/core' import { ActivatedRoute, Router } from '@angular/router' import { AuthService, ComponentPagination, ConfirmService, LocalStorageService, Notifier, ScreenService, ServerService, UserService } from '@app/core' import { immutableAssign } from '@app/helpers' import { UserHistoryService } from '@app/shared/shared-main' import { AbstractVideoList } from '@app/shared/shared-video-miniature' @Component({ selector: 'my-account-history', templateUrl: './my-account-history.component.html', styleUrls: [ './my-account-history.component.scss' ] }) export class MyAccountHistoryComponent extends AbstractVideoList implements OnInit, OnDestroy { titlePage: string pagination: ComponentPagination = { currentPage: 1, itemsPerPage: 5, totalItems: null } videosHistoryEnabled: boolean constructor ( protected router: Router, protected serverService: ServerService, protected route: ActivatedRoute, protected authService: AuthService, protected userService: UserService, protected notifier: Notifier, protected screenService: ScreenService, protected storageService: LocalStorageService, private confirmService: ConfirmService, private userHistoryService: UserHistoryService ) { super() this.titlePage = $localize`My videos history` } ngOnInit () { super.ngOnInit() this.videosHistoryEnabled = this.authService.getUser().videosHistoryEnabled } ngOnDestroy () { super.ngOnDestroy() } getVideosObservable (page: number) { const newPagination = immutableAssign(this.pagination, { currentPage: page }) return this.userHistoryService.getUserVideosHistory(newPagination) } generateSyndicationList () { throw new Error('Method not implemented.') } onVideosHistoryChange () { this.userService.updateMyProfile({ videosHistoryEnabled: this.videosHistoryEnabled }) .subscribe( () => { const message = this.videosHistoryEnabled === true ? $localize`Videos history is enabled` : $localize`Videos history is disabled` this.notifier.success(message) this.authService.refreshUserInformation() }, err => this.notifier.error(err.message) ) } async deleteHistory () { const title = $localize`Delete videos history` const message = $localize`Are you sure you want to delete all your videos history?` const res = await this.confirmService.confirm(message, title) if (res !== true) return this.userHistoryService.deleteUserVideosHistory() .subscribe( () => { this.notifier.success($localize`Videos history deleted`) this.reloadVideos() }, err => this.notifier.error(err.message) ) } }