support $method(...) calls, and warn on store.method(...)

pull/1348/head
Rich Harris 7 years ago
parent 6ff02b263e
commit aaab6853ce

@ -93,6 +93,7 @@ export default class Generator {
helpers: Set<string>; helpers: Set<string>;
components: Set<string>; components: Set<string>;
events: Set<string>; events: Set<string>;
methods: Set<string>;
transitions: Set<string>; transitions: Set<string>;
actions: Set<string>; actions: Set<string>;
importedComponents: Map<string, string>; importedComponents: Map<string, string>;
@ -141,6 +142,7 @@ export default class Generator {
this.helpers = new Set(); this.helpers = new Set();
this.components = new Set(); this.components = new Set();
this.events = new Set(); this.events = new Set();
this.methods = new Set();
this.transitions = new Set(); this.transitions = new Set();
this.actions = new Set(); this.actions = new Set();
this.importedComponents = new Map(); this.importedComponents = new Map();
@ -419,6 +421,7 @@ export default class Generator {
code, code,
source, source,
computations, computations,
methods,
templateProperties, templateProperties,
imports imports
} = this; } = this;
@ -608,6 +611,10 @@ export default class Generator {
if (templateProperties.methods && dom) { if (templateProperties.methods && dom) {
addDeclaration('methods', templateProperties.methods.value); addDeclaration('methods', templateProperties.methods.value);
templateProperties.methods.value.properties.forEach(prop => {
this.methods.add(prop.key.name);
});
} }
if (templateProperties.namespace) { if (templateProperties.namespace) {

@ -519,10 +519,19 @@ export default class Element extends Node {
if (!validCalleeObjects.has(flattened.name)) { if (!validCalleeObjects.has(flattened.name)) {
// allow event.stopPropagation(), this.select() etc // allow event.stopPropagation(), this.select() etc
// TODO verify that it's a valid callee (i.e. built-in or declared method) // TODO verify that it's a valid callee (i.e. built-in or declared method)
generator.code.prependRight( if (flattened.name[0] === '$' && !generator.methods.has(flattened.name)) {
attribute.expression.start, generator.code.overwrite(
`${block.alias('component')}.` attribute.expression.start,
); attribute.expression.start + 1,
`${block.alias('component')}.store.`
);
} else {
generator.code.prependRight(
attribute.expression.start,
`${block.alias('component')}.`
);
}
if (shouldHoist) eventHandlerUsesComponent = true; // this feels a bit hacky but it works! if (shouldHoist) eventHandlerUsesComponent = true; // this feels a bit hacky but it works!
} }

@ -24,7 +24,7 @@ export default function validateEventHandlerCallee(
const { name } = flattenReference(callee); const { name } = flattenReference(callee);
if (validCalleeObjects.has(name) || name === 'options' || name === 'store') return; if (validCalleeObjects.has(name) || name === 'options') return;
if (name === 'refs') { if (name === 'refs') {
refCallees.push(callee); refCallees.push(callee);
@ -34,21 +34,30 @@ export default function validateEventHandlerCallee(
if ( if (
(callee.type === 'Identifier' && validBuiltins.has(callee.name)) || (callee.type === 'Identifier' && validBuiltins.has(callee.name)) ||
validator.methods.has(callee.name) validator.methods.has(callee.name)
) ) {
return; return;
}
const validCallees = ['this.*', 'event.*', 'options.*', 'console.*', 'store.*'].concat( if (name[0] === '$') {
// assume it's a store method
return;
}
const validCallees = ['this.*', 'event.*', 'options.*', 'console.*'].concat(
Array.from(validBuiltins), Array.from(validBuiltins),
Array.from(validator.methods.keys()) Array.from(validator.methods.keys())
); );
let message = `'${validator.source.slice( let message = `'${validator.source.slice(callee.start, callee.end)}' is an invalid callee ` ;
callee.start,
callee.end if (name === 'store') {
)}' is an invalid callee (should be one of ${list(validCallees)})`; message += `(did you mean '$${validator.source.slice(callee.start + 6, callee.end)}(...)'?)`;
} else {
message += `(should be one of ${list(validCallees)})`;
if (callee.type === 'Identifier' && validator.helpers.has(callee.name)) { if (callee.type === 'Identifier' && validator.helpers.has(callee.name)) {
message += `. '${callee.name}' exists on 'helpers', did you put it in the wrong place?`; message += `. '${callee.name}' exists on 'helpers', did you put it in the wrong place?`;
}
} }
validator.warn(attribute.expression, { validator.warn(attribute.expression, {

@ -1 +1 @@
<input on:input='store.setName(this.value)'> <input on:input='$setName(this.value)'>

@ -1,6 +1,6 @@
[{ [{
"code": "invalid-callee", "code": "invalid-callee",
"message": "'foo' is an invalid callee (should be one of this.*, event.*, options.*, console.*, store.*, set, fire, destroy or bar). 'foo' exists on 'helpers', did you put it in the wrong place?", "message": "'foo' is an invalid callee (should be one of this.*, event.*, options.*, console.*, set, fire, destroy or bar). 'foo' exists on 'helpers', did you put it in the wrong place?",
"pos": 18, "pos": 18,
"start": { "start": {
"line": 1, "line": 1,

@ -1,6 +1,6 @@
[{ [{
"code": "invalid-callee", "code": "invalid-callee",
"message": "'foo' is an invalid callee (should be one of this.*, event.*, options.*, console.*, store.*, set, fire, destroy or bar)", "message": "'foo' is an invalid callee (should be one of this.*, event.*, options.*, console.*, set, fire, destroy or bar)",
"pos": 18, "pos": 18,
"start": { "start": {
"line": 1, "line": 1,

@ -0,0 +1 @@
<button on:click="store.set({ foo: 'bar' })">click me</button>

@ -0,0 +1,15 @@
[{
"code": "invalid-callee",
"message": "'store.set' is an invalid callee (did you mean '$set(...)'?)",
"pos": 18,
"start": {
"line": 1,
"column": 18,
"character": 18
},
"end": {
"line": 1,
"column": 43,
"character": 43
}
}]

@ -1,6 +1,6 @@
[{ [{
"code": "invalid-callee", "code": "invalid-callee",
"message": "'resize' is an invalid callee (should be one of this.*, event.*, options.*, console.*, store.*, set, fire or destroy)", "message": "'resize' is an invalid callee (should be one of this.*, event.*, options.*, console.*, set, fire or destroy)",
"start": { "start": {
"line": 1, "line": 1,
"column": 26, "column": 26,

Loading…
Cancel
Save