aboutsummaryrefslogtreecommitdiffstats
path: root/packages/instant/src/components/zero_ex_instant_container.tsx
blob: ef6adf384934fc2dfc648dc8e78b2500746cf438 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
import * as React from 'react';

import { AvailableERC20TokenSelector } from '../containers/available_erc20_token_selector';
import { LatestBuyQuoteOrderDetails } from '../containers/latest_buy_quote_order_details';
import { LatestError } from '../containers/latest_error';
import { SelectedAssetBuyOrderStateButtons } from '../containers/selected_asset_buy_order_state_buttons';
import { SelectedAssetInstantHeading } from '../containers/selected_asset_instant_heading';

import { SelectedAssetBuyOrderProgress } from '../containers/selected_asset_buy_order_progress';

import { ColorOption } from '../style/theme';
import { zIndex } from '../style/z_index';

import { SlideAnimationState } from './animations/slide_animation';
import { SlidingPanel } from './sliding_panel';
import { Container } from './ui/container';
import { Flex } from './ui/flex';

export interface ZeroExInstantContainerProps {}
export interface ZeroExInstantContainerState {
    tokenSelectionPanelAnimationState: SlideAnimationState;
}

export class ZeroExInstantContainer extends React.Component<ZeroExInstantContainerProps, ZeroExInstantContainerState> {
    public state = {
        tokenSelectionPanelAnimationState: 'none' as SlideAnimationState,
    };
    public render(): React.ReactNode {
        return (
            <Container
                width={{ default: '350px', sm: '100%' }}
                height={{ default: 'auto', sm: '100%' }}
                position="relative"
            >
                <Container zIndex={zIndex.errorPopup} position="relative">
                    <LatestError />
                </Container>
                <Container
                    zIndex={zIndex.mainContainer}
                    position="relative"
                    backgroundColor={ColorOption.white}
                    borderRadius="3px"
                    hasBoxShadow={true}
                    overflow="hidden"
                    height="100%"
                >
                    <Flex direction="column" height="100%" justify="flex-start">
                        <SelectedAssetInstantHeading onSelectAssetClick={this._handleSymbolClick} />
                        <SelectedAssetBuyOrderProgress />
                        <LatestBuyQuoteOrderDetails />
                        <Container padding="20px" width="100%">
                            <SelectedAssetBuyOrderStateButtons />
                        </Container>
                    </Flex>
                    <SlidingPanel
                        title="Select Token"
                        animationState={this.state.tokenSelectionPanelAnimationState}
                        onClose={this._handlePanelClose}
                    >
                        <AvailableERC20TokenSelector onTokenSelect={this._handlePanelClose} />
                    </SlidingPanel>
                </Container>
            </Container>
        );
    }
    private readonly _handleSymbolClick = (): void => {
        this.setState({
            tokenSelectionPanelAnimationState: 'slidIn',
        });
    };
    private readonly _handlePanelClose = (): void => {
        this.setState({
            tokenSelectionPanelAnimationState: 'slidOut',
        });
    };
}