mirror of https://github.com/Chocobozzz/PeerTube
71 lines
1.7 KiB
TypeScript
71 lines
1.7 KiB
TypeScript
import { Component, ElementRef, OnInit, ViewChild } from '@angular/core'
|
|
import { AuthService, ServerService, User } from '@app/core'
|
|
import { NgbModal, NgbModalRef } from '@ng-bootstrap/ng-bootstrap'
|
|
import { HTMLServerConfig } from '@shared/models'
|
|
|
|
@Component({
|
|
selector: 'my-account-setup-modal',
|
|
templateUrl: './account-setup-modal.component.html',
|
|
styleUrls: [ './account-setup-modal.component.scss' ]
|
|
})
|
|
export class AccountSetupModalComponent implements OnInit {
|
|
@ViewChild('modal', { static: true }) modal: ElementRef
|
|
|
|
user: User = null
|
|
ref: NgbModalRef = null
|
|
|
|
private serverConfig: HTMLServerConfig
|
|
|
|
constructor (
|
|
private authService: AuthService,
|
|
private modalService: NgbModal,
|
|
private serverService: ServerService
|
|
) { }
|
|
|
|
get userInformationLoaded () {
|
|
return this.authService.userInformationLoaded
|
|
}
|
|
|
|
get instanceName () {
|
|
return this.serverConfig.instance.name
|
|
}
|
|
|
|
get isUserRoot () {
|
|
return this.user.username === 'root'
|
|
}
|
|
|
|
get hasAccountAvatar () {
|
|
return !!this.user.account.avatar
|
|
}
|
|
|
|
get hasAccountDescription () {
|
|
return !!this.user.account.description
|
|
}
|
|
|
|
ngOnInit () {
|
|
this.serverConfig = this.serverService.getHTMLConfig()
|
|
this.user = this.authService.getUser()
|
|
|
|
this.authService.userInformationLoaded
|
|
.subscribe(
|
|
() => {
|
|
if (this.isUserRoot) return false
|
|
if (this.hasAccountAvatar && this.hasAccountDescription) return false
|
|
|
|
this.show()
|
|
}
|
|
)
|
|
}
|
|
|
|
show () {
|
|
if (this.ref) return false
|
|
|
|
this.ref = this.modalService.open(this.modal, {
|
|
centered: true,
|
|
backdrop: 'static',
|
|
keyboard: false,
|
|
size: 'md'
|
|
})
|
|
}
|
|
}
|