]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blob - client/src/app/+verify-account/verify-account-email/verify-account-email.component.ts
Refractor notification service
[github/Chocobozzz/PeerTube.git] / client / src / app / +verify-account / verify-account-email / verify-account-email.component.ts
1 import { Component, OnInit } from '@angular/core'
2 import { ActivatedRoute, Router } from '@angular/router'
3 import { I18n } from '@ngx-translate/i18n-polyfill'
4 import { Notifier } from '@app/core'
5 import { UserService } from '@app/shared'
6
7 @Component({
8 selector: 'my-verify-account-email',
9 templateUrl: './verify-account-email.component.html'
10 })
11
12 export class VerifyAccountEmailComponent implements OnInit {
13 success = false
14
15 private userId: number
16 private verificationString: string
17
18 constructor (
19 private userService: UserService,
20 private notifier: Notifier,
21 private router: Router,
22 private route: ActivatedRoute,
23 private i18n: I18n
24 ) {
25 }
26
27 ngOnInit () {
28 this.userId = this.route.snapshot.queryParams['userId']
29 this.verificationString = this.route.snapshot.queryParams['verificationString']
30
31 if (!this.userId || !this.verificationString) {
32 this.notifier.error(this.i18n('Unable to find user id or verification string.'))
33 } else {
34 this.verifyEmail()
35 }
36 }
37
38 verifyEmail () {
39 this.userService.verifyEmail(this.userId, this.verificationString)
40 .subscribe(
41 () => {
42 this.success = true
43 setTimeout(() => {
44 this.router.navigate([ '/login' ])
45 }, 2000)
46 },
47
48 err => {
49 this.notifier.error(err.message)
50 }
51 )
52 }
53 }