From 3567a75e331df0cde39650de834eb4822266bde5 Mon Sep 17 00:00:00 2001 From: nathan Date: Thu, 23 Jun 2022 11:00:47 -0600 Subject: [PATCH] Et2Widget: I figured out how to bind external listeners defined as template attributes directly on load. Not sure we want to turn it on yet though. --- api/js/etemplate/Et2Widget/Et2Widget.ts | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/api/js/etemplate/Et2Widget/Et2Widget.ts b/api/js/etemplate/Et2Widget/Et2Widget.ts index 1dd1703ee6..f8a4b6ad31 100644 --- a/api/js/etemplate/Et2Widget/Et2Widget.ts +++ b/api/js/etemplate/Et2Widget/Et2Widget.ts @@ -1405,13 +1405,15 @@ function transformAttributes(widget, mgr : et2_arrayMgr, attributes) break; } - // TODO: Figure out how to bind handlers directly, since we can do that now - /* (handlers can only be bound _after_ the widget is added to the DOM + // Bind handlers directly, since we can do that now. Event handlers still need to be defined + // in properties() as {type: Function}, but this will take care of the binding. This is + // separate from internal events. + // (handlers can only be bound _after_ the widget is added to the DOM if(attribute.startsWith("on") && typeof attrValue == "function") { - widget.addEventListener(attribute, attrValue); + //widget.updateComplete.then(() => addEventListener(attribute, attrValue)); } - */ + // Set as attribute or property, as appropriate. Don't set missing attributes. if(widget.getAttributeNames().indexOf(attribute) >= 0 || property.reflect && attrValue) {