xref: /trunk/main/sc/source/ui/dbgui/foptmgr.cxx (revision 22407013)
1b3f79822SAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3b3f79822SAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4b3f79822SAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5b3f79822SAndrew Rist  * distributed with this work for additional information
6b3f79822SAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7b3f79822SAndrew Rist  * to you under the Apache License, Version 2.0 (the
8b3f79822SAndrew Rist  * "License"); you may not use this file except in compliance
9b3f79822SAndrew Rist  * with the License.  You may obtain a copy of the License at
10b3f79822SAndrew Rist  *
11b3f79822SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12b3f79822SAndrew Rist  *
13b3f79822SAndrew Rist  * Unless required by applicable law or agreed to in writing,
14b3f79822SAndrew Rist  * software distributed under the License is distributed on an
15b3f79822SAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16b3f79822SAndrew Rist  * KIND, either express or implied.  See the License for the
17b3f79822SAndrew Rist  * specific language governing permissions and limitations
18b3f79822SAndrew Rist  * under the License.
19b3f79822SAndrew Rist  *
20b3f79822SAndrew Rist  *************************************************************/
21b3f79822SAndrew Rist 
22b3f79822SAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_sc.hxx"
26cdf0e10cSrcweir 
27cdf0e10cSrcweir // System - Includes ---------------------------------------------------------
28cdf0e10cSrcweir 
29cdf0e10cSrcweir 
30cdf0e10cSrcweir 
31cdf0e10cSrcweir // INCLUDE -------------------------------------------------------------------
32cdf0e10cSrcweir 
33cdf0e10cSrcweir #include <vcl/morebtn.hxx>
34cdf0e10cSrcweir #include <svtools/stdctrl.hxx>
35cdf0e10cSrcweir 
36cdf0e10cSrcweir #include "anyrefdg.hxx"
37cdf0e10cSrcweir #include "rangeutl.hxx"
38cdf0e10cSrcweir #include "dbcolect.hxx"
39cdf0e10cSrcweir #include "viewdata.hxx"
40cdf0e10cSrcweir #include "document.hxx"
41cdf0e10cSrcweir #include "queryparam.hxx"
42cdf0e10cSrcweir 
43cdf0e10cSrcweir #define _FOPTMGR_CXX
44cdf0e10cSrcweir #include "foptmgr.hxx"
45cdf0e10cSrcweir #undef _FOPTMGR_CXX
46cdf0e10cSrcweir 
47cdf0e10cSrcweir //----------------------------------------------------------------------------
48cdf0e10cSrcweir 
ScFilterOptionsMgr(Dialog * ptrDlg,ScViewData * ptrViewData,const ScQueryParam & refQueryData,MoreButton & refBtnMore,CheckBox & refBtnCase,CheckBox & refBtnRegExp,CheckBox & refBtnHeader,CheckBox & refBtnUnique,CheckBox & refBtnCopyResult,CheckBox & refBtnDestPers,ListBox & refLbCopyArea,Edit & refEdCopyArea,formula::RefButton & refRbCopyArea,FixedText & refFtDbAreaLabel,FixedInfo & refFtDbArea,FixedLine & refFlOptions,const String & refStrNoName,const String & refStrUndefined)49cdf0e10cSrcweir ScFilterOptionsMgr::ScFilterOptionsMgr(
50cdf0e10cSrcweir 								Dialog*				ptrDlg,
51cdf0e10cSrcweir 								ScViewData*			ptrViewData,
52cdf0e10cSrcweir 								const ScQueryParam&	refQueryData,
53cdf0e10cSrcweir 								MoreButton&			refBtnMore,
54cdf0e10cSrcweir 								CheckBox&			refBtnCase,
55cdf0e10cSrcweir 								CheckBox&			refBtnRegExp,
56cdf0e10cSrcweir 								CheckBox&			refBtnHeader,
57cdf0e10cSrcweir 								CheckBox&			refBtnUnique,
58cdf0e10cSrcweir 								CheckBox&			refBtnCopyResult,
59cdf0e10cSrcweir 								CheckBox&			refBtnDestPers,
60cdf0e10cSrcweir 								ListBox&			refLbCopyArea,
61cdf0e10cSrcweir 								Edit&				refEdCopyArea,
62cdf0e10cSrcweir 								formula::RefButton&		refRbCopyArea,
63cdf0e10cSrcweir 								FixedText&			refFtDbAreaLabel,
64cdf0e10cSrcweir 								FixedInfo&			refFtDbArea,
65cdf0e10cSrcweir                                 FixedLine&          refFlOptions,
66cdf0e10cSrcweir 								const String&		refStrNoName,
67cdf0e10cSrcweir 								const String&		refStrUndefined )
68cdf0e10cSrcweir 
69cdf0e10cSrcweir 	:	pDlg			( ptrDlg ),
70cdf0e10cSrcweir 		pViewData		( ptrViewData ),
71cdf0e10cSrcweir 		pDoc			( ptrViewData ? ptrViewData->GetDocument() : NULL ),
72cdf0e10cSrcweir 		rBtnMore		( refBtnMore ),
73cdf0e10cSrcweir 		rBtnCase		( refBtnCase ),
74cdf0e10cSrcweir 		rBtnRegExp		( refBtnRegExp ),
75cdf0e10cSrcweir 		rBtnHeader		( refBtnHeader ),
76cdf0e10cSrcweir 		rBtnUnique		( refBtnUnique ),
77cdf0e10cSrcweir 		rBtnCopyResult	( refBtnCopyResult ),
78cdf0e10cSrcweir 		rBtnDestPers	( refBtnDestPers ),
79cdf0e10cSrcweir 		rLbCopyPos		( refLbCopyArea ),
80cdf0e10cSrcweir 		rEdCopyPos		( refEdCopyArea ),
81cdf0e10cSrcweir 		rRbCopyPos		( refRbCopyArea ),
82cdf0e10cSrcweir 		rFtDbAreaLabel	( refFtDbAreaLabel ),
83cdf0e10cSrcweir 		rFtDbArea		( refFtDbArea ),
84cdf0e10cSrcweir         rFlOptions      ( refFlOptions ),
85cdf0e10cSrcweir 		rStrNoName		( refStrNoName ),
86cdf0e10cSrcweir 		rStrUndefined	( refStrUndefined ),
87cdf0e10cSrcweir 		rQueryData		( refQueryData )
88cdf0e10cSrcweir {
89cdf0e10cSrcweir 	Init();
90cdf0e10cSrcweir }
91cdf0e10cSrcweir 
92cdf0e10cSrcweir 
93cdf0e10cSrcweir //----------------------------------------------------------------------------
94cdf0e10cSrcweir 
~ScFilterOptionsMgr()95cdf0e10cSrcweir ScFilterOptionsMgr::~ScFilterOptionsMgr()
96cdf0e10cSrcweir {
97cdf0e10cSrcweir 	sal_uInt16 nEntries = rLbCopyPos.GetEntryCount();
98cdf0e10cSrcweir 	sal_uInt16 i;
99cdf0e10cSrcweir 
100cdf0e10cSrcweir 	for ( i=2; i<nEntries; i++ )
101cdf0e10cSrcweir 		delete (String*)rLbCopyPos.GetEntryData( i );
102cdf0e10cSrcweir }
103cdf0e10cSrcweir 
104cdf0e10cSrcweir 
105cdf0e10cSrcweir //----------------------------------------------------------------------------
106cdf0e10cSrcweir 
Init()107cdf0e10cSrcweir void ScFilterOptionsMgr::Init()
108cdf0e10cSrcweir {
109cdf0e10cSrcweir 	DBG_ASSERT( pViewData && pDoc, "Init failed :-/" );
110cdf0e10cSrcweir 
111cdf0e10cSrcweir 	rLbCopyPos.SetSelectHdl	 ( LINK( this, ScFilterOptionsMgr, LbPosSelHdl ) );
112cdf0e10cSrcweir 	rEdCopyPos.SetModifyHdl	 ( LINK( this, ScFilterOptionsMgr, EdPosModifyHdl ) );
113cdf0e10cSrcweir 	rBtnCopyResult.SetClickHdl( LINK( this, ScFilterOptionsMgr, BtnCopyResultHdl ) );
114cdf0e10cSrcweir 
115cdf0e10cSrcweir 	rBtnMore.AddWindow( &rBtnCase );
116cdf0e10cSrcweir 	rBtnMore.AddWindow( &rBtnRegExp );
117cdf0e10cSrcweir 	rBtnMore.AddWindow( &rBtnHeader );
118cdf0e10cSrcweir 	rBtnMore.AddWindow( &rBtnUnique );
119cdf0e10cSrcweir 	rBtnMore.AddWindow( &rBtnCopyResult );
120cdf0e10cSrcweir 	rBtnMore.AddWindow( &rBtnDestPers );
121cdf0e10cSrcweir 	rBtnMore.AddWindow( &rLbCopyPos );
122cdf0e10cSrcweir 	rBtnMore.AddWindow( &rEdCopyPos );
123cdf0e10cSrcweir 	rBtnMore.AddWindow( &rRbCopyPos );
124cdf0e10cSrcweir 	rBtnMore.AddWindow( &rFtDbAreaLabel );
125cdf0e10cSrcweir 	rBtnMore.AddWindow( &rFtDbArea );
126cdf0e10cSrcweir     rBtnMore.AddWindow( &rFlOptions );
127cdf0e10cSrcweir 
128cdf0e10cSrcweir 	rBtnCase	.Check( rQueryData.bCaseSens );
129cdf0e10cSrcweir 	rBtnHeader	.Check( rQueryData.bHasHeader );
130cdf0e10cSrcweir 	rBtnRegExp	.Check( rQueryData.bRegExp );
131cdf0e10cSrcweir 	rBtnUnique	.Check( !rQueryData.bDuplicate );
132cdf0e10cSrcweir 
133cdf0e10cSrcweir 	if ( pViewData && pDoc )
134cdf0e10cSrcweir 	{
135cdf0e10cSrcweir 		String			theAreaStr;
136cdf0e10cSrcweir 		ScRange			theCurArea ( ScAddress( rQueryData.nCol1,
137cdf0e10cSrcweir 												rQueryData.nRow1,
138cdf0e10cSrcweir 												pViewData->GetTabNo() ),
139cdf0e10cSrcweir 									 ScAddress( rQueryData.nCol2,
140cdf0e10cSrcweir 												rQueryData.nRow2,
141cdf0e10cSrcweir 												pViewData->GetTabNo() ) );
142cdf0e10cSrcweir 		ScDBCollection*	pDBColl		= pDoc->GetDBCollection();
143cdf0e10cSrcweir 		String			theDbArea;
144cdf0e10cSrcweir 		String			theDbName	= rStrNoName;
145cdf0e10cSrcweir         const formula::FormulaGrammar::AddressConvention eConv = pDoc->GetAddressConvention();
146cdf0e10cSrcweir 
147cdf0e10cSrcweir 		theCurArea.Format( theAreaStr, SCR_ABS_3D, pDoc, eConv );
148cdf0e10cSrcweir 
149cdf0e10cSrcweir 		// Zielbereichsliste fuellen
150cdf0e10cSrcweir 
151cdf0e10cSrcweir 		rLbCopyPos.Clear();
152cdf0e10cSrcweir 		rLbCopyPos.InsertEntry( rStrUndefined, 0 );
153cdf0e10cSrcweir 
154cdf0e10cSrcweir 		ScAreaNameIterator aIter( pDoc );
155cdf0e10cSrcweir 		String aName;
156cdf0e10cSrcweir 		ScRange aRange;
157cdf0e10cSrcweir 		String aRefStr;
158cdf0e10cSrcweir 		while ( aIter.Next( aName, aRange ) )
159cdf0e10cSrcweir 		{
160cdf0e10cSrcweir 			sal_uInt16 nInsert = rLbCopyPos.InsertEntry( aName );
161cdf0e10cSrcweir 
162cdf0e10cSrcweir 			aRange.aStart.Format( aRefStr, SCA_ABS_3D, pDoc, eConv );
163cdf0e10cSrcweir 			rLbCopyPos.SetEntryData( nInsert, new String( aRefStr ) );
164cdf0e10cSrcweir 		}
165cdf0e10cSrcweir 
166cdf0e10cSrcweir 		rBtnDestPers.Check( sal_True );			// beim Aufruf immer an
167cdf0e10cSrcweir 		rLbCopyPos.SelectEntryPos( 0 );
168cdf0e10cSrcweir 		rEdCopyPos.SetText( EMPTY_STRING );
169cdf0e10cSrcweir 
170cdf0e10cSrcweir 		/*
171cdf0e10cSrcweir 		 * Ueberpruefen, ob es sich bei dem uebergebenen
172cdf0e10cSrcweir 		 * Bereich um einen Datenbankbereich handelt:
173cdf0e10cSrcweir 		 */
174cdf0e10cSrcweir 
175cdf0e10cSrcweir 		theDbArea = theAreaStr;
176cdf0e10cSrcweir 
177*22407013SOliver-Rainer Wittmann         if ( pDBColl )
178*22407013SOliver-Rainer Wittmann         {
179*22407013SOliver-Rainer Wittmann             ScAddress&	rStart	= theCurArea.aStart;
180*22407013SOliver-Rainer Wittmann             ScAddress&	rEnd	= theCurArea.aEnd;
181*22407013SOliver-Rainer Wittmann             ScDBData*	pDBData = pDBColl->GetDBAtArea(
182*22407013SOliver-Rainer Wittmann                 rStart.Tab(), rStart.Col(), rStart.Row(), rEnd.Col(), rEnd.Row() );
183*22407013SOliver-Rainer Wittmann             if ( pDBData )
184*22407013SOliver-Rainer Wittmann             {
185*22407013SOliver-Rainer Wittmann                 rBtnHeader.Check( pDBData->HasHeader() );
186*22407013SOliver-Rainer Wittmann                 pDBData->GetName( theDbName );
187*22407013SOliver-Rainer Wittmann 
188*22407013SOliver-Rainer Wittmann                 if ( !pDBData->IsInternalUnnamed()
189*22407013SOliver-Rainer Wittmann                      && !pDBData->IsInternalForAutoFilter() )
190*22407013SOliver-Rainer Wittmann                 {
191*22407013SOliver-Rainer Wittmann                     rBtnHeader.Disable();
192*22407013SOliver-Rainer Wittmann                 }
193*22407013SOliver-Rainer Wittmann             }
194*22407013SOliver-Rainer Wittmann         }
195cdf0e10cSrcweir 
196cdf0e10cSrcweir 		theDbArea.AppendAscii(RTL_CONSTASCII_STRINGPARAM(" ("));
197cdf0e10cSrcweir 		theDbArea += theDbName;
198cdf0e10cSrcweir 		theDbArea += ')';
199cdf0e10cSrcweir 		rFtDbArea.SetText( theDbArea );
200cdf0e10cSrcweir 
201cdf0e10cSrcweir 		//------------------------------------------------------
202cdf0e10cSrcweir 		// Kopierposition:
203cdf0e10cSrcweir 
204cdf0e10cSrcweir 		if ( !rQueryData.bInplace )
205cdf0e10cSrcweir 		{
206cdf0e10cSrcweir 			String aString;
207cdf0e10cSrcweir 
208cdf0e10cSrcweir 			ScAddress( rQueryData.nDestCol,
209cdf0e10cSrcweir 					   rQueryData.nDestRow,
210cdf0e10cSrcweir 					   rQueryData.nDestTab
211cdf0e10cSrcweir 					 ).Format( aString, SCA_ABS_3D, pDoc, eConv );
212cdf0e10cSrcweir 
213cdf0e10cSrcweir 			rBtnCopyResult.Check( sal_True );
214cdf0e10cSrcweir 			rEdCopyPos.SetText( aString );
215cdf0e10cSrcweir 			EdPosModifyHdl( &rEdCopyPos );
216cdf0e10cSrcweir 			rLbCopyPos.Enable();
217cdf0e10cSrcweir 			rEdCopyPos.Enable();
218cdf0e10cSrcweir 			rRbCopyPos.Enable();
219cdf0e10cSrcweir 			rBtnDestPers.Enable();
220cdf0e10cSrcweir 		}
221cdf0e10cSrcweir 		else
222cdf0e10cSrcweir 		{
223cdf0e10cSrcweir 			rBtnCopyResult.Check( sal_False );
224cdf0e10cSrcweir 			rEdCopyPos.SetText( EMPTY_STRING );
225cdf0e10cSrcweir 			rLbCopyPos.Disable();
226cdf0e10cSrcweir 			rEdCopyPos.Disable();
227cdf0e10cSrcweir 			rRbCopyPos.Disable();
228cdf0e10cSrcweir 			rBtnDestPers.Disable();
229cdf0e10cSrcweir 		}
230cdf0e10cSrcweir 	}
231cdf0e10cSrcweir 	else
232cdf0e10cSrcweir 		rEdCopyPos.SetText( EMPTY_STRING );
233cdf0e10cSrcweir }
234cdf0e10cSrcweir 
235cdf0e10cSrcweir 
236cdf0e10cSrcweir //----------------------------------------------------------------------------
237cdf0e10cSrcweir 
VerifyPosStr(const String & rPosStr) const238cdf0e10cSrcweir sal_Bool ScFilterOptionsMgr::VerifyPosStr( const String& rPosStr ) const
239cdf0e10cSrcweir {
240cdf0e10cSrcweir 	String aPosStr( rPosStr );
241cdf0e10cSrcweir 	xub_StrLen nColonPos = aPosStr.Search( ':' );
242cdf0e10cSrcweir 
243cdf0e10cSrcweir 	if ( STRING_NOTFOUND != nColonPos )
244cdf0e10cSrcweir 		aPosStr.Erase( nColonPos );
245cdf0e10cSrcweir 
246cdf0e10cSrcweir 	sal_uInt16 nResult = ScAddress().Parse( aPosStr, pDoc, pDoc->GetAddressConvention() );
247cdf0e10cSrcweir 
248cdf0e10cSrcweir 	return ( SCA_VALID == (nResult & SCA_VALID) );
249cdf0e10cSrcweir }
250cdf0e10cSrcweir 
251cdf0e10cSrcweir 
252cdf0e10cSrcweir //----------------------------------------------------------------------------
253cdf0e10cSrcweir // Handler:
254cdf0e10cSrcweir 
255cdf0e10cSrcweir //----------------------------------------------------------------------------
256cdf0e10cSrcweir 
IMPL_LINK(ScFilterOptionsMgr,LbPosSelHdl,ListBox *,pLb)257cdf0e10cSrcweir IMPL_LINK( ScFilterOptionsMgr, LbPosSelHdl, ListBox*, pLb )
258cdf0e10cSrcweir {
259cdf0e10cSrcweir 	if ( pLb == &rLbCopyPos )
260cdf0e10cSrcweir 	{
261cdf0e10cSrcweir 		String aString;
262cdf0e10cSrcweir 		sal_uInt16 nSelPos = rLbCopyPos.GetSelectEntryPos();
263cdf0e10cSrcweir 
264cdf0e10cSrcweir 		if ( nSelPos > 0 )
265cdf0e10cSrcweir 			aString = *(String*)rLbCopyPos.GetEntryData( nSelPos );
266cdf0e10cSrcweir 
267cdf0e10cSrcweir 		rEdCopyPos.SetText( aString );
268cdf0e10cSrcweir 	}
269cdf0e10cSrcweir 
270cdf0e10cSrcweir 	return 0;
271cdf0e10cSrcweir }
272cdf0e10cSrcweir 
273cdf0e10cSrcweir 
274cdf0e10cSrcweir //----------------------------------------------------------------------------
275cdf0e10cSrcweir 
IMPL_LINK(ScFilterOptionsMgr,EdPosModifyHdl,Edit *,pEd)276cdf0e10cSrcweir IMPL_LINK( ScFilterOptionsMgr, EdPosModifyHdl, Edit*, pEd )
277cdf0e10cSrcweir {
278cdf0e10cSrcweir 	if ( pEd == &rEdCopyPos )
279cdf0e10cSrcweir 	{
280cdf0e10cSrcweir 		String	theCurPosStr = pEd->GetText();
281cdf0e10cSrcweir 		sal_uInt16	nResult = ScAddress().Parse( theCurPosStr, pDoc, pDoc->GetAddressConvention() );
282cdf0e10cSrcweir 
283cdf0e10cSrcweir 		if ( SCA_VALID == (nResult & SCA_VALID) )
284cdf0e10cSrcweir 		{
285cdf0e10cSrcweir 			String*	pStr	= NULL;
286cdf0e10cSrcweir 			sal_Bool	bFound	= sal_False;
287cdf0e10cSrcweir 			sal_uInt16	i		= 0;
288cdf0e10cSrcweir 			sal_uInt16	nCount	= rLbCopyPos.GetEntryCount();
289cdf0e10cSrcweir 
290cdf0e10cSrcweir 			for ( i=2; i<nCount && !bFound; i++ )
291cdf0e10cSrcweir 			{
292cdf0e10cSrcweir 				pStr = (String*)rLbCopyPos.GetEntryData( i );
293cdf0e10cSrcweir 				bFound = (theCurPosStr == *pStr);
294cdf0e10cSrcweir 			}
295cdf0e10cSrcweir 
296cdf0e10cSrcweir 			if ( bFound )
297cdf0e10cSrcweir 				rLbCopyPos.SelectEntryPos( --i );
298cdf0e10cSrcweir 			else
299cdf0e10cSrcweir 				rLbCopyPos.SelectEntryPos( 0 );
300cdf0e10cSrcweir 		}
301cdf0e10cSrcweir 		else
302cdf0e10cSrcweir 			rLbCopyPos.SelectEntryPos( 0 );
303cdf0e10cSrcweir 	}
304cdf0e10cSrcweir 
305cdf0e10cSrcweir 	return 0;
306cdf0e10cSrcweir }
307cdf0e10cSrcweir 
308cdf0e10cSrcweir 
309cdf0e10cSrcweir //----------------------------------------------------------------------------
310cdf0e10cSrcweir 
IMPL_LINK(ScFilterOptionsMgr,BtnCopyResultHdl,CheckBox *,pBox)311cdf0e10cSrcweir IMPL_LINK( ScFilterOptionsMgr, BtnCopyResultHdl, CheckBox*, pBox )
312cdf0e10cSrcweir {
313cdf0e10cSrcweir 	if ( pBox == &rBtnCopyResult )
314cdf0e10cSrcweir 	{
315cdf0e10cSrcweir 		if ( pBox->IsChecked() )
316cdf0e10cSrcweir 		{
317cdf0e10cSrcweir 			rBtnDestPers.Enable();
318cdf0e10cSrcweir 			rLbCopyPos.Enable();
319cdf0e10cSrcweir 			rEdCopyPos.Enable();
320cdf0e10cSrcweir 			rRbCopyPos.Enable();
321cdf0e10cSrcweir 			rEdCopyPos.GrabFocus();
322cdf0e10cSrcweir 		}
323cdf0e10cSrcweir 		else
324cdf0e10cSrcweir 		{
325cdf0e10cSrcweir 			rBtnDestPers.Disable();
326cdf0e10cSrcweir 			rLbCopyPos.Disable();
327cdf0e10cSrcweir 			rEdCopyPos.Disable();
328cdf0e10cSrcweir 			rRbCopyPos.Disable();
329cdf0e10cSrcweir 		}
330cdf0e10cSrcweir 	}
331cdf0e10cSrcweir 
332cdf0e10cSrcweir 	return 0;
333cdf0e10cSrcweir }
334