summaryrefslogtreecommitdiff
path: root/extensions/source/propctrlr/propertyeditor.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'extensions/source/propctrlr/propertyeditor.cxx')
-rw-r--r--extensions/source/propctrlr/propertyeditor.cxx544
1 files changed, 0 insertions, 544 deletions
diff --git a/extensions/source/propctrlr/propertyeditor.cxx b/extensions/source/propctrlr/propertyeditor.cxx
deleted file mode 100644
index 0a50fff7f..000000000
--- a/extensions/source/propctrlr/propertyeditor.cxx
+++ /dev/null
@@ -1,544 +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 "propertyeditor.hxx"
-#include "browserpage.hxx"
-#include "linedescriptor.hxx"
-
-/** === begin UNO includes === **/
-/** === end UNO includes === **/
-#include <tools/debug.hxx>
-
-//............................................................................
-namespace pcr
-{
-//............................................................................
-
- #define LAYOUT_BORDER_LEFT 3
- #define LAYOUT_BORDER_TOP 3
- #define LAYOUT_BORDER_RIGHT 3
- #define LAYOUT_BORDER_BOTTOM 3
-
- /** === begin UNO using === **/
- using ::com::sun::star::uno::Any;
- using ::com::sun::star::inspection::XPropertyControl;
- using ::com::sun::star::uno::Reference;
- /** === end UNO using === **/
-
- //==================================================================
- // class OPropertyEditor
- //==================================================================
- DBG_NAME(OPropertyEditor)
- //------------------------------------------------------------------
- OPropertyEditor::OPropertyEditor( Window* pParent, WinBits nWinStyle)
- :Control(pParent, nWinStyle)
- ,m_aTabControl( this )
- ,m_nNextId(1)
- ,m_bHasHelpSection( false )
- ,m_nMinHelpLines( 0 )
- ,m_nMaxHelpLines( 0 )
- {
- DBG_CTOR(OPropertyEditor,NULL);
-
- m_aTabControl.Show();
- m_aTabControl.SetDeactivatePageHdl(LINK(this, OPropertyEditor, OnPageDeactivate));
- m_aTabControl.SetActivatePageHdl(LINK(this, OPropertyEditor, OnPageActivate));
- m_aTabControl.SetBackground(GetBackground());
- m_aTabControl.SetPaintTransparent(sal_True);
- }
-
- //------------------------------------------------------------------
- OPropertyEditor::~OPropertyEditor()
- {
- Hide();
- ClearAll();
- DBG_DTOR(OPropertyEditor,NULL);
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::ClearAll()
- {
- m_nNextId=1;
- sal_uInt16 nCount = m_aTabControl.GetPageCount();
- for(long i = nCount-1; i >= 0; --i)
- {
- sal_uInt16 nID = m_aTabControl.GetPageId((sal_uInt16)i);
- OBrowserPage* pPage = static_cast<OBrowserPage*>(m_aTabControl.GetTabPage(nID));
- if (pPage)
- {
- pPage->EnableInput(sal_False);
- m_aTabControl.RemovePage(nID);
- delete pPage;
- }
- }
- m_aTabControl.Clear();
-
- {
- MapStringToPageId aEmpty;
- m_aPropertyPageIds.swap( aEmpty );
- }
-
- while ( !m_aHiddenPages.empty() )
- {
- delete m_aHiddenPages.begin()->second.pPage;
- m_aHiddenPages.erase( m_aHiddenPages.begin() );
- }
- }
-
- //------------------------------------------------------------------
- sal_Int32 OPropertyEditor::getMinimumHeight()
- {
- sal_Int32 nMinHeight( LAYOUT_BORDER_TOP + LAYOUT_BORDER_BOTTOM );
-
- if ( m_aTabControl.GetPageCount() > 0 )
- {
- sal_uInt16 nFirstID = m_aTabControl.GetPageId( 0 );
-
- // reserve space for the tabs themself
- Rectangle aTabArea( m_aTabControl.GetTabBounds( nFirstID ) );
- nMinHeight += aTabArea.GetHeight();
-
- // ask the page how much it requires
- OBrowserPage* pPage = static_cast< OBrowserPage* >( m_aTabControl.GetTabPage( nFirstID ) );
- if ( pPage )
- nMinHeight += pPage->getMinimumHeight();
- }
- else
- nMinHeight += 250; // arbitrary ...
-
- return nMinHeight;
- }
-
- //------------------------------------------------------------------
- sal_Int32 OPropertyEditor::getMinimumWidth()
- {
- sal_uInt16 nCount = m_aTabControl.GetPageCount();
- sal_Int32 nPageMinWidth = 0;
- for(long i = nCount-1; i >= 0; --i)
- {
- sal_uInt16 nID = m_aTabControl.GetPageId((sal_uInt16)i);
- OBrowserPage* pPage = static_cast<OBrowserPage*>(m_aTabControl.GetTabPage(nID));
- if (pPage)
- {
- sal_Int32 nCurPageMinWidth = pPage->getMinimumWidth();
- if( nCurPageMinWidth > nPageMinWidth )
- nPageMinWidth = nCurPageMinWidth;
- }
- }
- return nPageMinWidth+6;
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::CommitModified()
- {
- // commit all of my pages, if necessary
-
- sal_uInt16 nCount = m_aTabControl.GetPageCount();
- for ( sal_uInt16 i=0; i<nCount; ++i )
- {
- sal_uInt16 nID = m_aTabControl.GetPageId( i );
- OBrowserPage* pPage = static_cast< OBrowserPage* >( m_aTabControl.GetTabPage( nID ) );
-
- if ( pPage && pPage->getListBox().IsModified() )
- pPage->getListBox().CommitModified();
- }
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::GetFocus()
- {
- m_aTabControl.GrabFocus();
- }
-
- //------------------------------------------------------------------
- OBrowserPage* OPropertyEditor::getPage( const ::rtl::OUString& _rPropertyName )
- {
- OBrowserPage* pPage = NULL;
- MapStringToPageId::const_iterator aPropertyPageIdPos = m_aPropertyPageIds.find( _rPropertyName );
- if ( aPropertyPageIdPos != m_aPropertyPageIds.end() )
- pPage = static_cast< OBrowserPage* >( m_aTabControl.GetTabPage( aPropertyPageIdPos->second ) );
- return pPage;
- }
-
- //------------------------------------------------------------------
- const OBrowserPage* OPropertyEditor::getPage( const ::rtl::OUString& _rPropertyName ) const
- {
- return const_cast< OPropertyEditor* >( this )->getPage( _rPropertyName );
- }
-
- //------------------------------------------------------------------
- OBrowserPage* OPropertyEditor::getPage( sal_uInt16& _rPageId )
- {
- return static_cast< OBrowserPage* >( m_aTabControl.GetTabPage( _rPageId ) );
- }
-
- //------------------------------------------------------------------
- const OBrowserPage* OPropertyEditor::getPage( sal_uInt16& _rPageId ) const
- {
- return const_cast< OPropertyEditor* >( this )->getPage( _rPageId );
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::Resize()
- {
- Rectangle aPlayground(
- Point( LAYOUT_BORDER_LEFT, LAYOUT_BORDER_TOP ),
- Size(
- GetOutputSizePixel().Width() - LAYOUT_BORDER_LEFT - LAYOUT_BORDER_RIGHT,
- GetOutputSizePixel().Height() - LAYOUT_BORDER_TOP - LAYOUT_BORDER_BOTTOM
- )
- );
-
- Rectangle aTabArea( aPlayground );
- m_aTabControl.SetPosSizePixel( aTabArea.TopLeft(), aTabArea.GetSize() );
- }
-
- //------------------------------------------------------------------
- sal_uInt16 OPropertyEditor::AppendPage( const String & _rText, const rtl::OString& _rHelpId )
- {
- // obtain a new id
- sal_uInt16 nId = m_nNextId++;
- // insert the id
- m_aTabControl.InsertPage(nId, _rText);
-
- // create a new page
- OBrowserPage* pPage = new OBrowserPage(&m_aTabControl);
- pPage->SetText( _rText );
- // some knittings
- pPage->SetSizePixel(m_aTabControl.GetTabPageSizePixel());
- pPage->getListBox().SetListener(m_pListener);
- pPage->getListBox().SetObserver(m_pObserver);
- pPage->getListBox().EnableHelpSection( m_bHasHelpSection );
- pPage->getListBox().SetHelpLineLimites( m_nMinHelpLines, m_nMaxHelpLines );
- pPage->SetHelpId( _rHelpId );
-
- // immediately activate the page
- m_aTabControl.SetTabPage(nId, pPage);
- m_aTabControl.SetCurPageId(nId);
-
- return nId;
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::SetHelpId( const rtl::OString& rHelpId )
- {
- Control::SetHelpId("");
- m_aTabControl.SetHelpId(rHelpId);
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::RemovePage(sal_uInt16 nID)
- {
- OBrowserPage* pPage = static_cast<OBrowserPage*>(m_aTabControl.GetTabPage(nID));
-
- if (pPage)
- pPage->EnableInput(sal_False);
- m_aTabControl.RemovePage(nID);
- if (pPage)
- delete pPage;
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::SetPage(sal_uInt16 nId)
- {
- m_aTabControl.SetCurPageId(nId);
- }
-
- //------------------------------------------------------------------
- sal_uInt16 OPropertyEditor::GetCurPage()
- {
- if(m_aTabControl.GetPageCount()>0)
- return m_aTabControl.GetCurPageId();
- else
- return 0;
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::Update(const ::std::mem_fun_t<void,OBrowserListBox>& _aUpdateFunction)
- {
- // forward this to all our pages
- sal_uInt16 nCount = m_aTabControl.GetPageCount();
- for (sal_uInt16 i=0;i<nCount;++i)
- {
- sal_uInt16 nID = m_aTabControl.GetPageId(i);
- OBrowserPage* pPage = static_cast<OBrowserPage*>(m_aTabControl.GetTabPage(nID));
- if (pPage)
- _aUpdateFunction(&pPage->getListBox());
- }
- }
- //------------------------------------------------------------------
- void OPropertyEditor::EnableUpdate()
- {
- Update(::std::mem_fun(&OBrowserListBox::EnableUpdate));
- }
- //------------------------------------------------------------------
- void OPropertyEditor::DisableUpdate()
- {
- Update(::std::mem_fun(&OBrowserListBox::DisableUpdate));
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::forEachPage( PageOperation _pOperation, const void* _pArgument )
- {
- sal_uInt16 nCount = m_aTabControl.GetPageCount();
- for ( sal_uInt16 i=0; i<nCount; ++i )
- {
- sal_uInt16 nID = m_aTabControl.GetPageId(i);
- OBrowserPage* pPage = static_cast< OBrowserPage* >( m_aTabControl.GetTabPage( nID ) );
- if ( !pPage )
- continue;
- (this->*_pOperation)( *pPage, _pArgument );
- }
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::setPageLineListener( OBrowserPage& _rPage, const void* )
- {
- _rPage.getListBox().SetListener( m_pListener );
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::SetLineListener(IPropertyLineListener* _pListener)
- {
- m_pListener = _pListener;
- forEachPage( &OPropertyEditor::setPageLineListener );
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::setPageControlObserver( OBrowserPage& _rPage, const void* )
- {
- _rPage.getListBox().SetObserver( m_pObserver );
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::SetControlObserver( IPropertyControlObserver* _pObserver )
- {
- m_pObserver = _pObserver;
- forEachPage( &OPropertyEditor::setPageControlObserver );
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::EnableHelpSection( bool _bEnable )
- {
- m_bHasHelpSection = _bEnable;
- forEachPage( &OPropertyEditor::enableHelpSection );
- }
-
- //------------------------------------------------------------------
- bool OPropertyEditor::HasHelpSection() const
- {
- return m_bHasHelpSection;
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::SetHelpText( const ::rtl::OUString& _rHelpText )
- {
- forEachPage( &OPropertyEditor::setHelpSectionText, &_rHelpText );
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::SetHelpLineLimites( sal_Int32 _nMinLines, sal_Int32 _nMaxLines )
- {
- m_nMinHelpLines = _nMinLines;
- m_nMaxHelpLines = _nMaxLines;
- forEachPage( &OPropertyEditor::setHelpLineLimits );
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::enableHelpSection( OBrowserPage& _rPage, const void* )
- {
- _rPage.getListBox().EnableHelpSection( m_bHasHelpSection );
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::setHelpSectionText( OBrowserPage& _rPage, const void* _pPointerToOUString )
- {
- OSL_ENSURE( _pPointerToOUString, "OPropertyEditor::setHelpSectionText: invalid argument!" );
- if ( !_pPointerToOUString )
- return;
-
- const ::rtl::OUString& rText( *(const ::rtl::OUString*)_pPointerToOUString );
- _rPage.getListBox().SetHelpText( rText );
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::setHelpLineLimits( OBrowserPage& _rPage, const void* )
- {
- _rPage.getListBox().SetHelpLineLimites( m_nMinHelpLines, m_nMaxHelpLines );
- }
-
- //------------------------------------------------------------------
- sal_uInt16 OPropertyEditor::InsertEntry( const OLineDescriptor& rData, sal_uInt16 _nPageId, sal_uInt16 nPos )
- {
- // let the current page handle this
- OBrowserPage* pPage = getPage( _nPageId );
- DBG_ASSERT( pPage, "OPropertyEditor::InsertEntry: don't have such a page!" );
- if ( !pPage )
- return LISTBOX_ENTRY_NOTFOUND;
-
- sal_uInt16 nEntry = pPage->getListBox().InsertEntry( rData, nPos );
-
- OSL_ENSURE( m_aPropertyPageIds.find( rData.sName ) == m_aPropertyPageIds.end(),
- "OPropertyEditor::InsertEntry: property already present in the map!" );
- m_aPropertyPageIds.insert( MapStringToPageId::value_type( rData.sName, _nPageId ) );
-
- return nEntry;
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::RemoveEntry( const ::rtl::OUString& _rName )
- {
- OBrowserPage* pPage = getPage( _rName );
- if ( pPage )
- {
- OSL_VERIFY( pPage->getListBox().RemoveEntry( _rName ) );
-
- OSL_ENSURE( m_aPropertyPageIds.find( _rName ) != m_aPropertyPageIds.end(),
- "OPropertyEditor::RemoveEntry: property not present in the map!" );
- m_aPropertyPageIds.erase( _rName );
- }
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::ChangeEntry( const OLineDescriptor& rData )
- {
- OBrowserPage* pPage = getPage( rData.sName );
- if ( pPage )
- pPage->getListBox().ChangeEntry( rData, EDITOR_LIST_REPLACE_EXISTING );
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::SetPropertyValue( const ::rtl::OUString& rEntryName, const Any& _rValue, bool _bUnknownValue )
- {
- OBrowserPage* pPage = getPage( rEntryName );
- if ( pPage )
- pPage->getListBox().SetPropertyValue( rEntryName, _rValue, _bUnknownValue );
- }
-
- //------------------------------------------------------------------
- sal_uInt16 OPropertyEditor::GetPropertyPos( const ::rtl::OUString& rEntryName ) const
- {
- sal_uInt16 nVal=LISTBOX_ENTRY_NOTFOUND;
- const OBrowserPage* pPage = getPage( rEntryName );
- if ( pPage )
- nVal = pPage->getListBox().GetPropertyPos( rEntryName );
- return nVal;
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::ShowPropertyPage( sal_uInt16 _nPageId, bool _bShow )
- {
- if ( !_bShow )
- {
- sal_uInt16 nPagePos = m_aTabControl.GetPagePos( _nPageId );
- if ( TAB_PAGE_NOTFOUND == nPagePos )
- return;
- DBG_ASSERT( m_aHiddenPages.find( _nPageId ) == m_aHiddenPages.end(), "OPropertyEditor::ShowPropertyPage: page already hidden!" );
-
- m_aHiddenPages[ _nPageId ] = HiddenPage( nPagePos, m_aTabControl.GetTabPage( _nPageId ) );
- m_aTabControl.RemovePage( _nPageId );
- }
- else
- {
- ::std::map< sal_uInt16, HiddenPage >::iterator aPagePos = m_aHiddenPages.find( _nPageId );
- if ( aPagePos == m_aHiddenPages.end() )
- return;
-
- aPagePos->second.pPage->SetSizePixel( m_aTabControl.GetTabPageSizePixel() );
- m_aTabControl.InsertPage( aPagePos->first, aPagePos->second.pPage->GetText(), aPagePos->second.nPos );
- m_aTabControl.SetTabPage( aPagePos->first, aPagePos->second.pPage );
-
- m_aHiddenPages.erase( aPagePos );
- }
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::EnablePropertyControls( const ::rtl::OUString& _rEntryName, sal_Int16 _nControls, bool _bEnable )
- {
- for ( sal_uInt16 i = 0; i < m_aTabControl.GetPageCount(); ++i )
- {
- OBrowserPage* pPage = static_cast< OBrowserPage* >( m_aTabControl.GetTabPage( m_aTabControl.GetPageId( i ) ) );
- if ( pPage )
- pPage->getListBox().EnablePropertyControls( _rEntryName, _nControls, _bEnable );
- }
- }
-
- //------------------------------------------------------------------
- void OPropertyEditor::EnablePropertyLine( const ::rtl::OUString& _rEntryName, bool _bEnable )
- {
- for ( sal_uInt16 i = 0; i < m_aTabControl.GetPageCount(); ++i )
- {
- OBrowserPage* pPage = static_cast< OBrowserPage* >( m_aTabControl.GetTabPage( m_aTabControl.GetPageId( i ) ) );
- if ( pPage )
- pPage->getListBox().EnablePropertyLine( _rEntryName, _bEnable );
- }
- }
-
- //------------------------------------------------------------------
- Reference< XPropertyControl > OPropertyEditor::GetPropertyControl(const ::rtl::OUString& rEntryName)
- {
- Reference< XPropertyControl > xControl;
- // let the current page handle this
- OBrowserPage* pPage = static_cast<OBrowserPage*>(m_aTabControl.GetTabPage(m_aTabControl.GetCurPageId()));
- if (pPage)
- xControl = pPage->getListBox().GetPropertyControl(rEntryName);
- return xControl;
- }
-
- //------------------------------------------------------------------
- IMPL_LINK(OPropertyEditor, OnPageActivate, TabControl*, EMPTYARG)
- {
- if (m_aPageActivationHandler.IsSet())
- m_aPageActivationHandler.Call(NULL);
- return 0L;
- }
-
- //------------------------------------------------------------------
- IMPL_LINK(OPropertyEditor, OnPageDeactivate, TabControl*, EMPTYARG)
- {
- // commit the data on the current (to-be-decativated) tab page
- // (79404)
- sal_Int32 nCurrentId = m_aTabControl.GetCurPageId();
- OBrowserPage* pCurrentPage = static_cast<OBrowserPage*>(m_aTabControl.GetTabPage((sal_uInt16)nCurrentId));
- if ( !pCurrentPage )
- return 1L;
-
- if ( pCurrentPage->getListBox().IsModified() )
- pCurrentPage->getListBox().CommitModified();
-
- return 1L;
- }
-
-//............................................................................
-} // namespace pcr
-//............................................................................
-
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */