1 import { Component, linkEvent } from 'inferno';
2 import { Subscription } from 'rxjs';
3 import { retryWhen, delay, take } from 'rxjs/operators';
10 } from '../interfaces';
11 import { WebSocketService, UserService } from '../services';
12 import { wsJsonToRes, capitalizeFirstLetter, toast } from '../utils';
13 import { i18n } from '../i18next';
16 passwordChangeForm: PasswordChangeForm;
20 export class PasswordChange extends Component<any, State> {
21 private subscription: Subscription;
25 token: this.props.match.params.token,
27 password_verify: undefined,
32 constructor(props: any, context: any) {
33 super(props, context);
35 this.state = this.emptyState;
37 this.subscription = WebSocketService.Instance.subject
38 .pipe(retryWhen(errors => errors.pipe(delay(3000), take(10))))
40 msg => this.parseMessage(msg),
41 err => console.error(err),
42 () => console.log('complete')
44 WebSocketService.Instance.getSite();
47 componentWillUnmount() {
48 this.subscription.unsubscribe();
53 <div class="container">
55 <div class="col-12 col-lg-6 offset-lg-3 mb-4">
56 <h5>{i18n.t('password_change')}</h5>
57 {this.passwordChangeForm()}
64 passwordChangeForm() {
66 <form onSubmit={linkEvent(this, this.handlePasswordChangeSubmit)}>
67 <div class="form-group row">
68 <label class="col-sm-2 col-form-label">
69 {i18n.t('new_password')}
71 <div class="col-sm-10">
74 value={this.state.passwordChangeForm.password}
75 onInput={linkEvent(this, this.handlePasswordChange)}
81 <div class="form-group row">
82 <label class="col-sm-2 col-form-label">
83 {i18n.t('verify_password')}
85 <div class="col-sm-10">
88 value={this.state.passwordChangeForm.password_verify}
89 onInput={linkEvent(this, this.handleVerifyPasswordChange)}
95 <div class="form-group row">
96 <div class="col-sm-10">
97 <button type="submit" class="btn btn-secondary">
98 {this.state.loading ? (
99 <svg class="icon icon-spinner spin">
100 <use xlinkHref="#icon-spinner"></use>
103 capitalizeFirstLetter(i18n.t('save'))
112 handlePasswordChange(i: PasswordChange, event: any) {
113 i.state.passwordChangeForm.password = event.target.value;
117 handleVerifyPasswordChange(i: PasswordChange, event: any) {
118 i.state.passwordChangeForm.password_verify = event.target.value;
122 handlePasswordChangeSubmit(i: PasswordChange, event: any) {
123 event.preventDefault();
124 i.state.loading = true;
127 WebSocketService.Instance.passwordChange(i.state.passwordChangeForm);
130 parseMessage(msg: WebSocketJsonResponse) {
131 let res = wsJsonToRes(msg);
133 toast(i18n.t(msg.error), 'danger');
134 this.state.loading = false;
135 this.setState(this.state);
137 } else if (res.op == UserOperation.PasswordChange) {
138 let data = res.data as LoginResponse;
139 this.state = this.emptyState;
140 this.setState(this.state);
141 UserService.Instance.login(data);
142 this.props.history.push('/');
143 } else if (res.op == UserOperation.GetSite) {
144 let data = res.data as GetSiteResponse;
145 document.title = `${i18n.t('password_change')} - ${data.site.name}`;