summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMnikolenko Productengine <mnikolenko@productengine.com>2024-03-18 15:13:25 +0200
committerMnikolenko Productengine <mnikolenko@productengine.com>2024-03-18 15:13:25 +0200
commit052fdac5187cc529bbbe9be0c8d0f27516058ebd (patch)
treec87c0b29132a625757f57208f9cf58489bd91659
parent5a6ec3e26ad9a6fb33e18a3d0198482c0685a4fa (diff)
update to use new lua leap; initial support for scroll list
-rw-r--r--indra/llui/llfloaterreglistener.cpp21
-rw-r--r--indra/llui/llfloaterreglistener.h1
-rw-r--r--indra/llui/llluafloater.cpp70
-rw-r--r--indra/llui/llluafloater.h3
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;