Skip to content
Snippets Groups Projects
Commit 85f69fbd authored by Tofu Linden's avatar Tofu Linden
Browse files

merge storm-159

parents b92ca367 98e6d56b
No related branches found
No related tags found
No related merge requests found
...@@ -1445,6 +1445,43 @@ static void give_inventory_cb(const LLSD& notification, const LLSD& response) ...@@ -1445,6 +1445,43 @@ static void give_inventory_cb(const LLSD& notification, const LLSD& response)
} }
} }
static void show_item_sharing_confirmation(const std::string name,
LLViewerInventoryItem* inv_item,
const LLSD& dest,
const LLUUID& dest_agent,
const LLUUID& session_id = LLUUID::null)
{
if (!inv_item)
{
llassert(NULL != inv_item);
return;
}
LLSD substitutions;
substitutions["RESIDENTS"] = name;
substitutions["ITEMS"] = inv_item ? inv_item->getName() : LLStringUtil::null;
LLSD payload;
payload["agent_id"] = dest_agent;
payload["item_id"] = inv_item->getUUID();
payload["session_id"] = session_id;
payload["d&d_dest"] = dest.asString();
LLNotificationsUtil::add("ShareItemsConfirmation", substitutions, payload, &give_inventory_cb);
}
static void get_name_cb(const LLUUID& id,
const std::string& first_name,
const std::string& last_name,
LLViewerInventoryItem* inv_item,
const LLSD& dest,
const LLUUID& dest_agent)
{
show_item_sharing_confirmation(first_name + " " + last_name,
inv_item,
dest,
id,
LLUUID::null);
}
// function used as drag-and-drop handler for simple agent give inventory requests // function used as drag-and-drop handler for simple agent give inventory requests
//static //static
bool LLToolDragAndDrop::handleGiveDragAndDrop(LLUUID dest_agent, LLUUID session_id, BOOL drop, bool LLToolDragAndDrop::handleGiveDragAndDrop(LLUUID dest_agent, LLUUID session_id, BOOL drop,
...@@ -1477,20 +1514,28 @@ bool LLToolDragAndDrop::handleGiveDragAndDrop(LLUUID dest_agent, LLUUID session_ ...@@ -1477,20 +1514,28 @@ bool LLToolDragAndDrop::handleGiveDragAndDrop(LLUUID dest_agent, LLUUID session_
if (drop) if (drop)
{ {
LLIMModel::LLIMSession * session = LLIMModel::instance().findIMSession(session_id); LLIMModel::LLIMSession * session = LLIMModel::instance().findIMSession(session_id);
// If no IM session found get the destination agent's name by id.
if (NULL == session) if (NULL == session)
{ {
llassert(NULL != session); std::string fullname;
return false;
// If destination agent's name is found in cash proceed to showing the confirmation dialog.
// Otherwise set up a callback to show the dialog when the name arrives.
if (gCacheName->getFullName(dest_agent, fullname))
{
show_item_sharing_confirmation(fullname, inv_item, dest, dest_agent, LLUUID::null);
}
else
{
gCacheName->get(dest_agent, FALSE, boost::bind(&get_name_cb, _1, _2, _3, inv_item, dest, dest_agent));
}
return true;
} }
LLSD substitutions;
substitutions["RESIDENTS"] = session->mName; // If an IM session with destination agent is found item offer will be logged in this session.
substitutions["ITEMS"] = inv_item->getName(); show_item_sharing_confirmation(session->mName, inv_item, dest, dest_agent, session_id);
LLSD payload;
payload["agent_id"] = dest_agent;
payload["item_id"] = inv_item->getUUID();
payload["session_id"] = session_id;
payload["d&d_dest"] = dest.asString();
LLNotificationsUtil::add("ShareItemsConfirmation", substitutions, payload, &give_inventory_cb);
} }
} }
else else
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment