blob: 21a10c8ffc7f61a8e86194846d838a65131462cb (
plain) (
tree)
|
|
import { Component, OnInit } from '@angular/core'
import { RestPagination, RestTable } from '@app/shared'
import { SortMeta } from 'primeng/components/common/sortmeta'
import { Notifier } from '@app/core'
import { I18n } from '@ngx-translate/i18n-polyfill'
import { VideoImport, VideoImportState } from '../../../../../shared/models/videos'
import { VideoImportService } from '@app/shared/video-import'
@Component({
selector: 'my-account-video-imports',
templateUrl: './my-account-video-imports.component.html',
styleUrls: [ './my-account-video-imports.component.scss' ]
})
export class MyAccountVideoImportsComponent extends RestTable implements OnInit {
videoImports: VideoImport[] = []
totalRecords = 0
rowsPerPage = 10
sort: SortMeta = { field: 'createdAt', order: 1 }
pagination: RestPagination = { count: this.rowsPerPage, start: 0 }
constructor (
private notifier: Notifier,
private videoImportService: VideoImportService,
private i18n: I18n
) {
super()
}
ngOnInit () {
this.initialize()
}
isVideoImportSuccess (videoImport: VideoImport) {
return videoImport.state.id === VideoImportState.SUCCESS
}
isVideoImportPending (videoImport: VideoImport) {
return videoImport.state.id === VideoImportState.PENDING
}
isVideoImportFailed (videoImport: VideoImport) {
return videoImport.state.id === VideoImportState.FAILED
}
getVideoUrl (video: { uuid: string }) {
return '/videos/watch/' + video.uuid
}
getEditVideoUrl (video: { uuid: string }) {
return '/videos/update/' + video.uuid
}
protected loadData () {
this.videoImportService.getMyVideoImports(this.pagination, this.sort)
.subscribe(
resultList => {
this.videoImports = resultList.data
this.totalRecords = resultList.total
},
err => this.notifier.error(err.message)
)
}
}
|