summaryrefslogtreecommitdiff
path: root/extensions/source/bibliography/bibview.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'extensions/source/bibliography/bibview.cxx')
-rw-r--r--extensions/source/bibliography/bibview.cxx232
1 files changed, 232 insertions, 0 deletions
diff --git a/extensions/source/bibliography/bibview.cxx b/extensions/source/bibliography/bibview.cxx
new file mode 100644
index 000000000000..fee2610898f6
--- /dev/null
+++ b/extensions/source/bibliography/bibview.cxx
@@ -0,0 +1,232 @@
+/*************************************************************************
+ *
+ * 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"
+
+#ifndef BIB_HRC
+#include "bib.hrc"
+#endif
+#include "bibcont.hxx"
+#include "bibbeam.hxx"
+#include "bibmod.hxx"
+#include "general.hxx"
+#include "bibview.hxx"
+#include "datman.hxx"
+#include "bibresid.hxx"
+#include "bibmod.hxx"
+#include "sections.hrc"
+#include "bibconfig.hxx"
+
+
+#include <vcl/svapp.hxx>
+#include <com/sun/star/sdbc/XResultSetUpdate.hpp>
+#include <com/sun/star/form/XLoadable.hpp>
+#include <vcl/msgbox.hxx>
+#include <tools/debug.hxx>
+
+using namespace ::com::sun::star;
+using namespace ::com::sun::star::form;
+using namespace ::com::sun::star::beans;
+using namespace ::com::sun::star::lang;
+using namespace ::com::sun::star::uno;
+
+#define C2U( cChar ) ::rtl::OUString::createFromAscii( cChar )
+
+//.........................................................................
+namespace bib
+{
+//.........................................................................
+
+ // -----------------------------------------------------------------------
+ BibView::BibView( Window* _pParent, BibDataManager* _pManager, WinBits _nStyle )
+ :BibWindow( _pParent, _nStyle )
+ ,m_pDatMan( _pManager )
+ ,m_xDatMan( _pManager )
+ ,m_pGeneralPage( NULL )
+ {
+ if ( m_xDatMan.is() )
+ connectForm( m_xDatMan );
+ }
+
+ // -----------------------------------------------------------------------
+ BibView::~BibView()
+ {
+ BibGeneralPage* pGeneralPage = m_pGeneralPage;
+ m_pGeneralPage = NULL;
+
+ pGeneralPage->CommitActiveControl();
+ Reference< XForm > xForm = m_pDatMan->getForm();
+ Reference< XPropertySet > xProps( xForm, UNO_QUERY );
+ Reference< sdbc::XResultSetUpdate > xResUpd( xProps, UNO_QUERY );
+ DBG_ASSERT( xResUpd.is(), "BibView::~BibView: invalid form!" );
+
+ if ( xResUpd.is() )
+ {
+ Any aModified = xProps->getPropertyValue( C2U( "IsModified" ) );
+ sal_Bool bFlag = sal_False;
+ if ( ( aModified >>= bFlag ) && bFlag )
+ {
+
+ try
+ {
+ Any aNew = xProps->getPropertyValue( C2U( "IsNew" ) );
+ aNew >>= bFlag;
+ if ( bFlag )
+ xResUpd->insertRow();
+ else
+ xResUpd->updateRow();
+ }
+ catch( const uno::Exception& rEx)
+ {
+ (void) rEx;
+ }
+ }
+ }
+
+ if ( isFormConnected() )
+ disconnectForm();
+
+ pGeneralPage->RemoveListeners();
+ m_xGeneralPage = NULL;
+ }
+
+ /* -----------------16.11.99 13:13-------------------
+
+ --------------------------------------------------*/
+ void BibView::UpdatePages()
+ {
+ // TODO:
+ // this is _strange_: Why not updating the existent general page?
+ // I consider the current behaviour a HACK.
+ // frank.schoenheit@sun.com
+ if ( m_pGeneralPage )
+ {
+ m_pGeneralPage->Hide();
+ m_pGeneralPage->RemoveListeners();
+ m_xGeneralPage = 0;
+ }
+
+ m_xGeneralPage = m_pGeneralPage = new BibGeneralPage( this, m_pDatMan );
+
+ Resize();
+
+ if( HasFocus() )
+ // "delayed" GetFocus() because GetFocus() is initially called before GeneralPage is created
+ m_pGeneralPage->GrabFocus();
+
+ String sErrorString( m_pGeneralPage->GetErrorString() );
+ if ( sErrorString.Len() )
+ {
+ sal_Bool bExecute = BibModul::GetConfig()->IsShowColumnAssignmentWarning();
+ if(!m_pDatMan->HasActiveConnection())
+ {
+ //no connection is available -> the data base has to be assigned
+ m_pDatMan->DispatchDBChangeDialog();
+ bExecute = sal_False;
+ }
+ else if(bExecute)
+ {
+ sErrorString += '\n';
+ sErrorString += String( BibResId( RID_MAP_QUESTION ) );
+ QueryBox aQuery( this, WB_YES_NO, sErrorString );
+ aQuery.SetDefaultCheckBoxText();
+ short nResult = aQuery.Execute();
+ BibModul::GetConfig()->SetShowColumnAssignmentWarning(
+ !aQuery.GetCheckBoxState());
+ if( RET_YES != nResult )
+ {
+ bExecute = sal_False;
+ }
+ }
+ if(bExecute)
+ {
+ Application::PostUserEvent( STATIC_LINK( this, BibView, CallMappingHdl ) );
+ }
+ }
+ }
+ //---------------------------------------------------------------------
+ //--- 19.10.01 16:55:49 -----------------------------------------------
+
+ void BibView::_loaded( const EventObject& _rEvent )
+ {
+ UpdatePages();
+ FormControlContainer::_loaded( _rEvent );
+ }
+
+ void BibView::_reloaded( const EventObject& _rEvent )
+ {
+ UpdatePages();
+ FormControlContainer::_loaded( _rEvent );
+ }
+
+ /* -----------------------------02.02.00 16:49--------------------------------
+
+ ---------------------------------------------------------------------------*/
+ IMPL_STATIC_LINK( BibView, CallMappingHdl, BibView*, EMPTYARG )
+ {
+ pThis->m_pDatMan->CreateMappingDialog( pThis );
+ return 0;
+ }
+ /* -----------------------------13.04.00 16:12--------------------------------
+
+ ---------------------------------------------------------------------------*/
+ void BibView::Resize()
+ {
+ if ( m_pGeneralPage )
+ {
+ ::Size aSz( GetOutputSizePixel() );
+ m_pGeneralPage->SetSizePixel( aSz );
+ }
+ Window::Resize();
+ }
+
+ //---------------------------------------------------------------------
+ //--- 18.10.01 18:52:45 -----------------------------------------------
+
+ Reference< awt::XControlContainer > BibView::getControlContainer()
+ {
+ Reference< awt::XControlContainer > xReturn;
+ if ( m_pGeneralPage )
+ xReturn = m_pGeneralPage->GetControlContainer();
+ return xReturn;
+ }
+
+ void BibView::GetFocus()
+ {
+ if( m_pGeneralPage )
+ m_pGeneralPage->GrabFocus();
+ }
+
+ BOOL BibView::HandleShortCutKey( const KeyEvent& rKeyEvent )
+ {
+ return m_pGeneralPage? m_pGeneralPage->HandleShortCutKey( rKeyEvent ) : FALSE;
+ }
+
+//.........................................................................
+} // namespace bib
+//.........................................................................