blob: d9fb20446067e087866d216f4a6232aac9d6eb95 (
plain) (
tree)
|
|
import { Component, OnInit } from '@angular/core'
import { RestPagination, RestTable } from '@app/shared'
import { SortMeta } from 'primeng/components/common/sortmeta'
import { NotificationsService } from 'angular2-notifications'
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 notificationsService: NotificationsService,
private videoImportService: VideoImportService,
private i18n: I18n
) {
super()
}
ngOnInit () {
this.loadSort()
}
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.notificationsService.error(this.i18n('Error'), err.message)
)
}
}
|