support bindings for className object
This commit is contained in:
parent
f9038e2af9
commit
0a6c50b3bb
1 changed files with 21 additions and 9 deletions
|
@ -1,5 +1,18 @@
|
||||||
import { setAttribute, text, TAG_NAMES } from "./html.js";
|
import { setAttribute, text, TAG_NAMES } from "./html.js";
|
||||||
|
|
||||||
|
|
||||||
|
function classNames(obj, value) {
|
||||||
|
return Object.entries(obj).reduce((cn, [name, enabled]) => {
|
||||||
|
if (typeof enabled === "function") {
|
||||||
|
enabled = enabled(value);
|
||||||
|
}
|
||||||
|
if (enabled) {
|
||||||
|
return (cn.length ? " " : "") + name;
|
||||||
|
} else {
|
||||||
|
return cn;
|
||||||
|
}
|
||||||
|
}, "");
|
||||||
|
}
|
||||||
/*
|
/*
|
||||||
supports
|
supports
|
||||||
- event handlers (attribute fn value with name that starts with on)
|
- event handlers (attribute fn value with name that starts with on)
|
||||||
|
@ -20,11 +33,6 @@ export default class Template {
|
||||||
this._attach();
|
this._attach();
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: obj needs to support bindings
|
|
||||||
classes(obj) {
|
|
||||||
Object.entries(obj).filter(([, value]) => value).map(([key]) => key).join(" ");
|
|
||||||
}
|
|
||||||
|
|
||||||
root() {
|
root() {
|
||||||
return this._root;
|
return this._root;
|
||||||
}
|
}
|
||||||
|
@ -98,6 +106,10 @@ export default class Template {
|
||||||
binding();
|
binding();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_addClassNamesBinding(node, obj) {
|
||||||
|
this._addAttributeBinding(node, "className", value => classNames(obj, value));
|
||||||
|
}
|
||||||
|
|
||||||
_addTextBinding(fn) {
|
_addTextBinding(fn) {
|
||||||
const initialValue = fn(this._value);
|
const initialValue = fn(this._value);
|
||||||
const node = text(initialValue);
|
const node = text(initialValue);
|
||||||
|
@ -130,7 +142,10 @@ export default class Template {
|
||||||
if (attributes) {
|
if (attributes) {
|
||||||
for(let [key, value] of Object.entries(attributes)) {
|
for(let [key, value] of Object.entries(attributes)) {
|
||||||
const isFn = typeof value === "function";
|
const isFn = typeof value === "function";
|
||||||
if (key.startsWith("on") && key.length > 2 && isFn) {
|
// binding for className as object of className => enabled
|
||||||
|
if (key === "className" && typeof value === "object" && value !== null) {
|
||||||
|
this._addClassNamesBinding(node, value);
|
||||||
|
} else if (key.startsWith("on") && key.length > 2 && isFn) {
|
||||||
const eventName = key.substr(2, 1).toLowerCase() + key.substr(3);
|
const eventName = key.substr(2, 1).toLowerCase() + key.substr(3);
|
||||||
const handler = value;
|
const handler = value;
|
||||||
this._addEventListener(node, eventName, handler);
|
this._addEventListener(node, eventName, handler);
|
||||||
|
@ -204,6 +219,3 @@ for (const tag of TAG_NAMES) {
|
||||||
return this.el(tag, ... params);
|
return this.el(tag, ... params);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Reference in a new issue