feat: chimpunk

This commit is contained in:
Gautier Arcin
2021-08-18 17:33:15 +02:00
parent 4d6114f8f8
commit 95697e2491
7 changed files with 141 additions and 1 deletions

View File

@ -0,0 +1,27 @@
import mailchimp from '@mailchimp/mailchimp_marketing'
mailchimp.setConfig({
apiKey: process.env.NEXT_PUBLIC_MAILCHIMP_API_KEY,
server: process.env.NEXT_PUBLIC_MAILCHIMP_API_SERVER, // E.g. us1
})
export default async (req, res) => {
const { email } = req.body
if (!email) {
return res.status(400).json({ error: 'Email is required' })
}
try {
const test = await mailchimp.lists.addListMember(
process.env.NEXT_PUBLIC_MAILCHIMP_AUDIENCE_ID,
{
email_address: email,
status: 'subscribed',
}
)
return res.status(201).json({ error: '' })
} catch (error) {
return res.status(500).json({ error: error.message || error.toString() })
}
}

27
pages/api/mailchimp.js Normal file
View File

@ -0,0 +1,27 @@
import mailchimp from '@mailchimp/mailchimp_marketing'
mailchimp.setConfig({
apiKey: process.env.NEXT_PUBLIC_MAILCHIMP_API_KEY,
server: process.env.NEXT_PUBLIC_MAILCHIMP_API_SERVER, // E.g. us1
})
export default async (req, res) => {
const { email } = req.body
if (!email) {
return res.status(400).json({ error: 'Email is required' })
}
try {
const test = await mailchimp.lists.addListMember(
process.env.NEXT_PUBLIC_MAILCHIMP_AUDIENCE_ID,
{
email_address: email,
status: 'subscribed',
}
)
return res.status(201).json({ error: '' })
} catch (error) {
return res.status(500).json({ error: error.message || error.toString() })
}
}

View File

@ -5,6 +5,8 @@ import siteMetadata from '@/data/siteMetadata'
import { getAllFilesFrontMatter } from '@/lib/mdx'
import formatDate from '@/lib/utils/formatDate'
import { FormSuscribe } from '@/components/FormSuscribe'
const MAX_DISPLAY = 5
export async function getStaticProps() {
@ -17,6 +19,7 @@ export default function Home({ posts }) {
return (
<>
<PageSEO title={siteMetadata.title} description={siteMetadata.description} />
{siteMetadata.newsletter.provider !== '' && <FormSuscribe />}
<div className="divide-y divide-gray-200 dark:divide-gray-700">
<div className="pt-6 pb-8 space-y-2 md:space-y-5">
<h1 className="text-3xl font-extrabold leading-9 tracking-tight text-gray-900 dark:text-gray-100 sm:text-4xl sm:leading-10 md:text-6xl md:leading-14">