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
10b3f79822SAndrew Rist *
11b3f79822SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0
12b3f79822SAndrew Rist *
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.
19b3f79822SAndrew Rist *
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
177*22407013SOliver-Rainer Wittmann if ( pDBColl )
178*22407013SOliver-Rainer Wittmann {
179*22407013SOliver-Rainer Wittmann ScAddress& rStart = theCurArea.aStart;
180*22407013SOliver-Rainer Wittmann 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() );
183*22407013SOliver-Rainer Wittmann if ( pDBData )
184*22407013SOliver-Rainer Wittmann {
185*22407013SOliver-Rainer Wittmann rBtnHeader.Check( pDBData->HasHeader() );
186*22407013SOliver-Rainer Wittmann pDBData->GetName( theDbName );
187*22407013SOliver-Rainer Wittmann
188*22407013SOliver-Rainer Wittmann if ( !pDBData->IsInternalUnnamed()
189*22407013SOliver-Rainer Wittmann && !pDBData->IsInternalForAutoFilter() )
190*22407013SOliver-Rainer Wittmann {
191*22407013SOliver-Rainer Wittmann rBtnHeader.Disable();
192*22407013SOliver-Rainer Wittmann }
193*22407013SOliver-Rainer Wittmann }
194*22407013SOliver-Rainer Wittmann }
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