aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra')
-rw-r--r--linden/indra/newview/llfloaterchatterbox.cpp54
-rw-r--r--linden/indra/newview/llfloaterchatterbox.h2
-rw-r--r--linden/indra/newview/llimpanel.cpp36
-rw-r--r--linden/indra/newview/skins/default/xui/en-us/floater_chatterbox.xml6
4 files changed, 90 insertions, 8 deletions
diff --git a/linden/indra/newview/llfloaterchatterbox.cpp b/linden/indra/newview/llfloaterchatterbox.cpp
index 036c7c4..53a2cf5 100644
--- a/linden/indra/newview/llfloaterchatterbox.cpp
+++ b/linden/indra/newview/llfloaterchatterbox.cpp
@@ -88,6 +88,10 @@ void* LLFloaterMyFriends::createGroupsPanel(void* data)
88// 88//
89// LLFloaterChatterBox 89// LLFloaterChatterBox
90// 90//
91
92static std::string sTitle = "Communicate";
93static int sUnreadCount = 0;
94
91LLFloaterChatterBox::LLFloaterChatterBox(const LLSD& seed) : 95LLFloaterChatterBox::LLFloaterChatterBox(const LLSD& seed) :
92 mActiveVoiceFloater(NULL) 96 mActiveVoiceFloater(NULL)
93{ 97{
@@ -122,6 +126,9 @@ LLFloaterChatterBox::LLFloaterChatterBox(const LLSD& seed) :
122 addFloater(LLFloaterChat::getInstance(LLSD()), FALSE); 126 addFloater(LLFloaterChat::getInstance(LLSD()), FALSE);
123 } 127 }
124 mTabContainer->lockTabs(); 128 mTabContainer->lockTabs();
129
130 sUnreadCount = 0;
131 sTitle = getTitle();
125} 132}
126 133
127LLFloaterChatterBox::~LLFloaterChatterBox() 134LLFloaterChatterBox::~LLFloaterChatterBox()
@@ -217,6 +224,53 @@ void LLFloaterChatterBox::setMinimized(BOOL minimized)
217 LLFloaterChat::getInstance()->updateConsoleVisibility(); 224 LLFloaterChat::getInstance()->updateConsoleVisibility();
218} 225}
219 226
227void LLFloaterChatterBox::markAsUnread(bool unread)
228{
229 LLFloaterChatterBox* floater = LLFloaterChatterBox::getInstance();
230
231 // Update IM unread count
232 if (unread)
233 {
234 sUnreadCount++;
235 }
236 else if (!unread)
237 {
238 sUnreadCount--;
239 }
240
241 if (floater)
242 {
243 // Update the title message with the number of unread IMs.
244 // Remove the message when we hit 0.
245 if (sUnreadCount > 0)
246 {
247 // Check for plurals
248 std::string unread_string;
249 if (sUnreadCount == 1)
250 {
251 unread_string = floater->getString("unread_count_string_singular");
252 }
253 else
254 {
255 unread_string = floater->getString("unread_count_string_plural");
256 }
257
258 std::ostringstream unread_count_message;
259 unread_count_message << sTitle << " (" << sUnreadCount << " " << unread_string << ")";
260
261 // Update the floater title
262 floater->setTitle(unread_count_message.str());
263 }
264 else
265 {
266 sUnreadCount = 0;
267
268 // Update the floater title
269 floater->setTitle(sTitle);
270 }
271 }
272}
273
220void LLFloaterChatterBox::removeFloater(LLFloater* floaterp) 274void LLFloaterChatterBox::removeFloater(LLFloater* floaterp)
221{ 275{
222 if (floaterp->getName() == "chat floater") 276 if (floaterp->getName() == "chat floater")
diff --git a/linden/indra/newview/llfloaterchatterbox.h b/linden/indra/newview/llfloaterchatterbox.h
index 57f07a0..39e1025 100644
--- a/linden/indra/newview/llfloaterchatterbox.h
+++ b/linden/indra/newview/llfloaterchatterbox.h
@@ -90,6 +90,8 @@ public:
90 VisibilityPolicy<LLFloater>::hide(instance, key); 90 VisibilityPolicy<LLFloater>::hide(instance, key);
91 } 91 }
92 92
93 static void markAsUnread(bool unread);
94
93private: 95private:
94 LLFloater* getFloater(const LLSD& key) 96 LLFloater* getFloater(const LLSD& key)
95 { 97 {
diff --git a/linden/indra/newview/llimpanel.cpp b/linden/indra/newview/llimpanel.cpp
index 16d64ac..f30ae8c 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"
@@ -1170,6 +1171,7 @@ void LLFloaterIMPanel::init(const std::string& session_label)
1170 FALSE); 1171 FALSE);
1171 1172
1172 setTitle(mSessionLabel); 1173 setTitle(mSessionLabel);
1174
1173 mInputEditor->setMaxTextLength(1023); 1175 mInputEditor->setMaxTextLength(1023);
1174 // enable line history support for instant message bar 1176 // enable line history support for instant message bar
1175 mInputEditor->setEnableLineHistory(TRUE); 1177 mInputEditor->setEnableLineHistory(TRUE);
@@ -1498,7 +1500,21 @@ void LLFloaterIMPanel::addHistoryLine(const std::string &utf8msg, const LLColor4
1498 && hostp 1500 && hostp
1499 && source != gAgent.getID()) 1501 && source != gAgent.getID())
1500 { 1502 {
1501 hostp->setFloaterFlashing(this, TRUE); 1503 // Only start flashing on first update so we can
1504 // get the proper unread number of unread tabs here
1505 if (!hostp->isFloaterFlashing(this))
1506 {
1507 hostp->setFloaterFlashing(this, TRUE);
1508 LLFloaterChatterBox::markAsUnread(true);
1509 }
1510
1511 //// Only increment the number of unread IMs if they're from individuals
1512 //// We increment the first received for the rest during new IM creation.
1513 //if (mDialog == IM_SESSION_P2P_INVITE ||
1514 // mDialog == IM_NOTHING_SPECIAL)
1515 //{
1516 // LLFloaterChatterBox::markAsUnread(true);
1517 //}
1502 } 1518 }
1503 } 1519 }
1504 1520
@@ -1566,13 +1582,17 @@ void LLFloaterIMPanel::setVisible(BOOL b)
1566 LLMultiFloater* hostp = getHost(); 1582 LLMultiFloater* hostp = getHost();
1567 if( b && hostp ) 1583 if( b && hostp )
1568 { 1584 {
1569 hostp->setFloaterFlashing(this, FALSE); 1585 if (hostp->isFloaterFlashing(this))
1570 1586 {
1571 /* Don't change containing floater title - leave it "Instant Message" JC 1587 hostp->setFloaterFlashing(this, FALSE);
1572 LLUIString title = sTitleString; 1588 LLFloaterChatterBox::markAsUnread(false);
1573 title.setArg("[NAME]", mSessionLabel); 1589
1574 hostp->setTitle( title ); 1590 /* Don't change containing floater title - leave it "Instant Message" JC
1575 */ 1591 LLUIString title = sTitleString;
1592 title.setArg("[NAME]", mSessionLabel);
1593 hostp->setTitle( title );
1594 */
1595 }
1576 } 1596 }
1577} 1597}
1578 1598
diff --git a/linden/indra/newview/skins/default/xui/en-us/floater_chatterbox.xml b/linden/indra/newview/skins/default/xui/en-us/floater_chatterbox.xml
index 69f8286..150c570 100644
--- a/linden/indra/newview/skins/default/xui/en-us/floater_chatterbox.xml
+++ b/linden/indra/newview/skins/default/xui/en-us/floater_chatterbox.xml
@@ -8,5 +8,11 @@
8 mouse_opaque="false" name="chatterbox_tab_container" width="391"></icon> 8 mouse_opaque="false" name="chatterbox_tab_container" width="391"></icon>
9 <tab_container bottom="2" follows="left|right|top|bottom" height="370" left="0" 9 <tab_container bottom="2" follows="left|right|top|bottom" height="370" left="0"
10 name="chatterbox_tabs" tab_position="bottom" tab_width="80" width="395" /> 10 name="chatterbox_tabs" tab_position="bottom" tab_width="80" width="395" />
11 <string name="unread_count_string_singular">
12 Unread IM
13 </string>
14 <string name="unread_count_string_plural">
15 Unread IMs
16 </string>
11</multi_floater> 17</multi_floater>
12 18