2017-07-22 18:57:38 +03:00
|
|
|
|
import React from 'react';
|
2020-06-04 19:41:27 +03:00
|
|
|
|
import { defineMessages, FormattedMessage as Message } from 'react-intl';
|
2017-07-22 18:57:38 +03:00
|
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
|
import { Input, Form, FormModel } from 'app/components/ui/form';
|
2019-12-07 21:02:00 +02:00
|
|
|
|
import profileForm from 'app/components/profile/profileForm.scss';
|
2020-01-17 23:37:52 +03:00
|
|
|
|
|
2020-06-04 19:41:27 +03:00
|
|
|
|
const messages = defineMessages({
|
|
|
|
|
codePlaceholder: 'Enter the code here',
|
|
|
|
|
});
|
2017-07-22 18:57:38 +03:00
|
|
|
|
|
|
|
|
|
export default function Confirmation({
|
2020-05-24 02:08:24 +03:00
|
|
|
|
form,
|
|
|
|
|
formRef = () => {},
|
|
|
|
|
onSubmit,
|
|
|
|
|
onInvalid,
|
2017-07-22 18:57:38 +03:00
|
|
|
|
}: {
|
2020-05-24 02:08:24 +03:00
|
|
|
|
form: FormModel;
|
|
|
|
|
formRef?: (el: Form | null) => void;
|
|
|
|
|
onSubmit: (form: FormModel) => Promise<void> | void;
|
|
|
|
|
onInvalid: () => void;
|
2017-07-22 18:57:38 +03:00
|
|
|
|
}) {
|
2020-05-24 02:08:24 +03:00
|
|
|
|
return (
|
|
|
|
|
<Form form={form} onSubmit={onSubmit} onInvalid={onInvalid} ref={formRef}>
|
|
|
|
|
<div className={profileForm.formBody}>
|
|
|
|
|
<div className={profileForm.formRow}>
|
|
|
|
|
<p className={profileForm.description}>
|
2020-06-04 19:41:27 +03:00
|
|
|
|
<Message
|
|
|
|
|
key="enterCodeFromApp"
|
|
|
|
|
defaultMessage="In order to finish two‑factor auth setup, please enter the code received in the mobile app:"
|
|
|
|
|
/>
|
2020-05-24 02:08:24 +03:00
|
|
|
|
</p>
|
|
|
|
|
</div>
|
2017-07-22 18:57:38 +03:00
|
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
|
<div className={profileForm.formRow}>
|
|
|
|
|
<Input
|
|
|
|
|
{...form.bindField('totp')}
|
|
|
|
|
required
|
|
|
|
|
autoComplete="off"
|
|
|
|
|
skin="light"
|
|
|
|
|
placeholder={messages.codePlaceholder}
|
|
|
|
|
/>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</Form>
|
|
|
|
|
);
|
2017-07-22 18:57:38 +03:00
|
|
|
|
}
|