1 import { Component, linkEvent } from 'inferno';
2 import { Subscription } from 'rxjs';
3 import { retryWhen, delay, take } from 'rxjs/operators';
9 } from '../interfaces';
10 import { WebSocketService, UserService } from '../services';
11 import { wsJsonToRes, capitalizeFirstLetter, toast } from '../utils';
12 import { i18n } from '../i18next';
15 passwordChangeForm: PasswordChangeForm;
19 export class PasswordChange extends Component<any, State> {
20 private subscription: Subscription;
24 token: this.props.match.params.token,
26 password_verify: undefined,
31 constructor(props: any, context: any) {
32 super(props, context);
34 this.state = this.emptyState;
36 this.subscription = WebSocketService.Instance.subject
37 .pipe(retryWhen(errors => errors.pipe(delay(3000), take(10))))
39 msg => this.parseMessage(msg),
40 err => console.error(err),
41 () => console.log('complete')
45 componentWillUnmount() {
46 this.subscription.unsubscribe();
50 document.title = `${i18n.t('password_change')} - ${
51 WebSocketService.Instance.site.name
57 <div class="container">
59 <div class="col-12 col-lg-6 offset-lg-3 mb-4">
60 <h5>{i18n.t('password_change')}</h5>
61 {this.passwordChangeForm()}
68 passwordChangeForm() {
70 <form onSubmit={linkEvent(this, this.handlePasswordChangeSubmit)}>
71 <div class="form-group row">
72 <label class="col-sm-2 col-form-label">
73 {i18n.t('new_password')}
75 <div class="col-sm-10">
78 value={this.state.passwordChangeForm.password}
79 onInput={linkEvent(this, this.handlePasswordChange)}
85 <div class="form-group row">
86 <label class="col-sm-2 col-form-label">
87 {i18n.t('verify_password')}
89 <div class="col-sm-10">
92 value={this.state.passwordChangeForm.password_verify}
93 onInput={linkEvent(this, this.handleVerifyPasswordChange)}
99 <div class="form-group row">
100 <div class="col-sm-10">
101 <button type="submit" class="btn btn-secondary">
102 {this.state.loading ? (
103 <svg class="icon icon-spinner spin">
104 <use xlinkHref="#icon-spinner"></use>
107 capitalizeFirstLetter(i18n.t('save'))
116 handlePasswordChange(i: PasswordChange, event: any) {
117 i.state.passwordChangeForm.password = event.target.value;
121 handleVerifyPasswordChange(i: PasswordChange, event: any) {
122 i.state.passwordChangeForm.password_verify = event.target.value;
126 handlePasswordChangeSubmit(i: PasswordChange, event: any) {
127 event.preventDefault();
128 i.state.loading = true;
131 WebSocketService.Instance.passwordChange(i.state.passwordChangeForm);
134 parseMessage(msg: WebSocketJsonResponse) {
135 let res = wsJsonToRes(msg);
137 toast(i18n.t(msg.error), 'danger');
138 this.state.loading = false;
139 this.setState(this.state);
142 if (res.op == UserOperation.PasswordChange) {
143 let data = res.data as LoginResponse;
144 this.state = this.emptyState;
145 this.setState(this.state);
146 UserService.Instance.login(data);
147 this.props.history.push('/');