summaryrefslogtreecommitdiff
path: root/dbaccess/source/ui/app/AppDetailView.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'dbaccess/source/ui/app/AppDetailView.cxx')
-rw-r--r--dbaccess/source/ui/app/AppDetailView.cxx963
1 files changed, 0 insertions, 963 deletions
diff --git a/dbaccess/source/ui/app/AppDetailView.cxx b/dbaccess/source/ui/app/AppDetailView.cxx
deleted file mode 100644
index 21fe3cab5..000000000
--- a/dbaccess/source/ui/app/AppDetailView.cxx
+++ /dev/null
@@ -1,963 +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_dbaccess.hxx"
-#include "AppDetailView.hxx"
-#include <osl/diagnose.h>
-#include "dbaccess_helpid.hrc"
-#include "dbu_app.hrc"
-#include "AppView.hxx"
-#include <com/sun/star/ui/XUIConfigurationManager.hpp>
-#include <com/sun/star/ui/XModuleUIConfigurationManagerSupplier.hpp>
-#include <com/sun/star/ui/XImageManager.hpp>
-#include <com/sun/star/ui/ImageType.hpp>
-#include <com/sun/star/sdbcx/XViewsSupplier.hpp>
-#include <com/sun/star/graphic/XGraphic.hpp>
-#include <com/sun/star/util/URL.hpp>
-#include "listviewitems.hxx"
-#include <vcl/image.hxx>
-#include <vcl/mnemonic.hxx>
-#include <vcl/mnemonic.hxx>
-#include "browserids.hxx"
-#include "AppDetailPageHelper.hxx"
-#include <vcl/svapp.hxx>
-#include "callbacks.hxx"
-#include "IController.hxx"
-#include "moduledbu.hxx"
-#include <svtools/localresaccess.hxx>
-#include <algorithm>
-#include "dbtreelistbox.hxx"
-#include "IApplicationController.hxx"
-#include "imageprovider.hxx"
-
-using namespace ::dbaui;
-using namespace ::com::sun::star::uno;
-using namespace ::com::sun::star::sdbc;
-using namespace ::com::sun::star::sdbcx;
-using namespace ::com::sun::star::lang;
-using namespace ::com::sun::star::ucb;
-using namespace ::com::sun::star::graphic;
-using namespace ::com::sun::star::ui;
-using namespace ::com::sun::star::container;
-using namespace ::com::sun::star::beans;
-using ::com::sun::star::util::URL;
-using ::com::sun::star::sdb::application::NamedDatabaseObject;
-
-#define SPACEBETWEENENTRIES 4
-
-// -----------------------------------------------------------------------------
-TaskEntry::TaskEntry( const sal_Char* _pAsciiUNOCommand, sal_uInt16 _nHelpID, sal_uInt16 _nTitleResourceID, bool _bHideWhenDisabled )
- :sUNOCommand( ::rtl::OUString::createFromAscii( _pAsciiUNOCommand ) )
- ,nHelpID( _nHelpID )
- ,sTitle( ModuleRes( _nTitleResourceID ) )
- ,bHideWhenDisabled( _bHideWhenDisabled )
-{
-}
-
-// -----------------------------------------------------------------------------
-OCreationList::OCreationList( OTasksWindow& _rParent )
- :SvTreeListBox( &_rParent, WB_TABSTOP | WB_HASBUTTONSATROOT | WB_HASBUTTONS )
- ,m_rTaskWindow( _rParent )
- ,m_pMouseDownEntry( NULL )
- ,m_pLastActiveEntry( NULL )
-{
- sal_uInt16 nSize = SPACEBETWEENENTRIES;
- SetSpaceBetweenEntries(nSize);
- SetSelectionMode( NO_SELECTION );
- SetExtendedWinBits( EWB_NO_AUTO_CURENTRY );
- SetNodeDefaultImages( );
- EnableEntryMnemonics();
-}
-// -----------------------------------------------------------------------------
-void OCreationList::Paint( const Rectangle& _rRect )
-{
- if ( m_pMouseDownEntry )
- m_aOriginalFont = GetFont();
-
- m_aOriginalBackgroundColor = GetBackground().GetColor();
- SvTreeListBox::Paint( _rRect );
- SetBackground( m_aOriginalBackgroundColor );
-
- if ( m_pMouseDownEntry )
- Control::SetFont( m_aOriginalFont );
-}
-
-// -----------------------------------------------------------------------------
-void OCreationList::PreparePaint( SvLBoxEntry* _pEntry )
-{
- Wallpaper aEntryBackground( m_aOriginalBackgroundColor );
- if ( _pEntry )
- {
- if ( _pEntry == GetCurEntry() )
- {
- // draw a selection background
- bool bIsMouseDownEntry = ( _pEntry == m_pMouseDownEntry );
- DrawSelectionBackground( GetBoundingRect( _pEntry ), bIsMouseDownEntry ? 1 : 2, sal_False, sal_True, sal_False );
-
- if ( bIsMouseDownEntry )
- {
- Font aFont( GetFont() );
- aFont.SetColor( GetSettings().GetStyleSettings().GetHighlightTextColor() );
- Control::SetFont( aFont );
- }
-
- // and temporary set a transparent background, for all the other
- // paint operations the SvTreeListBox is going to do
- aEntryBackground = Wallpaper( Color( COL_TRANSPARENT ) );
- }
- }
-
- SetBackground( aEntryBackground );
-}
-
-// -----------------------------------------------------------------------------
-void OCreationList::SelectSearchEntry( const void* _pEntry )
-{
- SvLBoxEntry* pEntry = const_cast< SvLBoxEntry* >( static_cast< const SvLBoxEntry* >( _pEntry ) );
- OSL_ENSURE( pEntry, "OCreationList::SelectSearchEntry: invalid entry!" );
-
- if ( pEntry )
- setCurrentEntryInvalidate( pEntry );
-
- if ( !HasChildPathFocus() )
- GrabFocus();
-}
-
-// -----------------------------------------------------------------------------
-void OCreationList::ExecuteSearchEntry( const void* _pEntry ) const
-{
- SvLBoxEntry* pEntry = const_cast< SvLBoxEntry* >( static_cast< const SvLBoxEntry* >( _pEntry ) );
- OSL_ENSURE( pEntry, "OCreationList::ExecuteSearchEntry: invalid entry!" );
- OSL_ENSURE( pEntry == GetCurEntry(), "OCreationList::ExecuteSearchEntry: SelectSearchEntry should have been called before!" );
-
- if ( pEntry )
- onSelected( pEntry );
-}
-
-// -----------------------------------------------------------------------------
-Rectangle OCreationList::GetFocusRect( SvLBoxEntry* _pEntry, long _nLine )
-{
- Rectangle aRect = SvTreeListBox::GetFocusRect( _pEntry, _nLine );
- aRect.Left() = 0;
-
- // try to let the focus rect start before the bitmap item - this looks better
- SvLBoxItem* pBitmapItem = _pEntry->GetFirstItem( SV_ITEM_ID_LBOXCONTEXTBMP );
- SvLBoxTab* pTab = pBitmapItem ? GetTab( _pEntry, pBitmapItem ) : NULL;
- SvViewDataItem* pItemData = pBitmapItem ? GetViewDataItem( _pEntry, pBitmapItem ) : NULL;
- OSL_ENSURE( pTab && pItemData, "OCreationList::GetFocusRect: could not find the first bitmap item!" );
- if ( pTab && pItemData )
- aRect.Left() = pTab->GetPos() - pItemData->aSize.Width() / 2;
-
- // inflate the rectangle a little bit - looks better, too
- aRect.Left() = ::std::max< long >( 0, aRect.Left() - 2 );
- aRect.Right() = ::std::min< long >( GetOutputSizePixel().Width() - 1, aRect.Right() + 2 );
-
- return aRect;
-}
-// -----------------------------------------------------------------------------
-void OCreationList::StartDrag( sal_Int8 /*_nAction*/, const Point& /*_rPosPixel*/ )
-{
- // don't give this to the base class, it does a ReleaseMouse as very first action
- // Though I think this is a bug (it should ReleaseMouse only if it is going to do
- // something with the drag-event), I hesitate to fix it in the current state,
- // since I don't overlook the consequences, and we're close to 2.0 ...)
-}
-// -----------------------------------------------------------------------------
-void OCreationList::ModelHasCleared()
-{
- SvTreeListBox::ModelHasCleared();
- m_pLastActiveEntry = NULL;
- m_pMouseDownEntry = NULL;
-}
-// -----------------------------------------------------------------------------
-void OCreationList::GetFocus()
-{
- SvTreeListBox::GetFocus();
- if ( !GetCurEntry() )
- setCurrentEntryInvalidate( m_pLastActiveEntry ? m_pLastActiveEntry : GetFirstEntryInView() );
-}
-// -----------------------------------------------------------------------------
-void OCreationList::LoseFocus()
-{
- SvTreeListBox::LoseFocus();
- m_pLastActiveEntry = GetCurEntry();
- setCurrentEntryInvalidate( NULL );
-}
-// -----------------------------------------------------------------------------
-void OCreationList::MouseButtonDown( const MouseEvent& rMEvt )
-{
- SvTreeListBox::MouseButtonDown( rMEvt );
-
- OSL_ENSURE( !m_pMouseDownEntry, "OCreationList::MouseButtonDown: I missed some mouse event!" );
- m_pMouseDownEntry = GetCurEntry();
- if ( m_pMouseDownEntry )
- {
- InvalidateEntry( m_pMouseDownEntry );
- CaptureMouse();
- }
-}
-// -----------------------------------------------------------------------------
-void OCreationList::MouseMove( const MouseEvent& rMEvt )
-{
- if ( rMEvt.IsLeaveWindow() )
- {
- setCurrentEntryInvalidate( NULL );
- }
- else if ( !rMEvt.IsSynthetic() )
- {
- SvLBoxEntry* pEntry = GetEntry( rMEvt.GetPosPixel() );
-
- if ( m_pMouseDownEntry )
- {
- // we're currently in a "mouse down" phase
- OSL_ENSURE( IsMouseCaptured(), "OCreationList::MouseMove: inconsistence (1)!" );
- if ( pEntry == m_pMouseDownEntry )
- {
- setCurrentEntryInvalidate( m_pMouseDownEntry );
- }
- else
- {
- OSL_ENSURE( ( GetCurEntry() == m_pMouseDownEntry ) || !GetCurEntry(),
- "OCreationList::MouseMove: inconsistence (2)!" );
- setCurrentEntryInvalidate( NULL );
- }
- }
- else
- {
- // the user is simply hovering with the mouse
- if ( setCurrentEntryInvalidate( pEntry ) )
- {
- if ( !m_pMouseDownEntry )
- updateHelpText();
- }
- }
- }
-
- SvTreeListBox::MouseMove(rMEvt);
-}
-// -----------------------------------------------------------------------------
-void OCreationList::MouseButtonUp( const MouseEvent& rMEvt )
-{
- SvLBoxEntry* pEntry = GetEntry( rMEvt.GetPosPixel() );
- bool bExecute = false;
- // Was the mouse released over the active entry?
- // (i.e. the entry which was under the mouse when the button went down)
- if ( pEntry && ( m_pMouseDownEntry == pEntry ) )
- {
- if ( !rMEvt.IsShift() && !rMEvt.IsMod1() && !rMEvt.IsMod2() && rMEvt.IsLeft() && rMEvt.GetClicks() == 1 )
- bExecute = true;
- }
-
- if ( m_pMouseDownEntry )
- {
- OSL_ENSURE( IsMouseCaptured(), "OCreationList::MouseButtonUp: hmmm .... no mouse captured, but an active entry?" );
- ReleaseMouse();
-
- InvalidateEntry( m_pMouseDownEntry );
- m_pMouseDownEntry = NULL;
- }
-
- SvTreeListBox::MouseButtonUp( rMEvt );
-
- if ( bExecute )
- onSelected( pEntry );
-}
-// -----------------------------------------------------------------------------
-bool OCreationList::setCurrentEntryInvalidate( SvLBoxEntry* _pEntry )
-{
- if ( GetCurEntry() != _pEntry )
- {
- if ( GetCurEntry() )
- InvalidateEntry( GetCurEntry() );
- SetCurEntry( _pEntry );
- if ( GetCurEntry() )
- {
- InvalidateEntry( GetCurEntry() );
- CallEventListeners( VCLEVENT_LISTBOX_SELECT, GetCurEntry() );
- }
- updateHelpText();
- return true;
- }
- return false;
-}
-// -----------------------------------------------------------------------------
-void OCreationList::updateHelpText()
-{
- sal_uInt16 nHelpTextId = 0;
- if ( GetCurEntry() )
- nHelpTextId = reinterpret_cast< TaskEntry* >( GetCurEntry()->GetUserData() )->nHelpID;
- m_rTaskWindow.setHelpText( nHelpTextId );
-}
-// -----------------------------------------------------------------------------
-void OCreationList::onSelected( SvLBoxEntry* _pEntry ) const
-{
- OSL_ENSURE( _pEntry, "OCreationList::onSelected: invalid entry!" );
- URL aCommand;
- aCommand.Complete = reinterpret_cast< TaskEntry* >( _pEntry->GetUserData() )->sUNOCommand;
- m_rTaskWindow.getDetailView()->getBorderWin().getView()->getAppController().executeChecked( aCommand, Sequence< PropertyValue >() );
-}
-// -----------------------------------------------------------------------------
-void OCreationList::KeyInput( const KeyEvent& rKEvt )
-{
- const KeyCode& rCode = rKEvt.GetKeyCode();
- if ( !rCode.IsMod1() && !rCode.IsMod2() && !rCode.IsShift() )
- {
- if ( rCode.GetCode() == KEY_RETURN )
- {
- SvLBoxEntry* pEntry = GetCurEntry() ? GetCurEntry() : FirstSelected();
- if ( pEntry )
- onSelected( pEntry );
- return;
- }
- }
- SvLBoxEntry* pOldCurrent = GetCurEntry();
- SvTreeListBox::KeyInput(rKEvt);
- SvLBoxEntry* pNewCurrent = GetCurEntry();
-
- if ( pOldCurrent != pNewCurrent )
- {
- if ( pOldCurrent )
- InvalidateEntry( pOldCurrent );
- if ( pNewCurrent )
- {
- InvalidateEntry( pNewCurrent );
- CallEventListeners( VCLEVENT_LISTBOX_SELECT, pNewCurrent );
- }
- updateHelpText();
- }
-}
-// -----------------------------------------------------------------------------
-DBG_NAME(OTasksWindow)
-OTasksWindow::OTasksWindow(Window* _pParent,OApplicationDetailView* _pDetailView)
- : Window(_pParent,WB_DIALOGCONTROL )
- ,m_aCreation(*this)
- ,m_aDescription(this)
- ,m_aHelpText(this,WB_WORDBREAK)
- ,m_aFL(this,WB_VERT)
- ,m_pDetailView(_pDetailView)
-{
- DBG_CTOR(OTasksWindow,NULL);
- SetUniqueId(UID_APP_TASKS_WINDOW);
- m_aCreation.SetHelpId(HID_APP_CREATION_LIST);
- m_aCreation.SetSelectHdl(LINK(this, OTasksWindow, OnEntrySelectHdl));
- m_aHelpText.SetHelpId(HID_APP_HELP_TEXT);
- m_aDescription.SetHelpId(HID_APP_DESCRIPTION_TEXT);
- m_aDescription.SetText(ModuleRes(STR_DESCRIPTION));
-
- ImageProvider aImageProvider;
- Image aFolderImage = aImageProvider.getFolderImage( DatabaseObject::FORM );
- m_aCreation.SetDefaultCollapsedEntryBmp( aFolderImage );
- m_aCreation.SetDefaultExpandedEntryBmp( aFolderImage );
-
- ImplInitSettings(sal_True,sal_True,sal_True);
-}
-// -----------------------------------------------------------------------------
-OTasksWindow::~OTasksWindow()
-{
- DBG_DTOR(OTasksWindow,NULL);
- Clear();
-}
-// -----------------------------------------------------------------------
-void OTasksWindow::DataChanged( const DataChangedEvent& rDCEvt )
-{
- DBG_CHKTHIS(OTasksWindow,NULL);
- Window::DataChanged( rDCEvt );
-
- if ( (rDCEvt.GetType() == DATACHANGED_SETTINGS) &&
- (rDCEvt.GetFlags() & SETTINGS_STYLE) )
- {
- ImplInitSettings( sal_True, sal_True, sal_True );
- Invalidate();
- }
-}
-// -----------------------------------------------------------------------------
-void OTasksWindow::ImplInitSettings( sal_Bool bFont, sal_Bool bForeground, sal_Bool bBackground )
-{
- DBG_CHKTHIS(OTasksWindow,NULL);
- const StyleSettings& rStyleSettings = GetSettings().GetStyleSettings();
- if( bFont )
- {
- Font aFont;
- aFont = rStyleSettings.GetFieldFont();
- aFont.SetColor( rStyleSettings.GetWindowTextColor() );
- SetPointFont( aFont );
- }
-
- if( bForeground || bFont )
- {
- SetTextColor( rStyleSettings.GetFieldTextColor() );
- SetTextFillColor();
- m_aHelpText.SetTextColor( rStyleSettings.GetFieldTextColor() );
- m_aHelpText.SetTextFillColor();
- m_aDescription.SetTextColor( rStyleSettings.GetFieldTextColor() );
- m_aDescription.SetTextFillColor();
- }
-
- if( bBackground )
- {
- SetBackground( rStyleSettings.GetFieldColor() );
- m_aHelpText.SetBackground( rStyleSettings.GetFieldColor() );
- m_aDescription.SetBackground( rStyleSettings.GetFieldColor() );
- m_aFL.SetBackground( rStyleSettings.GetFieldColor() );
- }
-
- Font aFont = m_aDescription.GetControlFont();
- aFont.SetWeight(WEIGHT_BOLD);
- m_aDescription.SetControlFont(aFont);
-}
-// -----------------------------------------------------------------------------
-void OTasksWindow::setHelpText(sal_uInt16 _nId)
-{
- DBG_CHKTHIS(OTasksWindow,NULL);
- if ( _nId )
- {
- String sText = ModuleRes(_nId);
-
- m_aHelpText.SetText(sText);
- }
- else
- {
- m_aHelpText.SetText(String());
-}
-}
-// -----------------------------------------------------------------------------
-IMPL_LINK(OTasksWindow, OnEntrySelectHdl, SvTreeListBox*, /*_pTreeBox*/)
-{
- DBG_CHKTHIS(OTasksWindow,NULL);
- SvLBoxEntry* pEntry = m_aCreation.GetHdlEntry();
- if ( pEntry )
- m_aHelpText.SetText( ModuleRes( reinterpret_cast< TaskEntry* >( pEntry->GetUserData() )->nHelpID ) );
- return 1L;
-}
-// -----------------------------------------------------------------------------
-void OTasksWindow::Resize()
-{
- DBG_CHKTHIS(OTasksWindow,NULL);
-
- // parent window dimension
- Size aOutputSize( GetOutputSize() );
- long nOutputWidth = aOutputSize.Width();
- long nOutputHeight = aOutputSize.Height();
-
- Size aFLSize = LogicToPixel( Size( 2, 6 ), MAP_APPFONT );
- sal_Int32 n6PPT = aFLSize.Height();
- long nHalfOutputWidth = static_cast<long>(nOutputWidth * 0.5);
-
- m_aCreation.SetPosSizePixel( Point(0, 0), Size(nHalfOutputWidth - n6PPT, nOutputHeight) );
- // i77897 make the m_aHelpText a little bit smaller. (-5)
- sal_Int32 nNewWidth = nOutputWidth - nHalfOutputWidth - aFLSize.Width() - 5;
- m_aDescription.SetPosSizePixel( Point(nHalfOutputWidth + n6PPT, 0), Size(nNewWidth, nOutputHeight) );
- Size aDesc = m_aDescription.CalcMinimumSize();
- m_aHelpText.SetPosSizePixel( Point(nHalfOutputWidth + n6PPT, aDesc.Height() ), Size(nNewWidth, nOutputHeight - aDesc.Height() - n6PPT) );
-
- m_aFL.SetPosSizePixel( Point(nHalfOutputWidth , 0), Size(aFLSize.Width(), nOutputHeight ) );
-}
-// -----------------------------------------------------------------------------
-void OTasksWindow::fillTaskEntryList( const TaskEntryList& _rList )
-{
- DBG_CHKTHIS(OTasksWindow,NULL);
- Clear();
-
- try
- {
- Reference< XModuleUIConfigurationManagerSupplier > xModuleCfgMgrSupplier(
- getDetailView()->getBorderWin().getView()->getORB()->createInstance(
- ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.ui.ModuleUIConfigurationManagerSupplier" ) )
- ) ,
- UNO_QUERY
- );
- Reference< XUIConfigurationManager > xUIConfigMgr = xModuleCfgMgrSupplier->getUIConfigurationManager(
- ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.sdb.OfficeDatabaseDocument" ) )
- );
- Reference< XImageManager > xImageMgr( xUIConfigMgr->getImageManager(), UNO_QUERY );
-
- // copy the commands so we can use them with the config managers
- Sequence< ::rtl::OUString > aCommands( _rList.size() );
- ::rtl::OUString* pCommands = aCommands.getArray();
- TaskEntryList::const_iterator aEnd = _rList.end();
- for ( TaskEntryList::const_iterator pCopyTask = _rList.begin(); pCopyTask != aEnd; ++pCopyTask, ++pCommands )
- *pCommands = pCopyTask->sUNOCommand;
-
- Sequence< Reference< XGraphic> > aImages = xImageMgr->getImages(
- ImageType::SIZE_DEFAULT | ImageType::COLOR_NORMAL ,
- aCommands
- );
-
- const Reference< XGraphic >* pImages( aImages.getConstArray() );
-
- for ( TaskEntryList::const_iterator pTask = _rList.begin(); pTask != aEnd; ++pTask, ++pImages )
- {
- SvLBoxEntry* pEntry = m_aCreation.InsertEntry( pTask->sTitle );
- pEntry->SetUserData( reinterpret_cast< void* >( new TaskEntry( *pTask ) ) );
-
- Image aImage = Image( *pImages );
- m_aCreation.SetExpandedEntryBmp( pEntry, aImage );
- m_aCreation.SetCollapsedEntryBmp( pEntry, aImage );
- }
- }
- catch(Exception&)
- {
- }
-
- m_aCreation.Show();
- m_aCreation.SelectAll(sal_False);
- m_aHelpText.Show();
- m_aDescription.Show();
- m_aFL.Show();
- m_aCreation.updateHelpText();
- Enable(!_rList.empty());
-}
-// -----------------------------------------------------------------------------
-void OTasksWindow::Clear()
-{
- DBG_CHKTHIS(OTasksWindow,NULL);
- m_aCreation.resetLastActive();
- SvLBoxEntry* pEntry = m_aCreation.First();
- while ( pEntry )
- {
- delete reinterpret_cast< TaskEntry* >( pEntry->GetUserData() );
- pEntry = m_aCreation.Next(pEntry);
- }
- m_aCreation.Clear();
-}
-//==================================================================
-// class OApplicationDetailView
-//==================================================================
-DBG_NAME(OApplicationDetailView)
-OApplicationDetailView::OApplicationDetailView(OAppBorderWindow& _rParent,PreviewMode _ePreviewMode) : OSplitterView(&_rParent,sal_False )
- ,m_aHorzSplitter(this)
- ,m_aTasks(this,STR_TASKS,WB_BORDER | WB_DIALOGCONTROL )
- ,m_aContainer(this,0,WB_BORDER | WB_DIALOGCONTROL )
- ,m_rBorderWin(_rParent)
-{
- DBG_CTOR(OApplicationDetailView,NULL);
- SetUniqueId(UID_APP_DETAIL_VIEW);
- ImplInitSettings( sal_True, sal_True, sal_True );
-
- m_pControlHelper = new OAppDetailPageHelper(&m_aContainer,m_rBorderWin,_ePreviewMode);
- m_pControlHelper->Show();
- m_aContainer.setChildWindow(m_pControlHelper);
-
- OTasksWindow* pTasks = new OTasksWindow(&m_aTasks,this);
- pTasks->Show();
- pTasks->Disable(m_rBorderWin.getView()->getCommandController().isDataSourceReadOnly());
- m_aTasks.setChildWindow(pTasks);
- m_aTasks.SetUniqueId(UID_APP_TASKS_VIEW);
- m_aTasks.Show();
-
- m_aContainer.SetUniqueId(UID_APP_CONTAINER_VIEW);
- m_aContainer.Show();
-
- const long nFrameWidth = LogicToPixel( Size( 3, 0 ), MAP_APPFONT ).Width();
- m_aHorzSplitter.SetPosSizePixel( Point(0,50), Size(0,nFrameWidth) );
- // now set the components at the base class
- set(&m_aContainer,&m_aTasks);
-
- m_aHorzSplitter.Show();
- m_aHorzSplitter.SetUniqueId(UID_APP_VIEW_HORZ_SPLIT);
- setSplitter(&m_aHorzSplitter);
-}
-// -----------------------------------------------------------------------------
-OApplicationDetailView::~OApplicationDetailView()
-{
- DBG_DTOR(OApplicationDetailView,NULL);
- set(NULL,NULL);
- setSplitter(NULL);
- m_pControlHelper = NULL;
-}
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::ImplInitSettings( sal_Bool bFont, sal_Bool bForeground, sal_Bool bBackground )
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- const StyleSettings& rStyleSettings = GetSettings().GetStyleSettings();
- if( bFont )
- {
- Font aFont;
- aFont = rStyleSettings.GetFieldFont();
- aFont.SetColor( rStyleSettings.GetWindowTextColor() );
- SetPointFont( aFont );
- }
-
- if( bForeground || bFont )
- {
- SetTextColor( rStyleSettings.GetFieldTextColor() );
- SetTextFillColor();
- }
-
- if( bBackground )
- SetBackground( rStyleSettings.GetFieldColor() );
-
- m_aHorzSplitter.SetBackground( rStyleSettings.GetDialogColor() );
- m_aHorzSplitter.SetFillColor( rStyleSettings.GetDialogColor() );
- m_aHorzSplitter.SetTextFillColor(rStyleSettings.GetDialogColor() );
-}
-// -----------------------------------------------------------------------
-void OApplicationDetailView::DataChanged( const DataChangedEvent& rDCEvt )
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- OSplitterView::DataChanged( rDCEvt );
-
- if ( (rDCEvt.GetType() == DATACHANGED_FONTS) ||
- (rDCEvt.GetType() == DATACHANGED_DISPLAY) ||
- (rDCEvt.GetType() == DATACHANGED_FONTSUBSTITUTION) ||
- ((rDCEvt.GetType() == DATACHANGED_SETTINGS) &&
- (rDCEvt.GetFlags() & SETTINGS_STYLE)) )
- {
- ImplInitSettings( sal_True, sal_True, sal_True );
- Invalidate();
- }
-}
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::GetFocus()
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- OSplitterView::GetFocus();
-}
-
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::setTaskExternalMnemonics( MnemonicGenerator& _rMnemonics )
-{
- m_aExternalMnemonics = _rMnemonics;
-}
-
-// -----------------------------------------------------------------------------
-bool OApplicationDetailView::interceptKeyInput( const KeyEvent& _rEvent )
-{
- const KeyCode& rKeyCode = _rEvent.GetKeyCode();
- if ( rKeyCode.GetModifier() == KEY_MOD2 )
- return getTasksWindow().HandleKeyInput( _rEvent );
-
- // not handled
- return false;
-}
-
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::createTablesPage(const Reference< XConnection >& _xConnection )
-{
- impl_createPage( E_TABLE, _xConnection, NULL );
-}
-
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::createPage( ElementType _eType,const Reference< XNameAccess >& _xContainer )
-{
- impl_createPage( _eType, NULL, _xContainer );
-}
-
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::impl_createPage( ElementType _eType, const Reference< XConnection >& _rxConnection,
- const Reference< XNameAccess >& _rxNonTableElements )
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
-
- // get the data for the pane
- const TaskPaneData& rData = impl_getTaskPaneData( _eType );
- getTasksWindow().fillTaskEntryList( rData.aTasks );
-
- // enable the pane as a whole, depending on the availability of the first command
- OSL_ENSURE( !rData.aTasks.empty(), "OApplicationDetailView::impl_createPage: no tasks at all!?" );
- bool bEnabled = rData.aTasks.empty()
- ? false
- : getBorderWin().getView()->getCommandController().isCommandEnabled( rData.aTasks[0].sUNOCommand );
- getTasksWindow().Enable( bEnabled );
- m_aContainer.setTitle( rData.nTitleId );
-
- // let our helper create the object list
- if ( _eType == E_TABLE )
- m_pControlHelper->createTablesPage( _rxConnection );
- else
- m_pControlHelper->createPage( _eType, _rxNonTableElements );
-
- // resize for proper window arrangements
- Resize();
-}
-
-// -----------------------------------------------------------------------------
-const TaskPaneData& OApplicationDetailView::impl_getTaskPaneData( ElementType _eType )
-{
- if ( m_aTaskPaneData.empty() )
- m_aTaskPaneData.resize( ELEMENT_COUNT );
- OSL_ENSURE( ( _eType >= 0 ) && ( _eType < E_ELEMENT_TYPE_COUNT ), "OApplicationDetailView::impl_getTaskPaneData: illegal element type!" );
- TaskPaneData& rData = m_aTaskPaneData[ _eType ];
-
- //oj: do not check, otherwise extensions will only be visible after a reload.
- impl_fillTaskPaneData( _eType, rData );
-
- return rData;
-}
-
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::impl_fillTaskPaneData( ElementType _eType, TaskPaneData& _rData ) const
-{
- TaskEntryList& rList( _rData.aTasks );
- rList.clear(); rList.reserve( 4 );
-
- switch ( _eType )
- {
- case E_TABLE:
- rList.push_back( TaskEntry( ".uno:DBNewTable", RID_STR_TABLES_HELP_TEXT_DESIGN, RID_STR_NEW_TABLE ) );
- rList.push_back( TaskEntry( ".uno:DBNewTableAutoPilot", RID_STR_TABLES_HELP_TEXT_WIZARD, RID_STR_NEW_TABLE_AUTO ) );
- rList.push_back( TaskEntry( ".uno:DBNewView", RID_STR_VIEWS_HELP_TEXT_DESIGN, RID_STR_NEW_VIEW, true ) );
- _rData.nTitleId = RID_STR_TABLES_CONTAINER;
- break;
-
- case E_FORM:
- rList.push_back( TaskEntry( ".uno:DBNewForm", RID_STR_FORMS_HELP_TEXT, RID_STR_NEW_FORM ) );
- rList.push_back( TaskEntry( ".uno:DBNewFormAutoPilot", RID_STR_FORMS_HELP_TEXT_WIZARD, RID_STR_NEW_FORM_AUTO ) );
- _rData.nTitleId = RID_STR_FORMS_CONTAINER;
- break;
-
- case E_REPORT:
- rList.push_back( TaskEntry( ".uno:DBNewReport", RID_STR_REPORT_HELP_TEXT, RID_STR_NEW_REPORT, true ) );
- rList.push_back( TaskEntry( ".uno:DBNewReportAutoPilot", RID_STR_REPORTS_HELP_TEXT_WIZARD, RID_STR_NEW_REPORT_AUTO ) );
- _rData.nTitleId = RID_STR_REPORTS_CONTAINER;
- break;
-
- case E_QUERY:
- rList.push_back( TaskEntry( ".uno:DBNewQuery", RID_STR_QUERIES_HELP_TEXT, RID_STR_NEW_QUERY ) );
- rList.push_back( TaskEntry( ".uno:DBNewQueryAutoPilot", RID_STR_QUERIES_HELP_TEXT_WIZARD, RID_STR_NEW_QUERY_AUTO ) );
- rList.push_back( TaskEntry( ".uno:DBNewQuerySql", RID_STR_QUERIES_HELP_TEXT_SQL, RID_STR_NEW_QUERY_SQL ) );
- _rData.nTitleId = RID_STR_QUERIES_CONTAINER;
- break;
-
- default:
- OSL_FAIL( "OApplicationDetailView::impl_fillTaskPaneData: illegal element type!" );
- }
-
- MnemonicGenerator aAllMnemonics( m_aExternalMnemonics );
-
- // remove the entries which are not enabled currently
- for ( TaskEntryList::iterator pTask = rList.begin();
- pTask != rList.end();
- )
- {
- if ( pTask->bHideWhenDisabled
- && !getBorderWin().getView()->getCommandController().isCommandEnabled( pTask->sUNOCommand )
- )
- pTask = rList.erase( pTask );
- else
- {
- aAllMnemonics.RegisterMnemonic( pTask->sTitle );
- ++pTask;
- }
- }
-
- // for the remaining entries, assign mnemonics
- for ( TaskEntryList::iterator pTask = rList.begin();
- pTask != rList.end();
- ++pTask
- )
- {
- aAllMnemonics.CreateMnemonic( pTask->sTitle );
- // don't do this for now, until our task window really supports mnemonics
- }
-}
-
-// -----------------------------------------------------------------------------
-::rtl::OUString OApplicationDetailView::getQualifiedName( SvLBoxEntry* _pEntry ) const
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- return m_pControlHelper->getQualifiedName( _pEntry );
-}
-// -----------------------------------------------------------------------------
-sal_Bool OApplicationDetailView::isLeaf(SvLBoxEntry* _pEntry) const
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- return m_pControlHelper->isLeaf(_pEntry);
-}
-// -----------------------------------------------------------------------------
-sal_Bool OApplicationDetailView::isALeafSelected() const
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- return m_pControlHelper->isALeafSelected();
-}
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::selectAll()
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- m_pControlHelper->selectAll();
-}
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::sortDown()
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- m_pControlHelper->sortDown();
-}
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::sortUp()
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- m_pControlHelper->sortUp();
-}
-// -----------------------------------------------------------------------------
-sal_Bool OApplicationDetailView::isFilled() const
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- return m_pControlHelper->isFilled();
-}
-// -----------------------------------------------------------------------------
-ElementType OApplicationDetailView::getElementType() const
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- return m_pControlHelper->getElementType();
-}
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::clearPages(sal_Bool _bTaskAlso)
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- if ( _bTaskAlso )
- getTasksWindow().Clear();
- m_pControlHelper->clearPages();
-}
-// -----------------------------------------------------------------------------
-sal_Int32 OApplicationDetailView::getSelectionCount()
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- return m_pControlHelper->getSelectionCount();
-}
-// -----------------------------------------------------------------------------
-sal_Int32 OApplicationDetailView::getElementCount()
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- return m_pControlHelper->getElementCount();
-}
-
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::getSelectionElementNames( ::std::vector< ::rtl::OUString>& _rNames ) const
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- m_pControlHelper->getSelectionElementNames( _rNames );
-}
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::describeCurrentSelectionForControl( const Control& _rControl, Sequence< NamedDatabaseObject >& _out_rSelectedObjects )
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- m_pControlHelper->describeCurrentSelectionForControl( _rControl, _out_rSelectedObjects );
-}
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::describeCurrentSelectionForType( const ElementType _eType, Sequence< NamedDatabaseObject >& _out_rSelectedObjects )
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- m_pControlHelper->describeCurrentSelectionForType( _eType, _out_rSelectedObjects );
-}
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::selectElements(const Sequence< ::rtl::OUString>& _aNames)
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- m_pControlHelper->selectElements( _aNames );
-}
-// -----------------------------------------------------------------------------
-SvLBoxEntry* OApplicationDetailView::getEntry( const Point& _aPoint ) const
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- return m_pControlHelper->getEntry(_aPoint);
-}
-// -----------------------------------------------------------------------------
-sal_Bool OApplicationDetailView::isCutAllowed()
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- return m_pControlHelper->isCutAllowed();
-}
-sal_Bool OApplicationDetailView::isCopyAllowed()
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- return m_pControlHelper->isCopyAllowed();
-}
-sal_Bool OApplicationDetailView::isPasteAllowed() { DBG_CHKTHIS(OApplicationDetailView,NULL);return m_pControlHelper->isPasteAllowed(); }
-void OApplicationDetailView::copy() { DBG_CHKTHIS(OApplicationDetailView,NULL);m_pControlHelper->copy(); }
-void OApplicationDetailView::cut() { DBG_CHKTHIS(OApplicationDetailView,NULL);m_pControlHelper->cut(); }
-void OApplicationDetailView::paste()
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- m_pControlHelper->paste();
-}
-// -----------------------------------------------------------------------------
-SvLBoxEntry* OApplicationDetailView::elementAdded(ElementType _eType,const ::rtl::OUString& _rName, const Any& _rObject )
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- return m_pControlHelper->elementAdded(_eType,_rName, _rObject );
-}
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::elementRemoved(ElementType _eType,const ::rtl::OUString& _rName )
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- m_pControlHelper->elementRemoved(_eType,_rName );
-}
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::elementReplaced(ElementType _eType
- ,const ::rtl::OUString& _rOldName
- ,const ::rtl::OUString& _rNewName )
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- m_pControlHelper->elementReplaced( _eType, _rOldName, _rNewName );
-}
-// -----------------------------------------------------------------------------
-PreviewMode OApplicationDetailView::getPreviewMode()
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- return m_pControlHelper->getPreviewMode();
-}
-// -----------------------------------------------------------------------------
-sal_Bool OApplicationDetailView::isPreviewEnabled()
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- return m_pControlHelper->isPreviewEnabled();
-}
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::switchPreview(PreviewMode _eMode)
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- m_pControlHelper->switchPreview(_eMode);
-}
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::showPreview(const Reference< XContent >& _xContent)
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- m_pControlHelper->showPreview(_xContent);
-}
-// -----------------------------------------------------------------------------
-void OApplicationDetailView::showPreview( const ::rtl::OUString& _sDataSourceName,
- const ::rtl::OUString& _sName,
- sal_Bool _bTable)
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- m_pControlHelper->showPreview(_sDataSourceName,_sName,_bTable);
-}
-// -----------------------------------------------------------------------------
-sal_Bool OApplicationDetailView::isSortUp() const
-{
- DBG_CHKTHIS(OApplicationDetailView,NULL);
- return m_pControlHelper->isSortUp();
-}
-// -----------------------------------------------------------------------------
-Window* OApplicationDetailView::getTreeWindow() const
-{
- return m_pControlHelper->getCurrentView();
-}
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */