diff options
author | Steve Klebanoff <steve.klebanoff@gmail.com> | 2018-11-02 02:29:33 +0800 |
---|---|---|
committer | Steve Klebanoff <steve.klebanoff@gmail.com> | 2018-11-02 02:29:33 +0800 |
commit | 61a1a0be974c8610623f2bcb9a43797532cc78d9 (patch) | |
tree | c975bade60c51873e77f04669cf0d7edda185ec2 /packages/instant/src/components | |
parent | 3430896eb79b68e370b68f8954b1ef1b97d86a18 (diff) | |
download | dexon-0x-contracts-61a1a0be974c8610623f2bcb9a43797532cc78d9.tar dexon-0x-contracts-61a1a0be974c8610623f2bcb9a43797532cc78d9.tar.gz dexon-0x-contracts-61a1a0be974c8610623f2bcb9a43797532cc78d9.tar.bz2 dexon-0x-contracts-61a1a0be974c8610623f2bcb9a43797532cc78d9.tar.lz dexon-0x-contracts-61a1a0be974c8610623f2bcb9a43797532cc78d9.tar.xz dexon-0x-contracts-61a1a0be974c8610623f2bcb9a43797532cc78d9.tar.zst dexon-0x-contracts-61a1a0be974c8610623f2bcb9a43797532cc78d9.zip |
Move BuyOrderProgress to its own component
Diffstat (limited to 'packages/instant/src/components')
-rw-r--r-- | packages/instant/src/components/buy_order_progress.tsx | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/packages/instant/src/components/buy_order_progress.tsx b/packages/instant/src/components/buy_order_progress.tsx new file mode 100644 index 000000000..e259e5606 --- /dev/null +++ b/packages/instant/src/components/buy_order_progress.tsx @@ -0,0 +1,35 @@ +import * as React from 'react'; + +import { TimedProgressBar } from '../components/timed_progress_bar'; + +import { TimeCounter } from '../components/time_counter'; +import { Container } from '../components/ui'; +import { OrderProcessState, OrderState } from '../types'; + +export interface BuyOrderProgressProps { + buyOrderState: OrderState; +} + +export const BuyOrderProgress: React.StatelessComponent<BuyOrderProgressProps> = props => { + const { buyOrderState } = props; + + if ( + buyOrderState.processState === OrderProcessState.PROCESSING || + buyOrderState.processState === OrderProcessState.SUCCESS || + buyOrderState.processState === OrderProcessState.FAILURE + ) { + const progress = buyOrderState.progress; + const hasEnded = buyOrderState.processState !== OrderProcessState.PROCESSING; + const expectedTimeMs = progress.expectedEndTimeUnix - progress.startTimeUnix; + return ( + <Container padding="20px 20px 0px 20px" width="100%"> + <Container marginBottom="5px"> + <TimeCounter estimatedTimeMs={expectedTimeMs} hasEnded={hasEnded} key={progress.startTimeUnix} /> + </Container> + <TimedProgressBar expectedTimeMs={expectedTimeMs} hasEnded={hasEnded} key={progress.startTimeUnix} /> + </Container> + ); + } + + return null; +}; |