summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorZolnai Tamás <zolniatamas@caesar.elte.hu>2012-08-08 20:50:35 +0200
committerAndras Timar <atimar@suse.com>2012-08-10 21:51:40 +0200
commit35b6007b7f62b75a3e6ec924fa5863cd6e7a53e0 (patch)
tree84a62f8673a5f5729c2f7db28685dadd1cc77930
parente370b12af6e2c1e3fc3bf67350541c4e4503f40c (diff)
fdo#49750 Search Toolbar keeps its history
Until now, only the ToolBar's TextField stored the history, but this is destructed when ToolBar is closed. The "Manager" class is alive in case of Toolbar's invisibility, so I made this class to store history temporarly. Change-Id: I816dd3c83440000ab4e6caaeb2cccf390d3042fd Signed-off-by: Andras Timar <atimar@suse.com>
-rw-r--r--svx/inc/tbunosearchcontrollers.hxx5
-rw-r--r--svx/source/tbxctrls/tbunosearchcontrollers.cxx20
2 files changed, 25 insertions, 0 deletions
diff --git a/svx/inc/tbunosearchcontrollers.hxx b/svx/inc/tbunosearchcontrollers.hxx
index 032662cf361d..91ddec8ba12e 100644
--- a/svx/inc/tbunosearchcontrollers.hxx
+++ b/svx/inc/tbunosearchcontrollers.hxx
@@ -46,6 +46,7 @@
#include <vcl/window.hxx>
#include <map>
+#include <vector>
namespace css = ::com::sun::star ;
namespace svx
@@ -86,11 +87,15 @@ public:
void freeController ( const css::uno::Reference< css::frame::XFrame >& xFrame, const css::uno::Reference< css::frame::XStatusListener >& xStatusListener, const ::rtl::OUString& sCommandURL );
css::uno::Reference< css::frame::XStatusListener > findController( const css::uno::Reference< css::frame::XFrame >& xFrame, const ::rtl::OUString& sCommandURL );
+ void saveSearchHistory(const FindTextFieldControl* m_pFindTextFieldControl);
+ void loadSearchHistory(FindTextFieldControl* m_pFindTextFieldControl);
+
private:
typedef ::comphelper::SequenceAsVector< css::beans::PropertyValue > SearchToolbarControllersVec;
typedef ::std::map< css::uno::Reference< css::frame::XFrame >, SearchToolbarControllersVec > SearchToolbarControllersMap;
SearchToolbarControllersMap aSearchToolbarControllersMap;
+ std::vector<rtl::OUString> aSearchStrings;
};
diff --git a/svx/source/tbxctrls/tbunosearchcontrollers.cxx b/svx/source/tbxctrls/tbunosearchcontrollers.cxx
index 5fddc89c48a5..f53dab21f4ec 100644
--- a/svx/source/tbxctrls/tbunosearchcontrollers.cxx
+++ b/svx/source/tbxctrls/tbunosearchcontrollers.cxx
@@ -248,6 +248,24 @@ SearchToolbarControllersManager& SearchToolbarControllersManager::createControll
return theSearchToolbarControllersManager::get();
}
+void SearchToolbarControllersManager::saveSearchHistory(const FindTextFieldControl* m_pFindTextFieldControl)
+{
+ sal_uInt16 nECount( m_pFindTextFieldControl->GetEntryCount() );
+ aSearchStrings.resize( nECount );
+ for( sal_uInt16 i=0; i<nECount; ++i )
+ {
+ aSearchStrings[i] = m_pFindTextFieldControl->GetEntry(i);
+ }
+}
+
+void SearchToolbarControllersManager::loadSearchHistory(FindTextFieldControl* m_pFindTextFieldControl)
+{
+ for( sal_uInt16 i=0; i<aSearchStrings.size(); ++i )
+ {
+ m_pFindTextFieldControl->InsertEntry(aSearchStrings[i],i);
+ }
+}
+
void SearchToolbarControllersManager::registryController( const css::uno::Reference< css::frame::XFrame >& xFrame, const css::uno::Reference< css::frame::XStatusListener >& xStatusListener, const ::rtl::OUString& sCommandURL )
{
SearchToolbarControllersMap::iterator pIt = aSearchToolbarControllersMap.find(xFrame);
@@ -384,6 +402,7 @@ void SAL_CALL FindTextToolbarController::dispose() throw ( css::uno::RuntimeExce
SearchToolbarControllersManager::createControllersManager().freeController(m_xFrame, css::uno::Reference< css::frame::XStatusListener >(static_cast< ::cppu::OWeakObject* >(this), css::uno::UNO_QUERY), m_aCommandURL);
svt::ToolboxController::dispose();
+ SearchToolbarControllersManager::createControllersManager().saveSearchHistory(m_pFindTextFieldControl);
delete m_pFindTextFieldControl;
m_pFindTextFieldControl = 0;
}
@@ -430,6 +449,7 @@ css::uno::Reference< css::awt::XWindow > SAL_CALL FindTextToolbarController::cre
Size aSize(250, m_pFindTextFieldControl->GetTextHeight() + 200);
m_pFindTextFieldControl->SetSizePixel( aSize );
m_pFindTextFieldControl->SetModifyHdl(LINK(this, FindTextToolbarController, EditModifyHdl));
+ SearchToolbarControllersManager::createControllersManager().loadSearchHistory(m_pFindTextFieldControl);
}
xItemWindow = VCLUnoHelper::GetInterface( m_pFindTextFieldControl );