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 : disposeOnce();
87 0 : }
88 :
89 0 : void ScPivotFilterDlg::dispose()
90 : {
91 0 : for (sal_uInt16 i=0; i<=MAXCOL; i++)
92 0 : delete pEntryLists[i];
93 :
94 0 : delete pOutItem;
95 0 : m_pLbField1.clear();
96 0 : m_pLbCond1.clear();
97 0 : m_pEdVal1.clear();
98 0 : m_pLbConnect1.clear();
99 0 : m_pLbField2.clear();
100 0 : m_pLbCond2.clear();
101 0 : m_pEdVal2.clear();
102 0 : m_pLbConnect2.clear();
103 0 : m_pLbField3.clear();
104 0 : m_pLbCond3.clear();
105 0 : m_pEdVal3.clear();
106 0 : m_pBtnCase.clear();
107 0 : m_pBtnRegExp.clear();
108 0 : m_pBtnUnique.clear();
109 0 : m_pFtDbArea.clear();
110 0 : for (auto a : aValueEdArr) a.clear();
111 0 : for (auto a : aFieldLbArr) a.clear();
112 0 : for (auto a : aCondLbArr) a.clear();
113 0 : ModalDialog::dispose();
114 0 : }
115 :
116 0 : void ScPivotFilterDlg::Init( const SfxItemSet& rArgSet )
117 : {
118 : const ScQueryItem& rQueryItem = static_cast<const ScQueryItem&>(
119 0 : rArgSet.Get( nWhichQuery ));
120 :
121 0 : m_pBtnCase->SetClickHdl ( LINK( this, ScPivotFilterDlg, CheckBoxHdl ) );
122 :
123 0 : m_pLbField1->SetSelectHdl ( LINK( this, ScPivotFilterDlg, LbSelectHdl ) );
124 0 : m_pLbField2->SetSelectHdl ( LINK( this, ScPivotFilterDlg, LbSelectHdl ) );
125 0 : m_pLbField3->SetSelectHdl ( LINK( this, ScPivotFilterDlg, LbSelectHdl ) );
126 0 : m_pLbConnect1->SetSelectHdl( LINK( this, ScPivotFilterDlg, LbSelectHdl ) );
127 0 : m_pLbConnect2->SetSelectHdl( LINK( this, ScPivotFilterDlg, LbSelectHdl ) );
128 :
129 0 : m_pBtnCase->Check( theQueryData.bCaseSens );
130 0 : m_pBtnRegExp->Check( theQueryData.bRegExp );
131 0 : m_pBtnUnique->Check( !theQueryData.bDuplicate );
132 :
133 0 : pViewData = rQueryItem.GetViewData();
134 0 : pDoc = pViewData ? pViewData->GetDocument() : NULL;
135 :
136 : // fuer leichteren Zugriff:
137 0 : aFieldLbArr [0] = m_pLbField1;
138 0 : aFieldLbArr [1] = m_pLbField2;
139 0 : aFieldLbArr [2] = m_pLbField3;
140 0 : aValueEdArr [0] = m_pEdVal1;
141 0 : aValueEdArr [1] = m_pEdVal2;
142 0 : aValueEdArr [2] = m_pEdVal3;
143 0 : aCondLbArr [0] = m_pLbCond1;
144 0 : aCondLbArr [1] = m_pLbCond2;
145 0 : aCondLbArr [2] = m_pLbCond3;
146 :
147 0 : if ( pViewData && pDoc )
148 : {
149 : ScRange theCurArea ( ScAddress( theQueryData.nCol1,
150 : theQueryData.nRow1,
151 : nSrcTab ),
152 : ScAddress( theQueryData.nCol2,
153 : theQueryData.nRow2,
154 0 : nSrcTab ) );
155 0 : ScDBCollection* pDBColl = pDoc->GetDBCollection();
156 0 : OUString theDbName = OUString(STR_DB_LOCAL_NONAME);
157 :
158 : /*
159 : * Ueberpruefen, ob es sich bei dem uebergebenen
160 : * Bereich um einen Datenbankbereich handelt:
161 : */
162 :
163 0 : if ( pDBColl )
164 : {
165 0 : ScAddress& rStart = theCurArea.aStart;
166 0 : ScAddress& rEnd = theCurArea.aEnd;
167 0 : ScDBData* pDBData = pDBColl->GetDBAtArea( rStart.Tab(),
168 0 : rStart.Col(), rStart.Row(),
169 0 : rEnd.Col(), rEnd.Row() );
170 0 : if ( pDBData )
171 0 : theDbName = pDBData->GetName();
172 : }
173 :
174 0 : OUStringBuffer aBuf;
175 0 : aBuf.appendAscii(" (");
176 0 : aBuf.append(theDbName);
177 0 : aBuf.append(')');
178 0 : m_pFtDbArea->SetText(aBuf.makeStringAndClear());
179 : }
180 : else
181 : {
182 0 : m_pFtDbArea->SetText( EMPTY_OUSTRING );
183 : }
184 :
185 : // Feldlisten einlesen und Eintraege selektieren:
186 :
187 0 : FillFieldLists();
188 :
189 0 : for ( SCSIZE i=0; i<3; i++ )
190 : {
191 0 : if ( theQueryData.GetEntry(i).bDoQuery )
192 : {
193 0 : const ScQueryEntry& rEntry = theQueryData.GetEntry(i);
194 0 : const ScQueryEntry::Item& rItem = rEntry.GetQueryItem();
195 0 : OUString aValStr = rItem.maString.getString();
196 0 : if (rEntry.IsQueryByEmpty())
197 0 : aValStr = aStrEmpty;
198 0 : else if (rEntry.IsQueryByNonEmpty())
199 0 : aValStr = aStrNotEmpty;
200 0 : sal_uInt16 nCondPos = (sal_uInt16)rEntry.eOp;
201 0 : sal_uInt16 nFieldSelPos = GetFieldSelPos( static_cast<SCCOL>(rEntry.nField) );
202 :
203 0 : aFieldLbArr[i]->SelectEntryPos( nFieldSelPos );
204 0 : aCondLbArr [i]->SelectEntryPos( nCondPos );
205 0 : UpdateValueList( static_cast<sal_uInt16>(i+1) );
206 0 : aValueEdArr[i]->SetText( aValStr );
207 0 : if (aValStr.equals(aStrEmpty) || aValStr.equals(aStrNotEmpty))
208 0 : aCondLbArr[i]->Disable();
209 : }
210 : else
211 : {
212 0 : aFieldLbArr[i]->SelectEntryPos( 0 ); // "keiner" selektieren
213 0 : aCondLbArr [i]->SelectEntryPos( 0 ); // "=" selektieren
214 0 : UpdateValueList( static_cast<sal_uInt16>(i) );
215 0 : aValueEdArr[i]->SetText( EMPTY_OUSTRING );
216 : }
217 0 : aValueEdArr[i]->SetModifyHdl( LINK( this, ScPivotFilterDlg, ValModifyHdl ) );
218 : }
219 :
220 : // Disable/Enable Logik:
221 :
222 0 : (m_pLbField1->GetSelectEntryPos() != 0)
223 0 : && (m_pLbField2->GetSelectEntryPos() != 0)
224 0 : ? m_pLbConnect1->SelectEntryPos( (sal_uInt16)theQueryData.GetEntry(1).eConnect )
225 0 : : m_pLbConnect1->SetNoSelection();
226 :
227 0 : (m_pLbField2->GetSelectEntryPos() != 0)
228 0 : && (m_pLbField3->GetSelectEntryPos() != 0)
229 0 : ? m_pLbConnect2->SelectEntryPos( (sal_uInt16)theQueryData.GetEntry(2).eConnect )
230 0 : : m_pLbConnect2->SetNoSelection();
231 :
232 0 : if ( m_pLbField1->GetSelectEntryPos() == 0 )
233 : {
234 0 : m_pLbConnect1->Disable();
235 0 : m_pLbField2->Disable();
236 0 : m_pLbCond2->Disable();
237 0 : m_pEdVal2->Disable();
238 : }
239 0 : else if ( m_pLbConnect1->GetSelectEntryCount() == 0 )
240 : {
241 0 : m_pLbField2->Disable();
242 0 : m_pLbCond2->Disable();
243 0 : m_pEdVal2->Disable();
244 : }
245 :
246 0 : if ( m_pLbField2->GetSelectEntryPos() == 0 )
247 : {
248 0 : m_pLbConnect2->Disable();
249 0 : m_pLbField3->Disable();
250 0 : m_pLbCond3->Disable();
251 0 : m_pEdVal3->Disable();
252 : }
253 0 : else if ( m_pLbConnect2->GetSelectEntryCount() == 0 )
254 : {
255 0 : m_pLbField3->Disable();
256 0 : m_pLbCond3->Disable();
257 0 : m_pEdVal3->Disable();
258 : }
259 0 : }
260 :
261 0 : void ScPivotFilterDlg::FillFieldLists()
262 : {
263 0 : m_pLbField1->Clear();
264 0 : m_pLbField2->Clear();
265 0 : m_pLbField3->Clear();
266 0 : m_pLbField1->InsertEntry( aStrNone, 0 );
267 0 : m_pLbField2->InsertEntry( aStrNone, 0 );
268 0 : m_pLbField3->InsertEntry( aStrNone, 0 );
269 :
270 0 : if ( pDoc )
271 : {
272 0 : OUString aFieldName;
273 0 : SCTAB nTab = nSrcTab;
274 0 : SCCOL nFirstCol = theQueryData.nCol1;
275 0 : SCROW nFirstRow = theQueryData.nRow1;
276 0 : SCCOL nMaxCol = theQueryData.nCol2;
277 0 : SCCOL col = 0;
278 0 : sal_uInt16 i=1;
279 :
280 0 : for ( col=nFirstCol; col<=nMaxCol; col++ )
281 : {
282 0 : aFieldName = pDoc->GetString(col, nFirstRow, nTab);
283 0 : if ( aFieldName.isEmpty() )
284 : {
285 0 : aFieldName = ScGlobal::ReplaceOrAppend( aStrColumn, "%1", ScColToAlpha( col ));
286 : }
287 0 : m_pLbField1->InsertEntry( aFieldName, i );
288 0 : m_pLbField2->InsertEntry( aFieldName, i );
289 0 : m_pLbField3->InsertEntry( aFieldName, i );
290 0 : i++;
291 : }
292 0 : nFieldCount = i;
293 : }
294 0 : }
295 :
296 0 : void ScPivotFilterDlg::UpdateValueList( sal_uInt16 nList )
297 : {
298 0 : if ( pDoc && nList>0 && nList<=3 )
299 : {
300 0 : ComboBox* pValList = aValueEdArr[nList-1];
301 0 : sal_Int32 nFieldSelPos = aFieldLbArr[nList-1]->GetSelectEntryPos();
302 0 : sal_Int32 nListPos = 0;
303 0 : OUString aCurValue = pValList->GetText();
304 :
305 0 : pValList->Clear();
306 0 : pValList->InsertEntry( aStrNotEmpty, 0 );
307 0 : pValList->InsertEntry( aStrEmpty, 1 );
308 0 : nListPos = 2;
309 :
310 0 : if ( pDoc && nFieldSelPos )
311 : {
312 0 : SCCOL nColumn = theQueryData.nCol1 + static_cast<SCCOL>(nFieldSelPos) - 1;
313 0 : if (!pEntryLists[nColumn])
314 : {
315 0 : WaitObject aWaiter( this );
316 :
317 0 : SCTAB nTab = nSrcTab;
318 0 : SCROW nFirstRow = theQueryData.nRow1;
319 0 : SCROW nLastRow = theQueryData.nRow2;
320 0 : nFirstRow++;
321 0 : bool bHasDates = false;
322 0 : bool bCaseSens = m_pBtnCase->IsChecked();
323 0 : pEntryLists[nColumn] = new std::vector<ScTypedStrData>;
324 : pDoc->GetFilterEntriesArea(
325 0 : nColumn, nFirstRow, nLastRow, nTab, bCaseSens, *pEntryLists[nColumn], bHasDates);
326 : }
327 :
328 0 : std::vector<ScTypedStrData>* pColl = pEntryLists[nColumn];
329 0 : std::vector<ScTypedStrData>::const_iterator it = pColl->begin(), itEnd = pColl->end();
330 0 : for (; it != itEnd; ++it)
331 : {
332 0 : pValList->InsertEntry(it->GetString(), nListPos);
333 0 : nListPos++;
334 : }
335 : }
336 0 : pValList->SetText( aCurValue );
337 : }
338 0 : }
339 :
340 0 : void ScPivotFilterDlg::ClearValueList( sal_uInt16 nList )
341 : {
342 0 : if ( nList>0 && nList<=3 )
343 : {
344 0 : ComboBox* pValList = aValueEdArr[nList-1];
345 0 : pValList->Clear();
346 0 : pValList->InsertEntry( aStrNotEmpty, 0 );
347 0 : pValList->InsertEntry( aStrEmpty, 1 );
348 0 : pValList->SetText( EMPTY_OUSTRING );
349 : }
350 0 : }
351 :
352 0 : sal_uInt16 ScPivotFilterDlg::GetFieldSelPos( SCCOL nField )
353 : {
354 0 : if ( nField >= theQueryData.nCol1 && nField <= theQueryData.nCol2 )
355 0 : return static_cast<sal_uInt16>(nField - theQueryData.nCol1 + 1);
356 : else
357 0 : return 0;
358 : }
359 :
360 0 : const ScQueryItem& ScPivotFilterDlg::GetOutputItem()
361 : {
362 0 : ScQueryParam theParam( theQueryData );
363 0 : sal_Int32 nConnect1 = m_pLbConnect1->GetSelectEntryPos();
364 0 : sal_Int32 nConnect2 = m_pLbConnect2->GetSelectEntryPos();
365 :
366 0 : svl::SharedStringPool& rPool = pViewData->GetDocument()->GetSharedStringPool();
367 :
368 0 : for ( SCSIZE i=0; i<3; i++ )
369 : {
370 0 : sal_uInt16 nField = aFieldLbArr[i]->GetSelectEntryPos();
371 0 : ScQueryOp eOp = (ScQueryOp)aCondLbArr[i]->GetSelectEntryPos();
372 :
373 0 : bool bDoThis = (aFieldLbArr[i]->GetSelectEntryPos() != 0);
374 0 : theParam.GetEntry(i).bDoQuery = bDoThis;
375 :
376 0 : if ( bDoThis )
377 : {
378 0 : ScQueryEntry& rEntry = theParam.GetEntry(i);
379 0 : ScQueryEntry::Item& rItem = rEntry.GetQueryItem();
380 :
381 0 : OUString aStrVal = aValueEdArr[i]->GetText();
382 :
383 : /*
384 : * Dialog liefert die ausgezeichneten Feldwerte "leer"/"nicht leer"
385 : * als Konstanten in nVal in Verbindung mit dem Schalter
386 : * bQueryByString auf FALSE.
387 : */
388 0 : if ( aStrVal.equals(aStrEmpty) )
389 : {
390 : OSL_ASSERT(eOp == SC_EQUAL);
391 0 : rEntry.SetQueryByEmpty();
392 : }
393 0 : else if ( aStrVal.equals(aStrNotEmpty) )
394 : {
395 : OSL_ASSERT(eOp == SC_EQUAL);
396 0 : rEntry.SetQueryByNonEmpty();
397 : }
398 : else
399 : {
400 0 : rItem.maString = rPool.intern(aStrVal);
401 0 : rItem.mfVal = 0.0;
402 0 : rItem.meType = ScQueryEntry::ByString;
403 : }
404 :
405 0 : rEntry.nField = nField ? (theQueryData.nCol1 +
406 0 : static_cast<SCCOL>(nField) - 1) : static_cast<SCCOL>(0);
407 0 : rEntry.eOp = eOp;
408 : }
409 : }
410 :
411 0 : theParam.GetEntry(1).eConnect = (nConnect1 != LISTBOX_ENTRY_NOTFOUND)
412 : ? (ScQueryConnect)nConnect1
413 0 : : SC_AND;
414 0 : theParam.GetEntry(2).eConnect = (nConnect2 != LISTBOX_ENTRY_NOTFOUND)
415 : ? (ScQueryConnect)nConnect2
416 0 : : SC_AND;
417 :
418 0 : theParam.bInplace = false;
419 0 : theParam.nDestTab = 0; // Woher kommen diese Werte?
420 0 : theParam.nDestCol = 0;
421 0 : theParam.nDestRow = 0;
422 :
423 0 : theParam.bDuplicate = !m_pBtnUnique->IsChecked();
424 0 : theParam.bCaseSens = m_pBtnCase->IsChecked();
425 0 : theParam.bRegExp = m_pBtnRegExp->IsChecked();
426 :
427 0 : if ( pOutItem ) DELETEZ( pOutItem );
428 0 : pOutItem = new ScQueryItem( nWhichQuery, &theParam );
429 :
430 0 : return *pOutItem;
431 : }
432 :
433 : // Handler:
434 :
435 0 : IMPL_LINK( ScPivotFilterDlg, LbSelectHdl, ListBox*, pLb )
436 : {
437 : /*
438 : * Behandlung der Enable/Disable-Logik,
439 : * abhaengig davon, welche ListBox angefasst wurde:
440 : */
441 :
442 0 : if (pLb == m_pLbConnect1)
443 : {
444 0 : if ( !m_pLbField2->IsEnabled() )
445 : {
446 0 : m_pLbField2->Enable();
447 0 : m_pLbCond2->Enable();
448 0 : m_pEdVal2->Enable();
449 : }
450 : }
451 0 : else if (pLb == m_pLbConnect2)
452 : {
453 0 : if ( !m_pLbField3->IsEnabled() )
454 : {
455 0 : m_pLbField3->Enable();
456 0 : m_pLbCond3->Enable();
457 0 : m_pEdVal3->Enable();
458 : }
459 : }
460 0 : else if (pLb == m_pLbField1)
461 : {
462 0 : if ( m_pLbField1->GetSelectEntryPos() == 0 )
463 : {
464 0 : m_pLbConnect1->SetNoSelection();
465 0 : m_pLbConnect2->SetNoSelection();
466 0 : m_pLbField2->SelectEntryPos( 0 );
467 0 : m_pLbField3->SelectEntryPos( 0 );
468 0 : m_pLbCond2->SelectEntryPos( 0 );
469 0 : m_pLbCond3->SelectEntryPos( 0 );
470 0 : ClearValueList( 1 );
471 0 : ClearValueList( 2 );
472 0 : ClearValueList( 3 );
473 :
474 0 : m_pLbConnect1->Disable();
475 0 : m_pLbConnect2->Disable();
476 0 : m_pLbField2->Disable();
477 0 : m_pLbField3->Disable();
478 0 : m_pLbCond2->Disable();
479 0 : m_pLbCond3->Disable();
480 0 : m_pEdVal2->Disable();
481 0 : m_pEdVal3->Disable();
482 : }
483 : else
484 : {
485 0 : UpdateValueList( 1 );
486 0 : if ( !m_pLbConnect1->IsEnabled() )
487 : {
488 0 : m_pLbConnect1->Enable();
489 : }
490 : }
491 : }
492 0 : else if (pLb == m_pLbField2)
493 : {
494 0 : if ( m_pLbField2->GetSelectEntryPos() == 0 )
495 : {
496 0 : m_pLbConnect2->SetNoSelection();
497 0 : m_pLbField3->SelectEntryPos( 0 );
498 0 : m_pLbCond3->SelectEntryPos( 0 );
499 0 : ClearValueList( 2 );
500 0 : ClearValueList( 3 );
501 :
502 0 : m_pLbConnect2->Disable();
503 0 : m_pLbField3->Disable();
504 0 : m_pLbCond3->Disable();
505 0 : m_pEdVal3->Disable();
506 : }
507 : else
508 : {
509 0 : UpdateValueList( 2 );
510 0 : if ( !m_pLbConnect2->IsEnabled() )
511 : {
512 0 : m_pLbConnect2->Enable();
513 : }
514 : }
515 : }
516 0 : else if (pLb == m_pLbField3)
517 : {
518 0 : ( m_pLbField3->GetSelectEntryPos() == 0 )
519 0 : ? ClearValueList( 3 )
520 0 : : UpdateValueList( 3 );
521 : }
522 :
523 0 : return 0;
524 : }
525 :
526 0 : IMPL_LINK( ScPivotFilterDlg, CheckBoxHdl, CheckBox*, pBox )
527 : {
528 : // bei Gross-/Kleinschreibung die Werte-Listen aktualisieren
529 :
530 0 : if (pBox == m_pBtnCase) // Wertlisten
531 : {
532 0 : for (sal_uInt16 i=0; i<=MAXCOL; i++)
533 0 : DELETEZ( pEntryLists[i] );
534 :
535 0 : OUString aCurVal1 = m_pEdVal1->GetText();
536 0 : OUString aCurVal2 = m_pEdVal2->GetText();
537 0 : OUString aCurVal3 = m_pEdVal3->GetText();
538 0 : UpdateValueList( 1 );
539 0 : UpdateValueList( 2 );
540 0 : UpdateValueList( 3 );
541 0 : m_pEdVal1->SetText( aCurVal1 );
542 0 : m_pEdVal2->SetText( aCurVal2 );
543 0 : m_pEdVal3->SetText( aCurVal3 );
544 : }
545 :
546 0 : return 0;
547 : }
548 :
549 0 : IMPL_LINK( ScPivotFilterDlg, ValModifyHdl, ComboBox*, pEd )
550 : {
551 0 : if ( pEd )
552 : {
553 0 : OUString aStrVal = pEd->GetText();
554 0 : ListBox* pLb = m_pLbCond1;
555 :
556 0 : if ( pEd == m_pEdVal2 ) pLb = m_pLbCond2;
557 0 : else if ( pEd == m_pEdVal3 ) pLb = m_pLbCond3;
558 :
559 : // wenn einer der Sonderwerte leer/nicht-leer
560 : // gewaehlt wird, so macht nur der =-Operator Sinn:
561 :
562 0 : if ( aStrEmpty.equals(aStrVal) || aStrNotEmpty.equals(aStrVal) )
563 : {
564 0 : pLb->SelectEntry(OUString('='));
565 0 : pLb->Disable();
566 : }
567 : else
568 0 : pLb->Enable();
569 : }
570 :
571 0 : return 0;
572 0 : }
573 :
574 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|