mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-12 03:54:13 +00:00
41f8ab8966
* Add support for decimal and symbol getters * Make custom token form interactive via address lookup * Add balance field, improve error handling * Fix lint errors * Fix erc20 interface * Expand method name * Normalize parameter name * Remove extra variable * Stricten typing for decimals * Use common input field between decimal and symbol fields * use mycrypto-nano-result
59 lines
1.8 KiB
TypeScript
59 lines
1.8 KiB
TypeScript
import React from 'react';
|
|
import { Input } from 'components/ui';
|
|
import { translateRaw } from 'translations';
|
|
import { IGenerateAddressLookup } from './AddCustomTokenForm';
|
|
import { isValidETHAddress } from 'libs/validators';
|
|
import { Result } from 'mycrypto-nano-result';
|
|
|
|
interface OwnProps {
|
|
addressLookup: IGenerateAddressLookup;
|
|
onChange(address: Result<string>): void;
|
|
}
|
|
|
|
enum ErrType {
|
|
INVALIDADDR = 'Not a valid address',
|
|
ADDRTAKEN = 'A token with this address already exists'
|
|
}
|
|
|
|
interface State {
|
|
address: Result<string>;
|
|
userInput: string;
|
|
}
|
|
|
|
export class AddressField extends React.Component<OwnProps, State> {
|
|
public state: State = {
|
|
address: Result.from({ res: '' }),
|
|
userInput: ''
|
|
};
|
|
|
|
public render() {
|
|
const { userInput, address } = this.state;
|
|
|
|
return (
|
|
<label className="AddCustom-field form-group">
|
|
<div className="input-group-header">{translateRaw('TOKEN_ADDR')}</div>
|
|
<Input
|
|
isValid={address.ok()}
|
|
className="input-group-input-small"
|
|
type="text"
|
|
name="Address"
|
|
value={address.ok() ? address.unwrap() : userInput}
|
|
onChange={this.handleFieldChange}
|
|
/>
|
|
{address.err() && <div className="AddCustom-field-error">{address.err()}</div>}
|
|
</label>
|
|
);
|
|
}
|
|
|
|
private handleFieldChange = (e: React.FormEvent<HTMLInputElement>) => {
|
|
const userInput = e.currentTarget.value;
|
|
const addrTaken = this.props.addressLookup[userInput];
|
|
const validAddr = isValidETHAddress(userInput);
|
|
const err = addrTaken ? ErrType.ADDRTAKEN : !validAddr ? ErrType.INVALIDADDR : undefined;
|
|
const address: Result<string> = err ? Result.from({ err }) : Result.from({ res: userInput });
|
|
|
|
this.setState({ userInput, address });
|
|
this.props.onChange(address);
|
|
};
|
|
}
|