xref: /aoo42x/main/sc/source/ui/dbgui/pfiltdlg.cxx (revision a479921a)
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
25*b77af630Sdamjan #include "precompiled_scui.hxx"
26cdf0e10cSrcweir 
27cdf0e10cSrcweir 
28cdf0e10cSrcweir 
29cdf0e10cSrcweir 
30cdf0e10cSrcweir #ifndef PCH
31cdf0e10cSrcweir #include <vcl/waitobj.hxx>
32cdf0e10cSrcweir #endif
33cdf0e10cSrcweir 
34cdf0e10cSrcweir // INCLUDE ---------------------------------------------------------------
35cdf0e10cSrcweir 
36cdf0e10cSrcweir #include "viewdata.hxx"
37cdf0e10cSrcweir #include "document.hxx"
38cdf0e10cSrcweir #include "uiitems.hxx"
39cdf0e10cSrcweir #include "global.hxx"
40cdf0e10cSrcweir #include "dbcolect.hxx"
41cdf0e10cSrcweir #include "scresid.hxx"
42cdf0e10cSrcweir 
43cdf0e10cSrcweir #include "sc.hrc"
44cdf0e10cSrcweir #include "filter.hrc"
45cdf0e10cSrcweir #include "globstr.hrc"
46cdf0e10cSrcweir 
47cdf0e10cSrcweir #define _PFILTDLG_CXX
48cdf0e10cSrcweir #include "pfiltdlg.hxx"
49cdf0e10cSrcweir #undef _PFILTDLG_CXX
50cdf0e10cSrcweir #include <svl/zforlist.hxx>
51cdf0e10cSrcweir 
52cdf0e10cSrcweir //==================================================================
53cdf0e10cSrcweir 
ScPivotFilterDlg(Window * pParent,const SfxItemSet & rArgSet,SCTAB nSourceTab)54cdf0e10cSrcweir ScPivotFilterDlg::ScPivotFilterDlg( Window*				pParent,
55cdf0e10cSrcweir 									const SfxItemSet&	rArgSet,
56cdf0e10cSrcweir 									SCTAB 				nSourceTab )
57cdf0e10cSrcweir 
58cdf0e10cSrcweir 	:	ModalDialog	( pParent, ScResId( RID_SCDLG_PIVOTFILTER ) ),
59cdf0e10cSrcweir 		//
60cdf0e10cSrcweir         aFlCriteria     ( this, ScResId( FL_CRITERIA ) ),
61cdf0e10cSrcweir 		aLbField1		( this, ScResId( LB_FIELD1 ) ),
62cdf0e10cSrcweir 		aLbCond1		( this, ScResId( LB_COND1 ) ),
63cdf0e10cSrcweir 		aEdVal1			( this, ScResId( ED_VAL1 ) ),
64cdf0e10cSrcweir 		aLbConnect1		( this, ScResId( LB_OP1 ) ),
65cdf0e10cSrcweir 		aLbField2		( this, ScResId( LB_FIELD2 ) ),
66cdf0e10cSrcweir 		aLbCond2		( this, ScResId( LB_COND2 ) ),
67cdf0e10cSrcweir 		aEdVal2			( this, ScResId( ED_VAL2 ) ),
68cdf0e10cSrcweir 		aLbConnect2		( this, ScResId( LB_OP2 ) ),
69cdf0e10cSrcweir 		aLbField3		( this, ScResId( LB_FIELD3 ) ),
70cdf0e10cSrcweir 		aLbCond3		( this, ScResId( LB_COND3 ) ),
71cdf0e10cSrcweir 		aEdVal3			( this, ScResId( ED_VAL3 ) ),
72cdf0e10cSrcweir 		aFtConnect		( this, ScResId( FT_OP ) ),
73cdf0e10cSrcweir 		aFtField		( this, ScResId( FT_FIELD ) ),
74cdf0e10cSrcweir 		aFtCond			( this, ScResId( FT_COND ) ),
75cdf0e10cSrcweir 		aFtVal			( this, ScResId( FT_VAL ) ),
76cdf0e10cSrcweir         aFlOptions      ( this, ScResId( FL_OPTIONS ) ),
77cdf0e10cSrcweir 		aBtnCase		( this, ScResId( BTN_CASE ) ),
78cdf0e10cSrcweir 		aBtnRegExp		( this, ScResId( BTN_REGEXP ) ),
79cdf0e10cSrcweir 		aBtnUnique		( this, ScResId( BTN_UNIQUE ) ),
80cdf0e10cSrcweir 		aFtDbAreaLabel	( this, ScResId( FT_DBAREA_LABEL ) ),
81cdf0e10cSrcweir 		aFtDbArea		( this, ScResId( FT_DBAREA ) ),
82cdf0e10cSrcweir 		aBtnOk			( this, ScResId( BTN_OK ) ),
83cdf0e10cSrcweir 		aBtnCancel		( this, ScResId( BTN_CANCEL ) ),
84cdf0e10cSrcweir 		aBtnHelp		( this, ScResId( BTN_HELP ) ),
85cdf0e10cSrcweir 		aBtnMore		( this, ScResId( BTN_MORE ) ),
86cdf0e10cSrcweir 		aStrUndefined	( ScResId( SCSTR_UNDEFINED ) ),
87cdf0e10cSrcweir 		aStrNoName		( ScGlobal::GetRscString(STR_DB_NONAME) ),
88cdf0e10cSrcweir 		aStrNone		( ScResId( SCSTR_NONE ) ),
89cdf0e10cSrcweir 		aStrEmpty		( ScResId( SCSTR_EMPTY ) ),
90cdf0e10cSrcweir 		aStrNotEmpty	( ScResId( SCSTR_NOTEMPTY ) ),
91cdf0e10cSrcweir 		aStrRow			( ScResId( SCSTR_ROW ) ),
92cdf0e10cSrcweir 		aStrColumn		( ScResId( SCSTR_COLUMN ) ),
93cdf0e10cSrcweir 		//
94cdf0e10cSrcweir 		nWhichQuery		( rArgSet.GetPool()->GetWhich( SID_QUERY ) ),
95cdf0e10cSrcweir 		theQueryData	( ((const ScQueryItem&)
96cdf0e10cSrcweir 						   rArgSet.Get( nWhichQuery )).GetQueryData() ),
97cdf0e10cSrcweir 		pOutItem		( NULL ),
98cdf0e10cSrcweir 		pViewData		( NULL ),
99cdf0e10cSrcweir 		pDoc			( NULL ),
100cdf0e10cSrcweir 		nSrcTab			( nSourceTab ),		// ist nicht im QueryParam
101cdf0e10cSrcweir 		nFieldCount		( 0 )
102cdf0e10cSrcweir {
103cdf0e10cSrcweir 	for (sal_uInt16 i=0; i<=MAXCOL; i++)
104cdf0e10cSrcweir 		pEntryLists[i] = NULL;
105cdf0e10cSrcweir 
106cdf0e10cSrcweir 	Init( rArgSet );
107cdf0e10cSrcweir 	FreeResource();
108cdf0e10cSrcweir }
109cdf0e10cSrcweir 
110cdf0e10cSrcweir //------------------------------------------------------------------------
111cdf0e10cSrcweir 
~ScPivotFilterDlg()112cdf0e10cSrcweir __EXPORT ScPivotFilterDlg::~ScPivotFilterDlg()
113cdf0e10cSrcweir {
114cdf0e10cSrcweir 	for (sal_uInt16 i=0; i<=MAXCOL; i++)
115cdf0e10cSrcweir 		delete pEntryLists[i];
116cdf0e10cSrcweir 
117cdf0e10cSrcweir 	if ( pOutItem )
118cdf0e10cSrcweir 		delete pOutItem;
119cdf0e10cSrcweir }
120cdf0e10cSrcweir 
121cdf0e10cSrcweir //------------------------------------------------------------------------
122cdf0e10cSrcweir 
Init(const SfxItemSet & rArgSet)123cdf0e10cSrcweir void __EXPORT ScPivotFilterDlg::Init( const SfxItemSet& rArgSet )
124cdf0e10cSrcweir {
125cdf0e10cSrcweir 	const ScQueryItem& rQueryItem = (const ScQueryItem&)
126cdf0e10cSrcweir 									rArgSet.Get( nWhichQuery );
127cdf0e10cSrcweir 
128cdf0e10cSrcweir 	aBtnCase.SetClickHdl	( LINK( this, ScPivotFilterDlg, CheckBoxHdl ) );
129cdf0e10cSrcweir 
130cdf0e10cSrcweir 	aLbField1.SetSelectHdl	( LINK( this, ScPivotFilterDlg, LbSelectHdl ) );
131cdf0e10cSrcweir 	aLbField2.SetSelectHdl	( LINK( this, ScPivotFilterDlg, LbSelectHdl ) );
132cdf0e10cSrcweir 	aLbField3.SetSelectHdl	( LINK( this, ScPivotFilterDlg, LbSelectHdl ) );
133cdf0e10cSrcweir 	aLbConnect1.SetSelectHdl( LINK( this, ScPivotFilterDlg, LbSelectHdl ) );
134cdf0e10cSrcweir 	aLbConnect2.SetSelectHdl( LINK( this, ScPivotFilterDlg, LbSelectHdl ) );
135cdf0e10cSrcweir 
136cdf0e10cSrcweir 	aBtnMore.AddWindow( &aBtnCase );
137cdf0e10cSrcweir 	aBtnMore.AddWindow( &aBtnRegExp );
138cdf0e10cSrcweir 	aBtnMore.AddWindow( &aBtnUnique );
139cdf0e10cSrcweir 	aBtnMore.AddWindow( &aFtDbAreaLabel );
140cdf0e10cSrcweir 	aBtnMore.AddWindow( &aFtDbArea );
141cdf0e10cSrcweir     aBtnMore.AddWindow( &aFlOptions );
142cdf0e10cSrcweir 
143cdf0e10cSrcweir 	aBtnCase	.Check( theQueryData.bCaseSens );
144cdf0e10cSrcweir 	aBtnRegExp	.Check( theQueryData.bRegExp );
145cdf0e10cSrcweir 	aBtnUnique	.Check( !theQueryData.bDuplicate );
146cdf0e10cSrcweir 
147cdf0e10cSrcweir 	pViewData 	= rQueryItem.GetViewData();
148cdf0e10cSrcweir 	pDoc	  	= pViewData ? pViewData->GetDocument() : NULL;
149cdf0e10cSrcweir 
150cdf0e10cSrcweir 	// fuer leichteren Zugriff:
151cdf0e10cSrcweir 	aFieldLbArr	 [0] = &aLbField1;
152cdf0e10cSrcweir 	aFieldLbArr	 [1] = &aLbField2;
153cdf0e10cSrcweir 	aFieldLbArr	 [2] = &aLbField3;
154cdf0e10cSrcweir 	aValueEdArr	 [0] = &aEdVal1;
155cdf0e10cSrcweir 	aValueEdArr	 [1] = &aEdVal2;
156cdf0e10cSrcweir 	aValueEdArr	 [2] = &aEdVal3;
157cdf0e10cSrcweir 	aCondLbArr	 [0] = &aLbCond1;
158cdf0e10cSrcweir 	aCondLbArr	 [1] = &aLbCond2;
159cdf0e10cSrcweir 	aCondLbArr 	 [2] = &aLbCond3;
160cdf0e10cSrcweir 
161cdf0e10cSrcweir 	if ( pViewData && pDoc )
162cdf0e10cSrcweir 	{
163cdf0e10cSrcweir 		String			theAreaStr;
164cdf0e10cSrcweir 		ScRange			theCurArea ( ScAddress( theQueryData.nCol1,
165cdf0e10cSrcweir 												theQueryData.nRow1,
166cdf0e10cSrcweir 												nSrcTab ),
167cdf0e10cSrcweir 									 ScAddress( theQueryData.nCol2,
168cdf0e10cSrcweir 												theQueryData.nRow2,
169cdf0e10cSrcweir 												nSrcTab ) );
170cdf0e10cSrcweir 		ScDBCollection*	pDBColl		= pDoc->GetDBCollection();
171cdf0e10cSrcweir 		String			theDbArea;
172cdf0e10cSrcweir 		String			theDbName	= aStrNoName;
173cdf0e10cSrcweir 
174cdf0e10cSrcweir 		/*
175cdf0e10cSrcweir 		 * Ueberpruefen, ob es sich bei dem uebergebenen
176cdf0e10cSrcweir 		 * Bereich um einen Datenbankbereich handelt:
177cdf0e10cSrcweir 		 */
178cdf0e10cSrcweir 
179cdf0e10cSrcweir 		theCurArea.Format( theAreaStr, SCR_ABS_3D, pDoc, pDoc->GetAddressConvention() );
180cdf0e10cSrcweir 
181cdf0e10cSrcweir 		if ( pDBColl )
182cdf0e10cSrcweir 		{
183cdf0e10cSrcweir 			ScAddress&	rStart	= theCurArea.aStart;
184cdf0e10cSrcweir 			ScAddress&	rEnd	= theCurArea.aEnd;
185cdf0e10cSrcweir 			ScDBData*	pDBData = pDBColl->GetDBAtArea(	rStart.Tab(),
186cdf0e10cSrcweir 														rStart.Col(), rStart.Row(),
187cdf0e10cSrcweir 														rEnd.Col(),   rEnd.Row() );
188cdf0e10cSrcweir 			if ( pDBData )
189cdf0e10cSrcweir 				pDBData->GetName( theDbName );
190cdf0e10cSrcweir 		}
191cdf0e10cSrcweir 
192cdf0e10cSrcweir 		theDbArea.AppendAscii(RTL_CONSTASCII_STRINGPARAM(" ("));
193cdf0e10cSrcweir 		theDbArea += theDbName;
194cdf0e10cSrcweir 		theDbArea += ')';
195cdf0e10cSrcweir 		aFtDbArea.SetText( theDbArea );
196cdf0e10cSrcweir 	}
197cdf0e10cSrcweir 	else
198cdf0e10cSrcweir 	{
199cdf0e10cSrcweir 		aFtDbArea.SetText( EMPTY_STRING );
200cdf0e10cSrcweir 	}
201cdf0e10cSrcweir 
202cdf0e10cSrcweir 	// Feldlisten einlesen und Eintraege selektieren:
203cdf0e10cSrcweir 
204cdf0e10cSrcweir 	FillFieldLists();
205cdf0e10cSrcweir 
206cdf0e10cSrcweir 	for ( SCSIZE i=0; i<3; i++ )
207cdf0e10cSrcweir 	{
208cdf0e10cSrcweir 		if ( theQueryData.GetEntry(i).bDoQuery )
209cdf0e10cSrcweir 		{
210cdf0e10cSrcweir 			ScQueryEntry& rEntry = theQueryData.GetEntry(i);
211cdf0e10cSrcweir 
212cdf0e10cSrcweir             String	aValStr		 = *rEntry.pStr;
213cdf0e10cSrcweir             if (!rEntry.bQueryByString && aValStr == EMPTY_STRING)
214cdf0e10cSrcweir             {
215cdf0e10cSrcweir                 if (rEntry.nVal == SC_EMPTYFIELDS)
216cdf0e10cSrcweir                     aValStr = aStrEmpty;
217cdf0e10cSrcweir                 else if (rEntry.nVal == SC_NONEMPTYFIELDS)
218cdf0e10cSrcweir                     aValStr = aStrNotEmpty;
219cdf0e10cSrcweir             }
220cdf0e10cSrcweir 			sal_uInt16	nCondPos	 = (sal_uInt16)rEntry.eOp;
221cdf0e10cSrcweir 			sal_uInt16	nFieldSelPos = GetFieldSelPos( static_cast<SCCOL>(rEntry.nField) );
222cdf0e10cSrcweir 
223cdf0e10cSrcweir 			aFieldLbArr[i]->SelectEntryPos( nFieldSelPos );
224cdf0e10cSrcweir 			aCondLbArr [i]->SelectEntryPos( nCondPos );
225cdf0e10cSrcweir 			UpdateValueList( static_cast<sal_uInt16>(i+1) );
226cdf0e10cSrcweir 			aValueEdArr[i]->SetText( aValStr );
227cdf0e10cSrcweir             if (aValStr == aStrEmpty || aValStr == aStrNotEmpty)
228cdf0e10cSrcweir                 aCondLbArr[i]->Disable();
229cdf0e10cSrcweir 		}
230cdf0e10cSrcweir 		else
231cdf0e10cSrcweir 		{
232cdf0e10cSrcweir 			aFieldLbArr[i]->SelectEntryPos( 0 ); // "keiner" selektieren
233cdf0e10cSrcweir 			aCondLbArr [i]->SelectEntryPos( 0 ); // "=" selektieren
234cdf0e10cSrcweir 			UpdateValueList( static_cast<sal_uInt16>(i) );
235cdf0e10cSrcweir 			aValueEdArr[i]->SetText( EMPTY_STRING );
236cdf0e10cSrcweir 		}
237cdf0e10cSrcweir 		aValueEdArr[i]->SetModifyHdl( LINK( this, ScPivotFilterDlg, ValModifyHdl ) );
238cdf0e10cSrcweir 	}
239cdf0e10cSrcweir 
240cdf0e10cSrcweir 	// Disable/Enable Logik:
241cdf0e10cSrcweir 
242cdf0e10cSrcweir 	   (aLbField1.GetSelectEntryPos() != 0)
243cdf0e10cSrcweir 	&& (aLbField2.GetSelectEntryPos() != 0)
244cdf0e10cSrcweir 		? aLbConnect1.SelectEntryPos( (sal_uInt16)theQueryData.GetEntry(1).eConnect )
245cdf0e10cSrcweir 		: aLbConnect1.SetNoSelection();
246cdf0e10cSrcweir 
247cdf0e10cSrcweir 	   (aLbField2.GetSelectEntryPos() != 0)
248cdf0e10cSrcweir 	&& (aLbField3.GetSelectEntryPos() != 0)
249cdf0e10cSrcweir 		? aLbConnect2.SelectEntryPos( (sal_uInt16)theQueryData.GetEntry(2).eConnect )
250cdf0e10cSrcweir 		: aLbConnect2.SetNoSelection();
251cdf0e10cSrcweir 
252cdf0e10cSrcweir 	if ( aLbField1.GetSelectEntryPos() == 0 )
253cdf0e10cSrcweir 	{
254cdf0e10cSrcweir 		aLbConnect1.Disable();
255cdf0e10cSrcweir 		aLbField2.Disable();
256cdf0e10cSrcweir 		aLbCond2.Disable();
257cdf0e10cSrcweir 		aEdVal2.Disable();
258cdf0e10cSrcweir 	}
259cdf0e10cSrcweir 	else if ( aLbConnect1.GetSelectEntryCount() == 0 )
260cdf0e10cSrcweir 	{
261cdf0e10cSrcweir 		aLbField2.Disable();
262cdf0e10cSrcweir 		aLbCond2.Disable();
263cdf0e10cSrcweir 		aEdVal2.Disable();
264cdf0e10cSrcweir 	}
265cdf0e10cSrcweir 
266cdf0e10cSrcweir 	if ( aLbField2.GetSelectEntryPos() == 0 )
267cdf0e10cSrcweir 	{
268cdf0e10cSrcweir 		aLbConnect2.Disable();
269cdf0e10cSrcweir 		aLbField3.Disable();
270cdf0e10cSrcweir 		aLbCond3.Disable();
271cdf0e10cSrcweir 		aEdVal3.Disable();
272cdf0e10cSrcweir 	}
273cdf0e10cSrcweir 	else if ( aLbConnect2.GetSelectEntryCount() == 0 )
274cdf0e10cSrcweir 	{
275cdf0e10cSrcweir 		aLbField3.Disable();
276cdf0e10cSrcweir 		aLbCond3.Disable();
277cdf0e10cSrcweir 		aEdVal3.Disable();
278cdf0e10cSrcweir 	}
279cdf0e10cSrcweir }
280cdf0e10cSrcweir 
281cdf0e10cSrcweir //------------------------------------------------------------------------
282cdf0e10cSrcweir 
FillFieldLists()283cdf0e10cSrcweir void ScPivotFilterDlg::FillFieldLists()
284cdf0e10cSrcweir {
285cdf0e10cSrcweir 	aLbField1.Clear();
286cdf0e10cSrcweir 	aLbField2.Clear();
287cdf0e10cSrcweir 	aLbField3.Clear();
288cdf0e10cSrcweir 	aLbField1.InsertEntry( aStrNone, 0 );
289cdf0e10cSrcweir 	aLbField2.InsertEntry( aStrNone, 0 );
290cdf0e10cSrcweir 	aLbField3.InsertEntry( aStrNone, 0 );
291cdf0e10cSrcweir 
292cdf0e10cSrcweir 	if ( pDoc )
293cdf0e10cSrcweir 	{
294cdf0e10cSrcweir 		String	aFieldName;
295cdf0e10cSrcweir 		SCTAB	nTab		= nSrcTab;
296cdf0e10cSrcweir 		SCCOL	nFirstCol	= theQueryData.nCol1;
297cdf0e10cSrcweir 		SCROW	nFirstRow	= theQueryData.nRow1;
298cdf0e10cSrcweir 		SCCOL	nMaxCol		= theQueryData.nCol2;
299cdf0e10cSrcweir 		SCCOL	col = 0;
300cdf0e10cSrcweir 		sal_uInt16	i=1;
301cdf0e10cSrcweir 
302cdf0e10cSrcweir 		for ( col=nFirstCol; col<=nMaxCol; col++ )
303cdf0e10cSrcweir 		{
304cdf0e10cSrcweir 			pDoc->GetString( col, nFirstRow, nTab, aFieldName );
305cdf0e10cSrcweir 			if ( aFieldName.Len() == 0 )
306cdf0e10cSrcweir 			{
307cdf0e10cSrcweir 				aFieldName  = aStrColumn;
308cdf0e10cSrcweir 				aFieldName += ' ';
309cdf0e10cSrcweir                 aFieldName += ScColToAlpha( col );
310cdf0e10cSrcweir 			}
311cdf0e10cSrcweir 			aLbField1.InsertEntry( aFieldName, i );
312cdf0e10cSrcweir 			aLbField2.InsertEntry( aFieldName, i );
313cdf0e10cSrcweir 			aLbField3.InsertEntry( aFieldName, i );
314cdf0e10cSrcweir 			i++;
315cdf0e10cSrcweir 		}
316cdf0e10cSrcweir 		nFieldCount = i;
317cdf0e10cSrcweir 	}
318cdf0e10cSrcweir }
319cdf0e10cSrcweir 
320cdf0e10cSrcweir //------------------------------------------------------------------------
321cdf0e10cSrcweir 
UpdateValueList(sal_uInt16 nList)322cdf0e10cSrcweir void ScPivotFilterDlg::UpdateValueList( sal_uInt16 nList )
323cdf0e10cSrcweir {
324cdf0e10cSrcweir 	if ( pDoc && nList>0 && nList<=3 )
325cdf0e10cSrcweir 	{
326cdf0e10cSrcweir 		ComboBox*	pValList		= aValueEdArr[nList-1];
327cdf0e10cSrcweir 		sal_uInt16		nFieldSelPos	= aFieldLbArr[nList-1]->GetSelectEntryPos();
328cdf0e10cSrcweir 		sal_uInt16		nListPos		= 0;
329cdf0e10cSrcweir 		String		aCurValue  		= pValList->GetText();
330cdf0e10cSrcweir 
331cdf0e10cSrcweir 		pValList->Clear();
332cdf0e10cSrcweir 		pValList->InsertEntry( aStrNotEmpty, 0 );
333cdf0e10cSrcweir 		pValList->InsertEntry( aStrEmpty, 1 );
334cdf0e10cSrcweir 		nListPos = 2;
335cdf0e10cSrcweir 
336cdf0e10cSrcweir 		if ( pDoc && nFieldSelPos )
337cdf0e10cSrcweir 		{
338cdf0e10cSrcweir 			SCCOL nColumn = theQueryData.nCol1 + static_cast<SCCOL>(nFieldSelPos) - 1;
339cdf0e10cSrcweir 			if (!pEntryLists[nColumn])
340cdf0e10cSrcweir 			{
341cdf0e10cSrcweir 				WaitObject aWaiter( this );
342cdf0e10cSrcweir 
343cdf0e10cSrcweir 				SCTAB	nTab		= nSrcTab;
344cdf0e10cSrcweir 				SCROW	nFirstRow	= theQueryData.nRow1;
345cdf0e10cSrcweir 				SCROW	nLastRow	= theQueryData.nRow2;
346cdf0e10cSrcweir 				nFirstRow++;
347cdf0e10cSrcweir                 bool bHasDates = false;
348cdf0e10cSrcweir 
349cdf0e10cSrcweir 				pEntryLists[nColumn] = new TypedScStrCollection( 128, 128 );
350cdf0e10cSrcweir 				pEntryLists[nColumn]->SetCaseSensitive( aBtnCase.IsChecked() );
351cdf0e10cSrcweir 				pDoc->GetFilterEntriesArea( nColumn, nFirstRow, nLastRow,
352cdf0e10cSrcweir                                             nTab, *pEntryLists[nColumn], bHasDates );
353cdf0e10cSrcweir 			}
354cdf0e10cSrcweir 
355cdf0e10cSrcweir 			TypedScStrCollection* pColl = pEntryLists[nColumn];
356cdf0e10cSrcweir 			sal_uInt16 nValueCount = pColl->GetCount();
357cdf0e10cSrcweir 			if ( nValueCount > 0 )
358cdf0e10cSrcweir 			{
359cdf0e10cSrcweir 				for ( sal_uInt16 i=0; i<nValueCount; i++ )
360cdf0e10cSrcweir 				{
361cdf0e10cSrcweir 					pValList->InsertEntry( (*pColl)[i]->GetString(), nListPos );
362cdf0e10cSrcweir 					nListPos++;
363cdf0e10cSrcweir 				}
364cdf0e10cSrcweir 			}
365cdf0e10cSrcweir 		}
366cdf0e10cSrcweir 		pValList->SetText( aCurValue );
367cdf0e10cSrcweir 	}
368cdf0e10cSrcweir }
369cdf0e10cSrcweir 
370cdf0e10cSrcweir //------------------------------------------------------------------------
371cdf0e10cSrcweir 
ClearValueList(sal_uInt16 nList)372cdf0e10cSrcweir void ScPivotFilterDlg::ClearValueList( sal_uInt16 nList )
373cdf0e10cSrcweir {
374cdf0e10cSrcweir 	if ( nList>0 && nList<=3 )
375cdf0e10cSrcweir 	{
376cdf0e10cSrcweir 		ComboBox* pValList = aValueEdArr[nList-1];
377cdf0e10cSrcweir 		pValList->Clear();
378cdf0e10cSrcweir 		pValList->InsertEntry( aStrNotEmpty, 0 );
379cdf0e10cSrcweir 		pValList->InsertEntry( aStrEmpty, 1 );
380cdf0e10cSrcweir 		pValList->SetText( EMPTY_STRING );
381cdf0e10cSrcweir 	}
382cdf0e10cSrcweir }
383cdf0e10cSrcweir 
384cdf0e10cSrcweir //------------------------------------------------------------------------
385cdf0e10cSrcweir 
GetFieldSelPos(SCCOL nField)386cdf0e10cSrcweir sal_uInt16 ScPivotFilterDlg::GetFieldSelPos( SCCOL nField )
387cdf0e10cSrcweir {
388cdf0e10cSrcweir 	if ( nField >= theQueryData.nCol1 && nField <= theQueryData.nCol2 )
389cdf0e10cSrcweir 		return static_cast<sal_uInt16>(nField - theQueryData.nCol1 + 1);
390cdf0e10cSrcweir 	else
391cdf0e10cSrcweir 		return 0;
392cdf0e10cSrcweir }
393cdf0e10cSrcweir 
394cdf0e10cSrcweir //------------------------------------------------------------------------
395cdf0e10cSrcweir 
GetOutputItem()396cdf0e10cSrcweir const ScQueryItem& ScPivotFilterDlg::GetOutputItem()
397cdf0e10cSrcweir {
398cdf0e10cSrcweir 	ScQueryParam 	theParam( theQueryData );
399cdf0e10cSrcweir 	sal_uInt16			nConnect1 = aLbConnect1.GetSelectEntryPos();
400cdf0e10cSrcweir 	sal_uInt16 			nConnect2 = aLbConnect2.GetSelectEntryPos();
401cdf0e10cSrcweir 
402cdf0e10cSrcweir 	for ( SCSIZE i=0; i<3; i++ )
403cdf0e10cSrcweir 	{
404cdf0e10cSrcweir 		sal_uInt16 		nField	= aFieldLbArr[i]->GetSelectEntryPos();
405cdf0e10cSrcweir 		ScQueryOp	eOp		= (ScQueryOp)aCondLbArr[i]->GetSelectEntryPos();
406cdf0e10cSrcweir 
407cdf0e10cSrcweir 		sal_Bool bDoThis = (aFieldLbArr[i]->GetSelectEntryPos() != 0);
408cdf0e10cSrcweir 		theParam.GetEntry(i).bDoQuery = bDoThis;
409cdf0e10cSrcweir 
410cdf0e10cSrcweir 		if ( bDoThis )
411cdf0e10cSrcweir 		{
412cdf0e10cSrcweir 			ScQueryEntry& rEntry = theParam.GetEntry(i);
413cdf0e10cSrcweir 
414cdf0e10cSrcweir 			String aStrVal( aValueEdArr[i]->GetText() );
415cdf0e10cSrcweir 
416cdf0e10cSrcweir 			/*
417cdf0e10cSrcweir 			 * Dialog liefert die ausgezeichneten Feldwerte "leer"/"nicht leer"
418cdf0e10cSrcweir 			 * als Konstanten in nVal in Verbindung mit dem Schalter
419cdf0e10cSrcweir 			 * bQueryByString auf FALSE.
420cdf0e10cSrcweir 			 */
421cdf0e10cSrcweir 			if ( aStrVal == aStrEmpty )
422cdf0e10cSrcweir 			{
423cdf0e10cSrcweir 				*rEntry.pStr	= EMPTY_STRING;
424cdf0e10cSrcweir 				rEntry.nVal 	= SC_EMPTYFIELDS;
425cdf0e10cSrcweir 				rEntry.bQueryByString = sal_False;
426cdf0e10cSrcweir 			}
427cdf0e10cSrcweir 			else if ( aStrVal == aStrNotEmpty )
428cdf0e10cSrcweir 			{
429cdf0e10cSrcweir 				*rEntry.pStr	= EMPTY_STRING;
430cdf0e10cSrcweir 				rEntry.nVal		= SC_NONEMPTYFIELDS;
431cdf0e10cSrcweir 				rEntry.bQueryByString = sal_False;
432cdf0e10cSrcweir 			}
433cdf0e10cSrcweir 			else
434cdf0e10cSrcweir 			{
435cdf0e10cSrcweir 				*rEntry.pStr	= aStrVal;
436cdf0e10cSrcweir 				rEntry.nVal		= 0;
437cdf0e10cSrcweir 				rEntry.bQueryByString = sal_True;
438cdf0e10cSrcweir 			}
439cdf0e10cSrcweir 
440cdf0e10cSrcweir             rEntry.nField	= nField ? (theQueryData.nCol1 +
441cdf0e10cSrcweir                     static_cast<SCCOL>(nField) - 1) : static_cast<SCCOL>(0);
442cdf0e10cSrcweir 			rEntry.eOp	  	= eOp;
443cdf0e10cSrcweir 		}
444cdf0e10cSrcweir 	}
445cdf0e10cSrcweir 
446cdf0e10cSrcweir 	theParam.GetEntry(1).eConnect = (nConnect1 != LISTBOX_ENTRY_NOTFOUND)
447cdf0e10cSrcweir 									? (ScQueryConnect)nConnect1
448cdf0e10cSrcweir 									: SC_AND;
449cdf0e10cSrcweir 	theParam.GetEntry(2).eConnect = (nConnect2 != LISTBOX_ENTRY_NOTFOUND)
450cdf0e10cSrcweir 									? (ScQueryConnect)nConnect2
451cdf0e10cSrcweir 									: SC_AND;
452cdf0e10cSrcweir 
453cdf0e10cSrcweir 	theParam.bInplace   = sal_False;
454cdf0e10cSrcweir 	theParam.nDestTab	= 0;	// Woher kommen diese Werte?
455cdf0e10cSrcweir 	theParam.nDestCol	= 0;
456cdf0e10cSrcweir 	theParam.nDestRow	= 0;
457cdf0e10cSrcweir 
458cdf0e10cSrcweir 	theParam.bDuplicate		= !aBtnUnique.IsChecked();
459cdf0e10cSrcweir 	theParam.bCaseSens 		= aBtnCase.IsChecked();
460cdf0e10cSrcweir 	theParam.bRegExp		= aBtnRegExp.IsChecked();
461cdf0e10cSrcweir 
462cdf0e10cSrcweir 	if ( pOutItem ) DELETEZ( pOutItem );
463cdf0e10cSrcweir 	pOutItem = new ScQueryItem( nWhichQuery, &theParam );
464cdf0e10cSrcweir 
465cdf0e10cSrcweir 	return *pOutItem;
466cdf0e10cSrcweir }
467cdf0e10cSrcweir 
468cdf0e10cSrcweir //------------------------------------------------------------------------
469cdf0e10cSrcweir // Handler:
470cdf0e10cSrcweir //------------------------------------------------------------------------
471cdf0e10cSrcweir 
IMPL_LINK(ScPivotFilterDlg,LbSelectHdl,ListBox *,pLb)472cdf0e10cSrcweir IMPL_LINK( ScPivotFilterDlg, LbSelectHdl, ListBox*, pLb )
473cdf0e10cSrcweir {
474cdf0e10cSrcweir 	/*
475cdf0e10cSrcweir 	 * Behandlung der Enable/Disable-Logik,
476cdf0e10cSrcweir 	 * abhaengig davon, welche ListBox angefasst wurde:
477cdf0e10cSrcweir 	 */
478cdf0e10cSrcweir 
479cdf0e10cSrcweir 	if ( pLb == &aLbConnect1 )
480cdf0e10cSrcweir 	{
481cdf0e10cSrcweir 		if ( !aLbField2.IsEnabled() )
482cdf0e10cSrcweir 		{
483cdf0e10cSrcweir 			aLbField2.Enable();
484cdf0e10cSrcweir 			aLbCond2.Enable();
485cdf0e10cSrcweir 			aEdVal2.Enable();
486cdf0e10cSrcweir 		}
487cdf0e10cSrcweir 	}
488cdf0e10cSrcweir 	else if ( pLb == &aLbConnect2 )
489cdf0e10cSrcweir 	{
490cdf0e10cSrcweir 		if ( !aLbField3.IsEnabled() )
491cdf0e10cSrcweir 		{
492cdf0e10cSrcweir 			aLbField3.Enable();
493cdf0e10cSrcweir 			aLbCond3.Enable();
494cdf0e10cSrcweir 			aEdVal3.Enable();
495cdf0e10cSrcweir 		}
496cdf0e10cSrcweir 	}
497cdf0e10cSrcweir 	else if ( pLb == &aLbField1 )
498cdf0e10cSrcweir 	{
499cdf0e10cSrcweir 		if ( aLbField1.GetSelectEntryPos() == 0 )
500cdf0e10cSrcweir 		{
501cdf0e10cSrcweir 			aLbConnect1.SetNoSelection();
502cdf0e10cSrcweir 			aLbConnect2.SetNoSelection();
503cdf0e10cSrcweir 			aLbField2.SelectEntryPos( 0 );
504cdf0e10cSrcweir 			aLbField3.SelectEntryPos( 0 );
505cdf0e10cSrcweir 			aLbCond2.SelectEntryPos( 0 );
506cdf0e10cSrcweir 			aLbCond3.SelectEntryPos( 0 );
507cdf0e10cSrcweir 			ClearValueList( 1 );
508cdf0e10cSrcweir 			ClearValueList( 2 );
509cdf0e10cSrcweir 			ClearValueList( 3 );
510cdf0e10cSrcweir 
511cdf0e10cSrcweir 			aLbConnect1.Disable();
512cdf0e10cSrcweir 			aLbConnect2.Disable();
513cdf0e10cSrcweir 			aLbField2.Disable();
514cdf0e10cSrcweir 			aLbField3.Disable();
515cdf0e10cSrcweir 			aLbCond2.Disable();
516cdf0e10cSrcweir 			aLbCond3.Disable();
517cdf0e10cSrcweir 			aEdVal2.Disable();
518cdf0e10cSrcweir 			aEdVal3.Disable();
519cdf0e10cSrcweir 		}
520cdf0e10cSrcweir 		else
521cdf0e10cSrcweir 		{
522cdf0e10cSrcweir 			UpdateValueList( 1 );
523cdf0e10cSrcweir 			if ( !aLbConnect1.IsEnabled() )
524cdf0e10cSrcweir 			{
525cdf0e10cSrcweir 				aLbConnect1.Enable();
526cdf0e10cSrcweir 			}
527cdf0e10cSrcweir 		}
528cdf0e10cSrcweir 	}
529cdf0e10cSrcweir 	else if ( pLb == &aLbField2 )
530cdf0e10cSrcweir 	{
531cdf0e10cSrcweir 		if ( aLbField2.GetSelectEntryPos() == 0 )
532cdf0e10cSrcweir 		{
533cdf0e10cSrcweir 			aLbConnect2.SetNoSelection();
534cdf0e10cSrcweir 			aLbField3.SelectEntryPos( 0 );
535cdf0e10cSrcweir 			aLbCond3.SelectEntryPos( 0 );
536cdf0e10cSrcweir 			ClearValueList( 2 );
537cdf0e10cSrcweir 			ClearValueList( 3 );
538cdf0e10cSrcweir 
539cdf0e10cSrcweir 			aLbConnect2.Disable();
540cdf0e10cSrcweir 			aLbField3.Disable();
541cdf0e10cSrcweir 			aLbCond3.Disable();
542cdf0e10cSrcweir 			aEdVal3.Disable();
543cdf0e10cSrcweir 		}
544cdf0e10cSrcweir 		else
545cdf0e10cSrcweir 		{
546cdf0e10cSrcweir 			UpdateValueList( 2 );
547cdf0e10cSrcweir 			if ( !aLbConnect2.IsEnabled() )
548cdf0e10cSrcweir 			{
549cdf0e10cSrcweir 				aLbConnect2.Enable();
550cdf0e10cSrcweir 			}
551cdf0e10cSrcweir 		}
552cdf0e10cSrcweir 	}
553cdf0e10cSrcweir 	else if ( pLb == &aLbField3 )
554cdf0e10cSrcweir 	{
555cdf0e10cSrcweir 		( aLbField3.GetSelectEntryPos() == 0 )
556cdf0e10cSrcweir 			? ClearValueList( 3 )
557cdf0e10cSrcweir 			: UpdateValueList( 3 );
558cdf0e10cSrcweir 	}
559cdf0e10cSrcweir 
560cdf0e10cSrcweir 	return 0;
561cdf0e10cSrcweir }
562cdf0e10cSrcweir 
563cdf0e10cSrcweir //----------------------------------------------------------------------------
564cdf0e10cSrcweir 
IMPL_LINK(ScPivotFilterDlg,CheckBoxHdl,CheckBox *,pBox)565cdf0e10cSrcweir IMPL_LINK( ScPivotFilterDlg, CheckBoxHdl, CheckBox*, pBox )
566cdf0e10cSrcweir {
567cdf0e10cSrcweir 	//	bei Gross-/Kleinschreibung die Werte-Listen aktualisieren
568cdf0e10cSrcweir 
569cdf0e10cSrcweir 	if ( pBox == &aBtnCase )					// Wertlisten
570cdf0e10cSrcweir 	{
571cdf0e10cSrcweir 		for (sal_uInt16 i=0; i<=MAXCOL; i++)
572cdf0e10cSrcweir 			DELETEZ( pEntryLists[i] );
573cdf0e10cSrcweir 
574cdf0e10cSrcweir 		String aCurVal1 = aEdVal1.GetText();
575cdf0e10cSrcweir 		String aCurVal2 = aEdVal2.GetText();
576cdf0e10cSrcweir 		String aCurVal3 = aEdVal3.GetText();
577cdf0e10cSrcweir 		UpdateValueList( 1 );
578cdf0e10cSrcweir 		UpdateValueList( 2 );
579cdf0e10cSrcweir 		UpdateValueList( 3 );
580cdf0e10cSrcweir 		aEdVal1.SetText( aCurVal1 );
581cdf0e10cSrcweir 		aEdVal2.SetText( aCurVal2 );
582cdf0e10cSrcweir 		aEdVal3.SetText( aCurVal3 );
583cdf0e10cSrcweir 	}
584cdf0e10cSrcweir 
585cdf0e10cSrcweir 	return 0;
586cdf0e10cSrcweir }
587cdf0e10cSrcweir 
588cdf0e10cSrcweir //------------------------------------------------------------------------
589cdf0e10cSrcweir 
IMPL_LINK(ScPivotFilterDlg,ValModifyHdl,ComboBox *,pEd)590cdf0e10cSrcweir IMPL_LINK( ScPivotFilterDlg, ValModifyHdl, ComboBox*, pEd )
591cdf0e10cSrcweir {
592cdf0e10cSrcweir 	if ( pEd )
593cdf0e10cSrcweir 	{
594cdf0e10cSrcweir 		String aStrVal	= pEd->GetText();
595cdf0e10cSrcweir 		ListBox* pLb	= &aLbCond1;
596cdf0e10cSrcweir 
597cdf0e10cSrcweir 			 if ( pEd == &aEdVal2 ) pLb = &aLbCond2;
598cdf0e10cSrcweir 		else if ( pEd == &aEdVal3 )	pLb = &aLbCond3;
599cdf0e10cSrcweir 
600cdf0e10cSrcweir 		// wenn einer der Sonderwerte leer/nicht-leer
601cdf0e10cSrcweir 		// gewaehlt wird, so macht nur der =-Operator Sinn:
602cdf0e10cSrcweir 
603cdf0e10cSrcweir 		if ( aStrEmpty == aStrVal || aStrNotEmpty == aStrVal )
604cdf0e10cSrcweir 		{
605cdf0e10cSrcweir 			pLb->SelectEntry( '=' );
606cdf0e10cSrcweir 			pLb->Disable();
607cdf0e10cSrcweir 		}
608cdf0e10cSrcweir 		else
609cdf0e10cSrcweir 			pLb->Enable();
610cdf0e10cSrcweir 	}
611cdf0e10cSrcweir 
612cdf0e10cSrcweir 	return 0;
613cdf0e10cSrcweir }
614cdf0e10cSrcweir 
615cdf0e10cSrcweir 
616