diff options
Diffstat (limited to 'extensions/source/propctrlr/browserline.cxx')
-rw-r--r-- | extensions/source/propctrlr/browserline.cxx | 532 |
1 files changed, 0 insertions, 532 deletions
diff --git a/extensions/source/propctrlr/browserline.cxx b/extensions/source/propctrlr/browserline.cxx deleted file mode 100644 index e337bc6fe..000000000 --- a/extensions/source/propctrlr/browserline.cxx +++ /dev/null @@ -1,532 +0,0 @@ -/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ -/************************************************************************* - * - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * Copyright 2000, 2010 Oracle and/or its affiliates. - * - * OpenOffice.org - a multi-platform office productivity suite - * - * This file is part of OpenOffice.org. - * - * OpenOffice.org is free software: you can redistribute it and/or modify - * it under the terms of the GNU Lesser General Public License version 3 - * only, as published by the Free Software Foundation. - * - * OpenOffice.org is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU Lesser General Public License version 3 for more details - * (a copy is included in the LICENSE file that accompanied this code). - * - * You should have received a copy of the GNU Lesser General Public License - * version 3 along with OpenOffice.org. If not, see - * <http://www.openoffice.org/license.html> - * for a copy of the LGPLv3 License. - * - ************************************************************************/ - -// MARKER(update_precomp.py): autogen include statement, do not remove -#include "precompiled_extensions.hxx" -#include "browserline.hxx" - -/** === begin UNO includes === **/ -#include <com/sun/star/inspection/PropertyLineElement.hpp> -#include <com/sun/star/graphic/XGraphicProvider.hpp> -/** === end UNO includes === **/ - -#include <vcl/svapp.hxx> -#include <tools/debug.hxx> -#include <tools/diagnose_ex.h> -#include <tools/urlobj.hxx> -#include <toolkit/helper/vclunohelper.hxx> - -#include <comphelper/processfactory.hxx> -#include <comphelper/componentcontext.hxx> - -//............................................................................ -namespace pcr -{ -//............................................................................ - - /** === begin UNO using === **/ - using ::com::sun::star::uno::Reference; - using ::com::sun::star::inspection::XPropertyControl; - using ::com::sun::star::inspection::XPropertyControlContext; - using ::com::sun::star::uno::UNO_QUERY_THROW; - using ::com::sun::star::uno::Exception; - using ::com::sun::star::graphic::XGraphicProvider; - using ::com::sun::star::uno::Sequence; - using ::com::sun::star::beans::PropertyValue; - using ::com::sun::star::graphic::XGraphic; - /** === end UNO using === **/ - - namespace PropertyLineElement = ::com::sun::star::inspection::PropertyLineElement; - - //================================================================== - //= OBrowserLine - //================================================================== - DBG_NAME(OBrowserLine) - //------------------------------------------------------------------ - - OBrowserLine::OBrowserLine( const ::rtl::OUString& _rEntryName, Window* pParent ) - :m_sEntryName( _rEntryName ) - ,m_aFtTitle(pParent) - ,m_pControlWindow( NULL ) - ,m_pBrowseButton(NULL) - ,m_pAdditionalBrowseButton( NULL ) - ,m_pClickListener( NULL ) - ,m_pTheParent(pParent) - ,m_nNameWidth(0) - ,m_nEnableFlags( 0xFFFF ) - ,m_bIndentTitle( false ) - ,m_bReadOnly( false ) - { - DBG_CTOR(OBrowserLine,NULL); - m_aFtTitle.Show(); - } - - //------------------------------------------------------------------ - OBrowserLine::~OBrowserLine() - { - implHideBrowseButton( true, false ); - implHideBrowseButton( false, false ); - - DBG_DTOR(OBrowserLine,NULL); - } - - //------------------------------------------------------------------ - void OBrowserLine::IndentTitle( bool _bIndent ) - { - if ( m_bIndentTitle != _bIndent ) - { - m_bIndentTitle = _bIndent; - impl_layoutComponents(); - } - } - - //------------------------------------------------------------------ - void OBrowserLine::SetComponentHelpIds( const rtl::OString& _rHelpId, const rtl::OString& _sPrimaryButtonId, const rtl::OString& _sSecondaryButtonId ) - { - if ( m_pControlWindow ) - m_pControlWindow->SetHelpId( _rHelpId ); - - if ( m_pBrowseButton ) - { - m_pBrowseButton->SetHelpId( _rHelpId ); - m_pBrowseButton->SetUniqueId( _sPrimaryButtonId ); - - if ( m_pAdditionalBrowseButton ) - { - m_pAdditionalBrowseButton->SetHelpId( _rHelpId ); - m_pAdditionalBrowseButton->SetUniqueId( _sSecondaryButtonId ); - } - } - } - - //------------------------------------------------------------------ - void OBrowserLine::setControl( const Reference< XPropertyControl >& _rxControl ) - { - m_xControl = _rxControl; - m_pControlWindow = m_xControl.is() ? VCLUnoHelper::GetWindow( _rxControl->getControlWindow() ) : NULL; - DBG_ASSERT( m_pControlWindow, "OBrowserLine::setControl: setting NULL controls/windows is not allowed!" ); - - if ( m_pControlWindow ) - { - m_pControlWindow->SetParent( m_pTheParent ); - m_pControlWindow->Show(); - } - impl_layoutComponents(); - } - - //------------------------------------------------------------------ - Window* OBrowserLine::GetRefWindow() - { - Window* pRefWindow=&m_aFtTitle; - - if(m_pBrowseButton) - { - pRefWindow=(Window*)m_pBrowseButton; - } - else if ( m_pControlWindow ) - { - pRefWindow = m_pControlWindow; - } - return pRefWindow; - } - - //------------------------------------------------------------------ - void OBrowserLine::SetTabOrder(Window* pRefWindow, sal_uInt16 nFlags ) - { - m_aFtTitle.SetZOrder(pRefWindow,nFlags); - if ( m_pControlWindow ) - m_pControlWindow->SetZOrder( (Window*)&m_aFtTitle, WINDOW_ZORDER_BEHIND ); - - if ( m_pBrowseButton ) - m_pBrowseButton->SetZOrder( m_pControlWindow, WINDOW_ZORDER_BEHIND ); - - if ( m_pAdditionalBrowseButton ) - m_pAdditionalBrowseButton->SetZOrder( m_pBrowseButton, WINDOW_ZORDER_BEHIND ); - } - - //------------------------------------------------------------------ - sal_Bool OBrowserLine::GrabFocus() - { - sal_Bool bRes=sal_False; - - if ( m_pControlWindow && m_pControlWindow->IsEnabled() ) - { - m_pControlWindow->GrabFocus(); - bRes = sal_True; - } - else if ( m_pAdditionalBrowseButton && m_pAdditionalBrowseButton->IsEnabled() ) - { - m_pAdditionalBrowseButton->GrabFocus(); - bRes = sal_True; - } - else if ( m_pBrowseButton && m_pBrowseButton->IsEnabled() ) - { - m_pBrowseButton->GrabFocus(); - bRes = sal_True; - } - return bRes; - } - - //------------------------------------------------------------------ - void OBrowserLine::SetPosSizePixel( Point _rPos, Size _rSize ) - { - m_aLinePos = _rPos; - m_aOutputSize = _rSize; - - impl_layoutComponents(); - } - - //------------------------------------------------------------------ - void OBrowserLine::Show(sal_Bool bFlag) - { - m_aFtTitle.Show(bFlag); - if ( m_pControlWindow ) - m_pControlWindow->Show( bFlag ); - if ( m_pBrowseButton ) - m_pBrowseButton->Show( bFlag ); - if ( m_pAdditionalBrowseButton ) - m_pAdditionalBrowseButton->Show( bFlag ); - } - - //------------------------------------------------------------------ - void OBrowserLine::Hide() - { - Show(sal_False); - } - - //------------------------------------------------------------------ - sal_Bool OBrowserLine::IsVisible() - { - return m_aFtTitle.IsVisible(); - } - - //------------------------------------------------------------------ - void OBrowserLine::impl_layoutComponents() - { - { - Point aTitlePos( m_aLinePos.X(), m_aLinePos.Y() + 8 ); - Size aTitleSize( m_nNameWidth - 3, m_aOutputSize.Height() ); - - if ( m_bIndentTitle ) - { - Size aIndent( m_pTheParent->LogicToPixel( Size( 8, 0 ), MAP_APPFONT ) ); - aTitlePos.X() += aIndent.Width(); - aTitleSize.Width() -= aIndent.Width(); - } - m_aFtTitle.SetPosSizePixel( aTitlePos, aTitleSize ); - } - - sal_Int32 nBrowseButtonSize = m_aOutputSize.Height() - 4; - - if ( m_pControlWindow ) - { - Point aControlPos( m_aLinePos.X() + m_nNameWidth, m_aLinePos.Y() + 2 ); - m_pControlWindow->SetPosPixel( aControlPos ); - - Size aControlSize( m_aOutputSize.Width() - 4 - m_nNameWidth - nBrowseButtonSize - 4, m_pControlWindow->GetSizePixel().Height() ); - if ( m_pAdditionalBrowseButton ) - aControlSize.Width() -= nBrowseButtonSize + 4; - m_pControlWindow->SetSizePixel( aControlSize ); - } - - if ( m_pBrowseButton ) - { - Point aButtonPos( m_aOutputSize.Width() - 4 - nBrowseButtonSize, m_aLinePos.Y() + 2 ); - Size aButtonSize( nBrowseButtonSize, nBrowseButtonSize ); - m_pBrowseButton->SetPosSizePixel( aButtonPos, aButtonSize ); - - if ( m_pAdditionalBrowseButton ) - { - aButtonPos.X() -= nBrowseButtonSize + 4; - m_pAdditionalBrowseButton->SetPosSizePixel( aButtonPos, aButtonSize ); - } - } - } - - //------------------------------------------------------------------ - void OBrowserLine::SetTitle(const XubString& _rNewTtile ) - { - if ( GetTitle() == _rNewTtile ) - return; - // #99102# -------------- - m_aFtTitle.SetText( _rNewTtile ); - if ( m_pControlWindow ) - m_pControlWindow->SetAccessibleName( _rNewTtile ); - if ( m_pBrowseButton ) - m_pBrowseButton->SetAccessibleName( _rNewTtile ); - FullFillTitleString(); - } - - // #99102# --------------------------------------------------------- - void OBrowserLine::FullFillTitleString() - { - if( m_pTheParent ) - { - String aText = m_aFtTitle.GetText(); - - while( m_pTheParent->GetTextWidth( aText ) < m_nNameWidth ) - aText.AppendAscii("..........."); - - // for Issue 69452 - if (Application::GetSettings().GetLayoutRTL()) - { - sal_Unicode cRTL_mark = 0x200F; - aText.Append(cRTL_mark); - } - - m_aFtTitle.SetText(aText); - } - } - - //------------------------------------------------------------------ - XubString OBrowserLine::GetTitle() const - { - String sDisplayName = m_aFtTitle.GetText(); - - // for Issue 69452 - if (Application::GetSettings().GetLayoutRTL()) - { - sal_Unicode cRTL_mark = 0x200F; - sDisplayName.EraseTrailingChars(cRTL_mark); - } - - sDisplayName.EraseTrailingChars( '.' ); - - return sDisplayName; - } - - //------------------------------------------------------------------ - void OBrowserLine::SetReadOnly( bool _bReadOnly ) - { - if ( m_bReadOnly != _bReadOnly ) - { - m_bReadOnly = _bReadOnly; - implUpdateEnabledDisabled(); - } - } - - //------------------------------------------------------------------ - namespace - { - void implSetBitIfAffected( sal_uInt16& _nEnabledBits, sal_Int16 _nAffectedMask, sal_Int16 _nTestBit, bool _bSet ) - { - if ( _nAffectedMask & _nTestBit ) - { - if ( _bSet ) - _nEnabledBits |= _nTestBit; - else - _nEnabledBits &= ~_nTestBit; - } - } - - void implEnable( Window* _pWindow, sal_uInt16 _nEnabledBits, sal_uInt16 _nMatchBits ) - { - if ( _pWindow ) - _pWindow->Enable( ( _nEnabledBits & _nMatchBits ) == _nMatchBits ); - } - - void implEnable( Window* _pWindow, bool _bEnable ) - { - if ( _pWindow ) - _pWindow->Enable( _bEnable ); - } - } - - //------------------------------------------------------------------ - void OBrowserLine::implUpdateEnabledDisabled() - { - implEnable( &m_aFtTitle, m_nEnableFlags, PropertyLineElement::CompleteLine ); - if ( m_pControlWindow ) - implEnable( m_pControlWindow, m_nEnableFlags, PropertyLineElement::CompleteLine | PropertyLineElement::InputControl ); - - if ( m_bReadOnly ) - { - implEnable( m_pBrowseButton, false ); - implEnable( m_pAdditionalBrowseButton, false ); - } - else - { - implEnable( m_pBrowseButton, m_nEnableFlags, PropertyLineElement::CompleteLine | PropertyLineElement::PrimaryButton ); - implEnable( m_pAdditionalBrowseButton, m_nEnableFlags, PropertyLineElement::CompleteLine | PropertyLineElement::SecondaryButton ); - } - } - - //------------------------------------------------------------------ - void OBrowserLine::EnablePropertyLine( bool _bEnable ) - { - implSetBitIfAffected( m_nEnableFlags, PropertyLineElement::CompleteLine, PropertyLineElement::CompleteLine, _bEnable ); - implUpdateEnabledDisabled(); - } - - //------------------------------------------------------------------ - void OBrowserLine::EnablePropertyControls( sal_Int16 _nControls, bool _bEnable ) - { - implSetBitIfAffected( m_nEnableFlags, _nControls, PropertyLineElement::InputControl, _bEnable ); - implSetBitIfAffected( m_nEnableFlags, _nControls, PropertyLineElement::PrimaryButton, _bEnable ); - implSetBitIfAffected( m_nEnableFlags, _nControls, PropertyLineElement::SecondaryButton, _bEnable ); - implUpdateEnabledDisabled(); - } - - //------------------------------------------------------------------ - PushButton& OBrowserLine::impl_ensureButton( bool _bPrimary ) - { - PushButton*& rpButton = _bPrimary ? m_pBrowseButton : m_pAdditionalBrowseButton; - - if ( !rpButton ) - { - rpButton = new PushButton( m_pTheParent, WB_NOPOINTERFOCUS ); - rpButton->SetGetFocusHdl( LINK( this, OBrowserLine, OnButtonFocus ) ); - rpButton->SetClickHdl( LINK( this, OBrowserLine, OnButtonClicked ) ); - rpButton->SetText( String::CreateFromAscii( "..." ) ); - } - - rpButton->Show(); - - impl_layoutComponents(); - - return *rpButton; - } - - //------------------------------------------------------------------ - void OBrowserLine::impl_getImagesFromURL_nothrow( const ::rtl::OUString& _rImageURL, Image& _out_rImage ) - { - try - { - ::comphelper::ComponentContext aContext( ::comphelper::getProcessServiceFactory() ); - Reference< XGraphicProvider > xGraphicProvider( aContext.createComponent( "com.sun.star.graphic.GraphicProvider" ), UNO_QUERY_THROW ); - - Sequence< PropertyValue > aMediaProperties(1); - aMediaProperties[0].Name = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "URL" ) ); - aMediaProperties[0].Value <<= _rImageURL; - - Reference< XGraphic > xGraphic( xGraphicProvider->queryGraphic( aMediaProperties ), UNO_QUERY_THROW ); - _out_rImage = Image( xGraphic ); - } - catch( const Exception& ) - { - DBG_UNHANDLED_EXCEPTION(); - } - } - - //------------------------------------------------------------------ - void OBrowserLine::ShowBrowseButton( const ::rtl::OUString& _rImageURL, sal_Bool _bPrimary ) - { - PushButton& rButton( impl_ensureButton( _bPrimary ) ); - - OSL_PRECOND( _rImageURL.getLength(), "OBrowserLine::ShowBrowseButton: use the other version if you don't have an image!" ); - Image aImage; - impl_getImagesFromURL_nothrow( _rImageURL, aImage ); - - rButton.SetModeImage( aImage ); - } - - //------------------------------------------------------------------ - void OBrowserLine::ShowBrowseButton( const Image& _rImage, sal_Bool _bPrimary ) - { - PushButton& rButton( impl_ensureButton( _bPrimary ) ); - if ( !!_rImage ) - rButton.SetModeImage( _rImage ); - } - - //------------------------------------------------------------------ - void OBrowserLine::ShowBrowseButton( sal_Bool _bPrimary ) - { - impl_ensureButton( _bPrimary ); - } - - //------------------------------------------------------------------ - void OBrowserLine::implHideBrowseButton( sal_Bool _bPrimary, bool _bReLayout ) - { - PushButton*& rpButton = _bPrimary ? m_pBrowseButton : m_pAdditionalBrowseButton; - - if ( rpButton ) - { - rpButton->Hide(); - delete rpButton; - rpButton = NULL; - } - - if ( _bReLayout ) - impl_layoutComponents(); - } - - //------------------------------------------------------------------ - void OBrowserLine::HideBrowseButton( sal_Bool _bPrimary ) - { - implHideBrowseButton( _bPrimary, true ); - } - - //------------------------------------------------------------------ - void OBrowserLine::SetTitleWidth(sal_uInt16 nWidth) - { - if (m_nNameWidth != nWidth+10) - { - m_nNameWidth = nWidth+10; - impl_layoutComponents(); - } - // #99102# --------- - FullFillTitleString(); - } - - //------------------------------------------------------------------ - void OBrowserLine::SetClickListener( IButtonClickListener* _pListener ) - { - m_pClickListener = _pListener; - } - - //------------------------------------------------------------------ - IMPL_LINK( OBrowserLine, OnButtonClicked, PushButton*, _pButton ) - { - if ( m_pClickListener ) - m_pClickListener->buttonClicked( this, _pButton == m_pBrowseButton ); - - return 0L; - } - - //------------------------------------------------------------------ - IMPL_LINK( OBrowserLine, OnButtonFocus, PushButton*, /*pPB*/ ) - { - if ( m_xControl.is() ) - { - try - { - Reference< XPropertyControlContext > xContext( m_xControl->getControlContext(), UNO_QUERY_THROW ); - xContext->focusGained( m_xControl ); - } - catch( const Exception& ) - { - DBG_UNHANDLED_EXCEPTION(); - } - } - return 0; - } -//............................................................................ -} // namespace pcr -//............................................................................ - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |