1 import { Component, OnInit } from '@angular/core'
2 import { ActivatedRoute, Router } from '@angular/router'
3 import { USER_PASSWORD, UserService } from '@app/shared'
4 import { NotificationsService } from 'angular2-notifications'
5 import { AuthService } from '../core'
6 import { FormReactive } from '../shared'
7 import { I18n } from '@ngx-translate/i18n-polyfill'
8 import { RESET_PASSWORD_CONFIRM } from '@app/shared/forms/form-validators/reset-password'
9 import { FormValidatorService } from '@app/shared/forms/form-validators/form-validator.service'
13 templateUrl: './reset-password.component.html',
14 styleUrls: [ './reset-password.component.scss' ]
17 export class ResetPasswordComponent extends FormReactive implements OnInit {
18 private userId: number
19 private verificationString: string
22 protected formValidatorService: FormValidatorService,
23 private authService: AuthService,
24 private userService: UserService,
25 private notificationsService: NotificationsService,
26 private router: Router,
27 private route: ActivatedRoute,
35 password: USER_PASSWORD,
36 'password-confirm': RESET_PASSWORD_CONFIRM
39 this.userId = this.route.snapshot.queryParams['userId']
40 this.verificationString = this.route.snapshot.queryParams['verificationString']
42 if (!this.userId || !this.verificationString) {
43 this.notificationsService.error(this.i18n('Error'), this.i18n('Unable to find user id or verification string.'))
44 this.router.navigate([ '/' ])
49 this.userService.resetPassword(this.userId, this.verificationString, this.form.value.password)
52 this.notificationsService.success(this.i18n('Success'), this.i18n('Your password has been successfully reset!'))
53 this.router.navigate([ '/login' ])
56 err => this.notificationsService.error('Error', err.message)
60 isConfirmedPasswordValid () {
61 const values = this.form.value
62 return values.password === values['password-confirm']