1 import { SortMeta } from 'primeng/api'
2 import { mergeMap } from 'rxjs'
3 import { Component, OnInit } from '@angular/core'
4 import { AuthService, Notifier, RestPagination, RestTable, ServerService } from '@app/core'
5 import { DropdownAction, VideoChannelService, VideoChannelSyncService } from '@app/shared/shared-main'
6 import { HTMLServerConfig } from '@shared/models/server'
7 import { VideoChannelSync, VideoChannelSyncState } from '@shared/models/videos'
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`List imports`,
50 linkBuilder: () => [ '/my-library/video-imports' ],
51 queryParamsBuilder: sync => ({ search: `videoChannelSyncId:${sync.id}` }),
52 iconName: 'cloud-download'
57 label: $localize`Delete`,
59 handler: videoChannelSync => this.deleteSync(videoChannelSync)
62 label: $localize`Fully synchronize the channel`,
63 description: $localize`This fetches any missing videos on the local channel`,
65 handler: videoChannelSync => this.fullySynchronize(videoChannelSync)
71 protected reloadData () {
72 this.error = undefined
74 this.authService.userInformationLoaded
75 .pipe(mergeMap(() => {
76 const user = this.authService.getUser()
77 return this.videoChannelsSyncService.listAccountVideoChannelsSyncs({
79 account: user.account,
80 pagination: this.pagination
85 this.channelSyncs = res.data
86 this.totalRecords = res.total
89 this.error = err.message
95 return this.serverConfig.import.videoChannelSynchronization.enabled
98 deleteSync (videoChannelSync: VideoChannelSync) {
99 this.videoChannelsSyncService.deleteSync(videoChannelSync.id)
102 this.notifier.success($localize`Synchronization removed successfully for ${videoChannelSync.channel.displayName}.`)
106 this.error = err.message
111 fullySynchronize (videoChannelSync: VideoChannelSync) {
112 this.videoChannelService.importVideos(videoChannelSync.channel.name, videoChannelSync.externalChannelUrl, videoChannelSync.id)
115 this.notifier.success($localize`Full synchronization requested successfully for ${videoChannelSync.channel.displayName}.`)
118 this.error = err.message
123 getSyncCreateLink () {
124 return '/my-library/video-channel-syncs/create'
127 getSyncStateClass (stateId: number) {
128 return [ 'pt-badge', MyVideoChannelSyncsComponent.STATE_CLASS_BY_ID[stateId] ]
132 return 'MyVideoChannelsSyncComponent'
135 getChannelUrl (name: string) {