vega-frontend-monorepo/libs/wallet/src/rest-connector-form.tsx

109 lines
2.8 KiB
TypeScript
Raw Normal View History

import { t } from '@vegaprotocol/react-helpers';
import { Button, FormGroup, Input, InputError } from '@vegaprotocol/ui-toolkit';
import { useState } from 'react';
import { useForm } from 'react-hook-form';
import type { RestConnector } from '.';
interface FormFields {
url: string;
wallet: string;
passphrase: string;
}
interface RestConnectorFormProps {
connector: RestConnector;
onAuthenticate: () => void;
}
const VEGA_DEFAULT_URL = 'http://localhost:1789/api/v1';
export function RestConnectorForm({
connector,
onAuthenticate,
}: RestConnectorFormProps) {
const [error, setError] = useState('');
const {
register,
handleSubmit,
formState: { errors },
} = useForm<FormFields>({
defaultValues: {
url: VEGA_DEFAULT_URL,
},
});
async function onSubmit(fields: FormFields) {
try {
setError('');
const res = await connector.authenticate(fields.url, {
wallet: fields.wallet,
passphrase: fields.passphrase,
});
if (res.success) {
onAuthenticate();
} else {
throw res.error;
}
} catch (err) {
if (err instanceof TypeError) {
setError(t(`Wallet not running at ${fields.url}`));
} else if (err instanceof Error) {
setError(t('Authentication failed'));
} else {
setError(t('Something went wrong'));
}
}
}
return (
<form onSubmit={handleSubmit(onSubmit)} data-testid="rest-connector-form">
<FormGroup label={t('Url')} labelFor="url">
<Input
{...register('url', { required: t('Required') })}
id="url"
type="text"
/>
{errors.url?.message && (
<InputError intent="danger" className="mt-4">
{errors.url.message}
</InputError>
)}
</FormGroup>
<FormGroup label={t('Wallet')} labelFor="wallet">
<Input
{...register('wallet', { required: t('Required') })}
id="wallet"
type="text"
/>
{errors.wallet?.message && (
<InputError intent="danger" className="mt-4">
{errors.wallet.message}
</InputError>
)}
</FormGroup>
<FormGroup label={t('Passphrase')} labelFor="passphrase">
<Input
{...register('passphrase', { required: t('Required') })}
id="passphrase"
type="password"
/>
{errors.passphrase?.message && (
<InputError intent="danger" className="mt-4">
{errors.passphrase.message}
</InputError>
)}
</FormGroup>
{error && (
<p className="text-danger mb-12" data-testid="form-error">
{error}
</p>
)}
<Button variant="primary" type="submit">
{t('Connect')}
</Button>
</form>
);
}