LCOV - code coverage report
Current view: top level - sc/source/ui/dbgui - pfiltdlg.cxx (source / functions) Hit Total Coverage
Test: commit c8344322a7af75b84dd3ca8f78b05543a976dfd5 Lines: 0 322 0.0 %
Date: 2015-06-13 12:38:46 Functions: 0 18 0.0 %
Legend: Lines: hit not hit

          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: */

Generated by: LCOV version 1.11