Line data Source code
1 : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : /*
3 : * This file is part of the LibreOffice project.
4 : *
5 : * This Source Code Form is subject to the terms of the Mozilla Public
6 : * License, v. 2.0. If a copy of the MPL was not distributed with this
7 : * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8 : *
9 : * This file incorporates work covered by the following license notice:
10 : *
11 : * Licensed to the Apache Software Foundation (ASF) under one or more
12 : * contributor license agreements. See the NOTICE file distributed
13 : * with this work for additional information regarding copyright
14 : * ownership. The ASF licenses this file to you under the Apache
15 : * License, Version 2.0 (the "License"); you may not use this file
16 : * except in compliance with the License. You may obtain a copy of
17 : * the License at http://www.apache.org/licenses/LICENSE-2.0 .
18 : */
19 :
20 : #undef SC_DLLIMPLEMENTATION
21 :
22 : #include <vcl/waitobj.hxx>
23 :
24 : #include "viewdata.hxx"
25 : #include "document.hxx"
26 : #include "uiitems.hxx"
27 : #include "global.hxx"
28 : #include "globalnames.hxx"
29 : #include "dbdata.hxx"
30 : #include "scresid.hxx"
31 : #include "queryentry.hxx"
32 : #include "typedstrdata.hxx"
33 :
34 : #include "sc.hrc"
35 : #include "filter.hrc"
36 : #include "globstr.hrc"
37 :
38 : #include "pfiltdlg.hxx"
39 : #include <svl/zforlist.hxx>
40 : #include <svl/sharedstringpool.hxx>
41 :
42 0 : ScPivotFilterDlg::ScPivotFilterDlg(vcl::Window* pParent, const SfxItemSet& rArgSet,
43 : SCTAB nSourceTab )
44 : : ModalDialog(pParent, "PivotFilterDialog",
45 : "modules/scalc/ui/pivotfilterdialog.ui" )
46 : ,
47 :
48 : aStrNone ( SC_RESSTR(SCSTR_NONE) ),
49 : aStrEmpty ( SC_RESSTR(SCSTR_FILTER_EMPTY) ),
50 : aStrNotEmpty ( SC_RESSTR(SCSTR_FILTER_NOTEMPTY) ),
51 : aStrColumn ( SC_RESSTR(SCSTR_COLUMN) ),
52 :
53 0 : nWhichQuery ( rArgSet.GetPool()->GetWhich( SID_QUERY ) ),
54 : theQueryData ( static_cast<const ScQueryItem&>(
55 0 : rArgSet.Get( nWhichQuery )).GetQueryData() ),
56 : pOutItem ( NULL ),
57 : pViewData ( NULL ),
58 : pDoc ( NULL ),
59 : nSrcTab ( nSourceTab ), // ist nicht im QueryParam
60 0 : nFieldCount ( 0 )
61 : {
62 0 : get(m_pLbField1, "field1");
63 0 : get(m_pLbCond1, "cond1");
64 0 : get(m_pEdVal1, "val1");
65 0 : get(m_pLbConnect1, "connect1");
66 0 : get(m_pLbField2, "field2");
67 0 : get(m_pLbCond2, "cond2");
68 0 : get(m_pEdVal2, "val2");
69 0 : get(m_pLbConnect2, "connect2");
70 0 : get(m_pLbField3, "field3");
71 0 : get(m_pLbCond3, "cond3");
72 0 : get(m_pEdVal3, "val3");
73 0 : get(m_pBtnCase, "case");
74 0 : get(m_pBtnRegExp, "regexp");
75 0 : get(m_pBtnUnique, "unique");
76 0 : get(m_pFtDbArea, "dbarea");
77 :
78 0 : for (sal_uInt16 i=0; i<=MAXCOL; i++)
79 0 : pEntryLists[i] = NULL;
80 :
81 0 : Init( rArgSet );
82 0 : }
83 :
84 0 : ScPivotFilterDlg::~ScPivotFilterDlg()
85 : {
86 0 : for (sal_uInt16 i=0; i<=MAXCOL; i++)
87 0 : delete pEntryLists[i];
88 :
89 0 : delete pOutItem;
90 0 : }
91 :
92 0 : void ScPivotFilterDlg::Init( const SfxItemSet& rArgSet )
93 : {
94 : const ScQueryItem& rQueryItem = static_cast<const ScQueryItem&>(
95 0 : rArgSet.Get( nWhichQuery ));
96 :
97 0 : m_pBtnCase->SetClickHdl ( LINK( this, ScPivotFilterDlg, CheckBoxHdl ) );
98 :
99 0 : m_pLbField1->SetSelectHdl ( LINK( this, ScPivotFilterDlg, LbSelectHdl ) );
100 0 : m_pLbField2->SetSelectHdl ( LINK( this, ScPivotFilterDlg, LbSelectHdl ) );
101 0 : m_pLbField3->SetSelectHdl ( LINK( this, ScPivotFilterDlg, LbSelectHdl ) );
102 0 : m_pLbConnect1->SetSelectHdl( LINK( this, ScPivotFilterDlg, LbSelectHdl ) );
103 0 : m_pLbConnect2->SetSelectHdl( LINK( this, ScPivotFilterDlg, LbSelectHdl ) );
104 :
105 0 : m_pBtnCase->Check( theQueryData.bCaseSens );
106 0 : m_pBtnRegExp->Check( theQueryData.bRegExp );
107 0 : m_pBtnUnique->Check( !theQueryData.bDuplicate );
108 :
109 0 : pViewData = rQueryItem.GetViewData();
110 0 : pDoc = pViewData ? pViewData->GetDocument() : NULL;
111 :
112 : // fuer leichteren Zugriff:
113 0 : aFieldLbArr [0] = m_pLbField1;
114 0 : aFieldLbArr [1] = m_pLbField2;
115 0 : aFieldLbArr [2] = m_pLbField3;
116 0 : aValueEdArr [0] = m_pEdVal1;
117 0 : aValueEdArr [1] = m_pEdVal2;
118 0 : aValueEdArr [2] = m_pEdVal3;
119 0 : aCondLbArr [0] = m_pLbCond1;
120 0 : aCondLbArr [1] = m_pLbCond2;
121 0 : aCondLbArr [2] = m_pLbCond3;
122 :
123 0 : if ( pViewData && pDoc )
124 : {
125 : ScRange theCurArea ( ScAddress( theQueryData.nCol1,
126 : theQueryData.nRow1,
127 : nSrcTab ),
128 : ScAddress( theQueryData.nCol2,
129 : theQueryData.nRow2,
130 0 : nSrcTab ) );
131 0 : ScDBCollection* pDBColl = pDoc->GetDBCollection();
132 0 : OUString theDbName = OUString(STR_DB_LOCAL_NONAME);
133 :
134 : /*
135 : * Ueberpruefen, ob es sich bei dem uebergebenen
136 : * Bereich um einen Datenbankbereich handelt:
137 : */
138 :
139 0 : if ( pDBColl )
140 : {
141 0 : ScAddress& rStart = theCurArea.aStart;
142 0 : ScAddress& rEnd = theCurArea.aEnd;
143 0 : ScDBData* pDBData = pDBColl->GetDBAtArea( rStart.Tab(),
144 0 : rStart.Col(), rStart.Row(),
145 0 : rEnd.Col(), rEnd.Row() );
146 0 : if ( pDBData )
147 0 : theDbName = pDBData->GetName();
148 : }
149 :
150 0 : OUStringBuffer aBuf;
151 0 : aBuf.appendAscii(" (");
152 0 : aBuf.append(theDbName);
153 0 : aBuf.append(')');
154 0 : m_pFtDbArea->SetText(aBuf.makeStringAndClear());
155 : }
156 : else
157 : {
158 0 : m_pFtDbArea->SetText( EMPTY_OUSTRING );
159 : }
160 :
161 : // Feldlisten einlesen und Eintraege selektieren:
162 :
163 0 : FillFieldLists();
164 :
165 0 : for ( SCSIZE i=0; i<3; i++ )
166 : {
167 0 : if ( theQueryData.GetEntry(i).bDoQuery )
168 : {
169 0 : const ScQueryEntry& rEntry = theQueryData.GetEntry(i);
170 0 : const ScQueryEntry::Item& rItem = rEntry.GetQueryItem();
171 0 : OUString aValStr = rItem.maString.getString();
172 0 : if (rEntry.IsQueryByEmpty())
173 0 : aValStr = aStrEmpty;
174 0 : else if (rEntry.IsQueryByNonEmpty())
175 0 : aValStr = aStrNotEmpty;
176 0 : sal_uInt16 nCondPos = (sal_uInt16)rEntry.eOp;
177 0 : sal_uInt16 nFieldSelPos = GetFieldSelPos( static_cast<SCCOL>(rEntry.nField) );
178 :
179 0 : aFieldLbArr[i]->SelectEntryPos( nFieldSelPos );
180 0 : aCondLbArr [i]->SelectEntryPos( nCondPos );
181 0 : UpdateValueList( static_cast<sal_uInt16>(i+1) );
182 0 : aValueEdArr[i]->SetText( aValStr );
183 0 : if (aValStr.equals(aStrEmpty) || aValStr.equals(aStrNotEmpty))
184 0 : aCondLbArr[i]->Disable();
185 : }
186 : else
187 : {
188 0 : aFieldLbArr[i]->SelectEntryPos( 0 ); // "keiner" selektieren
189 0 : aCondLbArr [i]->SelectEntryPos( 0 ); // "=" selektieren
190 0 : UpdateValueList( static_cast<sal_uInt16>(i) );
191 0 : aValueEdArr[i]->SetText( EMPTY_OUSTRING );
192 : }
193 0 : aValueEdArr[i]->SetModifyHdl( LINK( this, ScPivotFilterDlg, ValModifyHdl ) );
194 : }
195 :
196 : // Disable/Enable Logik:
197 :
198 0 : (m_pLbField1->GetSelectEntryPos() != 0)
199 0 : && (m_pLbField2->GetSelectEntryPos() != 0)
200 0 : ? m_pLbConnect1->SelectEntryPos( (sal_uInt16)theQueryData.GetEntry(1).eConnect )
201 0 : : m_pLbConnect1->SetNoSelection();
202 :
203 0 : (m_pLbField2->GetSelectEntryPos() != 0)
204 0 : && (m_pLbField3->GetSelectEntryPos() != 0)
205 0 : ? m_pLbConnect2->SelectEntryPos( (sal_uInt16)theQueryData.GetEntry(2).eConnect )
206 0 : : m_pLbConnect2->SetNoSelection();
207 :
208 0 : if ( m_pLbField1->GetSelectEntryPos() == 0 )
209 : {
210 0 : m_pLbConnect1->Disable();
211 0 : m_pLbField2->Disable();
212 0 : m_pLbCond2->Disable();
213 0 : m_pEdVal2->Disable();
214 : }
215 0 : else if ( m_pLbConnect1->GetSelectEntryCount() == 0 )
216 : {
217 0 : m_pLbField2->Disable();
218 0 : m_pLbCond2->Disable();
219 0 : m_pEdVal2->Disable();
220 : }
221 :
222 0 : if ( m_pLbField2->GetSelectEntryPos() == 0 )
223 : {
224 0 : m_pLbConnect2->Disable();
225 0 : m_pLbField3->Disable();
226 0 : m_pLbCond3->Disable();
227 0 : m_pEdVal3->Disable();
228 : }
229 0 : else if ( m_pLbConnect2->GetSelectEntryCount() == 0 )
230 : {
231 0 : m_pLbField3->Disable();
232 0 : m_pLbCond3->Disable();
233 0 : m_pEdVal3->Disable();
234 : }
235 0 : }
236 :
237 0 : void ScPivotFilterDlg::FillFieldLists()
238 : {
239 0 : m_pLbField1->Clear();
240 0 : m_pLbField2->Clear();
241 0 : m_pLbField3->Clear();
242 0 : m_pLbField1->InsertEntry( aStrNone, 0 );
243 0 : m_pLbField2->InsertEntry( aStrNone, 0 );
244 0 : m_pLbField3->InsertEntry( aStrNone, 0 );
245 :
246 0 : if ( pDoc )
247 : {
248 0 : OUString aFieldName;
249 0 : SCTAB nTab = nSrcTab;
250 0 : SCCOL nFirstCol = theQueryData.nCol1;
251 0 : SCROW nFirstRow = theQueryData.nRow1;
252 0 : SCCOL nMaxCol = theQueryData.nCol2;
253 0 : SCCOL col = 0;
254 0 : sal_uInt16 i=1;
255 :
256 0 : for ( col=nFirstCol; col<=nMaxCol; col++ )
257 : {
258 0 : aFieldName = pDoc->GetString(col, nFirstRow, nTab);
259 0 : if ( aFieldName.isEmpty() )
260 : {
261 0 : aFieldName = ScGlobal::ReplaceOrAppend( aStrColumn, "%1", ScColToAlpha( col ));
262 : }
263 0 : m_pLbField1->InsertEntry( aFieldName, i );
264 0 : m_pLbField2->InsertEntry( aFieldName, i );
265 0 : m_pLbField3->InsertEntry( aFieldName, i );
266 0 : i++;
267 : }
268 0 : nFieldCount = i;
269 : }
270 0 : }
271 :
272 0 : void ScPivotFilterDlg::UpdateValueList( sal_uInt16 nList )
273 : {
274 0 : if ( pDoc && nList>0 && nList<=3 )
275 : {
276 0 : ComboBox* pValList = aValueEdArr[nList-1];
277 0 : sal_Int32 nFieldSelPos = aFieldLbArr[nList-1]->GetSelectEntryPos();
278 0 : sal_Int32 nListPos = 0;
279 0 : OUString aCurValue = pValList->GetText();
280 :
281 0 : pValList->Clear();
282 0 : pValList->InsertEntry( aStrNotEmpty, 0 );
283 0 : pValList->InsertEntry( aStrEmpty, 1 );
284 0 : nListPos = 2;
285 :
286 0 : if ( pDoc && nFieldSelPos )
287 : {
288 0 : SCCOL nColumn = theQueryData.nCol1 + static_cast<SCCOL>(nFieldSelPos) - 1;
289 0 : if (!pEntryLists[nColumn])
290 : {
291 0 : WaitObject aWaiter( this );
292 :
293 0 : SCTAB nTab = nSrcTab;
294 0 : SCROW nFirstRow = theQueryData.nRow1;
295 0 : SCROW nLastRow = theQueryData.nRow2;
296 0 : nFirstRow++;
297 0 : bool bHasDates = false;
298 0 : bool bCaseSens = m_pBtnCase->IsChecked();
299 0 : pEntryLists[nColumn] = new std::vector<ScTypedStrData>;
300 : pDoc->GetFilterEntriesArea(
301 0 : nColumn, nFirstRow, nLastRow, nTab, bCaseSens, *pEntryLists[nColumn], bHasDates);
302 : }
303 :
304 0 : std::vector<ScTypedStrData>* pColl = pEntryLists[nColumn];
305 0 : std::vector<ScTypedStrData>::const_iterator it = pColl->begin(), itEnd = pColl->end();
306 0 : for (; it != itEnd; ++it)
307 : {
308 0 : pValList->InsertEntry(it->GetString(), nListPos);
309 0 : nListPos++;
310 : }
311 : }
312 0 : pValList->SetText( aCurValue );
313 : }
314 0 : }
315 :
316 0 : void ScPivotFilterDlg::ClearValueList( sal_uInt16 nList )
317 : {
318 0 : if ( nList>0 && nList<=3 )
319 : {
320 0 : ComboBox* pValList = aValueEdArr[nList-1];
321 0 : pValList->Clear();
322 0 : pValList->InsertEntry( aStrNotEmpty, 0 );
323 0 : pValList->InsertEntry( aStrEmpty, 1 );
324 0 : pValList->SetText( EMPTY_OUSTRING );
325 : }
326 0 : }
327 :
328 0 : sal_uInt16 ScPivotFilterDlg::GetFieldSelPos( SCCOL nField )
329 : {
330 0 : if ( nField >= theQueryData.nCol1 && nField <= theQueryData.nCol2 )
331 0 : return static_cast<sal_uInt16>(nField - theQueryData.nCol1 + 1);
332 : else
333 0 : return 0;
334 : }
335 :
336 0 : const ScQueryItem& ScPivotFilterDlg::GetOutputItem()
337 : {
338 0 : ScQueryParam theParam( theQueryData );
339 0 : sal_Int32 nConnect1 = m_pLbConnect1->GetSelectEntryPos();
340 0 : sal_Int32 nConnect2 = m_pLbConnect2->GetSelectEntryPos();
341 :
342 0 : svl::SharedStringPool& rPool = pViewData->GetDocument()->GetSharedStringPool();
343 :
344 0 : for ( SCSIZE i=0; i<3; i++ )
345 : {
346 0 : sal_uInt16 nField = aFieldLbArr[i]->GetSelectEntryPos();
347 0 : ScQueryOp eOp = (ScQueryOp)aCondLbArr[i]->GetSelectEntryPos();
348 :
349 0 : bool bDoThis = (aFieldLbArr[i]->GetSelectEntryPos() != 0);
350 0 : theParam.GetEntry(i).bDoQuery = bDoThis;
351 :
352 0 : if ( bDoThis )
353 : {
354 0 : ScQueryEntry& rEntry = theParam.GetEntry(i);
355 0 : ScQueryEntry::Item& rItem = rEntry.GetQueryItem();
356 :
357 0 : OUString aStrVal = aValueEdArr[i]->GetText();
358 :
359 : /*
360 : * Dialog liefert die ausgezeichneten Feldwerte "leer"/"nicht leer"
361 : * als Konstanten in nVal in Verbindung mit dem Schalter
362 : * bQueryByString auf FALSE.
363 : */
364 0 : if ( aStrVal.equals(aStrEmpty) )
365 : {
366 : OSL_ASSERT(eOp == SC_EQUAL);
367 0 : rEntry.SetQueryByEmpty();
368 : }
369 0 : else if ( aStrVal.equals(aStrNotEmpty) )
370 : {
371 : OSL_ASSERT(eOp == SC_EQUAL);
372 0 : rEntry.SetQueryByNonEmpty();
373 : }
374 : else
375 : {
376 0 : rItem.maString = rPool.intern(aStrVal);
377 0 : rItem.mfVal = 0.0;
378 0 : rItem.meType = ScQueryEntry::ByString;
379 : }
380 :
381 0 : rEntry.nField = nField ? (theQueryData.nCol1 +
382 0 : static_cast<SCCOL>(nField) - 1) : static_cast<SCCOL>(0);
383 0 : rEntry.eOp = eOp;
384 : }
385 : }
386 :
387 0 : theParam.GetEntry(1).eConnect = (nConnect1 != LISTBOX_ENTRY_NOTFOUND)
388 : ? (ScQueryConnect)nConnect1
389 0 : : SC_AND;
390 0 : theParam.GetEntry(2).eConnect = (nConnect2 != LISTBOX_ENTRY_NOTFOUND)
391 : ? (ScQueryConnect)nConnect2
392 0 : : SC_AND;
393 :
394 0 : theParam.bInplace = false;
395 0 : theParam.nDestTab = 0; // Woher kommen diese Werte?
396 0 : theParam.nDestCol = 0;
397 0 : theParam.nDestRow = 0;
398 :
399 0 : theParam.bDuplicate = !m_pBtnUnique->IsChecked();
400 0 : theParam.bCaseSens = m_pBtnCase->IsChecked();
401 0 : theParam.bRegExp = m_pBtnRegExp->IsChecked();
402 :
403 0 : if ( pOutItem ) DELETEZ( pOutItem );
404 0 : pOutItem = new ScQueryItem( nWhichQuery, &theParam );
405 :
406 0 : return *pOutItem;
407 : }
408 :
409 : // Handler:
410 :
411 0 : IMPL_LINK( ScPivotFilterDlg, LbSelectHdl, ListBox*, pLb )
412 : {
413 : /*
414 : * Behandlung der Enable/Disable-Logik,
415 : * abhaengig davon, welche ListBox angefasst wurde:
416 : */
417 :
418 0 : if (pLb == m_pLbConnect1)
419 : {
420 0 : if ( !m_pLbField2->IsEnabled() )
421 : {
422 0 : m_pLbField2->Enable();
423 0 : m_pLbCond2->Enable();
424 0 : m_pEdVal2->Enable();
425 : }
426 : }
427 0 : else if (pLb == m_pLbConnect2)
428 : {
429 0 : if ( !m_pLbField3->IsEnabled() )
430 : {
431 0 : m_pLbField3->Enable();
432 0 : m_pLbCond3->Enable();
433 0 : m_pEdVal3->Enable();
434 : }
435 : }
436 0 : else if (pLb == m_pLbField1)
437 : {
438 0 : if ( m_pLbField1->GetSelectEntryPos() == 0 )
439 : {
440 0 : m_pLbConnect1->SetNoSelection();
441 0 : m_pLbConnect2->SetNoSelection();
442 0 : m_pLbField2->SelectEntryPos( 0 );
443 0 : m_pLbField3->SelectEntryPos( 0 );
444 0 : m_pLbCond2->SelectEntryPos( 0 );
445 0 : m_pLbCond3->SelectEntryPos( 0 );
446 0 : ClearValueList( 1 );
447 0 : ClearValueList( 2 );
448 0 : ClearValueList( 3 );
449 :
450 0 : m_pLbConnect1->Disable();
451 0 : m_pLbConnect2->Disable();
452 0 : m_pLbField2->Disable();
453 0 : m_pLbField3->Disable();
454 0 : m_pLbCond2->Disable();
455 0 : m_pLbCond3->Disable();
456 0 : m_pEdVal2->Disable();
457 0 : m_pEdVal3->Disable();
458 : }
459 : else
460 : {
461 0 : UpdateValueList( 1 );
462 0 : if ( !m_pLbConnect1->IsEnabled() )
463 : {
464 0 : m_pLbConnect1->Enable();
465 : }
466 : }
467 : }
468 0 : else if (pLb == m_pLbField2)
469 : {
470 0 : if ( m_pLbField2->GetSelectEntryPos() == 0 )
471 : {
472 0 : m_pLbConnect2->SetNoSelection();
473 0 : m_pLbField3->SelectEntryPos( 0 );
474 0 : m_pLbCond3->SelectEntryPos( 0 );
475 0 : ClearValueList( 2 );
476 0 : ClearValueList( 3 );
477 :
478 0 : m_pLbConnect2->Disable();
479 0 : m_pLbField3->Disable();
480 0 : m_pLbCond3->Disable();
481 0 : m_pEdVal3->Disable();
482 : }
483 : else
484 : {
485 0 : UpdateValueList( 2 );
486 0 : if ( !m_pLbConnect2->IsEnabled() )
487 : {
488 0 : m_pLbConnect2->Enable();
489 : }
490 : }
491 : }
492 0 : else if (pLb == m_pLbField3)
493 : {
494 0 : ( m_pLbField3->GetSelectEntryPos() == 0 )
495 0 : ? ClearValueList( 3 )
496 0 : : UpdateValueList( 3 );
497 : }
498 :
499 0 : return 0;
500 : }
501 :
502 0 : IMPL_LINK( ScPivotFilterDlg, CheckBoxHdl, CheckBox*, pBox )
503 : {
504 : // bei Gross-/Kleinschreibung die Werte-Listen aktualisieren
505 :
506 0 : if (pBox == m_pBtnCase) // Wertlisten
507 : {
508 0 : for (sal_uInt16 i=0; i<=MAXCOL; i++)
509 0 : DELETEZ( pEntryLists[i] );
510 :
511 0 : OUString aCurVal1 = m_pEdVal1->GetText();
512 0 : OUString aCurVal2 = m_pEdVal2->GetText();
513 0 : OUString aCurVal3 = m_pEdVal3->GetText();
514 0 : UpdateValueList( 1 );
515 0 : UpdateValueList( 2 );
516 0 : UpdateValueList( 3 );
517 0 : m_pEdVal1->SetText( aCurVal1 );
518 0 : m_pEdVal2->SetText( aCurVal2 );
519 0 : m_pEdVal3->SetText( aCurVal3 );
520 : }
521 :
522 0 : return 0;
523 : }
524 :
525 0 : IMPL_LINK( ScPivotFilterDlg, ValModifyHdl, ComboBox*, pEd )
526 : {
527 0 : if ( pEd )
528 : {
529 0 : OUString aStrVal = pEd->GetText();
530 0 : ListBox* pLb = m_pLbCond1;
531 :
532 0 : if ( pEd == m_pEdVal2 ) pLb = m_pLbCond2;
533 0 : else if ( pEd == m_pEdVal3 ) pLb = m_pLbCond3;
534 :
535 : // wenn einer der Sonderwerte leer/nicht-leer
536 : // gewaehlt wird, so macht nur der =-Operator Sinn:
537 :
538 0 : if ( aStrEmpty.equals(aStrVal) || aStrNotEmpty.equals(aStrVal) )
539 : {
540 0 : pLb->SelectEntry(OUString('='));
541 0 : pLb->Disable();
542 : }
543 : else
544 0 : pLb->Enable();
545 : }
546 :
547 0 : return 0;
548 0 : }
549 :
550 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|