xref: /AOO41X/main/sc/source/ui/dbgui/foptmgr.cxx (revision 8e8ee8fefdac26d905672cc573c35fd0ae1f9356)
1b3f79822SAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3b3f79822SAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4b3f79822SAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5b3f79822SAndrew Rist  * distributed with this work for additional information
6b3f79822SAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7b3f79822SAndrew Rist  * to you under the Apache License, Version 2.0 (the
8b3f79822SAndrew Rist  * "License"); you may not use this file except in compliance
9b3f79822SAndrew Rist  * with the License.  You may obtain a copy of the License at
10cdf0e10cSrcweir  *
11b3f79822SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir  *
13b3f79822SAndrew Rist  * Unless required by applicable law or agreed to in writing,
14b3f79822SAndrew Rist  * software distributed under the License is distributed on an
15b3f79822SAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16b3f79822SAndrew Rist  * KIND, either express or implied.  See the License for the
17b3f79822SAndrew Rist  * specific language governing permissions and limitations
18b3f79822SAndrew Rist  * under the License.
19cdf0e10cSrcweir  *
20b3f79822SAndrew Rist  *************************************************************/
21b3f79822SAndrew Rist 
22b3f79822SAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_sc.hxx"
26cdf0e10cSrcweir 
27cdf0e10cSrcweir // System - Includes ---------------------------------------------------------
28cdf0e10cSrcweir 
29cdf0e10cSrcweir 
30cdf0e10cSrcweir 
31cdf0e10cSrcweir // INCLUDE -------------------------------------------------------------------
32cdf0e10cSrcweir 
33cdf0e10cSrcweir #include <vcl/morebtn.hxx>
34cdf0e10cSrcweir #include <svtools/stdctrl.hxx>
35cdf0e10cSrcweir 
36cdf0e10cSrcweir #include "anyrefdg.hxx"
37cdf0e10cSrcweir #include "rangeutl.hxx"
38cdf0e10cSrcweir #include "dbcolect.hxx"
39cdf0e10cSrcweir #include "viewdata.hxx"
40cdf0e10cSrcweir #include "document.hxx"
41cdf0e10cSrcweir #include "queryparam.hxx"
42cdf0e10cSrcweir 
43cdf0e10cSrcweir #define _FOPTMGR_CXX
44cdf0e10cSrcweir #include "foptmgr.hxx"
45cdf0e10cSrcweir #undef _FOPTMGR_CXX
46cdf0e10cSrcweir 
47cdf0e10cSrcweir //----------------------------------------------------------------------------
48cdf0e10cSrcweir 
ScFilterOptionsMgr(Dialog * ptrDlg,ScViewData * ptrViewData,const ScQueryParam & refQueryData,MoreButton & refBtnMore,CheckBox & refBtnCase,CheckBox & refBtnRegExp,CheckBox & refBtnHeader,CheckBox & refBtnUnique,CheckBox & refBtnCopyResult,CheckBox & refBtnDestPers,ListBox & refLbCopyArea,Edit & refEdCopyArea,formula::RefButton & refRbCopyArea,FixedText & refFtDbAreaLabel,FixedInfo & refFtDbArea,FixedLine & refFlOptions,const String & refStrNoName,const String & refStrUndefined)49cdf0e10cSrcweir ScFilterOptionsMgr::ScFilterOptionsMgr(
50cdf0e10cSrcweir                                 Dialog*             ptrDlg,
51cdf0e10cSrcweir                                 ScViewData*         ptrViewData,
52cdf0e10cSrcweir                                 const ScQueryParam& refQueryData,
53cdf0e10cSrcweir                                 MoreButton&         refBtnMore,
54cdf0e10cSrcweir                                 CheckBox&           refBtnCase,
55cdf0e10cSrcweir                                 CheckBox&           refBtnRegExp,
56cdf0e10cSrcweir                                 CheckBox&           refBtnHeader,
57cdf0e10cSrcweir                                 CheckBox&           refBtnUnique,
58cdf0e10cSrcweir                                 CheckBox&           refBtnCopyResult,
59cdf0e10cSrcweir                                 CheckBox&           refBtnDestPers,
60cdf0e10cSrcweir                                 ListBox&            refLbCopyArea,
61cdf0e10cSrcweir                                 Edit&               refEdCopyArea,
62cdf0e10cSrcweir                                 formula::RefButton&     refRbCopyArea,
63cdf0e10cSrcweir                                 FixedText&          refFtDbAreaLabel,
64cdf0e10cSrcweir                                 FixedInfo&          refFtDbArea,
65cdf0e10cSrcweir                                 FixedLine&          refFlOptions,
66cdf0e10cSrcweir                                 const String&       refStrNoName,
67cdf0e10cSrcweir                                 const String&       refStrUndefined )
68cdf0e10cSrcweir 
69cdf0e10cSrcweir     :   pDlg            ( ptrDlg ),
70cdf0e10cSrcweir         pViewData       ( ptrViewData ),
71cdf0e10cSrcweir         pDoc            ( ptrViewData ? ptrViewData->GetDocument() : NULL ),
72cdf0e10cSrcweir         rBtnMore        ( refBtnMore ),
73cdf0e10cSrcweir         rBtnCase        ( refBtnCase ),
74cdf0e10cSrcweir         rBtnRegExp      ( refBtnRegExp ),
75cdf0e10cSrcweir         rBtnHeader      ( refBtnHeader ),
76cdf0e10cSrcweir         rBtnUnique      ( refBtnUnique ),
77cdf0e10cSrcweir         rBtnCopyResult  ( refBtnCopyResult ),
78cdf0e10cSrcweir         rBtnDestPers    ( refBtnDestPers ),
79cdf0e10cSrcweir         rLbCopyPos      ( refLbCopyArea ),
80cdf0e10cSrcweir         rEdCopyPos      ( refEdCopyArea ),
81cdf0e10cSrcweir         rRbCopyPos      ( refRbCopyArea ),
82cdf0e10cSrcweir         rFtDbAreaLabel  ( refFtDbAreaLabel ),
83cdf0e10cSrcweir         rFtDbArea       ( refFtDbArea ),
84cdf0e10cSrcweir         rFlOptions      ( refFlOptions ),
85cdf0e10cSrcweir         rStrNoName      ( refStrNoName ),
86cdf0e10cSrcweir         rStrUndefined   ( refStrUndefined ),
87cdf0e10cSrcweir         rQueryData      ( refQueryData )
88cdf0e10cSrcweir {
89cdf0e10cSrcweir     Init();
90cdf0e10cSrcweir }
91cdf0e10cSrcweir 
92cdf0e10cSrcweir 
93cdf0e10cSrcweir //----------------------------------------------------------------------------
94cdf0e10cSrcweir 
~ScFilterOptionsMgr()95cdf0e10cSrcweir ScFilterOptionsMgr::~ScFilterOptionsMgr()
96cdf0e10cSrcweir {
97cdf0e10cSrcweir     sal_uInt16 nEntries = rLbCopyPos.GetEntryCount();
98cdf0e10cSrcweir     sal_uInt16 i;
99cdf0e10cSrcweir 
100cdf0e10cSrcweir     for ( i=2; i<nEntries; i++ )
101cdf0e10cSrcweir         delete (String*)rLbCopyPos.GetEntryData( i );
102cdf0e10cSrcweir }
103cdf0e10cSrcweir 
104cdf0e10cSrcweir 
105cdf0e10cSrcweir //----------------------------------------------------------------------------
106cdf0e10cSrcweir 
Init()107cdf0e10cSrcweir void ScFilterOptionsMgr::Init()
108cdf0e10cSrcweir {
109cdf0e10cSrcweir     DBG_ASSERT( pViewData && pDoc, "Init failed :-/" );
110cdf0e10cSrcweir 
111cdf0e10cSrcweir     rLbCopyPos.SetSelectHdl  ( LINK( this, ScFilterOptionsMgr, LbPosSelHdl ) );
112cdf0e10cSrcweir     rEdCopyPos.SetModifyHdl  ( LINK( this, ScFilterOptionsMgr, EdPosModifyHdl ) );
113cdf0e10cSrcweir     rBtnCopyResult.SetClickHdl( LINK( this, ScFilterOptionsMgr, BtnCopyResultHdl ) );
114cdf0e10cSrcweir 
115cdf0e10cSrcweir     rBtnMore.AddWindow( &rBtnCase );
116cdf0e10cSrcweir     rBtnMore.AddWindow( &rBtnRegExp );
117cdf0e10cSrcweir     rBtnMore.AddWindow( &rBtnHeader );
118cdf0e10cSrcweir     rBtnMore.AddWindow( &rBtnUnique );
119cdf0e10cSrcweir     rBtnMore.AddWindow( &rBtnCopyResult );
120cdf0e10cSrcweir     rBtnMore.AddWindow( &rBtnDestPers );
121cdf0e10cSrcweir     rBtnMore.AddWindow( &rLbCopyPos );
122cdf0e10cSrcweir     rBtnMore.AddWindow( &rEdCopyPos );
123cdf0e10cSrcweir     rBtnMore.AddWindow( &rRbCopyPos );
124cdf0e10cSrcweir     rBtnMore.AddWindow( &rFtDbAreaLabel );
125cdf0e10cSrcweir     rBtnMore.AddWindow( &rFtDbArea );
126cdf0e10cSrcweir     rBtnMore.AddWindow( &rFlOptions );
127cdf0e10cSrcweir 
128cdf0e10cSrcweir     rBtnCase    .Check( rQueryData.bCaseSens );
129cdf0e10cSrcweir     rBtnHeader  .Check( rQueryData.bHasHeader );
130cdf0e10cSrcweir     rBtnRegExp  .Check( rQueryData.bRegExp );
131cdf0e10cSrcweir     rBtnUnique  .Check( !rQueryData.bDuplicate );
132cdf0e10cSrcweir 
133cdf0e10cSrcweir     if ( pViewData && pDoc )
134cdf0e10cSrcweir     {
135cdf0e10cSrcweir         String          theAreaStr;
136cdf0e10cSrcweir         ScRange         theCurArea ( ScAddress( rQueryData.nCol1,
137cdf0e10cSrcweir                                                 rQueryData.nRow1,
138cdf0e10cSrcweir                                                 pViewData->GetTabNo() ),
139cdf0e10cSrcweir                                      ScAddress( rQueryData.nCol2,
140cdf0e10cSrcweir                                                 rQueryData.nRow2,
141cdf0e10cSrcweir                                                 pViewData->GetTabNo() ) );
142cdf0e10cSrcweir         ScDBCollection* pDBColl     = pDoc->GetDBCollection();
143cdf0e10cSrcweir         String          theDbArea;
144cdf0e10cSrcweir         String          theDbName   = rStrNoName;
145cdf0e10cSrcweir         const formula::FormulaGrammar::AddressConvention eConv = pDoc->GetAddressConvention();
146cdf0e10cSrcweir 
147cdf0e10cSrcweir         theCurArea.Format( theAreaStr, SCR_ABS_3D, pDoc, eConv );
148cdf0e10cSrcweir 
149cdf0e10cSrcweir         // Zielbereichsliste fuellen
150cdf0e10cSrcweir 
151cdf0e10cSrcweir         rLbCopyPos.Clear();
152cdf0e10cSrcweir         rLbCopyPos.InsertEntry( rStrUndefined, 0 );
153cdf0e10cSrcweir 
154cdf0e10cSrcweir         ScAreaNameIterator aIter( pDoc );
155cdf0e10cSrcweir         String aName;
156cdf0e10cSrcweir         ScRange aRange;
157cdf0e10cSrcweir         String aRefStr;
158cdf0e10cSrcweir         while ( aIter.Next( aName, aRange ) )
159cdf0e10cSrcweir         {
160cdf0e10cSrcweir             sal_uInt16 nInsert = rLbCopyPos.InsertEntry( aName );
161cdf0e10cSrcweir 
162cdf0e10cSrcweir             aRange.aStart.Format( aRefStr, SCA_ABS_3D, pDoc, eConv );
163cdf0e10cSrcweir             rLbCopyPos.SetEntryData( nInsert, new String( aRefStr ) );
164cdf0e10cSrcweir         }
165cdf0e10cSrcweir 
166cdf0e10cSrcweir         rBtnDestPers.Check( sal_True );         // beim Aufruf immer an
167cdf0e10cSrcweir         rLbCopyPos.SelectEntryPos( 0 );
168cdf0e10cSrcweir         rEdCopyPos.SetText( EMPTY_STRING );
169cdf0e10cSrcweir 
170cdf0e10cSrcweir         /*
171cdf0e10cSrcweir          * Ueberpruefen, ob es sich bei dem uebergebenen
172cdf0e10cSrcweir          * Bereich um einen Datenbankbereich handelt:
173cdf0e10cSrcweir          */
174cdf0e10cSrcweir 
175cdf0e10cSrcweir         theDbArea = theAreaStr;
176cdf0e10cSrcweir 
177cdf0e10cSrcweir         if ( pDBColl )
178cdf0e10cSrcweir         {
179cdf0e10cSrcweir             ScAddress&  rStart  = theCurArea.aStart;
180cdf0e10cSrcweir             ScAddress&  rEnd    = theCurArea.aEnd;
181*22407013SOliver-Rainer Wittmann             ScDBData*   pDBData = pDBColl->GetDBAtArea(
182*22407013SOliver-Rainer Wittmann                 rStart.Tab(), rStart.Col(), rStart.Row(), rEnd.Col(), rEnd.Row() );
183cdf0e10cSrcweir             if ( pDBData )
184cdf0e10cSrcweir             {
185cdf0e10cSrcweir                 rBtnHeader.Check( pDBData->HasHeader() );
186cdf0e10cSrcweir                 pDBData->GetName( theDbName );
187cdf0e10cSrcweir 
188*22407013SOliver-Rainer Wittmann                 if ( !pDBData->IsInternalUnnamed()
189*22407013SOliver-Rainer Wittmann                      && !pDBData->IsInternalForAutoFilter() )
190cdf0e10cSrcweir                 {
191cdf0e10cSrcweir                     rBtnHeader.Disable();
192cdf0e10cSrcweir                 }
193cdf0e10cSrcweir             }
194cdf0e10cSrcweir         }
195cdf0e10cSrcweir 
196cdf0e10cSrcweir         theDbArea.AppendAscii(RTL_CONSTASCII_STRINGPARAM(" ("));
197cdf0e10cSrcweir         theDbArea += theDbName;
198cdf0e10cSrcweir         theDbArea += ')';
199cdf0e10cSrcweir         rFtDbArea.SetText( theDbArea );
200cdf0e10cSrcweir 
201cdf0e10cSrcweir         //------------------------------------------------------
202cdf0e10cSrcweir         // Kopierposition:
203cdf0e10cSrcweir 
204cdf0e10cSrcweir         if ( !rQueryData.bInplace )
205cdf0e10cSrcweir         {
206cdf0e10cSrcweir             String aString;
207cdf0e10cSrcweir 
208cdf0e10cSrcweir             ScAddress( rQueryData.nDestCol,
209cdf0e10cSrcweir                        rQueryData.nDestRow,
210cdf0e10cSrcweir                        rQueryData.nDestTab
211cdf0e10cSrcweir                      ).Format( aString, SCA_ABS_3D, pDoc, eConv );
212cdf0e10cSrcweir 
213cdf0e10cSrcweir             rBtnCopyResult.Check( sal_True );
214cdf0e10cSrcweir             rEdCopyPos.SetText( aString );
215cdf0e10cSrcweir             EdPosModifyHdl( &rEdCopyPos );
216cdf0e10cSrcweir             rLbCopyPos.Enable();
217cdf0e10cSrcweir             rEdCopyPos.Enable();
218cdf0e10cSrcweir             rRbCopyPos.Enable();
219cdf0e10cSrcweir             rBtnDestPers.Enable();
220cdf0e10cSrcweir         }
221cdf0e10cSrcweir         else
222cdf0e10cSrcweir         {
223cdf0e10cSrcweir             rBtnCopyResult.Check( sal_False );
224cdf0e10cSrcweir             rEdCopyPos.SetText( EMPTY_STRING );
225cdf0e10cSrcweir             rLbCopyPos.Disable();
226cdf0e10cSrcweir             rEdCopyPos.Disable();
227cdf0e10cSrcweir             rRbCopyPos.Disable();
228cdf0e10cSrcweir             rBtnDestPers.Disable();
229cdf0e10cSrcweir         }
230cdf0e10cSrcweir     }
231cdf0e10cSrcweir     else
232cdf0e10cSrcweir         rEdCopyPos.SetText( EMPTY_STRING );
233cdf0e10cSrcweir }
234cdf0e10cSrcweir 
235cdf0e10cSrcweir 
236cdf0e10cSrcweir //----------------------------------------------------------------------------
237cdf0e10cSrcweir 
VerifyPosStr(const String & rPosStr) const238cdf0e10cSrcweir sal_Bool ScFilterOptionsMgr::VerifyPosStr( const String& rPosStr ) const
239cdf0e10cSrcweir {
240cdf0e10cSrcweir     String aPosStr( rPosStr );
241cdf0e10cSrcweir     xub_StrLen nColonPos = aPosStr.Search( ':' );
242cdf0e10cSrcweir 
243cdf0e10cSrcweir     if ( STRING_NOTFOUND != nColonPos )
244cdf0e10cSrcweir         aPosStr.Erase( nColonPos );
245cdf0e10cSrcweir 
246cdf0e10cSrcweir     sal_uInt16 nResult = ScAddress().Parse( aPosStr, pDoc, pDoc->GetAddressConvention() );
247cdf0e10cSrcweir 
248cdf0e10cSrcweir     return ( SCA_VALID == (nResult & SCA_VALID) );
249cdf0e10cSrcweir }
250cdf0e10cSrcweir 
251cdf0e10cSrcweir 
252cdf0e10cSrcweir //----------------------------------------------------------------------------
253cdf0e10cSrcweir // Handler:
254cdf0e10cSrcweir 
255cdf0e10cSrcweir //----------------------------------------------------------------------------
256cdf0e10cSrcweir 
IMPL_LINK(ScFilterOptionsMgr,LbPosSelHdl,ListBox *,pLb)257cdf0e10cSrcweir IMPL_LINK( ScFilterOptionsMgr, LbPosSelHdl, ListBox*, pLb )
258cdf0e10cSrcweir {
259cdf0e10cSrcweir     if ( pLb == &rLbCopyPos )
260cdf0e10cSrcweir     {
261cdf0e10cSrcweir         String aString;
262cdf0e10cSrcweir         sal_uInt16 nSelPos = rLbCopyPos.GetSelectEntryPos();
263cdf0e10cSrcweir 
264cdf0e10cSrcweir         if ( nSelPos > 0 )
265cdf0e10cSrcweir             aString = *(String*)rLbCopyPos.GetEntryData( nSelPos );
266cdf0e10cSrcweir 
267cdf0e10cSrcweir         rEdCopyPos.SetText( aString );
268cdf0e10cSrcweir     }
269cdf0e10cSrcweir 
270cdf0e10cSrcweir     return 0;
271cdf0e10cSrcweir }
272cdf0e10cSrcweir 
273cdf0e10cSrcweir 
274cdf0e10cSrcweir //----------------------------------------------------------------------------
275cdf0e10cSrcweir 
IMPL_LINK(ScFilterOptionsMgr,EdPosModifyHdl,Edit *,pEd)276cdf0e10cSrcweir IMPL_LINK( ScFilterOptionsMgr, EdPosModifyHdl, Edit*, pEd )
277cdf0e10cSrcweir {
278cdf0e10cSrcweir     if ( pEd == &rEdCopyPos )
279cdf0e10cSrcweir     {
280cdf0e10cSrcweir         String  theCurPosStr = pEd->GetText();
281cdf0e10cSrcweir         sal_uInt16  nResult = ScAddress().Parse( theCurPosStr, pDoc, pDoc->GetAddressConvention() );
282cdf0e10cSrcweir 
283cdf0e10cSrcweir         if ( SCA_VALID == (nResult & SCA_VALID) )
284cdf0e10cSrcweir         {
285cdf0e10cSrcweir             String* pStr    = NULL;
286cdf0e10cSrcweir             sal_Bool    bFound  = sal_False;
287cdf0e10cSrcweir             sal_uInt16  i       = 0;
288cdf0e10cSrcweir             sal_uInt16  nCount  = rLbCopyPos.GetEntryCount();
289cdf0e10cSrcweir 
290cdf0e10cSrcweir             for ( i=2; i<nCount && !bFound; i++ )
291cdf0e10cSrcweir             {
292cdf0e10cSrcweir                 pStr = (String*)rLbCopyPos.GetEntryData( i );
293cdf0e10cSrcweir                 bFound = (theCurPosStr == *pStr);
294cdf0e10cSrcweir             }
295cdf0e10cSrcweir 
296cdf0e10cSrcweir             if ( bFound )
297cdf0e10cSrcweir                 rLbCopyPos.SelectEntryPos( --i );
298cdf0e10cSrcweir             else
299cdf0e10cSrcweir                 rLbCopyPos.SelectEntryPos( 0 );
300cdf0e10cSrcweir         }
301cdf0e10cSrcweir         else
302cdf0e10cSrcweir             rLbCopyPos.SelectEntryPos( 0 );
303cdf0e10cSrcweir     }
304cdf0e10cSrcweir 
305cdf0e10cSrcweir     return 0;
306cdf0e10cSrcweir }
307cdf0e10cSrcweir 
308cdf0e10cSrcweir 
309cdf0e10cSrcweir //----------------------------------------------------------------------------
310cdf0e10cSrcweir 
IMPL_LINK(ScFilterOptionsMgr,BtnCopyResultHdl,CheckBox *,pBox)311cdf0e10cSrcweir IMPL_LINK( ScFilterOptionsMgr, BtnCopyResultHdl, CheckBox*, pBox )
312cdf0e10cSrcweir {
313cdf0e10cSrcweir     if ( pBox == &rBtnCopyResult )
314cdf0e10cSrcweir     {
315cdf0e10cSrcweir         if ( pBox->IsChecked() )
316cdf0e10cSrcweir         {
317cdf0e10cSrcweir             rBtnDestPers.Enable();
318cdf0e10cSrcweir             rLbCopyPos.Enable();
319cdf0e10cSrcweir             rEdCopyPos.Enable();
320cdf0e10cSrcweir             rRbCopyPos.Enable();
321cdf0e10cSrcweir             rEdCopyPos.GrabFocus();
322cdf0e10cSrcweir         }
323cdf0e10cSrcweir         else
324cdf0e10cSrcweir         {
325cdf0e10cSrcweir             rBtnDestPers.Disable();
326cdf0e10cSrcweir             rLbCopyPos.Disable();
327cdf0e10cSrcweir             rEdCopyPos.Disable();
328cdf0e10cSrcweir             rRbCopyPos.Disable();
329cdf0e10cSrcweir         }
330cdf0e10cSrcweir     }
331cdf0e10cSrcweir 
332cdf0e10cSrcweir     return 0;
333cdf0e10cSrcweir }
334