diff options
author | Andrey Kleshchev <andreykproductengine@lindenlab.com> | 2022-09-14 20:52:04 +0300 |
---|---|---|
committer | Andrey Kleshchev <andreykproductengine@lindenlab.com> | 2022-09-14 21:08:35 +0300 |
commit | c50dd63ca38ce44f6c6997a052a114989db8c942 (patch) | |
tree | 83bdde49d00c68a5763c08aa88e4a2a823ac606a /indra | |
parent | a9a63db0f08bcf5c2593bc8b6c7ab6e532376988 (diff) |
SL-18153 Fix invisible blocking popup
Don't add popup to the list twice
Diffstat (limited to 'indra')
-rw-r--r-- | indra/llui/llmodaldialog.cpp | 12 |
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' } } |