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;
`;