1*96de5490SAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3*96de5490SAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4*96de5490SAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5*96de5490SAndrew Rist  * distributed with this work for additional information
6*96de5490SAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7*96de5490SAndrew Rist  * to you under the Apache License, Version 2.0 (the
8*96de5490SAndrew Rist  * "License"); you may not use this file except in compliance
9*96de5490SAndrew Rist  * with the License.  You may obtain a copy of the License at
10*96de5490SAndrew Rist  *
11*96de5490SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12*96de5490SAndrew Rist  *
13*96de5490SAndrew Rist  * Unless required by applicable law or agreed to in writing,
14*96de5490SAndrew Rist  * software distributed under the License is distributed on an
15*96de5490SAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*96de5490SAndrew Rist  * KIND, either express or implied.  See the License for the
17*96de5490SAndrew Rist  * specific language governing permissions and limitations
18*96de5490SAndrew Rist  * under the License.
19*96de5490SAndrew Rist  *
20*96de5490SAndrew Rist  *************************************************************/
21*96de5490SAndrew Rist 
22*96de5490SAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_dbaccess.hxx"
26cdf0e10cSrcweir #ifndef DBAUI_QUERY_TABLEWINDOWDATA_HXX
27cdf0e10cSrcweir #include "QTableWindow.hxx"
28cdf0e10cSrcweir #endif
29cdf0e10cSrcweir #ifndef DBAUI_QUERYTABLEVIEW_HXX
30cdf0e10cSrcweir #include "QueryTableView.hxx"
31cdf0e10cSrcweir #endif
32cdf0e10cSrcweir #ifndef DBACCESS_SHARED_DBUSTRINGS_HRC
33cdf0e10cSrcweir #include "dbustrings.hrc"
34cdf0e10cSrcweir #endif
35cdf0e10cSrcweir #ifndef _TOOLS_DEBUG_HXX
36cdf0e10cSrcweir #include <tools/debug.hxx>
37cdf0e10cSrcweir #endif
38cdf0e10cSrcweir #include "dbaccess_helpid.hrc"
39cdf0e10cSrcweir #ifndef DBAUI_QUERYDESIGNVIEW_HXX
40cdf0e10cSrcweir #include "QueryDesignView.hxx"
41cdf0e10cSrcweir #endif
42cdf0e10cSrcweir #ifndef DBACCESS_UI_BROWSER_ID_HXX
43cdf0e10cSrcweir #include "browserids.hxx"
44cdf0e10cSrcweir #endif
45cdf0e10cSrcweir #ifndef DBAUI_QUERYCONTROLLER_HXX
46cdf0e10cSrcweir #include "querycontroller.hxx"
47cdf0e10cSrcweir #endif
48cdf0e10cSrcweir #ifndef _SV_IMAGE_HXX
49cdf0e10cSrcweir #include <vcl/image.hxx>
50cdf0e10cSrcweir #endif
51cdf0e10cSrcweir #ifndef DBAUI_TABLEWINDOWLISTBOX_HXX
52cdf0e10cSrcweir #include "TableWindowListBox.hxx"
53cdf0e10cSrcweir #endif
54cdf0e10cSrcweir #ifndef _DBU_QRY_HRC_
55cdf0e10cSrcweir #include "dbu_qry.hrc"
56cdf0e10cSrcweir #endif
57cdf0e10cSrcweir #ifndef DBAUI_QUERY_HRC
58cdf0e10cSrcweir #include "Query.hrc"
59cdf0e10cSrcweir #endif
60cdf0e10cSrcweir #ifndef _COM_SUN_STAR_SDBCX_XKEYSSUPPLIER_HPP_
61cdf0e10cSrcweir #include <com/sun/star/sdbcx/XKeysSupplier.hpp>
62cdf0e10cSrcweir #endif
63cdf0e10cSrcweir #ifndef _COM_SUN_STAR_CONTAINER_XNAMEACCESS_HPP_
64cdf0e10cSrcweir #include <com/sun/star/container/XNameAccess.hpp>
65cdf0e10cSrcweir #endif
66cdf0e10cSrcweir #ifndef _COM_SUN_STAR_CONTAINER_XINDEXACCESS_HPP_
67cdf0e10cSrcweir #include <com/sun/star/container/XIndexAccess.hpp>
68cdf0e10cSrcweir #endif
69cdf0e10cSrcweir #ifndef _COM_SUN_STAR_BEANS_XPROPERTYSET_HPP_
70cdf0e10cSrcweir #include <com/sun/star/beans/XPropertySet.hpp>
71cdf0e10cSrcweir #endif
72cdf0e10cSrcweir #ifndef _COM_SUN_STAR_SDBCX_KEYTYPE_HPP_
73cdf0e10cSrcweir #include <com/sun/star/sdbcx/KeyType.hpp>
74cdf0e10cSrcweir #endif
75cdf0e10cSrcweir #ifndef _COM_SUN_STAR_SDBCX_XCOLUMNSSUPPLIER_HPP_
76cdf0e10cSrcweir #include <com/sun/star/sdbcx/XColumnsSupplier.hpp>
77cdf0e10cSrcweir #endif
78cdf0e10cSrcweir #ifndef DBAUI_TABLEFIELDINFO_HXX
79cdf0e10cSrcweir #include "TableFieldInfo.hxx"
80cdf0e10cSrcweir #endif
81cdf0e10cSrcweir #ifndef _COMPHELPER_UNO3_HXX_
82cdf0e10cSrcweir #include <comphelper/uno3.hxx>
83cdf0e10cSrcweir #endif
84cdf0e10cSrcweir #ifndef _COMPHELPER_EXTRACT_HXX_
85cdf0e10cSrcweir #include <comphelper/extract.hxx>
86cdf0e10cSrcweir #endif
87cdf0e10cSrcweir #ifndef DBAUI_TOOLS_HXX
88cdf0e10cSrcweir #include "UITools.hxx"
89cdf0e10cSrcweir #endif
90cdf0e10cSrcweir 
91cdf0e10cSrcweir 
92cdf0e10cSrcweir using namespace ::com::sun::star::sdbc;
93cdf0e10cSrcweir using namespace ::com::sun::star::sdbcx;
94cdf0e10cSrcweir using namespace ::com::sun::star::uno;
95cdf0e10cSrcweir using namespace ::com::sun::star::container;
96cdf0e10cSrcweir using namespace ::com::sun::star::beans;
97cdf0e10cSrcweir using namespace dbaui;
98cdf0e10cSrcweir //========================================================================
99cdf0e10cSrcweir // class OQueryTableWindow
100cdf0e10cSrcweir //========================================================================
DBG_NAME(OQueryTableWindow)101cdf0e10cSrcweir DBG_NAME(OQueryTableWindow)
102cdf0e10cSrcweir //------------------------------------------------------------------------------
103cdf0e10cSrcweir OQueryTableWindow::OQueryTableWindow( Window* pParent, const TTableWindowData::value_type& pTabWinData, sal_Unicode* pszInitialAlias)
104cdf0e10cSrcweir 	:OTableWindow( pParent, pTabWinData )
105cdf0e10cSrcweir 	,m_nAliasNum(0)
106cdf0e10cSrcweir {
107cdf0e10cSrcweir 	DBG_CTOR(OQueryTableWindow,NULL);
108cdf0e10cSrcweir 	if (pszInitialAlias != NULL)
109cdf0e10cSrcweir 		m_strInitialAlias = ::rtl::OUString(pszInitialAlias);
110cdf0e10cSrcweir 	else
111cdf0e10cSrcweir 		m_strInitialAlias = GetAliasName();
112cdf0e10cSrcweir 
113cdf0e10cSrcweir 	// wenn der Tabellen- gleich dem Aliasnamen ist, dann darf ich das nicht an InitialAlias weiterreichen, denn das Anhaengen
114cdf0e10cSrcweir 	// eines eventuelle Tokens nicht klappen ...
115cdf0e10cSrcweir 	if (m_strInitialAlias == pTabWinData->GetTableName())
116cdf0e10cSrcweir 		m_strInitialAlias = ::rtl::OUString();
117cdf0e10cSrcweir 
118cdf0e10cSrcweir 	SetHelpId(HID_CTL_QRYDGNTAB);
119cdf0e10cSrcweir }
120cdf0e10cSrcweir 
121cdf0e10cSrcweir //------------------------------------------------------------------------------
~OQueryTableWindow()122cdf0e10cSrcweir OQueryTableWindow::~OQueryTableWindow()
123cdf0e10cSrcweir {
124cdf0e10cSrcweir 	DBG_DTOR(OQueryTableWindow,NULL);
125cdf0e10cSrcweir }
126cdf0e10cSrcweir 
127cdf0e10cSrcweir //------------------------------------------------------------------------------
Init()128cdf0e10cSrcweir sal_Bool OQueryTableWindow::Init()
129cdf0e10cSrcweir {
130cdf0e10cSrcweir 	sal_Bool bSuccess = OTableWindow::Init();
131cdf0e10cSrcweir 	if(!bSuccess)
132cdf0e10cSrcweir 		return bSuccess;
133cdf0e10cSrcweir 
134cdf0e10cSrcweir 	OQueryTableView* pContainer = static_cast<OQueryTableView*>(getTableView());
135cdf0e10cSrcweir 
136cdf0e10cSrcweir 	// zuerst Alias bestimmen
137cdf0e10cSrcweir 	::rtl::OUString sAliasName;
138cdf0e10cSrcweir 
139cdf0e10cSrcweir 	TTableWindowData::value_type pWinData = GetData();
140cdf0e10cSrcweir 
141cdf0e10cSrcweir 	if (m_strInitialAlias.getLength() )
142cdf0e10cSrcweir 		// Der Alias wurde explizit mit angegeben
143cdf0e10cSrcweir 		sAliasName = m_strInitialAlias;
144cdf0e10cSrcweir 	else if ( GetTable().is() )
145cdf0e10cSrcweir 		GetTable()->getPropertyValue( PROPERTY_NAME ) >>= sAliasName;
146cdf0e10cSrcweir     else
147cdf0e10cSrcweir         return sal_False;
148cdf0e10cSrcweir 
149cdf0e10cSrcweir 	// Alias mit fortlaufender Nummer versehen
150cdf0e10cSrcweir 	if (pContainer->CountTableAlias(sAliasName, m_nAliasNum))
151cdf0e10cSrcweir 	{
152cdf0e10cSrcweir 		sAliasName += ::rtl::OUString('_');
153cdf0e10cSrcweir 		sAliasName += ::rtl::OUString::valueOf(m_nAliasNum);
154cdf0e10cSrcweir 	}
155cdf0e10cSrcweir 
156cdf0e10cSrcweir 
157cdf0e10cSrcweir 	sAliasName = String(sAliasName).EraseAllChars('"');
158cdf0e10cSrcweir 	SetAliasName(sAliasName);
159cdf0e10cSrcweir 		// SetAliasName reicht das als WinName weiter, dadurch benutzt es die Basisklasse
160cdf0e10cSrcweir 	// reset the titel
161cdf0e10cSrcweir 	m_aTitle.SetText( pWinData->GetWinName() );
162cdf0e10cSrcweir 	m_aTitle.Show();
163cdf0e10cSrcweir 
164cdf0e10cSrcweir 	//	sal_Bool bSuccess(sal_True);
165cdf0e10cSrcweir 	if (!bSuccess)
166cdf0e10cSrcweir 	{	// es soll nur ein Dummy-Window aufgemacht werden ...
167cdf0e10cSrcweir 		DBG_ASSERT(GetAliasName().getLength(), "OQueryTableWindow::Init : kein Alias- UND kein Tabellenname geht nicht !");
168cdf0e10cSrcweir 			// .. aber das braucht wenigstens einen Alias
169cdf0e10cSrcweir 
170cdf0e10cSrcweir 		// ::com::sun::star::form::ListBox anlegen
171cdf0e10cSrcweir 		if (!m_pListBox)
172cdf0e10cSrcweir 			m_pListBox = CreateListBox();
173cdf0e10cSrcweir 
174cdf0e10cSrcweir 		// Titel setzen
175cdf0e10cSrcweir 		m_aTitle.SetText(GetAliasName());
176cdf0e10cSrcweir 		m_aTitle.Show();
177cdf0e10cSrcweir 
178cdf0e10cSrcweir 		clearListBox();
179cdf0e10cSrcweir 			// neu zu fuellen brauche ich die nicht, da ich ja keine Tabelle habe
180cdf0e10cSrcweir 		m_pListBox->Show();
181cdf0e10cSrcweir 	}
182cdf0e10cSrcweir 
183cdf0e10cSrcweir 	getTableView()->getDesignView()->getController().InvalidateFeature(ID_BROWSER_QUERY_EXECUTE);
184cdf0e10cSrcweir 	return bSuccess;
185cdf0e10cSrcweir }
186cdf0e10cSrcweir // -----------------------------------------------------------------------------
createUserData(const Reference<XPropertySet> & _xColumn,bool _bPrimaryKey)187cdf0e10cSrcweir void* OQueryTableWindow::createUserData(const Reference< XPropertySet>& _xColumn,bool _bPrimaryKey)
188cdf0e10cSrcweir {
189cdf0e10cSrcweir 	OTableFieldInfo* pInfo = new OTableFieldInfo();
190cdf0e10cSrcweir 	pInfo->SetKey(_bPrimaryKey ? TAB_PRIMARY_FIELD : TAB_NORMAL_FIELD);
191cdf0e10cSrcweir 	if ( _xColumn.is() )
192cdf0e10cSrcweir 		pInfo->SetDataType(::comphelper::getINT32(_xColumn->getPropertyValue(PROPERTY_TYPE)));
193cdf0e10cSrcweir 	return pInfo;
194cdf0e10cSrcweir }
195cdf0e10cSrcweir // -----------------------------------------------------------------------------
deleteUserData(void * & _pUserData)196cdf0e10cSrcweir void OQueryTableWindow::deleteUserData(void*& _pUserData)
197cdf0e10cSrcweir {
198cdf0e10cSrcweir 	delete static_cast<OTableFieldInfo*>(_pUserData);
199cdf0e10cSrcweir 	_pUserData = NULL;
200cdf0e10cSrcweir }
201cdf0e10cSrcweir //------------------------------------------------------------------------------
OnEntryDoubleClicked(SvLBoxEntry * pEntry)202cdf0e10cSrcweir void OQueryTableWindow::OnEntryDoubleClicked(SvLBoxEntry* pEntry)
203cdf0e10cSrcweir {
204cdf0e10cSrcweir 	DBG_ASSERT(pEntry != NULL, "OQueryTableWindow::OnEntryDoubleClicked : pEntry darf nicht NULL sein !");
205cdf0e10cSrcweir 		// man koennte das auch abfragen und dann ein return hinsetzen, aber so weist es vielleicht auf Fehler bei Aufrufer hin
206cdf0e10cSrcweir 
207cdf0e10cSrcweir 	if (getTableView()->getDesignView()->getController().isReadOnly())
208cdf0e10cSrcweir 		return;
209cdf0e10cSrcweir 
210cdf0e10cSrcweir 	OTableFieldInfo* pInf = static_cast<OTableFieldInfo*>(pEntry->GetUserData());
211cdf0e10cSrcweir 	DBG_ASSERT(pInf != NULL, "OQueryTableWindow::OnEntryDoubleClicked : Feld hat keine FieldInfo !");
212cdf0e10cSrcweir 
213cdf0e10cSrcweir 	// eine DragInfo aufbauen
214cdf0e10cSrcweir 	OTableFieldDescRef aInfo = new OTableFieldDesc(GetTableName(),m_pListBox->GetEntryText(pEntry));
215cdf0e10cSrcweir 	aInfo->SetTabWindow(this);
216cdf0e10cSrcweir 	aInfo->SetAlias(GetAliasName());
217cdf0e10cSrcweir 	aInfo->SetFieldIndex(m_pListBox->GetModel()->GetAbsPos(pEntry));
218cdf0e10cSrcweir 	aInfo->SetDataType(pInf->GetDataType());
219cdf0e10cSrcweir 
220cdf0e10cSrcweir 	// und das entsprechende Feld einfuegen
221cdf0e10cSrcweir 	static_cast<OQueryTableView*>(getTableView())->InsertField(aInfo);
222cdf0e10cSrcweir }
223cdf0e10cSrcweir 
224cdf0e10cSrcweir //------------------------------------------------------------------------------
ExistsField(const::rtl::OUString & strFieldName,OTableFieldDescRef & rInfo)225cdf0e10cSrcweir sal_Bool OQueryTableWindow::ExistsField(const ::rtl::OUString& strFieldName, OTableFieldDescRef& rInfo)
226cdf0e10cSrcweir {
227cdf0e10cSrcweir 	DBG_ASSERT(m_pListBox != NULL, "OQueryTableWindow::ExistsField : habe keine ::com::sun::star::form::ListBox !");
228cdf0e10cSrcweir 	OSL_ENSURE(rInfo.isValid(),"OQueryTableWindow::ExistsField: invlid argument for OTableFieldDescRef!");
229cdf0e10cSrcweir 	Reference< XConnection> xConnection = getTableView()->getDesignView()->getController().getConnection();
230cdf0e10cSrcweir 	sal_Bool bExists = sal_False;
231cdf0e10cSrcweir 	if(xConnection.is())
232cdf0e10cSrcweir 	{
233cdf0e10cSrcweir 		SvLBoxEntry* pEntry = m_pListBox->First();
234cdf0e10cSrcweir 		try
235cdf0e10cSrcweir 		{
236cdf0e10cSrcweir 			Reference<XDatabaseMetaData> xMeta = xConnection->getMetaData();
237cdf0e10cSrcweir 			::comphelper::UStringMixEqual bCase(xMeta.is() && xMeta->supportsMixedCaseQuotedIdentifiers());
238cdf0e10cSrcweir 
239cdf0e10cSrcweir 			while (pEntry)
240cdf0e10cSrcweir 			{
241cdf0e10cSrcweir 				if (bCase(strFieldName,::rtl::OUString(m_pListBox->GetEntryText(pEntry))))
242cdf0e10cSrcweir 				{
243cdf0e10cSrcweir 					OTableFieldInfo* pInf = static_cast<OTableFieldInfo*>(pEntry->GetUserData());
244cdf0e10cSrcweir 					DBG_ASSERT(pInf != NULL, "OQueryTableWindow::ExistsField : Feld hat keine FieldInfo !");
245cdf0e10cSrcweir 
246cdf0e10cSrcweir 					rInfo->SetTabWindow(this);
247cdf0e10cSrcweir 					rInfo->SetField(strFieldName);
248cdf0e10cSrcweir 					rInfo->SetTable(GetTableName());
249cdf0e10cSrcweir 					rInfo->SetAlias(GetAliasName());
250cdf0e10cSrcweir 					rInfo->SetFieldIndex(m_pListBox->GetModel()->GetAbsPos(pEntry));
251cdf0e10cSrcweir 					rInfo->SetDataType(pInf->GetDataType());
252cdf0e10cSrcweir 					bExists = sal_True;
253cdf0e10cSrcweir 					break;
254cdf0e10cSrcweir 				}
255cdf0e10cSrcweir 				pEntry = m_pListBox->Next(pEntry);
256cdf0e10cSrcweir 			}
257cdf0e10cSrcweir 		}
258cdf0e10cSrcweir 		catch(SQLException&)
259cdf0e10cSrcweir 		{
260cdf0e10cSrcweir 		}
261cdf0e10cSrcweir 	}
262cdf0e10cSrcweir 
263cdf0e10cSrcweir 	return bExists;
264cdf0e10cSrcweir }
265cdf0e10cSrcweir 
266cdf0e10cSrcweir //------------------------------------------------------------------------------
ExistsAVisitedConn() const267cdf0e10cSrcweir sal_Bool OQueryTableWindow::ExistsAVisitedConn() const
268cdf0e10cSrcweir {
269cdf0e10cSrcweir 	return static_cast<const OQueryTableView*>(getTableView())->ExistsAVisitedConn(this);
270cdf0e10cSrcweir }
271cdf0e10cSrcweir 
272cdf0e10cSrcweir //------------------------------------------------------------------------------
KeyInput(const KeyEvent & rEvt)273cdf0e10cSrcweir void OQueryTableWindow::KeyInput( const KeyEvent& rEvt )
274cdf0e10cSrcweir {
275cdf0e10cSrcweir 	OTableWindow::KeyInput( rEvt );
276cdf0e10cSrcweir }
277cdf0e10cSrcweir // -----------------------------------------------------------------------------
278cdf0e10cSrcweir 
279cdf0e10cSrcweir 
280cdf0e10cSrcweir 
281