LCOV - code coverage report
Current view: top level - sc/source/ui/dbgui - pfiltdlg.cxx (source / functions) Hit Total Coverage
Test: commit 10e77ab3ff6f4314137acd6e2702a6e5c1ce1fae Lines: 0 300 0.0 %
Date: 2014-11-03 Functions: 0 17 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 :     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: */

Generated by: LCOV version 1.10