1 import { Component, Input } from '@angular/core'
2 import { AuthService, ConfirmService, Notifier, RedirectService, User, UserService } from '@app/core'
5 selector: 'my-account-danger-zone',
6 templateUrl: './my-account-danger-zone.component.html',
7 styleUrls: [ './my-account-danger-zone.component.scss' ]
9 export class MyAccountDangerZoneComponent {
10 @Input() user: User = null
13 private authService: AuthService,
14 private notifier: Notifier,
15 private userService: UserService,
16 private confirmService: ConfirmService,
17 private redirectService: RedirectService
21 const res = await this.confirmService.confirmWithInput(
22 $localize`Are you sure you want to delete your account?` +
24 // eslint-disable-next-line max-len
25 $localize`This will delete all your data, including channels, videos, comments and you won't be able to create another user on this instance with "${this.user.username}" username.` +
27 $localize`Content cached by other servers and other third-parties might make longer to be deleted.`,
29 $localize`Type your username to confirm`,
31 $localize`Delete your account`,
32 $localize`Delete my account`
34 if (res === false) return
36 this.userService.deleteMe()
39 this.notifier.success($localize`Your account is deleted.`)
41 this.authService.logout()
42 this.redirectService.redirectToHomepage()
45 error: err => this.notifier.error(err.message)