MyCrypto/common/containers/Tabs/ENS/components/NameInput.tsx

97 lines
2.8 KiB
TypeScript

import React, { Component } from 'react';
import classnames from 'classnames';
import { connect } from 'react-redux';
import { AppState } from 'reducers';
import { resolveDomainRequested, TResolveDomainRequested } from 'actions/ens';
import { isValidENSName } from 'libs/validators';
import './NameInput.scss';
interface State {
domainToCheck: string;
isValidDomain: boolean;
isFocused: boolean;
}
interface Props {
domainRequests: AppState['ens']['domainRequests'];
resolveDomainRequested: TResolveDomainRequested;
}
class NameInput extends Component<Props, State> {
public state = {
isFocused: false,
isValidDomain: false,
domainToCheck: ''
};
public render() {
const { domainRequests } = this.props;
const { isValidDomain, domainToCheck, isFocused } = this.state;
const req = domainRequests[domainToCheck];
const isLoading = req && !req.data && !req.error;
return (
<form className="ENSInput" onSubmit={this.onSubmit}>
<div className="ENSInput-name input-group">
<input
value={domainToCheck}
className={classnames(
'form-control',
!domainToCheck ? '' : isValidDomain ? 'is-valid' : 'is-invalid'
)}
type="text"
placeholder="mycrypto"
onChange={this.onChange}
onFocus={this.onFocus}
onBlur={this.onBlur}
disabled={isLoading}
/>
<span className="input-group-addon">.eth</span>
</div>
{domainToCheck &&
!isValidDomain &&
!isFocused && (
<p className="help-block is-invalid">
Must be at least 7 characters, no special characters
</p>
)}
<button
className="ENSInput-button btn btn-primary btn-block"
disabled={!isValidDomain || isLoading}
>
Check Availability
</button>
</form>
);
}
// add delay to namehash computation / getting the availability
private onChange = (event: React.FormEvent<HTMLButtonElement>) => {
const domainToCheck = event.currentTarget.value.toLowerCase().trim();
const isValidDomain = isValidENSName(domainToCheck);
this.setState({
domainToCheck,
isValidDomain
});
};
private onSubmit = (ev: React.FormEvent<HTMLElement>) => {
ev.preventDefault();
const { isValidDomain, domainToCheck } = this.state;
return isValidDomain && this.props.resolveDomainRequested(domainToCheck);
};
private onFocus = () => this.setState({ isFocused: true });
private onBlur = () => this.setState({ isFocused: false });
}
function mapStateToProps(state: AppState) {
return {
domainRequests: state.ens.domainRequests
};
}
export default connect(mapStateToProps, {
resolveDomainRequested
})(NameInput);