import { Component, OnDestroy, OnInit } from '@angular/core'
import { ActivatedRoute, Router } from '@angular/router'
+import { RedirectService } from '@app/core'
+import { immutableAssign } from '@app/shared/misc/utils'
import { NotificationsService } from 'angular2-notifications'
import { Subscription } from 'rxjs/Subscription'
+import { AuthService } from '../../core/auth'
import { AbstractVideoList } from '../../shared/video/abstract-video-list'
import { VideoService } from '../../shared/video/video.service'
currentRoute = '/videos/search'
loadOnInit = false
- private search = ''
+ protected otherRouteParams = {
+ search: ''
+ }
private subActivatedRoute: Subscription
constructor (protected router: Router,
protected route: ActivatedRoute,
protected notificationsService: NotificationsService,
- private videoService: VideoService) {
+ protected authService: AuthService,
+ private videoService: VideoService,
+ private redirectService: RedirectService
+ ) {
super()
}
this.subActivatedRoute = this.route.queryParams.subscribe(
queryParams => {
- this.search = queryParams['search']
+ const querySearch = queryParams['search']
+
+ if (!querySearch) return this.redirectService.redirectToHomepage()
+ if (this.otherRouteParams.search === querySearch) return
+
+ this.otherRouteParams.search = querySearch
this.reloadVideos()
},
}
ngOnDestroy () {
- if (this.subActivatedRoute) {
- this.subActivatedRoute.unsubscribe()
- }
+ super.ngOnDestroy()
+
+ if (this.subActivatedRoute) this.subActivatedRoute.unsubscribe()
+ }
+
+ getVideosObservable (page: number) {
+ const newPagination = immutableAssign(this.pagination, { currentPage: page })
+ return this.videoService.searchVideos(this.otherRouteParams.search, newPagination, this.sort)
}
- getVideosObservable () {
- return this.videoService.searchVideos(this.search, this.pagination, this.sort)
+ generateSyndicationList () {
+ throw new Error('Search does not support syndication.')
}
}