diff --git a/ClickableWidgets.go b/ClickableWidgets.go index 64215600..9c992db0 100644 --- a/ClickableWidgets.go +++ b/ClickableWidgets.go @@ -507,7 +507,8 @@ type TreeNodeWidget struct { label string flags TreeNodeFlags layout Layout - eventHandler func() + event func() + eventHandler *EventHandler } // TreeNode creates a new tree node widget. @@ -531,10 +532,16 @@ func (t *TreeNodeWidget) Flags(flags TreeNodeFlags) *TreeNodeWidget { return t } -// Event create TreeNode with eventHandler +// Event create TreeNode with event handling function. // You could detect events (e.g. IsItemClicked IsMouseDoubleClicked etc...) and handle them for TreeNode inside eventHandler. -// Deprecated: Use EventHandler instead! +// Deprecated: Use (*TreeNodeWidget).EventHandler instead! func (t *TreeNodeWidget) Event(handler func()) *TreeNodeWidget { + t.event = handler + return t +} + +// EventHandler allows to set *EventHandler instance for the actual TreeNode. +func (t *TreeNodeWidget) EventHandler(handler *EventHandler) *TreeNodeWidget { t.eventHandler = handler return t } @@ -549,8 +556,12 @@ func (t *TreeNodeWidget) Layout(widgets ...Widget) *TreeNodeWidget { func (t *TreeNodeWidget) Build() { open := imgui.TreeNodeExStrV(t.label, imgui.TreeNodeFlags(t.flags)) + if t.event != nil { + t.event() + } + if t.eventHandler != nil { - t.eventHandler() + t.eventHandler.Build() } if open { diff --git a/examples/widgets/widgets.go b/examples/widgets/widgets.go index 2b187e93..67c191db 100644 --- a/examples/widgets/widgets.go +++ b/examples/widgets/widgets.go @@ -179,11 +179,13 @@ func loop() { g.TreeNode("TreeNode with event handler").Layout( g.Selectable("Selectable 1").OnClick(func() { fmt.Println(1) }), g.Selectable("Selectable 2").OnClick(func() { fmt.Println(2) }), - ).Event(func() { - if g.IsItemClicked(g.MouseButtonLeft) { - fmt.Println("Clicked") - } - }), + ).EventHandler(g.Event().OnClick(g.MouseButtonLeft, func() { + fmt.Println("Clicked") + }).OnDClick(g.MouseButtonLeft, func() { + fmt.Println("Double-Clicked") + }).OnClick(g.MouseButtonRight, func() { + fmt.Println("Right-Clicked") + })), ), g.TabItem("TreeTable").Layout( g.TreeTable().