diff options
author | Fabio Berger <me@fabioberger.com> | 2018-07-05 21:04:58 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-07-05 21:04:58 +0800 |
commit | 87a7a4ad2d55641cbe06d7157df0d8f0996d033a (patch) | |
tree | f0374adf1f3e6d87df25032499f14ec7c231265c /packages/web3-wrapper/src/utils.ts | |
parent | 5176d929fa6d3c6ce414448ea2441bd450f04e3c (diff) | |
parent | a1fb438a8c8722d14c7a1e52e844898ff5451e66 (diff) | |
download | dexon-sol-tools-87a7a4ad2d55641cbe06d7157df0d8f0996d033a.tar dexon-sol-tools-87a7a4ad2d55641cbe06d7157df0d8f0996d033a.tar.gz dexon-sol-tools-87a7a4ad2d55641cbe06d7157df0d8f0996d033a.tar.bz2 dexon-sol-tools-87a7a4ad2d55641cbe06d7157df0d8f0996d033a.tar.lz dexon-sol-tools-87a7a4ad2d55641cbe06d7157df0d8f0996d033a.tar.xz dexon-sol-tools-87a7a4ad2d55641cbe06d7157df0d8f0996d033a.tar.zst dexon-sol-tools-87a7a4ad2d55641cbe06d7157df0d8f0996d033a.zip |
Merge pull request #821 from 0xProject/remove-web3-from-wrapper
Remove Web3.js From 0x-monorepo 🍾
Diffstat (limited to 'packages/web3-wrapper/src/utils.ts')
-rw-r--r-- | packages/web3-wrapper/src/utils.ts | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/packages/web3-wrapper/src/utils.ts b/packages/web3-wrapper/src/utils.ts new file mode 100644 index 000000000..d13eb9404 --- /dev/null +++ b/packages/web3-wrapper/src/utils.ts @@ -0,0 +1,58 @@ +import { BigNumber } from '@0xproject/utils'; +import * as _ from 'lodash'; + +export const utils = { + isBigNumber(value: any): boolean { + const isBigNumber = _.isObject(value) && value.isBigNumber; + return isBigNumber; + }, + convertHexToNumber(value: string): number { + const valueBigNumber = new BigNumber(value); + const valueNumber = valueBigNumber.toNumber(); + return valueNumber; + }, + convertHexToNumberOrNull(hex: string | null): number | null { + if (_.isNull(hex)) { + return null; + } + const decimal = this.convertHexToNumber(hex); + return decimal; + }, + convertAmountToBigNumber(value: string | number | BigNumber): BigNumber { + const num = value || 0; + const isBigNumber = utils.isBigNumber(num); + if (isBigNumber) { + return num as BigNumber; + } + + if (_.isString(num) && (num.indexOf('0x') === 0 || num.indexOf('-0x') === 0)) { + return new BigNumber(num.replace('0x', ''), 16); + } + + const baseTen = 10; + return new BigNumber((num as number).toString(baseTen), baseTen); + }, + encodeAmountAsHexString(value: string | number | BigNumber): string { + const valueBigNumber = utils.convertAmountToBigNumber(value); + const hexBase = 16; + const valueHex = valueBigNumber.toString(hexBase); + + return valueBigNumber.lessThan(0) ? '-0x' + valueHex.substr(1) : '0x' + valueHex; + }, + numberToHex(value: number): string { + if (!isFinite(value) && !this.isHexStrict(value)) { + throw new Error(`Given input ${value} is not a number.`); + } + + const valueBigNumber = new BigNumber(value); + const hexBase = 16; + const result = valueBigNumber.toString(hexBase); + + return valueBigNumber.lt(0) ? '-0x' + result.substr(1) : '0x' + result; + }, + isHexStrict(hex: string | number): boolean { + return ( + (_.isString(hex) || _.isNumber(hex)) && /^(-)?0x[0-9a-f]*$/i.test(_.isNumber(hex) ? hex.toString() : hex) + ); + }, +}; |