diff options
Diffstat (limited to 'linden/indra/newview/llnotify.cpp')
-rw-r--r-- | linden/indra/newview/llnotify.cpp | 25 |
1 files changed, 18 insertions, 7 deletions
diff --git a/linden/indra/newview/llnotify.cpp b/linden/indra/newview/llnotify.cpp index 7c206bb..92224b8 100644 --- a/linden/indra/newview/llnotify.cpp +++ b/linden/indra/newview/llnotify.cpp | |||
@@ -2,6 +2,8 @@ | |||
2 | * @file llnotify.cpp | 2 | * @file llnotify.cpp |
3 | * @brief Non-blocking notification that doesn't take keyboard focus. | 3 | * @brief Non-blocking notification that doesn't take keyboard focus. |
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2003&license=viewergpl$ | ||
6 | * | ||
5 | * Copyright (c) 2003-2007, Linden Research, Inc. | 7 | * Copyright (c) 2003-2007, Linden Research, Inc. |
6 | * | 8 | * |
7 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
@@ -24,6 +26,7 @@ | |||
24 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | 26 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO |
25 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | 27 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, |
26 | * COMPLETENESS OR PERFORMANCE. | 28 | * COMPLETENESS OR PERFORMANCE. |
29 | * $/LicenseInfo$ | ||
27 | */ | 30 | */ |
28 | 31 | ||
29 | #include "llviewerprecompiledheaders.h" | 32 | #include "llviewerprecompiledheaders.h" |
@@ -584,11 +587,14 @@ void LLNotifyBox::moveToBack() | |||
584 | if (gNotifyBoxView->getChildCount() > 0) | 587 | if (gNotifyBoxView->getChildCount() > 0) |
585 | { | 588 | { |
586 | LLNotifyBox* front = gNotifyBoxView->getFirstNontipBox(); | 589 | LLNotifyBox* front = gNotifyBoxView->getFirstNontipBox(); |
587 | gNotifyBoxView->showOnly(front); | 590 | if (front) |
588 | // assuming that moveToBack is only called by clicking the next button, | 591 | { |
589 | // we give focus to the next next button | 592 | gNotifyBoxView->showOnly(front); |
590 | front->mNextBtn->setFocus(TRUE); | 593 | // assuming that moveToBack is only called by clicking the next button, |
591 | gFocusMgr.triggerFocusFlash(); // TODO: it's ugly to call this here | 594 | // we give focus to the next next button |
595 | front->mNextBtn->setFocus(TRUE); | ||
596 | gFocusMgr.triggerFocusFlash(); // TODO: it's ugly to call this here | ||
597 | } | ||
592 | } | 598 | } |
593 | } | 599 | } |
594 | } | 600 | } |
@@ -910,7 +916,7 @@ bool LLNotifyBox::parseNotify(const LLString& xml_filename) | |||
910 | } | 916 | } |
911 | } | 917 | } |
912 | 918 | ||
913 | //XUI:translate | 919 | //*TODO:translate |
914 | if (xml_template->mOptions.empty()) | 920 | if (xml_template->mOptions.empty()) |
915 | { | 921 | { |
916 | xml_template->addOption("OK", FALSE); | 922 | xml_template->addOption("OK", FALSE); |
@@ -927,12 +933,17 @@ LLNotifyBoxView::LLNotifyBoxView(const LLString& name, const LLRect& rect, BOOL | |||
927 | 933 | ||
928 | LLNotifyBox * LLNotifyBoxView::getFirstNontipBox() const | 934 | LLNotifyBox * LLNotifyBoxView::getFirstNontipBox() const |
929 | { | 935 | { |
936 | // *TODO: Don't make assumptions like this! | ||
930 | // assumes every child is a notify box | 937 | // assumes every child is a notify box |
931 | for(child_list_const_iter_t iter = getChildList()->begin(); | 938 | for(child_list_const_iter_t iter = getChildList()->begin(); |
932 | iter != getChildList()->end(); | 939 | iter != getChildList()->end(); |
933 | iter++) | 940 | iter++) |
934 | { | 941 | { |
935 | LLNotifyBox * box = static_cast<LLNotifyBox*>(*iter); | 942 | // hack! *TODO: Integrate llnotify and llgroupnotify |
943 | LLView* view = *iter; | ||
944 | if (view->getName() == "groupnotify") | ||
945 | continue; | ||
946 | LLNotifyBox* box = static_cast<LLNotifyBox*>(view); | ||
936 | if(!box->isTip() && !box->isDead()) | 947 | if(!box->isTip() && !box->isDead()) |
937 | { | 948 | { |
938 | return box; | 949 | return box; |