aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llimpanel.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llimpanel.cpp')
-rw-r--r--linden/indra/newview/llimpanel.cpp36
1 files changed, 28 insertions, 8 deletions
diff --git a/linden/indra/newview/llimpanel.cpp b/linden/indra/newview/llimpanel.cpp
index dede746..5a563a4 100644
--- a/linden/indra/newview/llimpanel.cpp
+++ b/linden/indra/newview/llimpanel.cpp
@@ -49,6 +49,7 @@
49#include "llconsole.h" 49#include "llconsole.h"
50#include "llfloater.h" 50#include "llfloater.h"
51#include "llfloatergroupinfo.h" 51#include "llfloatergroupinfo.h"
52#include "llfloaterchatterbox.h"
52#include "llimview.h" 53#include "llimview.h"
53#include "llinventory.h" 54#include "llinventory.h"
54#include "llinventorymodel.h" 55#include "llinventorymodel.h"
@@ -1160,6 +1161,7 @@ void LLFloaterIMPanel::init(const std::string& session_label)
1160 FALSE); 1161 FALSE);
1161 1162
1162 setTitle(mSessionLabel); 1163 setTitle(mSessionLabel);
1164
1163 mInputEditor->setMaxTextLength(1023); 1165 mInputEditor->setMaxTextLength(1023);
1164 // enable line history support for instant message bar 1166 // enable line history support for instant message bar
1165 mInputEditor->setEnableLineHistory(TRUE); 1167 mInputEditor->setEnableLineHistory(TRUE);
@@ -1472,7 +1474,21 @@ void LLFloaterIMPanel::addHistoryLine(const std::string &utf8msg, const LLColor4
1472 && hostp 1474 && hostp
1473 && source != gAgent.getID()) 1475 && source != gAgent.getID())
1474 { 1476 {
1475 hostp->setFloaterFlashing(this, TRUE); 1477 // Only start flashing on first update so we can
1478 // get the proper unread number of unread tabs here
1479 if (!hostp->isFloaterFlashing(this))
1480 {
1481 hostp->setFloaterFlashing(this, TRUE);
1482 LLFloaterChatterBox::markAsUnread(true);
1483 }
1484
1485 //// Only increment the number of unread IMs if they're from individuals
1486 //// We increment the first received for the rest during new IM creation.
1487 //if (mDialog == IM_SESSION_P2P_INVITE ||
1488 // mDialog == IM_NOTHING_SPECIAL)
1489 //{
1490 // LLFloaterChatterBox::markAsUnread(true);
1491 //}
1476 } 1492 }
1477 } 1493 }
1478 1494
@@ -1540,13 +1556,17 @@ void LLFloaterIMPanel::setVisible(BOOL b)
1540 LLMultiFloater* hostp = getHost(); 1556 LLMultiFloater* hostp = getHost();
1541 if( b && hostp ) 1557 if( b && hostp )
1542 { 1558 {
1543 hostp->setFloaterFlashing(this, FALSE); 1559 if (hostp->isFloaterFlashing(this))
1544 1560 {
1545 /* Don't change containing floater title - leave it "Instant Message" JC 1561 hostp->setFloaterFlashing(this, FALSE);
1546 LLUIString title = sTitleString; 1562 LLFloaterChatterBox::markAsUnread(false);
1547 title.setArg("[NAME]", mSessionLabel); 1563
1548 hostp->setTitle( title ); 1564 /* Don't change containing floater title - leave it "Instant Message" JC
1549 */ 1565 LLUIString title = sTitleString;
1566 title.setArg("[NAME]", mSessionLabel);
1567 hostp->setTitle( title );
1568 */
1569 }
1550 } 1570 }
1551} 1571}
1552 1572