mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-23 01:19:02 +00:00
b493a0c968
* offline-send mvp * cleanup unneeded imports * - create pollOfflineStatus action, action creator, interface * expand UnlockHeader when collapse-button is clicked, instead of div * kick-off pollOfflineStatus upon SendTransaction mount. * Create sagas for polling offline status * remove comment * - create CONFIG_FORCE_OFFLINE action, action creator, interface * Adjust OfflineToggle terms to "Force Online/Offline", and understand when forced offline and when really offline. * - Assume offline in SendTransaction when either offline or forcedOffline * - handle forceOffline action in reducer - adjust state type / provide default state for forceOffline in config reducer * adjust test to pass with different key name * fix incorrect import * - allow size to be specified in offline toggle * - Decode and display nonce in confirmation modal * - set default nonces when forced offline and have online connectivity based on transaction count - pass nonce to generateCompleteTransaction - refactor componentDidUpdate * Allow optional nonce to be passed to generateCompleteTransaction * - create stripHexPrefix function * - cleanup sagas * move getParam into helper util * update address on component update * - show spinner while transaction is being signed - reset state when wallet instance changes (new wallet instantiated via UnlockHeader) * center-align offline message * Adjust force offline/online button text * - validate nonces when offline - only estimate gas when online - don't show send tx button when offline * - break generateCompleteTransactionFromRawTransaction into multiple functions. - support offline generation in generateCompleteTransaction (and generateCompleteTransactionFromRawTransaction). Balance checking is now only done when not offline to support offline generation. * Create Help component (to be used as a tooltip) * Disable hardware wallets when offline. * Hide Send Entire Balance when balance is falsy * Show help icon in nonce field. * - show helper instructions on how to broadcast when user is offline after generating a tx - hardcoded gas limits when offline - refactors * create isPositiveInteger helper function * fix nonce validation * really fix nonce validation (specifically the input highlighting) * remove stray // @flow's * remove offline tab nav * remove unused action arg * address PR comments
78 lines
2.1 KiB
TypeScript
78 lines
2.1 KiB
TypeScript
import React from 'react';
|
|
import translate, { translateRaw } from 'translations';
|
|
import UnitDropdown from './UnitDropdown';
|
|
import { Ether } from 'libs/units';
|
|
|
|
interface Props {
|
|
value: string;
|
|
unit: string;
|
|
tokens: string[];
|
|
balance: number | null | Ether;
|
|
onChange?(value: string, unit: string): void;
|
|
}
|
|
|
|
export default class AmountField extends React.Component {
|
|
public props: Props;
|
|
|
|
public render() {
|
|
const { value, unit, onChange, balance } = this.props;
|
|
const isReadonly = !onChange;
|
|
return (
|
|
<div className="row form-group">
|
|
<div className="col-xs-11">
|
|
<label>{translate('SEND_amount')}</label>
|
|
<div className="input-group">
|
|
<input
|
|
className={`form-control ${isFinite(Number(value)) &&
|
|
Number(value) > 0
|
|
? 'is-valid'
|
|
: 'is-invalid'}`}
|
|
type="text"
|
|
placeholder={translateRaw('SEND_amount_short')}
|
|
value={value}
|
|
disabled={isReadonly}
|
|
onChange={isReadonly ? void 0 : this.onValueChange}
|
|
/>
|
|
<UnitDropdown
|
|
value={unit}
|
|
options={['ether'].concat(this.props.tokens)}
|
|
onChange={isReadonly ? void 0 : this.onUnitChange}
|
|
/>
|
|
</div>
|
|
{!isReadonly &&
|
|
balance && (
|
|
<span className="help-block">
|
|
<a onClick={this.onSendEverything}>
|
|
<span className="strong">
|
|
{translate('SEND_TransferTotal')}
|
|
</span>
|
|
</a>
|
|
</span>
|
|
)}
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
public onUnitChange = (unit: string) => {
|
|
if (this.props.onChange) {
|
|
this.props.onChange(this.props.value, unit);
|
|
}
|
|
};
|
|
|
|
public onValueChange = (e: React.SyntheticEvent<HTMLInputElement>) => {
|
|
if (this.props.onChange) {
|
|
this.props.onChange(
|
|
(e.target as HTMLInputElement).value,
|
|
this.props.unit
|
|
);
|
|
}
|
|
};
|
|
|
|
public onSendEverything = () => {
|
|
if (this.props.onChange) {
|
|
this.props.onChange('everything', this.props.unit);
|
|
}
|
|
};
|
|
}
|