1 import { Component, OnInit } from '@angular/core'
2 import { ActivatedRoute, Router } from '@angular/router'
3 import { Notifier, UserService } from '@app/core'
4 import { FormReactive, FormValidatorService, ResetPasswordValidatorsService, UserValidatorsService } from '@app/shared/shared-forms'
5 import { I18n } from '@ngx-translate/i18n-polyfill'
9 templateUrl: './reset-password.component.html',
10 styleUrls: [ './reset-password.component.scss' ]
13 export class ResetPasswordComponent extends FormReactive implements OnInit {
14 private userId: number
15 private verificationString: string
18 protected formValidatorService: FormValidatorService,
19 private resetPasswordValidatorsService: ResetPasswordValidatorsService,
20 private userValidatorsService: UserValidatorsService,
21 private userService: UserService,
22 private notifier: Notifier,
23 private router: Router,
24 private route: ActivatedRoute,
32 password: this.userValidatorsService.USER_PASSWORD,
33 'password-confirm': this.resetPasswordValidatorsService.RESET_PASSWORD_CONFIRM
36 this.userId = this.route.snapshot.queryParams['userId']
37 this.verificationString = this.route.snapshot.queryParams['verificationString']
39 if (!this.userId || !this.verificationString) {
40 this.notifier.error(this.i18n('Unable to find user id or verification string.'))
41 this.router.navigate([ '/' ])
46 this.userService.resetPassword(this.userId, this.verificationString, this.form.value.password)
49 this.notifier.success(this.i18n('Your password has been successfully reset!'))
50 this.router.navigate([ '/login' ])
53 err => this.notifier.error(err.message)
57 isConfirmedPasswordValid () {
58 const values = this.form.value
59 return values.password === values['password-confirm']