1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
|
import { ChangeDetectorRef, Component, OnDestroy, OnInit } from '@angular/core'
import { ActivatedRoute, Router } from '@angular/router'
import { BehaviorSubject } from 'rxjs/BehaviorSubject'
import { NotificationsService } from 'angular2-notifications'
import {
SortField,
Video,
VideoService
} from '../shared'
import { AuthService, AuthUser } from '../../core'
import { RestPagination, Search, SearchField } from '../../shared'
import { SearchService } from '../../shared'
@Component({
selector: 'my-videos-list',
styleUrls: [ './video-list.component.scss' ],
templateUrl: './video-list.component.html'
})
export class VideoListComponent implements OnInit, OnDestroy {
loading: BehaviorSubject<boolean> = new BehaviorSubject(false)
pagination: RestPagination = {
currentPage: 1,
itemsPerPage: 25,
totalItems: null
}
sort: SortField
user: AuthUser = null
videos: Video[] = []
private search: Search
private subActivatedRoute: any
private subSearch: any
constructor (
private notificationsService: NotificationsService,
private authService: AuthService,
private changeDetector: ChangeDetectorRef,
private router: Router,
private route: ActivatedRoute,
private videoService: VideoService,
private searchService: SearchService
) {}
ngOnInit () {
if (this.authService.isLoggedIn()) {
this.user = AuthUser.load()
}
// Subscribe to route changes
this.subActivatedRoute = this.route.params.subscribe(routeParams => {
this.loadRouteParams(routeParams)
// Update the search service component
this.searchService.updateSearch.next(this.search)
this.getVideos()
})
// Subscribe to search changes
this.subSearch = this.searchService.searchUpdated.subscribe(search => {
this.search = search
// Reset pagination
this.pagination.currentPage = 1
this.navigateToNewParams()
})
}
ngOnDestroy () {
this.subActivatedRoute.unsubscribe()
this.subSearch.unsubscribe()
}
getVideos () {
this.loading.next(true)
this.videos = []
let observable = null
if (this.search.value) {
observable = this.videoService.searchVideos(this.search, this.pagination, this.sort)
} else {
observable = this.videoService.getVideos(this.pagination, this.sort)
}
observable.subscribe(
({ videos, totalVideos }) => {
this.videos = videos
this.pagination.totalItems = totalVideos
this.loading.next(false)
},
error => this.notificationsService.error('Error', error.text)
)
}
isThereNoVideo () {
return !this.loading.getValue() && this.videos.length === 0
}
onPageChanged (event: any) {
// Be sure the current page is set
this.pagination.currentPage = event.page
this.navigateToNewParams()
}
onSort (sort: SortField) {
this.sort = sort
this.navigateToNewParams()
}
private buildRouteParams () {
// There is always a sort and a current page
const params: any = {
sort: this.sort,
page: this.pagination.currentPage
}
// Maybe there is a search
if (this.search.value) {
params.field = this.search.field
params.search = this.search.value
}
return params
}
private loadRouteParams (routeParams) {
if (routeParams['search'] !== undefined) {
this.search = {
value: routeParams['search'],
field: routeParams['field'] as SearchField
}
} else {
this.search = {
value: '',
field: 'name'
}
}
this.sort = routeParams['sort'] as SortField || '-createdAt'
if (routeParams['page'] !== undefined) {
this.pagination.currentPage = parseInt(routeParams['page'], 10)
} else {
this.pagination.currentPage = 1
}
}
private navigateToNewParams () {
const routeParams = this.buildRouteParams()
this.router.navigate(['/videos/list', routeParams])
}
}
|