|
|
|
|
@@ -1,8 +1,15 @@
|
|
|
|
|
class_name LuaEventUtils
|
|
|
|
|
extends RefCounted
|
|
|
|
|
|
|
|
|
|
static func is_date_button(node: Node) -> bool:
|
|
|
|
|
if node is DateButton:
|
|
|
|
|
return true
|
|
|
|
|
|
|
|
|
|
return node.has_method("init_with_date") and node.has_method("parse_date_string")
|
|
|
|
|
|
|
|
|
|
static func connect_element_event(signal_node: Node, event_name: String, subscription) -> bool:
|
|
|
|
|
if not signal_node:
|
|
|
|
|
print("ERROR: Signal node is null for event: ", event_name)
|
|
|
|
|
return false
|
|
|
|
|
|
|
|
|
|
match event_name:
|
|
|
|
|
@@ -70,6 +77,95 @@ static func connect_element_event(signal_node: Node, event_name: String, subscri
|
|
|
|
|
subscription.connected_signal = "focus_exited"
|
|
|
|
|
subscription.connected_node = signal_node
|
|
|
|
|
return true
|
|
|
|
|
"change":
|
|
|
|
|
# Check for DateButton first before generic button signals
|
|
|
|
|
if is_date_button(signal_node):
|
|
|
|
|
if signal_node.has_signal("date_selected"):
|
|
|
|
|
signal_node.date_selected.connect(subscription.lua_api._on_date_selected_text.bind(subscription))
|
|
|
|
|
subscription.connected_signal = "date_selected"
|
|
|
|
|
subscription.connected_node = signal_node
|
|
|
|
|
return true
|
|
|
|
|
else:
|
|
|
|
|
# Try to initialize if it has the init method
|
|
|
|
|
if signal_node.has_method("init"):
|
|
|
|
|
signal_node.init()
|
|
|
|
|
if signal_node.has_signal("date_selected"):
|
|
|
|
|
signal_node.date_selected.connect(subscription.lua_api._on_date_selected_text.bind(subscription))
|
|
|
|
|
subscription.connected_signal = "date_selected"
|
|
|
|
|
subscription.connected_node = signal_node
|
|
|
|
|
return true
|
|
|
|
|
return false
|
|
|
|
|
elif signal_node.has_signal("item_selected"):
|
|
|
|
|
signal_node.item_selected.connect(subscription.lua_api._on_input_item_selected.bind(subscription))
|
|
|
|
|
subscription.connected_signal = "item_selected"
|
|
|
|
|
subscription.connected_node = signal_node
|
|
|
|
|
return true
|
|
|
|
|
elif signal_node.has_signal("focus_exited") and (signal_node is LineEdit or signal_node is TextEdit):
|
|
|
|
|
# For text inputs and textareas, change event fires only on focus lost
|
|
|
|
|
signal_node.focus_exited.connect(subscription.lua_api._on_input_focus_lost.bind(subscription))
|
|
|
|
|
subscription.connected_signal = "focus_exited_change"
|
|
|
|
|
subscription.connected_node = signal_node
|
|
|
|
|
return true
|
|
|
|
|
elif signal_node.has_signal("value_changed"):
|
|
|
|
|
signal_node.value_changed.connect(subscription.lua_api._on_input_value_changed.bind(subscription))
|
|
|
|
|
subscription.connected_signal = "value_changed"
|
|
|
|
|
subscription.connected_node = signal_node
|
|
|
|
|
return true
|
|
|
|
|
elif signal_node.has_signal("color_changed"):
|
|
|
|
|
signal_node.color_changed.connect(subscription.lua_api._on_input_color_changed.bind(subscription))
|
|
|
|
|
subscription.connected_signal = "color_changed"
|
|
|
|
|
subscription.connected_node = signal_node
|
|
|
|
|
return true
|
|
|
|
|
elif signal_node.has_signal("toggled"):
|
|
|
|
|
signal_node.toggled.connect(subscription.lua_api._on_input_toggled.bind(subscription))
|
|
|
|
|
subscription.connected_signal = "toggled"
|
|
|
|
|
subscription.connected_node = signal_node
|
|
|
|
|
return true
|
|
|
|
|
elif signal_node.has_signal("file_selected"):
|
|
|
|
|
signal_node.file_selected.connect(subscription.lua_api._on_file_selected.bind(subscription))
|
|
|
|
|
subscription.connected_signal = "file_selected"
|
|
|
|
|
subscription.connected_node = signal_node
|
|
|
|
|
return true
|
|
|
|
|
elif signal_node.has_signal("pressed"):
|
|
|
|
|
signal_node.pressed.connect(subscription.lua_api._on_event_triggered.bind(subscription))
|
|
|
|
|
subscription.connected_signal = "pressed"
|
|
|
|
|
subscription.connected_node = signal_node
|
|
|
|
|
return true
|
|
|
|
|
else:
|
|
|
|
|
return false
|
|
|
|
|
"input":
|
|
|
|
|
# Input event fires on every keystroke for text inputs and textareas
|
|
|
|
|
if signal_node.has_signal("text_changed"):
|
|
|
|
|
# Handle different signal signatures: LineEdit passes text, TextEdit doesn't
|
|
|
|
|
var callback: Callable
|
|
|
|
|
if signal_node is LineEdit:
|
|
|
|
|
# LineEdit passes the new text as argument
|
|
|
|
|
callback = func(text: String): subscription.lua_api._on_input_text_changed(text, subscription)
|
|
|
|
|
else:
|
|
|
|
|
# TextEdit doesn't pass arguments, get text manually
|
|
|
|
|
callback = func(): subscription.lua_api._on_input_text_changed(signal_node.text, subscription)
|
|
|
|
|
|
|
|
|
|
signal_node.text_changed.connect(callback)
|
|
|
|
|
subscription.connected_signal = "text_changed"
|
|
|
|
|
subscription.connected_node = signal_node
|
|
|
|
|
subscription.callback_func = callback # Store for later disconnect
|
|
|
|
|
return true
|
|
|
|
|
else:
|
|
|
|
|
print("ERROR: No text_changed signal found for input event on ", signal_node.get_class())
|
|
|
|
|
return false
|
|
|
|
|
"submit":
|
|
|
|
|
# For form elements - look for a submit button or form container
|
|
|
|
|
if signal_node.has_signal("pressed"):
|
|
|
|
|
signal_node.pressed.connect(subscription.lua_api._on_form_submit.bind(subscription))
|
|
|
|
|
subscription.connected_signal = "form_submit"
|
|
|
|
|
subscription.connected_node = signal_node
|
|
|
|
|
return true
|
|
|
|
|
elif signal_node.has_signal("text_submitted"):
|
|
|
|
|
# LineEdit Enter key support
|
|
|
|
|
signal_node.text_submitted.connect(subscription.lua_api._on_text_submit.bind(subscription))
|
|
|
|
|
subscription.connected_signal = "text_submitted"
|
|
|
|
|
subscription.connected_node = signal_node
|
|
|
|
|
return true
|
|
|
|
|
|
|
|
|
|
return false
|
|
|
|
|
|
|
|
|
|
@@ -151,6 +247,41 @@ static func disconnect_subscription(subscription, lua_api) -> void:
|
|
|
|
|
"focus_exited":
|
|
|
|
|
if target_node.has_signal("focus_exited"):
|
|
|
|
|
target_node.focus_exited.disconnect(lua_api._on_event_triggered.bind(subscription))
|
|
|
|
|
"text_changed":
|
|
|
|
|
if target_node.has_signal("text_changed"):
|
|
|
|
|
# Use the stored callback function for proper disconnect
|
|
|
|
|
if subscription.callback_func:
|
|
|
|
|
target_node.text_changed.disconnect(subscription.callback_func)
|
|
|
|
|
else:
|
|
|
|
|
# Fallback for old connections
|
|
|
|
|
target_node.text_changed.disconnect(lua_api._on_input_text_changed.bind(subscription))
|
|
|
|
|
"focus_exited_change":
|
|
|
|
|
if target_node.has_signal("focus_exited"):
|
|
|
|
|
target_node.focus_exited.disconnect(lua_api._on_input_focus_lost.bind(subscription))
|
|
|
|
|
"value_changed":
|
|
|
|
|
if target_node.has_signal("value_changed"):
|
|
|
|
|
target_node.value_changed.disconnect(lua_api._on_input_value_changed.bind(subscription))
|
|
|
|
|
"color_changed":
|
|
|
|
|
if target_node.has_signal("color_changed"):
|
|
|
|
|
target_node.color_changed.disconnect(lua_api._on_input_color_changed.bind(subscription))
|
|
|
|
|
"toggled":
|
|
|
|
|
if target_node.has_signal("toggled"):
|
|
|
|
|
target_node.toggled.disconnect(lua_api._on_input_toggled.bind(subscription))
|
|
|
|
|
"item_selected":
|
|
|
|
|
if target_node.has_signal("item_selected"):
|
|
|
|
|
target_node.item_selected.disconnect(lua_api._on_input_item_selected.bind(subscription))
|
|
|
|
|
"file_selected":
|
|
|
|
|
if target_node.has_signal("file_selected"):
|
|
|
|
|
target_node.file_selected.disconnect(lua_api._on_file_selected.bind(subscription))
|
|
|
|
|
"date_selected":
|
|
|
|
|
if target_node.has_signal("date_selected"):
|
|
|
|
|
target_node.date_selected.disconnect(lua_api._on_date_selected_text.bind(subscription))
|
|
|
|
|
"form_submit":
|
|
|
|
|
if target_node.has_signal("pressed"):
|
|
|
|
|
target_node.pressed.disconnect(lua_api._on_form_submit.bind(subscription))
|
|
|
|
|
"text_submitted":
|
|
|
|
|
if target_node.has_signal("text_submitted"):
|
|
|
|
|
target_node.text_submitted.disconnect(lua_api._on_text_submit.bind(subscription))
|
|
|
|
|
"input":
|
|
|
|
|
# Only disable input processing if no other input subscriptions remain
|
|
|
|
|
if _count_active_input_subscriptions(lua_api) <= 1:
|
|
|
|
|
|