-import { Component, ViewChild } from '@angular/core'
+import { Component, HostListener, OnInit, ViewChild } from '@angular/core'
import { CanComponentDeactivate } from '@app/shared/guards/can-deactivate-guard.service'
-import { VideoImportComponent } from '@app/videos/+video-edit/video-import.component'
-import { VideoUploadComponent } from '@app/videos/+video-edit/video-upload.component'
-import { ServerService } from '@app/core'
+import { VideoImportUrlComponent } from '@app/videos/+video-edit/video-add-components/video-import-url.component'
+import { VideoUploadComponent } from '@app/videos/+video-edit/video-add-components/video-upload.component'
+import { AuthService, ServerService } from '@app/core'
+import { VideoImportTorrentComponent } from '@app/videos/+video-edit/video-add-components/video-import-torrent.component'
+import { ServerConfig } from '@shared/models'
@Component({
selector: 'my-videos-add',
templateUrl: './video-add.component.html',
styleUrls: [ './video-add.component.scss' ]
})
-export class VideoAddComponent implements CanComponentDeactivate {
- @ViewChild('videoUpload') videoUpload: VideoUploadComponent
- @ViewChild('videoImport') videoImport: VideoImportComponent
+export class VideoAddComponent implements OnInit, CanComponentDeactivate {
+ @ViewChild('videoUpload', { static: false }) videoUpload: VideoUploadComponent
+ @ViewChild('videoImportUrl', { static: false }) videoImportUrl: VideoImportUrlComponent
+ @ViewChild('videoImportTorrent', { static: false }) videoImportTorrent: VideoImportTorrentComponent
- secondStepType: 'upload' | 'import'
+ secondStepType: 'upload' | 'import-url' | 'import-torrent'
videoName: string
+ serverConfig: ServerConfig
constructor (
+ private auth: AuthService,
private serverService: ServerService
) {}
- onFirstStepDone (type: 'upload' | 'import', videoName: string) {
+ ngOnInit () {
+ this.serverConfig = this.serverService.getTmpConfig()
+
+ this.serverService.getConfig()
+ .subscribe(config => this.serverConfig = config)
+ }
+
+ onFirstStepDone (type: 'upload' | 'import-url' | 'import-torrent', videoName: string) {
this.secondStepType = type
this.videoName = videoName
}
- canDeactivate () {
+ onError () {
+ this.videoName = undefined
+ this.secondStepType = undefined
+ }
+
+ @HostListener('window:beforeunload', [ '$event' ])
+ onUnload (event: any) {
+ const { text, canDeactivate } = this.canDeactivate()
+
+ if (canDeactivate) return
+
+ event.returnValue = text
+ return text
+ }
+
+ canDeactivate (): { canDeactivate: boolean, text?: string} {
if (this.secondStepType === 'upload') return this.videoUpload.canDeactivate()
- if (this.secondStepType === 'import') return this.videoImport.canDeactivate()
+ if (this.secondStepType === 'import-url') return this.videoImportUrl.canDeactivate()
+ if (this.secondStepType === 'import-torrent') return this.videoImportTorrent.canDeactivate()
return { canDeactivate: true }
}
- isVideoImportEnabled () {
- return this.serverService.getConfig().import.videos.http.enabled
+ isVideoImportHttpEnabled () {
+ return this.serverConfig.import.videos.http.enabled
+ }
+
+ isVideoImportTorrentEnabled () {
+ return this.serverConfig.import.videos.torrent.enabled
+ }
+
+ isInSecondStep () {
+ return !!this.secondStepType
+ }
+
+ isRootUser () {
+ return this.auth.getUser().username === 'root'
}
}