diff options
author | Maxim Monastirsky <momonasmon@gmail.com> | 2016-01-18 01:10:21 +0200 |
---|---|---|
committer | Samuel Mehrbrodt <Samuel.Mehrbrodt@cib.de> | 2016-01-22 13:23:31 +0000 |
commit | 70e08ce45ae06abdd978430263c8ef5d6a8826e2 (patch) | |
tree | a61c34851fe6c484259e8fd0fdc3c5bee6b80124 /framework | |
parent | 2a74b694dbbca2083ffa4b20ec89c8574f00c34a (diff) |
Don't update the save icon on every keystroke
Change-Id: Iad6195ea8b082ca5e6c1a7e9fa48742ff2b495a6
(cherry picked from commit 69882b0ef861099fd6bfa802d6f7ba5d1391c269)
Reviewed-on: https://gerrit.libreoffice.org/21701
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Samuel Mehrbrodt <Samuel.Mehrbrodt@cib.de>
Diffstat (limited to 'framework')
-rw-r--r-- | framework/source/uielement/popuptoolbarcontroller.cxx | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/framework/source/uielement/popuptoolbarcontroller.cxx b/framework/source/uielement/popuptoolbarcontroller.cxx index 0464368b08cc..6b9c5526e22f 100644 --- a/framework/source/uielement/popuptoolbarcontroller.cxx +++ b/framework/source/uielement/popuptoolbarcontroller.cxx @@ -345,11 +345,13 @@ public: virtual css::uno::Sequence< OUString > SAL_CALL getSupportedServiceNames() throw ( css::uno::RuntimeException ) override; private: + bool m_bModified; css::uno::Reference< css::util::XModifiable > m_xModifiable; }; SaveToolbarController::SaveToolbarController( const css::uno::Reference< css::uno::XComponentContext >& rxContext ) : ImplInheritanceHelper( rxContext, ".uno:SaveAsMenu" ) + , m_bModified( false ) { } @@ -413,7 +415,7 @@ void SaveToolbarController::updateImage() { aImage = vcl::CommandInfoProvider::Instance().GetImageForCommand( ".uno:SaveAs", bLargeIcons, m_xFrame ); } - else if ( m_xModifiable.is() && m_xModifiable->isModified() ) + else if ( m_bModified ) { Image aResImage( bLargeIcons ? FwkResId( IMG_SAVEMODIFIED_LARGE ) : FwkResId( IMG_SAVEMODIFIED_SMALL ) ); aImage = aResImage; @@ -455,7 +457,12 @@ void SaveToolbarController::statusChanged( const css::frame::FeatureStateEvent& void SaveToolbarController::modified( const css::lang::EventObject& /*rEvent*/ ) throw ( css::uno::RuntimeException, std::exception ) { - updateImage(); + bool bModified = m_xModifiable->isModified(); + if ( bModified != m_bModified ) + { + m_bModified = bModified; + updateImage(); + } } void SaveToolbarController::disposing( const css::lang::EventObject& rEvent ) |