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? This will delete all your data, including channels, videos and comments. Content cached by other servers and other third-parties might make longer to be deleted.`,
23 $localize`Type your username to confirm`,
25 $localize`Delete your account`,
26 $localize`Delete my account`
28 if (res === false) return
30 this.userService.deleteMe().subscribe(
32 this.notifier.success($localize`Your account is deleted.`)
34 this.authService.logout()
35 this.redirectService.redirectToHomepage()
38 err => this.notifier.error(err.message)