/************************************************************************* * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: generalpage.hxx,v $ * * $Revision: 1.21 $ * * last change: $Author: rt $ $Date: 2008-01-30 08:45:55 $ * * The Contents of this file are made available subject to * the terms of GNU Lesser General Public License Version 2.1. * * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2005 by Sun Microsystems, Inc. * 901 San Antonio Road, Palo Alto, CA 94303, USA * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software Foundation. * * This library 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 for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * ************************************************************************/ #ifndef _DBAUI_GENERALPAGE_HXX_ #define _DBAUI_GENERALPAGE_HXX_ #ifndef _DBAUI_ADMINPAGES_HXX_ #include "adminpages.hxx" #endif #ifndef DBACCESS_SOURCE_UI_INC_OPENDOCCONTROLS_HXX #include "opendoccontrols.hxx" #endif #ifndef _SV_FIXED_HXX #include #endif #ifndef _SV_LSTBOX_HXX #include #endif #ifndef _SV_EDIT_HXX #include #endif #include #include //......................................................................... namespace dbaui { //......................................................................... class IDatabaseSettingsDialog; //========================================================================= //= OGeneralPage //========================================================================= class OGeneralPage : public OGenericAdministrationPage { OGeneralPage(Window* pParent, const SfxItemSet& _rItems, sal_Bool _bDBWizardMode = sal_False); ~OGeneralPage(); public: enum CreationMode { eCreateNew, eConnectExternal, eOpenExisting }; struct DocumentDescriptor { String sURL; String sFilter; }; private: // dialog controls FixedText m_aFTHeaderText; FixedText m_aFTHelpText; FixedText m_aFT_DatasourceTypeHeader; RadioButton m_aRB_CreateDatabase; RadioButton m_aRB_OpenDocument; RadioButton m_aRB_GetExistingDatabase; FixedText m_aFT_DocListLabel; ::std::auto_ptr< OpenDocumentListBox > m_pLB_DocumentList; OpenDocumentButton m_aPB_OpenDocument; FixedText m_aTypePreLabel; FixedText m_aDatasourceTypeLabel; ::std::auto_ptr< ListBox > m_pDatasourceType; FixedText m_aFTDataSourceAppendix; FixedText m_aTypePostLabel; FixedText m_aSpecialMessage; sal_Bool m_DBWizardMode; String m_sMySQLEntry; CreationMode m_eOriginalCreationMode; DocumentDescriptor m_aBrowsedDocument; ::svt::ControlDependencyManager m_aControlDependencies; ODsnTypeCollection* m_pCollection; /// the DSN type collection instance DATASOURCE_TYPE m_eCurrentSelection; /// currently selected type DATASOURCE_TYPE m_eNotSupportedKnownType; /// if a data source of an unsupported, but known type is encountered .... enum SPECIAL_MESSAGE { smNone, smUnsupportedType }; SPECIAL_MESSAGE m_eLastMessage; Link m_aTypeSelectHandler; /// to be called if a new type is selected Link m_aCreationModeHandler; /// to be called if a new type is selected Link m_aDocumentSelectionHandler; /// to be called when a document in the RecentDoc list is selected Link m_aChooseDocumentHandler; /// to be called when a recent document has been definately chosen sal_Bool m_bDisplayingInvalid : 1; // the currently displayed data source is deleted sal_Bool m_bUserGrabFocus : 1; bool approveDataSourceType( DATASOURCE_TYPE eType, String& _inout_rDisplayName ); void insertDatasourceTypeEntryData(DATASOURCE_TYPE eType, String sDisplayName); public: static SfxTabPage* Create(Window* pParent, const SfxItemSet& _rAttrSet, sal_Bool _bDBWizardMode = sal_False); /// set a handler which gets called every time the user selects a new type void SetTypeSelectHandler(const Link& _rHandler) { m_aTypeSelectHandler = _rHandler; } void SetCreationModeHandler(const Link& _rHandler) { m_aCreationModeHandler = _rHandler; } void SetDocumentSelectionHandler( const Link& _rHandler) { m_aDocumentSelectionHandler = _rHandler; } void SetChooseDocumentHandler( const Link& _rHandler) { m_aChooseDocumentHandler = _rHandler; } CreationMode GetDatabaseCreationMode() const; DocumentDescriptor GetSelectedDocument() const; /// get the currently selected datasource type DATASOURCE_TYPE GetSelectedType() const { return m_eCurrentSelection; } protected: // SfxTabPage overridables virtual BOOL FillItemSet(SfxItemSet& _rCoreAttrs); virtual void Reset(const SfxItemSet& _rCoreAttrs); virtual void implInitControls(const SfxItemSet& _rSet, sal_Bool _bSaveValue); virtual void GetFocus(); // OGenericAdministrationPage::fillControls virtual void fillControls(::std::vector< ISaveValueWrapper* >& _rControlList); // OGenericAdministrationPage::fillWindows virtual void fillWindows(::std::vector< ISaveValueWrapper* >& _rControlList); protected: void onTypeSelected(const DATASOURCE_TYPE _eType); void initializeTypeList(); void implSetCurrentType( const DATASOURCE_TYPE _eType ); void switchMessage(const DATASOURCE_TYPE _eType); /// sets the the title of the parent dialog void setParentTitle(DATASOURCE_TYPE _eSelectedType); DECL_LINK(OnDatasourceTypeSelected, ListBox*); DECL_LINK(OnSetupModeSelected, RadioButton*); DECL_LINK(OnDocumentSelected, ListBox*); DECL_LINK(OnOpenDocument, PushButton*); }; //......................................................................... } // namespace dbaui //......................................................................... #endif // _DBAUI_GENERALPAGE_HXX_