1 import { Component, OnInit } from '@angular/core'
2 import { AuthService, Notifier, RestPagination, RestTable, ServerService } from '@app/core'
3 import { DropdownAction, VideoChannelService, VideoChannelSyncService } from '@app/shared/shared-main'
4 import { HTMLServerConfig } from '@shared/models/server'
5 import { VideoChannelSync, VideoChannelSyncState } from '@shared/models/videos'
6 import { SortMeta } from 'primeng/api'
7 import { mergeMap } from 'rxjs'
10 templateUrl: './my-video-channel-syncs.component.html',
11 styleUrls: [ './my-video-channel-syncs.component.scss' ]
13 export class MyVideoChannelSyncsComponent extends RestTable implements OnInit {
16 channelSyncs: VideoChannelSync[] = []
19 videoChannelSyncActions: DropdownAction<VideoChannelSync>[][] = []
20 sort: SortMeta = { field: 'createdAt', order: 1 }
21 pagination: RestPagination = { count: this.rowsPerPage, start: 0 }
23 private static STATE_CLASS_BY_ID = {
24 [VideoChannelSyncState.FAILED]: 'badge-red',
25 [VideoChannelSyncState.PROCESSING]: 'badge-blue',
26 [VideoChannelSyncState.SYNCED]: 'badge-green',
27 [VideoChannelSyncState.WAITING_FIRST_RUN]: 'badge-yellow'
30 private serverConfig: HTMLServerConfig
33 private videoChannelsSyncService: VideoChannelSyncService,
34 private serverService: ServerService,
35 private notifier: Notifier,
36 private authService: AuthService,
37 private videoChannelService: VideoChannelService
43 this.serverConfig = this.serverService.getHTMLConfig()
46 this.videoChannelSyncActions = [
49 label: $localize`Delete`,
51 handler: videoChannelSync => this.deleteSync(videoChannelSync)
54 label: $localize`Fully synchronize the channel`,
55 description: $localize`This fetches any missing videos on the local channel`,
57 handler: videoChannelSync => this.fullySynchronize(videoChannelSync)
63 protected reloadData () {
64 this.error = undefined
66 this.authService.userInformationLoaded
67 .pipe(mergeMap(() => {
68 const user = this.authService.getUser()
69 return this.videoChannelsSyncService.listAccountVideoChannelsSyncs({
71 account: user.account,
72 pagination: this.pagination
77 this.channelSyncs = res.data
80 this.error = err.message
86 return this.serverConfig.import.videoChannelSynchronization.enabled
89 deleteSync (videoChannelSync: VideoChannelSync) {
90 this.videoChannelsSyncService.deleteSync(videoChannelSync.id)
93 this.notifier.success($localize`Synchronization removed successfully for ${videoChannelSync.channel.displayName}.`)
97 this.error = err.message
102 fullySynchronize (videoChannelSync: VideoChannelSync) {
103 this.videoChannelService.importVideos(videoChannelSync.channel.name, videoChannelSync.externalChannelUrl, videoChannelSync.id)
106 this.notifier.success($localize`Full synchronization requested successfully for ${videoChannelSync.channel.displayName}.`)
109 this.error = err.message
114 getSyncCreateLink () {
115 return '/my-library/video-channel-syncs/create'
118 getSyncStateClass (stateId: number) {
119 return [ 'pt-badge', MyVideoChannelSyncsComponent.STATE_CLASS_BY_ID[stateId] ]
123 return 'MyVideoChannelsSyncComponent'
126 getChannelUrl (name: string) {