-
Notifications
You must be signed in to change notification settings - Fork 355
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Expected a closing tag for <p> (2:1-2:4) before the end of paragraph #672
Comments
Thanks for opening this, but can you provide a more simplified example to reproduce the error? I'm not seeing this same error when I create a (simplified) test to be run by mocha. |
I can't really create a minimal example but I will explain what happens. I use a custom (private) CMS system that automatically creates HTML and markdown code. export function getBlogs() {
const blogs = data.blogs
fs.emptyDirSync(`./src/content/blog/`)
blogs.forEach(async (blog) => {
const slug = makeSlug(blog.title)
const date = parseFormattedDate(blog.publish_date)
const parsedContent = await marked.parse(blog.content)
console.log(`Writing ${slug}.mdx`)
fs.writeFile(
`./src/content/blog/${slug}.mdx`,
`---
title: '${blog.title}'
description: '${blog.description}'
pubDate: '${date}'
heroImage: 'data:image/${blog.hero_image?.content_type};base64,${blog.hero_image?.base64}'
---
${removeSpecificTags(correctHtml(parsedContent), 'br')}
`,
)
})
}
// function that corrects HTML tags
export const correctHtml = (html: string) => {
return sanitizeHtml(html, {
allowVulnerableTags: true,
allowedTags: false, // allow all tags but close unclosed tags
allowedAttributes: false, // allow all attributes
allowedSchemes: ['data', 'http', 'https'],
})
}
export const removeSpecificTags = (html: string, tag: string) => {
const regex = new RegExp(`<${tag}\\s*\\/?>`, 'gi')
return html.replace(regex, '')
} Which puts the mdx in a folder for Astro to see as a content thingy: import { defineCollection, z } from 'astro:content'
const blog = defineCollection({
type: 'content',
// Type-check frontmatter using a schema
schema: z.object({
title: z.string(),
description: z.string(),
// Transform string to Date object
pubDate: z.coerce.date(),
updatedDate: z.coerce.date().optional(),
heroImage: z.string().optional(),
}),
})
export const collections = { blog } This is a blogpost page: ---
import { type CollectionEntry, getCollection } from 'astro:content'
import BlogPost from '../../layouts/BlogPost.astro'
export async function getStaticPaths() {
const posts = await getCollection('blog')
return posts.map((post) => ({
params: { slug: post.slug },
props: post,
}))
}
type Props = CollectionEntry<'blog'>
const post = Astro.props
const { Content } = await post.render()
---
<BlogPost {...post.data}>
<Content />
</BlogPost>
---
import type { CollectionEntry } from 'astro:content'
import BaseHead from '../components/BaseHead.astro'
import Header from '../components/Header.astro'
import Footer from '../components/Footer.astro'
import FormattedDate from '../components/FormattedDate.astro'
import ProgressiveBlur from '@/components/ProgressiveBlur.astro'
import { Badge } from '@/components/ui/badge'
import BackgroundEffect from '@/components/background-effect.astro'
import Layout from '@/components/Layout.astro'
type Props = CollectionEntry<'blog'>['data']
const { title, description, pubDate, updatedDate, heroImage } = Astro.props
---
<Layout SITE_TITLE={title} SITE_DESCRIPTION={description}>
<section class="items-center gap-2 row-span-4 col-span-4 image-container">
<Badge variant="secondary"
><FormattedDate date={pubDate} />
{
updatedDate && (
<div class="last-updated-on">
Last updated on <FormattedDate date={updatedDate} />
</div>
)
}</Badge
>
<h1
class="text-3xl font-bold tracking-tighter sm:text-4xl md:text-5xl lg:text-6xl/none"
transition:name={`title-${title.replace(/[^a-z0-9]/gi, '')}`}
>
{title}
</h1>
<!-- <span
class="max-w-[750px] text-center text-lg font-light text-foreground"
data-br=":rme:"
data-brr="1"
style="display: inline-block; vertical-align: top; text-decoration: inherit; max-width: 502px;"
transition:name={`description-${title.replace(/[^a-z0-9]/gi, '')}`}
>{description}</span
> -->
<img
width={1020}
height={510}
src={heroImage}
alt=`Hero image for ${title}`
class="aspect-video overflow-hidden rounded-xl w-full h-fit object-cover object-center mt-8"
transition:name={`hero-${title.replace(/[^a-z0-9]/gi, '')}`}
/>
<div
class="w-full mt-8 prose md:prose-lg lg:prose-xl dark:prose-invert max-w-none prose-img:rounded-xl"
>
<slot />
</div>
</section>
</Layout> This is how I get the error. |
Hi @FormalSnake, we can't really speak to MDX, just to this module. So what I recommend is that you send a PR that adds a new test to |
I will try, thanks! |
PLEASE NOTE: make sure the bug exists in the latest patch level of the project. For instance, if you are running a 2.x version of Apostrophe, you should use the latest in that major version to confirm the bug.
To Reproduce
Use this code for mdx files:
Get some code out of it:
Use it for blogs in Astro and error:
Expected a closing tag for <p> (2:1-2:4) before the end of paragraph
This is due to this:
The text was updated successfully, but these errors were encountered: