From d72a7102b2ee3e59385c8dec00312bfadc44ff8b Mon Sep 17 00:00:00 2001 From: Bruno Windels Date: Sun, 16 Jun 2019 15:12:54 +0200 Subject: [PATCH] only bind className when the obj has at least 1 fn, also support it html --- src/ui/web/general/Template.js | 24 ++++++++++++------------ src/ui/web/general/html.js | 16 ++++++++++++++++ 2 files changed, 28 insertions(+), 12 deletions(-) diff --git a/src/ui/web/general/Template.js b/src/ui/web/general/Template.js index 820c5775..b8c566c2 100644 --- a/src/ui/web/general/Template.js +++ b/src/ui/web/general/Template.js @@ -1,17 +1,13 @@ -import { setAttribute, text, isChildren, TAG_NAMES } from "./html.js"; +import { setAttribute, text, isChildren, classNames, TAG_NAMES } from "./html.js"; -function classNames(obj, value) { - return Object.entries(obj).reduce((cn, [name, enabled]) => { - if (typeof enabled === "function") { - enabled = enabled(value); +function objHasFns(obj) { + for(const value of Object.values(obj)) { + if (typeof value === "function") { + return true; } - if (enabled) { - return (cn.length ? " " : "") + name; - } else { - return cn; - } - }, ""); + } + return false; } /** Bindable template. Renders once, and allows bindings for given nodes. If you need @@ -152,7 +148,11 @@ export default class Template { const isFn = typeof value === "function"; // binding for className as object of className => enabled if (key === "className" && typeof value === "object" && value !== null) { - this._addClassNamesBinding(node, value); + if (objHasFns(value)) { + this._addClassNamesBinding(node, value); + } else { + setAttribute(node, key, classNames(value)); + } } else if (key.startsWith("on") && key.length > 2 && isFn) { const eventName = key.substr(2, 1).toLowerCase() + key.substr(3); const handler = value; diff --git a/src/ui/web/general/html.js b/src/ui/web/general/html.js index a4f816c9..b003b5a1 100644 --- a/src/ui/web/general/html.js +++ b/src/ui/web/general/html.js @@ -5,6 +5,19 @@ export function isChildren(children) { return typeof children !== "object" || !!children.nodeType || Array.isArray(children); } +export function classNames(obj, value) { + return Object.entries(obj).reduce((cn, [name, enabled]) => { + if (typeof enabled === "function") { + enabled = enabled(value); + } + if (enabled) { + return cn + (cn.length ? " " : "") + name; + } else { + return cn; + } + }, ""); +} + export function setAttribute(el, name, value) { if (name === "className") { name = "class"; @@ -29,6 +42,9 @@ export function el(elementName, attributes, children) { if (attributes) { for (let [name, value] of Object.entries(attributes)) { + if (name === "className" && typeof value === "object" && value !== null) { + value = classNames(value); + } setAttribute(e, name, value); } }