aboutsummaryrefslogtreecommitdiffstats
path: root/packages/website/ts/@next/components
diff options
context:
space:
mode:
authorFred Carlsen <fred@sjelfull.no>2018-11-30 16:55:38 +0800
committerFred Carlsen <fred@sjelfull.no>2018-11-30 16:58:20 +0800
commit189920eab99a731dd6b0880a99ec8cc911b64314 (patch)
treeec8a2892410732e6339bf4568be50c586a2e65bb /packages/website/ts/@next/components
parent83499176d9b627d383a7edc17dd862861af05320 (diff)
downloaddexon-sol-tools-189920eab99a731dd6b0880a99ec8cc911b64314.tar
dexon-sol-tools-189920eab99a731dd6b0880a99ec8cc911b64314.tar.gz
dexon-sol-tools-189920eab99a731dd6b0880a99ec8cc911b64314.tar.bz2
dexon-sol-tools-189920eab99a731dd6b0880a99ec8cc911b64314.tar.lz
dexon-sol-tools-189920eab99a731dd6b0880a99ec8cc911b64314.tar.xz
dexon-sol-tools-189920eab99a731dd6b0880a99ec8cc911b64314.tar.zst
dexon-sol-tools-189920eab99a731dd6b0880a99ec8cc911b64314.zip
Added newsletter form to footer
Diffstat (limited to 'packages/website/ts/@next/components')
-rw-r--r--packages/website/ts/@next/components/footer.tsx8
-rw-r--r--packages/website/ts/@next/components/icon.tsx22
-rw-r--r--packages/website/ts/@next/components/newsletterForm.tsx76
3 files changed, 103 insertions, 3 deletions
diff --git a/packages/website/ts/@next/components/footer.tsx b/packages/website/ts/@next/components/footer.tsx
index b962b8f34..0aff4e840 100644
--- a/packages/website/ts/@next/components/footer.tsx
+++ b/packages/website/ts/@next/components/footer.tsx
@@ -4,9 +4,10 @@ import styled from 'styled-components';
import { colors } from 'ts/style/colors';
-import { Button } from './button';
-import { Column, Section, Wrap } from './layout';
-import { Logo } from './logo';
+import { Button } from 'ts/@next/components/button';
+import { Column, Section, Wrap } from 'ts/@next/components/layout';
+import { Logo } from 'ts/@next/components/logo';
+import { NewsletterForm } from 'ts/@next/components/newsletterForm';
interface FooterInterface {
}
@@ -61,6 +62,7 @@ export const Footer: React.StatelessComponent<FooterInterface> = ({}) => (
<Wrap>
<Column colWidth="1/2" noPadding>
<Logo />
+ <NewsletterForm />
</Column>
<Column colWidth="1/2" noPadding>
diff --git a/packages/website/ts/@next/components/icon.tsx b/packages/website/ts/@next/components/icon.tsx
new file mode 100644
index 000000000..10916f28e
--- /dev/null
+++ b/packages/website/ts/@next/components/icon.tsx
@@ -0,0 +1,22 @@
+import * as React from 'react';
+import styled from 'styled-components';
+
+interface Props {
+ icon: any;
+ size?: any;
+}
+
+const StyledIcon = styled.div`
+ margin: auto;
+ flex-shrink: 0;
+
+ ${(props: Props) => props.size && `
+ width: ${props.size}; height: auto;
+ `}
+`;
+
+export const Icon: React.StatelessComponent = ({ icon, ...props }) => (
+ <>
+ <StyledIcon as={icon as 'svg'} {...props} />
+ </>
+);
diff --git a/packages/website/ts/@next/components/newsletterForm.tsx b/packages/website/ts/@next/components/newsletterForm.tsx
new file mode 100644
index 000000000..6a82acbff
--- /dev/null
+++ b/packages/website/ts/@next/components/newsletterForm.tsx
@@ -0,0 +1,76 @@
+import * as React from 'react';
+import styled from 'styled-components';
+
+import { colors } from 'ts/style/colors';
+
+import formArrow from 'ts/@next/icons/form-arrow.svg';
+
+import {Button} from 'ts/@next/components/button';
+import {Icon} from 'ts/@next/components/icon';
+
+interface InputProps {
+ name: string;
+ label: string;
+}
+
+interface Props {
+}
+
+const Input = ({ ...props }) => {
+ const { name, label } = props;
+ const id = 'input-' + name;
+
+ return (
+ <>
+ <label className="visuallyHidden" htmlFor={id}>{label}</label>
+ <StyledInput id={id} placeholder={label} {...props} />
+ </>
+ )
+};
+
+export const NewsletterForm: React.StatelessComponent = (props: Props) => (
+ <StyledForm>
+ <InputWrapper>
+ <Input name="email" type="email" label="Email Address" />
+ <Icon icon={formArrow} />
+ </InputWrapper>
+ <Text>Subscribe to our newsletter for updates in the 0x ecosystem</Text>
+ </StyledForm>
+);
+
+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: ${colors.textDarkSecondary};
+ font-size: 1.294117647rem;
+ padding: 0 0 16px;
+ width: 100%;
+ margin-bottom: 13px;
+`;
+
+const InputWrapper = styled.div`
+ position: relative;
+`;
+
+const ButtonWrapper = styled(Button)`
+ display: flex;
+ justify-content: center;
+ align-items: center;
+`;
+
+const Text = styled.span`
+ color: #656565;
+ font-size: 0.833333333rem;
+ font-weight: 300;
+ line-height: 1.2em;
+`;