summaryrefslogtreecommitdiff
path: root/dbaccess/source/ui
diff options
context:
space:
mode:
Diffstat (limited to 'dbaccess/source/ui')
-rw-r--r--dbaccess/source/ui/dlg/adminpages.cxx199
1 files changed, 90 insertions, 109 deletions
diff --git a/dbaccess/source/ui/dlg/adminpages.cxx b/dbaccess/source/ui/dlg/adminpages.cxx
index 0d4025e7414e..04ff335046bd 100644
--- a/dbaccess/source/ui/dlg/adminpages.cxx
+++ b/dbaccess/source/ui/dlg/adminpages.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: adminpages.cxx,v $
*
- * $Revision: 1.34 $
+ * $Revision: 1.35 $
*
- * last change: $Author: hr $ $Date: 2003-03-19 17:52:19 $
+ * last change: $Author: hr $ $Date: 2004-08-02 15:42:57 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -95,10 +95,7 @@
#ifndef _SV_ACCEL_HXX
#include <vcl/accel.hxx>
#endif
-#ifndef _SV_TOOLBOX_HXX
-#include <vcl/toolbox.hxx>
-#endif
-
+#include <algorithm>
#include <stdlib.h>
#ifndef _OSL_FILE_HXX_
#include <osl/file.hxx>
@@ -112,7 +109,18 @@
#ifndef _DBAUI_LOCALRESACCESS_HXX_
#include "localresaccess.hxx"
#endif
-
+#ifndef _SV_FIELD_HXX
+#include <vcl/field.hxx>
+#endif
+#ifndef _SV_LSTBOX_HXX
+#include <vcl/lstbox.hxx>
+#endif
+#ifndef _SV_EDIT_HXX
+#include <vcl/edit.hxx>
+#endif
+#ifndef _SV_BUTTON_HXX
+#include <vcl/button.hxx>
+#endif
//.........................................................................
namespace dbaui
@@ -120,11 +128,9 @@ namespace dbaui
//.........................................................................
using namespace ::com::sun::star::uno;
- using namespace ::com::sun::star::ucb;
using namespace ::com::sun::star::sdbc;
using namespace ::com::sun::star::beans;
using namespace ::com::sun::star::lang;
- using namespace ::com::sun::star::container;
using namespace ::dbtools;
using namespace ::svt;
@@ -143,8 +149,8 @@ namespace dbaui
//-------------------------------------------------------------------------
OGenericAdministrationPage::OGenericAdministrationPage(Window* _pParent, const ResId& _rId, const SfxItemSet& _rAttrSet)
:SfxTabPage(_pParent, _rId, _rAttrSet)
- ,m_pToolBox( NULL )
- ,m_pKeyAccel( NULL )
+ ,m_pAdminDialog(NULL)
+ ,m_pItemSetHelper(NULL)
{
SetExchangeSupport(sal_True);
}
@@ -152,8 +158,6 @@ namespace dbaui
//-------------------------------------------------------------------------
OGenericAdministrationPage::~OGenericAdministrationPage()
{
- if ( m_pKeyAccel )
- delete m_pKeyAccel;
}
//-------------------------------------------------------------------------
@@ -174,7 +178,14 @@ namespace dbaui
{
implInitControls(_rCoreAttrs, sal_False);
}
-
+ //-------------------------------------------------------------------------
+ void OGenericAdministrationPage::ActivatePage()
+ {
+ TabPage::ActivatePage();
+ OSL_ENSURE(m_pItemSetHelper,"NO ItemSetHelper set!");
+ if ( m_pItemSetHelper )
+ ActivatePage(*m_pItemSetHelper->getOutputSet());
+ }
//-------------------------------------------------------------------------
void OGenericAdministrationPage::ActivatePage(const SfxItemSet& _rSet)
{
@@ -209,101 +220,6 @@ namespace dbaui
}
// -----------------------------------------------------------------------
- sal_Bool OGenericAdministrationPage::prepareConnectionAction( ODbAdminDialog* _pDialog, const String& _rActionDescription, OPageSettings** _pViewSettings )
- {
- sal_Bool bDeleteSettings = sal_True;
- sal_Bool bContinueAction = sal_True;
- if (_pDialog->isCurrentModified())
- {
- // the current data source is modified, so we need to save it in case we're
- // about to do something which requires a connection
- if (!_pDialog->isApplyable())
- {
- ErrorBox aError(this, ModuleRes(ERR_CANTDOTABLEACTION));
- aError.Execute();
- }
- else
- {
- QueryBox aAskForSave(this, ModuleRes(QUERY_NEED_TO_SAVE_FILTER));
- aAskForSave.SetText(_rActionDescription);
- if (RET_YES == aAskForSave.Execute())
- {
- _pDialog->applyChangesAsync(_pViewSettings ? *_pViewSettings : NULL);
- bDeleteSettings = sal_False;
- }
- }
- bContinueAction = sal_False;
- }
-
- if (bDeleteSettings && _pViewSettings)
- {
- delete *_pViewSettings;
- *_pViewSettings = NULL;
- }
- return bContinueAction;
- }
-
- // -----------------------------------------------------------------------
- void OGenericAdministrationPage::enableToolBoxAcceleration( ToolBox* _pDerivedClassToolBox )
- {
- DBG_ASSERT( !m_pKeyAccel && !m_pToolBox, "OGenericAdministrationPage::enableToolBoxAcceleration: already enabled!" );
- if ( !m_pKeyAccel )
- {
- m_pKeyAccel = new Accelerator;
- m_pKeyAccel->SetSelectHdl( LINK( this, OGenericAdministrationPage, OnAccelSelected ) );
- }
-
- m_pToolBox = _pDerivedClassToolBox;
- }
-
- // -----------------------------------------------------------------------
- void OGenericAdministrationPage::addToolboxAccelerator( sal_uInt16 _nToolboxItemId, const KeyCode& _rKey )
- {
- DBG_ASSERT( m_pKeyAccel && m_pToolBox, "OGenericAdministrationPage::addToolboxAccelerator: toolbox acceleration not enabled!" );
- if ( !(m_pKeyAccel && m_pToolBox) )
- return;
-
- // assert that the toolbox knows this item
- DBG_ASSERT( TOOLBOX_ITEM_NOTFOUND != m_pToolBox->GetItemPos( _nToolboxItemId ),
- "OGenericAdministrationPage::addToolboxAccelerator: invalid id!" );
- // assert that the accelerator does not know this item, yet
- OSL_ENSURE( !m_pKeyAccel->IsIdValid( _nToolboxItemId ), "OGenericAdministrationPage::addToolboxAccelerator: already have this id!" );
-
- // add the item to the accelerator
- m_pKeyAccel->InsertItem( _nToolboxItemId, _rKey );
- }
-
- //------------------------------------------------------------------------
- long OGenericAdministrationPage::PreNotify( NotifyEvent& _rNEvt )
- {
- if ( m_pKeyAccel )
- {
- if ( EVENT_KEYINPUT == _rNEvt.GetType() )
- {
- const KeyEvent* pEvent = _rNEvt.GetKeyEvent();
- if ( m_pKeyAccel->Call( pEvent->GetKeyCode() ) )
- return 1;
- }
- }
- return SfxTabPage::PreNotify( _rNEvt );
- }
-
- //------------------------------------------------------------------------
- void OGenericAdministrationPage::onToolBoxAction( sal_uInt16 _nClickedItemId )
- {
- }
-
- //------------------------------------------------------------------------
- IMPL_LINK( OGenericAdministrationPage, OnAccelSelected, void*, NOTINTERESTEDIN )
- {
- sal_uInt16 nId = m_pKeyAccel->GetCurItemId();
- if ( m_pToolBox && m_pToolBox->IsItemEnabled( nId ) )
- onToolBoxAction( nId );
-
- return 0L;
- }
-
- // -----------------------------------------------------------------------
IMPL_LINK(OGenericAdministrationPage, OnControlModified, Control*, EMPTYARG)
{
callModifiedHdl();
@@ -335,7 +251,72 @@ namespace dbaui
}
return sal_True;
}
+ // -----------------------------------------------------------------------
+ void OGenericAdministrationPage::postInitControls(const SfxItemSet& _rSet, sal_Bool _bSaveValue)
+ {
+ // check whether or not the selection is invalid or readonly (invalid implies readonly, but not vice versa)
+ sal_Bool bValid, bReadonly;
+ getFlags(_rSet, bValid, bReadonly);
+
+ ::std::vector< ISaveValueWrapper* > aControlList;
+ if ( _bSaveValue )
+ {
+ fillControls(aControlList);
+ ::std::for_each(aControlList.begin(),aControlList.end(),TSaveValueWrapperFunctor());
+ }
+ if ( bReadonly )
+ {
+ fillWindows(aControlList);
+ ::std::for_each(aControlList.begin(),aControlList.end(),TDisableWrapperFunctor());
+ }
+
+ ::std::for_each(aControlList.begin(),aControlList.end(),TDeleteWrapperFunctor());
+ aControlList.clear();
+ }
+ // -----------------------------------------------------------------------
+ void OGenericAdministrationPage::enableHeader( const Bitmap& _rBitmap, sal_Int32 _nPixelHeight, GrantAccess )
+ {
+ }
+ // -----------------------------------------------------------------------
+ void OGenericAdministrationPage::initializePage()
+ {
+ OSL_ENSURE(m_pItemSetHelper,"NO ItemSetHelper set!");
+ if ( m_pItemSetHelper )
+ Reset(*m_pItemSetHelper->getOutputSet());
+ }
+ // -----------------------------------------------------------------------
+ sal_Bool OGenericAdministrationPage::commitPage(COMMIT_REASON _eReason)
+ {
+ return sal_True;
+ }
+ // -----------------------------------------------------------------------
+ void OGenericAdministrationPage::fillBool(SfxItemSet& _rSet,CheckBox* _pCheckBox,USHORT _nID,sal_Bool& _bChangedSomething)
+ {
+ if( (_pCheckBox != NULL) && (_pCheckBox->GetState() != _pCheckBox->GetSavedValue()) )
+ {
+ _rSet.Put(SfxBoolItem(_nID, _pCheckBox->IsChecked()));
+ _bChangedSomething = sal_True;
+ }
+ }
+ // -----------------------------------------------------------------------
+ void OGenericAdministrationPage::fillInt32(SfxItemSet& _rSet,NumericField* _pEdit,USHORT _nID,sal_Bool& _bChangedSomething)
+ {
+ if( (_pEdit != NULL) && (_pEdit->GetValue() != _pEdit->GetSavedValue().ToInt32()) )
+ {
+ _rSet.Put(SfxInt32Item(_nID, _pEdit->GetValue()));
+ _bChangedSomething = sal_True;
+ }
+ }
+ // -----------------------------------------------------------------------
+ void OGenericAdministrationPage::fillString(SfxItemSet& _rSet,Edit* _pEdit,USHORT _nID,sal_Bool& _bChangedSomething)
+ {
+ if( (_pEdit != NULL) && (_pEdit->GetText() != _pEdit->GetSavedValue()) )
+ {
+ _rSet.Put(SfxStringItem(_nID, _pEdit->GetText()));
+ _bChangedSomething = sal_True;
+ }
+ }
//.........................................................................
} // namespace dbaui