void LLIMFloater::onClickCloseBtn() { LLIMModel::LLIMSession* session = LLIMModel::instance().findIMSession( mSessionID); if (session == NULL) { llwarns << "Empty session." << llendl; return; } bool is_call_with_chat = session->isGroupSessionType() || session->isAdHocSessionType() || session->isP2PSessionType(); LLVoiceChannel* voice_channel = LLIMModel::getInstance()->getVoiceChannel(mSessionID); if (is_call_with_chat && voice_channel != NULL && voice_channel->isActive()) { LLSD payload; payload["session_id"] = mSessionID; LLNotificationsUtil::add("ConfirmLeaveCall", LLSD(), payload, confirmLeaveCallCallback); return; } LLFloater::onClickCloseBtn(); }
//-------------------------------------------------------------------------- bool LLIMHandler::processNotification(const LLSD& notify) { if(mChannel.isDead()) { return false; } LLNotificationPtr notification = LLNotifications::instance().find(notify["id"].asUUID()); if(!notification) return false; static LLCachedControl<bool> fsUseNearbyChatConsole(gSavedSettings, "FSUseNearbyChatConsole"); if (FSLogImToChatConsole && fsUseNearbyChatConsole) { if(notify["sigtype"].asString() == "add" || notify["sigtype"].asString() == "change") { LLSD substitutions = notification->getSubstitutions(); // FS:LO FIRE-5230 - Chat Console Improvement: Replacing the "IM" in front of group chat messages with the actual group name std::string group; LLIMModel::LLIMSession* session = LLIMModel::getInstance()->findIMSession(substitutions["SESSION_ID"]); if(session) { S32 groupNameLength = gSavedSettings.getS32("FSShowGroupNameLength"); if(groupNameLength != 0 && session->isGroupSessionType()) { group = session->mName.substr(0,groupNameLength); } } // FS:LO FIRE-5230 - Chat Console Improvement: Replacing the "IM" in front of group chat messages with the actual group name // Filter notifications with empty ID and empty message if (substitutions["FROM_ID"].asString() == "" && substitutions["MESSAGE"].asString() == "") return false; // Ansarial, replace long lock of local DN handling with the following call //LLAvatarNameCache::get(LLUUID(substitutions["FROM_ID"].asString()), boost::bind(&LLIMHandler::onAvatarNameLookup, this, _1, _2, substitutions["MESSAGE"].asString())); LLAvatarNameCache::get(LLUUID(substitutions["FROM_ID"].asString()), boost::bind(&LLIMHandler::onAvatarNameLookup, this, _1, _2, substitutions["MESSAGE"].asString(),group)); // FS:LO FIRE-5230 - Chat Console Improvement: Replacing the "IM" in front of group chat messages with the actual group name } } else { // arrange a channel on a screen if(!mChannel.get()->getVisible()) { initChannel(); } if(notify["sigtype"].asString() == "add" || notify["sigtype"].asString() == "change") { LLSD substitutions = notification->getSubstitutions(); // According to comments in LLIMMgr::addMessage(), if we get message // from ourselves, the sender id is set to null. This fixes EXT-875. LLUUID avatar_id = substitutions["FROM_ID"].asUUID(); if (avatar_id.isNull()) avatar_id = gAgentID; LLToastIMPanel::Params im_p; im_p.notification = notification; im_p.avatar_id = avatar_id; im_p.from = substitutions["FROM"].asString(); im_p.time = substitutions["TIME"].asString(); im_p.message = substitutions["MESSAGE"].asString(); im_p.session_id = substitutions["SESSION_ID"].asUUID(); LLToastIMPanel* im_box = new LLToastIMPanel(im_p); LLToast::Params p; p.notif_id = notification->getID(); p.session_id = im_p.session_id; p.notification = notification; p.panel = im_box; p.can_be_stored = false; p.on_delete_toast = boost::bind(&LLIMHandler::onDeleteToast, this, _1); LLScreenChannel* channel = dynamic_cast<LLScreenChannel*>(mChannel.get()); if(channel) channel->addToast(p); // send a signal to the counter manager; mNewNotificationSignal(); } else if (notify["sigtype"].asString() == "delete") { mChannel.get()->killToastByNotificationID(notification->getID()); } } return false; }