diff options
Diffstat (limited to 'linden/indra')
-rw-r--r-- | linden/indra/newview/llfloaterchatterbox.cpp | 54 | ||||
-rw-r--r-- | linden/indra/newview/llfloaterchatterbox.h | 2 | ||||
-rw-r--r-- | linden/indra/newview/llimpanel.cpp | 36 | ||||
-rw-r--r-- | linden/indra/newview/skins/default/xui/en-us/floater_chatterbox.xml | 6 |
4 files changed, 90 insertions, 8 deletions
diff --git a/linden/indra/newview/llfloaterchatterbox.cpp b/linden/indra/newview/llfloaterchatterbox.cpp index 1114635..e7de62c 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 | |||
92 | static std::string sTitle = "Communicate"; | ||
93 | static int sUnreadCount = 0; | ||
94 | |||
91 | LLFloaterChatterBox::LLFloaterChatterBox(const LLSD& seed) : | 95 | LLFloaterChatterBox::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 | ||
127 | LLFloaterChatterBox::~LLFloaterChatterBox() | 134 | LLFloaterChatterBox::~LLFloaterChatterBox() |
@@ -217,6 +224,53 @@ void LLFloaterChatterBox::setMinimized(BOOL minimized) | |||
217 | LLFloaterChat::getInstance()->updateConsoleVisibility(); | 224 | LLFloaterChat::getInstance()->updateConsoleVisibility(); |
218 | } | 225 | } |
219 | 226 | ||
227 | void 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 | |||
220 | void LLFloaterChatterBox::removeFloater(LLFloater* floaterp) | 274 | void 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 ac494d1..197c735 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 | |||
93 | private: | 95 | private: |
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 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 | ||
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..96904d7 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 | ||