summaryrefslogtreecommitdiff
path: root/formula
diff options
context:
space:
mode:
authorAndreas Heinisch <andreas.heinisch@yahoo.de>2023-05-09 11:04:37 +0200
committerAndreas Heinisch <andreas.heinisch@yahoo.de>2023-05-09 17:39:05 +0200
commit421d4fc533498d058a91f9686c47b35114e6a6c9 (patch)
treefa90d769d6f1abc031d5cc8e479b419dc6e18d9b /formula
parent600ad0a53e25beed8b418d477635d0c8513d5d07 (diff)
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.heinisch@yahoo.de>
Diffstat (limited to 'formula')
-rw-r--r--formula/source/ui/dlg/formula.cxx3
-rw-r--r--formula/source/ui/dlg/funcpage.cxx10
-rw-r--r--formula/source/ui/dlg/funcpage.hxx6
3 files changed, 17 insertions, 2 deletions
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;