aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llimview.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llimview.cpp')
-rw-r--r--linden/indra/newview/llimview.cpp55
1 files changed, 42 insertions, 13 deletions
diff --git a/linden/indra/newview/llimview.cpp b/linden/indra/newview/llimview.cpp
index e451388..797c2a4 100644
--- a/linden/indra/newview/llimview.cpp
+++ b/linden/indra/newview/llimview.cpp
@@ -83,6 +83,7 @@ LLIMMgr* gIMMgr = NULL;
83// *FIXME: make these all either UIStrings or Strings 83// *FIXME: make these all either UIStrings or Strings
84static LLString sOnlyUserMessage; 84static LLString sOnlyUserMessage;
85static LLUIString sOfflineMessage; 85static LLUIString sOfflineMessage;
86static LLString sMutedMessage;
86static LLUIString sInviteMessage; 87static LLUIString sInviteMessage;
87 88
88std::map<std::string,LLString> LLFloaterIM::sEventStringsMap; 89std::map<std::string,LLString> LLFloaterIM::sEventStringsMap;
@@ -161,6 +162,7 @@ BOOL LLFloaterIM::postBuild()
161 sOfflineMessage = getUIString("offline_message"); 162 sOfflineMessage = getUIString("offline_message");
162 163
163 sInviteMessage = getUIString("invite_message"); 164 sInviteMessage = getUIString("invite_message");
165 sMutedMessage = childGetText("muted_message");
164 166
165 if ( sErrorStringsMap.find("generic") == sErrorStringsMap.end() ) 167 if ( sErrorStringsMap.find("generic") == sErrorStringsMap.end() )
166 { 168 {
@@ -400,10 +402,10 @@ void LLIMMgr::addMessage(
400 EInstantMessage dialog, 402 EInstantMessage dialog,
401 U32 parent_estate_id, 403 U32 parent_estate_id,
402 const LLUUID& region_id, 404 const LLUUID& region_id,
403 const LLVector3& position) 405 const LLVector3& position,
406 bool link_name) // If this is true, then we insert the name and link it to a profile
404{ 407{
405 LLUUID other_participant_id = target_id; 408 LLUUID other_participant_id = target_id;
406 bool is_from_system = target_id.isNull() || !strcmp(from, SYSTEM_FROM);
407 409
408 // don't process muted IMs 410 // don't process muted IMs
409 if (LLMuteList::getInstance()->isMuted( 411 if (LLMuteList::getInstance()->isMuted(
@@ -420,8 +422,6 @@ void LLIMMgr::addMessage(
420 other_participant_id = LLUUID::null; 422 other_participant_id = LLUUID::null;
421 } 423 }
422 424
423
424
425 LLFloaterIMPanel* floater; 425 LLFloaterIMPanel* floater;
426 LLUUID new_session_id = session_id; 426 LLUUID new_session_id = session_id;
427 if (new_session_id.isNull()) 427 if (new_session_id.isNull())
@@ -482,15 +482,17 @@ void LLIMMgr::addMessage(
482 } 482 }
483 483
484 // now add message to floater 484 // now add message to floater
485 if ( is_from_system ) // chat came from system 485 bool is_from_system = target_id.isNull() || !strcmp(from, SYSTEM_FROM);
486 const LLColor4& color = ( is_from_system ?
487 gSavedSettings.getColor4("SystemChatColor") :
488 gSavedSettings.getColor("IMChatColor"));
489 if ( !link_name )
486 { 490 {
487 floater->addHistoryLine( 491 floater->addHistoryLine(msg,color); // No name to prepend, so just add the message normally
488 msg,
489 gSavedSettings.getColor4("SystemChatColor"));
490 } 492 }
491 else 493 else
492 { 494 {
493 floater->addHistoryLine(other_participant_id, msg, gSavedSettings.getColor("IMChatColor")); 495 floater->addHistoryLine(msg, color, true, other_participant_id, from); // Insert linked name to front of message
494 } 496 }
495 497
496 LLFloaterChatterBox* chat_floater = LLFloaterChatterBox::getInstance(LLSD()); 498 LLFloaterChatterBox* chat_floater = LLFloaterChatterBox::getInstance(LLSD());
@@ -615,6 +617,8 @@ LLUUID LLIMMgr::addSession(
615 617
616 noteOfflineUsers(floater, ids); 618 noteOfflineUsers(floater, ids);
617 LLFloaterChatterBox::showInstance(session_id); 619 LLFloaterChatterBox::showInstance(session_id);
620 noteMutedUsers(floater, ids);
621 LLFloaterChatterBox::getInstance(LLSD())->showFloater(floater);
618 } 622 }
619 else 623 else
620 { 624 {
@@ -659,6 +663,7 @@ LLUUID LLIMMgr::addSession(
659 663
660 noteOfflineUsers(floater, ids); 664 noteOfflineUsers(floater, ids);
661 LLFloaterChatterBox::showInstance(session_id); 665 LLFloaterChatterBox::showInstance(session_id);
666 noteMutedUsers(floater, ids);
662 } 667 }
663 else 668 else
664 { 669 {
@@ -1232,6 +1237,31 @@ void LLIMMgr::noteOfflineUsers(
1232 } 1237 }
1233} 1238}
1234 1239
1240void LLIMMgr::noteMutedUsers(LLFloaterIMPanel* floater,
1241 const LLDynamicArray<LLUUID>& ids)
1242{
1243 S32 count = ids.count();
1244 if(count > 0)
1245 {
1246 const LLRelationship* info = NULL;
1247 LLAvatarTracker& at = LLAvatarTracker::instance();
1248 for(S32 i = 0; i < count; ++i)
1249 {
1250 info = at.getBuddyInfo(ids.get(i));
1251 char first[DB_FIRST_NAME_BUF_SIZE]; /*Flawfinder: ignore*/
1252 char last[DB_LAST_NAME_BUF_SIZE]; /*Flawfinder: ignore*/
1253 if(info && LLMuteList::getInstance() && LLMuteList::getInstance()->isMuted(ids.get(i))
1254 && gCacheName->getName(ids.get(i), first, last))
1255 {
1256 LLUIString muted = sMutedMessage;
1257 muted.setArg("[FIRST]", first);
1258 muted.setArg("[LAST]", last);
1259 floater->addHistoryLine(muted);
1260 }
1261 }
1262 }
1263}
1264
1235void LLIMMgr::processIMTypingStart(const LLIMInfo* im_info) 1265void LLIMMgr::processIMTypingStart(const LLIMInfo* im_info)
1236{ 1266{
1237 processIMTypingCore(im_info, TRUE); 1267 processIMTypingCore(im_info, TRUE);
@@ -1520,8 +1550,7 @@ public:
1520 snprintf( 1550 snprintf(
1521 buffer, 1551 buffer,
1522 sizeof(buffer), 1552 sizeof(buffer),
1523 "%s%s%s%s", 1553 "%s%s%s",
1524 name.c_str(),
1525 separator_string, 1554 separator_string,
1526 saved, 1555 saved,
1527 (message.c_str() + message_offset)); /*Flawfinder: ignore*/ 1556 (message.c_str() + message_offset)); /*Flawfinder: ignore*/
@@ -1540,7 +1569,8 @@ public:
1540 IM_SESSION_INVITE, 1569 IM_SESSION_INVITE,
1541 message_params["parent_estate_id"].asInteger(), 1570 message_params["parent_estate_id"].asInteger(),
1542 message_params["region_id"].asUUID(), 1571 message_params["region_id"].asUUID(),
1543 ll_vector3_from_sd(message_params["position"])); 1572 ll_vector3_from_sd(message_params["position"]),
1573 true);
1544 1574
1545 snprintf( 1575 snprintf(
1546 buffer, 1576 buffer,
@@ -1628,4 +1658,3 @@ LLHTTPRegistration<LLViewerChatterBoxInvitation>
1628 gHTTPRegistrationMessageChatterBoxInvitation( 1658 gHTTPRegistrationMessageChatterBoxInvitation(
1629 "/message/ChatterBoxInvitation"); 1659 "/message/ChatterBoxInvitation");
1630 1660
1631