-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathevent-properties.js
63 lines (60 loc) · 1.74 KB
/
event-properties.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
const eventProperties = require('../event-properties');
const { parse, transform } = require('ember-template-recast');
function codeshift(input, plugin) {
return plugin(
{
path: 'filename.hbs',
source: input,
},
{
parse,
visit(ast, callback) {
const results = transform(ast, callback);
return results && results.code;
},
}
);
}
const TESTS = [
[
'onclick={{action "foo"}}',
`<button onclick={{action "foo"}}>button</button>`,
`<button {{on "click" (action "foo")}}>button</button>`
],
[
'onmousedown={{foo}}',
`<button onmousedown={{foo}}>button</button>`,
`<button {{on "mousedown" foo}}>button</button>`
],
[
'onclick={{action foo bar}}',
`<button onclick={{action foo bar}}>button</button>`,
`<button {{on "click" (fn foo bar)}}>button</button>`
],
[
'value="target.value"',
`<button onclick={{action foo value="target.value"}}>button</button>`,
`<button {{on "click" (action foo value="target.value")}}>button</button>`
],
[
'target=something',
`<button onclick={{action foo target=something}}>button</button>`,
`<button {{on "click" (action foo target=something)}}>button</button>`
],
[
'not an action',
`<button onclick={{or foo bar}}>button</button>`,
`<button {{on "click" (or foo bar)}}>button</button>`
],
[
'nested actions',
`<button onclick={{or (action "foo") (action this.bar baz)}}>button</button>`,
`<button {{on "click" (or (action "foo") (fn this.bar baz))}}>button</button>`
]
];
TESTS.forEach(([name, input, expectedOutput]) => {
it(name, () => {
const output = codeshift(input, eventProperties);
expect((output || '').trim()).toEqual(expectedOutput.trim());
});
});