Skip to content
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

Parsing strangeness around flow-level JSX elements #12

Closed
4 tasks done
iczero opened this issue Jan 3, 2024 · 5 comments
Closed
4 tasks done

Parsing strangeness around flow-level JSX elements #12

iczero opened this issue Jan 3, 2024 · 5 comments
Labels
🙋 no/question This does not need any changes 👎 phase/no Post cannot or will not be acted on

Comments

@iczero
Copy link

iczero commented Jan 3, 2024

Initial checklist

Problem

The current flow-level JSX tokenizer is only used for single elements. It cannot handle text. This results in some strangeness when tokenizing which causes flow-level elements to be parsed as inline (text) elements instead.

  • <a>: mdxJsxFlowTag
  • <a><b>: mdxJsxFlowTag, mdxJsxFlowTag
  • <a>hello</a>: +paragraph, mdxJsxTextTag, text, mdxJsxTextTag, -paragraph (transformed as <p><a>hello</a></p>)

This paragraph wrapping behavior causes mdx-js/mdx#1526, which is currently fixed by an AST transform.

Additionally, some users may wish to restore CommonMark behavior for flow-level markdown within tags (mdx-js/mdx#1798). Instead of starting a new paragraph immediately after the tag, the PR requires a blank line to resume flow-level markdown. An opt-in configuration option is used to enable this behavior.

Solution

Please see PR #11. It introduces a new parsing scheme behind a configuration option which allows opting in to new behavior.

Alternatives

Do nothing. The current behavior has existed for a few years and is fine.

@github-actions github-actions bot added 👋 phase/new Post is being triaged automatically 🤞 phase/open Post is being triaged manually and removed 👋 phase/new Post is being triaged automatically labels Jan 3, 2024
@ChristianMurphy
Copy link
Member

ChristianMurphy commented Jan 3, 2024

Welcome @iczero! 👋

This paragraph wrapping behavior causes mdx-js/mdx#1526, which is currently fixed by an AST transform.

Happy to discuss how to make the implementation more efficient.

Additionally, some users may wish to restore CommonMark behavior for flow-level markdown within tags (mdx-js/mdx#1798). Instead of starting a new paragraph immediately after the tag, the PR requires a blank line to resume flow-level markdown.

To be clear on the goal of MDX, it is Markdown + JSX, there is no HTML in MDX.
I am against changing the behavior to making it more HTML like, in ways that diverge from JSX.
Paragraph handling was closer to a mix of HTML and JSX in version 1, it caused endless confusion there are many edge cases.
https://github.com/mdx-js/mdx/issues?q=is%3Aissue+paragraph+is%3Aclosed
I am aware there are arguments both ways, the consistency of the current API is better than the litany of edge cases that mixed HTML/JSX causes.

An opt-in configuration option is used to enable this behavior.

I am against making syntax configurable in core.
MDX should offer a single and consistent language, which includes a single and consistent way of handling tags and paragraphs.
Any variations and customizations can exist in plugins. https://unifiedjs.com/learn/guide/ https://github.com/micromark/micromark#creating-a-micromark-extension

@iczero
Copy link
Author

iczero commented Jan 5, 2024

@ChristianMurphy,

I have closed the PR for now because it uses a terrible approach that doesn't work.

I believe it will be more productive to discuss further when I have a prototype that actually works. I will try to make it an extension.

Thank you for your time.

@wooorm
Copy link
Member

wooorm commented Jan 5, 2024

Additionally, some users may wish to restore CommonMark behavior for flow-level markdown within tags (mdx-js/mdx#1798). Instead of starting a new paragraph immediately after the tag, the PR requires a blank line to resume flow-level markdown. An opt-in configuration option is used to enable this behavior.

They should not. That is not MDX. It is not a good idea. Your custom versions would not work with other tools that use MDX. Such as site engines. Or it would not have proper syntax highlighting in folks’ editors or on GitHub.

As Christian mentions, that was used in MDX 1 and it was the most requested feature to change.
The behavior you want to model is also an often discussed problem in markdown itself: many folks don’t understand the rules and post questions on our markdown related projects.

This paragraph wrapping behavior causes mdx-js/mdx#1526, which is currently fixed by an AST transform.

It is not about p. It’s about which markdown is allowed in other things. <>> block quote?<>, <>* list?<>, <># heading?<>, <> indented code?<>, <>```js\bfenced?.code()<>, <>*emphasis*?<>, etc.

The solution, whether it’s with how XML-like things are treated in markdown or the complete JSX grammar of MDX, is to teach users.

In MDX, it’s as follows:
Put text and tags on the same line if you want text things, aka emphasis, strong, links, spans of code, that kinda stuff.
Put them on separate lines if you want to include “blocks”, aka block quotes, lists, headings, code blocks, etc.

https://mdxjs.com/docs/what-is-mdx/#interleaving

@iczero iczero closed this as not planned Won't fix, can't repro, duplicate, stale Jan 5, 2024

This comment has been minimized.

@JounQin JounQin added the 🙋 no/question This does not need any changes label Jan 6, 2024
Copy link

github-actions bot commented Jan 6, 2024

Hi! Thanks for reaching out! Because we treat issues as our backlog, we close issues that are questions since they don’t represent a task to be completed.

See our support docs for how and where to ask questions.

Thanks,
— bb

@github-actions github-actions bot added 👎 phase/no Post cannot or will not be acted on and removed 🤞 phase/open Post is being triaged manually labels Jan 6, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
🙋 no/question This does not need any changes 👎 phase/no Post cannot or will not be acted on
Development

No branches or pull requests

4 participants