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