diff --git a/packages/mdx/estree-to-js.js b/packages/mdx/estree-to-js.js index 2ef877c94..f05a5c9c9 100644 --- a/packages/mdx/estree-to-js.js +++ b/packages/mdx/estree-to-js.js @@ -5,13 +5,16 @@ module.exports = estreeToJs const customGenerator = Object.assign({}, astring.baseGenerator, { JSXAttribute: JSXAttribute, JSXClosingElement: JSXClosingElement, + JSXClosingFragment: JSXClosingFragment, JSXElement: JSXElement, JSXEmptyExpression: JSXEmptyExpression, JSXExpressionContainer: JSXExpressionContainer, + JSXFragment: JSXFragment, JSXIdentifier: JSXIdentifier, JSXMemberExpression: JSXMemberExpression, JSXNamespacedName: JSXNamespacedName, JSXOpeningElement: JSXOpeningElement, + JSXOpeningFragment: JSXOpeningFragment, JSXSpreadAttribute: JSXSpreadAttribute, JSXText: JSXText }) @@ -36,6 +39,11 @@ function JSXClosingElement(node, state) { this[node.name.type](node.name, state) } +// `>` +function JSXClosingFragment(node, state) { + state.write('>') +} + // `
` function JSXElement(node, state) { state.write('<') @@ -56,6 +64,24 @@ function JSXElement(node, state) { } } +// `<>>` +function JSXFragment(node, state) { + this[node.openingFragment.type](node.openingElement, state) + + let index = -1 + + while (++index < node.children.length) { + this[node.children[index].type](node.children[index], state) + } + + /* istanbul ignore if - incorrect tree. */ + if (!node.closingFragment) { + throw new Error('Cannot handle fragment w/o closing tag') + } + + this[node.closingFragment.type](node.closingElement, state) +} + // `{}` function JSXEmptyExpression() {} @@ -77,6 +103,11 @@ function JSXOpeningElement(node, state) { } } +// `<>` +function JSXOpeningFragment(node, state) { + state.write('<>') +} + // `div` function JSXIdentifier(node, state) { state.write(node.name)