1 import { SortMeta } from 'primeng/api'
2 import { finalize } from 'rxjs/operators'
3 import { Component, OnInit } from '@angular/core'
4 import { ActivatedRoute, Router } from '@angular/router'
5 import { AuthService, ConfirmService, Notifier, RestPagination, RestTable } from '@app/core'
6 import { AdvancedInputFilter } from '@app/shared/shared-forms'
7 import { DropdownAction, Video, VideoService } from '@app/shared/shared-main'
8 import { VideoActionsDisplayType } from '@app/shared/shared-video-miniature'
9 import { UserRight, VideoPrivacy, VideoState, VideoStreamingPlaylistType } from '@shared/models'
10 import { VideoAdminService } from './video-admin.service'
13 selector: 'my-video-list',
14 templateUrl: './video-list.component.html',
15 styleUrls: [ './video-list.component.scss' ]
17 export class VideoListComponent extends RestTable implements OnInit {
21 sort: SortMeta = { field: 'publishedAt', order: -1 }
22 pagination: RestPagination = { count: this.rowsPerPage, start: 0 }
24 bulkVideoActions: DropdownAction<Video[]>[][] = []
26 selectedVideos: Video[] = []
28 inputFilters: AdvancedInputFilter[]
30 videoActionsOptions: VideoActionsDisplayType = {
45 protected route: ActivatedRoute,
46 protected router: Router,
47 private confirmService: ConfirmService,
48 private auth: AuthService,
49 private notifier: Notifier,
50 private videoService: VideoService,
51 private videoAdminService: VideoAdminService
57 return this.auth.getUser()
63 this.inputFilters = this.videoAdminService.buildAdminInputFilter()
65 this.bulkVideoActions = [
68 label: $localize`Delete`,
69 handler: videos => this.removeVideos(videos),
70 isDisplayed: () => this.authUser.hasRight(UserRight.REMOVE_ANY_VIDEO)
77 return 'VideoListComponent'
80 isInSelectionMode () {
81 return this.selectedVideos.length !== 0
88 getPrivacyBadgeClass (privacy: VideoPrivacy) {
89 if (privacy === VideoPrivacy.PUBLIC) return 'badge-blue'
94 isUnpublished (state: VideoState) {
95 return state !== VideoState.LIVE_ENDED && state !== VideoState.PUBLISHED
98 isAccountBlocked (video: Video) {
99 return video.blockedOwner
102 isServerBlocked (video: Video) {
103 return video.blockedServer
106 isVideoBlocked (video: Video) {
107 return video.blacklisted
110 isHLS (video: Video) {
111 const p = video.streamingPlaylists.find(p => p.type === VideoStreamingPlaylistType.HLS)
114 return p.files.length !== 0
117 isWebTorrent (video: Video) {
118 return video.files.length !== 0
121 getFilesSize (video: Video) {
122 let files = video.files
124 if (this.isHLS(video)) {
125 files = files.concat(video.streamingPlaylists[0].files)
128 return files.reduce((p, f) => p += f.size, 0)
131 protected reloadData () {
132 this.selectedVideos = []
136 this.videoAdminService.getAdminVideos({
137 pagination: this.pagination,
140 }).pipe(finalize(() => this.loading = false))
142 next: resultList => {
143 this.videos = resultList.data
144 this.totalRecords = resultList.total
147 error: err => this.notifier.error(err.message)
151 private async removeVideos (videos: Video[]) {
152 const message = $localize`Are you sure you want to delete these ${videos.length} videos?`
153 const res = await this.confirmService.confirm(message, $localize`Delete`)
154 if (res === false) return
156 this.videoService.removeVideo(videos.map(v => v.id))
159 this.notifier.success($localize`${videos.length} videos deleted.`)
163 error: err => this.notifier.error(err.message)