|
|
@ -895,9 +895,8 @@ export default class Element extends Node {
|
|
|
|
snippet = expression.snippet;
|
|
|
|
snippet = expression.snippet;
|
|
|
|
dependencies = expression.dependencies;
|
|
|
|
dependencies = expression.dependencies;
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
const varName = camelCase(name);
|
|
|
|
snippet = `ctx${propertize(name)}`;
|
|
|
|
snippet = `ctx.${varName}`;
|
|
|
|
dependencies = [name];
|
|
|
|
dependencies = [varName];
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
const updater = `@toggleClass(${this.var}, "${name}", ${snippet});`;
|
|
|
|
const updater = `@toggleClass(${this.var}, "${name}", ${snippet});`;
|
|
|
|
|
|
|
|
|
|
|
@ -905,7 +904,7 @@ export default class Element extends Node {
|
|
|
|
|
|
|
|
|
|
|
|
if ((dependencies && dependencies.size > 0) || this.classDependencies.length) {
|
|
|
|
if ((dependencies && dependencies.size > 0) || this.classDependencies.length) {
|
|
|
|
const allDeps = this.classDependencies.concat(...dependencies);
|
|
|
|
const allDeps = this.classDependencies.concat(...dependencies);
|
|
|
|
const deps = allDeps.map(dependency => `changed.${dependency}`).join(' || ');
|
|
|
|
const deps = allDeps.map(dependency => `changed${propertize(dependency)}`).join(' || ');
|
|
|
|
const condition = allDeps.length > 1 ? `(${deps})` : deps;
|
|
|
|
const condition = allDeps.length > 1 ? `(${deps})` : deps;
|
|
|
|
|
|
|
|
|
|
|
|
block.builders.update.addConditional(
|
|
|
|
block.builders.update.addConditional(
|
|
|
@ -988,7 +987,7 @@ export default class Element extends Node {
|
|
|
|
|
|
|
|
|
|
|
|
const classExpr = this.classes.map((classDir: Class) => {
|
|
|
|
const classExpr = this.classes.map((classDir: Class) => {
|
|
|
|
const { expression, name } = classDir;
|
|
|
|
const { expression, name } = classDir;
|
|
|
|
const snippet = expression ? expression.snippet : `ctx.${camelCase(name)}`;
|
|
|
|
const snippet = expression ? expression.snippet : `ctx${propertize(name)}`;
|
|
|
|
return `${snippet} ? "${name}" : ""`;
|
|
|
|
return `${snippet} ? "${name}" : ""`;
|
|
|
|
}).join(', ');
|
|
|
|
}).join(', ');
|
|
|
|
|
|
|
|
|
|
|
@ -1170,8 +1169,6 @@ const events = [
|
|
|
|
}
|
|
|
|
}
|
|
|
|
];
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
|
|
function camelCase(str) {
|
|
|
|
function propertize(prop) {
|
|
|
|
return str.replace(/(-\w)/g, function (m) {
|
|
|
|
return /^[a-zA-Z_$][0-9a-zA-Z_$]*$/.test(prop) ? `.${prop}` : `["${prop}"]`;
|
|
|
|
return m[1].toUpperCase();
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|