Skip to content

Commit

Permalink
Remove whitespace between unraveled text nodes
Browse files Browse the repository at this point in the history
Closes GH-2000.
Closes GH-2252.
  • Loading branch information
wooorm authored Feb 9, 2023
1 parent d0a65fc commit 764d3a2
Show file tree
Hide file tree
Showing 2 changed files with 55 additions and 2 deletions.
15 changes: 14 additions & 1 deletion packages/mdx/lib/plugin/remark-mark-and-unravel.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
/**
* @typedef {import('mdast').Content} Content
* @typedef {import('mdast').Root} Root
*
* @typedef {import('remark-mdx')} DoNotTouchAsThisImportItIncludesMdxInTree
Expand Down Expand Up @@ -47,6 +48,9 @@ export function remarkMarkAndUnravel() {
if (all && oneOrMore) {
offset = -1

/** @type {Array<Content>} */
const newChildren = []

while (++offset < children.length) {
const child = children[offset]

Expand All @@ -59,9 +63,18 @@ export function remarkMarkAndUnravel() {
// @ts-expect-error: content model is fine.
child.type = 'mdxFlowExpression'
}

if (
child.type === 'text' &&
/^[\t\r\n ]+$/.test(String(child.value))
) {
// Empty.
} else {
newChildren.push(child)
}
}

parent.children.splice(index, 1, ...children)
parent.children.splice(index, 1, ...newChildren)
return index
}
}
Expand Down
42 changes: 41 additions & 1 deletion packages/mdx/test/compile.js
Original file line number Diff line number Diff line change
Expand Up @@ -1256,7 +1256,7 @@ test('MDX (JSX)', async () => {
renderToStaticMarkup(
React.createElement(await run(compileSync('<a>b</a>\t<b>c</b>')))
),
'<a>b</a>\n\t\n<b>c</b>',
'<a>b</a>\n<b>c</b>',
'should unravel JSX (text) and whitespace as only children'
)

Expand Down Expand Up @@ -1363,6 +1363,46 @@ test('MDX (JSX)', async () => {
'<i>the sum of one and one is: 2</i>',
'should support JSX in expressions'
)

// Important: there should not be whitespace in the `tr`.
// This is normally not present, but unraveling makes this a bit more complex.
// See: <https://github.com/mdx-js/mdx/issues/2000>.
assert.equal(
compileSync(`<table>
<thead>
<tr>
<th>a</th>
<th>b</th>
</tr>
</thead>
</table>`).value,
[
'/*@jsxRuntime automatic @jsxImportSource react*/',
'import {jsx as _jsx, jsxs as _jsxs} from "react/jsx-runtime";',
'function _createMdxContent(props) {',
' return _jsx("table", {',
' children: _jsx("thead", {',
' children: _jsxs("tr", {',
' children: [_jsx("th", {',
' children: "a"',
' }), _jsx("th", {',
' children: "b"',
' })]',
' })',
' })',
' });',
'}',
'function MDXContent(props = {}) {',
' const {wrapper: MDXLayout} = props.components || ({});',
' return MDXLayout ? _jsx(MDXLayout, Object.assign({}, props, {',
' children: _jsx(_createMdxContent, props)',
' })) : _createMdxContent(props);',
'}',
'export default MDXContent;',
''
].join('\n'),
'should support JSX in expressions'
)
})

test('MDX (ESM)', async () => {
Expand Down

1 comment on commit 764d3a2

@vercel
Copy link

@vercel vercel bot commented on 764d3a2 Feb 9, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Successfully deployed to the following URLs:

mdx – ./

mdx-mdx.vercel.app
mdxjs.com
mdx-git-main-mdx.vercel.app
v2.mdxjs.com

Please sign in to comment.