formula/source/ui/dlg/formula.cxx         |    3 ++-
 formula/source/ui/dlg/funcpage.cxx        |   10 +++++++++-
 formula/source/ui/dlg/funcpage.hxx        |    6 ++++++
 sc/qa/uitest/function_wizard/tdf104487.py |   28 ++++++++++++++++++++++++++++
 4 files changed, 45 insertions(+), 2 deletions(-)

New commits:
commit 421d4fc533498d058a91f9686c47b35114e6a6c9
Author:     Andreas Heinisch <andreas.heini...@yahoo.de>
AuthorDate: Tue May 9 11:04:37 2023 +0200
Commit:     Andreas Heinisch <andreas.heini...@yahoo.de>
CommitDate: Tue May 9 17:39:05 2023 +0200

    tdf#104487 - Function wizard: remember last used function category
    
    Change-Id: I978dd63553e3528e7b9b853dbb438304f1f680cc
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/151565
    Tested-by: Jenkins
    Reviewed-by: Andreas Heinisch <andreas.heini...@yahoo.de>

diff --git a/formula/source/ui/dlg/formula.cxx 
b/formula/source/ui/dlg/formula.cxx
index c12534268131..123642c46c1e 100644
--- a/formula/source/ui/dlg/formula.cxx
+++ b/formula/source/ui/dlg/formula.cxx
@@ -828,7 +828,8 @@ void FormulaDlg_Impl::FillListboxes()
     }
     else if ( pData )
     {
-        m_xFuncPage->SetCategory( 1 );
+        // tdf#104487 - remember last used function category
+        m_xFuncPage->SetCategory(FuncPage::GetRememeberdFunctionCategory());
         m_xFuncPage->SetFunction( -1 );
     }
     FuncSelHdl(*m_xFuncPage);
diff --git a/formula/source/ui/dlg/funcpage.cxx 
b/formula/source/ui/dlg/funcpage.cxx
index 3013b84c06b6..dbdb49464ae7 100644
--- a/formula/source/ui/dlg/funcpage.cxx
+++ b/formula/source/ui/dlg/funcpage.cxx
@@ -37,6 +37,9 @@ IMPL_LINK(FuncPage, KeyInputHdl, const KeyEvent&, rKEvt, bool)
     return false;
 }
 
+// tdf#104487 - remember last used function category - set default to All 
category
+sal_Int32 FuncPage::m_nRememberedFunctionCategory = 1;
+
 FuncPage::FuncPage(weld::Container* pParent, const IFunctionManager* 
_pFunctionManager)
     : m_xBuilder(Application::CreateBuilder(pParent, 
"formula/ui/functionpage.ui"))
     , m_xContainer(m_xBuilder->weld_container("FunctionPage"))
@@ -58,7 +61,8 @@ FuncPage::FuncPage(weld::Container* pParent, const 
IFunctionManager* _pFunctionM
         m_xLbCategory->append(sId, pCategory->getName());
     }
 
-    m_xLbCategory->set_active(1);
+    // tdf#104487 - remember last used function category
+    m_xLbCategory->set_active(m_nRememberedFunctionCategory);
     OUString searchStr = m_xLbFunctionSearchString->get_text();
     UpdateFunctionList(searchStr);
     // lock to its initial size
@@ -96,6 +100,8 @@ void FuncPage::UpdateFunctionList(const OUString& aStr)
     m_xLbFunction->freeze();
 
     const sal_Int32 nSelPos = m_xLbCategory->get_active();
+    // tdf#104487 - remember last used function category
+    m_nRememberedFunctionCategory = nSelPos;
 
     if (aStr.isEmpty() || nSelPos == 0)
     {
@@ -217,6 +223,8 @@ IMPL_LINK_NOARG(FuncPage, ModifyHdl, weld::Entry&, void)
 
 void FuncPage::SetCategory(sal_Int32 nCat)
 {
+    // tdf#104487 - remember last used function category
+    m_nRememberedFunctionCategory = nCat;
     m_xLbCategory->set_active(nCat);
     UpdateFunctionList(OUString());
 }
diff --git a/formula/source/ui/dlg/funcpage.hxx 
b/formula/source/ui/dlg/funcpage.hxx
index 1e91b610ec0d..e7ca248d861b 100644
--- a/formula/source/ui/dlg/funcpage.hxx
+++ b/formula/source/ui/dlg/funcpage.hxx
@@ -48,6 +48,9 @@ private:
     ::std::vector< TFunctionDesc >  aLRUList;
     OUString    m_aHelpId;
 
+    // tdf#104487 - remember last used function category
+    static sal_Int32 m_nRememberedFunctionCategory;
+
     void impl_addFunctions(const IFunctionCategory* _pCategory);
 
     DECL_LINK(SelComboBoxHdl, weld::ComboBox&, void);
@@ -71,6 +74,9 @@ public:
     sal_Int32       GetFunction() const;
     sal_Int32       GetFunctionEntryCount() const;
 
+    // tdf#104487 - remember last used function category
+    static sal_Int32 GetRememeberdFunctionCategory() { return 
m_nRememberedFunctionCategory; };
+
     sal_Int32       GetFuncPos(const IFunctionDescription* _pDesc);
     const IFunctionDescription* GetFuncDesc( sal_Int32  nPos ) const;
     OUString        GetSelFunctionName() const;
diff --git a/sc/qa/uitest/function_wizard/tdf104487.py 
b/sc/qa/uitest/function_wizard/tdf104487.py
new file mode 100755
index 000000000000..8b563bc5b372
--- /dev/null
+++ b/sc/qa/uitest/function_wizard/tdf104487.py
@@ -0,0 +1,28 @@
+# -*- tab-width: 4; indent-tabs-mode: nil; py-indent-offset: 4 -*-
+#
+# This file is part of the LibreOffice project.
+#
+# This Source Code Form is subject to the terms of the Mozilla Public
+# License, v. 2.0. If a copy of the MPL was not distributed with this
+# file, You can obtain one at http://mozilla.org/MPL/2.0/.
+#
+from uitest.framework import UITestCase
+from uitest.uihelper.common import get_state_as_dict, select_pos
+
+class tdf104487(UITestCase):
+    def test_tdf104487_remember_function_category(self):
+        with self.ui_test.create_doc_in_start_center("calc"):
+            # Open function dialog and select select a function category
+            with 
self.ui_test.execute_modeless_dialog_through_command(".uno:FunctionDialog") as 
xDialog:
+                xCategory = xDialog.getChild("category")
+                select_pos(xCategory, "3")
+
+            # Open function dialog again and check whether function category 
was remembered
+            with 
self.ui_test.execute_modeless_dialog_through_command(".uno:FunctionDialog") as 
xDialog:
+                xCategory = xDialog.getChild("category")
+                # Without the fix in place, this test would have failed with
+                # AssertionError: '3' != '1'
+                # i.e. the last used function category in the function wizard 
was not remembered
+                self.assertEqual("3", 
get_state_as_dict(xCategory)["SelectEntryPos"])
+
+# vim: set shiftwidth=4 softtabstop=4 expandtab:

Reply via email to