| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- import React, { useState } from 'react';
- import PropTypes from 'prop-types';
- import { withTranslation } from 'react-i18next';
- import loggerFactory from '~/utils/logger';
- import { withUnstatedContainers } from './UnstatedUtils';
- import AppContainer from '~/client/services/AppContainer';
- import { toastSuccess, toastError } from '~/client/util/apiNotification';
- const logger = loggerFactory('growi:passwordReset');
- const PasswordResetExecutionForm = (props) => {
- const { t, appContainer } = props;
- const [newPassword, setNewPassword] = useState('');
- const [newPasswordConfirm, setNewPasswordConfirm] = useState('');
- const [validationErrorI18n, setValidationErrorI18n] = useState('');
- // get token from URL
- const pathname = window.location.pathname.split('/');
- const token = pathname[2];
- const changePassword = async(e) => {
- e.preventDefault();
- if (newPassword === '' || newPasswordConfirm === '') {
- setValidationErrorI18n('personal_settings.password_is_not_set');
- return;
- }
- if (newPassword !== newPasswordConfirm) {
- setValidationErrorI18n('forgot_password.password_and_confirm_password_does_not_match');
- return;
- }
- try {
- await appContainer.apiv3Put('/forgot-password', {
- token, newPassword, newPasswordConfirm,
- });
- setValidationErrorI18n('');
- toastSuccess(t('toaster.update_successed', { target: t('Password') }));
- }
- catch (err) {
- toastError(err);
- logger.error(err);
- }
- };
- return (
- <form role="form" onSubmit={changePassword}>
- <div className="form-group">
- <div className="input-group">
- <input
- name="password"
- placeholder={t('forgot_password.new_password')}
- className="form-control"
- type="password"
- onChange={e => setNewPassword(e.target.value)}
- />
- </div>
- </div>
- <div className="form-group">
- <div className="input-group">
- <input
- name="password"
- placeholder={t('forgot_password.confirm_new_password')}
- className="form-control"
- type="password"
- onChange={e => setNewPasswordConfirm(e.target.value)}
- />
- </div>
- {validationErrorI18n !== '' && (
- <p className="text-danger mt-2">{t(validationErrorI18n)}</p>
- )}
- </div>
- <div className="form-group">
- <input name="reset-password-btn" className="btn btn-lg btn-primary btn-block" value={t('forgot_password.reset_password')} type="submit" />
- </div>
- <a href="/login">
- <i className="icon-login mr-1"></i>{t('forgot_password.sign_in_instead')}
- </a>
- </form>
- );
- };
- const PasswordResetExecutionFormWrapper = withUnstatedContainers(PasswordResetExecutionForm, [AppContainer]);
- PasswordResetExecutionForm.propTypes = {
- t: PropTypes.func.isRequired, // i18next
- appContainer: PropTypes.instanceOf(AppContainer).isRequired,
- };
- export default withTranslation()(PasswordResetExecutionFormWrapper);
|