mirror of https://github.com/Chocobozzz/PeerTube
105 lines
3.8 KiB
TypeScript
105 lines
3.8 KiB
TypeScript
import { ViewportScroller, NgIf } from '@angular/common'
|
|
import { HttpErrorResponse } from '@angular/common/http'
|
|
import { AfterViewChecked, Component, OnInit } from '@angular/core'
|
|
import { AuthService, Notifier, User, UserService } from '@app/core'
|
|
import { genericUploadErrorHandler } from '@app/helpers'
|
|
import { shallowCopy } from '@peertube/peertube-core-utils'
|
|
import { MyAccountDangerZoneComponent } from './my-account-danger-zone/my-account-danger-zone.component'
|
|
import { MyAccountChangeEmailComponent } from './my-account-change-email/my-account-change-email.component'
|
|
import { MyAccountEmailPreferencesComponent } from './my-account-email-preferences/my-account-email-preferences.component'
|
|
import { MyAccountTwoFactorButtonComponent } from './my-account-two-factor/my-account-two-factor-button.component'
|
|
import { MyAccountChangePasswordComponent } from './my-account-change-password/my-account-change-password.component'
|
|
import {
|
|
MyAccountNotificationPreferencesComponent
|
|
} from './my-account-notification-preferences/my-account-notification-preferences.component'
|
|
import { UserVideoSettingsComponent } from '../../shared/shared-user-settings/user-video-settings.component'
|
|
import { UserInterfaceSettingsComponent } from '../../shared/shared-user-settings/user-interface-settings.component'
|
|
import { MyAccountProfileComponent } from './my-account-profile/my-account-profile.component'
|
|
import { UserQuotaComponent } from '../../shared/shared-main/users/user-quota.component'
|
|
import { ActorAvatarEditComponent } from '../../shared/shared-actor-image-edit/actor-avatar-edit.component'
|
|
|
|
@Component({
|
|
selector: 'my-account-settings',
|
|
templateUrl: './my-account-settings.component.html',
|
|
styleUrls: [ './my-account-settings.component.scss' ],
|
|
standalone: true,
|
|
imports: [
|
|
ActorAvatarEditComponent,
|
|
UserQuotaComponent,
|
|
MyAccountProfileComponent,
|
|
UserInterfaceSettingsComponent,
|
|
UserVideoSettingsComponent,
|
|
MyAccountNotificationPreferencesComponent,
|
|
NgIf,
|
|
MyAccountChangePasswordComponent,
|
|
MyAccountTwoFactorButtonComponent,
|
|
MyAccountEmailPreferencesComponent,
|
|
MyAccountChangeEmailComponent,
|
|
MyAccountDangerZoneComponent
|
|
]
|
|
})
|
|
export class MyAccountSettingsComponent implements OnInit, AfterViewChecked {
|
|
user: User = null
|
|
|
|
private lastScrollHash: string
|
|
|
|
constructor (
|
|
private viewportScroller: ViewportScroller,
|
|
private userService: UserService,
|
|
private authService: AuthService,
|
|
private notifier: Notifier
|
|
) {}
|
|
|
|
get userInformationLoaded () {
|
|
return this.authService.userInformationLoaded
|
|
}
|
|
|
|
ngOnInit () {
|
|
this.user = this.authService.getUser()
|
|
}
|
|
|
|
ngAfterViewChecked () {
|
|
if (window.location.hash && window.location.hash !== this.lastScrollHash) {
|
|
this.viewportScroller.scrollToAnchor(window.location.hash.replace('#', ''))
|
|
|
|
this.lastScrollHash = window.location.hash
|
|
}
|
|
}
|
|
|
|
onAvatarChange (formData: FormData) {
|
|
this.userService.changeAvatar(formData)
|
|
.subscribe({
|
|
next: data => {
|
|
this.notifier.success($localize`Avatar changed.`)
|
|
|
|
this.user.updateAccountAvatar(data.avatars)
|
|
|
|
// So my-actor-avatar component detects changes
|
|
this.user.account = shallowCopy(this.user.account)
|
|
},
|
|
|
|
error: (err: HttpErrorResponse) => genericUploadErrorHandler({
|
|
err,
|
|
name: $localize`avatar`,
|
|
notifier: this.notifier
|
|
})
|
|
})
|
|
}
|
|
|
|
onAvatarDelete () {
|
|
this.userService.deleteAvatar()
|
|
.subscribe({
|
|
next: () => {
|
|
this.notifier.success($localize`Avatar deleted.`)
|
|
|
|
this.user.updateAccountAvatar()
|
|
|
|
// So my-actor-avatar component detects changes
|
|
this.user.account = shallowCopy(this.user.account)
|
|
},
|
|
|
|
error: (err: HttpErrorResponse) => this.notifier.error(err.message)
|
|
})
|
|
}
|
|
}
|