-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
91 lines (80 loc) · 2.33 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
module.exports = {
preCodeGen: function(ast, options) {
ast.nodes = processNodes(ast.nodes)
return ast
}
}
function processNodes(nodes, insideConditional = false)
{
for (let i = 0; i<nodes.length; i++)
{
const node = nodes[i]
if(!/Each|Conditional/.test(node.type))
{
if(node.block)
node.block.nodes = processNodes(node.block.nodes)
if(node.type == 'Code' && node.buffer && node.mustEscape)
{
node.type = 'Text'
node.val = `{{${node.val}}}`
delete node.buffer
delete node.mustEscape
delete node.isInline
}
continue
}
if(node.consequent) // if this node is a conditional
{
const newNodes = [],
consequent = processNodes(node.consequent.nodes),
name = insideConditional? 'v-else-if' : 'v-if',
vueIfAttr = [{ name, val: `"${node.test}"`, mustEscape: false }]
newNodes.push(
processControlNode(consequent, vueIfAttr, `empty ${name}=${node.test}`)
)
if(node.alternate)
{
if(node.alternate.type == 'Block')
{
const alternate = processNodes(node.alternate.nodes),
vueElseAttr = [{ name: 'v-else', val: true, mustEscape: false }]
newNodes.push(
processControlNode(alternate, vueElseAttr, `empty v-else`)
)
}
else
newNodes.push( ...processNodes([node.alternate], true))
}
nodes.splice(i, 1, ...newNodes)
i += newNodes.length-1
}
else // its a loop
{
const loop = (node.key ? `"(${node.val}, ${node.key})` : `"${node.val}` )+ ` in ${node.obj}"`,
vueLoopAttr = [{ name: 'v-for', val: loop, mustEscape: false }]
if(node.key && node.key.toLowerCase() == 'key')
vueLoopAttr.push({name: ':key', val: `"${node.key}"`, mustEscape: false })
const children = processNodes(node.block.nodes)
nodes[i] = processControlNode(children, vueLoopAttr, `empty v-for=${loop}`)
}
}
return nodes
}
function processControlNode(items, vueAttr, emptyStr)
{
if(!items.length)
return {
type: 'Comment', val: emptyStr, buffer: true, line: node.line, column: node.column, filename:node.filename
}
if(
items.length > 1 ||
!items[0].attrs ||
items[0].attrs.find(a => /^v-(for|if|else)/.test(a.name))
)
return {
block: { type: 'Block', nodes: items }, attrs: vueAttr,
type: 'Tag', name: 'template', selfClosing: false, attributeBlocks: [], isInline: false
}
items[0].attrs.push(...vueAttr)
return items[0]
}