diff --git a/packages/babel-plugin-transform-vue-jsx/src/index.js b/packages/babel-plugin-transform-vue-jsx/src/index.js index e36143a..bf07daf 100644 --- a/packages/babel-plugin-transform-vue-jsx/src/index.js +++ b/packages/babel-plugin-transform-vue-jsx/src/index.js @@ -152,11 +152,13 @@ const parseAttributeJSXAttribute = (t, path, attributes, tagName, elementType) = let name let modifiers let argument + let rawName if (t.isJSXNamespacedName(namePath)) { name = `${namePath.get('namespace.name').node}:${namePath.get('name.name').node}` } else { name = namePath.get('name').node } + rawName = name if (prefixes.includes(name) && t.isJSXExpressionContainer(path.get('value'))) { return t.JSXSpreadAttribute(t.objectExpression([t.objectProperty(t.stringLiteral(name), path.get('value').node.expression)])) } @@ -188,6 +190,7 @@ const parseAttributeJSXAttribute = (t, path, attributes, tagName, elementType) = value._argument = argument value._modifiers = modifiers + value._rawName = rawName if (rootAttributes.includes(name)) { attributes[name] = value @@ -294,6 +297,9 @@ const transformDirectives = (t, directives) => directives.properties.map(directive => t.objectExpression([ t.objectProperty(t.identifier('name'), directive.key), + ...(directive.value._rawName + ? [t.objectProperty(t.identifier('rawName'), t.stringLiteral(directive.value._rawName))] + : []), t.objectProperty(t.identifier('value'), directive.value), ...(directive.value._argument ? [t.objectProperty(t.identifier('arg'), t.stringLiteral(directive.value._argument))] diff --git a/packages/babel-plugin-transform-vue-jsx/test/functional.js b/packages/babel-plugin-transform-vue-jsx/test/functional.js index 71e1839..e10f2fa 100644 --- a/packages/babel-plugin-transform-vue-jsx/test/functional.js +++ b/packages/babel-plugin-transform-vue-jsx/test/functional.js @@ -250,8 +250,8 @@ test('Custom directives', t => { }) t.is(wrapper.vnode.data.directives.length, 2) - t.deepEqual(wrapper.vnode.data.directives[0], { def: directive, modifiers: {}, name: 'test', value: 123 }) - t.deepEqual(wrapper.vnode.data.directives[1], { def: directive, modifiers: {}, name: 'other', value: 234 }) + t.deepEqual(wrapper.vnode.data.directives[0], { def: directive, modifiers: {}, name: 'test', rawName: 'v-test', value: 123 }) + t.deepEqual(wrapper.vnode.data.directives[1], { def: directive, modifiers: {}, name: 'other', rawName: 'vOther', value: 234 }) }) test('xlink:href', t => { diff --git a/packages/babel-plugin-transform-vue-jsx/test/snapshot.js b/packages/babel-plugin-transform-vue-jsx/test/snapshot.js index 586aed1..73ca2b6 100644 --- a/packages/babel-plugin-transform-vue-jsx/test/snapshot.js +++ b/packages/babel-plugin-transform-vue-jsx/test/snapshot.js @@ -232,25 +232,37 @@ render(h => h("div", _mergeJSXProps([{}, spread, { }, { name: 'Directives', - from: `render(h =>
)`, + from: `render(h => )`, to: `render(h => h("div", { "directives": [{ name: "test", + rawName: "v-test", value: 123 }, { name: "something", + rawName: "vSomething_modifier", value: 1234, modifiers: { "modifier": true } }, { name: "other-stuff", + rawName: "vOtherStuff:argument_modifier1_modifier2", value: 234, arg: "argument", modifiers: { "modifier1": true, "modifier2": true } + }, { + name: "other-stuff", + rawName: "vOtherStuff:argument2_modifier1_modifier2", + value: 2345, + arg: "argument2", + modifiers: { + "modifier1": true, + "modifier2": true + } }] }));`, },