import * as React from 'react'; import styled from 'styled-components'; import { colors } from 'ts/style/colors'; interface InputProps { isSubmitted: boolean; name: string; label: string; } interface ArrowProps { isSubmitted: boolean; } const Input: React.ReactNode = React.forwardRef((props: InputProps, ref) => { const { name, label } = props; const id = `input-${name}`; return ( ); }); export class NewsletterForm extends React.Component { public emailInput = React.createRef(); public state = { isSubmitted: false, }; public render(): React.ReactNode { const {isSubmitted} = this.state; return ( 🎉 Thank you for signing up! Subscribe to our newsletter for updates in the 0x ecosystem ); } private async _onSubmitAsync(e: Event): Promise { e.preventDefault(); const email = this.emailInput.current.value; const referrer = 'https://0xproject.com/'; this.setState({ isSubmitted: true }); try { const response = await fetch('https://website-api.0xproject.com/newsletter_subscriber/substack', { method: 'post', mode: 'cors', headers: { 'content-type': 'application/json; charset=utf-8', }, body: JSON.stringify({ email, referrer }), }); } catch (e) { // dosomething } } } const StyledForm = styled.form` appearance: none; border: 0; color: ${colors.white}; padding: 13px 0 14px; margin-top: 27px; `; const StyledInput = styled.input` appearance: none; background-color: transparent; border: 0; border-bottom: 1px solid #393939; color: #fff; font-size: 1.294117647rem; padding: 15px 0; outline: none; width: 100%; &::placeholder { color: #B1B1B1; // #9D9D9D on light theme } `; const InputWrapper = styled.div` position: relative; `; const InnerInputWrapper = styled.div` opacity: ${props => props.isSubmitted && 0}; visibility: ${props => props.isSubmitted && 'hidden'}; transition: opacity 0.25s ease-in-out, visibility 0.25s ease-in-out; transition-delay: 0.30s; `; const SubmitButton = styled.button` width: 44px; height: 44px; background-color: transparent; border: 0; position: absolute; right: 0; top: calc(50% - 22px); overflow: hidden; outline: 0; &:focus-within { //background-color: #eee; } `; const Text = styled.p` color: #656565; font-size: 0.833333333rem; font-weight: 300; line-height: 1.2em; margin-top: 15px; `; const SuccessText = styled.p` color: #B1B1B1; font-size: 1rem; font-weight: 300; line-height: 1.2em; padding-top: 25px; position: absolute; left: 0; top: 0; text-align: left; right: 50px; opacity: ${props => props.isSubmitted ? 1 : 0}; visibility: ${props => props.isSubmitted ? 'visible' : 'hidden'}; transition: opacity 0.25s ease-in-out, visibility 0.25s ease-in-out; transition-delay: 0.55s; `; const Arrow = styled.svg` transform: ${props => props.isSubmitted && `translateX(44px)`}; transition: transform 0.25s ease-in-out; `;