mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-24 09:59:35 +00:00
8fe664c171
* Add definition file for bn.js * Remove types-bn * make isBN a static property * progress commit -- swap out bignumber.js for bn.js * Swap out bignumber for bn in vendor * Change modn to number return * Start to strip out units lib for a string manipulation based lib * Convert codebase to only base units * Get rid of useless component * Handle only wei in values * Use unit conversion in sidebar * Automatically strip hex prefix, and handle decimal edge case * Handle base 16 wei in transactions * Make a render callback component for dealing with unit conversion * Switch contracts to use bn.js, and get transaction values from signedTx instead of state * Get send transaction working with bn.js * Remove redundant hex stripping, return base value of tokens * Cleanup unit file * Re-implement toFixed for strings * Use formatNumber in codebase * Cleanup code * Undo package test changes * Update snapshot and remove console logs * Use TokenValue / Wei more consistently where applicable * Add typing to deterministicWallets, fix confirmation modal, make UnitDisplay more flexible * Clean up prop handling in UnitDisplay * Change instanceof to typeof check, change boolean of displayBalance * Fix tsc errors * Fix token row displaying wrong decimals * Fix deterministic modal token display * Handle hex and non hex strings automatically in BN conversion * Fix handling of strings and numbers for BN * add web3 fixes & comments * Display short balances on deterministic modals * add more tests, fix rounding * Add spacer to balance sidebar network name * Fix tsc error
61 lines
1.4 KiB
TypeScript
61 lines
1.4 KiB
TypeScript
import { toTokenBase } from 'libs/units';
|
|
|
|
import React, { Component } from 'react';
|
|
|
|
interface IChildren {
|
|
onUserInput: UnitConverter['onUserInput'];
|
|
convertedUnit: string;
|
|
}
|
|
interface IFakeEvent {
|
|
currentTarget: {
|
|
value: string;
|
|
};
|
|
}
|
|
|
|
export interface Props {
|
|
decimal: number;
|
|
children({ onUserInput, convertedUnit }: IChildren): React.ReactElement<any>;
|
|
onChange(baseUnit: IFakeEvent);
|
|
}
|
|
|
|
interface State {
|
|
userInput: string;
|
|
}
|
|
|
|
const initialState = { userInput: '' };
|
|
|
|
export class UnitConverter extends Component<Props, State> {
|
|
public state: State = initialState;
|
|
|
|
public componentWillReceiveProps(nextProps: Props) {
|
|
const { userInput } = this.state;
|
|
|
|
if (this.props.decimal !== nextProps.decimal) {
|
|
this.baseUnitCb(userInput, nextProps.decimal);
|
|
}
|
|
}
|
|
|
|
public onUserInput = (e: React.FormEvent<HTMLInputElement>) => {
|
|
const { value } = e.currentTarget;
|
|
const { decimal } = this.props;
|
|
this.baseUnitCb(value, decimal);
|
|
this.setState({ userInput: value });
|
|
};
|
|
|
|
public render() {
|
|
return this.props.children({
|
|
onUserInput: this.onUserInput,
|
|
convertedUnit: this.state.userInput
|
|
});
|
|
}
|
|
private baseUnitCb = (value: string, decimal: number) => {
|
|
const baseUnit = toTokenBase(value, decimal).toString();
|
|
const fakeEvent = {
|
|
currentTarget: {
|
|
value: baseUnit
|
|
}
|
|
};
|
|
this.props.onChange(fakeEvent);
|
|
};
|
|
}
|