MyCrypto/common/containers/Tabs/ScheduleTransaction/components/Fields/ScheduleDepositField.tsx

73 lines
2.2 KiB
TypeScript

import { connect } from 'react-redux';
import React, { Component } from 'react';
import { AppState } from 'reducers';
import { setScheduleDepositField, TSetScheduleDepositField } from 'actions/schedule';
import { translateRaw } from 'translations';
import { Input, Tooltip } from 'components/ui';
import { getDecimal } from 'selectors/transaction';
import { getScheduleDeposit, isValidScheduleDeposit } from 'selectors/schedule/fields';
import { toWei } from 'libs/units';
import Help from 'components/ui/Help';
interface OwnProps {
decimal: number;
scheduleDeposit: any;
validScheduleDeposit: boolean;
}
interface DispatchProps {
setScheduleDepositField: TSetScheduleDepositField;
}
type Props = OwnProps & DispatchProps;
class ScheduleDepositFieldClass extends Component<Props> {
public render() {
const { scheduleDeposit, validScheduleDeposit } = this.props;
return (
<div className="input-group-wrapper">
<label className="input-group">
<div className="input-group-header">
<span className="ScheduleFields-field-title-wrap">
{translateRaw('SCHEDULE_DEPOSIT')}
<div className="ScheduleFields-field-title-tooltip">
<Tooltip>{translateRaw('SCHEDULE_DEPOSIT_TOOLTIP')}</Tooltip>
<Help className="ScheduleFields-field-title-help" />
</div>
</span>
</div>
<Input
className={!!scheduleDeposit.raw && !validScheduleDeposit ? 'invalid' : ''}
type="number"
placeholder="0.00001"
value={scheduleDeposit.raw}
onChange={this.handleDepositChange}
/>
</label>
</div>
);
}
private handleDepositChange = (ev: React.FormEvent<HTMLInputElement>) => {
const { decimal } = this.props;
const { value } = ev.currentTarget;
this.props.setScheduleDepositField({
raw: value,
value: value ? toWei(value, decimal) : null
});
};
}
export const ScheduleDepositField = connect(
(state: AppState) => ({
decimal: getDecimal(state),
scheduleDeposit: getScheduleDeposit(state),
validScheduleDeposit: isValidScheduleDeposit(state)
}),
{
setScheduleDepositField
}
)(ScheduleDepositFieldClass);