import { BuyQuoteInfo } from '@0x/asset-buyer'; import { BigNumber } from '@0x/utils'; import * as _ from 'lodash'; import * as React from 'react'; import { oc } from 'ts-optchain'; import { ColorOption } from '../style/theme'; import { format } from '../util/format'; import { AmountPlaceholder } from './amount_placeholder'; import { Container, Flex, Text } from './ui'; export interface OrderDetailsProps { buyQuoteInfo?: BuyQuoteInfo; ethUsdPrice?: BigNumber; isLoading: boolean; } export class OrderDetails extends React.Component { public render(): React.ReactNode { const { buyQuoteInfo, ethUsdPrice } = this.props; const buyQuoteAccessor = oc(buyQuoteInfo); const ethAssetPrice = buyQuoteAccessor.ethPerAssetPrice(); const ethTokenFee = buyQuoteAccessor.feeEthAmount(); const totalEthAmount = buyQuoteAccessor.totalEthAmount(); return ( Order Details ); } } export interface EthAmountRowProps { rowLabel: string; ethAmount?: BigNumber; isEthAmountInBaseUnits?: boolean; ethUsdPrice?: BigNumber; shouldEmphasize?: boolean; isLoading: boolean; } export const EthAmountRow: React.StatelessComponent = ({ rowLabel, ethAmount, isEthAmountInBaseUnits, ethUsdPrice, shouldEmphasize, isLoading, }) => { // TODO: put in private function const usdFormatter = isEthAmountInBaseUnits ? format.ethBaseAmountInUsd : format.ethUnitAmountInUsd; const shouldHideUsdPriceSection = _.isUndefined(ethUsdPrice) || _.isUndefined(ethAmount); const usdPriceSection = shouldHideUsdPriceSection ? null : ( ({usdFormatter(ethAmount, ethUsdPrice)}) ); const fontWeight = shouldEmphasize ? 700 : 400; const ethFormatter = isEthAmountInBaseUnits ? format.ethBaseAmount : format.ethUnitAmount; return ( {rowLabel} {usdPriceSection} {ethFormatter( ethAmount, 4, , )} ); }; EthAmountRow.defaultProps = { shouldEmphasize: false, isEthAmountInBaseUnits: true, }; EthAmountRow.displayName = 'EthAmountRow';