feat: chimpunk
This commit is contained in:
27
pages/api/mailchimp copy.js
Normal file
27
pages/api/mailchimp copy.js
Normal 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
27
pages/api/mailchimp.js
Normal 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() })
|
||||
}
|
||||
}
|
@ -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">
|
||||
|
Reference in New Issue
Block a user