From 9afb590d1094793fca797449fb7017da9fa06b4e Mon Sep 17 00:00:00 2001 From: tu4mo Date: Sun, 9 Jan 2022 23:59:46 +0200 Subject: [PATCH] feat: support comments in templates (#661) --- .../src/__snapshots__/index.test.ts.snap | 18 ++++++++++++++++++ .../src/index.test.ts | 15 +++++++++++++++ .../src/index.ts | 2 +- 3 files changed, 34 insertions(+), 1 deletion(-) diff --git a/packages/babel-plugin-transform-svg-component/src/__snapshots__/index.test.ts.snap b/packages/babel-plugin-transform-svg-component/src/__snapshots__/index.test.ts.snap index a5d510b6..587508f1 100644 --- a/packages/babel-plugin-transform-svg-component/src/__snapshots__/index.test.ts.snap +++ b/packages/babel-plugin-transform-svg-component/src/__snapshots__/index.test.ts.snap @@ -65,6 +65,15 @@ const MyComponent = (props: React.SVGProps) => ; export default MyComponent;" `; +exports[`plugin javascript custom templates supports comments in templates 1`] = ` +"/** + * Comment + */ +const MyComponent = () => ; + +export default MyComponent;" +`; + exports[`plugin javascript custom templates supports template that does not return an array 1`] = `";"`; exports[`plugin javascript custom templates supports type annotation on component 1`] = ` @@ -284,6 +293,15 @@ const MyComponent = (props: React.SVGProps) => ; export default MyComponent;" `; +exports[`plugin typescript custom templates supports comments in templates 1`] = ` +"/** + * Comment + */ +const MyComponent = () => ; + +export default MyComponent;" +`; + exports[`plugin typescript custom templates supports template that does not return an array 1`] = `";"`; exports[`plugin typescript custom templates supports type annotation on component 1`] = ` diff --git a/packages/babel-plugin-transform-svg-component/src/index.test.ts b/packages/babel-plugin-transform-svg-component/src/index.test.ts index 61d67c90..cce4d490 100644 --- a/packages/babel-plugin-transform-svg-component/src/index.test.ts +++ b/packages/babel-plugin-transform-svg-component/src/index.test.ts @@ -248,6 +248,21 @@ describe('plugin', () => { }) expect(code).toMatchSnapshot() }) + + it('supports comments in templates', () => { + const { code } = testPlugin(language)('', { + template: ({ jsx }, { tpl }) => tpl` + /** + * Comment + */ + const MyComponent = () => ${jsx} + + export default MyComponent; + `, + state: { componentName: 'SvgComponent' }, + }) + expect(code).toMatchSnapshot() + }) }) describe('#jsxRuntime', () => { diff --git a/packages/babel-plugin-transform-svg-component/src/index.ts b/packages/babel-plugin-transform-svg-component/src/index.ts index 65f9afdf..8448a845 100644 --- a/packages/babel-plugin-transform-svg-component/src/index.ts +++ b/packages/babel-plugin-transform-svg-component/src/index.ts @@ -17,7 +17,7 @@ const plugin = (_: ConfigAPI, opts: Options) => { const plugins: ParserOptions['plugins'] = opts.typescript ? ['jsx', 'typescript'] : ['jsx'] - const tpl = babelTemplate.smart({ plugins }).ast + const tpl = babelTemplate.smart({ plugins, preserveComments: true }).ast return { visitor: { Program(path: NodePath) {