diff --git a/packages/website/ts/components/banner.tsx b/packages/website/ts/components/banner.tsx index ce3fd499a1..10c9ab7bcf 100644 --- a/packages/website/ts/components/banner.tsx +++ b/packages/website/ts/components/banner.tsx @@ -51,6 +51,7 @@ export const Banner: React.StatelessComponent = (props: Props) => { color={colors.white} isTransparent={false} href={mainCta.href} + onClick={mainCta.onClick} target={mainCta.shouldOpenInNewTab ? '_blank' : ''} > {mainCta.text} diff --git a/packages/website/ts/components/dropdowns/dropdown_developers.tsx b/packages/website/ts/components/dropdowns/dropdown_developers.tsx index 590d2ead96..0cbca886af 100644 --- a/packages/website/ts/components/dropdowns/dropdown_developers.tsx +++ b/packages/website/ts/components/dropdowns/dropdown_developers.tsx @@ -41,6 +41,10 @@ const introData: LinkConfig[] = [ label: 'Market making', url: `${WebsitePaths.MarketMaker}`, }, + { + label: 'Free Credits', + url: `${WebsitePaths.Credits}`, + }, ]; const docsData: LinkConfig[] = [ diff --git a/packages/website/ts/index.tsx b/packages/website/ts/index.tsx index 7bb018d17e..b1f30eb0bd 100644 --- a/packages/website/ts/index.tsx +++ b/packages/website/ts/index.tsx @@ -20,6 +20,7 @@ import { NextAboutJobs } from 'ts/pages/about/jobs'; import { NextAboutMission } from 'ts/pages/about/mission'; import { NextAboutPress } from 'ts/pages/about/press'; import { NextAboutTeam } from 'ts/pages/about/team'; +import { NextCredits } from 'ts/pages/credits'; import { NextEcosystem } from 'ts/pages/ecosystem'; import { Next0xInstant } from 'ts/pages/instant'; import { NextLanding } from 'ts/pages/landing'; @@ -110,6 +111,11 @@ render( path={WebsitePaths.MarketMaker} component={NextMarketMaker as any} /> + diff --git a/packages/website/ts/pages/credits.tsx b/packages/website/ts/pages/credits.tsx new file mode 100644 index 0000000000..d89fb7bf7f --- /dev/null +++ b/packages/website/ts/pages/credits.tsx @@ -0,0 +1,117 @@ +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 NextCreditsProps {} + +export class NextCredits extends React.Component { + public state = { + isContactModalOpen: false, + }; + + private readonly _offersData: OfferData[]; + + constructor(props: NextCreditsProps) { + 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 ( + + + +
+
+ + + +
+ ); + } + + private readonly _onOpenContactModal = (): void => { + this.setState({ isContactModalOpen: true }); + }; + + private readonly _onDismissContactModal = (): void => { + this.setState({ isContactModalOpen: false }); + }; + + private readonly _renderHeroActions = () => ( + <> + + + ); +} diff --git a/packages/website/ts/types.ts b/packages/website/ts/types.ts index 081c6d0144..0a0e150d90 100644 --- a/packages/website/ts/types.ts +++ b/packages/website/ts/types.ts @@ -379,6 +379,7 @@ export enum WebsitePaths { AssetBuyer = '/docs/asset-buyer', Migrations = '/docs/migrations', Careers = '/careers', + Credits = '/credits', } export enum DocPackages {