aboutsummaryrefslogtreecommitdiffstats
path: root/packages/website/ts/pages/market_maker.tsx
blob: 854870358df83269d621dd44e518fdb6348d64d9 (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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
import * as _ from 'lodash';
import { opacify } from 'polished';
import * as React from 'react';

import { Banner } from 'ts/components/banner';
import { Button } from 'ts/components/button';
import { Action, Definition } from 'ts/components/definition';
import { Hero } from 'ts/components/hero';
import { ModalContact, ModalContactType } from 'ts/components/modals/modal_contact';
import { Section } from 'ts/components/newLayout';
import { SiteWrap } from 'ts/components/siteWrap';
import { colors } from 'ts/style/colors';
import { WebsitePaths } from 'ts/types';

interface OfferData {
    icon: string;
    title: string;
    description: string;
    links?: Action[];
}
export interface NextMarketMakerProps {}

export class NextMarketMaker extends React.Component<NextMarketMakerProps> {
    public state = {
        isContactModalOpen: false,
    };

    private readonly _offersData: OfferData[];

    constructor(props: NextMarketMakerProps) {
        super(props);
        this._offersData = [
            {
                icon: 'supportForAllEthereumStandards',
                title: 'Comprehensive Tutorials',
                description:
                    'Stay on the bleeding edge of crypto by learning how to market make on decentralized exchanges. The network of 0x relayers provides market makers a first-mover advantage to capture larger spreads, find arbitrage opportunities, and trade on new types of exchanges like prediction markets and non-fungible token marketplaces.',
                links: [
                    {
                        label: 'Explore the Docs',
                        url: `${WebsitePaths.Wiki}#Market-Making-on-0x`,
                    },
                ],
            },
            {
                icon: 'generateRevenueForYourBusiness-large',
                title: 'Market Making Compensation',
                description: 'Accepted applicants can receive up to $15,000 for completing onboarding',
            },
            {
                icon: 'getInTouch',
                title: 'Dedicated Support',
                description:
                    'The 0x team will provide 1:1 onboarding assistance and promptly answer all your questions. They will walk you through the tutorials so that you know how to read 0x order types, spin up an Ethereum node, and execute trades on the blockchain.',
                links: [
                    {
                        label: 'Contact Us',
                        onClick: this._onOpenContactModal,
                        shouldUseAnchorTag: true,
                    },
                ],
            },
        ];
    }

    public render(): React.ReactNode {
        return (
            <SiteWrap theme="light">
                <Hero
                    maxWidth="865px"
                    maxWidthHeading="715px"
                    isLargeTitle={false}
                    isFullWidth={false}
                    isCenteredMobile={false}
                    title="Bring liquidity to the markets of the future"
                    description="Market makers (MMs) are important stakeholders in the 0x ecosystem. The Market Making Program provides a set of resources that help onboard MMs to bring liquidity to the 0x network. The Program includes tutorials, monetary incentives, and 1:1 support from the 0x team."
                    actions={this._renderHeroActions()}
                />

                <Section bgColor="light" isFlex={true} maxWidth="1170px">
                    <Definition
                        title="Secure Trading"
                        titleSize="small"
                        description="Take full custody of your assets to eliminate counterparty risk"
                        icon="secureTrading"
                        iconSize="medium"
                        isInline={true}
                    />

                    <Definition
                        title="Networked Liquidity Pool"
                        titleSize="small"
                        description="Use one pool of capital across multiple relayers to trade against a large group of takers"
                        icon="networkedLiquidity"
                        iconSize="medium"
                        isInline={true}
                    />

                    <Definition
                        title="Low Cost"
                        titleSize="small"
                        description="Pay no gas fees to make 0x orders"
                        icon="low-cost"
                        iconSize="medium"
                        isInline={true}
                    />
                </Section>

                <Section>
                    {_.map(this._offersData, (item, index) => (
                        <Definition
                            key={`offers-${index}`}
                            icon={item.icon}
                            title={item.title}
                            description={item.description}
                            isInlineIcon={true}
                            iconSize={240}
                            fontSize="medium"
                            actions={item.links}
                        />
                    ))}
                </Section>

                <Banner
                    heading="Start trading today."
                    subline="Check out our Market Making tutorials to get started"
                    mainCta={{ text: 'Tutorials', href: `${WebsitePaths.Wiki}#Market-Making-on-0x` }}
                    secondaryCta={{ text: 'Apply Now', onClick: this._onOpenContactModal }}
                />
                <ModalContact
                    isOpen={this.state.isContactModalOpen}
                    onDismiss={this._onDismissContactModal}
                    modalContactType={ModalContactType.MarketMaker}
                />
            </SiteWrap>
        );
    }

    private readonly _onOpenContactModal = (): void => {
        this.setState({ isContactModalOpen: true });
    };

    private readonly _onDismissContactModal = (): void => {
        this.setState({ isContactModalOpen: false });
    };

    private readonly _renderHeroActions = () => (
        <>
            <Button href={`${WebsitePaths.Wiki}#Market-Making-on-0x`} bgColor="dark" isInline={true}>
                Get Started
            </Button>
            <Button
                onClick={this._onOpenContactModal}
                borderColor={opacify(0.4)(colors.brandDark)}
                isTransparent={true}
                isInline={true}
            >
                Apply Now
            </Button>
        </>
    );
}