summaryrefslogtreecommitdiff
path: root/indra/llui
diff options
context:
space:
mode:
authorAndrey Kleshchev <andreykproductengine@lindenlab.com>2022-09-14 20:52:04 +0300
committerAndrey Kleshchev <andreykproductengine@lindenlab.com>2022-09-14 21:08:35 +0300
commitc50dd63ca38ce44f6c6997a052a114989db8c942 (patch)
tree83bdde49d00c68a5763c08aa88e4a2a823ac606a /indra/llui
parenta9a63db0f08bcf5c2593bc8b6c7ab6e532376988 (diff)
SL-18153 Fix invisible blocking popup
Don't add popup to the list twice
Diffstat (limited to 'indra/llui')
-rw-r--r--indra/llui/llmodaldialog.cpp12
1 files changed, 10 insertions, 2 deletions
diff --git a/indra/llui/llmodaldialog.cpp b/indra/llui/llmodaldialog.cpp
index 5cfa8ea973..50fc6913a9 100644
--- a/indra/llui/llmodaldialog.cpp
+++ b/indra/llui/llmodaldialog.cpp
@@ -100,7 +100,10 @@ void LLModalDialog::onOpen(const LLSD& key)
if (!sModalStack.empty())
{
LLModalDialog* front = sModalStack.front();
- front->setVisible(FALSE);
+ if (front != this)
+ {
+ front->setVisible(FALSE);
+ }
}
// This is a modal dialog. It sucks up all mouse and keyboard operations.
@@ -108,7 +111,12 @@ void LLModalDialog::onOpen(const LLSD& key)
LLUI::getInstance()->addPopup(this);
setFocus(TRUE);
- sModalStack.push_front( this );
+ std::list<LLModalDialog*>::iterator iter = std::find(sModalStack.begin(), sModalStack.end(), this);
+ if (iter == sModalStack.end())
+ {
+ sModalStack.push_front(this);
+ }
+ // else act like it is a 'bring to front'
}
}