92 lines
3.1 KiB
React
92 lines
3.1 KiB
React
|
// @flow
|
||
|
import React, { useState } from 'react';
|
||
|
import { FormField, Form } from 'component/common/form';
|
||
|
import Button from 'component/button';
|
||
|
import ErrorText from 'component/common/error-text';
|
||
|
import Card from 'component/common/card';
|
||
|
import * as PAGES from 'constants/pages';
|
||
|
|
||
|
type Props = {
|
||
|
user: ?User,
|
||
|
doToast: ({ message: string }) => void,
|
||
|
doUserPasswordSet: (string, ?string) => void,
|
||
|
doClearPasswordEntry: () => void,
|
||
|
passwordSetSuccess: boolean,
|
||
|
passwordSetError: ?string,
|
||
|
};
|
||
|
|
||
|
export default function SettingAccountPassword(props: Props) {
|
||
|
const { user, doToast, doUserPasswordSet, passwordSetSuccess, passwordSetError, doClearPasswordEntry } = props;
|
||
|
const [oldPassword, setOldPassword] = useState('');
|
||
|
const [newPassword, setNewPassword] = useState('');
|
||
|
const [isAddingPassword, setIsAddingPassword] = useState(false);
|
||
|
const hasPassword = user && user.password_set;
|
||
|
|
||
|
function handleSubmit() {
|
||
|
doUserPasswordSet(newPassword, oldPassword);
|
||
|
}
|
||
|
|
||
|
React.useEffect(() => {
|
||
|
if (passwordSetSuccess) {
|
||
|
setIsAddingPassword(false);
|
||
|
doToast({
|
||
|
message: __('Password updated successfully.'),
|
||
|
});
|
||
|
doClearPasswordEntry();
|
||
|
setOldPassword('');
|
||
|
setNewPassword('');
|
||
|
}
|
||
|
}, [passwordSetSuccess, setOldPassword, setNewPassword, doClearPasswordEntry, doToast]);
|
||
|
|
||
|
return (
|
||
|
<Card
|
||
|
title={__('Account password')}
|
||
|
subtitle={hasPassword ? '' : __('You do not currently have a password set.')}
|
||
|
actions={
|
||
|
isAddingPassword ? (
|
||
|
<div>
|
||
|
<Form onSubmit={handleSubmit} className="section">
|
||
|
{hasPassword && (
|
||
|
<FormField
|
||
|
type="password"
|
||
|
name="setting_set_old_password"
|
||
|
label={__('Old Password')}
|
||
|
value={oldPassword}
|
||
|
onChange={e => setOldPassword(e.target.value)}
|
||
|
/>
|
||
|
)}
|
||
|
<FormField
|
||
|
type="password"
|
||
|
name="setting_set_new_password"
|
||
|
label={__('New Password')}
|
||
|
value={newPassword}
|
||
|
onChange={e => setNewPassword(e.target.value)}
|
||
|
/>
|
||
|
|
||
|
<div className="section__actions">
|
||
|
<Button button="primary" type="submit" label={__('Set Password')} disabled={!newPassword} />
|
||
|
{hasPassword ? (
|
||
|
<Button button="link" label={__('Forgot Password?')} navigate={`/$/${PAGES.AUTH_PASSWORD_RESET}`} />
|
||
|
) : (
|
||
|
<Button button="link" label={__('Cancel')} onClick={() => setIsAddingPassword(false)} />
|
||
|
)}
|
||
|
</div>
|
||
|
</Form>
|
||
|
{passwordSetError && (
|
||
|
<div className="section">
|
||
|
<ErrorText>{passwordSetError}</ErrorText>
|
||
|
</div>
|
||
|
)}
|
||
|
</div>
|
||
|
) : (
|
||
|
<Button
|
||
|
button="primary"
|
||
|
label={hasPassword ? __('Update Your Password') : __('Add A Password')}
|
||
|
onClick={() => setIsAddingPassword(true)}
|
||
|
/>
|
||
|
)
|
||
|
}
|
||
|
/>
|
||
|
);
|
||
|
}
|