PeerTube/client/src/app/+signup/+register/register.component.ts
Chocobozzz 338633ce72
Remove barrels
They can prevent tree shaking
2024-03-05 10:52:32 +01:00

232 lines
6.4 KiB
TypeScript

import { CdkStep, CdkStepperNext, CdkStepperPrevious } from '@angular/cdk/stepper'
import { Component, OnInit, ViewChild } from '@angular/core'
import { FormGroup } from '@angular/forms'
import { ActivatedRoute, RouterLink } from '@angular/router'
import { AuthService, ServerService } from '@app/core'
import { HooksService } from '@app/core/plugins/hooks.service'
import { ServerConfig, ServerStats, UserRegister } from '@peertube/peertube-models'
import { SignupService } from '../shared/signup.service'
import { SignupSuccessBeforeEmailComponent } from '../shared/signup-success-before-email.component'
import { LoaderComponent } from '../../shared/shared-main/loaders/loader.component'
import { RegisterStepChannelComponent } from './steps/register-step-channel.component'
import { RegisterStepUserComponent } from './steps/register-step-user.component'
import { RegisterStepTermsComponent } from './steps/register-step-terms.component'
import { RegisterStepAboutComponent } from './steps/register-step-about.component'
import { SignupStepTitleComponent } from '../shared/signup-step-title.component'
import { CustomStepperComponent } from './custom-stepper.component'
import { SignupLabelComponent } from '../../shared/shared-main/account/signup-label.component'
import { NgIf } from '@angular/common'
import { InstanceAboutAccordionComponent } from '@app/shared/shared-instance/instance-about-accordion.component'
@Component({
selector: 'my-register',
templateUrl: './register.component.html',
styleUrls: [ './register.component.scss' ],
standalone: true,
imports: [
NgIf,
SignupLabelComponent,
CustomStepperComponent,
CdkStep,
SignupStepTitleComponent,
RegisterStepAboutComponent,
RouterLink,
CdkStepperNext,
InstanceAboutAccordionComponent,
RegisterStepTermsComponent,
CdkStepperPrevious,
RegisterStepUserComponent,
RegisterStepChannelComponent,
LoaderComponent,
SignupSuccessBeforeEmailComponent
]
})
export class RegisterComponent implements OnInit {
@ViewChild('lastStep') lastStep: CdkStep
@ViewChild('instanceAboutAccordion') instanceAboutAccordion: InstanceAboutAccordionComponent
signupError: string
signupSuccess = false
videoUploadDisabled: boolean
videoQuota: number
formStepTerms: FormGroup
formStepUser: FormGroup
formStepChannel: FormGroup
aboutHtml = {
codeOfConduct: ''
}
instanceInformationPanels = {
codeOfConduct: true,
terms: true,
administrators: false,
features: false,
moderation: false
}
defaultPreviousStepButtonLabel = $localize`Go to the previous step`
defaultNextStepButtonLabel = $localize`Go to the next step`
stepUserButtonLabel = this.defaultNextStepButtonLabel
signupDisabled = false
serverStats: ServerStats
private serverConfig: ServerConfig
constructor (
private route: ActivatedRoute,
private authService: AuthService,
private signupService: SignupService,
private server: ServerService,
private hooks: HooksService
) { }
get requiresEmailVerification () {
return this.serverConfig.signup.requiresEmailVerification
}
get requiresApproval () {
return this.serverConfig.signup.requiresApproval
}
get minimumAge () {
return this.serverConfig.signup.minimumAge
}
get instanceName () {
return this.serverConfig.instance.name
}
ngOnInit () {
this.serverConfig = this.route.snapshot.data.serverConfig
if (this.serverConfig.signup.allowed === false || this.serverConfig.signup.allowedForCurrentIP === false) {
this.signupDisabled = true
return
}
this.videoQuota = this.serverConfig.user.videoQuota
this.videoUploadDisabled = this.videoQuota === 0
this.stepUserButtonLabel = this.videoUploadDisabled
? $localize`:Button on the registration form to finalize the account and channel creation:Signup`
: this.defaultNextStepButtonLabel
this.server.getServerStats()
.subscribe(stats => this.serverStats = stats)
this.hooks.runAction('action:signup.register.init', 'signup')
}
hasSameChannelAndAccountNames () {
return this.getUsername() === this.getChannelName()
}
getUsername () {
if (!this.formStepUser) return undefined
return this.formStepUser.value['username']
}
getChannelName () {
if (!this.formStepChannel) return undefined
return this.formStepChannel.value['name']
}
onTermsFormBuilt (form: FormGroup) {
this.formStepTerms = form
}
onUserFormBuilt (form: FormGroup) {
this.formStepUser = form
}
onChannelFormBuilt (form: FormGroup) {
this.formStepChannel = form
}
onTermsClick () {
this.instanceAboutAccordion.expandTerms()
}
onCodeOfConductClick () {
this.instanceAboutAccordion.expandCodeOfConduct()
}
onInstanceAboutAccordionInit (instanceAboutAccordion: InstanceAboutAccordionComponent) {
this.aboutHtml = instanceAboutAccordion.aboutHtml
}
skipChannelCreation () {
this.formStepChannel.reset()
this.lastStep.select()
this.signup()
}
async signup () {
this.signupError = undefined
const termsForm = this.formStepTerms.value
const userForm = this.formStepUser.value
const channelForm = this.formStepChannel?.value
const channel = this.formStepChannel?.value?.name
? { name: channelForm?.name, displayName: channelForm?.displayName }
: undefined
const body = await this.hooks.wrapObject(
{
username: userForm.username,
password: userForm.password,
email: userForm.email,
displayName: userForm.displayName,
registrationReason: termsForm.registrationReason,
channel
},
'signup',
'filter:api.signup.registration.create.params'
)
const obs = this.requiresApproval
? this.signupService.requestSignup(body)
: this.signupService.directSignup(body)
obs.subscribe({
next: () => {
if (this.requiresEmailVerification || this.requiresApproval) {
this.signupSuccess = true
return
}
// Auto login
this.autoLogin(body)
},
error: err => {
this.signupError = err.message
}
})
}
private autoLogin (body: UserRegister) {
this.authService.login({ username: body.username, password: body.password })
.subscribe({
next: () => {
this.signupSuccess = true
},
error: err => {
this.signupError = err.message
}
})
}
}