1*2e2212a7SAndrew Rist /************************************************************** 2cdf0e10cSrcweir * 3*2e2212a7SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*2e2212a7SAndrew Rist * or more contributor license agreements. See the NOTICE file 5*2e2212a7SAndrew Rist * distributed with this work for additional information 6*2e2212a7SAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*2e2212a7SAndrew Rist * to you under the Apache License, Version 2.0 (the 8*2e2212a7SAndrew Rist * "License"); you may not use this file except in compliance 9*2e2212a7SAndrew Rist * with the License. You may obtain a copy of the License at 10*2e2212a7SAndrew Rist * 11*2e2212a7SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12*2e2212a7SAndrew Rist * 13*2e2212a7SAndrew Rist * Unless required by applicable law or agreed to in writing, 14*2e2212a7SAndrew Rist * software distributed under the License is distributed on an 15*2e2212a7SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*2e2212a7SAndrew Rist * KIND, either express or implied. See the License for the 17*2e2212a7SAndrew Rist * specific language governing permissions and limitations 18*2e2212a7SAndrew Rist * under the License. 19*2e2212a7SAndrew Rist * 20*2e2212a7SAndrew Rist *************************************************************/ 21*2e2212a7SAndrew Rist 22*2e2212a7SAndrew Rist 23cdf0e10cSrcweir #ifndef DBAUI_QUERYDLG_HXX 24cdf0e10cSrcweir #define DBAUI_QUERYDLG_HXX 25cdf0e10cSrcweir #ifndef _SV_DIALOG_HXX //autogen 26cdf0e10cSrcweir #include <vcl/dialog.hxx> 27cdf0e10cSrcweir #endif 28cdf0e10cSrcweir 29cdf0e10cSrcweir #ifndef _SV_BUTTON_HXX //autogen 30cdf0e10cSrcweir #include <vcl/button.hxx> 31cdf0e10cSrcweir #endif 32cdf0e10cSrcweir 33cdf0e10cSrcweir #ifndef _SV_FIXED_HXX //autogen 34cdf0e10cSrcweir #include <vcl/fixed.hxx> 35cdf0e10cSrcweir #endif 36cdf0e10cSrcweir #ifndef _SV_LSTBOX_HXX 37cdf0e10cSrcweir #include <vcl/lstbox.hxx> 38cdf0e10cSrcweir #endif 39cdf0e10cSrcweir 40cdf0e10cSrcweir #ifndef DBAUI_ENUMTYPES_HXX 41cdf0e10cSrcweir #include "QEnumTypes.hxx" 42cdf0e10cSrcweir #endif 43cdf0e10cSrcweir 44cdf0e10cSrcweir #ifndef DBAUI_RELCONTROLIFACE_HXX 45cdf0e10cSrcweir #include "RelControliFace.hxx" 46cdf0e10cSrcweir #endif 47cdf0e10cSrcweir #ifndef DBAUI_JOINTABLEVIEW_HXX 48cdf0e10cSrcweir #include "JoinTableView.hxx" 49cdf0e10cSrcweir #endif 50cdf0e10cSrcweir 51cdf0e10cSrcweir 52cdf0e10cSrcweir namespace dbaui 53cdf0e10cSrcweir { 54cdf0e10cSrcweir class OQueryTableConnectionData; 55cdf0e10cSrcweir class OTableListBoxControl; 56cdf0e10cSrcweir class OQueryTableView; 57cdf0e10cSrcweir class OJoinControl; 58cdf0e10cSrcweir class DlgQryJoin : public ModalDialog 59cdf0e10cSrcweir ,public IRelationControlInterface 60cdf0e10cSrcweir { 61cdf0e10cSrcweir protected: 62cdf0e10cSrcweir FixedText aML_HelpText; 63cdf0e10cSrcweir OKButton aPB_OK; 64cdf0e10cSrcweir CancelButton aPB_CANCEL; 65cdf0e10cSrcweir HelpButton aPB_HELP; 66cdf0e10cSrcweir 67cdf0e10cSrcweir OJoinControl* m_pJoinControl; 68cdf0e10cSrcweir OTableListBoxControl* m_pTableControl; 69cdf0e10cSrcweir OJoinTableView::OTableWindowMap* m_pTableMap; 70cdf0e10cSrcweir OQueryTableView* m_pTableView; 71cdf0e10cSrcweir 72cdf0e10cSrcweir EJoinType eJoinType; 73cdf0e10cSrcweir TTableConnectionData::value_type m_pConnData; // enth"alt linke und rechte Tabelle 74cdf0e10cSrcweir TTableConnectionData::value_type m_pOrigConnData; 75cdf0e10cSrcweir ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection > m_xConnection; 76cdf0e10cSrcweir 77cdf0e10cSrcweir 78cdf0e10cSrcweir DECL_LINK( OKClickHdl, Button* ); 79cdf0e10cSrcweir DECL_LINK( LBChangeHdl, ListBox* ); 80cdf0e10cSrcweir DECL_LINK( NaturalToggleHdl, CheckBox* ); 81cdf0e10cSrcweir 82cdf0e10cSrcweir /** setJoinType enables and set the new join type 83cdf0e10cSrcweir @param _eNewJoinType the new jointype 84cdf0e10cSrcweir */ 85cdf0e10cSrcweir void setJoinType(EJoinType _eNewJoinType); 86cdf0e10cSrcweir public: 87cdf0e10cSrcweir DlgQryJoin( OQueryTableView * pParent, 88cdf0e10cSrcweir const TTableConnectionData::value_type& pData, 89cdf0e10cSrcweir OJoinTableView::OTableWindowMap* _pTableMap, 90cdf0e10cSrcweir const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection >& _xConnection, 91cdf0e10cSrcweir sal_Bool _bAllowTableSelect); 92cdf0e10cSrcweir virtual ~DlgQryJoin(); GetJoinType() const93cdf0e10cSrcweir EJoinType GetJoinType() const { return eJoinType; }; 94cdf0e10cSrcweir 95cdf0e10cSrcweir /** getConnectionData returns the current connection data 96cdf0e10cSrcweir @return the current connectiondata 97cdf0e10cSrcweir */ 98cdf0e10cSrcweir virtual TTableConnectionData::value_type getConnectionData() const; 99cdf0e10cSrcweir 100cdf0e10cSrcweir /** setValid set the valid inside, can be used for OK buttons 101cdf0e10cSrcweir @param _bValid true when the using control allows an update 102cdf0e10cSrcweir */ 103cdf0e10cSrcweir virtual void setValid(sal_Bool _bValid); 104cdf0e10cSrcweir getConnection()105cdf0e10cSrcweir virtual ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection > getConnection() { return m_xConnection; } 106cdf0e10cSrcweir 107cdf0e10cSrcweir /** notifyConnectionChange is callback which is called when the table selection has changed and a new connection exists 108cdf0e10cSrcweir @param _pConnectionData the connection which exists between the new tables 109cdf0e10cSrcweir */ 110cdf0e10cSrcweir virtual void notifyConnectionChange(); 111cdf0e10cSrcweir }; 112cdf0e10cSrcweir } 113cdf0e10cSrcweir #endif // DBAUI_QUERYDLG_HXX 114cdf0e10cSrcweir 115cdf0e10cSrcweir 116cdf0e10cSrcweir 117