2019-10-01 19:43:59 +00:00
|
|
|
import {
|
|
|
|
NodeTypes,
|
|
|
|
CallExpression,
|
|
|
|
ElementNode,
|
|
|
|
locStub,
|
|
|
|
Namespaces,
|
|
|
|
ElementTypes
|
|
|
|
} from '../src'
|
|
|
|
import { CREATE_VNODE } from '../src/runtimeConstants'
|
2019-10-03 03:10:41 +00:00
|
|
|
import { isString } from '@vue/shared'
|
2019-10-01 19:04:58 +00:00
|
|
|
|
|
|
|
const leadingBracketRE = /^\[/
|
|
|
|
const bracketsRE = /^\[|\]$/g
|
|
|
|
|
|
|
|
// Create a matcher for an object
|
|
|
|
// where non-static expressions should be wrapped in []
|
|
|
|
// e.g.
|
|
|
|
// - createObjectMatcher({ 'foo': '[bar]' }) matches { foo: bar }
|
|
|
|
// - createObjectMatcher({ '[foo]': 'bar' }) matches { [foo]: "bar" }
|
|
|
|
export function createObjectMatcher(obj: any) {
|
|
|
|
return {
|
|
|
|
type: NodeTypes.JS_OBJECT_EXPRESSION,
|
|
|
|
properties: Object.keys(obj).map(key => ({
|
|
|
|
type: NodeTypes.JS_PROPERTY,
|
|
|
|
key: {
|
|
|
|
type: NodeTypes.SIMPLE_EXPRESSION,
|
|
|
|
content: key.replace(bracketsRE, ''),
|
|
|
|
isStatic: !leadingBracketRE.test(key)
|
|
|
|
},
|
2019-10-03 03:10:41 +00:00
|
|
|
value: isString(obj[key])
|
|
|
|
? {
|
|
|
|
type: NodeTypes.SIMPLE_EXPRESSION,
|
|
|
|
content: obj[key].replace(bracketsRE, ''),
|
|
|
|
isStatic: !leadingBracketRE.test(obj[key])
|
|
|
|
}
|
|
|
|
: obj[key]
|
2019-10-01 19:04:58 +00:00
|
|
|
}))
|
|
|
|
}
|
|
|
|
}
|
2019-10-01 19:43:59 +00:00
|
|
|
|
|
|
|
export function createElementWithCodegen(
|
|
|
|
args: CallExpression['arguments']
|
|
|
|
): ElementNode {
|
|
|
|
return {
|
|
|
|
type: NodeTypes.ELEMENT,
|
|
|
|
loc: locStub,
|
|
|
|
ns: Namespaces.HTML,
|
|
|
|
tag: 'div',
|
|
|
|
tagType: ElementTypes.ELEMENT,
|
|
|
|
isSelfClosing: false,
|
|
|
|
props: [],
|
|
|
|
children: [],
|
|
|
|
codegenNode: {
|
|
|
|
type: NodeTypes.JS_CALL_EXPRESSION,
|
|
|
|
loc: locStub,
|
|
|
|
callee: CREATE_VNODE,
|
|
|
|
arguments: args
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|