diff options
author | Mnikolenko Productengine <mnikolenko@productengine.com> | 2024-03-18 15:13:25 +0200 |
---|---|---|
committer | Mnikolenko Productengine <mnikolenko@productengine.com> | 2024-03-18 15:13:25 +0200 |
commit | 052fdac5187cc529bbbe9be0c8d0f27516058ebd (patch) | |
tree | c87c0b29132a625757f57208f9cf58489bd91659 | |
parent | 5a6ec3e26ad9a6fb33e18a3d0198482c0685a4fa (diff) |
update to use new lua leap; initial support for scroll list
-rw-r--r-- | indra/llui/llfloaterreglistener.cpp | 21 | ||||
-rw-r--r-- | indra/llui/llfloaterreglistener.h | 1 | ||||
-rw-r--r-- | indra/llui/llluafloater.cpp | 70 | ||||
-rw-r--r-- | indra/llui/llluafloater.h | 3 |
4 files changed, 77 insertions, 18 deletions
diff --git a/indra/llui/llfloaterreglistener.cpp b/indra/llui/llfloaterreglistener.cpp index 6fee688121..bdf26c1db8 100644 --- a/indra/llui/llfloaterreglistener.cpp +++ b/indra/llui/llfloaterreglistener.cpp @@ -76,12 +76,12 @@ LLFloaterRegListener::LLFloaterRegListener(): LLSD requiredParams; requiredParams["xml_path"] = LLSD(); - requiredParams["command_pump"] = LLSD(); - requiredParams["reqid"] = LLSD(); add("showLuaFloater", - "Open the new floater using XML file specified in [\"xml_path\"]" - "with ID in [\"reqid\"], which sends UI events to even pump specified in [\"command_pump\"]", + "Open the new floater using XML file specified in [\"xml_path\"]", &LLFloaterRegListener::showLuaFloater, requiredParams); + add("getFloaterEvents", + "Return the table of Lua Floater events which are send to the script", + &LLFloaterRegListener::getLuaFloaterEvents); } void LLFloaterRegListener::getBuildMap(const LLSD& event) const @@ -169,3 +169,16 @@ void LLFloaterRegListener::showLuaFloater(const LLSD &event) const { LLLuaFloater::showLuaFloater(event); } + +void LLFloaterRegListener::getLuaFloaterEvents(const LLSD &event) const +{ + if (event.has("reply")) + { + LLSD events_data = LLLuaFloater::getEventsData(); + + LLReqID reqID(event); + LLSD reply(reqID.makeResponse()); + LLEventPumps::instance().obtain(event["reply"]).post(reply.with("events", events_data)); + } +} + diff --git a/indra/llui/llfloaterreglistener.h b/indra/llui/llfloaterreglistener.h index 2d58303aa0..cbfb7855b9 100644 --- a/indra/llui/llfloaterreglistener.h +++ b/indra/llui/llfloaterreglistener.h @@ -51,6 +51,7 @@ private: void clickButton(const LLSD& event) const; void showLuaFloater(const LLSD &event) const; + void getLuaFloaterEvents(const LLSD &event) const; }; #endif /* ! defined(LL_LLFLOATERREGLISTENER_H) */ diff --git a/indra/llui/llluafloater.cpp b/indra/llui/llluafloater.cpp index b60a893f12..36dd0d58bd 100644 --- a/indra/llui/llluafloater.cpp +++ b/indra/llui/llluafloater.cpp @@ -31,6 +31,7 @@ #include "llcheckboxctrl.h" #include "llcombobox.h" +#include "llscrolllistctrl.h" const std::string LISTENER_NAME("LLLuaFloater"); @@ -50,9 +51,8 @@ std::map<std::string, std::string> EVENT_LIST = LLLuaFloater::LLLuaFloater(const LLSD &key) : LLFloater(key), - mCommandPumpName(key["command_pump"].asString()), - mDispatcher("LLLuaFloater", "action"), - mReqID(key) + mCommandPumpName(key["reply"].asString()), + mDispatcher("LLLuaFloater", "action") { mListenerPumpName = LLUUID::generateNewID().asString(); @@ -69,9 +69,7 @@ LLLuaFloater::LLLuaFloater(const LLSD &key) : return false; }); - LLSD requiredParams; - requiredParams["ctrl_name"] = LLSD(); - requiredParams["value"] = LLSD(); + LLSD requiredParams = LLSD().with("ctrl_name", LLSD()).with("value", LLSD()); mDispatcher.add("set_enabled", "", [this](const LLSD &event) { LLUICtrl *ctrl = getChild<LLUICtrl>(event["ctrl_name"].asString()); @@ -96,12 +94,39 @@ LLLuaFloater::LLLuaFloater(const LLSD &key) : ctrl->setValue(event["value"]); } }, requiredParams); + mDispatcher.add("add_list_element", "", [this](const LLSD &event) + { + LLScrollListCtrl *ctrl = getChild<LLScrollListCtrl>(event["ctrl_name"].asString()); + if(ctrl) + { + ctrl->addElement(event["value"]); + } + }, requiredParams); requiredParams = LLSD().with("value", LLSD()); mDispatcher.add("set_title", "", [this](const LLSD &event) { setTitle(event["value"].asString()); - }); + }, requiredParams); + + requiredParams = LLSD().with("ctrl_name", LLSD()).with("reqid", LLSD()); + mDispatcher.add("get_value", "", [this](const LLSD &event) + { + LLUICtrl *ctrl = getChild<LLUICtrl>(event["ctrl_name"].asString()); + if(ctrl) + { + LLSD response; + response["value"] = ctrl->getValue(); + response["reqid"] = event["reqid"]; + post(response); + } + }, requiredParams); +} + +LLLuaFloater::~LLLuaFloater() +{ + //post empty LLSD() to indicate done, in case it wasn't handled by the script after CLOSE_EVENT + post(LLSD()); } BOOL LLLuaFloater::postBuild() @@ -199,7 +224,20 @@ void LLLuaFloater::registerCallback(const std::string &ctrl_name, const std::str } else if (event == EVENT_LIST["DOUBLE_CLICK_EVENT"]) { - ctrl->setDoubleClickCallback(mouse_event_coords_cb); + LLScrollListCtrl *list = dynamic_cast<LLScrollListCtrl *>(ctrl); + if (list) + { + list->setDoubleClickCallback( + [this, data, list]() + { + LLSD event(data); + post(event.with("value", list->getCurrentID())); + }); + } + else + { + ctrl->setDoubleClickCallback(mouse_event_coords_cb); + } } else { @@ -209,10 +247,8 @@ void LLLuaFloater::registerCallback(const std::string &ctrl_name, const std::str void LLLuaFloater::post(const LLSD &data) { - //send event data to the script signed with ["reqid"] key - LLSD stamped_data(data); - mReqID.stamp(stamped_data); - LLEventPumps::instance().obtain(mCommandPumpName).post(stamped_data); + //send event data to the script + LLEventPumps::instance().obtain(mCommandPumpName).post(data); } void LLLuaFloater::showLuaFloater(const LLSD &data) @@ -224,4 +260,12 @@ void LLLuaFloater::showLuaFloater(const LLSD &data) floater->openFloater(floater->getKey()); } - +LLSD LLLuaFloater::getEventsData() +{ + LLSD event_data; + for (auto &it : EVENT_LIST) + { + event_data[it.first] = it.second; + } + return event_data; +} diff --git a/indra/llui/llluafloater.h b/indra/llui/llluafloater.h index eec6180bee..0dd39e7d1e 100644 --- a/indra/llui/llluafloater.h +++ b/indra/llui/llluafloater.h @@ -35,15 +35,16 @@ class LLLuaFloater : public LLFloater public: LLLuaFloater(const LLSD &key); BOOL postBuild(); + virtual ~LLLuaFloater(); void registerCallback(const std::string &ctrl_name, const std::string &event); void onClose(bool app_quitting); void post(const LLSD &data); static void showLuaFloater(const LLSD &data); + static LLSD getEventsData(); private: - LLReqID mReqID; LLEventDispatcher mDispatcher; LLTempBoundListener mBoundListener; |